key.c 21 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841
  1. #include "key.h"
  2. #include "usart.h"
  3. #include "interface.h"
  4. extern Menu_table menu;
  5. extern TipsFlag tipsflag;
  6. bool sent1_key = false;
  7. bool sent2_key = false;
  8. bool sent3_key = false;
  9. bool sent4_key = false;
  10. struct keys key[1]={0};
  11. char timeout[] = "+CONNECT TIMEOUT";
  12. uint16_t S1 = 0;
  13. uint16_t S2 = 0;
  14. uint16_t S3 = 0;
  15. uint16_t S4 = 0;
  16. uint32_t enterInterface_time = 0;
  17. void ClearBtSnItem(void);
  18. uint8_t KEY_1_Scan(void)
  19. {
  20. static uint8_t key_state = 0;
  21. static uint8_t last_key_state = 0;
  22. static uint32_t debounce_time = 0;
  23. key_state = HAL_GPIO_ReadPin(GPIOB, GPIO_PIN_3);
  24. if (key_state != last_key_state) // 检测按键状态变化
  25. {
  26. last_key_state = key_state;
  27. debounce_time = HAL_GetTick(); // 记录当前时间
  28. }
  29. else
  30. {
  31. if (HAL_GetTick() - debounce_time > 30) // 去抖时间
  32. {
  33. if (key_state == GPIO_PIN_RESET) // 按键按下
  34. {
  35. if(!sent1_key)
  36. {
  37. enterInterface_time = HAL_GetTick();
  38. switch(menu.current)
  39. {
  40. case 0:
  41. {
  42. scanMac();
  43. SET_MENU_STATUS(0,0,0,0);
  44. break;
  45. }
  46. case 1:
  47. {
  48. SET_MENU_STATUS(1,1,0,1);
  49. break;
  50. }
  51. case 2:
  52. {
  53. if(menu.up!=4)
  54. {
  55. menu.up+=1;
  56. menu.next-=1;
  57. }
  58. else if(menu.up==4)
  59. {
  60. menu.up=0;
  61. menu.next=4;
  62. }
  63. refresh=true;
  64. break;
  65. }
  66. case 3:
  67. {
  68. if(menu.up!=3)
  69. {
  70. menu.up+=1;
  71. menu.next-=1;
  72. }
  73. else if(menu.up==3)
  74. {
  75. menu.up=0;
  76. menu.next=3;
  77. }
  78. refresh=true;
  79. break;
  80. }
  81. case 4:
  82. case 5:
  83. case 6:
  84. case 7:
  85. case 0xA0:
  86. {
  87. if(menu.up!=1)
  88. {
  89. menu.up+=1;
  90. menu.next-=1;
  91. }
  92. else if(menu.up==1)
  93. {
  94. menu.up=0;
  95. menu.next=1;
  96. }
  97. refresh=true;
  98. break;
  99. }
  100. case 0xA1:
  101. {
  102. if(menu.up!=0xE)
  103. {
  104. menu.up+=1;
  105. menu.next-=1;
  106. }
  107. else if(menu.up==0xE)
  108. {
  109. menu.up=0;
  110. menu.next=0xE;
  111. }
  112. refresh=true;
  113. break;
  114. }
  115. case 0xA2:
  116. {
  117. if(menu.up!=0xF)
  118. {
  119. menu.up+=1;
  120. menu.next-=1;
  121. }
  122. else if(menu.up==0xF)
  123. {
  124. menu.up=0;
  125. menu.next=0xF;
  126. }
  127. refresh=true;
  128. break;
  129. }
  130. }
  131. #if debugkeyinfo == 1
  132. PRINT_MENU_STATUS("K1");
  133. #endif
  134. sent1_key = true;
  135. }
  136. return 1;
  137. }
  138. else // 按键释放
  139. {
  140. sent1_key = false;
  141. return 0;
  142. }
  143. }
  144. }
  145. return 0;
  146. }
  147. uint8_t KEY_2_Scan(void)
  148. {
  149. static uint8_t key_state = 0;
  150. static uint8_t last_key_state = 0;
  151. static uint32_t debounce_time = 0;
  152. key_state = HAL_GPIO_ReadPin(GPIOB, GPIO_PIN_4);
  153. if (key_state != last_key_state) // 检测按键状态变化
  154. {
  155. last_key_state = key_state;
  156. debounce_time = HAL_GetTick(); // 记录当前时间
  157. }
  158. else
  159. {
  160. if (HAL_GetTick() - debounce_time > 30) // 去抖时间
  161. {
  162. if (key_state == GPIO_PIN_RESET) // 按键按下
  163. {
  164. if (!sent2_key)
  165. {
  166. enterInterface_time = HAL_GetTick();
  167. switch (menu.current)
  168. {
  169. case 0:
  170. {
  171. scanMac();
  172. SET_MENU_STATUS(0,0,0,0);
  173. break;
  174. }
  175. case 1:
  176. {
  177. SET_MENU_STATUS(1,0,1,1);
  178. break;
  179. }
  180. case 2:
  181. {
  182. if(menu.next!=4)
  183. {
  184. menu.up-=1;
  185. menu.next+=1;
  186. }
  187. else if(menu.next==4)
  188. {
  189. menu.up=4;
  190. menu.next=0;
  191. }
  192. refresh=true;
  193. break;
  194. }
  195. case 3:
  196. {
  197. if(menu.next!=3)
  198. {
  199. menu.up-=1;
  200. menu.next+=1;
  201. }
  202. else if(menu.next==3)
  203. {
  204. menu.up=3;
  205. menu.next=0;
  206. }
  207. refresh=true;
  208. break;
  209. }
  210. case 4:
  211. case 5:
  212. case 6:
  213. case 7:
  214. case 0xA0:
  215. {
  216. if(menu.next!=1)
  217. {
  218. menu.up-=1;
  219. menu.next+=1;
  220. }
  221. else if(menu.next==1)
  222. {
  223. menu.up=1;
  224. menu.next=0;
  225. }
  226. refresh=true;
  227. break;
  228. }
  229. case 0xA1:
  230. {
  231. if(menu.next!=0xE)
  232. {
  233. menu.up-=1;
  234. menu.next+=1;
  235. }
  236. else if(menu.next==0xE)
  237. {
  238. menu.up=0xE;
  239. menu.next=0;
  240. }
  241. refresh=true;
  242. break;
  243. }
  244. case 0xA2:
  245. {
  246. if(menu.next!=0xF)
  247. {
  248. menu.up-=1;
  249. menu.next+=1;
  250. }
  251. else if(menu.next==0xF)
  252. {
  253. menu.up=0xF;
  254. menu.next=0;
  255. }
  256. refresh=true;
  257. break;
  258. }
  259. }
  260. #if debugkeyinfo == 1
  261. PRINT_MENU_STATUS("K2");
  262. #endif
  263. sent2_key = true;
  264. }
  265. return 1;
  266. }
  267. else // 按键释放
  268. {
  269. sent2_key = false;
  270. return 0;
  271. }
  272. }
  273. }
  274. return 0;
  275. }
  276. // 定义menu_dict存储menu.next对应的信息
  277. MenuInfo menu_dict[] = {
  278. {"AT+CONN=101000000001\r\n", "+CONNECTED:0,101000000001", "+DISCONN:0,101000000001", 0x0001},
  279. {"AT+CONN=101000000002\r\n", "+CONNECTED:0,101000000002", "+DISCONN:0,101000000002", 0x0002},
  280. {"AT+CONN=101000000003\r\n", "+CONNECTED:0,101000000003", "+DISCONN:0,101000000003", 0x0003},
  281. {"AT+CONN=101000000004\r\n", "+CONNECTED:0,101000000004", "+DISCONN:0,101000000004", 0x0004},
  282. {"AT+CONN=101000000005\r\n", "+CONNECTED:0,101000000005", "+DISCONN:0,101000000005", 0x0005},
  283. {"AT+CONN=101000000006\r\n", "+CONNECTED:0,101000000006", "+DISCONN:0,101000000006", 0x0006},
  284. {"AT+CONN=101000000007\r\n", "+CONNECTED:0,101000000007", "+DISCONN:0,101000000007", 0x0007},
  285. {"AT+CONN=101000000008\r\n", "+CONNECTED:0,101000000008", "+DISCONN:0,101000000008", 0x0008},
  286. {"AT+CONN=101000000009\r\n", "+CONNECTED:0,101000000009", "+DISCONN:0,101000000009", 0x0009},
  287. {"AT+CONN=10100000000A\r\n", "+CONNECTED:0,10100000000A", "+DISCONN:0,10100000000A", 0x000A},
  288. {"AT+CONN=10100000000B\r\n", "+CONNECTED:0,10100000000B", "+DISCONN:0,10100000000B", 0x000B},
  289. {"AT+CONN=10100000000C\r\n", "+CONNECTED:0,10100000000C", "+DISCONN:0,10100000000C", 0x000C},
  290. {"AT+CONN=10100000000D\r\n", "+CONNECTED:0,10100000000D", "+DISCONN:0,10100000000D", 0x000D},
  291. {"AT+CONN=10100000000E\r\n", "+CONNECTED:0,10100000000E", "+DISCONN:0,10100000000E", 0x000E},
  292. {"AT+CONN=10100000000F\r\n", "+CONNECTED:0,10100000000F", "+DISCONN:0,10100000000F", 0x000F},
  293. {"AT+CONN=101000000010\r\n", "+CONNECTED:0,101000000010", "+DISCONN:0,101000000010", 0x0010},
  294. {"AT+CONN=101000000011\r\n", "+CONNECTED:0,101000000011", "+DISCONN:0,101000000011", 0x0011},
  295. {"AT+CONN=101000000012\r\n", "+CONNECTED:0,101000000012", "+DISCONN:0,101000000012", 0x0012},
  296. {"AT+CONN=101000000013\r\n", "+CONNECTED:0,101000000013", "+DISCONN:0,101000000013", 0x0013},
  297. {"AT+CONN=101000000014\r\n", "+CONNECTED:0,101000000014", "+DISCONN:0,101000000014", 0x0014},
  298. {"AT+CONN=101000000015\r\n", "+CONNECTED:0,101000000015", "+DISCONN:0,101000000015", 0x0015},
  299. {"AT+CONN=101000000016\r\n", "+CONNECTED:0,101000000016", "+DISCONN:0,101000000016", 0x0016},
  300. {"AT+CONN=101000000017\r\n", "+CONNECTED:0,101000000017", "+DISCONN:0,101000000017", 0x0017},
  301. {"AT+CONN=101000000018\r\n", "+CONNECTED:0,101000000018", "+DISCONN:0,101000000018", 0x0018},
  302. {"AT+CONN=101000000019\r\n", "+CONNECTED:0,101000000019", "+DISCONN:0,101000000019", 0x0019},
  303. {"AT+CONN=10100000001A\r\n", "+CONNECTED:0,10100000001A", "+DISCONN:0,10100000001A", 0x001A},
  304. {"AT+CONN=10100000001B\r\n", "+CONNECTED:0,10100000001B", "+DISCONN:0,10100000001B", 0x001B},
  305. {"AT+CONN=10100000001C\r\n", "+CONNECTED:0,10100000001C", "+DISCONN:0,10100000001C", 0x001C},
  306. {"AT+CONN=10100000001D\r\n", "+CONNECTED:0,10100000001D", "+DISCONN:0,10100000001D", 0x001D},
  307. {"AT+CONN=10100000001E\r\n", "+CONNECTED:0,10100000001E", "+DISCONN:0,10100000001E", 0x001E},
  308. {"AT+CONN=10100000001F\r\n", "+CONNECTED:0,10100000001F", "+DISCONN:0,10100000001F", 0x001F},
  309. // 其他项依次类推
  310. };
  311. uint8_t KEY_3_Scan(void)
  312. {
  313. static uint8_t key_state = 0;
  314. static uint8_t last_key_state = 0;
  315. static uint32_t debounce_time = 0;
  316. key_state = HAL_GPIO_ReadPin(GPIOB, GPIO_PIN_5);
  317. if (key_state != last_key_state) // 检测按键状态变化
  318. {
  319. last_key_state = key_state;
  320. debounce_time = HAL_GetTick(); // 记录当前时间
  321. }
  322. else
  323. {
  324. if (HAL_GetTick() - debounce_time > 30) // 去抖时间
  325. {
  326. if (key_state == GPIO_PIN_RESET) // 按键按下
  327. {
  328. if (!sent3_key) {
  329. enterInterface_time = HAL_GetTick();
  330. switch (menu.current) {
  331. case 0://跳转到菜单界面
  332. {
  333. SET_MENU_STATUS(1,1,0,1);
  334. break;
  335. }
  336. case 1://跳转到L绑定界面
  337. {
  338. if(menu.up==1)
  339. {
  340. scanMac();
  341. SET_MENU_STATUS(2,4,0,2);
  342. }
  343. else
  344. {
  345. scanMac();
  346. SET_MENU_STATUS(3,3,0,2);
  347. }
  348. break;
  349. }
  350. case 2:
  351. {
  352. if(menu.up==0)
  353. {
  354. //清空SN
  355. ClearBtSnItem();
  356. SET_MENU_STATUS(1,1,0,1);
  357. break;
  358. }
  359. else
  360. {
  361. menu.PreNext=menu.next;//L1 - L4
  362. SET_MENU_STATUS(0xA0,1,0,3);
  363. break;
  364. }
  365. }
  366. case 3://施解封操作
  367. {
  368. if(menu.up==3)//L1操作
  369. {
  370. sendCmd_BT(menu.SN1,menu.SN1F,3,3);
  371. HAL_Delay(100);
  372. SET_MENU_STATUS(4,1,0,3);
  373. break;
  374. }
  375. if(menu.up==2)//2操作
  376. {
  377. sendCmd_BT(menu.SN2,menu.SN2F,3,3);
  378. HAL_Delay(100);
  379. SET_MENU_STATUS(5,1,0,3);
  380. break;
  381. }
  382. if(menu.up==1)//3操作
  383. {
  384. sendCmd_BT(menu.SN3,menu.SN3F,3,3);
  385. HAL_Delay(100);
  386. SET_MENU_STATUS(6,1,0,3);
  387. break;
  388. }
  389. if(menu.up==0)//4操作
  390. {
  391. sendCmd_BT(menu.SN4,menu.SN4F,3,3);
  392. HAL_Delay(100);
  393. SET_MENU_STATUS(7,1,0,3);
  394. break;
  395. }
  396. }
  397. case 4:
  398. case 5:
  399. case 6:
  400. case 7:
  401. {
  402. menu.enter=4;
  403. break;
  404. }
  405. case 0xA0:
  406. {
  407. if(menu.up==1)
  408. {
  409. SET_MENU_STATUS(0xA1,0xE,0,3);
  410. }
  411. else if(menu.up==0)
  412. {
  413. SET_MENU_STATUS(0xA2,0xF,0,3);
  414. }
  415. break;
  416. }
  417. case 0xA1:
  418. case 0xA2:
  419. {
  420. if(menu.PreNext==0)//L1 写
  421. {
  422. if(menu.current!=0xA2)
  423. {
  424. for (int i = 0; i < sizeof(menu_dict) / sizeof(menu_dict[0]); i++) {
  425. if (menu.next == i) {
  426. erase_flash(Sn1StatusAddr);
  427. erase_flash(Sn1Addr);
  428. erase_flash(serialNum1Addr);
  429. menu.SN1 = menu_dict[i].command;
  430. menu.SN1F = menu_dict[i].connected_msg;
  431. menu.SN1D = menu_dict[i].disconnected_msg;
  432. Write_Information(Sn1Addr, menu_dict[i].value);
  433. L1bd=true;
  434. }
  435. }
  436. }
  437. else
  438. {
  439. for (int i = 0; i < sizeof(menu_dict) / sizeof(menu_dict[0]); i++) {
  440. if ((menu.next+0xf) == i) {
  441. menu.SN1 = menu_dict[i].command;
  442. menu.SN1F = menu_dict[i].connected_msg;
  443. menu.SN1D = menu_dict[i].disconnected_msg;
  444. Write_Information(Sn1Addr, menu_dict[i].value);
  445. L1bd=true;
  446. }
  447. }
  448. }
  449. menu.home &= 0x0FFF;
  450. }
  451. if(menu.PreNext==1)//L2 写
  452. {
  453. if(menu.current!=0xA2)
  454. {
  455. for (int i = 0; i < sizeof(menu_dict) / sizeof(menu_dict[0]); i++) {
  456. if (menu.next == i) {
  457. menu.SN2 = menu_dict[i].command;
  458. menu.SN2F = menu_dict[i].connected_msg;
  459. menu.SN2D = menu_dict[i].disconnected_msg;
  460. Write_Information(Sn2Addr, menu_dict[i].value);
  461. L2bd=true;
  462. }
  463. }
  464. }
  465. else
  466. {
  467. for (int i = 0; i < sizeof(menu_dict) / sizeof(menu_dict[0]); i++) {
  468. if ((menu.next+0xf) == i) {
  469. menu.SN2 = menu_dict[i].command;
  470. menu.SN2F = menu_dict[i].connected_msg;
  471. menu.SN2D = menu_dict[i].disconnected_msg;
  472. Write_Information(Sn2Addr, menu_dict[i].value);
  473. L2bd=true;
  474. }
  475. }
  476. }
  477. menu.home &= 0xF0FF;
  478. }
  479. if(menu.PreNext==2)//L3 写
  480. {
  481. if(menu.current!=0xA2)
  482. {
  483. for (int i = 0; i < sizeof(menu_dict) / sizeof(menu_dict[0]); i++) {
  484. if (menu.next == i) {
  485. menu.SN3 = menu_dict[i].command;
  486. menu.SN3F = menu_dict[i].connected_msg;
  487. menu.SN3D = menu_dict[i].disconnected_msg;
  488. Write_Information(Sn3Addr, menu_dict[i].value);
  489. L3bd=true;
  490. }
  491. }
  492. }
  493. else
  494. {
  495. for (int i = 0; i < sizeof(menu_dict) / sizeof(menu_dict[0]); i++) {
  496. if ((menu.next+0xf) == i) {
  497. menu.SN3 = menu_dict[i].command;
  498. menu.SN3F = menu_dict[i].connected_msg;
  499. menu.SN3D = menu_dict[i].disconnected_msg;
  500. Write_Information(Sn3Addr, menu_dict[i].value);
  501. L3bd=true;
  502. }
  503. }
  504. }
  505. menu.home &= 0xFF0F;
  506. }
  507. if(menu.PreNext==3)//L4 写
  508. {
  509. if(menu.current!=0xA2)
  510. {
  511. for (int i = 0; i < sizeof(menu_dict) / sizeof(menu_dict[0]); i++) {
  512. if (menu.next == i) {
  513. menu.SN4 = menu_dict[i].command;
  514. menu.SN4F = menu_dict[i].connected_msg;
  515. menu.SN4D = menu_dict[i].disconnected_msg;
  516. Write_Information(Sn4Addr, menu_dict[i].value);
  517. L4bd=true;
  518. }
  519. }
  520. }
  521. else
  522. {
  523. for (int i = 0; i < sizeof(menu_dict) / sizeof(menu_dict[0]); i++) {
  524. if ((menu.next+0xf) == i) {
  525. menu.SN4 = menu_dict[i].command;
  526. menu.SN4F = menu_dict[i].connected_msg;
  527. menu.SN4D = menu_dict[i].disconnected_msg;
  528. Write_Information(Sn4Addr, menu_dict[i].value);
  529. L4bd=true;
  530. }
  531. }
  532. }
  533. menu.home &= 0xFFF0;
  534. }
  535. readLockStatusinit();
  536. scanMac();
  537. SET_MENU_STATUS(2,4,0,2);
  538. break;
  539. }
  540. }
  541. #if debugkeyinfo == 1
  542. PRINT_MENU_STATUS("K3");
  543. #endif
  544. sent3_key = true;
  545. }
  546. return 1;
  547. }
  548. else // 按键释放
  549. {
  550. sent3_key = false;
  551. return 0;
  552. }
  553. }
  554. }
  555. return 0;
  556. }
  557. uint8_t KEY_4_Scan(void)
  558. {
  559. static uint8_t key_state = 0;
  560. static uint8_t last_key_state = 0;
  561. static uint32_t debounce_time = 0;
  562. key_state = HAL_GPIO_ReadPin(GPIOB, GPIO_PIN_6);
  563. if (key_state != last_key_state) // 检测按键状态变化
  564. {
  565. last_key_state = key_state;
  566. debounce_time = HAL_GetTick(); // 记录当前时间
  567. }
  568. else
  569. {
  570. if (HAL_GetTick() - debounce_time > 30) // 去抖时间
  571. {
  572. if (key_state == GPIO_PIN_RESET) // 按键按下
  573. {
  574. enterInterface_time = HAL_GetTick();
  575. if (!sent4_key) {//返回
  576. switch (menu.current) {
  577. case 0:
  578. case 1:
  579. {
  580. scanMac();
  581. SET_MENU_STATUS(0,0,0,0);
  582. break;
  583. }
  584. case 2:
  585. case 3:
  586. {
  587. scanMac();
  588. SET_MENU_STATUS(1,1,0,1);
  589. break;
  590. }
  591. case 4:
  592. case 5:
  593. case 6:
  594. case 7:
  595. {
  596. sendCmd_BT("AT+DISCONN=0\r\n","ERROR",1,1);//断开连接
  597. HAL_Delay(30);
  598. S1 = read_flash_16(Sn1StatusAddr);
  599. S2 = read_flash_16(Sn2StatusAddr);
  600. S3 = read_flash_16(Sn3StatusAddr);
  601. S4 = read_flash_16(Sn4StatusAddr);
  602. scanMac();
  603. SET_MENU_STATUS(3,3,0,2);
  604. break;
  605. }
  606. case 0xA0:
  607. {
  608. SET_MENU_STATUS(2,4,0,2);
  609. break;
  610. }
  611. case 0xA1:
  612. case 0xA2:
  613. {
  614. S1 = read_flash_16(Sn1StatusAddr);
  615. S2 = read_flash_16(Sn2StatusAddr);
  616. S3 = read_flash_16(Sn3StatusAddr);
  617. S4 = read_flash_16(Sn4StatusAddr);
  618. HAL_Delay(30);
  619. scanMac();
  620. SET_MENU_STATUS(0xA0,1,0,3);
  621. break;
  622. }
  623. }
  624. #if debugkeyinfo == 1
  625. PRINT_MENU_STATUS("K4");
  626. #endif
  627. sent4_key = true;
  628. }
  629. return 1;
  630. }
  631. else // 按键释放
  632. {
  633. sent4_key = false;
  634. return 0;
  635. }
  636. }
  637. }
  638. return 0;
  639. }
  640. void updatekeystate(void)
  641. {
  642. KEY_1_Scan();
  643. KEY_2_Scan();
  644. KEY_3_Scan();
  645. KEY_4_Scan();
  646. }
  647. // 定义存储信息的结构体数组
  648. struct BtMenuItem btMenuItems[] = {
  649. {0x0001, "0001", "AT+CONN=101000000001\r\n", "+CONNECTED:0,101000000001"},
  650. {0x0002, "0002", "AT+CONN=101000000002\r\n", "+CONNECTED:0,101000000002"},
  651. {0x0003, "0003", "AT+CONN=101000000003\r\n", "+CONNECTED:0,101000000003"},
  652. {0x0004, "0004", "AT+CONN=101000000004\r\n", "+CONNECTED:0,101000000004"},
  653. {0x0005, "0005", "AT+CONN=101000000005\r\n", "+CONNECTED:0,101000000005"},
  654. {0x0006, "0006", "AT+CONN=101000000006\r\n", "+CONNECTED:0,101000000006"},
  655. {0x0007, "0007", "AT+CONN=101000000007\r\n", "+CONNECTED:0,101000000007"},
  656. {0x0008, "0008", "AT+CONN=101000000008\r\n", "+CONNECTED:0,101000000008"},
  657. {0x0009, "0009", "AT+CONN=101000000009\r\n", "+CONNECTED:0,101000000009"},
  658. {0x000A, "000A", "AT+CONN=10100000000A\r\n", "+CONNECTED:0,10100000000A"},
  659. {0x000B, "000B", "AT+CONN=10100000000B\r\n", "+CONNECTED:0,10100000000B"},
  660. {0x000C, "000C", "AT+CONN=10100000000C\r\n", "+CONNECTED:0,10100000000C"},
  661. {0x000D, "000D", "AT+CONN=10100000000D\r\n", "+CONNECTED:0,10100000000D"},
  662. {0x000E, "000E", "AT+CONN=10100000000E\r\n", "+CONNECTED:0,10100000000E"},
  663. {0x000F, "000F", "AT+CONN=10100000000F\r\n", "+CONNECTED:0,10100000000F"},
  664. {0x0010, "0010", "AT+CONN=101000000010\r\n", "+CONNECTED:0,101000000010"},
  665. {0x0011, "0011", "AT+CONN=101000000011\r\n", "+CONNECTED:0,101000000011"},
  666. {0x0012, "0012", "AT+CONN=101000000012\r\n", "+CONNECTED:0,101000000012"},
  667. {0x0013, "0013", "AT+CONN=101000000013\r\n", "+CONNECTED:0,101000000013"},
  668. {0x0014, "0014", "AT+CONN=101000000014\r\n", "+CONNECTED:0,101000000014"},
  669. {0x0015, "0015", "AT+CONN=101000000015\r\n", "+CONNECTED:0,101000000015"},
  670. {0x0016, "0016", "AT+CONN=101000000016\r\n", "+CONNECTED:0,101000000016"},
  671. {0x0017, "0017", "AT+CONN=101000000017\r\n", "+CONNECTED:0,101000000017"},
  672. {0x0018, "0018", "AT+CONN=101000000018\r\n", "+CONNECTED:0,101000000018"},
  673. {0x0019, "0019", "AT+CONN=101000000019\r\n", "+CONNECTED:0,101000000019"},
  674. {0x001A, "001A", "AT+CONN=10100000001A\r\n", "+CONNECTED:0,10100000001A"},
  675. {0x001B, "001B", "AT+CONN=10100000001B\r\n", "+CONNECTED:0,10100000001B"},
  676. {0x001C, "001C", "AT+CONN=10100000001C\r\n", "+CONNECTED:0,10100000001C"},
  677. {0x001D, "001D", "AT+CONN=10100000001D\r\n", "+CONNECTED:0,10100000001D"},
  678. {0x001E, "001E", "AT+CONN=10100000001E\r\n", "+CONNECTED:0,10100000001E"},
  679. {0x001F, "001F", "AT+CONN=10100000001F\r\n", "+CONNECTED:0,10100000001F"},
  680. };
  681. void scanMac(void)
  682. {
  683. uint16_t SN1 = read_flash_16(Sn1Addr);
  684. uint16_t SN2 = read_flash_16(Sn2Addr);
  685. uint16_t SN3 = read_flash_16(Sn3Addr);
  686. uint16_t SN4 = read_flash_16(Sn4Addr);
  687. if(SN1==0xffff)
  688. {
  689. SN1=0;
  690. }
  691. if(SN2==0xffff)
  692. {
  693. SN2=0;
  694. }
  695. if(SN3==0xffff)
  696. {
  697. SN3=0;
  698. }
  699. if(SN4==0xffff)
  700. {
  701. SN4=0;
  702. }
  703. locksnu8.L1snT8[0] = SN1>>8&0xff;
  704. locksnu8.L1snT8[1] = SN1&0xff;
  705. locksnu8.L2snT8[0] = SN2>>8&0xff;
  706. locksnu8.L2snT8[1] = SN2&0xff;
  707. locksnu8.L3snT8[0] = SN3>>8&0xff;
  708. locksnu8.L3snT8[1] = SN3&0xff;
  709. locksnu8.L4snT8[0] = SN4>>8&0xff;
  710. locksnu8.L4snT8[1] = SN4&0xff;
  711. // 匹配并设置属性
  712. for (int i = 0; i < sizeof(btMenuItems)/sizeof(btMenuItems[0]); i++) {
  713. if (SN1 == (uint16_t)i + 1) {
  714. menu.SN1name = btMenuItems[i].name;
  715. menu.SN1 = btMenuItems[i].command;
  716. menu.SN1F = btMenuItems[i].feedback;
  717. L1bd = true;
  718. break;
  719. }
  720. }
  721. for (int i = 0; i < sizeof(btMenuItems)/sizeof(btMenuItems[0]); i++) {
  722. if (SN2 == (uint16_t)i + 1) {
  723. menu.SN2name = btMenuItems[i].name;
  724. menu.SN2 = btMenuItems[i].command;
  725. menu.SN2F = btMenuItems[i].feedback;
  726. L2bd = true;
  727. break;
  728. }
  729. }
  730. for (int i = 0; i < sizeof(btMenuItems)/sizeof(btMenuItems[0]); i++) {
  731. if (SN3 == (uint16_t)i + 1) {
  732. menu.SN3name = btMenuItems[i].name;
  733. menu.SN3 = btMenuItems[i].command;
  734. menu.SN3F = btMenuItems[i].feedback;
  735. L3bd = true;
  736. break;
  737. }
  738. }
  739. for (int i = 0; i < sizeof(btMenuItems)/sizeof(btMenuItems[0]); i++) {
  740. if (SN4 == (uint16_t)i + 1) {
  741. menu.SN4name = btMenuItems[i].name;
  742. menu.SN4 = btMenuItems[i].command;
  743. menu.SN4F = btMenuItems[i].feedback;
  744. L4bd = true;
  745. break;
  746. }
  747. }
  748. }
  749. void ClearBtSnItem(void)
  750. {
  751. menu.SN1name=NULL;
  752. menu.SN1=NULL;
  753. menu.SN1F=NULL;
  754. menu.SN1D=NULL;
  755. erase_flash(Sn1StatusAddr);
  756. erase_flash(Sn1Addr);
  757. erase_flash(serialNum1Addr);
  758. L1bd=false;
  759. menu.SN2name=NULL;
  760. menu.SN2=NULL;
  761. menu.SN2F=NULL;
  762. menu.SN2D=NULL;
  763. menu.SN3name=NULL;
  764. menu.SN3=NULL;
  765. menu.SN3F=NULL;
  766. menu.SN3D=NULL;
  767. menu.SN4name=NULL;
  768. menu.SN4=NULL;
  769. menu.SN4F=NULL;
  770. menu.SN4D=NULL;
  771. erase_flash(Sn2StatusAddr);
  772. erase_flash(Sn3StatusAddr);
  773. erase_flash(Sn4StatusAddr);
  774. erase_flash(Sn2Addr);
  775. erase_flash(Sn3Addr);
  776. erase_flash(Sn4Addr);
  777. erase_flash(serialNum2Addr);
  778. erase_flash(serialNum3Addr);
  779. erase_flash(serialNum4Addr);
  780. L2bd=false;
  781. L3bd=false;
  782. L4bd=false;
  783. menu.home=0x10000;//其他地址
  784. }