- 授权协议: MIT
- 开发语言: C/C++
- 操作系统: Windows
- 软件首页: https://github.com/Microsoft/DirectXMesh
- 软件文档: https://github.com/Microsoft/DirectXMesh
软件介绍
DirectXMesh 是微软开发的 DirectX 的几何处理库。
示例代码:
std::unique_ptr<WaveFrontReader<uint16_t>> mesh( new WaveFrontReader<uint16_t>() ); if ( FAILED( mesh->Load( L"test.obj" ) ) ) // Error if ( mesh->hasNormals ) // Skip next computation size_t nFaces = mesh->indices.size() / 3; size_t nVerts = mesh->vertices.size(); std::unique_ptr<XMFLOAT3[]> pos( new XMFLOAT3[ nVerts ] ); for( size_t j = 0; j < nVerts; ++j ) pos[ j ] = mesh->vertices[ j ].position; std::unique_ptr<XMFLOAT3[]> normals( new XMFLOAT3[ nVerts ] ); if ( FAILED( ComputeNormals( &mesh->indices.front(), nFaces, pos.get(), nVerts, CNORM_DEFAULT, normals.get() ) ) ) // Error if ( !mesh->hasTexcoords ) // Skip next computation std::unique_ptr<XMFLOAT2[]> texcoords( new XMFLOAT2[ nVerts ] ); for( size_t j = 0; j < nVerts; ++j ) texcoords[ j ] = mesh->vertices[ j ].textureCoordinate; std::unique_ptr<XMFLOAT3[]> tangents( new XMFLOAT3[ nVerts ] ); std::unique_ptr<XMFLOAT3[]> bitangents( new XMFLOAT3[ nVerts ] ); if ( FAILED( ComputeTangentFrame( &mesh->indices.front(), nFaces, pos.get(), normals.get(), texcoords.get(), nVerts, tangents.get(), bitangents.get() ) ) ) // Error
莱昂氏UNIX源代码分析
(澳)John Lions / 尤晋元 / 机械工业出版社 / 2000-7-1 / 49.00
本书由上、下两篇组成。上篇为UNIX版本6的源代码,下篇是莱昂先生对UNIX操作系统版本6源代码的详细分析。本书语言简洁、透彻,曾作为未公开出版物广泛流传了二十多年,是一部杰出经典之作。本书适合UNIX操作系统编程人员、大专院校师生学习参考使用。一起来看看 《莱昂氏UNIX源代码分析》 这本书的介绍吧!
