aboutsummaryrefslogtreecommitdiffstatshomepage
path: root/linden/indra/newview/llviewerobject.cpp
diff options
context:
space:
mode:
Diffstat (limited to '')
-rw-r--r--linden/indra/newview/llviewerobject.cpp84
1 files changed, 55 insertions, 29 deletions
diff --git a/linden/indra/newview/llviewerobject.cpp b/linden/indra/newview/llviewerobject.cpp
index cb3afc5..b33b2bb 100644
--- a/linden/indra/newview/llviewerobject.cpp
+++ b/linden/indra/newview/llviewerobject.cpp
@@ -4,7 +4,7 @@
4 * 4 *
5 * $LicenseInfo:firstyear=2001&license=viewergpl$ 5 * $LicenseInfo:firstyear=2001&license=viewergpl$
6 * 6 *
7 * Copyright (c) 2001-2008, Linden Research, Inc. 7 * Copyright (c) 2001-2009, Linden Research, Inc.
8 * 8 *
9 * Second Life Viewer Source Code 9 * Second Life Viewer Source Code
10 * The source code in this file ("Source Code") is provided by Linden Lab 10 * The source code in this file ("Source Code") is provided by Linden Lab
@@ -150,6 +150,8 @@ LLViewerObject *LLViewerObject::createObject(const LLUUID &id, const LLPCode pco
150 res = new LLVOGround(id, pcode, regionp); break; 150 res = new LLVOGround(id, pcode, regionp); break;
151 case LL_VO_PART_GROUP: 151 case LL_VO_PART_GROUP:
152 res = new LLVOPartGroup(id, pcode, regionp); break; 152 res = new LLVOPartGroup(id, pcode, regionp); break;
153 case LL_VO_HUD_PART_GROUP:
154 res = new LLVOHUDPartGroup(id, pcode, regionp); break;
153 case LL_VO_WL_SKY: 155 case LL_VO_WL_SKY:
154 res = new LLVOWLSky(id, pcode, regionp); break; 156 res = new LLVOWLSky(id, pcode, regionp); break;
155 default: 157 default:
@@ -159,7 +161,7 @@ LLViewerObject *LLViewerObject::createObject(const LLUUID &id, const LLPCode pco
159 return res; 161 return res;
160} 162}
161 163
162LLViewerObject::LLViewerObject(const LLUUID &id, const LLPCode pcode, LLViewerRegion *regionp) 164LLViewerObject::LLViewerObject(const LLUUID &id, const LLPCode pcode, LLViewerRegion *regionp, BOOL is_global)
163: LLPrimitive(), 165: LLPrimitive(),
164 mChildList(), 166 mChildList(),
165 mID(id), 167 mID(id),
@@ -201,7 +203,10 @@ LLViewerObject::LLViewerObject(const LLUUID &id, const LLPCode pcode, LLViewerRe
201 mMedia(NULL), 203 mMedia(NULL),
202 mClickAction(0) 204 mClickAction(0)
203{ 205{
204 llassert(mRegionp); 206 if(!is_global)
207 {
208 llassert(mRegionp);
209 }
205 210
206 LLPrimitive::init_primitive(pcode); 211 LLPrimitive::init_primitive(pcode);
207 212
@@ -209,7 +214,11 @@ LLViewerObject::LLViewerObject(const LLUUID &id, const LLPCode pcode, LLViewerRe
209 mLastInterpUpdateSecs = LLFrameTimer::getElapsedSeconds(); 214 mLastInterpUpdateSecs = LLFrameTimer::getElapsedSeconds();
210 215
211 mPositionRegion = LLVector3(0.f, 0.f, 0.f); 216 mPositionRegion = LLVector3(0.f, 0.f, 0.f);
212 mPositionAgent = mRegionp->getOriginAgent(); 217
218 if(!is_global)
219 {
220 mPositionAgent = mRegionp->getOriginAgent();
221 }
213 222
214 LLViewerObject::sNumObjects++; 223 LLViewerObject::sNumObjects++;
215} 224}
@@ -2763,12 +2772,6 @@ void LLViewerObject::setPixelAreaAndAngle(LLAgent &agent)
2763 2772
2764BOOL LLViewerObject::updateLOD() 2773BOOL LLViewerObject::updateLOD()
2765{ 2774{
2766 // Update volume of looping sounds
2767 if (mAudioSourcep && mAudioSourcep->isLoop())
2768 {
2769 F32 volume = mAudioGain * gSavedSettings.getF32("AudioLevelSFX");
2770 mAudioSourcep->setGain(volume);
2771 }
2772 return FALSE; 2775 return FALSE;
2773} 2776}
2774 2777
@@ -3055,28 +3058,38 @@ LLNameValue *LLViewerObject::getNVPair(const std::string& name) const
3055 3058
3056void LLViewerObject::updatePositionCaches() const 3059void LLViewerObject::updatePositionCaches() const
3057{ 3060{
3058 if (!isRoot()) 3061 if(mRegionp)
3059 {
3060 mPositionRegion = ((LLViewerObject *)getParent())->getPositionRegion() + getPosition() * getParent()->getRotation();
3061 mPositionAgent = mRegionp->getPosAgentFromRegion(mPositionRegion);
3062 }
3063 else
3064 { 3062 {
3065 mPositionRegion = getPosition(); 3063 if (!isRoot())
3066 mPositionAgent = mRegionp->getPosAgentFromRegion(mPositionRegion); 3064 {
3065 mPositionRegion = ((LLViewerObject *)getParent())->getPositionRegion() + getPosition() * getParent()->getRotation();
3066 mPositionAgent = mRegionp->getPosAgentFromRegion(mPositionRegion);
3067 }
3068 else
3069 {
3070 mPositionRegion = getPosition();
3071 mPositionAgent = mRegionp->getPosAgentFromRegion(mPositionRegion);
3072 }
3067 } 3073 }
3068} 3074}
3069 3075
3070const LLVector3d LLViewerObject::getPositionGlobal() const 3076const LLVector3d LLViewerObject::getPositionGlobal() const
3071{ 3077{
3072 LLVector3d position_global = mRegionp->getPosGlobalFromRegion(getPositionRegion()); 3078 if(mRegionp)
3073
3074 if (isAttachment())
3075 { 3079 {
3076 position_global = gAgent.getPosGlobalFromAgent(getRenderPosition()); 3080 LLVector3d position_global = mRegionp->getPosGlobalFromRegion(getPositionRegion());
3077 }
3078 3081
3079 return position_global; 3082 if (isAttachment())
3083 {
3084 position_global = gAgent.getPosGlobalFromAgent(getRenderPosition());
3085 }
3086 return position_global;
3087 }
3088 else
3089 {
3090 LLVector3d position_global(getPosition());
3091 return position_global;
3092 }
3080} 3093}
3081 3094
3082const LLVector3 &LLViewerObject::getPositionAgent() const 3095const LLVector3 &LLViewerObject::getPositionAgent() const
@@ -3398,6 +3411,7 @@ LLViewerObject* LLViewerObject::getRootEdit() const
3398 3411
3399BOOL LLViewerObject::lineSegmentIntersect(const LLVector3& start, const LLVector3& end, 3412BOOL LLViewerObject::lineSegmentIntersect(const LLVector3& start, const LLVector3& end,
3400 S32 face, 3413 S32 face,
3414 BOOL pick_transparent,
3401 S32* face_hit, 3415 S32* face_hit,
3402 LLVector3* intersection, 3416 LLVector3* intersection,
3403 LLVector2* tex_coord, 3417 LLVector2* tex_coord,
@@ -3407,6 +3421,20 @@ BOOL LLViewerObject::lineSegmentIntersect(const LLVector3& start, const LLVector
3407 return false; 3421 return false;
3408} 3422}
3409 3423
3424BOOL LLViewerObject::lineSegmentBoundingBox(const LLVector3& start, const LLVector3& end)
3425{
3426 if (mDrawable.isNull() || mDrawable->isDead())
3427 {
3428 return FALSE;
3429 }
3430
3431 const LLVector3* ext = mDrawable->getSpatialExtents();
3432
3433 LLVector3 center = (ext[1]+ext[0])*0.5f;
3434 LLVector3 size = (ext[1]-ext[0])*0.5f;
3435
3436 return LLLineSegmentBoxIntersect(start, end, center, size);
3437}
3410 3438
3411U8 LLViewerObject::getMediaType() const 3439U8 LLViewerObject::getMediaType() const
3412{ 3440{
@@ -4331,8 +4359,7 @@ void LLViewerObject::setAttachedSound(const LLUUID &audio_uuid, const LLUUID& ow
4331 { 4359 {
4332 BOOL queue = flags & LL_SOUND_FLAG_QUEUE; 4360 BOOL queue = flags & LL_SOUND_FLAG_QUEUE;
4333 mAudioGain = gain; 4361 mAudioGain = gain;
4334 F32 volume = gain * gSavedSettings.getF32("AudioLevelSFX"); 4362 mAudioSourcep->setGain(gain);
4335 mAudioSourcep->setGain(volume);
4336 mAudioSourcep->setLoop(flags & LL_SOUND_FLAG_LOOP); 4363 mAudioSourcep->setLoop(flags & LL_SOUND_FLAG_LOOP);
4337 mAudioSourcep->setSyncMaster(flags & LL_SOUND_FLAG_SYNC_MASTER); 4364 mAudioSourcep->setSyncMaster(flags & LL_SOUND_FLAG_SYNC_MASTER);
4338 mAudioSourcep->setSyncSlave(flags & LL_SOUND_FLAG_SYNC_SLAVE); 4365 mAudioSourcep->setSyncSlave(flags & LL_SOUND_FLAG_SYNC_SLAVE);
@@ -4370,8 +4397,7 @@ void LLViewerObject::adjustAudioGain(const F32 gain)
4370 if (mAudioSourcep) 4397 if (mAudioSourcep)
4371 { 4398 {
4372 mAudioGain = gain; 4399 mAudioGain = gain;
4373 F32 volume = mAudioGain * gSavedSettings.getF32("AudioLevelSFX"); 4400 mAudioSourcep->setGain(mAudioGain);
4374 mAudioSourcep->setGain(volume);
4375 } 4401 }
4376} 4402}
4377 4403