CollectMaster485.c 97 KB

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