statusbar.cpp 12 KB

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