diff options
Diffstat (limited to 'linden/indra/newview/llmaniptranslate.cpp')
-rw-r--r-- | linden/indra/newview/llmaniptranslate.cpp | 74 |
1 files changed, 42 insertions, 32 deletions
diff --git a/linden/indra/newview/llmaniptranslate.cpp b/linden/indra/newview/llmaniptranslate.cpp index e405dc4..1963b1a 100644 --- a/linden/indra/newview/llmaniptranslate.cpp +++ b/linden/indra/newview/llmaniptranslate.cpp | |||
@@ -2,6 +2,8 @@ | |||
2 | * @file llmaniptranslate.cpp | 2 | * @file llmaniptranslate.cpp |
3 | * @brief LLManipTranslate class implementation | 3 | * @brief LLManipTranslate class implementation |
4 | * | 4 | * |
5 | * $LicenseInfo:firstyear=2002&license=viewergpl$ | ||
6 | * | ||
5 | * Copyright (c) 2002-2007, Linden Research, Inc. | 7 | * Copyright (c) 2002-2007, Linden Research, Inc. |
6 | * | 8 | * |
7 | * Second Life Viewer Source Code | 9 | * Second Life Viewer Source Code |
@@ -24,6 +26,7 @@ | |||
24 | * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO | 26 | * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO |
25 | * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, | 27 | * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, |
26 | * COMPLETENESS OR PERFORMANCE. | 28 | * COMPLETENESS OR PERFORMANCE. |
29 | * $/LicenseInfo$ | ||
27 | */ | 30 | */ |
28 | 31 | ||
29 | /** | 32 | /** |
@@ -258,7 +261,7 @@ LLManipTranslate::~LLManipTranslate() | |||
258 | void LLManipTranslate::handleSelect() | 261 | void LLManipTranslate::handleSelect() |
259 | { | 262 | { |
260 | gSelectMgr->saveSelectedObjectTransform(SELECT_ACTION_TYPE_PICK); | 263 | gSelectMgr->saveSelectedObjectTransform(SELECT_ACTION_TYPE_PICK); |
261 | gFloaterTools->setStatusText("Drag to move, shift-drag to copy"); | 264 | gFloaterTools->setStatusText("move"); |
262 | LLManip::handleSelect(); | 265 | LLManip::handleSelect(); |
263 | } | 266 | } |
264 | 267 | ||
@@ -266,7 +269,6 @@ void LLManipTranslate::handleDeselect() | |||
266 | { | 269 | { |
267 | mHighlightedPart = LL_NO_PART; | 270 | mHighlightedPart = LL_NO_PART; |
268 | mManipPart = LL_NO_PART; | 271 | mManipPart = LL_NO_PART; |
269 | gFloaterTools->setStatusText(""); | ||
270 | LLManip::handleDeselect(); | 272 | LLManip::handleDeselect(); |
271 | } | 273 | } |
272 | 274 | ||
@@ -293,14 +295,7 @@ BOOL LLManipTranslate::handleMouseDown(S32 x, S32 y, MASK mask) | |||
293 | // Assumes that one of the arrows on an object was hit. | 295 | // Assumes that one of the arrows on an object was hit. |
294 | BOOL LLManipTranslate::handleMouseDownOnPart( S32 x, S32 y, MASK mask ) | 296 | BOOL LLManipTranslate::handleMouseDownOnPart( S32 x, S32 y, MASK mask ) |
295 | { | 297 | { |
296 | BOOL can_move = mObjectSelection->getObjectCount() != 0; | 298 | BOOL can_move = canAffectSelection(); |
297 | for (LLViewerObject* objectp = mObjectSelection->getFirstObject(); | ||
298 | objectp; | ||
299 | objectp = mObjectSelection->getNextObject()) | ||
300 | { | ||
301 | can_move = can_move && objectp->permMove() && (objectp->permModify() || !gSavedSettings.getBOOL("EditLinkedParts")); | ||
302 | } | ||
303 | |||
304 | if (!can_move) | 299 | if (!can_move) |
305 | { | 300 | { |
306 | return FALSE; | 301 | return FALSE; |
@@ -428,8 +423,6 @@ BOOL LLManipTranslate::handleHover(S32 x, S32 y, MASK mask) | |||
428 | } | 423 | } |
429 | } | 424 | } |
430 | 425 | ||
431 | LLViewerObject *object; | ||
432 | |||
433 | // Suppress processing if mouse hasn't actually moved. | 426 | // Suppress processing if mouse hasn't actually moved. |
434 | // This may cause problems if the camera moves outside of the | 427 | // This may cause problems if the camera moves outside of the |
435 | // rotation above. | 428 | // rotation above. |
@@ -488,7 +481,7 @@ BOOL LLManipTranslate::handleHover(S32 x, S32 y, MASK mask) | |||
488 | return TRUE; | 481 | return TRUE; |
489 | } | 482 | } |
490 | 483 | ||
491 | object = selectNode->getObject(); | 484 | LLViewerObject* object = selectNode->getObject(); |
492 | if (!object) | 485 | if (!object) |
493 | { | 486 | { |
494 | // somehow we lost the object! | 487 | // somehow we lost the object! |
@@ -651,11 +644,11 @@ BOOL LLManipTranslate::handleHover(S32 x, S32 y, MASK mask) | |||
651 | LLVector3d clamped_relative_move = axis_magnitude * axis_d; // scalar multiply | 644 | LLVector3d clamped_relative_move = axis_magnitude * axis_d; // scalar multiply |
652 | LLVector3 clamped_relative_move_f = (F32)axis_magnitude * axis_f; // scalar multiply | 645 | LLVector3 clamped_relative_move_f = (F32)axis_magnitude * axis_f; // scalar multiply |
653 | 646 | ||
654 | for(selectNode = mObjectSelection->getFirstNode(); | 647 | for (LLObjectSelection::iterator iter = mObjectSelection->begin(); |
655 | selectNode; | 648 | iter != mObjectSelection->end(); iter++) |
656 | selectNode = mObjectSelection->getNextNode() ) | ||
657 | { | 649 | { |
658 | object = selectNode->getObject(); | 650 | LLSelectNode* selectNode = *iter; |
651 | LLViewerObject* object = selectNode->getObject(); | ||
659 | 652 | ||
660 | // Only apply motion to root objects and objects selected | 653 | // Only apply motion to root objects and objects selected |
661 | // as "individual". | 654 | // as "individual". |
@@ -1044,16 +1037,19 @@ BOOL LLManipTranslate::handleMouseUp(S32 x, S32 y, MASK mask) | |||
1044 | // first, perform normal processing in case this was a quick-click | 1037 | // first, perform normal processing in case this was a quick-click |
1045 | handleHover(x, y, mask); | 1038 | handleHover(x, y, mask); |
1046 | 1039 | ||
1047 | // make sure arrow colors go back to normal | 1040 | if(hasMouseCapture()) |
1048 | mManipPart = LL_NO_PART; | 1041 | { |
1049 | gSelectMgr->enableSilhouette(TRUE); | 1042 | // make sure arrow colors go back to normal |
1043 | mManipPart = LL_NO_PART; | ||
1044 | gSelectMgr->enableSilhouette(TRUE); | ||
1050 | 1045 | ||
1051 | // Might have missed last update due to UPDATE_DELAY timing. | 1046 | // Might have missed last update due to UPDATE_DELAY timing. |
1052 | gSelectMgr->sendMultipleUpdate( UPD_POSITION ); | 1047 | gSelectMgr->sendMultipleUpdate( UPD_POSITION ); |
1053 | 1048 | ||
1054 | mInSnapRegime = FALSE; | 1049 | mInSnapRegime = FALSE; |
1055 | gSelectMgr->saveSelectedObjectTransform(SELECT_ACTION_TYPE_PICK); | 1050 | gSelectMgr->saveSelectedObjectTransform(SELECT_ACTION_TYPE_PICK); |
1056 | //gAgent.setObjectTracking(gSavedSettings.getBOOL("TrackFocusObject")); | 1051 | //gAgent.setObjectTracking(gSavedSettings.getBOOL("TrackFocusObject")); |
1052 | } | ||
1057 | 1053 | ||
1058 | return LLManip::handleMouseUp(x, y, mask); | 1054 | return LLManip::handleMouseUp(x, y, mask); |
1059 | } | 1055 | } |
@@ -1736,12 +1732,8 @@ void LLManipTranslate::renderText() | |||
1736 | } | 1732 | } |
1737 | else | 1733 | else |
1738 | { | 1734 | { |
1739 | LLViewerObject* objectp = mObjectSelection->getFirstRootObject(); | 1735 | const BOOL children_ok = TRUE; |
1740 | if(!objectp) | 1736 | LLViewerObject* objectp = mObjectSelection->getFirstRootObject(children_ok); |
1741 | { | ||
1742 | objectp = mObjectSelection->getFirstObject(); | ||
1743 | } | ||
1744 | |||
1745 | if (objectp) | 1737 | if (objectp) |
1746 | { | 1738 | { |
1747 | renderXYZ(objectp->getPositionEdit()); | 1739 | renderXYZ(objectp->getPositionEdit()); |
@@ -2261,3 +2253,21 @@ void LLManipTranslate::renderGridVert(F32 x_trans, F32 y_trans, F32 r, F32 g, F3 | |||
2261 | } | 2253 | } |
2262 | 2254 | ||
2263 | } | 2255 | } |
2256 | |||
2257 | // virtual | ||
2258 | BOOL LLManipTranslate::canAffectSelection() | ||
2259 | { | ||
2260 | BOOL can_move = mObjectSelection->getObjectCount() != 0; | ||
2261 | if (can_move) | ||
2262 | { | ||
2263 | struct f : public LLSelectedObjectFunctor | ||
2264 | { | ||
2265 | virtual bool apply(LLViewerObject* objectp) | ||
2266 | { | ||
2267 | return objectp->permMove() && (objectp->permModify() || !gSavedSettings.getBOOL("EditLinkedParts")); | ||
2268 | } | ||
2269 | } func; | ||
2270 | can_move = mObjectSelection->applyToObjects(&func); | ||
2271 | } | ||
2272 | return can_move; | ||
2273 | } | ||