Imported existing code
This commit is contained in:
792
indra/newview/lltoolcomp.cpp
Normal file
792
indra/newview/lltoolcomp.cpp
Normal file
@@ -0,0 +1,792 @@
|
||||
/**
|
||||
* @file lltoolcomp.cpp
|
||||
* @brief Composite tools
|
||||
*
|
||||
* $LicenseInfo:firstyear=2001&license=viewergpl$
|
||||
*
|
||||
* Copyright (c) 2001-2009, Linden Research, Inc.
|
||||
*
|
||||
* Second Life Viewer Source Code
|
||||
* The source code in this file ("Source Code") is provided by Linden Lab
|
||||
* to you under the terms of the GNU General Public License, version 2.0
|
||||
* ("GPL"), unless you have obtained a separate licensing agreement
|
||||
* ("Other License"), formally executed by you and Linden Lab. Terms of
|
||||
* the GPL can be found in doc/GPL-license.txt in this distribution, or
|
||||
* online at http://secondlifegrid.net/programs/open_source/licensing/gplv2
|
||||
*
|
||||
* There are special exceptions to the terms and conditions of the GPL as
|
||||
* it is applied to this Source Code. View the full text of the exception
|
||||
* in the file doc/FLOSS-exception.txt in this software distribution, or
|
||||
* online at
|
||||
* http://secondlifegrid.net/programs/open_source/licensing/flossexception
|
||||
*
|
||||
* By copying, modifying or distributing this software, you acknowledge
|
||||
* that you have read and understood your obligations described above,
|
||||
* and agree to abide by those obligations.
|
||||
*
|
||||
* ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO
|
||||
* WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY,
|
||||
* COMPLETENESS OR PERFORMANCE.
|
||||
* $/LicenseInfo$
|
||||
*/
|
||||
|
||||
#include "llviewerprecompiledheaders.h"
|
||||
|
||||
#include "lltoolcomp.h"
|
||||
|
||||
#include "llgl.h"
|
||||
#include "indra_constants.h"
|
||||
|
||||
#include "llmanip.h"
|
||||
#include "llmaniprotate.h"
|
||||
#include "llmanipscale.h"
|
||||
#include "llmaniptranslate.h"
|
||||
#include "llmenugl.h" // for right-click menu hack
|
||||
#include "llselectmgr.h"
|
||||
#include "lltoolfocus.h"
|
||||
#include "lltoolgrab.h"
|
||||
#include "lltoolgun.h"
|
||||
#include "lltoolmgr.h"
|
||||
#include "lltoolselectrect.h"
|
||||
#include "lltoolplacer.h"
|
||||
#include "llviewermenu.h"
|
||||
#include "llviewerobject.h"
|
||||
#include "llviewerwindow.h"
|
||||
#include "llagent.h"
|
||||
#include "llfloatertools.h"
|
||||
#include "llviewercontrol.h"
|
||||
|
||||
const S32 BUTTON_HEIGHT = 16;
|
||||
const S32 BUTTON_WIDTH_SMALL = 32;
|
||||
const S32 BUTTON_WIDTH_BIG = 48;
|
||||
const S32 HPAD = 4;
|
||||
|
||||
extern LLControlGroup gSavedSettings;
|
||||
|
||||
|
||||
// we use this in various places instead of NULL
|
||||
static LLTool* sNullTool = new LLTool(std::string("null"), NULL);
|
||||
|
||||
//-----------------------------------------------------------------------
|
||||
// LLToolComposite
|
||||
|
||||
//static
|
||||
void LLToolComposite::setCurrentTool( LLTool* new_tool )
|
||||
{
|
||||
if( mCur != new_tool )
|
||||
{
|
||||
if( mSelected )
|
||||
{
|
||||
mCur->handleDeselect();
|
||||
mCur = new_tool;
|
||||
mCur->handleSelect();
|
||||
}
|
||||
else
|
||||
{
|
||||
mCur = new_tool;
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
LLToolComposite::LLToolComposite(const std::string& name)
|
||||
: LLTool(name),
|
||||
mCur(sNullTool),
|
||||
mDefault(sNullTool),
|
||||
mSelected(FALSE),
|
||||
mMouseDown(FALSE), mManip(NULL), mSelectRect(NULL)
|
||||
{
|
||||
}
|
||||
|
||||
// Returns to the default tool
|
||||
BOOL LLToolComposite::handleMouseUp(S32 x, S32 y, MASK mask)
|
||||
{
|
||||
BOOL handled = mCur->handleMouseUp( x, y, mask );
|
||||
if( handled )
|
||||
{
|
||||
setCurrentTool( mDefault );
|
||||
}
|
||||
return handled;
|
||||
}
|
||||
|
||||
void LLToolComposite::onMouseCaptureLost()
|
||||
{
|
||||
mCur->onMouseCaptureLost();
|
||||
setCurrentTool( mDefault );
|
||||
}
|
||||
|
||||
BOOL LLToolComposite::isSelecting()
|
||||
{
|
||||
return mCur == mSelectRect;
|
||||
}
|
||||
|
||||
void LLToolComposite::handleSelect()
|
||||
{
|
||||
if (!gSavedSettings.getBOOL("EditLinkedParts"))
|
||||
{
|
||||
LLSelectMgr::getInstance()->promoteSelectionToRoot();
|
||||
}
|
||||
mCur = mDefault;
|
||||
mCur->handleSelect();
|
||||
mSelected = TRUE;
|
||||
}
|
||||
|
||||
//----------------------------------------------------------------------------
|
||||
// LLToolCompInspect
|
||||
//----------------------------------------------------------------------------
|
||||
|
||||
LLToolCompInspect::LLToolCompInspect()
|
||||
: LLToolComposite(std::string("Inspect"))
|
||||
{
|
||||
mSelectRect = new LLToolSelectRect(this);
|
||||
mDefault = mSelectRect;
|
||||
}
|
||||
|
||||
|
||||
LLToolCompInspect::~LLToolCompInspect()
|
||||
{
|
||||
delete mSelectRect;
|
||||
mSelectRect = NULL;
|
||||
}
|
||||
|
||||
BOOL LLToolCompInspect::handleMouseDown(S32 x, S32 y, MASK mask)
|
||||
{
|
||||
mMouseDown = TRUE;
|
||||
gViewerWindow->pickAsync(x, y, mask, pickCallback);
|
||||
return TRUE;
|
||||
}
|
||||
|
||||
void LLToolCompInspect::pickCallback(const LLPickInfo& pick_info)
|
||||
{
|
||||
LLViewerObject* hit_obj = pick_info.getObject();
|
||||
|
||||
if (!LLToolCompInspect::getInstance()->mMouseDown)
|
||||
{
|
||||
// fast click on object, but mouse is already up...just do select
|
||||
LLToolCompInspect::getInstance()->mSelectRect->handleObjectSelection(pick_info, gSavedSettings.getBOOL("EditLinkedParts"), FALSE);
|
||||
return;
|
||||
}
|
||||
|
||||
if( hit_obj )
|
||||
{
|
||||
if (LLSelectMgr::getInstance()->getSelection()->getObjectCount())
|
||||
{
|
||||
LLEditMenuHandler::gEditMenuHandler = LLSelectMgr::getInstance();
|
||||
}
|
||||
LLToolCompInspect::getInstance()->setCurrentTool( LLToolCompInspect::getInstance()->mSelectRect );
|
||||
LLToolCompInspect::getInstance()->mSelectRect->handlePick( pick_info );
|
||||
|
||||
}
|
||||
else
|
||||
{
|
||||
LLToolCompInspect::getInstance()->setCurrentTool( LLToolCompInspect::getInstance()->mSelectRect );
|
||||
LLToolCompInspect::getInstance()->mSelectRect->handlePick( pick_info );
|
||||
}
|
||||
}
|
||||
|
||||
BOOL LLToolCompInspect::handleDoubleClick(S32 x, S32 y, MASK mask)
|
||||
{
|
||||
return TRUE;
|
||||
}
|
||||
|
||||
//----------------------------------------------------------------------------
|
||||
// LLToolCompTranslate
|
||||
//----------------------------------------------------------------------------
|
||||
|
||||
LLToolCompTranslate::LLToolCompTranslate()
|
||||
: LLToolComposite(std::string("Move"))
|
||||
{
|
||||
mManip = new LLManipTranslate(this);
|
||||
mSelectRect = new LLToolSelectRect(this);
|
||||
|
||||
mCur = mManip;
|
||||
mDefault = mManip;
|
||||
}
|
||||
|
||||
LLToolCompTranslate::~LLToolCompTranslate()
|
||||
{
|
||||
delete mManip;
|
||||
mManip = NULL;
|
||||
|
||||
delete mSelectRect;
|
||||
mSelectRect = NULL;
|
||||
}
|
||||
|
||||
BOOL LLToolCompTranslate::handleHover(S32 x, S32 y, MASK mask)
|
||||
{
|
||||
if( !mCur->hasMouseCapture() )
|
||||
{
|
||||
setCurrentTool( mManip );
|
||||
}
|
||||
return mCur->handleHover( x, y, mask );
|
||||
}
|
||||
|
||||
|
||||
BOOL LLToolCompTranslate::handleMouseDown(S32 x, S32 y, MASK mask)
|
||||
{
|
||||
mMouseDown = TRUE;
|
||||
gViewerWindow->pickAsync(x, y, mask, pickCallback, TRUE);
|
||||
return TRUE;
|
||||
}
|
||||
|
||||
void LLToolCompTranslate::pickCallback(const LLPickInfo& pick_info)
|
||||
{
|
||||
LLViewerObject* hit_obj = pick_info.getObject();
|
||||
|
||||
LLToolCompTranslate::getInstance()->mManip->highlightManipulators(pick_info.mMousePt.mX, pick_info.mMousePt.mY);
|
||||
if (!LLToolCompTranslate::getInstance()->mMouseDown)
|
||||
{
|
||||
// fast click on object, but mouse is already up...just do select
|
||||
LLToolCompTranslate::getInstance()->mSelectRect->handleObjectSelection(pick_info, gSavedSettings.getBOOL("EditLinkedParts"), FALSE);
|
||||
return;
|
||||
}
|
||||
|
||||
if( hit_obj || LLToolCompTranslate::getInstance()->mManip->getHighlightedPart() != LLManip::LL_NO_PART )
|
||||
{
|
||||
if (LLToolCompTranslate::getInstance()->mManip->getSelection()->getObjectCount())
|
||||
{
|
||||
LLEditMenuHandler::gEditMenuHandler = LLSelectMgr::getInstance();
|
||||
}
|
||||
|
||||
BOOL can_move = LLToolCompTranslate::getInstance()->mManip->canAffectSelection();
|
||||
|
||||
if( LLManip::LL_NO_PART != LLToolCompTranslate::getInstance()->mManip->getHighlightedPart() && can_move)
|
||||
{
|
||||
LLToolCompTranslate::getInstance()->setCurrentTool( LLToolCompTranslate::getInstance()->mManip );
|
||||
LLToolCompTranslate::getInstance()->mManip->handleMouseDownOnPart( pick_info.mMousePt.mX, pick_info.mMousePt.mY, pick_info.mKeyMask );
|
||||
}
|
||||
else
|
||||
{
|
||||
LLToolCompTranslate::getInstance()->setCurrentTool( LLToolCompTranslate::getInstance()->mSelectRect );
|
||||
LLToolCompTranslate::getInstance()->mSelectRect->handlePick( pick_info );
|
||||
|
||||
// *TODO: add toggle to trigger old click-drag functionality
|
||||
// LLToolCompTranslate::getInstance()->mManip->handleMouseDownOnPart( XY_part, x, y, mask);
|
||||
}
|
||||
}
|
||||
else
|
||||
{
|
||||
LLToolCompTranslate::getInstance()->setCurrentTool( LLToolCompTranslate::getInstance()->mSelectRect );
|
||||
LLToolCompTranslate::getInstance()->mSelectRect->handlePick( pick_info );
|
||||
}
|
||||
}
|
||||
|
||||
BOOL LLToolCompTranslate::handleMouseUp(S32 x, S32 y, MASK mask)
|
||||
{
|
||||
mMouseDown = FALSE;
|
||||
return LLToolComposite::handleMouseUp(x, y, mask);
|
||||
}
|
||||
|
||||
LLTool* LLToolCompTranslate::getOverrideTool(MASK mask)
|
||||
{
|
||||
if (mask == MASK_CONTROL)
|
||||
{
|
||||
return LLToolCompRotate::getInstance();
|
||||
}
|
||||
else if (mask == (MASK_CONTROL | MASK_SHIFT))
|
||||
{
|
||||
return LLToolCompScale::getInstance();
|
||||
}
|
||||
return LLToolComposite::getOverrideTool(mask);
|
||||
}
|
||||
|
||||
BOOL LLToolCompTranslate::handleDoubleClick(S32 x, S32 y, MASK mask)
|
||||
{
|
||||
if (mManip->getSelection()->isEmpty() && mManip->getHighlightedPart() == LLManip::LL_NO_PART)
|
||||
{
|
||||
// You should already have an object selected from the mousedown.
|
||||
// If so, show its properties
|
||||
gFloaterTools->showPanel(LLFloaterTools::PANEL_CONTENTS);
|
||||
return TRUE;
|
||||
}
|
||||
// Nothing selected means the first mouse click was probably
|
||||
// bad, so try again.
|
||||
return FALSE;
|
||||
}
|
||||
|
||||
|
||||
void LLToolCompTranslate::render()
|
||||
{
|
||||
mCur->render(); // removing this will not draw the RGB arrows and guidelines
|
||||
|
||||
if( mCur != mManip )
|
||||
{
|
||||
LLGLDepthTest gls_depth(GL_TRUE, GL_FALSE);
|
||||
mManip->renderGuidelines();
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
//-----------------------------------------------------------------------
|
||||
// LLToolCompScale
|
||||
|
||||
LLToolCompScale::LLToolCompScale()
|
||||
: LLToolComposite(std::string("Stretch"))
|
||||
{
|
||||
mManip = new LLManipScale(this);
|
||||
mSelectRect = new LLToolSelectRect(this);
|
||||
|
||||
mCur = mManip;
|
||||
mDefault = mManip;
|
||||
}
|
||||
|
||||
LLToolCompScale::~LLToolCompScale()
|
||||
{
|
||||
delete mManip;
|
||||
delete mSelectRect;
|
||||
}
|
||||
|
||||
BOOL LLToolCompScale::handleHover(S32 x, S32 y, MASK mask)
|
||||
{
|
||||
if( !mCur->hasMouseCapture() )
|
||||
{
|
||||
setCurrentTool(mManip );
|
||||
}
|
||||
return mCur->handleHover( x, y, mask );
|
||||
}
|
||||
|
||||
|
||||
BOOL LLToolCompScale::handleMouseDown(S32 x, S32 y, MASK mask)
|
||||
{
|
||||
mMouseDown = TRUE;
|
||||
gViewerWindow->pickAsync(x, y, mask, pickCallback);
|
||||
return TRUE;
|
||||
}
|
||||
|
||||
void LLToolCompScale::pickCallback(const LLPickInfo& pick_info)
|
||||
{
|
||||
LLViewerObject* hit_obj = pick_info.getObject();
|
||||
|
||||
LLToolCompScale::getInstance()->mManip->highlightManipulators(pick_info.mMousePt.mX, pick_info.mMousePt.mY);
|
||||
if (!LLToolCompScale::getInstance()->mMouseDown)
|
||||
{
|
||||
// fast click on object, but mouse is already up...just do select
|
||||
LLToolCompScale::getInstance()->mSelectRect->handleObjectSelection(pick_info, gSavedSettings.getBOOL("EditLinkedParts"), FALSE);
|
||||
|
||||
return;
|
||||
}
|
||||
|
||||
if( hit_obj || LLToolCompScale::getInstance()->mManip->getHighlightedPart() != LLManip::LL_NO_PART)
|
||||
{
|
||||
if (LLToolCompScale::getInstance()->mManip->getSelection()->getObjectCount())
|
||||
{
|
||||
LLEditMenuHandler::gEditMenuHandler = LLSelectMgr::getInstance();
|
||||
}
|
||||
if( LLManip::LL_NO_PART != LLToolCompScale::getInstance()->mManip->getHighlightedPart() )
|
||||
{
|
||||
LLToolCompScale::getInstance()->setCurrentTool( LLToolCompScale::getInstance()->mManip );
|
||||
LLToolCompScale::getInstance()->mManip->handleMouseDownOnPart( pick_info.mMousePt.mX, pick_info.mMousePt.mY, pick_info.mKeyMask );
|
||||
}
|
||||
else
|
||||
{
|
||||
LLToolCompScale::getInstance()->setCurrentTool( LLToolCompScale::getInstance()->mSelectRect );
|
||||
LLToolCompScale::getInstance()->mSelectRect->handlePick( pick_info );
|
||||
}
|
||||
}
|
||||
else
|
||||
{
|
||||
LLToolCompScale::getInstance()->setCurrentTool( LLToolCompScale::getInstance()->mSelectRect );
|
||||
LLToolCompScale::getInstance()->mSelectRect->handlePick( pick_info );
|
||||
}
|
||||
}
|
||||
|
||||
BOOL LLToolCompScale::handleMouseUp(S32 x, S32 y, MASK mask)
|
||||
{
|
||||
mMouseDown = FALSE;
|
||||
return LLToolComposite::handleMouseUp(x, y, mask);
|
||||
}
|
||||
|
||||
LLTool* LLToolCompScale::getOverrideTool(MASK mask)
|
||||
{
|
||||
if (mask == MASK_CONTROL)
|
||||
{
|
||||
return LLToolCompRotate::getInstance();
|
||||
}
|
||||
|
||||
return LLToolComposite::getOverrideTool(mask);
|
||||
}
|
||||
|
||||
|
||||
BOOL LLToolCompScale::handleDoubleClick(S32 x, S32 y, MASK mask)
|
||||
{
|
||||
if (!mManip->getSelection()->isEmpty() && mManip->getHighlightedPart() == LLManip::LL_NO_PART)
|
||||
{
|
||||
// You should already have an object selected from the mousedown.
|
||||
// If so, show its properties
|
||||
gFloaterTools->showPanel(LLFloaterTools::PANEL_CONTENTS);
|
||||
//gBuildView->setPropertiesPanelOpen(TRUE);
|
||||
return TRUE;
|
||||
}
|
||||
else
|
||||
{
|
||||
// Nothing selected means the first mouse click was probably
|
||||
// bad, so try again.
|
||||
return handleMouseDown(x, y, mask);
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
void LLToolCompScale::render()
|
||||
{
|
||||
mCur->render();
|
||||
|
||||
if( mCur != mManip )
|
||||
{
|
||||
LLGLDepthTest gls_depth(GL_TRUE, GL_FALSE);
|
||||
mManip->renderGuidelines();
|
||||
}
|
||||
}
|
||||
|
||||
//-----------------------------------------------------------------------
|
||||
// LLToolCompCreate
|
||||
|
||||
LLToolCompCreate::LLToolCompCreate()
|
||||
: LLToolComposite(std::string("Create"))
|
||||
{
|
||||
mPlacer = new LLToolPlacer();
|
||||
mSelectRect = new LLToolSelectRect(this);
|
||||
|
||||
mCur = mPlacer;
|
||||
mDefault = mPlacer;
|
||||
mObjectPlacedOnMouseDown = FALSE;
|
||||
}
|
||||
|
||||
|
||||
LLToolCompCreate::~LLToolCompCreate()
|
||||
{
|
||||
delete mPlacer;
|
||||
delete mSelectRect;
|
||||
}
|
||||
|
||||
|
||||
BOOL LLToolCompCreate::handleMouseDown(S32 x, S32 y, MASK mask)
|
||||
{
|
||||
BOOL handled = FALSE;
|
||||
mMouseDown = TRUE;
|
||||
|
||||
if ( (mask == MASK_SHIFT) || (mask == MASK_CONTROL) )
|
||||
{
|
||||
gViewerWindow->pickAsync(x, y, mask, pickCallback);
|
||||
handled = TRUE;
|
||||
}
|
||||
else
|
||||
{
|
||||
setCurrentTool( mPlacer );
|
||||
handled = mPlacer->placeObject( x, y, mask );
|
||||
}
|
||||
|
||||
mObjectPlacedOnMouseDown = TRUE;
|
||||
|
||||
return TRUE;
|
||||
}
|
||||
|
||||
void LLToolCompCreate::pickCallback(const LLPickInfo& pick_info)
|
||||
{
|
||||
// *NOTE: We mask off shift and control, so you cannot
|
||||
// multi-select multiple objects with the create tool.
|
||||
MASK mask = (pick_info.mKeyMask & ~MASK_SHIFT);
|
||||
mask = (mask & ~MASK_CONTROL);
|
||||
|
||||
LLToolCompCreate::getInstance()->setCurrentTool( LLToolCompCreate::getInstance()->mSelectRect );
|
||||
LLToolCompCreate::getInstance()->mSelectRect->handlePick( pick_info );
|
||||
}
|
||||
|
||||
BOOL LLToolCompCreate::handleDoubleClick(S32 x, S32 y, MASK mask)
|
||||
{
|
||||
return handleMouseDown(x, y, mask);
|
||||
}
|
||||
|
||||
BOOL LLToolCompCreate::handleMouseUp(S32 x, S32 y, MASK mask)
|
||||
{
|
||||
BOOL handled = FALSE;
|
||||
|
||||
if ( mMouseDown && !mObjectPlacedOnMouseDown && !(mask == MASK_SHIFT) && !(mask == MASK_CONTROL) )
|
||||
{
|
||||
setCurrentTool( mPlacer );
|
||||
handled = mPlacer->placeObject( x, y, mask );
|
||||
}
|
||||
|
||||
mObjectPlacedOnMouseDown = FALSE;
|
||||
mMouseDown = FALSE;
|
||||
|
||||
if (!handled)
|
||||
{
|
||||
handled = LLToolComposite::handleMouseUp(x, y, mask);
|
||||
}
|
||||
|
||||
return handled;
|
||||
}
|
||||
|
||||
//-----------------------------------------------------------------------
|
||||
// LLToolCompRotate
|
||||
|
||||
LLToolCompRotate::LLToolCompRotate()
|
||||
: LLToolComposite(std::string("Rotate"))
|
||||
{
|
||||
mManip = new LLManipRotate(this);
|
||||
mSelectRect = new LLToolSelectRect(this);
|
||||
|
||||
mCur = mManip;
|
||||
mDefault = mManip;
|
||||
}
|
||||
|
||||
|
||||
LLToolCompRotate::~LLToolCompRotate()
|
||||
{
|
||||
delete mManip;
|
||||
delete mSelectRect;
|
||||
}
|
||||
|
||||
BOOL LLToolCompRotate::handleHover(S32 x, S32 y, MASK mask)
|
||||
{
|
||||
if( !mCur->hasMouseCapture() )
|
||||
{
|
||||
setCurrentTool( mManip );
|
||||
}
|
||||
return mCur->handleHover( x, y, mask );
|
||||
}
|
||||
|
||||
|
||||
BOOL LLToolCompRotate::handleMouseDown(S32 x, S32 y, MASK mask)
|
||||
{
|
||||
mMouseDown = TRUE;
|
||||
gViewerWindow->pickAsync(x, y, mask, pickCallback);
|
||||
return TRUE;
|
||||
}
|
||||
|
||||
void LLToolCompRotate::pickCallback(const LLPickInfo& pick_info)
|
||||
{
|
||||
LLViewerObject* hit_obj = pick_info.getObject();
|
||||
|
||||
LLToolCompRotate::getInstance()->mManip->highlightManipulators(pick_info.mMousePt.mX, pick_info.mMousePt.mY);
|
||||
if (!LLToolCompRotate::getInstance()->mMouseDown)
|
||||
{
|
||||
// fast click on object, but mouse is already up...just do select
|
||||
LLToolCompRotate::getInstance()->mSelectRect->handleObjectSelection(pick_info, gSavedSettings.getBOOL("EditLinkedParts"), FALSE);
|
||||
return;
|
||||
}
|
||||
|
||||
if( hit_obj || LLToolCompRotate::getInstance()->mManip->getHighlightedPart() != LLManip::LL_NO_PART)
|
||||
{
|
||||
if (LLToolCompRotate::getInstance()->mManip->getSelection()->getObjectCount())
|
||||
{
|
||||
LLEditMenuHandler::gEditMenuHandler = LLSelectMgr::getInstance();
|
||||
}
|
||||
if( LLManip::LL_NO_PART != LLToolCompRotate::getInstance()->mManip->getHighlightedPart() )
|
||||
{
|
||||
LLToolCompRotate::getInstance()->setCurrentTool( LLToolCompRotate::getInstance()->mManip );
|
||||
LLToolCompRotate::getInstance()->mManip->handleMouseDownOnPart( pick_info.mMousePt.mX, pick_info.mMousePt.mY, pick_info.mKeyMask );
|
||||
}
|
||||
else
|
||||
{
|
||||
LLToolCompRotate::getInstance()->setCurrentTool( LLToolCompRotate::getInstance()->mSelectRect );
|
||||
LLToolCompRotate::getInstance()->mSelectRect->handlePick( pick_info );
|
||||
}
|
||||
}
|
||||
else
|
||||
{
|
||||
LLToolCompRotate::getInstance()->setCurrentTool( LLToolCompRotate::getInstance()->mSelectRect );
|
||||
LLToolCompRotate::getInstance()->mSelectRect->handlePick( pick_info );
|
||||
}
|
||||
}
|
||||
|
||||
BOOL LLToolCompRotate::handleMouseUp(S32 x, S32 y, MASK mask)
|
||||
{
|
||||
mMouseDown = FALSE;
|
||||
return LLToolComposite::handleMouseUp(x, y, mask);
|
||||
}
|
||||
|
||||
LLTool* LLToolCompRotate::getOverrideTool(MASK mask)
|
||||
{
|
||||
if (mask == (MASK_CONTROL | MASK_SHIFT))
|
||||
{
|
||||
return LLToolCompScale::getInstance();
|
||||
}
|
||||
return LLToolComposite::getOverrideTool(mask);
|
||||
}
|
||||
|
||||
BOOL LLToolCompRotate::handleDoubleClick(S32 x, S32 y, MASK mask)
|
||||
{
|
||||
if (!mManip->getSelection()->isEmpty() && mManip->getHighlightedPart() == LLManip::LL_NO_PART)
|
||||
{
|
||||
// You should already have an object selected from the mousedown.
|
||||
// If so, show its properties
|
||||
gFloaterTools->showPanel(LLFloaterTools::PANEL_CONTENTS);
|
||||
//gBuildView->setPropertiesPanelOpen(TRUE);
|
||||
return TRUE;
|
||||
}
|
||||
else
|
||||
{
|
||||
// Nothing selected means the first mouse click was probably
|
||||
// bad, so try again.
|
||||
return handleMouseDown(x, y, mask);
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
void LLToolCompRotate::render()
|
||||
{
|
||||
mCur->render();
|
||||
|
||||
if( mCur != mManip )
|
||||
{
|
||||
LLGLDepthTest gls_depth(GL_TRUE, GL_FALSE);
|
||||
mManip->renderGuidelines();
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
//-----------------------------------------------------------------------
|
||||
// LLToolCompGun
|
||||
|
||||
LLToolCompGun::LLToolCompGun()
|
||||
: LLToolComposite(std::string("Mouselook"))
|
||||
{
|
||||
mGun = new LLToolGun(this);
|
||||
mGrab = new LLToolGrab(this);
|
||||
mNull = sNullTool;
|
||||
|
||||
setCurrentTool(mGun);
|
||||
mDefault = mGun;
|
||||
}
|
||||
|
||||
|
||||
LLToolCompGun::~LLToolCompGun()
|
||||
{
|
||||
delete mGun;
|
||||
mGun = NULL;
|
||||
|
||||
delete mGrab;
|
||||
mGrab = NULL;
|
||||
|
||||
// don't delete a static object
|
||||
// delete mNull;
|
||||
mNull = NULL;
|
||||
}
|
||||
|
||||
BOOL LLToolCompGun::handleHover(S32 x, S32 y, MASK mask)
|
||||
{
|
||||
// *NOTE: This hack is here to make mouselook kick in again after
|
||||
// item selected from context menu.
|
||||
if ( mCur == mNull && !gPopupMenuView->getVisible() )
|
||||
{
|
||||
LLSelectMgr::getInstance()->deselectAll();
|
||||
setCurrentTool( (LLTool*) mGrab );
|
||||
}
|
||||
|
||||
// Note: if the tool changed, we can't delegate the current mouse event
|
||||
// after the change because tools can modify the mouse during selection and deselection.
|
||||
// Instead we let the current tool handle the event and then make the change.
|
||||
// The new tool will take effect on the next frame.
|
||||
|
||||
mCur->handleHover( x, y, mask );
|
||||
|
||||
// If mouse button not down...
|
||||
if( !gViewerWindow->getLeftMouseDown())
|
||||
{
|
||||
// let ALT switch from gun to grab
|
||||
if ( mCur == mGun && (mask & MASK_ALT) )
|
||||
{
|
||||
setCurrentTool( (LLTool*) mGrab );
|
||||
}
|
||||
else if ( mCur == mGrab && !(mask & MASK_ALT) )
|
||||
{
|
||||
setCurrentTool( (LLTool*) mGun );
|
||||
setMouseCapture(TRUE);
|
||||
}
|
||||
}
|
||||
|
||||
return TRUE;
|
||||
}
|
||||
|
||||
|
||||
BOOL LLToolCompGun::handleMouseDown(S32 x, S32 y, MASK mask)
|
||||
{
|
||||
// if the left button is grabbed, don't put up the pie menu
|
||||
if (gAgent.leftButtonGrabbed())
|
||||
{
|
||||
gAgent.setControlFlags(AGENT_CONTROL_ML_LBUTTON_DOWN);
|
||||
return FALSE;
|
||||
}
|
||||
|
||||
// On mousedown, start grabbing
|
||||
gGrabTransientTool = this;
|
||||
LLToolMgr::getInstance()->getCurrentToolset()->selectTool( (LLTool*) mGrab );
|
||||
|
||||
return LLToolGrab::getInstance()->handleMouseDown(x, y, mask);
|
||||
}
|
||||
|
||||
|
||||
BOOL LLToolCompGun::handleDoubleClick(S32 x, S32 y, MASK mask)
|
||||
{
|
||||
// if the left button is grabbed, don't put up the pie menu
|
||||
if (gAgent.leftButtonGrabbed())
|
||||
{
|
||||
gAgent.setControlFlags(AGENT_CONTROL_ML_LBUTTON_DOWN);
|
||||
return FALSE;
|
||||
}
|
||||
|
||||
// On mousedown, start grabbing
|
||||
gGrabTransientTool = this;
|
||||
LLToolMgr::getInstance()->getCurrentToolset()->selectTool( (LLTool*) mGrab );
|
||||
|
||||
return LLToolGrab::getInstance()->handleDoubleClick(x, y, mask);
|
||||
}
|
||||
|
||||
|
||||
BOOL LLToolCompGun::handleRightMouseDown(S32 x, S32 y, MASK mask)
|
||||
{
|
||||
/* JC - suppress context menu 8/29/2002
|
||||
|
||||
// On right mouse, go through some convoluted steps to
|
||||
// make the build menu appear.
|
||||
setCurrentTool( (LLTool*) mNull );
|
||||
|
||||
// This should return FALSE, meaning the context menu will
|
||||
// be shown.
|
||||
return FALSE;
|
||||
*/
|
||||
|
||||
// Returning true will suppress the context menu
|
||||
return TRUE;
|
||||
}
|
||||
|
||||
|
||||
BOOL LLToolCompGun::handleMouseUp(S32 x, S32 y, MASK mask)
|
||||
{
|
||||
gAgent.setControlFlags(AGENT_CONTROL_ML_LBUTTON_UP);
|
||||
setCurrentTool( (LLTool*) mGun );
|
||||
return TRUE;
|
||||
}
|
||||
|
||||
void LLToolCompGun::onMouseCaptureLost()
|
||||
{
|
||||
if (mComposite)
|
||||
{
|
||||
mComposite->onMouseCaptureLost();
|
||||
return;
|
||||
}
|
||||
mCur->onMouseCaptureLost();
|
||||
}
|
||||
|
||||
void LLToolCompGun::handleSelect()
|
||||
{
|
||||
LLToolComposite::handleSelect();
|
||||
setMouseCapture(TRUE);
|
||||
}
|
||||
|
||||
void LLToolCompGun::handleDeselect()
|
||||
{
|
||||
LLToolComposite::handleDeselect();
|
||||
setMouseCapture(FALSE);
|
||||
}
|
||||
|
||||
|
||||
BOOL LLToolCompGun::handleScrollWheel(S32 x, S32 y, S32 clicks)
|
||||
{
|
||||
if (clicks > 0)
|
||||
{
|
||||
gAgent.changeCameraToDefault();
|
||||
|
||||
}
|
||||
return TRUE;
|
||||
}
|
||||
Reference in New Issue
Block a user