sipTestLogic.cc 8.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304
  1. #pragma once
  2. #include "uart/ProtocolSender.h"
  3. #include "voip/media_player.h"
  4. #include "manager/ConfigManager.h"
  5. #include "core/utilities.h"
  6. #include "service/BusinessConfig.h"
  7. #include "core/wavfile.h"
  8. #include "voip/audio_player.h"
  9. #include "zkaudio.h"
  10. /*
  11. *此文件由GUI工具生成
  12. *文件功能:用于处理用户的逻辑相应代码
  13. *功能说明:
  14. *========================onButtonClick_XXXX
  15. 当页面中的按键按下后系统会调用对应的函数,XXX代表GUI工具里面的[ID值]名称,
  16. 如Button1,当返回值为false的时候系统将不再处理这个按键,返回true的时候系统将会继续处理此按键。比如SYS_BACK.
  17. *========================onSlideWindowItemClick_XXXX(int index)
  18. 当页面中存在滑动窗口并且用户点击了滑动窗口的图标后系统会调用此函数,XXX代表GUI工具里面的[ID值]名称,
  19. 如slideWindow1;index 代表按下图标的偏移值
  20. *========================onSeekBarChange_XXXX(int progress)
  21. 当页面中存在滑动条并且用户改变了进度后系统会调用此函数,XXX代表GUI工具里面的[ID值]名称,
  22. 如SeekBar1;progress 代表当前的进度值
  23. *========================ogetListItemCount_XXXX()
  24. 当页面中存在滑动列表的时候,更新的时候系统会调用此接口获取列表的总数目,XXX代表GUI工具里面的[ID值]名称,
  25. 如List1;返回值为当前列表的总条数
  26. *========================oobtainListItemData_XXXX(ZKListView::ZKListItem *pListItem, int index)
  27. 当页面中存在滑动列表的时候,更新的时候系统会调用此接口获取列表当前条目下的内容信息,XXX代表GUI工具里面的[ID值]名称,
  28. 如List1;pListItem 是贴图中的单条目对象,index是列表总目的偏移量。具体见函数说明
  29. *========================常用接口===============
  30. *LOGD(...) 打印调试信息的接口
  31. *mTextXXXPtr->setText("****") 在控件TextXXX上显示文字****
  32. *mButton1Ptr->setSelected(true); 将控件mButton1设置为选中模式,图片会切换成选中图片,按钮文字会切换为选中后的颜色
  33. *mSeekBarPtr->setProgress(12) 在控件mSeekBar上将进度调整到12
  34. *mListView1Ptr->refreshListView() 让mListView1 重新刷新,当列表数据变化后调用
  35. *mDashbroadView1Ptr->setTargetAngle(120) 在控件mDashbroadView1上指针显示角度调整到120度
  36. *
  37. * 在Eclipse编辑器中 使用 “alt + /” 快捷键可以打开智能提示
  38. */
  39. static base::MediaPlayer media_player;
  40. namespace {
  41. FILE* file = NULL;
  42. class RecordTest : public Thread {
  43. public:
  44. void recordAudio() {
  45. file = wavfile_write_open("/mnt/usb1/record.wav");
  46. //设置录音(输入)音量
  47. zk_audio_input_set_volume_native(0, 0);
  48. zk_audio_input_set_volume_native(1, zk_audio_input_volume_native_max());
  49. if (0 != zk_audio_input_init(2, 8000)) {
  50. LOGD("audio input init failed");
  51. return;
  52. }
  53. // //aec apc 初始化
  54. // init();
  55. const int buf_len = zk_audio_input_get_channel_buffer_size();
  56. uint8_t* buf[2];
  57. buf[0] = (uint8_t*)malloc(buf_len);
  58. buf[1] = (uint8_t*)malloc(buf_len);
  59. time_t deadline = time(NULL) + 5;
  60. int n = 0;
  61. while (time(NULL) < deadline) {
  62. zk_audio_input_get_frame((uint8_t**)buf);
  63. wavfile_write(file, ( short*) buf[1],
  64. ZK_AUDIO_NUMBER_OF_SAMPLES_PER_FRAME);
  65. }
  66. free(buf[0]);
  67. free(buf[1]);
  68. zk_audio_input_deinit();
  69. wavfile_write_close(file);
  70. mRecordTestTextViewPtr->setText(LANGUAGEMANAGER->getValue("RecordPlay"));
  71. playAudio();
  72. }
  73. void playAudio() {
  74. zk_audio_output_set_volume_native(zk_audio_output_volume_native_max());
  75. std::ifstream ifs("/mnt/usb1/record.wav",
  76. std::ios::binary | std::ios::in);
  77. if (!ifs.is_open()) {
  78. LOGD("file not found");
  79. return;
  80. }
  81. base::AudioParameter in;
  82. in.number_of_channels = 1;
  83. in.sample_rate = 8000;
  84. in.sample_format = base::SAMPLE_FMT_S16;
  85. base::AudioPlayer player(in);
  86. uint8_t buffer[256];
  87. player.Play();
  88. int m = 0;
  89. while (!ifs.eof()) {
  90. ifs.read((char*)buffer, int(sizeof(buffer)));
  91. int n = ifs.gcount();
  92. player.PutSamples(buffer, n);
  93. }
  94. ifs.close();
  95. player.Stop();
  96. mRecordTestTextViewPtr->setText(LANGUAGEMANAGER->getValue("RecordStop"));
  97. mRecordTestButtonPtr->setSelected(false);
  98. }
  99. void Record() {
  100. if(!isRunning()) {
  101. mRecordTestTextViewPtr->setText(LANGUAGEMANAGER->getValue("RecordStart"));
  102. play_ = true;
  103. this->run("recordTest");
  104. }
  105. }
  106. void Play() {
  107. if(!isRunning()) {
  108. play_ = false;
  109. this->run("recordTest");
  110. }
  111. }
  112. virtual bool threadLoop() {
  113. if(play_) {
  114. recordAudio();
  115. return false;
  116. }
  117. playAudio ();
  118. return false;
  119. }
  120. private:
  121. bool play_ = true;
  122. };
  123. static RecordTest recordTest;
  124. }
  125. static bool panelCallKeysCheckbox = false;
  126. void setCheckbox(std::string check) {
  127. if (check == "KEY<") {
  128. if (panelCallKeysCheckbox) {
  129. panelCallKeysCheckbox = false;
  130. mPanelCallKeysCheckboxPtr->setChecked(false);
  131. }
  132. else {
  133. panelCallKeysCheckbox = true;
  134. mPanelCallKeysCheckboxPtr->setChecked(true);
  135. }
  136. }
  137. }
  138. /**
  139. * 注册定时器
  140. * 填充数组用于注册定时器
  141. * 注意:id不能重复
  142. */
  143. static S_ACTIVITY_TIMEER REGISTER_ACTIVITY_TIMER_TAB[] = {
  144. //{0, 6000}, //定时器id=0, 时间间隔6秒
  145. //{1, 1000},
  146. };
  147. /**
  148. * 当界面构造时触发
  149. */
  150. static void onUI_init(){
  151. //Tips :添加 UI初始化的显示代码到这里,如:mText1Ptr->setText("123");
  152. mEditTextDestURIPtr->setText(StoragePreferences::getString(SIP_REG_DOOR_ACCOUNT, SIP_REG_DOOR_ACCOUNT_DEFAULT));
  153. }
  154. /**
  155. * 当切换到该界面时触发
  156. */
  157. static void onUI_intent(const Intent *intentPtr) {
  158. if (intentPtr != NULL) {
  159. //TODO
  160. }
  161. }
  162. /*
  163. * 当界面显示时触发
  164. */
  165. static void onUI_show() {
  166. }
  167. /*
  168. * 当界面隐藏时触发
  169. */
  170. static void onUI_hide() {
  171. }
  172. /*
  173. * 当界面完全退出时触发
  174. */
  175. static void onUI_quit() {
  176. }
  177. /**
  178. * 串口数据回调接口
  179. */
  180. static void onProtocolDataUpdate(const SProtocolData &data) {
  181. }
  182. /**
  183. * 定时器触发函数
  184. * 不建议在此函数中写耗时操作,否则将影响UI刷新
  185. * 参数: id
  186. * 当前所触发定时器的id,与注册时的id相同
  187. * 返回值: true
  188. * 继续运行当前定时器
  189. * false
  190. * 停止运行当前定时器
  191. */
  192. static bool onUI_Timer(int id){
  193. switch (id) {
  194. break;
  195. default:
  196. break;
  197. }
  198. return true;
  199. }
  200. /**
  201. * 有新的触摸事件时触发
  202. * 参数:ev
  203. * 新的触摸事件
  204. * 返回值:true
  205. * 表示该触摸事件在此被拦截,系统不再将此触摸事件传递到控件上
  206. * false
  207. * 触摸事件将继续传递到控件上
  208. */
  209. static bool onsipTestActivityTouchEvent(const MotionEvent &ev) {
  210. switch (ev.mActionStatus) {
  211. case MotionEvent::E_ACTION_DOWN://触摸按下
  212. //LOGD("时刻 = %ld 坐标 x = %d, y = %d", ev.mEventTime, ev.mX, ev.mY);
  213. break;
  214. case MotionEvent::E_ACTION_MOVE://触摸滑动
  215. break;
  216. case MotionEvent::E_ACTION_UP: //触摸抬起
  217. break;
  218. default:
  219. break;
  220. }
  221. return false;
  222. }
  223. static void onEditTextChanged_EditTextDestURI(const std::string &text) {
  224. //LOGD(" onEditTextChanged_ EditTextDestURI %s !!!\n", text.c_str());
  225. StoragePreferences::putString(SIP_REG_DOOR_ACCOUNT, text);
  226. }
  227. static bool onButtonClick_CallButton(ZKButton *pButton) {
  228. LOGD(" ButtonClick CallButton !!!\n");
  229. int port = StoragePreferences::getInt(SIP_REG_PORT, SIP_REG_PORT_DEFAULT);
  230. std::string domain = StoragePreferences::getString(SIP_REG_DOMAIN, SIP_REG_DOMAIN_DEFAULT);
  231. std::string od_number = StoragePreferences::getString(SIP_REG_DOOR_ACCOUNT, SIP_REG_DOOR_ACCOUNT_DEFAULT);
  232. std::string od_number_uri = URI(od_number, domain, port);
  233. LOGD("od_number_uri: %s", od_number_uri.c_str());
  234. GetTelephone()->MakeCall(od_number_uri);
  235. return false;
  236. }
  237. static bool onButtonClick_sys_back(ZKButton *pButton) {
  238. LOGD(" ButtonClick sys_back !!!\n");
  239. // 切换回TCP模式
  240. StoragePreferences::putString(STORE_SIGNAL_TYPE, "TCP");
  241. return false;
  242. }
  243. static void onCheckedChanged_Checkbox1(ZKCheckBox* pCheckBox, bool isChecked) {
  244. LOGD(" Checkbox Checkbox1 checked %d", isChecked);
  245. }
  246. static void onCheckedChanged_HandleKeysCheckbox(ZKCheckBox* pCheckBox, bool isChecked) {
  247. LOGD(" Checkbox HandleKeysCheckbox checked %d", isChecked);
  248. }
  249. static bool onButtonClick_RecordTestButton(ZKButton *pButton) {
  250. LOGD(" ButtonClick RecordTestButton !!!\n");
  251. // 如果线程在运行,则不能重复运行
  252. if(recordTest.isRunning()) {
  253. return false;
  254. }
  255. if(!pButton->isSelected()) {
  256. pButton->setSelected(true);
  257. }
  258. recordTest.Record();
  259. return false;
  260. }
  261. static void onCheckedChanged_PanelCallKeysCheckbox(ZKCheckBox* pCheckBox, bool isChecked) {
  262. LOGD(" Checkbox PanelCallKeysCheckbox checked %d", isChecked);
  263. }