diff options
Diffstat (limited to 'linden/indra/newview/lldrawable.h')
-rw-r--r-- | linden/indra/newview/lldrawable.h | 36 |
1 files changed, 24 insertions, 12 deletions
diff --git a/linden/indra/newview/lldrawable.h b/linden/indra/newview/lldrawable.h index 062427e..6ff4d1e 100644 --- a/linden/indra/newview/lldrawable.h +++ b/linden/indra/newview/lldrawable.h | |||
@@ -38,8 +38,8 @@ | |||
38 | #include "v4coloru.h" | 38 | #include "v4coloru.h" |
39 | #include "llquaternion.h" | 39 | #include "llquaternion.h" |
40 | #include "xform.h" | 40 | #include "xform.h" |
41 | #include "llmemtype.h" | ||
41 | #include "llprimitive.h" | 42 | #include "llprimitive.h" |
42 | #include "llviewerimage.h" | ||
43 | #include "lldarray.h" | 43 | #include "lldarray.h" |
44 | #include "llstat.h" | 44 | #include "llstat.h" |
45 | #include "llviewerobject.h" | 45 | #include "llviewerobject.h" |
@@ -52,6 +52,7 @@ class LLSpatialGroup; | |||
52 | class LLSpatialBridge; | 52 | class LLSpatialBridge; |
53 | class LLSpatialPartition; | 53 | class LLSpatialPartition; |
54 | class LLVOVolume; | 54 | class LLVOVolume; |
55 | class LLViewerImage; | ||
55 | 56 | ||
56 | extern F32 gFrameTimeSeconds; | 57 | extern F32 gFrameTimeSeconds; |
57 | 58 | ||
@@ -74,7 +75,7 @@ public: | |||
74 | 75 | ||
75 | BOOL isLight() const; | 76 | BOOL isLight() const; |
76 | 77 | ||
77 | BOOL isVisible() const { return (mVisible == sCurVisible); } | 78 | BOOL isVisible() const; |
78 | virtual void setVisible(LLCamera& camera_in, std::vector<LLDrawable*>* results = NULL, BOOL for_select = FALSE); | 79 | virtual void setVisible(LLCamera& camera_in, std::vector<LLDrawable*>* results = NULL, BOOL for_select = FALSE); |
79 | 80 | ||
80 | 81 | ||
@@ -121,10 +122,11 @@ public: | |||
121 | inline S32 getNumFaces() const; | 122 | inline S32 getNumFaces() const; |
122 | 123 | ||
123 | //void removeFace(const S32 i); // SJB: Avoid using this, it's slow | 124 | //void removeFace(const S32 i); // SJB: Avoid using this, it's slow |
124 | LLFace* addFace(LLDrawPool *poolp, LLViewerImage *texturep, const BOOL shared_geom = FALSE); | 125 | LLFace* addFace(LLFacePool *poolp, LLViewerImage *texturep); |
126 | LLFace* addFace(const LLTextureEntry *te, LLViewerImage *texturep); | ||
125 | void deleteFaces(S32 offset, S32 count); | 127 | void deleteFaces(S32 offset, S32 count); |
126 | void setNumFaces(const S32 numFaces, LLDrawPool *poolp, LLViewerImage *texturep); | 128 | void setNumFaces(const S32 numFaces, LLFacePool *poolp, LLViewerImage *texturep); |
127 | void setNumFacesFast(const S32 numFaces, LLDrawPool *poolp, LLViewerImage *texturep); | 129 | void setNumFacesFast(const S32 numFaces, LLFacePool *poolp, LLViewerImage *texturep); |
128 | void mergeFaces(LLDrawable* src); | 130 | void mergeFaces(LLDrawable* src); |
129 | 131 | ||
130 | void init(); | 132 | void init(); |
@@ -138,6 +140,8 @@ public: | |||
138 | 140 | ||
139 | BOOL isActive() const { return isState(ACTIVE); } | 141 | BOOL isActive() const { return isState(ACTIVE); } |
140 | BOOL isStatic() const { return !isActive(); } | 142 | BOOL isStatic() const { return !isActive(); } |
143 | BOOL isAnimating() const; | ||
144 | |||
141 | virtual BOOL updateMove(); | 145 | virtual BOOL updateMove(); |
142 | virtual void movePartition(); | 146 | virtual void movePartition(); |
143 | 147 | ||
@@ -146,6 +150,7 @@ public: | |||
146 | virtual void updateDistance(LLCamera& camera); | 150 | virtual void updateDistance(LLCamera& camera); |
147 | BOOL updateGeometry(BOOL priority); | 151 | BOOL updateGeometry(BOOL priority); |
148 | BOOL updateLighting(BOOL priority); | 152 | BOOL updateLighting(BOOL priority); |
153 | void updateFaceSize(S32 idx); | ||
149 | void updateLightSet(); | 154 | void updateLightSet(); |
150 | 155 | ||
151 | F32 getSunShadowFactor() const { return mSunShadowFactor; } | 156 | F32 getSunShadowFactor() const { return mSunShadowFactor; } |
@@ -195,6 +200,7 @@ public: | |||
195 | protected: | 200 | protected: |
196 | virtual ~LLDrawable() { destroy(); } | 201 | virtual ~LLDrawable() { destroy(); } |
197 | void moveUpdatePipeline(BOOL moved); | 202 | void moveUpdatePipeline(BOOL moved); |
203 | void updatePartition(); | ||
198 | BOOL updateMoveDamped(); | 204 | BOOL updateMoveDamped(); |
199 | BOOL updateMoveUndamped(); | 205 | BOOL updateMoveUndamped(); |
200 | 206 | ||
@@ -206,6 +212,7 @@ public: | |||
206 | typedef std::set<LLPointer<LLDrawable> > drawable_set_t; | 212 | typedef std::set<LLPointer<LLDrawable> > drawable_set_t; |
207 | typedef std::vector<LLPointer<LLDrawable> > drawable_vector_t; | 213 | typedef std::vector<LLPointer<LLDrawable> > drawable_vector_t; |
208 | typedef std::list<LLPointer<LLDrawable> > drawable_list_t; | 214 | typedef std::list<LLPointer<LLDrawable> > drawable_list_t; |
215 | typedef std::queue<LLPointer<LLDrawable> > drawable_queue_t; | ||
209 | 216 | ||
210 | struct CompareDistanceGreater | 217 | struct CompareDistanceGreater |
211 | { | 218 | { |
@@ -246,11 +253,14 @@ public: | |||
246 | UNLIT = 0x00000200, | 253 | UNLIT = 0x00000200, |
247 | LIGHT = 0x00000400, | 254 | LIGHT = 0x00000400, |
248 | LIGHTING_BUILT = 0x00000800, | 255 | LIGHTING_BUILT = 0x00000800, |
249 | REBUILD_VOLUME = 0x00001000, | 256 | REBUILD_VOLUME = 0x00001000, //volume changed LOD or parameters, or vertex buffer changed |
250 | REBUILD_TCOORD = 0x00002000, | 257 | REBUILD_TCOORD = 0x00002000, //texture coordinates changed |
251 | REBUILD_GEOMETRY= REBUILD_VOLUME|REBUILD_TCOORD, | 258 | REBUILD_COLOR = 0x00004000, //color changed |
252 | REBUILD_LIGHTING= 0x00008000, | 259 | REBUILD_LIGHTING= 0x00008000, //lighting information changed |
253 | REBUILD_ALL = REBUILD_GEOMETRY|REBUILD_LIGHTING, | 260 | REBUILD_POSITION= 0x00010000, //vertex positions/normals changed |
261 | REBUILD_GEOMETRY= REBUILD_POSITION|REBUILD_TCOORD|REBUILD_COLOR, | ||
262 | REBUILD_MATERIAL= REBUILD_TCOORD|REBUILD_COLOR, | ||
263 | REBUILD_ALL = REBUILD_GEOMETRY|REBUILD_LIGHTING|REBUILD_VOLUME, | ||
254 | ON_SHIFT_LIST = 0x00100000, | 264 | ON_SHIFT_LIST = 0x00100000, |
255 | // NO_INTERP_COLOR = 0x00200000, | 265 | // NO_INTERP_COLOR = 0x00200000, |
256 | BLOCKER = 0x00400000, | 266 | BLOCKER = 0x00400000, |
@@ -285,6 +295,8 @@ public: | |||
285 | void setSpatialBridge(LLSpatialBridge* bridge) { mSpatialBridge = (LLDrawable*) bridge; } | 295 | void setSpatialBridge(LLSpatialBridge* bridge) { mSpatialBridge = (LLDrawable*) bridge; } |
286 | LLSpatialBridge* getSpatialBridge() { return (LLSpatialBridge*) (LLDrawable*) mSpatialBridge; } | 296 | LLSpatialBridge* getSpatialBridge() { return (LLSpatialBridge*) (LLDrawable*) mSpatialBridge; } |
287 | 297 | ||
298 | static F32 sCurPixelAngle; //current pixels per radian | ||
299 | |||
288 | protected: | 300 | protected: |
289 | typedef std::vector<LLFace*> face_list_t; | 301 | typedef std::vector<LLFace*> face_list_t; |
290 | 302 | ||
@@ -296,7 +308,7 @@ protected: | |||
296 | LLPointer<LLDrawable> mSpatialBridge; | 308 | LLPointer<LLDrawable> mSpatialBridge; |
297 | S32 mSpatialGroupOffset; | 309 | S32 mSpatialGroupOffset; |
298 | 310 | ||
299 | U32 mVisible; | 311 | mutable U32 mVisible; |
300 | F32 mRadius; | 312 | F32 mRadius; |
301 | LLVector3 mExtents[2]; | 313 | LLVector3 mExtents[2]; |
302 | LLVector3d mPositionGroup; | 314 | LLVector3d mPositionGroup; |
@@ -308,7 +320,6 @@ protected: | |||
308 | LLVector3 mCurrentScale; | 320 | LLVector3 mCurrentScale; |
309 | 321 | ||
310 | static U32 sCurVisible; // Counter for what value of mVisible means currently visible | 322 | static U32 sCurVisible; // Counter for what value of mVisible means currently visible |
311 | static F32 sCurPixelAngle; //current pixels per radian | ||
312 | 323 | ||
313 | static U32 sNumZombieDrawables; | 324 | static U32 sNumZombieDrawables; |
314 | static LLDynamicArrayPtr<LLPointer<LLDrawable> > sDeadList; | 325 | static LLDynamicArrayPtr<LLPointer<LLDrawable> > sDeadList; |
@@ -318,6 +329,7 @@ protected: | |||
318 | inline LLFace* LLDrawable::getFace(const S32 i) const | 329 | inline LLFace* LLDrawable::getFace(const S32 i) const |
319 | { | 330 | { |
320 | llassert((U32)i < mFaces.size()); | 331 | llassert((U32)i < mFaces.size()); |
332 | llassert(mFaces[i]); | ||
321 | return mFaces[i]; | 333 | return mFaces[i]; |
322 | } | 334 | } |
323 | 335 | ||