aboutsummaryrefslogtreecommitdiffstatshomepage
path: root/linden/indra/newview/llviewerobject.h
diff options
context:
space:
mode:
authorJacek Antonelli2008-08-15 23:44:46 -0500
committerJacek Antonelli2008-08-15 23:44:46 -0500
commit38d6d37f2d982fa959e9e8a4a3f7e1ccfad7b5d4 (patch)
treeadca584755d22ca041a2dbfc35d4eca01f70b32c /linden/indra/newview/llviewerobject.h
parentREADME.txt (diff)
downloadmeta-impy-38d6d37f2d982fa959e9e8a4a3f7e1ccfad7b5d4.zip
meta-impy-38d6d37f2d982fa959e9e8a4a3f7e1ccfad7b5d4.tar.gz
meta-impy-38d6d37f2d982fa959e9e8a4a3f7e1ccfad7b5d4.tar.bz2
meta-impy-38d6d37f2d982fa959e9e8a4a3f7e1ccfad7b5d4.tar.xz
Second Life viewer sources 1.13.2.12
Diffstat (limited to '')
-rw-r--r--linden/indra/newview/llviewerobject.h645
1 files changed, 645 insertions, 0 deletions
diff --git a/linden/indra/newview/llviewerobject.h b/linden/indra/newview/llviewerobject.h
new file mode 100644
index 0000000..a439a01
--- /dev/null
+++ b/linden/indra/newview/llviewerobject.h
@@ -0,0 +1,645 @@
1/**
2 * @file llviewerobject.h
3 * @brief Description of LLViewerObject class, which is the base class for most objects in the viewer.
4 *
5 * Copyright (c) 2001-2007, Linden Research, Inc.
6 *
7 * The source code in this file ("Source Code") is provided by Linden Lab
8 * to you under the terms of the GNU General Public License, version 2.0
9 * ("GPL"), unless you have obtained a separate licensing agreement
10 * ("Other License"), formally executed by you and Linden Lab. Terms of
11 * the GPL can be found in doc/GPL-license.txt in this distribution, or
12 * online at http://secondlife.com/developers/opensource/gplv2
13 *
14 * There are special exceptions to the terms and conditions of the GPL as
15 * it is applied to this Source Code. View the full text of the exception
16 * in the file doc/FLOSS-exception.txt in this software distribution, or
17 * online at http://secondlife.com/developers/opensource/flossexception
18 *
19 * By copying, modifying or distributing this software, you acknowledge
20 * that you have read and understood your obligations described above,
21 * and agree to abide by those obligations.
22 *
23 * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO
24 * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY,
25 * COMPLETENESS OR PERFORMANCE.
26 */
27
28#ifndef LL_LLVIEWEROBJECT_H
29#define LL_LLVIEWEROBJECT_H
30
31#include <map>
32
33#include "linked_lists.h"
34#include "llassetstorage.h"
35#include "lldarrayptr.h"
36#include "llhudtext.h"
37#include "llhudicon.h"
38#include "llinventory.h"
39#include "llmemory.h"
40#include "llprimitive.h"
41#include "lluuid.h"
42#include "llvoinventorylistener.h"
43#include "object_flags.h"
44#include "llquaternion.h"
45#include "v3dmath.h"
46#include "v3math.h"
47
48class LLAgent; // TODO: Get rid of this.
49class LLAudioSource;
50class LLAudioSourceVO;
51class LLBBox;
52class LLDataPacker;
53class LLColor4;
54class LLFrameTimer;
55class LLDrawable;
56class LLHost;
57class LLWorld;
58class LLNameValue;
59class LLNetMap;
60class LLMessageSystem;
61class LLPrimitive;
62class LLPipeline;
63class LLTextureEntry;
64class LLViewerImage;
65class LLViewerInventoryItem;
66class LLViewerObject;
67class LLViewerPartSourceScript;
68class LLViewerRegion;
69class LLViewerObjectMedia;
70class LLVOInventoryListener;
71
72typedef enum e_object_update_type
73{
74 OUT_FULL,
75 OUT_TERSE_IMPROVED,
76 OUT_FULL_COMPRESSED,
77 OUT_FULL_CACHED,
78} EObjectUpdateType;
79
80
81// callback typedef for inventory
82typedef void (*inventory_callback)(LLViewerObject*,
83 InventoryObjectList*,
84 S32 serial_num,
85 void*);
86
87// a small struct for keeping track of joints
88struct LLVOJointInfo
89{
90 EHavokJointType mJointType;
91 LLVector3 mPivot; // parent-frame
92 // whether the below an axis or anchor (and thus its frame)
93 // depends on the joint type:
94 // HINGE ==> axis=parent-frame
95 // P2P ==> anchor=child-frame
96 LLVector3 mAxisOrAnchor;
97};
98
99// for exporting textured materials from SL
100struct LLMaterialExportInfo
101{
102public:
103 LLMaterialExportInfo(S32 mat_index, S32 texture_index, LLColor4 color) :
104 mMaterialIndex(mat_index), mTextureIndex(texture_index), mColor(color) {};
105
106 S32 mMaterialIndex;
107 S32 mTextureIndex;
108 LLColor4 mColor;
109};
110
111//============================================================================
112
113class LLViewerObject : public LLPrimitive, public LLRefCount
114{
115protected:
116 virtual ~LLViewerObject(); // use unref()
117
118 // TomY: Provide for a list of extra parameter structures, mapped by structure name
119 struct ExtraParameter
120 {
121 BOOL in_use;
122 LLNetworkData *data;
123 };
124 std::map<U16, ExtraParameter*> mExtraParameterList;
125
126public:
127 typedef std::vector<LLPointer<LLViewerObject> > child_list_t;
128
129 LLViewerObject(const LLUUID &id, const LLPCode type, LLViewerRegion *regionp);
130 MEM_TYPE_NEW(LLMemType::MTYPE_OBJECT);
131
132 virtual void markDead(); // Mark this object as dead, and clean up its references
133 BOOL isDead() const {return mDead;}
134 BOOL isOrphaned() const { return mOrphaned; }
135 BOOL isParticleSource() const;
136
137 static void initVOClasses();
138 static void cleanupVOClasses();
139
140 void addNVPair(const std::string& data);
141 BOOL removeNVPair(const char *name);
142 LLNameValue *getNVPair(const char *name) const; // null if no name value pair by that name
143
144 // Object create and update functions
145 virtual BOOL idleUpdate(LLAgent &agent, LLWorld &world, const F64 &time);
146
147 // Types of media we can associate
148 enum { MEDIA_TYPE_NONE = 0, MEDIA_TYPE_WEB_PAGE = 1 };
149
150 // Return codes for processUpdateMessage
151 enum { MEDIA_URL_REMOVED = 0x1, MEDIA_URL_ADDED = 0x2, MEDIA_URL_UPDATED = 0x4 };
152
153 enum { CLICK_ACTION_TOUCH = 0, CLICK_ACTION_SIT = 1, CLICK_ACTION_BUY = 2 };
154
155 virtual U32 processUpdateMessage(LLMessageSystem *mesgsys,
156 void **user_data,
157 U32 block_num,
158 const EObjectUpdateType update_type,
159 LLDataPacker *dp);
160
161
162 virtual BOOL isActive() const; // Whether this object needs to do an idleUpdate.
163 BOOL onActiveList() const {return mOnActiveList;}
164 void setOnActiveList(BOOL on_active) { mOnActiveList = on_active; }
165
166 virtual BOOL isAttachment() const { return FALSE; }
167 virtual BOOL isHUDAttachment() const { return FALSE; }
168 virtual void updateRadius() {};
169 virtual F32 getVObjRadius() const; // default implemenation is mDrawable->getRadius()
170
171 BOOL isJointChild() const { return mJointInfo ? TRUE : FALSE; }
172 EHavokJointType getJointType() const { return mJointInfo ? mJointInfo->mJointType : HJT_INVALID; }
173 // for jointed and other parent-relative hacks
174 LLViewerObject* getSubParent();
175 const LLViewerObject* getSubParent() const;
176
177 // Object visiblility and GPW functions
178 virtual void setPixelAreaAndAngle(LLAgent &agent); // Override to generate accurate apparent angle and area
179
180 virtual U32 getNumVertices() const;
181 virtual U32 getNumIndices() const;
182 S32 getNumFaces() const { return mNumFaces; }
183
184 // Graphical stuff for objects - maybe broken out into render class later?
185 virtual void updateTextures(LLAgent &agent);
186 virtual void boostTexturePriority(BOOL boost_children = TRUE); // When you just want to boost priority of this object
187
188 virtual LLDrawable* createDrawable(LLPipeline *pipeline);
189 virtual BOOL updateGeometry(LLDrawable *drawable);
190 virtual BOOL updateLOD();
191 virtual BOOL setDrawableParent(LLDrawable* parentp);
192 virtual BOOL updateLighting(BOOL do_lighting) { return TRUE; };
193 F32 getRotTime() { return mRotTime; }
194 void resetRot();
195 void applyAngularVelocity(F32 dt);
196
197 void setLineWidthForWindowSize(S32 window_width);
198
199 static void increaseArrowLength(); // makes axis arrows for selections longer
200 static void decreaseArrowLength(); // makes axis arrows for selections shorter
201
202 // Accessor functions
203 LLViewerRegion* getRegion() const { return mRegionp; }
204
205 BOOL isSelected() const { return mUserSelected; }
206 void setSelected(BOOL sel) { mUserSelected = sel; mRotTime = 0.f;}
207
208 const LLUUID &getID() const { return mID; }
209 U32 getLocalID() const { return mLocalID; }
210 U32 getCRC() const { return mTotalCRC; }
211
212 virtual BOOL isFlexible() const { return false; }
213
214 // This method returns true if the object is over land owned by
215 // the agent.
216 BOOL isOverAgentOwnedLand() const;
217
218 // True if over land owned by group of which the agent is
219 // either officer or member.
220 BOOL isOverGroupOwnedLand() const;
221
222 /*
223 // This method will scan through this object, and then query the
224 // selection manager to see if the local agent probably has the
225 // ability to modify the object. Since this calls into the
226 // selection manager, you should avoid calling this method from
227 // there.
228 BOOL isProbablyModifiable() const;
229 */
230
231 virtual void setParent(LLViewerObject* parent);
232 virtual void addChild(LLViewerObject *childp);
233 virtual void removeChild(LLViewerObject *childp);
234 child_list_t& getChildren();
235 void addThisAndAllChildren(LLDynamicArray<LLViewerObject*>& objects);
236 void addThisAndNonJointChildren(LLDynamicArray<LLViewerObject*>& objects);
237 BOOL isChild(LLViewerObject *childp) const;
238 BOOL isSeat() const;
239
240
241 //detect if given line segment (in agent space) intersects with this viewer object.
242 //returns TRUE if intersection detected and moves end to the point of intersection
243 //closest to start.
244 virtual BOOL lineSegmentIntersect(const LLVector3& start, LLVector3& end) const;
245
246 const LLVector3d getPositionGlobal() const;
247 const LLVector3 &getPositionRegion() const;
248 const LLVector3 getPositionEdit() const;
249 const LLVector3 &getPositionAgent() const;
250 const LLVector3 getRenderPosition() const;
251
252 virtual const LLVector3 getPivotPositionAgent() const; // Usually = to getPositionAgent, unless like flex objects it's not
253
254 LLViewerObject* getRootEdit() const;
255
256 const LLQuaternion getRotationRegion() const;
257 const LLQuaternion getRotationEdit() const;
258 const LLQuaternion getRenderRotation() const;
259 virtual const LLMatrix4 getRenderMatrix() const;
260
261 void setPosition(const LLVector3 &pos, BOOL damped = FALSE);
262 void setPositionGlobal(const LLVector3d &position, BOOL damped = FALSE);
263 void setPositionRegion(const LLVector3 &position, BOOL damped = FALSE);
264 void setPositionEdit(const LLVector3 &position, BOOL damped = FALSE);
265 void setPositionAgent(const LLVector3 &pos_agent, BOOL damped = FALSE);
266 void setPositionParent(const LLVector3 &pos_parent, BOOL damped = FALSE);
267 void setPositionAbsoluteGlobal( const LLVector3d &pos_global, BOOL damped = FALSE );
268 void sendPositionUpdate() const;
269
270 virtual const LLMatrix4& getWorldMatrix(LLXformMatrix* xform) const { return xform->getWorldMatrix(); }
271
272 inline void setRotation(const F32 x, const F32 y, const F32 z, BOOL damped = FALSE);
273 inline void setRotation(const LLQuaternion& quat, BOOL damped = FALSE);
274 void sendRotationUpdate() const;
275
276 /*virtual*/ void setNumTEs(const U8 num_tes);
277 /*virtual*/ void setTE(const U8 te, const LLTextureEntry &texture_entry);
278 /*virtual*/ S32 setTETexture(const U8 te, const LLUUID &uuid);
279 S32 setTETextureCore(const U8 te, const LLUUID& uuid, LLHost host);
280 /*virtual*/ S32 setTEColor(const U8 te, const LLColor4 &color);
281 /*virtual*/ S32 setTEScale(const U8 te, const F32 s, const F32 t);
282 /*virtual*/ S32 setTEScaleS(const U8 te, const F32 s);
283 /*virtual*/ S32 setTEScaleT(const U8 te, const F32 t);
284 /*virtual*/ S32 setTEOffset(const U8 te, const F32 s, const F32 t);
285 /*virtual*/ S32 setTEOffsetS(const U8 te, const F32 s);
286 /*virtual*/ S32 setTEOffsetT(const U8 te, const F32 t);
287 /*virtual*/ S32 setTERotation(const U8 te, const F32 r);
288 /*virtual*/ S32 setTEBumpmap(const U8 te, const U8 bump );
289 /*virtual*/ S32 setTETexGen(const U8 te, const U8 texgen );
290 /*virtual*/ S32 setTEShiny(const U8 te, const U8 shiny );
291 /*virtual*/ S32 setTEFullbright(const U8 te, const U8 fullbright );
292 /*virtual*/ S32 setTEMediaFlags(const U8 te, const U8 media_flags );
293 /*virtual*/ BOOL setMaterial(const U8 material);
294 virtual void setTEImage(const U8 te, LLViewerImage *imagep); // Not derived from LLPrimitive
295 LLViewerImage *getTEImage(const U8 te) const;
296
297 S32 getFaceIndexOffset() { return mFaceIndexOffset; }
298
299 void fitFaceTexture(const U8 face);
300 void sendTEUpdate() const; // Sends packed representation of all texture entry information
301
302 virtual void setScale(const LLVector3 &scale, BOOL damped = FALSE);
303 void sendScaleUpdate();
304
305 void sendShapeUpdate();
306
307 U8 getState() { return mState; }
308
309 F32 getAppAngle() const { return mAppAngle; }
310 F32 getMaxScale() const;
311 F32 getMidScale() const;
312 F32 getMinScale() const;
313
314 // Owner id is this object's owner
315 void setAttachedSound(const LLUUID &audio_uuid, const LLUUID& owner_id, const F32 gain, const U8 flags);
316 void adjustAudioGain(const F32 gain);
317 void clearAttachedSound() { mAudioSourcep = NULL; }
318
319 // Create if necessary
320 LLAudioSource *getAudioSource(const LLUUID& owner_id);
321
322 U8 getMediaType() const;
323 void setMediaType(U8 media_type);
324
325 const LLString& getMediaURL() const;
326 void setMediaURL(const LLString& media_url);
327
328 BOOL getMediaPassedWhitelist() const;
329 void setMediaPassedWhitelist(BOOL passed);
330
331 void sendMaterialUpdate() const;
332
333 void setCanSelect(BOOL canSelect);
334
335 void setDebugText(const std::string &utf8text);
336 void setIcon(LLViewerImage* icon_image);
337 void clearIcon();
338
339 void markForUpdate(BOOL priority);
340 void updateVolume(const LLVolumeParams& volume_params);
341 virtual void updateSpatialExtents(LLVector3& min, LLVector3& max);
342
343 LLBBox getBoundingBoxAgent() const;
344
345 void updatePositionCaches() const; // Update the global and region position caches from the object (and parent's) xform.
346 void updateText(); // update text label position
347 virtual void updateDrawable(BOOL force_damped); // force updates on static objects
348
349 void setDrawableState(U32 state, BOOL recursive = TRUE);
350 void clearDrawableState(U32 state, BOOL recursive = TRUE);
351
352 // Called when the drawable shifts
353 virtual void onShift(const LLVector3 &shift_vector) { }
354
355 //////////////////////////////////////
356 //
357 // Inventory methods
358 //
359
360 // This function is called when someone is interested in a viewer
361 // object's inventory. The callback is called as soon as the
362 // viewer object has the inventory stored locally.
363 void registerInventoryListener(LLVOInventoryListener* listener, void* user_data);
364 void removeInventoryListener(LLVOInventoryListener* listener);
365 BOOL isInventoryPending() { return mInventoryPending; }
366 void clearInventoryListeners();
367 void requestInventory();
368 static void processTaskInv(LLMessageSystem* msg, void** user_data);
369 void removeInventory(const LLUUID& item_id);
370
371 // The updateInventory() call potentially calls into the selection
372 // manager, so do no call updateInventory() from the selection
373 // manager until we have better iterators.
374 void updateInventory(LLViewerInventoryItem* item, U8 key, bool is_new);
375 LLInventoryObject* getInventoryObject(const LLUUID& item_id);
376 void getInventoryContents(InventoryObjectList& objects);
377 LLInventoryObject* getInventoryRoot();
378 LLViewerInventoryItem* getInventoryItemByAsset(const LLUUID& asset_id);
379 S16 getInventorySerial() const { return mInventorySerialNum; }
380
381 // This function will make sure that we refresh the inventory.
382 void dirtyInventory();
383 BOOL isInventoryDirty() { return mInventoryDirty; }
384
385 // save a script, which involves removing the old one, and rezzing
386 // in the new one. This method should be called with the asset id
387 // of the new and old script AFTER the bytecode has been saved.
388 void saveScript(const LLViewerInventoryItem* item, BOOL active, bool is_new);
389
390 // move an inventory item out of the task and into agent
391 // inventory. This operation is based on messaging. No permissions
392 // checks are made on the viewer - the server will double check.
393 void moveInventory(const LLUUID& agent_folder, const LLUUID& item_id);
394
395 // Find the number of instances of this object's inventory that are of the given type
396 S32 countInventoryContents( LLAssetType::EType type );
397
398 BOOL permAnyOwner() const;
399 BOOL permYouOwner() const;
400 BOOL permGroupOwner() const;
401 BOOL permOwnerModify() const;
402 BOOL permModify() const;
403 BOOL permCopy() const;
404 BOOL permMove() const;
405 BOOL permTransfer() const;
406 inline BOOL usePhysics() const { return ((mFlags & FLAGS_USE_PHYSICS) != 0); }
407 inline BOOL flagScripted() const { return ((mFlags & FLAGS_SCRIPTED) != 0); }
408 inline BOOL flagHandleTouch() const { return ((mFlags & FLAGS_HANDLE_TOUCH) != 0); }
409 inline BOOL flagTakesMoney() const { return ((mFlags & FLAGS_TAKES_MONEY) != 0); }
410 inline BOOL flagPhantom() const { return ((mFlags & FLAGS_PHANTOM) != 0); }
411 inline BOOL flagInventoryEmpty() const { return ((mFlags & FLAGS_INVENTORY_EMPTY) != 0); }
412 inline BOOL flagCastShadows() const { return ((mFlags & FLAGS_CAST_SHADOWS) != 0); }
413 inline BOOL flagAllowInventoryAdd() const { return ((mFlags & FLAGS_ALLOW_INVENTORY_DROP) != 0); }
414 inline BOOL flagTemporary() const { return ((mFlags & FLAGS_TEMPORARY) != 0); }
415 inline BOOL flagTemporaryOnRez() const { return ((mFlags & FLAGS_TEMPORARY_ON_REZ) != 0); }
416 inline BOOL flagAnimSource() const { return ((mFlags & FLAGS_ANIM_SOURCE) != 0); }
417 inline BOOL flagCameraSource() const { return ((mFlags & FLAGS_CAMERA_SOURCE) != 0); }
418 inline BOOL flagCameraDecoupled() const { return ((mFlags & FLAGS_CAMERA_DECOUPLED) != 0); }
419
420 // Does "open" object menu item apply?
421 BOOL allowOpen() const;
422
423 void setClickAction(U8 action) { mClickAction = action; }
424 U8 getClickAction() const { return mClickAction; }
425 bool specialHoverCursor() const; // does it have a special hover cursor?
426
427 void setRegion(LLViewerRegion *regionp);
428 virtual void updateRegion(LLViewerRegion *regionp) {}
429
430 void updateFlags();
431 BOOL setFlags(U32 flag, BOOL state);
432
433 virtual void dump() const;
434 static U32 getNumZombieObjects() { return sNumZombieObjects; }
435
436 void printNameValuePairs() const;
437
438 virtual S32 getLOD() const { return 3; }
439
440 virtual LLNetworkData* getParameterEntry(U16 param_type) const;
441 virtual bool setParameterEntry(U16 param_type, const LLNetworkData& new_value, bool local_origin);
442 virtual BOOL getParameterEntryInUse(U16 param_type) const;
443 virtual bool setParameterEntryInUse(U16 param_type, BOOL in_use, bool local_origin);
444 // Called when a parameter is changed
445 virtual void parameterChanged(U16 param_type, bool local_origin);
446 virtual void parameterChanged(U16 param_type, LLNetworkData* data, BOOL in_use, bool local_origin);
447
448 friend class LLViewerObjectList;
449 friend class LLViewerMediaList;
450
451private:
452 ExtraParameter* createNewParameterEntry(U16 param_type);
453 ExtraParameter* getExtraParameterEntry(U16 param_type) const;
454 ExtraParameter* getExtraParameterEntryCreate(U16 param_type);
455 bool unpackParameterEntry(U16 param_type, LLDataPacker *dp);
456
457public:
458 //
459 // Viewer-side only types - use the LL_PCODE_APP mask.
460 //
461 typedef enum e_vo_types
462 {
463 LL_VO_CLOUDS = LL_PCODE_APP | 0x20,
464 LL_VO_SURFACE_PATCH = LL_PCODE_APP | 0x30,
465 LL_VO_STARS = LL_PCODE_APP | 0x40,
466 LL_VO_SQUARE_TORUS = LL_PCODE_APP | 0x50,
467 LL_VO_SKY = LL_PCODE_APP | 0x60,
468 LL_VO_WATER = LL_PCODE_APP | 0x70,
469 LL_VO_GROUND = LL_PCODE_APP | 0x80,
470 LL_VO_PART_GROUP = LL_PCODE_APP | 0x90,
471 LL_VO_TRIANGLE_TORUS = LL_PCODE_APP | 0xa0,
472 } EVOType;
473
474 child_list_t mChildList;
475 LLUUID mID;
476
477 // unique within region, not unique across regions
478 // Local ID = 0 is not used
479 U32 mLocalID;
480
481 // Last total CRC received from sim, used for caching
482 U32 mTotalCRC;
483
484 LLPointer<LLViewerImage> *mTEImages;
485
486 // Selection, picking and rendering variables
487 U32 mGLName; // GL "name" used by selection code
488 BOOL mbCanSelect; // true if user can select this object by clicking
489
490 // Grabbed from UPDATE_FLAGS
491 U32 mFlags;
492
493 // Pipeline classes
494 LLPointer<LLDrawable> mDrawable;
495
496 // Band-aid to select object after all creation initialization is done
497 BOOL mCreateSelected;
498
499 // Replace textures with web pages on this object while drawing
500 BOOL mRenderMedia;
501
502 // In bits
503 S32 mBestUpdatePrecision;
504
505 // TODO: Make all this stuff private. JC
506 LLPointer<LLHUDText> mText;
507 LLPointer<LLHUDIcon> mIcon;
508
509 static BOOL sUseSharedDrawables;
510
511protected:
512 // delete an item in the inventory, but don't tell the
513 // server. This is used internally by remove, update, and
514 // savescript.
515 void deleteInventoryItem(const LLUUID& item_id);
516
517 // do the update/caching logic. called by saveScript and
518 // updateInventory.
519 void doUpdateInventory(LLViewerInventoryItem* item, U8 key, bool is_new);
520
521
522 static LLViewerObject *createObject(const LLUUID &id, LLPCode pcode, LLViewerRegion *regionp);
523
524 BOOL setData(const U8 *datap, const U32 data_size);
525
526 //////////////////////////
527 //
528 // inventory functionality
529 //
530
531 static void processTaskInvFile(void** user_data, S32 error_code);
532 void loadTaskInvFile(const char* filename);
533 void doInventoryCallback();
534
535 BOOL isOnMap();
536
537 void unpackParticleSource(const S32 block_num, const LLUUID& owner_id);
538 void unpackParticleSource(LLDataPacker &dp, const LLUUID& owner_id);
539
540private:
541 void setNameValueList(const std::string& list); // clears nv pairs and then individually adds \n separated NV pairs from \0 terminated string
542 void deleteTEImages(); // correctly deletes list of images
543
544protected:
545 typedef std::map<char *, LLNameValue *> name_value_map_t;
546 name_value_map_t mNameValuePairs; // Any name-value pairs stored by script
547
548 F64 mLastInterpUpdateSecs; // Last update for purposes of interpolation
549 F64 mLastMessageUpdateSecs; // Last update from a message from the simulator
550
551 // extra data sent from the sim...currently only used for tree species info
552 U8* mData;
553
554 LLPointer<LLViewerPartSourceScript> mPartSourcep; // Particle source associated with this object.
555 LLAudioSourceVO *mAudioSourcep;
556
557 F32 mAppAngle; // Apparent visual arc in degrees
558 F32 mPixelArea; // Apparent area in pixels
559
560 // This is the object's inventory from the viewer's perspective.
561 InventoryObjectList* mInventory;
562 class LLInventoryCallbackInfo
563 {
564 public:
565 ~LLInventoryCallbackInfo();
566 LLVOInventoryListener* mListener;
567 void* mInventoryData;
568 };
569 LLLinkedList<LLInventoryCallbackInfo> mInventoryCallbacks;
570 S16 mInventorySerialNum;
571
572 LLViewerRegion *mRegionp; // Region that this object belongs to.
573 BOOL mInventoryPending;
574 BOOL mInventoryDirty;
575 BOOL mDead;
576 BOOL mOrphaned; // This is an orphaned child
577 BOOL mUserSelected; // Cached user select information
578 BOOL mOnActiveList;
579 BOOL mOnMap; // On the map.
580 BOOL mStatic; // Object doesn't move.
581 S32 mFaceIndexOffset; // offset into drawable's faces, zero except in special cases
582 S32 mNumFaces;
583
584 S32 mLastUpdateFrame; // frames in which an object had last moved for smart coalescing of drawables
585 // (child objects not moving relative to parent)
586
587 F32 mTimeDilation; // Time dilation sent with the object.
588 F32 mRotTime; // Amount (in seconds) that object has rotated according to angular velocity (llSetTargetOmega)
589 LLQuaternion mLastRot; // last rotation received from the simulator
590
591 LLVOJointInfo* mJointInfo;
592 U8 mState; // legacy
593 LLViewerObjectMedia* mMedia; // NULL if no media associated
594 U8 mClickAction;
595
596 static U32 sNumZombieObjects; // Objects which are dead, but not deleted
597
598 static BOOL sMapDebug; // Map render mode
599 static LLColor4 sEditSelectColor;
600 static LLColor4 sNoEditSelectColor;
601 static F32 sCurrentPulse;
602 static BOOL sPulseEnabled;
603
604 static S32 sAxisArrowLength;
605
606 // These two caches are only correct for non-parented objects right now!
607 mutable LLVector3 mPositionRegion;
608 mutable LLVector3 mPositionAgent;
609
610private:
611 static S32 sNumObjects;
612};
613
614
615///////////////////
616//
617// Inlines
618//
619//
620
621inline void LLViewerObject::setRotation(const LLQuaternion& quat, BOOL damped)
622{
623 LLPrimitive::setRotation(quat);
624 setChanged(ROTATED | SILHOUETTE);
625 updateDrawable(damped);
626}
627
628inline void LLViewerObject::setRotation(const F32 x, const F32 y, const F32 z, BOOL damped)
629{
630 LLPrimitive::setRotation(x, y, z);
631 setChanged(ROTATED | SILHOUETTE);
632 updateDrawable(damped);
633}
634
635class LLViewerObjectMedia
636{
637public:
638 LLViewerObjectMedia() : mMediaURL(), mPassedWhitelist(FALSE), mMediaType(0) { }
639
640 LLString mMediaURL; // for web pages on surfaces, one per prim
641 BOOL mPassedWhitelist; // user has OK'd display
642 U8 mMediaType; // see LLTextureEntry::WEB_PAGE, etc.
643};
644
645#endif