diff options
Diffstat (limited to 'indra/llui/llbutton.cpp')
| -rw-r--r-- | indra/llui/llbutton.cpp | 64 | 
1 files changed, 35 insertions, 29 deletions
diff --git a/indra/llui/llbutton.cpp b/indra/llui/llbutton.cpp index 34f3049f2e..f26711065a 100644 --- a/indra/llui/llbutton.cpp +++ b/indra/llui/llbutton.cpp @@ -1,32 +1,27 @@ +  /**    * @file llbutton.cpp   * @brief LLButton base class   * - * $LicenseInfo:firstyear=2001&license=viewergpl$ - *  - * Copyright (c) 2001-2009, Linden Research, Inc. - *  + * $LicenseInfo:firstyear=2001&license=viewerlgpl$   * 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 + * Copyright (C) 2010, Linden Research, Inc.   *  - * 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 + * This library is free software; you can redistribute it and/or + * modify it under the terms of the GNU Lesser General Public + * License as published by the Free Software Foundation; + * version 2.1 of the License only.   *  - * 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. + * This library is distributed in the hope that it will be useful, + * but WITHOUT ANY WARRANTY; without even the implied warranty of + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU + * Lesser General Public License for more details.   *  - * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO - * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, - * COMPLETENESS OR PERFORMANCE. + * You should have received a copy of the GNU Lesser General Public + * License along with this library; if not, write to the Free Software + * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA  02110-1301  USA + *  + * Linden Research, Inc., 945 Battery Street, San Francisco, CA  94111  USA   * $/LicenseInfo$   */ @@ -504,7 +499,7 @@ void LLButton::onMouseEnter(S32 x, S32 y, MASK mask)  	if (isInEnabledChain())  		mNeedsHighlight = TRUE; -} +	}  void LLButton::onMouseLeave(S32 x, S32 y, MASK mask)  { @@ -563,15 +558,19 @@ void LLButton::draw()  		pressed_by_keyboard = gKeyboard->getKeyDown(' ') || (mCommitOnReturn && gKeyboard->getKeyDown(KEY_RETURN));  	} -	// Unselected image assignments -	S32 local_mouse_x; -	S32 local_mouse_y; -	LLUI::getMousePositionLocal(this, &local_mouse_x, &local_mouse_y); +	bool mouse_pressed_and_over = false; +	if (hasMouseCapture()) +	{ +		S32 local_mouse_x ; +		S32 local_mouse_y; +		LLUI::getMousePositionLocal(this, &local_mouse_x, &local_mouse_y); +		mouse_pressed_and_over = pointInView(local_mouse_x, local_mouse_y); +	}  	bool enabled = isInEnabledChain();  	bool pressed = pressed_by_keyboard  -					|| (hasMouseCapture() && pointInView(local_mouse_x, local_mouse_y)) +					|| mouse_pressed_and_over  					|| mForcePressedState;  	bool selected = getToggleState(); @@ -1120,7 +1119,7 @@ void LLButton::setFloaterToggle(LLUICtrl* ctrl, const LLSD& sdname)  	// Get the visibility control name for the floater  	std::string vis_control_name = LLFloaterReg::declareVisibilityControl(sdname.asString());  	// Set the button control value (toggle state) to the floater visibility control (Sets the value as well) -	button->setControlVariable(LLUI::sSettingGroups["floater"]->getControl(vis_control_name)); +	button->setControlVariable(LLFloater::getControlGroup()->getControl(vis_control_name));  	// Set the clicked callback to toggle the floater  	button->setClickedCallback(boost::bind(&LLFloaterReg::toggleFloaterInstance, sdname));  } @@ -1134,7 +1133,7 @@ void LLButton::setDockableFloaterToggle(LLUICtrl* ctrl, const LLSD& sdname)  	// Get the visibility control name for the floater  	std::string vis_control_name = LLFloaterReg::declareVisibilityControl(sdname.asString());  	// Set the button control value (toggle state) to the floater visibility control (Sets the value as well) -	button->setControlVariable(LLUI::sSettingGroups["floater"]->getControl(vis_control_name)); +	button->setControlVariable(LLFloater::getControlGroup()->getControl(vis_control_name));  	// Set the clicked callback to toggle the floater  	button->setClickedCallback(boost::bind(&LLDockableFloater::toggleInstance, sdname));  } @@ -1162,3 +1161,10 @@ void LLButton::resetMouseDownTimer()  	mMouseDownTimer.stop();  	mMouseDownTimer.reset();  } + + +BOOL LLButton::handleDoubleClick(S32 x, S32 y, MASK mask) +{ +	// just treat a double click as a second click +	return handleMouseDown(x, y, mask); +}  | 
