📄 submodel.cpp
字号:
#include "bspconv.h"
#include "bspbrush.h"
_CBSPLeafNode *CreateSubmodel(CMapEntity* entity) {
CVector<CMapBrush> *brushes = entity->GetBrushes();
if (!brushes->GetNum()) {
return 0;
}
_CBSPLeafNode *leaf = new _CBSPLeafNode;
leaf->brushes.TailAlloc(brushes->GetNum());
leaf->min = vec4( WORLD_SIZE, WORLD_SIZE, WORLD_SIZE);
leaf->max = vec4(-WORLD_SIZE, -WORLD_SIZE, -WORLD_SIZE);
for(int i=0; i<brushes->GetNum(); i++) {
leaf->brushes[i] = new _CBSPBrush;
_CBSPBrush *brush = leaf->brushes[i];
brush->BuildBrush( &brushes->GetElemNoBCheck(i) );
leaf->faces.Append( brush->faces );
for(int i=0; i<brush->faces.GetNum(); i++) {
CAlignedVec<vec4> *p = brush->faces[i]->winding.GetPoints();
for(int j=0; j<p->GetNum(); j++) {
leaf->min.minSelf( p->GetElemNoBCheck(j) );
leaf->max.maxSelf( p->GetElemNoBCheck(j) );
}
}
}
g_CLog.Log(LOG_SYSTEM, "%4d faces on submodel.", leaf->faces.GetNum());
return leaf;
}
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -