aboutsummaryrefslogtreecommitdiffstatshomepage
path: root/linden/indra/newview/lltexturectrl.cpp
diff options
context:
space:
mode:
authorJacek Antonelli2008-08-15 23:45:42 -0500
committerJacek Antonelli2008-08-15 23:45:42 -0500
commitce28e056c20bf2723f565bbf464b87781ec248a2 (patch)
treeef7b0501c4de4b631a916305cbc2a5fdc125e52d /linden/indra/newview/lltexturectrl.cpp
parentSecond Life viewer sources 1.19.1.4b (diff)
downloadmeta-impy-ce28e056c20bf2723f565bbf464b87781ec248a2.zip
meta-impy-ce28e056c20bf2723f565bbf464b87781ec248a2.tar.gz
meta-impy-ce28e056c20bf2723f565bbf464b87781ec248a2.tar.bz2
meta-impy-ce28e056c20bf2723f565bbf464b87781ec248a2.tar.xz
Second Life viewer sources 1.20.2
Diffstat (limited to 'linden/indra/newview/lltexturectrl.cpp')
-rw-r--r--linden/indra/newview/lltexturectrl.cpp124
1 files changed, 62 insertions, 62 deletions
diff --git a/linden/indra/newview/lltexturectrl.cpp b/linden/indra/newview/lltexturectrl.cpp
index ec8d91c..acf4a10 100644
--- a/linden/indra/newview/lltexturectrl.cpp
+++ b/linden/indra/newview/lltexturectrl.cpp
@@ -64,7 +64,7 @@
64#include "llviewerobject.h" 64#include "llviewerobject.h"
65#include "llviewercontrol.h" 65#include "llviewercontrol.h"
66#include "llglheaders.h" 66#include "llglheaders.h"
67#include "llvieweruictrlfactory.h" 67#include "lluictrlfactory.h"
68 68
69 69
70static const S32 CLOSE_BTN_WIDTH = 100; 70static const S32 CLOSE_BTN_WIDTH = 100;
@@ -119,7 +119,7 @@ public:
119 EAcceptance *accept, 119 EAcceptance *accept,
120 LLString& tooltip_msg); 120 LLString& tooltip_msg);
121 virtual void draw(); 121 virtual void draw();
122 virtual BOOL handleKeyHere(KEY key, MASK mask, BOOL called_from_parent); 122 virtual BOOL handleKeyHere(KEY key, MASK mask);
123 123
124 // LLFloater overrides 124 // LLFloater overrides
125 virtual void onClose(bool app_quitting); 125 virtual void onClose(bool app_quitting);
@@ -214,11 +214,11 @@ LLFloaterTexturePicker::LLFloaterTexturePicker(
214 mNonImmediateFilterPermMask(non_immediate_filter_perm_mask), 214 mNonImmediateFilterPermMask(non_immediate_filter_perm_mask),
215 mContextConeOpacity(0.f) 215 mContextConeOpacity(0.f)
216{ 216{
217 gUICtrlFactory->buildFloater(this,"floater_texture_ctrl.xml"); 217 LLUICtrlFactory::getInstance()->buildFloater(this,"floater_texture_ctrl.xml");
218 218
219 mTentativeLabel = LLUICtrlFactory::getTextBoxByName(this,"Multiple"); 219 mTentativeLabel = getChild<LLTextBox>("Multiple");
220 220
221 mResolutionLabel = LLUICtrlFactory::getTextBoxByName(this,"unknown"); 221 mResolutionLabel = getChild<LLTextBox>("unknown");
222 222
223 223
224 childSetAction("Default",LLFloaterTexturePicker::onBtnSetToDefault,this); 224 childSetAction("Default",LLFloaterTexturePicker::onBtnSetToDefault,this);
@@ -229,10 +229,10 @@ LLFloaterTexturePicker::LLFloaterTexturePicker(
229 childSetCommitCallback("show_folders_check", onShowFolders, this); 229 childSetCommitCallback("show_folders_check", onShowFolders, this);
230 childSetVisible("show_folders_check", FALSE); 230 childSetVisible("show_folders_check", FALSE);
231 231
232 mSearchEdit = (LLSearchEditor*)getCtrlByNameAndType("inventory search editor", WIDGET_TYPE_SEARCH_EDITOR); 232 mSearchEdit = getChild<LLSearchEditor>("inventory search editor");
233 mSearchEdit->setSearchCallback(onSearchEdit, this); 233 mSearchEdit->setSearchCallback(onSearchEdit, this);
234 234
235 mInventoryPanel = (LLInventoryPanel*)this->getCtrlByNameAndType("inventory panel", WIDGET_TYPE_INVENTORY_PANEL); 235 mInventoryPanel = getChild<LLInventoryPanel>("inventory panel");
236 236
237 if(mInventoryPanel) 237 if(mInventoryPanel)
238 { 238 {
@@ -332,9 +332,9 @@ void LLFloaterTexturePicker::setCanApplyImmediately(BOOL b)
332 332
333void LLFloaterTexturePicker::stopUsingPipette() 333void LLFloaterTexturePicker::stopUsingPipette()
334{ 334{
335 if (gToolMgr && gToolMgr->getCurrentTool() == gToolPipette) 335 if (LLToolMgr::getInstance()->getCurrentTool() == LLToolPipette::getInstance())
336 { 336 {
337 gToolMgr->clearTransientTool(); 337 LLToolMgr::getInstance()->clearTransientTool();
338 } 338 }
339} 339}
340 340
@@ -407,15 +407,15 @@ BOOL LLFloaterTexturePicker::handleDragAndDrop(
407 return handled; 407 return handled;
408} 408}
409 409
410BOOL LLFloaterTexturePicker::handleKeyHere(KEY key, MASK mask, BOOL called_from_parent) 410BOOL LLFloaterTexturePicker::handleKeyHere(KEY key, MASK mask)
411{ 411{
412 LLFolderView* root_folder = mInventoryPanel->getRootFolder(); 412 LLFolderView* root_folder = mInventoryPanel->getRootFolder();
413 413
414 if (root_folder && mSearchEdit) 414 if (root_folder && mSearchEdit)
415 { 415 {
416 if (!called_from_parent && mSearchEdit->hasFocus() && 416 if (mSearchEdit->hasFocus()
417 (key == KEY_RETURN || key == KEY_DOWN) && 417 && (key == KEY_RETURN || key == KEY_DOWN)
418 mask == MASK_NONE) 418 && mask == MASK_NONE)
419 { 419 {
420 if (!root_folder->getCurSelectedItem()) 420 if (!root_folder->getCurSelectedItem())
421 { 421 {
@@ -442,7 +442,7 @@ BOOL LLFloaterTexturePicker::handleKeyHere(KEY key, MASK mask, BOOL called_from_
442 } 442 }
443 } 443 }
444 444
445 return LLFloater::handleKeyHere(key, mask, called_from_parent); 445 return LLFloater::handleKeyHere(key, mask);
446} 446}
447 447
448// virtual 448// virtual
@@ -533,14 +533,14 @@ void LLFloaterTexturePicker::draw()
533 // if we're inactive, gray out "apply immediate" checkbox 533 // if we're inactive, gray out "apply immediate" checkbox
534 childSetEnabled("show_folders_check", mActive && mCanApplyImmediately && !mNoCopyTextureSelected); 534 childSetEnabled("show_folders_check", mActive && mCanApplyImmediately && !mNoCopyTextureSelected);
535 childSetEnabled("Select", mActive); 535 childSetEnabled("Select", mActive);
536 childSetEnabled("Pipette", gToolMgr != NULL && mActive); 536 childSetEnabled("Pipette", mActive);
537 childSetValue("Pipette", gToolMgr && gToolMgr->getCurrentTool() == gToolPipette); 537 childSetValue("Pipette", LLToolMgr::getInstance()->getCurrentTool() == LLToolPipette::getInstance());
538 538
539 //RN: reset search bar to reflect actual search query (all caps, for example) 539 //RN: reset search bar to reflect actual search query (all caps, for example)
540 mSearchEdit->setText(mInventoryPanel->getFilterSubString()); 540 mSearchEdit->setText(mInventoryPanel->getFilterSubString());
541 541
542 //BOOL allow_copy = FALSE; 542 //BOOL allow_copy = FALSE;
543 if( getVisible() && mOwner) 543 if( mOwner )
544 { 544 {
545 mTexturep = NULL; 545 mTexturep = NULL;
546 if(mImageAssetID.notNull()) 546 if(mImageAssetID.notNull())
@@ -739,18 +739,18 @@ void LLFloaterTexturePicker::onBtnPipette( void* userdata )
739{ 739{
740 LLFloaterTexturePicker* self = (LLFloaterTexturePicker*) userdata; 740 LLFloaterTexturePicker* self = (LLFloaterTexturePicker*) userdata;
741 741
742 if ( self && gToolMgr) 742 if ( self)
743 { 743 {
744 BOOL pipette_active = self->childGetValue("Pipette").asBoolean(); 744 BOOL pipette_active = self->childGetValue("Pipette").asBoolean();
745 pipette_active = !pipette_active; 745 pipette_active = !pipette_active;
746 if (pipette_active) 746 if (pipette_active)
747 { 747 {
748 gToolPipette->setSelectCallback(onTextureSelect, self); 748 LLToolPipette::getInstance()->setSelectCallback(onTextureSelect, self);
749 gToolMgr->setTransientTool(gToolPipette); 749 LLToolMgr::getInstance()->setTransientTool(LLToolPipette::getInstance());
750 } 750 }
751 else 751 else
752 { 752 {
753 gToolMgr->clearTransientTool(); 753 LLToolMgr::getInstance()->clearTransientTool();
754 } 754 }
755 } 755 }
756 756
@@ -859,7 +859,7 @@ void LLFloaterTexturePicker::onTextureSelect( const LLTextureEntry& te, void *da
859 LLUUID inventory_item_id = self->findItemID(te.getID(), TRUE); 859 LLUUID inventory_item_id = self->findItemID(te.getID(), TRUE);
860 if (self && inventory_item_id.notNull()) 860 if (self && inventory_item_id.notNull())
861 { 861 {
862 gToolPipette->setResult(TRUE, ""); 862 LLToolPipette::getInstance()->setResult(TRUE, "");
863 self->setImageID(te.getID()); 863 self->setImageID(te.getID());
864 864
865 self->mNoCopyTextureSelected = FALSE; 865 self->mNoCopyTextureSelected = FALSE;
@@ -875,13 +875,15 @@ void LLFloaterTexturePicker::onTextureSelect( const LLTextureEntry& te, void *da
875 } 875 }
876 else 876 else
877 { 877 {
878 gToolPipette->setResult(FALSE, "You do not have a copy this \nof texture in your inventory"); 878 LLToolPipette::getInstance()->setResult(FALSE, "You do not have a copy this \nof texture in your inventory");
879 } 879 }
880} 880}
881 881
882/////////////////////////////////////////////////////////////////////// 882///////////////////////////////////////////////////////////////////////
883// LLTextureCtrl 883// LLTextureCtrl
884 884
885static LLRegisterWidget<LLTextureCtrl> r("texture_picker");
886
885LLTextureCtrl::LLTextureCtrl( 887LLTextureCtrl::LLTextureCtrl(
886 const std::string& name, 888 const std::string& name,
887 const LLRect &rect, 889 const LLRect &rect,
@@ -933,6 +935,7 @@ LLTextureCtrl::LLTextureCtrl(
933 LLRect border_rect(0, getRect().getHeight(), getRect().getWidth(), 0); 935 LLRect border_rect(0, getRect().getHeight(), getRect().getWidth(), 0);
934 border_rect.mBottom += BTN_HEIGHT_SMALL; 936 border_rect.mBottom += BTN_HEIGHT_SMALL;
935 mBorder = new LLViewBorder("border", border_rect, LLViewBorder::BEVEL_IN); 937 mBorder = new LLViewBorder("border", border_rect, LLViewBorder::BEVEL_IN);
938 mBorder->setFollowsAll();
936 addChild(mBorder); 939 addChild(mBorder);
937 940
938 setEnabled(TRUE); // for the tooltip 941 setEnabled(TRUE); // for the tooltip
@@ -1276,50 +1279,47 @@ BOOL LLTextureCtrl::handleDragAndDrop(S32 x, S32 y, MASK mask,
1276 1279
1277void LLTextureCtrl::draw() 1280void LLTextureCtrl::draw()
1278{ 1281{
1279 if( getVisible() ) 1282 mBorder->setKeyboardFocusHighlight(hasFocus());
1280 {
1281 mBorder->setKeyboardFocusHighlight(hasFocus());
1282 1283
1283 if (mImageAssetID.isNull() || !mValid) 1284 if (mImageAssetID.isNull() || !mValid)
1284 { 1285 {
1285 mTexturep = NULL; 1286 mTexturep = NULL;
1286 } 1287 }
1287 else 1288 else
1288 { 1289 {
1289 mTexturep = gImageList.getImage(mImageAssetID, MIPMAP_YES, IMMEDIATE_NO); 1290 mTexturep = gImageList.getImage(mImageAssetID, MIPMAP_YES, IMMEDIATE_NO);
1290 mTexturep->setBoostLevel(LLViewerImage::BOOST_PREVIEW); 1291 mTexturep->setBoostLevel(LLViewerImage::BOOST_PREVIEW);
1291 } 1292 }
1292 1293
1293 // Border 1294 // Border
1294 LLRect border( 0, getRect().getHeight(), getRect().getWidth(), BTN_HEIGHT_SMALL ); 1295 LLRect border( 0, getRect().getHeight(), getRect().getWidth(), BTN_HEIGHT_SMALL );
1295 gl_rect_2d( border, mBorderColor, FALSE ); 1296 gl_rect_2d( border, mBorderColor, FALSE );
1296 1297
1297 // Interior 1298 // Interior
1298 LLRect interior = border; 1299 LLRect interior = border;
1299 interior.stretch( -1 ); 1300 interior.stretch( -1 );
1300 1301
1301 if( mTexturep ) 1302 if( mTexturep )
1303 {
1304 if( mTexturep->getComponents() == 4 )
1302 { 1305 {
1303 if( mTexturep->getComponents() == 4 ) 1306 gl_rect_2d_checkerboard( interior );
1304 {
1305 gl_rect_2d_checkerboard( interior );
1306 }
1307
1308 gl_draw_scaled_image( interior.mLeft, interior.mBottom, interior.getWidth(), interior.getHeight(), mTexturep);
1309 mTexturep->addTextureStats( (F32)(interior.getWidth() * interior.getHeight()) );
1310 } 1307 }
1311 else 1308
1312 { 1309 gl_draw_scaled_image( interior.mLeft, interior.mBottom, interior.getWidth(), interior.getHeight(), mTexturep);
1313 gl_rect_2d( interior, LLColor4::grey, TRUE ); 1310 mTexturep->addTextureStats( (F32)(interior.getWidth() * interior.getHeight()) );
1311 }
1312 else
1313 {
1314 gl_rect_2d( interior, LLColor4::grey, TRUE );
1314 1315
1315 // Draw X 1316 // Draw X
1316 gl_draw_x( interior, LLColor4::black ); 1317 gl_draw_x( interior, LLColor4::black );
1317 } 1318 }
1318 1319
1319 mTentativeLabel->setVisible( !mTexturep.isNull() && getTentative() ); 1320 mTentativeLabel->setVisible( !mTexturep.isNull() && getTentative() );
1320 1321
1321 LLUICtrl::draw(); 1322 LLUICtrl::draw();
1322 }
1323} 1323}
1324 1324
1325BOOL LLTextureCtrl::allowDrop(LLInventoryItem* item) 1325BOOL LLTextureCtrl::allowDrop(LLInventoryItem* item)
@@ -1370,14 +1370,14 @@ BOOL LLTextureCtrl::doDrop(LLInventoryItem* item)
1370 return TRUE; 1370 return TRUE;
1371} 1371}
1372 1372
1373BOOL LLTextureCtrl::handleUnicodeCharHere(llwchar uni_char, BOOL called_from_parent) 1373BOOL LLTextureCtrl::handleUnicodeCharHere(llwchar uni_char)
1374{ 1374{
1375 if( getVisible() && getEnabled() && !called_from_parent && ' ' == uni_char ) 1375 if( ' ' == uni_char )
1376 { 1376 {
1377 showPicker(TRUE); 1377 showPicker(TRUE);
1378 return TRUE; 1378 return TRUE;
1379 } 1379 }
1380 return LLUICtrl::handleUnicodeCharHere(uni_char, called_from_parent); 1380 return LLUICtrl::handleUnicodeCharHere(uni_char);
1381} 1381}
1382 1382
1383void LLTextureCtrl::setValue( const LLSD& value ) 1383void LLTextureCtrl::setValue( const LLSD& value )