aboutsummaryrefslogtreecommitdiffstatshomepage
path: root/linden/indra/llui/lltabcontainer.cpp
diff options
context:
space:
mode:
Diffstat (limited to 'linden/indra/llui/lltabcontainer.cpp')
-rw-r--r--linden/indra/llui/lltabcontainer.cpp114
1 files changed, 60 insertions, 54 deletions
diff --git a/linden/indra/llui/lltabcontainer.cpp b/linden/indra/llui/lltabcontainer.cpp
index 01c06c3..135931d 100644
--- a/linden/indra/llui/lltabcontainer.cpp
+++ b/linden/indra/llui/lltabcontainer.cpp
@@ -70,6 +70,7 @@ LLTabContainerCommon::LLTabContainerCommon(
70 : 70 :
71 LLPanel(name, rect, bordered), 71 LLPanel(name, rect, bordered),
72 mCurrentTabIdx(-1), 72 mCurrentTabIdx(-1),
73 mTabsHidden(FALSE),
73 mScrolled(FALSE), 74 mScrolled(FALSE),
74 mScrollPos(0), 75 mScrollPos(0),
75 mScrollPosPixels(0), 76 mScrollPosPixels(0),
@@ -95,6 +96,7 @@ LLTabContainerCommon::LLTabContainerCommon(
95 : 96 :
96 LLPanel(name, rect_control, bordered), 97 LLPanel(name, rect_control, bordered),
97 mCurrentTabIdx(-1), 98 mCurrentTabIdx(-1),
99 mTabsHidden(FALSE),
98 mScrolled(FALSE), 100 mScrolled(FALSE),
99 mScrollPos(0), 101 mScrollPos(0),
100 mScrollPosPixels(0), 102 mScrollPosPixels(0),
@@ -147,11 +149,11 @@ void LLTabContainerCommon::addPlaceholder(LLPanel* child, const LLString& label)
147 addTabPanel(child, label, FALSE, NULL, NULL, 0, TRUE); 149 addTabPanel(child, label, FALSE, NULL, NULL, 0, TRUE);
148} 150}
149 151
150void LLTabContainerCommon::lockTabs() 152void LLTabContainerCommon::lockTabs(S32 num_tabs)
151{ 153{
152 // count current tabs and ensure no new tabs get 154 // count current tabs or use supplied value and ensure no new tabs get
153 // inserted between them 155 // inserted between them
154 mLockedTabCount = getTabCount(); 156 mLockedTabCount = num_tabs > 0 ? num_tabs : getTabCount();
155} 157}
156 158
157void LLTabContainerCommon::removeTabPanel(LLPanel* child) 159void LLTabContainerCommon::removeTabPanel(LLPanel* child)
@@ -542,12 +544,12 @@ void LLTabContainerCommon::setTabPanelFlashing(LLPanel* child, BOOL state )
542 } 544 }
543} 545}
544 546
545void LLTabContainerCommon::setTabImage(LLPanel* child, std::string img_name) 547void LLTabContainerCommon::setTabImage(LLPanel* child, std::string img_name, const LLColor4& color)
546{ 548{
547 LLTabTuple* tuple = getTabByPanel(child); 549 LLTabTuple* tuple = getTabByPanel(child);
548 if( tuple ) 550 if( tuple )
549 { 551 {
550 tuple->mButton->setImageOverlay(img_name, LLFontGL::RIGHT); 552 tuple->mButton->setImageOverlay(img_name, LLFontGL::RIGHT, color);
551 } 553 }
552} 554}
553 555
@@ -667,6 +669,8 @@ LLView* LLTabContainerCommon::fromXML(LLXMLNodePtr node, LLView *parent, LLUICtr
667 } 669 }
668 } 670 }
669 671
672 node->getAttributeBOOL("hide_tabs", tab_container->mTabsHidden);
673
670 tab_container->setPanelParameters(node, parent); 674 tab_container->setPanelParameters(node, parent);
671 675
672 if (LLFloater::getFloaterHost()) 676 if (LLFloater::getFloaterHost())
@@ -1036,10 +1040,11 @@ void LLTabContainer::setPanelTitle(S32 index, const LLString& title)
1036{ 1040{
1037 if (index >= 0 && index < (S32)mTabList.size()) 1041 if (index >= 0 && index < (S32)mTabList.size())
1038 { 1042 {
1039 LLButton* tab_button = mTabList[index]->mButton; 1043 LLTabTuple* tuple = mTabList[index];
1044 LLButton* tab_button = tuple->mButton;
1040 const LLFontGL* fontp = gResMgr->getRes( LLFONT_SANSSERIF_SMALL ); 1045 const LLFontGL* fontp = gResMgr->getRes( LLFONT_SANSSERIF_SMALL );
1041 mTotalTabWidth -= tab_button->getRect().getWidth(); 1046 mTotalTabWidth -= tab_button->getRect().getWidth();
1042 tab_button->reshape(llclamp(fontp->getWidth(title) + TAB_PADDING, mMinTabWidth, mMaxTabWidth), tab_button->getRect().getHeight()); 1047 tab_button->reshape(llclamp(fontp->getWidth(title) + TAB_PADDING + tuple->mPadding, mMinTabWidth, mMaxTabWidth), tab_button->getRect().getHeight());
1043 mTotalTabWidth += tab_button->getRect().getWidth(); 1048 mTotalTabWidth += tab_button->getRect().getWidth();
1044 tab_button->setLabelSelected(title); 1049 tab_button->setLabelSelected(title);
1045 tab_button->setLabelUnselected(title); 1050 tab_button->setLabelUnselected(title);
@@ -1245,63 +1250,60 @@ void LLTabContainer::draw()
1245 1250
1246 LLPanel::draw(); 1251 LLPanel::draw();
1247 1252
1248 // Show all the buttons 1253 // if tabs are hidden, don't draw them and leave them in the invisible state
1249 for(tuple_list_t::iterator iter = mTabList.begin(); iter != mTabList.end(); ++iter) 1254 if (!mTabsHidden)
1250 { 1255 {
1251 LLTabTuple* tuple = *iter; 1256 // Show all the buttons
1252 tuple->mButton->setVisible( TRUE ); 1257 for(tuple_list_t::iterator iter = mTabList.begin(); iter != mTabList.end(); ++iter)
1253 } 1258 {
1254 1259 LLTabTuple* tuple = *iter;
1255 // Draw some of the buttons... 1260 tuple->mButton->setVisible( TRUE );
1261 }
1256 1262
1257 LLGLEnable scissor_test(has_scroll_arrows ? GL_SCISSOR_TEST : GL_FALSE); 1263 // Draw some of the buttons...
1258 if( has_scroll_arrows ) 1264 LLRect clip_rect = getLocalRect();
1259 { 1265 if (has_scroll_arrows)
1260 // ...but clip them.
1261 S32 x1 = mLeftArrowBtn->getRect().mRight;
1262 S32 y1 = 0;
1263 S32 x2 = mRightArrowBtn->getRect().mLeft;
1264 S32 y2 = 1;
1265 if (mTabList.size() > 0)
1266 { 1266 {
1267 y2 = mTabList[0]->mButton->getRect().mTop; 1267 // ...but clip them.
1268 clip_rect.mLeft = mLeftArrowBtn->getRect().mRight;
1269 clip_rect.mRight = mRightArrowBtn->getRect().mLeft;
1268 } 1270 }
1269 LLUI::setScissorRegionLocal(LLRect(x1, y2, x2, y1)); 1271 LLLocalClipRect clip(clip_rect);
1270 }
1271 1272
1272 S32 max_scroll_visible = mTabList.size() - mMaxScrollPos + mScrollPos; 1273 S32 max_scroll_visible = mTabList.size() - mMaxScrollPos + mScrollPos;
1273 S32 idx = 0; 1274 S32 idx = 0;
1274 for(tuple_list_t::iterator iter = mTabList.begin(); iter != mTabList.end(); ++iter) 1275 for(tuple_list_t::iterator iter = mTabList.begin(); iter != mTabList.end(); ++iter)
1275 { 1276 {
1276 LLTabTuple* tuple = *iter; 1277 LLTabTuple* tuple = *iter;
1277 1278
1278 tuple->mButton->translate( left - tuple->mButton->getRect().mLeft, 0 ); 1279 tuple->mButton->translate( left - tuple->mButton->getRect().mLeft, 0 );
1279 left += tuple->mButton->getRect().getWidth(); 1280 left += tuple->mButton->getRect().getWidth();
1280 1281
1281 if( idx < mScrollPos ) 1282 if( idx < mScrollPos )
1282 {
1283 if( tuple->mButton->getFlashing() )
1284 { 1283 {
1285 mLeftArrowBtn->setFlashing( TRUE ); 1284 if( tuple->mButton->getFlashing() )
1285 {
1286 mLeftArrowBtn->setFlashing( TRUE );
1287 }
1286 } 1288 }
1287 } 1289 else
1288 else 1290 if( max_scroll_visible < idx )
1289 if( max_scroll_visible < idx )
1290 {
1291 if( tuple->mButton->getFlashing() )
1292 { 1291 {
1293 mRightArrowBtn->setFlashing( TRUE ); 1292 if( tuple->mButton->getFlashing() )
1293 {
1294 mRightArrowBtn->setFlashing( TRUE );
1295 }
1294 } 1296 }
1295 }
1296 1297
1297 LLUI::pushMatrix(); 1298 LLUI::pushMatrix();
1298 { 1299 {
1299 LLUI::translate((F32)tuple->mButton->getRect().mLeft, (F32)tuple->mButton->getRect().mBottom, 0.f); 1300 LLUI::translate((F32)tuple->mButton->getRect().mLeft, (F32)tuple->mButton->getRect().mBottom, 0.f);
1300 tuple->mButton->draw(); 1301 tuple->mButton->draw();
1302 }
1303 LLUI::popMatrix();
1304
1305 idx++;
1301 } 1306 }
1302 LLUI::popMatrix();
1303
1304 idx++;
1305 } 1307 }
1306 1308
1307 mLeftArrowBtn->setFlashing(FALSE); 1309 mLeftArrowBtn->setFlashing(FALSE);
@@ -1628,12 +1630,12 @@ BOOL LLTabContainer::handleDragAndDrop(S32 x, S32 y, MASK mask, BOOL drop, EDrag
1628 return LLView::handleDragAndDrop(x, y, mask, drop, type, cargo_data, accept, tooltip); 1630 return LLView::handleDragAndDrop(x, y, mask, drop, type, cargo_data, accept, tooltip);
1629} 1631}
1630 1632
1631void LLTabContainer::setTabImage(LLPanel* child, std::string image_name) 1633void LLTabContainer::setTabImage(LLPanel* child, std::string image_name, const LLColor4& color)
1632{ 1634{
1633 LLTabTuple* tuple = getTabByPanel(child); 1635 LLTabTuple* tuple = getTabByPanel(child);
1634 if( tuple ) 1636 if( tuple )
1635 { 1637 {
1636 tuple->mButton->setImageOverlay(image_name, LLFontGL::RIGHT); 1638 tuple->mButton->setImageOverlay(image_name, LLFontGL::RIGHT, color);
1637 1639
1638 const LLFontGL* fontp = gResMgr->getRes( LLFONT_SANSSERIF_SMALL ); 1640 const LLFontGL* fontp = gResMgr->getRes( LLFONT_SANSSERIF_SMALL );
1639 // remove current width from total tab strip width 1641 // remove current width from total tab strip width
@@ -1642,7 +1644,11 @@ void LLTabContainer::setTabImage(LLPanel* child, std::string image_name)
1642 S32 image_overlay_width = tuple->mButton->getImageOverlay().notNull() ? 1644 S32 image_overlay_width = tuple->mButton->getImageOverlay().notNull() ?
1643 tuple->mButton->getImageOverlay()->getWidth(0) : 1645 tuple->mButton->getImageOverlay()->getWidth(0) :
1644 0; 1646 0;
1645 tuple->mButton->reshape(llclamp(fontp->getWidth(tuple->mButton->getLabelSelected()) + TAB_PADDING + image_overlay_width, mMinTabWidth, mMaxTabWidth), 1647
1648 tuple->mPadding = image_overlay_width;
1649
1650 tuple->mButton->setRightHPad(tuple->mPadding + LLBUTTON_H_PAD);
1651 tuple->mButton->reshape(llclamp(fontp->getWidth(tuple->mButton->getLabelSelected()) + TAB_PADDING + tuple->mPadding, mMinTabWidth, mMaxTabWidth),
1646 tuple->mButton->getRect().getHeight()); 1652 tuple->mButton->getRect().getHeight());
1647 // add back in button width to total tab strip width 1653 // add back in button width to total tab strip width
1648 mTotalTabWidth += tuple->mButton->getRect().getWidth(); 1654 mTotalTabWidth += tuple->mButton->getRect().getWidth();