aboutsummaryrefslogtreecommitdiffstatshomepage
path: root/linden/indra/llui/llspinctrl.cpp
diff options
context:
space:
mode:
Diffstat (limited to 'linden/indra/llui/llspinctrl.cpp')
-rw-r--r--linden/indra/llui/llspinctrl.cpp29
1 files changed, 25 insertions, 4 deletions
diff --git a/linden/indra/llui/llspinctrl.cpp b/linden/indra/llui/llspinctrl.cpp
index 1f33279..668ddfa 100644
--- a/linden/indra/llui/llspinctrl.cpp
+++ b/linden/indra/llui/llspinctrl.cpp
@@ -4,6 +4,7 @@
4 * 4 *
5 * Copyright (c) 2001-2007, Linden Research, Inc. 5 * Copyright (c) 2001-2007, Linden Research, Inc.
6 * 6 *
7 * Second Life Viewer Source Code
7 * The source code in this file ("Source Code") is provided by Linden Lab 8 * The source code in this file ("Source Code") is provided by Linden Lab
8 * to you under the terms of the GNU General Public License, version 2.0 9 * to you under the terms of the GNU General Public License, version 2.0
9 * ("GPL"), unless you have obtained a separate licensing agreement 10 * ("GPL"), unless you have obtained a separate licensing agreement
@@ -142,6 +143,23 @@ LLSpinCtrl::~LLSpinCtrl()
142} 143}
143 144
144 145
146F32 clamp_precision(F32 value, S32 decimal_precision)
147{
148 // pow() isn't perfect
149
150 F64 clamped_value = value;
151 for (S32 i = 0; i < decimal_precision; i++)
152 clamped_value *= 10.0;
153
154 clamped_value = llround((F32)clamped_value);
155
156 for (S32 i = 0; i < decimal_precision; i++)
157 clamped_value /= 10.0;
158
159 return (F32)clamped_value;
160}
161
162
145// static 163// static
146void LLSpinCtrl::onUpBtn( void *userdata ) 164void LLSpinCtrl::onUpBtn( void *userdata )
147{ 165{
@@ -150,6 +168,7 @@ void LLSpinCtrl::onUpBtn( void *userdata )
150 { 168 {
151 // use getValue()/setValue() to force reload from/to control 169 // use getValue()/setValue() to force reload from/to control
152 F32 val = (F32)self->getValue().asReal() + self->mIncrement; 170 F32 val = (F32)self->getValue().asReal() + self->mIncrement;
171 val = clamp_precision(val, self->mPrecision);
153 val = llmin( val, self->mMaxValue ); 172 val = llmin( val, self->mMaxValue );
154 173
155 if( self->mValidateCallback ) 174 if( self->mValidateCallback )
@@ -182,6 +201,7 @@ void LLSpinCtrl::onDownBtn( void *userdata )
182 if( self->getEnabled() ) 201 if( self->getEnabled() )
183 { 202 {
184 F32 val = (F32)self->getValue().asReal() - self->mIncrement; 203 F32 val = (F32)self->getValue().asReal() - self->mIncrement;
204 val = clamp_precision(val, self->mPrecision);
185 val = llmax( val, self->mMinValue ); 205 val = llmax( val, self->mMinValue );
186 206
187 if( self->mValidateCallback ) 207 if( self->mValidateCallback )
@@ -243,12 +263,13 @@ void LLSpinCtrl::clear()
243} 263}
244 264
245 265
266
246void LLSpinCtrl::updateEditor() 267void LLSpinCtrl::updateEditor()
247{ 268{
248 LLLocale locale(LLLocale::USER_LOCALE); 269 LLLocale locale(LLLocale::USER_LOCALE);
249 270
250 // Don't display very small negative values as -0.000 271 // Don't display very small negative values as -0.000
251 F32 displayed_value = (F32)floor(getValue().asReal() * pow(10.0, (F64)mPrecision) + 0.5) / (F32)pow(10.0, (F64)mPrecision); 272 F32 displayed_value = clamp_precision((F32)getValue().asReal(), mPrecision);
252 273
253// if( S32( displayed_value * pow( 10, mPrecision ) ) == 0 ) 274// if( S32( displayed_value * pow( 10, mPrecision ) ) == 0 )
254// { 275// {
@@ -320,7 +341,7 @@ void LLSpinCtrl::setFocus(BOOL b)
320 341
321void LLSpinCtrl::setEnabled(BOOL b) 342void LLSpinCtrl::setEnabled(BOOL b)
322{ 343{
323 LLUICtrl::setEnabled( b ); 344 LLView::setEnabled( b );
324 mEditor->setEnabled( b ); 345 mEditor->setEnabled( b );
325} 346}
326 347
@@ -335,8 +356,8 @@ void LLSpinCtrl::setTentative(BOOL b)
335BOOL LLSpinCtrl::isMouseHeldDown() 356BOOL LLSpinCtrl::isMouseHeldDown()
336{ 357{
337 return 358 return
338 gFocusMgr.getMouseCapture() == mDownBtn || 359 mDownBtn->hasMouseCapture()
339 gFocusMgr.getMouseCapture() == mUpBtn; 360 || mUpBtn->hasMouseCapture();
340} 361}
341 362
342void LLSpinCtrl::onCommit() 363void LLSpinCtrl::onCommit()