navibar.cpp 12 KB

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