当前位置: 首页>>代码示例>>C++>>正文


C++ Geometry::BuildGeometry方法代码示例

本文整理汇总了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;
}
开发者ID:SinYocto,项目名称:Zee,代码行数:63,代码来源:OBJParser.cpp


注:本文中的Geometry::BuildGeometry方法示例由纯净天空整理自Github/MSDocs等开源代码及文档管理平台,相关代码片段筛选自各路编程大神贡献的开源项目,源码版权归原作者所有,传播和使用请参考对应项目的License;未经允许,请勿转载。