lldebugmessagebox.cpp
上传用户:king477883
上传日期:2021-03-01
资源大小:9553k
文件大小:9k
源码类别:

游戏引擎

开发平台:

C++ Builder

  1. /** 
  2.  * @file lldebugmessagebox.cpp
  3.  * @brief Implementation of a simple, non-modal message box.
  4.  *
  5.  * $LicenseInfo:firstyear=2002&license=viewergpl$
  6.  * 
  7.  * Copyright (c) 2002-2010, Linden Research, Inc.
  8.  * 
  9.  * Second Life Viewer Source Code
  10.  * The source code in this file ("Source Code") is provided by Linden Lab
  11.  * to you under the terms of the GNU General Public License, version 2.0
  12.  * ("GPL"), unless you have obtained a separate licensing agreement
  13.  * ("Other License"), formally executed by you and Linden Lab.  Terms of
  14.  * the GPL can be found in doc/GPL-license.txt in this distribution, or
  15.  * online at http://secondlifegrid.net/programs/open_source/licensing/gplv2
  16.  * 
  17.  * There are special exceptions to the terms and conditions of the GPL as
  18.  * it is applied to this Source Code. View the full text of the exception
  19.  * in the file doc/FLOSS-exception.txt in this software distribution, or
  20.  * online at
  21.  * http://secondlifegrid.net/programs/open_source/licensing/flossexception
  22.  * 
  23.  * By copying, modifying or distributing this software, you acknowledge
  24.  * that you have read and understood your obligations described above,
  25.  * and agree to abide by those obligations.
  26.  * 
  27.  * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO
  28.  * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY,
  29.  * COMPLETENESS OR PERFORMANCE.
  30.  * $/LicenseInfo$
  31.  */
  32. #include "llviewerprecompiledheaders.h"
  33. #include "lldebugmessagebox.h"
  34. #include "llresmgr.h"
  35. #include "llfontgl.h"
  36. #include "llbutton.h"
  37. #include "llsliderctrl.h"
  38. #include "llcheckboxctrl.h"
  39. #include "lltextbox.h"
  40. #include "lllineeditor.h"
  41. #include "llfocusmgr.h"
  42. ///----------------------------------------------------------------------------
  43. /// Class LLDebugVarMessageBox
  44. ///----------------------------------------------------------------------------
  45. std::map<std::string, LLDebugVarMessageBox*> LLDebugVarMessageBox::sInstances;
  46. LLDebugVarMessageBox::LLDebugVarMessageBox(const std::string& title, EDebugVarType var_type, void *var) : 
  47. LLFloater(LLSD()),
  48. mVarType(var_type), mVarData(var), mAnimate(FALSE)
  49. {
  50. setRect(LLRect(10,160,400,10));
  51. LLSliderCtrl::Params slider_p;
  52. slider_p.label(title);
  53. slider_p.label_width(70);
  54. slider_p.text_width(40);
  55. slider_p.can_edit_text(true);
  56. slider_p.show_text(true);
  57. mSlider1 = NULL;
  58. mSlider2 = NULL;
  59. mSlider3 = NULL;
  60. switch(var_type)
  61. {
  62. case VAR_TYPE_F32:
  63. slider_p.name("slider 1");
  64. slider_p.rect(LLRect(20,130,190,110));
  65. slider_p.initial_value(*((F32*)var));
  66. slider_p.min_value(-100.f);
  67. slider_p.max_value(100.f);
  68. slider_p.increment(0.1f);
  69. slider_p.decimal_digits(3);
  70. mSlider1 = LLUICtrlFactory::create<LLSliderCtrl>(slider_p);
  71. addChild(mSlider1);
  72. break;
  73. case VAR_TYPE_S32:
  74. slider_p.name("slider 1");
  75. slider_p.rect(LLRect(20,100,190,80));
  76. slider_p.initial_value((F32)*((S32*)var));
  77. slider_p.min_value(-255.f);
  78. slider_p.max_value(255.f);
  79. slider_p.increment(1.f);
  80. slider_p.decimal_digits(0);
  81. mSlider1 = LLUICtrlFactory::create<LLSliderCtrl>(slider_p);
  82. addChild(mSlider1);
  83. break;
  84. case VAR_TYPE_VEC3:
  85. slider_p.name("slider 1");
  86. slider_p.label("x: ");
  87. slider_p.rect(LLRect(20,130,190,110));
  88. slider_p.initial_value(((LLVector3*)var)->mV[VX]);
  89. slider_p.min_value(-100.f);
  90. slider_p.max_value(100.f);
  91. slider_p.increment(0.1f);
  92. slider_p.decimal_digits(3);
  93. mSlider1 = LLUICtrlFactory::create<LLSliderCtrl>(slider_p);
  94. slider_p.name("slider 2");
  95. slider_p.label("y: ");
  96. slider_p.rect(LLRect(20,100,190,80));
  97. slider_p.initial_value(((LLVector3*)var)->mV[VY]);
  98. mSlider2 = LLUICtrlFactory::create<LLSliderCtrl>(slider_p);
  99. slider_p.name("slider 3");
  100. slider_p.label("z: ");
  101. slider_p.rect(LLRect(20,70,190,50));
  102. slider_p.initial_value(((LLVector3*)var)->mV[VZ]);
  103. mSlider2 = LLUICtrlFactory::create<LLSliderCtrl>(slider_p);
  104. addChild(mSlider1);
  105. addChild(mSlider2);
  106. addChild(mSlider3);
  107. break;
  108. default:
  109. llwarns << "Unhandled var type " << var_type << llendl;
  110. break;
  111. }
  112. LLButton::Params p;
  113. p.name(std::string("Animate"));
  114. p.label(std::string("Animate"));
  115. p.rect(LLRect(20, 45, 180, 25));
  116. p.click_callback.function(boost::bind(&LLDebugVarMessageBox::onAnimateClicked, this, _2));
  117. mAnimateButton = LLUICtrlFactory::create<LLButton>(p);
  118. addChild(mAnimateButton);
  119. LLTextBox::Params params;
  120. params.name("value");
  121. params.initial_value(params.name());
  122. params.rect(LLRect(20,20,190,0));
  123. mText = LLUICtrlFactory::create<LLTextBox> (params);
  124. addChild(mText);
  125. //disable hitting enter closes dialog
  126. setDefaultBtn();
  127. }
  128. LLDebugVarMessageBox::~LLDebugVarMessageBox()
  129. {
  130. sInstances.erase(mTitle);
  131. }
  132. void LLDebugVarMessageBox::show(const std::string& title, F32 *var, F32 max_value, F32 increment)
  133. {
  134. #ifndef LL_RELEASE_FOR_DOWNLOAD
  135. LLDebugVarMessageBox* box = show(title, VAR_TYPE_F32, (void*)var);
  136. max_value = llabs(max_value);
  137. box->mSlider1->setMaxValue(max_value);
  138. box->mSlider1->setMinValue(-max_value);
  139. box->mSlider1->setIncrement(increment);
  140. if (!gFocusMgr.childHasKeyboardFocus(box))
  141. {
  142. box->mSlider1->setValue(*var);
  143. }
  144. box->mSlider1->setCommitCallback(boost::bind(&LLDebugVarMessageBox::sliderChanged, box, _2));
  145. #endif
  146. }
  147. void LLDebugVarMessageBox::show(const std::string& title, S32 *var, S32 max_value, S32 increment)
  148. {
  149. #ifndef LL_RELEASE_FOR_DOWNLOAD
  150. LLDebugVarMessageBox* box = show(title, VAR_TYPE_S32, (void*)var);
  151. F32 max_val = llabs((F32)max_value);
  152. box->mSlider1->setMaxValue(max_val);
  153. box->mSlider1->setMinValue(-max_val);
  154. box->mSlider1->setIncrement((F32)increment);
  155. if (!gFocusMgr.childHasKeyboardFocus(box))
  156. {
  157. box->mSlider1->setValue((F32)*var);
  158. }
  159. box->mSlider1->setCommitCallback(boost::bind(&LLDebugVarMessageBox::sliderChanged, box, _2));
  160. #endif
  161. }
  162. void LLDebugVarMessageBox::show(const std::string& title, LLVector3 *var, LLVector3 max_value, LLVector3 increment)
  163. {
  164. #ifndef LL_RELEASE_FOR_DOWNLOAD
  165. LLDebugVarMessageBox* box = show(title, VAR_TYPE_VEC3, (LLVector3*)var);
  166. max_value.abs();
  167. box->mSlider1->setMaxValue(max_value.mV[VX]);
  168. box->mSlider1->setMinValue(-max_value.mV[VX]);
  169. box->mSlider1->setIncrement(increment.mV[VX]);
  170. box->mSlider1->setCommitCallback(boost::bind(&LLDebugVarMessageBox::sliderChanged, box, _2));
  171. box->mSlider2->setMaxValue(max_value.mV[VX]);
  172. box->mSlider2->setMinValue(-max_value.mV[VX]);
  173. box->mSlider2->setIncrement(increment.mV[VX]);
  174. box->mSlider2->setCommitCallback(boost::bind(&LLDebugVarMessageBox::sliderChanged, box, _2));
  175. box->mSlider3->setMaxValue(max_value.mV[VX]);
  176. box->mSlider3->setMinValue(-max_value.mV[VX]);
  177. box->mSlider3->setIncrement(increment.mV[VX]);
  178. box->mSlider3->setCommitCallback(boost::bind(&LLDebugVarMessageBox::sliderChanged, box, _2));
  179. #endif
  180. }
  181. LLDebugVarMessageBox* LLDebugVarMessageBox::show(const std::string& title, EDebugVarType var_type, void *var)
  182. {
  183. std::string title_string(title);
  184. LLDebugVarMessageBox *box = sInstances[title_string];
  185. if (!box)
  186. {
  187. box = new LLDebugVarMessageBox(title, var_type, var);
  188. sInstances[title_string] = box;
  189. gFloaterView->addChild(box);
  190. box->reshape(200,150);
  191. box->openFloater();
  192. box->mTitle = title_string;
  193. }
  194. return box;
  195. }
  196. void LLDebugVarMessageBox::sliderChanged(const LLSD& data)
  197. {
  198. if (!mVarData)
  199. return;
  200. switch(mVarType)
  201. {
  202. case VAR_TYPE_F32:
  203. *((F32*)mVarData) = (F32)mSlider1->getValue().asReal();
  204. break;
  205. case VAR_TYPE_S32:
  206. *((S32*)mVarData) = (S32)mSlider1->getValue().asInteger();
  207. break;
  208. case VAR_TYPE_VEC3:
  209. {
  210. LLVector3* vec_p = (LLVector3*)mVarData;
  211. vec_p->setVec((F32)mSlider1->getValue().asReal(), 
  212. (F32)mSlider2->getValue().asReal(), 
  213. (F32)mSlider3->getValue().asReal());
  214. break;
  215. }
  216. default:
  217. llwarns << "Unhandled var type " << mVarType << llendl;
  218. break;
  219. }
  220. }
  221. void LLDebugVarMessageBox::onAnimateClicked(const LLSD& data)
  222. {
  223. mAnimate = !mAnimate;
  224. mAnimateButton->setToggleState(mAnimate);
  225. }
  226. void LLDebugVarMessageBox::draw()
  227. {
  228. std::string text;
  229. switch(mVarType)
  230. {
  231.   case VAR_TYPE_F32:
  232. text = llformat("%.3f", *((F32*)mVarData));
  233. break;
  234.   case VAR_TYPE_S32:
  235. text = llformat("%d", *((S32*)mVarData));
  236. break;
  237.   case VAR_TYPE_VEC3:
  238.   {
  239.   LLVector3* vec_p = (LLVector3*)mVarData;
  240.   text= llformat("%.3f %.3f %.3f", vec_p->mV[VX], vec_p->mV[VY], vec_p->mV[VZ]);
  241.   break;
  242.   }
  243.   default:
  244. llwarns << "Unhandled var type " << mVarType << llendl;
  245. break;
  246. }
  247. mText->setText(text);
  248. if(mAnimate)
  249. {
  250. if (mSlider1)
  251. {
  252. F32 animated_val = clamp_rescale(fmodf((F32)LLFrameTimer::getElapsedSeconds() / 5.f, 1.f), 0.f, 1.f, 0.f, mSlider1->getMaxValue());
  253. mSlider1->setValue(animated_val);
  254. sliderChanged(LLSD());
  255. if (mSlider2)
  256. {
  257. mSlider2->setValue(animated_val);
  258. sliderChanged(LLSD());
  259. }
  260. if (mSlider3)
  261. {
  262. mSlider3->setValue(animated_val);
  263. sliderChanged(LLSD());
  264. }
  265. }
  266. }
  267. LLFloater::draw();
  268. }