本文整理汇总了C++中Geometry::BuildGeometry方法的典型用法代码示例。如果您正苦于以下问题:C++ Geometry::BuildGeometry方法的具体用法?C++ Geometry::BuildGeometry怎么用?C++ Geometry::BuildGeometry使用的例子?那么, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在类Geometry
的用法示例。
在下文中一共展示了Geometry::BuildGeometry方法的1个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的C++代码示例。
示例1: Parse
bool OBJParser::Parse(const wchar_t* filePath, Model** result)
{
bool isSucceed = false;
{
Assert(NULL != filePath);
Assert(NULL != result);
Assert(*result == NULL);
YString::Copy(mFilePath, _countof(mFilePath), filePath);
PerformanceTimer::Begin(L"parsing OBJ file");
clear();
YFile* file = YFile::Open(filePath, YFile::READ);
Assert(NULL != file);
wchar_t lineContent[MAX_STR_LEN];
while(file->ReadLine(lineContent, MAX_STR_LEN) != NULL)
{
if(parseLine(file, lineContent))
break;
}
file->Close();
PerformanceTimer::End();
PerformanceTimer::Begin(L"building result model geometry");
// 为获取得到的geo数据计算tbn并创建vb,ib
for(size_t i = 0; i < mGeoList.size(); ++i)
{
Geometry* geo = mGeoList[i];
if(((mDataContentType & UV_DATA) == 0))
{
geo->CalculateNormals();
geo->BuildGeometry(XYZ_N);
}
else
{
geo->CalculateTBN();
geo->BuildGeometry(XYZ_UV_TBN);
}
geo->SaveToFile(L"Assets/Geometries");
gEngine->GetGeometryManager()->AddGeometry(geo);
}
PerformanceTimer::End();
*result = mResultModel;
clear();
}
isSucceed = true;
Exit:
return isSucceed;
}