statusbar.cpp 12 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386
  1. #include "statusbar.h"
  2. #include "entry/EasyUIContext.h"
  3. /*TAG:GlobalVariable全局变量*/
  4. static ZKTextView* mTextViewTCPPtr;
  5. static ZKTextView* mTextViewRegPtr;
  6. static ZKTextView* mPartNamePtr;
  7. static ZKPainter* mPainter1Ptr;
  8. static ZKTextView* mDateViewPtr;
  9. static statusbar* mstatusbarPtr;
  10. /* register sysapp */
  11. REGISTER_SYSAPP(APP_TYPE_SYS_STATUSBAR, statusbar);
  12. typedef struct {
  13. int id; // 定时器ID , 不能重复
  14. int time; // 定时器 时间间隔 单位 毫秒
  15. }S_ACTIVITY_TIMEER;
  16. #include "logic/statusbar.cc"
  17. /***********/
  18. typedef struct {
  19. int id;
  20. const char *pApp;
  21. } SAppInfo;
  22. /**
  23. *点击跳转window
  24. */
  25. static SAppInfo sAppInfoTab[] = {
  26. // { ID_MAIN_TEXT, "TextViewActivity" },
  27. };
  28. /***************/
  29. typedef bool (*ButtonCallback)(ZKButton *pButton);
  30. /**
  31. * button onclick表
  32. */
  33. typedef struct {
  34. int id;
  35. ButtonCallback callback;
  36. }S_ButtonCallback;
  37. /*TAG:ButtonCallbackTab按键映射表*/
  38. static S_ButtonCallback sButtonCallbackTab[] = {
  39. };
  40. /***************/
  41. typedef void (*SeekBarCallback)(ZKSeekBar *pSeekBar, int progress);
  42. typedef struct {
  43. int id;
  44. SeekBarCallback callback;
  45. }S_ZKSeekBarCallback;
  46. /*TAG:SeekBarCallbackTab*/
  47. static S_ZKSeekBarCallback SZKSeekBarCallbackTab[] = {
  48. };
  49. typedef int (*ListViewGetItemCountCallback)(const ZKListView *pListView);
  50. typedef void (*ListViewobtainListItemDataCallback)(ZKListView *pListView,ZKListView::ZKListItem *pListItem, int index);
  51. typedef void (*ListViewonItemClickCallback)(ZKListView *pListView, int index, int id);
  52. typedef struct {
  53. int id;
  54. ListViewGetItemCountCallback getListItemCountCallback;
  55. ListViewobtainListItemDataCallback obtainListItemDataCallback;
  56. ListViewonItemClickCallback onItemClickCallback;
  57. }S_ListViewFunctionsCallback;
  58. /*TAG:ListViewFunctionsCallback*/
  59. static S_ListViewFunctionsCallback SListViewFunctionsCallbackTab[] = {
  60. };
  61. typedef void (*SlideWindowItemClickCallback)(ZKSlideWindow *pSlideWindow, int index);
  62. typedef struct {
  63. int id;
  64. SlideWindowItemClickCallback onSlideItemClickCallback;
  65. }S_SlideWindowItemClickCallback;
  66. /*TAG:SlideWindowFunctionsCallbackTab*/
  67. static S_SlideWindowItemClickCallback SSlideWindowItemClickCallbackTab[] = {
  68. };
  69. typedef void (*EditTextInputCallback)(const std::string &text);
  70. typedef struct {
  71. int id;
  72. EditTextInputCallback onEditTextChangedCallback;
  73. }S_EditTextInputCallback;
  74. /*TAG:EditTextInputCallback*/
  75. static S_EditTextInputCallback SEditTextInputCallbackTab[] = {
  76. };
  77. typedef void (*VideoViewCallback)(ZKVideoView *pVideoView, int msg);
  78. typedef struct {
  79. int id; //VideoView ID
  80. bool loop; // 是否是轮播类型
  81. int defaultvolume;//轮播类型时,默认视频音量
  82. VideoViewCallback onVideoViewCallback;
  83. }S_VideoViewCallback;
  84. /*TAG:VideoViewCallback*/
  85. static S_VideoViewCallback SVideoViewCallbackTab[] = {
  86. };
  87. statusbar::statusbar() {
  88. mVideoLoopIndex = -1;
  89. mVideoLoopErrorCount = 0;
  90. }
  91. statusbar::~statusbar() {
  92. // 退出应用时需要反注册
  93. EASYUICONTEXT->unregisterGlobalTouchListener(this);
  94. onUI_quit();
  95. unregisterProtocolDataUpdateListener(onProtocolDataUpdate);
  96. mTextViewTCPPtr = NULL;
  97. mTextViewRegPtr = NULL;
  98. mPartNamePtr = NULL;
  99. mPainter1Ptr = NULL;
  100. mDateViewPtr = NULL;
  101. mstatusbarPtr = NULL;
  102. }
  103. const char* statusbar::getAppName() const{
  104. return "statusbar.ftu";
  105. }
  106. //TAG:onCreate
  107. void statusbar::onCreate() {
  108. BaseApp::onCreate();
  109. mTextViewTCPPtr = (ZKTextView*)findControlByID(ID_STATUSBAR_TextViewTCP);
  110. mTextViewRegPtr = (ZKTextView*)findControlByID(ID_STATUSBAR_TextViewReg);
  111. mPartNamePtr = (ZKTextView*)findControlByID(ID_STATUSBAR_PartName);
  112. mPainter1Ptr = (ZKPainter*)findControlByID(ID_STATUSBAR_Painter1);
  113. mDateViewPtr = (ZKTextView*)findControlByID(ID_STATUSBAR_DateView);
  114. mstatusbarPtr = this;
  115. onUI_init();
  116. // 注册监听全局触摸
  117. EASYUICONTEXT->registerGlobalTouchListener(this);
  118. registerProtocolDataUpdateListener(onProtocolDataUpdate);
  119. rigesterActivityTimer();
  120. startVideoLoopPlayback();
  121. }
  122. void statusbar::onClick(ZKBase *pBase) {
  123. int buttonTablen = sizeof(sButtonCallbackTab) / sizeof(S_ButtonCallback);
  124. for (int i = 0; i < buttonTablen; ++i) {
  125. if (sButtonCallbackTab[i].id == pBase->getID()) {
  126. if (sButtonCallbackTab[i].callback((ZKButton*)pBase)) {
  127. return;
  128. }
  129. break;
  130. }
  131. }
  132. int len = sizeof(sAppInfoTab) / sizeof(sAppInfoTab[0]);
  133. for (int i = 0; i < len; ++i) {
  134. if (sAppInfoTab[i].id == pBase->getID()) {
  135. EASYUICONTEXT->openActivity(sAppInfoTab[i].pApp);
  136. return;
  137. }
  138. }
  139. BaseApp::onClick(pBase);
  140. }
  141. bool statusbar::onTimer(int id) {
  142. return onUI_Timer(id);
  143. }
  144. void statusbar::onProgressChanged(ZKSeekBar *pSeekBar, int progress){
  145. int seekBarTablen = sizeof(SZKSeekBarCallbackTab) / sizeof(S_ZKSeekBarCallback);
  146. for (int i = 0; i < seekBarTablen; ++i) {
  147. if (SZKSeekBarCallbackTab[i].id == pSeekBar->getID()) {
  148. SZKSeekBarCallbackTab[i].callback(pSeekBar, progress);
  149. break;
  150. }
  151. }
  152. }
  153. int statusbar::getListItemCount(const ZKListView *pListView) const{
  154. int tablen = sizeof(SListViewFunctionsCallbackTab) / sizeof(S_ListViewFunctionsCallback);
  155. for (int i = 0; i < tablen; ++i) {
  156. if (SListViewFunctionsCallbackTab[i].id == pListView->getID()) {
  157. return SListViewFunctionsCallbackTab[i].getListItemCountCallback(pListView);
  158. break;
  159. }
  160. }
  161. return 0;
  162. }
  163. void statusbar::obtainListItemData(ZKListView *pListView,ZKListView::ZKListItem *pListItem, int index){
  164. int tablen = sizeof(SListViewFunctionsCallbackTab) / sizeof(S_ListViewFunctionsCallback);
  165. for (int i = 0; i < tablen; ++i) {
  166. if (SListViewFunctionsCallbackTab[i].id == pListView->getID()) {
  167. SListViewFunctionsCallbackTab[i].obtainListItemDataCallback(pListView, pListItem, index);
  168. break;
  169. }
  170. }
  171. }
  172. void statusbar::onItemClick(ZKListView *pListView, int index, int id){
  173. int tablen = sizeof(SListViewFunctionsCallbackTab) / sizeof(S_ListViewFunctionsCallback);
  174. for (int i = 0; i < tablen; ++i) {
  175. if (SListViewFunctionsCallbackTab[i].id == pListView->getID()) {
  176. SListViewFunctionsCallbackTab[i].onItemClickCallback(pListView, index, id);
  177. break;
  178. }
  179. }
  180. }
  181. void statusbar::onSlideItemClick(ZKSlideWindow *pSlideWindow, int index) {
  182. int tablen = sizeof(SSlideWindowItemClickCallbackTab) / sizeof(S_SlideWindowItemClickCallback);
  183. for (int i = 0; i < tablen; ++i) {
  184. if (SSlideWindowItemClickCallbackTab[i].id == pSlideWindow->getID()) {
  185. SSlideWindowItemClickCallbackTab[i].onSlideItemClickCallback(pSlideWindow, index);
  186. break;
  187. }
  188. }
  189. }
  190. bool statusbar::onTouchEvent(const MotionEvent &ev) {
  191. return onstatusbarActivityTouchEvent(ev);
  192. }
  193. void statusbar::onTextChanged(ZKTextView *pTextView, const std::string &text) {
  194. int tablen = sizeof(SEditTextInputCallbackTab) / sizeof(S_EditTextInputCallback);
  195. for (int i = 0; i < tablen; ++i) {
  196. if (SEditTextInputCallbackTab[i].id == pTextView->getID()) {
  197. SEditTextInputCallbackTab[i].onEditTextChangedCallback(text);
  198. break;
  199. }
  200. }
  201. }
  202. void statusbar::rigesterActivityTimer() {
  203. int tablen = sizeof(REGISTER_ACTIVITY_TIMER_TAB) / sizeof(S_ACTIVITY_TIMEER);
  204. for (int i = 0; i < tablen; ++i) {
  205. S_ACTIVITY_TIMEER temp = REGISTER_ACTIVITY_TIMER_TAB[i];
  206. registerTimer(temp.id, temp.time);
  207. }
  208. }
  209. void statusbar::onVideoPlayerMessage(ZKVideoView *pVideoView, int msg) {
  210. int tablen = sizeof(SVideoViewCallbackTab) / sizeof(S_VideoViewCallback);
  211. for (int i = 0; i < tablen; ++i) {
  212. if (SVideoViewCallbackTab[i].id == pVideoView->getID()) {
  213. if (SVideoViewCallbackTab[i].loop) {
  214. //循环播放
  215. videoLoopPlayback(pVideoView, msg, i);
  216. } else if (SVideoViewCallbackTab[i].onVideoViewCallback != NULL){
  217. SVideoViewCallbackTab[i].onVideoViewCallback(pVideoView, msg);
  218. }
  219. break;
  220. }
  221. }
  222. }
  223. void statusbar::videoLoopPlayback(ZKVideoView *pVideoView, int msg, size_t callbackTabIndex) {
  224. switch (msg) {
  225. case ZKVideoView::E_MSGTYPE_VIDEO_PLAY_STARTED:
  226. LOGD("ZKVideoView::E_MSGTYPE_VIDEO_PLAY_STARTED\n");
  227. if (callbackTabIndex >= (sizeof(SVideoViewCallbackTab)/sizeof(S_VideoViewCallback))) {
  228. break;
  229. }
  230. pVideoView->setVolume(SVideoViewCallbackTab[callbackTabIndex].defaultvolume / 10.0);
  231. mVideoLoopErrorCount = 0;
  232. break;
  233. case ZKVideoView::E_MSGTYPE_VIDEO_PLAY_ERROR:
  234. /**错误处理 */
  235. ++mVideoLoopErrorCount;
  236. if (mVideoLoopErrorCount > 100) {
  237. LOGD("video loop error counts > 100, quit loop playback !");
  238. break;
  239. } //不用break, 继续尝试播放下一个
  240. case ZKVideoView::E_MSGTYPE_VIDEO_PLAY_COMPLETED:
  241. LOGD("ZKVideoView::E_MSGTYPE_VIDEO_PLAY_COMPLETED\n");
  242. std::vector<std::string> videolist;
  243. std::string fileName(getAppName());
  244. if (fileName.size() < 4) {
  245. LOGD("getAppName size < 4, ignore!");
  246. break;
  247. }
  248. fileName = fileName.substr(0, fileName.length() - 4) + "_video_list.txt";
  249. fileName = "/mnt/extsd/" + fileName;
  250. if (!parseVideoFileList(fileName.c_str(), videolist)) {
  251. LOGD("parseVideoFileList failed !");
  252. break;
  253. }
  254. if (pVideoView && !videolist.empty()) {
  255. mVideoLoopIndex = (mVideoLoopIndex + 1) % videolist.size();
  256. pVideoView->play(videolist[mVideoLoopIndex].c_str());
  257. }
  258. break;
  259. }
  260. }
  261. void statusbar::startVideoLoopPlayback() {
  262. int tablen = sizeof(SVideoViewCallbackTab) / sizeof(S_VideoViewCallback);
  263. for (int i = 0; i < tablen; ++i) {
  264. if (SVideoViewCallbackTab[i].loop) {
  265. ZKVideoView* videoView = (ZKVideoView*)findControlByID(SVideoViewCallbackTab[i].id);
  266. if (!videoView) {
  267. return;
  268. }
  269. //循环播放
  270. videoLoopPlayback(videoView, ZKVideoView::E_MSGTYPE_VIDEO_PLAY_COMPLETED, i);
  271. return;
  272. }
  273. }
  274. }
  275. void statusbar::stopVideoLoopPlayback() {
  276. int tablen = sizeof(SVideoViewCallbackTab) / sizeof(S_VideoViewCallback);
  277. for (int i = 0; i < tablen; ++i) {
  278. if (SVideoViewCallbackTab[i].loop) {
  279. ZKVideoView* videoView = (ZKVideoView*)findControlByID(SVideoViewCallbackTab[i].id);
  280. if (!videoView) {
  281. return;
  282. }
  283. if (videoView->isPlaying()) {
  284. videoView->stop();
  285. }
  286. return;
  287. }
  288. }
  289. }
  290. bool statusbar::parseVideoFileList(const char *pFileListPath, std::vector<string>& mediaFileList) {
  291. mediaFileList.clear();
  292. if (NULL == pFileListPath || 0 == strlen(pFileListPath)) {
  293. LOGD("video file list is null!");
  294. return false;
  295. }
  296. ifstream is(pFileListPath, ios_base::in);
  297. if (!is.is_open()) {
  298. LOGD("cann't open file %s \n", pFileListPath);
  299. return false;
  300. }
  301. char tmp[1024] = {0};
  302. while (is.getline(tmp, sizeof(tmp))) {
  303. string str = tmp;
  304. removeCharFromString(str, '\"');
  305. removeCharFromString(str, '\r');
  306. removeCharFromString(str, '\n');
  307. if (str.size() > 1) {
  308. mediaFileList.push_back(str.c_str());
  309. }
  310. }
  311. LOGD("(f:%s, l:%d) parse fileList[%s], get [%d]files\n", __FUNCTION__,
  312. __LINE__, pFileListPath, mediaFileList.size());
  313. for (size_t i = 0; i < mediaFileList.size(); i++) {
  314. LOGD("file[%d]:[%s]\n", i, mediaFileList[i].c_str());
  315. }
  316. is.close();
  317. return true;
  318. }
  319. int statusbar::removeCharFromString(string& nString, char c)
  320. {
  321. string::size_type pos;
  322. while(1) {
  323. pos = nString.find(c);
  324. if(pos != string::npos) {
  325. nString.erase(pos, 1);
  326. } else {
  327. break;
  328. }
  329. }
  330. return (int)nString.size();
  331. }
  332. void statusbar::registerUserTimer(int id, int time) {
  333. registerTimer(id, time);
  334. }
  335. void statusbar::unregisterUserTimer(int id) {
  336. unregisterTimer(id);
  337. }
  338. void statusbar::resetUserTimer(int id, int time) {
  339. resetTimer(id, time);
  340. }