mba32a.c 15 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703
  1. #include "mba32a.h"
  2. #include "usart.h"
  3. #include "interface.h"
  4. /**
  5. * @breaf 外部定义
  6. */
  7. extern UART_HandleTypeDef huart3;
  8. extern UART_HandleTypeDef huart5;
  9. extern Menu_table menu; //结构体
  10. extern TipsFlag tipsflag;
  11. /**
  12. * @breaf 本页定义
  13. */
  14. BtFrame btframe;
  15. BtStep btstep;
  16. bool BT_CONN = false;
  17. bool connected = false; //连接断进程标志位
  18. bool resetBTmodule = false;
  19. uint8_t step_BT=0;
  20. uint8_t dev1[12]={0};
  21. uint8_t resetcount=0;
  22. uint16_t u5length=0;
  23. uint16_t resetFlag16=0;
  24. uint8_t g_MBA32A_8buf[1024]={0}; //蓝牙接收数组
  25. uint8_t g_MBA32A_8buf_Down[1024]={0} ; //蓝牙搬移数组
  26. uint16_t bt_dataLength=0; //bt接收有效数据长度
  27. uint8_t bt_error_num=0; //bt接收的错误事件
  28. uint32_t bt_serial_num=0; //bt接收的流水号
  29. uint8_t bt_battery=0; //bt剩余电量百分比
  30. uint8_t bt_log_num=0; //bt记录事件数量
  31. uint8_t bt_lock_machinesta=0; //bt锁(电机)状态(0x00开;0x01关;0x02异常)
  32. uint8_t bt_lock_ropesta=0; //bt锁(锁绳)状态(0x00插入;0x01拔出)
  33. uint16_t bt_hwver=0; //bt硬件版本号
  34. uint16_t bt_sfver=0; //bt软件版本号
  35. /**
  36. * @breaf 本页方法
  37. */
  38. uint8_t sendCmd_BT(char *pCmd, char *pRes, uint32_t timeOut, uint8_t sendNum);
  39. void MBA32AReset(void);
  40. void Start_Read_resetFlag16(void);
  41. void Bt_Connection(void);
  42. /**
  43. * @breaf 非本页方法
  44. */
  45. void execute_interface(Menu_table menu);
  46. /**
  47. * @breaf 蓝牙初始化,工作接口
  48. */
  49. void MBA32A_Init(void)
  50. {
  51. INIT_BT_FRAME();/** 流水号/用户id/自动施封 **/
  52. Start_Read_resetFlag16();/** 启动位读写检查 **/
  53. switch(btstep)
  54. {
  55. case BtStepDefault:
  56. break;
  57. case UUIDS:
  58. {
  59. if(sendCmd_BT("AT+UUIDS?\r\n","+UUIDS:FFF0",1,1))//蓝牙芯片默认值,需要修改
  60. {
  61. if(sendCmd_BT("AT+UUIDS=0002\r\n","OK",1,1))
  62. {
  63. printf("#01设置主服务成功\n");
  64. btstep++;
  65. }
  66. }
  67. else
  68. { //ERROR 其他值
  69. MBA32AReset();
  70. break;
  71. }
  72. }
  73. case UUIDN:
  74. {
  75. if(sendCmd_BT("AT+UUIDN?\r\n","+UUIDN:FFF1",1,1))//蓝牙芯片默认值,需要修改
  76. {
  77. if(sendCmd_BT("AT+UUIDN=FF04\r\n","OK",1,1))
  78. {
  79. printf("#02设置读服务成功\n");
  80. btstep++;
  81. }
  82. }
  83. else
  84. { //ERROR 其他值
  85. MBA32AReset();
  86. break;
  87. }
  88. }
  89. case UUIDW:
  90. {
  91. if(sendCmd_BT("AT+UUIDW?\r\n","+UUIDW:FFF2",1,1))//蓝牙芯片默认值,需要修改
  92. {
  93. if(sendCmd_BT("AT+UUIDW=FFF5\r\n","OK",1,1))
  94. {
  95. printf("#03设置写服务成功\n");
  96. btstep++;
  97. }
  98. }
  99. else
  100. { //ERROR 其他值
  101. MBA32AReset();
  102. break;
  103. }
  104. }
  105. }
  106. }
  107. /**
  108. * @breaf 蓝牙启动位读写检查
  109. */
  110. void Start_Read_resetFlag16(void)
  111. {
  112. resetFlag16 = read_flash_16(resetDevAddr);
  113. if(resetFlag16==0xFFFF)//开机检测(首次启动)
  114. {
  115. if(sendCmd_BT("AT+RESET=1\r\n","OK",1,1))
  116. {
  117. Write_Information(resetDevAddr);//写入0xAAAA
  118. printf("#复位设备成功\r\n");
  119. btstep = UUIDS;
  120. }
  121. if(!sendCmd_BT("AT+DISCONN=0\r\n","OK",1,1))
  122. {
  123. printf("#无设备连接\r\n");
  124. }
  125. else
  126. {
  127. printf("#已断开连接设备\r\n");
  128. }
  129. }
  130. else if(resetFlag16==0xAAAA)//开机检测(大于1次启动)
  131. {
  132. printf("#非首次启动\r\n");
  133. if (!sendCmd_BT("AT+UUIDS?\r\n","+UUIDS:0002",1,1))
  134. {
  135. PRINT_NUUID("UUIDS");//UUID项不符合
  136. btstep = UUIDS;
  137. }
  138. if (!sendCmd_BT("AT+UUIDN?\r\n","+UUIDN:FF04",1,1))
  139. {
  140. PRINT_NUUID("UUIDN");//UUID项不符合
  141. btstep = UUIDN;
  142. }
  143. if (!sendCmd_BT("AT+UUIDW?\r\n","+UUIDW:FFF5",1,1))
  144. {
  145. PRINT_NUUID("UUIDW");//UUID项不符合
  146. btstep = UUIDW;
  147. }
  148. else
  149. {
  150. PRINT_UUID("UUID项");//UUID项符合设置项
  151. btstep = BtStepDefault;
  152. }
  153. }
  154. }
  155. /**
  156. * @breaf 蓝牙初始化,演示接口
  157. */
  158. void MBA32A_Init_demo(void)
  159. {
  160. startdtu = true;
  161. menu.home=0;
  162. btframe.serialNum = 0x00000001;//流水号
  163. btframe.userId = 0x64747531;//dtu1
  164. btframe.Autoseal = 0x01;
  165. printf("\r\t\tBTinit%d...",resetcount);
  166. resetFlag16 = read_flash_16(resetDevAddr);
  167. if(resetFlag16==0xFFFF)//开机检测(首次启动)
  168. {
  169. if(sendCmd_BT("AT+RESET=1\r\n","OK",1,1))
  170. {
  171. Write_Information(resetDevAddr);//写入0xAAAA
  172. printf("复位设备成功\r\n");
  173. }
  174. else if(sendCmd_BT("AT+DISCONN=0\r\n","OK",1,1))
  175. {
  176. printf("取消连接所有设备\r\n");
  177. }
  178. else
  179. {
  180. printf("复位失败\r\n");
  181. }
  182. }
  183. else if(resetFlag16==0xAAAA)//开机检测(大于1次启动)
  184. {
  185. //printf("复位%X\r\n",resetFlag16);
  186. printf("非首次启动\r\n");
  187. }
  188. switch(step_BT)
  189. {
  190. case 0:
  191. {
  192. if(sendCmd_BT("AT+DEV?\r\n","+DEV:0,101000000003",1,1))
  193. {
  194. startdtu=false; //关闭开始界面
  195. BT_CONN=true;
  196. connected=true;
  197. if(sendCmd_BT("AT+AUTO_CFG=1\r\n","OK",1,1))
  198. {
  199. printf("自动重连打开\r\n");
  200. }
  201. printf("设备已连接\r\n");
  202. //L1bd=true;
  203. break;
  204. }
  205. else if(sendCmd_BT("AT+DEV?\r\n","+DEV:",1,1))
  206. {
  207. printf("未连接设备\r\n");
  208. }
  209. step_BT++;
  210. }
  211. case 1:
  212. {
  213. printf("设备未连接\r\n");
  214. if(!connected)//断进程标志位
  215. {
  216. if(sendCmd_BT("AT+UUIDS?\r\n","+UUIDS:FFF0",1,1))//蓝牙芯片默认值,需要修改
  217. {
  218. if(sendCmd_BT("AT+UUIDS=0002\r\n","OK",1,1))
  219. {
  220. printf("01设置主服务成功\n");
  221. step_BT++;
  222. }
  223. }
  224. else if(sendCmd_BT("AT+UUIDS?\r\n","+UUIDS:0002",1,1))
  225. {
  226. printf("UUIDS非默认值,符合\n");
  227. step_BT++;
  228. }
  229. else
  230. { //ERROR 其他值
  231. MBA32AReset();
  232. break;
  233. }
  234. }
  235. }
  236. case 2:
  237. {
  238. if(!connected)//断进程标志位
  239. {
  240. if(sendCmd_BT("AT+UUIDN?\r\n","+UUIDN:FFF1",1,1))//蓝牙芯片默认值,需要修改
  241. {
  242. if(sendCmd_BT("AT+UUIDN=FF04\r\n","OK",1,1))
  243. {
  244. printf("02设置读服务成功\n");
  245. step_BT++;
  246. }
  247. }
  248. else if(sendCmd_BT("AT+UUIDN?\r\n","+UUIDN:FF04",1,1))
  249. {
  250. printf("UUIDN非默认值,符合\n");
  251. step_BT++;
  252. }
  253. else
  254. { //ERROR 其他值
  255. MBA32AReset();
  256. break;
  257. }
  258. }
  259. }
  260. case 3:
  261. {
  262. if(!connected)//断进程标志位
  263. {
  264. if(sendCmd_BT("AT+UUIDW?\r\n","+UUIDW:FFF2",1,1))//蓝牙芯片默认值,需要修改
  265. {
  266. if(sendCmd_BT("AT+UUIDW=FFF5\r\n","OK",1,1))
  267. {
  268. printf("03设置写服务成功\n");
  269. step_BT++;
  270. }
  271. }
  272. else if(sendCmd_BT("AT+UUIDW?\r\n","+UUIDW:FFF5",1,1))
  273. {
  274. printf("UUIDW非默认值,符合\n");
  275. step_BT++;
  276. }
  277. else
  278. { //ERROR 其他值
  279. MBA32AReset();
  280. break;
  281. }
  282. }
  283. }
  284. case 4:
  285. {
  286. if(!connected)//断进程标志位
  287. {
  288. if(sendCmd_BT("AT+CONN=101000000003\r\n","+CONNECTED:0,101000000003",3,3))
  289. {
  290. startdtu=false; //关闭开始界面
  291. BT_CONN=true;
  292. //L1bd=true;
  293. if(sendCmd_BT("AT+AUTO_CFG=1\r\n","OK",1,1))
  294. {
  295. printf("自动重连打开\r\n");
  296. }
  297. printf("连接成功!");
  298. break;
  299. }
  300. else if(sendCmd_BT("AT+CONN=101000000003\r\n","+CONNECT TIMEOUT",3,5))
  301. {
  302. printf("连接超时!");
  303. MBA32AReset(); //后台复位
  304. break;
  305. }
  306. else
  307. {
  308. printf("连接失败! %s",g_MBA32A_8buf_Down);
  309. MBA32AReset();
  310. break;
  311. }
  312. }
  313. }
  314. }
  315. }
  316. /**
  317. * @breaf 模块复位函数(接收数组清0)
  318. */
  319. void MBA32AReset(void)
  320. {
  321. printf("Bt reset\r\n");
  322. HAL_GPIO_WritePin(REST_BT_GPIO_Port,REST_BT_Pin,GPIO_PIN_RESET);
  323. HAL_Delay(4000);
  324. btstep = UUIDS;
  325. resetBTmodule=true;//freertos监测模块重启位
  326. resetcount+=1;
  327. }
  328. /**
  329. * @breaf 串口发送命令子函数
  330. */
  331. void USART_SendString(UART_HandleTypeDef *huart, char *str)
  332. {
  333. printf("\r\n\tTransmit CMD:\t");
  334. HAL_UART_Transmit(huart, (uint8_t*)str, strlen(str), 0xFFFF);
  335. HAL_UART_Transmit(&huart3, (uint8_t*)str, strlen(str), 0xFFFF);
  336. }
  337. /**
  338. * @breaf 串口发送命令,有接收数组比较函数
  339. */
  340. uint8_t sendCmd_BT(char *pCmd, char *pRes, uint32_t timeOut, uint8_t sendNum)
  341. {
  342. uint8_t i = 0;
  343. uint32_t time;
  344. for(i = 0; i < sendNum; i++)
  345. {
  346. time = timeOut * 10;
  347. USART_SendString(&huart5, pCmd);
  348. HAL_Delay(30);
  349. printf("------->%s",g_MBA32A_8buf_Down);
  350. //memset(g_MBA32A_8buf_Down,0,50);
  351. while(time--)
  352. {
  353. if(strstr((const char *)g_MBA32A_8buf_Down, pRes) != NULL) // 如果检索到关键词
  354. {
  355. memset(g_MBA32A_8buf_Down,0,50);
  356. return 1;
  357. }
  358. HAL_Delay(100);
  359. }
  360. }
  361. return 0;
  362. }
  363. /**
  364. * @breaf 20字节串口回显
  365. */
  366. void Echo_BT(uint8_t echosize)
  367. {
  368. HAL_UART_Transmit(&huart3,g_MBA32A_8buf_Down, echosize, 0xFFFF);//TTL回显
  369. }
  370. /**
  371. * @breaf 查询蓝牙锁信息帧
  372. */
  373. void lock_searchInfo(void) //蓝牙查询信息帧
  374. {
  375. uint8_t header[2] = {0x66, 0x00};//Jl_lock帧头
  376. uint8_t serchInfo_CMD[] = {0x01, 0x00};//查询信息命令帧
  377. sendCombinedArray(header,sizeof(header),serchInfo_CMD,sizeof(serchInfo_CMD));
  378. Echo_BT(20);
  379. }
  380. /**
  381. * @breaf 蓝牙开锁信息帧
  382. */
  383. void open_lock(BtFrame btframe) //蓝牙开锁信息帧
  384. {
  385. uint8_t header[2] = {0x66, 0x00};//Jl_lock帧头
  386. uint8_t open_CMD[] = {0x02, 0x0C, 0x00,0x00,0x00,0x00, 0x00,0x00,0x00,0x00, \
  387. 0x00,0x00,0x00,0x00, 0x00};//开锁命令帧
  388. uint32_t serialNum = btframe.serialNum;//流水号
  389. open_CMD[2]=(serialNum>>24) & 0xff;
  390. open_CMD[3]=(serialNum>>16) & 0xff;
  391. open_CMD[4]=(serialNum>>8) & 0xff;
  392. open_CMD[5]= serialNum & 0xff;
  393. uint32_t userid = btframe.userId;//用户id
  394. open_CMD[6]=(userid>>24) & 0xff;
  395. open_CMD[7]=(userid>>16) & 0xff;
  396. open_CMD[8]=(userid>>8) & 0xff;
  397. open_CMD[9]= userid & 0xff;
  398. uint32_t ntime = btframe.Ntime;//现在时间
  399. open_CMD[10]=(ntime>>24) & 0xff;
  400. open_CMD[11]=(ntime>>16) & 0xff;
  401. open_CMD[12]=(ntime>>8) & 0xff;
  402. open_CMD[13]= ntime & 0xff;
  403. open_CMD[14] = btframe.Autoseal;//自动施封时间
  404. sendCombinedArray(header,sizeof(header),open_CMD,sizeof(open_CMD));
  405. Echo_BT(20);
  406. refresh=true;
  407. }
  408. /**
  409. * @breaf 蓝牙关锁信息帧
  410. */
  411. void close_lock(BtFrame btframe) //蓝牙关锁信息帧
  412. {
  413. uint8_t header[2] = {0x66, 0x00};//Jl_lock帧头
  414. uint8_t close_CMD[] = {0x03, 0x0B};//关锁命令帧
  415. sendCombinedArray(header,sizeof(header),close_CMD,sizeof(close_CMD));
  416. Echo_BT(20);
  417. refresh=true;
  418. }
  419. /**
  420. * @breaf 写死的蓝牙连接函数
  421. */
  422. void Bt_Connection(void)
  423. {
  424. if(sendCmd_BT("AT+CONN=101000000003\r\n","+CONNECTED:0,101000000003",3,3))
  425. {
  426. if(sendCmd_BT("AT+AUTO_CFG=1\r\n","OK",1,1))
  427. {
  428. printf("自动重连打开\r\n");
  429. }
  430. printf("连接成功!");
  431. menu.current=2;
  432. refresh=true;
  433. /** 后期修改 **/
  434. BT_CONN=true;
  435. L1bd=true;
  436. }
  437. else if(sendCmd_BT("AT+CONN=101000000003\r\n","+CONNECT TIMEOUT",3,5))
  438. {
  439. printf("连接超时!");
  440. MBA32AReset(); //后台复位
  441. }
  442. else
  443. {
  444. printf("连接失败! %s",g_MBA32A_8buf_Down);
  445. MBA32AReset();
  446. }
  447. }
  448. /**
  449. * @breaf 蓝牙扫描MAC切分函数
  450. */
  451. #define JL_LOCK_LENGTH 11
  452. #define DEV_LENGTH 12
  453. //#define DEV_COUNT 4
  454. uint16_t counter_bt = 0;
  455. void split_BtArr(uint8_t* arr, uint16_t len)
  456. {
  457. bool found_JLLock = false;
  458. //uint8_t JLLock[] = {0x01, 0x00, 0x01, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00};
  459. uint8_t JLLock[] = {0x31, 0x00, 0x31, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00};
  460. //uint8_t null[] = {0x31, 0x31, 0x31, 0x00, 0x00};
  461. for (uint16_t i = 0; i < len - JL_LOCK_LENGTH; i++)
  462. {
  463. if (memcmp(&arr[i], JLLock, JL_LOCK_LENGTH) == 0)
  464. {
  465. found_JLLock = true;
  466. }
  467. if (found_JLLock)
  468. {
  469. memcpy(dev1, arr+i , DEV_LENGTH);
  470. printf("d1:%s",dev1);
  471. }
  472. }
  473. }
  474. /**
  475. * @breaf 蓝牙扫描函数
  476. */
  477. void Bt_MacScan(char *pCmd)
  478. {
  479. //"AT+SCAN=1\r\n"
  480. if(menu.current==3)//MAC1搜索
  481. {
  482. USART_SendString(&huart5, pCmd);
  483. HAL_Delay(300);
  484. printf("%s\r\n",g_MBA32A_8buf_Down);
  485. // for (int i = 0; i < u5length; i++) {
  486. // printf("0x%02x ", g_MBA32A_8buf_Down[i]);
  487. // }
  488. //split_BtArr(g_MBA32A_8buf_Down, u5length);
  489. HAL_Delay(1000);
  490. }
  491. // else if(menu.current==4)//MAC2搜索
  492. // {
  493. // USART_SendString(&huart5, pCmd);
  494. // }
  495. // else if(menu.current==5)//MAC3搜索
  496. // {
  497. // USART_SendString(&huart5, pCmd);
  498. // }
  499. // else if(menu.current==6)//MAC4搜索
  500. // {
  501. // USART_SendString(&huart5, pCmd);
  502. // }
  503. }
  504. /**
  505. * @breaf 问询蓝牙锁工作信息函数
  506. */
  507. void workinfo_W(void)
  508. {
  509. if(*g_MBA32A_8buf_Down == NULL)
  510. return;
  511. if(g_MBA32A_8buf_Down[0]==0x66 && g_MBA32A_8buf_Down[1]==0x00 )//未加密帧头(命令字0x01)
  512. {
  513. if(g_MBA32A_8buf_Down[2]==0x01)
  514. {
  515. // bt_dataLength = g_MBA32A_8buf_Down[3];//接收数据长度
  516. // bt_error_num = g_MBA32A_8buf_Down[4]; //错误事件数
  517. // // 将4个字节存入 bt_serial_num流水号
  518. // bt_serial_num |= g_MBA32A_8buf_Down[5]<<24;
  519. // bt_serial_num |= g_MBA32A_8buf_Down[6]<<16;
  520. // bt_serial_num |= g_MBA32A_8buf_Down[7]<<8;
  521. // bt_serial_num |= g_MBA32A_8buf_Down[8];
  522. // bt_battery = g_MBA32A_8buf_Down[9]; //电量百分比
  523. // bt_log_num = g_MBA32A_8buf_Down[10];//记录型事件
  524. bt_lock_machinesta = g_MBA32A_8buf_Down[11]; //电机状态
  525. bt_lock_ropesta = g_MBA32A_8buf_Down[12]; //锁绳状态
  526. // bt_hwver |= g_MBA32A_8buf_Down[13]<<8; //硬件版本号
  527. // bt_hwver |= g_MBA32A_8buf_Down[14];
  528. // bt_sfver |= g_MBA32A_8buf_Down[15]<<8; //软件版本号
  529. // bt_sfver |= g_MBA32A_8buf_Down[16];
  530. }
  531. else if((g_MBA32A_8buf_Down[2]==0x03) && (g_MBA32A_8buf_Down[3]==0x01))//施封(关锁完成)
  532. {
  533. }
  534. else if((g_MBA32A_8buf_Down[2]==0x02) && (g_MBA32A_8buf_Down[3]==0x01))//解封(关锁完成)
  535. {
  536. }
  537. }
  538. }
  539. /**
  540. * @breaf 00-施解封操作(Freertos 工作函数)
  541. */
  542. void open_close_lock(void)
  543. {
  544. if(menu.up == 1 && menu.current == 0x0C && tipsflag!=Abnormal_motor && tipsflag == Default){
  545. btframe.serialNum+=1;
  546. // 施封操作
  547. tipsflag = InProgress;//进行中
  548. close_lock(btframe);
  549. }
  550. else if(menu.up == 0 && menu.current == 0x0C && tipsflag!=Abnormal_motor && tipsflag == Default)
  551. {
  552. btframe.serialNum+=1;
  553. // 解封操作
  554. tipsflag = InProgress;//进行中
  555. open_lock(btframe);
  556. }
  557. }
  558. /**
  559. * @breaf 01-key跳转回按键后current跳转0x0C
  560. */
  561. void Seal_Unseal_Jumptips(void)
  562. {
  563. if (menu.enter == 4)
  564. {
  565. if ((menu.current == 8 || menu.current == 9 || menu.current == 0xa || menu.current == 0xb))
  566. {
  567. if (menu.up == 1)
  568. {
  569. menu.current = 0x0C;
  570. HAL_Delay(300);
  571. }
  572. else if (menu.up == 0)
  573. {
  574. menu.current = 0x0C;
  575. HAL_Delay(300);
  576. }
  577. }
  578. }
  579. }
  580. /**
  581. * @breaf 02-设置锁位状态
  582. * @enter InProgress
  583. */
  584. unsigned char warning[]="WARNING";
  585. unsigned char left[]="<<";
  586. unsigned char right[]=">>";
  587. void tips(void)
  588. {
  589. if (tipsflag == Default) {
  590. // 执行默认操作
  591. } else if (tipsflag == InProgress) {
  592. tipsflag = Default;
  593. OLED_ShowString(37,5,warning,16,0);
  594. OLED_ShowString(13,32, right,16,1);
  595. OLED_ShowString(95,32,left,16,1);
  596. // 执行操作中的操作
  597. OLED_ShowChinese(38,32,22,16,1);//操
  598. OLED_ShowChinese(58,32,23,16,1);//作
  599. OLED_ShowChinese(78,32, 0,16,1);//中
  600. }
  601. else if (tipsflag == Abnormal_motor)
  602. {
  603. OLED_ShowString(20,52,">>",12,1); //显示ASCII字符
  604. OLED_ShowChinese(38,52,17,12,1);//电
  605. OLED_ShowChinese(51,52,18,12,1);//机
  606. OLED_ShowChinese(64,52,19,12,1);//异
  607. OLED_ShowChinese(77,52,20,12,1);//常
  608. OLED_ShowString(92,52,"<<",12,1); //显示ASCII字符
  609. }
  610. else {
  611. // 处理其他情况
  612. }
  613. }
  614. /**
  615. * @breaf 03-扫描锁位状态
  616. */
  617. void Scan_lock_status(void)
  618. {
  619. if(bt_lock_machinesta==0x01 && bt_lock_ropesta==0x00 && g_MBA32A_8buf_Down[0]==0x66)//0x01电机关 0x00锁绳插入
  620. {
  621. tipsflag = Default;
  622. menu.home=0xF000;//关(全部关闭)
  623. }
  624. else if(bt_lock_machinesta==0x00 && bt_lock_ropesta==0x01 && g_MBA32A_8buf_Down[0]==0x66)
  625. {
  626. tipsflag = Default;
  627. menu.home=0x1000;//开(全部开启)
  628. }
  629. else if(bt_lock_ropesta==0x00 && bt_lock_machinesta==0x00 && g_MBA32A_8buf_Down[0]==0x66)
  630. {
  631. tipsflag = Default;
  632. menu.home=0x1000;//开(电机打开,锁绳插入,可按键拔出)
  633. }
  634. else if(bt_lock_ropesta==0x01 && bt_lock_machinesta==0x00 && g_MBA32A_8buf_Down[0]==0x66)
  635. {
  636. tipsflag = Default;
  637. menu.home=0x1000;//开(电机关闭,锁绳拔出)
  638. }
  639. else if(bt_lock_ropesta==0x01 && bt_lock_machinesta==0x01 && g_MBA32A_8buf_Down[0]==0x66)
  640. {
  641. tipsflag = Default;
  642. menu.home=0x1000;//开(电机关闭,锁绳拔出)
  643. }
  644. else if(bt_lock_machinesta == 0x02 && g_MBA32A_8buf_Down[0]==0x66)
  645. {
  646. tipsflag = Abnormal_motor;
  647. }
  648. }