DirectXMesh 几何处理库开源项目

我要开发同款
匿名用户2015年04月20日
38阅读
开发技术C/C++
所属分类程序开发、图形/图像处理
授权协议MIT

作品详情

DirectXMesh是微软开发的DirectX的几何处理库。

示例代码:

std::unique_ptr<WaveFrontReader<uint16_t>> mesh( new WaveFrontReader<uint16_t>() );if ( FAILED( mesh->Load( L"test.obj" ) ) )  // Errorif ( mesh->hasNormals )   // Skip next computationsize_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() ) ) )  // Errorif ( !mesh->hasTexcoords )  // Skip next computationstd::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
声明:本文仅代表作者观点,不代表本站立场。如果侵犯到您的合法权益,请联系我们删除侵权资源!如果遇到资源链接失效,请您通过评论或工单的方式通知管理员。未经允许,不得转载,本站所有资源文章禁止商业使用运营!
下载安装【程序员客栈】APP
实时对接需求、及时收发消息、丰富的开放项目需求、随时随地查看项目状态

评论