MmiData.c 176 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798991001011021031041051061071081091101111121131141151161171181191201211221231241251261271281291301311321331341351361371381391401411421431441451461471481491501511521531541551561571581591601611621631641651661671681691701711721731741751761771781791801811821831841851861871881891901911921931941951961971981992002012022032042052062072082092102112122132142152162172182192202212222232242252262272282292302312322332342352362372382392402412422432442452462472482492502512522532542552562572582592602612622632642652662672682692702712722732742752762772782792802812822832842852862872882892902912922932942952962972982993003013023033043053063073083093103113123133143153163173183193203213223233243253263273283293303313323333343353363373383393403413423433443453463473483493503513523533543553563573583593603613623633643653663673683693703713723733743753763773783793803813823833843853863873883893903913923933943953963973983994004014024034044054064074084094104114124134144154164174184194204214224234244254264274284294304314324334344354364374384394404414424434444454464474484494504514524534544554564574584594604614624634644654664674684694704714724734744754764774784794804814824834844854864874884894904914924934944954964974984995005015025035045055065075085095105115125135145155165175185195205215225235245255265275285295305315325335345355365375385395405415425435445455465475485495505515525535545555565575585595605615625635645655665675685695705715725735745755765775785795805815825835845855865875885895905915925935945955965975985996006016026036046056066076086096106116126136146156166176186196206216226236246256266276286296306316326336346356366376386396406416426436446456466476486496506516526536546556566576586596606616626636646656666676686696706716726736746756766776786796806816826836846856866876886896906916926936946956966976986997007017027037047057067077087097107117127137147157167177187197207217227237247257267277287297307317327337347357367377387397407417427437447457467477487497507517527537547557567577587597607617627637647657667677687697707717727737747757767777787797807817827837847857867877887897907917927937947957967977987998008018028038048058068078088098108118128138148158168178188198208218228238248258268278288298308318328338348358368378388398408418428438448458468478488498508518528538548558568578588598608618628638648658668678688698708718728738748758768778788798808818828838848858868878888898908918928938948958968978988999009019029039049059069079089099109119129139149159169179189199209219229239249259269279289299309319329339349359369379389399409419429439449459469479489499509519529539549559569579589599609619629639649659669679689699709719729739749759769779789799809819829839849859869879889899909919929939949959969979989991000100110021003100410051006100710081009101010111012101310141015101610171018101910201021102210231024102510261027102810291030103110321033103410351036103710381039104010411042104310441045104610471048104910501051105210531054105510561057105810591060106110621063106410651066106710681069107010711072107310741075107610771078107910801081108210831084108510861087108810891090109110921093109410951096109710981099110011011102110311041105110611071108110911101111111211131114111511161117111811191120112111221123112411251126112711281129113011311132113311341135113611371138113911401141114211431144114511461147114811491150115111521153115411551156115711581159116011611162116311641165116611671168116911701171117211731174117511761177117811791180118111821183118411851186118711881189119011911192119311941195119611971198119912001201120212031204120512061207120812091210121112121213121412151216121712181219122012211222122312241225122612271228122912301231123212331234123512361237123812391240124112421243124412451246124712481249125012511252125312541255125612571258125912601261126212631264126512661267126812691270127112721273127412751276127712781279128012811282128312841285128612871288128912901291129212931294129512961297129812991300130113021303130413051306130713081309131013111312131313141315131613171318131913201321132213231324132513261327132813291330133113321333133413351336133713381339134013411342134313441345134613471348134913501351135213531354135513561357135813591360136113621363136413651366136713681369137013711372137313741375137613771378137913801381138213831384138513861387138813891390139113921393139413951396139713981399140014011402140314041405140614071408140914101411141214131414141514161417141814191420142114221423142414251426142714281429143014311432143314341435143614371438143914401441144214431444144514461447144814491450145114521453145414551456145714581459146014611462146314641465146614671468146914701471147214731474147514761477147814791480148114821483148414851486148714881489149014911492149314941495149614971498149915001501150215031504150515061507150815091510151115121513151415151516151715181519152015211522152315241525152615271528152915301531153215331534153515361537153815391540154115421543154415451546154715481549155015511552155315541555155615571558155915601561156215631564156515661567156815691570157115721573157415751576157715781579158015811582158315841585158615871588158915901591159215931594159515961597159815991600160116021603160416051606160716081609161016111612161316141615161616171618161916201621162216231624162516261627162816291630163116321633163416351636163716381639164016411642164316441645164616471648164916501651165216531654165516561657165816591660166116621663166416651666166716681669167016711672167316741675167616771678167916801681168216831684168516861687168816891690169116921693169416951696169716981699170017011702170317041705170617071708170917101711171217131714171517161717171817191720172117221723172417251726172717281729173017311732173317341735173617371738173917401741174217431744174517461747174817491750175117521753175417551756175717581759176017611762176317641765176617671768176917701771177217731774177517761777177817791780178117821783178417851786178717881789179017911792179317941795179617971798179918001801180218031804180518061807180818091810181118121813181418151816181718181819182018211822182318241825182618271828182918301831183218331834183518361837183818391840184118421843184418451846184718481849185018511852185318541855185618571858185918601861186218631864186518661867186818691870187118721873187418751876187718781879188018811882188318841885188618871888188918901891189218931894189518961897189818991900190119021903190419051906190719081909191019111912191319141915191619171918191919201921192219231924192519261927192819291930193119321933193419351936193719381939194019411942194319441945194619471948194919501951195219531954195519561957195819591960196119621963196419651966196719681969197019711972197319741975197619771978197919801981198219831984198519861987198819891990199119921993199419951996199719981999200020012002200320042005200620072008200920102011201220132014201520162017201820192020202120222023202420252026202720282029203020312032203320342035203620372038203920402041204220432044204520462047204820492050205120522053205420552056205720582059206020612062206320642065206620672068206920702071207220732074207520762077207820792080208120822083208420852086208720882089209020912092209320942095209620972098209921002101210221032104210521062107210821092110211121122113211421152116211721182119212021212122212321242125212621272128212921302131213221332134213521362137213821392140214121422143214421452146214721482149215021512152215321542155215621572158215921602161216221632164216521662167216821692170217121722173217421752176217721782179218021812182218321842185218621872188218921902191219221932194219521962197219821992200220122022203220422052206220722082209221022112212221322142215221622172218221922202221222222232224222522262227222822292230223122322233223422352236223722382239224022412242224322442245224622472248224922502251225222532254225522562257225822592260226122622263226422652266226722682269227022712272227322742275227622772278227922802281228222832284228522862287228822892290229122922293229422952296229722982299230023012302230323042305230623072308230923102311231223132314231523162317231823192320232123222323232423252326232723282329233023312332233323342335233623372338233923402341234223432344234523462347234823492350235123522353235423552356235723582359236023612362236323642365236623672368236923702371237223732374237523762377237823792380238123822383238423852386238723882389239023912392239323942395239623972398239924002401240224032404240524062407240824092410241124122413241424152416241724182419242024212422242324242425242624272428242924302431243224332434243524362437243824392440244124422443244424452446244724482449245024512452245324542455245624572458245924602461246224632464246524662467246824692470247124722473247424752476247724782479248024812482248324842485248624872488248924902491249224932494249524962497249824992500250125022503250425052506250725082509251025112512251325142515251625172518251925202521252225232524252525262527252825292530253125322533253425352536253725382539254025412542254325442545254625472548254925502551255225532554255525562557255825592560256125622563256425652566256725682569257025712572257325742575257625772578257925802581258225832584258525862587258825892590259125922593259425952596259725982599260026012602260326042605260626072608260926102611261226132614261526162617261826192620262126222623262426252626262726282629263026312632263326342635263626372638263926402641264226432644264526462647264826492650265126522653265426552656265726582659266026612662266326642665266626672668266926702671267226732674267526762677267826792680268126822683268426852686268726882689269026912692269326942695269626972698269927002701270227032704270527062707270827092710271127122713271427152716271727182719272027212722272327242725272627272728272927302731273227332734273527362737273827392740274127422743274427452746274727482749275027512752275327542755275627572758275927602761276227632764276527662767276827692770277127722773277427752776277727782779278027812782278327842785278627872788278927902791279227932794279527962797279827992800280128022803280428052806280728082809281028112812281328142815281628172818281928202821282228232824282528262827282828292830283128322833283428352836283728382839284028412842284328442845284628472848284928502851285228532854285528562857285828592860286128622863286428652866286728682869287028712872287328742875287628772878287928802881288228832884288528862887288828892890289128922893289428952896289728982899290029012902290329042905290629072908290929102911291229132914291529162917291829192920292129222923292429252926292729282929293029312932293329342935293629372938293929402941294229432944294529462947294829492950295129522953295429552956295729582959296029612962296329642965296629672968296929702971297229732974297529762977297829792980298129822983298429852986298729882989299029912992299329942995299629972998299930003001300230033004300530063007300830093010301130123013301430153016301730183019302030213022302330243025302630273028302930303031303230333034303530363037303830393040304130423043304430453046304730483049305030513052305330543055305630573058305930603061306230633064306530663067306830693070307130723073307430753076307730783079308030813082308330843085308630873088308930903091309230933094309530963097309830993100310131023103310431053106310731083109311031113112311331143115311631173118311931203121312231233124312531263127312831293130313131323133313431353136313731383139314031413142314331443145314631473148314931503151315231533154315531563157315831593160316131623163316431653166316731683169317031713172317331743175317631773178317931803181318231833184318531863187318831893190319131923193319431953196319731983199320032013202320332043205320632073208320932103211321232133214321532163217321832193220322132223223322432253226322732283229323032313232323332343235323632373238323932403241324232433244324532463247324832493250325132523253325432553256325732583259326032613262326332643265326632673268326932703271327232733274327532763277327832793280328132823283328432853286328732883289329032913292329332943295329632973298329933003301330233033304330533063307330833093310331133123313331433153316331733183319332033213322332333243325332633273328332933303331333233333334333533363337333833393340334133423343334433453346334733483349335033513352335333543355335633573358335933603361336233633364336533663367336833693370337133723373337433753376337733783379338033813382338333843385338633873388338933903391339233933394339533963397339833993400340134023403340434053406340734083409341034113412341334143415341634173418341934203421342234233424342534263427342834293430343134323433343434353436343734383439344034413442344334443445344634473448344934503451345234533454345534563457345834593460346134623463346434653466346734683469347034713472347334743475347634773478347934803481348234833484348534863487348834893490349134923493349434953496349734983499350035013502350335043505350635073508350935103511351235133514351535163517351835193520352135223523352435253526352735283529353035313532353335343535353635373538353935403541354235433544354535463547354835493550355135523553355435553556355735583559356035613562356335643565356635673568356935703571357235733574357535763577357835793580358135823583358435853586358735883589359035913592359335943595359635973598359936003601360236033604360536063607360836093610361136123613361436153616361736183619362036213622362336243625362636273628362936303631363236333634363536363637363836393640364136423643364436453646364736483649365036513652365336543655365636573658365936603661366236633664366536663667366836693670367136723673367436753676367736783679368036813682368336843685368636873688368936903691369236933694369536963697369836993700370137023703370437053706370737083709371037113712371337143715371637173718371937203721372237233724372537263727372837293730373137323733373437353736373737383739374037413742374337443745374637473748374937503751375237533754375537563757375837593760376137623763376437653766376737683769377037713772377337743775377637773778377937803781378237833784378537863787378837893790379137923793379437953796379737983799380038013802380338043805380638073808380938103811381238133814381538163817381838193820382138223823382438253826382738283829383038313832383338343835383638373838383938403841384238433844384538463847384838493850385138523853385438553856385738583859386038613862386338643865386638673868386938703871387238733874387538763877387838793880388138823883388438853886388738883889389038913892389338943895389638973898389939003901390239033904390539063907390839093910391139123913391439153916391739183919392039213922392339243925392639273928392939303931393239333934393539363937393839393940394139423943394439453946394739483949395039513952395339543955395639573958395939603961396239633964396539663967396839693970397139723973397439753976397739783979398039813982398339843985398639873988398939903991399239933994399539963997399839994000400140024003400440054006400740084009401040114012401340144015401640174018401940204021402240234024402540264027402840294030403140324033403440354036403740384039404040414042404340444045404640474048404940504051405240534054405540564057405840594060406140624063406440654066406740684069407040714072407340744075407640774078407940804081408240834084408540864087408840894090409140924093409440954096409740984099410041014102410341044105410641074108410941104111411241134114411541164117411841194120412141224123412441254126412741284129413041314132413341344135413641374138413941404141414241434144414541464147414841494150415141524153415441554156415741584159416041614162416341644165416641674168416941704171417241734174417541764177417841794180418141824183418441854186418741884189419041914192419341944195419641974198419942004201420242034204420542064207420842094210421142124213421442154216421742184219422042214222422342244225422642274228422942304231423242334234423542364237423842394240424142424243424442454246424742484249425042514252425342544255425642574258425942604261426242634264426542664267426842694270427142724273427442754276427742784279428042814282428342844285428642874288428942904291429242934294429542964297429842994300430143024303430443054306430743084309431043114312431343144315431643174318431943204321432243234324432543264327432843294330433143324333433443354336433743384339434043414342434343444345434643474348434943504351435243534354435543564357435843594360436143624363436443654366436743684369437043714372437343744375437643774378437943804381438243834384438543864387438843894390439143924393439443954396439743984399440044014402440344044405440644074408440944104411441244134414441544164417441844194420442144224423442444254426442744284429443044314432443344344435443644374438443944404441444244434444444544464447444844494450445144524453445444554456445744584459446044614462446344644465446644674468446944704471447244734474447544764477447844794480448144824483448444854486448744884489449044914492449344944495449644974498449945004501450245034504450545064507450845094510451145124513451445154516451745184519452045214522452345244525452645274528452945304531453245334534453545364537453845394540454145424543454445454546454745484549455045514552455345544555455645574558455945604561456245634564456545664567456845694570457145724573457445754576457745784579458045814582458345844585458645874588458945904591459245934594459545964597459845994600460146024603460446054606460746084609461046114612461346144615461646174618461946204621462246234624462546264627462846294630463146324633463446354636463746384639464046414642464346444645464646474648464946504651465246534654465546564657465846594660466146624663466446654666466746684669467046714672467346744675467646774678467946804681468246834684468546864687468846894690469146924693469446954696469746984699470047014702470347044705470647074708470947104711471247134714471547164717471847194720472147224723472447254726472747284729473047314732473347344735473647374738473947404741474247434744474547464747474847494750475147524753475447554756475747584759476047614762476347644765476647674768476947704771477247734774477547764777477847794780478147824783478447854786478747884789479047914792479347944795479647974798479948004801480248034804480548064807480848094810481148124813481448154816481748184819482048214822482348244825482648274828482948304831483248334834483548364837483848394840484148424843484448454846484748484849485048514852485348544855485648574858485948604861486248634864486548664867486848694870487148724873487448754876487748784879488048814882488348844885488648874888488948904891489248934894489548964897489848994900490149024903490449054906490749084909491049114912491349144915491649174918491949204921492249234924492549264927492849294930493149324933493449354936493749384939494049414942494349444945494649474948494949504951495249534954495549564957495849594960496149624963496449654966496749684969497049714972497349744975497649774978497949804981498249834984498549864987498849894990499149924993499449954996499749984999500050015002500350045005500650075008500950105011501250135014501550165017501850195020502150225023502450255026502750285029503050315032503350345035503650375038503950405041504250435044504550465047504850495050505150525053505450555056505750585059506050615062506350645065506650675068506950705071507250735074507550765077507850795080508150825083508450855086508750885089509050915092509350945095509650975098509951005101510251035104510551065107510851095110511151125113511451155116511751185119512051215122512351245125512651275128512951305131513251335134513551365137513851395140514151425143514451455146514751485149515051515152515351545155515651575158515951605161516251635164516551665167516851695170517151725173517451755176517751785179518051815182518351845185518651875188518951905191519251935194519551965197519851995200520152025203520452055206520752085209521052115212521352145215521652175218521952205221522252235224522552265227522852295230523152325233523452355236523752385239524052415242524352445245524652475248524952505251525252535254525552565257525852595260526152625263526452655266526752685269527052715272527352745275527652775278527952805281528252835284528552865287528852895290529152925293529452955296529752985299530053015302530353045305530653075308530953105311531253135314531553165317531853195320532153225323532453255326532753285329533053315332533353345335533653375338533953405341534253435344534553465347534853495350535153525353535453555356535753585359536053615362536353645365536653675368536953705371537253735374537553765377537853795380538153825383538453855386538753885389539053915392539353945395539653975398539954005401540254035404540554065407540854095410541154125413541454155416541754185419542054215422542354245425542654275428542954305431543254335434543554365437543854395440544154425443544454455446544754485449545054515452545354545455545654575458545954605461546254635464546554665467546854695470547154725473547454755476547754785479548054815482548354845485548654875488548954905491549254935494549554965497549854995500550155025503550455055506550755085509551055115512551355145515551655175518551955205521552255235524552555265527552855295530553155325533553455355536553755385539554055415542554355445545554655475548554955505551555255535554555555565557555855595560556155625563556455655566556755685569557055715572557355745575557655775578557955805581558255835584558555865587558855895590559155925593559455955596559755985599560056015602560356045605560656075608560956105611561256135614561556165617561856195620562156225623562456255626562756285629563056315632563356345635563656375638563956405641564256435644564556465647564856495650565156525653565456555656565756585659566056615662566356645665566656675668566956705671567256735674567556765677567856795680568156825683568456855686568756885689569056915692569356945695569656975698569957005701570257035704570557065707570857095710571157125713571457155716571757185719572057215722572357245725572657275728572957305731573257335734573557365737573857395740574157425743574457455746574757485749575057515752575357545755575657575758575957605761576257635764576557665767576857695770577157725773577457755776577757785779578057815782578357845785578657875788578957905791579257935794579557965797579857995800580158025803580458055806580758085809581058115812581358145815581658175818581958205821582258235824582558265827582858295830583158325833583458355836583758385839584058415842584358445845584658475848584958505851585258535854585558565857585858595860586158625863586458655866586758685869587058715872587358745875587658775878587958805881588258835884588558865887588858895890589158925893589458955896589758985899590059015902590359045905590659075908590959105911591259135914591559165917591859195920592159225923592459255926592759285929593059315932593359345935593659375938593959405941594259435944594559465947594859495950595159525953595459555956595759585959596059615962596359645965596659675968596959705971597259735974597559765977597859795980598159825983598459855986598759885989599059915992599359945995599659975998599960006001600260036004600560066007600860096010601160126013601460156016601760186019602060216022602360246025602660276028602960306031603260336034603560366037603860396040604160426043604460456046604760486049605060516052605360546055605660576058605960606061606260636064606560666067606860696070607160726073607460756076607760786079608060816082608360846085608660876088608960906091609260936094609560966097609860996100610161026103610461056106610761086109611061116112611361146115611661176118611961206121612261236124612561266127612861296130613161326133613461356136613761386139614061416142614361446145614661476148614961506151615261536154615561566157615861596160616161626163616461656166616761686169617061716172617361746175617661776178617961806181618261836184618561866187618861896190619161926193619461956196619761986199620062016202620362046205620662076208620962106211621262136214621562166217621862196220622162226223622462256226622762286229623062316232623362346235623662376238623962406241624262436244624562466247624862496250625162526253625462556256625762586259626062616262626362646265626662676268626962706271627262736274627562766277627862796280628162826283628462856286628762886289629062916292629362946295629662976298629963006301630263036304630563066307630863096310631163126313631463156316631763186319632063216322632363246325632663276328632963306331633263336334633563366337633863396340634163426343634463456346634763486349635063516352635363546355635663576358635963606361636263636364636563666367636863696370637163726373637463756376637763786379638063816382638363846385638663876388638963906391639263936394639563966397639863996400640164026403640464056406640764086409641064116412641364146415641664176418641964206421642264236424642564266427642864296430643164326433643464356436643764386439644064416442644364446445644664476448644964506451645264536454645564566457645864596460646164626463646464656466646764686469647064716472647364746475647664776478647964806481648264836484648564866487648864896490649164926493649464956496649764986499650065016502650365046505650665076508650965106511651265136514651565166517651865196520652165226523652465256526652765286529653065316532653365346535653665376538653965406541654265436544654565466547654865496550655165526553655465556556655765586559656065616562656365646565656665676568656965706571657265736574657565766577657865796580658165826583658465856586658765886589659065916592659365946595659665976598659966006601660266036604660566066607660866096610661166126613661466156616661766186619662066216622662366246625662666276628662966306631663266336634663566366637663866396640664166426643664466456646664766486649665066516652665366546655665666576658665966606661666266636664666566666667666866696670667166726673667466756676667766786679668066816682668366846685668666876688668966906691669266936694669566966697669866996700670167026703670467056706670767086709671067116712671367146715671667176718671967206721672267236724672567266727672867296730673167326733673467356736673767386739674067416742674367446745674667476748674967506751675267536754675567566757675867596760676167626763676467656766676767686769677067716772677367746775677667776778677967806781678267836784678567866787678867896790679167926793679467956796679767986799680068016802680368046805680668076808680968106811681268136814681568166817681868196820682168226823682468256826682768286829683068316832683368346835683668376838683968406841684268436844684568466847684868496850685168526853685468556856685768586859686068616862686368646865686668676868686968706871687268736874687568766877687868796880688168826883688468856886688768886889689068916892689368946895689668976898689969006901690269036904690569066907690869096910691169126913691469156916691769186919692069216922692369246925692669276928692969306931693269336934693569366937693869396940694169426943694469456946694769486949695069516952695369546955695669576958695969606961696269636964696569666967696869696970697169726973697469756976697769786979698069816982698369846985698669876988698969906991699269936994699569966997699869997000700170027003700470057006700770087009701070117012701370147015701670177018701970207021702270237024702570267027702870297030703170327033703470357036703770387039704070417042704370447045704670477048704970507051705270537054705570567057705870597060706170627063706470657066706770687069707070717072707370747075707670777078707970807081708270837084708570867087708870897090709170927093709470957096709770987099710071017102710371047105710671077108710971107111711271137114711571167117711871197120712171227123712471257126712771287129713071317132713371347135713671377138713971407141714271437144714571467147714871497150715171527153715471557156715771587159716071617162716371647165716671677168716971707171717271737174717571767177717871797180718171827183718471857186718771887189719071917192719371947195719671977198719972007201720272037204720572067207720872097210721172127213721472157216721772187219722072217222722372247225722672277228722972307231723272337234723572367237723872397240724172427243724472457246724772487249725072517252725372547255725672577258725972607261726272637264726572667267726872697270727172727273727472757276727772787279728072817282728372847285728672877288728972907291729272937294729572967297729872997300730173027303730473057306730773087309731073117312731373147315731673177318731973207321732273237324732573267327732873297330733173327333733473357336733773387339734073417342734373447345734673477348734973507351735273537354735573567357735873597360736173627363736473657366736773687369737073717372737373747375737673777378737973807381738273837384738573867387738873897390739173927393739473957396739773987399740074017402740374047405740674077408740974107411741274137414741574167417741874197420742174227423742474257426742774287429743074317432743374347435743674377438743974407441744274437444744574467447744874497450745174527453745474557456745774587459746074617462746374647465746674677468746974707471747274737474747574767477747874797480748174827483748474857486748774887489749074917492749374947495749674977498749975007501750275037504750575067507750875097510751175127513751475157516751775187519752075217522752375247525752675277528752975307531753275337534753575367537753875397540754175427543754475457546754775487549755075517552755375547555755675577558755975607561756275637564756575667567756875697570757175727573757475757576757775787579758075817582758375847585758675877588758975907591759275937594759575967597759875997600760176027603760476057606760776087609761076117612761376147615761676177618761976207621762276237624762576267627762876297630763176327633763476357636763776387639764076417642764376447645764676477648764976507651765276537654765576567657765876597660766176627663766476657666766776687669767076717672767376747675767676777678767976807681768276837684768576867687768876897690769176927693769476957696769776987699770077017702770377047705770677077708770977107711771277137714771577167717771877197720772177227723772477257726772777287729773077317732773377347735773677377738773977407741774277437744774577467747774877497750775177527753775477557756775777587759776077617762776377647765776677677768776977707771777277737774777577767777777877797780778177827783778477857786778777887789779077917792779377947795779677977798779978007801780278037804780578067807780878097810781178127813781478157816781778187819782078217822782378247825782678277828782978307831783278337834783578367837783878397840784178427843784478457846784778487849785078517852785378547855785678577858785978607861786278637864786578667867786878697870787178727873787478757876787778787879788078817882788378847885788678877888788978907891789278937894789578967897789878997900790179027903790479057906790779087909791079117912791379147915791679177918791979207921792279237924792579267927792879297930793179327933793479357936793779387939794079417942794379447945794679477948794979507951795279537954795579567957795879597960796179627963796479657966796779687969797079717972797379747975797679777978797979807981798279837984798579867987798879897990799179927993799479957996799779987999800080018002800380048005800680078008800980108011801280138014801580168017801880198020802180228023802480258026802780288029803080318032803380348035803680378038803980408041804280438044804580468047804880498050805180528053805480558056805780588059806080618062806380648065806680678068806980708071807280738074807580768077807880798080808180828083808480858086808780888089809080918092809380948095809680978098809981008101810281038104810581068107810881098110811181128113811481158116811781188119812081218122812381248125812681278128812981308131813281338134813581368137813881398140814181428143814481458146814781488149815081518152815381548155815681578158815981608161816281638164816581668167816881698170817181728173817481758176817781788179818081818182818381848185818681878188818981908191819281938194819581968197819881998200820182028203820482058206820782088209821082118212821382148215821682178218821982208221822282238224822582268227822882298230823182328233823482358236823782388239824082418242824382448245824682478248824982508251825282538254825582568257825882598260826182628263826482658266826782688269827082718272827382748275827682778278827982808281828282838284828582868287828882898290829182928293829482958296
  1. /********************************************************************
  2. 版权所有:
  3. 文件版本: V1.00
  4. 文件名称: Mmidata.c
  5. 生成日期: 2008年09月9日
  6. 作 者:
  7. 使用范围:
  8. 功 能:菜单调用的各种处理函数
  9. 更新信息:
  10. 更新日志1:
  11. 修改者:
  12. 修改日期:
  13. 修改内容:
  14. 修改原因:
  15. *********************************************************************/
  16. #include "head.h"
  17. #if defined LINUX_KERNEL_APP
  18. #include <linux/delay.h>
  19. #endif
  20. #include "uart_user.h"
  21. #define LCD_SIZE 160
  22. UINT m_ScreenNum;
  23. UINT m_CurrentScreen;
  24. UINT m_SwNo;
  25. DATA_MENU_DEF g_tDataMenu1; //数据菜单定义
  26. DATA_MENU_DEF g_tDataMenu2; //数据菜单定义
  27. DATA_MENU_DEF g_tExtraMenu;
  28. char m_WarningStr[PARA_NAME_LEN]; //提示信息字符
  29. char m_errInf[24]; // 错误信息保存
  30. UINT m_Password; //密码
  31. UINT m_NewPassword; //密码修改时新密码
  32. char m_strPassword[10];
  33. char m_strPassword2[10];
  34. char m_YdYcHalfOfRateValue[16]="";
  35. UINT m_AllSection; //全部定值区选择时选择的定值区
  36. UINT m_ValidSection; //有效定值区选择时选择的定值区
  37. UINT m_CtrlWord; // 当前显示控制子
  38. char m_set_name[24]; // 定值名称
  39. char m_set_name_ext[24]; // 定值名称
  40. char m_set_inf[24]; // 定值信息1 ,显示提示信息
  41. //#ifdef DISP_LIST_NUM
  42. char LIST_tmp[MAX_SET_NUMBER][MOD_NAME_LEN]; //存放定值选项字符串及对应数字的数组(如:"0:退出"、"1:投入")
  43. //#endif
  44. #ifdef CPU_FUXI
  45. char menu_tmp[MAX_SET_NUMBER][MOD_NAME_LEN];
  46. #endif
  47. SET_VALUE m_SetBuf[MAX_SET_NUMBER];// 定义定值查看及整定时的buf
  48. INDEX_DEF g_tIndex[INDEX_NUM]; // 名称 值索引结构定义
  49. const char *TestDo_Hz="合";
  50. WORD g_sw_index;
  51. char m_equipstr[22];
  52. u8 m_setgroup[GROUP_NUM];
  53. u8 bPubSetMenuShow[SET_PUB_NUM];
  54. u8 bSwSetMenuShow[SET_NUM];
  55. u8 bParaSetMenuShow[PARA_NUM];
  56. u8 bCstSetMenuShow[CSTSET_NUM];
  57. char m_Ledgoose[12];
  58. char m_Ledbh[12];
  59. char m_Ledfa[12];
  60. char m_Fa_sl[12];
  61. char m_Bh_chr[12];
  62. char m_Fa_chr[12];
  63. char m_Goose_chr[12];
  64. char m_Ledjzs[12];
  65. char m_TzCount[12];
  66. char m_HzCount[12];
  67. WORD m_selsection;
  68. WORD m_sectionnum;
  69. char m_selsec_char[10];
  70. char m_Mode_chr[20];
  71. char m_Tqhz_chr[20];
  72. char m_Zdjl_chr[20];
  73. char m_StopFun_chr[20];
  74. char m_Yftr_chr[20];
  75. bool mmd_CheckPassword2(void)
  76. {
  77. u8 passstr[10];
  78. #ifdef PASSWORD_4_STR
  79. strcpy(passstr,INTER_PASSWORD_STR_4);
  80. #else
  81. strcpy(passstr,INTER_PASSWORD_STR);
  82. #endif
  83. if((strcmp(m_strPassword,tRunPara.wPasswordstr2)!=0)&&(strcmp(m_strPassword,passstr)!=0))
  84. {
  85. m_Password=0;
  86. mmi_zero_passwordstr();
  87. strcpy(m_WarningStr,"输入密码错误!");
  88. return false;
  89. }
  90. m_Password=0;
  91. mmi_zero_passwordstr();
  92. return true;
  93. }
  94. /**************************************************************************
  95. 函数名称:mmd_RenewDataMenu
  96. 函数版本:1.00
  97. 作者:
  98. 创建日期:2008.9.1
  99. 函数功能说明:刷新动态菜单
  100. 输入参数:
  101. 输出参数:
  102. 返回值:
  103. 更新信息:
  104. 更新日志1:
  105. 日期:
  106. 修改者:
  107. 修改内容:
  108. 修改原因:
  109. ***************************************************************************/
  110. static int mmd_RenewDataMenu(DATA_MENU_DEF *pt)
  111. {
  112. int i;
  113. int index=(pt->sFocusIndex/pt->sScreenNum)*pt->sScreenNum; //当前显示的动态数据的索引
  114. for(i=0;i<pt->sScreenNum;i++) //更新显示项
  115. {
  116. (*pt->GetValueFuncAddr)(index,&pt->tDataFields[i]);
  117. if(++index>pt->sTotalNum-1) break; //最后一个CPU
  118. }
  119. m_CurrentScreen=(pt->sFocusIndex/pt->sScreenNum)+1; //当前屏数
  120. return M_OK;
  121. }
  122. /**************************************************************************
  123. 函数名称:mmd_initDataMenu
  124. 函数版本:1.00
  125. 作者:
  126. 创建日期:2008.9.1
  127. 函数功能说明:初始化动态菜单
  128. 输入参数:pt 动态显示数据结构,num最大显示数目
  129. fun_next,转下一屏处理函数,
  130. fun_value 取值函数
  131. menuno,fieldno 要显示的屏号和域号
  132. type,轮询召唤的类型
  133. 输出参数:
  134. 返回值:
  135. 更新信息:
  136. 更新日志1:
  137. 日期:
  138. 修改者:
  139. 修改内容:
  140. 修改原因:
  141. ***************************************************************************/
  142. static void mmd_initDataMenu(DATA_MENU_DEF *pt,int num,void *fun_next,void *fun_value,unsigned char menuno,unsigned char fieldno)
  143. {
  144. int i;
  145. int (*pfun)(int i,DATA_FIELD_DEF *pd);
  146. int screennum;
  147. pfun=(int(*)(int i,DATA_FIELD_DEF *pF))fun_value; //更新显示数据的函数
  148. screennum=mmi_GetScreenNum(menuno,fieldno); // 取当前屏幕最大显示树木
  149. if(fun_value!=NULL)
  150. {
  151. for(i=0;i<screennum;i++) // 更新显示数据
  152. {
  153. (*pfun)(i,&pt->tDataFields[i]);
  154. if(i>=num-1)break;
  155. }
  156. }
  157. if(screennum<=0)screennum=1;
  158. m_ScreenNum=num/screennum;
  159. if(num%screennum>0)m_ScreenNum+=1;
  160. pt->sFocusIndex=0; //第一个显示的动态菜单的索引
  161. pt->sTotalNum=num; //总的动态菜单数
  162. pt->sScreenNum=screennum;
  163. pt->GetPrevFuncAddr=fun_next; //44
  164. pt->GetNextFuncAddr=fun_next; //44
  165. pt->GetValueFuncAddr=fun_value;
  166. m_CurrentScreen=1;
  167. }
  168. /**************************************************************************
  169. 函数名称:mmd_IndexMenuKey
  170. 函数版本:1.00
  171. 作者:
  172. 创建日期:2008.9.1
  173. 函数功能说明:列表选择时,按键的处理函数
  174. 输入参数:
  175. 输出参数:
  176. 返回值:
  177. 更新信息:
  178. 更新日志1:
  179. 日期:
  180. 修改者:
  181. 修改内容:
  182. 修改原因:
  183. ***************************************************************************/
  184. int mmd_IndexMenuKey(int key)
  185. {
  186. int t;
  187. INDEX_DEF *pt;
  188. t=mmi_GetActiveFieldPara(); // 取得当前列表结构的下标
  189. if(t>=INDEX_NUM)return M_ERROR;
  190. pt=&g_tIndex[t];
  191. if(pt->num<=0)return M_ERROR;
  192. if(key==HA_KEY_ENTER) //确认键处理
  193. {
  194. int ret;
  195. *pt->pValue=pt->value[pt->bCurrent]; //赋值
  196. if(pt->EnterFunc!=NULL)
  197. {
  198. ret=(*pt->EnterFunc)(); // 执行函数
  199. return ret;
  200. }
  201. return M_OK;
  202. }
  203. if(key!=HA_KEY_ADD&&key!=HA_KEY_SUB)return M_ERROR;
  204. if(key==HA_KEY_ADD) // +键处理
  205. {
  206. pt->bCurrent++;
  207. }
  208. else if(key==HA_KEY_SUB) // +键处理
  209. {
  210. if(pt->bCurrent==0)
  211. {
  212. pt->bCurrent=pt->num-1;
  213. }
  214. else
  215. {
  216. pt->bCurrent--;
  217. }
  218. }
  219. if(pt->bCurrent>=pt->num)
  220. {
  221. pt->bCurrent=0;
  222. }
  223. strcpy(pt->str,pt->name[pt->bCurrent]); //更新列表显示
  224. *pt->pValue=pt->value[pt->bCurrent];
  225. return M_OK;
  226. }
  227. /***********************定值修改**********************************/
  228. /**************************************************************************
  229. 函数名称:mmd_IsIntegType
  230. 函数版本:1.00
  231. 作者:
  232. 创建日期:2008.9.23
  233. 函数功能说明: 判断参数类型是否为整型类型的
  234. 输入参数:
  235. 输出参数:
  236. 返回值:
  237. 更新信息:
  238. 更新日志1:
  239. 日期:
  240. 修改者:
  241. 修改内容:
  242. 修改原因:
  243. ***************************************************************************/
  244. static bool mmd_IsIntegType(WORD type)
  245. {
  246. if(type==SETTYPE_KG||type==SETTYPE_LIST||type==SETTYPE_UINT||type==SETTYPE_LINT||type==SETTYPE_5INT||type==SETTYPE_4INT)
  247. {
  248. return true;
  249. }
  250. return false;
  251. }
  252. static bool mmd_IsHexType(WORD type)
  253. {
  254. if(type==SETTYPE_YMD||type==SETTYPE_HMS||type==SETTYPE_IP)
  255. {
  256. return true;
  257. }
  258. return false;
  259. }
  260. /**************************************************************************
  261. 函数名称:mmd_ChangeList
  262. 函数版本:1.00
  263. 作者:
  264. 创建日期:2008.9.1
  265. 函数功能说明:改变下拉列表的值
  266. 输入参数:
  267. 输出参数:
  268. 返回值:若是列表,返回真值
  269. 更新信息:
  270. 更新日志1:
  271. 日期:
  272. 修改者:
  273. 修改内容:
  274. 修改原因:
  275. ***************************************************************************/
  276. static bool mmd_ChangeList(const TSETTABLE *pSetTable,int key,SET_VALUE *setbuf)
  277. {
  278. int setno;
  279. const TSETTABLE *pTable;
  280. long listvalue;
  281. //判断是否是列表
  282. setno=g_set_disp.no[mmi_GetActiveFieldIndex()];//取得当前定值的索引,判断是否是列表项
  283. pTable=&pSetTable[setno];
  284. if(pTable->wType==SETTYPE_LIST) // 列表项
  285. {
  286. listvalue=setbuf[setno].tt; //取得控制字的值
  287. if(key==HA_KEY_ADD)
  288. {
  289. listvalue++;
  290. if(listvalue>=pTable->listnum)
  291. {
  292. listvalue=pTable->fMin;
  293. }
  294. }
  295. else if(key==HA_KEY_SUB)
  296. {
  297. if(listvalue>pTable->fMin)
  298. {
  299. listvalue--;
  300. }
  301. else
  302. {
  303. listvalue=pTable->listnum-1;
  304. }
  305. }
  306. setbuf[setno].tt=listvalue;//pTable->list[listvalue].dat;操作列表定值出问题
  307. return true;
  308. }
  309. return false;
  310. }
  311. /**************************************************************************
  312. 函数名称:mmd_ChangeSet
  313. 函数版本:1.00
  314. 作者:
  315. 创建日期:2008.9.11
  316. 函数功能说明:转换定值,将EEPROM中的值转换为菜单整定时使用的值,主要是控制字
  317. 由浮点数转为定点数
  318. 输入参数:
  319. 输出参数:
  320. 返回值:
  321. 更新信息:
  322. 更新日志1:
  323. 日期:
  324. 修改者:
  325. 修改内容:
  326. 修改原因:
  327. ***************************************************************************/
  328. bool mmd_checkset_yb(u8 index) //判断定值分类对应的压板是否有效
  329. {
  330. u8 yb,group_sub;
  331. int sw=0;
  332. //if(index==0)return true;
  333. //index-=1;
  334. u8 yb_fa_g = g_tRelay[sw].run_stu.fa_g_tt;
  335. yb=SetGroups[index].set_yb;
  336. #ifdef YB_AUTO_SELECT
  337. yb_fa_g = goose_yb_enable(sw)&&(yb==SET_HYB_GOOSE);
  338. #else
  339. #ifndef GD_AREA_ZHONGSHAN //非中山的地区,开关定值显示直接关联硬件压板。中山要求智能分布式模式下显示所有开关定值
  340. #ifndef GD_AREA_ZHONGSHAN_2020
  341. yb_fa_g = g_tRelay[sw].run_stu.fa_g_tt&&(yb==SET_HYB_GOOSE);
  342. #endif
  343. #endif
  344. #endif
  345. group_sub = SetGroups[index].group_sub;
  346. if(yb==0)return true;
  347. #ifdef GD_AREA_ECZD_2020
  348. if(yb==SET_HYB_TQ)
  349. {
  350. if(group_sub == GROUP_SET_TQHZ)
  351. {
  352. return (g_tRelay[sw].run_stu.bhtt)||yb_fa_g;
  353. }
  354. else
  355. {
  356. return g_tRelay[sw].run_stu.bhtt||yb_fa_g;
  357. }
  358. }
  359. if(yb==SET_HYB_JL)
  360. {
  361. if(group_sub == GROUP_SET_DYJL)
  362. {
  363. return (g_tRelay[sw].run_stu.bhtt)||yb_fa_g;
  364. }
  365. else
  366. {
  367. return g_tRelay[sw].run_stu.bhtt||yb_fa_g;
  368. }
  369. }
  370. #endif
  371. if(yb==SET_HYB_BH)
  372. {
  373. if((group_sub == GROUP_SET_DYJL)
  374. ||(group_sub == GROUP_SET_PLJL))
  375. {
  376. return g_tRelay[sw].run_stu.bhtt||yb_fa_g;
  377. }
  378. else if(group_sub == GROUP_SET_TQHZ)
  379. {
  380. return (g_tRelay[sw].run_stu.bhtt)||yb_fa_g;
  381. }
  382. else
  383. {
  384. #ifdef YB_AUTO_SELECT
  385. return bh_yb_enable(sw)||yb_fa_g;
  386. #else
  387. return g_tRelay[sw].run_stu.bhtt||yb_fa_g;
  388. #endif
  389. }
  390. }
  391. if(yb==SET_HYB_FA)
  392. {
  393. #ifdef YB_AUTO_SELECT
  394. return fa_yb_enable(sw)||yb_fa_g;
  395. #else
  396. return g_tRelay[sw].run_stu.fatt||yb_fa_g;
  397. #endif
  398. }
  399. if(yb==SET_HYB_GOOSE)
  400. {
  401. #ifdef YB_AUTO_SELECT
  402. return goose_yb_enable(sw);
  403. #else
  404. return g_tRelay[sw].run_stu.fa_g_tt;
  405. #endif
  406. }
  407. return true;
  408. }
  409. int mmd_ChangeSet(const TSETTABLE *pSet,int num,SET_VALUE *setbuf) //ext为不需显示的定值组
  410. {
  411. int i;
  412. for(i=0;i<num;i++)
  413. {
  414. if(mmd_IsIntegType(pSet[i].wType))
  415. {
  416. float ff=setbuf[i].ff;
  417. setbuf[i].tt=(uint32_t)ff;
  418. }
  419. }
  420. return 0;
  421. }
  422. bool mmd_checkset_menucfg(const TSETTABLE *pSet,int i,u8 group) //判断定值分类对应的压板是否有效
  423. {
  424. if(pSet==&tPubSetTable[0])
  425. {
  426. return bPubSetMenuShow[i]&&(tPubSetTable[i].group==group);
  427. }
  428. else if(pSet==&tSwSetTable[0])
  429. {
  430. return bSwSetMenuShow[i]&&(tSwSetTable[i].group==group);
  431. }
  432. else if(pSet==&tEquipParaTable[0])
  433. {
  434. return bParaSetMenuShow[i]&&(tEquipParaTable[i].group==group);
  435. }
  436. else if(pSet==&tCstSetTable[0])
  437. {
  438. return bCstSetMenuShow[i]&&(tCstSetTable[i].group==group);
  439. }
  440. return (pSet[i].group==group);
  441. }
  442. int mmd_GetshowSetNum(const TSETTABLE *pSet,int num,u8 group)
  443. {
  444. int i;
  445. for(i=0;i<num;i++)
  446. {
  447. if (pSet[i].wType != SETTYPE_LABEL)
  448. {
  449. bool bYB_set;
  450. bool bmenu_set;
  451. bmenu_set=mmd_checkset_menucfg(pSet,i,group);
  452. bYB_set=mmd_checkset_yb(pSet[i].group);
  453. if((m_setgroup[pSet[i].group])&&bYB_set&&bmenu_set) // 定值分类组为0 或显示定制为1
  454. {
  455. g_set_disp.no[g_set_disp.num] = i;
  456. g_set_disp.num++;
  457. }
  458. }
  459. }
  460. return g_set_disp.num;
  461. }
  462. /**************************************************************************
  463. 函数名称:mmd_CheckSet
  464. 函数版本:1.00
  465. 作者:
  466. 创建日期:2008.9.1
  467. 函数功能说明:检查参数
  468. 输入参数:
  469. 输出参数:
  470. 返回值:
  471. 更新信息:
  472. 更新日志1:
  473. 日期:
  474. 修改者:
  475. 修改内容:
  476. 修改原因:
  477. ***************************************************************************/
  478. static bool mmd_CheckSet(const TSETTABLE *pSet,int num,SET_VALUE *setbuf)
  479. {
  480. int i;
  481. char tmpstr[32];
  482. for(i=0;i<num;i++)
  483. {
  484. if(mmd_IsIntegType(pSet[i].wType))
  485. {
  486. float ff=setbuf[i].ff;
  487. if(CheckFloatSet((void *)&ff,pSet[i].fMax,pSet[i].fMin)>0)break;
  488. }
  489. else if(mmd_IsHexType(pSet[i].wType))
  490. {
  491. //float ff=setbuf[i].ff;
  492. //if(CheckFloatSet((void *)&ff,pSet[i].fMax,pSet[i].fMin)>0)break;
  493. }
  494. else
  495. {
  496. if(CheckFloatSet((void *)&setbuf[i].ff,pSet[i].fMax,pSet[i].fMin)>0)break;
  497. }
  498. }
  499. if(i<num)
  500. {
  501. strcpy(m_WarningStr,pSet[i].szName);
  502. if(mmd_IsIntegType(pSet[i].wType))
  503. {
  504. sprintf(m_errInf,"RA:%.0f~%.0f",pSet[i].fMin,pSet[i].fMax);
  505. }
  506. else
  507. {
  508. strcpy(m_errInf,"RA:");
  509. switch(mmi_GetFloatFactor((void *)&pSet[i].fMin))
  510. {
  511. case 0: //浮点数
  512. sprintf(tmpstr,"%.0f",pSet[i].fMin);
  513. break;
  514. case 1: //浮点数
  515. sprintf(tmpstr,"%.1f",pSet[i].fMin);
  516. break;
  517. case 2: //浮点数
  518. sprintf(tmpstr,"%.2f",pSet[i].fMin);
  519. break;
  520. case 3: //浮点数
  521. sprintf(tmpstr,"%.3f",pSet[i].fMin);
  522. break;
  523. default:
  524. sprintf(tmpstr,"%.2f",pSet[i].fMin);
  525. break;
  526. }
  527. strcat(m_errInf,tmpstr);
  528. strcat(m_errInf,"~");
  529. switch(mmi_GetFloatFactor((void *)&pSet[i].fMax))
  530. {
  531. case 0: //浮点数
  532. sprintf(tmpstr,"%.0f",pSet[i].fMax);
  533. break;
  534. case 1: //浮点数
  535. sprintf(tmpstr,"%.1f",pSet[i].fMax);
  536. break;
  537. case 2: //浮点数
  538. sprintf(tmpstr,"%.2f",pSet[i].fMax);
  539. break;
  540. case 3: //浮点数
  541. sprintf(tmpstr,"%.3f",pSet[i].fMax);
  542. break;
  543. default:
  544. sprintf(tmpstr,"%.2f",pSet[i].fMax);
  545. break;
  546. }
  547. strcat(m_errInf,tmpstr);
  548. }
  549. return false;
  550. }
  551. return true; //弹出定值固化菜单,需选择输入区号
  552. }
  553. int m_SetSwNo=0;
  554. /**************************************************************************
  555. 函数名称:mmd_ReChangeSet
  556. 函数版本:1.00
  557. 作者:
  558. 创建日期:2008.9.1
  559. 函数功能说明:将整定值转换为要保存的值
  560. 输入参数:
  561. 输出参数:
  562. 返回值:
  563. 更新信息:
  564. 更新日志1:
  565. 日期:
  566. 修改者:
  567. 修改内容:
  568. 修改原因:
  569. ***************************************************************************/
  570. void mmd_ReChangeSet(const TSETTABLE *pSet,int num,SET_VALUE *setbuf)
  571. {
  572. int i;
  573. for(i=0;i<num;i++)
  574. {
  575. if(mmd_IsIntegType(pSet[i].wType))
  576. {
  577. uint32_t tt=setbuf[i].tt;
  578. setbuf[i].ff=tt;
  579. }
  580. }
  581. }
  582. bool bSetChange=false;
  583. u8 SetGroupIndex;
  584. u8 set_show_group[GROUP_NUM];
  585. void GetDefSetGroup(u8 *dat)
  586. {
  587. int i;
  588. for(i=0;i<GROUP_NUM;i++)
  589. {
  590. dat[i]=(u8)SetGroups[i].defval;
  591. }
  592. }
  593. int mmd_GetDefaultPubSet(int value)
  594. {
  595. GetDefPara((void*)m_SetBuf,PUB_SET_NUMBER,&tPubSetTable[0]);
  596. mmd_ChangeSet(&tPubSetTable[0],PUB_SET_NUMBER,m_SetBuf);
  597. return M_OK;
  598. }
  599. int mmd_GetDefaultBhSet(int value)
  600. {
  601. GetDefPara((void*)m_SetBuf,SW_SET_NUMBER,&tSwSetTable[0]);
  602. mmd_ChangeSet(&tSwSetTable[0],SW_SET_NUMBER,m_SetBuf);
  603. return M_OK;
  604. }
  605. int mmd_GetDefaultParaSet(int value)
  606. {
  607. GetDefPara((void*)m_SetBuf,EQUIP_PARA_NUMBER,&tEquipParaTable[0]);
  608. mmd_ChangeSet(&tEquipParaTable[0],EQUIP_PARA_NUMBER,m_SetBuf);
  609. return M_OK;
  610. }
  611. int mmd_GetDefaultCstSet(int value)
  612. {
  613. GetDefPara((void*)m_SetBuf,CSTSET_NUMBER,&tCstSetTable[0]);
  614. mmd_ChangeSet(&tCstSetTable[0],CSTSET_NUMBER,m_SetBuf);
  615. return M_OK;
  616. }
  617. void mmd_split_setname(unsigned char *str,int len,DATA_FIELD_DEF *pt,int index)
  618. {
  619. int lineoff;
  620. unsigned char tmpstr[24];
  621. lineoff=mmd_splitstr(str,len);
  622. if(lineoff==0)
  623. {
  624. sprintf(pt[index].FmtStr,"%-20.20s",str);
  625. }
  626. else
  627. {
  628. lineoff=mmd_splitstr(str,len);
  629. sprintf(pt[index+1].FmtStr," %-16.16s",&str[lineoff]);
  630. strcpy(tmpstr,str);
  631. tmpstr[lineoff]='\0';
  632. sprintf(pt[index].FmtStr,"%-20.20s",tmpstr);
  633. }
  634. }
  635. void mmd_analyse(const TSETTABLE *pTable,int screennum)
  636. {
  637. int i;
  638. int offset=0;
  639. int addlines=2;
  640. int screencnt=0;
  641. int bgn=0;
  642. unsigned char tmpstr[PARA_NAME_LEN];
  643. for(i=0;i<g_set_disp.num;i++)
  644. {
  645. g_set_disp.Y_offset[i]=offset;
  646. g_set_disp.screennum[i]=0;
  647. if(offset==0)bgn=i;
  648. g_set_disp.bgn[i]=bgn;
  649. sprintf(tmpstr,"%02d.%s",i,pTable[g_set_disp.no[i]].szName);
  650. if((mmd_splitstr(tmpstr,20))==0) //定值名称一行可现实
  651. {
  652. addlines=2;
  653. }
  654. else
  655. {
  656. addlines=3;
  657. }
  658. screencnt++;
  659. offset+=addlines;
  660. if(offset==screennum)
  661. {
  662. int j;
  663. for(j=0;j<screencnt;j++)
  664. {
  665. g_set_disp.screennum[bgn+j]=screencnt;
  666. }
  667. offset=0;
  668. screencnt=0;
  669. }
  670. else if(offset>screennum)
  671. {
  672. int j;
  673. for(j=0;j<screencnt-1;j++)
  674. {
  675. g_set_disp.screennum[bgn+j]=screencnt-1;
  676. }
  677. g_set_disp.Y_offset[i]=0;
  678. g_set_disp.bgn[i]=i;
  679. bgn=i;
  680. offset=addlines;
  681. screencnt =1;
  682. }
  683. }
  684. if(screencnt>0)
  685. {
  686. int j;
  687. for(j=0;j<screencnt;j++)
  688. {
  689. g_set_disp.screennum[bgn+j]=screencnt;
  690. }
  691. }
  692. }
  693. void mmd_GetSet(int index,DATA_FIELD_DEF *pt,const TSETTABLE *pTable,SET_VALUE *setbuf)
  694. {
  695. float ff;
  696. DATA_FIELD_DEF *pex=&g_tExtraMenu.tDataFields[0];
  697. int setno;
  698. int lineoff;
  699. //#ifdef DISP_LIST_NUM
  700. int i=0;
  701. //#endif
  702. #ifdef DISP_LIST_NUM
  703. DWORD dat;
  704. #endif
  705. u8 tmp_len;
  706. const char fill_content[] = " ";
  707. //定值汉字描述
  708. m_set_name[0]=0;
  709. m_set_name_ext[0]=0;
  710. m_set_inf[0]=0;
  711. pt->bEdit=false;
  712. setno=g_set_disp.no[index];
  713. pTable+=setno;
  714. //定值名称处理
  715. {
  716. unsigned char tmpstr[PARA_NAME_LEN];
  717. sprintf(tmpstr,"%02d.%s",index+1,pTable->szName);
  718. lineoff=mmd_splitstr(tmpstr,20);
  719. pex[g_tExtraMenu.sTotalNum].offset=g_set_disp.Y_offset[index];
  720. if(lineoff==0)
  721. {
  722. sprintf(pex[g_tExtraMenu.sTotalNum].FmtStr,"%-20.20s",tmpstr);
  723. g_tExtraMenu.sTotalNum++;
  724. }
  725. else
  726. {
  727. sprintf(pex[g_tExtraMenu.sTotalNum+1].FmtStr," %-18.18s",&tmpstr[lineoff]);
  728. tmpstr[lineoff]='\0';
  729. sprintf(pex[g_tExtraMenu.sTotalNum].FmtStr,"%-20.20s",tmpstr);
  730. pex[g_tExtraMenu.sTotalNum+1].offset=pex[g_tExtraMenu.sTotalNum].offset+1;
  731. g_tExtraMenu.sTotalNum+=2;
  732. }
  733. }
  734. switch(pTable->wType)
  735. {
  736. case SETTYPE_YMD: // 年月日
  737. strcpy(pt->FmtStr,"20%y"); //对齐符号位
  738. pt->pData=(void*)&setbuf[setno].tt;
  739. break;
  740. case SETTYPE_IP: // 年月日
  741. strcpy(pt->FmtStr,"%p"); //对齐符号位
  742. pt->pData=(void*)&setbuf[setno].tt;
  743. break;
  744. case SETTYPE_KG: //16进制显示 控制字
  745. strcpy(pt->FmtStr,"%*4XH"); //对齐符号位
  746. if(bSetChange)
  747. {
  748. strcpy(m_set_inf,"长按->键选择整定");
  749. }
  750. else
  751. {
  752. sprintf(m_set_inf,"RA:%04XH~%04XH",(long)pTable->fMin,(long)pTable->fMax);
  753. }
  754. pt->pData=(void*)&setbuf[setno].tt;
  755. break;
  756. case SETTYPE_UINT: //16进制显示 控制字
  757. strcpy(pt->FmtStr,"%*3u"); //对齐符号位
  758. sprintf(m_set_inf,"RA:%03u~%03u",(long)pTable->fMin,(long)pTable->fMax);
  759. pt->pData=(void*)&setbuf[setno].tt;
  760. break;
  761. case SETTYPE_5INT: //10进制显示 5位
  762. strcpy(pt->FmtStr,"%*5u"); //对齐符号位
  763. sprintf(m_set_inf,"RA:%05u~%05u",(long)pTable->fMin,(long)pTable->fMax);
  764. pt->pData=(void*)&setbuf[setno].tt;
  765. break;
  766. case SETTYPE_LINT: //16进制显示 控制字
  767. strcpy(pt->FmtStr,"%*6u"); //对齐符号位
  768. sprintf(m_set_inf,"RA:%06u~%06u",(long)pTable->fMin,(long)pTable->fMax);
  769. pt->pData=(void*)&setbuf[setno].tt;
  770. break;
  771. case SETTYPE_LIST: //列表选择
  772. {
  773. int j;
  774. int len=0;
  775. for(i=0;i<pTable->listnum;i++) //查找最长的字符串
  776. {
  777. j=strlen(pTable->list[i].str);
  778. if(len<j)
  779. {
  780. len=j;
  781. }
  782. }
  783. if(len<10)
  784. {
  785. strcpy(pt->FmtStr,"%s");
  786. }
  787. else if(len<12)
  788. {
  789. strcpy(pt->FmtStr,"%s");
  790. }
  791. else if(len<14)
  792. {
  793. strcpy(pt->FmtStr,"%s");
  794. }
  795. else
  796. {
  797. strcpy(pt->FmtStr,"%s");
  798. }
  799. pt->bEdit=true;
  800. i = 0;
  801. #ifdef DISP_LIST_NUM
  802. //串口波特率在液晶会显示(600:600)(1200:1200)...,改成(0:600)(1:1200)...序号从0开始
  803. if(pTable->list == BaudList)
  804. {
  805. dat = setbuf[setno].tt;
  806. }
  807. else
  808. {
  809. dat = pTable->list[setbuf[setno].tt].dat;
  810. }
  811. i = sprintf(LIST_tmp[setno],"%d:",dat);
  812. #endif
  813. #ifdef CPU_FUXI
  814. strcpy(menu_tmp[setno], pTable->list[setbuf[setno].tt].str);
  815. pt->pData = (void*)menu_tmp[setno];
  816. #else
  817. tmp_len = strlen(pTable->list[setbuf[setno].tt].str);
  818. i = sprintf((LIST_tmp[setno]+i),"%s",pTable->list[setbuf[setno].tt].str);
  819. strncat((LIST_tmp[setno]+i),fill_content,len-tmp_len); // 用空白填充剩余区域,防止显示上一个列表项的部分内容
  820. pt->pData = (void*)LIST_tmp[setno];
  821. #endif
  822. }
  823. break;
  824. default:
  825. ff=setbuf[setno].ff;
  826. switch(mmi_GetFloatFactor((void *)&ff))
  827. {
  828. case 0: //浮点数
  829. strcpy(pt->FmtStr,"%+-6.1f");
  830. break;
  831. case 1: //浮点数
  832. strcpy(pt->FmtStr,"%+-6.1f");
  833. break;
  834. case 2: //浮点数
  835. strcpy(pt->FmtStr,"%+-6.2f");
  836. break;
  837. case 3: //浮点数
  838. strcpy(pt->FmtStr,"%+-6.3f");
  839. break;
  840. default:
  841. strcpy(pt->FmtStr,"%+-6.1f");
  842. break;
  843. }
  844. ff=pTable->fMin;
  845. switch(mmi_GetFloatFactor((void *)&ff))
  846. {
  847. case 0: //浮点数
  848. sprintf(m_set_inf,"RA:%-5.1f",ff);
  849. break;
  850. case 1: //浮点数
  851. sprintf(m_set_inf,"RA:%-5.1f",ff);
  852. break;
  853. case 2: //浮点数
  854. sprintf(m_set_inf,"RA:%-5.2f",ff);
  855. break;
  856. case 3: //浮点数
  857. sprintf(m_set_inf,"RA:%-5.3f",ff);
  858. break;
  859. default:
  860. sprintf(m_set_inf,"RA:%-5.1f",ff);
  861. break;
  862. }
  863. ff=pTable->fMax;
  864. switch(mmi_GetFloatFactor((void *)&ff))
  865. {
  866. case 0: //浮点数
  867. sprintf(m_set_name,"%-5.1f",ff);
  868. break;
  869. case 1: //浮点数
  870. sprintf(m_set_name,"%-5.1f",ff);
  871. break;
  872. case 2: //浮点数
  873. sprintf(m_set_name,"%-5.2f",ff);
  874. break;
  875. case 3: //浮点数
  876. sprintf(m_set_name,"%-5.3f",ff);
  877. break;
  878. default:
  879. sprintf(m_set_name,"%-5.1f",ff);
  880. break;
  881. }
  882. strcat(m_set_inf,"~");
  883. strcat(m_set_inf,m_set_name);
  884. pt->pData=(void*)&setbuf[setno].ff;
  885. break;
  886. }
  887. strcat(pt->FmtStr," "); //单位
  888. strcat(pt->FmtStr,SetUints[pTable->wUnit]); //单位
  889. pt->offset=(lineoff==0)?g_set_disp.Y_offset[index]+1:g_set_disp.Y_offset[index]+2; // 偏移地址
  890. sprintf(m_equipstr,"%s",SetGroups[pTable->group].item_name);
  891. }
  892. /**************************************************************************
  893. 函数名称:mmd_RenewPubSet
  894. 函数版本:1.00
  895. 作者:
  896. 创建日期:2008.9.11
  897. 函数功能说明:刷新定值显示
  898. 输入参数:
  899. 输出参数:
  900. 返回值:
  901. 更新信息:
  902. 更新日志1:
  903. 日期:
  904. 修改者:
  905. 修改内容:
  906. 修改原因:
  907. ***************************************************************************/
  908. int mmd_RenewPubSet(void)
  909. {
  910. DATA_MENU_DEF *pt=&g_tDataMenu1;
  911. DATA_MENU_DEF *pext=&g_tExtraMenu;
  912. int i;
  913. int bgn;
  914. bgn=g_set_disp.bgn[pt->sFocusIndex];
  915. pext->sTotalNum=0; //总的动态菜单数
  916. for(i=0;i<g_set_disp.screennum[pt->sFocusIndex];i++)
  917. {
  918. mmd_GetSet(bgn+i,&g_tDataMenu1.tDataFields[i],&tPubSetTable[0],m_SetBuf);
  919. }
  920. pt->sScreenNum=g_set_disp.screennum[pt->sFocusIndex];
  921. pext->sFocusIndex=0; //第一个显示的动态菜单的索引
  922. pext->sScreenNum=pext->sTotalNum;
  923. return M_OK;
  924. }
  925. int mmd_RenewPubSetGroup(void)
  926. {
  927. mmd_RenewDataMenu(&g_tDataMenu2);
  928. return M_OK;
  929. }
  930. static void mmd_GetSetGroupName(int i,DATA_FIELD_DEF *pF)
  931. {
  932. //strcpy(pF->FmtStr,SetGroups[set_show_group[i]].item_name);
  933. sprintf(pF->FmtStr,"%d.%s",i+1,SetGroups[set_show_group[i]].item_name);
  934. }
  935. int mmd_backPubSet(int value)
  936. {
  937. mmd_InitPubSetGroup(-1);
  938. g_tDataMenu2.sFocusIndex=SetGroupIndex;
  939. mmi_FormsInit(42,1); // 更新最后修改的数据
  940. mmd_RenewPubSetGroup();
  941. return M_OK;
  942. }
  943. int mmd_ValueJump(void)
  944. {
  945. #ifdef SEC_SETVALUE_7
  946. return M_JUMP1;
  947. #else
  948. return M_JUMP0;
  949. #endif
  950. }
  951. int mmd_InitPubSetGroup(int value)
  952. {
  953. int i,num=0;
  954. for(i=0;i<GROUP_NUM;i++)
  955. {
  956. if(SetGroups[i].group == SETGROUP_TYPE_PUB&&(m_setgroup[i]>0))
  957. {
  958. int j;
  959. for(j=0;j<PUB_SET_NUMBER;j++)
  960. {
  961. if((bPubSetMenuShow[j]>0)&&(tPubSetTable[j].group==i)&&(tPubSetTable[j].wType!= SETTYPE_LABEL))
  962. {
  963. set_show_group[num++]=i;
  964. break;
  965. }
  966. }
  967. }
  968. }
  969. if(num==0)
  970. {
  971. strcpy(m_WarningStr,"公共定值未配置");
  972. return M_JUMP2;
  973. }
  974. mmd_initDataMenu(&g_tDataMenu2,num,mmd_RenewPubSetGroup,mmd_GetSetGroupName,42,1);
  975. /*读取公共定值*/
  976. if(!ReadPara((void*)m_SetBuf,EEP_PUB_ADDR+(PUB_SETSIZE*m_selsection),PUB_SET_NUMBER,&tPubSetTable[0]))
  977. {
  978. if(value==-1)
  979. {
  980. GetDefPara((void*)m_SetBuf,PUB_SET_NUMBER,&tPubSetTable[0]);
  981. }
  982. else
  983. {
  984. strcpy(m_WarningStr,"定值读取错误,请整定");
  985. return M_JUMP3;
  986. }
  987. }
  988. mmd_ChangeSet(&tPubSetTable[0],PUB_SET_NUMBER,m_SetBuf);
  989. return M_JUMP0;
  990. }
  991. /**************************************************************************
  992. 函数名称:mmd_InitSetSolid
  993. 函数版本:1.00
  994. 作者:
  995. 创建日期:2008.9.1
  996. 函数功能说明:初始化定值整定的显示
  997. 输入参数:
  998. 输出参数:
  999. 返回值:
  1000. 更新信息:
  1001. 更新日志1:
  1002. 日期:
  1003. 修改者:
  1004. 修改内容:
  1005. 修改原因:
  1006. ***************************************************************************/
  1007. int mmd_InitPubSet(int value)
  1008. {
  1009. int num=PUB_SET_NUMBER;
  1010. int screennum;
  1011. int i;
  1012. m_AllSection=0;
  1013. g_set_disp.num=0;
  1014. num=mmd_GetshowSetNum(&tPubSetTable[0],PUB_SET_NUMBER,set_show_group[value]);
  1015. SetGroupIndex=value;
  1016. screennum=mmi_GetScreenNum(43,1); // 取当前屏幕最大显示数目
  1017. bSetChange=true;
  1018. mmd_analyse(&tPubSetTable[0],screennum);
  1019. {
  1020. DATA_MENU_DEF *pt=&g_tDataMenu1;
  1021. DATA_MENU_DEF *pext=&g_tExtraMenu;
  1022. pext->sTotalNum=0;
  1023. for(i=0;i<g_set_disp.screennum[0];i++)
  1024. {
  1025. mmd_GetSet(i,&g_tDataMenu1.tDataFields[i],&tPubSetTable[0],m_SetBuf);
  1026. }
  1027. m_ScreenNum=num;
  1028. pt->sFocusIndex=0; //第一个显示的动态菜单的索引
  1029. pt->sTotalNum=num; //总的动态菜单数
  1030. pt->sScreenNum=g_set_disp.screennum[0];
  1031. pt->GetPrevFuncAddr=mmd_RenewPubSet; //44
  1032. pt->GetNextFuncAddr=mmd_RenewPubSet; //44
  1033. pext->sFocusIndex=0; //第一个显示的动态菜单的索引
  1034. pext->sScreenNum=pext->sTotalNum;
  1035. pext->GetPrevFuncAddr=NULL; //44
  1036. pext->GetNextFuncAddr=NULL; //44
  1037. m_CurrentScreen=1;
  1038. }
  1039. return M_JUMP0;
  1040. }
  1041. /**************************************************************************
  1042. 函数名称:mmd_SetKey
  1043. 函数版本:1.00
  1044. 作者:
  1045. 创建日期:2008.9.1
  1046. 函数功能说明:列表项选择
  1047. 输入参数:
  1048. 输出参数:
  1049. 返回值:
  1050. 更新信息:
  1051. 更新日志1:
  1052. 日期:
  1053. 修改者:
  1054. 修改内容:
  1055. 修改原因:
  1056. ***************************************************************************/
  1057. int mmd_SetPubKey(int key)
  1058. {
  1059. if(key==HA_KEY_UP&&g_tScreen.lcd_type!=LCD_TYPE_160_KEY9)key=HA_KEY_ADD;
  1060. if(key==HA_KEY_DOWN&&g_tScreen.lcd_type!=LCD_TYPE_160_KEY9)key=HA_KEY_SUB;
  1061. if(key==HA_KEY_ADD||key==HA_KEY_SUB) // +键增加列表
  1062. {
  1063. if(!g_bModify) return M_ERROR; // 只在修改状态下执行此函数
  1064. if(mmd_ChangeList(&tPubSetTable[0],key,m_SetBuf))
  1065. {
  1066. mmd_RenewPubSet(); //刷新修改后的值
  1067. return M_OK;
  1068. }
  1069. }
  1070. return M_ERROR;
  1071. }
  1072. int mmd_SavePubSet(int value)
  1073. {
  1074. #ifdef PUB_SET_SECTION
  1075. WORD save_section;
  1076. int i;
  1077. bool b_section_change = false; //局部变量初始化,避免下面if中判断为随机态
  1078. #endif
  1079. if(mmd_CheckPassword2()==false)
  1080. {
  1081. return M_JUMP2;
  1082. }
  1083. mmd_ReChangeSet(&tPubSetTable[0],PUB_SET_NUMBER,m_SetBuf);
  1084. if(!mmd_CheckSet(&tPubSetTable[0],PUB_SET_NUMBER,m_SetBuf))
  1085. {
  1086. mmd_ChangeSet(&tPubSetTable[0],PUB_SET_NUMBER,m_SetBuf);
  1087. return M_JUMP3;
  1088. }
  1089. #ifdef PUB_SET_SECTION
  1090. save_section = m_SetBuf[1].ff;
  1091. if(save_section!=m_runsection)
  1092. {
  1093. b_section_change = true;
  1094. }
  1095. if(SavePara((void *)m_SetBuf,EEP_PUB_ADDR+(PUB_SETSIZE*save_section),PUB_SET_NUMBER,&tPubSetTable[0]))
  1096. {
  1097. strcpy(m_WarningStr,"公共定值保存成功");
  1098. soe_record_opt(EV_PUBSET_OK,0);
  1099. MakeRunSet(false);
  1100. rt_err_clr(ERR_CODE_SET_PUB,0);
  1101. m_runsection = save_section;
  1102. }
  1103. else
  1104. {
  1105. strcpy(m_WarningStr,"公共定值保存失败");
  1106. soe_record_opt(EV_PUBSET_FAIL,0);
  1107. b_section_change = false;
  1108. }
  1109. //将其他公共定值区的定值区定值也做修改
  1110. if(b_section_change)
  1111. {
  1112. for(i=0;i<SEC_NUMBER;i++)
  1113. {
  1114. if(i == save_section)
  1115. continue;
  1116. /*读取公共定值*/
  1117. if(!ReadPara((void*)m_SetBuf,EEP_PUB_ADDR+PUB_SETSIZE*i,PUB_SET_NUMBER,&tPubSetTable[0]))
  1118. {
  1119. rt_err_set(ERR_CODE_SET_PUB,0);
  1120. GetDefPara((void*)m_SetBuf,PUB_SET_NUMBER,&tPubSetTable[0]);
  1121. }
  1122. else
  1123. {
  1124. rt_err_clr(ERR_CODE_SET_PUB,0);
  1125. }
  1126. m_SetBuf[SET_SECTION].ff=m_runsection;
  1127. if(SavePara((void *)m_SetBuf,EEP_PUB_ADDR+(PUB_SETSIZE*i),PUB_SET_NUMBER,&tPubSetTable[0]))
  1128. {
  1129. strcpy(m_WarningStr,"公共定值保存成功");
  1130. soe_record_opt(EV_PUBSET_OK,0);
  1131. MakeRunSet(false);
  1132. rt_err_clr(ERR_CODE_SET_PUB,0);
  1133. m_runsection = save_section;
  1134. }
  1135. else
  1136. {
  1137. strcpy(m_WarningStr,"公共定值保存失败");
  1138. soe_record_opt(EV_PUBSET_FAIL,0);
  1139. }
  1140. }
  1141. }
  1142. #else
  1143. if(SavePara((void *)m_SetBuf,EEP_PUB_ADDR,PUB_SET_NUMBER,&tPubSetTable[0]))
  1144. {
  1145. strcpy(m_WarningStr,"公共定值保存成功");
  1146. soe_record_opt(EV_PUBSET_OK,0);
  1147. MakeRunSet(false);
  1148. rt_err_clr(ERR_CODE_SET_PUB,0);
  1149. }
  1150. else
  1151. {
  1152. strcpy(m_WarningStr,"公共定值保存失败");
  1153. soe_record_opt(EV_PUBSET_FAIL,0);
  1154. }
  1155. #endif
  1156. return M_JUMP0;
  1157. }
  1158. int mmd_SavePubPassword2(int value)
  1159. {
  1160. #ifndef PASSWORD_2_INVALID
  1161. return M_JUMP1;
  1162. #endif
  1163. return mmd_SavePubSet(0);
  1164. }
  1165. int mmd_SaveBhPassword2(int value)
  1166. {
  1167. #ifndef PASSWORD_2_INVALID
  1168. return M_JUMP1;
  1169. #endif
  1170. return mmd_SaveBhSet(0);
  1171. }
  1172. int mmd_SaveParaPassword2(int value)
  1173. {
  1174. #ifndef PASSWORD_2_INVALID
  1175. return M_JUMP1;
  1176. #endif
  1177. return mmd_SaveParaSet(0);
  1178. }
  1179. int mmd_SaveAzPassword2(int value)
  1180. {
  1181. #ifndef PASSWORD_2_INVALID
  1182. return M_JUMP1;
  1183. #endif
  1184. return mmd_SaveAzSet(0);
  1185. }
  1186. int mmd_RenewBhSet(void)
  1187. {
  1188. DATA_MENU_DEF *pt=&g_tDataMenu1;
  1189. DATA_MENU_DEF *pext=&g_tExtraMenu;
  1190. int i;
  1191. int bgn;
  1192. bgn=g_set_disp.bgn[pt->sFocusIndex];
  1193. pext->sTotalNum=0; //总的动态菜单数
  1194. for(i=0;i<g_set_disp.screennum[pt->sFocusIndex];i++)
  1195. {
  1196. mmd_GetSet(bgn+i,&g_tDataMenu1.tDataFields[i],&tSwSetTable[0],m_SetBuf);
  1197. }
  1198. pt->sScreenNum=g_set_disp.screennum[pt->sFocusIndex];
  1199. pext->sFocusIndex=0; //第一个显示的动态菜单的索引
  1200. pext->sScreenNum=pext->sTotalNum;
  1201. return M_OK;
  1202. }
  1203. int mmd_RenewBhSetGroup(void)
  1204. {
  1205. mmd_RenewDataMenu(&g_tDataMenu2);
  1206. return M_OK;
  1207. }
  1208. int mmd_backBhSet(int value)
  1209. {
  1210. mmd_InitBhSetGroup(-1);
  1211. g_tDataMenu2.sFocusIndex=SetGroupIndex;
  1212. mmi_FormsInit(44,1); // 更新最后修改的数据
  1213. mmd_RenewBhSetGroup();
  1214. return M_OK;
  1215. }
  1216. int mmd_InitBhSetGroup(int value)
  1217. {
  1218. int i,num=0;
  1219. for(i=0;i<GROUP_NUM;i++)
  1220. {
  1221. if(SetGroups[i].group == SETGROUP_TYPE_BH&&(m_setgroup[i]>0))
  1222. {
  1223. int j;
  1224. bool bYB;
  1225. bYB=mmd_checkset_yb(i);
  1226. for(j=0;j<SW_SET_NUMBER;j++)
  1227. {
  1228. if((bSwSetMenuShow[j]>0)&&(tSwSetTable[j].group==i)&&(tSwSetTable[j].wType!= SETTYPE_LABEL)&&bYB)
  1229. {
  1230. set_show_group[num++]=i;
  1231. break;
  1232. }
  1233. }
  1234. }
  1235. }
  1236. if(num==0)
  1237. {
  1238. strcpy(m_WarningStr,"保护定值未配置");
  1239. return M_JUMP2;
  1240. }
  1241. mmd_initDataMenu(&g_tDataMenu2,num,mmd_RenewBhSetGroup,mmd_GetSetGroupName,44,1);
  1242. /*读定值*/
  1243. if(!ReadPara((void*)m_SetBuf,EEP_SET_ADDR+SETSIZE*(m_runsection),SW_SET_NUMBER,&tSwSetTable[0]))
  1244. {
  1245. if(value==-1)
  1246. {
  1247. GetDefPara((void*)m_SetBuf,SW_SET_NUMBER,&tSwSetTable[0]);
  1248. }
  1249. else
  1250. {
  1251. strcpy(m_WarningStr,"定值读取错误,请整定");
  1252. return M_JUMP3;
  1253. }
  1254. }
  1255. mmd_ChangeSet(&tSwSetTable[0],SW_SET_NUMBER,m_SetBuf);
  1256. return M_JUMP0;
  1257. }
  1258. /**************************************************************************
  1259. 函数名称:mmd_InitSetSolid
  1260. 函数版本:1.00
  1261. 作者:
  1262. 创建日期:2008.9.1
  1263. 函数功能说明:初始化定值整定的显示
  1264. 更新日志1:
  1265. 日期:
  1266. 修改者:
  1267. 修改内容:
  1268. 修改原因:
  1269. ***************************************************************************/
  1270. int mmd_InitBhSet(int value)
  1271. {
  1272. int num=SW_SET_NUMBER;
  1273. int screennum;
  1274. int i;
  1275. m_AllSection=0;
  1276. g_set_disp.num=0;
  1277. num=mmd_GetshowSetNum(&tSwSetTable[0],SW_SET_NUMBER,set_show_group[value]);
  1278. SetGroupIndex=value;
  1279. screennum=mmi_GetScreenNum(45,1); // 取当前屏幕最大显示数目
  1280. bSetChange=true;
  1281. mmd_analyse(&tSwSetTable[0],screennum);
  1282. {
  1283. DATA_MENU_DEF *pt=&g_tDataMenu1;
  1284. DATA_MENU_DEF *pext=&g_tExtraMenu;
  1285. pext->sTotalNum=0;
  1286. for(i=0;i<g_set_disp.screennum[0];i++)
  1287. {
  1288. mmd_GetSet(i,&g_tDataMenu1.tDataFields[i],&tSwSetTable[0],m_SetBuf);
  1289. }
  1290. m_ScreenNum=num;
  1291. pt->sFocusIndex=0; //第一个显示的动态菜单的索引
  1292. pt->sTotalNum=num; //总的动态菜单数
  1293. pt->sScreenNum=g_set_disp.screennum[0];
  1294. pt->GetPrevFuncAddr=mmd_RenewBhSet; //44
  1295. pt->GetNextFuncAddr=mmd_RenewBhSet; //44
  1296. pext->sFocusIndex=0; //第一个显示的动态菜单的索引
  1297. pext->sScreenNum=pext->sTotalNum;
  1298. pext->GetPrevFuncAddr=NULL; //44
  1299. pext->GetNextFuncAddr=NULL; //44
  1300. m_CurrentScreen=1;
  1301. }
  1302. return M_JUMP0;
  1303. }
  1304. /**************************************************************************
  1305. 日期:
  1306. 修改者:
  1307. 修改内容:
  1308. 修改原因:
  1309. ***************************************************************************/
  1310. int mmd_SetBhKey(int key)
  1311. {
  1312. if(key==HA_KEY_UP&&g_tScreen.lcd_type!=LCD_TYPE_160_KEY9)key=HA_KEY_ADD;
  1313. if(key==HA_KEY_DOWN&&g_tScreen.lcd_type!=LCD_TYPE_160_KEY9)key=HA_KEY_SUB;
  1314. if(key==HA_KEY_ADD||key==HA_KEY_SUB) // +键增加列表
  1315. {
  1316. if(!g_bModify) return M_ERROR; // 只在修改状态下执行此函数
  1317. if(mmd_ChangeList(&tSwSetTable[0],key,m_SetBuf))
  1318. {
  1319. mmd_RenewBhSet(); //刷新修改后的值
  1320. return M_OK;
  1321. }
  1322. }
  1323. return M_ERROR;
  1324. }
  1325. int mmd_SaveBhSet(int value)
  1326. {
  1327. if(mmd_CheckPassword2()==false)
  1328. {
  1329. return M_JUMP2;
  1330. }
  1331. mmd_ReChangeSet(&tSwSetTable[0],SW_SET_NUMBER,m_SetBuf);
  1332. if(!mmd_CheckSet(&tSwSetTable[0],SW_SET_NUMBER,m_SetBuf))
  1333. {
  1334. mmd_ChangeSet(&tSwSetTable[0],SW_SET_NUMBER,m_SetBuf);
  1335. return M_JUMP3;
  1336. }
  1337. //if(SavePara((void *)m_SetBuf,EEP_SET_ADDR+(m_runsection)*SETSIZE,SW_SET_NUMBER,&tSwSetTable[0]))
  1338. if(SavePara((void *)m_SetBuf,EEP_SET_ADDR+(m_selsection)*SETSIZE,SW_SET_NUMBER,&tSwSetTable[0]))
  1339. {
  1340. strcpy(m_WarningStr,"定值保存成功");
  1341. soe_record_opt(EV_SET_OK,0);
  1342. MakeRunSet(false);
  1343. rt_err_clr(ERR_CODE_SET,0);
  1344. }
  1345. else
  1346. {
  1347. strcpy(m_WarningStr,"定值保存失败");
  1348. soe_record_opt(EV_SET_FAIL,0);
  1349. }
  1350. return M_JUMP0;
  1351. }
  1352. int mmd_RenewAzSet(void)
  1353. {
  1354. DATA_MENU_DEF *pt=&g_tDataMenu1;
  1355. DATA_MENU_DEF *pext=&g_tExtraMenu;
  1356. int i;
  1357. int bgn;
  1358. bgn=g_set_disp.bgn[pt->sFocusIndex];
  1359. pext->sTotalNum=0; //总的动态菜单数
  1360. for(i=0;i<g_set_disp.screennum[pt->sFocusIndex];i++)
  1361. {
  1362. mmd_GetSet(bgn+i,&g_tDataMenu1.tDataFields[i],&tSwSetTable[0],m_SetBuf);
  1363. }
  1364. pt->sScreenNum=g_set_disp.screennum[pt->sFocusIndex];
  1365. pext->sFocusIndex=0; //第一个显示的动态菜单的索引
  1366. pext->sScreenNum=pext->sTotalNum;
  1367. return M_OK;
  1368. }
  1369. int mmd_RenewAzSetGroup(void)
  1370. {
  1371. mmd_RenewDataMenu(&g_tDataMenu2);
  1372. return M_OK;
  1373. }
  1374. int mmd_InitAzSetGroup(int value)
  1375. {
  1376. int i,num=0;
  1377. unsigned char menuno = 0;//**
  1378. int bYB1=1;
  1379. menuno=g_tScreen.cActiveMenuNo;
  1380. switch(menuno)
  1381. {
  1382. case 150:
  1383. case 64:
  1384. case 66:
  1385. bYB1 = 1;
  1386. break;
  1387. case 96:
  1388. case 90:
  1389. bYB1 = 0;
  1390. break;
  1391. }
  1392. for(i=0;i<GROUP_NUM;i++)
  1393. {
  1394. #ifdef GD_AREA_ECZD_2020
  1395. if((SetGroups[i].group == SETGROUP_TYPE_AZ
  1396. ||SetGroups[i].group == SETGROUP_TYPE_JL)&&(m_setgroup[i]>0))
  1397. #else
  1398. if(SetGroups[i].group == SETGROUP_TYPE_AZ&&(m_setgroup[i]>0))
  1399. #endif
  1400. {
  1401. int j;
  1402. bool bYB;
  1403. if(bYB1)
  1404. {
  1405. bYB=mmd_checkset_yb(i);
  1406. }
  1407. else
  1408. {
  1409. bYB=true; //查看定值时全部定值要显示出来
  1410. }
  1411. for(j=0;j<SW_SET_NUMBER;j++)
  1412. {
  1413. if((bSwSetMenuShow[j]>0)&&(tSwSetTable[j].group==i)&&(tSwSetTable[j].wType!= SETTYPE_LABEL)&&bYB)
  1414. {
  1415. set_show_group[num++]=i;
  1416. break;
  1417. }
  1418. }
  1419. }
  1420. }
  1421. if(num==0)
  1422. {
  1423. strcpy(m_WarningStr,"安自定值未配置");
  1424. return M_JUMP2;
  1425. }
  1426. if(bYB1)
  1427. {
  1428. mmd_initDataMenu(&g_tDataMenu2,num,mmd_RenewAzSetGroup,mmd_GetSetGroupName,62,1);
  1429. }
  1430. else
  1431. {
  1432. mmd_initDataMenu(&g_tDataMenu2,num,mmd_RenewAzSetGroup,mmd_GetSetGroupName,95,1);
  1433. }
  1434. /*读定值*/
  1435. //if(!ReadPara((void*)m_SetBuf,EEP_SET_ADDR+SETSIZE*(m_runsection),SW_SET_NUMBER,&tSwSetTable[0]))
  1436. if(!ReadPara((void*)m_SetBuf,EEP_SET_ADDR+SETSIZE*(m_selsection),SW_SET_NUMBER,&tSwSetTable[0]))
  1437. {
  1438. if(value==-1)
  1439. {
  1440. GetDefPara((void*)m_SetBuf,SW_SET_NUMBER,&tSwSetTable[0]);
  1441. }
  1442. else
  1443. {
  1444. strcpy(m_WarningStr,"定值读取错误,请整定");
  1445. return M_JUMP3;
  1446. }
  1447. }
  1448. mmd_ChangeSet(&tSwSetTable[0],SW_SET_NUMBER,m_SetBuf);
  1449. return M_JUMP0;
  1450. }
  1451. int mmd_backAzSet(int value)
  1452. {
  1453. mmd_InitAzSetGroup(-1);
  1454. g_tDataMenu2.sFocusIndex=SetGroupIndex;
  1455. mmi_FormsInit(62,1); // 更新最后修改的数据
  1456. mmd_RenewAzSetGroup();
  1457. return M_OK;
  1458. }
  1459. int mmd_backPubSetPoll(int key)
  1460. {
  1461. if(key==((g_tScreen.lcd_type==LCD_TYPE_6KEY)?HA_KEY_LEFT:HA_KEY_ESC)) // 老版本按键6键,左键为取消键
  1462. {
  1463. mmd_InitPubSetGroup(-1);
  1464. g_tDataMenu2.sFocusIndex=SetGroupIndex;
  1465. mmi_FormsInit(91,1); // 更新最后修改的数据
  1466. mmd_RenewPubSetGroup();
  1467. }
  1468. return M_OK;
  1469. }
  1470. int mmd_backBhSetPoll(int key)
  1471. {
  1472. if(key==((g_tScreen.lcd_type==LCD_TYPE_6KEY)?HA_KEY_LEFT:HA_KEY_ESC)) // 老版本按键6键,左键为取消键
  1473. {
  1474. mmd_InitBhSetGroup(-1);
  1475. g_tDataMenu2.sFocusIndex=SetGroupIndex;
  1476. mmi_FormsInit(93,1); // 更新最后修改的数据
  1477. mmd_RenewBhSetGroup();
  1478. }
  1479. return M_OK;
  1480. }
  1481. int mmd_backAzSetPoll(int key)
  1482. {
  1483. if(key==((g_tScreen.lcd_type==LCD_TYPE_6KEY)?HA_KEY_LEFT:HA_KEY_ESC)) // 老版本按键6键,左键为取消键
  1484. {
  1485. mmd_InitAzSetGroup(-1);
  1486. g_tDataMenu2.sFocusIndex=SetGroupIndex;
  1487. mmi_FormsInit(95,1); // 更新最后修改的数据
  1488. mmd_RenewAzSetGroup();
  1489. }
  1490. return M_OK;
  1491. }
  1492. int mmd_SetGroupInit(int value)
  1493. {
  1494. bool bret;
  1495. bret=ReadEppData(EEP_SETGROUP_ADDR,m_setgroup,GROUP_NUM);
  1496. if(!bret)
  1497. {
  1498. GetDefSetGroup(m_setgroup);
  1499. }
  1500. return M_OK;
  1501. }
  1502. int mmd_CheckSecValue(void)
  1503. {
  1504. int selsec;
  1505. selsec=atoi(m_selsec_char);
  1506. if(selsec>m_sectionnum || selsec<0)
  1507. {
  1508. m_selsection=0;
  1509. strcpy(m_selsec_char,"00");
  1510. strcpy(m_WarningStr,"输入区号错误!");
  1511. return M_JUMP3;
  1512. }
  1513. m_selsection=selsec;
  1514. rt_printf("%s:Current Section = %d\r\n",__func__,m_selsection);
  1515. mmd_SetGroupInit(0);
  1516. return M_JUMP0;
  1517. }
  1518. int mmd_CheckCopyPassword(int value)
  1519. {
  1520. u8 passstr[10];
  1521. #ifdef PASSWORD_4_STR
  1522. strcpy(passstr,PASS_WORD_STR_4);
  1523. #else
  1524. strcpy(passstr,PASS_WORD_STR);
  1525. #endif
  1526. if((strcmp(m_strPassword,tRunPara.wPasswordstr)!=0)&&(strcmp(m_strPassword,passstr)!=0))
  1527. {
  1528. m_Password=0;
  1529. mmi_zero_passwordstr();
  1530. strcpy(m_WarningStr,"输入密码错误!");
  1531. return M_JUMP3;
  1532. }
  1533. return M_JUMP0;
  1534. }
  1535. int mmd_GetshowAzSetNum(const TSETTABLE *pSet,int bgn,int end,u8 group)
  1536. {
  1537. int i;
  1538. //152 86
  1539. unsigned char menuno = 0;//**
  1540. int bYB1=1;
  1541. rt_printf("g_tScreen.cActiveMenuNo =%d,g_tScreen.cActiveFieldNo =%d\r\n",g_tScreen.cActiveMenuNo,g_tScreen.cActiveFieldNo);
  1542. menuno=g_tScreen.cActiveMenuNo;
  1543. switch(menuno)
  1544. {
  1545. case 152:
  1546. case 192:
  1547. case 62:
  1548. case 202:
  1549. case 172:
  1550. case 162:
  1551. bYB1 = 1;
  1552. break;
  1553. case 86:
  1554. case 79:
  1555. case 88:
  1556. case 95:
  1557. case 97:
  1558. case 93:
  1559. bYB1 = 0;
  1560. break;
  1561. }
  1562. for(i=bgn;i<=end;i++)
  1563. {
  1564. if (pSet[i].wType != SETTYPE_LABEL)
  1565. {
  1566. bool bYB_set;
  1567. bool bmenu_set;
  1568. bmenu_set=mmd_checkset_menucfg(pSet,i,group);
  1569. if(bYB1)
  1570. {
  1571. bYB_set=mmd_checkset_yb(pSet[i].group);
  1572. }
  1573. else
  1574. {
  1575. bYB_set=true;
  1576. }
  1577. if((m_setgroup[pSet[i].group])&&bYB_set&&bmenu_set) // 定值分类组为0 或显示定制为1
  1578. {
  1579. g_set_disp.no[g_set_disp.num] = i;
  1580. g_set_disp.num++;
  1581. }
  1582. }
  1583. }
  1584. return g_set_disp.num;
  1585. }
  1586. /**************************************************************************
  1587. 函数名称:mmd_InitSetSolid
  1588. 函数版本:1.00
  1589. 作者:
  1590. 创建日期:2008.9.1
  1591. 函数功能说明:初始化定值整定的显示
  1592. 更新日志1:
  1593. 日期:
  1594. 修改者:
  1595. 修改内容:
  1596. 修改原因:
  1597. ***************************************************************************/
  1598. int mmd_InitAzSet(int value)
  1599. {
  1600. int num=SW_SET_NUMBER;
  1601. int screennum;
  1602. int i;
  1603. m_AllSection=0;
  1604. g_set_disp.num=0;
  1605. num=mmd_GetshowAzSetNum(&tSwSetTable[0],SET_LABLE_TQ,SET_LABLE_FATT-1,set_show_group[value]);
  1606. SetGroupIndex=value;
  1607. screennum=mmi_GetScreenNum(63,1); // 取当前屏幕最大显示数目
  1608. bSetChange=true;
  1609. mmd_analyse(&tSwSetTable[0],screennum);
  1610. {
  1611. DATA_MENU_DEF *pt=&g_tDataMenu1;
  1612. DATA_MENU_DEF *pext=&g_tExtraMenu;
  1613. pext->sTotalNum=0;
  1614. for(i=0;i<g_set_disp.screennum[0];i++)
  1615. {
  1616. mmd_GetSet(i,&g_tDataMenu1.tDataFields[i],&tSwSetTable[0],m_SetBuf);
  1617. }
  1618. m_ScreenNum=num;
  1619. pt->sFocusIndex=0; //第一个显示的动态菜单的索引
  1620. pt->sTotalNum=num; //总的动态菜单数
  1621. pt->sScreenNum=g_set_disp.screennum[0];
  1622. pt->GetPrevFuncAddr=mmd_RenewAzSet; //44
  1623. pt->GetNextFuncAddr=mmd_RenewAzSet; //44
  1624. pext->sFocusIndex=0; //第一个显示的动态菜单的索引
  1625. pext->sScreenNum=pext->sTotalNum;
  1626. pext->GetPrevFuncAddr=NULL; //44
  1627. pext->GetNextFuncAddr=NULL; //44
  1628. m_CurrentScreen=1;
  1629. }
  1630. return M_JUMP0;
  1631. }
  1632. /**************************************************************************
  1633. 日期:
  1634. 修改者:
  1635. 修改内容:
  1636. 修改原因:
  1637. ***************************************************************************/
  1638. int mmd_SetAzKey(int key)
  1639. {
  1640. if(key==HA_KEY_UP&&g_tScreen.lcd_type!=LCD_TYPE_160_KEY9)key=HA_KEY_ADD;
  1641. if(key==HA_KEY_DOWN&&g_tScreen.lcd_type!=LCD_TYPE_160_KEY9)key=HA_KEY_SUB;
  1642. if(key==HA_KEY_ADD||key==HA_KEY_SUB) // +键增加列表
  1643. {
  1644. if(!g_bModify) return M_ERROR; // 只在修改状态下执行此函数
  1645. if(mmd_ChangeList(&tSwSetTable[0],key,m_SetBuf))
  1646. {
  1647. mmd_RenewAzSet(); //刷新修改后的值
  1648. return M_OK;
  1649. }
  1650. }
  1651. return M_ERROR;
  1652. }
  1653. int mmd_SaveAzSet(int value)
  1654. {
  1655. if(mmd_CheckPassword2()==false)
  1656. {
  1657. return M_JUMP2;
  1658. }
  1659. mmd_ReChangeSet(&tSwSetTable[0],SW_SET_NUMBER,m_SetBuf);
  1660. if(!mmd_CheckSet(&tSwSetTable[0],SW_SET_NUMBER,m_SetBuf))
  1661. {
  1662. mmd_ChangeSet(&tSwSetTable[0],SW_SET_NUMBER,m_SetBuf);
  1663. return M_JUMP3;
  1664. }
  1665. //if(SavePara((void *)m_SetBuf,EEP_SET_ADDR+(m_runsection)*SETSIZE,SW_SET_NUMBER,&tSwSetTable[0]))
  1666. if(SavePara((void *)m_SetBuf,EEP_SET_ADDR+(m_selsection)*SETSIZE,SW_SET_NUMBER,&tSwSetTable[0]))
  1667. {
  1668. strcpy(m_WarningStr,"定值保存成功");
  1669. soe_record_opt(EV_SET_OK,0);
  1670. MakeRunSet(false);
  1671. rt_err_clr(ERR_CODE_SET,0);
  1672. }
  1673. else
  1674. {
  1675. strcpy(m_WarningStr,"定值保存失败");
  1676. soe_record_opt(EV_SET_FAIL,0);
  1677. }
  1678. return M_JUMP0;
  1679. }
  1680. int mmd_ChangeYBSet(const TSETTABLE *pSet,int num,SET_VALUE *setbuf) //ext为不需显示的定值组
  1681. {
  1682. int i;
  1683. int sw=0;
  1684. for(i=0;i<num;i++)
  1685. {
  1686. if(mmd_IsIntegType(pSet[i].wType))
  1687. {
  1688. float ff=setbuf[i].ff;
  1689. setbuf[i].tt=(uint32_t)ff;
  1690. }
  1691. if (pSet[i].wType != SETTYPE_LABEL)
  1692. {
  1693. //xj 2019.10.21
  1694. if(pSet[i].group==GROUP_SET_YB&&(g_tRelay[sw].run_stu.bhtt==1 ||g_tRelay[sw].run_stu.fatt ||g_tRelay[sw].run_stu.fa_g_tt)&&(bPubSetMenuShow[i]>0)) // 定值分类组为0 或显示定制为1
  1695. {
  1696. g_set_disp.no[g_set_disp.num] = i;
  1697. g_set_disp.num++;
  1698. }
  1699. }
  1700. }
  1701. return g_set_disp.num;
  1702. }
  1703. /**************************************************************************
  1704. 函数名称:mmd_RenewYBSet
  1705. 函数版本:1.00
  1706. 作者:
  1707. 创建日期:2008.9.11
  1708. 函数功能说明:刷新定值显示
  1709. 输入参数:
  1710. 输出参数:
  1711. 返回值:
  1712. 更新信息:
  1713. 更新日志1:
  1714. 日期:
  1715. 修改者:
  1716. 修改内容:
  1717. 修改原因:
  1718. ***************************************************************************/
  1719. int mmd_RenewYBSet(void)
  1720. {
  1721. DATA_MENU_DEF *pt=&g_tDataMenu1;
  1722. int i;
  1723. int index=(pt->sFocusIndex/pt->sScreenNum)*pt->sScreenNum;
  1724. for(i=0;i<pt->sScreenNum;i++)
  1725. {
  1726. mmd_GetSet(index,&g_tDataMenu1.tDataFields[i], &tPubSetTable[0],m_SetBuf);
  1727. if(++index>pt->sTotalNum-1) break; //最后一个CPU
  1728. }
  1729. m_CurrentScreen=(pt->sFocusIndex/pt->sScreenNum)+1;
  1730. return M_OK;
  1731. }
  1732. /**************************************************************************
  1733. 函数名称:mmd_InitSetSolid
  1734. 函数版本:1.00
  1735. 作者:
  1736. 创建日期:2008.9.1
  1737. 函数功能说明:初始化定值整定的显示
  1738. 输入参数:
  1739. 输出参数:
  1740. 返回值:
  1741. 更新信息:
  1742. 更新日志1:
  1743. 日期:
  1744. 修改者:
  1745. 修改内容:
  1746. 修改原因:
  1747. ***************************************************************************/
  1748. int mmd_InitYBSet(int value)
  1749. {
  1750. int num=PUB_SET_NUMBER;
  1751. m_AllSection=0;
  1752. g_set_disp.num=0;
  1753. if(value>=0)
  1754. {
  1755. /*读取压板定值*/
  1756. if(!ReadPara((void*)m_SetBuf,EEP_PUB_ADDR+(PUB_SETSIZE*m_runsection),PUB_SET_NUMBER,&tPubSetTable[0]))
  1757. {
  1758. return M_JUMP3;
  1759. }
  1760. }
  1761. num=mmd_ChangeYBSet(&tPubSetTable[0],PUB_SET_NUMBER,&m_SetBuf[0]);
  1762. if(num==0)
  1763. {
  1764. strcpy(m_WarningStr,"无可整定定值!");
  1765. return M_JUMP2;
  1766. }
  1767. bSetChange=true;
  1768. {
  1769. DATA_MENU_DEF *pt=&g_tDataMenu1;
  1770. mmd_GetSet(0,&g_tDataMenu1.tDataFields[0],&tPubSetTable[0],m_SetBuf);
  1771. m_ScreenNum=num;
  1772. pt->sFocusIndex=0; //第一个显示的动态菜单的索引
  1773. pt->sTotalNum=num; //总的动态菜单数
  1774. pt->GetPrevFuncAddr=mmd_RenewYBSet; //44
  1775. pt->GetNextFuncAddr=mmd_RenewYBSet; //44
  1776. m_CurrentScreen=1;
  1777. }
  1778. return M_JUMP0;
  1779. }
  1780. /**************************************************************************
  1781. 函数名称:mmd_SetKey
  1782. 函数版本:1.00
  1783. 作者:
  1784. 创建日期:2008.9.1
  1785. 函数功能说明:列表项选择
  1786. 输入参数:
  1787. 输出参数:
  1788. 返回值:
  1789. 更新信息:
  1790. 更新日志1:
  1791. 日期:
  1792. 修改者:
  1793. 修改内容:
  1794. 修改原因:
  1795. ***************************************************************************/
  1796. int mmd_SetYBKey(int key)
  1797. {
  1798. if(key==HA_KEY_UP&&g_tScreen.lcd_type!=LCD_TYPE_160_KEY9)key=HA_KEY_ADD;
  1799. if(key==HA_KEY_DOWN&&g_tScreen.lcd_type!=LCD_TYPE_160_KEY9)key=HA_KEY_SUB;
  1800. if(key==HA_KEY_ADD||key==HA_KEY_SUB) // +键增加列表
  1801. {
  1802. if(!g_bModify) return M_ERROR; // 只在修改状态下执行此函数
  1803. if(mmd_ChangeList(&tPubSetTable[0],key,m_SetBuf))
  1804. {
  1805. mmd_RenewYBSet(); //刷新修改后的值
  1806. return M_OK;
  1807. }
  1808. }
  1809. return M_ERROR;
  1810. }
  1811. int mmd_SaveYBSet(int value)
  1812. {
  1813. mmd_ReChangeSet(&tPubSetTable[0],PUB_SET_NUMBER,m_SetBuf);
  1814. if(!mmd_CheckSet(&tPubSetTable[0],PUB_SET_NUMBER,m_SetBuf))
  1815. {
  1816. mmd_ChangeSet(&tPubSetTable[0],PUB_SET_NUMBER,m_SetBuf);
  1817. return M_JUMP3;
  1818. }
  1819. if(SavePara((void *)m_SetBuf,EEP_PUB_ADDR+(PUB_SETSIZE*m_runsection),PUB_SET_NUMBER,&tPubSetTable[0]))
  1820. {
  1821. strcpy(m_WarningStr,"压板保存成功");
  1822. soe_record_opt(EV_PUBSET_OK,0);
  1823. MakeRunSet(false);
  1824. rt_err_clr(ERR_CODE_SET_PUB,0);
  1825. }
  1826. else
  1827. {
  1828. strcpy(m_WarningStr,"压板保存失败");
  1829. soe_record_opt(EV_PUBSET_FAIL,0);
  1830. }
  1831. return M_JUMP0; //弹出定值固化菜单,需选择输入区号
  1832. }
  1833. int mmd_GetDefaultYBSet(int value)
  1834. {
  1835. GetDefPara((void*)m_SetBuf,PUB_SET_NUMBER,&tPubSetTable[0]);
  1836. mmd_InitYBSet(-1);
  1837. return M_OK;
  1838. }
  1839. /**************************************************************************
  1840. 函数名称:mmd_CheckDzPassword
  1841. 函数版本:1.00
  1842. 作者:
  1843. 创建日期:2008.9.1
  1844. 函数功能说明:检查定值密码,
  1845. 输入参数:
  1846. 输出参数:
  1847. 返回值:
  1848. 更新信息:
  1849. 更新日志1:
  1850. 日期:
  1851. 修改者:
  1852. 修改内容:
  1853. 修改原因:
  1854. ***************************************************************************/
  1855. int mmd_CheckDzPassword(int value)
  1856. {
  1857. bool bret;
  1858. //if(m_Password!=tRunPara.wPassword&&m_Password!=PASS_WORD)
  1859. u8 passstr[10];
  1860. #ifdef PASSWORD_4_STR
  1861. strcpy(passstr,PASS_WORD_STR_4);
  1862. #else
  1863. strcpy(passstr,PASS_WORD_STR);
  1864. #endif
  1865. if((strcmp(m_strPassword,tRunPara.wPasswordstr)!=0)&&(strcmp(m_strPassword,passstr)!=0))
  1866. {
  1867. m_Password=0;
  1868. mmi_zero_passwordstr();
  1869. strcpy(m_WarningStr,"输入密码错误!");
  1870. return M_JUMP3;
  1871. }
  1872. m_Password=0;
  1873. mmi_zero_passwordstr();
  1874. bret=ReadEppData(EEP_SETGROUP_ADDR,m_setgroup,GROUP_NUM);
  1875. if(!bret)
  1876. {
  1877. GetDefSetGroup(m_setgroup);
  1878. }
  1879. return M_JUMP0;
  1880. }
  1881. /**************************************************************************
  1882. 函数名称:mmd_CheckXTPassword
  1883. 函数版本:1.00
  1884. 作者:
  1885. 创建日期:2008.9.1
  1886. 函数功能说明:检查系统维护密码
  1887. 输入参数:
  1888. 输出参数:
  1889. 返回值:
  1890. 更新信息:
  1891. 更新日志1:
  1892. 日期:
  1893. 修改者:
  1894. 修改内容:
  1895. 修改原因:
  1896. ***************************************************************************/
  1897. int mmd_CheckXTPassword(int value) // 系统维护密码
  1898. {
  1899. //if(m_Password==INTER_PASSWORD) // 特殊密码,进特内部设置菜单
  1900. u8 passstr[10];
  1901. #ifdef PASSWORD_4_STR
  1902. strcpy(passstr,INTER_PASSWORD_STR_4);
  1903. #else
  1904. strcpy(passstr,INTER_PASSWORD_STR);
  1905. #endif
  1906. if(strcmp(m_strPassword,passstr)==0)
  1907. {
  1908. m_Password=0;
  1909. mmi_zero_passwordstr();
  1910. return M_JUMP1;
  1911. }
  1912. #ifdef PASSWORD_4_STR
  1913. strcpy(passstr,PASS_WORD_STR_4);
  1914. #else
  1915. strcpy(passstr,PASS_WORD_STR);
  1916. #endif
  1917. //if(m_Password!=tRunPara.wPassword&&m_Password!=PASS_WORD)
  1918. if((strcmp(m_strPassword,tRunPara.wPasswordstr)!=0)&&(strcmp(m_strPassword,passstr)!=0))
  1919. {
  1920. m_Password=0;
  1921. mmi_zero_passwordstr();
  1922. strcpy(m_WarningStr,"输入密码错误!");
  1923. return M_JUMP3;
  1924. }
  1925. m_Password=0;
  1926. mmi_zero_passwordstr();
  1927. return M_JUMP0;
  1928. }
  1929. /**************************************************************************
  1930. 函数名称:mmd_CheckCopyPassword
  1931. 函数版本:1.00
  1932. 作者:
  1933. 创建日期:2008.9.1
  1934. 函数功能说明:检查定值复制密码,并取有效定值区及全部定值区到相应的buf中
  1935. 输入参数:
  1936. 输出参数:
  1937. 返回值:
  1938. 更新信息:
  1939. 更新日志1:
  1940. 日期:
  1941. 修改者:
  1942. 修改内容:
  1943. 修改原因:
  1944. ***************************************************************************/
  1945. int mmd_CheckParaPassword(int value)
  1946. {
  1947. bool bret;
  1948. u8 passstr[10];
  1949. //if(m_Password!=tRunPara.wPassword&&m_Password!=PASS_WORD)
  1950. #ifdef PASSWORD_4_STR
  1951. strcpy(passstr,INTER_PASSWORD_STR_4);
  1952. #else
  1953. strcpy(passstr,INTER_PASSWORD_STR);
  1954. #endif
  1955. if((strcmp(m_strPassword,tRunPara.wPasswordstr)!=0)&&(strcmp(m_strPassword,passstr)!=0))
  1956. {
  1957. m_Password=0;
  1958. mmi_zero_passwordstr();
  1959. strcpy(m_WarningStr,"输入密码错误!");
  1960. return M_JUMP3;
  1961. }
  1962. m_Password=0;
  1963. mmi_zero_passwordstr();
  1964. bret=ReadEppData(EEP_SETGROUP_ADDR,m_setgroup,GROUP_NUM);
  1965. if(!bret)
  1966. {
  1967. GetDefSetGroup(m_setgroup);
  1968. }
  1969. return mmd_InitParaSetGroup(0);
  1970. }
  1971. /**************************************************************************
  1972. 函数名称:mmd_RenewEquipPara
  1973. 函数版本:1.00
  1974. 作者:
  1975. 创建日期:2008.9.23
  1976. 函数功能说明: 刷新装置参数的显示
  1977. 输入参数:
  1978. 输出参数:
  1979. 返回值:
  1980. 更新信息:
  1981. 更新日志1
  1982. 日期:
  1983. 修改者:
  1984. 修改内容:
  1985. 修改原因:
  1986. ***************************************************************************/
  1987. //下面是参数修改
  1988. int mmd_RenewParaSet(void)
  1989. {
  1990. DATA_MENU_DEF *pt=&g_tDataMenu1;
  1991. DATA_MENU_DEF *pext=&g_tExtraMenu;
  1992. int i;
  1993. int bgn;
  1994. bgn=g_set_disp.bgn[pt->sFocusIndex];
  1995. pext->sTotalNum=0; //总的动态菜单数
  1996. for(i=0;i<g_set_disp.screennum[pt->sFocusIndex];i++)
  1997. {
  1998. mmd_GetSet(bgn+i,&g_tDataMenu1.tDataFields[i],&tEquipParaTable[0],m_SetBuf);
  1999. }
  2000. pt->sScreenNum=g_set_disp.screennum[pt->sFocusIndex];
  2001. pext->sFocusIndex=0; //第一个显示的动态菜单的索引
  2002. pext->sScreenNum=pext->sTotalNum;
  2003. return M_OK;
  2004. }
  2005. int mmd_RenewParaSetGroup(void)
  2006. {
  2007. mmd_RenewDataMenu(&g_tDataMenu2);
  2008. return M_OK;
  2009. }
  2010. int mmd_backParaSet(int value)
  2011. {
  2012. mmd_InitParaSetGroup(-1);
  2013. g_tDataMenu2.sFocusIndex=SetGroupIndex;
  2014. mmi_FormsInit(70,1); // 更新最后修改的数据
  2015. mmd_RenewParaSetGroup();
  2016. return M_OK;
  2017. }
  2018. int mmd_InitParaSetGroup(int value)
  2019. {
  2020. int i,num=0;
  2021. for(i=0;i<GROUP_NUM;i++)
  2022. {
  2023. if(SetGroups[i].group == SETGROUP_TYPE_PARA&&(m_setgroup[i]>0))
  2024. {
  2025. int j;
  2026. for(j=0;j<EQUIP_PARA_NUMBER;j++)
  2027. {
  2028. if((bParaSetMenuShow[j]>0)&&(tEquipParaTable[j].group==i)&&(tEquipParaTable[j].wType!= SETTYPE_LABEL))
  2029. if(tEquipParaTable[j].group==i)
  2030. {
  2031. set_show_group[num++]=i;
  2032. break;
  2033. }
  2034. }
  2035. }
  2036. }
  2037. if(num==0)
  2038. {
  2039. strcpy(m_WarningStr,"装置参数未配置");
  2040. return M_JUMP3;
  2041. }
  2042. mmd_initDataMenu(&g_tDataMenu2,num,mmd_RenewParaSetGroup,mmd_GetSetGroupName,70,1);
  2043. if(!ReadPara((void*)m_SetBuf,EEP_EQUIP_PARA_ADDR,EQUIP_PARA_NUMBER,&tEquipParaTable[0]))
  2044. {
  2045. if(value==-1)
  2046. {
  2047. GetDefPara((float*)m_SetBuf,EQUIP_PARA_NUMBER,&tEquipParaTable[0]);
  2048. }
  2049. else
  2050. {
  2051. return M_JUMP2;
  2052. }
  2053. }
  2054. mmd_ChangeSet(&tEquipParaTable[0],EQUIP_PARA_NUMBER,m_SetBuf);
  2055. return M_JUMP0;
  2056. }
  2057. int mmd_SaveParaSet(int value)
  2058. {
  2059. if(mmd_CheckPassword2()==false)
  2060. {
  2061. return M_JUMP2;
  2062. }
  2063. mmd_ReChangeSet(&tEquipParaTable[0],EQUIP_PARA_NUMBER,m_SetBuf);
  2064. if(!mmd_CheckSet(&tEquipParaTable[0],EQUIP_PARA_NUMBER,m_SetBuf))
  2065. {
  2066. mmd_ChangeSet(&tEquipParaTable[0],EQUIP_PARA_NUMBER,m_SetBuf);
  2067. return M_JUMP3;
  2068. }
  2069. if(SavePara((void *)m_SetBuf,EEP_EQUIP_PARA_ADDR,EQUIP_PARA_NUMBER,&tEquipParaTable[0]))
  2070. {
  2071. strcpy(m_WarningStr,"参数保存成功");
  2072. soe_record_opt(EV_EQUPARA_OK,0);
  2073. MakeRunPara(false,false);
  2074. rt_err_clr(ERR_CODE_EQU_PARA,0);
  2075. }
  2076. else
  2077. {
  2078. strcpy(m_WarningStr,"参数保存失败");
  2079. soe_record_opt(EV_EQUPARA_FAIL,0);
  2080. }
  2081. return M_JUMP0;
  2082. }
  2083. /**************************************************************************
  2084. 函数名称:mmd_InitSetSolid
  2085. 函数版本:1.00
  2086. 作者:
  2087. 创建日期:2008.9.1
  2088. 函数功能说明:初始化定值整定的显示
  2089. 输入参数:
  2090. 输出参数:
  2091. 返回值:
  2092. 更新信息:
  2093. 更新日志1:
  2094. 日期:
  2095. 修改者:
  2096. 修改内容:
  2097. 修改原因:
  2098. ***************************************************************************/
  2099. int mmd_InitParaSet(int value)
  2100. {
  2101. int num=EQUIP_PARA_NUMBER;
  2102. int screennum;
  2103. int i;
  2104. m_AllSection=0;
  2105. g_set_disp.num=0;
  2106. num=mmd_GetshowSetNum(&tEquipParaTable[0],EQUIP_PARA_NUMBER,set_show_group[value]);
  2107. SetGroupIndex=value;
  2108. screennum=mmi_GetScreenNum(71,1); // 取当前屏幕最大显示数目
  2109. bSetChange=true;
  2110. mmd_analyse(&tEquipParaTable[0],screennum);
  2111. {
  2112. DATA_MENU_DEF *pt=&g_tDataMenu1;
  2113. DATA_MENU_DEF *pext=&g_tExtraMenu;
  2114. pext->sTotalNum=0;
  2115. for(i=0;i<g_set_disp.screennum[0];i++)
  2116. {
  2117. mmd_GetSet(i,&g_tDataMenu1.tDataFields[i],&tEquipParaTable[0],m_SetBuf);
  2118. }
  2119. m_ScreenNum=num;
  2120. pt->sFocusIndex=0; //第一个显示的动态菜单的索引
  2121. pt->sTotalNum=num; //总的动态菜单数
  2122. pt->sScreenNum=g_set_disp.screennum[0];
  2123. pt->GetPrevFuncAddr=mmd_RenewParaSet; //44
  2124. pt->GetNextFuncAddr=mmd_RenewParaSet; //44
  2125. pext->sFocusIndex=0; //第一个显示的动态菜单的索引
  2126. pext->sScreenNum=pext->sTotalNum;
  2127. pext->GetPrevFuncAddr=NULL; //44
  2128. pext->GetNextFuncAddr=NULL; //44
  2129. m_CurrentScreen=1;
  2130. }
  2131. return M_JUMP0;
  2132. }
  2133. /**************************************************************************
  2134. 函数名称:mmd_SetKey
  2135. 函数版本:1.00
  2136. 作者:
  2137. 创建日期:2008.9.1
  2138. 函数功能说明:列表项选择
  2139. 输入参数:
  2140. 输出参数:
  2141. 返回值:
  2142. 更新信息:
  2143. 更新日志1:
  2144. 日期:
  2145. 修改者:
  2146. 修改内容:
  2147. 修改原因:
  2148. ***************************************************************************/
  2149. int mmd_SetParaKey(int key)
  2150. {
  2151. if(key==HA_KEY_UP&&g_tScreen.lcd_type!=LCD_TYPE_160_KEY9)key=HA_KEY_ADD;
  2152. if(key==HA_KEY_DOWN&&g_tScreen.lcd_type!=LCD_TYPE_160_KEY9)key=HA_KEY_SUB;
  2153. if(key==HA_KEY_ADD||key==HA_KEY_SUB) // +键增加列表
  2154. {
  2155. if(!g_bModify) return M_ERROR; // 只在修改状态下执行此函数
  2156. if(mmd_ChangeList(&tEquipParaTable[0],key,m_SetBuf))
  2157. {
  2158. mmd_RenewParaSet(); //刷新修改后的值
  2159. return M_OK;
  2160. }
  2161. }
  2162. return M_ERROR;
  2163. }
  2164. /**************************************************************************
  2165. 函数名称:mmd_GetEventShow
  2166. 函数版本:1.00
  2167. 作者:
  2168. 创建日期:2008.9.1
  2169. 函数功能说明:事件及记录显示
  2170. 输入参数:
  2171. 输出参数:
  2172. 返回值:
  2173. 更新信息:
  2174. 更新日志1:
  2175. 日期:
  2176. 修改者:
  2177. 修改内容:
  2178. 修改原因:
  2179. ***************************************************************************/
  2180. EVENT_SHOW m_tEvent; // 查询事件的结构
  2181. EVENT_SHOW m_tAutoEv; // 自动弹出事件的结构
  2182. int mmd_splitstr(unsigned char *str,int lcdsize) // 根据lcd宽度,分析一行可显示的字符串
  2183. {
  2184. int i;
  2185. int len=strlen(str);
  2186. if(len<=lcdsize)return 0; // 一行可以显示
  2187. for(i=0;i<len;)
  2188. {
  2189. if(str[i]>0x80) //是汉字
  2190. {
  2191. i+=2;
  2192. }
  2193. else
  2194. {
  2195. i++;
  2196. }
  2197. if(((i>=lcdsize-1)&&str[i]>=0x80)||i>=lcdsize)
  2198. {
  2199. return i;
  2200. }
  2201. }
  2202. return 0;
  2203. }
  2204. void mmd_GetEventShow(EVENT_SHOW *pe,bool bPDA)
  2205. {
  2206. EVENT_STRUCT *er=&pe->tEv;
  2207. char tmpstr[64], tmpstr1[64];
  2208. char namestr[64];
  2209. char valstr[3][20];
  2210. BYTE paranum=0;
  2211. int lineoff;
  2212. int i;
  2213. struct rtc_time_t tTime;
  2214. u8 ev_type;
  2215. timespec_to_rtc(er->ts,&tTime,1);
  2216. pe->year=tTime.year;
  2217. pe->month=tTime.month;
  2218. pe->day=tTime.day;
  2219. pe->hour=tTime.hour;
  2220. pe->min=tTime.min;
  2221. pe->sec=(tTime.ms/1000);
  2222. pe->ms=(tTime.ms%1000);
  2223. pe->sParaCur=0;
  2224. pe->sParaNum=0;
  2225. ev_type=er->ev_type&SOE_TYPE_MASK;
  2226. if(ev_type==SOE_TYPE_EV||ev_type==SOE_TYPE_OPT) // 不是遥信变位
  2227. {
  2228. int i;
  2229. const SOE_DEF * psoe;
  2230. int ev_sw=0;
  2231. u16 code;
  2232. if(er->ev_code>=EV_NUMBER)
  2233. {
  2234. sprintf(namestr,"错误代码:%d",er->ev_code);
  2235. return;
  2236. }
  2237. else
  2238. {
  2239. strcpy(namestr,"");
  2240. if (er->ev_code < EV_PUB_START)
  2241. {
  2242. code = er->ev_code % EV_SW_NUM;
  2243. ev_sw = (er->ev_code / EV_SW_NUM) + 1;
  2244. }
  2245. else
  2246. {
  2247. code = er->ev_code - EV_SW_NUM*(SWITCH_NUM_MAX-1);
  2248. ev_sw=0;
  2249. }
  2250. #if SWITCH_NUM_MAX != 1
  2251. {
  2252. if ((ev_sw > 0) && (ev_sw < SWITCH_NUM_MAX))
  2253. {
  2254. sprintf(namestr,"开关%d",ev_sw);
  2255. }
  2256. }
  2257. #endif
  2258. psoe=&tAllSOE[code];
  2259. strcat(namestr,psoe->strName); // soe 名称
  2260. #ifdef FUN_SET_CHANGE_SOE
  2261. if(er->ev_code==EV_SET_CHANGE_PARA) //定值修改soe,特殊处理
  2262. {
  2263. u16 type=(u16)(er->ev_arg[0]>>16);
  2264. u16 soeno=(u16)er->ev_arg[0];
  2265. const TSETTABLE *pTable;
  2266. SET_VALUE ft;
  2267. if(type==1) //公共参数
  2268. {
  2269. pTable=&tPubSetTable[soeno];
  2270. }
  2271. else if(type==2) //开关参数
  2272. {
  2273. pTable=&tSwSetTable[soeno];
  2274. }
  2275. else if(type==3) //装置参数
  2276. {
  2277. pTable=&tEquipParaTable[soeno];
  2278. }
  2279. else
  2280. {
  2281. pTable=&tCstSetTable[soeno];
  2282. }
  2283. sprintf(namestr,"%s(%s)",pTable->szName,SetGroups[pTable->group].item_name);
  2284. switch(pTable->wType)
  2285. {
  2286. case SETTYPE_F:
  2287. ft.tt=er->ev_arg[1];
  2288. sprintf(tmpstr,"由:%.3f",ft.ff);
  2289. strcpy(valstr[paranum++],tmpstr);
  2290. ft.tt=er->ev_arg[2];
  2291. sprintf(tmpstr,"改:%.3f",ft.ff);
  2292. strcpy(valstr[paranum++],tmpstr);
  2293. break;
  2294. case SETTYPE_UINT: //16进制显示 控制字
  2295. case SETTYPE_4INT: //10进制显示 4位
  2296. case SETTYPE_5INT: //10进制显示 5位
  2297. case SETTYPE_LINT: //16进制显示 控制字
  2298. ft.tt=er->ev_arg[1];
  2299. sprintf(tmpstr,"由:%d",(u16)ft.tt);
  2300. strcpy(valstr[paranum++],tmpstr);
  2301. ft.tt=er->ev_arg[2];
  2302. sprintf(tmpstr,"改:%d",(u16)ft.tt);
  2303. strcpy(valstr[paranum++],tmpstr);
  2304. break;
  2305. case SETTYPE_LIST: //列表选择
  2306. {
  2307. ft.tt=er->ev_arg[1];
  2308. sprintf(tmpstr,"由:%s", pTable->list[(u16)ft.tt].str);
  2309. strcpy(valstr[paranum++],tmpstr);
  2310. ft.tt=er->ev_arg[2];
  2311. sprintf(tmpstr,"改:%s", pTable->list[(u16)ft.tt].str);
  2312. strcpy(valstr[paranum++],tmpstr);
  2313. }
  2314. break;
  2315. case SETTYPE_IP:
  2316. {
  2317. u32 dat;
  2318. ft.tt=er->ev_arg[1];
  2319. dat=(u32)ft.tt;
  2320. sprintf(tmpstr,"由:%d.%d.%d.%d", (dat>>24)&0xFF, (dat>>16)&0xFF, (dat>>8)&0xFF, (dat>>0)&0xFF);
  2321. strcpy(valstr[paranum++],tmpstr);
  2322. ft.tt=er->ev_arg[2];
  2323. dat=(u32)ft.tt;
  2324. sprintf(tmpstr,"改:%d.%d.%d.%d", (dat>>24)&0xFF, (dat>>16)&0xFF, (dat>>8)&0xFF, (dat>>0)&0xFF);
  2325. strcpy(valstr[paranum++],tmpstr);
  2326. }
  2327. break;
  2328. case SETTYPE_YMD:
  2329. {
  2330. struct timespec ts;
  2331. struct rtc_time_t tTime;
  2332. memset(&ts, 0, sizeof(ts));
  2333. memset(&tTime, 0, sizeof(tTime));
  2334. ft.tt=er->ev_arg[1];
  2335. ts.tv_sec = (long)ft.tt;
  2336. timespec_to_rtc(ts,&tTime,1);
  2337. sprintf(tmpstr,"由:%04d-%02d-%02d", 2000+tTime.year, tTime.month, tTime.day);
  2338. strcpy(valstr[paranum++],tmpstr);
  2339. ft.tt=er->ev_arg[2];
  2340. ts.tv_sec = (long)ft.tt;
  2341. timespec_to_rtc(ts,&tTime,1);
  2342. sprintf(tmpstr,"改:%04d-%02d-%02d", 2000+tTime.year, tTime.month, tTime.day);
  2343. strcpy(valstr[paranum++],tmpstr);
  2344. }
  2345. break;
  2346. case SETTYPE_HMS:
  2347. {
  2348. struct timespec ts;
  2349. struct rtc_time_t tTime;
  2350. extern int timespec_to_rtchms(struct timespec ts, struct rtc_time_t * p_rtc,int is_round);
  2351. memset(&ts, 0, sizeof(ts));
  2352. memset(&tTime, 0, sizeof(tTime));
  2353. ft.tt=er->ev_arg[1];
  2354. ts.tv_sec = (long)ft.tt;
  2355. timespec_to_rtchms(ts,&tTime,1);
  2356. sprintf(tmpstr,"由:%02d:%02d:%02d", tTime.hour, tTime.min, tTime.ms%1000);
  2357. strcpy(valstr[paranum++],tmpstr);
  2358. memset(&ts, 0, sizeof(ts));
  2359. memset(&tTime, 0, sizeof(tTime));
  2360. ft.tt=er->ev_arg[2];
  2361. ts.tv_sec = (long)ft.tt;
  2362. timespec_to_rtchms(ts,&tTime,1);
  2363. sprintf(tmpstr,"改:%02d:%02d:%02d", tTime.hour, tTime.min, tTime.ms%1000);
  2364. strcpy(valstr[paranum++],tmpstr);
  2365. }
  2366. default:
  2367. break;
  2368. }
  2369. }
  2370. else
  2371. {
  2372. #endif
  2373. if(er->ev_value) // 置1 ,产生,显示参数
  2374. {
  2375. for(i=0; i<3; i++)
  2376. {
  2377. BYTE index=(psoe->Attrib[i]&0x1f);
  2378. if(index)
  2379. {
  2380. switch((psoe->Attrib[i]>>5)&0x07)
  2381. {
  2382. case 0: // 浮点数
  2383. FUC_Get_LongValue_String(er->ev_arg[i],tmpstr1);
  2384. sprintf((char*)tmpstr,"%s=%s%s",ev_para[index].strName,tmpstr1,g_unit[ev_para[index].byNo].name);
  2385. break;
  2386. case 1: // 整型值
  2387. sprintf(tmpstr,"%s=%d%s",ev_para[index].strName,er->ev_arg[i],g_unit[ev_para[index].byNo].name);
  2388. break;
  2389. case 2: // 遥控操作
  2390. {
  2391. BYTE sw=(er->ev_arg[0]>>8)&0xff; //开关号
  2392. BYTE no=(er->ev_arg[0]>>0)&0xff; //序号
  2393. char *ykowner;
  2394. ykowner=get_yk_owner((er->ev_arg[0]>>16)&0xff);
  2395. if (i==0)
  2396. {
  2397. sprintf(tmpstr,"通道:%s",ykowner);
  2398. }
  2399. else if (i==1)
  2400. {
  2401. //tmpstr[0]=0;
  2402. /*if(sw==0)
  2403. {
  2404. sprintf(tmpstr,"公共开出%d",no);
  2405. }
  2406. else
  2407. {
  2408. #if SWITCH_NUM_MAX != 1
  2409. sprintf(tmpstr,"开关%d开出%d",sw,no);
  2410. #else
  2411. sprintf(tmpstr,"%s",g_equ_config_do[no].name);
  2412. #endif
  2413. }*/
  2414. //if(no==0)
  2415. //{
  2416. // tmpstr[0]=0;
  2417. //}
  2418. //else
  2419. {
  2420. if(sw==0)
  2421. {
  2422. sprintf(tmpstr,"%s", g_pub_do_name[no-1]);
  2423. }
  2424. else
  2425. {
  2426. #if SWITCH_NUM_MAX!=1
  2427. sprintf(tmpstr,"开关%d%s",sw, g_sw_do_name[no-1]);
  2428. #else
  2429. sprintf(tmpstr,"%s", g_sw_do_name[no-1]);
  2430. #endif
  2431. }
  2432. }
  2433. }
  2434. }
  2435. break;
  2436. case 3: // 压板操作
  2437. {
  2438. strcat(namestr," 投入");
  2439. strcpy(tmpstr,"");
  2440. }
  2441. break;
  2442. default:
  2443. strcpy(tmpstr,"参数错误");
  2444. break;
  2445. }
  2446. strcpy(valstr[paranum++],tmpstr);
  2447. }
  2448. }
  2449. }
  2450. else // 置 0,显示返回值
  2451. {
  2452. strcat(namestr,ev_back[(psoe->soe_def&0x03)]);
  2453. }
  2454. #ifdef FUN_SET_CHANGE_SOE
  2455. }
  2456. #endif
  2457. }
  2458. }
  2459. // 遥信变位记录
  2460. else if(ev_type==SOE_TYPE_YX)
  2461. {
  2462. u8 solt=(u8)(er->ev_code>>8); //板卡号
  2463. u8 dino=(u8)(er->ev_code); //遥信号
  2464. // 第三行
  2465. // 填写事件名称
  2466. #if SWITCH_NUM_MAX==1
  2467. sprintf(namestr,"%s:",equ_di_name(solt,dino)); // 板卡xx开入xx变位
  2468. #else
  2469. sprintf(namestr,"板卡%d开入%d(%s):",solt,dino+1,equ_di_name(solt,dino)); // 板卡xx开入xx变位
  2470. #endif
  2471. if(soe_ev_is_on(er)) // 置1 ,产生,显示参数
  2472. {
  2473. strcpy(tmpstr,SOE_YX_H);
  2474. }
  2475. else
  2476. {
  2477. strcpy(tmpstr,SOE_YX_F);
  2478. }
  2479. strcat(namestr,tmpstr);
  2480. }
  2481. else if(ev_type==SOE_TYPE_LNK )
  2482. {
  2483. u32 cp_s=er->ev_arg[2]; // 通道号+地址
  2484. sprintf(namestr,"通道%d地址%d(点号%04x:%04x)变位",(u8)((cp_s>>21)&0x0f),(u8)((cp_s>>16)&0x1f),er->ev_code,(cp_s)&0xffff);
  2485. if(soe_ev_is_on(er)) // 置1 ,产生,显示参数
  2486. {
  2487. strcpy(tmpstr,SOE_YX_H);
  2488. }
  2489. else
  2490. {
  2491. strcpy(tmpstr,SOE_YX_F);
  2492. }
  2493. strcat(namestr,tmpstr);
  2494. }
  2495. // 双点变位记录
  2496. else if(ev_type==SOE_TYPE_DPI)
  2497. {
  2498. if(er->ev_value==SW_DI_TYPE_ON)
  2499. {
  2500. strcpy(tmpstr,"值=2");
  2501. }
  2502. else if(er->ev_value==SW_DI_TYPE_OFF)
  2503. {
  2504. strcpy(tmpstr,"值=1");
  2505. }
  2506. else
  2507. {
  2508. sprintf(tmpstr,"异常(值=%d)",er->ev_value);
  2509. }
  2510. sprintf(namestr,"双点%02d(点号=0x%04x): %s",er->ev_code,g_di_db_table[er->ev_code].cp,tmpstr);
  2511. }
  2512. // PLC变位记录
  2513. else if(ev_type==SOE_TYPE_PLC)
  2514. {
  2515. sprintf(namestr,"PLC(点号=%04x): %d",g_plc[er->ev_code].cp,er->ev_value);
  2516. }
  2517. else
  2518. {
  2519. sprintf(namestr,"未知类型:%d",er->ev_code);
  2520. }
  2521. for(i=0;i<5;i++)
  2522. {
  2523. sprintf(pe->str[i],"%-20.20s","");
  2524. }
  2525. sprintf(pe->namestr,"%-20.20s","");
  2526. sprintf(pe->valuestr,"%-20.20s","");
  2527. #if LCD_SIZE==128 // 128*64液晶
  2528. lineoff=mmd_splitstr(namestr,16);
  2529. if(lineoff==0)
  2530. {
  2531. sprintf(pe->namestr,"%-16.16s",namestr);
  2532. for(i=0;i<paranum;i++)
  2533. {
  2534. sprintf(pe->str[i],"%-15.15s",valstr[i]);
  2535. if(paranum>1)
  2536. {
  2537. strcat(pe->str[i],"+");
  2538. }
  2539. }
  2540. if(paranum>0)
  2541. {
  2542. strcpy(pe->valuestr,pe->str[0]);
  2543. }
  2544. }
  2545. else
  2546. {
  2547. sprintf(pe->valuestr,"%-15.15s",&namestr[lineoff]);
  2548. namestr[lineoff]='\0';
  2549. sprintf(pe->namestr,"%-16.16s",namestr);
  2550. if(paranum>0)
  2551. {
  2552. strcat(pe->valuestr,"+");
  2553. }
  2554. for(i=0;i<paranum;i++)
  2555. {
  2556. sprintf(pe->str[i],"%-15.15s+",valstr[i]);
  2557. }
  2558. }
  2559. #else
  2560. lineoff=mmd_splitstr(namestr,20);
  2561. if(lineoff==0)
  2562. {
  2563. sprintf(pe->str[0],"%-20.20s",namestr);
  2564. for(i=0;i<paranum;i++)
  2565. {
  2566. sprintf(pe->str[i+1],"%-20.20s",valstr[i]);
  2567. }
  2568. }
  2569. else
  2570. {
  2571. sprintf(pe->str[1],"%-20.20s",&namestr[lineoff]);
  2572. namestr[lineoff]='\0';
  2573. sprintf(pe->str[0],"%-20.20s",namestr);
  2574. for(i=0;i<paranum;i++)
  2575. {
  2576. sprintf(pe->str[i+2],"%-20.20s",valstr[i]);
  2577. }
  2578. }
  2579. #endif
  2580. pe->sParaNum=paranum;
  2581. }
  2582. /**************************************************************************
  2583. 函数名称:mmd_GetEvent
  2584. 函数版本:1.00
  2585. 作者:
  2586. 创建日期:2008.9.1
  2587. 函数功能说明:取事件记录信息
  2588. 输入参数:
  2589. 输出参数:
  2590. 返回值:
  2591. 更新信息:
  2592. 更新日志1:
  2593. 日期:
  2594. 修改者:
  2595. 修改内容:
  2596. 修改原因:
  2597. ***************************************************************************/
  2598. int mmd_GetEvent(int value)
  2599. {
  2600. DWORD addr;
  2601. if(g_soe_info.wEvNumber==0)
  2602. {
  2603. strcpy(m_WarningStr,"无事件记录信息");
  2604. return M_JUMP3;
  2605. }
  2606. addr=EEP_SOE_ADDR+g_soe_info.wEvIndex*(sizeof(EVENT_SAVE))+4;
  2607. e2prom_read(addr,(BYTE *)&m_tEvent.tEv,sizeof(EVENT_STRUCT));
  2608. mmd_GetEventShow(&m_tEvent,false);
  2609. m_tEvent.wCurrent=g_soe_info.wEvNumber;
  2610. m_tEvent.wNumber=g_soe_info.wEvNumber;
  2611. m_tEvent.wIndex=g_soe_info.wEvIndex;
  2612. return M_JUMP0;
  2613. }
  2614. int mmd_GetVipEvent(int value)
  2615. {
  2616. DWORD addr;
  2617. if(g_soe_info.wVipNumber==0)
  2618. {
  2619. strcpy(m_WarningStr,"无关键记录信息");
  2620. return M_JUMP3;
  2621. }
  2622. addr=EEP_VIP_ADDR+g_soe_info.wVipIndex*(sizeof(EVENT_SAVE))+4;
  2623. e2prom_read(addr,(BYTE *)&m_tEvent.tEv,sizeof(EVENT_STRUCT));
  2624. mmd_GetEventShow(&m_tEvent,false);
  2625. m_tEvent.wCurrent=g_soe_info.wVipNumber;
  2626. m_tEvent.wNumber=g_soe_info.wVipNumber;
  2627. m_tEvent.wIndex=g_soe_info.wVipIndex;
  2628. return M_JUMP0;
  2629. }
  2630. int mmd_GetDebugEvent(int value)
  2631. {
  2632. DWORD addr;
  2633. #ifndef ADD_DEBUG_RECORD_FUN //未配置调试记录的功能则每次进入菜单则需把关键记录的参数传入调试记录参数中
  2634. g_soe_info.wDebugNumber=g_soe_info.wVipNumber;
  2635. g_soe_info.wDebugIndex=g_soe_info.wVipIndex;
  2636. #endif
  2637. if(g_soe_info.wDebugNumber==0)
  2638. {
  2639. strcpy(m_WarningStr,"无调试记录信息");
  2640. return M_JUMP3;
  2641. }
  2642. addr=EEP_DEBUG_RECORD_ADDR+g_soe_info.wDebugIndex*(sizeof(EVENT_SAVE))+4;
  2643. e2prom_read(addr,(BYTE *)&m_tEvent.tEv,sizeof(EVENT_STRUCT));
  2644. mmd_GetEventShow(&m_tEvent,false);
  2645. m_tEvent.wCurrent=g_soe_info.wDebugNumber;
  2646. m_tEvent.wNumber=g_soe_info.wDebugNumber;
  2647. m_tEvent.wIndex=g_soe_info.wDebugIndex;
  2648. return M_JUMP0;
  2649. }
  2650. /**************************************************************************
  2651. 函数名称:mmd_GetOpe
  2652. 函数版本:1.00
  2653. 作者:
  2654. 创建日期:2008.9.1
  2655. 函数功能说明:取操作记录信息
  2656. 输入参数:
  2657. 输出参数:
  2658. 返回值:
  2659. 更新信息:
  2660. 更新日志1:
  2661. 日期:
  2662. 修改者:
  2663. 修改内容:
  2664. 修改原因:
  2665. ***************************************************************************/
  2666. int mmd_GetOpe(int value)
  2667. {
  2668. DWORD addr;
  2669. if(g_soe_info.wOpNumber==0)
  2670. {
  2671. strcpy(m_WarningStr,"无操作记录信息");
  2672. return M_JUMP3;
  2673. }
  2674. addr=EEP_OPERATE_ADDR+g_soe_info.wOpIndex*(sizeof(EVENT_SAVE))+4;
  2675. e2prom_read(addr,(BYTE *)&m_tEvent.tEv,sizeof(EVENT_STRUCT));
  2676. mmd_GetEventShow(&m_tEvent,false);
  2677. m_tEvent.wCurrent=g_soe_info.wOpNumber;
  2678. m_tEvent.wNumber=g_soe_info.wOpNumber;
  2679. m_tEvent.wIndex=g_soe_info.wOpIndex;
  2680. return M_JUMP0;
  2681. }
  2682. /**************************************************************************
  2683. 函数名称:mmd_GetSoePara
  2684. 函数版本:1.00
  2685. 作者:
  2686. 创建日期:2008.9.1
  2687. 函数功能说明:取记录显示的参数
  2688. 输入参数:
  2689. 输出参数:
  2690. 返回值:
  2691. 更新信息:
  2692. 更新日志1:
  2693. 日期:
  2694. 修改者:
  2695. 修改内容:
  2696. 修改原因:
  2697. ***************************************************************************/
  2698. static int mmd_GetSoePara(EVENT_SHOW *es)
  2699. {
  2700. if(g_tScreen.lcd_type!=LCD_TYPE_12232) // 是160*160液晶,参数一屏可以显示
  2701. {
  2702. return M_OK;
  2703. }
  2704. if(es->sParaNum<1)
  2705. {
  2706. return M_OK;
  2707. }
  2708. es->sParaCur++;
  2709. if(es->sParaCur>=es->sParaNum)
  2710. {
  2711. es->sParaCur=0;
  2712. }
  2713. sprintf(es->valuestr,"%-16.16s",es->str[es->sParaCur]);
  2714. return M_OK;
  2715. }
  2716. #ifdef SOE_PARA_ALL_SAVE
  2717. static int mmd_GetAllSoePara(EVENT_SHOW *pe)
  2718. {
  2719. EVENT_STRUCT *er=&pe->tEv;
  2720. u8 ev_type;
  2721. ev_type=er->ev_type&SOE_TYPE_MASK;
  2722. if(ev_type==SOE_TYPE_EV) // 事件
  2723. {
  2724. u16 code=0;
  2725. if(er->ev_code<EV_NUMBER&&er->ev_value)
  2726. {
  2727. if (er->ev_code < EV_PUB_START)
  2728. {
  2729. code = er->ev_code % EV_SW_NUM;
  2730. }
  2731. else
  2732. {
  2733. code = er->ev_code - EV_SW_NUM*(SWITCH_NUM_MAX-1);
  2734. }
  2735. if(tAllSOE[code].soe_def&0x10)
  2736. {
  2737. DATA_MENU_DEF *pt=&g_tDataMenu2;
  2738. u8 tmpstr[16];
  2739. FUC_Get_LongValue_String(er->allarg[0],tmpstr);
  2740. sprintf((char*)pt->tDataFields[0].FmtStr,"Uab=%s V",tmpstr);
  2741. FUC_Get_LongValue_String(er->allarg[1],tmpstr);
  2742. sprintf((char*)pt->tDataFields[1].FmtStr,"Ubc=%s V",tmpstr);
  2743. FUC_Get_LongValue_String(er->allarg[2],tmpstr);
  2744. sprintf((char*)pt->tDataFields[2].FmtStr,"Uca=%s V",tmpstr);
  2745. FUC_Get_LongValue_String(er->allarg[3],tmpstr);
  2746. sprintf((char*)pt->tDataFields[3].FmtStr,"U0=%s V",tmpstr);
  2747. FUC_Get_LongValue_String(er->allarg[4],tmpstr);
  2748. sprintf((char*)pt->tDataFields[4].FmtStr,"Ia= %s A",tmpstr);
  2749. FUC_Get_LongValue_String(er->allarg[5],tmpstr);
  2750. sprintf((char*)pt->tDataFields[5].FmtStr,"Ib= %s A",tmpstr);
  2751. FUC_Get_LongValue_String(er->allarg[6],tmpstr);
  2752. sprintf((char*)pt->tDataFields[6].FmtStr,"Ic= %s A",tmpstr);
  2753. FUC_Get_LongValue_String(er->allarg[7],tmpstr);
  2754. sprintf((char*)pt->tDataFields[7].FmtStr,"I0= %s A",tmpstr);
  2755. pt->sFocusIndex=0;
  2756. pt->sTotalNum=8;
  2757. pt->GetNextFuncAddr=NULL;
  2758. pt->GetPrevFuncAddr=NULL;
  2759. pt->GetValueFuncAddr=NULL;
  2760. return M_JUMP1;
  2761. }
  2762. }
  2763. }
  2764. return M_OK;
  2765. }
  2766. #endif
  2767. /**************************************************************************
  2768. 函数名称:mmd_GetNextEv
  2769. 函数版本:1.00
  2770. 作者:
  2771. 创建日期:2008.9.1
  2772. 函数功能说明:根据按键,切换到上一记录或下一记录显示
  2773. 输入参数:
  2774. 输出参数:
  2775. 返回值:
  2776. 更新信息:
  2777. 更新日志1:
  2778. 日期:
  2779. 修改者:
  2780. 修改内容:
  2781. 修改原因:
  2782. ***************************************************************************/
  2783. int mmd_GetNextEv(int key)
  2784. {
  2785. #ifdef SOE_PARA_ALL_SAVE
  2786. if(key==HA_KEY_ENTER) // 全参数显示
  2787. {
  2788. return mmd_GetAllSoePara(&m_tEvent);
  2789. }
  2790. #endif
  2791. if(key==HA_KEY_ADD) // 参数显示
  2792. {
  2793. return mmd_GetSoePara(&m_tEvent);
  2794. }
  2795. if(key==((g_tScreen.lcd_type==LCD_TYPE_6KEY)?HA_KEY_LEFT:HA_KEY_ESC)) // 老版本按键6键,左键为取消键
  2796. {
  2797. return M_ERROR;
  2798. }
  2799. if(key==HA_KEY_LEFT||key==HA_KEY_UP) // 上一条SOE
  2800. {
  2801. DWORD addr;
  2802. if(g_soe_info.wEvNumber<=1)
  2803. {
  2804. return M_ERROR;
  2805. }
  2806. if(m_tEvent.wCurrent<=1)
  2807. {
  2808. m_tEvent.wCurrent=g_soe_info.wEvNumber;
  2809. }
  2810. else
  2811. {
  2812. m_tEvent.wCurrent--;
  2813. }
  2814. if(m_tEvent.wIndex>0)
  2815. {
  2816. m_tEvent.wIndex--;
  2817. }
  2818. else
  2819. {
  2820. if(g_soe_info.wEvNumber==MAX_EVENT_NUMBER)
  2821. {
  2822. m_tEvent.wIndex=MAX_EVENT_NUMBER-1;
  2823. }
  2824. else
  2825. {
  2826. m_tEvent.wIndex=g_soe_info.wEvIndex;
  2827. }
  2828. }
  2829. addr=EEP_SOE_ADDR+m_tEvent.wIndex*(sizeof(EVENT_SAVE))+4;
  2830. e2prom_read(addr,(BYTE *)&m_tEvent.tEv,sizeof(EVENT_STRUCT));
  2831. mmd_GetEventShow(&m_tEvent,false);
  2832. m_tEvent.wNumber=g_soe_info.wEvNumber;
  2833. return M_JUMP0;
  2834. }
  2835. if(key==HA_KEY_RIGHT||key==HA_KEY_DOWN) // 下一条SOE
  2836. {
  2837. DWORD addr;
  2838. if(g_soe_info.wEvNumber<=1)
  2839. {
  2840. return M_ERROR;
  2841. }
  2842. m_tEvent.wCurrent++; // 标头个数调整
  2843. if(m_tEvent.wCurrent>g_soe_info.wEvNumber)
  2844. {
  2845. m_tEvent.wCurrent=1;
  2846. }
  2847. m_tEvent.wIndex++;
  2848. if(g_soe_info.wEvNumber>=MAX_EVENT_NUMBER)
  2849. {
  2850. if(m_tEvent.wIndex>=MAX_EVENT_NUMBER)
  2851. {
  2852. m_tEvent.wIndex=0;
  2853. }
  2854. }
  2855. else
  2856. {
  2857. if(m_tEvent.wIndex>g_soe_info.wEvIndex)
  2858. {
  2859. m_tEvent.wIndex=0;
  2860. }
  2861. }
  2862. addr=EEP_SOE_ADDR+m_tEvent.wIndex*(sizeof(EVENT_SAVE))+4;
  2863. e2prom_read(addr,(BYTE *)&m_tEvent.tEv,sizeof(EVENT_STRUCT));
  2864. mmd_GetEventShow(&m_tEvent,false);
  2865. m_tEvent.wNumber=g_soe_info.wEvNumber;
  2866. return M_JUMP0;
  2867. }
  2868. return M_ERROR;
  2869. }
  2870. int mmd_GetNextVip(int key)
  2871. {
  2872. #ifdef SOE_PARA_ALL_SAVE
  2873. if(key==HA_KEY_ENTER) // 全参数显示
  2874. {
  2875. return mmd_GetAllSoePara(&m_tEvent);
  2876. }
  2877. #endif
  2878. if(key==HA_KEY_ADD) // 参数显示
  2879. {
  2880. return mmd_GetSoePara(&m_tEvent);
  2881. }
  2882. if(key==((g_tScreen.lcd_type==LCD_TYPE_6KEY)?HA_KEY_LEFT:HA_KEY_ESC)) // 老版本按键6键,左键为取消键
  2883. {
  2884. return M_ERROR;
  2885. }
  2886. if(key==HA_KEY_LEFT||key==HA_KEY_UP) // 上一条SOE
  2887. {
  2888. DWORD addr;
  2889. if(g_soe_info.wVipNumber<=1)
  2890. {
  2891. return M_ERROR;
  2892. }
  2893. if(m_tEvent.wCurrent<=1)
  2894. {
  2895. m_tEvent.wCurrent=g_soe_info.wVipNumber;
  2896. }
  2897. else
  2898. {
  2899. m_tEvent.wCurrent--;
  2900. }
  2901. if(m_tEvent.wIndex>0)
  2902. {
  2903. m_tEvent.wIndex--;
  2904. }
  2905. else
  2906. {
  2907. if(g_soe_info.wVipNumber==MAX_VIP_NUMBER)
  2908. {
  2909. m_tEvent.wIndex=MAX_VIP_NUMBER-1;
  2910. }
  2911. else
  2912. {
  2913. m_tEvent.wIndex=g_soe_info.wVipIndex;
  2914. }
  2915. }
  2916. addr=EEP_VIP_ADDR+m_tEvent.wIndex*(sizeof(EVENT_SAVE))+4;
  2917. e2prom_read(addr,(BYTE *)&m_tEvent.tEv,sizeof(EVENT_STRUCT));
  2918. mmd_GetEventShow(&m_tEvent,false);
  2919. m_tEvent.wNumber=g_soe_info.wVipNumber;
  2920. return M_JUMP0;
  2921. }
  2922. if(key==HA_KEY_RIGHT||key==HA_KEY_DOWN) // 下一条SOE
  2923. {
  2924. DWORD addr;
  2925. if(g_soe_info.wVipNumber<=1)
  2926. {
  2927. return M_ERROR;
  2928. }
  2929. m_tEvent.wCurrent++; // 标头个数调整
  2930. if(m_tEvent.wCurrent>g_soe_info.wVipNumber)
  2931. {
  2932. m_tEvent.wCurrent=1;
  2933. }
  2934. m_tEvent.wIndex++;
  2935. if(g_soe_info.wVipNumber>=MAX_VIP_NUMBER)
  2936. {
  2937. if(m_tEvent.wIndex>=MAX_VIP_NUMBER)
  2938. {
  2939. m_tEvent.wIndex=0;
  2940. }
  2941. }
  2942. else
  2943. {
  2944. if(m_tEvent.wIndex>g_soe_info.wVipIndex)
  2945. {
  2946. m_tEvent.wIndex=0;
  2947. }
  2948. }
  2949. addr=EEP_VIP_ADDR+m_tEvent.wIndex*(sizeof(EVENT_SAVE))+4;
  2950. e2prom_read(addr,(BYTE *)&m_tEvent.tEv,sizeof(EVENT_STRUCT));
  2951. mmd_GetEventShow(&m_tEvent,false);
  2952. m_tEvent.wNumber=g_soe_info.wVipNumber;
  2953. return M_JUMP0;
  2954. }
  2955. return M_ERROR;
  2956. }
  2957. /**************************************************************************
  2958. 函数名称:mmd_GetNextDebug
  2959. 函数版本:1.00
  2960. 作者: jack.liu
  2961. 创建日期:2020.12.21
  2962. 函数功能说明:根据按键,切换到上一操作或下一操作记录显示
  2963. 输入参数:
  2964. 输出参数:
  2965. 返回值:
  2966. ***************************************************************************/
  2967. int mmd_GetNextDebug(int key)
  2968. {
  2969. #ifdef SOE_PARA_ALL_SAVE
  2970. if(key==HA_KEY_ENTER) // 全参数显示
  2971. {
  2972. return mmd_GetAllSoePara(&m_tEvent);
  2973. }
  2974. #endif
  2975. if(key==HA_KEY_ADD) // 参数显示
  2976. {
  2977. return mmd_GetSoePara(&m_tEvent);
  2978. }
  2979. if(key==((g_tScreen.lcd_type==LCD_TYPE_6KEY)?HA_KEY_LEFT:HA_KEY_ESC)) // 老版本按键6键,左键为取消键
  2980. {
  2981. return M_ERROR;
  2982. }
  2983. if(key==HA_KEY_LEFT||key==HA_KEY_UP) // 上一条SOE
  2984. {
  2985. DWORD addr;
  2986. if(g_soe_info.wDebugNumber<=1)
  2987. {
  2988. return M_ERROR;
  2989. }
  2990. if(m_tEvent.wCurrent<=1)
  2991. {
  2992. m_tEvent.wCurrent=g_soe_info.wDebugNumber;
  2993. }
  2994. else
  2995. {
  2996. m_tEvent.wCurrent--;
  2997. }
  2998. if(m_tEvent.wIndex>0)
  2999. {
  3000. m_tEvent.wIndex--;
  3001. }
  3002. else
  3003. {
  3004. if(g_soe_info.wDebugNumber==MAX_DEBUG_RECORD_NUMBER)
  3005. {
  3006. m_tEvent.wIndex=MAX_DEBUG_RECORD_NUMBER-1;
  3007. }
  3008. else
  3009. {
  3010. m_tEvent.wIndex=g_soe_info.wDebugIndex;
  3011. }
  3012. }
  3013. addr=EEP_DEBUG_RECORD_ADDR+m_tEvent.wIndex*(sizeof(EVENT_SAVE))+4;
  3014. e2prom_read(addr,(BYTE *)&m_tEvent.tEv,sizeof(EVENT_STRUCT));
  3015. mmd_GetEventShow(&m_tEvent,false);
  3016. m_tEvent.wNumber=g_soe_info.wDebugNumber;
  3017. return M_JUMP0;
  3018. }
  3019. if(key==HA_KEY_RIGHT||key==HA_KEY_DOWN) // 下一条SOE
  3020. {
  3021. DWORD addr;
  3022. if(g_soe_info.wDebugNumber<=1)
  3023. {
  3024. return M_ERROR;
  3025. }
  3026. m_tEvent.wCurrent++; // 标头个数调整
  3027. if(m_tEvent.wCurrent>g_soe_info.wDebugNumber)
  3028. {
  3029. m_tEvent.wCurrent=1;
  3030. }
  3031. m_tEvent.wIndex++;
  3032. if(g_soe_info.wDebugNumber>=MAX_DEBUG_RECORD_NUMBER)
  3033. {
  3034. if(m_tEvent.wIndex>=MAX_DEBUG_RECORD_NUMBER)
  3035. {
  3036. m_tEvent.wIndex=0;
  3037. }
  3038. }
  3039. else
  3040. {
  3041. if(m_tEvent.wIndex>g_soe_info.wDebugIndex)
  3042. {
  3043. m_tEvent.wIndex=0;
  3044. }
  3045. }
  3046. addr=EEP_DEBUG_RECORD_ADDR+m_tEvent.wIndex*(sizeof(EVENT_SAVE))+4;
  3047. e2prom_read(addr,(BYTE *)&m_tEvent.tEv,sizeof(EVENT_STRUCT));
  3048. mmd_GetEventShow(&m_tEvent,false);
  3049. m_tEvent.wNumber=g_soe_info.wDebugNumber;
  3050. return M_JUMP0;
  3051. }
  3052. return M_ERROR;
  3053. }
  3054. /**************************************************************************
  3055. 函数名称:mmd_GetNextOpe
  3056. 函数版本:1.00
  3057. 作者:
  3058. 创建日期:2008.9.1
  3059. 函数功能说明:根据按键,切换到上一操作或下一操作记录显示
  3060. 输入参数:
  3061. 输出参数:
  3062. 返回值:
  3063. 更新信息:
  3064. 更新日志1:
  3065. 日期:
  3066. 修改者:
  3067. 修改内容:
  3068. 修改原因:
  3069. ***************************************************************************/
  3070. int mmd_GetNextOpe(int key)
  3071. {
  3072. if(key==HA_KEY_ADD) // 参数显示
  3073. {
  3074. return mmd_GetSoePara(&m_tEvent);
  3075. }
  3076. if(key==((g_tScreen.lcd_type==LCD_TYPE_6KEY)?HA_KEY_LEFT:HA_KEY_ESC)) // 老版本按键6键,左键为取消键
  3077. {
  3078. return M_ERROR;
  3079. }
  3080. if(key==HA_KEY_LEFT||key==HA_KEY_UP) // 上一条SOE
  3081. {
  3082. DWORD addr;
  3083. if(g_soe_info.wOpNumber<=1)
  3084. {
  3085. return M_ERROR;
  3086. }
  3087. if(m_tEvent.wCurrent<=1)
  3088. {
  3089. m_tEvent.wCurrent=g_soe_info.wOpNumber;
  3090. }
  3091. else
  3092. {
  3093. m_tEvent.wCurrent--;
  3094. }
  3095. if(m_tEvent.wIndex>0)
  3096. {
  3097. m_tEvent.wIndex--;
  3098. }
  3099. else
  3100. {
  3101. if(g_soe_info.wOpNumber==MAX_OPERATE_NUMBER)
  3102. {
  3103. m_tEvent.wIndex=MAX_OPERATE_NUMBER-1;
  3104. }
  3105. else
  3106. {
  3107. m_tEvent.wIndex=g_soe_info.wOpIndex;
  3108. }
  3109. }
  3110. addr=EEP_OPERATE_ADDR+m_tEvent.wIndex*(sizeof(EVENT_SAVE))+4;
  3111. e2prom_read(addr,(BYTE *)&m_tEvent.tEv,sizeof(EVENT_STRUCT));
  3112. mmd_GetEventShow(&m_tEvent,false);
  3113. m_tEvent.wNumber=g_soe_info.wOpNumber;
  3114. return M_JUMP0;
  3115. }
  3116. if(key==HA_KEY_RIGHT||key==HA_KEY_DOWN) // 下一条SOE
  3117. {
  3118. DWORD addr;
  3119. if(g_soe_info.wOpNumber<=1)
  3120. {
  3121. return M_ERROR;
  3122. }
  3123. m_tEvent.wCurrent++; // 标头个数调整
  3124. if(m_tEvent.wCurrent>g_soe_info.wOpNumber)
  3125. {
  3126. m_tEvent.wCurrent=1;
  3127. }
  3128. m_tEvent.wIndex++;
  3129. if(g_soe_info.wOpNumber>=MAX_OPERATE_NUMBER)
  3130. {
  3131. if(m_tEvent.wIndex>=MAX_OPERATE_NUMBER)
  3132. {
  3133. m_tEvent.wIndex=0;
  3134. }
  3135. }
  3136. else
  3137. {
  3138. if(m_tEvent.wIndex>g_soe_info.wOpIndex)
  3139. {
  3140. m_tEvent.wIndex=0;
  3141. }
  3142. }
  3143. addr=EEP_OPERATE_ADDR+m_tEvent.wIndex*(sizeof(EVENT_SAVE))+4;
  3144. e2prom_read(addr,(BYTE *)&m_tEvent.tEv,sizeof(EVENT_STRUCT));
  3145. mmd_GetEventShow(&m_tEvent,false);
  3146. m_tEvent.wNumber=g_soe_info.wOpNumber;
  3147. return M_JUMP0;
  3148. }
  3149. return M_ERROR;
  3150. }
  3151. /**************************************************************************
  3152. 函数名称:CheckAutoSOE
  3153. 函数版本:1.00
  3154. 作者:
  3155. 创建日期:2008.9.1
  3156. 函数功能说明:检查是否有自动弹出的事件要显示
  3157. 输入参数:
  3158. 输出参数:
  3159. 返回值:
  3160. 更新信息:
  3161. 更新日志1:
  3162. 日期:
  3163. 修改者:
  3164. 修改内容:
  3165. 修改原因:
  3166. ***************************************************************************/
  3167. bool CheckAutoSOE(void)
  3168. {
  3169. if(g_run_stu.bHmiRmtTest&&(g_tScreen.cActiveMenuNo<124||g_tScreen.cActiveMenuNo>129)) // 退出测试模式
  3170. {
  3171. g_run_stu.bHmiRmtTest=false;
  3172. }
  3173. if(g_tScreen.cActiveMenuNo>0)
  3174. {
  3175. g_soe_info.bDpNew=false; //进入其他页面也不弹窗
  3176. return false;
  3177. }
  3178. if(g_tLcdComm.bLock)
  3179. {
  3180. g_soe_info.bDpNew=false;
  3181. return false;
  3182. }
  3183. if(!g_soe_info.bDpNew) //没有事件产生
  3184. {
  3185. return false;
  3186. }
  3187. if(g_tScreen.cActiveMenuNo==23)return false;
  3188. #ifdef YD_TEST_REALTIME_VALUE_DISPLAY
  3189. if((g_tScreen.cActiveMenuNo==124)||(g_tScreen.cActiveMenuNo==126))
  3190. {
  3191. g_soe_info.bDpNew=false; //进入其他页面也不弹窗
  3192. return false;
  3193. }
  3194. #endif
  3195. g_soe_info.bDpNew=false;
  3196. if(g_bVipSoe_show)
  3197. {
  3198. if(g_soe_info.bDpType)
  3199. {
  3200. mmd_GetOpe(0);
  3201. }
  3202. else
  3203. {
  3204. #ifdef ADD_DEBUG_RECORD_FUN
  3205. mmd_GetDebugEvent(0);
  3206. #else
  3207. mmd_GetVipEvent(0);
  3208. #endif
  3209. }
  3210. }
  3211. else
  3212. {
  3213. mmd_GetEvent(0);
  3214. }
  3215. return true;
  3216. }
  3217. /*下面是测量值显示*/
  3218. /**************************************************************************
  3219. 函数名称:mmd_GetMeaPubValue
  3220. 函数版本:1.00
  3221. 作者:
  3222. 创建日期:2008.9.1
  3223. 函数功能说明:处理测量值的显示
  3224. 输入参数:
  3225. i 显示的测量值的索引,
  3226. pF显示数据结构
  3227. 输出参数:
  3228. 返回值:
  3229. 更新信息:
  3230. 更新日志1:
  3231. 日期:
  3232. 修改者:
  3233. 修改内容:
  3234. 修改原因:
  3235. ***************************************************************************/
  3236. void mmd_angle_to_str(char *str,qs16 angle)
  3237. {
  3238. if(str == NULL)
  3239. {
  3240. return ;
  3241. }
  3242. if(angle > 0)
  3243. {
  3244. angle += Q16_BASE>>1;
  3245. }
  3246. else
  3247. {
  3248. angle -= Q16_BASE>>1;
  3249. }
  3250. #ifdef DISP_MEA_CN
  3251. sprintf(str,"%3d°",angle/Q16_BASE);
  3252. #else
  3253. sprintf(str," %3d°",angle/Q16_BASE);
  3254. #endif
  3255. }
  3256. static void mmd_GetMeaPubValue(int i,DATA_FIELD_DEF *pF)
  3257. {
  3258. char *pd=pF->FmtStr;
  3259. char tmpstr[24];
  3260. char meastr[24];
  3261. char meaCal[4];
  3262. //幅值
  3263. FUC_Get_LongValue_String(lMeaVal[i],tmpstr);
  3264. strcpy(meaCal," ");
  3265. if(lMeaCal[i])
  3266. {
  3267. strcpy(meaCal,"*");
  3268. }
  3269. if(g_pub_ac_desc[i].unit_angle == UNIT_ANG) //需要显示角度
  3270. {
  3271. sprintf(meastr,"%s%-4.4s=%-6.6s%s",meaCal,g_pub_ac_desc[i].name,tmpstr,g_unit[g_pub_ac_desc[i].unit].name); //幅值
  3272. }
  3273. else
  3274. {
  3275. sprintf(meastr,"%s%-s=%-6.6s%s",meaCal,g_pub_ac_desc[i].name,tmpstr,g_unit[g_pub_ac_desc[i].unit].name); //幅值
  3276. }
  3277. if(g_pub_ac_desc[i].unit_angle == UNIT_ANG) //需要显示角度
  3278. {
  3279. if(lMeaAng[i]!=ANGEL_INVALID)
  3280. {
  3281. mmd_angle_to_str(tmpstr,lMeaAng[i]);
  3282. }
  3283. else
  3284. {
  3285. strcpy(tmpstr," --- ");
  3286. }
  3287. strcat(meastr,tmpstr);
  3288. }
  3289. sprintf(pd,"%-20s",meastr);
  3290. }
  3291. /**************************************************************************
  3292. 函数名称:mmd_RenewMeaPub
  3293. 函数版本:1.00
  3294. 作者:
  3295. 创建日期:2008.9.1
  3296. 函数功能说明:刷新测量值显示
  3297. 输入参数:
  3298. 输出参数:
  3299. 返回值:
  3300. 更新信息:
  3301. 更新日志1:
  3302. 日期:
  3303. 修改者:
  3304. 修改内容:
  3305. 修改原因:
  3306. ***************************************************************************/
  3307. int mmd_RenewMeaPub(void)
  3308. {
  3309. FreshMeaPub(lMeaVal,lMeaAng,lMeaCal);
  3310. mmd_RenewDataMenu(&g_tDataMenu1);
  3311. return M_OK;
  3312. }
  3313. /**************************************************************************
  3314. 函数名称:mmd_GetMeaPub
  3315. 函数版本:1.00
  3316. 作者:
  3317. 创建日期:2008.9.1
  3318. 函数功能说明:取得测量值的显示
  3319. 输入参数:
  3320. 输出参数:
  3321. 返回值:
  3322. 更新信息:
  3323. 更新日志1:
  3324. 日期:
  3325. 修改者:
  3326. 修改内容:
  3327. 修改原因:
  3328. ***************************************************************************/
  3329. int mmd_GetMeaPub(int value)
  3330. {
  3331. FreshMeaPub(lMeaVal,lMeaAng,lMeaCal);
  3332. mmd_initDataMenu(&g_tDataMenu1,PUB_AC_NUM_ALL,mmd_RenewMeaPub,mmd_GetMeaPubValue,15,1);
  3333. return M_OK;
  3334. }
  3335. static void mmd_GetMeaSwValue(int i,DATA_FIELD_DEF *pF)
  3336. {
  3337. char *pd=pF->FmtStr;
  3338. char tmpstr[24];
  3339. char meastr[24];
  3340. char meaCal[4];
  3341. //幅值
  3342. FUC_Get_LongValue_String(lMeaVal[i],tmpstr);
  3343. strcpy(meaCal," ");
  3344. if(lMeaCal[i])
  3345. {
  3346. strcpy(meaCal,"*");
  3347. }
  3348. if(g_sw_ac_desc[i].unit_angle == UNIT_ANG) //需要显示角度
  3349. {
  3350. sprintf(meastr,"%s%-4.4s=%-6.6s%s",meaCal,g_sw_ac_desc[i].name,tmpstr,g_unit[g_sw_ac_desc[i].unit].name); //幅值//sprintf(meastr,"%s%-6.6s=%-6.6s%s",meaCal,g_sw_ac_desc[i].name,tmpstr,g_unit[g_sw_ac_desc[i].unit].name); //幅值
  3351. }
  3352. else if(g_sw_ac_desc[i].unit == UNIT_GE) //整型值
  3353. {
  3354. sprintf(meastr,"%s%-s=%d %s",meaCal,g_sw_ac_desc[i].name,lMeaVal[i],g_unit[g_sw_ac_desc[i].unit].name); //幅值
  3355. }
  3356. else
  3357. {
  3358. sprintf(meastr,"%s%-s=%-6.6s%s",meaCal,g_sw_ac_desc[i].name,tmpstr,g_unit[g_sw_ac_desc[i].unit].name); //幅值
  3359. }
  3360. if(g_sw_ac_desc[i].unit_angle == UNIT_ANG) //需要显示角度
  3361. {
  3362. if(lMeaAng[i]!=ANGEL_INVALID)
  3363. {
  3364. // sprintf(tmpstr," %3d°",lMeaAng[i]/65536L);
  3365. mmd_angle_to_str(tmpstr,lMeaAng[i]);
  3366. }
  3367. else
  3368. {
  3369. strcpy(tmpstr," --- ");
  3370. }
  3371. strcat(meastr,tmpstr);
  3372. }
  3373. sprintf(pd,"%-20s",meastr);
  3374. }
  3375. int mmd_RenewMeaSw(void)
  3376. {
  3377. FreshMeaSw(lMeaVal,lMeaAng,lMeaCal,g_sw_index);
  3378. mmd_RenewDataMenu(&g_tDataMenu1);
  3379. return M_OK;
  3380. }
  3381. int mmd_GetMeaSw(int value)
  3382. {
  3383. g_sw_index=1;
  3384. FreshMeaSw(lMeaVal,lMeaAng,lMeaCal,g_sw_index);
  3385. mmd_initDataMenu(&g_tDataMenu1,SW_AC_NUM_ALL,mmd_RenewMeaSw,mmd_GetMeaSwValue,16,1);
  3386. return M_OK;
  3387. }
  3388. int mmd_ChangeSwMea(int key)
  3389. {
  3390. if(key==HA_KEY_ADD||key==HA_KEY_SUB) // 显示下一个开关
  3391. {
  3392. if(key==HA_KEY_ADD)
  3393. {
  3394. g_sw_index++;
  3395. if(g_sw_index>SWITCH_NUM_MAX)
  3396. {
  3397. g_sw_index=1;
  3398. }
  3399. }
  3400. else
  3401. {
  3402. if(g_sw_index>1)
  3403. {
  3404. g_sw_index--;
  3405. }
  3406. else
  3407. {
  3408. g_sw_index=SWITCH_NUM_MAX;
  3409. }
  3410. }
  3411. FreshMeaSw(lMeaVal,lMeaAng,lMeaCal,g_sw_index);
  3412. mmd_initDataMenu(&g_tDataMenu1,SW_AC_NUM_ALL,mmd_RenewMeaSw,mmd_GetMeaSwValue,16,1);
  3413. }
  3414. return M_OK;
  3415. }
  3416. /*下面是遥信值显示*/
  3417. struct M_List
  3418. {
  3419. WORD list[64];
  3420. WORD num;
  3421. WORD ftuswnum;
  3422. WORD m_current;
  3423. }m_list;
  3424. struct M_board
  3425. {
  3426. BYTE list[16];
  3427. int list_num[16];
  3428. BYTE num;
  3429. BYTE m_current;
  3430. }m_board;
  3431. extern struct di g_di[];
  3432. static void mmd_GetPubYxValue(int i,DATA_FIELD_DEF *pF)
  3433. {
  3434. char *pd=pF->FmtStr;
  3435. char tmpstr[4];
  3436. struct equ_config_di *ecd=&g_equ_config_di[g_sw_pub.di_cfg_index[m_list.list[i]]];
  3437. //if(g_di[ecd->slot].value&(1<<ecd->index))
  3438. if(dido_di_is_on(ecd->slot,ecd->index))
  3439. {
  3440. strcpy(tmpstr,YX_H);
  3441. }
  3442. else
  3443. {
  3444. strcpy(tmpstr,YX_F);
  3445. }
  3446. sprintf(pd,"%-16.16s %s",ecd->name,tmpstr);
  3447. }
  3448. int mmd_RenewPubYX(void)
  3449. {
  3450. mmd_RenewDataMenu(&g_tDataMenu1);
  3451. return M_OK;
  3452. }
  3453. /**************************************************************************
  3454. 函数名称:mmd_GetMeaPub
  3455. 函数版本:1.00
  3456. 作者:
  3457. 创建日期:2008.9.1
  3458. 函数功能说明:取得测量值的显示
  3459. 输入参数:
  3460. 输出参数:
  3461. 返回值:
  3462. 更新信息:
  3463. 更新日志1:
  3464. 日期:
  3465. 修改者:
  3466. 修改内容:
  3467. 修改原因:
  3468. ***************************************************************************/
  3469. int mmd_GetPubYX(int value)
  3470. {
  3471. int i;
  3472. memset(&m_list,0,sizeof(m_list));
  3473. for(i=0;i<PUB_DI_NUM;i++)
  3474. {
  3475. if((short)g_sw_pub.di_cfg_index[i]!=INDEX_INVALLID) //此遥信有配置
  3476. {
  3477. m_list.list[m_list.num]=i;
  3478. m_list.num++;
  3479. }
  3480. }
  3481. if(m_list.num==0)
  3482. {
  3483. strcpy(m_WarningStr,"无公用遥信配置");
  3484. return M_JUMP3;
  3485. }
  3486. m_list.m_current=0;
  3487. mmd_initDataMenu(&g_tDataMenu1,m_list.num,mmd_RenewPubYX,mmd_GetPubYxValue,17,1);
  3488. return M_JUMP0;
  3489. }
  3490. static void mmd_GetSwYxValue(int i,DATA_FIELD_DEF *pF)
  3491. {
  3492. char *pd=pF->FmtStr;
  3493. char tmpstr[4];
  3494. struct equ_config_di *ecd=&g_equ_config_di[g_sw[m_board.list[m_board.m_current]].di_cfg_index[m_list.list[i]]];
  3495. //if(g_di[ecd->slot].value&(1<<ecd->index))
  3496. if(dido_di_is_on(ecd->slot,ecd->index))
  3497. {
  3498. strcpy(tmpstr,YX_H);
  3499. }
  3500. else
  3501. {
  3502. strcpy(tmpstr,YX_F);
  3503. }
  3504. sprintf(pd,"%-16.16s %s",ecd->name,tmpstr);
  3505. }
  3506. int mmd_RenewSwYX(void)
  3507. {
  3508. mmd_RenewDataMenu(&g_tDataMenu1);
  3509. return M_OK;
  3510. }
  3511. int mmd_GetSwYX(int value)
  3512. {
  3513. int i,sw;
  3514. memset(&m_board,0,sizeof(m_board));
  3515. for(sw=0; sw<SWITCH_NUM_MAX; sw++)
  3516. {
  3517. int sum=0;
  3518. for(i=0;i<SW_DI_NUM;i++)
  3519. {
  3520. if((short)g_sw[sw].di_cfg_index[i]!=INDEX_INVALLID) //此遥信有配置
  3521. {
  3522. sum++;
  3523. }
  3524. }
  3525. if(sum)// 此开关配置有遥信
  3526. {
  3527. m_board.list[m_board.num]=sw;
  3528. m_board.list_num[m_board.num]=sum;
  3529. m_board.num++;
  3530. }
  3531. }
  3532. if(m_board.num==0)
  3533. {
  3534. strcpy(m_WarningStr,"线路无遥信配置");
  3535. return M_JUMP3;
  3536. }
  3537. m_board.m_current=0;
  3538. memset(&m_list,0,sizeof(m_list));
  3539. sw=m_board.list[m_board.m_current];
  3540. for(i=0;i<SW_DI_NUM;i++)
  3541. {
  3542. if((short)g_sw[sw].di_cfg_index[i]!=INDEX_INVALLID) //此遥信有配置
  3543. {
  3544. m_list.list[m_list.num]=i;
  3545. m_list.num++;
  3546. }
  3547. }
  3548. g_sw_index=sw+1;
  3549. mmd_initDataMenu(&g_tDataMenu1,m_list.num,mmd_RenewSwYX,mmd_GetSwYxValue,18,1);
  3550. return M_JUMP0;
  3551. }
  3552. int mmd_ChangeYxSw(int key)
  3553. {
  3554. int i,sw;
  3555. if(m_board.num==0)return M_OK;
  3556. if(key==HA_KEY_ADD||key==HA_KEY_SUB)
  3557. {
  3558. if(key==HA_KEY_ADD) // 显示下一个开关
  3559. {
  3560. m_board.m_current++;
  3561. if(m_board.m_current>=m_board.num)
  3562. {
  3563. m_board.m_current=0;
  3564. }
  3565. }
  3566. if(key==HA_KEY_SUB) // 显示上一个开关
  3567. {
  3568. if(m_board.m_current>0)
  3569. {
  3570. m_board.m_current--;
  3571. }
  3572. else
  3573. {
  3574. m_board.m_current=m_board.num-1;
  3575. }
  3576. }
  3577. memset(&m_list,0,sizeof(m_list));
  3578. sw=m_board.list[m_board.m_current];
  3579. for(i=0;i<SW_DI_NUM;i++)
  3580. {
  3581. if((short)g_sw[sw].di_cfg_index[i]!=INDEX_INVALLID) //此遥信有配置
  3582. {
  3583. m_list.list[m_list.num]=i;
  3584. m_list.num++;
  3585. }
  3586. }
  3587. g_sw_index=sw+1;
  3588. Add_Clear_Screen();
  3589. mmd_initDataMenu(&g_tDataMenu1,m_list.num,mmd_RenewSwYX,mmd_GetSwYxValue,18,1);
  3590. }
  3591. return M_OK;
  3592. }
  3593. static void mmd_GetBoardYXValue(int no,DATA_FIELD_DEF *pF)
  3594. {
  3595. char *pd=pF->FmtStr;
  3596. char tmpstr[8];
  3597. int i,di_no;
  3598. int num;
  3599. strcpy(pd,"");
  3600. di_no=no*10;
  3601. num=m_board.list_num[m_board.m_current];
  3602. for(i=0;i<10;i++)
  3603. {
  3604. if(di_no>=num) //超出有效遥信范围
  3605. {
  3606. strcpy(tmpstr," ");
  3607. }
  3608. else
  3609. {
  3610. // // TODO:if(g_di[g_sw_index].value&(1<<di_no))
  3611. if(dido_di_is_on(g_sw_index,di_no))
  3612. {
  3613. strcpy(tmpstr,"●");
  3614. }
  3615. else
  3616. {
  3617. strcpy(tmpstr,"○");
  3618. }
  3619. di_no++;
  3620. }
  3621. strcat(pd,tmpstr);
  3622. }
  3623. }
  3624. int mmd_RenewBoardYX(void)
  3625. {
  3626. mmd_RenewDataMenu(&g_tDataMenu1);
  3627. return M_OK;
  3628. }
  3629. int mmd_GetBoardYX(int value)
  3630. {
  3631. int i;
  3632. memset(&m_board,0,sizeof(m_board));
  3633. for(i=0; i<g_equ_config->equ_slot_num; i++)
  3634. {
  3635. int di_num = equ_get_di_num(i);
  3636. if(di_num>0)
  3637. {
  3638. m_board.list[m_board.num]=i;
  3639. m_board.list_num[m_board.num]=di_num;
  3640. m_board.num++;
  3641. }
  3642. }
  3643. if(m_board.num==0)
  3644. {
  3645. strcpy(m_WarningStr,"无遥信板卡配置");
  3646. return M_JUMP3;
  3647. }
  3648. m_board.m_current=0;
  3649. g_sw_index=m_board.list[m_board.m_current];
  3650. mmd_initDataMenu(&g_tDataMenu1,3,mmd_RenewBoardYX,mmd_GetBoardYXValue,19,1);
  3651. return M_JUMP0;
  3652. }
  3653. int mmd_ChangeYxBoard(int key)
  3654. {
  3655. if(m_board.num<=1)return M_OK;
  3656. if(key==((g_tScreen.lcd_type==LCD_TYPE_6KEY)?HA_KEY_LEFT:HA_KEY_ESC)) // 老版本按键6键,左键为取消键
  3657. {
  3658. return M_ERROR;
  3659. }
  3660. if(key==HA_KEY_ADD||key==HA_KEY_DOWN||key==HA_KEY_RIGHT) // 显示下一个开关
  3661. {
  3662. m_board.m_current++;
  3663. if(m_board.m_current>=m_board.num)
  3664. {
  3665. m_board.m_current=0;
  3666. }
  3667. }
  3668. if(key==HA_KEY_SUB||key==HA_KEY_UP||key==HA_KEY_LEFT) // 显示上一个开关
  3669. {
  3670. if(m_board.m_current>0)
  3671. {
  3672. m_board.m_current--;
  3673. }
  3674. else
  3675. {
  3676. m_board.m_current=m_board.num-1;
  3677. }
  3678. }
  3679. g_sw_index=m_board.list[m_board.m_current];
  3680. mmd_initDataMenu(&g_tDataMenu1,3,mmd_RenewBoardYX,mmd_GetBoardYXValue,19,1);
  3681. return M_OK;
  3682. }
  3683. /************下面是FTU遥测,遥信显示处理************************/
  3684. typedef struct MENU_MEA
  3685. {
  3686. u8 index[MEA_MENU_MAX];
  3687. u8 num;
  3688. }MENU_MEA;
  3689. MENU_MEA tMenuMea;
  3690. static void mmd_GetFtuMeaValue(int index,DATA_FIELD_DEF *pF)
  3691. {
  3692. char *pd=pF->FmtStr;
  3693. char tmpstr[24];
  3694. char meastr[24];
  3695. char meaCal[4];
  3696. u8 unit_angle ;
  3697. long lValue=0;
  3698. int i;
  3699. float pt;
  3700. if(tMenuMea.num==0) //没有额外显示配置文件
  3701. {
  3702. i=index;
  3703. }
  3704. else
  3705. {
  3706. i=tMenuMea.index[index];
  3707. }
  3708. lValue=lMeaVal[i];
  3709. if(pRunSet->bTT_ShowOne)
  3710. {
  3711. if(i<SW_AC_MENU_NUM)
  3712. {
  3713. switch(g_sw_ac_desc[i].unit)
  3714. {
  3715. case UNIT_A5:
  3716. case UNIT_BIA:
  3717. case UNIT_I0A:
  3718. if (strstr(g_sw_ac_desc[i].name,"I0"))//I0零序电流变比不一样
  3719. {
  3720. if(pRunSet->ct0_two)
  3721. lValue = _MulFac_S(lMeaVal[i],((DWORD)(pRunSet->ct0_one/pRunSet->ct0_two))<<16);
  3722. }
  3723. else
  3724. {
  3725. if(pRunSet->ct_two)
  3726. lValue = _MulFac_S(lMeaVal[i],((DWORD)(pRunSet->ct_one/pRunSet->ct_two))<<16);//((DWORD)(pRunSet->ct_one/pRunSet->ct_two));
  3727. }
  3728. break;
  3729. case UNIT_W:
  3730. case UNIT_Var:
  3731. case UNIT_kW:
  3732. case UNIT_kVar:
  3733. if(pRunSet->pt1_two)
  3734. lValue=(long)((float)lMeaVal[i]*(pRunSet->ct_one/pRunSet->ct_two*pRunSet->pt_rate/pRunSet->pt1_two));
  3735. break;
  3736. default:
  3737. break;
  3738. }
  3739. }
  3740. else
  3741. {
  3742. switch(g_pub_ac_desc[i-SW_AC_MENU_NUM].unit)
  3743. {
  3744. case UNIT_V100:
  3745. case UNIT_V220:
  3746. case UNIT_kV:
  3747. //判断PT变比电源侧&&母线侧&&零序电压
  3748. if (strstr(g_pub_ac_desc[i].name,"U0"))
  3749. pt = pRunSet->pt_3U0;
  3750. else if(strchr(g_pub_ac_desc[i-SW_AC_MENU_NUM].name,'2'))
  3751. pt = pRunSet->pt2_two;
  3752. else
  3753. pt = pRunSet->pt1_two;
  3754. if(pt)
  3755. lValue=(long)((float)lMeaVal[i]*(pRunSet->pt_rate/pt));
  3756. break;
  3757. default:
  3758. lValue=lMeaVal[i];
  3759. break;
  3760. }
  3761. }
  3762. }
  3763. else
  3764. {
  3765. lValue=lMeaVal[i];
  3766. }
  3767. //幅值
  3768. FUC_Get_LongValue_String(lValue,tmpstr);
  3769. meaCal[0]=0;
  3770. #ifndef DISP_MEA_CN
  3771. strcpy(meaCal," ");
  3772. if(lMeaCal[i])
  3773. {
  3774. strcpy(meaCal,"*");
  3775. }
  3776. #endif
  3777. if(i<SW_AC_MENU_NUM)
  3778. {
  3779. unit_angle=g_sw_ac_desc[i].unit_angle;
  3780. if(g_sw_ac_desc[i].unit == UNIT_GE) //整型值
  3781. {
  3782. sprintf(meastr,"%s%-s=%d %s",meaCal,g_sw_ac_desc[i].name,lValue,g_unit[g_sw_ac_desc[i].unit].name); //幅值
  3783. }
  3784. else
  3785. {
  3786. if(pRunSet->bTT_ShowOne)//单位显示
  3787. {
  3788. switch(g_sw_ac_desc[i].unit)
  3789. {
  3790. case UNIT_A5:
  3791. case UNIT_BIA:
  3792. case UNIT_I0A:
  3793. if(unit_angle == UNIT_ANG) //需要显示角度
  3794. {
  3795. #ifdef DISP_MEA_CN
  3796. sprintf(meastr,"%s%-6.6s=%-6.6sA",meaCal,g_sw_ac_desc[i].name,tmpstr); //幅值
  3797. #else
  3798. sprintf(meastr,"%s%-4.4s=%-6.6s A",meaCal,g_sw_ac_desc[i].name,tmpstr); //幅值
  3799. #endif
  3800. }
  3801. else
  3802. {
  3803. sprintf(meastr,"%s%-s=%-6.6sA",meaCal,g_sw_ac_desc[i].name,tmpstr);
  3804. }
  3805. break;
  3806. case UNIT_kW:
  3807. case UNIT_W:
  3808. #ifdef DISP_MEA_CN
  3809. sprintf(meastr,"%s%-s=%-7.7sKW",meaCal,g_sw_ac_desc[i].name,tmpstr);
  3810. #else
  3811. sprintf(meastr,"%s%-s=%-7.7s KW",meaCal,g_sw_ac_desc[i].name,tmpstr);
  3812. #endif
  3813. break;
  3814. case UNIT_kVar:
  3815. case UNIT_Var:
  3816. #ifdef DISP_MEA_CN
  3817. sprintf(meastr,"%s%-s=%-7.7sKVar",meaCal,g_sw_ac_desc[i].name,tmpstr);
  3818. #else
  3819. sprintf(meastr,"%s%-s=%-7.7s KVar",meaCal,g_sw_ac_desc[i].name,tmpstr);
  3820. #endif
  3821. break;
  3822. default:
  3823. #ifdef DISP_MEA_CN
  3824. sprintf(meastr,"%s%-s=%-6.6s%s",meaCal,g_sw_ac_desc[i].name,tmpstr,g_unit[g_sw_ac_desc[i].unit].name);
  3825. #else
  3826. sprintf(meastr,"%s%-s=%-6.6s%s ",meaCal,g_sw_ac_desc[i].name,tmpstr,g_unit[g_sw_ac_desc[i].unit].name);
  3827. #endif
  3828. break;
  3829. }
  3830. }
  3831. else
  3832. {
  3833. if(unit_angle == UNIT_ANG) //需要显示角度
  3834. {
  3835. #ifdef DISP_MEA_CN
  3836. sprintf(meastr,"%s%-7.7s=%-5.5s%s",meaCal,g_sw_ac_desc[i].name,tmpstr,g_unit[g_sw_ac_desc[i].unit].name); //幅值
  3837. #else
  3838. sprintf(meastr,"%s%-4.4s=%-6.6s%s",meaCal,g_sw_ac_desc[i].name,tmpstr,g_unit[g_sw_ac_desc[i].unit].name); //幅值
  3839. #endif
  3840. }
  3841. else
  3842. {
  3843. sprintf(meastr,"%s%-s=%-6.6s%s",meaCal,g_sw_ac_desc[i].name,tmpstr,g_unit[g_sw_ac_desc[i].unit].name);
  3844. }
  3845. }
  3846. }
  3847. }
  3848. else
  3849. {
  3850. unit_angle=g_pub_ac_desc[i-SW_AC_MENU_NUM].unit_angle;
  3851. if(pRunSet->bTT_ShowOne)//单位显示
  3852. {
  3853. switch(g_pub_ac_desc[i-SW_AC_MENU_NUM].unit)
  3854. {
  3855. case UNIT_V100:
  3856. case UNIT_V220:
  3857. case UNIT_kV:
  3858. #ifdef DISP_MEA_CN
  3859. sprintf(meastr,"%s%-7.7s=%-4.4sKV",meaCal,g_pub_ac_desc[i-SW_AC_MENU_NUM].name,tmpstr); //幅值
  3860. #else
  3861. sprintf(meastr,"%s%-4.4s=%-6.6sKV",meaCal,g_pub_ac_desc[i-SW_AC_MENU_NUM].name,tmpstr); //幅值
  3862. #endif
  3863. break;
  3864. default:
  3865. #ifdef DISP_MEA_CN
  3866. sprintf(meastr,"%s%-s=%-5.5s%s",meaCal,g_pub_ac_desc[i-SW_AC_MENU_NUM].name,tmpstr,g_unit[g_pub_ac_desc[i-SW_AC_MENU_NUM].unit].name); //幅值
  3867. #else
  3868. sprintf(meastr,"%s%-s=%-6.6s%s",meaCal,g_pub_ac_desc[i-SW_AC_MENU_NUM].name,tmpstr,g_unit[g_pub_ac_desc[i-SW_AC_MENU_NUM].unit].name); //幅值
  3869. #endif
  3870. break;
  3871. }
  3872. }
  3873. else if(unit_angle == UNIT_ANG) //需要显示角度
  3874. {
  3875. #ifdef DISP_MEA_CN
  3876. sprintf(meastr,"%s%-7.7s=%-5.5s%s",meaCal,g_pub_ac_desc[i-SW_AC_MENU_NUM].name,tmpstr,g_unit[g_pub_ac_desc[i-SW_AC_MENU_NUM].unit].name); //幅值
  3877. #else
  3878. sprintf(meastr,"%s%-4.4s=%-6.6s%s",meaCal,g_pub_ac_desc[i-SW_AC_MENU_NUM].name,tmpstr,g_unit[g_pub_ac_desc[i-SW_AC_MENU_NUM].unit].name); //幅值
  3879. #endif
  3880. }
  3881. else
  3882. sprintf(meastr,"%s%-s=%-6.6s%s",meaCal,g_pub_ac_desc[i-SW_AC_MENU_NUM].name,tmpstr,g_unit[g_pub_ac_desc[i-SW_AC_MENU_NUM].unit].name); //幅值
  3883. }
  3884. if(unit_angle) //需要显示角度
  3885. {
  3886. if(lMeaAng[i]!=ANGEL_INVALID)
  3887. {
  3888. mmd_angle_to_str(tmpstr,lMeaAng[i]);
  3889. }
  3890. else
  3891. {
  3892. strcpy(tmpstr," --- ");
  3893. }
  3894. #if LCD_SIZE==160
  3895. strcat(meastr,tmpstr);
  3896. #endif
  3897. }
  3898. #if LCD_SIZE==128
  3899. sprintf(pd,"%-16.16s",meastr);
  3900. #else
  3901. sprintf(pd,"%-20.20s",meastr);
  3902. #endif
  3903. }
  3904. int mmd_RenewFtuMea(void)
  3905. {
  3906. FreshMeaSw(lMeaVal,lMeaAng,lMeaCal,1);
  3907. FreshMeaPub(&lMeaVal[SW_AC_MENU_NUM],&lMeaAng[SW_AC_MENU_NUM],&lMeaCal[SW_AC_MENU_NUM]);
  3908. mmd_RenewDataMenu(&g_tDataMenu1);
  3909. return M_OK;
  3910. }
  3911. int mmd_GetFtuMea(int value)
  3912. {
  3913. int num;
  3914. num=(tMenuMea.num>0)?tMenuMea.num:MEA_MENU_MAX;
  3915. FreshMeaSw(lMeaVal,lMeaAng,lMeaCal,1);
  3916. FreshMeaPub(&lMeaVal[SW_AC_MENU_NUM],&lMeaAng[SW_AC_MENU_NUM],&lMeaCal[SW_AC_MENU_NUM]);
  3917. mmd_initDataMenu(&g_tDataMenu1,num,mmd_RenewFtuMea,mmd_GetFtuMeaValue,21,1);
  3918. return M_OK;
  3919. }
  3920. static void mmd_GetFtuYxValue(int i,DATA_FIELD_DEF *pF)
  3921. {
  3922. char *pd=pF->FmtStr;
  3923. char tmpstr[4];
  3924. struct equ_config_di *ecd;
  3925. if(i<m_list.ftuswnum)
  3926. {
  3927. ecd=&g_equ_config_di[g_sw[0].di_cfg_index[m_list.list[i]]];
  3928. }
  3929. else
  3930. {
  3931. ecd=&g_equ_config_di[g_sw_pub.di_cfg_index[m_list.list[i]]];
  3932. }
  3933. //if(g_di[ecd->slot].value&(1<<ecd->index))
  3934. if(dido_di_is_on(ecd->slot,ecd->index))
  3935. {
  3936. strcpy(tmpstr,YX_H);
  3937. }
  3938. else
  3939. {
  3940. strcpy(tmpstr,YX_F);
  3941. }
  3942. //关联压板处理
  3943. if(SW_DI_BSCH+1==ecd->type && ecd->owner!=0 && (!CHZ_ALL_EN(0)))//闭锁重合压板
  3944. strcpy(tmpstr,YX_H);
  3945. if((SW_DI_CHZ+1==ecd->type && ecd->owner!=0 && (!CHZ_ALL_EN(0)))||//重合闸投入压板
  3946. (SW_DI_BHZTT+1==ecd->type && ecd->owner!=0 && (!FUN_ALL_EN(0)))||//保护总投入压板
  3947. (ecd->owner!=0 && (!TQ_ALL_EN(0))))//同期压板
  3948. strcpy(tmpstr,YX_F);
  3949. #if defined BHFAGS_YB_YK || defined GD_AREA_ZHONGSHAN || defined GD_AREA_ECZD_2020
  3950. if((SW_DI_BHTT+1==ecd->type && ecd->owner!=0 && (!BH_ALL_EN(0)))||//常规保护压板
  3951. (SW_DI_FA_TT+1==ecd->type && ecd->owner!=0 && (!FA_ALL_EN(0)))||//FA压板
  3952. (SW_DI_FA_GOOSE+1==ecd->type && ecd->owner!=0 && (!BH_GOOSE_EN(0))))//智能分布式压板
  3953. strcpy(tmpstr,YX_F);
  3954. #endif
  3955. #ifdef GD_AREA_SHANTOU
  3956. if(SW_DI_TYTQ+1==ecd->type && ecd->owner!=0 && TYTQ_ALL_EN(0))//停用同期压板
  3957. strcpy(tmpstr,YX_H);
  3958. #endif
  3959. #ifdef GD_AREA_ECZD_2020
  3960. if(ecd->owner!=0 && TYTQ_ALL_EN(0))//停用同期压板
  3961. strcpy(tmpstr,YX_H);
  3962. if(ecd->owner!=0 && !JL_ALL_EN(0))//自动解列软压板
  3963. strcpy(tmpstr,YX_H);
  3964. if(SW_DI_BHZTT+1==ecd->type && ecd->owner!=0 && !FUN_ALL_EN(0))//停用保护功能总
  3965. strcpy(tmpstr,YX_H);
  3966. #endif
  3967. #ifdef GD_AREA_MAIN_2020 //广东标准2020 停用同期合闸功能软压板
  3968. if(ecd->owner!=0 && TYTQ_ALL_EN(0))//停用同期压板
  3969. strcpy(tmpstr,YX_H);
  3970. if(ecd->owner!=0 && !JL_ALL_EN(0))//自动解列软压板
  3971. strcpy(tmpstr,YX_H);
  3972. if(SW_DI_BHZTT+1==ecd->type && ecd->owner!=0 && !FUN_ALL_EN(0))//停用保护功能总
  3973. strcpy(tmpstr,YX_H);
  3974. #endif
  3975. #if LCD_SIZE==128
  3976. sprintf(pd,"%-13.13s %s",shield_str(ecd),tmpstr);
  3977. #else
  3978. sprintf(pd,"%-16.16s %s",shield_str(ecd),tmpstr);
  3979. #endif
  3980. }
  3981. int mmd_RenewFtuYX(void)
  3982. {
  3983. mmd_RenewDataMenu(&g_tDataMenu1);
  3984. return M_OK;
  3985. }
  3986. /**************************************************************************
  3987. 函数名称:mmd_GetMeaPub
  3988. 函数版本:1.00
  3989. 作者:
  3990. 创建日期:2008.9.1
  3991. 函数功能说明:取得测量值的显示
  3992. 输入参数:
  3993. 输出参数:
  3994. 返回值:
  3995. 更新信息:
  3996. 更新日志1:
  3997. 日期:
  3998. 修改者:
  3999. 修改内容:
  4000. 修改原因:
  4001. ***************************************************************************/
  4002. int mmd_GetFtuYX(int value)
  4003. {
  4004. int i;
  4005. memset(&m_list,0,sizeof(m_list));
  4006. for(i=0;i<SW_DI_NUM;i++)
  4007. {
  4008. if((short)g_sw[0].di_cfg_index[i]!=INDEX_INVALLID) //此遥信有配置
  4009. {
  4010. m_list.list[m_list.num]=i;
  4011. m_list.num++;
  4012. }
  4013. }
  4014. m_list.ftuswnum=m_list.num;
  4015. for(i=0;i<PUB_DI_NUM;i++)
  4016. {
  4017. if((short)g_sw_pub.di_cfg_index[i]!=INDEX_INVALLID) //此遥信有配置
  4018. {
  4019. m_list.list[m_list.num]=i;
  4020. m_list.num++;
  4021. }
  4022. }
  4023. if(m_list.num==0)
  4024. {
  4025. strcpy(m_WarningStr,"无遥信配置");
  4026. return M_JUMP3;
  4027. }
  4028. m_list.m_current=0;
  4029. mmd_initDataMenu(&g_tDataMenu1,m_list.num,mmd_RenewFtuYX,mmd_GetFtuYxValue,22,1);
  4030. return M_JUMP0;
  4031. }
  4032. static void mmd_GetGooseValue(int i,DATA_FIELD_DEF *pF)
  4033. {
  4034. char *pd=pF->FmtStr;
  4035. char tmpstr[16];
  4036. sprintf(tmpstr,"%d",tFAg.inval[i]);
  4037. sprintf(pd,"%-16.16s %s",g_goose_recv_tbl[i].name,tmpstr);
  4038. }
  4039. int mmd_RenewGoose(void)
  4040. {
  4041. mmd_RenewDataMenu(&g_tDataMenu1);
  4042. return M_OK;
  4043. }
  4044. int mmd_GetGoose(int value)
  4045. {
  4046. mmd_initDataMenu(&g_tDataMenu1,GOOSE_RECV_TBL_NUMBER,mmd_RenewGoose,mmd_GetGooseValue,23,1);
  4047. return M_JUMP0;
  4048. }
  4049. static void mmd_GetFaStatusValue(int i,DATA_FIELD_DEF *pF)
  4050. {
  4051. sprintf(pF->FmtStr,"%-20.20s",strGprsInf[i]);
  4052. }
  4053. void mmd_RefreshFAStatus(void)
  4054. {
  4055. int num=0;
  4056. sprintf(strGprsInf[num++],"电流型 : %s",m_Ledbh);
  4057. sprintf(strGprsInf[num++],"集中式 : %s",m_Ledjzs);
  4058. sprintf(strGprsInf[num++],"重合闸充电: %s",m_Bh_chr);
  4059. sprintf(strGprsInf[num++],"电压电流型: %s",m_Ledfa);
  4060. sprintf(strGprsInf[num++],"联络/分段 : %s",m_Fa_sl);
  4061. sprintf(strGprsInf[num++],"联络充电 : %s",m_Fa_chr);
  4062. sprintf(strGprsInf[num++],"智能分布式: %s",m_Ledgoose);
  4063. sprintf(strGprsInf[num++],"分布式充电: %s",m_Goose_chr);
  4064. g_gprs_info_num=num;
  4065. }
  4066. int mmd_RenewFAStatus(void)
  4067. {
  4068. mmd_RefreshFAStatus();
  4069. mmd_RenewDataMenu(&g_tDataMenu1);
  4070. return M_OK;
  4071. }
  4072. int mmd_GetFaStatus(int value)
  4073. {
  4074. mmd_RefreshFAStatus();
  4075. mmd_initDataMenu(&g_tDataMenu1,g_gprs_info_num,mmd_RenewFAStatus,mmd_GetFaStatusValue,8,1);
  4076. return M_OK;
  4077. }
  4078. /////////////////////////////////////////////////////////////////////////////////////////////////////
  4079. //GD_AREA_ECZD_2020
  4080. static void mmd_GetFunmodSetValue(int i,DATA_FIELD_DEF *pF)
  4081. {
  4082. sprintf(pF->FmtStr,"%-20.20s",strGprsInf[i]);
  4083. }
  4084. void mmd_RefreshFunmodSet(void)
  4085. {
  4086. int num=0;
  4087. #if (!defined (GD_AREA_ZHONGSHAN_2020)) && (!defined (GD_AREA_ECZD_2020))
  4088. mmd_RefreshFAStatus();
  4089. return;
  4090. #endif
  4091. #ifdef GD_AREA_ZHONGSHAN_2020
  4092. sprintf(strGprsInf[num++],"控制开入");
  4093. #else
  4094. sprintf(strGprsInf[num++],"控制字");
  4095. #endif
  4096. sprintf(strGprsInf[num++]," 保护/FA: %s",m_Mode_chr);
  4097. sprintf(strGprsInf[num++]," 同期合闸: %s",m_Tqhz_chr);
  4098. sprintf(strGprsInf[num++]," 自动解列: %s",m_Zdjl_chr);
  4099. sprintf(strGprsInf[num++]," 停用: %s",m_StopFun_chr);
  4100. sprintf(strGprsInf[num++],"软压板");
  4101. #ifdef GD_AREA_ZHONGSHAN_2020
  4102. sprintf(strGprsInf[num++]," 远方修改功能: %s",m_Yftr_chr);
  4103. #else
  4104. sprintf(strGprsInf[num++]," 远方投入: %s",m_Yftr_chr);
  4105. #endif
  4106. g_gprs_info_num=num;
  4107. }
  4108. int mmd_RenewFunmodSet(void)
  4109. {
  4110. mmd_RefreshFunmodSet();
  4111. mmd_RenewDataMenu(&g_tDataMenu1);
  4112. return M_OK;
  4113. }
  4114. int mmd_GetFunmodSet(int value)
  4115. {
  4116. mmd_RefreshFunmodSet();
  4117. mmd_initDataMenu(&g_tDataMenu1,g_gprs_info_num,mmd_RenewFunmodSet,mmd_GetFunmodSetValue,28,1);
  4118. return M_OK;
  4119. }
  4120. /////////////////////////////////////////////////////////////////////////////////////////////////////
  4121. int mmd_GetFtuIfo(int value)
  4122. {
  4123. return M_OK;
  4124. }
  4125. int mmd_TestDiDo(int value)
  4126. {
  4127. return M_OK;
  4128. }
  4129. /**************************************************************************
  4130. 函数名称:mmd_GetSectionInf
  4131. 函数版本:1.00
  4132. 作者:
  4133. 创建日期:2008.10.21
  4134. 函数功能说明:获取有效定值区
  4135. 输入参数:
  4136. 输出参数:
  4137. 返回值:
  4138. 更新信息:
  4139. 更新日志1:
  4140. 日期:
  4141. 修改者: sunxi
  4142. 修改内容:
  4143. 修改原因:
  4144. ***************************************************************************/
  4145. int mmd_GetSectionInf(int value)
  4146. {
  4147. int i,j;
  4148. DATA_MENU_DEF *pt=&g_tDataMenu1;
  4149. char *pd;
  4150. char tmpstr[4];
  4151. pd=g_tDataMenu1.tDataFields[0].FmtStr;
  4152. strcpy(pd,"有效定值区: ");
  4153. for(i=0,j=0;i<SEC_NUMBER;i++)
  4154. {
  4155. if(tSecInfo.szSections[i]==0x55)
  4156. {
  4157. sprintf(tmpstr,"%02u ",i);
  4158. strcat(pd,tmpstr);
  4159. if(strlen(pd)>=15)
  4160. {
  4161. j++;
  4162. pd=g_tDataMenu1.tDataFields[j].FmtStr;
  4163. strcpy(pd," ");
  4164. }
  4165. }
  4166. }
  4167. if(strlen(pd)>0)j++;
  4168. pt->sFocusIndex=0; //第一个显示的动态菜单的索引
  4169. pt->sTotalNum=j; // 将菜单总数置于小于菜单数,保证不清屏
  4170. pt->GetPrevFuncAddr=NULL; //44
  4171. pt->GetNextFuncAddr=NULL; //44
  4172. return M_JUMP0;
  4173. }
  4174. /*系统时间显示*/
  4175. TIME_SHOW m_ShowTime;
  4176. TIME_SHOW m_SetTime;
  4177. int mmd_GetSetTime(int value)
  4178. {
  4179. struct timespec ts;
  4180. struct rtc_time_t rtc;
  4181. clk_time_get(&ts);
  4182. timespec_to_rtc(ts,&rtc,1);
  4183. m_SetTime.year=rtc.year;
  4184. m_SetTime.month=rtc.month;
  4185. m_SetTime.day=rtc.day;
  4186. m_SetTime.hour=rtc.hour;
  4187. m_SetTime.min=rtc.min;
  4188. m_SetTime.sec=rtc.ms/1000;
  4189. return M_OK;
  4190. }
  4191. /**************************************************************************
  4192. 函数名称:mmd_SetTime
  4193. 函数版本:1.00
  4194. 作者:
  4195. 创建日期:2008.10.21
  4196. 函数功能说明:校验并设置系统时间
  4197. 输入参数:
  4198. 输出参数:
  4199. 返回值:
  4200. 更新信息:
  4201. 更新日志1:
  4202. 日期:
  4203. 修改者: sunxi
  4204. 修改内容:
  4205. 修改原因:
  4206. ***************************************************************************/
  4207. int mmd_SetTime(int value)
  4208. {
  4209. TIME mt;
  4210. if(m_SetTime.year>99)
  4211. {
  4212. strcpy(m_WarningStr,"年设置错误");
  4213. return M_JUMP3;
  4214. }
  4215. if(m_SetTime.month>12||m_SetTime.month<1)
  4216. {
  4217. strcpy(m_WarningStr,"月设置错误");
  4218. return M_JUMP3;
  4219. }
  4220. if(m_SetTime.day>31||m_SetTime.day<1)
  4221. {
  4222. strcpy(m_WarningStr,"日设置错误");
  4223. return M_JUMP3;
  4224. }
  4225. if(m_SetTime.hour>23)
  4226. {
  4227. strcpy(m_WarningStr,"时设置错误");
  4228. return M_JUMP3;
  4229. }
  4230. if(m_SetTime.min>59)
  4231. {
  4232. strcpy(m_WarningStr,"分设置错误");
  4233. return M_JUMP3;
  4234. }
  4235. if(m_SetTime.sec>59)
  4236. {
  4237. strcpy(m_WarningStr,"秒设置错误");
  4238. return M_JUMP3;
  4239. }
  4240. if(m_SetTime.month==2) // 2月特殊处理
  4241. {
  4242. WORD year=m_SetTime.year+2000;
  4243. if(year%4==0) //闰年
  4244. {
  4245. if(m_SetTime.day>29)
  4246. {
  4247. strcpy(m_WarningStr,"日设置错误");
  4248. return M_JUMP3;
  4249. }
  4250. }
  4251. else
  4252. {
  4253. if(m_SetTime.day>28)
  4254. {
  4255. strcpy(m_WarningStr,"日设置错误");
  4256. return M_JUMP3;
  4257. }
  4258. }
  4259. }
  4260. mt.year=m_SetTime.year;
  4261. mt.month=m_SetTime.month;
  4262. mt.day=m_SetTime.day;
  4263. mt.hour=m_SetTime.hour;
  4264. mt.min=m_SetTime.min;
  4265. mt.ms=(WORD)m_SetTime.sec*1000;
  4266. if(sys_time_set(&mt) == 0)
  4267. {
  4268. strcpy(m_WarningStr,"时间设置成功");
  4269. }
  4270. else
  4271. {
  4272. strcpy(m_WarningStr,"读RTC失败");
  4273. }
  4274. return M_JUMP3;
  4275. }
  4276. /**************************************************************************
  4277. 函数名称:mmd_ChangeSection
  4278. 函数版本:1.00
  4279. 作者:
  4280. 创建日期:2008.9.1
  4281. 函数功能说明:切换定值区
  4282. 输入参数:
  4283. 输出参数:
  4284. 返回值:
  4285. 更新信息:
  4286. 更新日志1:
  4287. 日期:
  4288. 修改者:
  4289. 修改内容:
  4290. 修改原因:
  4291. ***************************************************************************/
  4292. #if 0
  4293. static int mmd_ChangeSection(int value)
  4294. {
  4295. bool ret=false;
  4296. UINT section=m_ValidSection;
  4297. TSECTIONINFO tSec;
  4298. if((short)section>=0&&section<SEC_NUMBER)
  4299. {
  4300. MakeRunSet(false); // 将当前运行定值区转换为运行定值区
  4301. tSec=tSecInfo;
  4302. tSec.sCurSec=section;
  4303. if(SaveSection(&tSec))
  4304. {
  4305. soe_record_opt(EV_SECQH_OK,section);
  4306. tSecInfo=tSec;
  4307. ret=true;
  4308. rt_err_clr(ERR_CODE_SET);
  4309. }
  4310. }
  4311. if(ret)
  4312. {
  4313. strcpy(m_WarningStr,"定值区切换成功");
  4314. }
  4315. else
  4316. {
  4317. strcpy(m_WarningStr,"定值区切换失败");
  4318. soe_record_opt(EV_SECQH_FAIL,section);
  4319. }
  4320. return M_JUMP3;
  4321. }
  4322. #endif
  4323. /**************************************************************************
  4324. 函数名称:mmd_ClearSOE
  4325. 函数版本:1.00
  4326. 作者:
  4327. 创建日期:2008.9.1
  4328. 函数功能说明:清除事件库
  4329. 输入参数:
  4330. 输出参数:
  4331. 返回值:
  4332. 更新信息:
  4333. 更新日志1:
  4334. 日期:
  4335. 修改者:
  4336. 修改内容:
  4337. 修改原因:
  4338. ***************************************************************************/
  4339. int mmd_ClearSOE(int value) /*清除事件库 */
  4340. {
  4341. soe_clear_ev(); // 清事件记录
  4342. soe_record_opt(EV_CLEAR_SOE,0);
  4343. strcpy(m_WarningStr,"事件库清除完毕");
  4344. return M_JUMP3;
  4345. }
  4346. /**************************************************************************
  4347. 函数名称:mmd_ClearOperateSOE
  4348. 函数版本:1.00
  4349. 作者:
  4350. 创建日期:2008.9.1
  4351. 函数功能说明:清除操作记录
  4352. 输入参数:
  4353. 输出参数:
  4354. 返回值:
  4355. 更新信息:
  4356. 更新日志1:
  4357. 日期:
  4358. 修改者:
  4359. 修改内容:
  4360. 修改原因:
  4361. ***************************************************************************/
  4362. int mmd_ClearOperateSOE(int value) /*清除操作记录 */
  4363. {
  4364. soe_clear_opt();
  4365. soe_record_opt(EV_CLEAR_OPE,0);
  4366. strcpy(m_WarningStr,"操作记录清除完毕");
  4367. return M_JUMP3;
  4368. }
  4369. /**************************************************************************
  4370. 函数名称:mmd_SavePassWord
  4371. 函数版本:1.00
  4372. 作者:
  4373. 创建日期:2008.9.1
  4374. 函数功能说明:保存密码
  4375. 输入参数:
  4376. 输出参数:
  4377. 返回值:
  4378. 更新信息:
  4379. 更新日志1:
  4380. 日期:
  4381. 修改者:
  4382. 修改内容:
  4383. 修改原因:
  4384. ***************************************************************************/
  4385. int mmd_SavePassWord(int value)
  4386. {
  4387. int i;
  4388. BYTE charnum=0;
  4389. for(i=0;i<PASSWORD_LEN;i++)
  4390. {
  4391. if(m_strPassword[i]>='0'&&m_strPassword[i]<='9') //数字
  4392. {
  4393. charnum|=(0<<i);
  4394. }
  4395. if(m_strPassword[i]>='A'&&m_strPassword[i]<='Z') //数字
  4396. {
  4397. charnum|=(1<<i);
  4398. }
  4399. }
  4400. #ifndef PASSWORD_4_STR
  4401. if(charnum==0||charnum==0xFF)
  4402. {
  4403. m_NewPassword=0;
  4404. m_Password=0;
  4405. mmi_zero_passwordstr();
  4406. strcpy(m_WarningStr,"输入一级密码非法");
  4407. return M_JUMP3;
  4408. }
  4409. #endif
  4410. charnum=0;
  4411. for(i=0;i<PASSWORD_LEN;i++)
  4412. {
  4413. if(m_strPassword2[i]>='0'&&m_strPassword2[i]<='9') //数字
  4414. {
  4415. charnum|=(0<<i);
  4416. }
  4417. if(m_strPassword2[i]>='A'&&m_strPassword2[i]<='Z') //数字
  4418. {
  4419. charnum|=(1<<i);
  4420. }
  4421. }
  4422. #ifndef PASSWORD_4_STR
  4423. if(charnum==0||charnum==0xFF)
  4424. {
  4425. m_NewPassword=0;
  4426. m_Password=0;
  4427. mmi_zero_passwordstr();
  4428. strcpy(m_WarningStr,"输入二级密码非法");
  4429. return M_JUMP3;
  4430. }
  4431. #endif
  4432. SavePassword(m_strPassword);
  4433. SavePassword2(m_strPassword2);
  4434. tRunPara.wPassword= ReadPassword();
  4435. strcpy(m_WarningStr,"密码修改成功");
  4436. m_Password=0;
  4437. m_NewPassword=0;
  4438. mmi_zero_passwordstr();
  4439. return M_JUMP3;
  4440. }
  4441. /*************开出测试************************/
  4442. static void mmd_GetBoardDoValue(int no,DATA_FIELD_DEF *pF)
  4443. {
  4444. //sprintf(pF->FmtStr,"%-15.15s",g_equ_config_do[no].name);
  4445. sprintf(pF->FmtStr,"%-20.20s",g_equ_config_do[no].name);
  4446. }
  4447. int mmd_RenewBoardDo(void)
  4448. {
  4449. mmd_RenewDataMenu(&g_tDataMenu1);
  4450. return M_OK;
  4451. }
  4452. int mmd_GetBoardDO(int value)
  4453. {
  4454. int i;
  4455. memset(&m_board,0,sizeof(m_board));
  4456. for(i=0; i<g_equ_config->equ_slot_num; i++)
  4457. {
  4458. int do_num = equ_get_do_num(i);
  4459. if(do_num>0)
  4460. {
  4461. m_board.list[m_board.num]=i;
  4462. m_board.list_num[m_board.num]=do_num;
  4463. m_board.num++;
  4464. }
  4465. }
  4466. if(m_board.num==0)
  4467. {
  4468. strcpy(m_WarningStr,"无开出板卡配置");
  4469. return M_JUMP3;
  4470. }
  4471. m_board.m_current=0;
  4472. g_sw_index=m_board.list[m_board.m_current];
  4473. mmd_initDataMenu(&g_tDataMenu1,m_board.list_num[m_board.m_current],mmd_RenewBoardDo,mmd_GetBoardDoValue,112,1);
  4474. return M_JUMP0;
  4475. }
  4476. int mmd_ChangeDoBoard(int key)
  4477. {
  4478. if(m_board.num==0)return M_OK;
  4479. if(key==HA_KEY_ADD) // 显示下一个开关
  4480. {
  4481. m_board.m_current++;
  4482. if(m_board.m_current>=m_board.num)
  4483. {
  4484. m_board.m_current=0;
  4485. }
  4486. g_sw_index=m_board.list[m_board.m_current];
  4487. mmd_initDataMenu(&g_tDataMenu1,m_board.list_num[m_board.m_current],mmd_RenewBoardDo,mmd_GetBoardDoValue,112,1);
  4488. return M_JUMP0;
  4489. }
  4490. if(key==HA_KEY_SUB) // 显示上一个开关
  4491. {
  4492. if(m_board.m_current>0)
  4493. {
  4494. m_board.m_current--;
  4495. }
  4496. else
  4497. {
  4498. m_board.m_current=m_board.num-1;
  4499. }
  4500. g_sw_index=m_board.list[m_board.m_current];
  4501. mmd_initDataMenu(&g_tDataMenu1,m_board.list_num[m_board.m_current],mmd_RenewBoardDo,mmd_GetBoardDoValue,112,1);
  4502. return M_JUMP0;
  4503. }
  4504. return M_OK;
  4505. }
  4506. /**************************************************************************
  4507. 函数名称:mmd_TestHz
  4508. 函数版本:1.00
  4509. 作者:
  4510. 创建日期:2008.9.23
  4511. 函数功能说明: 进行测试开出
  4512. 输入参数:
  4513. 输出参数:
  4514. 返回值:
  4515. 更新信息:
  4516. 更新日志1:
  4517. 日期:
  4518. 修改者:
  4519. 修改内容:
  4520. 修改原因:
  4521. ***************************************************************************/
  4522. int mmd_TestHz(int value)
  4523. {
  4524. sprintf(m_WarningStr,"开出测试完毕");
  4525. dido_do(m_board.list[m_board.m_current],(1<<value),1);
  4526. return M_JUMP3;
  4527. }
  4528. WORD g_RmtIndex;
  4529. static void mmd_GooseKcValue(int no,DATA_FIELD_DEF *pF)
  4530. {
  4531. sprintf(pF->FmtStr,"%s",g_goose_send_tbl[no].name);
  4532. }
  4533. int mmd_RenewGooseKc(void)
  4534. {
  4535. mmd_RenewDataMenu(&g_tDataMenu1);
  4536. return M_OK;
  4537. }
  4538. int mmd_GetGooseKc(int value)
  4539. {
  4540. mmd_initDataMenu(&g_tDataMenu1,GOOSE_SEND_TBL_NUMBER,mmd_RenewGooseKc,mmd_GooseKcValue,114,1);
  4541. return M_OK;
  4542. }
  4543. int mmd_GooseKcTest(int value)
  4544. {
  4545. if(g_RmtIndex==0)
  4546. {
  4547. tFAg.ug.bFlag.bTstgz=value;
  4548. }
  4549. else if(g_RmtIndex==1)
  4550. {
  4551. tFAg.ug.bFlag.bTstglok=value;
  4552. }
  4553. else if(g_RmtIndex==2)
  4554. {
  4555. tFAg.ug.bFlag.bTstjt=value;
  4556. }
  4557. else if(g_RmtIndex==3)
  4558. {
  4559. tFAg.ug.bFlag.bTstglbs=value;
  4560. }
  4561. else if(g_RmtIndex==4)
  4562. {
  4563. tFAg.ug.bFlag.bTstcomerr=value;
  4564. }
  4565. return M_OK;
  4566. }
  4567. /******主循环界面******/
  4568. /**************************************************************************
  4569. 函数名称:mmd_RenewMain
  4570. 函数版本:1.00
  4571. 作者:
  4572. 创建日期:2008.10.8
  4573. 函数功能说明:刷新主循环界面
  4574. 输入参数:
  4575. 输出参数:
  4576. 返回值:
  4577. 更新信息:
  4578. 更新日志1:
  4579. 日期:
  4580. 修改者:
  4581. 修改内容:
  4582. 修改原因:
  4583. ***************************************************************************/
  4584. DWORD m_MainNoTime; // 主循环界面时间
  4585. int mmd_RenewMain(void)
  4586. {
  4587. if((dTCounter-m_MainNoTime)>8*SAM_FREQUENCY) // 8秒钟界面翻一屏
  4588. {
  4589. DATA_MENU_DEF *pt=&g_tDataMenu1;
  4590. if(pt->sTotalNum<=pt->sScreenNum)return M_OK;
  4591. if((pt->sFocusIndex/pt->sScreenNum)*pt->sScreenNum+pt->sScreenNum>=pt->sTotalNum)
  4592. {
  4593. pt->sFocusIndex=0;
  4594. }
  4595. else
  4596. {
  4597. pt->sFocusIndex=(pt->sFocusIndex/pt->sScreenNum)*pt->sScreenNum+pt->sScreenNum;
  4598. }
  4599. Add_Clear_Screen();
  4600. m_MainNoTime=dTCounter;
  4601. }
  4602. mmd_RenewDataMenu(&g_tDataMenu1);
  4603. return M_OK;
  4604. }
  4605. /**************************************************************************
  4606. 函数名称:mmd_KeyMain
  4607. 函数版本:1.00
  4608. 作者:
  4609. 创建日期:2008.10.8
  4610. 函数功能说明:判断是否有按键,有按键,将主循环界面时间清为当前值
  4611. 输入参数:
  4612. 输出参数:
  4613. 返回值:
  4614. 更新信息:
  4615. 更新日志1:
  4616. 日期:
  4617. 修改者:
  4618. 修改内容:
  4619. 修改原因:
  4620. ***************************************************************************/
  4621. int mmd_KeyMain(int key)
  4622. {
  4623. m_MainNoTime=dTCounter;
  4624. return M_OK;
  4625. }
  4626. /**************************************************************************
  4627. 函数名称:mmd_EnterMainMenu
  4628. 函数版本:1.00
  4629. 作者:
  4630. 创建日期:2008.10.8
  4631. 函数功能说明:进入主循环界面,并初始化测量值的显示
  4632. 输入参数:
  4633. 输出参数:
  4634. 返回值:
  4635. 更新信息:
  4636. 更新日志1:
  4637. 日期:
  4638. 修改者:
  4639. 修改内容:
  4640. 修改原因:
  4641. ***************************************************************************/
  4642. int mmd_EnterMainMenu(int key)
  4643. {
  4644. if(key==HA_KEY_ENTER)
  4645. {
  4646. #if 0
  4647. #if SWITCH_NUM_MAX==1
  4648. #ifdef GD_AREA_ECZD_2020
  4649. return M_JUMP3;
  4650. #else
  4651. return M_JUMP2;
  4652. #endif
  4653. #else
  4654. return M_JUMP2;
  4655. #endif
  4656. #else
  4657. return M_JUMP3; //全部显示功能模块配置 jack.liu 20201105
  4658. #endif
  4659. }
  4660. if(key==((g_tScreen.lcd_type==LCD_TYPE_6KEY)?HA_KEY_LEFT:HA_KEY_ESC)) // 老版本按键6键,左键为取消键
  4661. {
  4662. #if SWITCH_NUM_MAX==1
  4663. mmd_GetFtuMea(0);
  4664. #endif
  4665. if(g_tLcdComm.tImage.pBuf==NULL)
  4666. {
  4667. return M_JUMP0;
  4668. }
  4669. else
  4670. {
  4671. return M_JUMP1;
  4672. }
  4673. }
  4674. return M_ERROR;
  4675. }
  4676. int mmd_BoardLedTest(int value)
  4677. {
  4678. if(value==1) // 辅助板
  4679. {
  4680. g_led_aux_test_st=(g_led_aux_test_st>0)?0:1;
  4681. g_led_kz_test_st=0;
  4682. }
  4683. else if(value==2) //状态板
  4684. {
  4685. g_led_kz_test_st=(g_led_kz_test_st>0)?0:1;
  4686. g_led_aux_test_st=0;
  4687. }
  4688. else if(value==0) //液晶板
  4689. {
  4690. add_led_test(TEST_LCD);
  4691. g_led_aux_test_st=0;
  4692. g_led_kz_test_st=0;
  4693. }
  4694. return M_OK;
  4695. }
  4696. /*内部定值处理*/
  4697. /**************************************************************************
  4698. 函数名称:mmd_RenewCstSet
  4699. 函数版本:1.00
  4700. 作者:
  4701. 创建日期:2008.9.1
  4702. 函数功能说明:更新内部定值显示
  4703. 输入参数:
  4704. 输出参数:
  4705. 返回值:
  4706. 更新信息:
  4707. 更新日志1:
  4708. 日期:
  4709. 修改者:
  4710. 修改内容:
  4711. 修改原因:
  4712. ***************************************************************************/
  4713. int mmd_RenewCstSet(void)
  4714. {
  4715. DATA_MENU_DEF *pt=&g_tDataMenu1;
  4716. DATA_MENU_DEF *pext=&g_tExtraMenu;
  4717. int i;
  4718. int bgn;
  4719. bgn=g_set_disp.bgn[pt->sFocusIndex];
  4720. pext->sTotalNum=0; //总的动态菜单数
  4721. for(i=0;i<g_set_disp.screennum[pt->sFocusIndex];i++)
  4722. {
  4723. mmd_GetSet(bgn+i,&g_tDataMenu1.tDataFields[i],&tCstSetTable[0],m_SetBuf);
  4724. }
  4725. pt->sScreenNum=g_set_disp.screennum[pt->sFocusIndex];
  4726. pext->sFocusIndex=0; //第一个显示的动态菜单的索引
  4727. pext->sScreenNum=pext->sTotalNum;
  4728. return M_OK;
  4729. }
  4730. int mmd_RenewCstSetGroup(void)
  4731. {
  4732. mmd_RenewDataMenu(&g_tDataMenu2);
  4733. return M_OK;
  4734. }
  4735. int mmd_backCstSet(int value)
  4736. {
  4737. mmd_InitCstSetGroup(-1);
  4738. g_tDataMenu2.sFocusIndex=SetGroupIndex;
  4739. mmi_FormsInit(182,1); // 更新最后修改的数据
  4740. mmd_RenewCstSetGroup();
  4741. return M_OK;
  4742. }
  4743. int mmd_InitCstSetGroup(int value)
  4744. {
  4745. int i,num=0;
  4746. bool bret;
  4747. bret=ReadEppData(EEP_SETGROUP_ADDR,m_setgroup,GROUP_NUM);
  4748. if(!bret)
  4749. {
  4750. GetDefSetGroup(m_setgroup);
  4751. }
  4752. for(i=0;i<GROUP_NUM;i++)
  4753. {
  4754. if(SetGroups[i].group == SETGROUP_TYPE_CSTSET&&(m_setgroup[i]>0))
  4755. {
  4756. int j;
  4757. for(j=0;j<CSTSET_NUMBER;j++)
  4758. {
  4759. if(tCstSetTable[j].group==i)
  4760. {
  4761. set_show_group[num++]=i;
  4762. break;
  4763. }
  4764. }
  4765. }
  4766. }
  4767. if(num==0)
  4768. {
  4769. strcpy(m_WarningStr,"内部定值未配置");
  4770. return M_JUMP2;
  4771. }
  4772. mmd_initDataMenu(&g_tDataMenu2,num,mmd_RenewCstSetGroup,mmd_GetSetGroupName,182,1);
  4773. if(!ReadPara((void*)m_SetBuf,EEP_CSTSET_ADDR,CSTSET_NUMBER,&tCstSetTable[0]))
  4774. {
  4775. if(value==-1)
  4776. {
  4777. GetDefPara((float*)m_SetBuf,CSTSET_NUMBER,&tCstSetTable[0]);
  4778. }
  4779. else
  4780. {
  4781. return M_JUMP3;
  4782. }
  4783. }
  4784. mmd_ChangeSet(&tCstSetTable[0],CSTSET_NUMBER,m_SetBuf);
  4785. return M_JUMP0;
  4786. }
  4787. int mmd_SaveCstSet(int value)
  4788. {
  4789. mmd_ReChangeSet(&tCstSetTable[0],CSTSET_NUMBER,m_SetBuf);
  4790. if(!mmd_CheckSet(&tCstSetTable[0],CSTSET_NUMBER,m_SetBuf))
  4791. {
  4792. mmd_ChangeSet(&tCstSetTable[0],CSTSET_NUMBER,m_SetBuf);
  4793. return M_JUMP3;
  4794. }
  4795. if(SavePara((void *)m_SetBuf,EEP_CSTSET_ADDR,CSTSET_NUMBER,&tCstSetTable[0]))
  4796. {
  4797. strcpy(m_WarningStr,"定值保存成功");
  4798. soe_record_opt(EV_CSTSET_OK,0); // 内部定值整定成功
  4799. MakeRunSet(false); // 将当前运行定值区转换为运行定值区
  4800. rt_err_clr(ERR_CODE_SET_IN,0);
  4801. }
  4802. else
  4803. {
  4804. strcpy(m_WarningStr,"定值保存失败");
  4805. soe_record_opt(EV_CSTSET_FAIL,0); // 内部定值整定成功
  4806. }
  4807. return M_JUMP0;
  4808. }
  4809. /**************************************************************************
  4810. 函数名称:mmd_InitSetSolid
  4811. 函数版本:1.00
  4812. 作者:
  4813. 创建日期:2008.9.1
  4814. 函数功能说明:初始化定值整定的显示
  4815. 输入参数:
  4816. 输出参数:
  4817. 返回值:
  4818. 更新信息:
  4819. 更新日志1:
  4820. 日期:
  4821. 修改者:
  4822. 修改内容:
  4823. 修改原因:
  4824. ***************************************************************************/
  4825. int mmd_InitCstSet(int value)
  4826. {
  4827. int num=CSTSET_NUMBER;
  4828. int screennum;
  4829. int i;
  4830. m_AllSection=0;
  4831. g_set_disp.num=0;
  4832. num=mmd_GetshowSetNum(&tCstSetTable[0],CSTSET_NUMBER,set_show_group[value]);
  4833. SetGroupIndex=value;
  4834. screennum=mmi_GetScreenNum(183,1); // 取当前屏幕最大显示数目
  4835. bSetChange=true;
  4836. mmd_analyse(&tCstSetTable[0],screennum);
  4837. {
  4838. DATA_MENU_DEF *pt=&g_tDataMenu1;
  4839. DATA_MENU_DEF *pext=&g_tExtraMenu;
  4840. pext->sTotalNum=0;
  4841. for(i=0;i<g_set_disp.screennum[0];i++)
  4842. {
  4843. mmd_GetSet(i,&g_tDataMenu1.tDataFields[i],&tCstSetTable[0],m_SetBuf);
  4844. }
  4845. m_ScreenNum=num;
  4846. pt->sFocusIndex=0; //第一个显示的动态菜单的索引
  4847. pt->sTotalNum=num; //总的动态菜单数
  4848. pt->sScreenNum=g_set_disp.screennum[0];
  4849. pt->GetPrevFuncAddr=mmd_RenewCstSet; //44
  4850. pt->GetNextFuncAddr=mmd_RenewCstSet; //44
  4851. pext->sFocusIndex=0; //第一个显示的动态菜单的索引
  4852. pext->sScreenNum=pext->sTotalNum;
  4853. pext->GetPrevFuncAddr=NULL; //44
  4854. pext->GetNextFuncAddr=NULL; //44
  4855. m_CurrentScreen=1;
  4856. }
  4857. return M_JUMP0;
  4858. }
  4859. /**************************************************************************
  4860. 函数名称:mmd_SetKey
  4861. 函数版本:1.00
  4862. 作者:
  4863. 创建日期:2008.9.1
  4864. 函数功能说明:列表项选择
  4865. 输入参数:
  4866. 输出参数:
  4867. 返回值:
  4868. 更新信息:
  4869. 更新日志1:
  4870. 日期:
  4871. 修改者:
  4872. 修改内容:
  4873. 修改原因:
  4874. ***************************************************************************/
  4875. int mmd_SetCstKey(int key)
  4876. {
  4877. if(key==HA_KEY_UP&&g_tScreen.lcd_type!=LCD_TYPE_160_KEY9)key=HA_KEY_ADD;
  4878. if(key==HA_KEY_DOWN&&g_tScreen.lcd_type!=LCD_TYPE_160_KEY9)key=HA_KEY_SUB;
  4879. if(key==HA_KEY_ADD||key==HA_KEY_SUB) // +键增加列表
  4880. {
  4881. if(!g_bModify) return M_ERROR; // 只在修改状态下执行此函数
  4882. if(mmd_ChangeList(&tCstSetTable[0],key,m_SetBuf))
  4883. {
  4884. mmd_RenewCstSet(); //刷新修改后的值
  4885. return M_OK;
  4886. }
  4887. }
  4888. return M_ERROR;
  4889. }
  4890. /*下面是精度自校及手校处理*/
  4891. /**************************************************************************
  4892. 函数名称:mmd_SaveAdjustValue
  4893. 函数版本:1.00
  4894. 作者:
  4895. 创建日期:2008.9.1
  4896. 函数功能说明:保存精度手校系数
  4897. 输入参数:
  4898. 输出参数:
  4899. 返回值:
  4900. 更新信息:
  4901. 更新日志1:
  4902. 日期:
  4903. 修改者:
  4904. 修改内容:
  4905. 修改原因:
  4906. ***************************************************************************/
  4907. int mmd_SaveAdjustValue(int value)
  4908. {
  4909. // TODO:增加恢复默认系数操作
  4910. factor_restore_default();
  4911. strcpy(m_WarningStr,"通道系数恢复为默认值");
  4912. log_str_time(LOG_OPERATE,"面板恢复默认校准系数",0,0);
  4913. return M_JUMP0;
  4914. }
  4915. /**************************************************************************
  4916. 函数名称:mmd_StartAutojust
  4917. 函数版本:1.00
  4918. 作者:
  4919. 创建日期:2008.9.1
  4920. 函数功能说明:启动精度自校
  4921. 输入参数:
  4922. 输出参数:
  4923. 返回值:
  4924. 更新信息:
  4925. 更新日志1:
  4926. 日期:
  4927. 修改者:
  4928. 修改内容:
  4929. 修改原因:
  4930. ***************************************************************************/
  4931. int mmd_StartAutojust(int value)
  4932. {
  4933. int ret;
  4934. ret = sw_auto_adjust(-1);
  4935. switch(ret)
  4936. {
  4937. case 0:
  4938. strcpy(m_WarningStr,"通道校正成功!");
  4939. break;
  4940. case -1:
  4941. strcpy(m_WarningStr,"输入校正值太大");
  4942. break;
  4943. case -2:
  4944. strcpy(m_WarningStr,"通道系数超范围");
  4945. break;
  4946. case -3:
  4947. strcpy(m_WarningStr,"输入角度值太小");
  4948. break;
  4949. case -4:
  4950. strcpy(m_WarningStr,"输入角度值太大");
  4951. break;
  4952. case -5:
  4953. strcpy(m_WarningStr,"角度系数超范围");
  4954. break;
  4955. case -6:
  4956. strcpy(m_WarningStr,"系数保存错误");
  4957. break;
  4958. default:
  4959. strcpy(m_WarningStr,"未知错误");
  4960. break;
  4961. }
  4962. return M_JUMP3;
  4963. }
  4964. int mmd_StartZljust1(int value)
  4965. {
  4966. int ret;
  4967. // equ_power_adjust();
  4968. ret = sw_adjust_dc_0();
  4969. switch(ret)
  4970. {
  4971. case 0:
  4972. sprintf(m_WarningStr,"直流%fV校正成功!",dc_adjust[0]);
  4973. break;
  4974. case -1:
  4975. sprintf(m_WarningStr,"输入直流%0.1fV值太小",dc_adjust[0]);
  4976. break;
  4977. case -2:
  4978. sprintf(m_WarningStr,"输入直流%0.1fV值太大",dc_adjust[0]);
  4979. break;
  4980. default:
  4981. break;
  4982. }
  4983. if(ret==0)
  4984. {
  4985. return M_JUMP0;
  4986. }
  4987. else
  4988. {
  4989. return M_JUMP3;
  4990. }
  4991. }
  4992. int mmd_StartZljust2(int value)
  4993. {
  4994. int ret;
  4995. ret = sw_adjust_dc_1();
  4996. switch(ret)
  4997. {
  4998. case 0:
  4999. sprintf(m_WarningStr,"直流校正成功!");
  5000. break;
  5001. case -1:
  5002. sprintf(m_WarningStr,"输入直流%0.1fV值太小",dc_adjust[1]);
  5003. break;
  5004. case -2:
  5005. sprintf(m_WarningStr,"输入直流%0.1f值太大",dc_adjust[1]);
  5006. break;
  5007. default:
  5008. break;
  5009. }
  5010. return M_JUMP3;
  5011. }
  5012. int mmd_StartPowerAjust(int value)
  5013. {
  5014. int ret=0;
  5015. //ret = equ_power_adjust();
  5016. switch(ret)
  5017. {
  5018. case 0:
  5019. sprintf(m_WarningStr,"电源电压校正成功!");
  5020. break;
  5021. case -1:
  5022. sprintf(m_WarningStr,"电源电压值超范围");
  5023. break;
  5024. case -2:
  5025. sprintf(m_WarningStr,"系数保存错误");
  5026. break;
  5027. default:
  5028. break;
  5029. }
  5030. return M_JUMP3;
  5031. }
  5032. void GetBoardName(BYTE type,char *name)
  5033. {
  5034. extern struct board_res_head *g_board_res_head;
  5035. struct board_res *br;
  5036. int i;
  5037. br = g_board_res;
  5038. for(i=0; i<g_board_res_head->br_num; i++)
  5039. {
  5040. if(br[i].type==type)
  5041. {
  5042. strcpy(name,br[i].name);
  5043. return ;
  5044. }
  5045. }
  5046. strcpy(name,"未知");
  5047. }
  5048. void mmd_GetInfValue(int no,DATA_FIELD_DEF *pF)
  5049. {
  5050. struct board_res *br;
  5051. struct board_info *bi;
  5052. char bName[24];
  5053. int i=no;
  5054. br = g_board_res;
  5055. bi = g_board_info;
  5056. GetBoardName(bi[i].type,bName);
  5057. #if LCD_SIZE==128
  5058. sprintf(pF->FmtStr,"%-4.4s %04X %01X%02X%02x",bName,bi[i].crc,(BYTE)(bi[i].version>>16),(BYTE)(bi[i].version>>8),(BYTE)(bi[i].version>>0));
  5059. #else
  5060. sprintf(pF->FmtStr,"板卡%d %04X %01X.%02X.%02x",
  5061. i,bi[i].crc,(BYTE)(bi[i].version>>16),(BYTE)(bi[i].version>>8),(BYTE)(bi[i].version>>0));
  5062. #endif
  5063. }
  5064. int mmd_RenewInf(void)
  5065. {
  5066. mmd_RenewDataMenu(&g_tDataMenu1);
  5067. return M_OK;
  5068. }
  5069. /**************************************************************************
  5070. 函数名称:mmd_GetInf
  5071. 函数版本:1.00
  5072. 作者:
  5073. 创建日期:2008.9.1
  5074. 函数功能说明:取得装置信息
  5075. 输入参数:
  5076. 输出参数:
  5077. 返回值:
  5078. 更新信息:
  5079. 更新日志1:
  5080. 日期:
  5081. 修改者:
  5082. 修改内容:
  5083. 修改原因:
  5084. ***************************************************************************/
  5085. int mmd_GetInf(int value)
  5086. {
  5087. char tmpbuf[64];
  5088. if(set_get_fixed_arg(FIXED_SET_TPE,tmpbuf, 32)==0)
  5089. {
  5090. strncpy(m_equipstr,tmpbuf,20);
  5091. }
  5092. else
  5093. {
  5094. strcpy(m_equipstr,"FYD830");
  5095. }
  5096. if(set_get_fixed_arg(FIXED_SET_CRC,tmpbuf, 32)==0)
  5097. {
  5098. sprintf(m_errInf,"%sH",tmpbuf);//strncpy(m_errInf,tmpbuf,20);
  5099. }
  5100. else
  5101. {
  5102. sprintf(m_errInf,"%04XH",g_board_info[0].crc);
  5103. }
  5104. //sprintf(m_errInf,"%sH",CODE_CRC);
  5105. if(set_get_fixed_arg(FIXED_SET_SVR,tmpbuf, 32)==0)
  5106. strncpy(m_set_inf,tmpbuf,20);
  5107. else
  5108. sprintf(m_set_inf,"SV%02d.%03d",g_board_info[0].version/1000,g_board_info[0].version%1000);
  5109. //sprintf(m_set_inf,"%01X.%02X.%02x",(BYTE)(g_board_info[0].version>>16),(BYTE)(g_board_info[0].version>>8),(BYTE)(g_board_info[0].version>>0));
  5110. if(set_get_fixed_arg(FIXED_SET_CPT,tmpbuf, 32)==0)
  5111. {
  5112. strcpy(m_WarningStr,tmpbuf);
  5113. }
  5114. else
  5115. {
  5116. strcpy(m_WarningStr,VER_TIME);
  5117. }
  5118. return M_OK;
  5119. }
  5120. BYTE strGprsInf[30][24];
  5121. int g_gprs_info_num;
  5122. static void mmd_GetConfigInfValue(int no,DATA_FIELD_DEF *pF)
  5123. {
  5124. int i;
  5125. int errno=0;
  5126. for(i=0;i<ERR_CODE_NUM;i++)
  5127. {
  5128. if(rt_err_test(i)>0)
  5129. {
  5130. errno++;
  5131. if((no+1)==errno)
  5132. {
  5133. break;
  5134. }
  5135. }
  5136. }
  5137. if(i==ERR_CODE_NUM)
  5138. {
  5139. sprintf(pF->FmtStr,"无错误信息,代码:%d",no);
  5140. }
  5141. else
  5142. {
  5143. if(g_tScreen.lcd_type!=LCD_TYPE_160160)
  5144. {
  5145. sprintf(pF->FmtStr,"%-16.16s",rt_err_msg(i));
  5146. }
  5147. else
  5148. {
  5149. sprintf(pF->FmtStr,"%02d.%-17.17s",no+1,rt_err_msg(i));
  5150. }
  5151. }
  5152. }
  5153. int mmd_RenewConfigInf(void)
  5154. {
  5155. mmd_RenewDataMenu(&g_tDataMenu1);
  5156. return M_OK;
  5157. }
  5158. /**************************************************************************
  5159. 函数名称:mmd_GetInf
  5160. 函数版本:1.00
  5161. 作者:
  5162. 创建日期:2008.9.1
  5163. 函数功能说明:取得装置信息
  5164. 输入参数:
  5165. 输出参数:
  5166. 返回值:
  5167. 更新信息:
  5168. 更新日志1:
  5169. 日期:
  5170. 修改者:
  5171. 修改内容:
  5172. 修改原因:
  5173. ***************************************************************************/
  5174. int mmd_GetConfigInf(int value)
  5175. {
  5176. int i;
  5177. int err_cnt=0;
  5178. for(i=0;i<ERR_CODE_NUM;i++)
  5179. {
  5180. if(rt_err_test(i)>0)
  5181. {
  5182. err_cnt++;
  5183. }
  5184. }
  5185. if(err_cnt==0)
  5186. {
  5187. strcpy(m_WarningStr,"无故障信息!");
  5188. return M_JUMP3;
  5189. }
  5190. mmd_initDataMenu(&g_tDataMenu1,err_cnt,mmd_RenewConfigInf,mmd_GetConfigInfValue,7,1);
  5191. return M_JUMP0;
  5192. }
  5193. static void mmd_GetExtInfValue(int no,DATA_FIELD_DEF *pF)
  5194. {
  5195. #if LCD_SIZE==128
  5196. sprintf(pF->FmtStr,"%-16.16s",strGprsInf[no]);
  5197. #else
  5198. sprintf(pF->FmtStr,"%-20.20s",strGprsInf[no]);
  5199. #endif
  5200. }
  5201. int mmd_RenewExtInf(void)
  5202. {
  5203. mmd_RenewDataMenu(&g_tDataMenu1);
  5204. return M_OK;
  5205. }
  5206. int mmd_GetDebugInf(int value)
  5207. {
  5208. int num=0;
  5209. int debug_port;
  5210. char * acteth;
  5211. #ifdef FUN_JDXX
  5212. u32 version_jdxx;
  5213. version_jdxx = FUN_JDXX_VERSION;
  5214. #endif
  5215. acteth = env_get_info(ENV_ETHACT);
  5216. debug_port = 0;
  5217. #if LCD_SIZE==128
  5218. sprintf(strGprsInf[num++],"调试串口:%d",g_con_uart_index);
  5219. sprintf(strGprsInf[num++],"波特率:115200");
  5220. sprintf(strGprsInf[num++],"校验位:无校验");
  5221. sprintf(strGprsInf[num++],"调试网口:%d",debug_port+1);
  5222. sprintf(strGprsInf[num++],"IP地址:",env_get_info(ENV_IPADDR));
  5223. sprintf(strGprsInf[num++],"%s",env_get_info(ENV_IPADDR));
  5224. sprintf(strGprsInf[num++],"子网掩码:",env_get_info(ENV_NETMASK));
  5225. sprintf(strGprsInf[num++],"%s",env_get_info(ENV_NETMASK));
  5226. sprintf(strGprsInf[num++],"网关:",env_get_info(ENV_GATEWAYIP));
  5227. sprintf(strGprsInf[num++],"%s",env_get_info(ENV_GATEWAYIP));
  5228. #else
  5229. sprintf(strGprsInf[num++],"调试串口:%d",g_con_uart_index);
  5230. sprintf(strGprsInf[num++],"波特率:115200 无校验");
  5231. sprintf(strGprsInf[num++],"调试网口:%d",debug_port+1);
  5232. printf("[%s:%d] debug_port = %d\r\n", __func__, __LINE__, debug_port);
  5233. sprintf(strGprsInf[num++],"IP=%s",env_get_info(ENV_IPADDR));
  5234. sprintf(strGprsInf[num++],"MASK=%s",env_get_info(ENV_NETMASK));
  5235. sprintf(strGprsInf[num++],"GATE=%s",env_get_info(ENV_GATEWAYIP));
  5236. sprintf(strGprsInf[num++],"编译脚本:");
  5237. sprintf(strGprsInf[num++],"%s",SH_NAME);
  5238. #ifdef FUN_JDXX
  5239. sprintf(strGprsInf[num++],"JDXX_Ver:V%02d.%03d",version_jdxx/1000,version_jdxx%1000);
  5240. #else
  5241. sprintf(strGprsInf[num++],"JDXX_Ver:------");
  5242. #endif
  5243. #endif
  5244. g_gprs_info_num=num;
  5245. mmd_initDataMenu(&g_tDataMenu1,num,mmd_RenewExtInf,mmd_GetExtInfValue,8,1);
  5246. return M_OK;
  5247. }
  5248. int mmd_GetFileInf(int value)
  5249. {
  5250. int num=0;
  5251. int i;
  5252. int index=0;
  5253. extern struct board_res_head *g_board_res_head;
  5254. for(i=0; i<g_board_res_head->br_num; i++)
  5255. {
  5256. if(g_board_res[i].type==g_board_info[EQU_SLOT_KZ].type)
  5257. {
  5258. index=i;
  5259. }
  5260. }
  5261. #if LCD_SIZE==128
  5262. sprintf(strGprsInf[num],"%d.装置资源:%04XH",num+1,g_crc_rsc); //显示面板上num排序应从1(num+1)开始
  5263. num++;
  5264. sprintf(strGprsInf[num],"%d.板卡资源:%04XH",num+1,g_crc_brd_res);
  5265. num++;
  5266. sprintf(strGprsInf[num],"%d.通道配置:%04XH",num+1,g_crc_equ_cfg);
  5267. num++;
  5268. sprintf(strGprsInf[num],"%d.转发点表:%04XH",num+1,g_crc_rectable);
  5269. num++;
  5270. sprintf(strGprsInf[num],"%d.定值描述:%04XH",num+1,g_crc_set_desc);
  5271. num++;
  5272. sprintf(strGprsInf[num],"%d.定值数据:%04XH",num+1,g_crc_set_data);
  5273. num++;
  5274. sprintf(strGprsInf[num],"%d.HV:%s",num+1,g_board_res[index].name);
  5275. num++;
  5276. sprintf(strGprsInf[num],"%d.KV:%s",num+1,(env_get_info(ENV_KERNEL)+15));
  5277. strGprsInf[num][13]=0;
  5278. num++;
  5279. #else
  5280. sprintf(strGprsInf[num],"%d.装置资源文件:%04XH",num+1,g_crc_rsc); //显示面板上num排序应从1(num+1)开始
  5281. num++;
  5282. sprintf(strGprsInf[num],"%d.板卡资源文件:%04XH",num+1,g_crc_brd_res);
  5283. num++;
  5284. sprintf(strGprsInf[num],"%d.通道配置文件:%04XH",num+1,g_crc_equ_cfg);
  5285. num++;
  5286. sprintf(strGprsInf[num],"%d.转发点表文件:%04XH",num+1,g_crc_rectable);
  5287. num++;
  5288. sprintf(strGprsInf[num],"%d.定值描述文件:%04XH",num+1,g_crc_set_desc);
  5289. num++;
  5290. sprintf(strGprsInf[num],"%d.定值数据文件:%04XH",num+1,g_crc_set_data);
  5291. num++;
  5292. sprintf(strGprsInf[num],"%d.HV:%s",num+1,g_board_res[index].name);
  5293. num++;
  5294. sprintf(strGprsInf[num],"%d.KV:%s",num+1,(env_get_info(ENV_KERNEL)+15));
  5295. strGprsInf[num][13]=0;
  5296. num++;
  5297. #endif
  5298. g_gprs_info_num=num;
  5299. mmd_initDataMenu(&g_tDataMenu1,num,mmd_RenewExtInf,mmd_GetExtInfValue,9,1);
  5300. return M_OK;
  5301. }
  5302. /****GPRS维护信息显示**********************/
  5303. static void mmd_GprsInf(int i,DATA_FIELD_DEF *pF)
  5304. {
  5305. char *pd=pF->FmtStr;
  5306. #if LCD_SIZE==128
  5307. sprintf(pd,"%-16.16s",strGprsInf[i]);
  5308. #else
  5309. sprintf(pd,"%-20.20s",strGprsInf[i]);
  5310. #endif
  5311. }
  5312. int mmd_RenewGprsInf(void)
  5313. {
  5314. mmd_RenewDataMenu(&g_tDataMenu1);
  5315. return M_OK;
  5316. }
  5317. int mmd_GetGprsInf(int value)
  5318. {
  5319. int i;
  5320. for(i=0;i<20;i++)
  5321. {
  5322. strcpy(strGprsInf[i]," ");
  5323. }
  5324. mmd_initDataMenu(&g_tDataMenu1,3,mmd_RenewGprsInf,mmd_GprsInf,11,1);
  5325. IEC101_PH_GprsInfo();
  5326. return M_OK;
  5327. }
  5328. int mmd_GprsInfKey(int key)
  5329. {
  5330. if(key==HA_KEY_ENTER) // +键增加列表
  5331. {
  5332. int i;
  5333. for(i=0;i<CFG_UART_NUM_MAX-1;i++)
  5334. {
  5335. if(UART_CHANNEL[i]< 0)
  5336. {
  5337. continue;
  5338. }
  5339. //外部通信报文处理
  5340. if(tRunPara.tUartPara[i].wProtocol==PROTOCOL_101_PH) // 101规约
  5341. {
  5342. IEC101_DEF *pt=(IEC101_DEF *)g_tRsComm[i].ptBuf;
  5343. pt->bCallGprsInf=true;
  5344. }
  5345. }
  5346. }
  5347. return M_OK;
  5348. }
  5349. int mmd_get_gprs_info(void)
  5350. {
  5351. BYTE *pd=tGprsInf.data;
  5352. int num=0;
  5353. if(!tGprsInf.bInf)return 0;
  5354. tGprsInf.bInf=false;
  5355. if(pd[0]==1)
  5356. {
  5357. strcpy(strGprsInf[num++],"模块状态 :正常");
  5358. }
  5359. else
  5360. {
  5361. strcpy(strGprsInf[num++],"模块状态 :异常");
  5362. }
  5363. if(pd[1]==1)
  5364. {
  5365. strcpy(strGprsInf[num++],"SIM卡状态:正常");
  5366. }
  5367. else
  5368. {
  5369. strcpy(strGprsInf[num++],"SIM卡状态:异常");
  5370. }
  5371. if(pd[2]==1)
  5372. {
  5373. strcpy(strGprsInf[num++],"PPP拨号 :正常");
  5374. }
  5375. else
  5376. {
  5377. strcpy(strGprsInf[num++],"PPP拨号 :异常");
  5378. }
  5379. sprintf(strGprsInf[num++],"信号强度 :%2d",pd[9]);
  5380. sprintf(strGprsInf[num++],"IP:%d.%d.%d.%d",pd[19],pd[20],pd[21],pd[22]);
  5381. if(pd[10]==1)
  5382. {
  5383. strcpy(strGprsInf[num++],"频段:900MHz");
  5384. }
  5385. else
  5386. {
  5387. strcpy(strGprsInf[num++],"频段:1800MHz(其他)");
  5388. }
  5389. sprintf(strGprsInf[num++],"ICMP延时:%d ms",(pd[24]|(pd[23]<<8)));
  5390. sprintf(strGprsInf[num++],"上传字节数:%d",(pd[34]|(pd[33]<<8)|(pd[32]<<16)|(pd[31]<<24)));
  5391. sprintf(strGprsInf[num++],"下载字节数:%d",(pd[38]|(pd[37]<<8)|(pd[36]<<16)|(pd[35]<<24)));
  5392. g_gprs_info_num = num;
  5393. return num;
  5394. }
  5395. int mmd_AuotGprsInf(void)
  5396. {
  5397. int num;
  5398. num = mmd_get_gprs_info();
  5399. if(num)
  5400. {
  5401. g_tDataMenu1.sTotalNum=num; //总的动态菜单数
  5402. }
  5403. mmd_RenewGprsInf();
  5404. return M_OK;
  5405. }
  5406. u8 *goosefilebuf=NULL;
  5407. u8 *gooseinfbuf;
  5408. struct file * goosepfile=NULL;
  5409. int gooseinflenth=0;
  5410. int gooseinfbgn=0;
  5411. void mmd_printgooseinf(void)
  5412. {
  5413. int i;
  5414. DATA_MENU_DEF *pt=&g_tDataMenu1;
  5415. int num=0;
  5416. u8 *buf=gooseinfbuf;
  5417. char *ptstr;
  5418. pt->sFocusIndex=0;
  5419. for(i=0;i<9;i++)
  5420. {
  5421. sprintf(pt->tDataFields[i].FmtStr,"%20.20s"," ");
  5422. }
  5423. if(gooseinfbgn>=gooseinflenth)return;
  5424. ptstr=pt->tDataFields[pt->sFocusIndex].FmtStr;
  5425. for(i=gooseinfbgn;i<gooseinflenth;i++)
  5426. {
  5427. if(buf[i] == 0x0A)
  5428. {
  5429. ptstr[20]=0;
  5430. pt->sFocusIndex++;
  5431. if(pt->sFocusIndex>=9)
  5432. {
  5433. i++;
  5434. break;
  5435. }
  5436. num=0;
  5437. ptstr=pt->tDataFields[pt->sFocusIndex].FmtStr;
  5438. }
  5439. else if(buf[i]<0x20)
  5440. {
  5441. }
  5442. else
  5443. {
  5444. ptstr[num++]=buf[i];
  5445. if(buf[i]>0x80)
  5446. {
  5447. ptstr[num++]=buf[i+1];
  5448. i+=1;
  5449. }
  5450. if(num>=19)
  5451. {
  5452. ptstr[20]=0;
  5453. pt->sFocusIndex++;
  5454. if(pt->sFocusIndex>=9)
  5455. {
  5456. i++;
  5457. break;
  5458. }
  5459. num=0;
  5460. ptstr=pt->tDataFields[pt->sFocusIndex].FmtStr;
  5461. }
  5462. }
  5463. }
  5464. ptstr[20]=0;
  5465. gooseinfbgn=i;
  5466. pt->sFocusIndex=0; //第一个显示的动态菜单的索引
  5467. pt->sTotalNum=9; //总的动态菜单数
  5468. pt->sScreenNum=9;
  5469. pt->GetPrevFuncAddr=NULL; //44
  5470. pt->GetNextFuncAddr=NULL; //44
  5471. pt->GetValueFuncAddr=NULL;
  5472. }
  5473. int mmd_GetGooseInf(int value)
  5474. {
  5475. u32 i,file_length;
  5476. struct file * pfile;
  5477. u8 *filebuf;
  5478. u8 filestr[256],*pstr,strlenth;
  5479. loff_t pos;
  5480. // 打开文件
  5481. pfile = rt_file_open("/tmp/kmsg",O_RDONLY ,0);
  5482. if(IS_ERR(pfile))
  5483. {
  5484. sprintf(m_WarningStr,"无法打开kmsg文件");
  5485. return M_JUMP3;
  5486. }
  5487. // 得到文件长度
  5488. file_length = rt_file_getfile_size(pfile);
  5489. if(file_length <= 0)
  5490. {
  5491. rt_file_close(pfile,0);
  5492. sprintf(m_WarningStr,"kmsg文件长度=0");
  5493. return M_JUMP3;
  5494. }
  5495. // 分配内存
  5496. filebuf = rt_malloc(file_length);
  5497. if((filebuf) == NULL)
  5498. {
  5499. rt_file_close(pfile,0);
  5500. sprintf(m_WarningStr,"内存分配失败");
  5501. return M_JUMP3;
  5502. }
  5503. pos = 0;
  5504. if(rt_file_read(pfile,filebuf,file_length,&pos) != file_length)
  5505. {
  5506. rt_file_close(pfile,0);
  5507. rt_free(filebuf);
  5508. sprintf(m_WarningStr,"kmsg读取失败");
  5509. return M_JUMP3;
  5510. }
  5511. pstr = filestr;
  5512. strlenth=0; // 纠错处理
  5513. //找到\r\n位置,得到一行长度
  5514. for(i = 0; i < file_length; i++)
  5515. {
  5516. *pstr++=filebuf[i];
  5517. strlenth++;
  5518. if(filebuf[i] == 0x0a||strlenth>=256)
  5519. {
  5520. *pstr=0;
  5521. pstr=filestr;
  5522. if(strstr(filestr,"goose_init...")) //
  5523. {
  5524. goosefilebuf=filebuf;
  5525. goosepfile=pfile;
  5526. gooseinfbuf=&filebuf[i+1];
  5527. gooseinfbgn=0;
  5528. gooseinflenth=file_length-i;
  5529. mmd_printgooseinf();
  5530. return M_JUMP0;
  5531. }
  5532. }
  5533. }
  5534. rt_file_close(pfile,0); // 关闭文件
  5535. rt_free(filebuf); // 释放内存
  5536. sprintf(m_WarningStr,"未找到 goose信息");
  5537. return M_JUMP3;
  5538. }
  5539. int mmd_gooseKey(int key)
  5540. {
  5541. if(key==((g_tScreen.lcd_type==LCD_TYPE_6KEY)?HA_KEY_LEFT:HA_KEY_ESC)) // 老版本按键6键,左键为取消键
  5542. {
  5543. rt_file_close(goosepfile,0); // 关闭文件
  5544. rt_free(goosefilebuf); // 释放内存
  5545. return M_JUMP1;
  5546. }
  5547. if(key==HA_KEY_ENTER)
  5548. {
  5549. mmd_printgooseinf();
  5550. }
  5551. return M_OK;
  5552. }
  5553. /**************************************************************************
  5554. 函数名称:mmd_InitDefaultEquipSet
  5555. 函数版本:1.00
  5556. 作者:
  5557. 创建日期:2008.9.1
  5558. 函数功能说明:恢复出厂设置,定值,定值区信息,压板,内部定值,参数均设为默认值,
  5559. 清事件记录、操作记录,运行定值区0 ,有效区一个 0
  5560. 输入参数:
  5561. 输出参数:
  5562. 返回值:
  5563. 更新信息:
  5564. 更新日志1:
  5565. 日期:
  5566. 修改者:
  5567. 修改内容:
  5568. 修改原因:
  5569. ***************************************************************************/
  5570. int mmd_InitDefaultEquipSet(int value)
  5571. {
  5572. if(rt_err_test(ERR_CODE_FACTOR)) // 装置配置若校验错误,置为默认值,若正确,不做处理
  5573. {
  5574. // 恢复错误的系数,正确的保留
  5575. factor_restore_default();
  5576. log_str_time(LOG_OPERATE,"装置恢复默认校准系数",0,0);
  5577. }
  5578. init_default_equip_set(0);
  5579. strcpy(m_WarningStr,"恢复为出厂设置");
  5580. return M_JUMP3;
  5581. }
  5582. int mmd_SoftReset(int value)
  5583. {
  5584. watchdog_reset_cpu(3);
  5585. return M_OK;
  5586. }
  5587. /*下面是远动测试的内容*/
  5588. double GetYdYcValue(int i)
  5589. {
  5590. double ff;
  5591. int ycvalue;
  5592. DWORD lmeaval=0;
  5593. long lzero=0;
  5594. BYTE no=g_ac_table[i].indexno;
  5595. u8 link_qds=0;
  5596. int sw=g_ac_table[i].owner;
  5597. if(no>0)
  5598. {
  5599. DWORD dwMax;
  5600. DWORD dwDeadVal;
  5601. float rate;
  5602. float f_65536=65536.0;
  5603. no-=1;
  5604. rate=(float)g_ac_table[i].rate/65536.0;
  5605. dwMax=(DWORD)g_ac_table[i].normal;
  5606. //dwMax = (tRunPara.bDeadType==true) ? (DWORD)g_ac_table[i].normal:_AbsL(pt104->yc_save[i]);
  5607. if(dwMax==0) //防止额定或者前一次保存值为0
  5608. dwMax=1;
  5609. dwDeadVal=_Mul_Div_U(g_ac_table[i].dead_value,dwMax,6553600);
  5610. if(dwDeadVal==0)dwDeadVal=1;
  5611. if(dwMax==0)f_65536=1.0;
  5612. #if 0 //远动测试情况下遥测数据测试值锁定功能 此处暂不开启
  5613. lmeaval=GetRmtMeaVal(g_ac_table[i].owner,no,&link_qds);
  5614. #else
  5615. if(sw==0) // 公共测量值
  5616. {
  5617. if(no < PUB_AC_NUM_ALL)
  5618. {
  5619. lmeaval=g_sw_pub.ac_in[no];
  5620. }
  5621. lzero=g_unit[g_pub_ac_desc[no].unit].zero;
  5622. }
  5623. else if(sw<=SWITCH_NUM_EXT)
  5624. {
  5625. sw-=1;
  5626. if(no < SW_AC_NUM_ALL)
  5627. {
  5628. lmeaval=g_sw[sw].ac_in[no];
  5629. if(link_qds)
  5630. {
  5631. link_qds=g_sw[sw].link_qds[no];
  5632. }
  5633. }
  5634. lzero=g_unit[g_sw_ac_desc[no].unit].zero;
  5635. }
  5636. if(lzero>0&&_AbsL(lmeaval)<lzero && pRunSet->bTT_RET_ZERO)
  5637. {
  5638. lmeaval=0;
  5639. }
  5640. #endif
  5641. //rt_printf("%d--",lmeaval);
  5642. ff=((double)lmeaval)/f_65536*rate; //转为浮点数
  5643. #ifdef VOLT_ADAPTIVE_FACTOR
  5644. if(pRunSet->bTT_AdaptiveFactor)
  5645. {
  5646. if(0 == g_ac_table[i].owner)
  5647. {
  5648. if((no <= PUB_AC_UCA1) && (no >= PUB_AC_UA1))
  5649. {
  5650. ff=((double)lmeaval)/f_65536*10/pRunSet->pt1_two;
  5651. }
  5652. else if((no <= PUB_AC_UCA2) && (no >= PUB_AC_UA2))
  5653. {
  5654. ff=((double)lmeaval)/f_65536*10/pRunSet->pt2_two;
  5655. }
  5656. }
  5657. }
  5658. #endif
  5659. ycvalue=(int)rt_round(ff);
  5660. if(tRunPara.bYcFloat)
  5661. {
  5662. if(_AbsL(lmeaval) > (dwMax*10)) // 大于额定值的10倍*65536
  5663. {
  5664. //if(dwMax>0)QDS|=0x01; //遥测溢出
  5665. }
  5666. }
  5667. else
  5668. {
  5669. if (ycvalue >= 0)
  5670. {
  5671. if (ycvalue > 32767)
  5672. {
  5673. ycvalue = 32767;
  5674. //QDS|=0x01; //遥测溢出
  5675. }
  5676. }
  5677. else
  5678. {
  5679. if (ycvalue < (-32768))
  5680. {
  5681. ycvalue = -32768;
  5682. //QDS|=0x01; //遥测溢出
  5683. }
  5684. }
  5685. }
  5686. }
  5687. else //备用点号,数值上送0
  5688. {
  5689. ycvalue=0;
  5690. ff=0;
  5691. }
  5692. return ff;
  5693. }
  5694. static void mmd_GetRmtYCValue(int i,DATA_FIELD_DEF *pF)
  5695. {
  5696. char *pd=pF->FmtStr;
  5697. char tmpstr[16];
  5698. #ifdef YD_TEST_REALTIME_VALUE_DISPLAY
  5699. char flag=0; //溢出标志
  5700. double v;
  5701. #endif
  5702. strcpy(pd,"");
  5703. if(g_ac_table[i].indexno!=0)
  5704. {
  5705. #ifdef YD_TEST_REALTIME_VALUE_DISPLAY
  5706. tbl_getname(RES_TYPE_YC,i,pd);
  5707. #else
  5708. tbl_getacname(g_ac_table[i].owner,g_ac_table[i].indexno,pd);
  5709. #endif
  5710. }
  5711. else
  5712. {
  5713. sprintf(pd,"备用遥测%d",i+1);
  5714. }
  5715. #ifdef YD_TEST_REALTIME_VALUE_DISPLAY
  5716. strcpy(tmpstr,"");
  5717. v=GetYdYcValue(i);
  5718. if((v<-99999)||(v>999999))
  5719. flag=1;
  5720. sprintf(tmpstr,"%.4lf",v);
  5721. #if LCD_SIZE==128
  5722. sprintf(pd,"%-13.13s %s",pd,tmpstr);
  5723. #else
  5724. if((g_ac_table[i].owner)&&(g_ac_table[i].indexno>=21)&&(g_ac_table[i].indexno<=32))
  5725. {
  5726. if(flag)
  5727. sprintf(pd,"%-12.12s : over",pd);
  5728. else
  5729. sprintf(pd,"%-12.12s :%-6.6s",pd,tmpstr);
  5730. }
  5731. else
  5732. sprintf(pd,"%-8.8s :%-10.10s",pd,tmpstr);
  5733. #endif
  5734. #else
  5735. sprintf(tmpstr," :%.2f",(float)g_ac_table[i].normal/(65536*2)); // 额定值的一半
  5736. strcat(pd,tmpstr);
  5737. #endif
  5738. }
  5739. /**************************************************************************
  5740. 函数名称:mmd_RenewMea
  5741. 函数版本:1.00
  5742. 作者:
  5743. 创建日期:2008.9.1
  5744. 函数功能说明:刷新测量值显示
  5745. 输入参数:
  5746. 输出参数:
  5747. 返回值:
  5748. 更新信息:
  5749. 更新日志1:
  5750. 日期:
  5751. 修改者:
  5752. 修改内容:
  5753. 修改原因:
  5754. ***************************************************************************/
  5755. int mmd_RenewRmtYC(void)
  5756. {
  5757. mmd_RenewDataMenu(&g_tDataMenu1);
  5758. return M_OK;
  5759. }
  5760. /**************************************************************************
  5761. 函数名称:mmd_GetMea
  5762. 函数版本:1.00
  5763. 作者:
  5764. 创建日期:2008.9.1
  5765. 函数功能说明:取得测量值的显示
  5766. 输入参数:
  5767. 输出参数:
  5768. 返回值:
  5769. 更新信息:
  5770. 更新日志1:
  5771. 日期:
  5772. 修改者:
  5773. 修改内容:
  5774. 修改原因:
  5775. ***************************************************************************/
  5776. int mmd_GetRmtYC(int value)
  5777. {
  5778. mmd_initDataMenu(&g_tDataMenu1,g_table_head->ac_num,mmd_RenewRmtYC,mmd_GetRmtYCValue,126,1);
  5779. return M_OK;
  5780. }
  5781. /*下面是遥信测试处理*/
  5782. static void mmd_GetRmtYXValue(int i,DATA_FIELD_DEF *pF)
  5783. {
  5784. char *pd=pF->FmtStr;
  5785. #ifdef YD_TEST_REALTIME_VALUE_DISPLAY
  5786. u8 data=0;
  5787. int sz_index;
  5788. char valStr[5]="";
  5789. #endif
  5790. strcpy(pd,"");
  5791. if(g_di_table[i].indexno==0)
  5792. {
  5793. bool bMix=true;
  5794. int m;
  5795. for(m=0; m<g_table_head->di_db_num; m++) // 双点
  5796. {
  5797. if(g_di_table[i].cp==g_di_db_table[m].cp)
  5798. {
  5799. #ifdef YD_TEST_REALTIME_VALUE_DISPLAY
  5800. sz_index = tbl_get_sz_index_yx(i); //找到双点在sz_table的位置(双点+x+x)
  5801. //sz_index+=1; //合并点显示第一行名称
  5802. if(tbl_getname_sz(RES_TYPE_YX,sz_index,pd)<0)
  5803. #endif
  5804. tbl_getdiname(((g_di_db_table[m].no[0]>>8)&0xff),(g_di_db_table[m].no[0]&0xff),pd);
  5805. //sprintf(pd,"%s-%d-%d",pd,sz_index,i);
  5806. strcat(pd," (双点) ");
  5807. bMix=false;
  5808. break;
  5809. }
  5810. }
  5811. if(bMix) //合并点
  5812. {
  5813. for(m=0; m<g_table_head->dimerge_num; m++)
  5814. {
  5815. if(g_di_table[i].cp==g_di_merge_table[m].cp)
  5816. {
  5817. #ifdef YD_TEST_REALTIME_VALUE_DISPLAY
  5818. sz_index = tbl_get_sz_index_yx(i); //找到双点在sz_table的位置(合并点+x+x)
  5819. //sz_index+=1; //合并点显示第一行名称
  5820. if(tbl_getname_sz(RES_TYPE_YX,sz_index,pd)<0)
  5821. #endif
  5822. //tbl_getdiname(((g_di_merge_table[m].no[0]>>12)&0x0f),(g_di_merge_table[m].no[0]&0xff),pd);
  5823. tbl_getdiname(((g_di_merge_table[m].no[0]>>8)&0xff),(g_di_merge_table[m].no[0]&0xff),pd); //高八位的低四位为归属 没有实点属性
  5824. strcat(pd," (合并点) ");
  5825. bMix=false;
  5826. break;
  5827. }
  5828. }
  5829. }
  5830. if(bMix) sprintf(pd,"备用遥信%d",i+1);
  5831. }
  5832. else
  5833. {
  5834. #ifdef YD_TEST_REALTIME_VALUE_DISPLAY
  5835. tbl_getname(RES_TYPE_YX,i,pd);
  5836. #else
  5837. tbl_getdiname(g_di_table[i].owner,g_di_table[i].indexno,pd);
  5838. #endif
  5839. }
  5840. #ifdef YD_TEST_REALTIME_VALUE_DISPLAY
  5841. data=tbl_get_yx(i,1);
  5842. #if 1
  5843. if(data==1)
  5844. strcpy(valStr," 分");
  5845. else if(data==2)
  5846. strcpy(valStr," 合");
  5847. else
  5848. strcpy(valStr,"非法");
  5849. #endif
  5850. #if LCD_SIZE==128
  5851. sprintf(pd,"%-13.13s %d",pd,data);
  5852. #else
  5853. //sprintf(pd,"%-16.16s %d",pd,data);
  5854. sprintf(pd,"%-14.14s %-4.4s",pd,valStr);
  5855. #endif
  5856. #endif
  5857. }
  5858. /**************************************************************************
  5859. 函数名称:mmd_RenewRmtYX
  5860. 函数版本:1.00
  5861. 作者:
  5862. 创建日期:2008.9.1
  5863. 函数功能说明:刷新遥信显示
  5864. 输入参数:
  5865. 输出参数:
  5866. 返回值:
  5867. 更新信息:
  5868. 更新日志1:
  5869. 日期:
  5870. 修改者:
  5871. 修改内容:
  5872. 修改原因:
  5873. ***************************************************************************/
  5874. int mmd_RenewRmtYX(void)
  5875. {
  5876. mmd_RenewDataMenu(&g_tDataMenu1);
  5877. return M_OK;
  5878. }
  5879. /**************************************************************************
  5880. 函数名称:mmd_GetRmtYX
  5881. 函数版本:1.00
  5882. 作者:
  5883. 创建日期:2008.9.1
  5884. 函数功能说明:取得遥信值的显示
  5885. 输入参数:
  5886. 输出参数:
  5887. 返回值:
  5888. 更新信息:
  5889. 更新日志1:
  5890. 日期:
  5891. 修改者:
  5892. 修改内容:
  5893. 修改原因:
  5894. ***************************************************************************/
  5895. int mmd_GetRmtYX(int value)
  5896. {
  5897. mmd_initDataMenu(&g_tDataMenu1,g_table_head->di_num,mmd_RenewRmtYX,mmd_GetRmtYXValue,124,1);
  5898. return M_OK;
  5899. }
  5900. int mmd_CheckRmtTbl(int value)
  5901. {
  5902. if(rt_err_test(ERR_CODE_IEC_TABLE))
  5903. {
  5904. strcpy(m_WarningStr,"转发表加载错误!");
  5905. return M_JUMP3;
  5906. }
  5907. return M_JUMP0;
  5908. }
  5909. int mmd_GetRmtIndex(int value)
  5910. {
  5911. g_RmtIndex=value;
  5912. sprintf(m_YdYcHalfOfRateValue,":%.2f",(float)g_ac_table[g_RmtIndex].normal/(65536*2)); // 额定值的一半
  5913. return M_OK;
  5914. }
  5915. int mmd_SendRmtYX(int value)
  5916. {
  5917. int i=g_RmtIndex;
  5918. u8 type=0;
  5919. u8 buf[12];
  5920. if(g_di_table[i].indexno==0)
  5921. {
  5922. int m;
  5923. for(m=0; m<g_table_head->di_db_num; m++) // 双点
  5924. {
  5925. if(g_di_table[i].cp==g_di_db_table[m].cp)
  5926. {
  5927. type=3;
  5928. }
  5929. }
  5930. for(m=0; m<g_table_head->dimerge_num; m++)
  5931. {
  5932. if(g_di_table[i].cp==g_di_merge_table[m].cp)
  5933. {
  5934. type=4;
  5935. }
  5936. }
  5937. }
  5938. // 点表类型
  5939. buf[2]=type;
  5940. // 点号
  5941. buf[3]=(u8)g_di_table[i].cp;
  5942. buf[4]=(u8)(g_di_table[i].cp>>8);
  5943. // 归属
  5944. buf[5]=g_di_table[i].owner;
  5945. // 实点、虚点
  5946. buf[6]=0;
  5947. // 资源表中索引
  5948. buf[7]=g_di_table[i].indexno;
  5949. buf[8]=value;
  5950. buf[9]=0;
  5951. buf[10]=0;
  5952. buf[11]=0;
  5953. send_rmt_yx(buf);
  5954. g_run_stu.bHmiRmtTest=true;
  5955. return M_OK;
  5956. }
  5957. int mmd_SendRmtYC(int value)
  5958. {
  5959. DWORD val;
  5960. u8 buf[12];
  5961. val=g_ac_table[g_RmtIndex].normal/2; // 额定值的一半
  5962. buf[5]=g_ac_table[g_RmtIndex].owner;
  5963. buf[7]=g_ac_table[g_RmtIndex].indexno;
  5964. buf[8]=(u8)(val>>0);
  5965. buf[9]=(u8)(val>>8);
  5966. buf[10]=(u8)(val>>16);
  5967. buf[11]=(u8)(val>>24);
  5968. send_rmt_yc(buf);
  5969. g_run_stu.bHmiRmtTest=true;
  5970. return M_OK;
  5971. }
  5972. int mmd_SendRmtDD(int value)
  5973. {
  5974. DWORD val;
  5975. u8 buf[12];
  5976. val=g_dd_table[g_RmtIndex].normal/2; // 额定值的一半
  5977. buf[5]=g_ac_table[g_RmtIndex].owner;
  5978. buf[7]=g_ac_table[g_RmtIndex].indexno;
  5979. buf[8]=(u8)(val>>0);
  5980. buf[9]=(u8)(val>>8);
  5981. buf[10]=(u8)(val>>16);
  5982. buf[11]=(u8)(val>>24);
  5983. send_rmt_dd(buf);
  5984. g_run_stu.bHmiRmtTest=true;
  5985. return M_OK;
  5986. }
  5987. // 电度远动测试
  5988. static void mmd_GetRmtDDValue(int i,DATA_FIELD_DEF *pF)
  5989. {
  5990. char *pd=pF->FmtStr;
  5991. char tmpstr[16];
  5992. strcpy(pd,"");
  5993. //if(g_dd_table[i].indexno!=0)
  5994. if((g_dd_table[i].indexno>0)&&(g_dd_table[i].indexno<=SW_DD_NUM_ALL))
  5995. {
  5996. tbl_getddname(g_dd_table[i].owner,g_dd_table[i].indexno,pd);
  5997. }
  5998. else
  5999. {
  6000. sprintf(pd,"备用电度%d",i+1);
  6001. }
  6002. sprintf(tmpstr," :%.2f",(float)g_dd_table[i].normal/(65536*2)); // 额定值的一半
  6003. strcat(pd,tmpstr);
  6004. }
  6005. /**************************************************************************
  6006. 函数名称:mmd_RenewMea
  6007. 函数版本:1.00
  6008. 作者:
  6009. 创建日期:2008.9.1
  6010. 函数功能说明:刷新测量值显示
  6011. 输入参数:
  6012. 输出参数:
  6013. 返回值:
  6014. 更新信息:
  6015. 更新日志1:
  6016. 日期:
  6017. 修改者:
  6018. 修改内容:
  6019. 修改原因:
  6020. ***************************************************************************/
  6021. int mmd_RenewRmtDD(void)
  6022. {
  6023. mmd_RenewDataMenu(&g_tDataMenu1);
  6024. return M_OK;
  6025. }
  6026. /**************************************************************************
  6027. 函数名称:mmd_GetMea
  6028. 函数版本:1.00
  6029. 作者:
  6030. 创建日期:2008.9.1
  6031. 函数功能说明:取得测量值的显示
  6032. 输入参数:
  6033. 输出参数:
  6034. 返回值:
  6035. 更新信息:
  6036. 更新日志1:
  6037. 日期:
  6038. 修改者:
  6039. 修改内容:
  6040. 修改原因:
  6041. ***************************************************************************/
  6042. int mmd_GetRmtDD(int value)
  6043. {
  6044. mmd_initDataMenu(&g_tDataMenu1,g_table_head->dd_num,mmd_RenewRmtDD,mmd_GetRmtDDValue,128,1);
  6045. return M_OK;
  6046. }
  6047. int mmd_Jump0(int value)
  6048. {
  6049. return M_JUMP0;
  6050. }
  6051. int mmd_BatActive(int value)
  6052. {
  6053. if(bat_active(1)!=0)
  6054. {
  6055. strcpy(m_WarningStr,"电池活化启动失败!");
  6056. rt_printf("%s\r\n",m_WarningStr);
  6057. return M_JUMP3;
  6058. }
  6059. return M_JUMP0;
  6060. }
  6061. int mmd_BatActOff(int value)
  6062. {
  6063. #ifdef BATTERY_WITH_COMM
  6064. StopBattAct();
  6065. #else
  6066. if(sw_do_pub(PUB_DO_HHTC,SW_DO_TYPE_ON)!=0)
  6067. {
  6068. strcpy(m_WarningStr,"电池活化退出失败!");
  6069. rt_printf("%s\r\n",m_WarningStr);
  6070. return M_JUMP3;
  6071. }
  6072. soe_record_opt(EV_BAT_HANDACTOFF, 1);
  6073. #endif
  6074. return M_JUMP0;
  6075. }
  6076. /**************************************************************************
  6077. 函数名称:mmd_InitDefaultEquipSet
  6078. 函数版本:1.00
  6079. 作者:
  6080. 创建日期:2008.9.1
  6081. 函数功能说明:恢复出厂设置,定值,定值区信息,压板,内部定值,参数均设为默认值,
  6082. 清事件记录、操作记录,运行定值区0 ,有效区一个 0
  6083. 输入参数:
  6084. 输出参数:
  6085. 返回值:
  6086. 更新信息:
  6087. 更新日志1:
  6088. 日期:
  6089. 修改者:
  6090. 修改内容:
  6091. 修改原因:
  6092. ***************************************************************************/
  6093. int init_default_equip_set(int value)
  6094. {
  6095. int i;
  6096. e2prom_reinit();
  6097. GetDefPara((float*)m_SetBuf,EQUIP_PARA_NUMBER,&tEquipParaTable[0]); //装置参数默认
  6098. //调试网口参数做特殊处理。调试网口的默认参数以UBOOT中的环境变量为默认值.
  6099. GetDefDebugNetPara();
  6100. SavePara((void *)m_SetBuf,EEP_EQUIP_PARA_ADDR,EQUIP_PARA_NUMBER,&tEquipParaTable[0]);
  6101. #ifdef PUB_SET_SECTION
  6102. for(i=0;i<SEC_NUMBER;i++)
  6103. {
  6104. GetDefPara((float*)&m_SetBuf,PUB_SET_NUMBER,&tPubSetTable[0]);//定值默认
  6105. SavePara((void *)&m_SetBuf,EEP_PUB_ADDR+i*PUB_SETSIZE,PUB_SET_NUMBER,&tPubSetTable[0]);
  6106. }
  6107. #else
  6108. GetDefPara((float*)m_SetBuf,PUB_SET_NUMBER,&tPubSetTable[0]);//定值默认
  6109. SavePara((void *)m_SetBuf,EEP_PUB_ADDR,PUB_SET_NUMBER,&tPubSetTable[0]);
  6110. #endif
  6111. for(i=0;i<SEC_NUMBER;i++)
  6112. {
  6113. GetDefPara((float*)m_SetBuf,SW_SET_NUMBER,&tSwSetTable[0]);//定值默认
  6114. SavePara((void *)m_SetBuf,EEP_SET_ADDR+i*SETSIZE,SW_SET_NUMBER,&tSwSetTable[0]);
  6115. }
  6116. GetDefPara((float*)m_SetBuf,CSTSET_NUMBER,&tCstSetTable[0]);//定值默认
  6117. SavePara((void *)m_SetBuf,EEP_CSTSET_ADDR,CSTSET_NUMBER,&tCstSetTable[0]);
  6118. m_runsection=0; // 当前运行定值区为 0区
  6119. #ifdef PASSWORD_4_STR
  6120. SavePassword(INIT_PASSWORD_STR_4); // 密码初始化
  6121. SavePassword2(INIT_PASSWORD_STR_4); // 密码初始化
  6122. #else
  6123. SavePassword(INIT_PASSWORD_STR); // 密码初始化
  6124. SavePassword2(INIT_PASSWORD_STR); // 密码初始化
  6125. #endif
  6126. soe_clear_ev(); // 清事件记录
  6127. soe_clear_opt() ; // 清操作记录
  6128. soe_record_opt(EV_INIT_EQUIP,0); // 记录操作记录
  6129. MakeRunSet(true); // 将当前运行定值区转换为运行定值区
  6130. MakeRunPara(false, true); // 转换参数到运行参数区
  6131. SaveUqua(true);
  6132. GetDefSetGroup(m_setgroup);
  6133. SaveEppData(EEP_SETGROUP_ADDR,m_setgroup,GROUP_NUM);
  6134. {
  6135. extern int led_save_flag; // 当前灯状态保存一下
  6136. led_save_flag=1;
  6137. }
  6138. rt_printf("恢复为出厂设置\r\n");
  6139. return 0;
  6140. }
  6141. extern int gprs_net_get_gprs_info(void);
  6142. /******************************************************************************
  6143. 函数名称: gprs_get_info
  6144. 函数版本: 01.01
  6145. 创建作者: xxxxxx
  6146. 创建日期: 2014-12-30
  6147. 函数说明: 获取当前屏分配的实体数
  6148. 参数说明: 无
  6149. 返回值: 成功返回0.
  6150. 修改记录:
  6151. */
  6152. int gprs_get_info(void)
  6153. {
  6154. u8 *pd=tGprsInf.data;
  6155. int num=0;
  6156. //获取内部GPRS状态信息
  6157. num = mmd_get_gprs_info();
  6158. g_gprs_info_num = num;
  6159. if(num > 0)
  6160. {
  6161. return num;
  6162. }
  6163. if(!tGprsInf.bInf)
  6164. {
  6165. return 0;
  6166. }
  6167. tGprsInf.bInf=false;
  6168. if((pd[0]|(pd[1]<<8))==0x0001)
  6169. {
  6170. strcpy(strGprsInf[num++],"模块状态 :正常");
  6171. }
  6172. else
  6173. {
  6174. strcpy(strGprsInf[num++],"模块状态 :异常");
  6175. }
  6176. if((pd[2]|(pd[3]<<8))==0x0001)
  6177. {
  6178. strcpy(strGprsInf[num++],"SIM卡状态:正常");
  6179. }
  6180. else
  6181. {
  6182. strcpy(strGprsInf[num++],"SIM卡状态:异常");
  6183. }
  6184. if((pd[4]|(pd[5]<<8))==0x0001)
  6185. {
  6186. strcpy(strGprsInf[num++],"PPP拨号 :正常");
  6187. }
  6188. else
  6189. {
  6190. strcpy(strGprsInf[num++],"PPP拨号 :异常");
  6191. }
  6192. sprintf(strGprsInf[num++],"信号强度 :%2d",(pd[16]|(pd[17]<<8)));
  6193. // SIM卡IP
  6194. sprintf(strGprsInf[num++],"%d.%d.%d.%d",pd[36],pd[37],pd[38],pd[39]);
  6195. // CH1是否正常,端口是多少,IP1
  6196. if((pd[6]|(pd[7]<<8))==0x0001)
  6197. {
  6198. sprintf(strGprsInf[num++],"CH1:正常 %d",(pd[44]|(pd[45]<<8)));
  6199. }
  6200. else
  6201. {
  6202. sprintf(strGprsInf[num++],"CH1:异常 %d",(pd[44]|(pd[45]<<8)));
  6203. }
  6204. sprintf(strGprsInf[num++],"%d.%d.%d.%d",pd[40],pd[41],pd[42],pd[43]);
  6205. // CH2是否正常,端口是多少,IP2
  6206. if((pd[8]|(pd[9]<<8))==0x0001)
  6207. {
  6208. sprintf(strGprsInf[num++],"CH2:正常 %d",(pd[50]|(pd[51]<<8)));
  6209. }
  6210. else
  6211. {
  6212. sprintf(strGprsInf[num++],"CH2:异常 %d",(pd[50]|(pd[51]<<8)));
  6213. }
  6214. sprintf(strGprsInf[num++],"%d.%d.%d.%d",pd[46],pd[47],pd[48],pd[49]);
  6215. strcpy(strGprsInf[num++],"频段:自适应");
  6216. strcpy(strGprsInf[num++],"流量(秒):");
  6217. sprintf(strGprsInf[num++],"%d",(pd[26]|(pd[27]<<8)|(pd[28]<<16)|(pd[29]<<24)));
  6218. strcpy(strGprsInf[num++],"流量(B) :");
  6219. sprintf(strGprsInf[num++],"%d",(pd[30]|(pd[31]<<8)|(pd[32]<<16)|(pd[33]<<24)));
  6220. if((pd[14]|(pd[15]<<8))==0x0001)
  6221. {
  6222. strcpy(strGprsInf[num++],"重启状态:重启");
  6223. }
  6224. else
  6225. {
  6226. strcpy(strGprsInf[num++],"重启状态:未重启");
  6227. }
  6228. g_gprs_info_num = num;
  6229. return num;
  6230. }
  6231. int mmd_FreshTime(void)
  6232. {
  6233. struct timespec ts;
  6234. struct rtc_time_t rtc;
  6235. clk_time_get(&ts);
  6236. timespec_to_rtc(ts,&rtc,1);
  6237. m_ShowTime.year=rtc.year; //显示时间刷新
  6238. m_ShowTime.month=rtc.month;
  6239. m_ShowTime.day=rtc.day;
  6240. m_ShowTime.hour=rtc.hour;
  6241. m_ShowTime.min=rtc.min;
  6242. m_ShowTime.sec=rtc.ms/1000;
  6243. return M_OK;
  6244. }
  6245. extern unsigned int s_stat_get(int chnl,int type);
  6246. void mmd_freshmainunit(bool bfirst)
  6247. {
  6248. MAIN_IMAGE_DEF *pm=&g_tLcdComm.tImage;
  6249. int i;
  6250. u8 owner,index;
  6251. for(i=0;i<pm->sYxNum;i++) //遥信都转为双点处理
  6252. {
  6253. int val=0;
  6254. DWORD dotaddr;
  6255. bool bfresh=false;
  6256. D_UNIT_DEF *pu=&pm->tYxUnits[i];
  6257. owner=(u8)(pu->yx_di>>8);
  6258. index=(u8)(pu->yx_di>>0);
  6259. if(owner==0xFF) // 特殊遥信若充电标志等
  6260. {
  6261. if(index==1) // 0xff01 为充电标志
  6262. {
  6263. int sw;
  6264. bool bcd=false;
  6265. for(sw=0;sw<g_sw_num;sw++)
  6266. {
  6267. RUN_STU_SW *prun=&g_tRelay[sw].run_stu;
  6268. bcd|=(prun->goose_qccd||prun->goose_glcd||prun->goose_ll_cd);
  6269. }
  6270. val=((g_run_stu.cd>0)||bcd)?2:1;
  6271. }
  6272. }
  6273. else if(owner>=0x20) // 板卡遥信
  6274. {
  6275. val=dido_di_is_on(owner-0x20,index)+1;
  6276. }
  6277. else
  6278. {
  6279. val=GetRmtYxVal(owner,index);
  6280. }
  6281. if(bfirst)
  6282. {
  6283. bfresh=true;
  6284. }
  6285. else if(pu->yx_value!=val)
  6286. {
  6287. bfresh=true;
  6288. }
  6289. pu->yx_value=val;
  6290. if(bfresh)
  6291. {
  6292. dotaddr=pu->addr_open;
  6293. if(val==1)
  6294. {
  6295. dotaddr=pu->addr_open;
  6296. }
  6297. else if(val==2)
  6298. {
  6299. dotaddr=pu->addr_close;
  6300. }
  6301. else if(pu->yx_attrib!=0)
  6302. {
  6303. dotaddr=pu->addr_third;
  6304. }
  6305. lcd_DrawImage(pu->sx,pu->sy,&pm->pBuf[dotaddr],0); //主接线
  6306. }
  6307. }
  6308. for(i=0;i<pm->sYcNum;i++)
  6309. {
  6310. YC_UNIT_DEF *py=&pm->tYcUnits[i];
  6311. owner=(u8)(py->yc_di>>8);
  6312. index=(u8)(py->yc_di>>0);
  6313. if(owner==0xff) //特殊遥测,管理板使用
  6314. {
  6315. int chnl,type;
  6316. u32 ubytes=0;
  6317. float fbytes;
  6318. u8 fmtstr[20];
  6319. chnl=(index>>4)&0x0f;
  6320. type=(index)&0x0f;
  6321. if(chnl>COMM_CHANNEL_NUM)return;
  6322. ubytes=s_stat_get(chnl,type);
  6323. strcpy(fmtstr,"%*6uB");
  6324. if(ubytes>=10000)
  6325. {
  6326. fbytes=ubytes;
  6327. fbytes/=1024;
  6328. if(fbytes>=1000)
  6329. {
  6330. fbytes/=1024;
  6331. if(fbytes>=1000)
  6332. {
  6333. strcpy(fmtstr,"%*6.1fM");
  6334. }
  6335. else if(fbytes>=100)
  6336. {
  6337. strcpy(fmtstr,"%*6.2fM");
  6338. }
  6339. else if(fbytes>=10)
  6340. {
  6341. strcpy(fmtstr,"%*6.3fM");
  6342. }
  6343. else
  6344. {
  6345. strcpy(fmtstr,"%*6.4fM");
  6346. }
  6347. }
  6348. else
  6349. {
  6350. if(fbytes>=100)
  6351. {
  6352. strcpy(fmtstr,"%*6.2fK");
  6353. }
  6354. else if(fbytes>=10)
  6355. {
  6356. strcpy(fmtstr,"%*6.3fK");
  6357. }
  6358. }
  6359. fmt_Printf(py->sx/8,py->sy,MMI_FOCUS_ASC5_7,fmtstr,(void *)(&fbytes));
  6360. }
  6361. else
  6362. {
  6363. fmt_Printf(py->sx/8,py->sy,MMI_FOCUS_ASC5_7,fmtstr,(void *)(&ubytes));
  6364. }
  6365. }
  6366. else
  6367. {
  6368. float ycdata;
  6369. if(index==0)
  6370. {
  6371. ycdata=0;
  6372. }
  6373. else
  6374. {
  6375. ycdata=GetRmtMeaVal(owner,index-1,NULL)/65536.0;
  6376. }
  6377. fmt_Printf(py->sx/8,py->sy,MMI_FOCUS_ASC5_7,(char *)py->fmtstr,(void *)(&ycdata));
  6378. }
  6379. }
  6380. }
  6381. int mmd_freshmain(void)
  6382. {
  6383. mmd_freshmainunit(false);
  6384. return M_OK;
  6385. }
  6386. unsigned char m_LockIcon[2];
  6387. int mmd_mainimageKey(int key)
  6388. {
  6389. if(key==HA_KEY_ENTER) //
  6390. {
  6391. g_tLcdComm.bLock=!g_tLcdComm.bLock;
  6392. if(g_tLcdComm.bLock)m_LockIcon[0]='\1';
  6393. else m_LockIcon[0]=' ';
  6394. m_LockIcon[1]=0;
  6395. }
  6396. if(key==((g_tScreen.lcd_type==LCD_TYPE_6KEY)?HA_KEY_LEFT:HA_KEY_ESC)) // 老版本按键6键,左键为取消键
  6397. {
  6398. g_tLcdComm.bLock=false;
  6399. m_LockIcon[0]=' ';
  6400. m_LockIcon[1]=0;
  6401. }
  6402. return M_OK;
  6403. }
  6404. int mmd_ClearQUA(int value)
  6405. {
  6406. SaveUqua(true);
  6407. strcpy(m_WarningStr,"电压合格率清零");
  6408. return M_JUMP3;
  6409. }
  6410. int mmd_ClearIMP(int value)
  6411. {
  6412. int sw;
  6413. for(sw=0;sw<SWITCH_NUM_MAX;sw++)
  6414. {
  6415. g_sw[sw].ac_in[SW_AC_IN_IMP1]=0;
  6416. g_sw[sw].ac_in[SW_AC_IN_IMP2]=0;
  6417. }
  6418. strcpy(m_WarningStr,"脉冲计数值清零");
  6419. return M_JUMP3;
  6420. }
  6421. int mmd_FA_Unlock(int value)
  6422. {
  6423. g_run_stu.rmtjs= true;
  6424. #ifdef FUNC_ONLY_MMD_JS
  6425. g_run_stu.b_mmdjs= true;
  6426. #endif
  6427. strcpy(m_WarningStr,"FA闭锁解除");
  6428. return M_JUMP3;
  6429. }
  6430. int mmd_testKey(int key)
  6431. {
  6432. if(key==HA_KEY_LEFT) strcpy(m_WarningStr,"左键 ");
  6433. else if(key==HA_KEY_RIGHT) strcpy(m_WarningStr,"右键 ");
  6434. else if(key==HA_KEY_UP) strcpy(m_WarningStr,"上键 ");
  6435. else if(key==HA_KEY_DOWN) strcpy(m_WarningStr,"下键 ");
  6436. else if(key==HA_KEY_ENTER) strcpy(m_WarningStr,"确认键 ");
  6437. else if(key==HA_KEY_ESC) strcpy(m_WarningStr,"取消键 ");
  6438. else if(key==HA_KEY_RST) strcpy(m_WarningStr,"复归键 ");
  6439. else if(key==HA_KEY_ADD) strcpy(m_WarningStr,"加键 ");
  6440. else if(key==HA_KEY_SUB) strcpy(m_WarningStr,"减键 ");
  6441. else return M_JUMP0;
  6442. return M_OK;
  6443. }
  6444. int mmd_clearWarnStr(int val)
  6445. {
  6446. strcpy(m_WarningStr,"");
  6447. return M_OK;
  6448. }
  6449. int mmd_DIDOTest(int value)
  6450. {
  6451. char tmpbuf[8],tmpstr[4];
  6452. int i;
  6453. bool bs=false;
  6454. tmpbuf[0] = 1; // DO板卡
  6455. tmpbuf[1] = 1; // DI板卡
  6456. dido_auto_test(tmpbuf,1);
  6457. if(dido_buf[1]) // 开出异常
  6458. {
  6459. strcpy(m_WarningStr,"开出");
  6460. for(i=0;i<5;i++)
  6461. {
  6462. if((dido_buf[1]>>i)&0x01)
  6463. {
  6464. sprintf(tmpstr,"%d ",i+1);
  6465. strcat(m_WarningStr,tmpstr);
  6466. }
  6467. }
  6468. strcat(m_WarningStr,"异常");
  6469. return M_JUMP3;
  6470. }
  6471. strcpy(m_WarningStr,"开入");
  6472. if(dido_buf[6]) // 开如 1-8异常
  6473. {
  6474. bs=true;
  6475. for(i=0;i<8;i++)
  6476. {
  6477. if((dido_buf[6]>>i)&0x01)
  6478. {
  6479. sprintf(tmpstr,"%d ",i+1);
  6480. strcat(m_WarningStr,tmpstr);
  6481. if(strlen(m_WarningStr)>=15)
  6482. {
  6483. strcat(m_WarningStr,"异常");
  6484. return M_JUMP3;
  6485. }
  6486. }
  6487. }
  6488. }
  6489. if(dido_buf[7]) // 开如 1-8异常
  6490. {
  6491. bs=true;
  6492. for(i=0;i<8;i++)
  6493. {
  6494. if(((dido_buf[7]>>i)&0x01)&&bs)
  6495. {
  6496. sprintf(tmpstr,"%d ",i+9);
  6497. strcat(m_WarningStr,tmpstr);
  6498. if(strlen(m_WarningStr)>=15)
  6499. {
  6500. strcat(m_WarningStr,"异常");
  6501. return M_JUMP3;
  6502. }
  6503. }
  6504. }
  6505. }
  6506. if(dido_buf[8]) // 开如 1-8异常
  6507. {
  6508. bs=true;
  6509. for(i=0;i<8;i++)
  6510. {
  6511. if(((dido_buf[8]>>i)&0x01)&&bs)
  6512. {
  6513. sprintf(tmpstr,"%d ",i+17);
  6514. strcat(m_WarningStr,tmpstr);
  6515. if(strlen(m_WarningStr)>=15)
  6516. {
  6517. strcat(m_WarningStr,"异常");
  6518. return M_JUMP3;
  6519. }
  6520. }
  6521. }
  6522. }
  6523. if(bs)
  6524. {
  6525. strcat(m_WarningStr,"异常");
  6526. }
  6527. else
  6528. {
  6529. strcpy(m_WarningStr,"开入开出测试正常");
  6530. }
  6531. return M_JUMP3;
  6532. }
  6533. static void mmd_GetSetGroupValue(int i,DATA_FIELD_DEF *pF)
  6534. {
  6535. int index;
  6536. if(m_setgroup[i])
  6537. {
  6538. sprintf(pF->FmtStr,"%-16.16s 投",SetGroups[i].item_name);
  6539. }
  6540. else
  6541. {
  6542. sprintf(pF->FmtStr,"%-16.16s 退",SetGroups[i].item_name);
  6543. }
  6544. index=mmi_GetActiveFieldIndex();
  6545. sprintf(m_equipstr,"%s",SetGroups[index].group_name);
  6546. }
  6547. int mmd_RenewSetGroup(void)
  6548. {
  6549. mmd_RenewDataMenu(&g_tDataMenu1);
  6550. return M_OK;
  6551. }
  6552. int mmd_InitSetGroup(int value)
  6553. {
  6554. bool bret;
  6555. bret=ReadEppData(EEP_SETGROUP_ADDR,m_setgroup,GROUP_NUM);
  6556. if(!bret)
  6557. {
  6558. GetDefSetGroup(m_setgroup);
  6559. }
  6560. mmd_initDataMenu(&g_tDataMenu1,GROUP_NUM,mmd_RenewSetGroup,mmd_GetSetGroupValue,188,1);
  6561. return M_OK;
  6562. }
  6563. int mmd_ChangeSetGroup(int value)
  6564. {
  6565. int index=mmi_GetActiveFieldIndex();
  6566. if(m_setgroup[index])
  6567. {
  6568. m_setgroup[index]=0;
  6569. }
  6570. else
  6571. {
  6572. m_setgroup[index]=1;
  6573. }
  6574. mmd_RenewDataMenu(&g_tDataMenu1);
  6575. return M_OK;
  6576. }
  6577. int mmd_SaveSetGroup(int value)
  6578. {
  6579. SaveEppData(EEP_SETGROUP_ADDR,m_setgroup,GROUP_NUM);
  6580. return M_JUMP0;
  6581. }
  6582. WORD m_srcsection;
  6583. WORD m_dstsection;
  6584. WORD m_maxsection;
  6585. int mmd_changesection(int value)
  6586. {
  6587. #ifdef PUB_SET_SECTION
  6588. int i;
  6589. #endif
  6590. if(m_dstsection>=SEC_NUMBER||m_runsection==m_dstsection)
  6591. {
  6592. strcpy(m_WarningStr,"切换区号异常");
  6593. return M_JUMP3;
  6594. }
  6595. //切换定值区,重新初始化运行定值区
  6596. m_runsection=m_dstsection;
  6597. #ifdef PUB_SET_SECTION
  6598. for(i=0;i<SEC_NUMBER;i++)
  6599. {
  6600. /*读取公共定值*/
  6601. if(!ReadPara((void*)m_SetBuf,EEP_PUB_ADDR+PUB_SETSIZE*i,PUB_SET_NUMBER,&tPubSetTable[0]))
  6602. {
  6603. rt_err_set(ERR_CODE_SET_PUB,0);
  6604. GetDefPara((void*)m_SetBuf,PUB_SET_NUMBER,&tPubSetTable[0]);
  6605. }
  6606. else
  6607. {
  6608. rt_err_clr(ERR_CODE_SET_PUB,0);
  6609. }
  6610. m_SetBuf[SET_SECTION].ff=m_dstsection;
  6611. SavePara((void *)m_SetBuf,EEP_PUB_ADDR+PUB_SETSIZE*i,PUB_SET_NUMBER,&tPubSetTable[0]);
  6612. if(i == m_runsection)
  6613. {
  6614. MakeRunSet(false);
  6615. }
  6616. }
  6617. #else
  6618. /*读取公共定值*/
  6619. if(!ReadPara((void*)m_SetBuf,EEP_PUB_ADDR,PUB_SET_NUMBER,&tPubSetTable[0]))
  6620. {
  6621. rt_err_set(ERR_CODE_SET_PUB,0);
  6622. GetDefPara((void*)m_SetBuf,PUB_SET_NUMBER,&tPubSetTable[0]);
  6623. }
  6624. else
  6625. {
  6626. rt_err_clr(ERR_CODE_SET_PUB,0);
  6627. }
  6628. m_SetBuf[SET_SECTION].ff=m_dstsection;
  6629. SavePara((void *)m_SetBuf,EEP_PUB_ADDR,PUB_SET_NUMBER,&tPubSetTable[0]);
  6630. MakeRunSet(false);
  6631. #endif
  6632. return M_JUMP0;
  6633. }
  6634. int mmd_copysection(int value)
  6635. {
  6636. if(m_runsection==m_dstsection)
  6637. {
  6638. strcpy(m_WarningStr,"运行区不能复制");
  6639. return M_JUMP3;
  6640. }
  6641. if(m_dstsection>=SEC_NUMBER||m_srcsection>=SEC_NUMBER)
  6642. {
  6643. strcpy(m_WarningStr,"区号超出范围");
  6644. return M_JUMP3;
  6645. }
  6646. /*读取公共定值*/
  6647. if(!ReadPara((void*)m_SetBuf,EEP_SET_ADDR+(m_srcsection)*SETSIZE,SW_SET_NUMBER,&tSwSetTable[0]))
  6648. {
  6649. strcpy(m_WarningStr,"源定值区读取错误");
  6650. return M_JUMP3;
  6651. }
  6652. SavePara((void*)m_SetBuf,EEP_SET_ADDR+(m_dstsection)*SETSIZE,SW_SET_NUMBER,&tSwSetTable[0]);
  6653. strcpy(m_WarningStr,"定值区复制成功");
  6654. return M_JUMP3;
  6655. }
  6656. int mmd_initSection(int value)
  6657. {
  6658. m_maxsection=(SEC_NUMBER-1);
  6659. m_srcsection=m_runsection;
  6660. m_dstsection=m_runsection+1;
  6661. if(m_dstsection>=SEC_NUMBER)m_dstsection=0;
  6662. return M_OK;
  6663. }
  6664. int _Run61850(void)
  6665. {
  6666. int ret=0;
  6667. //char *envp[] = { NULL };
  6668. //char *cmd[] = {"/app/fs61850.ko", "&", NULL}; //调用shell脚本,关闭对应端口
  6669. //ret=call_usermodehelper("/app/fs61850.ko", cmd, envp, UMH_WAIT_PROC);
  6670. //rt_printf("\r\n run 61850 ret=%d\r\n",ret);
  6671. return ret;
  6672. }
  6673. static bool b61850run=true;
  6674. int _Stop61850(void)
  6675. {
  6676. int ret=0;
  6677. //char *envp[] = { NULL };
  6678. //char *cmd[] = {"/usr/bin/killall", "fs61850.ko", NULL}; //调用shell脚本,关闭对应端口
  6679. //ret=call_usermodehelper("/usr/bin/killall", cmd, envp, UMH_WAIT_PROC);
  6680. //rt_printf("\r\nkillall 61850 ret=%d\r\n",ret);
  6681. return ret;
  6682. }
  6683. int mmd_Stop61850(int value)
  6684. {
  6685. int ret=0;
  6686. if(b61850run)
  6687. {
  6688. ret=_Stop61850();
  6689. sprintf(m_WarningStr,"停止61850库ret=%d",ret);
  6690. }
  6691. else
  6692. {
  6693. //ret=_Run61850();
  6694. sprintf(m_WarningStr,"装置重启/",ret);
  6695. watchdog_reset_cpu(2);
  6696. }
  6697. b61850run=!b61850run;
  6698. return M_JUMP3;
  6699. }
  6700. static void mmd_getmenumea(u8 *buf)
  6701. {
  6702. u8 str[128];
  6703. u8 str1[128];
  6704. int len,i;
  6705. int index=-1;
  6706. len=iec_findchardot(buf,str);
  6707. if(len==0)return;
  6708. if(strcmp(str,"MEA")==0) //测量值
  6709. {
  6710. buf+=len+1;
  6711. len=iec_findchardot(buf,str);
  6712. if(len==0)return;
  6713. for(i=0;i<SW_AC_NUM_ALL;i++)
  6714. {
  6715. if(strcmp(str,g_sw_ac_desc[i].name)==0)
  6716. {
  6717. index=i;
  6718. break;
  6719. }
  6720. }
  6721. if(index==-1)
  6722. {
  6723. for(i=0;i<PUB_AC_NUM_ALL;i++)
  6724. {
  6725. if(strcmp(str,g_pub_ac_desc[i].name)==0)
  6726. {
  6727. index=SW_AC_MENU_NUM+i;
  6728. break;
  6729. }
  6730. }
  6731. }
  6732. if(index>=0)
  6733. {
  6734. int j;
  6735. buf+=len+1;
  6736. len=iec_findchardot(buf,str1);
  6737. if(len==0)return;
  6738. j=strtoul(str1,NULL,10);
  6739. //j=strtoul(buf,NULL,10);
  6740. if(j>0)
  6741. {
  6742. j-=1;
  6743. if(j>=MEA_MENU_MAX)return;
  6744. tMenuMea.index[j]=index;
  6745. tMenuMea.num++;
  6746. }
  6747. }
  6748. }
  6749. }
  6750. //#ifdef YPARA_LINK
  6751. void print_yparatable(void)
  6752. {
  6753. int i=0;
  6754. if(ParaIDNum >0) rt_printf("-------ParaIDNum=%d\r\n",ParaIDNum);
  6755. for(i=0;i<ParaIDNum;i++)
  6756. {
  6757. if(i%50 == 0) msleep(500);
  6758. if(tParaID[i].link_ch == 0)
  6759. {
  6760. rt_printf("local----parId = %x,group_type=%d,setno = %d\r\n ",tParaID[i].parId,tParaID[i].group_type,tParaID[i].setno);
  6761. }
  6762. else
  6763. {
  6764. rt_printf("link----link_ch = %d,parId=%x,link_cp = %x\r\n ",tParaID[i].link_ch,tParaID[i].parId,tParaID[i].link_cp);
  6765. }
  6766. }
  6767. }
  6768. /*获取通道号类型*/
  6769. int get_chnl_index(char *name)
  6770. {
  6771. int val = 0;
  6772. if(strcmp(name,"网络")==0) /*本地,不级联*/
  6773. {
  6774. val = LINK_NET;
  6775. }
  6776. else if(strstr(name,"串口")) /*本地,不级联*/
  6777. {
  6778. sscanf(name, "串口%d", &val); /*数据长度*/
  6779. if(val >= (CFG_UART_NUM_MAX+1)) return -1;
  6780. val += 1;
  6781. }
  6782. return val;
  6783. }
  6784. //#endif
  6785. static void mmd_getmenuset(u8 *buf)
  6786. {
  6787. u8 str[128],str1[128],str2[128],strpara[128];
  6788. int val_rd_only=0;
  6789. int len,i;
  6790. int val;
  6791. u32 paraid,chnl=0,index=0,link_cp=0;
  6792. //rt_printf("-----------------\r\n");
  6793. len=iec_findchardot(buf,str);
  6794. if(len==0)return;
  6795. if(strcmp(str,"SET")==0) //定值
  6796. {
  6797. buf+=len+1;
  6798. len=iec_findchardot(buf,str);
  6799. if(len==0)return;
  6800. buf+=len+1;
  6801. len=iec_findchardot(buf,str1);
  6802. if(len==0)return;
  6803. buf+=len+1;
  6804. len=iec_findchardot(buf,str2);
  6805. if(len==0)return;
  6806. buf+=len+1;
  6807. len=iec_findchardot(buf,strpara);
  6808. if(len==0)return;
  6809. val=strtoul(strpara,NULL,10);
  6810. //rt_printf("val=%d,len=%d\r\n",val,len);
  6811. buf+=len+1;
  6812. len=iec_findchardot(buf,strpara); //通信点号
  6813. if(len==0)return;
  6814. paraid=strtoul(strpara,NULL,16);
  6815. buf+=len+1;
  6816. /*兼容老lcd,没相关字段不return,默认为0*/
  6817. len=iec_findchardot(buf,strpara); //只读
  6818. if(len > 0)
  6819. {
  6820. val_rd_only = strtoul(strpara,NULL,10);
  6821. buf+=len+1;
  6822. }
  6823. len=iec_findchardot(buf,strpara); /*级联通道*/
  6824. if(len > 0)
  6825. {
  6826. chnl = get_chnl_index(strpara);
  6827. buf+=len+1;
  6828. }
  6829. len=iec_findchardot(buf,strpara); /*级联序号*/
  6830. if(len > 0)
  6831. {
  6832. index=strtoul(strpara,NULL,10);
  6833. buf+=len+1;
  6834. }
  6835. len=iec_findchardot(buf,strpara);
  6836. if(len > 0)
  6837. {
  6838. link_cp=strtoul(strpara,NULL,16); /*级联点号*/
  6839. buf+=len+1;
  6840. }
  6841. //if(paraid > 0)
  6842. //{
  6843. //rt_printf("paraid=%x,val_rd_only=%x,chnl=%x,index=%x,link_cp=%x\r\n",paraid,val_rd_only,chnl,index,link_cp);
  6844. //}
  6845. //len=iec_findchardot(buf,strpara); /*级联点号*/
  6846. //if(len==0)return;
  6847. if((chnl == 0) && (index == 0))
  6848. {
  6849. for(i=0;i<SET_PUB_NUM;i++)
  6850. {
  6851. if((strcmp(str,tPubSetTable[i].szName)==0)&&(strcmp(str1,SetGroups[tPubSetTable[i].group].group_name)==0)&&(strcmp(str2,SetGroups[tPubSetTable[i].group].item_name)==0))
  6852. {
  6853. bPubSetMenuShow[i]=val;
  6854. if((paraid>0) && (ParaIDNum <MAX_SET_NUMBER)) // 定值参数修改的点号
  6855. {
  6856. tParaID[ParaIDNum].group_type=SETGROUP_TYPE_PUB;
  6857. tParaID[ParaIDNum].parId=paraid;
  6858. if(val_rd_only) tParaID[ParaIDNum].b_rd_only = true;
  6859. tParaID[ParaIDNum].setno=i;
  6860. tParaID[ParaIDNum].link_ch = (chnl<<5) + (index&0x1F);
  6861. ParaIDNum++;
  6862. }
  6863. return;
  6864. }
  6865. }
  6866. for(i=0;i<SET_NUM;i++)
  6867. {
  6868. if((strcmp(str,tSwSetTable[i].szName)==0)&&(strcmp(str1,SetGroups[tSwSetTable[i].group].group_name)==0)&&(strcmp(str2,SetGroups[tSwSetTable[i].group].item_name)==0))
  6869. {
  6870. bSwSetMenuShow[i]=val;
  6871. if((paraid>0) && (ParaIDNum <MAX_SET_NUMBER)) // 定值参数修改的点号
  6872. {
  6873. tParaID[ParaIDNum].group_type=SETGROUP_TYPE_BH;
  6874. tParaID[ParaIDNum].parId=paraid;
  6875. if(val_rd_only) tParaID[ParaIDNum].b_rd_only = true;
  6876. tParaID[ParaIDNum].setno=i;
  6877. tParaID[ParaIDNum].link_ch = (chnl<<5) + (index&0x1F);
  6878. ParaIDNum++;
  6879. }
  6880. return;
  6881. }
  6882. }
  6883. for(i=0;i<PARA_NUM;i++)
  6884. {
  6885. if((strcmp(str,tEquipParaTable[i].szName)==0)&&(strcmp(str1,SetGroups[tEquipParaTable[i].group].group_name)==0)&&(strcmp(str2,SetGroups[tEquipParaTable[i].group].item_name)==0))
  6886. {
  6887. bParaSetMenuShow[i]=val;
  6888. if((paraid>0) && (ParaIDNum <MAX_SET_NUMBER)) // 定值参数修改的点号
  6889. {
  6890. tParaID[ParaIDNum].group_type=SETGROUP_TYPE_PARA;
  6891. tParaID[ParaIDNum].parId=paraid;
  6892. if(val_rd_only) tParaID[ParaIDNum].b_rd_only = true;
  6893. tParaID[ParaIDNum].setno=i;
  6894. tParaID[ParaIDNum].link_ch = (chnl<<5) + (index&0x1F);
  6895. ParaIDNum++;
  6896. }
  6897. return;
  6898. }
  6899. }
  6900. for(i=0;i<CSTSET_NUM;i++)
  6901. {
  6902. if((strcmp(str,tCstSetTable[i].szName)==0)&&(strcmp(str1,SetGroups[tCstSetTable[i].group].group_name)==0)&&(strcmp(str2,SetGroups[tCstSetTable[i].group].item_name)==0))
  6903. {
  6904. bCstSetMenuShow[i]=val;
  6905. if((paraid>0) && (ParaIDNum <MAX_SET_NUMBER)) // 定值参数修改的点号
  6906. {
  6907. tParaID[ParaIDNum].group_type=SETGROUP_TYPE_CSTSET;
  6908. tParaID[ParaIDNum].parId=paraid;
  6909. tParaID[ParaIDNum].setno=i;
  6910. tParaID[ParaIDNum].link_ch = (chnl<<5) + (index&0x1F);
  6911. ParaIDNum++;
  6912. }
  6913. return;
  6914. }
  6915. }
  6916. }
  6917. else
  6918. {
  6919. if((paraid>0) && (ParaIDNum <MAX_SET_NUMBER)) // 定值参数修改的点号
  6920. {
  6921. tParaID[ParaIDNum].parId=paraid;
  6922. tParaID[ParaIDNum].link_ch = (chnl<<5) + (index&0x1F);
  6923. tParaID[ParaIDNum].link_cp = link_cp;
  6924. ParaIDNum++;
  6925. }
  6926. }
  6927. }
  6928. }
  6929. bool g_bVipSoe_show;
  6930. static void mmd_getmenuSoeShow(u8 *buf)
  6931. {
  6932. u8 str[128];
  6933. u8 str1[128];
  6934. int len;
  6935. int val;
  6936. len=iec_findchardot(buf,str);
  6937. if(len==0)return;
  6938. if(strcmp(str,"EVENT_SHOW")==0) // 关键记录显示定义
  6939. {
  6940. buf+=len+1;
  6941. len=iec_findchardot(buf,str);
  6942. if(len==0)return;
  6943. buf+=len+1;
  6944. len=iec_findchardot(buf,str1);
  6945. if(len==0)return;
  6946. val=strtoul(str1,NULL,10);
  6947. //val=strtoul(buf,NULL,10);
  6948. if(val==0)
  6949. {
  6950. g_bVipSoe_show=false;
  6951. return;
  6952. }
  6953. }
  6954. }
  6955. #ifdef FUNC_YT_HARD_YB
  6956. const short sw_yt_hard_yb_index[]=
  6957. {
  6958. SW_DI_BHZTT, // 保护总功能投退压板
  6959. SW_DI_BHTT, // 常规保护投退压板
  6960. SW_DI_CHZ, // 重合闸压板
  6961. SW_DI_FA_TT, // 就地FA压板
  6962. SW_DI_FA_GOOSE, //智能FA压板
  6963. SW_DI_FA_LS, //联络/分段模式
  6964. SW_DI_SAFE_AUTO, //安全自动控制
  6965. };
  6966. const int YT_SW_HARD_YB_NUM = (sizeof(sw_yt_hard_yb_index)/sizeof(sw_yt_hard_yb_index[0]));
  6967. const short pub_yt_hard_yb_index[]=
  6968. {
  6969. PUB_DI_JX, //检修压板
  6970. PUB_DI_YF, // 远方
  6971. PUB_DI_JD, // 就地
  6972. };
  6973. const int YT_PUB_HARD_YB_NUM = (sizeof(pub_yt_hard_yb_index)/sizeof(pub_yt_hard_yb_index[0]));
  6974. #ifdef FUNC_YT_MIX
  6975. u32 tHardYBID[SW_DI_NUM+PUB_DI_NUM+MIX_YT_NUM];
  6976. #else
  6977. u32 tHardYBID[SW_DI_NUM+PUB_DI_NUM];
  6978. #endif
  6979. static void mmd_getmenuHardYB(u8 *buf)
  6980. {
  6981. u8 str[128];
  6982. u8 str1[128];
  6983. int len;
  6984. int i;
  6985. u32 paraid=0;
  6986. len=iec_findchardot(buf,str);
  6987. if(len==0)return;
  6988. if(strcmp(str,"HARD_YB")==0)
  6989. {
  6990. buf+=len+1;
  6991. len=iec_findchardot(buf,str);
  6992. if(len==0)return;
  6993. buf+=len+1;
  6994. len=iec_findchardot(buf,str1);
  6995. if(len==0)return;
  6996. paraid=strtoul(str1,NULL,16);
  6997. //paraid=strtoul(buf,NULL,16);
  6998. }
  6999. for(i=0;i<YT_SW_HARD_YB_NUM;i++)
  7000. {
  7001. if(strcmp(str,g_sw_di_name[sw_yt_hard_yb_index[i]])==0)
  7002. {
  7003. if(paraid>0)
  7004. {
  7005. tHardYBID[i] = paraid;
  7006. }
  7007. return;
  7008. }
  7009. }
  7010. for(i=0;i<YT_PUB_HARD_YB_NUM;i++)
  7011. {
  7012. if(strcmp(str,g_pub_di_name[pub_yt_hard_yb_index[i]])==0)
  7013. {
  7014. if(paraid>0)
  7015. {
  7016. tHardYBID[YT_SW_HARD_YB_NUM+i] = paraid;
  7017. }
  7018. return;
  7019. }
  7020. }
  7021. #ifdef FUNC_YT_MIX
  7022. for(i=0;i<MIX_YT_NUM;i++)
  7023. {
  7024. if(strcmp(str,mix_yt_index[i])==0)
  7025. {
  7026. if(paraid>0)
  7027. {
  7028. tHardYBID[YT_SW_HARD_YB_NUM+YT_PUB_HARD_YB_NUM+i] = paraid;
  7029. }
  7030. return;
  7031. }
  7032. }
  7033. #endif
  7034. }
  7035. #endif
  7036. int mmd_menu_cfg_init(void)
  7037. {
  7038. u32 i,file_length;
  7039. struct file * pfile;
  7040. u8 *filebuf;
  7041. u8 filestr[128],*pstr,strlenth;
  7042. loff_t pos;
  7043. tMenuMea.num=0;
  7044. memset(bPubSetMenuShow,1,SET_PUB_NUM);
  7045. memset(bSwSetMenuShow,1,SET_NUM);
  7046. memset(bParaSetMenuShow,1,PARA_NUM);
  7047. memset(bCstSetMenuShow,1,CSTSET_NUM);
  7048. memset(&tParaID[0],0,sizeof(SET_PARAID)*MAX_SET_NUMBER);
  7049. #ifdef FUNC_YT_HARD_YB
  7050. #ifdef FUNC_YT_MIX
  7051. memset(tHardYBID,0,(SW_DI_NUM+PUB_DI_NUM+MIX_YT_NUM));
  7052. #else
  7053. memset(tHardYBID,0,(SW_DI_NUM+PUB_DI_NUM));
  7054. #endif
  7055. #endif
  7056. ParaIDNum=0;
  7057. #ifdef YPARA_LINK
  7058. memset(&tPara_val[0],0,sizeof(SET_PARA_VAL)*MAX_SET_NUMBER);
  7059. #endif
  7060. g_bVipSoe_show=true;
  7061. // 打开文件
  7062. pfile = rt_file_open("/app/data/lcd_menu.csv",O_RDONLY ,0);
  7063. if(IS_ERR(pfile))
  7064. {
  7065. dp_err_n_c_rt("无法打开 lcd_menu.csv,新建...\r\n");
  7066. mmd_create_menufile();
  7067. pfile = rt_file_open("/app/data/lcd_menu.csv",O_RDONLY ,0);
  7068. if(IS_ERR(pfile))
  7069. return -1;
  7070. }
  7071. // 得到文件长度
  7072. file_length = rt_file_getfile_size(pfile);
  7073. if(file_length <= 0)
  7074. {
  7075. rt_file_close(pfile,0);
  7076. return -2;
  7077. }
  7078. // 分配内存
  7079. filebuf = rt_malloc(file_length);
  7080. if((filebuf) == NULL)
  7081. {
  7082. rt_file_close(pfile,0);
  7083. return -3;
  7084. }
  7085. pos = 0;
  7086. if(rt_file_read(pfile,filebuf,file_length,&pos) != file_length)
  7087. {
  7088. rt_file_close(pfile,0);
  7089. rt_free(filebuf);
  7090. return -4;
  7091. }
  7092. pstr = filestr;
  7093. strlenth=0; // 纠错处理
  7094. //找到\r\n位置,得到一行长度
  7095. for(i = 0; i < file_length; i++)
  7096. {
  7097. *pstr++=filebuf[i];
  7098. strlenth++;
  7099. if(filebuf[i] == 0x0a||strlenth>=128)
  7100. {
  7101. pstr-=2; // 去掉回车换行
  7102. *pstr++=','; //增加逗号
  7103. *pstr='\0';
  7104. mmd_getmenumea(filestr);
  7105. mmd_getmenuset(filestr);
  7106. mmd_getmenuSoeShow(filestr);
  7107. #ifdef FUNC_YT_HARD_YB
  7108. mmd_getmenuHardYB(filestr);
  7109. #endif
  7110. pstr=filestr;
  7111. strlenth=0;
  7112. }
  7113. }
  7114. #if 0
  7115. print_yparatable();
  7116. #endif
  7117. rt_file_close(pfile,0); // 关闭文件
  7118. rt_free(filebuf); // 释放内存
  7119. #if 0
  7120. //打印调试信息
  7121. for(i=0;i<tMenuMea.num;i++)
  7122. {
  7123. if(tMenuMea.index[i])rt_printf("\r\nMEA%d index=%d",i+1,tMenuMea.index[i]);
  7124. }
  7125. for(i=0;i<SET_PUB_NUM;i++)
  7126. {
  7127. if(bPubSetMenuShow[i]&&(tPubSetTable[i].wType!=SETTYPE_LABEL))rt_printf("\r\n%s ",tPubSetTable[i].szName);
  7128. }
  7129. for(i=0;i<SET_NUM;i++)
  7130. {
  7131. if(bSwSetMenuShow[i]&&(tSwSetTable[i].wType!=SETTYPE_LABEL)) rt_printf("\r\n%s ",tSwSetTable[i].szName);
  7132. }
  7133. for(i=0;i<ParaIDNum;i++)
  7134. {
  7135. if(tParaID[i].group_type==SETGROUP_TYPE_PUB)
  7136. {
  7137. rt_printf("\r\n%s %04x :%d",tPubSetTable[tParaID[i].setno].szName, tParaID[i].parId,tParaID[i].setno);
  7138. }
  7139. }
  7140. for(i=0;i<ParaIDNum;i++)
  7141. {
  7142. if(tParaID[i].group_type==SETGROUP_TYPE_BH)
  7143. {
  7144. rt_printf("\r\n%s %04x :%d",tSwSetTable[tParaID[i].setno].szName, tParaID[i].parId,tParaID[i].setno);
  7145. }
  7146. }
  7147. for(i=0;i<ParaIDNum;i++)
  7148. {
  7149. if(tParaID[i].group_type==SETGROUP_TYPE_PARA)
  7150. {
  7151. rt_printf("\r\n%s %04x :%d",tEquipParaTable[tParaID[i].setno].szName, tParaID[i].parId,tParaID[i].setno);
  7152. }
  7153. }
  7154. #endif
  7155. return 0;
  7156. }
  7157. void mmd_create_menufile(void)
  7158. {
  7159. char *p;
  7160. char tmpbuf[128];
  7161. struct file * pfile;
  7162. loff_t pos;
  7163. int i;
  7164. WORD addr=0;
  7165. p=tmpbuf;
  7166. // 创建描述文件
  7167. pfile = rt_file_open("/app/data/lcd_menu.csv",O_CREAT|O_RDWR|O_TRUNC,0);
  7168. if(IS_ERR(pfile))
  7169. {
  7170. return ;
  7171. }
  7172. pos = 0;
  7173. for(i=0;i<SW_AC_MENU_NUM;i++)
  7174. {
  7175. sprintf(p,"MEA,%s,0\r\n",g_sw_ac_desc[i].name);
  7176. rt_file_write(pfile,p,strlen(p),&pos);
  7177. }
  7178. for(i=0;i<PUB_AC_MENU_NUM;i++)
  7179. {
  7180. sprintf(p,"MEA,%s,0\r\n",g_pub_ac_desc[i].name);
  7181. rt_file_write(pfile,p,strlen(p),&pos);
  7182. }
  7183. sprintf(p,"my_set_desc,名称,组名,分组名,液晶显示,通信点号,只读,级联通道,级联地址,级联点号\r\n");
  7184. rt_file_write(pfile,p,strlen(p),&pos);
  7185. for(i=0;i<PUB_SET_NUMBER;i++)
  7186. {
  7187. //if(tPubSetTable[i].wType!=SETTYPE_LABEL)
  7188. {
  7189. addr = GetCstValForwardAddr(SETGROUP_TYPE_PUB,i);
  7190. sprintf(p,"SET,%s,%s,%s,1,0x%x,0,0,0,0\r\n",tPubSetTable[i].szName,SetGroups[tPubSetTable[i].group].group_name,SetGroups[tPubSetTable[i].group].item_name,addr);
  7191. rt_file_write(pfile,p,strlen(p),&pos);
  7192. }
  7193. }
  7194. for(i=0;i<SW_SET_NUMBER;i++)
  7195. {
  7196. //if(tSwSetTable[i].wType!=SETTYPE_LABEL)
  7197. {
  7198. addr = GetCstValForwardAddr(SETGROUP_TYPE_BH,i);
  7199. sprintf(p,"SET,%s,%s,%s,1,0x%x,0,0,0,0\r\n",tSwSetTable[i].szName,SetGroups[tSwSetTable[i].group].group_name,SetGroups[tSwSetTable[i].group].item_name,addr);
  7200. rt_file_write(pfile,p,strlen(p),&pos);
  7201. }
  7202. }
  7203. for(i=0;i<EQUIP_PARA_NUMBER;i++)
  7204. {
  7205. //if(tEquipParaTable[i].wType!=SETTYPE_LABEL)
  7206. {
  7207. addr = GetCstValForwardAddr(SETGROUP_TYPE_PARA,i);
  7208. sprintf(p,"SET,%s,%s,%s,1,0x%x,0,0,0,0\r\n",tEquipParaTable[i].szName,SetGroups[tEquipParaTable[i].group].group_name,SetGroups[tEquipParaTable[i].group].item_name,addr);
  7209. rt_file_write(pfile,p,strlen(p),&pos);
  7210. }
  7211. }
  7212. for(i=0;i<CSTSET_NUMBER;i++)
  7213. {
  7214. //if(tEquipParaTable[i].wType!=SETTYPE_LABEL)
  7215. {
  7216. addr = GetCstValForwardAddr(SETGROUP_TYPE_CSTSET,i);
  7217. sprintf(p,"SET,%s,%s,%s,1,0x%x,0,0,0,0\r\n",tCstSetTable[i].szName,SetGroups[tCstSetTable[i].group].group_name,SetGroups[tCstSetTable[i].group].item_name,addr);
  7218. rt_file_write(pfile,p,strlen(p),&pos);
  7219. }
  7220. }
  7221. strcpy(p,"EVENT_SHOW,SOE弹出关键记录,1\r\n");
  7222. rt_file_write(pfile,p,strlen(p),&pos);
  7223. #ifdef FUNC_YT_HARD_YB
  7224. for(i=0;i<YT_SW_HARD_YB_NUM;i++)
  7225. {
  7226. sprintf(p,"HARD_YB,%s,0x0000\r\n",g_sw_di_name[sw_yt_hard_yb_index[i]]);
  7227. rt_file_write(pfile,p,strlen(p),&pos);
  7228. }
  7229. for(i=0;i<YT_PUB_HARD_YB_NUM;i++)
  7230. {
  7231. sprintf(p,"HARD_YB,%s,0x0000\r\n",g_pub_di_name[pub_yt_hard_yb_index[i]]);
  7232. rt_file_write(pfile,p,strlen(p),&pos);
  7233. }
  7234. #ifdef FUNC_YT_MIX
  7235. for(i=0;i<MIX_YT_NUM;i++)
  7236. {
  7237. sprintf(p,"HARD_YB,%s,0x0000\r\n",mix_yt_index[i]);
  7238. rt_file_write(pfile,p,strlen(p),&pos);
  7239. }
  7240. #endif
  7241. #endif
  7242. rt_file_close(pfile,0);
  7243. return ;
  7244. }
  7245. #ifdef FUN_SET_CHANGE_SOE
  7246. void log_operate_set_change(const TSETTABLE *pTable,u16 setno,long v1,long v2)
  7247. {
  7248. char namestr[128];
  7249. char tmpstr[64];
  7250. SET_VALUE ft;
  7251. sprintf(namestr,"%s(%s)",pTable->szName,SetGroups[pTable->group].item_name);
  7252. switch(pTable->wType)
  7253. {
  7254. case SETTYPE_F:
  7255. ft.tt=v1;
  7256. sprintf(tmpstr,"由:%.3f",ft.ff);
  7257. strcat(namestr,tmpstr);
  7258. ft.tt=v2;
  7259. sprintf(tmpstr,"改:%.3f",ft.ff);
  7260. strcat(namestr,tmpstr);
  7261. break;
  7262. case SETTYPE_UINT: //16进制显示 控制字
  7263. case SETTYPE_4INT: //10进制显示 4位
  7264. case SETTYPE_5INT: //10进制显示 5位
  7265. case SETTYPE_LINT: //16进制显示 控制字
  7266. ft.tt=v1;
  7267. sprintf(tmpstr,"由:%d",(u16)ft.tt);
  7268. strcat(namestr,tmpstr);
  7269. ft.tt=v2;
  7270. sprintf(tmpstr,"改:%d",(u16)ft.tt);
  7271. strcat(namestr,tmpstr);
  7272. break;
  7273. case SETTYPE_LIST: //列表选择
  7274. {
  7275. ft.tt=v1;
  7276. sprintf(tmpstr,"由:%s", pTable->list[(u16)ft.tt].str);
  7277. strcat(namestr,tmpstr);
  7278. ft.tt=v2;
  7279. sprintf(tmpstr,"改:%s", pTable->list[(u16)ft.tt].str);
  7280. strcat(namestr,tmpstr);
  7281. }
  7282. break;
  7283. case SETTYPE_IP:
  7284. {
  7285. u32 dat;
  7286. ft.tt=v1;
  7287. dat=(u32)ft.tt;
  7288. sprintf(tmpstr,"由:%d.%d.%d.%d", (dat>>24)&0xFF, (dat>>16)&0xFF, (dat>>8)&0xFF, (dat>>0)&0xFF);
  7289. strcat(namestr,tmpstr);
  7290. ft.tt=v2;
  7291. dat=(u32)ft.tt;
  7292. sprintf(tmpstr,"改:%d.%d.%d.%d", (dat>>24)&0xFF, (dat>>16)&0xFF, (dat>>8)&0xFF, (dat>>0)&0xFF);
  7293. strcat(namestr,tmpstr);
  7294. }
  7295. break;
  7296. case SETTYPE_YMD:
  7297. {
  7298. struct timespec ts;
  7299. struct rtc_time_t tTime;
  7300. memset(&ts, 0, sizeof(ts));
  7301. memset(&tTime, 0, sizeof(tTime));
  7302. ft.tt=v1;
  7303. ts.tv_sec = (long)ft.tt;
  7304. timespec_to_rtc(ts,&tTime,1);
  7305. sprintf(tmpstr,"由:%04d-%02d-%02d", 2000+tTime.year, tTime.month, tTime.day);
  7306. strcat(namestr,tmpstr);
  7307. ft.tt=v2;
  7308. ts.tv_sec = (long)ft.tt;
  7309. timespec_to_rtc(ts,&tTime,1);
  7310. sprintf(tmpstr,"改:%04d-%02d-%02d", 2000+tTime.year, tTime.month, tTime.day);
  7311. strcat(namestr,tmpstr);
  7312. }
  7313. break;
  7314. case SETTYPE_HMS:
  7315. {
  7316. struct timespec ts;
  7317. struct rtc_time_t tTime;
  7318. extern int timespec_to_rtchms(struct timespec ts, struct rtc_time_t * p_rtc,int is_round);
  7319. memset(&ts, 0, sizeof(ts));
  7320. memset(&tTime, 0, sizeof(tTime));
  7321. ft.tt=v1;
  7322. ts.tv_sec = (long)ft.tt;
  7323. timespec_to_rtchms(ts,&tTime,1);
  7324. sprintf(tmpstr,"由:%02d:%02d:%02d", tTime.hour, tTime.min, tTime.ms%1000);
  7325. strcat(namestr,tmpstr);
  7326. memset(&ts, 0, sizeof(ts));
  7327. memset(&tTime, 0, sizeof(tTime));
  7328. ft.tt=v2;
  7329. ts.tv_sec = (long)ft.tt;
  7330. timespec_to_rtchms(ts,&tTime,1);
  7331. sprintf(tmpstr," 改为:%02d:%02d:%02d", tTime.hour, tTime.min, tTime.ms%1000);
  7332. strcat(namestr,tmpstr);
  7333. }
  7334. default:
  7335. return;
  7336. }
  7337. log_str_time(LOG_OPERATE,namestr,0,0);
  7338. }
  7339. void para_change_check_soe(float *pf,DWORD wAddr,WORD num,const TSETTABLE *pTable)
  7340. {
  7341. SET_VALUE *pbuf;
  7342. int i;
  7343. pbuf = rt_malloc(MAX_SET_NUMBER*4);
  7344. if(!pbuf)
  7345. {
  7346. rt_printf("\r\npara_change_check_soe 定值变化检查,分配缓存失败!\r\n");
  7347. return;
  7348. }
  7349. if(!ReadPara((void*)pbuf,wAddr,num,pTable))
  7350. {
  7351. GetDefPara((void*)pbuf,num,pTable);
  7352. }
  7353. for(i=0;i<num;i++)
  7354. {
  7355. SET_VALUE ft,fval;
  7356. long v0=0;
  7357. if(pTable==(&tPubSetTable[0])) //公共定值
  7358. {
  7359. v0=(1<<16)|i;
  7360. }
  7361. else if(pTable==(&tSwSetTable[0])) //开关定值
  7362. {
  7363. v0=(2<<16)|i;
  7364. }
  7365. else if(pTable==(&tEquipParaTable[0])) //参数定值
  7366. {
  7367. v0=(3<<16)|i;
  7368. }
  7369. else if(pTable==(&tCstSetTable[0])) //内部定值
  7370. {
  7371. v0=(4<<16)|i;
  7372. }
  7373. if(mmd_IsHexType(pTable[i].wType))
  7374. {
  7375. u32 *pt;
  7376. pt=(u32*)(&pf[i]);
  7377. ft.tt=(u32)*pt;
  7378. fval.tt=(u32)(pbuf[i].tt);
  7379. }
  7380. else if (mmd_IsIntegType(pTable[i].wType))
  7381. {
  7382. ft.tt=(u32)pf[i];
  7383. fval.tt=(u32)pbuf[i].ff;
  7384. }
  7385. else
  7386. {
  7387. ft.ff=pf[i];
  7388. fval.ff=pbuf[i].ff;
  7389. }
  7390. if(ft.tt!=fval.tt)
  7391. {
  7392. soe_record_opt3(EV_SET_CHANGE_PARA,v0,fval.tt,ft.tt);
  7393. log_operate_set_change(&pTable[i],i,fval.tt,ft.tt);
  7394. }
  7395. }
  7396. rt_free(pbuf);
  7397. }
  7398. #endif