soft_seed_device.c 43 KB

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