summaryrefslogtreecommitdiff
path: root/indra/newview/llhints.cpp
diff options
context:
space:
mode:
authorNat Goodspeed <nat@lindenlab.com>2024-05-14 21:02:28 -0400
committerNat Goodspeed <nat@lindenlab.com>2024-05-14 21:02:28 -0400
commit094dcc07f8c1d90ae723dbe60eddacb90a09eae8 (patch)
treee750942e5f22ed677b543bd49509c2a7cdc5ce56 /indra/newview/llhints.cpp
parentd4043d3b011c32eb503c43c551872f9c24d7344f (diff)
parent38c2a5bde985a6a8a96d912d432f8bdf7e5b60be (diff)
Merge DRTVWR-591-maint-X to main on promotion of secondlife/viewer #705: Maintenance X
Diffstat (limited to 'indra/newview/llhints.cpp')
-rw-r--r--indra/newview/llhints.cpp652
1 files changed, 326 insertions, 326 deletions
diff --git a/indra/newview/llhints.cpp b/indra/newview/llhints.cpp
index 7271376a3c..1de2a64d72 100644
--- a/indra/newview/llhints.cpp
+++ b/indra/newview/llhints.cpp
@@ -5,21 +5,21 @@
* $LicenseInfo:firstyear=2000&license=viewerlgpl$
* Second Life Viewer Source Code
* Copyright (C) 2010, Linden Research, Inc.
- *
+ *
* This library is free software; you can redistribute it and/or
* modify it under the terms of the GNU Lesser General Public
* License as published by the Free Software Foundation;
* version 2.1 of the License only.
- *
+ *
* This library is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
* Lesser General Public License for more details.
- *
+ *
* You should have received a copy of the GNU Lesser General Public
* License along with this library; if not, write to the Free Software
* Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
- *
+ *
* Linden Research, Inc., 945 Battery Street, San Francisco, CA 94111 USA
* $/LicenseInfo$
*/
@@ -40,312 +40,312 @@ class LLHintPopup : public LLPanel
{
public:
- typedef enum e_popup_direction
- {
- LEFT,
- TOP,
- RIGHT,
- BOTTOM,
- TOP_RIGHT
- } EPopupDirection;
-
- struct PopupDirections : public LLInitParam::TypeValuesHelper<LLHintPopup::EPopupDirection, PopupDirections>
- {
- static void declareValues()
- {
- declare("left", LLHintPopup::LEFT);
- declare("right", LLHintPopup::RIGHT);
- declare("top", LLHintPopup::TOP);
- declare("bottom", LLHintPopup::BOTTOM);
- declare("top_right", LLHintPopup::TOP_RIGHT);
- }
- };
-
- struct TargetParams : public LLInitParam::Block<TargetParams>
- {
- Mandatory<std::string> target;
- Mandatory<EPopupDirection, PopupDirections> direction;
-
- TargetParams()
- : target("target"),
- direction("direction")
- {}
- };
-
- struct Params : public LLInitParam::Block<Params, LLPanel::Params>
- {
- Mandatory<LLNotificationPtr> notification;
- Optional<TargetParams> target_params;
- Optional<S32> distance;
- Optional<LLUIImage*> left_arrow,
- up_arrow,
- right_arrow,
- down_arrow,
- lower_left_arrow,
- hint_image;
-
- Optional<S32> left_arrow_offset,
- up_arrow_offset,
- right_arrow_offset,
- down_arrow_offset;
- Optional<F32> fade_in_time,
- fade_out_time;
-
- Params()
- : distance("distance"),
- left_arrow("left_arrow"),
- up_arrow("up_arrow"),
- right_arrow("right_arrow"),
- down_arrow("down_arrow"),
- lower_left_arrow("lower_left_arrow"),
- hint_image("hint_image"),
- left_arrow_offset("left_arrow_offset"),
- up_arrow_offset("up_arrow_offset"),
- right_arrow_offset("right_arrow_offset"),
- down_arrow_offset("down_arrow_offset"),
- fade_in_time("fade_in_time"),
- fade_out_time("fade_out_time")
- {}
- };
-
- LLHintPopup(const Params&);
-
- /*virtual*/ BOOL postBuild();
-
- void onClickClose()
- {
- if (!mHidden)
- {
- hide();
- LLNotifications::instance().cancel(mNotification);
- }
- }
- void draw();
- void hide() { if(!mHidden) {mHidden = true; mFadeTimer.reset();} }
+ typedef enum e_popup_direction
+ {
+ LEFT,
+ TOP,
+ RIGHT,
+ BOTTOM,
+ TOP_RIGHT
+ } EPopupDirection;
+
+ struct PopupDirections : public LLInitParam::TypeValuesHelper<LLHintPopup::EPopupDirection, PopupDirections>
+ {
+ static void declareValues()
+ {
+ declare("left", LLHintPopup::LEFT);
+ declare("right", LLHintPopup::RIGHT);
+ declare("top", LLHintPopup::TOP);
+ declare("bottom", LLHintPopup::BOTTOM);
+ declare("top_right", LLHintPopup::TOP_RIGHT);
+ }
+ };
+
+ struct TargetParams : public LLInitParam::Block<TargetParams>
+ {
+ Mandatory<std::string> target;
+ Mandatory<EPopupDirection, PopupDirections> direction;
+
+ TargetParams()
+ : target("target"),
+ direction("direction")
+ {}
+ };
+
+ struct Params : public LLInitParam::Block<Params, LLPanel::Params>
+ {
+ Mandatory<LLNotificationPtr> notification;
+ Optional<TargetParams> target_params;
+ Optional<S32> distance;
+ Optional<LLUIImage*> left_arrow,
+ up_arrow,
+ right_arrow,
+ down_arrow,
+ lower_left_arrow,
+ hint_image;
+
+ Optional<S32> left_arrow_offset,
+ up_arrow_offset,
+ right_arrow_offset,
+ down_arrow_offset;
+ Optional<F32> fade_in_time,
+ fade_out_time;
+
+ Params()
+ : distance("distance"),
+ left_arrow("left_arrow"),
+ up_arrow("up_arrow"),
+ right_arrow("right_arrow"),
+ down_arrow("down_arrow"),
+ lower_left_arrow("lower_left_arrow"),
+ hint_image("hint_image"),
+ left_arrow_offset("left_arrow_offset"),
+ up_arrow_offset("up_arrow_offset"),
+ right_arrow_offset("right_arrow_offset"),
+ down_arrow_offset("down_arrow_offset"),
+ fade_in_time("fade_in_time"),
+ fade_out_time("fade_out_time")
+ {}
+ };
+
+ LLHintPopup(const Params&);
+
+ /*virtual*/ BOOL postBuild();
+
+ void onClickClose()
+ {
+ if (!mHidden)
+ {
+ hide();
+ LLNotifications::instance().cancel(mNotification);
+ }
+ }
+ void draw();
+ void hide() { if(!mHidden) {mHidden = true; mFadeTimer.reset();} }
private:
- LLNotificationPtr mNotification;
- std::string mTarget;
- EPopupDirection mDirection;
- S32 mDistance;
- LLUIImagePtr mArrowLeft,
- mArrowUp,
- mArrowRight,
- mArrowDown,
- mArrowDownAndLeft;
- S32 mArrowLeftOffset,
- mArrowUpOffset,
- mArrowRightOffset,
- mArrowDownOffset;
- LLFrameTimer mFadeTimer;
- F32 mFadeInTime,
- mFadeOutTime;
- bool mHidden;
+ LLNotificationPtr mNotification;
+ std::string mTarget;
+ EPopupDirection mDirection;
+ S32 mDistance;
+ LLUIImagePtr mArrowLeft,
+ mArrowUp,
+ mArrowRight,
+ mArrowDown,
+ mArrowDownAndLeft;
+ S32 mArrowLeftOffset,
+ mArrowUpOffset,
+ mArrowRightOffset,
+ mArrowDownOffset;
+ LLFrameTimer mFadeTimer;
+ F32 mFadeInTime,
+ mFadeOutTime;
+ bool mHidden;
};
static LLDefaultChildRegistry::Register<LLHintPopup> r("hint_popup");
LLHintPopup::LLHintPopup(const LLHintPopup::Params& p)
-: mNotification(p.notification),
- mDirection(TOP),
- mDistance(p.distance),
- mArrowLeft(p.left_arrow),
- mArrowUp(p.up_arrow),
- mArrowRight(p.right_arrow),
- mArrowDown(p.down_arrow),
- mArrowDownAndLeft(p.lower_left_arrow),
- mArrowLeftOffset(p.left_arrow_offset),
- mArrowUpOffset(p.up_arrow_offset),
- mArrowRightOffset(p.right_arrow_offset),
- mArrowDownOffset(p.down_arrow_offset),
- mHidden(false),
- mFadeInTime(p.fade_in_time),
- mFadeOutTime(p.fade_out_time),
- LLPanel(p)
+: mNotification(p.notification),
+ mDirection(TOP),
+ mDistance(p.distance),
+ mArrowLeft(p.left_arrow),
+ mArrowUp(p.up_arrow),
+ mArrowRight(p.right_arrow),
+ mArrowDown(p.down_arrow),
+ mArrowDownAndLeft(p.lower_left_arrow),
+ mArrowLeftOffset(p.left_arrow_offset),
+ mArrowUpOffset(p.up_arrow_offset),
+ mArrowRightOffset(p.right_arrow_offset),
+ mArrowDownOffset(p.down_arrow_offset),
+ mHidden(false),
+ mFadeInTime(p.fade_in_time),
+ mFadeOutTime(p.fade_out_time),
+ LLPanel(p)
{
- if (p.target_params.isProvided())
- {
- mDirection = p.target_params.direction;
- mTarget = p.target_params.target;
- }
- if (p.hint_image.isProvided())
- {
- buildFromFile("panel_hint_image.xml", p);
- getChild<LLIconCtrl>("hint_image")->setImage(p.hint_image());
- }
- else
- {
- buildFromFile( "panel_hint.xml", p);
- }
+ if (p.target_params.isProvided())
+ {
+ mDirection = p.target_params.direction;
+ mTarget = p.target_params.target;
+ }
+ if (p.hint_image.isProvided())
+ {
+ buildFromFile("panel_hint_image.xml", p);
+ getChild<LLIconCtrl>("hint_image")->setImage(p.hint_image());
+ }
+ else
+ {
+ buildFromFile( "panel_hint.xml", p);
+ }
}
BOOL LLHintPopup::postBuild()
{
- LLTextBox& hint_text = getChildRef<LLTextBox>("hint_text");
- hint_text.setText(mNotification->getMessage());
-
- getChild<LLButton>("close")->setClickedCallback(boost::bind(&LLHintPopup::onClickClose, this));
- getChild<LLTextBox>("hint_title")->setText(mNotification->getLabel());
-
- LLRect text_bounds = hint_text.getTextBoundingRect();
- S32 delta_height = text_bounds.getHeight() - hint_text.getRect().getHeight();
- reshape(getRect().getWidth(), getRect().getHeight() + delta_height);
- hint_text.reshape(hint_text.getRect().getWidth(), hint_text.getRect().getHeight() + delta_height);
-// hint_text.translate(0, -delta_height);
- return TRUE;
+ LLTextBox& hint_text = getChildRef<LLTextBox>("hint_text");
+ hint_text.setText(mNotification->getMessage());
+
+ getChild<LLButton>("close")->setClickedCallback(boost::bind(&LLHintPopup::onClickClose, this));
+ getChild<LLTextBox>("hint_title")->setText(mNotification->getLabel());
+
+ LLRect text_bounds = hint_text.getTextBoundingRect();
+ S32 delta_height = text_bounds.getHeight() - hint_text.getRect().getHeight();
+ reshape(getRect().getWidth(), getRect().getHeight() + delta_height);
+ hint_text.reshape(hint_text.getRect().getWidth(), hint_text.getRect().getHeight() + delta_height);
+// hint_text.translate(0, -delta_height);
+ return TRUE;
}
void LLHintPopup::draw()
{
- F32 alpha = 1.f;
- if (mHidden)
- {
- alpha = clamp_rescale(mFadeTimer.getElapsedTimeF32(), 0.f, mFadeOutTime, 1.f, 0.f);
- if (alpha == 0.f)
- {
- die();
- return;
- }
- }
- else
- {
- alpha = clamp_rescale(mFadeTimer.getElapsedTimeF32(), 0.f, mFadeInTime, 0.f, 1.f);
- }
-
- LLIconCtrl* hint_icon = findChild<LLIconCtrl>("hint_image");
-
- if (hint_icon)
- {
- LLUIImagePtr hint_image = hint_icon->getImage();
- S32 image_height = hint_image.isNull() ? 0 : hint_image->getHeight();
- S32 image_width = hint_image.isNull() ? 0 : hint_image->getWidth();
-
- LLView* layout_stack = hint_icon->getParent()->getParent();
- S32 delta_height = image_height - layout_stack->getRect().getHeight();
- hint_icon->getParent()->reshape(image_width, hint_icon->getParent()->getRect().getHeight());
- layout_stack->reshape(layout_stack->getRect().getWidth(), image_height);
- layout_stack->translate(0, -delta_height);
-
- LLRect hint_rect = getLocalRect();
- reshape(hint_rect.getWidth(), hint_rect.getHeight() + delta_height);
- }
-
- { LLViewDrawContext context(alpha);
-
- if (mTarget.empty())
- {
- // just draw contents, no arrow, in default position
- LLPanel::draw();
- }
- else
- {
- LLView* targetp = LLHints::getInstance()->getHintTarget(mTarget).get();
- if (!targetp)
- {
- // target widget is no longer valid, go away
- die();
- }
- else if (!targetp->isInVisibleChain())
- {
- // if target is invisible, don't draw, but keep alive in case widget comes back
- // but do make it so that it allows mouse events to pass through
- setEnabled(false);
- setMouseOpaque(false);
- }
- else
- {
- // revert back enabled and mouse opaque state in case we disabled it before
- setEnabled(true);
- setMouseOpaque(true);
-
- LLRect target_rect;
- targetp->localRectToOtherView(targetp->getLocalRect(), &target_rect, getParent());
-
- LLRect my_local_rect = getLocalRect();
- LLRect my_rect;
- LLRect arrow_rect;
- LLUIImagePtr arrow_imagep;
-
- switch(mDirection)
- {
- case LEFT:
- my_rect.setCenterAndSize( target_rect.mLeft - (my_local_rect.getWidth() / 2 + mDistance),
- target_rect.getCenterY(),
- my_local_rect.getWidth(),
- my_local_rect.getHeight());
- if (mArrowRight)
- {
- arrow_rect.setCenterAndSize(my_local_rect.mRight + mArrowRight->getWidth() / 2 + mArrowRightOffset,
- my_local_rect.getCenterY(),
- mArrowRight->getWidth(),
- mArrowRight->getHeight());
- arrow_imagep = mArrowRight;
- }
- break;
- case TOP:
- my_rect.setCenterAndSize( target_rect.getCenterX(),
- target_rect.mTop + (my_local_rect.getHeight() / 2 + mDistance),
- my_local_rect.getWidth(),
- my_local_rect.getHeight());
- if (mArrowDown)
- {
- arrow_rect.setCenterAndSize(my_local_rect.getCenterX(),
- my_local_rect.mBottom - mArrowDown->getHeight() / 2 + mArrowDownOffset,
- mArrowDown->getWidth(),
- mArrowDown->getHeight());
- arrow_imagep = mArrowDown;
- }
- break;
- case RIGHT:
- my_rect.setCenterAndSize( target_rect.mRight + (my_local_rect.getWidth() / 2 + mDistance),
- target_rect.getCenterY(),
- my_local_rect.getWidth(),
- my_local_rect.getHeight());
- if (mArrowLeft)
- {
- arrow_rect.setCenterAndSize(my_local_rect.mLeft - mArrowLeft->getWidth() / 2 + mArrowLeftOffset,
- my_local_rect.getCenterY(),
- mArrowLeft->getWidth(),
- mArrowLeft->getHeight());
- arrow_imagep = mArrowLeft;
- }
- break;
- case BOTTOM:
- my_rect.setCenterAndSize( target_rect.getCenterX(),
- target_rect.mBottom - (my_local_rect.getHeight() / 2 + mDistance),
- my_local_rect.getWidth(),
- my_local_rect.getHeight());
- if (mArrowUp)
- {
- arrow_rect.setCenterAndSize(my_local_rect.getCenterX(),
- my_local_rect.mTop + mArrowUp->getHeight() / 2 + mArrowUpOffset,
- mArrowUp->getWidth(),
- mArrowUp->getHeight());
- arrow_imagep = mArrowUp;
- }
- break;
- case TOP_RIGHT:
- my_rect.setCenterAndSize( target_rect.mRight + (my_local_rect.getWidth() / 2),
- target_rect.mTop + (my_local_rect.getHeight() / 2 + mDistance),
- my_local_rect.getWidth(),
- my_local_rect.getHeight());
- if (mArrowDownAndLeft)
- {
- arrow_rect.setCenterAndSize(my_local_rect.mLeft + mArrowDownAndLeft->getWidth() / 2 + mArrowLeftOffset,
- my_local_rect.mBottom - mArrowDownAndLeft->getHeight() / 2 + mArrowDownOffset,
- mArrowDownAndLeft->getWidth(),
- mArrowDownAndLeft->getHeight());
- arrow_imagep = mArrowDownAndLeft;
- }
- }
- setShape(my_rect);
- LLPanel::draw();
-
- if (arrow_imagep) arrow_imagep->draw(arrow_rect, LLColor4(1.f, 1.f, 1.f, alpha));
- }
- }
- }
+ F32 alpha = 1.f;
+ if (mHidden)
+ {
+ alpha = clamp_rescale(mFadeTimer.getElapsedTimeF32(), 0.f, mFadeOutTime, 1.f, 0.f);
+ if (alpha == 0.f)
+ {
+ die();
+ return;
+ }
+ }
+ else
+ {
+ alpha = clamp_rescale(mFadeTimer.getElapsedTimeF32(), 0.f, mFadeInTime, 0.f, 1.f);
+ }
+
+ LLIconCtrl* hint_icon = findChild<LLIconCtrl>("hint_image");
+
+ if (hint_icon)
+ {
+ LLUIImagePtr hint_image = hint_icon->getImage();
+ S32 image_height = hint_image.isNull() ? 0 : hint_image->getHeight();
+ S32 image_width = hint_image.isNull() ? 0 : hint_image->getWidth();
+
+ LLView* layout_stack = hint_icon->getParent()->getParent();
+ S32 delta_height = image_height - layout_stack->getRect().getHeight();
+ hint_icon->getParent()->reshape(image_width, hint_icon->getParent()->getRect().getHeight());
+ layout_stack->reshape(layout_stack->getRect().getWidth(), image_height);
+ layout_stack->translate(0, -delta_height);
+
+ LLRect hint_rect = getLocalRect();
+ reshape(hint_rect.getWidth(), hint_rect.getHeight() + delta_height);
+ }
+
+ { LLViewDrawContext context(alpha);
+
+ if (mTarget.empty())
+ {
+ // just draw contents, no arrow, in default position
+ LLPanel::draw();
+ }
+ else
+ {
+ LLView* targetp = LLHints::getInstance()->getHintTarget(mTarget).get();
+ if (!targetp)
+ {
+ // target widget is no longer valid, go away
+ die();
+ }
+ else if (!targetp->isInVisibleChain())
+ {
+ // if target is invisible, don't draw, but keep alive in case widget comes back
+ // but do make it so that it allows mouse events to pass through
+ setEnabled(false);
+ setMouseOpaque(false);
+ }
+ else
+ {
+ // revert back enabled and mouse opaque state in case we disabled it before
+ setEnabled(true);
+ setMouseOpaque(true);
+
+ LLRect target_rect;
+ targetp->localRectToOtherView(targetp->getLocalRect(), &target_rect, getParent());
+
+ LLRect my_local_rect = getLocalRect();
+ LLRect my_rect;
+ LLRect arrow_rect;
+ LLUIImagePtr arrow_imagep;
+
+ switch(mDirection)
+ {
+ case LEFT:
+ my_rect.setCenterAndSize( target_rect.mLeft - (my_local_rect.getWidth() / 2 + mDistance),
+ target_rect.getCenterY(),
+ my_local_rect.getWidth(),
+ my_local_rect.getHeight());
+ if (mArrowRight)
+ {
+ arrow_rect.setCenterAndSize(my_local_rect.mRight + mArrowRight->getWidth() / 2 + mArrowRightOffset,
+ my_local_rect.getCenterY(),
+ mArrowRight->getWidth(),
+ mArrowRight->getHeight());
+ arrow_imagep = mArrowRight;
+ }
+ break;
+ case TOP:
+ my_rect.setCenterAndSize( target_rect.getCenterX(),
+ target_rect.mTop + (my_local_rect.getHeight() / 2 + mDistance),
+ my_local_rect.getWidth(),
+ my_local_rect.getHeight());
+ if (mArrowDown)
+ {
+ arrow_rect.setCenterAndSize(my_local_rect.getCenterX(),
+ my_local_rect.mBottom - mArrowDown->getHeight() / 2 + mArrowDownOffset,
+ mArrowDown->getWidth(),
+ mArrowDown->getHeight());
+ arrow_imagep = mArrowDown;
+ }
+ break;
+ case RIGHT:
+ my_rect.setCenterAndSize( target_rect.mRight + (my_local_rect.getWidth() / 2 + mDistance),
+ target_rect.getCenterY(),
+ my_local_rect.getWidth(),
+ my_local_rect.getHeight());
+ if (mArrowLeft)
+ {
+ arrow_rect.setCenterAndSize(my_local_rect.mLeft - mArrowLeft->getWidth() / 2 + mArrowLeftOffset,
+ my_local_rect.getCenterY(),
+ mArrowLeft->getWidth(),
+ mArrowLeft->getHeight());
+ arrow_imagep = mArrowLeft;
+ }
+ break;
+ case BOTTOM:
+ my_rect.setCenterAndSize( target_rect.getCenterX(),
+ target_rect.mBottom - (my_local_rect.getHeight() / 2 + mDistance),
+ my_local_rect.getWidth(),
+ my_local_rect.getHeight());
+ if (mArrowUp)
+ {
+ arrow_rect.setCenterAndSize(my_local_rect.getCenterX(),
+ my_local_rect.mTop + mArrowUp->getHeight() / 2 + mArrowUpOffset,
+ mArrowUp->getWidth(),
+ mArrowUp->getHeight());
+ arrow_imagep = mArrowUp;
+ }
+ break;
+ case TOP_RIGHT:
+ my_rect.setCenterAndSize( target_rect.mRight + (my_local_rect.getWidth() / 2),
+ target_rect.mTop + (my_local_rect.getHeight() / 2 + mDistance),
+ my_local_rect.getWidth(),
+ my_local_rect.getHeight());
+ if (mArrowDownAndLeft)
+ {
+ arrow_rect.setCenterAndSize(my_local_rect.mLeft + mArrowDownAndLeft->getWidth() / 2 + mArrowLeftOffset,
+ my_local_rect.mBottom - mArrowDownAndLeft->getHeight() / 2 + mArrowDownOffset,
+ mArrowDownAndLeft->getWidth(),
+ mArrowDownAndLeft->getHeight());
+ arrow_imagep = mArrowDownAndLeft;
+ }
+ }
+ setShape(my_rect);
+ LLPanel::draw();
+
+ if (arrow_imagep) arrow_imagep->draw(arrow_rect, LLColor4(1.f, 1.f, 1.f, alpha));
+ }
+ }
+ }
}
@@ -365,57 +365,57 @@ LLHints::~LLHints()
void LLHints::show(LLNotificationPtr hint)
{
- LLHintPopup::Params p(LLUICtrlFactory::getDefaultParams<LLHintPopup>());
+ LLHintPopup::Params p(LLUICtrlFactory::getDefaultParams<LLHintPopup>());
- LLParamSDParser parser;
- parser.readSD(hint->getPayload(), p, true);
- p.notification = hint;
+ LLParamSDParser parser;
+ parser.readSD(hint->getPayload(), p, true);
+ p.notification = hint;
- if (p.validateBlock())
- {
- LLHintPopup* popup = new LLHintPopup(p);
+ if (p.validateBlock())
+ {
+ LLHintPopup* popup = new LLHintPopup(p);
- mHints[hint] = popup;
+ mHints[hint] = popup;
- LLView* hint_holder = gViewerWindow->getHintHolder();
- if (hint_holder)
- {
- hint_holder->addChild(popup);
- popup->centerWithin(hint_holder->getLocalRect());
- }
- }
+ LLView* hint_holder = gViewerWindow->getHintHolder();
+ if (hint_holder)
+ {
+ hint_holder->addChild(popup);
+ popup->centerWithin(hint_holder->getLocalRect());
+ }
+ }
}
void LLHints::hide(LLNotificationPtr hint)
{
- hint_map_t::iterator found_it = mHints.find(hint);
- if (found_it != mHints.end())
- {
- found_it->second->hide();
- mHints.erase(found_it);
- }
+ hint_map_t::iterator found_it = mHints.find(hint);
+ if (found_it != mHints.end())
+ {
+ found_it->second->hide();
+ mHints.erase(found_it);
+ }
}
void LLHints::registerHintTarget(const std::string& name, LLHandle<LLView> target)
{
- mTargetRegistry.defaultRegistrar().replace(name, target);
+ mTargetRegistry.defaultRegistrar().replace(name, target);
}
LLHandle<LLView> LLHints::getHintTarget(const std::string& name)
{
- LLHandle<LLView>* handlep = mTargetRegistry.getValue(name);
- if (handlep)
- {
- return *handlep;
- }
- else
- {
- return LLHandle<LLView>();
- }
+ LLHandle<LLView>* handlep = mTargetRegistry.getValue(name);
+ if (handlep)
+ {
+ return *handlep;
+ }
+ else
+ {
+ return LLHandle<LLView>();
+ }
}
void LLHints::showHints(const LLSD& show)
{
- bool visible = show.asBoolean();
- gViewerWindow->getHintHolder()->setVisible(visible);
+ bool visible = show.asBoolean();
+ gViewerWindow->getHintHolder()->setVisible(visible);
}