diff options
Diffstat (limited to 'linden/indra/newview/llagent.cpp')
-rw-r--r-- | linden/indra/newview/llagent.cpp | 37 |
1 files changed, 31 insertions, 6 deletions
diff --git a/linden/indra/newview/llagent.cpp b/linden/indra/newview/llagent.cpp index 42fc27d..8b49d54 100644 --- a/linden/indra/newview/llagent.cpp +++ b/linden/indra/newview/llagent.cpp | |||
@@ -903,6 +903,7 @@ BOOL LLAgent::canManageEstate() const | |||
903 | { | 903 | { |
904 | return mRegionp && mRegionp->canManageEstate(); | 904 | return mRegionp && mRegionp->canManageEstate(); |
905 | } | 905 | } |
906 | |||
906 | //----------------------------------------------------------------------------- | 907 | //----------------------------------------------------------------------------- |
907 | // sendMessage() | 908 | // sendMessage() |
908 | //----------------------------------------------------------------------------- | 909 | //----------------------------------------------------------------------------- |
@@ -2934,6 +2935,7 @@ void LLAgent::endAnimationUpdateUI() | |||
2934 | // Don't let this be called more than once if the camera | 2935 | // Don't let this be called more than once if the camera |
2935 | // mode hasn't changed. --JC | 2936 | // mode hasn't changed. --JC |
2936 | mLastCameraMode = mCameraMode; | 2937 | mLastCameraMode = mCameraMode; |
2938 | |||
2937 | } | 2939 | } |
2938 | 2940 | ||
2939 | 2941 | ||
@@ -4194,15 +4196,22 @@ void LLAgent::changeCameraToCustomizeAvatar(BOOL animate) | |||
4194 | if (animate && !mAvatarObject.isNull()) | 4196 | if (animate && !mAvatarObject.isNull()) |
4195 | { | 4197 | { |
4196 | sendAnimationRequest(ANIM_AGENT_CUSTOMIZE, ANIM_REQUEST_START); | 4198 | sendAnimationRequest(ANIM_AGENT_CUSTOMIZE, ANIM_REQUEST_START); |
4199 | mAvatarObject->startMotion(ANIM_AGENT_CUSTOMIZE); | ||
4197 | LLMotion* turn_motion = mAvatarObject->findMotion(ANIM_AGENT_CUSTOMIZE); | 4200 | LLMotion* turn_motion = mAvatarObject->findMotion(ANIM_AGENT_CUSTOMIZE); |
4201 | |||
4198 | if (turn_motion) | 4202 | if (turn_motion) |
4199 | { | 4203 | { |
4200 | mAnimationDuration = turn_motion->getDuration() + CUSTOMIZE_AVATAR_CAMERA_ANIM_SLOP; | 4204 | mAnimationDuration = turn_motion->getDuration() + CUSTOMIZE_AVATAR_CAMERA_ANIM_SLOP; |
4205 | |||
4201 | } | 4206 | } |
4202 | else | 4207 | else |
4203 | { | 4208 | { |
4204 | mAnimationDuration = gSavedSettings.getF32("ZoomTime"); | 4209 | mAnimationDuration = gSavedSettings.getF32("ZoomTime"); |
4205 | } | 4210 | } |
4211 | |||
4212 | |||
4213 | |||
4214 | |||
4206 | gAgent.setFocusGlobal(LLVector3d::zero); | 4215 | gAgent.setFocusGlobal(LLVector3d::zero); |
4207 | } | 4216 | } |
4208 | else | 4217 | else |
@@ -4709,6 +4718,22 @@ U8 LLAgent::getGodLevel() const | |||
4709 | #endif | 4718 | #endif |
4710 | } | 4719 | } |
4711 | 4720 | ||
4721 | bool LLAgent::isTeen() const | ||
4722 | { | ||
4723 | return mAccess < SIM_ACCESS_MATURE; | ||
4724 | } | ||
4725 | |||
4726 | void LLAgent::setTeen(bool teen) | ||
4727 | { | ||
4728 | if (teen) | ||
4729 | { | ||
4730 | mAccess = SIM_ACCESS_PG; | ||
4731 | } | ||
4732 | else | ||
4733 | { | ||
4734 | mAccess = SIM_ACCESS_MATURE; | ||
4735 | } | ||
4736 | } | ||
4712 | 4737 | ||
4713 | void LLAgent::buildFullname(std::string& name) const | 4738 | void LLAgent::buildFullname(std::string& name) const |
4714 | { | 4739 | { |
@@ -5627,7 +5652,7 @@ void LLAgent::teleportRequest( | |||
5627 | } | 5652 | } |
5628 | 5653 | ||
5629 | // Landmark ID = LLUUID::null means teleport home | 5654 | // Landmark ID = LLUUID::null means teleport home |
5630 | void LLAgent::teleportViaLandmark(const LLUUID& landmark_id) | 5655 | void LLAgent::teleportViaLandmark(const LLUUID& landmark_asset_id) |
5631 | { | 5656 | { |
5632 | LLViewerRegion *regionp = getRegion(); | 5657 | LLViewerRegion *regionp = getRegion(); |
5633 | if(regionp && teleportCore()) | 5658 | if(regionp && teleportCore()) |
@@ -5637,7 +5662,7 @@ void LLAgent::teleportViaLandmark(const LLUUID& landmark_id) | |||
5637 | msg->nextBlockFast(_PREHASH_Info); | 5662 | msg->nextBlockFast(_PREHASH_Info); |
5638 | msg->addUUIDFast(_PREHASH_AgentID, getID()); | 5663 | msg->addUUIDFast(_PREHASH_AgentID, getID()); |
5639 | msg->addUUIDFast(_PREHASH_SessionID, getSessionID()); | 5664 | msg->addUUIDFast(_PREHASH_SessionID, getSessionID()); |
5640 | msg->addUUIDFast(_PREHASH_LandmarkID, landmark_id); | 5665 | msg->addUUIDFast(_PREHASH_LandmarkID, landmark_asset_id); |
5641 | sendReliableMessage(); | 5666 | sendReliableMessage(); |
5642 | } | 5667 | } |
5643 | } | 5668 | } |
@@ -6850,7 +6875,7 @@ void LLAgent::removeWearable( EWearableType type ) | |||
6850 | { | 6875 | { |
6851 | LLWearable* old_wearable = mWearableEntry[ type ].mWearable; | 6876 | LLWearable* old_wearable = mWearableEntry[ type ].mWearable; |
6852 | 6877 | ||
6853 | if ( (gAgent.mAccess < SIM_ACCESS_MATURE) | 6878 | if ( (gAgent.isTeen()) |
6854 | && (type == WT_UNDERSHIRT || type == WT_UNDERPANTS)) | 6879 | && (type == WT_UNDERSHIRT || type == WT_UNDERPANTS)) |
6855 | { | 6880 | { |
6856 | // Can't take off underclothing in simple UI mode or on PG accounts | 6881 | // Can't take off underclothing in simple UI mode or on PG accounts |
@@ -6985,8 +7010,8 @@ void LLAgent::setWearableOutfit( | |||
6985 | wearables_to_remove[WT_SOCKS] = remove; | 7010 | wearables_to_remove[WT_SOCKS] = remove; |
6986 | wearables_to_remove[WT_JACKET] = remove; | 7011 | wearables_to_remove[WT_JACKET] = remove; |
6987 | wearables_to_remove[WT_GLOVES] = remove; | 7012 | wearables_to_remove[WT_GLOVES] = remove; |
6988 | wearables_to_remove[WT_UNDERSHIRT] = (gAgent.mAccess >= SIM_ACCESS_MATURE) & remove; | 7013 | wearables_to_remove[WT_UNDERSHIRT] = (!gAgent.isTeen()) & remove; |
6989 | wearables_to_remove[WT_UNDERPANTS] = (gAgent.mAccess >= SIM_ACCESS_MATURE) & remove; | 7014 | wearables_to_remove[WT_UNDERPANTS] = (!gAgent.isTeen()) & remove; |
6990 | wearables_to_remove[WT_SKIRT] = remove; | 7015 | wearables_to_remove[WT_SKIRT] = remove; |
6991 | 7016 | ||
6992 | S32 count = wearables.count(); | 7017 | S32 count = wearables.count(); |
@@ -7224,7 +7249,7 @@ void LLAgent::userRemoveWearable( void* userdata ) | |||
7224 | EWearableType type = (EWearableType)(intptr_t)userdata; | 7249 | EWearableType type = (EWearableType)(intptr_t)userdata; |
7225 | 7250 | ||
7226 | if( !(type==WT_SHAPE || type==WT_SKIN || type==WT_HAIR ) ) //&& | 7251 | if( !(type==WT_SHAPE || type==WT_SKIN || type==WT_HAIR ) ) //&& |
7227 | //!((gAgent.mAccess >= SIM_ACCESS_MATURE) && ( type==WT_UNDERPANTS || type==WT_UNDERSHIRT )) ) | 7252 | //!((!gAgent.isTeen()) && ( type==WT_UNDERPANTS || type==WT_UNDERSHIRT )) ) |
7228 | { | 7253 | { |
7229 | gAgent.removeWearable( type ); | 7254 | gAgent.removeWearable( type ); |
7230 | } | 7255 | } |