aboutsummaryrefslogtreecommitdiffstatshomepage
path: root/linden/indra/llui/llpanel.cpp
diff options
context:
space:
mode:
Diffstat (limited to '')
-rw-r--r--linden/indra/llui/llpanel.cpp29
1 files changed, 22 insertions, 7 deletions
diff --git a/linden/indra/llui/llpanel.cpp b/linden/indra/llui/llpanel.cpp
index af8aa21..7430e50 100644
--- a/linden/indra/llui/llpanel.cpp
+++ b/linden/indra/llui/llpanel.cpp
@@ -356,6 +356,13 @@ BOOL LLPanel::handleKeyHere( KEY key, MASK mask, BOOL called_from_parent )
356 if( getVisible() && getEnabled() && 356 if( getVisible() && getEnabled() &&
357 gFocusMgr.childHasKeyboardFocus(this) && !called_from_parent ) 357 gFocusMgr.childHasKeyboardFocus(this) && !called_from_parent )
358 { 358 {
359 // handle user hitting ESC to defocus
360 if (key == KEY_ESCAPE)
361 {
362 gFocusMgr.setKeyboardFocus(NULL);
363 return TRUE;
364 }
365
359 LLUICtrl* cur_focus = gFocusMgr.getKeyboardFocus(); 366 LLUICtrl* cur_focus = gFocusMgr.getKeyboardFocus();
360 // If we have a default button, click it when 367 // If we have a default button, click it when
361 // return is pressed, unless current focus is a return-capturing button 368 // return is pressed, unless current focus is a return-capturing button
@@ -1322,6 +1329,7 @@ LLView* LLLayoutStack::fromXML(LLXMLNodePtr node, LLView *parent, LLUICtrlFactor
1322 } 1329 }
1323 } 1330 }
1324 } 1331 }
1332 layout_stackp->updateLayout();
1325 1333
1326 return layout_stackp; 1334 return layout_stackp;
1327} 1335}
@@ -1442,10 +1450,14 @@ void LLLayoutStack::updateLayout(BOOL force_resize)
1442 { 1450 {
1443 // panels that are not fully visible do not count towards shrink headroom 1451 // panels that are not fully visible do not count towards shrink headroom
1444 if ((*panel_it)->mVisibleAmt < 1.f) 1452 if ((*panel_it)->mVisibleAmt < 1.f)
1453 {
1445 continue; 1454 continue;
1455 }
1446 // if currently resizing a panel or the panel is flagged as not automatically resizing 1456 // if currently resizing a panel or the panel is flagged as not automatically resizing
1447 // only track total available headroom, but don't use it for automatic resize logic 1457 // only track total available headroom, but don't use it for automatic resize logic
1448 if ((*panel_it)->mResizeBar->hasMouseCapture() || (!(*panel_it)->mAutoResize && !force_resize)) 1458 if ((*panel_it)->mResizeBar->hasMouseCapture()
1459 || (!(*panel_it)->mAutoResize
1460 && !force_resize))
1449 { 1461 {
1450 if (mOrientation == HORIZONTAL) 1462 if (mOrientation == HORIZONTAL)
1451 { 1463 {
@@ -1498,7 +1510,9 @@ void LLLayoutStack::updateLayout(BOOL force_resize)
1498 S32 delta_size = 0; 1510 S32 delta_size = 0;
1499 1511
1500 // if panel can automatically resize (not animating, and resize flag set)... 1512 // if panel can automatically resize (not animating, and resize flag set)...
1501 if ((*panel_it)->mVisibleAmt == 1.f && (force_resize || (*panel_it)->mAutoResize) && !(*panel_it)->mResizeBar->hasMouseCapture()) 1513 if ((*panel_it)->mVisibleAmt == 1.f
1514 && (force_resize || (*panel_it)->mAutoResize)
1515 && !(*panel_it)->mResizeBar->hasMouseCapture())
1502 { 1516 {
1503 if (mOrientation == HORIZONTAL) 1517 if (mOrientation == HORIZONTAL)
1504 { 1518 {
@@ -1506,7 +1520,7 @@ void LLLayoutStack::updateLayout(BOOL force_resize)
1506 if (pixels_to_distribute < 0) 1520 if (pixels_to_distribute < 0)
1507 { 1521 {
1508 // shrink proportionally to amount over minimum 1522 // shrink proportionally to amount over minimum
1509 delta_size = llround((F32)pixels_to_distribute * (F32)(cur_width - (*panel_it)->mMinWidth) / (F32)shrink_headroom_available); 1523 delta_size = (shrink_headroom_available > 0) ? llround((F32)pixels_to_distribute * (F32)(cur_width - (*panel_it)->mMinWidth) / (F32)shrink_headroom_available) : 0;
1510 } 1524 }
1511 else 1525 else
1512 { 1526 {
@@ -1525,7 +1539,7 @@ void LLLayoutStack::updateLayout(BOOL force_resize)
1525 if (pixels_to_distribute < 0) 1539 if (pixels_to_distribute < 0)
1526 { 1540 {
1527 // shrink proportionally to amount over minimum 1541 // shrink proportionally to amount over minimum
1528 delta_size = llround((F32)pixels_to_distribute * (F32)(cur_height - (*panel_it)->mMinHeight) / (F32)shrink_headroom_available); 1542 delta_size = (shrink_headroom_available > 0) ? llround((F32)pixels_to_distribute * (F32)(cur_height - (*panel_it)->mMinHeight) / (F32)shrink_headroom_available) : 0;
1529 } 1543 }
1530 else 1544 else
1531 { 1545 {
@@ -1617,9 +1631,10 @@ void LLLayoutStack::updateLayout(BOOL force_resize)
1617 } 1631 }
1618 1632
1619 // not enough room to fit existing contents 1633 // not enough room to fit existing contents
1620 if (!force_resize 1634 if (force_resize == FALSE
1621 && ((cur_y != -mPanelSpacing) 1635 // layout did not complete by reaching target position
1622 || (cur_x != mRect.getWidth() + mPanelSpacing))) 1636 && ((mOrientation == VERTICAL && cur_y != -mPanelSpacing)
1637 || (mOrientation == HORIZONTAL && cur_x != mRect.getWidth() + mPanelSpacing)))
1623 { 1638 {
1624 // do another layout pass with all stacked elements contributing 1639 // do another layout pass with all stacked elements contributing
1625 // even those that don't usually resize 1640 // even those that don't usually resize