func_music.c 16 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575
  1. #include "include.h"
  2. #include "func.h"
  3. #include "func_music.h"
  4. func_msc_t f_msc AT(.buf.func.music);
  5. #if FUNC_MUSIC_EN
  6. char fname_buf[100] AT(.fname.buf);
  7. void music_slot_kick(void);
  8. #if MUSIC_NAVIGATION_EN
  9. void func_music_file_navigation(void)
  10. {
  11. u16 f_num = 0;
  12. music_control(MUSIC_STOP);
  13. f_num = music_list_view_adapter(f_msc.file_num, FL_CDUP);
  14. if (f_num) {
  15. f_msc.file_num = f_num;
  16. }
  17. f_msc.prev_flag = 0;
  18. if (listbox_cb.sta == LB_STA_DEV_IN) {
  19. func_music_insert_device(listbox_cb.evt_dev);
  20. } else if (listbox_cb.sta == LB_STA_DEV_OUT) {
  21. func_music_remove_device(listbox_cb.evt_dev);
  22. } else {
  23. f_msc.file_change = 1;
  24. }
  25. }
  26. #endif // MUSIC_NAVIGATION_EN
  27. AT(.text.func.music)
  28. void func_music_mp3_res_play(u32 addr, u32 len)
  29. {
  30. u32 cur_time;
  31. if (len == 0) {
  32. return;
  33. }
  34. msc_breakpiont_t brkpt;
  35. music_get_breakpiont(&brkpt); //保存当前播放位置
  36. cur_time = music_get_cur_time();
  37. music_control(MUSIC_MSG_STOP);
  38. mp3_res_play(addr, len);
  39. music_decode_init();
  40. music_set_jump(&brkpt); //恢复播放位置
  41. music_set_cur_time(cur_time);
  42. if (f_msc.pause) {
  43. music_control(MUSIC_MSG_PAUSE);
  44. } else {
  45. music_control(MUSIC_MSG_PLAY);
  46. }
  47. }
  48. AT(.text.func.music)
  49. static void func_music_get_curtime(void)
  50. {
  51. u16 cur_sec;
  52. cur_sec = music_get_cur_time() / 10;
  53. f_msc.curtime.min = cur_sec / 60;
  54. f_msc.curtime.sec = cur_sec % 60;
  55. }
  56. AT(.text.func.music)
  57. void func_music_remove_device(u8 dev)
  58. {
  59. if (f_msc.cur_dev == dev) {
  60. bsp_clr_mute_sta();
  61. if (dev_is_online(DEV_SDCARD) || dev_is_online(DEV_UDISK) || dev_is_online(DEV_SDCARD1)) {
  62. f_msc.dev_change = 1;
  63. music_breakpoint_save();
  64. } else {
  65. #if MUSIC_MODE_RETURN
  66. func_cb.sta = func_cb.last;
  67. #else
  68. func_cb.sta = FUNC_NULL;
  69. #endif
  70. }
  71. #if BT_APP_EN
  72. bsp_app_msc_send_dev_info();
  73. #endif
  74. }
  75. }
  76. AT(.text.func.music)
  77. void func_music_insert_device(u8 dev)
  78. {
  79. sys_cb.cur_dev = dev;
  80. bsp_clr_mute_sta();
  81. f_msc.dev_change = 2;
  82. music_breakpoint_save();
  83. }
  84. AT(.text.func.music)
  85. bool func_music_switch_device(void)
  86. {
  87. if (f_msc.cur_dev == DEV_SDCARD) {
  88. if (dev_is_online(DEV_UDISK)) {
  89. sys_cb.cur_dev = DEV_UDISK;
  90. return true;
  91. } else if (dev_is_online(DEV_SDCARD1)) {
  92. sys_cb.cur_dev = DEV_SDCARD1;
  93. return true;
  94. }
  95. } else if (f_msc.cur_dev == DEV_UDISK) {
  96. if (dev_is_online(DEV_SDCARD1)) {
  97. sys_cb.cur_dev = DEV_SDCARD1;
  98. return true;
  99. } else if (dev_is_online(DEV_SDCARD)) {
  100. sys_cb.cur_dev = DEV_SDCARD;
  101. return true;
  102. }
  103. } else if (f_msc.cur_dev == DEV_SDCARD1) {
  104. if (dev_is_online(DEV_SDCARD)) {
  105. sys_cb.cur_dev = DEV_SDCARD;
  106. return true;
  107. } else if (dev_is_online(DEV_UDISK)) {
  108. sys_cb.cur_dev = DEV_UDISK;
  109. return true;
  110. }
  111. }
  112. return false;
  113. }
  114. AT(.text.func.music)
  115. bool func_music_auto_next_device(void)
  116. {
  117. if (!func_music_switch_device()) {
  118. return false;
  119. }
  120. led_music_busy();
  121. fsdisk_callback_init(sys_cb.cur_dev);
  122. if ((!fs_mount()) || (!pf_scan_music(1))) {
  123. //挂载失败或无文件时还原到原设备
  124. fsdisk_callback_init(f_msc.cur_dev);
  125. if ((!fs_mount()) || (!pf_scan_music(1))) {
  126. func_cb.sta = FUNC_NULL;
  127. led_idle();
  128. return false;
  129. }
  130. return false;
  131. }
  132. led_idle();
  133. f_msc.cur_dev = sys_cb.cur_dev;
  134. return true;
  135. }
  136. //direction: 0->上一曲, 1->下一曲
  137. AT(.text.func.music)
  138. void func_music_switch_file(u8 direction)
  139. {
  140. u16 dir_snum, dir_lnum;
  141. music_control(MUSIC_MSG_STOP);
  142. switch (sys_cb.play_mode) {
  143. case NORMAL_MODE:
  144. case SINGLE_MODE:
  145. if (direction) {
  146. #if MUSIC_AUTO_SWITCH_DEVICE
  147. //auto switch to next device
  148. if (f_msc.file_num == f_msc.file_total) {
  149. if (func_music_auto_next_device()) {
  150. f_msc.file_num = 1;
  151. f_msc.file_change = 1;
  152. return;
  153. }
  154. }
  155. #endif // MUSIC_AUTO_SWITCH_DEVICE
  156. f_msc.file_num++;
  157. if (f_msc.file_num > f_msc.file_total) {
  158. f_msc.file_num = 1;
  159. }
  160. } else {
  161. #if MUSIC_AUTO_SWITCH_DEVICE
  162. //auto switch to next device
  163. if (f_msc.file_num == 1) {
  164. if (func_music_auto_next_device()) {
  165. f_msc.file_num = f_msc.file_total;
  166. f_msc.file_change = 1;
  167. return;
  168. }
  169. }
  170. #endif // MUSIC_AUTO_SWITCH_DEVICE
  171. f_msc.file_num--;
  172. if ((f_msc.file_num < 1) || (f_msc.file_num > f_msc.file_total)) {
  173. f_msc.file_num = f_msc.file_total;
  174. }
  175. }
  176. break;
  177. case FLODER_MODE:
  178. dir_snum = fs_get_dir_fstart(); //获取当前文件夹起始文件编号
  179. dir_lnum = dir_snum + fs_getdir_files() - 1; //获取当前文件夹结束文件编号
  180. if (direction) {
  181. f_msc.file_num++;
  182. if (f_msc.file_num > dir_lnum) {
  183. f_msc.file_num = dir_snum;
  184. }
  185. } else {
  186. f_msc.file_num--;
  187. if ((f_msc.file_num < dir_snum) || (f_msc.file_num > dir_lnum)) {
  188. f_msc.file_num = dir_lnum;
  189. }
  190. }
  191. printf("Floder play mode: %d,%d\n", f_msc.file_num, dir_lnum);
  192. break;
  193. case RANDOM_MODE:
  194. f_msc.file_num = get_random(f_msc.file_total) + 1;
  195. break;
  196. }
  197. f_msc.file_change = 1;
  198. if (direction) {
  199. f_msc.prev_flag = 0;
  200. } else {
  201. f_msc.prev_flag = 1;
  202. }
  203. }
  204. AT(.text.func.music)
  205. void func_music_auto_next_file(void)
  206. {
  207. f_msc.file_change = 1;
  208. f_msc.prev_flag = 0;
  209. if (sys_cb.play_mode != SINGLE_MODE) {
  210. func_music_switch_file(1);
  211. }
  212. }
  213. #if MUSIC_REC_FILE_FILTER
  214. //切换播放录音文件或不播放录音文件
  215. AT(.text.func.music)
  216. bool func_music_filter_switch(u8 rec_type)
  217. {
  218. u16 file_num = f_msc.file_num;
  219. music_control(MUSIC_MSG_STOP);
  220. f_msc.file_change = 1;
  221. if (rec_type) {
  222. fs_scan_set(SCAN_SPEED|SCAN_SUB_FOLDER, music_only_record_file_filter, music_only_record_dir_filter); //只播放录音文件
  223. if (!pf_scan_music(0)) {
  224. //无录音文件,还原到正常音乐
  225. fs_scan_set(SCAN_SPEED|SCAN_SUB_FOLDER, music_file_filter, music_rm_record_dir_filter); //不播放录音文件
  226. pf_scan_music(0);
  227. f_msc.file_num = file_num;
  228. return false;
  229. }
  230. } else {
  231. fs_scan_set(SCAN_SPEED|SCAN_SUB_FOLDER, music_file_filter, music_rm_record_dir_filter); //不播放录音文件
  232. if (!pf_scan_music(0)) {
  233. fs_scan_set(SCAN_SPEED|SCAN_SUB_FOLDER, music_only_record_file_filter, music_only_record_dir_filter); //只播放录音文件
  234. pf_scan_music(0);
  235. f_msc.file_num = file_num;
  236. return false;
  237. }
  238. }
  239. f_msc.file_num = 1;
  240. return true;
  241. }
  242. #endif // MUSIC_REC_FILE_FILTER
  243. #if MUSIC_FOLDER_SELECT_EN
  244. //direction: 0->上一文件夹, 1->下一文件夹
  245. AT(.text.func.music)
  246. void func_music_switch_dir(u8 direction)
  247. {
  248. u16 dir_file_num;
  249. if (f_msc.dir_total <= 1) {
  250. return;
  251. }
  252. if (direction) {
  253. f_msc.dir_num++;
  254. } else {
  255. f_msc.dir_num--;
  256. }
  257. if (f_msc.dir_num > f_msc.dir_total) {
  258. f_msc.dir_num = 1;
  259. } else if (f_msc.dir_num < 1) {
  260. f_msc.dir_num = f_msc.dir_total;
  261. }
  262. music_control(MUSIC_MSG_STOP); //先结束当前播放
  263. dir_file_num = fs_open_dir_num(f_msc.dir_num);
  264. if (dir_file_num > 0) {
  265. f_msc.file_num = dir_file_num;
  266. }
  267. f_msc.file_change = 1;
  268. f_msc.prev_flag = 0;
  269. bsp_clr_mute_sta();
  270. }
  271. //选择指定编号文件夹播放
  272. AT(.text.func.music)
  273. void func_music_select_dir(u16 sel_num)
  274. {
  275. u16 dir_file_num;
  276. if ((sel_num < 1) || (sel_num > f_msc.dir_total)) {
  277. return;
  278. }
  279. f_msc.dir_num = sel_num;
  280. music_control(MUSIC_MSG_STOP); //先结束当前播放
  281. dir_file_num = fs_open_dir_num(f_msc.dir_num);
  282. if (dir_file_num > 0) {
  283. f_msc.file_num = dir_file_num;
  284. }
  285. f_msc.file_change = 1;
  286. f_msc.prev_flag = 0;
  287. }
  288. #endif // MUSIC_FOLDER_SELECT_EN
  289. AT(.text.func.music)
  290. void func_music_file_new(void)
  291. {
  292. if (f_msc.file_change) {
  293. f_msc.file_change = 0;
  294. music_control(MUSIC_MSG_STOP);
  295. if (fs_open_num(f_msc.file_num)) {
  296. memset(f_msc.fname, 0, sizeof(fname_buf));
  297. fs_get_short_fname(f_msc.fname, 0);
  298. f_msc.dir_num = fs_get_dirs_count(); //获取当前文件所在文件夹编号
  299. f_msc.alltime.min = 0xff;
  300. f_msc.alltime.sec = 0;
  301. f_msc.curtime.min = 0;
  302. f_msc.curtime.sec = 0;
  303. f_msc.pause = 0;
  304. f_msc.encrypt = 0;
  305. #if MUSIC_ENCRYPT_EN
  306. if (!music_is_encrypt(MUSIC_ENCRYPT_KEY)) {
  307. f_msc.encrypt = 1;
  308. }
  309. #endif // MUSIC_ENCRYPT_EN
  310. #if MUSIC_ID3_TAG_EN
  311. if (strstr(f_msc.fname, ".mp3") != NULL) {
  312. get_mp3_id3_tag();
  313. }
  314. #endif // MUSIC_ID3_TAG_EN
  315. #if MUSIC_AAC_SUPPORT
  316. if (strstr(f_msc.fname, ".aac") != NULL) {
  317. if (aacio_decode_init()) {
  318. f_msc.type = AACIO_TYPE;
  319. }
  320. } else
  321. #endif // MUSIC_AAC_SUPPORT
  322. f_msc.type = music_decode_init();
  323. if(f_msc.type != NONE_TYPE) {
  324. #if MUSIC_ID3_TAG_EN
  325. if (strstr(f_msc.fname, ".wma") != NULL) {
  326. get_wma_id3_tag();
  327. }
  328. #endif // MUSIC_ID3_TAG_EN
  329. printf("music decoding [%s]\n", f_msc.fname);
  330. printf("new file number: %d, %d\n", f_msc.file_num, f_msc.file_total);
  331. param_msc_num_write();
  332. gui_box_show_num(f_msc.file_num);
  333. music_breakpoint_init();
  334. param_sync();
  335. led_music_play();
  336. music_control(MUSIC_MSG_PLAY); //开始播放
  337. delay_5ms(1);
  338. }
  339. }
  340. }
  341. f_msc.brkpt_flag = 0;
  342. }
  343. AT(.text.func.music)
  344. void func_music_device_new(void)
  345. {
  346. u8 dev_change = f_msc.dev_change;
  347. if (f_msc.dev_change) {
  348. f_msc.dev_change = 0;
  349. music_control(MUSIC_MSG_STOP);
  350. if ((dev_change == 1) && (!func_music_switch_device())) {
  351. return;
  352. }
  353. led_music_busy();
  354. fsdisk_callback_init(sys_cb.cur_dev);
  355. if ((!fs_mount()) || (!pf_scan_music(1))) {
  356. //还原到原设备
  357. sys_cb.cur_dev = f_msc.cur_dev;
  358. fsdisk_callback_init(sys_cb.cur_dev);
  359. if ((!fs_mount()) || (!pf_scan_music(0))) {
  360. func_cb.sta = FUNC_NULL;
  361. led_idle();
  362. return;
  363. }
  364. }
  365. led_idle();
  366. f_msc.cur_dev = sys_cb.cur_dev;
  367. param_msc_num_read();
  368. f_msc.brkpt_flag = 1;
  369. f_msc.file_change = 1;
  370. #if SYS_MODE_BREAKPOINT_EN
  371. param_sys_mode_write(func_cb.sta);
  372. param_sync();
  373. #endif // SYS_MODE_BREAKPOINT_EN
  374. }
  375. }
  376. #if IR_NUMKEY_EN
  377. static void func_box_event(void)
  378. {
  379. #if (GUI_SELECT != GUI_NO)
  380. u16 ret;
  381. if (box_cb.event) {
  382. box_cb.event = 0;
  383. bsp_clr_mute_sta();
  384. if (sys_cb.play_mode != FLODER_MODE) {
  385. if ((box_cb.number > 0) && (box_cb.number <= f_msc.file_total)) {
  386. f_msc.file_num = box_cb.number;
  387. f_msc.file_change = 1;
  388. }
  389. } else {
  390. if ((box_cb.number > 0) && (box_cb.number <= f_msc.dir_total)) {
  391. music_control(MUSIC_MSG_STOP);
  392. ret = fs_open_dir_num(box_cb.number); //打开目录,并返回起始文件编号
  393. printf("open_dir_num: %d, %d\n",box_cb.number, ret);
  394. if (ret != 0) {
  395. f_msc.dir_num = box_cb.number;
  396. f_msc.file_num = ret;
  397. }
  398. f_msc.file_change = 1;
  399. }
  400. }
  401. }
  402. #endif
  403. }
  404. #endif // IR_NUMKEY_EN
  405. AT(.text.func.music)
  406. void func_music_process(void)
  407. {
  408. u16 total_time;
  409. func_process();
  410. #if IR_NUMKEY_EN
  411. func_box_event();
  412. #endif // IR_NUMKEY_EN
  413. func_music_file_new();
  414. music_slot_kick();
  415. func_music_get_curtime();
  416. if ((get_music_dec_sta() == MUSIC_STOP) && (f_msc.dev_change == 0)) {
  417. if (dev_is_online(f_msc.cur_dev)) { //设备拔出结束解码不自动切换下一曲
  418. music_breakpoint_clr();
  419. if ((f_msc.prev_flag) && ((f_msc.alltime.min == 0xff)
  420. || ((f_msc.curtime.min == 0) && (f_msc.curtime.sec == 0)))) {
  421. //错误文件或播放小于2S保持切换方向
  422. func_music_switch_file(0);
  423. } else {
  424. func_music_auto_next_file();
  425. }
  426. }
  427. }
  428. if (f_msc.alltime.min == 0xff) {
  429. total_time = music_get_total_time();
  430. if (total_time != 0xffff) {
  431. f_msc.alltime.min = total_time / 60;
  432. f_msc.alltime.sec = total_time % 60;
  433. printf("[%s] total time: %02d:%02d\n\n", f_msc.fname, f_msc.alltime.min, f_msc.alltime.sec);
  434. }
  435. }
  436. func_music_device_new();
  437. #if MUSIC_LRC_EN
  438. bsp_lrc_get_content();
  439. #endif // MUSIC_LRC_EN
  440. }
  441. void func_music_filter_set(void)
  442. {
  443. #if MUSIC_REC_FILE_FILTER
  444. if (f_msc.rec_type) {
  445. fs_scan_set(SCAN_SPEED|SCAN_SUB_FOLDER, music_only_record_file_filter, music_only_record_dir_filter); //只播放录音文件
  446. } else {
  447. fs_scan_set(SCAN_SPEED|SCAN_SUB_FOLDER, music_file_filter, music_rm_record_dir_filter); //不播放录音文件
  448. }
  449. #else
  450. fs_scan_set(SCAN_SPEED|SCAN_SUB_FOLDER, music_file_filter, music_dir_filter); //播放全部文件
  451. #endif // MUSIC_REC_FILE_FILTER
  452. }
  453. static void func_music_enter(void)
  454. {
  455. msg_queue_clear();
  456. if ((!dev_is_online(DEV_UDISK)) && (!dev_is_online(DEV_SDCARD)) && (!dev_is_online(DEV_SDCARD1))) {
  457. func_cb.sta = FUNC_NULL;
  458. return;
  459. }
  460. #if BT_BACKSTAGE_EN
  461. if (dev_is_online(DEV_UDISK)) {
  462. udisk_resume();
  463. }
  464. #endif
  465. func_music_filter_set();
  466. fsdisk_callback_init(sys_cb.cur_dev);
  467. memset(&f_msc, 0, sizeof(f_msc));
  468. f_msc.fname = &fname_buf[0];
  469. func_music_enter_display();
  470. #if WARNING_FUNC_MUSIC
  471. mp3_res_play(RES_BUF_MUSIC_MODE_MP3, RES_LEN_MUSIC_MODE_MP3);
  472. #endif
  473. led_music_busy();
  474. if ((!fs_mount()) || (!pf_scan_music(1))) {
  475. f_msc.cur_dev = sys_cb.cur_dev;
  476. if (!func_music_auto_next_device()) {
  477. f_msc.cur_dev = sys_cb.cur_dev;
  478. //#if MUSIC_MODE_RETURN
  479. // func_cb.sta = func_cb.last;
  480. //#else
  481. func_cb.sta = FUNC_NULL;
  482. //#endif
  483. led_idle();
  484. return;
  485. }
  486. }
  487. led_idle();
  488. func_cb.mp3_res_play = func_music_mp3_res_play;
  489. f_msc.cur_dev = sys_cb.cur_dev;
  490. param_msc_num_read();
  491. f_msc.file_change = 1;
  492. f_msc.brkpt_flag = 1;
  493. }
  494. static void func_music_exit(void)
  495. {
  496. func_music_exit_display();
  497. music_breakpoint_save();
  498. music_control(MUSIC_MSG_STOP);
  499. if (dev_is_online(DEV_SDCARD) || dev_is_online(DEV_SDCARD1)) {
  500. sd0_stop(1);
  501. #if I2C_MUX_SD_EN
  502. sd0_go_idle_state();
  503. #endif
  504. }
  505. #if BT_BACKSTAGE_EN
  506. if (dev_is_online(DEV_UDISK)) {
  507. udisk_suspend();
  508. }
  509. #endif
  510. func_cb.last = FUNC_MUSIC;
  511. }
  512. AT(.text.func.music)
  513. void func_music(void)
  514. {
  515. printf("%s\n", __func__);
  516. func_music_enter();
  517. while (func_cb.sta == FUNC_MUSIC) {
  518. func_music_process();
  519. func_music_message(msg_dequeue());
  520. func_music_display();
  521. }
  522. func_music_exit();
  523. }
  524. #endif // FUNC_MUSIC_EN