mba32a.c 15 KB

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