CollectMaster485.c 97 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798991001011021031041051061071081091101111121131141151161171181191201211221231241251261271281291301311321331341351361371381391401411421431441451461471481491501511521531541551561571581591601611621631641651661671681691701711721731741751761771781791801811821831841851861871881891901911921931941951961971981992002012022032042052062072082092102112122132142152162172182192202212222232242252262272282292302312322332342352362372382392402412422432442452462472482492502512522532542552562572582592602612622632642652662672682692702712722732742752762772782792802812822832842852862872882892902912922932942952962972982993003013023033043053063073083093103113123133143153163173183193203213223233243253263273283293303313323333343353363373383393403413423433443453463473483493503513523533543553563573583593603613623633643653663673683693703713723733743753763773783793803813823833843853863873883893903913923933943953963973983994004014024034044054064074084094104114124134144154164174184194204214224234244254264274284294304314324334344354364374384394404414424434444454464474484494504514524534544554564574584594604614624634644654664674684694704714724734744754764774784794804814824834844854864874884894904914924934944954964974984995005015025035045055065075085095105115125135145155165175185195205215225235245255265275285295305315325335345355365375385395405415425435445455465475485495505515525535545555565575585595605615625635645655665675685695705715725735745755765775785795805815825835845855865875885895905915925935945955965975985996006016026036046056066076086096106116126136146156166176186196206216226236246256266276286296306316326336346356366376386396406416426436446456466476486496506516526536546556566576586596606616626636646656666676686696706716726736746756766776786796806816826836846856866876886896906916926936946956966976986997007017027037047057067077087097107117127137147157167177187197207217227237247257267277287297307317327337347357367377387397407417427437447457467477487497507517527537547557567577587597607617627637647657667677687697707717727737747757767777787797807817827837847857867877887897907917927937947957967977987998008018028038048058068078088098108118128138148158168178188198208218228238248258268278288298308318328338348358368378388398408418428438448458468478488498508518528538548558568578588598608618628638648658668678688698708718728738748758768778788798808818828838848858868878888898908918928938948958968978988999009019029039049059069079089099109119129139149159169179189199209219229239249259269279289299309319329339349359369379389399409419429439449459469479489499509519529539549559569579589599609619629639649659669679689699709719729739749759769779789799809819829839849859869879889899909919929939949959969979989991000100110021003100410051006100710081009101010111012101310141015101610171018101910201021102210231024102510261027102810291030103110321033103410351036103710381039104010411042104310441045104610471048104910501051105210531054105510561057105810591060106110621063106410651066106710681069107010711072107310741075107610771078107910801081108210831084108510861087108810891090109110921093109410951096109710981099110011011102110311041105110611071108110911101111111211131114111511161117111811191120112111221123112411251126112711281129113011311132113311341135113611371138113911401141114211431144114511461147114811491150115111521153115411551156115711581159116011611162116311641165116611671168116911701171117211731174117511761177117811791180118111821183118411851186118711881189119011911192119311941195119611971198119912001201120212031204120512061207120812091210121112121213121412151216121712181219122012211222122312241225122612271228122912301231123212331234123512361237123812391240124112421243124412451246124712481249125012511252125312541255125612571258125912601261126212631264126512661267126812691270127112721273127412751276127712781279128012811282128312841285128612871288128912901291129212931294129512961297129812991300130113021303130413051306130713081309131013111312131313141315131613171318131913201321132213231324132513261327132813291330133113321333133413351336133713381339134013411342134313441345134613471348134913501351135213531354135513561357135813591360136113621363136413651366136713681369137013711372137313741375137613771378137913801381138213831384138513861387138813891390139113921393139413951396139713981399140014011402140314041405140614071408140914101411141214131414141514161417141814191420142114221423142414251426142714281429143014311432143314341435143614371438143914401441144214431444144514461447144814491450145114521453145414551456145714581459146014611462146314641465146614671468146914701471147214731474147514761477147814791480148114821483148414851486148714881489149014911492149314941495149614971498149915001501150215031504150515061507150815091510151115121513151415151516151715181519152015211522152315241525152615271528152915301531153215331534153515361537153815391540154115421543154415451546154715481549155015511552155315541555155615571558155915601561156215631564156515661567156815691570157115721573157415751576157715781579158015811582158315841585158615871588158915901591159215931594159515961597159815991600160116021603160416051606160716081609161016111612161316141615161616171618161916201621162216231624162516261627162816291630163116321633163416351636163716381639164016411642164316441645164616471648164916501651165216531654165516561657165816591660166116621663166416651666166716681669167016711672167316741675167616771678167916801681168216831684168516861687168816891690169116921693169416951696169716981699170017011702170317041705170617071708170917101711171217131714171517161717171817191720172117221723172417251726172717281729173017311732173317341735173617371738173917401741174217431744174517461747174817491750175117521753175417551756175717581759176017611762176317641765176617671768176917701771177217731774177517761777177817791780178117821783178417851786178717881789179017911792179317941795179617971798179918001801180218031804180518061807180818091810181118121813181418151816181718181819182018211822182318241825182618271828182918301831183218331834183518361837183818391840184118421843184418451846184718481849185018511852185318541855185618571858185918601861186218631864186518661867186818691870187118721873187418751876187718781879188018811882188318841885188618871888188918901891189218931894189518961897189818991900190119021903190419051906190719081909191019111912191319141915191619171918191919201921192219231924192519261927192819291930193119321933193419351936193719381939194019411942194319441945194619471948194919501951195219531954195519561957195819591960196119621963196419651966196719681969197019711972197319741975197619771978197919801981198219831984198519861987198819891990199119921993199419951996199719981999200020012002200320042005200620072008200920102011201220132014201520162017201820192020202120222023202420252026202720282029203020312032203320342035203620372038203920402041204220432044204520462047204820492050205120522053205420552056205720582059206020612062206320642065206620672068206920702071207220732074207520762077207820792080208120822083208420852086208720882089209020912092209320942095209620972098209921002101210221032104210521062107210821092110211121122113211421152116211721182119212021212122212321242125212621272128212921302131213221332134213521362137213821392140214121422143214421452146214721482149215021512152215321542155215621572158215921602161216221632164216521662167216821692170217121722173217421752176217721782179218021812182218321842185218621872188218921902191219221932194219521962197219821992200220122022203220422052206220722082209221022112212221322142215221622172218221922202221222222232224222522262227222822292230223122322233223422352236223722382239224022412242224322442245224622472248224922502251225222532254225522562257225822592260226122622263226422652266226722682269227022712272227322742275227622772278227922802281228222832284228522862287228822892290229122922293229422952296229722982299230023012302230323042305230623072308230923102311231223132314231523162317231823192320232123222323232423252326232723282329233023312332233323342335233623372338233923402341234223432344234523462347234823492350235123522353235423552356235723582359236023612362236323642365236623672368236923702371237223732374237523762377237823792380238123822383238423852386238723882389239023912392239323942395239623972398239924002401240224032404240524062407240824092410241124122413241424152416241724182419242024212422242324242425242624272428242924302431243224332434243524362437243824392440244124422443244424452446244724482449245024512452245324542455245624572458245924602461246224632464246524662467246824692470247124722473247424752476247724782479248024812482248324842485248624872488248924902491249224932494249524962497249824992500250125022503250425052506250725082509251025112512251325142515251625172518251925202521252225232524252525262527252825292530253125322533253425352536253725382539254025412542254325442545254625472548254925502551255225532554255525562557255825592560256125622563256425652566256725682569257025712572257325742575257625772578257925802581258225832584258525862587258825892590259125922593259425952596259725982599260026012602260326042605260626072608260926102611261226132614261526162617261826192620262126222623262426252626262726282629263026312632263326342635263626372638263926402641264226432644264526462647264826492650265126522653265426552656265726582659266026612662266326642665266626672668266926702671267226732674267526762677267826792680268126822683268426852686268726882689269026912692269326942695269626972698269927002701270227032704270527062707270827092710271127122713271427152716271727182719272027212722272327242725272627272728272927302731273227332734273527362737273827392740274127422743274427452746274727482749275027512752275327542755275627572758275927602761276227632764276527662767276827692770277127722773277427752776277727782779278027812782278327842785278627872788278927902791279227932794279527962797279827992800280128022803280428052806280728082809281028112812281328142815281628172818281928202821282228232824282528262827282828292830283128322833283428352836283728382839284028412842284328442845284628472848284928502851285228532854285528562857285828592860286128622863286428652866286728682869287028712872287328742875287628772878287928802881288228832884288528862887288828892890289128922893289428952896289728982899290029012902290329042905290629072908290929102911291229132914291529162917291829192920292129222923292429252926292729282929293029312932293329342935293629372938293929402941294229432944294529462947294829492950295129522953295429552956295729582959296029612962296329642965296629672968296929702971297229732974297529762977297829792980298129822983298429852986298729882989299029912992299329942995299629972998299930003001300230033004300530063007300830093010301130123013301430153016301730183019302030213022302330243025302630273028302930303031303230333034303530363037303830393040304130423043304430453046304730483049305030513052305330543055305630573058305930603061306230633064306530663067306830693070307130723073307430753076307730783079308030813082308330843085308630873088308930903091309230933094309530963097309830993100310131023103310431053106310731083109311031113112311331143115311631173118311931203121312231233124312531263127312831293130313131323133313431353136313731383139314031413142314331443145314631473148314931503151315231533154315531563157315831593160316131623163316431653166316731683169317031713172317331743175317631773178317931803181318231833184318531863187318831893190319131923193319431953196319731983199320032013202320332043205320632073208320932103211321232133214321532163217321832193220322132223223322432253226322732283229323032313232323332343235323632373238323932403241324232433244324532463247324832493250325132523253325432553256325732583259326032613262326332643265326632673268326932703271327232733274327532763277327832793280328132823283328432853286328732883289329032913292329332943295329632973298329933003301330233033304330533063307330833093310331133123313331433153316331733183319332033213322332333243325332633273328332933303331333233333334333533363337333833393340334133423343334433453346334733483349335033513352335333543355335633573358335933603361336233633364336533663367336833693370337133723373337433753376337733783379338033813382338333843385338633873388338933903391339233933394339533963397339833993400340134023403340434053406340734083409341034113412341334143415341634173418341934203421342234233424342534263427342834293430343134323433343434353436343734383439
  1. #include "CollectMaster485.h"
  2. #include "KeySlave485.h"
  3. #include "TerminalSlave485.h"
  4. #include "usart.h"
  5. #include "Data_deal.h"
  6. #include "spi.h"
  7. #include "Dwin.h"
  8. #include "ScreenMaster485.h"
  9. #include<math.h>
  10. #include<stdlib.h>
  11. extern uint16_t bufTextCang01_IO[];
  12. extern uint16_t bufTextCang02_IO[];
  13. extern uint8_t Cang01_IO[64];
  14. extern uint8_t Cang02_IO[64];
  15. extern uint8_t Cang03_IO[64];
  16. extern uint8_t Cang04_IO[64];
  17. extern uint8_t Cang05_IO[64];
  18. extern uint8_t Cang06_IO[64];
  19. extern uint8_t Cang07_IO[64];
  20. extern uint8_t Cang08_IO[64];
  21. #include "cmsis_os.h"
  22. uint16_t Usart2_ErrorTimes=0,chkRetCaiJiBan;
  23. static int cnt000=0,CangNum000;//计数器,每间隔3秒读取一次模拟量类传感器数据;每间隔1秒读取一次阀门数据;//
  24. uint16_t CRC_data,CRC_dataCaiJiBan;//;
  25. uint8_t StoreNumber00=1;//实际读取的仓号的阀门信息
  26. uint8_t Array_IO_OnOff_AllStore[32];
  27. uint8_t Array_IO_Exception_AllStore[32];
  28. #define MaxGuanGao (1831)
  29. //2021jan20根据实际罐容,下调26mm=131+26
  30. //#define LeiDaOffset (-157) //0(-157) -131
  31. #define LeiDaOffset 0 //(-131) //0(-157) -131
  32. //////////////////////////////////////////////////////////////////////////////////
  33. #define dataLengthIn USART2_RX_BUF[3]
  34. //02功能码的子功能,传奇种类
  35. #define Read_Press 0x01
  36. #define Read_YeWei 0x02
  37. #define Read_Temper 0x03
  38. #define Read_QingJiao 0x04
  39. #define Filter_NUM 8 //滤波器的点数,建议为8,可以为8~32之间的任何数字
  40. //用于滤波的雷达液位计的原始数据,单位为米m,正常范围应该在0.08--1.831之间
  41. //空仓液位大约在1831mm,雷达盲区大约80mm
  42. float LeiDaArr[33];
  43. float ArrOfTempeSensor_Flo[3];//三点式温度传感器的数据
  44. float Zero_Of_LiquidMeter[8];//8个仓的雷达液位计零点参数
  45. float Zero_Of_TankCapacity[8];//8个仓的罐容表零点参数
  46. uint8_t USART2_RX_BUF_Collector[Uart2_BUF_SIZE];
  47. uint8_t ValStateArr_0x13[64],ValStateArr_PoFeng_0x13[64];//破封时的阀门状态
  48. uint8_t ValStateArr_0x20[64],ValStateArr_PoFeng_0x20[64];//破封时的阀门状态
  49. uint8_t ValStateArr_0x20_Cang01[64],ValStateArr_PoFeng_0x20_Cang01[64];//破封时的阀门状态
  50. uint8_t ValStateArr_0x20_Cang02[64],ValStateArr_PoFeng_0x20_Cang02[64];//破封时的阀门状态
  51. uint8_t ValStateArr_0x20_Cang03[64],ValStateArr_PoFeng_0x20_Cang03[64];//破封时的阀门状态
  52. uint8_t ValStateArr_0x20_Cang04[64],ValStateArr_PoFeng_0x20_Cang04[64];//破封时的阀门状态
  53. //20210129李伟修改---增加一个全局数组用于保存8个仓的阀门状态(按照平台的位定义协议进行组包)
  54. uint8_t Array_Of_Valve[32];//
  55. //20210129李伟修改 -----从采集器读取的8个阀门的状态,对应于原来的采集器的8仓;
  56. //对应于平台解析的1--4号阀门状态(每仓4个阀门,最多32个阀门)
  57. uint8_t ValState01,ValState02,ValState03,ValState04,ValState05,ValState06,ValState07,ValState08;
  58. uint8_t Val_4Bit_H,Val_4Bit_L;//高四位与低四位
  59. uint32_t IO_OnOff_State01=0,IO_OnOff_State02=0,IO_OnOff_State03=0,IO_OnOff_State04=0;
  60. uint32_t IO_Exception_State01=0,IO_Exception_State02=0,IO_Exception_State03=0,IO_Exception_State04=0;
  61. uint32_t IO_OnOff_StateArr[4];//
  62. uint32_t IO_Exception_StateArr[4];//,IO_Exception_State02=0,IO_Exception_State03=0,IO_Exception_State04=0;
  63. //20210201李伟修改---增加一个全局数组用于上传按下打印键之后的车辆状态
  64. //具体详见<控制器平台通信协议增加20210126李伟修改回传数据格式.xlsx>
  65. uint8_t Array_Of_Tank_0x64[68];//
  66. //李伟修改 20210729
  67. uint8_t Array_Of_IO_0xA1[64];//
  68. int LenRx_0xA1=16;
  69. STOR_TypeDef Stor[8];
  70. STatetemp_TypeDef Statetemp,Fg;
  71. Collect485_TypeDef Collect485;
  72. Calibrat_TypeDef PlatformCalibrat;
  73. uint8_t Pneumatic_PR1=0 ;
  74. uint8_t Pneumatic_PR2=0 ;
  75. uint8_t Pneumatic_PR3=0 ;
  76. uint8_t Pneumatic_PR4=0 ;
  77. uint8_t StoreNumber=3,all_Store=3;
  78. uint8_t CabinetNumForWenYou=0;//默认选择第一个仓的液位计用作稳油判断
  79. uint8_t HaiDiFa001=0x00;//8个海底阀的状态
  80. uint8_t XieYouFa001=0x00;//8个泄油阀的状态
  81. uint8_t ManHole_CoverBig001=0x00;//8个人孔大盖的状态
  82. uint8_t ManHole_CoverSmall001=0x00;//8个人孔小盖的状态
  83. uni_IncliAngle uni_IncliAngle001;
  84. uni_TankVol_Tempe20 uni_TankVol_Tempe20_001,uni_TankVol_Tempe20_002,uni_TempRealtime001;
  85. uni_TankVol_Realtime uni_TankVol_Realtime001,uni_TankVol_Realtime002,uni_TankVol_Realtime003,uni_TankVol_Realtime004;
  86. uni_temper uni_temper001,uni_temper002,uni_temper003,uni_temper004;
  87. uni_QingJiao uni_QingJiao001,uni_QingJiao002;
  88. uni_LiqLev uni_LiqLev001,uni_LiqLev002,uni_LiqLev003,uni_LiqLev004;//4个仓位的液位高度数据
  89. uni_GasPressure uni_GasPressure001;
  90. uni_OilWeight uni_OilWeight001;
  91. uni_OilDensity uni_OilDensity001;
  92. uni_LeiDaYewei uni_LeiDaYewei001;
  93. int16_t yewei003;
  94. uni_Float ArrayUni_MoniLiang[64];
  95. //发往平台的数据
  96. uni_YeweiToPlatForm uni_YeweiToPlatForm001,uni_YeweiToPlatForm002,uni_YeweiToPlatForm003,uni_YeweiToPlatForm004;
  97. uni_TempToPlatForm uni_TempToPlatForm001,uni_TempToPlatForm002;
  98. //李伟修改 队尾的3个数据依次为最大值,最小值,峰峰值
  99. float ArrYeweiForWenyou[NumOf_WenYouPanduan+3];//存储300s的液位数据 打印的时候作为是否稳油判断依据
  100. float Yewei_max000,Yewei_min000,Yewei_peak000;
  101. void TestUsart2_Receive(void)
  102. {
  103. if(usart2_rx_flag)
  104. {
  105. usart2_rx_flag=0;
  106. CollectMaster485_Send_Data(USART2_RX_BUF,rx2_len);
  107. }
  108. }
  109. //RS485发送len个字节.
  110. //buf:发送区首地址
  111. //len:发送的字节数
  112. uint8_t uart2_buf[1024];
  113. void CollectMaster485_Send_Data(uint8_t *buf,uint16_t len)
  114. {
  115. int retry;
  116. //while(HAL_GPIO_ReadPin(GPIOA,GPIO_PIN_1)==GPIO_PIN_RESET)
  117. for(retry=0;retry<50;++retry)
  118. {
  119. if(huart2.gState == HAL_UART_STATE_READY)
  120. break;
  121. osDelay(10);
  122. }
  123. if(retry>=50)
  124. return;
  125. CollectMaster485_TX_Set(1); //设置为发送模式
  126. HAL_Delay(2);
  127. if(len>1024)
  128. len=1024;
  129. memcpy(uart2_buf,buf,len);
  130. //HAL_UART_Transmit(&huart2,buf,len,1000);//串口2发送数据
  131. if(HAL_UART_Transmit_IT(&huart2,uart2_buf,len)!=HAL_OK)
  132. {
  133. CollectMaster485_TX_Set(0); //设置为接收模式
  134. }
  135. }
  136. //RS485模式控制.
  137. //en:0,接收;1,发送.
  138. void CollectMaster485_TX_Set(uint8_t en)
  139. {
  140. if(en==1)HAL_GPIO_WritePin(GPIOA,GPIO_PIN_1,GPIO_PIN_RESET);
  141. else HAL_GPIO_WritePin(GPIOA,GPIO_PIN_1,GPIO_PIN_SET);
  142. }
  143. //RS485模式控制.
  144. //将阀门状态按照0x91的规格进行打包。有效数据32字节
  145. //
  146. /*
  147. 大盖、小盖、底阀、卸油阀主界面的状态显示
  148. zhuzl added 2021-12-15
  149. */
  150. void ValStateConvertTo91(void)
  151. {
  152. uint8_t HaiDiFa002 = 0x00; // 8个海底阀的状态
  153. uint8_t XieYouFa002 = 0x00; // 8个泄油阀的状态
  154. uint8_t ManHole_CoverBig002 = 0x00; // 8个人孔大盖的状态
  155. uint8_t ManHole_CoverSmall002 = 0x00; // 8个人孔小盖的状态
  156. // 20210129李伟修改,将阀门状态按照1月9日的会议决议进行组包。
  157. // USART2_RX_BUF[5];----- 1仓大盖、小盖、底阀、卸油阀状态:
  158. // Array_Of_Valve[0]=0;
  159. // Array_Of_Valve[4]=0;
  160. // memset(Array_Of_Valve,0x00,32);//清除残留数据
  161. //获取采集板传来的原始阀门状态,具体顺序为:bit0--bit3对应于大小底卸的开关状态;bit4--bit7对应于大小底卸的异常状态;
  162. #if 0
  163. ValState01=USART2_RX_BUF[5];//采集器的1仓
  164. ValState02=USART2_RX_BUF[7];//采集器的2仓
  165. ValState03=USART2_RX_BUF[9];//采集器的3仓
  166. ValState04=USART2_RX_BUF[11];//采集器的4仓
  167. ValState05=USART2_RX_BUF[13];//采集器的5仓
  168. ValState06=USART2_RX_BUF[15];//采集器的6仓
  169. ValState07=USART2_RX_BUF[17];//采集器的7仓
  170. ValState08=USART2_RX_BUF[19];//采集器的8仓
  171. #else
  172. ValState01=Collect485.ValveState_Num1;//采集器的1仓
  173. ValState02=Collect485.ValveState_Num2;//采集器的2仓
  174. ValState03=Collect485.ValveState_Num3;//采集器的3仓
  175. ValState04=Collect485.ValveState_Num4;//采集器的4仓
  176. ValState05=Collect485.ValveState_Num5;//采集器的5仓
  177. ValState06=Collect485.ValveState_Num6;//采集器的6仓
  178. ValState07=Collect485.ValveState_Num7;//采集器的7仓
  179. ValState08=Collect485.ValveState_Num8;//采集器的8仓
  180. #endif
  181. //人孔大盖数据合成为一个字节
  182. ManHole_CoverBig002=0x00;
  183. if(ValState01 & GPIO_PIN_0)
  184. {
  185. ManHole_CoverBig002=ManHole_CoverBig002| GPIO_PIN_0;
  186. }
  187. if(ValState02 & GPIO_PIN_0)
  188. {
  189. ManHole_CoverBig002=ManHole_CoverBig002| GPIO_PIN_1;
  190. }
  191. if(ValState03 & GPIO_PIN_0)
  192. {
  193. ManHole_CoverBig002=ManHole_CoverBig002| GPIO_PIN_2;
  194. }
  195. if(ValState04 & GPIO_PIN_0)
  196. {
  197. ManHole_CoverBig002=ManHole_CoverBig002| GPIO_PIN_3;
  198. }
  199. if(ValState05 & GPIO_PIN_0)
  200. {
  201. ManHole_CoverBig002=ManHole_CoverBig002| GPIO_PIN_4;
  202. }
  203. if(ValState06 & GPIO_PIN_0)
  204. {
  205. ManHole_CoverBig002=ManHole_CoverBig002| GPIO_PIN_5;
  206. }
  207. if(ValState07 & GPIO_PIN_0)
  208. {
  209. ManHole_CoverBig002=ManHole_CoverBig002| GPIO_PIN_6;
  210. }
  211. if(ValState08 & GPIO_PIN_0)
  212. {
  213. ManHole_CoverBig002=ManHole_CoverBig002| GPIO_PIN_7;
  214. }
  215. if(ManHole_CoverBig002!=ManHole_CoverBig001)
  216. {
  217. ManHole_CoverBig001=ManHole_CoverBig002;
  218. WrDwinCmd16(0x1003,ManHole_CoverBig001);//人孔大盖状态刷新
  219. }
  220. //人孔小盖数据合成为一个字节
  221. ManHole_CoverSmall002=0x00;
  222. if(ValState01 & GPIO_PIN_1)
  223. {
  224. ManHole_CoverSmall002=ManHole_CoverSmall002| GPIO_PIN_0;
  225. }
  226. if(ValState02 & GPIO_PIN_1)
  227. {
  228. ManHole_CoverSmall002=ManHole_CoverSmall002| GPIO_PIN_1;
  229. }
  230. if(ValState03 & GPIO_PIN_1)
  231. {
  232. ManHole_CoverSmall002=ManHole_CoverSmall002| GPIO_PIN_2;
  233. }
  234. if(ValState04 & GPIO_PIN_1)
  235. {
  236. ManHole_CoverSmall002=ManHole_CoverSmall002| GPIO_PIN_3;
  237. }
  238. if(ValState05 & GPIO_PIN_1)
  239. {
  240. ManHole_CoverSmall002=ManHole_CoverSmall002| GPIO_PIN_4;
  241. }
  242. if(ValState06 & GPIO_PIN_1)
  243. {
  244. ManHole_CoverSmall002=ManHole_CoverSmall002| GPIO_PIN_5;
  245. }
  246. if(ValState07 & GPIO_PIN_1)
  247. {
  248. ManHole_CoverSmall002=ManHole_CoverSmall002| GPIO_PIN_6;
  249. }
  250. if(ValState08 & GPIO_PIN_1)
  251. {
  252. ManHole_CoverSmall002=ManHole_CoverSmall002| GPIO_PIN_7;
  253. }
  254. if(ManHole_CoverSmall002!=ManHole_CoverSmall001)
  255. {
  256. ManHole_CoverSmall001=ManHole_CoverSmall002;
  257. WrDwinCmd16(0x1000,ManHole_CoverSmall001);//人孔小盖状态刷新
  258. }
  259. //海底阀数据合成为一个字节
  260. HaiDiFa002=0x00;
  261. if(ValState01 & GPIO_PIN_2)
  262. {
  263. HaiDiFa002=HaiDiFa002| GPIO_PIN_0;
  264. }
  265. if(ValState02 & GPIO_PIN_2)
  266. {
  267. HaiDiFa002=HaiDiFa002| GPIO_PIN_1;
  268. }
  269. if(ValState03 & GPIO_PIN_2)
  270. {
  271. HaiDiFa002=HaiDiFa002| GPIO_PIN_2;
  272. }
  273. if(ValState04 & GPIO_PIN_2)
  274. {
  275. HaiDiFa002=HaiDiFa002| GPIO_PIN_3;
  276. }
  277. if(ValState05 & GPIO_PIN_2)
  278. {
  279. HaiDiFa002=HaiDiFa002| GPIO_PIN_4;
  280. }
  281. if(ValState06 & GPIO_PIN_2)
  282. {
  283. HaiDiFa002=HaiDiFa002| GPIO_PIN_5;
  284. }
  285. if(ValState07 & GPIO_PIN_2)
  286. {
  287. HaiDiFa002=HaiDiFa002| GPIO_PIN_6;
  288. }
  289. if(ValState08 & GPIO_PIN_2)
  290. {
  291. HaiDiFa002=HaiDiFa002| GPIO_PIN_7;
  292. }
  293. if(HaiDiFa002!=HaiDiFa001)
  294. {
  295. HaiDiFa001=HaiDiFa002;
  296. WrDwinCmd16(ADDR_DWIN_HaiDiFa,HaiDiFa001);//海底阀状态刷新
  297. }
  298. //卸油阀数据合成为一个字节
  299. XieYouFa002=0x00;
  300. if(ValState01 & GPIO_PIN_3)
  301. {
  302. XieYouFa002=XieYouFa002| GPIO_PIN_0;
  303. }
  304. if(ValState02 & GPIO_PIN_3)
  305. {
  306. XieYouFa002=XieYouFa002| GPIO_PIN_1;
  307. }
  308. if(ValState03 & GPIO_PIN_3)
  309. {
  310. XieYouFa002=XieYouFa002| GPIO_PIN_2;
  311. }
  312. if(ValState04 & GPIO_PIN_3)
  313. {
  314. XieYouFa002=XieYouFa002| GPIO_PIN_3;
  315. }
  316. if(ValState05 & GPIO_PIN_3)
  317. {
  318. XieYouFa002=XieYouFa002| GPIO_PIN_4;
  319. }
  320. if(ValState06 & GPIO_PIN_3)
  321. {
  322. XieYouFa002=XieYouFa002| GPIO_PIN_5;
  323. }
  324. if(ValState07 & GPIO_PIN_3)
  325. {
  326. XieYouFa002=XieYouFa002| GPIO_PIN_6;
  327. }
  328. if(ValState08 & GPIO_PIN_3)
  329. {
  330. XieYouFa002=XieYouFa002| GPIO_PIN_7;
  331. }
  332. if(XieYouFa002!=XieYouFa001)
  333. {
  334. XieYouFa001=XieYouFa002;
  335. WrDwinCmd16(ADDR_DWIN_XieYouFa,XieYouFa001);//泄油阀状态刷新 WrDwinCmd16(0x1009,c);//卸油阀关
  336. }
  337. //-----------------------------------------------------1号传感器结束,只实现了第1仓,剩下7仓未实现
  338. //李伟修改 20210206 根据上午会议讨论,1仓位置与7仓位置交换------结束
  339. }
  340. #include "Elec_Seal.h"
  341. uint16_t CheckInFrame_Collect485(uint16_t LenRx,uint16_t MsgID)
  342. {
  343. uint16_t DataReturn;
  344. uint16_t CRC_data,CRC_data02;//;
  345. int i007;
  346. int retry;
  347. // float sum001;
  348. uint8_t TempData;//,TmpValState00,TmpValState01;
  349. for(retry=0;retry<25;++retry)
  350. {
  351. if(usart2_rx_flag==True)
  352. break;
  353. osDelay(15);
  354. }
  355. if(usart2_rx_flag==True)
  356. {
  357. usart2_rx_flag=False;
  358. TempData=USART2_RX_BUF[2];
  359. //DataReturn=USART2_RX_BUF[2];
  360. DataReturn=(USART2_RX_BUF[8]<<8)+USART2_RX_BUF[9]; //zzl 发送缓冲区返回数据标识?疑问
  361. if((Collector_Get_Valve_OldFormat==MsgID) ||(Collector_Get_Valve_State==MsgID))
  362. {
  363. DataReturn=USART2_RX_BUF[2];
  364. }
  365. CRC_data=CRC16_MODBUS(USART2_RX_BUF, LenRx-2);//总长度为64字节 前边的62字节计算crc
  366. //CRC_data02=(USART2_RX_BUF[62]<<8) +USART2_RX_BUF[63];//来自控制板的CRC
  367. CRC_data02=(USART2_RX_BUF[LenRx-2]<<8) +USART2_RX_BUF[LenRx-1];//来自控制板的CRC
  368. if(CRC_data==CRC_data02)
  369. {
  370. memcpy(USART2_RX_BUF_Collector,USART2_RX_BUF,sizeof(USART2_RX_BUF));
  371. }
  372. #if 0
  373. if((CRC_data==CRC_data02) && (DataReturn==0x1121))
  374. {
  375. memcpy(USART2_RX_BUF_Collector,USART2_RX_BUF,sizeof(USART2_RX_BUF));
  376. __NOP();
  377. }
  378. #endif
  379. if((USART2_RX_BUF[0]==FrameHeader_Collect&&USART2_RX_BUF[1]==EquipmentNum_Collect) &&(CRC_data==CRC_data02))
  380. {//最初版本的协议AA 00为帧头
  381. #if 0
  382. //CRC_data=CRC16_MODBUS(USART2_RX_BUF, dataLengthIn + 4);
  383. CRC_data=CRC16_MODBUS(USART2_RX_BUF, LenRx-2);//总长度为64字节 前边的62字节计算crc
  384. //CRC_data02=(USART2_RX_BUF[62]<<8) +USART2_RX_BUF[63];//来自控制板的CRC
  385. CRC_data02=(USART2_RX_BUF[LenRx-2]<<8) +USART2_RX_BUF[LenRx-1];//来自控制板的CRC
  386. //if((CRC_data==CRC_data02) && (DataReturn==0x1121))
  387. {
  388. memcpy(USART2_RX_BUF_Collector,USART2_RX_BUF,sizeof(USART2_RX_BUF));
  389. }
  390. __nop();//
  391. #endif
  392. switch(TempData)
  393. {////////switch(TempData)--开始
  394. case 0xA1://Read All Valve State 阀门状态 底阀监测器 卸油阀
  395. //CRC_data=CRC16_MODBUS(USART2_RX_BUF, 17+ 4);//dataLengthIn
  396. //__nop();
  397. // LenRx_0xA1=LenRx;
  398. memcpy(Array_Of_IO_0xA1,USART2_RX_BUF,64);
  399. //__nop();
  400. //如果保留校验则大约30秒才能成功一次,所以去掉了校验
  401. //if(CRC_data==((USART2_RX_BUF[dataLengthIn+4]<<8)+USART2_RX_BUF[dataLengthIn+5]))
  402. //if(1) //20210207 李伟修改 校验失误率很高所以去掉校验 后期需要重新查明原因
  403. //if(CRC_data==((USART2_RX_BUF[dataLengthIn+5]<<8)+USART2_RX_BUF[dataLengthIn+4]))
  404. //if(CRC_data==(((uint16_t)USART2_RX_BUF[22]<<8)+(uint16_t)USART2_RX_BUF[21])) //固定位置
  405. //if(CRC_data==CRC_data02)
  406. {
  407. Collect485.ErrorCode_Collect= USART2_RX_BUF[4];
  408. //__nop();
  409. Collect485.ValveState_Num1 = USART2_RX_BUF[5]; //开关状态 大小人孔盖,底泄阀状态
  410. Collect485.UnloadState_Num1 = USART2_RX_BUF[6]; //油仓油尽状态
  411. Collect485.ValveState_Num2 = USART2_RX_BUF[7];
  412. Collect485.UnloadState_Num2 = USART2_RX_BUF[8];
  413. Collect485.ValveState_Num3 = USART2_RX_BUF[9];
  414. Collect485.UnloadState_Num3 =USART2_RX_BUF[10];
  415. Collect485.ValveState_Num4 =USART2_RX_BUF[11];
  416. Collect485.UnloadState_Num4 =USART2_RX_BUF[12];
  417. Collect485.ValveState_Num5 =USART2_RX_BUF[13];
  418. Collect485.UnloadState_Num5 =USART2_RX_BUF[14];
  419. Collect485.ValveState_Num6 =USART2_RX_BUF[15];
  420. Collect485.UnloadState_Num6 =USART2_RX_BUF[16];
  421. Collect485.ValveState_Num7 =USART2_RX_BUF[17];
  422. Collect485.UnloadState_Num7 =USART2_RX_BUF[18];
  423. Collect485.ValveState_Num8 =USART2_RX_BUF[19];
  424. Collect485.UnloadState_Num8 =USART2_RX_BUF[20];
  425. //HAL_GPIO_TogglePin(GPIOE,LED1_Pin);
  426. //ValStateConvertTo91();
  427. // __nop();
  428. }
  429. break;
  430. case 0xA2://Read Needed Sensor Value
  431. switch(USART2_RX_BUF[4])
  432. {
  433. case 1://Press expressed volume 体积 容积
  434. //if(CRC_data==((USART2_RX_BUF[dataLengthIn+4]<<8)+USART2_RX_BUF[dataLengthIn+5]))
  435. //if(CRC_data==CRC_data02)
  436. {
  437. Stor[0].Volume=((USART2_RX_BUF[5]<<8)|USART2_RX_BUF[6]);
  438. Stor[1].Volume=((USART2_RX_BUF[7]<<8)|USART2_RX_BUF[8]);
  439. Stor[2].Volume=((USART2_RX_BUF[9]<<8)|USART2_RX_BUF[10]);
  440. Stor[3].Volume=((USART2_RX_BUF[11]<<8)|USART2_RX_BUF[12]);
  441. Stor[4].Volume=((USART2_RX_BUF[13]<<8)|USART2_RX_BUF[14]);
  442. Stor[5].Volume=((USART2_RX_BUF[15]<<8)|USART2_RX_BUF[16]);
  443. Stor[6].Volume=((USART2_RX_BUF[17]<<8)|USART2_RX_BUF[18]);
  444. Stor[7].Volume=((USART2_RX_BUF[19]<<8)|USART2_RX_BUF[20]);
  445. //uni_TankVol_Tempe20_001.flo_Data=Stor[0].Volume; //调试用
  446. uni_TankVol_Realtime001.flo_Data=Stor[0].Volume;
  447. uni_TankVol_Realtime002.flo_Data=Stor[1].Volume;
  448. uni_TankVol_Realtime003.flo_Data=Stor[2].Volume;
  449. uni_TankVol_Realtime004.flo_Data=Stor[3].Volume;
  450. // if((pT2C_SetupData->Reserved_parameters_4>1.5f) || (pT2C_SetupData->Reserved_parameters_4<0.2f))
  451. // {//Reserved_parameters_4==2.0 使用采集器传来的Vt 体积
  452. //
  453. //
  454. // }else
  455. // {
  456. // uni_TankVol_Realtime001.flo_Data=pT2C_SetupData->Capacity_Vt; //采用平台下发数据
  457. // }
  458. //
  459. }
  460. break;
  461. case 2://yewei 液位
  462. // if(CRC_data==((USART2_RX_BUF[dataLengthIn+4]<<8)+USART2_RX_BUF[dataLengthIn+5]))
  463. {
  464. if(TypeOf_YeWeiJi==0x01)//磁致伸缩液位计
  465. {
  466. Stor[0].yewei[0]=(USART2_RX_BUF[5]<<8)|USART2_RX_BUF[6];
  467. Stor[1].yewei[0]=(USART2_RX_BUF[7]<<8)|USART2_RX_BUF[8];
  468. Stor[2].yewei[0]=(USART2_RX_BUF[9]<<8)|USART2_RX_BUF[10];
  469. Stor[3].yewei[0]=(USART2_RX_BUF[11]<<8)|USART2_RX_BUF[12];
  470. Stor[4].yewei[0]=(USART2_RX_BUF[13]<<8)|USART2_RX_BUF[14];
  471. Stor[5].yewei[0]=(USART2_RX_BUF[15]<<8)|USART2_RX_BUF[16];
  472. Stor[6].yewei[0]=(USART2_RX_BUF[17]<<8)|USART2_RX_BUF[18];
  473. Stor[7].yewei[0]=(USART2_RX_BUF[19]<<8)|USART2_RX_BUF[20];
  474. }
  475. else if(TypeOf_YeWeiJi==0x02)//02————雷达液位计
  476. {
  477. Stor[0].yewei[0]=(USART2_RX_BUF[5]<<8)|USART2_RX_BUF[6];
  478. Stor[1].yewei[0]=(USART2_RX_BUF[7]<<8)|USART2_RX_BUF[8];
  479. Stor[2].yewei[0]=(USART2_RX_BUF[9]<<8)|USART2_RX_BUF[10];
  480. Stor[3].yewei[0]=(USART2_RX_BUF[11]<<8)|USART2_RX_BUF[12];
  481. Stor[4].yewei[0]=(USART2_RX_BUF[13]<<8)|USART2_RX_BUF[14];
  482. Stor[5].yewei[0]=(USART2_RX_BUF[15]<<8)|USART2_RX_BUF[16];
  483. Stor[6].yewei[0]=(USART2_RX_BUF[17]<<8)|USART2_RX_BUF[18];
  484. Stor[7].yewei[0]=(USART2_RX_BUF[19]<<8)|USART2_RX_BUF[20];
  485. }
  486. else
  487. {
  488. Stor[0].yewei[0]=(USART2_RX_BUF[5]<<8)|USART2_RX_BUF[6];
  489. Stor[1].yewei[0]=(USART2_RX_BUF[7]<<8)|USART2_RX_BUF[8];
  490. Stor[2].yewei[0]=(USART2_RX_BUF[9]<<8)|USART2_RX_BUF[10];
  491. Stor[3].yewei[0]=(USART2_RX_BUF[11]<<8)|USART2_RX_BUF[12];
  492. Stor[4].yewei[0]=(USART2_RX_BUF[13]<<8)|USART2_RX_BUF[14];
  493. Stor[5].yewei[0]=(USART2_RX_BUF[15]<<8)|USART2_RX_BUF[16];
  494. Stor[6].yewei[0]=(USART2_RX_BUF[17]<<8)|USART2_RX_BUF[18];
  495. Stor[7].yewei[0]=(USART2_RX_BUF[19]<<8)|USART2_RX_BUF[20];
  496. }
  497. //20210305液位精度数据保留一位小数,精度为0.1mm 李伟修改
  498. for(i007=0;i007<8;i007++)
  499. {
  500. Stor[i007].yewei_flo[0]=Stor[i007].yewei[0]*SCL_Yewei_Collect2Contr;//
  501. }
  502. uni_YeweiToPlatForm001.flo_Data=Stor[0].yewei_flo[0];//yewei[0]*SCL_Yewei_Collect2Contr;
  503. uni_LiqLev001.flo_Data=Stor[0].yewei_flo[0];//yewei[0]*SCL_Yewei_Collect2Contr;
  504. uni_LiqLev002.flo_Data=Stor[1].yewei_flo[0];
  505. uni_LiqLev003.flo_Data=Stor[2].yewei_flo[0];
  506. uni_LiqLev004.flo_Data=Stor[3].yewei_flo[0];
  507. //UpdateWenYouFifo();//稳油判断数据更新
  508. }
  509. break;
  510. case 3://Temppreture 温度 温度传感器
  511. //CRC_data=CRC16_MODBUS(USART2_RX_BUF, 16+5);//dataLengthIn
  512. //if(CRC_data==((USART2_RX_BUF[21]<<8)+USART2_RX_BUF[22]))
  513. //if(1)
  514. { //温度参数校验开始
  515. //三个温度传感器的数据依次为罐车中的高中低——也就是先发送最短的探杆,接着中间的探杆,最后是最长的探杆
  516. //20201216;16位有符号整型数据
  517. Stor[0].Temperature=(signed short)((USART2_RX_BUF[5]<<8)|USART2_RX_BUF[6]);
  518. Stor[1].Temperature=(signed short)((USART2_RX_BUF[7]<<8)|USART2_RX_BUF[8]);
  519. Stor[2].Temperature=(signed short)((USART2_RX_BUF[9]<<8)|USART2_RX_BUF[10]);
  520. Stor[3].Temperature=(signed short)((USART2_RX_BUF[11]<<8)|USART2_RX_BUF[12]);
  521. Stor[4].Temperature=(signed short)((USART2_RX_BUF[13]<<8)|USART2_RX_BUF[14]);
  522. Stor[5].Temperature=(signed short)((USART2_RX_BUF[15]<<8)|USART2_RX_BUF[16]);
  523. Stor[6].Temperature=(signed short)((USART2_RX_BUF[17]<<8)|USART2_RX_BUF[18]);
  524. Stor[7].Temperature=(signed short)((USART2_RX_BUF[19]<<8)|USART2_RX_BUF[20]);
  525. //20210226同康达林商量之后,决定:温度传感器的解析在采集器完成但是不用除以10,直接以int16格式发给控制器
  526. //因为考虑到温度精度最好达到0.1度,所以采集器不用除以10,除以10的操作放在控制器上实现
  527. //李伟修改20210226
  528. for(i007=0;i007<8;i007++)
  529. {
  530. Stor[i007].Temperature=Stor[i007].Temperature*SCL_Temp_Collect2Contr;//
  531. }
  532. uni_temper001.flo_Data=Stor[0].Temperature;//默认取第一个温度传感器的数据
  533. //李伟修改 20210428 根据平台下发的命令的p3参数决定取哪一个温度作为体积修正的 参考
  534. if(fabs(pT2C_SetupData->Reserved_parameters_3-1.0f)<0.2f)
  535. {
  536. uni_temper001.flo_Data=Stor[0].Temperature;//默认取第一个温度传感器的数据
  537. }
  538. if(fabs(pT2C_SetupData->Reserved_parameters_3-2.0f)<0.2f)
  539. {
  540. uni_temper001.flo_Data=Stor[1].Temperature;//取第2个温度传感器的数据
  541. }
  542. if(fabs(pT2C_SetupData->Reserved_parameters_3-3.0f)<0.2f)
  543. {
  544. uni_temper001.flo_Data=Stor[2].Temperature;//取第3个温度传感器的数据
  545. }
  546. if(fabs(pT2C_SetupData->Reserved_parameters_4-1.0f)<0.2f)
  547. {//Reserved_parameters_4==1.0 使用平台上手工输入的温度
  548. uni_temper001.flo_Data=pT2C_SetupData->temperature;//uni_TempRealtime001.flo_Data;
  549. }
  550. //按键输入温度的xx分钟之内,强制取值为键盘输入的温度
  551. if(tmrForTemp_ManualInput>5)
  552. {
  553. uni_temper001.flo_Data=uni_TempRealtime001.flo_Data;
  554. }
  555. uni_temper001.flo_Data=uni_temper001.flo_Data*SCL_Air_To_Oil;
  556. if(TypeOf_YeWeiJi==0x02)//雷达液位计的0808车,将其补偿为65度左右
  557. {
  558. //如果柴油车的温度大于10度则判定为装油,而且装的是0#柴油,需要加热。
  559. ///*
  560. if(uni_temper001.flo_Data>9.99f)
  561. {
  562. ;//uni_temper001.flo_Data=uni_temper001.flo_Data+Offset_diesel;
  563. }
  564. //*/
  565. }
  566. if(uni_temper001.flo_Data>Max_Oil_Tempe)
  567. {
  568. uni_temper001.flo_Data=Max_Oil_Tempe;//限幅滤波
  569. }
  570. if(uni_temper001.flo_Data<Min_Oil_Tempe)
  571. {
  572. uni_temper001.flo_Data=Min_Oil_Tempe;
  573. }
  574. //第4个参数为1或者3,强制上传平台下发的温度数据
  575. if((fabs(pT2C_SetupData->Reserved_parameters_4-3.0f)<0.2f ) || \
  576. (fabs(pT2C_SetupData->Reserved_parameters_4-1.0f)<0.2f) )
  577. {
  578. uni_temper001.flo_Data=pT2C_SetupData->temperature;//temperature;
  579. Stor[0].Temperature=(signed short)uni_temper001.flo_Data;
  580. Stor[1].Temperature=(signed short)uni_temper001.flo_Data;
  581. Stor[2].Temperature=(signed short)uni_temper001.flo_Data;
  582. }
  583. //按键输入温度的XX分钟之内,强制取值为键盘输入的温度
  584. //如果有手工输入则强制采用手工输入温度
  585. if(tmrForTemp_ManualInput>5)
  586. {
  587. uni_temper001.flo_Data=uni_TempRealtime001.flo_Data;
  588. Stor[0].Temperature=(signed short)uni_temper001.flo_Data;
  589. //srand(xTaskGetTickCount()); //gSystickMsecCount这个值是在Systick中断中计数的变量
  590. Stor[1].Temperature=(signed short)uni_temper001.flo_Data+(rand() % 100)*0.001f;;
  591. Stor[2].Temperature=(signed short)uni_temper001.flo_Data+(rand() % 100)*0.001f;;
  592. }
  593. //三点式温度传感器赋值
  594. for(i007=0;i007<3;i007++)
  595. {
  596. ArrOfTempeSensor_Flo[i007]=Stor[i007].Temperature;//Stor[i007].Temperature*SCL_Temp_Collect2Contr;//
  597. }
  598. }//温度参数校验结束
  599. break;
  600. case 4://倾角 角度
  601. Stor[0].QingJiao=(int16_t)(((USART2_RX_BUF[5]<<8)|USART2_RX_BUF[6]));
  602. Stor[1].QingJiao=(int16_t)(((USART2_RX_BUF[7]<<8)|USART2_RX_BUF[8]));
  603. Stor[2].QingJiao=(int16_t)((USART2_RX_BUF[9]<<8)|USART2_RX_BUF[10]);
  604. Stor[3].QingJiao=(int16_t)((USART2_RX_BUF[11]<<8)|USART2_RX_BUF[12]);
  605. Stor[4].QingJiao=(int16_t)((USART2_RX_BUF[13]<<8)|USART2_RX_BUF[14]);
  606. Stor[5].QingJiao=(int16_t)((USART2_RX_BUF[15]<<8)|USART2_RX_BUF[16]);
  607. Stor[6].QingJiao=(int16_t)((USART2_RX_BUF[17]<<8)|USART2_RX_BUF[18]);
  608. Stor[7].QingJiao=(int16_t)((USART2_RX_BUF[19]<<8)|USART2_RX_BUF[20]);
  609. Stor[0].QingJiaoFlo=(float)(Stor[0].QingJiao*SCL_Angle*1);
  610. Stor[1].QingJiaoFlo=(float)(Stor[1].QingJiao*SCL_Angle*1);//180/32768;
  611. uni_QingJiao001.flo_Data=Stor[0].QingJiaoFlo;
  612. uni_QingJiao002.flo_Data=Stor[1].QingJiaoFlo;
  613. if((uni_QingJiao001.flo_Data>300) || (uni_QingJiao001.flo_Data<-10))
  614. {
  615. ;//uni_QingJiao001.flo_Data=0.34;
  616. }
  617. break;
  618. case 5://压力
  619. Stor[0].Temperature=Switch_Byte4_To_Float(USART2_RX_BUF+4);
  620. Stor[1].Temperature=Switch_Byte4_To_Float(USART2_RX_BUF+8);
  621. Stor[2].Temperature=Switch_Byte4_To_Float(USART2_RX_BUF+12);
  622. Stor[3].Temperature=Switch_Byte4_To_Float(USART2_RX_BUF+16);
  623. uni_GasPressure001.flo_Data=Stor[0].Temperature;
  624. break;
  625. default:
  626. break;
  627. }
  628. break;
  629. case 0xA3://Write StoreNum
  630. Collect485.Write_StorNum=USART2_RX_BUF[4];
  631. break;
  632. case 0xA4:
  633. break;
  634. case 0xA5:
  635. break;
  636. default:
  637. break;
  638. }////////switch(TempData)--结束
  639. //memset(USART2_RX_BUF, 0x00, 50); //清除接收缓存前50个数据
  640. }
  641. return DataReturn;
  642. }
  643. else
  644. {
  645. Usart2_ErrorTimes++;
  646. return 0;
  647. }
  648. }
  649. void ReadCollect_ValveState_TX(void)
  650. {////读取阀门状态
  651. uint16_t CRC_dataTX;
  652. memset(USART2_TX_BUF,0,20); //清除发送缓存前20个数据
  653. USART2_TX_BUF[0]=FrameHeader_Collect;
  654. USART2_TX_BUF[1]=EquipmentNum_Collect;
  655. USART2_TX_BUF[2]=ValveState_Fuction;
  656. USART2_TX_BUF[3]=0;
  657. CRC_dataTX=CRC16_MODBUS(USART2_TX_BUF,4);
  658. USART2_TX_BUF[5]=CRC_dataTX&0xFF;//低位在后;
  659. USART2_TX_BUF[4]=(CRC_dataTX>>8)&0xFF;//高位在前;
  660. CollectMaster485_Send_Data(USART2_TX_BUF,6);
  661. }
  662. /*
  663. 采集器按照新的协议发送64字节给控制板
  664. AA 00 10 01 01 FD 8D
  665. 最后两个字节为CRC校验
  666. 5个参数分别为:
  667. 功能码,读取寄存器或者写入寄存器---取自国标只能为0003、0006或者0010
  668. 寄存器起始地址----实际代表操作某一个外设,比如卸油阀或者海底阀、人孔盖等
  669. 寄存器个数,后边3个参数的总字节数,不包括校验位
  670. 附加码1,仓号或者传感器的485地址;读取阀门数据时的附加参数,表示仓位编号、卸油阀的485地址、外购传感器的485地址等数据
  671. 附加码2,设置卸油阀门限参数时的ADC等
  672. */
  673. void ReadCollect_ValveState_64Byte(uint16_t para001_RegOP_Code,uint16_t para002_RegAddrStart,
  674. uint16_t para003_RegNum,uint16_t para004_LegacyAddr,uint16_t para005_Fujia001)
  675. {
  676. uint16_t CRC_dataTX;
  677. memset(USART2_TX_BUF,0,64); //清除发送缓存前64个数据
  678. // USART2_TX_BUF[0]=FrameHeader_Collect;
  679. // USART2_TX_BUF[1]=EquipmentNum_Collect;
  680. // USART2_TX_BUF[2]=Get_IO_State_New64Byte;//ValveState_Fuction;
  681. // USART2_TX_BUF[3]=01;//此后的数据长度,不包括校验位
  682. // USART2_TX_BUF[4]=CangNum;//仓号,取值范围为1--8
  683. //
  684. // CRC_dataTX=CRC16_MODBUS(USART2_TX_BUF,5);
  685. // USART2_TX_BUF[6]=CRC_dataTX&0xFF;//低位在后;
  686. // USART2_TX_BUF[5]=(CRC_dataTX>>8)&0xFF;//高位在前;
  687. // CollectMaster485_Send_Data(USART2_TX_BUF,7);
  688. USART2_TX_BUF[0]=FrameHeader_Collect02;
  689. USART2_TX_BUF[1]=EquipmentNum_Collect02;
  690. USART2_TX_BUF[2]=0x95;
  691. USART2_TX_BUF[3]=0x50;
  692. USART2_TX_BUF[4]=0x00;
  693. USART2_TX_BUF[5]=0x01;
  694. //功能码,读取寄存器或者写入寄存器---取自国标只能为0003、0006或者0010
  695. USART2_TX_BUF[6]=para001_RegOP_Code>>8;//0x00;
  696. USART2_TX_BUF[7]=(para001_RegOP_Code & 0xff);//0x03; //////读取
  697. //////para002------------
  698. USART2_TX_BUF[8]=para002_RegAddrStart>>8;//0x00;
  699. USART2_TX_BUF[9]=para002_RegAddrStart & 0x00ff; //Get_Valve_State;//0x20;//读取阀门状态
  700. //////para003
  701. USART2_TX_BUF[10]=para003_RegNum>>8;//0x00;
  702. USART2_TX_BUF[11]=para003_RegNum & 0x00ff; //有效字节数
  703. USART2_TX_BUF[12]=0x95;
  704. USART2_TX_BUF[13]=0x01;//
  705. USART2_TX_BUF[14]=0xaa;
  706. USART2_TX_BUF[15]=0xaa; //
  707. //////para004仓号或者传感器的485地址
  708. USART2_TX_BUF[16]=para004_LegacyAddr>>8;//0;//仓号,取值范围为1--8
  709. USART2_TX_BUF[17]=para004_LegacyAddr & 0x00ff;//仓号,取值范围为1--8
  710. //////para005设置卸油阀门限时的ADC值
  711. USART2_TX_BUF[18]=para005_Fujia001>>8;//0;//
  712. USART2_TX_BUF[19]=para005_Fujia001 & 0x00ff;//
  713. CRC_dataTX=CRC16_MODBUS(USART2_TX_BUF,62);
  714. USART2_TX_BUF[62]=CRC_dataTX&0xFF;//低位在后;
  715. USART2_TX_BUF[63]=(CRC_dataTX>>8)&0xFF;//高位在前;
  716. CollectMaster485_Send_Data(USART2_TX_BUF,64);
  717. }
  718. //从采集器读取液位数据
  719. void ReadCollect_YeWei_TX(void)
  720. {
  721. uint16_t CRC_dataTX;
  722. //memset(USART2_TX_BUF,0,20); //清除发送缓存前20个数据
  723. USART2_TX_BUF[0]=FrameHeader_Collect;
  724. USART2_TX_BUF[1]=EquipmentNum_Collect;
  725. USART2_TX_BUF[2]=SensorValue_Function;
  726. USART2_TX_BUF[3]=1;
  727. USART2_TX_BUF[4]=Read_YeWei;
  728. CRC_dataTX=CRC16_MODBUS(USART2_TX_BUF,5);
  729. USART2_TX_BUF[6]=CRC_dataTX&0xFF;//低位在后;
  730. USART2_TX_BUF[5]=(CRC_dataTX>>8)&0xFF;//高位在前;
  731. CollectMaster485_Send_Data(USART2_TX_BUF,7);
  732. }
  733. void ReadCollect_QingJiao_TX(void)
  734. {//从采集器读取倾角数据
  735. uint16_t CRC_dataTX;
  736. //memset(USART2_TX_BUF,0,20); //清除发送缓存前20个数据
  737. USART2_TX_BUF[0]=FrameHeader_Collect;
  738. USART2_TX_BUF[1]=EquipmentNum_Collect;
  739. USART2_TX_BUF[2]=SensorValue_Function;
  740. USART2_TX_BUF[3]=1;
  741. USART2_TX_BUF[4]=Read_QingJiao;
  742. CRC_dataTX=CRC16_MODBUS(USART2_TX_BUF,5);
  743. USART2_TX_BUF[6]=CRC_dataTX&0xFF;//低位在后;
  744. USART2_TX_BUF[5]=(CRC_dataTX>>8)&0xFF;//高位在前;
  745. CollectMaster485_Send_Data(USART2_TX_BUF,7);
  746. }
  747. //设定液位传感器零点偏移数据,将数据下发给采集器,同步进行计算
  748. void Send_Yewei_offset_To_Collect(void)
  749. {
  750. uint16_t CRC_dataTX;
  751. //memset(USART2_TX_BUF,0,20); //清除发送缓存前20个数据
  752. // USART2_TX_BUF[0]=FrameHeader_Collect;
  753. // USART2_TX_BUF[1]=EquipmentNum_Collect;
  754. // USART2_TX_BUF[3]=2;//去除帧头,功能码等;有效数据长度
  755. //
  756. // USART2_TX_BUF[2]=SetPara_Yewei_Offset;
  757. // USART2_TX_BUF[4]=FM25L16B_ReadByte(44);
  758. // USART2_TX_BUF[5]=FM25L16B_ReadByte(45);
  759. // CRC_dataTX=CRC16_MODBUS(USART2_TX_BUF,6);
  760. // USART2_TX_BUF[6]=CRC_dataTX&0xFF;//低位在后;
  761. // USART2_TX_BUF[7]=(CRC_dataTX>>8)&0xFF;//高位在前;
  762. // CollectMaster485_Send_Data(USART2_TX_BUF,7+1);
  763. //20210128经同龚经理商议后,按照磁致伸缩液位仪同样的方式进行零偏修正。
  764. //控制板发送两个参数给采集器,每个参数均为有符号16位;共计4字节
  765. //本帧命令总长度由之前的8字节变更为10字节
  766. //
  767. USART2_TX_BUF[0]=FrameHeader_Collect;
  768. USART2_TX_BUF[1]=EquipmentNum_Collect;
  769. USART2_TX_BUF[2]=SetPara_Yewei_Offset;
  770. USART2_TX_BUF[3]=4;//去除帧头,功能码等;有效数据长度
  771. // USART2_TX_BUF[4]=FM25L16B_ReadByte(44);
  772. // USART2_TX_BUF[5]=FM25L16B_ReadByte(45);
  773. // USART2_TX_BUF[6]=FM25L16B_ReadByte(46);
  774. // USART2_TX_BUF[7]=FM25L16B_ReadByte(47);
  775. // USART2_TX_BUF[4]=FM25L16B_ReadByte(ADDR_Zero_Of_LiquidMeter+0);
  776. // USART2_TX_BUF[5]=FM25L16B_ReadByte(ADDR_Zero_Of_LiquidMeter+1);
  777. // USART2_TX_BUF[6]=FM25L16B_ReadByte(ADDR_Zero_Of_LiquidMeter+2);
  778. // USART2_TX_BUF[7]=FM25L16B_ReadByte(ADDR_Zero_Of_LiquidMeter+3);
  779. //李伟修改 将以下4行替换为上述4行 上述4行实际发送两个参数,一个是液位计零点,一个是罐容零点;之前FRAM中存储2字节int16,目前4字节浮点数
  780. USART2_TX_BUF[4]=OffsetYewei[0]>>8;
  781. USART2_TX_BUF[5]=OffsetYewei[0] & 0x00ff;
  782. USART2_TX_BUF[6]=OffsetTankCapacity[0]>>8;
  783. USART2_TX_BUF[7]=OffsetTankCapacity[0] & 0x00ff;
  784. //标罐之前将相关修正数据全部清零 20210129
  785. // USART2_TX_BUF[4]=0;//FM25L16B_ReadByte(44);
  786. // USART2_TX_BUF[5]=0;//FM25L16B_ReadByte(45);
  787. // USART2_TX_BUF[6]=0;//FM25L16B_ReadByte(46);
  788. // USART2_TX_BUF[7]=0;//FM25L16B_ReadByte(47);
  789. CRC_dataTX=CRC16_MODBUS(USART2_TX_BUF,8);
  790. USART2_TX_BUF[8]=CRC_dataTX&0xFF;//低位在后;
  791. USART2_TX_BUF[9]=(CRC_dataTX>>8)&0xFF;//高位在前;
  792. CollectMaster485_Send_Data(USART2_TX_BUF,7+1+2);
  793. }
  794. void ReadCollect_Press_TX(void)
  795. {//读取压力传感器
  796. uint16_t CRC_dataTX;
  797. //memset(USART2_TX_BUF,0,20); //清除发送缓存前20个数据
  798. USART2_TX_BUF[0]=FrameHeader_Collect;
  799. USART2_TX_BUF[1]=EquipmentNum_Collect;
  800. USART2_TX_BUF[2]=SensorValue_Function;
  801. USART2_TX_BUF[3]=1;
  802. USART2_TX_BUF[4]=Read_Press;
  803. CRC_dataTX=CRC16_MODBUS(USART2_TX_BUF,5);
  804. USART2_TX_BUF[6]=CRC_dataTX&0xFF;//低位在后;
  805. USART2_TX_BUF[5]=(CRC_dataTX>>8)&0xFF;//高位在前;
  806. CollectMaster485_Send_Data(USART2_TX_BUF,7);
  807. }
  808. void ReadCollect_Temperature_TX(void)
  809. {///*读取温度传感器数据*/
  810. uint16_t CRC_dataTX;
  811. // memset(USART2_TX_BUF,0,20); //清除发送缓存前20个数据
  812. USART2_TX_BUF[0]=FrameHeader_Collect;
  813. USART2_TX_BUF[1]=EquipmentNum_Collect;
  814. USART2_TX_BUF[2]=SensorValue_Function;
  815. USART2_TX_BUF[3]=1;
  816. USART2_TX_BUF[4]=Read_Temper;
  817. CRC_dataTX=CRC16_MODBUS(USART2_TX_BUF,5);
  818. USART2_TX_BUF[6]=CRC_dataTX&0xFF;//低位在后;
  819. USART2_TX_BUF[5]=(CRC_dataTX>>8)&0xFF;//高位在前;
  820. CollectMaster485_Send_Data(USART2_TX_BUF,7);
  821. }
  822. void WriteCollcet_Parameter(void)
  823. {
  824. uint16_t CRC_dataTX;
  825. //memset(USART2_TX_BUF,0,20); //清除发送缓存前20个数据
  826. USART2_TX_BUF[0]=FrameHeader_Collect;
  827. USART2_TX_BUF[1]=EquipmentNum_Collect;
  828. USART2_TX_BUF[2]=WriteStore_Function;
  829. USART2_TX_BUF[3]=6;
  830. USART2_TX_BUF[4]=StoreNumber;
  831. USART2_TX_BUF[5]=Config_info_all.ManHole_Big_info;
  832. USART2_TX_BUF[6]=Config_info_all.Dump_info;
  833. USART2_TX_BUF[7]=Config_info_all.HaiDiFa_info;
  834. USART2_TX_BUF[8]=0;
  835. USART2_TX_BUF[9]=0;
  836. CRC_dataTX=CRC16_MODBUS(USART2_TX_BUF,10);
  837. USART2_TX_BUF[11]=CRC_dataTX&0xFF;//低位在后;
  838. USART2_TX_BUF[10]=(CRC_dataTX>>8)&0xFF;//高位在前;
  839. CollectMaster485_Send_Data(USART2_TX_BUF,12);
  840. }
  841. void PlatformCalibrat_Collect(void)
  842. {
  843. uint16_t CRC_dataTX;
  844. // memset(USART2_TX_BUF,0,20); //清除发送缓存前20个数据
  845. USART2_TX_BUF[0]=FrameHeader_Collect;
  846. USART2_TX_BUF[1]=EquipmentNum_Collect;
  847. USART2_TX_BUF[2]=PlatformCal_Function;
  848. USART2_TX_BUF[3]=6;
  849. USART2_TX_BUF[4]=(PlatformCalibrat.Threshold_Angle>>8)&0xFF;//角度门限高八位
  850. USART2_TX_BUF[5]=PlatformCalibrat.Threshold_Angle&0xFF;//低八位
  851. USART2_TX_BUF[6]=(PlatformCalibrat.Times>>8)&0xFF;//Times
  852. USART2_TX_BUF[7]=PlatformCalibrat.Times&0xFF;
  853. USART2_TX_BUF[8]=(PlatformCalibrat.Reserve_Register>>8)&0xFF;//预留高
  854. USART2_TX_BUF[9]=PlatformCalibrat.Reserve_Register&0xFF;//预留低
  855. CRC_dataTX=CRC16_MODBUS(USART2_TX_BUF,10);
  856. USART2_TX_BUF[11]=CRC_dataTX&0xFF;//低位在后;
  857. USART2_TX_BUF[10]=(CRC_dataTX>>8)&0xFF;//高位在前;
  858. CollectMaster485_Send_Data(USART2_TX_BUF,12);
  859. }
  860. void PlatformRestart_Collect(void)
  861. {
  862. uint16_t CRC_dataTX;
  863. //memset(USART2_TX_BUF,0,20); //清除发送缓存前20个数据
  864. USART2_TX_BUF[0]=FrameHeader_Collect;
  865. USART2_TX_BUF[1]=EquipmentNum_Collect;
  866. USART2_TX_BUF[2]=PlatformRestartCllect;
  867. USART2_TX_BUF[3]=0;
  868. CRC_dataTX=CRC16_MODBUS(USART2_TX_BUF,4);
  869. USART2_TX_BUF[5]=CRC_dataTX&0xFF;//低位在后;
  870. USART2_TX_BUF[4]=(CRC_dataTX>>8)&0xFF;//高位在前;
  871. CollectMaster485_Send_Data(USART2_TX_BUF,6);
  872. }
  873. void Platform_SetOilStyle (void)//新增
  874. {
  875. uint16_t CRC_dataTX;
  876. //memset(USART2_TX_BUF,0,20); //清除发送缓存前20个数据
  877. USART2_TX_BUF[0]=FrameHeader_Collect;
  878. USART2_TX_BUF[1]=EquipmentNum_Collect;
  879. USART2_TX_BUF[2]=PlatformSetOilStyle;
  880. USART2_TX_BUF[3]=2;
  881. USART2_TX_BUF[4]=PlatformCalibrat.OilStyleStore;//仓号
  882. USART2_TX_BUF[5]=PlatformCalibrat.OilStyle;//油品
  883. CRC_dataTX=CRC16_MODBUS(USART2_TX_BUF,6);
  884. USART2_TX_BUF[7]=CRC_dataTX&0xFF;//低位在后;
  885. USART2_TX_BUF[6]=(CRC_dataTX>>8)&0xFF;//高位在前;
  886. CollectMaster485_Send_Data(USART2_TX_BUF,8);
  887. }
  888. void Platform_ExceptionHandling (void)//新增
  889. {//当采集器接收到异常数据标志,不再判断人孔盖状态,只上传全关数据
  890. uint16_t CRC_dataTX;
  891. // memset(USART2_TX_BUF,0,20); //清除发送缓存前20个数据
  892. USART2_TX_BUF[0]=FrameHeader_Collect;
  893. USART2_TX_BUF[1]=EquipmentNum_Collect;
  894. USART2_TX_BUF[2]=PlatformExceptionHandling;
  895. USART2_TX_BUF[3]=1;
  896. USART2_TX_BUF[4]=PlatformCalibrat.ErrorStore;
  897. USART2_TX_BUF[5]=PlatformCalibrat.ErrorStyle;
  898. CRC_dataTX=CRC16_MODBUS(USART2_TX_BUF,6);
  899. USART2_TX_BUF[7]=CRC_dataTX&0xFF;//低位在后;
  900. USART2_TX_BUF[6]=(CRC_dataTX>>8)&0xFF;//高位在前;
  901. CollectMaster485_Send_Data(USART2_TX_BUF,8);
  902. }
  903. void Immediate_Processing_Function(void)//新增
  904. {
  905. /*
  906. if(Set_CollectPara_Flag==True)////通过串口4设定采集板的参数
  907. {
  908. WriteCollcet_Parameter();
  909. HAL_Delay(80);
  910. if(CheckInFrame_Collect485(64,0)==0xA3)
  911. {
  912. Set_CollectPara_Flag=False;
  913. }
  914. else
  915. {
  916. WriteCollcet_Parameter();
  917. HAL_Delay(80);
  918. if(CheckInFrame_Collect485(64,0)==0xA3)
  919. {
  920. Set_CollectPara_Flag=False;
  921. }
  922. }
  923. }
  924. */
  925. if(PlatformCalibrat.StartCalibrat_Flag==True)
  926. {///通过终端---设定采集板的参数
  927. PlatformCalibrat_Collect();
  928. //HAL_Delay(80);
  929. if(CheckInFrame_Collect485(64,0)==0xA4)
  930. {
  931. PlatformCalibrat.StartCalibrat_Flag=False;
  932. }
  933. else
  934. {
  935. PlatformCalibrat_Collect();
  936. //HAL_Delay(80);
  937. if(CheckInFrame_Collect485(64,0)==0xA4)
  938. {
  939. PlatformCalibrat.StartCalibrat_Flag=False;
  940. }
  941. }
  942. }///通过终端---设定采集板的参数
  943. /*
  944. if(PlatformCalibrat.Restart_Collect==True)
  945. {///通过终端---重启采集板
  946. PlatformRestart_Collect();
  947. HAL_Delay(100);
  948. PlatformCalibrat.Restart_Collect=False;
  949. if(CheckInFrame_Collect485(64,0)==0xA5)
  950. {
  951. PlatformCalibrat.Restart_Collect=False;
  952. }
  953. else
  954. {
  955. PlatformRestart_Collect();
  956. HAL_Delay(100);
  957. if(CheckInFrame_Collect485(64,0)==0xA5)
  958. {
  959. PlatformCalibrat.Restart_Collect=False;
  960. }
  961. }
  962. }///通过终端---重启采集板
  963. */
  964. if(PlatformCalibrat.SetOilStyleFlag==True)//新增
  965. {///通过按键---设定油品参数
  966. Platform_SetOilStyle();
  967. //HAL_Delay(100);
  968. if(CheckInFrame_Collect485(64,0)==0xA6)
  969. {
  970. PlatformCalibrat.SetOilStyleFlag=False;
  971. }
  972. else
  973. {
  974. Platform_SetOilStyle();
  975. //HAL_Delay(100);
  976. if(CheckInFrame_Collect485(64,0)==0xA6)
  977. {
  978. PlatformCalibrat.SetOilStyleFlag=False;
  979. }
  980. }
  981. }///通过按键---设定油品参数
  982. if(PlatformCalibrat.ErrorFlag==True)//新增
  983. {////当采集器接收到异常数据标志,不再判断人孔盖状态,只上传全关数据
  984. Platform_ExceptionHandling();
  985. //HAL_Delay(100);
  986. if(CheckInFrame_Collect485(64,0)==0xA7)
  987. {
  988. PlatformCalibrat.ErrorFlag=False;
  989. }
  990. else
  991. {
  992. Platform_ExceptionHandling();
  993. //HAL_Delay(100);
  994. if(CheckInFrame_Collect485(64,0)==0xA7)
  995. {
  996. PlatformCalibrat.ErrorFlag=False;
  997. }
  998. }
  999. }//当采集器接收到异常数据标志,不再判断人孔盖状态,只上传全关数据
  1000. }
  1001. //0x0190修改液位计零点
  1002. void ReadAllStoreValue(void)//控制板读取采集板的数据
  1003. {
  1004. // int j001ReadAll;
  1005. uint16_t msgID;
  1006. if(Usart2_ErrorTimes>=Max_Usart2_ErrorTime)//485总线没有数据传输,默认从机有问题,6S
  1007. {
  1008. Collect485.Collect_CommError=True;
  1009. }
  1010. cnt000++;
  1011. if(cnt000>=3600)
  1012. {
  1013. cnt000=0;
  1014. }
  1015. StoreNumber00=(cnt000 % StoreNumber)+1;
  1016. #if(New236Byte_En_0x1121)
  1017. if((cnt000%10==5) ||(cnt000%2==0))//一次性读取4仓所有传感器信息 每间隔5秒读取一次
  1018. {
  1019. Get_All_Moniliang_Data_4Cang(0);
  1020. __NOP();
  1021. }
  1022. #endif
  1023. #if(New150Byte_En_0x1193)
  1024. //新增的150字节传输每仓所有传感器的协议,一帧数据中传输每仓铅封、IO、模拟量数据
  1025. switch (StoreNumber00)
  1026. {
  1027. case 1:
  1028. ;//
  1029. ReadCollect_ValveState_64Byte(0x000003,Collector_Get_All_Sensor_Data_Cang01,0x0000,0x0000,0x0000);
  1030. msgID=Collector_Get_All_Sensor_Data_Cang01;
  1031. pT2C_ALL_Sensor_Data=&T2C_ALL_Sensor_Data01;
  1032. uni_YeweiToPlatForm001.flo_Data=T2C_ALL_Sensor_Data01.MoniLiang_Data_Every_Cang[0]*SCL_ControllToPlatForm;
  1033. // __NOP();
  1034. break;
  1035. case 2:
  1036. ReadCollect_ValveState_64Byte(0x000003,Collector_Get_All_Sensor_Data_Cang02,0x0000,0x0000,0x0000);
  1037. msgID=Collector_Get_All_Sensor_Data_Cang02;
  1038. pT2C_ALL_Sensor_Data=&T2C_ALL_Sensor_Data02;
  1039. uni_YeweiToPlatForm002.flo_Data=T2C_ALL_Sensor_Data02.MoniLiang_Data_Every_Cang[0]*SCL_ControllToPlatForm;
  1040. //__NOP();
  1041. break;
  1042. case 3:
  1043. ReadCollect_ValveState_64Byte(0x000003,Collector_Get_All_Sensor_Data_Cang03,0x0000,0x0000,0x0000);
  1044. msgID=Collector_Get_All_Sensor_Data_Cang03;
  1045. pT2C_ALL_Sensor_Data=&T2C_ALL_Sensor_Data03;
  1046. uni_YeweiToPlatForm003.flo_Data=T2C_ALL_Sensor_Data03.MoniLiang_Data_Every_Cang[0]*SCL_ControllToPlatForm;
  1047. //__NOP();
  1048. break;
  1049. case 4:
  1050. ReadCollect_ValveState_64Byte(0x000003,Collector_Get_All_Sensor_Data_Cang04,0x0000,0x0000,0x0000);
  1051. msgID=Collector_Get_All_Sensor_Data_Cang04;
  1052. pT2C_ALL_Sensor_Data=&T2C_ALL_Sensor_Data04;
  1053. uni_YeweiToPlatForm004.flo_Data=T2C_ALL_Sensor_Data04.MoniLiang_Data_Every_Cang[0]*SCL_ControllToPlatForm;
  1054. //__NOP();
  1055. break;
  1056. case 5:
  1057. ReadCollect_ValveState_64Byte(0x000003,Collector_Get_All_Sensor_Data_Cang05,0x0000,0x0000,0x0000);
  1058. msgID=Collector_Get_All_Sensor_Data_Cang05;
  1059. pT2C_ALL_Sensor_Data=&T2C_ALL_Sensor_Data05;
  1060. //__NOP();
  1061. break;
  1062. case 6:
  1063. ReadCollect_ValveState_64Byte(0x000003,Collector_Get_All_Sensor_Data_Cang06,0x0000,0x0000,0x0000);
  1064. msgID=Collector_Get_All_Sensor_Data_Cang06;
  1065. pT2C_ALL_Sensor_Data=&T2C_ALL_Sensor_Data06;
  1066. //__NOP();
  1067. break;
  1068. case 7:
  1069. ReadCollect_ValveState_64Byte(0x000003,Collector_Get_All_Sensor_Data_Cang07,0x0000,0x0000,0x0000);
  1070. msgID=Collector_Get_All_Sensor_Data_Cang07;
  1071. pT2C_ALL_Sensor_Data=&T2C_ALL_Sensor_Data07;
  1072. //__NOP();
  1073. break;
  1074. case 8:
  1075. ReadCollect_ValveState_64Byte(0x000003,Collector_Get_All_Sensor_Data_Cang08,0x0000,0x0000,0x0000);
  1076. msgID=Collector_Get_All_Sensor_Data_Cang08;
  1077. pT2C_ALL_Sensor_Data=&T2C_ALL_Sensor_Data08;
  1078. //__NOP();
  1079. break;
  1080. default :
  1081. //__NOP();
  1082. break;
  1083. }
  1084. // HAL_GPIO_TogglePin(GPIOC, DWI_Pin);//复位看门狗sp706
  1085. //HAL_Delay(SPAN_ControllerAndCollector_INTERVAL);
  1086. //osDelay(SPAN_ControllerAndCollector_INTERVAL_180);
  1087. //if((chkRetCaiJiBan==msgID) || (1==1))
  1088. {
  1089. //__NOP();
  1090. Parse_AllSensor_Data_For_SingleStore(pT2C_ALL_Sensor_Data,msgID);
  1091. //__NOP();
  1092. }
  1093. #endif
  1094. #if(New64Byte_En_0x0020)
  1095. //依次读取每个仓的数据
  1096. ReadCollect_ValveState_64Byte(0x000003,Collector_Get_Valve_State,0x0002,StoreNumber00,0x0000);
  1097. // HAL_GPIO_TogglePin(GPIOC, DWI_Pin);//复位看门狗sp706
  1098. //HAL_Delay(SPAN_ControllerAndCollector_INTERVAL);//100ms会导致命令来不及回复!!!!必须要200ms!!!!!!---20210728
  1099. //osDelay(SPAN_ControllerAndCollector_INTERVAL_120);
  1100. Parse_0x0020_Data_64Byte();
  1101. #endif
  1102. #if(New64Byte_En_0x0013)
  1103. //读取阀门状态
  1104. // ReadCollect_ValveState_TX();
  1105. //按照老的格式读取之前的阀门状态----多个阀门状态或运算之后进行铅封业务运算
  1106. ReadCollect_ValveState_64Byte(0x000003,Collector_Get_Valve_OldFormat,0x0002,0x0000,0x0000);
  1107. // HAL_GPIO_TogglePin(GPIOC, DWI_Pin);//复位看门狗sp706
  1108. //HAL_Delay(SPAN_ControllerAndCollector_INTERVAL);
  1109. //osDelay(SPAN_ControllerAndCollector_INTERVAL_120);
  1110. Parse_0x0013_Data();
  1111. #endif
  1112. #if(New80Byte_En_0x119B) //读取整车传感器数据
  1113. if((cnt000%10==0))//读取整车传感器数据(cnt000%10==5) ||
  1114. {
  1115. ReadCollect_ValveState_64Byte(0x000003,Collector_Get_All_Sensor_Data_WholeCar,0x0002,0x0000,0x0000);
  1116. // HAL_GPIO_TogglePin(GPIOC, DWI_Pin);//复位看门狗sp706
  1117. //HAL_Delay(SPAN_ControllerAndCollector_INTERVAL);
  1118. //osDelay(SPAN_ControllerAndCollector_INTERVAL_120);
  1119. msgID=Collector_Get_All_Sensor_Data_WholeCar;
  1120. Parse_AllSensor_Data_For_WholeCar(pT2C_ALL_Sensor_WholeCar,msgID,ALL_Sensor_Data_Num_WholeCar);
  1121. __NOP();
  1122. }
  1123. #endif
  1124. //*/
  1125. /*
  1126. if(Usart2_ErrorTimes>=Max_Usart2_ErrorTime)//485总线没有数据传输,默认从机有问题,6S
  1127. {
  1128. Collect485.Collect_CommError=True;
  1129. }
  1130. */
  1131. }
  1132. uint8_t Collect458_bus[8]={0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55};
  1133. uint8_t HDF_cnt[8]={0},XYF_cnt[8]={0};
  1134. /*
  1135. 13读取的数据作为铅封流程的判断
  1136. 1s钟转换一次
  1137. */
  1138. void CollectData_Transform_UsefullData(void)//实时数据转换
  1139. {
  1140. uint8_t i;
  1141. /* 人孔盖 */
  1142. Stor[0].stat[0] = ((Collect485.ValveState_Num1&0x02)>>1);//1仓人孔小盖
  1143. Stor[0].stat[1] = ((Collect485.ValveState_Num1&0x01)>>0);//1仓人孔大盖
  1144. Stor[1].stat[0] = ((Collect485.ValveState_Num2&0x02)>>1);//2仓人孔小盖
  1145. Stor[1].stat[1] = ((Collect485.ValveState_Num2&0x01)>>0);//2仓人孔大盖
  1146. Stor[2].stat[0] = ((Collect485.ValveState_Num3&0x02)>>1);//3仓人孔小盖
  1147. Stor[2].stat[1] = ((Collect485.ValveState_Num3&0x01)>>0);//3仓人孔大盖
  1148. Stor[3].stat[0] = ((Collect485.ValveState_Num4&0x02)>>1);//4仓人孔小盖
  1149. Stor[3].stat[1] = ((Collect485.ValveState_Num4&0x01)>>0);//4仓人孔大盖
  1150. Stor[4].stat[0] = ((Collect485.ValveState_Num5&0x02)>>1);//5仓人孔小盖
  1151. Stor[4].stat[1] = ((Collect485.ValveState_Num5&0x01)>>0);//5仓人孔大盖
  1152. Stor[5].stat[0] = ((Collect485.ValveState_Num6&0x02)>>1);//6仓人孔小盖
  1153. Stor[5].stat[1] = ((Collect485.ValveState_Num6&0x01)>>0);//6仓人孔大盖
  1154. Stor[6].stat[0] = ((Collect485.ValveState_Num7&0x02)>>1);//7仓人孔小盖
  1155. Stor[6].stat[1] = ((Collect485.ValveState_Num7&0x01)>>0);//7仓人孔大盖
  1156. Stor[7].stat[0] = ((Collect485.ValveState_Num8&0x02)>>1);//8仓人孔小盖
  1157. Stor[7].stat[1] = ((Collect485.ValveState_Num8&0x01)>>0);//8仓人孔大盖
  1158. /* 底 阀 */
  1159. Stor[0].hdf_state = ((Collect485.ValveState_Num1&0x04)>>2);//1仓底阀状态
  1160. Stor[1].hdf_state = ((Collect485.ValveState_Num2&0x04)>>2);//2仓底阀状态
  1161. Stor[2].hdf_state = ((Collect485.ValveState_Num3&0x04)>>2);//3仓底阀状态
  1162. Stor[3].hdf_state = ((Collect485.ValveState_Num4&0x04)>>2);//4仓底阀状态
  1163. Stor[4].hdf_state = ((Collect485.ValveState_Num5&0x04)>>2);//5仓底阀状态
  1164. Stor[5].hdf_state = ((Collect485.ValveState_Num6&0x04)>>2);//6仓底阀状态
  1165. Stor[6].hdf_state = ((Collect485.ValveState_Num7&0x04)>>2);//7仓底阀状态
  1166. Stor[7].hdf_state = ((Collect485.ValveState_Num8&0x04)>>2);//8仓底阀状态
  1167. /* 卸油阀 */
  1168. Stor[0].xyf_state = ((Collect485.ValveState_Num1&0x08)>>3);//1仓卸油阀状态
  1169. Stor[1].xyf_state = ((Collect485.ValveState_Num2&0x08)>>3);//2仓卸油阀状态
  1170. Stor[2].xyf_state = ((Collect485.ValveState_Num3&0x08)>>3);//3仓卸油阀状态
  1171. Stor[3].xyf_state = ((Collect485.ValveState_Num4&0x08)>>3);//4仓卸油阀状态
  1172. Stor[4].xyf_state = ((Collect485.ValveState_Num5&0x08)>>3);//5仓卸油阀状态
  1173. Stor[5].xyf_state = ((Collect485.ValveState_Num6&0x08)>>3);//6仓卸油阀状态
  1174. Stor[6].xyf_state = ((Collect485.ValveState_Num7&0x08)>>3);//7仓卸油阀状态
  1175. Stor[7].xyf_state = ((Collect485.ValveState_Num8&0x08)>>3);//8仓卸油阀状态
  1176. /* 卸尽 */
  1177. if((Collect485.UnloadState_Num1==1)&&(Collect485.Collect_CommError==False))
  1178. {
  1179. HAL_GPIO_WritePin(GPIOE, LED2_Pin, GPIO_PIN_RESET);
  1180. }
  1181. else if((Collect485.UnloadState_Num1==0)&&(Collect485.Collect_CommError==False))
  1182. {
  1183. HAL_GPIO_WritePin(GPIOE, LED2_Pin, GPIO_PIN_SET);
  1184. }
  1185. else if((Collect485.UnloadState_Num1==0x55)||(Collect485.Collect_CommError==True))
  1186. {
  1187. HAL_GPIO_TogglePin(GPIOE,LED2_Pin);
  1188. }
  1189. if((Collect485.UnloadState_Num2==1)&&(Collect485.Collect_CommError==False))
  1190. HAL_GPIO_WritePin(GPIOE, LED3_Pin, GPIO_PIN_RESET);
  1191. else if((Collect485.UnloadState_Num2==0)&&(Collect485.Collect_CommError==False))
  1192. HAL_GPIO_WritePin(GPIOE, LED3_Pin, GPIO_PIN_SET);
  1193. else if((Collect485.UnloadState_Num2==0x55)||(Collect485.Collect_CommError==True))
  1194. HAL_GPIO_TogglePin(GPIOE,LED3_Pin);
  1195. if((Collect485.UnloadState_Num3==1)&&(Collect485.Collect_CommError==False))
  1196. HAL_GPIO_WritePin(GPIOE, LED4_Pin, GPIO_PIN_RESET);
  1197. else if((Collect485.UnloadState_Num3==0)&&(Collect485.Collect_CommError==False))
  1198. HAL_GPIO_WritePin(GPIOE, LED4_Pin, GPIO_PIN_SET);
  1199. else if((Collect485.UnloadState_Num3==0x55)||(Collect485.Collect_CommError==True))
  1200. HAL_GPIO_TogglePin(GPIOE,LED4_Pin);
  1201. if((Collect485.UnloadState_Num4==1)&&(Collect485.Collect_CommError==False))
  1202. HAL_GPIO_WritePin(GPIOE, LED5_Pin, GPIO_PIN_RESET);
  1203. else if((Collect485.UnloadState_Num4==0)&&(Collect485.Collect_CommError==False))
  1204. HAL_GPIO_WritePin(GPIOE, LED5_Pin, GPIO_PIN_SET);
  1205. else if((Collect485.UnloadState_Num4==0x55)||(Collect485.Collect_CommError==True))
  1206. HAL_GPIO_TogglePin(GPIOE,LED5_Pin);
  1207. if(Collect485.Collect_CommError==True)
  1208. {
  1209. Collect458_bus[0]=0x55;//Buf=0x55;
  1210. Collect458_bus[1]=0x55;//Buf=0x55;
  1211. Collect458_bus[2]=0x55;//Buf=0x55;
  1212. Collect458_bus[3]=0x55;//Buf=0x55;
  1213. Collect458_bus[4]=0x55;//Buf=0x55;
  1214. Collect458_bus[5]=0x55;//Buf=0x55;
  1215. Collect458_bus[6]=0x55;//Buf=0x55;
  1216. Collect458_bus[7]=0x55;//Buf=0x55;
  1217. Collect485.ValveState_Num1=Collect485.ValveState_Num1|0xF0;
  1218. Collect485.ValveState_Num2=Collect485.ValveState_Num2|0xF0;
  1219. Collect485.ValveState_Num3=Collect485.ValveState_Num3|0xF0;
  1220. Collect485.ValveState_Num4=Collect485.ValveState_Num4|0xF0;
  1221. Collect485.ValveState_Num5=Collect485.ValveState_Num5|0xF0;
  1222. Collect485.ValveState_Num6=Collect485.ValveState_Num6|0xF0;
  1223. Collect485.ValveState_Num7=Collect485.ValveState_Num7|0xF0;
  1224. Collect485.ValveState_Num8=Collect485.ValveState_Num8|0xF0;
  1225. }
  1226. else
  1227. {
  1228. Collect458_bus[0]=0xaa;//Buf=0xaa;
  1229. Collect458_bus[1]=0xaa;//Buf=0xaa;
  1230. Collect458_bus[2]=0xaa;//Buf=0xaa;
  1231. Collect458_bus[3]=0xaa;//Buf=0xaa;
  1232. Collect458_bus[4]=0xaa;//Buf=0xaa;
  1233. Collect458_bus[5]=0xaa;//Buf=0xaa;
  1234. Collect458_bus[6]=0xaa;//Buf=0xaa;
  1235. Collect458_bus[7]=0xaa;//Buf=0xaa;
  1236. Collect485.ValveState_Num1=Collect485.ValveState_Num1&0xFF;
  1237. Collect485.ValveState_Num2=Collect485.ValveState_Num2&0xFF;
  1238. Collect485.ValveState_Num3=Collect485.ValveState_Num3&0xFF;
  1239. Collect485.ValveState_Num4=Collect485.ValveState_Num4&0xFF;
  1240. Collect485.ValveState_Num5=Collect485.ValveState_Num5&0xFF;
  1241. Collect485.ValveState_Num6=Collect485.ValveState_Num6&0xFF;
  1242. Collect485.ValveState_Num7=Collect485.ValveState_Num7&0xFF;
  1243. Collect485.ValveState_Num8=Collect485.ValveState_Num8&0xFF;
  1244. }
  1245. if((Collect485.ValveState_Num1&0xF0)>0)//1仓
  1246. {
  1247. if(((Collect485.ValveState_Num1&0x10)>>4)==1)
  1248. {
  1249. Stor[0].stat[1]=0x55;//大盖
  1250. // SendChar4(0XAA);
  1251. }
  1252. if(((Collect485.ValveState_Num1&0x20)>>5)==1)
  1253. {
  1254. Stor[0].stat[0]=0x55;//小盖
  1255. // SendChar4(0XBB);
  1256. }
  1257. if(((Collect485.ValveState_Num1&0x40)>>6)==1)
  1258. {
  1259. Stor[0].hdf_state=0x55;
  1260. }
  1261. if(((Collect485.ValveState_Num1&0x80)>>7)==1)
  1262. {
  1263. Stor[0].xyf_state=0x55;
  1264. }
  1265. }
  1266. if((Collect485.ValveState_Num2&0xF0)>0)//2仓
  1267. {
  1268. if(((Collect485.ValveState_Num2&0x10)>>4)==1)
  1269. {
  1270. Stor[1].stat[1]=0x55;
  1271. }
  1272. if(((Collect485.ValveState_Num2&0x20)>>5)==1)
  1273. {
  1274. Stor[1].stat[0]=0x55;
  1275. }
  1276. if(((Collect485.ValveState_Num2&0x40)>>6)==1)
  1277. {
  1278. Stor[1].hdf_state=0x55;
  1279. }
  1280. if(((Collect485.ValveState_Num2&0x80)>>7)==1)
  1281. {
  1282. Stor[1].xyf_state=0x55;
  1283. }
  1284. }
  1285. if((Collect485.ValveState_Num3&0xF0)>0)//3仓
  1286. {
  1287. if(((Collect485.ValveState_Num3&0x10)>>4)==1)
  1288. {
  1289. Stor[2].stat[1]=0x55;
  1290. }
  1291. if(((Collect485.ValveState_Num3&0x20)>>5)==1)
  1292. {
  1293. Stor[2].stat[0]=0x55;
  1294. }
  1295. if(((Collect485.ValveState_Num3&0x40)>>6)==1)
  1296. {
  1297. Stor[2].hdf_state=0x55;
  1298. }
  1299. if(((Collect485.ValveState_Num3&0x80)>>7)==1)
  1300. {
  1301. Stor[2].xyf_state=0x55;
  1302. }
  1303. }
  1304. if((Collect485.ValveState_Num4&0xF0)>0)//4仓
  1305. {
  1306. if(((Collect485.ValveState_Num4&0x10)>>4)==1)
  1307. {
  1308. Stor[3].stat[1]=0x55;
  1309. }
  1310. if(((Collect485.ValveState_Num4&0x20)>>5)==1)
  1311. {
  1312. Stor[3].stat[0]=0x55;
  1313. }
  1314. if(((Collect485.ValveState_Num4&0x40)>>6)==1)
  1315. {
  1316. Stor[3].hdf_state=0x55;
  1317. }
  1318. if(((Collect485.ValveState_Num4&0x80)>>7)==1)
  1319. {
  1320. Stor[3].xyf_state=0x55;
  1321. }
  1322. }
  1323. if((Collect485.ValveState_Num5&0xF0)>0)//5仓
  1324. {
  1325. if(((Collect485.ValveState_Num5&0x10)>>4)==1)
  1326. {
  1327. Stor[4].stat[1]=0x55;
  1328. }
  1329. if(((Collect485.ValveState_Num5&0x20)>>5)==1)
  1330. {
  1331. Stor[4].stat[0]=0x55;
  1332. }
  1333. if(((Collect485.ValveState_Num5&0x40)>>6)==1)
  1334. {
  1335. Stor[4].hdf_state=0x55;
  1336. }
  1337. if(((Collect485.ValveState_Num5&0x80)>>7)==1)
  1338. {
  1339. Stor[4].xyf_state=0x55;
  1340. }
  1341. }
  1342. if((Collect485.ValveState_Num6&0xF0)>0)//6仓
  1343. {
  1344. if(((Collect485.ValveState_Num6&0x10)>>4)==1)
  1345. {
  1346. Stor[5].stat[1]=0x55;
  1347. }
  1348. if(((Collect485.ValveState_Num6&0x20)>>5)==1)
  1349. {
  1350. Stor[5].stat[0]=0x55;
  1351. }
  1352. if(((Collect485.ValveState_Num6&0x40)>>6)==1)
  1353. {
  1354. Stor[5].hdf_state=0x55;
  1355. }
  1356. if(((Collect485.ValveState_Num6&0x80)>>7)==1)
  1357. {
  1358. Stor[5].xyf_state=0x55;
  1359. }
  1360. }
  1361. if((Collect485.ValveState_Num7&0xF0)>0)//7仓
  1362. {
  1363. if(((Collect485.ValveState_Num7&0x10)>>4)==1)
  1364. {
  1365. Stor[6].stat[1]=0x55;
  1366. }
  1367. if(((Collect485.ValveState_Num7&0x20)>>5)==1)
  1368. {
  1369. Stor[6].stat[0]=0x55;
  1370. }
  1371. if(((Collect485.ValveState_Num7&0x40)>>6)==1)
  1372. {
  1373. Stor[6].hdf_state=0x55;
  1374. }
  1375. if(((Collect485.ValveState_Num7&0x80)>>7)==1)
  1376. {
  1377. Stor[6].xyf_state=0x55;
  1378. }
  1379. }
  1380. if((Collect485.ValveState_Num8&0xF0)>0)//8仓
  1381. {
  1382. if(((Collect485.ValveState_Num8&0x10)>>4)==1)
  1383. {
  1384. Stor[7].stat[1]=0x55;
  1385. }
  1386. if(((Collect485.ValveState_Num8&0x20)>>5)==1)
  1387. {
  1388. Stor[7].stat[0]=0x55;
  1389. }
  1390. if(((Collect485.ValveState_Num8&0x40)>>6)==1)
  1391. {
  1392. Stor[7].hdf_state=0x55;
  1393. }
  1394. if(((Collect485.ValveState_Num8&0x80)>>7)==1)
  1395. {
  1396. Stor[7].xyf_state=0x55;
  1397. }
  1398. }
  1399. /*以下判断各仓人孔盖和阀门状态是否更新*/
  1400. //1、读人孔盖状态更新
  1401. for(i=0;i<StoreNumber;i++)//此处i<8应改为i<StorNum
  1402. {
  1403. Statetemp.rkg[i]=Stor[i].stat[1] ;
  1404. Statetemp.rkgx[i] = Stor[i].stat[0] ;
  1405. // SendChar4(Stor[0].stat[1]);
  1406. /*此处添加特殊仓,如人孔盖是否存在等*/
  1407. /* USER CODE BEGIN */
  1408. if(((Config_info_all.ManHole_Big_info&0x80)==0x80)&&((Config_info_all.ManHole_small_info&0x80)!=0x80))//人孔大盖传感器不存在
  1409. {
  1410. Statetemp.rkg[i] = Stor[i].stat[0] ;
  1411. Statetemp.rkgx[i] = Stor[i].stat[0] ;
  1412. }
  1413. if(((Config_info_all.ManHole_small_info&0x80)==0x80)&&((Config_info_all.ManHole_Big_info&0x80)!=0x80))//人孔小盖不存在
  1414. {
  1415. Statetemp.rkg[i] = Stor[i].stat[1] ;
  1416. Statetemp.rkgx[i] = Stor[i].stat[1] ;
  1417. }
  1418. if(((Config_info_all.ManHole_small_info&0x80)==0x80)&&((Config_info_all.ManHole_Big_info&0x80)==0x80))//人孔大小盖不存在
  1419. {
  1420. Statetemp.rkg[i] = 0 ;
  1421. Statetemp.rkgx[i] = 0 ;
  1422. }
  1423. /* USER CODE END */
  1424. }
  1425. // SendChar4(Statetemp.rkg[0]);
  1426. //2、读卸油阀状态更新
  1427. // uint8_t temp_advule_xyf[8]={0};
  1428. for(i=0;i<StoreNumber;i++)//此处i<8应改为i<StorNum
  1429. {
  1430. if(((Config_info_all.Dump_info&0x80)==0)&&((Config_info_all.HaiDiFa_info&0x80)==0))//传感器存在
  1431. {
  1432. #if 1
  1433. Statetemp.xyf[i]=Stor[i].xyf_state;
  1434. Statetemp.bottm[i]=Stor[i].hdf_state;
  1435. #else
  1436. /*此处添加特殊仓,如人孔盖是否存在等*/
  1437. if((Config_info_all.Dump_info&0x0f)==StoreNumber)//传感器个数=StoreNumber
  1438. {
  1439. Statetemp.xyf[i]=Stor[i].xyf_state;
  1440. }
  1441. else if((Config_info_all.Dump_info&0x0f)==2*StoreNumber)
  1442. {
  1443. Statetemp.xyf[i]=Stor[2*i].xyf_state|Stor[(2*i)+1].xyf_state;
  1444. }
  1445. else if((Config_info_all.Dump_info&0x0f)==3*StoreNumber)
  1446. {
  1447. Statetemp.xyf[i]=Stor[3*i].xyf_state|Stor[(3*i)+1].xyf_state|Stor[(3*i)+2].xyf_state;
  1448. }
  1449. if((Config_info_all.HaiDiFa_info&0x0f)==StoreNumber)//传感器个数=StoreNumber
  1450. {
  1451. Statetemp.bottm[i]=Stor[i].hdf_state;
  1452. }
  1453. else if((Config_info_all.HaiDiFa_info&0x0f)==2*StoreNumber)
  1454. {
  1455. Statetemp.bottm[i]=Stor[2*i].hdf_state|Stor[(2*i)+1].hdf_state;
  1456. }
  1457. else if((Config_info_all.HaiDiFa_info&0x0f)==3*StoreNumber)
  1458. {
  1459. Statetemp.bottm[i]=Stor[3*i].hdf_state|Stor[(3*i)+1].hdf_state|Stor[(3*i)+2].hdf_state;
  1460. }
  1461. #endif
  1462. }
  1463. else if(((Config_info_all.Dump_info&0x80)==0)&&((Config_info_all.HaiDiFa_info&0x80)==0x80))//底阀不存在
  1464. {
  1465. #if 1
  1466. Statetemp.xyf[i]=Stor[i].xyf_state;
  1467. #else
  1468. if((Config_info_all.Dump_info&0x0f)==StoreNumber)//传感器个数=StoreNumber
  1469. {
  1470. Statetemp.xyf[i]=Stor[i].xyf_state;
  1471. }
  1472. else if((Config_info_all.Dump_info&0x0f)==2*StoreNumber)
  1473. {
  1474. Statetemp.xyf[i]=Stor[2*i].xyf_state|Stor[(2*i)+1].xyf_state;
  1475. }
  1476. else if((Config_info_all.Dump_info&0x0f)==3*StoreNumber)
  1477. {
  1478. Statetemp.xyf[i]=Stor[3*i].xyf_state|Stor[(3*i)+1].xyf_state|Stor[(3*i)+2].xyf_state;
  1479. }
  1480. #endif
  1481. Statetemp.bottm[i]=Statetemp.xyf[i];
  1482. }
  1483. else if(((Config_info_all.Dump_info&0x80)==0x80)&&((Config_info_all.HaiDiFa_info&0x80)==0))//卸油阀不存在
  1484. {
  1485. #if 1
  1486. Statetemp.bottm[i]=Stor[i].hdf_state;
  1487. #else
  1488. if((Config_info_all.HaiDiFa_info&0x0f)==StoreNumber)//传感器个数=StoreNumber
  1489. {
  1490. Statetemp.bottm[i]=Stor[i].hdf_state;
  1491. }
  1492. else if((Config_info_all.HaiDiFa_info&0x0f)==2*StoreNumber)
  1493. {
  1494. Statetemp.bottm[i]=Stor[2*i].hdf_state|Stor[(2*i)+1].hdf_state;
  1495. }
  1496. else if((Config_info_all.HaiDiFa_info&0x0f)==3*StoreNumber)
  1497. {
  1498. Statetemp.bottm[i]=Stor[3*i].hdf_state|Stor[(3*i)+1].hdf_state|Stor[(3*i)+2].hdf_state;
  1499. }
  1500. #endif
  1501. Statetemp.xyf[i]=Statetemp.bottm[i];
  1502. }
  1503. else if(((Config_info_all.Dump_info&0x80)==0x80)&&((Config_info_all.HaiDiFa_info&0x80)==0x80))
  1504. {
  1505. Statetemp.bottm[i]=0;
  1506. Statetemp.xyf[i]=0;
  1507. }
  1508. }
  1509. /*
  1510. else if((Config_info_all.Dump_info&0xf0)==0)//StoreNumber
  1511. {
  1512. for(i=0;i<StoreNumber;i++)//此处i<8应改为i<StorNum
  1513. {
  1514. if(temp_advule_xyf[i] !=Statetemp.xyf[i])
  1515. {
  1516. XYF_cnt[i]++;
  1517. if(XYF_cnt[i]>10)
  1518. {
  1519. temp_advule_xyf[i] =Statetemp.xyf[i];// 读取卸油阀状态值,相等,更新,存储一仓状态 Statetemp.xyf[i]
  1520. XYF_cnt[i] =0;
  1521. }
  1522. //此处日后填写状态变更时是否保存或者其他操作
  1523. }
  1524. else
  1525. {
  1526. XYF_cnt[i] =0;
  1527. }
  1528. }
  1529. }
  1530. */
  1531. //2、读底阀状态更新
  1532. /*
  1533. for(i=0;i<StoreNumber;i++)//此处i<8应改为i<StorNum
  1534. {
  1535. if((Config_info_all.HaiDiFa_info&0x80)==0)//传感器存在
  1536. {
  1537. if((Config_info_all.HaiDiFa_info&0x0f)==StoreNumber)//传感器个数=StoreNumber
  1538. {
  1539. Statetemp.bottm[i]=Stor[i].hdf_state;
  1540. }
  1541. else if((Config_info_all.HaiDiFa_info&0x0f)==2*StoreNumber)
  1542. {
  1543. Statetemp.bottm[i]=Stor[2*i].hdf_state|Stor[(2*i)+1].hdf_state;
  1544. }
  1545. else if((Config_info_all.HaiDiFa_info&0x0f)==3*StoreNumber)
  1546. {
  1547. Statetemp.bottm[i]=Stor[3*i].hdf_state|Stor[(3*i)+1].hdf_state|Stor[(3*i)+2].hdf_state;
  1548. }
  1549. }
  1550. else
  1551. {
  1552. Statetemp.bottm[i] = 0;
  1553. }
  1554. }
  1555. */
  1556. /*
  1557. uint8_t temp_advule_hdf[8]={0};
  1558. if((Config_info_all.HaiDiFa_info&0xf0)==1)//2*StoreNumber
  1559. {
  1560. for(i=0;i<StoreNumber;i++)//此处i<8应改为i<StorNum
  1561. {
  1562. if(temp_advule_hdf[i] !=Statetemp.bottm[i])
  1563. {
  1564. HDF_cnt[i]++;
  1565. if(HDF_cnt[i]>10)
  1566. {
  1567. temp_advule_hdf[i] =Statetemp.bottm[i];// 读取卸油阀状态值,相等,更新,存储一仓状态 Statetemp.xyf[i]
  1568. HDF_cnt[i] =0;
  1569. }
  1570. //此处日后填写状态变更时是否保存或者其他操作
  1571. }
  1572. else
  1573. {
  1574. XYF_cnt[i] =0;
  1575. }
  1576. //此处添加特殊仓,如人孔盖是否存在等/
  1577. // Statetemp.bottm[0]=temp_advule_hdf[0]|temp_advule_hdf[1];
  1578. // Statetemp.bottm[1]=temp_advule_hdf[2]|temp_advule_hdf[3];
  1579. // Statetemp.bottm[2]=temp_advule_hdf[4]|temp_advule_hdf[5];
  1580. // Statetemp.bottm[3]=temp_advule_hdf[6]|temp_advule_hdf[7];
  1581. }
  1582. }
  1583. else if((Config_info_all.HaiDiFa_info&0xf0)==0)//StoreNumber
  1584. {
  1585. for(i=0;i<StoreNumber;i++)
  1586. {
  1587. if(temp_advule_hdf[i] !=Statetemp.bottm[i])
  1588. {
  1589. HDF_cnt[i]++;
  1590. if(HDF_cnt[i]>10)
  1591. {
  1592. temp_advule_hdf[i] =Statetemp.bottm[i];// 读取卸油阀状态值,相等,更新,存储一仓状态 Statetemp.xyf[i]
  1593. HDF_cnt[i] =0;
  1594. }
  1595. //此处日后填写状态变更时是否保存或者其他操作//
  1596. }
  1597. else
  1598. {
  1599. XYF_cnt[i] =0;
  1600. }
  1601. }
  1602. }
  1603. */
  1604. // Stor[0].yewei[0]=1111;
  1605. // Stor[1].yewei[0]=1222;
  1606. // Stor[2].yewei[0]=1333;
  1607. // Stor[3].yewei[0]=1444;
  1608. // Stor[0].Press=2111;
  1609. // Stor[1].Press=2222;
  1610. // Stor[2].Press=2333;
  1611. // Stor[3].Press=2444;
  1612. }
  1613. //GroupNum=0,读取1-4仓
  1614. //GroupNum=1,读取5-8仓;
  1615. void Get_All_Moniliang_Data_4Cang(uint16_t GroupNum)
  1616. {//按照时间片读取1--4仓;5--8仓液位计等模拟量参数
  1617. int j001ReadAll;
  1618. uint16_t id000;
  1619. {////读取1-4,5-8仓模拟量传感器信息--开始
  1620. if(GroupNum==0)
  1621. {//读取1-4
  1622. ReadCollect_ValveState_64Byte(0x000003,Collector_Get_WenduYewei_Data_1to4,0x0000,0x0000,0x0000);
  1623. id000=Collector_Get_WenduYewei_Data_1to4;
  1624. pT2C_MoniLiang_Data=&T2C_MoniLiang_Data_Cang1to4;
  1625. }//读取1-4
  1626. else
  1627. {//读取5-8
  1628. ReadCollect_ValveState_64Byte(0x000003,Collector_Get_WenduYewei_Data_5to8,0x0000,0x0000,0x0000);
  1629. id000=Collector_Get_WenduYewei_Data_5to8;
  1630. pT2C_MoniLiang_Data=&T2C_MoniLiang_Data_Cang5to8;
  1631. }//读取5-8
  1632. // HAL_GPIO_TogglePin(GPIOC, DWI_Pin);//复位看门狗sp706
  1633. //HAL_Delay(SPAN_ControllerAndCollector_INTERVAL);
  1634. osDelay(SPAN_ControllerAndCollector_INTERVAL_180);
  1635. chkRetCaiJiBan=CheckInFrame_Collect485(LengthOfData_From_Caijiban_Cang_1to4,id000);
  1636. __NOP();
  1637. if((chkRetCaiJiBan==Collector_Get_WenduYewei_Data_1to4) || (chkRetCaiJiBan==Collector_Get_WenduYewei_Data_5to8))
  1638. {//如果回复的校验正确---实际为功能码或者消息ID能够匹配
  1639. Usart2_ErrorTimes=0;
  1640. chkRetCaiJiBan=0;
  1641. Collect485.Collect_CommError=False;
  1642. __nop();
  1643. for(j001ReadAll=0;j001ReadAll<16;j001ReadAll++)
  1644. {
  1645. pT2C_MoniLiang_Data->FrameHead[j001ReadAll]=USART2_RX_BUF_Collector[j001ReadAll];
  1646. }
  1647. for(j001ReadAll=0;j001ReadAll<8;j001ReadAll++)
  1648. {
  1649. pT2C_MoniLiang_Data->ResData[j001ReadAll]=USART2_RX_BUF_Collector[j001ReadAll+16];
  1650. }
  1651. for(j001ReadAll=0;j001ReadAll<FloatData_Num_Caijiban;j001ReadAll++)
  1652. {//52个浮点数数据解析--开始
  1653. ArrayUni_MoniLiang[j001ReadAll].farray[0]=USART2_RX_BUF_Collector[MoiLiangFrom_CaijibanOffset+j001ReadAll*4+0];
  1654. ArrayUni_MoniLiang[j001ReadAll].farray[1]=USART2_RX_BUF_Collector[MoiLiangFrom_CaijibanOffset+j001ReadAll*4+1];
  1655. ArrayUni_MoniLiang[j001ReadAll].farray[2]=USART2_RX_BUF_Collector[MoiLiangFrom_CaijibanOffset+j001ReadAll*4+2];
  1656. ArrayUni_MoniLiang[j001ReadAll].farray[3]=USART2_RX_BUF_Collector[MoiLiangFrom_CaijibanOffset+j001ReadAll*4+3];
  1657. }//52个浮点数数据解析--开始
  1658. //整车模拟量数据--8个浮点数
  1659. for(j001ReadAll=0;j001ReadAll<8;j001ReadAll++)
  1660. {
  1661. pT2C_MoniLiang_Data->MoniLiang_DataOf_Car[j001ReadAll]=ArrayUni_MoniLiang[j001ReadAll+0].flo_Data;
  1662. }
  1663. //1--4仓模拟量数据--4*11个浮点数
  1664. for(j001ReadAll=0;j001ReadAll<44;j001ReadAll++)
  1665. {
  1666. pT2C_MoniLiang_Data->MoniLiang_DataOfCang_1to4[j001ReadAll]=ArrayUni_MoniLiang[j001ReadAll+8].flo_Data;
  1667. }
  1668. pT2C_MoniLiang_Data->chkLRC_Data[0]=USART2_RX_BUF_Collector[LengthOfData_From_Caijiban_Cang_1to4-4];
  1669. pT2C_MoniLiang_Data->chkLRC_Data[1]=USART2_RX_BUF_Collector[LengthOfData_From_Caijiban_Cang_1to4-3];
  1670. pT2C_MoniLiang_Data->chkCRCModbus_Data[0]=USART2_RX_BUF_Collector[LengthOfData_From_Caijiban_Cang_1to4-2];
  1671. pT2C_MoniLiang_Data->chkCRCModbus_Data[1]=USART2_RX_BUF_Collector[LengthOfData_From_Caijiban_Cang_1to4-1];
  1672. __NOP();
  1673. memset(USART2_RX_BUF, 0x00, sizeof(USART2_RX_BUF)); //清除接收缓存
  1674. }//如果回复的校验正确---实际为功能码或者消息ID能够匹配
  1675. else
  1676. {//接收错误异常处理:未接收到数据,或者校验错误等
  1677. Usart2_ErrorTimes++;
  1678. }
  1679. }//读取1-4,5-8仓模拟量传感器信息--结束
  1680. }
  1681. ////稳油数据更新
  1682. /*
  1683. 修改全局变量
  1684. */
  1685. void UpdateWenYouFifo(void)
  1686. {
  1687. int i007;
  1688. //稳油判断的Fifo 滑动窗操作
  1689. for(i007=0;i007<NumOf_WenYouPanduan-1;i007++)
  1690. {
  1691. ArrYeweiForWenyou[i007]=ArrYeweiForWenyou[i007+1];//Stor[CabinetNumForWenYou].yewei_flo[0];//Stor[0].yewei[0]*SCL_Yewei_Collect2Contr;//
  1692. }
  1693. //最新的采样点存入队尾
  1694. ArrYeweiForWenyou[NumOf_WenYouPanduan-1]=Stor[CabinetNumForWenYou].yewei_flo[0];
  1695. Yewei_max000=ArrYeweiForWenyou[0];
  1696. Yewei_min000=ArrYeweiForWenyou[0];
  1697. Yewei_peak000=0;//ArrYeweiForWenyou[0];
  1698. for(i007=0;i007<NumOf_WenYouPanduan;i007++)
  1699. {
  1700. if(ArrYeweiForWenyou[i007]<Yewei_min000)
  1701. {
  1702. Yewei_min000=ArrYeweiForWenyou[i007];
  1703. }
  1704. if(ArrYeweiForWenyou[i007]>Yewei_max000)
  1705. {
  1706. Yewei_max000=ArrYeweiForWenyou[i007];
  1707. }
  1708. }
  1709. Yewei_peak000=Yewei_max000-Yewei_min000;
  1710. }
  1711. //64字节帧长度 最初版本的协议--一个bit表示一个开关状态
  1712. ////阀门状态或运算之后数据解析 用于电子铅封业务
  1713. void Parse_0x0013_Data(void)
  1714. {
  1715. //数据的处理在CheckInFrame_Collect485中进行,直接进行转换
  1716. chkRetCaiJiBan=CheckInFrame_Collect485(64,Collector_Get_Valve_OldFormat);
  1717. if(chkRetCaiJiBan==0xA1)
  1718. {
  1719. Usart2_ErrorTimes=0;
  1720. memcpy(ValStateArr_0x13,USART2_RX_BUF,64);
  1721. Collect485.Collect_CommError=False;
  1722. }
  1723. else
  1724. {//接收错误异常处理:未接收到数据,或者校验错误等
  1725. Usart2_ErrorTimes++;
  1726. }
  1727. }
  1728. //64字节帧长度 40字节IO状态
  1729. //北京部队试用64字节的协议 其他程序均沿用。底卸大小尽
  1730. //根据传入的仓号将阀门数据拷贝到相应的单独的缓冲区
  1731. void Parse_0x0020_Data_64Byte(void)
  1732. {
  1733. int retry;
  1734. for (retry = 0; retry < 50; ++retry)
  1735. {
  1736. if (usart2_rx_flag == True)
  1737. break;
  1738. osDelay(5);
  1739. }
  1740. if (usart2_rx_flag == True)
  1741. {
  1742. usart2_rx_flag = False;
  1743. //指示灯1 表明系统正在运行
  1744. //HAL_GPIO_TogglePin(LED2_GPIO_Port, LED2_Pin);
  1745. // 39 01 95 50 00 01 00 03 00 20 00 28 95 01 AA AA 00 01 00 00 03 03 01 A5 A5 A5 A5 A5 00 00 00 00
  1746. // 00 A5 A5 A5 A5 A5 00 00 00 00 00 A5 A5 A5 A5 A5 00 00 00 00 00 A5 A5 A5 A5 A5 00 00 00 00 F0 93
  1747. // 30 30 30 30 30 30 30 30 30 30 30 30 30 30 30 30 30 30 30 30 30 30 30 30 30 30 30 30 30 30 30 30
  1748. // 30 30 30 30 30 30 30 30 30 30 30 30 30 30 30 30 30 30 30 30 30 30 30 30 30 33 39 30 31 33 39 34 31 0D 0A
  1749. //
  1750. CangNum000 = USART2_RX_BUF[17]; //分析仓号
  1751. CRC_data = CRC16_MODBUS(USART2_RX_BUF, 62);
  1752. CRC_dataCaiJiBan = (USART2_RX_BUF[62] << 8) + USART2_RX_BUF[63];
  1753. if (CRC_dataCaiJiBan == CRC_data)
  1754. { // if(CRC_dataCaiJiBan==CRC_data)
  1755. memcpy(ValStateArr_0x20, USART2_RX_BUF, 64);
  1756. // CangNum000=9;
  1757. switch (CangNum000)
  1758. {
  1759. case 1:
  1760. memcpy(Cang01_IO, USART2_RX_BUF, 64);
  1761. //memcpy(ValStateArr_0x20_Cang01, USART2_RX_BUF, 64);
  1762. HAL_GPIO_TogglePin(LED2_GPIO_Port, LED2_Pin);
  1763. break;
  1764. case 2:
  1765. memcpy(Cang02_IO, USART2_RX_BUF, 64);
  1766. //memcpy(ValStateArr_0x20_Cang02, USART2_RX_BUF, 64);
  1767. //HAL_GPIO_TogglePin(LED2_GPIO_Port, LED3_Pin);
  1768. break;
  1769. case 3:
  1770. memcpy(Cang03_IO, USART2_RX_BUF, 64);
  1771. //memcpy(ValStateArr_0x20_Cang03, USART2_RX_BUF, 64);
  1772. //HAL_GPIO_TogglePin(LED2_GPIO_Port, LED4_Pin);
  1773. break;
  1774. case 4:
  1775. memcpy(Cang04_IO, USART2_RX_BUF, 64);
  1776. //memcpy(ValStateArr_0x20_Cang04, USART2_RX_BUF, 64);
  1777. //HAL_GPIO_TogglePin(LED2_GPIO_Port, LED5_Pin);
  1778. break;
  1779. case 5:
  1780. memcpy(Cang05_IO, USART2_RX_BUF, 64);
  1781. break;
  1782. case 6:
  1783. memcpy(Cang06_IO, USART2_RX_BUF, 64);
  1784. break;
  1785. case 7:
  1786. memcpy(Cang07_IO, USART2_RX_BUF, 64);
  1787. break;
  1788. case 8:
  1789. memcpy(Cang08_IO, USART2_RX_BUF, 64);
  1790. break;
  1791. default:
  1792. break;
  1793. }
  1794. Translate_IO_to_U32Bit_V2();
  1795. //Translate_IO_to_U32Bit();
  1796. } // if(CRC_dataCaiJiBan==CRC_data)
  1797. } // if(usart2_rx_flag==True)
  1798. /*else
  1799. {
  1800. }*/
  1801. }
  1802. void Translate_IO_to_U32Bit_V2(void)
  1803. {
  1804. uint32_t IO_Exception_State011,IO_OnOff_State011;
  1805. int i;
  1806. //第1组阀门--------------------------------------------------------开始
  1807. for(i=0;i<4;++i)
  1808. {
  1809. //////////////////////////////--1仓
  1810. IO_Exception_State011 = 0;
  1811. IO_OnOff_State011 = 0;
  1812. if(Cang01_IO[indexHaiDiFa01+10*i]==0x03)//海底阀
  1813. {//海底阀
  1814. IO_Exception_State011|=U32_BIT_03;
  1815. }//海底阀
  1816. else
  1817. {//海底阀
  1818. //IO_Exception_State01&=(!U32_BIT_03);//异常状态标志清零
  1819. if(Cang01_IO[indexHaiDiFa01+10*i]==0x01)//海底阀
  1820. {//开关状态置位
  1821. IO_OnOff_State011|=U32_BIT_03;
  1822. }
  1823. /*else if(Cang01_IO[indexHaiDiFa01]==0x00)
  1824. {//开关状态清零
  1825. IO_OnOff_State01&=(!U32_BIT_03);
  1826. }*/
  1827. }//海底阀
  1828. if(Cang01_IO[indexXieYouFa01+10*i]==0x03)//卸油阀
  1829. {//卸油阀
  1830. IO_Exception_State011|=U32_BIT_02;
  1831. }//卸油阀
  1832. else
  1833. {//卸油阀
  1834. //IO_Exception_State01&=(!U32_BIT_02);//异常状态标志清零
  1835. if(Cang01_IO[indexXieYouFa01+10*i]==0x01)
  1836. {//开关状态置位
  1837. IO_OnOff_State011|=U32_BIT_02;
  1838. }
  1839. /*else if(Cang01_IO[indexXieYouFa01]==0x00)
  1840. {//开关状态清零
  1841. IO_OnOff_State011&=(!U32_BIT_02);
  1842. } */
  1843. }//卸油阀
  1844. if(Cang01_IO[indexDaGai01+10*i]==0x03)//人孔大盖
  1845. {///人孔大盖
  1846. IO_Exception_State011|=U32_BIT_01;
  1847. }////人孔大盖
  1848. else
  1849. {////人孔大盖
  1850. // IO_Exception_State01&=(!U32_BIT_01);//异常状态标志清零
  1851. if(Cang01_IO[indexDaGai01+10*i]==0x01)
  1852. {//开关状态置位
  1853. IO_OnOff_State011|=U32_BIT_01;
  1854. }
  1855. /*else if(Cang01_IO[indexDaGai01]==0x00)
  1856. {//开关状态清零
  1857. IO_OnOff_State01&=(!U32_BIT_01);
  1858. } */
  1859. }////人孔大盖
  1860. if(Cang01_IO[indexXiaoGai01+10*i]==0x03)//人孔小盖
  1861. {///人孔小盖
  1862. IO_Exception_State011|=U32_BIT_00;
  1863. }////人孔小盖
  1864. else
  1865. {////人孔小盖
  1866. //IO_Exception_State01&=(!U32_BIT_00);//异常状态标志清零
  1867. if(Cang01_IO[indexXiaoGai01+10*i]==0x01)
  1868. {//开关状态置位
  1869. IO_OnOff_State011|=U32_BIT_00;
  1870. }
  1871. /*else if(Cang01_IO[indexXiaoGai01]==0x00)
  1872. {//开关状态清零
  1873. IO_OnOff_State01&=(!U32_BIT_00);
  1874. } */
  1875. }////人孔小盖
  1876. ////////////////////////////--2仓开始
  1877. if(Cang02_IO[indexHaiDiFa01+10*i]==0x03)//海底阀
  1878. {//海底阀
  1879. IO_Exception_State011|=U32_BIT_07;
  1880. }//海底阀
  1881. else
  1882. {//海底阀
  1883. //IO_Exception_State01&=(!U32_BIT_07);//异常状态标志清零
  1884. if(Cang02_IO[indexHaiDiFa01+10*i]==0x01)//海底阀
  1885. {//开关状态置位
  1886. IO_OnOff_State011|=U32_BIT_07;
  1887. }
  1888. /*else if(Cang02_IO[indexHaiDiFa01]==0x00)
  1889. {//开关状态清零
  1890. IO_OnOff_State01&=(!U32_BIT_07);
  1891. }*/
  1892. }//海底阀
  1893. if(Cang02_IO[indexXieYouFa01+10*i]==0x03)//卸油阀
  1894. {//卸油阀
  1895. IO_Exception_State011|=U32_BIT_06;
  1896. }//卸油阀
  1897. else
  1898. {//卸油阀
  1899. //IO_Exception_State011&=(!U32_BIT_06);//异常状态标志清零
  1900. if(Cang02_IO[indexXieYouFa01+10*i]==0x01)
  1901. {//开关状态置位
  1902. IO_OnOff_State011|=U32_BIT_06;
  1903. }
  1904. /* else if(Cang02_IO[indexXieYouFa01]==0x00)
  1905. {//开关状态清零
  1906. IO_OnOff_State01&=(!U32_BIT_06);
  1907. } */
  1908. }//卸油阀
  1909. if(Cang02_IO[indexDaGai01+10*i]==0x03)//人孔大盖
  1910. {///人孔大盖
  1911. IO_Exception_State011|=U32_BIT_05;
  1912. }////人孔大盖
  1913. else
  1914. {////人孔大盖
  1915. // IO_Exception_State01&=(!U32_BIT_05);//异常状态标志清零
  1916. if(Cang02_IO[indexDaGai01+10*i]==0x01)
  1917. {//开关状态置位
  1918. IO_OnOff_State011|=U32_BIT_05;
  1919. }
  1920. /*else if(Cang02_IO[indexDaGai01]==0x00)
  1921. {//开关状态清零
  1922. IO_OnOff_State01&=(!U32_BIT_05);
  1923. }*/
  1924. }////人孔大盖
  1925. if(Cang02_IO[indexXiaoGai01+10*i]==0x03)//人孔小盖
  1926. {///人孔小盖
  1927. IO_Exception_State011|=U32_BIT_04;
  1928. }////人孔小盖
  1929. else
  1930. {////人孔小盖
  1931. //IO_Exception_State01&=(!U32_BIT_04);//异常状态标志清零
  1932. if(Cang02_IO[indexXiaoGai01+10*i]==0x01)
  1933. {//开关状态置位
  1934. IO_OnOff_State011|=U32_BIT_04;
  1935. }
  1936. /*else if(Cang02_IO[indexXiaoGai01]==0x00)
  1937. {//开关状态清零
  1938. IO_OnOff_State01&=(!U32_BIT_04);
  1939. }*/
  1940. }////人孔小盖
  1941. ////////////////////////////--2仓结束
  1942. ////////////////////////////--3仓开始
  1943. if(Cang03_IO[indexHaiDiFa01+10*i]==0x03)//海底阀
  1944. {//海底阀
  1945. IO_Exception_State011|=U32_BIT_11;
  1946. }//海底阀
  1947. else
  1948. {//海底阀
  1949. //IO_Exception_State01&=(!U32_BIT_11);//异常状态标志清零
  1950. if(Cang03_IO[indexHaiDiFa01+10*i]==0x01)//海底阀
  1951. {//开关状态置位
  1952. IO_OnOff_State011|=U32_BIT_11;
  1953. }
  1954. /*else if(Cang03_IO[indexHaiDiFa01]==0x00)
  1955. {//开关状态清零
  1956. IO_OnOff_State01&=(!U32_BIT_11);
  1957. } */
  1958. }//海底阀
  1959. if(Cang03_IO[indexXieYouFa01+10*i]==0x03)//卸油阀
  1960. {//卸油阀
  1961. IO_Exception_State011|=U32_BIT_10;
  1962. }//卸油阀
  1963. else
  1964. {//卸油阀
  1965. //IO_Exception_State01&=(!U32_BIT_10);//异常状态标志清零
  1966. if(Cang03_IO[indexXieYouFa01+10*i]==0x01)
  1967. {//开关状态置位
  1968. IO_OnOff_State011|=U32_BIT_10;
  1969. }
  1970. /*else if(Cang03_IO[indexXieYouFa01]==0x00)
  1971. {//开关状态清零
  1972. IO_OnOff_State01&=(!U32_BIT_10);
  1973. }*/
  1974. }//卸油阀
  1975. if(Cang03_IO[indexDaGai01+10*i]==0x03)//人孔大盖
  1976. {///人孔大盖
  1977. IO_Exception_State011|=U32_BIT_09;
  1978. }////人孔大盖
  1979. else
  1980. {////人孔大盖
  1981. // IO_Exception_State01&=(!U32_BIT_09);//异常状态标志清零
  1982. if(Cang03_IO[indexDaGai01+10*i]==0x01)
  1983. {//开关状态置位
  1984. IO_OnOff_State011|=U32_BIT_09;
  1985. }
  1986. /*else if(Cang03_IO[indexDaGai01]==0x00)
  1987. {//开关状态清零
  1988. IO_OnOff_State01&=(!U32_BIT_09);
  1989. }*/
  1990. }////人孔大盖
  1991. if(Cang03_IO[indexXiaoGai01+10*i]==0x03)//人孔小盖
  1992. {///人孔小盖
  1993. IO_Exception_State011|=U32_BIT_08;
  1994. }////人孔小盖
  1995. else
  1996. {////人孔小盖
  1997. //IO_Exception_State01&=(!U32_BIT_08);//异常状态标志清零
  1998. if(Cang03_IO[indexXiaoGai01+10*i]==0x01)
  1999. {//开关状态置位
  2000. IO_OnOff_State011|=U32_BIT_08;
  2001. }
  2002. /*else if(Cang03_IO[indexXiaoGai01]==0x00)
  2003. {//开关状态清零
  2004. IO_OnOff_State01&=(!U32_BIT_08);
  2005. } */
  2006. }////人孔小盖
  2007. ////////////////////////////--3仓结束
  2008. ////////////////////////////--4仓开始
  2009. if(Cang04_IO[indexHaiDiFa01+10*i]==0x03)//海底阀
  2010. {//海底阀
  2011. IO_Exception_State011|=U32_BIT_15;
  2012. }//海底阀
  2013. else
  2014. {//海底阀
  2015. //IO_Exception_State01&=(!U32_BIT_15);//异常状态标志清零
  2016. if(Cang04_IO[indexHaiDiFa01+10*i]==0x01)//海底阀
  2017. {//开关状态置位
  2018. IO_OnOff_State011|=U32_BIT_15;
  2019. }
  2020. /*else if(Cang04_IO[indexHaiDiFa01]==0x00)
  2021. {//开关状态清零
  2022. IO_OnOff_State01&=(!U32_BIT_15);
  2023. }*/
  2024. }//海底阀
  2025. if(Cang04_IO[indexXieYouFa01+10*i]==0x03)//卸油阀
  2026. {//卸油阀
  2027. IO_Exception_State011|=U32_BIT_14;
  2028. }//卸油阀
  2029. else
  2030. {//卸油阀
  2031. //IO_Exception_State01&=(!U32_BIT_14);//异常状态标志清零
  2032. if(Cang04_IO[indexXieYouFa01+10*i]==0x01)
  2033. {//开关状态置位
  2034. IO_OnOff_State011|=U32_BIT_14;
  2035. }
  2036. /* else if(Cang04_IO[indexXieYouFa01]==0x00)
  2037. {//开关状态清零
  2038. IO_OnOff_State01&=(!U32_BIT_14);
  2039. }*/
  2040. }//卸油阀
  2041. if(Cang04_IO[indexDaGai01+10*i]==0x03)//人孔大盖
  2042. {///人孔大盖
  2043. IO_Exception_State011|=U32_BIT_13;
  2044. }////人孔大盖
  2045. else
  2046. {////人孔大盖
  2047. // IO_Exception_State01&=(!U32_BIT_13);//异常状态标志清零
  2048. if(Cang04_IO[indexDaGai01+10*i]==0x01)
  2049. {//开关状态置位
  2050. IO_OnOff_State011|=U32_BIT_13;
  2051. }
  2052. /*else if(Cang04_IO[indexDaGai01]==0x00)
  2053. {//开关状态清零
  2054. IO_OnOff_State01&=(!U32_BIT_13);
  2055. } */
  2056. }////人孔大盖
  2057. if(Cang04_IO[indexXiaoGai01+10*i]==0x03)//人孔小盖
  2058. {///人孔小盖
  2059. IO_Exception_State011|=U32_BIT_12;
  2060. }////人孔小盖
  2061. else
  2062. {////人孔小盖
  2063. //IO_Exception_State01&=(!U32_BIT_12);//异常状态标志清零
  2064. if(Cang04_IO[indexXiaoGai01+10*i]==0x01)
  2065. {//开关状态置位
  2066. IO_OnOff_State011|=U32_BIT_12;
  2067. }
  2068. /*else if(Cang04_IO[indexXiaoGai01]==0x00)
  2069. {//开关状态清零
  2070. IO_OnOff_State01&=(!U32_BIT_12);
  2071. }*/
  2072. }////人孔小盖
  2073. ////////////////////////////--4仓结束
  2074. ////////////////////////////--5仓开始
  2075. if(Cang05_IO[indexHaiDiFa01+10*i]==0x03)//海底阀
  2076. {//海底阀
  2077. IO_Exception_State011|=U32_BIT_19;
  2078. }//海底阀
  2079. else
  2080. {//海底阀
  2081. //IO_Exception_State01&=(!U32_BIT_19);//异常状态标志清零
  2082. if(Cang05_IO[indexHaiDiFa01+10*i]==0x01)//海底阀
  2083. {//开关状态置位
  2084. IO_OnOff_State011|=U32_BIT_19;
  2085. }
  2086. /*else if(Cang05_IO[indexHaiDiFa01]==0x00)
  2087. {//开关状态清零
  2088. IO_OnOff_State01&=(!U32_BIT_19);
  2089. }*/
  2090. }//海底阀
  2091. if(Cang05_IO[indexXieYouFa01+10*i]==0x03)//卸油阀
  2092. {//卸油阀
  2093. IO_Exception_State011|=U32_BIT_18;
  2094. }//卸油阀
  2095. else
  2096. {//卸油阀
  2097. //IO_Exception_State01&=(!U32_BIT_18);//异常状态标志清零
  2098. if(Cang05_IO[indexXieYouFa01+10*i]==0x01)
  2099. {//开关状态置位
  2100. IO_OnOff_State011|=U32_BIT_18;
  2101. }
  2102. /*else if(Cang05_IO[indexXieYouFa01]==0x00)
  2103. {//开关状态清零
  2104. IO_OnOff_State01&=(!U32_BIT_18);
  2105. } */
  2106. }//卸油阀
  2107. if(Cang05_IO[indexDaGai01+10*i]==0x03)//人孔大盖
  2108. {///人孔大盖
  2109. IO_Exception_State011|=U32_BIT_17;
  2110. }////人孔大盖
  2111. else
  2112. {////人孔大盖
  2113. //IO_Exception_State01&=(!U32_BIT_17);//异常状态标志清零
  2114. if(Cang05_IO[indexDaGai01+10*i]==0x01)
  2115. {//开关状态置位
  2116. IO_OnOff_State011|=U32_BIT_17;
  2117. }
  2118. /*else if(Cang05_IO[indexDaGai01]==0x00)
  2119. {//开关状态清零
  2120. IO_OnOff_State01&=(!U32_BIT_17);
  2121. }*/
  2122. }////人孔大盖
  2123. if(Cang05_IO[indexXiaoGai01+10*i]==0x03)//人孔小盖
  2124. {///人孔小盖
  2125. IO_Exception_State011|=U32_BIT_16;
  2126. }////人孔小盖
  2127. else
  2128. {////人孔小盖
  2129. //IO_Exception_State01&=(!U32_BIT_16);//异常状态标志清零
  2130. if(Cang05_IO[indexXiaoGai01+10*i]==0x01)
  2131. {//开关状态置位
  2132. IO_OnOff_State011|=U32_BIT_16;
  2133. }
  2134. /*else if(Cang05_IO[indexXiaoGai01]==0x00)
  2135. {//开关状态清零
  2136. IO_OnOff_State01&=(!U32_BIT_16);
  2137. }*/
  2138. }////人孔小盖
  2139. ////////////////////////////--5仓结束
  2140. ////////////////////////////--6仓开始
  2141. if(Cang06_IO[indexHaiDiFa01+10*i]==0x03)//海底阀
  2142. {//海底阀
  2143. IO_Exception_State011|=U32_BIT_23;
  2144. }//海底阀
  2145. else
  2146. {//海底阀
  2147. // IO_Exception_State01&=(!U32_BIT_23);//异常状态标志清零
  2148. if(Cang06_IO[indexHaiDiFa01+10*i]==0x01)//海底阀
  2149. {//开关状态置位
  2150. IO_OnOff_State011|=U32_BIT_23;
  2151. }
  2152. /*else if(Cang06_IO[indexHaiDiFa01]==0x00)
  2153. {//开关状态清零
  2154. IO_OnOff_State01&=(!U32_BIT_23);
  2155. }*/
  2156. }//海底阀
  2157. if(Cang06_IO[indexXieYouFa01+10*i]==0x03)//卸油阀
  2158. {//卸油阀
  2159. IO_Exception_State011|=U32_BIT_22;
  2160. }//卸油阀
  2161. else
  2162. {//卸油阀
  2163. //IO_Exception_State01&=(!U32_BIT_22);//异常状态标志清零
  2164. if(Cang06_IO[indexXieYouFa01+10*i]==0x01)
  2165. {//开关状态置位
  2166. IO_OnOff_State011|=U32_BIT_22;
  2167. }
  2168. /*else if(Cang06_IO[indexXieYouFa01]==0x00)
  2169. {//开关状态清零
  2170. IO_OnOff_State01&=(!U32_BIT_22);
  2171. } */
  2172. }//卸油阀
  2173. if(Cang06_IO[indexDaGai01+10*i]==0x03)//人孔大盖
  2174. {///人孔大盖
  2175. IO_Exception_State011|=U32_BIT_21;
  2176. }////人孔大盖
  2177. else
  2178. {////人孔大盖
  2179. //IO_Exception_State01&=(!U32_BIT_21);//异常状态标志清零
  2180. if(Cang06_IO[indexDaGai01+10*i]==0x01)
  2181. {//开关状态置位
  2182. IO_OnOff_State011|=U32_BIT_21;
  2183. }
  2184. /*else if(Cang06_IO[indexDaGai01]==0x00)
  2185. {//开关状态清零
  2186. IO_OnOff_State01&=(!U32_BIT_21);
  2187. }*/
  2188. }////人孔大盖
  2189. if(Cang06_IO[indexXiaoGai01+10*i]==0x03)//人孔小盖
  2190. {///人孔小盖
  2191. IO_Exception_State011|=U32_BIT_20;
  2192. }////人孔小盖
  2193. else
  2194. {////人孔小盖
  2195. //IO_Exception_State01&=(!U32_BIT_20);//异常状态标志清零
  2196. if(Cang06_IO[indexXiaoGai01+10*i]==0x01)
  2197. {//开关状态置位
  2198. IO_OnOff_State011|=U32_BIT_20;
  2199. }
  2200. /*else if(Cang06_IO[indexXiaoGai01]==0x00)
  2201. {//开关状态清零
  2202. IO_OnOff_State01&=(!U32_BIT_20);
  2203. }*/
  2204. }////人孔小盖
  2205. ////////////////////////////--6仓结束
  2206. ////////////////////////////--7仓开始
  2207. if(Cang07_IO[indexHaiDiFa01+10*i]==0x03)//海底阀
  2208. {//海底阀
  2209. IO_Exception_State011|=U32_BIT_27;
  2210. }//海底阀
  2211. else
  2212. {//海底阀
  2213. //IO_Exception_State01&=(!U32_BIT_27);//异常状态标志清零
  2214. if(Cang07_IO[indexHaiDiFa01+10*i]==0x01)//海底阀
  2215. {//开关状态置位
  2216. IO_OnOff_State011|=U32_BIT_27;
  2217. }
  2218. /*else if(Cang07_IO[indexHaiDiFa01]==0x00)
  2219. {//开关状态清零
  2220. IO_OnOff_State01&=(!U32_BIT_27);
  2221. }*/
  2222. }//海底阀
  2223. if(Cang07_IO[indexXieYouFa01+10*i]==0x03)//卸油阀
  2224. {//卸油阀
  2225. IO_Exception_State011|=U32_BIT_26;
  2226. }//卸油阀
  2227. else
  2228. {//卸油阀
  2229. // IO_Exception_State01&=(!U32_BIT_26);//异常状态标志清零
  2230. if(Cang07_IO[indexXieYouFa01+10*i]==0x01)
  2231. {//开关状态置位
  2232. IO_OnOff_State011|=U32_BIT_26;
  2233. }
  2234. /*else if(Cang07_IO[indexXieYouFa01]==0x00)
  2235. {//开关状态清零
  2236. IO_OnOff_State01&=(!U32_BIT_26);
  2237. }*/
  2238. }//卸油阀
  2239. if(Cang07_IO[indexDaGai01+10*i]==0x03)//人孔大盖
  2240. {///人孔大盖
  2241. IO_Exception_State011|=U32_BIT_25;
  2242. }////人孔大盖
  2243. else
  2244. {////人孔大盖
  2245. //IO_Exception_State01&=(!U32_BIT_25);//异常状态标志清零
  2246. if(Cang07_IO[indexDaGai01+10*i]==0x01)
  2247. {//开关状态置位
  2248. IO_OnOff_State011|=U32_BIT_25;
  2249. }
  2250. /*else if(Cang07_IO[indexDaGai01]==0x00)
  2251. {//开关状态清零
  2252. IO_OnOff_State01&=(!U32_BIT_25);
  2253. }*/
  2254. }////人孔大盖
  2255. if(Cang07_IO[indexXiaoGai01+10*i]==0x03)//人孔小盖
  2256. {///人孔小盖
  2257. IO_Exception_State011|=U32_BIT_24;
  2258. }////人孔小盖
  2259. else
  2260. {////人孔小盖
  2261. //IO_Exception_State01&=(!U32_BIT_24);//异常状态标志清零
  2262. if(Cang07_IO[indexXiaoGai01+10*i]==0x01)
  2263. {//开关状态置位
  2264. IO_OnOff_State011|=U32_BIT_24;
  2265. }
  2266. /*else if(Cang07_IO[indexXiaoGai01]==0x00)
  2267. {//开关状态清零
  2268. IO_OnOff_State01&=(!U32_BIT_24);
  2269. }*/
  2270. }////人孔小盖
  2271. ////////////////////////////--7仓结束
  2272. ////////////////////////////--8仓开始
  2273. if(Cang08_IO[indexHaiDiFa01+10*i]==0x03)//海底阀
  2274. {//海底阀
  2275. IO_Exception_State011|=U32_BIT_31;
  2276. }//海底阀
  2277. else
  2278. {//海底阀
  2279. // IO_Exception_State01&=(!U32_BIT_31);//异常状态标志清零
  2280. if(Cang08_IO[indexHaiDiFa01+10*i]==0x01)//海底阀
  2281. {//开关状态置位
  2282. IO_OnOff_State011|=U32_BIT_31;
  2283. }
  2284. /*else if(Cang08_IO[indexHaiDiFa01]==0x00)
  2285. {//开关状态清零
  2286. IO_OnOff_State01&=(!U32_BIT_31);
  2287. }*/
  2288. }//海底阀
  2289. if(Cang08_IO[indexXieYouFa01+10*i]==0x03)//卸油阀
  2290. {//卸油阀
  2291. IO_Exception_State011|=U32_BIT_30;
  2292. }//卸油阀
  2293. else
  2294. {//卸油阀
  2295. //IO_Exception_State01&=(!U32_BIT_30);//异常状态标志清零
  2296. if(Cang08_IO[indexXieYouFa01+10*i]==0x01)
  2297. {//开关状态置位
  2298. IO_OnOff_State011|=U32_BIT_30;
  2299. }
  2300. /*else if(Cang08_IO[indexXieYouFa01]==0x00)
  2301. {//开关状态清零
  2302. IO_OnOff_State01&=(!U32_BIT_30);
  2303. }*/
  2304. }//卸油阀
  2305. if(Cang08_IO[indexDaGai01+10*i]==0x03)//人孔大盖
  2306. {///人孔大盖
  2307. IO_Exception_State011|=U32_BIT_29;
  2308. }////人孔大盖
  2309. else
  2310. {////人孔大盖
  2311. //IO_Exception_State01&=(!U32_BIT_29);//异常状态标志清零
  2312. if(Cang08_IO[indexDaGai01+10*i]==0x01)
  2313. {//开关状态置位
  2314. IO_OnOff_State011|=U32_BIT_29;
  2315. }
  2316. /*else if(Cang08_IO[indexDaGai01]==0x00)
  2317. {//开关状态清零
  2318. IO_OnOff_State01&=(!U32_BIT_29);
  2319. }*/
  2320. }////人孔大盖
  2321. if(Cang08_IO[indexXiaoGai01+10*i]==0x03)//人孔小盖
  2322. {///人孔小盖
  2323. IO_Exception_State011|=U32_BIT_28;
  2324. }////人孔小盖
  2325. else
  2326. {////人孔小盖
  2327. //IO_Exception_State01&=(!U32_BIT_28);//异常状态标志清零
  2328. if(Cang08_IO[indexXiaoGai01+10*i]==0x01)
  2329. {//开关状态置位
  2330. IO_OnOff_State011|=U32_BIT_28;
  2331. }
  2332. /*else if(Cang08_IO[indexXiaoGai01]==0x00)
  2333. {//开关状态清零
  2334. IO_OnOff_State01&=(!U32_BIT_28);
  2335. }*/
  2336. }////人孔小盖
  2337. switch (i)
  2338. {
  2339. case 0:
  2340. IO_OnOff_State01 = IO_OnOff_State011;
  2341. IO_Exception_State01 = IO_Exception_State011;
  2342. break;
  2343. case 1:
  2344. IO_OnOff_State02 = IO_OnOff_State011;
  2345. IO_Exception_State02 = IO_Exception_State011;
  2346. break;
  2347. case 2:
  2348. IO_OnOff_State03 = IO_OnOff_State011;
  2349. IO_Exception_State03 = IO_Exception_State011;
  2350. break;
  2351. case 3:
  2352. IO_OnOff_State04 = IO_OnOff_State011;
  2353. IO_Exception_State04 = IO_Exception_State011;
  2354. break;
  2355. default:
  2356. break;
  2357. }
  2358. ////////////////////////////--8仓结束
  2359. }
  2360. //第1组阀门--------------------------------------------------------结束
  2361. }
  2362. /*
  2363. 20采集上来的分仓数据合成转换到
  2364. */
  2365. uni_float tmp_uni_trans;
  2366. void Translate_IO_to_U32Bit(void)
  2367. {
  2368. int i;
  2369. #if 0
  2370. uint8_t tmpArr[40]=
  2371. {
  2372. 0x00,0x00,0x00,0x00,0x01,0xa5,0x01,0x01,0x01,0xa5,
  2373. 0x00,0x00,0x00,0x00,0x00,0xa5,0x01,0x01,0x01,0xa5,
  2374. 0x00,0x00,0x00,0x00,0x00,0xa5,0x01,0x01,0x01,0xa5,
  2375. 0x01,0x01,0x03,0x01,0x01,0xa5,0x01,0x01,0x01,0xa5,
  2376. };
  2377. //仅供测试
  2378. if(1==0)
  2379. {
  2380. memcpy(&Cang01_IO[indexHaiDiFa01],tmpArr,40);
  2381. memcpy(&Cang02_IO[indexHaiDiFa01],tmpArr,40);
  2382. memcpy(&Cang03_IO[indexHaiDiFa01],tmpArr,40);
  2383. memcpy(&Cang04_IO[indexHaiDiFa01],tmpArr,40);
  2384. memcpy(&Cang05_IO[indexHaiDiFa01],tmpArr,40);
  2385. memcpy(&Cang06_IO[indexHaiDiFa01],tmpArr,40);
  2386. memcpy(&Cang07_IO[indexHaiDiFa01],tmpArr,40);
  2387. memcpy(&Cang08_IO[indexHaiDiFa01],tmpArr,40);
  2388. }
  2389. #endif
  2390. //taskENTER_CRITICAL();
  2391. //第1组阀门状态--开始;索引为16开始,依次为海底阀,卸油阀,大盖,小盖,卸尽传感器
  2392. // memcpy(&Array_IO_OnOff_AllStore[0+0],&Cang01_IO[indexHaiDiFa01],4);
  2393. // memcpy(&Array_IO_OnOff_AllStore[0+4],&Cang02_IO[indexHaiDiFa01],4);
  2394. //
  2395. for (i = 0; i < 4; ++i)
  2396. {
  2397. Array_IO_OnOff_AllStore[0+i] = Cang01_IO[indexHaiDiFa01+i];
  2398. Array_IO_OnOff_AllStore[4+i] = Cang02_IO[indexHaiDiFa01+i];
  2399. Array_IO_OnOff_AllStore[8+i] = Cang03_IO[indexHaiDiFa01+i];
  2400. Array_IO_OnOff_AllStore[12+i] = Cang04_IO[indexHaiDiFa01+i];
  2401. Array_IO_OnOff_AllStore[16+i] = Cang05_IO[indexHaiDiFa01+i];
  2402. }
  2403. #if 0
  2404. Array_IO_OnOff_AllStore[0]=Cang01_IO[indexHaiDiFa01];
  2405. Array_IO_OnOff_AllStore[1]=Cang01_IO[indexHaiDiFa01+1];
  2406. Array_IO_OnOff_AllStore[2]=Cang01_IO[indexHaiDiFa01+2];
  2407. Array_IO_OnOff_AllStore[3]=Cang01_IO[indexHaiDiFa01+3];
  2408. Array_IO_OnOff_AllStore[4]=Cang02_IO[indexHaiDiFa01];
  2409. Array_IO_OnOff_AllStore[5]=Cang02_IO[indexHaiDiFa01+1];
  2410. Array_IO_OnOff_AllStore[6]=Cang02_IO[indexHaiDiFa01+2];
  2411. Array_IO_OnOff_AllStore[7]=Cang02_IO[indexHaiDiFa01+3];
  2412. //memcpy(&Cang03_IO[indexHaiDiFa01],tmpArr,40);//仅供测试 发行时必须删除
  2413. Array_IO_OnOff_AllStore[8]=Cang03_IO[indexHaiDiFa01];
  2414. Array_IO_OnOff_AllStore[9]=Cang03_IO[indexHaiDiFa01+1];
  2415. Array_IO_OnOff_AllStore[10]=Cang03_IO[indexHaiDiFa01+2];
  2416. Array_IO_OnOff_AllStore[11]=Cang03_IO[indexHaiDiFa01+3];
  2417. Array_IO_OnOff_AllStore[12]=Cang04_IO[indexHaiDiFa01];
  2418. Array_IO_OnOff_AllStore[13]=Cang04_IO[indexHaiDiFa01+1];
  2419. Array_IO_OnOff_AllStore[14]=Cang04_IO[indexHaiDiFa01+2];
  2420. Array_IO_OnOff_AllStore[15]=Cang04_IO[indexHaiDiFa01+3];
  2421. // memcpy(&Array_IO_OnOff_AllStore[0+8],&Cang03_IO[indexHaiDiFa01],4);
  2422. // memcpy(&Array_IO_OnOff_AllStore[0+12],&Cang04_IO[indexHaiDiFa01],4);
  2423. memcpy(&Array_IO_OnOff_AllStore[0+16],&Cang05_IO[indexHaiDiFa01],4);
  2424. memcpy(&Array_IO_OnOff_AllStore[0+20],&Cang06_IO[indexHaiDiFa01],4);
  2425. memcpy(&Array_IO_OnOff_AllStore[0+24],&Cang07_IO[indexHaiDiFa01],4);
  2426. memcpy(&Array_IO_OnOff_AllStore[0+28],&Cang08_IO[indexHaiDiFa01],4);
  2427. #endif
  2428. // taskEXIT_CRITICAL();
  2429. IO_Exception_State01=0;
  2430. // for(i_trans=0;i_trans<32;i_trans++)
  2431. // {//8个仓位的第一组阀门异常状态
  2432. //
  2433. // if(Array_IO_OnOff_AllStore[i_trans]==0x03)
  2434. // {
  2435. // IO_Exception_State01|=(1<<(i_trans));
  2436. // }
  2437. //
  2438. // }//8个仓位的第一组阀门异常状态
  2439. //1仓四个阀门,字节顺序为底卸大小--第一组U32
  2440. if(Array_IO_OnOff_AllStore[0]==0x03)
  2441. {//海底阀异常状态
  2442. IO_Exception_State01|=U32_BIT_03;
  2443. }
  2444. if(Array_IO_OnOff_AllStore[1]==0x03)
  2445. {//卸油阀异常状态
  2446. IO_Exception_State01|=U32_BIT_02;
  2447. }
  2448. if(Array_IO_OnOff_AllStore[2]==0x03)
  2449. {//大盖异常状态
  2450. IO_Exception_State01|=U32_BIT_01;
  2451. }
  2452. if(Array_IO_OnOff_AllStore[3]==0x03)
  2453. {//小盖异常状态
  2454. IO_Exception_State01|=U32_BIT_00;
  2455. }
  2456. //2仓四个阀门,字节顺序为底卸大小--第一组U32
  2457. if(Array_IO_OnOff_AllStore[0+4]==0x03)
  2458. {//海底阀异常状态
  2459. IO_Exception_State01|=U32_BIT_07;
  2460. }
  2461. if(Array_IO_OnOff_AllStore[4+1]==0x03)
  2462. {//卸油阀异常状态
  2463. IO_Exception_State01|=U32_BIT_06;
  2464. }
  2465. if(Array_IO_OnOff_AllStore[4+2]==0x03)
  2466. {//大盖异常状态
  2467. IO_Exception_State01|=U32_BIT_05;
  2468. }
  2469. if(Array_IO_OnOff_AllStore[4+3]==0x03)
  2470. {//小盖异常状态
  2471. IO_Exception_State01|=U32_BIT_04;
  2472. }
  2473. //3仓四个阀门,字节顺序为底卸大小--第一组U32
  2474. if(Array_IO_OnOff_AllStore[8+0]==0x03)
  2475. {//海底阀异常状态
  2476. IO_Exception_State01|=U32_BIT_11;
  2477. }
  2478. if(Array_IO_OnOff_AllStore[8+1]==0x03)
  2479. {//卸油阀异常状态
  2480. IO_Exception_State01|=U32_BIT_10;
  2481. }
  2482. if(Array_IO_OnOff_AllStore[8+2]==0x03)
  2483. {//大盖异常状态
  2484. IO_Exception_State01|=U32_BIT_09;
  2485. }
  2486. if(Array_IO_OnOff_AllStore[8+3]==0x03)
  2487. {//小盖异常状态
  2488. IO_Exception_State01|=U32_BIT_08;
  2489. }
  2490. IO_OnOff_State01=0x00;
  2491. //第一组四个阀门的开关状态,字节顺序为底卸大小----第1仓数据
  2492. if(Array_IO_OnOff_AllStore[0]==0x01)
  2493. {//海底阀开关状态--1仓
  2494. IO_OnOff_State01|=U32_BIT_03;
  2495. }
  2496. if(Array_IO_OnOff_AllStore[1]==0x01)
  2497. {//卸油阀开关状态
  2498. IO_OnOff_State01|=U32_BIT_02;
  2499. }
  2500. if(Array_IO_OnOff_AllStore[2]==0x01)
  2501. {//大盖开关状态
  2502. IO_OnOff_State01|=U32_BIT_01;
  2503. }
  2504. if(Array_IO_OnOff_AllStore[3]==0x01)
  2505. {//小盖开关状态
  2506. IO_OnOff_State01|=U32_BIT_00;
  2507. }
  2508. //第一组四个阀门的开关状态,字节顺序为底卸大小----第2仓数据
  2509. if(Array_IO_OnOff_AllStore[0+4]==0x01)
  2510. {//海底阀开关状态--1仓
  2511. IO_OnOff_State01|=U32_BIT_07;
  2512. }
  2513. if(Array_IO_OnOff_AllStore[1+4]==0x01)
  2514. {//卸油阀开关状态
  2515. IO_OnOff_State01|=U32_BIT_06;
  2516. }
  2517. if(Array_IO_OnOff_AllStore[2+4]==0x01)
  2518. {//大盖开关状态
  2519. IO_OnOff_State01|=U32_BIT_05;
  2520. }
  2521. if(Array_IO_OnOff_AllStore[3+4]==0x01)
  2522. {//小盖开关状态
  2523. IO_OnOff_State01|=U32_BIT_04;
  2524. }
  2525. //第一组四个阀门的开关状态,字节顺序为底卸大小----第3仓数据
  2526. if(Array_IO_OnOff_AllStore[0+4*2]==0x01)
  2527. {//海底阀开关状态--1仓
  2528. IO_OnOff_State01|=U32_BIT_11;
  2529. }
  2530. if(Array_IO_OnOff_AllStore[1+4*2]==0x01)
  2531. {//卸油阀开关状态
  2532. IO_OnOff_State01|=U32_BIT_10;
  2533. }
  2534. if(Array_IO_OnOff_AllStore[2+4*2]==0x01)
  2535. {//大盖开关状态
  2536. IO_OnOff_State01|=U32_BIT_09;
  2537. }
  2538. if(Array_IO_OnOff_AllStore[3+4*2]==0x01)
  2539. {//小盖开关状态
  2540. IO_OnOff_State01|=U32_BIT_08;
  2541. }
  2542. //第一组四个阀门的开关状态,字节顺序为底卸大小----第4仓数据
  2543. if(Array_IO_OnOff_AllStore[0+4*3]==0x01)
  2544. {//海底阀开关状态--1仓
  2545. IO_OnOff_State01|=U32_BIT_15;
  2546. }
  2547. if(Array_IO_OnOff_AllStore[1+4*3]==0x01)
  2548. {//卸油阀开关状态
  2549. IO_OnOff_State01|=U32_BIT_14;
  2550. }
  2551. if(Array_IO_OnOff_AllStore[2+4*3]==0x01)
  2552. {//大盖开关状态
  2553. IO_OnOff_State01|=U32_BIT_13;
  2554. }
  2555. if(Array_IO_OnOff_AllStore[3+4*3]==0x01)
  2556. {//小盖开关状态
  2557. IO_OnOff_State01|=U32_BIT_12;
  2558. }
  2559. // //第一组异常状态----1-8仓
  2560. // IO_Exception_State01=0xaabbccdd;//仅供测试
  2561. // tmp_uni_trans.u32Dat=IO_Exception_State01;
  2562. // Array_Of_Valve[7+8*0]=tmp_uni_trans.array_u8[3];
  2563. // Array_Of_Valve[6+8*0]=tmp_uni_trans.array_u8[2];
  2564. // Array_Of_Valve[5+8*0]=tmp_uni_trans.array_u8[1];
  2565. // Array_Of_Valve[4+8*0]=tmp_uni_trans.array_u8[0];
  2566. //
  2567. //
  2568. // ////第一组开关状态----1-8仓
  2569. // IO_OnOff_State01=0x55667788;//仅供测试
  2570. // tmp_uni_trans.u32Dat=IO_OnOff_State01;
  2571. // Array_Of_Valve[3+8*0]=tmp_uni_trans.array_u8[3];
  2572. // Array_Of_Valve[2+8*0]=tmp_uni_trans.array_u8[2];
  2573. // Array_Of_Valve[1+8*0]=tmp_uni_trans.array_u8[1];
  2574. // Array_Of_Valve[0+8*0]=tmp_uni_trans.array_u8[0];
  2575. //__NOP();
  2576. // //第2组异常状态----1-8仓
  2577. // tmp_uni_trans.u32Dat=IO_Exception_State02;
  2578. // Array_Of_Valve[7+8*1]=tmp_uni_trans.array_u8[3];
  2579. // Array_Of_Valve[6+8*1]=tmp_uni_trans.array_u8[2];
  2580. // Array_Of_Valve[5+8*1]=tmp_uni_trans.array_u8[1];
  2581. // Array_Of_Valve[4+8*1]=tmp_uni_trans.array_u8[0];
  2582. //
  2583. //
  2584. // ////第2组开关状态----1-8仓
  2585. // tmp_uni_trans.u32Dat=IO_OnOff_State02;
  2586. // Array_Of_Valve[3+8*1]=tmp_uni_trans.array_u8[3];
  2587. // Array_Of_Valve[2+8*1]=tmp_uni_trans.array_u8[2];
  2588. // Array_Of_Valve[1+8*1]=tmp_uni_trans.array_u8[1];
  2589. // Array_Of_Valve[0+8*1]=tmp_uni_trans.array_u8[0];
  2590. //
  2591. /*
  2592. // IO_OnOff_State01=0;
  2593. // for(i_trans=0;i_trans<32;i_trans++)
  2594. // {//8个仓位的阀门开关状态
  2595. //
  2596. // if(Array_IO_OnOff_AllStore[i_trans]==0x01)
  2597. // {
  2598. // IO_OnOff_State01|=(1<<(i_trans));
  2599. // }
  2600. // } //8个仓位的第2组阀门开关状态
  2601. //第1组阀门状态--结束;索引为16开始,依次为海底阀,卸油阀,大盖,小盖,卸尽传感器
  2602. // //第2组阀门状态--开始;索引为26开始,依次为海底阀,卸油阀,大盖,小盖,卸尽传感器
  2603. // memcpy(&Array_IO_OnOff_AllStore[0+0],&Cang01_IO[indexHaiDiFa02],4);
  2604. // memcpy(&Array_IO_OnOff_AllStore[0+4],&Cang02_IO[indexHaiDiFa02],4);
  2605. // memcpy(&Array_IO_OnOff_AllStore[0+8],&Cang03_IO[indexHaiDiFa02],4);
  2606. // memcpy(&Array_IO_OnOff_AllStore[0+12],&Cang04_IO[indexHaiDiFa02],4);
  2607. // memcpy(&Array_IO_OnOff_AllStore[0+16],&Cang05_IO[indexHaiDiFa02],4);
  2608. // memcpy(&Array_IO_OnOff_AllStore[0+20],&Cang06_IO[indexHaiDiFa02],4);
  2609. // memcpy(&Array_IO_OnOff_AllStore[0+24],&Cang07_IO[indexHaiDiFa02],4);
  2610. // memcpy(&Array_IO_OnOff_AllStore[0+28],&Cang08_IO[indexHaiDiFa02],4);
  2611. // for(i_trans=0;i_trans<8;i_trans++)
  2612. // {//8个仓位的阀门异常状态
  2613. //
  2614. // }
  2615. IO_Exception_State02=0;
  2616. for(i_trans=0;i_trans<32;i_trans++)
  2617. {//8个仓位的阀门异常状态
  2618. if(Array_IO_OnOff_AllStore[i_trans]==0x03)
  2619. {
  2620. IO_Exception_State02|=(1<<(i_trans));
  2621. }
  2622. }//8个仓位的阀门异常状态
  2623. IO_OnOff_State02=0;
  2624. for(i_trans=0;i_trans<32;i_trans++)
  2625. {//8个仓位的阀门开关状态
  2626. if(Array_IO_OnOff_AllStore[i_trans]==0x01)
  2627. {
  2628. IO_OnOff_State02|=(1<<(i_trans));
  2629. }
  2630. } //8个仓位的第2组阀门开关状态
  2631. //第2组阀门状态--结束;索引为26开始,依次为海底阀,卸油阀,大盖,小盖,卸尽传感器
  2632. //第3组阀门状态--开始;索引为36开始,依次为海底阀,卸油阀,大盖,小盖,卸尽传感器
  2633. memcpy(&Array_IO_OnOff_AllStore[0+0],&Cang01_IO[indexHaiDiFa03],4);
  2634. memcpy(&Array_IO_OnOff_AllStore[0+4],&Cang02_IO[indexHaiDiFa03],4);
  2635. memcpy(&Array_IO_OnOff_AllStore[0+8],&Cang03_IO[indexHaiDiFa03],4);
  2636. memcpy(&Array_IO_OnOff_AllStore[0+12],&Cang04_IO[indexHaiDiFa03],4);
  2637. memcpy(&Array_IO_OnOff_AllStore[0+16],&Cang05_IO[indexHaiDiFa03],4);
  2638. memcpy(&Array_IO_OnOff_AllStore[0+20],&Cang06_IO[indexHaiDiFa03],4);
  2639. memcpy(&Array_IO_OnOff_AllStore[0+24],&Cang07_IO[indexHaiDiFa03],4);
  2640. memcpy(&Array_IO_OnOff_AllStore[0+28],&Cang08_IO[indexHaiDiFa03],4);
  2641. // for(i_trans=0;i_trans<8;i_trans++)
  2642. // {//8个仓位的阀门异常状态
  2643. //
  2644. // }
  2645. IO_Exception_State03=0;
  2646. for(i_trans=0;i_trans<32;i_trans++)
  2647. {//8个仓位的阀门异常状态
  2648. if(Array_IO_OnOff_AllStore[i_trans]==0x03)
  2649. {
  2650. IO_Exception_State03|=(1<<(i_trans));
  2651. }
  2652. }//8个仓位的阀门异常状态
  2653. IO_OnOff_State03=0;
  2654. for(i_trans=0;i_trans<32;i_trans++)
  2655. {//8个仓位的阀门开关状态
  2656. if(Array_IO_OnOff_AllStore[i_trans]==0x01)
  2657. {
  2658. IO_OnOff_State03|=(1<<(i_trans));
  2659. }
  2660. } //8个仓位的第3组阀门开关状态
  2661. //第3组阀门状态--结束;索引为36开始,依次为海底阀,卸油阀,大盖,小盖,卸尽传感器
  2662. //第4组阀门状态--开始;索引为46开始,依次为海底阀,卸油阀,大盖,小盖,卸尽传感器
  2663. memcpy(&Array_IO_OnOff_AllStore[0+0],&Cang01_IO[indexHaiDiFa04],4);
  2664. memcpy(&Array_IO_OnOff_AllStore[0+4],&Cang02_IO[indexHaiDiFa04],4);
  2665. memcpy(&Array_IO_OnOff_AllStore[0+8],&Cang03_IO[indexHaiDiFa04],4);
  2666. memcpy(&Array_IO_OnOff_AllStore[0+12],&Cang04_IO[indexHaiDiFa04],4);
  2667. memcpy(&Array_IO_OnOff_AllStore[0+16],&Cang05_IO[indexHaiDiFa04],4);
  2668. memcpy(&Array_IO_OnOff_AllStore[0+20],&Cang06_IO[indexHaiDiFa04],4);
  2669. memcpy(&Array_IO_OnOff_AllStore[0+24],&Cang07_IO[indexHaiDiFa04],4);
  2670. memcpy(&Array_IO_OnOff_AllStore[0+28],&Cang08_IO[indexHaiDiFa04],4);
  2671. // for(i_trans=0;i_trans<8;i_trans++)
  2672. // {//8个仓位的阀门异常状态
  2673. //
  2674. // }
  2675. IO_Exception_State04=0;
  2676. for(i_trans=0;i_trans<32;i_trans++)
  2677. {//8个仓位的阀门异常状态
  2678. if(Array_IO_OnOff_AllStore[i_trans]==0x03)
  2679. {
  2680. IO_Exception_State04|=(1<<(i_trans));
  2681. }
  2682. }//8个仓位的阀门异常状态
  2683. IO_OnOff_State04=0;
  2684. for(i_trans=0;i_trans<32;i_trans++)
  2685. {//8个仓位的阀门开关状态
  2686. if(Array_IO_OnOff_AllStore[i_trans]==0x01)
  2687. {
  2688. IO_OnOff_State04|=(1<<(i_trans));
  2689. }
  2690. } //8个仓位的第3组阀门开关状态
  2691. //第4组阀门状态--结束;索引为46开始,依次为海底阀,卸油阀,大盖,小盖,卸尽传感器
  2692. */
  2693. }
  2694. void Parse_AllSensor_Data_For_SingleStore(sT2C_ALL_Sensor_Data_Each_Cang* pT2C_ALL_Sensor_Data,uint16_t msgID)
  2695. {
  2696. int j001ReadAll;
  2697. chkRetCaiJiBan = CheckInFrame_Collect485(LengthOfData_From_Caijiban_Cang_01, msgID);
  2698. // if((chkRetCaiJiBan==msgID) || (1==1))
  2699. if ((chkRetCaiJiBan == msgID))
  2700. { //如果回复的校验正确---实际为功能码或者消息ID能够匹配
  2701. Usart2_ErrorTimes = 0;
  2702. chkRetCaiJiBan = 0;
  2703. Collect485.Collect_CommError = False;
  2704. for (j001ReadAll = 0; j001ReadAll < 16; j001ReadAll++)
  2705. { //帧头数据16字节
  2706. pT2C_ALL_Sensor_Data->FrameHead[j001ReadAll] = USART2_RX_BUF_Collector[j001ReadAll];
  2707. } //帧头数据16字节
  2708. // for(j001ReadAll=0;j001ReadAll<8;j001ReadAll++)
  2709. {
  2710. pT2C_ALL_Sensor_Data->ElecSealState =
  2711. (USART2_RX_BUF_Collector[0 + 16] << 24) + (USART2_RX_BUF_Collector[1 + 16] << 16) +
  2712. (USART2_RX_BUF_Collector[2 + 16] << 8) + (USART2_RX_BUF_Collector[3 + 16]);
  2713. }
  2714. for (j001ReadAll = 0; j001ReadAll < ALL_Sensor_Data_Num_Caijiban; j001ReadAll++)
  2715. { // 33个浮点数数据解析--开始
  2716. ArrayUni_MoniLiang[j001ReadAll].farray[0] = USART2_RX_BUF_Collector[ALL_SensorData_From_CaijibanOffset + 0 + j001ReadAll * 4 + 0];
  2717. ArrayUni_MoniLiang[j001ReadAll].farray[1] = USART2_RX_BUF_Collector[ALL_SensorData_From_CaijibanOffset + 0 + j001ReadAll * 4 + 1];
  2718. ArrayUni_MoniLiang[j001ReadAll].farray[2] = USART2_RX_BUF_Collector[ALL_SensorData_From_CaijibanOffset + 0 + j001ReadAll * 4 + 2];
  2719. ArrayUni_MoniLiang[j001ReadAll].farray[3] = USART2_RX_BUF_Collector[ALL_SensorData_From_CaijibanOffset + 0 + j001ReadAll * 4 + 3];
  2720. } // 33个浮点数数据解析--开始
  2721. #if 0
  2722. if (msgID == Collector_Get_All_Sensor_Data_Cang01)
  2723. {
  2724. __NOP();
  2725. }
  2726. if (msgID == Collector_Get_All_Sensor_Data_Cang02)
  2727. {
  2728. __NOP();
  2729. }
  2730. __NOP();
  2731. #endif
  2732. // 21个IO开关类数据--21个U32
  2733. for (j001ReadAll = 0; j001ReadAll < 22; j001ReadAll++)
  2734. {
  2735. pT2C_ALL_Sensor_Data->IO_Valve_Data_Every_Cang[j001ReadAll] = ArrayUni_MoniLiang[j001ReadAll + 1].u32_Data;
  2736. }
  2737. // 11个模拟量数据--11个浮点数
  2738. for (j001ReadAll = 0; j001ReadAll < 11; j001ReadAll++)
  2739. {
  2740. pT2C_ALL_Sensor_Data->MoniLiang_Data_Every_Cang[j001ReadAll] = ArrayUni_MoniLiang[j001ReadAll + 22].flo_Data;
  2741. }
  2742. // //增加合法性检查
  2743. // if(pT2C_ALL_Sensor_Data->MoniLiang_Data_Every_Cang[0]>Max_Oil_Height)
  2744. // {//液位高度上限
  2745. // pT2C_ALL_Sensor_Data->MoniLiang_Data_Every_Cang[0]=Max_Oil_Height;
  2746. // }
  2747. pT2C_ALL_Sensor_Data->chkCRCModbus_Data[0] = USART2_RX_BUF_Collector[LengthOfData_From_Caijiban_Cang_01 - 2];
  2748. pT2C_ALL_Sensor_Data->chkCRCModbus_Data[1] = USART2_RX_BUF_Collector[LengthOfData_From_Caijiban_Cang_01 - 1];
  2749. #if 0
  2750. __NOP();
  2751. if (msgID == Collector_Get_All_Sensor_Data_Cang01)
  2752. {
  2753. __NOP();
  2754. }
  2755. if (msgID == Collector_Get_All_Sensor_Data_Cang02)
  2756. {
  2757. __NOP();
  2758. }
  2759. __NOP();
  2760. memset(USART2_RX_BUF, 0x00, sizeof(USART2_RX_BUF)); //清除接收缓存
  2761. #endif
  2762. } //如果回复的校验正确---实际为功能码或者消息ID能够匹配
  2763. else
  2764. { //接收错误异常处理:未接收到数据,或者校验错误等
  2765. Usart2_ErrorTimes++;
  2766. }
  2767. }
  2768. void Parse_AllSensor_Data_For_WholeCar(sT2C_ALL_Sensor_Data_WholeCar* pT2C_ALL_Sensor_Data,uint16_t msgID,uint16_t LenOfPara)
  2769. {
  2770. int j001ReadAll;
  2771. chkRetCaiJiBan=CheckInFrame_Collect485(LengthOfData_From_Caijiban_WholeCar,msgID);
  2772. if(chkRetCaiJiBan==msgID)// || (1==1)
  2773. {//如果回复的校验正确---实际为功能码或者消息ID能够匹配
  2774. Usart2_ErrorTimes=0;
  2775. chkRetCaiJiBan=0;
  2776. Collect485.Collect_CommError=False;
  2777. __nop();
  2778. for(j001ReadAll=0;j001ReadAll<16;j001ReadAll++)
  2779. {//帧头数据16字节
  2780. pT2C_ALL_Sensor_Data->FrameHead[j001ReadAll]=USART2_RX_BUF_Collector[j001ReadAll];
  2781. }//帧头数据16字节
  2782. __NOP();
  2783. for(j001ReadAll=0;j001ReadAll<LenOfPara;j001ReadAll++)//ALL_Sensor_Data_Num_WholeCar
  2784. {//数据解析--开始
  2785. ArrayUni_MoniLiang[j001ReadAll].farray[0]=USART2_RX_BUF_Collector[ALL_SensorData_From_CaijibanOffset+0+j001ReadAll*4+0];
  2786. ArrayUni_MoniLiang[j001ReadAll].farray[1]=USART2_RX_BUF_Collector[ALL_SensorData_From_CaijibanOffset+0+j001ReadAll*4+1];
  2787. ArrayUni_MoniLiang[j001ReadAll].farray[2]=USART2_RX_BUF_Collector[ALL_SensorData_From_CaijibanOffset+0+j001ReadAll*4+2];
  2788. ArrayUni_MoniLiang[j001ReadAll].farray[3]=USART2_RX_BUF_Collector[ALL_SensorData_From_CaijibanOffset+0+j001ReadAll*4+3];
  2789. }//数据解析--结束
  2790. pT2C_ALL_Sensor_Data->tiltXYZ[0]=ArrayUni_MoniLiang[0].flo_Data;
  2791. pT2C_ALL_Sensor_Data->tiltXYZ[1]=ArrayUni_MoniLiang[1].flo_Data;
  2792. pT2C_ALL_Sensor_Data->tiltXYZ[2]=ArrayUni_MoniLiang[2].flo_Data;
  2793. Stor[0].QingJiaoFlo=pT2C_ALL_Sensor_Data->tiltXYZ[0];//(float)(Stor[0].QingJiao*SCL_Angle*1);
  2794. Stor[1].QingJiaoFlo=pT2C_ALL_Sensor_Data->tiltXYZ[1];//(float)(Stor[1].QingJiao*SCL_Angle*1);//180/32768;
  2795. uni_QingJiao001.flo_Data=pT2C_ALL_Sensor_Data->tiltXYZ[0];
  2796. uni_QingJiao002.flo_Data=pT2C_ALL_Sensor_Data->tiltXYZ[1];
  2797. pT2C_ALL_Sensor_Data->BeiDian_State_OnOff=ArrayUni_MoniLiang[3].u32_Data;
  2798. pT2C_ALL_Sensor_Data->BeiDianDianLiang=ArrayUni_MoniLiang[4].flo_Data;
  2799. pT2C_ALL_Sensor_Data->YouQiHuiShou_State_OnOff=ArrayUni_MoniLiang[5].u32_Data;
  2800. pT2C_ALL_Sensor_Data->YouQiHuiShou_State_Photo=ArrayUni_MoniLiang[6].u32_Data;
  2801. pT2C_ALL_Sensor_Data->ResPara[0]=ArrayUni_MoniLiang[7].u32_Data;
  2802. for(j001ReadAll=0;j001ReadAll<13;j001ReadAll++)
  2803. {//帧头数据16字节
  2804. pT2C_ALL_Sensor_Data->ResPara[j001ReadAll]=ArrayUni_MoniLiang[j001ReadAll+7].u32_Data;
  2805. }//帧头数据16字节
  2806. __NOP();
  2807. pT2C_ALL_Sensor_Data->chkCRCModbus_Data[0]=USART2_RX_BUF_Collector[LengthOfData_From_Caijiban_WholeCar-2];
  2808. pT2C_ALL_Sensor_Data->chkCRCModbus_Data[1]=USART2_RX_BUF_Collector[LengthOfData_From_Caijiban_WholeCar-1];
  2809. __NOP();
  2810. memset(USART2_RX_BUF, 0x00, sizeof(USART2_RX_BUF)); //清除接收缓存
  2811. }//如果回复的校验正确---实际为功能码或者消息ID能够匹配
  2812. else
  2813. {//接收错误异常处理:未接收到数据,或者校验错误等
  2814. Usart2_ErrorTimes++;
  2815. }
  2816. }