aboutsummaryrefslogtreecommitdiffstatshomepage
path: root/linden/indra/newview/lltoolselect.cpp
diff options
context:
space:
mode:
Diffstat (limited to 'linden/indra/newview/lltoolselect.cpp')
-rw-r--r--linden/indra/newview/lltoolselect.cpp54
1 files changed, 22 insertions, 32 deletions
diff --git a/linden/indra/newview/lltoolselect.cpp b/linden/indra/newview/lltoolselect.cpp
index d4a8153..d2f23ab 100644
--- a/linden/indra/newview/lltoolselect.cpp
+++ b/linden/indra/newview/lltoolselect.cpp
@@ -56,7 +56,7 @@ extern BOOL gAllowSelectAvatar;
56const F32 SELECTION_ROTATION_TRESHOLD = 0.1f; 56const F32 SELECTION_ROTATION_TRESHOLD = 0.1f;
57 57
58LLToolSelect::LLToolSelect( LLToolComposite* composite ) 58LLToolSelect::LLToolSelect( LLToolComposite* composite )
59: LLTool( "Select", composite ), 59: LLTool( std::string("Select"), composite ),
60 mIgnoreGroup( FALSE ) 60 mIgnoreGroup( FALSE )
61{ 61{
62 } 62 }
@@ -64,39 +64,24 @@ LLToolSelect::LLToolSelect( LLToolComposite* composite )
64// True if you selected an object. 64// True if you selected an object.
65BOOL LLToolSelect::handleMouseDown(S32 x, S32 y, MASK mask) 65BOOL LLToolSelect::handleMouseDown(S32 x, S32 y, MASK mask)
66{ 66{
67 BOOL handled = FALSE; 67 // do immediate pick query
68 68 mPick = gViewerWindow->pickImmediate(x, y, TRUE);
69 // didn't click in any UI object, so must have clicked in the world
70 LLViewerObject* object = NULL;
71
72 // You must hit the body for this tool to think you hit the object.
73 object = gObjectList.findObject( gLastHitObjectID );
74
75 if (object)
76 {
77 mSelectObjectID = object->getID();
78 handled = TRUE;
79 }
80 else
81 {
82 mSelectObjectID.setNull();
83 }
84 69
85 // Pass mousedown to agent 70 // Pass mousedown to agent
86 LLTool::handleMouseDown(x, y, mask); 71 LLTool::handleMouseDown(x, y, mask);
87 72
88 return handled; 73 return mPick.getObject().notNull();
89} 74}
90 75
91BOOL LLToolSelect::handleDoubleClick(S32 x, S32 y, MASK mask)
92{
93 //RN: double click to toggle individual/linked picking???
94 return LLTool::handleDoubleClick(x, y, mask);
95}
96 76
97// static 77// static
98LLSafeHandle<LLObjectSelection> LLToolSelect::handleObjectSelection(LLViewerObject *object, MASK mask, BOOL ignore_group, BOOL temp_select) 78LLObjectSelectionHandle LLToolSelect::handleObjectSelection(const LLPickInfo& pick, BOOL ignore_group, BOOL temp_select, BOOL select_root)
99{ 79{
80 LLViewerObject* object = pick.getObject();
81 if (select_root)
82 {
83 object = object->getRootEdit();
84 }
100 BOOL select_owned = gSavedSettings.getBOOL("SelectOwnedOnly"); 85 BOOL select_owned = gSavedSettings.getBOOL("SelectOwnedOnly");
101 BOOL select_movable = gSavedSettings.getBOOL("SelectMovableOnly"); 86 BOOL select_movable = gSavedSettings.getBOOL("SelectMovableOnly");
102 87
@@ -108,14 +93,16 @@ LLSafeHandle<LLObjectSelection> LLToolSelect::handleObjectSelection(LLViewerObje
108 LLSelectMgr::getInstance()->setForceSelection(TRUE); 93 LLSelectMgr::getInstance()->setForceSelection(TRUE);
109 } 94 }
110 95
111 BOOL extend_select = (mask == MASK_SHIFT) || (mask == MASK_CONTROL); 96 BOOL extend_select = (pick.mKeyMask == MASK_SHIFT) || (pick.mKeyMask == MASK_CONTROL);
112 97
113 // If no object, check for icon, then just deselect 98 // If no object, check for icon, then just deselect
114 if (!object) 99 if (!object)
115 { 100 {
116 if (gLastHitHUDIcon && gLastHitHUDIcon->getSourceObject()) 101 LLHUDIcon* last_hit_hud_icon = pick.mHUDIcon;
102
103 if (last_hit_hud_icon && last_hit_hud_icon->getSourceObject())
117 { 104 {
118 LLFloaterScriptDebug::show(gLastHitHUDIcon->getSourceObject()->getID()); 105 LLFloaterScriptDebug::show(last_hit_hud_icon->getSourceObject()->getID());
119 } 106 }
120 else if (!extend_select) 107 else if (!extend_select)
121 { 108 {
@@ -212,9 +199,12 @@ LLSafeHandle<LLObjectSelection> LLToolSelect::handleObjectSelection(LLViewerObje
212 select_node->setTransient(TRUE); 199 select_node->setTransient(TRUE);
213 } 200 }
214 201
215 for (S32 i = 0; i < (S32)root_object->mChildList.size(); i++) 202 LLViewerObject::const_child_list_t& child_list = root_object->getChildren();
203 for (LLViewerObject::child_list_t::const_iterator iter = child_list.begin();
204 iter != child_list.end(); iter++)
216 { 205 {
217 select_node = selection->findNode(root_object->mChildList[i]); 206 LLViewerObject* child = *iter;
207 select_node = selection->findNode(child);
218 if (select_node) 208 if (select_node)
219 { 209 {
220 select_node->setTransient(TRUE); 210 select_node->setTransient(TRUE);
@@ -240,8 +230,7 @@ BOOL LLToolSelect::handleMouseUp(S32 x, S32 y, MASK mask)
240{ 230{
241 mIgnoreGroup = gSavedSettings.getBOOL("EditLinkedParts"); 231 mIgnoreGroup = gSavedSettings.getBOOL("EditLinkedParts");
242 232
243 LLViewerObject* object = gObjectList.findObject(mSelectObjectID); 233 handleObjectSelection(mPick, mIgnoreGroup, FALSE);
244 LLToolSelect::handleObjectSelection(object, mask, mIgnoreGroup, FALSE);
245 234
246 return LLTool::handleMouseUp(x, y, mask); 235 return LLTool::handleMouseUp(x, y, mask);
247} 236}
@@ -275,3 +264,4 @@ void LLToolSelect::onMouseCaptureLost()
275 264
276 265
277 266
267