diff --git a/indra/newview/llhudnametag.cpp b/indra/newview/llhudnametag.cpp index f99bcfe15..42bfcf793 100644 --- a/indra/newview/llhudnametag.cpp +++ b/indra/newview/llhudnametag.cpp @@ -112,6 +112,7 @@ LLHUDNameTag::LLHUDNameTag(const U8 type) { LLPointer ptr(this); sTextObjects.insert(ptr); + mBubbleImage = LLUI::getUIImage("Rounded_Rect.png"); } LLHUDNameTag::~LLHUDNameTag() @@ -296,9 +297,6 @@ void LLHUDNameTag::renderText(BOOL for_select) mOffsetY = lltrunc(mHeight * ((mVertAlignment == ALIGN_VERT_CENTER) ? 0.5f : 1.f)); - // *TODO: cache this image - LLUIImagePtr imagep = LLUI::getUIImage("rounded_square.tga"); - // *TODO: make this a per-text setting static const LLCachedControl background_chat_color("BackgroundChatColor", LLColor4(0,0,0,1.f)); static const LLCachedControl chat_bubble_opacity("ChatBubbleOpacity", .5); @@ -331,7 +329,7 @@ void LLHUDNameTag::renderText(BOOL for_select) LLViewerCamera::getInstance()->getPixelVectors(mPositionAgent, y_pixel_vec, x_pixel_vec); - LLVector2 border_scale_vec((F32)border_width / (F32)imagep->getTextureWidth(), (F32)border_height / (F32)imagep->getTextureHeight()); + LLVector2 border_scale_vec((F32)border_width / (F32)mBubbleImage->getTextureWidth(), (F32)border_height / (F32)mBubbleImage->getTextureHeight()); LLVector3 width_vec = mWidth * x_pixel_vec; LLVector3 height_vec = mHeight * y_pixel_vec; LLVector3 scaled_border_width = (F32)llfloor(border_scale * (F32)border_width) * x_pixel_vec; @@ -379,11 +377,11 @@ void LLHUDNameTag::renderText(BOOL for_select) } else { - gGL.getTexUnit(0)->bind(imagep->getImage()); + gGL.getTexUnit(0)->bind(mBubbleImage->getImage()); gGL.color4fv(bg_color.mV); gl_segmented_rect_3d_tex(border_scale_vec, scaled_border_width, scaled_border_height, width_vec, height_vec); - + if ( mLabelSegments.size()) { LLUI::pushMatrix(); diff --git a/indra/newview/llhudnametag.h b/indra/newview/llhudnametag.h index 3325c22de..8c6185272 100644 --- a/indra/newview/llhudnametag.h +++ b/indra/newview/llhudnametag.h @@ -37,6 +37,7 @@ #include "llrect.h" //#include "llframetimer.h" #include "llfontgl.h" +#include "lluiimage.h" #include #include @@ -173,6 +174,8 @@ private: EVertAlignment mVertAlignment; S32 mLOD; BOOL mHidden; + + LLPointer mBubbleImage; static BOOL sDisplayText ; static std::set > sTextObjects; diff --git a/indra/newview/skins/default/textures/Rounded_Rect.png b/indra/newview/skins/default/textures/Rounded_Rect.png new file mode 100644 index 000000000..c270c2803 Binary files /dev/null and b/indra/newview/skins/default/textures/Rounded_Rect.png differ