aboutsummaryrefslogtreecommitdiffstatshomepage
path: root/linden/indra/newview/llvovolume.cpp
diff options
context:
space:
mode:
Diffstat (limited to 'linden/indra/newview/llvovolume.cpp')
-rw-r--r--linden/indra/newview/llvovolume.cpp20
1 files changed, 16 insertions, 4 deletions
diff --git a/linden/indra/newview/llvovolume.cpp b/linden/indra/newview/llvovolume.cpp
index 494e0fa..e4318ff 100644
--- a/linden/indra/newview/llvovolume.cpp
+++ b/linden/indra/newview/llvovolume.cpp
@@ -1124,30 +1124,36 @@ BOOL LLVOVolume::updateGeometry(LLDrawable *drawable)
1124 } 1124 }
1125 else if ((mLODChanged) || (mSculptChanged)) 1125 else if ((mLODChanged) || (mSculptChanged))
1126 { 1126 {
1127 LLPointer<LLVolume> old_volumep, new_volumep; 1127 LLVolume *old_volumep, *new_volumep;
1128 F32 old_lod, new_lod; 1128 F32 old_lod, new_lod;
1129 S32 old_num_faces, new_num_faces ;
1129 1130
1130 old_volumep = getVolume(); 1131 old_volumep = getVolume();
1131 old_lod = old_volumep->getDetail(); 1132 old_lod = old_volumep->getDetail();
1133 old_num_faces = old_volumep->getNumFaces() ;
1134 old_volumep = NULL ;
1132 1135
1133 { 1136 {
1134 LLFastTimer ftm(LLFastTimer::FTM_GEN_VOLUME); 1137 LLFastTimer ftm(LLFastTimer::FTM_GEN_VOLUME);
1135 LLVolumeParams volume_params = getVolume()->getParams(); 1138 LLVolumeParams volume_params = getVolume()->getParams();
1136 setVolume(volume_params, 0); 1139 setVolume(volume_params, 0);
1137 } 1140 }
1141
1138 new_volumep = getVolume(); 1142 new_volumep = getVolume();
1139 new_lod = new_volumep->getDetail(); 1143 new_lod = new_volumep->getDetail();
1144 new_num_faces = new_volumep->getNumFaces() ;
1145 new_volumep = NULL ;
1140 1146
1141 if ((new_lod != old_lod) || mSculptChanged) 1147 if ((new_lod != old_lod) || mSculptChanged)
1142 { 1148 {
1143 compiled = TRUE; 1149 compiled = TRUE;
1144 sNumLODChanges += getVolume()->getNumFaces(); 1150 sNumLODChanges += new_num_faces ;
1145 1151
1146 drawable->setState(LLDrawable::REBUILD_VOLUME); // for face->genVolumeTriangles() 1152 drawable->setState(LLDrawable::REBUILD_VOLUME); // for face->genVolumeTriangles()
1147 1153
1148 { 1154 {
1149 LLFastTimer t(LLFastTimer::FTM_GEN_TRIANGLES); 1155 LLFastTimer t(LLFastTimer::FTM_GEN_TRIANGLES);
1150 if (new_volumep->getNumFaces() != old_volumep->getNumFaces()) 1156 if (new_num_faces != old_num_faces)
1151 { 1157 {
1152 regenFaces(); 1158 regenFaces();
1153 } 1159 }
@@ -1225,7 +1231,12 @@ S32 LLVOVolume::setTETexture(const U8 te, const LLUUID &uuid)
1225 return res; 1231 return res;
1226} 1232}
1227 1233
1228S32 LLVOVolume::setTEColor(const U8 te, const LLColor4 &color) 1234S32 LLVOVolume::setTEColor(const U8 te, const LLColor3& color)
1235{
1236 return setTEColor(te, LLColor4(color));
1237}
1238
1239S32 LLVOVolume::setTEColor(const U8 te, const LLColor4& color)
1229{ 1240{
1230 S32 res = LLViewerObject::setTEColor(te, color); 1241 S32 res = LLViewerObject::setTEColor(te, color);
1231 if (res) 1242 if (res)
@@ -2458,6 +2469,7 @@ void LLVolumeGeometryManager::rebuildGeom(LLSpatialGroup* group)
2458 if (facep->mGeomCount + index_offset > 65535) 2469 if (facep->mGeomCount + index_offset > 65535)
2459 { //cut off alpha nodes at 64k vertices 2470 { //cut off alpha nodes at 64k vertices
2460 facep->mVertexBuffer = NULL ; 2471 facep->mVertexBuffer = NULL ;
2472 facep->mLastVertexBuffer = NULL ;
2461 continue ; 2473 continue ;
2462 } 2474 }
2463 2475