diff options
Diffstat (limited to 'linden/indra/llui/llscrollbar.cpp')
-rw-r--r-- | linden/indra/llui/llscrollbar.cpp | 48 |
1 files changed, 21 insertions, 27 deletions
diff --git a/linden/indra/llui/llscrollbar.cpp b/linden/indra/llui/llscrollbar.cpp index ec46551..cf64742 100644 --- a/linden/indra/llui/llscrollbar.cpp +++ b/linden/indra/llui/llscrollbar.cpp | |||
@@ -46,6 +46,7 @@ | |||
46 | #include "llwindow.h" | 46 | #include "llwindow.h" |
47 | #include "llglheaders.h" | 47 | #include "llglheaders.h" |
48 | #include "llcontrol.h" | 48 | #include "llcontrol.h" |
49 | #include "llglimmediate.h" | ||
49 | 50 | ||
50 | LLScrollbar::LLScrollbar( | 51 | LLScrollbar::LLScrollbar( |
51 | const LLString& name, LLRect rect, | 52 | const LLString& name, LLRect rect, |
@@ -92,7 +93,7 @@ LLScrollbar::LLScrollbar( | |||
92 | 93 | ||
93 | if( LLScrollbar::VERTICAL == mOrientation ) | 94 | if( LLScrollbar::VERTICAL == mOrientation ) |
94 | { | 95 | { |
95 | line_up_rect.setLeftTopAndSize( 0, mRect.getHeight(), SCROLLBAR_SIZE, SCROLLBAR_SIZE ); | 96 | line_up_rect.setLeftTopAndSize( 0, getRect().getHeight(), SCROLLBAR_SIZE, SCROLLBAR_SIZE ); |
96 | line_up_img="UIImgBtnScrollUpOutUUID"; | 97 | line_up_img="UIImgBtnScrollUpOutUUID"; |
97 | line_up_selected_img="UIImgBtnScrollUpInUUID"; | 98 | line_up_selected_img="UIImgBtnScrollUpInUUID"; |
98 | 99 | ||
@@ -107,7 +108,7 @@ LLScrollbar::LLScrollbar( | |||
107 | line_up_img="UIImgBtnScrollLeftOutUUID"; | 108 | line_up_img="UIImgBtnScrollLeftOutUUID"; |
108 | line_up_selected_img="UIImgBtnScrollLeftInUUID"; | 109 | line_up_selected_img="UIImgBtnScrollLeftInUUID"; |
109 | 110 | ||
110 | line_down_rect.setOriginAndSize( mRect.getWidth() - SCROLLBAR_SIZE, 0, SCROLLBAR_SIZE, SCROLLBAR_SIZE ); | 111 | line_down_rect.setOriginAndSize( getRect().getWidth() - SCROLLBAR_SIZE, 0, SCROLLBAR_SIZE, SCROLLBAR_SIZE ); |
111 | line_down_img="UIImgBtnScrollRightOutUUID"; | 112 | line_down_img="UIImgBtnScrollRightOutUUID"; |
112 | line_down_selected_img="UIImgBtnScrollRightInUUID"; | 113 | line_down_selected_img="UIImgBtnScrollRightInUUID"; |
113 | } | 114 | } |
@@ -210,7 +211,7 @@ void LLScrollbar::updateThumbRect() | |||
210 | 211 | ||
211 | const S32 THUMB_MIN_LENGTH = 16; | 212 | const S32 THUMB_MIN_LENGTH = 16; |
212 | 213 | ||
213 | S32 window_length = (mOrientation == LLScrollbar::HORIZONTAL) ? mRect.getWidth() : mRect.getHeight(); | 214 | S32 window_length = (mOrientation == LLScrollbar::HORIZONTAL) ? getRect().getWidth() : getRect().getHeight(); |
214 | S32 thumb_bg_length = window_length - 2 * SCROLLBAR_SIZE; | 215 | S32 thumb_bg_length = window_length - 2 * SCROLLBAR_SIZE; |
215 | S32 visible_lines = llmin( mDocSize, mPageSize ); | 216 | S32 visible_lines = llmin( mDocSize, mPageSize ); |
216 | S32 thumb_length = mDocSize ? llmax( visible_lines * thumb_bg_length / mDocSize, THUMB_MIN_LENGTH ) : thumb_bg_length; | 217 | S32 thumb_length = mDocSize ? llmax( visible_lines * thumb_bg_length / mDocSize, THUMB_MIN_LENGTH ) : thumb_bg_length; |
@@ -300,8 +301,8 @@ BOOL LLScrollbar::handleHover(S32 x, S32 y, MASK mask) | |||
300 | BOOL handled = FALSE; | 301 | BOOL handled = FALSE; |
301 | if( hasMouseCapture() ) | 302 | if( hasMouseCapture() ) |
302 | { | 303 | { |
303 | S32 height = mRect.getHeight(); | 304 | S32 height = getRect().getHeight(); |
304 | S32 width = mRect.getWidth(); | 305 | S32 width = getRect().getWidth(); |
305 | 306 | ||
306 | if( VERTICAL == mOrientation ) | 307 | if( VERTICAL == mOrientation ) |
307 | { | 308 | { |
@@ -408,13 +409,13 @@ BOOL LLScrollbar::handleHover(S32 x, S32 y, MASK mask) | |||
408 | 409 | ||
409 | mDocChanged = FALSE; | 410 | mDocChanged = FALSE; |
410 | return handled; | 411 | return handled; |
411 | } | 412 | } // end handleHover |
412 | 413 | ||
413 | 414 | ||
414 | BOOL LLScrollbar::handleScrollWheel(S32 x, S32 y, S32 clicks) | 415 | BOOL LLScrollbar::handleScrollWheel(S32 x, S32 y, S32 clicks) |
415 | { | 416 | { |
416 | BOOL handled = FALSE; | 417 | BOOL handled = FALSE; |
417 | if( getVisible() && mRect.localPointInRect( x, y ) ) | 418 | if( getVisible() && getRect().localPointInRect( x, y ) ) |
418 | { | 419 | { |
419 | if( getEnabled() ) | 420 | if( getEnabled() ) |
420 | { | 421 | { |
@@ -427,7 +428,7 @@ BOOL LLScrollbar::handleScrollWheel(S32 x, S32 y, S32 clicks) | |||
427 | } | 428 | } |
428 | 429 | ||
429 | BOOL LLScrollbar::handleDragAndDrop(S32 x, S32 y, MASK mask, BOOL drop, | 430 | BOOL LLScrollbar::handleDragAndDrop(S32 x, S32 y, MASK mask, BOOL drop, |
430 | EDragAndDropType cargo_type, void *carge_data, EAcceptance *accept, LLString &tooltip_msg) | 431 | EDragAndDropType cargo_type, void *cargo_data, EAcceptance *accept, LLString &tooltip_msg) |
431 | { | 432 | { |
432 | // enable this to get drag and drop to control scrollbars | 433 | // enable this to get drag and drop to control scrollbars |
433 | //if (!drop) | 434 | //if (!drop) |
@@ -436,7 +437,7 @@ BOOL LLScrollbar::handleDragAndDrop(S32 x, S32 y, MASK mask, BOOL drop, | |||
436 | // S32 variable_lines = getDocPosMax(); | 437 | // S32 variable_lines = getDocPosMax(); |
437 | // S32 pos = (VERTICAL == mOrientation) ? y : x; | 438 | // S32 pos = (VERTICAL == mOrientation) ? y : x; |
438 | // S32 thumb_length = (VERTICAL == mOrientation) ? mThumbRect.getHeight() : mThumbRect.getWidth(); | 439 | // S32 thumb_length = (VERTICAL == mOrientation) ? mThumbRect.getHeight() : mThumbRect.getWidth(); |
439 | // S32 thumb_track_length = (VERTICAL == mOrientation) ? (mRect.getHeight() - 2 * SCROLLBAR_SIZE) : (mRect.getWidth() - 2 * SCROLLBAR_SIZE); | 440 | // S32 thumb_track_length = (VERTICAL == mOrientation) ? (getRect().getHeight() - 2 * SCROLLBAR_SIZE) : (getRect().getWidth() - 2 * SCROLLBAR_SIZE); |
440 | // S32 usable_track_length = thumb_track_length - thumb_length; | 441 | // S32 usable_track_length = thumb_track_length - thumb_length; |
441 | // F32 ratio = (VERTICAL == mOrientation) ? F32(pos - SCROLLBAR_SIZE - thumb_length) / usable_track_length | 442 | // F32 ratio = (VERTICAL == mOrientation) ? F32(pos - SCROLLBAR_SIZE - thumb_length) / usable_track_length |
442 | // : F32(pos - SCROLLBAR_SIZE) / usable_track_length; | 443 | // : F32(pos - SCROLLBAR_SIZE) / usable_track_length; |
@@ -485,7 +486,7 @@ void LLScrollbar::draw() | |||
485 | 486 | ||
486 | screenPointToLocal(cursor_pos_gl.mX, cursor_pos_gl.mY, &local_mouse_x, &local_mouse_y); | 487 | screenPointToLocal(cursor_pos_gl.mX, cursor_pos_gl.mY, &local_mouse_x, &local_mouse_y); |
487 | BOOL other_captor = gFocusMgr.getMouseCapture() && gFocusMgr.getMouseCapture() != this; | 488 | BOOL other_captor = gFocusMgr.getMouseCapture() && gFocusMgr.getMouseCapture() != this; |
488 | BOOL hovered = mEnabled && !other_captor && (hasMouseCapture() || mThumbRect.pointInRect(local_mouse_x, local_mouse_y)); | 489 | BOOL hovered = getEnabled() && !other_captor && (hasMouseCapture() || mThumbRect.pointInRect(local_mouse_x, local_mouse_y)); |
489 | if (hovered) | 490 | if (hovered) |
490 | { | 491 | { |
491 | mCurGlowStrength = lerp(mCurGlowStrength, mHoverGlowStrength, LLCriticalDamp::getInterpolant(0.05f)); | 492 | mCurGlowStrength = lerp(mCurGlowStrength, mHoverGlowStrength, LLCriticalDamp::getInterpolant(0.05f)); |
@@ -504,8 +505,8 @@ void LLScrollbar::draw() | |||
504 | if (!rounded_rect_imagep) | 505 | if (!rounded_rect_imagep) |
505 | { | 506 | { |
506 | gl_rect_2d(mOrientation == HORIZONTAL ? SCROLLBAR_SIZE : 0, | 507 | gl_rect_2d(mOrientation == HORIZONTAL ? SCROLLBAR_SIZE : 0, |
507 | mOrientation == VERTICAL ? mRect.getHeight() - 2 * SCROLLBAR_SIZE : mRect.getHeight(), | 508 | mOrientation == VERTICAL ? getRect().getHeight() - 2 * SCROLLBAR_SIZE : getRect().getHeight(), |
508 | mOrientation == HORIZONTAL ? mRect.getWidth() - 2 * SCROLLBAR_SIZE : mRect.getWidth(), | 509 | mOrientation == HORIZONTAL ? getRect().getWidth() - 2 * SCROLLBAR_SIZE : getRect().getWidth(), |
509 | mOrientation == VERTICAL ? SCROLLBAR_SIZE : 0, mTrackColor, TRUE); | 510 | mOrientation == VERTICAL ? SCROLLBAR_SIZE : 0, mTrackColor, TRUE); |
510 | 511 | ||
511 | gl_rect_2d(mThumbRect, mThumbColor, TRUE); | 512 | gl_rect_2d(mThumbRect, mThumbColor, TRUE); |
@@ -518,8 +519,8 @@ void LLScrollbar::draw() | |||
518 | mOrientation == VERTICAL ? SCROLLBAR_SIZE : 0, | 519 | mOrientation == VERTICAL ? SCROLLBAR_SIZE : 0, |
519 | 16, | 520 | 16, |
520 | 16, | 521 | 16, |
521 | mOrientation == HORIZONTAL ? mRect.getWidth() - 2 * SCROLLBAR_SIZE : mRect.getWidth(), | 522 | mOrientation == HORIZONTAL ? getRect().getWidth() - 2 * SCROLLBAR_SIZE : getRect().getWidth(), |
522 | mOrientation == VERTICAL ? mRect.getHeight() - 2 * SCROLLBAR_SIZE : mRect.getHeight(), | 523 | mOrientation == VERTICAL ? getRect().getHeight() - 2 * SCROLLBAR_SIZE : getRect().getHeight(), |
523 | rounded_rect_imagep, | 524 | rounded_rect_imagep, |
524 | mTrackColor, | 525 | mTrackColor, |
525 | TRUE); | 526 | TRUE); |
@@ -538,10 +539,10 @@ void LLScrollbar::draw() | |||
538 | rounded_rect_imagep, mThumbColor ); | 539 | rounded_rect_imagep, mThumbColor ); |
539 | if (mCurGlowStrength > 0.01f) | 540 | if (mCurGlowStrength > 0.01f) |
540 | { | 541 | { |
541 | glBlendFunc(GL_SRC_ALPHA, GL_ONE); | 542 | gGL.blendFunc(GL_SRC_ALPHA, GL_ONE); |
542 | gl_draw_scaled_image_with_border(mThumbRect.mLeft, mThumbRect.mBottom, 16, 16, mThumbRect.getWidth(), mThumbRect.getHeight(), | 543 | gl_draw_scaled_image_with_border(mThumbRect.mLeft, mThumbRect.mBottom, 16, 16, mThumbRect.getWidth(), mThumbRect.getHeight(), |
543 | rounded_rect_imagep, LLColor4(1.f, 1.f, 1.f, mCurGlowStrength), TRUE); | 544 | rounded_rect_imagep, LLColor4(1.f, 1.f, 1.f, mCurGlowStrength), TRUE); |
544 | glBlendFunc(GL_SRC_ALPHA, GL_ONE_MINUS_SRC_ALPHA); | 545 | gGL.blendFunc(GL_SRC_ALPHA, GL_ONE_MINUS_SRC_ALPHA); |
545 | } | 546 | } |
546 | } | 547 | } |
547 | 548 | ||
@@ -553,7 +554,8 @@ void LLScrollbar::draw() | |||
553 | // Draw children | 554 | // Draw children |
554 | LLView::draw(); | 555 | LLView::draw(); |
555 | } | 556 | } |
556 | } | 557 | } // end draw |
558 | |||
557 | 559 | ||
558 | void LLScrollbar::changeLine( S32 delta, BOOL update_thumb ) | 560 | void LLScrollbar::changeLine( S32 delta, BOOL update_thumb ) |
559 | { | 561 | { |
@@ -579,21 +581,12 @@ void LLScrollbar::setValue(const LLSD& value) | |||
579 | setDocPos((S32) value.asInteger()); | 581 | setDocPos((S32) value.asInteger()); |
580 | } | 582 | } |
581 | 583 | ||
582 | EWidgetType LLScrollbar::getWidgetType() const | ||
583 | { | ||
584 | return WIDGET_TYPE_SCROLLBAR; | ||
585 | } | ||
586 | |||
587 | LLString LLScrollbar::getWidgetTag() const | ||
588 | { | ||
589 | return LL_SCROLLBAR_TAG; | ||
590 | } | ||
591 | 584 | ||
592 | BOOL LLScrollbar::handleKeyHere(KEY key, MASK mask, BOOL called_from_parent) | 585 | BOOL LLScrollbar::handleKeyHere(KEY key, MASK mask, BOOL called_from_parent) |
593 | { | 586 | { |
594 | BOOL handled = FALSE; | 587 | BOOL handled = FALSE; |
595 | 588 | ||
596 | if( getVisible() && mEnabled && !called_from_parent ) | 589 | if( getVisible() && getEnabled() && !called_from_parent ) |
597 | { | 590 | { |
598 | switch( key ) | 591 | switch( key ) |
599 | { | 592 | { |
@@ -661,3 +654,4 @@ void LLScrollbar::onLineDownBtnPressed( void* userdata ) | |||
661 | self->changeLine( self->mStepSize, TRUE ); | 654 | self->changeLine( self->mStepSize, TRUE ); |
662 | } | 655 | } |
663 | 656 | ||
657 | |||