settingLogic.cc 8.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240
  1. #pragma once
  2. #include "uart/ProtocolSender.h"
  3. #include "storage/StoragePreferences.h"
  4. #include "service/BusinessConfig.h"
  5. #include "manager/LanguageManager.h"
  6. /*
  7. *此文件由GUI工具生成
  8. *文件功能:用于处理用户的逻辑相应代码
  9. *功能说明:
  10. *========================onButtonClick_XXXX
  11. 当页面中的按键按下后系统会调用对应的函数,XXX代表GUI工具里面的[ID值]名称,
  12. 如Button1,当返回值为false的时候系统将不再处理这个按键,返回true的时候系统将会继续处理此按键。比如SYS_BACK.
  13. *========================onSlideWindowItemClick_XXXX(int index)
  14. 当页面中存在滑动窗口并且用户点击了滑动窗口的图标后系统会调用此函数,XXX代表GUI工具里面的[ID值]名称,
  15. 如slideWindow1;index 代表按下图标的偏移值
  16. *========================onSeekBarChange_XXXX(int progress)
  17. 当页面中存在滑动条并且用户改变了进度后系统会调用此函数,XXX代表GUI工具里面的[ID值]名称,
  18. 如SeekBar1;progress 代表当前的进度值
  19. *========================ogetListItemCount_XXXX()
  20. 当页面中存在滑动列表的时候,更新的时候系统会调用此接口获取列表的总数目,XXX代表GUI工具里面的[ID值]名称,
  21. 如List1;返回值为当前列表的总条数
  22. *========================oobtainListItemData_XXXX(ZKListView::ZKListItem *pListItem, int index)
  23. 当页面中存在滑动列表的时候,更新的时候系统会调用此接口获取列表当前条目下的内容信息,XXX代表GUI工具里面的[ID值]名称,
  24. 如List1;pListItem 是贴图中的单条目对象,index是列表总目的偏移量。具体见函数说明
  25. *========================常用接口===============
  26. *LOGD(...) 打印调试信息的接口
  27. *mTextXXXPtr->setText("****") 在控件TextXXX上显示文字****
  28. *mButton1Ptr->setSelected(true); 将控件mButton1设置为选中模式,图片会切换成选中图片,按钮文字会切换为选中后的颜色
  29. *mSeekBarPtr->setProgress(12) 在控件mSeekBar上将进度调整到12
  30. *mListView1Ptr->refreshListView() 让mListView1 重新刷新,当列表数据变化后调用
  31. *mDashbroadView1Ptr->setTargetAngle(120) 在控件mDashbroadView1上指针显示角度调整到120度
  32. *
  33. * 在Eclipse编辑器中 使用 “alt + /” 快捷键可以打开智能提示
  34. */
  35. static int themeRadioButton = StoragePreferences::getInt(STORE_THEME, defaultThemeInt);
  36. void setSettingTheme() {
  37. if (themeRadioButton == 1) {
  38. msys_backPtr->setButtonStatusPic(ZK_CONTROL_STATUS_NORMAL, "/button/back_bule.png");
  39. mTestButtonPtr->setButtonStatusPic(ZK_CONTROL_STATUS_NORMAL, "/button/elliptic_bule2.png");
  40. }
  41. else if (themeRadioButton == 2) {
  42. msys_backPtr->setButtonStatusPic(ZK_CONTROL_STATUS_NORMAL, "/button/back_pink.png");
  43. mTestButtonPtr->setButtonStatusPic(ZK_CONTROL_STATUS_NORMAL, "/button/elliptic_pink2.png");
  44. }
  45. }
  46. /**
  47. * 注册定时器
  48. * 填充数组用于注册定时器
  49. * 注意:id不能重复
  50. */
  51. static S_ACTIVITY_TIMEER REGISTER_ACTIVITY_TIMER_TAB[] = {
  52. //{0, 6000}, //定时器id=0, 时间间隔6秒
  53. //{1, 1000},
  54. };
  55. /**
  56. * 当界面构造时触发
  57. */
  58. static void onUI_init(){
  59. //Tips :添加 UI初始化的显示代码到这里,如:mText1Ptr->setText("123");
  60. }
  61. /**
  62. * 当切换到该界面时触发
  63. */
  64. static void onUI_intent(const Intent *intentPtr) {
  65. if (intentPtr != NULL) {
  66. //TODO
  67. }
  68. }
  69. /*
  70. * 当界面显示时触发
  71. */
  72. static void onUI_show() {
  73. mLightCheckboxPtr->setChecked(StoragePreferences::getBool(STORE_LIGHT, false));
  74. mVolumeCheckboxPtr->setChecked(StoragePreferences::getBool(STORE_VOLUME, false));
  75. EASYUICONTEXT->hideNaviBar();
  76. EASYUICONTEXT->hideStatusBar();
  77. setSettingTheme();
  78. }
  79. /*
  80. * 当界面隐藏时触发
  81. */
  82. static void onUI_hide() {
  83. }
  84. /*
  85. * 当界面完全退出时触发
  86. */
  87. static void onUI_quit() {
  88. EASYUICONTEXT->showStatusBar();
  89. EASYUICONTEXT->showNaviBar();
  90. }
  91. /**
  92. * 串口数据回调接口
  93. */
  94. static void onProtocolDataUpdate(const SProtocolData &data) {
  95. }
  96. /**
  97. * 定时器触发函数
  98. * 不建议在此函数中写耗时操作,否则将影响UI刷新
  99. * 参数: id
  100. * 当前所触发定时器的id,与注册时的id相同
  101. * 返回值: true
  102. * 继续运行当前定时器
  103. * false
  104. * 停止运行当前定时器
  105. */
  106. static bool onUI_Timer(int id){
  107. switch (id) {
  108. default:
  109. break;
  110. }
  111. return true;
  112. }
  113. /**
  114. * 有新的触摸事件时触发
  115. * 参数:ev
  116. * 新的触摸事件
  117. * 返回值:true
  118. * 表示该触摸事件在此被拦截,系统不再将此触摸事件传递到控件上
  119. * false
  120. * 触摸事件将继续传递到控件上
  121. */
  122. static bool onsettingActivityTouchEvent(const MotionEvent &ev) {
  123. switch (ev.mActionStatus) {
  124. case MotionEvent::E_ACTION_DOWN://触摸按下
  125. //LOGD("时刻 = %ld 坐标 x = %d, y = %d", ev.mEventTime, ev.mX, ev.mY);
  126. break;
  127. case MotionEvent::E_ACTION_MOVE://触摸滑动
  128. break;
  129. case MotionEvent::E_ACTION_UP: //触摸抬起
  130. break;
  131. default:
  132. break;
  133. }
  134. return false;
  135. }
  136. static void onCheckedChanged_LightCheckbox(ZKCheckBox* pCheckBox, bool isChecked) {
  137. LOGD(" Checkbox LightCheckbox checked %d", isChecked);
  138. StoragePreferences::putBool(STORE_LIGHT, isChecked);
  139. setIsLight(isChecked);
  140. }
  141. static bool onButtonClick_TestButton(ZKButton *pButton) {
  142. LOGD(" ButtonClick TestButton !!!\n");
  143. EASYUICONTEXT->openActivity("sipTestActivity");
  144. return false;
  145. }
  146. static bool onButtonClick_sys_back(ZKButton *pButton) {
  147. LOGD(" ButtonClick sys_back !!!\n");
  148. return false;
  149. }
  150. static void onCheckedChanged_VolumeCheckbox(ZKCheckBox* pCheckBox, bool isChecked) {
  151. LOGD(" Checkbox VolumeCheckbox checked %d", isChecked);
  152. StoragePreferences::putBool(STORE_VOLUME, isChecked);
  153. }
  154. static void onCheckedChanged_ThemeRadioGroup(ZKRadioGroup* pRadioGroup, int checkedID) {
  155. LOGD(" RadioGroup ThemeRadioGroup checked %d", checkedID);
  156. string themeStr = "蓝色";
  157. switch (checkedID) {
  158. case ID_SETTING_ThemeRadioButton1:
  159. LOGD("选择蓝色");
  160. themeStr = "蓝色";
  161. break;
  162. case ID_SETTING_ThemeRadioButton2:
  163. LOGD("选择红色");
  164. themeStr = "红色";
  165. break;
  166. }
  167. Intent* intent = new Intent();
  168. intent->putExtra(functionWindows, "theme");
  169. intent->putExtra(functionText, themeStr);
  170. EASYUICONTEXT->openActivity("functionActivity", intent);
  171. }
  172. static void onCheckedChanged_ModeRadioGroup(ZKRadioGroup* pRadioGroup, int checkedID) {
  173. LOGD(" RadioGroup ModeRadioGroup checked %d", checkedID);
  174. string modeStr = "模式1";
  175. switch (checkedID) {
  176. case ID_SETTING_ModeRadioButton1:
  177. LOGD("选择模式1");
  178. modeStr = "模式1";
  179. break;
  180. case ID_SETTING_ModeRadioButton2:
  181. LOGD("选择模式2");
  182. modeStr = "模式2";
  183. break;
  184. case ID_SETTING_ModeRadioButton3:
  185. LOGD("选择模式3");
  186. modeStr = "模式3";
  187. break;
  188. }
  189. Intent* intent = new Intent();
  190. intent->putExtra(functionWindows, "mode");
  191. intent->putExtra(functionText, modeStr);
  192. EASYUICONTEXT->openActivity("functionActivity", intent);
  193. }
  194. static bool onButtonClick_ZhCnButton(ZKButton *pButton) {
  195. LOGD(" ButtonClick ZhCnButton !!!\n");
  196. Intent* intent = new Intent();
  197. intent->putExtra(functionWindows, "language");
  198. intent->putExtra(functionText, "zh_CN");
  199. EASYUICONTEXT->openActivity("functionActivity", intent);
  200. return false;
  201. }
  202. static bool onButtonClick_EnUsButton(ZKButton *pButton) {
  203. LOGD(" ButtonClick EnUsButton !!!\n");
  204. Intent* intent = new Intent();
  205. intent->putExtra(functionWindows, "language");
  206. intent->putExtra(functionText, "en_US");
  207. EASYUICONTEXT->openActivity("functionActivity", intent);
  208. return false;
  209. }
  210. static bool onButtonClick_EsEsButton(ZKButton *pButton) {
  211. LOGD(" ButtonClick EsEsButton !!!\n");
  212. Intent* intent = new Intent();
  213. intent->putExtra(functionWindows, "language");
  214. intent->putExtra(functionText, "es_ES");
  215. EASYUICONTEXT->openActivity("functionActivity", intent);
  216. return false;
  217. }