aboutsummaryrefslogtreecommitdiffstatshomepage
path: root/linden/indra/newview/llfloaterwater.cpp
diff options
context:
space:
mode:
Diffstat (limited to 'linden/indra/newview/llfloaterwater.cpp')
-rw-r--r--linden/indra/newview/llfloaterwater.cpp85
1 files changed, 77 insertions, 8 deletions
diff --git a/linden/indra/newview/llfloaterwater.cpp b/linden/indra/newview/llfloaterwater.cpp
index c42b12b..7e2f188 100644
--- a/linden/indra/newview/llfloaterwater.cpp
+++ b/linden/indra/newview/llfloaterwater.cpp
@@ -168,7 +168,11 @@ void LLFloaterWater::initCallbacks(void) {
168 168
169 LLTextureCtrl* textCtrl = getChild<LLTextureCtrl>("WaterNormalMap"); 169 LLTextureCtrl* textCtrl = getChild<LLTextureCtrl>("WaterNormalMap");
170 textCtrl->setDefaultImageAssetID(DEFAULT_WATER_NORMAL); 170 textCtrl->setDefaultImageAssetID(DEFAULT_WATER_NORMAL);
171 childSetCommitCallback("WaterNormalMap", onNormalMapPicked, NULL); 171 childSetCommitCallback("WaterNormalMap", onNormalMapPicked, NULL);
172
173 // next/prev buttons
174 childSetAction("next", onClickNext, this);
175 childSetAction("prev", onClickPrev, this);
172} 176}
173 177
174void LLFloaterWater::onClickHelp(void* data) 178void LLFloaterWater::onClickHelp(void* data)
@@ -237,6 +241,12 @@ void LLFloaterWater::syncMenu()
237 241
238 LLWaterParamSet & current_params = param_mgr->mCurParams; 242 LLWaterParamSet & current_params = param_mgr->mCurParams;
239 243
244 LLComboBox* comboBox = getChild<LLComboBox>("WaterPresetsCombo");
245 if (comboBox->getSelectedItemLabel() != current_params.mName)
246 {
247 comboBox->setSimple(current_params.mName);
248 }
249
240 // blue horizon 250 // blue horizon
241 param_mgr->mFogColor = current_params.getVector4(param_mgr->mFogColor.mName, err); 251 param_mgr->mFogColor = current_params.getVector4(param_mgr->mFogColor.mName, err);
242 252
@@ -306,14 +316,26 @@ LLFloaterWater* LLFloaterWater::instance()
306} 316}
307void LLFloaterWater::show() 317void LLFloaterWater::show()
308{ 318{
309 LLFloaterWater* water = instance(); 319 if (!sWaterMenu)
310 water->syncMenu(); 320 {
311 321 LLFloaterWater* water = instance();
312 // comment in if you want the menu to rebuild each time 322 water->syncMenu();
313 //LLUICtrlFactory::getInstance()->buildFloater(water, "floater_water.xml");
314 //water->initCallbacks();
315 323
316 water->open(); 324 // comment in if you want the menu to rebuild each time
325 //LLUICtrlFactory::getInstance()->buildFloater(water, "floater_water.xml");
326 //water->initCallbacks();
327 }
328 else
329 {
330 if (sWaterMenu->getVisible())
331 {
332 sWaterMenu->close();
333 }
334 else
335 {
336 sWaterMenu->open();
337 }
338 }
317} 339}
318 340
319bool LLFloaterWater::isOpen() 341bool LLFloaterWater::isOpen()
@@ -727,3 +749,50 @@ void LLFloaterWater::onChangePresetName(LLUICtrl* ctrl, void * userData)
727 sWaterMenu->syncMenu(); 749 sWaterMenu->syncMenu();
728} 750}
729 751
752void LLFloaterWater::onClickNext(void* user_data)
753{
754 LLWaterParamManager * param_mgr = LLWaterParamManager::instance();
755 LLWaterParamSet& currentParams = param_mgr->mCurParams;
756
757 // find place of current param
758 std::map<std::string, LLWaterParamSet>::iterator mIt =
759 param_mgr->mParamList.find(currentParams.mName);
760
761 // if at the end, loop
762 std::map<std::string, LLWaterParamSet>::iterator last = param_mgr->mParamList.end(); --last;
763 if(mIt == last)
764 {
765 mIt = param_mgr->mParamList.begin();
766 }
767 else
768 {
769 mIt++;
770 }
771 /*param_mgr->mAnimator.mIsRunning = false;
772 param_mgr->mAnimator.mUseLindenTime = false;*/
773 param_mgr->loadPreset(mIt->first, true);
774}
775
776void LLFloaterWater::onClickPrev(void* user_data)
777{
778 LLWaterParamManager * param_mgr = LLWaterParamManager::instance();
779 LLWaterParamSet & currentParams = param_mgr->mCurParams;
780
781 // find place of current param
782 std::map<std::string, LLWaterParamSet>::iterator mIt =
783 param_mgr->mParamList.find(currentParams.mName);
784
785 // if at the beginning, loop
786 if(mIt == param_mgr->mParamList.begin())
787 {
788 std::map<std::string, LLWaterParamSet>::iterator last = param_mgr->mParamList.end(); --last;
789 mIt = last;
790 }
791 else
792 {
793 mIt--;
794 }
795 /*param_mgr->mAnimator.mIsRunning = false;
796 param_mgr->mAnimator.mUseLindenTime = false;*/
797 param_mgr->loadPreset(mIt->first, true);
798}