diff options
Diffstat (limited to 'indra/llui')
| -rw-r--r-- | indra/llui/llfloater.cpp | 17 | ||||
| -rw-r--r-- | indra/llui/llfloater.h | 1 | ||||
| -rw-r--r-- | indra/llui/llmenubutton.cpp | 8 | ||||
| -rw-r--r-- | indra/llui/llmenubutton.h | 3 | ||||
| -rw-r--r-- | indra/llui/lltabcontainer.cpp | 18 | ||||
| -rw-r--r-- | indra/llui/lltextbase.cpp | 44 | ||||
| -rw-r--r-- | indra/llui/lltextbase.h | 2 | 
7 files changed, 81 insertions, 12 deletions
| diff --git a/indra/llui/llfloater.cpp b/indra/llui/llfloater.cpp index a245dd8f78..d1e0b3e0b7 100644 --- a/indra/llui/llfloater.cpp +++ b/indra/llui/llfloater.cpp @@ -252,6 +252,7 @@ LLFloater::LLFloater(const LLSD& key, const LLFloater::Params& p)  	mMinHeight(p.min_height),  	mHeaderHeight(p.header_height),  	mLegacyHeaderHeight(p.legacy_header_height), +	mDefaultRectForGroup(true),  	mMinimized(FALSE),  	mForeground(FALSE),  	mFirstLook(TRUE), @@ -892,7 +893,10 @@ bool LLFloater::applyRectControl()  	if (last_in_group && last_in_group != this)  	{  		// other floaters in our group, position ourselves relative to them and don't save the rect -		mRectControl.clear(); +		if (mDefaultRectForGroup) +		{ +			mRectControl.clear(); +		}  		mPositioning = LLFloaterEnums::POSITIONING_CASCADE_GROUP;  	}  	else @@ -3399,8 +3403,15 @@ void LLFloater::stackWith(LLFloater& other)  	}  	next_rect.translate(floater_offset, -floater_offset); -	next_rect.setLeftTopAndSize(next_rect.mLeft, next_rect.mTop, getRect().getWidth(), getRect().getHeight()); -	 +	const LLRect& rect = getControlGroup()->getRect(mRectControl); +	if (rect.notEmpty() && !mDefaultRectForGroup && mResizable) +	{ +		next_rect.setLeftTopAndSize(next_rect.mLeft, next_rect.mTop, llmax(mMinWidth, rect.getWidth()), llmax(mMinHeight, rect.getHeight())); +	} +	else +	{ +		next_rect.setLeftTopAndSize(next_rect.mLeft, next_rect.mTop, getRect().getWidth(), getRect().getHeight()); +	}  	setShape(next_rect);  	if (!other.getHost()) diff --git a/indra/llui/llfloater.h b/indra/llui/llfloater.h index 165f67499b..475a790b14 100644 --- a/indra/llui/llfloater.h +++ b/indra/llui/llfloater.h @@ -436,6 +436,7 @@ public:  protected:  	bool			mSaveRect; +	bool			mDefaultRectForGroup;  	std::string		mRectControl;  	std::string		mPosXControl;  	std::string		mPosYControl; diff --git a/indra/llui/llmenubutton.cpp b/indra/llui/llmenubutton.cpp index 303afcda15..583704418b 100644 --- a/indra/llui/llmenubutton.cpp +++ b/indra/llui/llmenubutton.cpp @@ -40,6 +40,7 @@ void LLMenuButton::MenuPositions::declareValues()  	declare("topleft", MP_TOP_LEFT);  	declare("topright", MP_TOP_RIGHT);  	declare("bottomleft", MP_BOTTOM_LEFT); +	declare("bottomright", MP_BOTTOM_RIGHT);  }  LLMenuButton::Params::Params() @@ -212,6 +213,13 @@ void LLMenuButton::updateMenuOrigin()  			mY = rect.mBottom;  			break;  		} +		case MP_BOTTOM_RIGHT: +		{ +			const LLRect& menu_rect = menu->getRect(); +			mX = rect.mRight - menu_rect.getWidth(); +			mY = rect.mBottom; +			break; +		}  	}  } diff --git a/indra/llui/llmenubutton.h b/indra/llui/llmenubutton.h index 67ec1983b3..e42f8f53bd 100644 --- a/indra/llui/llmenubutton.h +++ b/indra/llui/llmenubutton.h @@ -41,7 +41,8 @@ public:  	{  		MP_TOP_LEFT,  		MP_TOP_RIGHT, -		MP_BOTTOM_LEFT +		MP_BOTTOM_LEFT, +		MP_BOTTOM_RIGHT  	} EMenuPosition;  	struct MenuPositions diff --git a/indra/llui/lltabcontainer.cpp b/indra/llui/lltabcontainer.cpp index 6521b883f8..1bb666abba 100644 --- a/indra/llui/lltabcontainer.cpp +++ b/indra/llui/lltabcontainer.cpp @@ -392,9 +392,13 @@ void LLTabContainer::draw()  	S32 cur_scroll_pos = getScrollPos();  	if (cur_scroll_pos > 0)  	{ -		S32 available_width_with_arrows = getRect().getWidth() - mRightTabBtnOffset - 2 * (LLPANEL_BORDER_WIDTH + tabcntr_arrow_btn_size  + tabcntr_arrow_btn_size + 1); -		if (!mIsVertical) +		if (mIsVertical)  		{ +			target_pixel_scroll = cur_scroll_pos * (BTN_HEIGHT + tabcntrv_pad); +		} +		else +		{ +			S32 available_width_with_arrows = getRect().getWidth() - mRightTabBtnOffset - 2 * (LLPANEL_BORDER_WIDTH + tabcntr_arrow_btn_size  + tabcntr_arrow_btn_size + 1);  			for(tuple_list_t::iterator iter = mTabList.begin(); iter != mTabList.end(); ++iter)  			{  				if (cur_scroll_pos == 0) @@ -1175,13 +1179,15 @@ void LLTabContainer::addTabPanel(const TabPanelParams& panel)  	sendChildToFront(mNextArrowBtn);  	sendChildToFront(mJumpPrevArrowBtn);  	sendChildToFront(mJumpNextArrowBtn); -	 + +	updateMaxScrollPos(); +  	if( select )  	{  		selectLastTab(); +		mScrollPos = mMaxScrollPos;  	} -	updateMaxScrollPos();  }  void LLTabContainer::addPlaceholder(LLPanel* child, const std::string& label) @@ -2063,9 +2069,9 @@ void LLTabContainer::updateMaxScrollPos()  		if( tab_total_height > available_height )  		{  			static LLUICachedControl<S32> tabcntrv_arrow_btn_size ("UITabCntrvArrowBtnSize", 0); -			S32 available_height_with_arrows = getRect().getHeight() - 2*(tabcntrv_arrow_btn_size + 3*tabcntrv_pad); +			S32 available_height_with_arrows = getRect().getHeight() - 2*(tabcntrv_arrow_btn_size + 3*tabcntrv_pad) - mNextArrowBtn->getRect().mBottom;  			S32 additional_needed = tab_total_height - available_height_with_arrows; -			setMaxScrollPos((S32) ceil(additional_needed / float(BTN_HEIGHT) ) ); +			setMaxScrollPos((S32) ceil(additional_needed / float(BTN_HEIGHT + tabcntrv_pad) ) );  			no_scroll = FALSE;  		}  	} diff --git a/indra/llui/lltextbase.cpp b/indra/llui/lltextbase.cpp index a23741b6dd..0727dd75d5 100644 --- a/indra/llui/lltextbase.cpp +++ b/indra/llui/lltextbase.cpp @@ -445,8 +445,48 @@ void LLTextBase::drawSelectionBackground()  			++rect_it)  		{  			LLRect selection_rect = *rect_it; -			selection_rect = *rect_it; -			selection_rect.translate(mVisibleTextRect.mLeft - content_display_rect.mLeft, mVisibleTextRect.mBottom - content_display_rect.mBottom); +            if (mScroller) +            { +                // If scroller is On content_display_rect has correct rect and safe to use as is +                // Note: we might need to account for border +                selection_rect.translate(mVisibleTextRect.mLeft - content_display_rect.mLeft, mVisibleTextRect.mBottom - content_display_rect.mBottom); +            } +            else +            { +                // If scroller is Off content_display_rect will have rect from document, adjusted to text width, heigh and position +                // and we have to acount for offset depending on position +                S32 v_delta = 0; +                S32 h_delta = 0; +                switch (mVAlign) +                { +                case LLFontGL::TOP: +                    v_delta = mVisibleTextRect.mTop - content_display_rect.mTop - mVPad; +                    break; +                case LLFontGL::VCENTER: +                    v_delta = (llmax(mVisibleTextRect.getHeight() - content_display_rect.mTop, -content_display_rect.mBottom) + (mVisibleTextRect.mBottom - content_display_rect.mBottom)) / 2; +                    break; +                case LLFontGL::BOTTOM: +                    v_delta = mVisibleTextRect.mBottom - content_display_rect.mBottom; +                    break; +                default: +                    break; +                } +                switch (mHAlign) +                { +                case LLFontGL::LEFT: +                    h_delta = mVisibleTextRect.mLeft - content_display_rect.mLeft + mHPad; +                    break; +                case LLFontGL::HCENTER: +                    h_delta = (llmax(mVisibleTextRect.getWidth() - content_display_rect.mLeft, -content_display_rect.mRight) + (mVisibleTextRect.mRight - content_display_rect.mRight)) / 2; +                    break; +                case LLFontGL::RIGHT: +                    h_delta = mVisibleTextRect.mRight - content_display_rect.mRight; +                    break; +                default: +                    break; +                } +                selection_rect.translate(h_delta, v_delta); +            }  			gl_rect_2d(selection_rect, selection_color);  		}  	} diff --git a/indra/llui/lltextbase.h b/indra/llui/lltextbase.h index 9831c35858..bff839f6c3 100644 --- a/indra/llui/lltextbase.h +++ b/indra/llui/lltextbase.h @@ -367,6 +367,8 @@ public:  	virtual void	onFocusReceived();  	virtual void	onFocusLost(); +    void        setParseHTML(bool parse_html) { mParseHTML = parse_html; } +  	// LLSpellCheckMenuHandler overrides  	/*virtual*/ bool		getSpellCheck() const; | 
