soft_seed_device.c 42 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941942943944945946947948949950951952953954955956957958959960961962963964965966967968969970971972973974975976977978979980981982983984985986987988989990991992993994995996997998999100010011002100310041005100610071008100910101011101210131014101510161017101810191020102110221023102410251026102710281029103010311032103310341035103610371038103910401041104210431044104510461047104810491050105110521053105410551056105710581059106010611062106310641065106610671068106910701071107210731074107510761077107810791080108110821083108410851086108710881089109010911092109310941095109610971098109911001101110211031104110511061107110811091110111111121113111411151116111711181119112011211122112311241125112611271128112911301131113211331134113511361137113811391140114111421143114411451146114711481149115011511152115311541155115611571158115911601161116211631164116511661167116811691170117111721173117411751176117711781179118011811182118311841185118611871188118911901191119211931194119511961197119811991200120112021203120412051206120712081209121012111212121312141215121612171218121912201221122212231224122512261227122812291230123112321233123412351236123712381239124012411242124312441245124612471248
  1. #include "soft_seed_device.h"
  2. #include "common.h"
  3. #include "string.h"
  4. #include "soft_p_2_c.h"
  5. #include "soft_eft.h"
  6. #include "soft_flow.h"
  7. #include "soft_water_device.h"
  8. #include "soft_uart.h"
  9. #include "soft_terrain.h"
  10. #include "soft_obstacle.h"
  11. #include "soft_bms.h"
  12. #include "soft_okcell.h"
  13. #include "soft_version.h"
  14. #include "math.h"
  15. #include "qingxie_bms.h"
  16. weight weight_vkinfo;
  17. seed seed_vkinfo;
  18. send_seed_device seed_dev;
  19. Weight_cal weight_order;
  20. bool weight_factory_cal_flag = false;
  21. /**
  22. * @file Weight_recieved_hookfuction
  23. * @brief VK协议称重传感器
  24. * @param none
  25. * @details
  26. * @author Zhang Sir
  27. **/
  28. void Weight_recieved_hookfuction(uint32_t CanID, uint8_t data[], uint8_t len)
  29. {
  30. switch (CanID)
  31. {
  32. //称重传感器
  33. case 0x81320:
  34. memcpy(&weight_vkinfo.sensor_status,&data[0],8);
  35. if(weight_vkinfo.weight < 0)
  36. {
  37. weight_vkinfo.weight = abs(weight_vkinfo.weight);
  38. }
  39. Dev.Weight.facid = FAC_VK;
  40. Dev.Weight_Link.connect_status = COMP_NORMAL;
  41. Dev.Weight_Link.recv_time = HAL_GetTick();
  42. break;
  43. //称重传感器设置回馈
  44. case 0x81322:
  45. switch (data[0])
  46. {
  47. //去皮校准ack
  48. case 0xf1:
  49. pmu_set_ack(_MSGID_SET,25,Cal_Remove_Peel,0);
  50. break;
  51. //称重校准ack
  52. case 0xf2:
  53. pmu_set_ack(_MSGID_SET,25,Cal_Weight,0);
  54. break;
  55. //恢复出厂设置ack
  56. case 0xf4:
  57. pmu_set_ack(_MSGID_SET,MSGID_SET_WEIGHT_RESETK,0,0);
  58. break;
  59. case 0xf5:
  60. break;
  61. case 0xf6:
  62. {
  63. char ver_buf[10] = {0};
  64. int ver_temp32 = 0;
  65. memcpy(&ver_temp32,&data[1],4);
  66. Int2String(ver_temp32,&ver_buf[2],6);
  67. ver_buf[0] = '0';
  68. ver_buf[1] = data[7] + '0';
  69. regist_dev_info(&dev_weight,DEVICE_WEIGHT,false,NULL,0,(char *)&ver_buf[0],8,NULL,0,"weight",7);
  70. break;
  71. }
  72. //厂家编号
  73. case 0xf7:
  74. if(data[1] == 'Q' && data[2] == 'F') //0x 51 46
  75. {
  76. weight_vkinfo.serial_num = 3;
  77. Dev.Weight.facid = FAC_QIFEI;
  78. }
  79. else
  80. {
  81. weight_vkinfo.serial_num = 0;
  82. }
  83. weight_init_vk.step.fac_num_flag = 0;
  84. weight_init_count = 10;
  85. //memcpy(&weight_vkinfo.serial_num, &data[1],4);
  86. break;
  87. //读取传感器K值
  88. case 0xe1:
  89. if(data[7] == 0x1)
  90. {
  91. memcpy(&weight_vkinfo.senor_k[0],&data[1],4);
  92. }
  93. else if(data[7] == 0x2)
  94. {
  95. memcpy(&weight_vkinfo.senor_k[2],&data[1],4);
  96. }
  97. weight_init_vk.step.read_k_flag = 0;
  98. break;
  99. //设置传感器K值ack
  100. case 0xe2:
  101. pmu_set_ack(_MSGID_SET,Cal_Set_Sensor_K,0,0);
  102. weight_vkinfo.senor_k[data[7]] = data[1] + (data[2] << 8);
  103. break;
  104. //称重传感器模式读取
  105. case 0xe3:
  106. weight_vkinfo.mode = data[1];
  107. weight_init_vk.step.weight_mode_flag = 0;
  108. weight_init_count = 10;
  109. break;
  110. //称重传感器模式ack
  111. case 0xe4:
  112. pmu_set_ack(_MSGID_SET,Cal_Set_Sensor_Mode,0,0);
  113. weight_vkinfo.mode = data[1];
  114. break;
  115. //最大下药率读取
  116. case 0xe5:
  117. memcpy(&weight_vkinfo.dose_rate,&data[1],2);
  118. weight_init_vk.step.dose_rate_flag = 0;
  119. weight_init_count = 10;
  120. break;
  121. //最高下药率ack
  122. case 0xe6:
  123. pmu_set_ack(_MSGID_EFT_CON,Cal_Set_Doserate,0,0);
  124. weight_vkinfo.dose_rate = data[1] + (data[2] << 8);
  125. break;
  126. case 0xe7:
  127. pmu_set_ack(_MSGID_EFT_CON,MSGID_SET_WEIGHTFAC_CAL,0,0);
  128. break;
  129. default:
  130. break;
  131. }
  132. break;
  133. //播撒器
  134. case 0x81323:
  135. memcpy(&seed_vkinfo,&data[0],7);
  136. Dev.Seed_Link.connect_status = COMP_NORMAL;
  137. Dev.Seed_Link.recv_time = HAL_GetTick();
  138. break;
  139. //播撒器回馈
  140. case 0x81325:
  141. switch (data[0])
  142. {
  143. case 0xf5:
  144. break;
  145. case 0xf6:
  146. break;
  147. case 0xf7:
  148. if(data[1] == 'Q' && data[2] == 'F')
  149. {
  150. seed_vkinfo.serial_num = 3;
  151. Dev.Seed.facid = FAC_QIFEI;
  152. }
  153. break;
  154. default:
  155. break;
  156. }
  157. break;
  158. case 0x81326:
  159. memcpy(&weight_vkinfo.Single_sensor[0],&data[0],8);
  160. break;
  161. default:
  162. break;
  163. }
  164. }
  165. //上电初始化发送的参数
  166. //device_type : 1 称重
  167. // : 2 播撒
  168. /**
  169. * @file seed_init_send_info
  170. * @brief 上电初始化发送的参数
  171. * @param 1 称重
  172. 2 播撒
  173. * @details
  174. * @author Zhang Sir
  175. **/
  176. Dev_weight_init weight_init_eft = {.step.read_k_flag = 1};
  177. Dev_weight_init weight_init_vk = {.step.dose_rate_flag = 1,
  178. .step.weight_mode_flag = 1,
  179. .step.read_k_flag = 1,
  180. .step.verison = 1,
  181. .step.fac_num_flag = 1};
  182. Dev_seed_init seed_init;
  183. bool recv_fmu_seed_info = false;
  184. uint8_t weight_init_count = 10;
  185. void seed_init_send_info(uint8_t device_type,char *factory)
  186. {
  187. uint8_t vk_canbuf[8] = {0,0,0,0,0,0XFE,0XFE,0};
  188. static uint8_t spread_init_count = 10;
  189. int vk_can_id = 0;
  190. if(strcmp(factory,"VK") == 0)
  191. {
  192. switch (device_type)
  193. {
  194. //称重
  195. case WEIGHT_DEVICE:
  196. vk_can_id = 0x81321;
  197. if(weight_init_vk.status != 0)
  198. {
  199. if(weight_init_vk.step.read_k_flag != 0)
  200. {
  201. vk_canbuf[0] = 0xE1;
  202. }
  203. else if(weight_init_vk.step.fac_num_flag != 0 && weight_init_count > 0)
  204. {
  205. vk_canbuf[0] = 0xF7;
  206. weight_init_count--;
  207. if(weight_init_count == 0)
  208. {
  209. weight_init_count = 10;
  210. weight_init_vk.step.fac_num_flag = 0;
  211. }
  212. }
  213. else if(weight_init_vk.step.verison != 0 && weight_init_count > 0)
  214. {
  215. vk_canbuf[0] = 0xF6;
  216. weight_init_count--;
  217. if(weight_init_count == 0)
  218. {
  219. weight_init_count = 10;
  220. weight_init_vk.step.verison = 0;
  221. }
  222. }
  223. else if (weight_init_vk.step.weight_mode_flag != 0 && weight_init_count > 0)
  224. {
  225. vk_canbuf[0] = 0xE3;
  226. weight_init_count--;
  227. if(weight_init_count == 0)
  228. {
  229. weight_init_count = 10;
  230. weight_init_vk.step.weight_mode_flag = 0;
  231. }
  232. }
  233. else if (weight_init_vk.step.dose_rate_flag != 0 && weight_init_count > 0)
  234. {
  235. vk_canbuf[0] = 0xE5;
  236. weight_init_count--;
  237. if(weight_init_count == 0)
  238. {
  239. weight_init_count = 10;
  240. weight_init_vk.step.dose_rate_flag = 0;
  241. }
  242. }
  243. // else if (weight_init_vk.step.dose_rate_flag != 0) //序列号和固件版本
  244. // {
  245. // vk_canbuf[0] = 0xf6;;
  246. // }
  247. // else if (weight_init_vk.step.dose_rate_flag != 0)
  248. // {
  249. // vk_canbuf[0] = 0xf5;
  250. // }
  251. can_send_msg_normal((unsigned char *)&vk_canbuf, 8, vk_can_id);
  252. }
  253. break;
  254. //播撒
  255. case SEED_DEVICE:
  256. vk_can_id = 0x81324;
  257. if(spread_init_count > 0)
  258. {
  259. //获取厂家信息
  260. vk_canbuf[0] = 0xf7;
  261. spread_init_count--;
  262. can_send_msg_normal((unsigned char *)&vk_canbuf, 8, vk_can_id);
  263. }
  264. break;
  265. default:
  266. break;
  267. }
  268. }
  269. else if (strcmp(factory,"EFT") == 0)
  270. {
  271. vk_can_id = SEND_EFT_INFO;
  272. switch (device_type)
  273. {
  274. case WEIGHT_DEVICE:
  275. if(weight_init_eft.status != 0 && eft_weightDev_priority == false)
  276. {
  277. if(weight_init_eft.step.read_k_flag != 0)
  278. {
  279. vk_canbuf[0] = 0xFD;
  280. vk_canbuf[5] = 0xf1;
  281. vk_canbuf[6] = 0xf3;
  282. }
  283. can_send_msg_normal((unsigned char *)&vk_canbuf, 8, vk_can_id);
  284. }
  285. break;
  286. case SEED_DEVICE:
  287. if(seed_init.status != 0)
  288. {
  289. if(seed_init.step.sn_flag != 0)
  290. {
  291. }
  292. else if(seed_init.step.version_flag != 0)
  293. {
  294. }
  295. //can_send_msg_normal((unsigned char *)&vk_canbuf, 8, vk_can_id);
  296. }
  297. break;
  298. default:
  299. break;
  300. }
  301. }
  302. }
  303. /**
  304. * @file Set_Seed_Weight_Par
  305. * @brief 设置称重播撒参数
  306. * @param 1 称重
  307. 2 播撒
  308. * @details
  309. * @author Zhang Sir
  310. **/
  311. void Set_Seed_Weight_Par(uint8_t device_type,char *factory)
  312. {
  313. uint8_t can_buf[8] = {0};
  314. if(strcmp(factory,"VK") == 0)
  315. {
  316. switch (device_type)
  317. {
  318. case WEIGHT_DEVICE:
  319. if(weight_order.type != 0)
  320. {
  321. can_buf[1] = 0x00; //D1 - D4
  322. can_buf[2] = 0x00;
  323. can_buf[3] = 0x00;
  324. can_buf[4] = 0x00;
  325. can_buf[5] = 0xFE;
  326. can_buf[6] = 0xFE;
  327. can_buf[7] = 0x00; //D5
  328. switch (weight_order.type)
  329. {
  330. //去皮校准
  331. case Weight_Peer:
  332. can_buf[0] = 0xF1;
  333. break;
  334. //重量校准
  335. case Weight_Kg:
  336. {
  337. int weight_kgCal = 0;
  338. weight_kgCal = weight_order.order_con2 + weight_order.order_con3 * 65536;
  339. can_buf[0] = 0xF2;
  340. memcpy(&can_buf[1], &weight_kgCal,4);
  341. }
  342. break;
  343. case Weight_Reserve:
  344. break;
  345. //恢复出厂设置
  346. case Seed_Bcak:
  347. can_buf[0] = 0xF4;
  348. break;
  349. //称重传感器K值
  350. case Weight_Set_K:
  351. can_buf[0] = 0xE2;
  352. can_buf[1] = weight_order.order_con2 & 0xff;
  353. can_buf[2] = (weight_order.order_con2 >> 8) & 0xff;
  354. can_buf[7] = weight_order.order_con1 - 1; //VK协议传感器编号是0-3
  355. break;
  356. //称重传感器模式
  357. case Weight_Mode:
  358. can_buf[0] = 0xE4;
  359. can_buf[1] = weight_order.order_con1 & 0xff;
  360. break;
  361. //最高下药率
  362. case Weight_Drug_Rate:
  363. can_buf[0] = 0xE6;
  364. can_buf[1] = weight_order.order_con1 & 0xff;
  365. can_buf[2] = (weight_order.order_con1 >> 8) & 0xff;
  366. break;
  367. case Weight_Bcak:
  368. can_buf[0] = 0xF4;
  369. break;
  370. case Weight_Fac_cal:
  371. can_buf[0] = 0xE7;
  372. break;
  373. default:
  374. break;
  375. }
  376. can_send_msg_normal((unsigned char *)&can_buf, 8, 0x81321);
  377. weight_order.type = 0;
  378. }
  379. break;
  380. case SEED_DEVICE:
  381. //更换信号输出方式 0 PWM 1 CAN
  382. if((seed_vkinfo.output != seed_output_mode) && recv_fmu_seed_info == true)
  383. {
  384. can_buf[0] = 0xF2;
  385. can_buf[1] = seed_output_mode;
  386. can_buf[2] = 0x00;
  387. can_buf[3] = 0x00;
  388. can_buf[4] = 0x00;
  389. can_buf[5] = 0xFE;
  390. can_buf[6] = 0xFE;
  391. can_buf[7] = 0;
  392. can_send_msg_normal((unsigned char *)&can_buf, 8, 0x81324);
  393. }
  394. break;
  395. default:
  396. break;
  397. }
  398. }
  399. else if (strcmp(factory,"EFT") == 0)
  400. {
  401. switch (device_type)
  402. {
  403. case SEED_DEVICE:
  404. //更换信号输出方式 0 PWM 1 CAN
  405. if((eft_info.can_enable != seed_output_mode) && recv_fmu_seed_info == true)
  406. {
  407. can_buf[0] = 0xF2;
  408. can_buf[1] = seed_output_mode;
  409. can_buf[2] = 0x00;
  410. can_buf[3] = 0x00;
  411. can_buf[4] = 0x00;
  412. can_buf[5] = 0xf1;
  413. can_buf[6] = 0xf3;
  414. can_buf[7] = 0;
  415. can_send_msg_normal((unsigned char *)&can_buf, 8, SEND_EFT_INFO);
  416. }
  417. break;
  418. case WEIGHT_DEVICE:
  419. if(eft_weightDev_priority == true)
  420. {
  421. can_buf[1] = 0x00; //D1 - D4
  422. can_buf[2] = 0x00;
  423. can_buf[3] = 0x00;
  424. can_buf[4] = 0x00;
  425. can_buf[5] = 0xF1;
  426. can_buf[6] = 0xF3;
  427. can_buf[7] = 0x00; //D5
  428. switch (weight_order.type)
  429. {
  430. //去皮校准
  431. case Weight_Peer:
  432. can_buf[0] = 0xE1;
  433. break;
  434. //重量校准
  435. case Weight_Kg:
  436. can_buf[0] = 0xE2;
  437. memcpy(&can_buf[1], &weight_order.order_con2,2);
  438. break;
  439. case Weight_Reserve:
  440. break;
  441. //恢复出厂设置
  442. case Seed_Bcak:
  443. can_buf[0] = 0xF4;
  444. break;
  445. //称重传感器K值
  446. case Weight_Set_K:
  447. z70weight.buf[0] = 0xE3;
  448. if(weight_order.order_con1 == 1)
  449. z70weight.info.k1 = weight_order.order_con2;
  450. else if(weight_order.order_con1 == 2)
  451. z70weight.info.k2 = weight_order.order_con2;
  452. else if(weight_order.order_con1 == 3)
  453. z70weight.info.k3 = weight_order.order_con2;
  454. else if(weight_order.order_con1 == 4)
  455. z70weight.info.k4 = weight_order.order_con2;
  456. memcpy(&can_buf,&z70weight.buf[0],8);
  457. break;
  458. default:
  459. break;
  460. }
  461. can_send_msg_normal((unsigned char *)&can_buf, 8, 0x88BB);
  462. weight_order.type = 0;
  463. }
  464. else
  465. {
  466. if(weight_order.type != 0)
  467. {
  468. can_buf[1] = 0x00;
  469. can_buf[2] = 0x00;
  470. can_buf[3] = 0x00;
  471. can_buf[4] = 0x00;
  472. can_buf[5] = 0xf1;
  473. can_buf[6] = 0xf3;
  474. can_buf[7] = 0;
  475. switch (weight_order.type)
  476. {
  477. case Weight_Peer:
  478. can_buf[0] = 0xF6;
  479. break;
  480. case Weight_Kg:
  481. can_buf[0] = 0xF7;
  482. can_buf[1] = (weight_order.order_con2 >> 8) & 0xff;
  483. can_buf[2] = weight_order.order_con2 & 0xff;
  484. break;
  485. case Weight_Reserve:
  486. break;
  487. case Seed_Bcak:
  488. can_buf[0] = 0xF5;
  489. break;
  490. case Weight_Set_K:
  491. can_buf[0] = 0xFC;
  492. can_buf[1] = eft_info.seed_k[0];
  493. can_buf[2] = eft_info.seed_k[1];
  494. can_buf[3] = eft_info.seed_k[2];
  495. can_buf[weight_order.order_con1] = weight_order.order_con2 & 0xff;
  496. break;
  497. default:
  498. break;
  499. }
  500. can_send_msg_normal((unsigned char *)&can_buf, 8, SEND_EFT_INFO);
  501. weight_order.type = 0;
  502. }
  503. }
  504. break;
  505. default:
  506. break;
  507. }
  508. }
  509. }
  510. /**
  511. * @file can_sendmsg_VK
  512. * @brief 播撒常发数据包
  513. * @param
  514. * @details
  515. * @author Zhang Sir
  516. **/
  517. void can_sendmsg_VK(void)
  518. {
  519. static uint8_t vk_count = 0;
  520. uint8_t vk_canbuf[8] = {0};
  521. if(Dev.Weight_Link.connect_status == COMP_NORMAL && (Dev.Weight.facid == FAC_VK ||
  522. Dev.Weight.facid == FAC_QIFEI) && HAL_GetTick() > 3000)
  523. {
  524. seed_init_send_info(WEIGHT_DEVICE,"VK");
  525. Set_Seed_Weight_Par(WEIGHT_DEVICE,"VK");
  526. }
  527. if(Dev.Seed_Link.connect_status == COMP_NORMAL && (Dev.Seed.facid == FAC_VK ||
  528. Dev.Seed.facid == FAC_QIFEI) && HAL_GetTick() > 2000)
  529. {
  530. seed_init_send_info(SEED_DEVICE,"VK");
  531. Set_Seed_Weight_Par(SEED_DEVICE,"VK");
  532. if(seed_output_mode == 1 )
  533. {
  534. if(HAL_GetTick() < 5000) //初始化自检
  535. {
  536. tppwm_value = 1000;
  537. sow_rotate_value = 1000;
  538. }
  539. //发送转速 和阀门
  540. vk_canbuf[0] = 0xf1;
  541. vk_canbuf[1] = tppwm_value & 0xff;
  542. vk_canbuf[2] = (tppwm_value >> 8) & 0xff;
  543. vk_canbuf[3] = sow_rotate_value & 0xff;
  544. vk_canbuf[4] = (sow_rotate_value >> 8) & 0xff;
  545. vk_canbuf[5] = 0xfe;
  546. vk_canbuf[6] = 0xfe;
  547. vk_canbuf[7] = vk_count;
  548. vk_count++;
  549. can_send_msg_normal((unsigned char *)&vk_canbuf, 8, 0x81324);
  550. }
  551. if(vk_count >= 255)
  552. {
  553. vk_count = 0;
  554. }
  555. }
  556. }
  557. Device_type Dev;
  558. comp_status seed_dev_link_status = COMP_NOEXIST;
  559. void check_dev_type_link(void )
  560. {
  561. int error_time = 0;
  562. error_time = HAL_GetTick() - Dev.Seed_Link.recv_time;
  563. if(Dev.Seed_Link.connect_status == COMP_NORMAL && error_time > 5000)
  564. {
  565. Dev.Seed_Link.connect_status = COMP_LOST;
  566. memset(&Dev.Seed.facid, 0, 7);
  567. }
  568. error_time = HAL_GetTick() - Dev.Weight_Link.recv_time;
  569. if(Dev.Pump_Link.connect_status == COMP_NORMAL && error_time > 5000)
  570. {
  571. Dev.Pump_Link.connect_status = COMP_LOST;
  572. memset(&Dev.Weight.facid, 0, 16);
  573. }
  574. error_time = HAL_GetTick() - Dev.Pump_Link.recv_time;
  575. if(Dev.Pump_Link.connect_status == COMP_NORMAL && error_time > 5000)
  576. {
  577. Dev.Pump_Link.connect_status = COMP_LOST;
  578. memset(&Dev.Pump.facid, 0, 11);
  579. }
  580. //
  581. error_time = HAL_GetTick() - Dev.Nozzle_Link.recv_time;
  582. if(Dev.Nozzle_Link.connect_status == COMP_NORMAL && error_time > 5000)
  583. {
  584. Dev.Nozzle_Link.connect_status = COMP_LOST;
  585. memset(&Dev.Nozzle.facid, 0, 11);
  586. }
  587. //
  588. error_time = HAL_GetTick() - Dev.Arm_Link.recv_time;
  589. if(Dev.Arm_Link.connect_status == COMP_NORMAL && error_time > 5000)
  590. {
  591. Dev.Arm_Link.connect_status = COMP_LOST;
  592. memset(&Dev.Arm.facid, 0, 2);
  593. }
  594. }
  595. void DM_obs_test( void )
  596. {
  597. if(((Dev.Part_Fradar_Link.connect_status != COMP_NORMAL) || (Dev.Part_radarF.facid != FAC_DM_RF_4D)) &&
  598. ((Dev.Part_Bradar_Link.connect_status != COMP_NORMAL) || (Dev.Part_radarB.facid != FAC_DM_RB_4D)))
  599. return;
  600. static uint32_t time_50hz = 0;
  601. static uint32_t time_49hz = 0;
  602. static uint32_t time_48hz = 0;
  603. static uint32_t time_47hz = 0;
  604. uint8_t can_buf[8] = {0};
  605. if(Check_Timer_Ready(&time_50hz,20))
  606. {
  607. memcpy(&can_buf[0],&planep.QuaterQ0,4);
  608. memcpy(&can_buf[4],&planep.QuaterQ1,4);
  609. can_send_msg_normal((unsigned char *)&can_buf, 8, 0x2345);
  610. }
  611. if(Check_Timer_Ready(&time_49hz,20))
  612. {
  613. memcpy(&can_buf[0],&planep.QuaterQ2,4);
  614. memcpy(&can_buf[4],&planep.QuaterQ3,4);
  615. can_send_msg_normal((unsigned char *)&can_buf, 8, 0x2346);
  616. }
  617. if(Check_Timer_Ready(&time_48hz,19))
  618. {
  619. memcpy(&can_buf[0],&planep.pos_x,4);
  620. memcpy(&can_buf[4],&planep.pos_y,4);
  621. can_send_msg_normal((unsigned char *)&can_buf, 8, 0x2347);
  622. }
  623. if(Check_Timer_Ready(&time_47hz,19))
  624. {
  625. memcpy(&can_buf[0],&planep.pos_z,4);
  626. memcpy(&can_buf[4],&planep.alt,2);
  627. static uint16_t fmu_lock_status = 0;
  628. if(planep.lock_status == 4)
  629. {
  630. fmu_lock_status = 1;
  631. }
  632. else
  633. {
  634. fmu_lock_status = 0;
  635. }
  636. memcpy(&can_buf[6],&fmu_lock_status,2);
  637. can_send_msg_normal((unsigned char *)&can_buf, 8, 0x2348);
  638. }
  639. }
  640. /**
  641. * @file update_device_type_data
  642. * @brief 更新设备信息
  643. * @param
  644. * @details
  645. * @author Zhang Sir
  646. **/
  647. void update_device_type_data(void)
  648. {
  649. //50hz更新 5hz发送
  650. static uint32_t time_1hz = 0;
  651. static uint32_t time_330hz = 0;
  652. static uint32_t time_5hz = 0;
  653. static uint32_t time_50hz = 0;
  654. if(Check_Timer_Ready(&time_1hz,_1_HZ_))
  655. {
  656. Check_dev_link(&Dev.Seed_Link,5000,(char *)&Dev.Seed.facid,sizeof(Seed_info));
  657. Check_dev_link(&Dev.Weight_Link,5000,(char *)&Dev.Weight.facid,sizeof(Weight_info));
  658. Check_dev_link(&Dev.Pump_Link,5000,(char *)&Dev.Pump.facid,sizeof(Pump_info));
  659. Check_dev_link(&Dev.Nozzle_Link,5000,(char *)&Dev.Nozzle.facid,sizeof(Nozzle_info));
  660. Check_dev_link(&Dev.Arm_Link,5000,(char *)&Dev.Arm.facid,sizeof(Arm_info));
  661. Check_dev_link(&Dev.Flow_Link1,5000,(char *)&Dev.Flow.facid,sizeof(Flow_info));
  662. Check_dev_link(&Dev.Checklow_Link,5000,(char *)&Dev.Checklow.facid,sizeof(CheckLow_info));
  663. Check_dev_link(&Distributor_Link,5000,(char *)&distributor.arm_sensor1,sizeof(distributor_info));
  664. Check_dev_link(&Dev.Current_Link,5000,(char *)&Dev.Current.facid,sizeof(Current_info));
  665. Check_dev_link(&Dev.Lackloss_Link,5000,NULL,0);
  666. Check_dev_link(&Dev.L_pump1_Link,5000,(char *)&Dev.L_pump1.facid,sizeof(Linear_pump_info));
  667. Check_dev_link(&Dev.L_pump2_Link,5000,(char *)&Dev.L_pump2.facid,sizeof(Linear_pump_info));
  668. check_radar_link_status();
  669. }
  670. if(Check_Timer_Ready(&time_330hz,330))
  671. {
  672. //EFT播撒称重
  673. can_sendmsg_eft();
  674. }
  675. if(Check_Timer_Ready(&time_5hz,_5_HZ_))
  676. {
  677. //VK播撒称重
  678. can_sendmsg_VK();
  679. //流量计
  680. can_sendmsg_flow();
  681. //分电板
  682. Can_sendmsg_to_distributor();
  683. }
  684. if(Check_Timer_Ready(&time_50hz,_50_HZ_))
  685. {
  686. //好盈电调水泵
  687. Hobbywing_esc_func();
  688. //播撒器
  689. if(Dev.Seed_Link.connect_status == COMP_NORMAL)
  690. {
  691. switch (Dev.Seed.facid)
  692. {
  693. case FAC_VK:
  694. Dev.Seed.angle = 0;
  695. Dev.Seed.speed = 0;
  696. Dev.Seed.caplow = 0;
  697. Dev.Seed.warn = 0;
  698. break;
  699. case FAC_EFT:
  700. Dev.Seed.angle = eft_info.valve_angel;
  701. Dev.Seed.speed = eft_info.speed_rpm * 10;
  702. Dev.Seed.caplow = eft_info.warn_status & 0x1;
  703. Dev.Seed.warn = eft_info.warn_status >> 1;
  704. break;
  705. case FAC_QIFEI:
  706. Dev.Seed.angle = 0;
  707. Dev.Seed.speed = 0;
  708. Dev.Seed.caplow = 0;
  709. Dev.Seed.warn = 0;//weight_vkinfo.warn_status;
  710. break;
  711. default:
  712. break;
  713. }
  714. }
  715. //称重
  716. if(Dev.Weight_Link.connect_status == COMP_NORMAL)
  717. {
  718. switch (Dev.Weight.facid)
  719. {
  720. case FAC_VK:
  721. Dev.Weight.mode = weight_vkinfo.mode;
  722. Dev.Weight.kg = weight_vkinfo.weight / 10;
  723. Dev.Weight.rate = weight_vkinfo.weight_rate;
  724. Dev.Weight.k1 = weight_vkinfo.senor_k[0];
  725. Dev.Weight.k2 = weight_vkinfo.senor_k[1];
  726. Dev.Weight.k3 = weight_vkinfo.senor_k[2];
  727. Dev.Weight.k4 = weight_vkinfo.senor_k[3];
  728. Dev.Weight.warn = weight_vkinfo.warn_status;
  729. Dev.Weight.single_sensor[0] = weight_vkinfo.Single_sensor[0];
  730. Dev.Weight.single_sensor[1] = weight_vkinfo.Single_sensor[1];
  731. Dev.Weight.single_sensor[2] = weight_vkinfo.Single_sensor[2];
  732. Dev.Weight.single_sensor[3] = weight_vkinfo.Single_sensor[3];
  733. break;
  734. case FAC_EFT:
  735. Dev.Weight.mode = 0;
  736. Dev.Weight.kg = eft_info.weight / 10;
  737. Dev.Weight.rate = 0;
  738. Dev.Weight.k1 = eft_info.seed_k[0];
  739. Dev.Weight.k2 = eft_info.seed_k[1];
  740. Dev.Weight.k3 = eft_info.seed_k[2];
  741. Dev.Weight.k4 = 0;
  742. Dev.Weight.warn = eft_info.watering_warn_status >> 4 & 0xff;
  743. break;
  744. case FAC_LIFTWEIGHT:
  745. Dev.Weight.mode = 0;
  746. Dev.Weight.kg = eft_info.weight;
  747. Dev.Weight.rate = 0;
  748. Dev.Weight.k1 = eft_info.seed_k[0];
  749. Dev.Weight.k2 = eft_info.seed_k[1];
  750. Dev.Weight.k3 = eft_info.seed_k[2];
  751. Dev.Weight.k4 = 0;
  752. Dev.Weight.warn = (LiftingWeight_warning << 8) & 0xff00;
  753. break;
  754. case FAC_QIFEI:
  755. Dev.Weight.mode = weight_vkinfo.mode;
  756. Dev.Weight.kg = weight_vkinfo.weight / 10;
  757. Dev.Weight.rate = weight_vkinfo.weight_rate;
  758. Dev.Weight.k1 = weight_vkinfo.senor_k[0];
  759. Dev.Weight.k2 = weight_vkinfo.senor_k[1];
  760. Dev.Weight.k3 = weight_vkinfo.senor_k[2];
  761. Dev.Weight.k4 = weight_vkinfo.senor_k[3];
  762. Dev.Weight.warn = weight_vkinfo.warn_status;
  763. Dev.Weight.dose_rate = weight_vkinfo.dose_rate;
  764. break;
  765. default:
  766. break;
  767. }
  768. }
  769. //水泵
  770. if(Dev.Pump_Link.connect_status == COMP_NORMAL)
  771. {
  772. switch (Dev.Pump.facid)
  773. {
  774. case FAC_VK:
  775. break;
  776. case FAC_EFT:
  777. Dev.Pump.rpm1 = eft_info.pump1_rpm * 60;
  778. Dev.Pump.rpm2 = eft_info.pump2_rpm * 60;
  779. Dev.Pump.rpm3 = 0;
  780. Dev.Pump.rpm4 = 0;
  781. if( (eft_info.watering_warn_status & 0x3) != 0)
  782. {
  783. Dev.Pump.warn = (eft_info.watering_warn_status & 0x3) + (eft_info.watering_warn_status & 0xf0);
  784. }
  785. else if((eft_info.watering_warn_status & 0x3) == 0)
  786. {
  787. Dev.Pump.warn = 0;
  788. }
  789. Dev.Pump.warn = 0; //屏蔽报警
  790. break;
  791. // case FAC_HW_ESC:
  792. // Dev.Pump.rpm1 = EscMsg[1].motorRPM;
  793. // Dev.Pump.rpm2 = EscMsg[2].motorRPM;
  794. // Dev.Pump.rpm3 = 0;
  795. // Dev.Pump.rpm4 = 0;
  796. // Dev.Pump.warn = EscMsg[1].warn_flag;
  797. // break;
  798. default:
  799. break;
  800. }
  801. }
  802. //离心喷头
  803. if(Dev.Nozzle_Link.connect_status == COMP_NORMAL)
  804. {
  805. switch (Dev.Nozzle.facid)
  806. {
  807. case FAC_VK:
  808. break;
  809. case FAC_EFT:
  810. Dev.Nozzle.rpm1 = eft_info.cent1_rpm * 60;
  811. Dev.Nozzle.rpm2 = eft_info.cent2_rpm * 60;
  812. Dev.Nozzle.rpm3 = 0;
  813. Dev.Nozzle.rpm4 = 0;
  814. if( (eft_info.watering_warn_status & 0xc) != 0)
  815. {
  816. Dev.Nozzle.warn = ((eft_info.watering_warn_status >> 2) & 0x3) + (eft_info.watering_warn_status & 0xf0);
  817. }
  818. else if((eft_info.watering_warn_status & 0xc) == 0)
  819. {
  820. Dev.Nozzle.warn = 0;
  821. }
  822. Dev.Nozzle.warn = 0; //屏蔽报警
  823. break;
  824. default:
  825. break;
  826. }
  827. }
  828. //机臂传感器
  829. if(Dev.Arm_Link.connect_status == COMP_NORMAL)
  830. {
  831. switch (Dev.Arm.facid)
  832. {
  833. case FAC_VK:
  834. break;
  835. case FAC_EFT:
  836. Dev.Arm.status = eft_info.enginearm_lock;
  837. break;
  838. case FAC_VK_ALLINONE:
  839. Dev.Arm.status = (((uint8_t)HAL_GPIO_ReadPin( GPIOB, GPIO_PIN_12 ) & 0x1) << 3) | \
  840. (((uint8_t)HAL_GPIO_ReadPin( GPIOB, GPIO_PIN_13 ) & 0x1) << 2) | \
  841. (((uint8_t)HAL_GPIO_ReadPin( GPIOB, GPIO_PIN_14 ) & 0x1)) | \
  842. (((uint8_t)HAL_GPIO_ReadPin( GPIOB, GPIO_PIN_15 ) & 0x1) << 1);
  843. break;
  844. default:
  845. break;
  846. }
  847. }
  848. //线性水泵
  849. if(Dev.L_pump1_Link.connect_status == COMP_NORMAL)
  850. {
  851. switch (Dev.L_pump1.facid)
  852. {
  853. case FAC_VK:
  854. break;
  855. case FAC_EFT:
  856. Dev.L_pump1.warn = Lpump1.error_status;
  857. Dev.L_pump1.rpm = Lpump1.rpm;
  858. break;
  859. case FAC_HW_ESC:
  860. Dev.L_pump1.warn = EscMsg[1].warn_flag;
  861. Dev.L_pump1.rpm = EscMsg[1].motorRPM;
  862. break;
  863. default:
  864. break;
  865. }
  866. }
  867. if(Dev.L_pump2_Link.connect_status == COMP_NORMAL)
  868. {
  869. switch (Dev.L_pump2.facid)
  870. {
  871. case FAC_VK:
  872. break;
  873. case FAC_EFT:
  874. Dev.L_pump2.warn = Lpump2.error_status;
  875. Dev.L_pump2.rpm = Lpump2.rpm;
  876. break;
  877. case FAC_HW_ESC:
  878. Dev.L_pump2.warn = EscMsg[2].warn_flag;
  879. Dev.L_pump2.rpm = EscMsg[2].motorRPM;
  880. break;
  881. default:
  882. break;
  883. }
  884. }
  885. // if(Dev.L_pump2_Link.connect_status == COMP_NORMAL)
  886. // {
  887. // switch (Dev.L_pump2.facid)
  888. // {
  889. // case FAC_VK:
  890. // break;
  891. // case FAC_HW_ESC:
  892. // Dev.L_pump2.warn = EscMsg[1].warn_flag;
  893. // Dev.L_pump2.rpm = EscMsg[1].motorRPM;
  894. // break;
  895. // default:
  896. // break;
  897. // }
  898. // }
  899. //智能电池
  900. if(Dev.Bms_Link.connect_status == COMP_NORMAL)
  901. {
  902. Dev.Bms.index = 0;
  903. Dev.Bms.facid = bms_data.serial_num;
  904. bms_data.bms_version[0] = 'V';
  905. bms_data.bms_version[1] = 'K';
  906. bms_data.bms_version[2] = '3';
  907. bms_data.bms_group = group_num;
  908. memcpy(&Dev.Bms.buf[Dev.Bms.index],&bms_data.bms_version,5 + bms_data.bms_num * 2);
  909. Dev.Bms.index += (5 + bms_data.bms_num * 2);
  910. memcpy(&Dev.Bms.buf[Dev.Bms.index],&bms_data.bms_ids,43);
  911. Dev.Bms.index += 43;
  912. memset(&Dev.Bms.buf[Dev.Bms.index],0,2); //EFT协议新加插头问题
  913. Dev.Bms.index += 2;
  914. if(bms_data.bms_group == 2)
  915. {
  916. memcpy(&Dev.Bms.buf[Dev.Bms.index],&bms_data2.bms_num,1 + bms_data2.bms_num * 2);
  917. Dev.Bms.index += (1 + bms_data2.bms_num * 2);
  918. memcpy(&Dev.Bms.buf[Dev.Bms.index],&bms_data2.bms_ids,43);
  919. Dev.Bms.index += 43;
  920. memset(&Dev.Bms.buf[Dev.Bms.index],0,2); //EFT协议新加插头问题
  921. Dev.Bms.index += 2;
  922. }
  923. }
  924. if(_Aqx_bms_link.connect_status == COMP_NORMAL)
  925. {
  926. Dev.Bms.facid = FAC_QX_BMS;
  927. Dev.Bms.buf[0] = 0;//电池串数
  928. Dev.Bms.index = 0;
  929. Dev.Bms.index++;
  930. for(uint8_t i = 0; i < 4; i++)
  931. {
  932. if(_qx_bms_link[i].connect_status == COMP_NORMAL)
  933. {
  934. Dev.Bms.buf[0]++;
  935. memcpy(&Dev.Bms.buf[Dev.Bms.index],&_qx_bms[i].bat_voltage,sizeof(qingxie_bms_status_t));
  936. Dev.Bms.index += sizeof(qingxie_bms_status_t);
  937. }
  938. }
  939. }
  940. //流量计、断料记、雷达数据一直发
  941. if(true/*Dev.Flow_Link1.connect_status == COMP_NORMAL*/)
  942. {
  943. switch (Dev.Flow.facid)
  944. {
  945. case FAC_VK:
  946. Dev.Flow.speed1 = flow_dev1.speed;
  947. Dev.Flow.speed2 = flow_dev2.speed;
  948. Dev.Flow.ml1 = flow_dev1.irq_count;
  949. Dev.Flow.ml2 = flow_dev2.irq_count;
  950. Dev.Flow.warn1 = 0;
  951. Dev.Flow.warn2 = 0;
  952. Dev.Flow.k1 = 0;
  953. Dev.Flow.k2 = 0;
  954. break;
  955. case FAC_MIMO_SIG:// APP需要识别单双管
  956. Dev.Flow.speed1 = flow_mimo1.flow_speed;
  957. Dev.Flow.speed2 = flow_mimo2.flow_speed;
  958. Dev.Flow.ml1 = (flow_mimo1.total_ml + 65535 * flow_mimo1.overturn_count) * FlOW_KP * 60 / 1000;
  959. Dev.Flow.ml2 = (flow_mimo2.total_ml + 65535 * flow_mimo2.overturn_count) * FlOW_KP * 60 / 1000;
  960. Dev.Flow.warn1 = flow_mimo1.status;
  961. Dev.Flow.warn2 = flow_mimo2.status;
  962. Dev.Flow.k1 = flow_mimo1.flow_k;
  963. Dev.Flow.k2 = flow_mimo2.flow_k;
  964. break;
  965. case FAC_MIMO_DOU:
  966. Dev.Flow.speed1 = flow_mimo1.flow_speed;
  967. Dev.Flow.speed2 = flow_mimo2.flow_speed;
  968. Dev.Flow.ml1 = (flow_mimo1.total_ml + 65535 * flow_mimo1.overturn_count) * FlOW_KP * 60 / 1000;
  969. Dev.Flow.ml2 = (flow_mimo2.total_ml + 65535 * flow_mimo2.overturn_count) * FlOW_KP * 60 / 1000;
  970. Dev.Flow.warn1 = flow_mimo1.status;
  971. Dev.Flow.warn2 = flow_mimo2.status;
  972. Dev.Flow.k1 = flow_mimo1.flow_k;
  973. Dev.Flow.k2 = flow_mimo2.flow_k;
  974. break;
  975. case FAC_QIFEI_SIG:
  976. Dev.Flow.speed1 = flow_inf.ch1.speed;
  977. Dev.Flow.speed2 = flow_inf.ch2.speed;
  978. Dev.Flow.ml1 = (flow_inf.ch1.ml + 65535 * flow_inf.ch1.overturn) * FlOW_KP * 60 / 1000;
  979. Dev.Flow.ml2 = (flow_inf.ch2.ml + 65535 * flow_inf.ch2.overturn) * FlOW_KP * 60 / 1000;
  980. Dev.Flow.warn1 = flow_inf.ch1.warn;
  981. Dev.Flow.warn2 = flow_inf.ch2.warn;
  982. Dev.Flow.k1 = flow_inf.ch1.k;
  983. Dev.Flow.k2 = flow_inf.ch2.k;
  984. break;
  985. case FAC_QIFEI_DOU: // 12做个调换
  986. Dev.Flow.speed1 = flow_inf.ch2.speed;
  987. Dev.Flow.speed2 = flow_inf.ch1.speed;
  988. Dev.Flow.ml1 = (flow_inf.ch2.ml + 65535 * flow_inf.ch2.overturn) * FlOW_KP * 60 / 1000;
  989. Dev.Flow.ml2 = (flow_inf.ch1.ml + 65535 * flow_inf.ch1.overturn) * FlOW_KP * 60 / 1000;
  990. Dev.Flow.warn1 = flow_inf.ch2.warn;
  991. Dev.Flow.warn2 = flow_inf.ch1.warn;
  992. Dev.Flow.k1 = flow_inf.ch2.k;
  993. Dev.Flow.k2 = flow_inf.ch1.k;
  994. break;
  995. case FAC_HW_ESC:
  996. Dev.Flow.speed1 = EscMsg[1].motorRPM / FlOW_KP;
  997. Dev.Flow.speed2 = EscMsg[2].motorRPM / FlOW_KP;
  998. Dev.Flow.ml1 = 0;//(flow_inf.ch1.ml + 65535 * flow_inf.ch1.overturn) * FlOW_KP * 60 / 1000;
  999. Dev.Flow.ml2 = 0;//(flow_inf.ch2.ml + 65535 * flow_inf.ch2.overturn) * FlOW_KP * 60 / 1000;
  1000. Dev.Flow.warn1 = 0;
  1001. Dev.Flow.warn2 = 0;
  1002. Dev.Flow.k1 = 0;
  1003. Dev.Flow.k2 = 0;
  1004. break;
  1005. default:
  1006. break;
  1007. }
  1008. switch (Dev.Checklow.facid)
  1009. {
  1010. case FAC_VK:
  1011. Dev.Checklow.L1_status = (uint16_t)L3_status;
  1012. Dev.Checklow.L2_status = (uint16_t)L4_status;
  1013. Dev.Checklow.liquid_persent = decode_liquid_info();
  1014. Dev.Checklow.seed_lackloss = mimo_lackloss.status;
  1015. Dev.Checklow.warn = 0;
  1016. Dev.Checklow.lack_distance = mimo_lackloss.distance / 10; //cm
  1017. Dev.Checklow.lack_power = mimo_lackloss.strength;
  1018. break;
  1019. case FAC_DM_CHECKLOW:
  1020. Dev.Checklow.L1_status = (uint16_t)L3_status;
  1021. Dev.Checklow.L2_status = (uint16_t)L4_status;
  1022. Dev.Checklow.liquid_persent = decode_liquid_info();
  1023. Dev.Checklow.seed_lackloss = DM_lackloss.status;
  1024. Dev.Checklow.warn = 0;
  1025. Dev.Checklow.lack_distance = DM_lackloss.distance;
  1026. Dev.Checklow.lack_power = DM_lackloss.strength;
  1027. break;
  1028. default:
  1029. break;
  1030. }
  1031. //雷达
  1032. Dev.Radar.height_T = get_radar_info(MSGID_SET_T_RADAR,0);
  1033. Dev.Radar.distance_F_Y = get_radar_info(MSGID_SET_F_RADAR,OBS_Y);
  1034. Dev.Radar.distance_F_Y_ori = Dev.Radar.distance_F_Y;
  1035. // if((Dev.Radar.distance_F_Y > 0) && (Fobs_handle_function() == false))
  1036. // Dev.Radar.distance_F_Y = 0;
  1037. Dev.Radar.distance_F_X = get_radar_info(MSGID_SET_F_RADAR,OBS_X);
  1038. Dev.Radar.signal_F_qulity = mimo_f_info.signal_qulity;
  1039. Dev.Radar.distance_B_Y = get_radar_info(MSGID_SET_B_RADAR,OBS_Y);
  1040. Dev.Radar.distance_B_Y_ori = Dev.Radar.distance_B_Y;
  1041. // if((Dev.Radar.distance_B_Y > 0) && (Bobs_handle_function() == false))
  1042. // Dev.Radar.distance_B_Y = 0;
  1043. Dev.Radar.distance_B_X = get_radar_info(MSGID_SET_B_RADAR,OBS_X);
  1044. Dev.Radar.signal_B_qulity = mimo_b_info.signal_qulity;
  1045. Dev.Radar.distance_L_Y = get_radar_info(MSGID_SET_L_RADAR,OBS_Y);
  1046. Dev.Radar.distance_L_Y_ori = Dev.Radar.distance_L_Y;
  1047. Dev.Radar.distance_L_X = get_radar_info(MSGID_SET_L_RADAR,OBS_X);
  1048. Dev.Radar.signal_L_qulity = 0;
  1049. Dev.Radar.distance_R_Y = get_radar_info(MSGID_SET_R_RADAR,OBS_Y);
  1050. Dev.Radar.distance_R_Y_ori = Dev.Radar.distance_R_Y;
  1051. Dev.Radar.distance_R_X = get_radar_info(MSGID_SET_R_RADAR,OBS_X);
  1052. Dev.Radar.signal_R_qulity = 0;
  1053. terrain_is_link = Dev.Radar.height_T > -1? true:false;
  1054. obs_f_is_link = Dev.Radar.distance_F_Y > -1? true:false;
  1055. obs_b_is_link = Dev.Radar.distance_B_Y > -1? true:false;
  1056. }
  1057. if(Dev.Current_Link.connect_status == COMP_NORMAL)
  1058. {
  1059. Dev.Current.facid = FAC_VK;
  1060. Dev.Current.tempture = power_BatteryInfo.temperature * 10;
  1061. Dev.Current.voltage = power_BatteryInfo.voltage * 10;
  1062. Dev.Current.current = power_BatteryInfo.current * 10;
  1063. }
  1064. if(Dev.Part_Tradar_Link.connect_status == COMP_NORMAL)
  1065. {
  1066. Dev.Part_radarT.height_part1 = T_radar[0].Distance * 0.05f * 100 * cos(T_radar[0].Amuzith * 0.1f / RAD);
  1067. Dev.Part_radarT.height_part2 = T_radar[1].Distance * 0.05f * 100 * cos(T_radar[1].Amuzith * 0.1f / RAD);
  1068. Dev.Part_radarT.height_part3 = T_radar[2].Distance * 0.05f * 100 * cos(T_radar[2].Amuzith * 0.1f / RAD);
  1069. }
  1070. if(Dev.Part_Fradar_Link.connect_status == COMP_NORMAL && Dev.Part_radarF.facid == FAC_DM_RF_4D)
  1071. {
  1072. Dev.Part_radarF.X1 = F_4DRadar[0][0];
  1073. Dev.Part_radarF.Y1 = F_4DRadar[0][1];
  1074. Dev.Part_radarF.Z1 = F_4DRadar[0][2];
  1075. Dev.Part_radarF.X2 = F_4DRadar[1][0];
  1076. Dev.Part_radarF.Y2 = F_4DRadar[1][1];
  1077. Dev.Part_radarF.Z2 = F_4DRadar[1][2];
  1078. Dev.Part_radarF.X3 = F_4DRadar[2][0];
  1079. Dev.Part_radarF.Y3 = F_4DRadar[2][1];
  1080. Dev.Part_radarF.Z3 = F_4DRadar[2][2];
  1081. }
  1082. if(Dev.Part_Bradar_Link.connect_status == COMP_NORMAL && Dev.Part_radarB.facid == FAC_DM_RB_4D)
  1083. {
  1084. Dev.Part_radarB.X1 = B_4DRadar[0][0];
  1085. Dev.Part_radarB.Y1 = B_4DRadar[0][1];
  1086. Dev.Part_radarB.Z1 = B_4DRadar[0][2];
  1087. Dev.Part_radarB.X2 = B_4DRadar[1][0];
  1088. Dev.Part_radarB.Y2 = B_4DRadar[1][1];
  1089. Dev.Part_radarB.Z2 = B_4DRadar[1][2];
  1090. Dev.Part_radarB.X3 = B_4DRadar[2][0];
  1091. Dev.Part_radarB.Y3 = B_4DRadar[2][1];
  1092. Dev.Part_radarB.Z3 = B_4DRadar[2][2];
  1093. }
  1094. if(Dev.Temp_Sensor_Link.connect_status == COMP_NORMAL)
  1095. {
  1096. switch (Dev.Temp_sensor.facid)
  1097. {
  1098. case FAC_EFT:
  1099. Dev.Temp_sensor.Positive_pole = Temp_sensor.Positive_pole;
  1100. Dev.Temp_sensor.Negative_pole = Temp_sensor.Negative_pole;
  1101. break;
  1102. default:
  1103. break;
  1104. }
  1105. }
  1106. }
  1107. }
  1108. comp_status QIFEI_link_status = COMP_NOEXIST;
  1109. uint32_t get_QIFEI_time = 0;
  1110. volatile char get_QIFEI_time_sem = 0;
  1111. unsigned int get_QIFEI_time_err = 0;
  1112. void QIFEI_recieved_hookfuction(uint32_t CanID, uint8_t data[], uint8_t len)
  1113. {
  1114. uint8_t id = 0;
  1115. QIFEI_link_status = COMP_NORMAL;
  1116. get_QIFEI_time = HAL_GetTick();
  1117. id = data[0];
  1118. switch (CanID)
  1119. {
  1120. case 0x0AD2:
  1121. break;
  1122. case 0x0AD0:
  1123. switch (id)
  1124. {
  1125. case 0x01:
  1126. break;
  1127. default:
  1128. break;
  1129. }
  1130. break;
  1131. default:
  1132. break;
  1133. }
  1134. }