aboutsummaryrefslogtreecommitdiffstatshomepage
path: root/linden/indra/llui/lltabcontainervertical.cpp
diff options
context:
space:
mode:
Diffstat (limited to 'linden/indra/llui/lltabcontainervertical.cpp')
-rw-r--r--linden/indra/llui/lltabcontainervertical.cpp74
1 files changed, 36 insertions, 38 deletions
diff --git a/linden/indra/llui/lltabcontainervertical.cpp b/linden/indra/llui/lltabcontainervertical.cpp
index 317b7ca..e2d84a5 100644
--- a/linden/indra/llui/lltabcontainervertical.cpp
+++ b/linden/indra/llui/lltabcontainervertical.cpp
@@ -392,49 +392,47 @@ void LLTabContainerVertical::draw()
392 } 392 }
393 393
394 // Draw some of the buttons... 394 // Draw some of the buttons...
395
396 LLGLEnable scissor_test(has_scroll_arrows ? GL_SCISSOR_TEST : GL_FALSE);
397
398 if( has_scroll_arrows )
399 {
400 // ...but clip them.
401 S32 x1 = mRect.mLeft;
402 S32 y1 = mDownArrowBtn->getRect().mTop + 3*TABCNTRV_PAD;
403 S32 x2 = mRect.mRight;
404 S32 y2 = mUpArrowBtn->getRect().mBottom - 3*TABCNTRV_PAD;
405 LLUI::setScissorRegionLocal(LLRect(x1, y2, x2, y1));
406 }
407
408 //S32 max_scroll_visible = mTabList.size() - mMaxScrollPos + mScrollPos;
409 S32 idx = 0;
410 for(std::vector<LLTabTuple*>::iterator iter = mTabList.begin(); iter != mTabList.end(); ++iter)
411 { 395 {
412 LLTabTuple* tuple = *iter; 396 LLRect clip_rect = getLocalRect();
413 tuple->mButton->translate( 0 , top - tuple->mButton->getRect().mTop); 397 if (has_scroll_arrows)
414 top -= BTN_HEIGHT + TABCNTRV_PAD;
415
416 LLUI::pushMatrix();
417 { 398 {
418 LLUI::translate((F32)tuple->mButton->getRect().mLeft, (F32)tuple->mButton->getRect().mBottom, 0.f); 399 // ...but clip them.
419 tuple->mButton->draw(); 400 clip_rect.mBottom = mDownArrowBtn->getRect().mTop + 3*TABCNTRV_PAD;
401 clip_rect.mTop = mUpArrowBtn->getRect().mBottom - 3*TABCNTRV_PAD;
420 } 402 }
421 LLUI::popMatrix(); 403 LLLocalClipRect clip(clip_rect);
422 404
423 idx++; 405 //S32 max_scroll_visible = mTabList.size() - mMaxScrollPos + mScrollPos;
424 } 406 S32 idx = 0;
407 for(std::vector<LLTabTuple*>::iterator iter = mTabList.begin(); iter != mTabList.end(); ++iter)
408 {
409 LLTabTuple* tuple = *iter;
410 tuple->mButton->translate( 0 , top - tuple->mButton->getRect().mTop);
411 top -= BTN_HEIGHT + TABCNTRV_PAD;
425 412
426 if( has_scroll_arrows ) 413 LLUI::pushMatrix();
427 { 414 {
428 // Redraw the arrows so that they appears on top. 415 LLUI::translate((F32)tuple->mButton->getRect().mLeft, (F32)tuple->mButton->getRect().mBottom, 0.f);
429 glPushMatrix(); 416 tuple->mButton->draw();
430 glTranslatef((F32)mUpArrowBtn->getRect().mLeft, (F32)mUpArrowBtn->getRect().mBottom, 0.f); 417 }
431 mUpArrowBtn->draw(); 418 LLUI::popMatrix();
432 glPopMatrix(); 419
433 420 idx++;
434 glPushMatrix(); 421 }
435 glTranslatef((F32)mDownArrowBtn->getRect().mLeft, (F32)mDownArrowBtn->getRect().mBottom, 0.f); 422
436 mDownArrowBtn->draw(); 423 if( has_scroll_arrows )
437 glPopMatrix(); 424 {
425 // Redraw the arrows so that they appears on top.
426 glPushMatrix();
427 glTranslatef((F32)mUpArrowBtn->getRect().mLeft, (F32)mUpArrowBtn->getRect().mBottom, 0.f);
428 mUpArrowBtn->draw();
429 glPopMatrix();
430
431 glPushMatrix();
432 glTranslatef((F32)mDownArrowBtn->getRect().mLeft, (F32)mDownArrowBtn->getRect().mBottom, 0.f);
433 mDownArrowBtn->draw();
434 glPopMatrix();
435 }
438 } 436 }
439 } 437 }
440} 438}