CollectMaster485.c 97 KB

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