aboutsummaryrefslogtreecommitdiffstatshomepage
path: root/linden/indra/llui/llfocusmgr.cpp
diff options
context:
space:
mode:
Diffstat (limited to 'linden/indra/llui/llfocusmgr.cpp')
-rw-r--r--linden/indra/llui/llfocusmgr.cpp70
1 files changed, 30 insertions, 40 deletions
diff --git a/linden/indra/llui/llfocusmgr.cpp b/linden/indra/llui/llfocusmgr.cpp
index f02996b..f79164e 100644
--- a/linden/indra/llui/llfocusmgr.cpp
+++ b/linden/indra/llui/llfocusmgr.cpp
@@ -4,6 +4,7 @@
4 * 4 *
5 * Copyright (c) 2002-2007, Linden Research, Inc. 5 * Copyright (c) 2002-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
@@ -40,18 +41,16 @@ LLFocusMgr::LLFocusMgr()
40 mLockedView( NULL ), 41 mLockedView( NULL ),
41 mKeyboardLockedFocusLostCallback( NULL ), 42 mKeyboardLockedFocusLostCallback( NULL ),
42 mMouseCaptor( NULL ), 43 mMouseCaptor( NULL ),
43 mMouseCaptureLostCallback( NULL ),
44 mKeyboardFocus( NULL ), 44 mKeyboardFocus( NULL ),
45 mDefaultKeyboardFocus( NULL ), 45 mDefaultKeyboardFocus( NULL ),
46 mKeyboardFocusLostCallback( NULL ), 46 mKeyboardFocusLostCallback( NULL ),
47 mTopView( NULL ), 47 mTopCtrl( NULL ),
48 mTopViewLostCallback( NULL ),
49 mFocusWeight(0.f), 48 mFocusWeight(0.f),
50 mAppHasFocus(TRUE) // Macs don't seem to notify us that we've gotten focus, so default to true 49 mAppHasFocus(TRUE) // Macs don't seem to notify us that we've gotten focus, so default to true
51 #ifdef _DEBUG 50 #ifdef _DEBUG
52 , mMouseCaptorName("none") 51 , mMouseCaptorName("none")
53 , mKeyboardFocusName("none") 52 , mKeyboardFocusName("none")
54 , mTopViewName("none") 53 , mTopCtrlName("none")
55 #endif 54 #endif
56{ 55{
57} 56}
@@ -65,7 +64,7 @@ void LLFocusMgr::releaseFocusIfNeeded( LLView* view )
65{ 64{
66 if( childHasMouseCapture( view ) ) 65 if( childHasMouseCapture( view ) )
67 { 66 {
68 setMouseCapture( NULL, NULL ); 67 setMouseCapture( NULL );
69 } 68 }
70 69
71 if( childHasKeyboardFocus( view )) 70 if( childHasKeyboardFocus( view ))
@@ -82,9 +81,9 @@ void LLFocusMgr::releaseFocusIfNeeded( LLView* view )
82 } 81 }
83 } 82 }
84 83
85 if( childIsTopView( view ) ) 84 if( childIsTopCtrl( view ) )
86 { 85 {
87 setTopView( NULL, NULL ); 86 setTopCtrl( NULL );
88 } 87 }
89} 88}
90 89
@@ -127,13 +126,13 @@ void LLFocusMgr::setKeyboardFocus(LLUICtrl* new_focus, FocusLostCallback on_focu
127 126
128 // If we've got a default keyboard focus, and the caller is 127 // If we've got a default keyboard focus, and the caller is
129 // releasing keyboard focus, move to the default. 128 // releasing keyboard focus, move to the default.
130 if (mDefaultKeyboardFocus != NULL && new_focus == NULL) 129 if (mDefaultKeyboardFocus != NULL && mKeyboardFocus == NULL)
131 { 130 {
132 mDefaultKeyboardFocus->setFocus(TRUE); 131 mDefaultKeyboardFocus->setFocus(TRUE);
133 } 132 }
134 133
135 LLView* focus_subtree = new_focus; 134 LLView* focus_subtree = mKeyboardFocus;
136 LLView* viewp = new_focus; 135 LLView* viewp = mKeyboardFocus;
137 // find root-most focus root 136 // find root-most focus root
138 while(viewp) 137 while(viewp)
139 { 138 {
@@ -147,13 +146,13 @@ void LLFocusMgr::setKeyboardFocus(LLUICtrl* new_focus, FocusLostCallback on_focu
147 146
148 if (focus_subtree) 147 if (focus_subtree)
149 { 148 {
150 mFocusHistory[focus_subtree->mViewHandle] = new_focus ? new_focus->mViewHandle : LLViewHandle::sDeadHandle; 149 mFocusHistory[focus_subtree->mViewHandle] = mKeyboardFocus ? mKeyboardFocus->mViewHandle : LLViewHandle::sDeadHandle;
151 } 150 }
152 } 151 }
153 152
154 if (lock) 153 if (lock)
155 { 154 {
156 mLockedView = new_focus; 155 mLockedView = mKeyboardFocus;
157 mKeyboardLockedFocusLostCallback = on_focus_lost; 156 mKeyboardLockedFocusLostCallback = on_focus_lost;
158 } 157 }
159} 158}
@@ -217,16 +216,13 @@ void LLFocusMgr::removeKeyboardFocusWithoutCallback( LLView* focus )
217} 216}
218 217
219 218
220void LLFocusMgr::setMouseCapture( LLMouseHandler* new_captor, void (*on_capture_lost)(LLMouseHandler* old_captor) ) 219void LLFocusMgr::setMouseCapture( LLMouseHandler* new_captor )
221{ 220{
222 //if (mFocusLocked) 221 //if (mFocusLocked)
223 //{ 222 //{
224 // return; 223 // return;
225 //} 224 //}
226 225
227 void (*old_callback)(LLMouseHandler*) = mMouseCaptureLostCallback;
228 mMouseCaptureLostCallback = on_capture_lost;
229
230 if( new_captor != mMouseCaptor ) 226 if( new_captor != mMouseCaptor )
231 { 227 {
232 LLMouseHandler* old_captor = mMouseCaptor; 228 LLMouseHandler* old_captor = mMouseCaptor;
@@ -249,9 +245,9 @@ void LLFocusMgr::setMouseCapture( LLMouseHandler* new_captor, void (*on_capture_
249 } 245 }
250 */ 246 */
251 247
252 if( old_callback ) 248 if( old_captor )
253 { 249 {
254 old_callback( old_captor ); 250 old_captor->onMouseCaptureLost();
255 } 251 }
256 252
257 #ifdef _DEBUG 253 #ifdef _DEBUG
@@ -269,7 +265,6 @@ void LLFocusMgr::removeMouseCaptureWithoutCallback( LLMouseHandler* captor )
269 if( mMouseCaptor == captor ) 265 if( mMouseCaptor == captor )
270 { 266 {
271 mMouseCaptor = NULL; 267 mMouseCaptor = NULL;
272 mMouseCaptureLostCallback = NULL;
273 #ifdef _DEBUG 268 #ifdef _DEBUG
274 mMouseCaptorName = "none"; 269 mMouseCaptorName = "none";
275 #endif 270 #endif
@@ -277,9 +272,9 @@ void LLFocusMgr::removeMouseCaptureWithoutCallback( LLMouseHandler* captor )
277} 272}
278 273
279 274
280BOOL LLFocusMgr::childIsTopView( LLView* parent ) 275BOOL LLFocusMgr::childIsTopCtrl( LLView* parent )
281{ 276{
282 LLView* top_view = mTopView; 277 LLView* top_view = (LLView*)mTopCtrl;
283 while( top_view ) 278 while( top_view )
284 { 279 {
285 if( top_view == parent ) 280 if( top_view == parent )
@@ -294,36 +289,25 @@ BOOL LLFocusMgr::childIsTopView( LLView* parent )
294 289
295 290
296// set new_top = NULL to release top_view. 291// set new_top = NULL to release top_view.
297void LLFocusMgr::setTopView( LLView* new_top, void (*on_top_lost)(LLView* old_top) ) 292void LLFocusMgr::setTopCtrl( LLUICtrl* new_top )
298{ 293{
299 void (*old_callback)(LLView*) = mTopViewLostCallback; 294 if( new_top != mTopCtrl )
300 mTopViewLostCallback = on_top_lost;
301
302 if( new_top != mTopView )
303 { 295 {
304 LLView* old_top = mTopView; 296 mTopCtrl = new_top;
305 mTopView = new_top;
306 if( old_callback )
307 {
308 old_callback( old_top );
309 }
310
311 mTopView = new_top;
312 297
313 #ifdef _DEBUG 298 #ifdef _DEBUG
314 mTopViewName = new_top ? new_top->getName() : "none"; 299 mTopCtrlName = new_top ? new_top->getName() : "none";
315 #endif 300 #endif
316 } 301 }
317} 302}
318 303
319void LLFocusMgr::removeTopViewWithoutCallback( LLView* top_view ) 304void LLFocusMgr::removeTopCtrlWithoutCallback( LLUICtrl* top_view )
320{ 305{
321 if( mTopView == top_view ) 306 if( mTopCtrl == top_view )
322 { 307 {
323 mTopView = NULL; 308 mTopCtrl = NULL;
324 mTopViewLostCallback = NULL;
325 #ifdef _DEBUG 309 #ifdef _DEBUG
326 mTopViewName = "none"; 310 mTopCtrlName = "none";
327 #endif 311 #endif
328 } 312 }
329} 313}
@@ -362,6 +346,12 @@ void LLFocusMgr::setAppHasFocus(BOOL focus)
362 { 346 {
363 triggerFocusFlash(); 347 triggerFocusFlash();
364 } 348 }
349
350 // release focus from "top ctrl"s, which generally hides them
351 if (!focus && mTopCtrl && mTopCtrl->hasFocus())
352 {
353 mTopCtrl->setFocus(FALSE);
354 }
365 mAppHasFocus = focus; 355 mAppHasFocus = focus;
366} 356}
367 357