index.vue 163 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941942943944945946947948949950951952953954955956957958959960961962963964965966967968969970971972973974975976977978979980981982983984985986987988989990991992993994995996997998999100010011002100310041005100610071008100910101011101210131014101510161017101810191020102110221023102410251026102710281029103010311032103310341035103610371038103910401041104210431044104510461047104810491050105110521053105410551056105710581059106010611062106310641065106610671068106910701071107210731074107510761077107810791080108110821083108410851086108710881089109010911092109310941095109610971098109911001101110211031104110511061107110811091110111111121113111411151116111711181119112011211122112311241125112611271128112911301131113211331134113511361137113811391140114111421143114411451146114711481149115011511152115311541155115611571158115911601161116211631164116511661167116811691170117111721173117411751176117711781179118011811182118311841185118611871188118911901191119211931194119511961197119811991200120112021203120412051206120712081209121012111212121312141215121612171218121912201221122212231224122512261227122812291230123112321233123412351236123712381239124012411242124312441245124612471248124912501251125212531254125512561257125812591260126112621263126412651266126712681269127012711272127312741275127612771278127912801281128212831284128512861287128812891290129112921293129412951296129712981299130013011302130313041305130613071308130913101311131213131314131513161317131813191320132113221323132413251326132713281329133013311332133313341335133613371338133913401341134213431344134513461347134813491350135113521353135413551356135713581359136013611362136313641365136613671368136913701371137213731374137513761377137813791380138113821383138413851386138713881389139013911392139313941395139613971398139914001401140214031404140514061407140814091410141114121413141414151416141714181419142014211422142314241425142614271428142914301431143214331434143514361437143814391440144114421443144414451446144714481449145014511452145314541455145614571458145914601461146214631464146514661467146814691470147114721473147414751476147714781479148014811482148314841485148614871488148914901491149214931494149514961497149814991500150115021503150415051506150715081509151015111512151315141515151615171518151915201521152215231524152515261527152815291530153115321533153415351536153715381539154015411542154315441545154615471548154915501551155215531554155515561557155815591560156115621563156415651566156715681569157015711572157315741575157615771578157915801581158215831584158515861587158815891590159115921593159415951596159715981599160016011602160316041605160616071608160916101611161216131614161516161617161816191620162116221623162416251626162716281629163016311632163316341635163616371638163916401641164216431644164516461647164816491650165116521653165416551656165716581659166016611662166316641665166616671668166916701671167216731674167516761677167816791680168116821683168416851686168716881689169016911692169316941695169616971698169917001701170217031704170517061707170817091710171117121713171417151716171717181719172017211722172317241725172617271728172917301731173217331734173517361737173817391740174117421743174417451746174717481749175017511752175317541755175617571758175917601761176217631764176517661767176817691770177117721773177417751776177717781779178017811782178317841785178617871788178917901791179217931794179517961797179817991800180118021803180418051806180718081809181018111812181318141815181618171818181918201821182218231824182518261827182818291830183118321833183418351836183718381839184018411842184318441845184618471848184918501851185218531854185518561857185818591860186118621863186418651866186718681869187018711872187318741875187618771878187918801881188218831884188518861887188818891890189118921893189418951896189718981899190019011902190319041905190619071908190919101911191219131914191519161917191819191920192119221923192419251926192719281929193019311932193319341935193619371938193919401941194219431944194519461947194819491950195119521953195419551956195719581959196019611962196319641965196619671968196919701971197219731974197519761977197819791980198119821983198419851986198719881989199019911992199319941995199619971998199920002001200220032004200520062007200820092010201120122013201420152016201720182019202020212022202320242025202620272028202920302031203220332034203520362037203820392040204120422043204420452046204720482049205020512052205320542055205620572058205920602061206220632064206520662067206820692070207120722073207420752076207720782079208020812082208320842085208620872088208920902091209220932094209520962097209820992100210121022103210421052106210721082109211021112112211321142115211621172118211921202121212221232124212521262127212821292130213121322133213421352136213721382139214021412142214321442145214621472148214921502151215221532154215521562157215821592160216121622163216421652166216721682169217021712172217321742175217621772178217921802181218221832184218521862187218821892190219121922193219421952196219721982199220022012202220322042205220622072208220922102211221222132214221522162217221822192220222122222223222422252226222722282229223022312232223322342235223622372238223922402241224222432244224522462247224822492250225122522253225422552256225722582259226022612262226322642265226622672268226922702271227222732274227522762277227822792280228122822283228422852286228722882289229022912292229322942295229622972298229923002301230223032304230523062307230823092310231123122313231423152316231723182319232023212322232323242325232623272328232923302331233223332334233523362337233823392340234123422343234423452346234723482349235023512352235323542355235623572358235923602361236223632364236523662367236823692370237123722373237423752376237723782379238023812382238323842385238623872388238923902391239223932394239523962397239823992400240124022403240424052406240724082409241024112412241324142415241624172418241924202421242224232424242524262427242824292430243124322433243424352436243724382439244024412442244324442445244624472448244924502451245224532454245524562457245824592460246124622463246424652466246724682469247024712472247324742475247624772478247924802481248224832484248524862487248824892490249124922493249424952496249724982499250025012502250325042505250625072508250925102511251225132514251525162517251825192520252125222523252425252526252725282529253025312532253325342535253625372538253925402541254225432544254525462547254825492550255125522553255425552556255725582559256025612562256325642565256625672568256925702571257225732574257525762577257825792580258125822583258425852586258725882589259025912592259325942595259625972598259926002601260226032604260526062607260826092610261126122613261426152616261726182619262026212622262326242625262626272628262926302631263226332634263526362637263826392640264126422643264426452646264726482649265026512652265326542655265626572658265926602661266226632664266526662667266826692670267126722673267426752676267726782679268026812682268326842685268626872688268926902691269226932694269526962697269826992700270127022703270427052706270727082709271027112712271327142715271627172718271927202721272227232724272527262727272827292730273127322733273427352736273727382739274027412742274327442745274627472748274927502751275227532754275527562757275827592760276127622763276427652766276727682769277027712772277327742775277627772778277927802781278227832784278527862787278827892790279127922793279427952796279727982799280028012802280328042805280628072808280928102811281228132814281528162817281828192820282128222823282428252826282728282829283028312832283328342835283628372838283928402841284228432844284528462847284828492850285128522853285428552856285728582859286028612862286328642865286628672868286928702871287228732874287528762877287828792880288128822883288428852886288728882889289028912892289328942895289628972898289929002901290229032904290529062907290829092910291129122913291429152916291729182919292029212922292329242925292629272928292929302931293229332934293529362937293829392940294129422943294429452946294729482949295029512952295329542955295629572958295929602961296229632964296529662967296829692970297129722973297429752976297729782979298029812982298329842985298629872988298929902991299229932994299529962997299829993000300130023003300430053006300730083009301030113012301330143015301630173018301930203021302230233024302530263027302830293030303130323033303430353036303730383039304030413042304330443045304630473048304930503051305230533054305530563057305830593060306130623063306430653066306730683069307030713072307330743075307630773078307930803081308230833084308530863087308830893090309130923093309430953096309730983099310031013102310331043105310631073108310931103111311231133114311531163117311831193120312131223123312431253126312731283129313031313132313331343135313631373138313931403141314231433144314531463147314831493150315131523153315431553156315731583159316031613162316331643165316631673168316931703171317231733174317531763177317831793180318131823183318431853186318731883189319031913192319331943195319631973198319932003201320232033204320532063207320832093210321132123213321432153216321732183219322032213222322332243225322632273228322932303231323232333234323532363237323832393240324132423243324432453246324732483249325032513252325332543255325632573258325932603261326232633264326532663267326832693270327132723273327432753276327732783279328032813282328332843285328632873288328932903291329232933294329532963297329832993300330133023303330433053306330733083309331033113312331333143315331633173318331933203321332233233324332533263327332833293330333133323333333433353336333733383339334033413342334333443345334633473348334933503351335233533354335533563357335833593360336133623363336433653366336733683369337033713372337333743375337633773378337933803381338233833384338533863387338833893390339133923393339433953396339733983399340034013402340334043405340634073408340934103411341234133414341534163417341834193420342134223423342434253426342734283429343034313432343334343435343634373438343934403441344234433444344534463447344834493450345134523453345434553456345734583459346034613462346334643465346634673468346934703471347234733474347534763477347834793480348134823483348434853486348734883489349034913492349334943495349634973498349935003501350235033504350535063507350835093510351135123513351435153516351735183519352035213522352335243525352635273528352935303531353235333534353535363537353835393540354135423543354435453546354735483549355035513552355335543555355635573558355935603561356235633564356535663567356835693570357135723573357435753576357735783579358035813582358335843585358635873588358935903591359235933594359535963597359835993600360136023603360436053606360736083609361036113612361336143615361636173618361936203621362236233624362536263627362836293630363136323633363436353636363736383639364036413642364336443645364636473648364936503651365236533654365536563657365836593660366136623663366436653666366736683669367036713672367336743675367636773678367936803681368236833684368536863687368836893690369136923693369436953696369736983699370037013702370337043705370637073708370937103711371237133714371537163717371837193720372137223723372437253726372737283729373037313732373337343735373637373738373937403741374237433744374537463747374837493750375137523753375437553756375737583759376037613762376337643765376637673768376937703771377237733774377537763777377837793780378137823783378437853786378737883789379037913792379337943795379637973798379938003801380238033804380538063807380838093810381138123813381438153816381738183819382038213822382338243825382638273828382938303831383238333834383538363837383838393840384138423843384438453846384738483849385038513852385338543855385638573858385938603861386238633864386538663867386838693870387138723873387438753876387738783879388038813882388338843885388638873888388938903891389238933894389538963897389838993900390139023903390439053906390739083909391039113912391339143915391639173918391939203921392239233924392539263927392839293930393139323933393439353936393739383939394039413942394339443945394639473948394939503951395239533954395539563957395839593960396139623963396439653966396739683969397039713972397339743975397639773978397939803981398239833984398539863987398839893990399139923993399439953996399739983999400040014002400340044005400640074008400940104011401240134014401540164017401840194020402140224023402440254026402740284029403040314032403340344035403640374038403940404041404240434044404540464047404840494050405140524053405440554056405740584059406040614062406340644065406640674068406940704071407240734074407540764077407840794080408140824083408440854086408740884089409040914092409340944095409640974098409941004101410241034104410541064107410841094110411141124113411441154116411741184119412041214122412341244125412641274128412941304131413241334134413541364137413841394140414141424143414441454146414741484149415041514152415341544155415641574158415941604161416241634164416541664167416841694170417141724173417441754176417741784179418041814182418341844185418641874188418941904191419241934194419541964197419841994200420142024203420442054206420742084209421042114212421342144215421642174218421942204221422242234224422542264227422842294230423142324233423442354236423742384239424042414242424342444245424642474248424942504251425242534254425542564257425842594260426142624263426442654266426742684269427042714272427342744275427642774278427942804281428242834284428542864287428842894290429142924293429442954296429742984299430043014302430343044305430643074308430943104311431243134314431543164317431843194320432143224323432443254326432743284329433043314332433343344335433643374338433943404341434243434344434543464347434843494350435143524353435443554356435743584359436043614362436343644365436643674368436943704371437243734374437543764377437843794380438143824383438443854386438743884389439043914392439343944395439643974398439944004401440244034404440544064407440844094410441144124413441444154416441744184419442044214422442344244425442644274428442944304431443244334434443544364437443844394440444144424443444444454446444744484449445044514452445344544455445644574458445944604461446244634464446544664467446844694470447144724473447444754476447744784479448044814482448344844485448644874488448944904491449244934494449544964497449844994500450145024503450445054506450745084509451045114512451345144515451645174518451945204521452245234524452545264527452845294530453145324533453445354536453745384539454045414542454345444545454645474548454945504551455245534554455545564557455845594560456145624563456445654566456745684569457045714572457345744575457645774578457945804581458245834584458545864587458845894590459145924593459445954596459745984599460046014602460346044605460646074608460946104611461246134614461546164617461846194620462146224623462446254626462746284629463046314632463346344635463646374638463946404641464246434644464546464647464846494650465146524653465446554656465746584659466046614662466346644665466646674668466946704671467246734674467546764677467846794680468146824683468446854686468746884689469046914692469346944695469646974698469947004701470247034704470547064707470847094710471147124713471447154716471747184719472047214722472347244725472647274728472947304731473247334734473547364737473847394740474147424743474447454746474747484749475047514752475347544755475647574758475947604761476247634764476547664767476847694770477147724773477447754776477747784779478047814782478347844785478647874788478947904791479247934794479547964797479847994800480148024803480448054806480748084809481048114812481348144815481648174818481948204821482248234824482548264827482848294830483148324833483448354836483748384839484048414842484348444845484648474848484948504851485248534854485548564857485848594860486148624863486448654866486748684869487048714872487348744875487648774878487948804881488248834884488548864887488848894890489148924893489448954896489748984899490049014902490349044905490649074908490949104911491249134914491549164917491849194920492149224923492449254926492749284929493049314932493349344935493649374938493949404941494249434944494549464947494849494950495149524953495449554956495749584959496049614962496349644965496649674968496949704971497249734974497549764977497849794980498149824983498449854986498749884989499049914992499349944995499649974998499950005001500250035004500550065007500850095010501150125013501450155016501750185019502050215022502350245025502650275028502950305031503250335034503550365037503850395040
  1. <template>
  2. <div class="hcfdlab">
  3. <div class="scal">
  4. <div class="toolbar-part-detail lbg_color1 ">
  5. <!-- 工具栏 -->
  6. <!-- <transformtool ref="transform" :servertype="servertype" :projectId='project.projectId' :wstep='wstep' :bStep='bStep' :vStep='vStep'></transformtool> -->
  7. <el-tabs v-model="activeName" type="card" @tab-click="handleClick" class="tabsel">
  8. <el-tab-pane label="几何建模" name="one"><geometry></geometry></el-tab-pane>
  9. <!-- 网格划分 -->
  10. <el-tab-pane label="网格划分" name="twos">
  11. <div class="imgzong">
  12. <div class="listitem lbg_color3 bkcolor3" v-for="(item,index) in meshlist" :key="'one-'+ index" :class="{activeOrange:active=='one-'+ index}" @click="clickgeometry($event,index,'one-'+ index)" >
  13. <div class="item2 " >
  14. <el-image :src="item.icon" fit="cover" />
  15. <span >{{item.titlie}}</span>
  16. </div>
  17. </div>
  18. </div>
  19. </el-tab-pane>
  20. <!-- 通用设置 -->
  21. <el-tab-pane :label="$t('HCFD.geneal.geneal')" name="two">
  22. <div class="imgzong">
  23. <div class="listitem lbg_color3 bkcolor3">
  24. <div class="item1" v-for="(itemcj,index) in twolist" :key="'two-'+ index" :class="{activeOrange:active=='two-'+ index}" @click="clickgeometry($event,index,'two-'+ index)">
  25. <el-image :src="itemcj.icon" fit="cover" />
  26. <span >{{itemcj.titlie}}</span>
  27. </div>
  28. </div>
  29. <!--分析类型 -->
  30. <div class="listitem lbg_color3 radiocontent bkcolor3">
  31. <div class="item1" >
  32. <el-form>
  33. <div class="radio_text text_color">
  34. <div class="classfelx">
  35. <el-tooltip class="item" effect="dark" content="分析类型" placement="bottom">
  36. <el-radio
  37. v-model="parameterObj.nmlParam.analysis_Type"
  38. label="Steady"
  39. >{{ $t("HCFD.geneal.steady") }}</el-radio
  40. >
  41. </el-tooltip>
  42. </div>
  43. <div class="classfelx">
  44. <el-tooltip class="item" effect="dark" content="分析类型" placement="bottom">
  45. <el-radio
  46. v-model="parameterObj.nmlParam.analysis_Type"
  47. label="Unsteady"
  48. >{{ $t("HCFD.geneal.unsteady") }}</el-radio
  49. >
  50. </el-tooltip>
  51. </div>
  52. </div>
  53. </el-form>
  54. </div>
  55. </div>
  56. <!-- 并行类型 -->
  57. <div class="listitem lbg_color3 radiocontent bkcolor3">
  58. <div class="item1" >
  59. <el-form>
  60. <div class="radio_text text_color">
  61. <el-radio-group
  62. v-model="parameterObj.nmlParam.parallel_Optional"
  63. @input="leixingchange($event)"
  64. >
  65. <div>
  66. <el-tooltip class="item" effect="dark" content="并行类型" placement="bottom">
  67. <el-radio label="Serial">
  68. {{ $t("HCFD.geneal.serial") }}</el-radio
  69. >
  70. </el-tooltip>
  71. </div>
  72. <div>
  73. <el-tooltip class="item" effect="dark" content="并行类型" placement="bottom">
  74. <el-radio label="MPI Parallel">{{
  75. $t("HCFD.geneal.mpi")
  76. }}</el-radio>
  77. </el-tooltip>
  78. </div>
  79. </el-radio-group>
  80. </div>
  81. </el-form>
  82. </div>
  83. </div>
  84. </div>
  85. </el-tab-pane>
  86. <!-- 物理模型 -->
  87. <el-tab-pane :label="$t('HCFD.physics.physics')" name="three">
  88. <div class="imgzong">
  89. <div class="listitem lbg_color3 bkcolor3" v-for="(item,index) in physicslist" :key="'three-'+ index" :class="{activeOrange:active=='three-'+ index}" @click="clickgeometry($event,index,'three-'+ index)" >
  90. <div class="item2 " >
  91. <el-image :src="item.icon" fit="cover" />
  92. <span >{{item.titlie}}</span>
  93. </div>
  94. </div>
  95. <div class="listitem lbg_color3 bkcolor3" >
  96. <div class="item1" v-for="(item,index) in physicslist2" :key="'three2-'+ index" :class="{activeOrange:active=='three2-'+ index}" @click="clickgeometry($event,index,'three2-'+ index)">
  97. <el-image :src="item.icon" fit="cover" />
  98. <span >{{item.titlie}}</span>
  99. </div>
  100. </div>
  101. <div class="listitem lbg_color3 bkcolor3" >
  102. <div class="item1" v-for="(item,index) in physicslist1" :key="'three1-'+ index" :class="{activeOrange:active=='three1-'+ index}" @click="clickgeometry($event,index,'three1-'+ index)">
  103. <el-image :src="item.icon" fit="cover" />
  104. <span >{{item.titlie}}</span>
  105. </div>
  106. </div>
  107. </div>
  108. </el-tab-pane>
  109. <!-- 求解控制 -->
  110. <el-tab-pane :label="$t('HCFD.solution.solution')" name="four">
  111. <div class="imgzong">
  112. <div class="listitem lbg_color3 bkcolor3" v-for="(item,index) in solutionlist" :key="'four-'+ index" :class="{activeOrange:active=='four-'+ index}" @click="clickgeometry($event,index,'four-'+ index)" >
  113. <div class="item2 " >
  114. <el-image :src="item.icon" fit="cover" />
  115. <span >{{item.titlie}}</span>
  116. </div>
  117. </div>
  118. <div class="listitem lbg_color3 bkcolor3 imgsolution" v-for="(item,index) in solutionlist2" :key="'four2-'+ index" :class="{activeOrange:active=='four2-'+ index}" @click="clickgeometry($event,index,'four2-'+ index)" >
  119. <div class="item2 " >
  120. <div class="itemimg">
  121. <el-image :src="item.icon" fit="cover" />
  122. </div>
  123. <span >{{item.titlie}}</span>
  124. </div>
  125. </div>
  126. <div class="listitem lbg_color3 bkcolor3 imgsolution" v-for="(item,index) in solutionlist21" :key="'four2-1'+ index" :class="{activeOrange:active=='four2-1'+ index}" @click="clickgeometry($event,index,'four2-1'+ index)" >
  127. <div class="item2 " >
  128. <el-image :src="item.icon" fit="cover" />
  129. <span >{{item.titlie}}</span>
  130. </div>
  131. </div>
  132. <div class="listitem lbg_color3 bkcolor3">
  133. <div class="item1" v-for="(item,index) in solutionlist3" :key="'four3-'+ index" :class="{activeOrange:active=='four3-'+ index}" @click="clickgeometry($event,index,'four3-'+ index)">
  134. <el-image :src="item.icon" fit="cover" />
  135. <span >{{item.titlie}}</span>
  136. </div>
  137. </div>
  138. </div>
  139. </el-tab-pane>
  140. <!-- 结果显示 -->
  141. <el-tab-pane :label=" $t('HCFD.results.results')" name="five">
  142. <div class="imgzong" v-if="lsolverState=='2'" >
  143. <div class="listitem lbg_color3 bkcolor3" >
  144. <div class="item1 " v-for="(item,index) in resultslist" :key="'five-'+ index" :class="{activeOrange:active=='five-'+ index}" @click="clickgeometry($event,index,'five-'+ index)" >
  145. <el-image :src="item.icon" fit="cover" />
  146. <span >{{item.titlie}}</span>
  147. </div>
  148. </div>
  149. <div class="listitem lbg_color3 bkcolor3" style=" display: flex" >
  150. <div>
  151. <div class="item1 " v-for="(item,index) in plotslsit" :key="'five1-'+ index" :class="{activeOrange:active=='five1-'+ index}" @click="clickgeometry($event,index,'five1-'+ index)" >
  152. <el-image :src="item.icon" fit="cover" />
  153. <span >{{item.titlie}}</span>
  154. </div>
  155. </div>
  156. <div>
  157. <div class="item1 " v-for="(item,index) in plotslsit1" :key="'five2-'+ index" :class="{activeOrange:active=='five2-'+ index}" @click="clickgeometry($event,index,'five2-'+ index)" >
  158. <el-image :src="item.icon" fit="cover" />
  159. <span >{{item.titlie}}</span>
  160. </div>
  161. </div>
  162. <div>
  163. <div class="item1 " v-for="(item,index) in plotslsit2" :key="'five3-'+ index" :class="{activeOrange:active=='five3-'+ index}" @click="clickgeometry($event,index,'five3-'+ index)" >
  164. <el-image :src="item.icon" fit="cover" />
  165. <span >{{item.titlie}}</span>
  166. </div>
  167. </div>
  168. </div>
  169. <div class="listitem lbg_color3 bkcolor3" >
  170. <div class="item1 " v-for="(item,index) in samplelist" :key="'five4-'+ index" :class="{activeOrange:active=='five4-'+ index}" @click="clickgeometry($event,index,'five4-'+ index)" >
  171. <el-image :src="item.icon" fit="cover" />
  172. <span >{{item.titlie}}</span>
  173. </div>
  174. </div>
  175. <div class="listitem lbg_color3 bkcolor3" style=" display: flex" >
  176. <div>
  177. <div class="item1 " v-for="(item,index) in generatelist" :key="'five5-'+ index" :class="{activeOrange:active=='five5-'+ index}" @click="clickgeometry($event,index,'five5-'+ index)" >
  178. <el-image :src="item.icon" fit="cover" />
  179. <span >{{item.titlie}}</span>
  180. </div>
  181. </div>
  182. <div>
  183. <div class="item1 " v-for="(item,index) in generatelist2" :key="'five6-'+ index" :class="{activeOrange:active=='five6-'+ index}" @click="clickgeometry($event,index,'five6-'+ index)" >
  184. <el-image :src="item.icon" fit="cover" />
  185. <span >{{item.titlie}}</span>
  186. </div>
  187. </div>
  188. </div>
  189. <div class="listitem lbg_color3 bkcolor3" style=" display: flex" >
  190. <div>
  191. <div class="item1 " v-for="(item,index) in displaylist" :key="'five7-'+ index" :class="{activeOrange:active=='five7-'+ index}" @click="clickgeometry($event,index,'five7-'+ index)" >
  192. <el-image :src="item.icon" fit="cover" />
  193. <span >{{item.titlie}}</span>
  194. </div>
  195. </div>
  196. <div>
  197. <div class="item1 " v-for="(item,index) in displaylist2" :key="'five8-'+ index" :class="{activeOrange:active=='five8-'+ index}" @click="clickgeometry($event,index,'five8-'+ index)" >
  198. <el-image :src="item.icon" fit="cover" />
  199. <span >{{item.titlie}}</span>
  200. </div>
  201. </div>
  202. </div>
  203. <div class="listitem lbg_color3 bkcolor3" >
  204. <div class="item1 " v-for="(item,index) in animationlist" :key="'five9-'+ index" :class="{activeOrange:active=='five9-'+ index}" @click="clickgeometry($event,index,'five9-'+ index)" >
  205. <el-image :src="item.icon" fit="cover" />
  206. <span >{{item.titlie}}</span>
  207. </div>
  208. </div>
  209. <div class="listitem lbg_color3 bkcolor3" >
  210. <div class="item1 " v-for="(item,index) in Cuelist" :key="'five9-'+ index" :class="{activeOrange:active=='five10-'+ index}" @click="clickgeometry($event,index,'five10-'+ index)" >
  211. <el-image :src="item.icon" fit="cover" />
  212. <span >{{item.titlie}}</span>
  213. </div>
  214. </div>
  215. </div>
  216. </el-tab-pane>
  217. <!-- 工具 -->
  218. <el-tab-pane :label="$t('HCFD.tool.unitConversion')" name="six">
  219. <div class="imgzong">
  220. <div class="item1" v-for="(item,index) in unitlist " :key="'six-'+ index" :class="{activeOrange:active=='six-'+ index}" @click="clickgeometry($event,index,'six-'+ index)">
  221. <el-tooltip class="item" effect="dark" :content="item.titlie" placement="bottom">
  222. <el-image :src="item.icon" fit="cover" />
  223. </el-tooltip>
  224. </div>
  225. </div>
  226. </el-tab-pane>
  227. </el-tabs>
  228. </div>
  229. </div>
  230. <!-- 文件上传 -->
  231. <el-dialog
  232. v-if="active=='one-0'"
  233. :visible.sync="dialog.upload_visiable"
  234. :close-on-click-modal="false"
  235. @close='activecleer()'
  236. class="dialog"
  237. :modal='false'
  238. custom-class='dialoglocation dialog_color'
  239. width="385px"
  240. :style="styX"
  241. >
  242. <div slot="title" class=dialog_header>
  243. <el-image class="imge" :src="q4" fit="cover" />
  244. <span class="text-color">文件上传</span>
  245. </div>
  246. <el-form>
  247. <!-- <el-form-item >
  248. <span>{{ $t("HCFD.file.name") }}:</span>
  249. <p class="text">{{project.projectName}}</p>
  250. <span>{{ $t("HCFD.file.desc") }}:</span>
  251. <p class="text">{{project.projectDesc}}</p>
  252. </el-form-item> -->
  253. <el-form-item label="File Type">
  254. <el-radio disabled v-model="project.fileType" label="binary"
  255. >{{ $t("HCFD.file.binary") }}</el-radio
  256. >
  257. <el-radio v-model="project.fileType" label="ascii">{{ $t("HCFD.file.ascii")}}</el-radio>
  258. </el-form-item>
  259. <vue-uploader
  260. ref="ugrid"
  261. :projectId="project.projectId"
  262. :solverType="'hcfd'"
  263. :accept="'.ugrid'"
  264. :name="'Load Grid File'"
  265. :upId="'2'"
  266. ></vue-uploader>
  267. <!-- <vue-uploader
  268. ref="mapbc"
  269. :projectId="project.projectId"
  270. :solverType="'hcfd'"
  271. :accept="'.mapbc,.dat'"
  272. :name="'Load BC File'"
  273. :upId="'1'"
  274. ></vue-uploader> -->
  275. </el-form>
  276. <div slot="footer" class="dialog-footer">
  277. <el-button @click="dialog.upload_visiable = false">{{ $t("HCFD.file.cancel")}}</el-button>
  278. <el-button type="primary" @click="dialog.upload_visiable = false"
  279. >{{ $t("HCFD.file.ok")}}</el-button
  280. >
  281. </div>
  282. </el-dialog>
  283. <!-- 缩放 -->
  284. <el-dialog
  285. v-if="active=='two-0'"
  286. :visible.sync="dialog.scale_visiable"
  287. :close-on-click-modal="false"
  288. @close='activecleer()'
  289. class="dialog"
  290. :modal='false'
  291. custom-class='dialoglocation dialog_color'
  292. width="385px"
  293. :style="styX"
  294. >
  295. <div slot="title" class=dialog_header>
  296. <el-image class="imge" :src="t1" fit="cover" />
  297. <span class="text-color">{{$t('HCFD.geneal.scale')}}</span>
  298. </div>
  299. <el-form>
  300. <el-form-item label="名称" :label-width="formLabelWidth2" >
  301. <el-input v-model="mcnames" autocomplete="off"></el-input>
  302. </el-form-item>
  303. <el-form-item label="类型" :label-width="formLabelWidth2" >
  304. <el-input value="suofang" autocomplete="off"></el-input>
  305. </el-form-item>
  306. <div class="line">
  307. <div class="linetext">相交/延长</div>
  308. </div>
  309. <el-form-item :label="$t('HCFD.geneal.factor')" :label-width="formLabelWidth2" >
  310. <el-input v-model="geneal.MeshTransform.Scale.Factor" autocomplete="off"></el-input>
  311. </el-form-item>
  312. </el-form>
  313. <div slot="footer" class="dialog-footer">
  314. <el-button @click="dialog.scale_visiable = false">{{ $t("HCFD.file.cancel")}}</el-button>
  315. <el-button type="primary" @click="hcfdparam(); dialog.scale_visiable = false"
  316. >{{ $t("HCFD.file.ok")}}</el-button
  317. >
  318. </div>
  319. </el-dialog>
  320. <!-- 翻译 -->
  321. <el-dialog
  322. v-if="active=='two-1'"
  323. :visible.sync="dialog.translation_visiable"
  324. :close-on-click-modal="false"
  325. @close='activecleer()'
  326. :modal='false'
  327. custom-class='dialoglocation dialog_color'
  328. width="385px"
  329. :style="styX"
  330. >
  331. <div slot="title" class=dialog_header>
  332. <el-image class="imge" :src="t2" fit="cover" />
  333. <span class="text-color">{{$t('HCFD.geneal.translation')}}</span>
  334. </div>
  335. <el-form class="div64">
  336. <el-form-item label="名称" :label-width="formLabelWidth2" >
  337. <el-input v-model="mcnames" autocomplete="off"></el-input>
  338. </el-form-item>
  339. <el-form-item label="类型" :label-width="formLabelWidth2" >
  340. <el-input value="PingYi" autocomplete="off"></el-input>
  341. </el-form-item>
  342. <div class="line">
  343. <div class="linetext">属性</div>
  344. </div>
  345. <div class="liitem">
  346. <el-form-item :label="$t('HCFD.geneal.distance')" :label-width="formLabelWidth7">
  347. <el-input v-model="geneal.MeshTransform.Translation.Distance" autocomplete="off"></el-input>
  348. </el-form-item>
  349. </div>
  350. <div class="liitem">
  351. <el-form-item :label="$t('HCFD.geneal.translationx')" :label-width="formLabelWidth7">
  352. <el-input v-model="geneal.MeshTransform.Translation.X" autocomplete="off"></el-input>
  353. </el-form-item>
  354. </div>
  355. <div class="liitem">
  356. <el-form-item :label=" $t('HCFD.geneal.translationy')" :label-width="formLabelWidth7">
  357. <el-input v-model="geneal.MeshTransform.Translation.Y" autocomplete="off"></el-input>
  358. </el-form-item>
  359. </div>
  360. <div class="liitem">
  361. <el-form-item :label="$t('HCFD.geneal.translationz')" :label-width="formLabelWidth7">
  362. <el-input v-model="geneal.MeshTransform.Translation.Z" autocomplete="off"></el-input>
  363. </el-form-item>
  364. </div>
  365. </el-form>
  366. <div slot="footer" class="dialog-footer">
  367. <el-button @click="dialog.translation_visiable = false"
  368. > {{ $t("HCFD.file.cancel")}} </el-button
  369. >
  370. <el-button type="primary" @click="hcfdparam(); dialog.translation_visiable = false"
  371. >{{ $t("HCFD.file.ok")}}</el-button
  372. >
  373. </div>
  374. </el-dialog>
  375. <!-- 旋转 -->
  376. <el-dialog
  377. v-if="active=='two-2'"
  378. :close-on-click-modal="false"
  379. @close='activecleer()'
  380. :modal='false'
  381. custom-class='dialoglocation dialog_color'
  382. :visible.sync="dialog.rotation_visiable"
  383. width="385px"
  384. :style="styX"
  385. >
  386. <div slot="title" class=dialog_header>
  387. <el-image class="imge" :src="t3" fit="cover" />
  388. <span class="text-color">{{$t('HCFD.geneal.rotation')}}</span>
  389. </div>
  390. <el-form class="div64">
  391. <el-form-item label="名称" :label-width="formLabelWidth2" >
  392. <el-input v-model="mcnames" autocomplete="off"></el-input>
  393. </el-form-item>
  394. <el-form-item label="类型" :label-width="formLabelWidth2" >
  395. <el-input value="xuanzuan" autocomplete="off"></el-input>
  396. </el-form-item>
  397. <div class="line">
  398. <div class="linetext">属性</div>
  399. </div>
  400. <el-form-item :label="$t('HCFD.geneal.angle')" :label-width="formLabelWidth7" >
  401. <el-input v-model="geneal.MeshTransform.Rotation.Angle" autocomplete="off"></el-input>
  402. </el-form-item>
  403. <el-form-item :label="$t('HCFD.geneal.rotationx')" :label-width="formLabelWidth7" >
  404. <el-input v-model="geneal.MeshTransform.Rotation.X" autocomplete="off"></el-input>
  405. </el-form-item>
  406. <el-form-item :label="$t('HCFD.geneal.rotationy')" :label-width="formLabelWidth7" >
  407. <el-input v-model="geneal.MeshTransform.Rotation.Y" autocomplete="off"></el-input>
  408. </el-form-item>
  409. <el-form-item :label="$t('HCFD.geneal.rotationz')" :label-width="formLabelWidth7" >
  410. <el-input v-model="geneal.MeshTransform.Rotation.Z" autocomplete="off"></el-input>
  411. </el-form-item>
  412. <el-form-item :label="$t('HCFD.geneal.rotationx1')" :label-width="formLabelWidth7" >
  413. <el-input v-model="geneal.MeshTransform.Rotation.X1" autocomplete="off"></el-input>
  414. </el-form-item>
  415. <el-form-item :label="$t('HCFD.geneal.rotationy1')" :label-width="formLabelWidth7" >
  416. <el-input v-model="geneal.MeshTransform.Rotation.Y1" autocomplete="off"></el-input>
  417. </el-form-item>
  418. <el-form-item :label="$t('HCFD.geneal.rotationz1')" :label-width="formLabelWidth7" >
  419. <el-input v-model="geneal.MeshTransform.Rotation.Z1" autocomplete="off"></el-input>
  420. </el-form-item>
  421. </el-form>
  422. <div slot="footer" class="dialog-footer">
  423. <el-button @click="dialog.rotation_visiable = false">{{ $t("HCFD.file.cancel")}}</el-button>
  424. <el-button type="primary" @click="hcfdparam(); dialog.rotation_visiable = false"
  425. >{{ $t("HCFD.file.ok")}} </el-button
  426. >
  427. </div>
  428. </el-dialog>
  429. <!-- 分析类型 -->
  430. <!-- <el-dialog
  431. class="lg-y-z"
  432. :visible.sync="dialog.type_visiable "
  433. :close-on-click-modal="false"
  434. @close='activecleer()'
  435. v-if="active=='two-3'"
  436. :modal='false'
  437. custom-class='dialoglocation dialog_color'
  438. width="385px"
  439. :style="styX"
  440. >
  441. <div slot="title" class=dialog_header>
  442. <el-image class="imge" :src="t4" fit="cover" />
  443. <span class="text-color">{{$t('HCFD.geneal.analysis')}}</span>
  444. </div>
  445. <el-form>
  446. <div class="radio_text text_color liangf">
  447. <div class="classfelx">
  448. <el-tooltip class="item" effect="dark" content="分析类型" placement="bottom">
  449. <el-radio
  450. v-model="parameterObj.nmlParam.analysis_Type"
  451. label="Steady"
  452. >{{ $t("HCFD.geneal.steady") }}</el-radio
  453. >
  454. </el-tooltip>
  455. </div>
  456. <div class="classfelx">
  457. <el-tooltip class="item" effect="dark" content="分析类型" placement="bottom">
  458. <el-radio
  459. v-model="parameterObj.nmlParam.analysis_Type"
  460. label="Unsteady"
  461. >{{ $t("HCFD.geneal.unsteady") }}</el-radio
  462. >
  463. </el-tooltip>
  464. </div>
  465. </div>
  466. </el-form>
  467. <div slot="footer" class="dialog-footer">
  468. <el-button
  469. @click="referencevisiable((dialog.type_visiable = false))"
  470. >{{ $t("HCFD.file.cancel")}} </el-button
  471. >
  472. <el-button type="primary" @click="hcfdparam(); dialog.type_visiable = false"
  473. >{{ $t("HCFD.file.ok")}}</el-button
  474. >
  475. </div>
  476. </el-dialog> -->
  477. <!-- 并行类型 -->
  478. <el-dialog
  479. class="lg-y-z"
  480. :visible.sync="dialog.parallel_visiable "
  481. :close-on-click-modal="false"
  482. @close='activecleer()'
  483. :modal='false'
  484. custom-class='dialoglocation dialog_color'
  485. width="385px"
  486. :style="styX"
  487. >
  488. <div slot="title" class=dialog_header>
  489. <el-image class="imge" :src="t5" fit="cover" />
  490. <span class="text-color">{{$t('HCFD.geneal.parallel')}}</span>
  491. </div>
  492. <el-form>
  493. <div class="radio_text text_color">
  494. <el-form-item :label="$t('HCFD.geneal.number')" :label-width="formLabelWidth2" v-if="
  495. parameterObj.nmlParam.parallel_Optional == 'MPI Parallel'
  496. ">
  497. <el-input v-model="parameterObj.nmlParam.number_of_Processors" autocomplete="off"></el-input>
  498. </el-form-item>
  499. </div>
  500. </el-form>
  501. <div slot="footer" class="dialog-footer">
  502. <el-button
  503. @click="referencevisiable((dialog.parallel_visiable = false))"
  504. >{{ $t("HCFD.file.cancel")}} </el-button
  505. >
  506. <el-button type="primary" @click="hcfdparam(); dialog.parallel_visiable = false"
  507. >{{ $t("HCFD.file.ok")}}</el-button
  508. >
  509. </div>
  510. </el-dialog>
  511. <!-- 控制方程 -->
  512. <el-dialog
  513. v-if="active=='three-0'"
  514. :visible.sync="dialog.equation_visiable"
  515. :close-on-click-modal="false"
  516. @close='activecleer()'
  517. class="dialog"
  518. :modal='false'
  519. custom-class='dialoglocation dialog_color'
  520. width="385px"
  521. :style="styX"
  522. >
  523. <div slot="title" class=dialog_header>
  524. <el-image class="imge" :src="w1" fit="cover" />
  525. <span class="text-color">{{$t('HCFD.physics.gover')}}</span>
  526. </div>
  527. <el-form>
  528. <el-radio-group
  529. v-model="parameterObj.nmlParam.eqn_type"
  530. size="mini"
  531. >
  532. <el-radio label="cal_perf_compress" style="display: block; padding:15px 0;">{{
  533. $t("HCFD.physics.compress")
  534. }}</el-radio>
  535. <el-radio label="cal_perf_incompress">{{
  536. $t("HCFD.physics.incompress")
  537. }}</el-radio>
  538. </el-radio-group>
  539. <div class="disflex text_color" v-if="parameterObj.nmlParam.eqn_type=='cal_perf_incompress'">
  540. <span class="text_color formLabelWidth8">{{ $t("HCFD.physics.artifical") }}</span>
  541. <el-input
  542. class='inpw75'
  543. size="mini"
  544. v-model="parameterObj.nmlParam.artificial_compress"
  545. ></el-input>
  546. </div>
  547. </el-form>
  548. <div slot="footer" class="dialog-footer">
  549. <el-button @click="dialog. equation_visiable = false"> {{ $t("HCFD.file.cancel")}} </el-button>
  550. <el-button type="primary" @click="hcfdparam(); dialog.equation_visiable = false"
  551. >{{ $t("HCFD.file.ok")}} </el-button
  552. >
  553. </div>
  554. </el-dialog>
  555. <!-- 粘性模型 -->
  556. <el-dialog
  557. class="lg-y-z"
  558. :visible.sync="dialog.inviscid_visiable"
  559. :close-on-click-modal="false"
  560. @close='activecleer()'
  561. v-if="active=='three2-0'"
  562. :modal='false'
  563. custom-class='dialoglocation dialog_color'
  564. width="385px"
  565. heigth="385px"
  566. :style="styX"
  567. >
  568. <div slot="title" class=dialog_header>
  569. <el-image class="imge" :src="w2" fit="cover" />
  570. <span class="text-color">{{$t('HCFD.physics.viscous')}}</span>
  571. </div>
  572. <el-form>
  573. <div class="selecr">
  574. <el-form-item label="模型类型" :label-width="formLabelWidth5">
  575. <el-select v-model="parameterObj.nmlParam.viscous_terms" placeholder="请选择">
  576. <el-option
  577. v-for="item in selectlist1"
  578. :key="item.value"
  579. :label="item.name"
  580. :value="item.value"
  581. >
  582. </el-option>
  583. </el-select>
  584. </el-form-item>
  585. <div class="line">
  586. <div class="linetext">属性</div>
  587. </div>
  588. <div v-if="parameterObj.nmlParam.viscous_terms=='laminar'">
  589. <el-form-item :label="$t('HCFD.physics.molecular')" :label-width="formLabelWidth5" >
  590. <el-input v-model="parameterObj.nmlParam.prandtlnumber_molecular" autocomplete="off"></el-input>
  591. </el-form-item>
  592. </div>
  593. <div v-if="parameterObj.nmlParam.viscous_terms=='turbulent'">
  594. <el-form-item label="湍流模型" :label-width="formLabelWidth5">
  595. <el-select v-model="parameterObj.nmlParam.turb_model" placeholder="请选择">
  596. <el-option
  597. v-for="item in selectlist2"
  598. :key="item.value"
  599. :label="item.name"
  600. :value="item.value"
  601. >
  602. </el-option>
  603. </el-select>
  604. </el-form-item>
  605. <el-form-item :label="$t('HCFD.physics.Molecular')" :label-width="formLabelWidth5" >
  606. <el-input v-model="parameterObj.nmlParam.prandtlnumber_molecular" autocomplete="off"></el-input>
  607. </el-form-item>
  608. <el-form-item :label="$t('HCFD.physics.turbulents')" :label-width="formLabelWidth5" >
  609. <el-input v-model="Physics.Turbulent.TurbulentPrandtlNumber" autocomplete="off"></el-input>
  610. </el-form-item>
  611. </div>
  612. </div>
  613. </el-form>
  614. <div slot="footer" class="dialog-footer">
  615. <el-button
  616. @click="dialog.inviscid_visiable= false"
  617. >{{ $t("HCFD.file.cancel")}} </el-button
  618. >
  619. <el-button type="primary" @click="hcfdparam(); dialog.inviscid_visiable = false"
  620. >{{ $t("HCFD.file.ok")}}</el-button
  621. >
  622. </div>
  623. </el-dialog>
  624. <!-- 运动网格 -->
  625. <el-dialog
  626. class="lg-y-z"
  627. :visible.sync="dialog.dynamic_visiable "
  628. :close-on-click-modal="false"
  629. @close='activecleer()'
  630. v-if="active=='three2-2'"
  631. :modal='false'
  632. custom-class='dialoglocation dialog_color'
  633. width="385px"
  634. :style="styX"
  635. >
  636. <div slot="title" class=dialog_header>
  637. <el-image class="imge" :src="w4" fit="cover" />
  638. <span class="text-color">{{$t('HCFD.physics.dynamic')}}</span>
  639. </div>
  640. <el-form>
  641. <div class="radio_text text_color liangf">
  642. <div class="classfelx">
  643. <el-radio
  644. v-model="parameterObj.nmlParam.dynamic_Mesh"
  645. label="on"
  646. >on</el-radio
  647. >
  648. </div>
  649. <div class="classfelx">
  650. <el-radio
  651. v-model="parameterObj.nmlParam.dynamic_Mesh"
  652. label="off"
  653. >off</el-radio
  654. >
  655. </div>
  656. </div>
  657. <div class="selecr" v-if="parameterObj.nmlParam.dynamic_Mesh=='on'">
  658. <el-form-item label="运动模型" :label-width="formLabelWidth7">
  659. <el-select v-model="ydval" placeholder="请选择">
  660. <el-option
  661. v-for="item in ydlist"
  662. :key="item.value"
  663. :label="item.name"
  664. :value="item.value"
  665. >
  666. </el-option>
  667. </el-select>
  668. </el-form-item>
  669. <div class="line">
  670. <div class="linetext">定义运动体</div>
  671. </div>
  672. <el-form-item label="数量" :label-width="formLabelWidth7">
  673. <el-input v-model="form.name" autocomplete="off"></el-input>
  674. </el-form-item>
  675. <el-form-item label="名字" :label-width="formLabelWidth7">
  676. <el-input v-model="form.name" autocomplete="off"></el-input>
  677. </el-form-item>
  678. <el-form-item label="运动机理" :label-width="formLabelWidth7">
  679. <el-select v-model="ydval2" placeholder="请选择">
  680. <el-option
  681. v-for="item in ydlist2"
  682. :key="item.value"
  683. :label="item.name"
  684. :value="item.value"
  685. >
  686. </el-option>
  687. </el-select>
  688. </el-form-item>
  689. <el-form-item label="类型" :label-width="formLabelWidth7">
  690. <el-select v-model="ydval3" placeholder="请选择">
  691. <el-option
  692. v-for="item in ydlist3"
  693. :key="item.value"
  694. :label="item.name"
  695. :value="item.value"
  696. >
  697. </el-option>
  698. </el-select>
  699. </el-form-item>
  700. <div v-if="ydval2=='0'&&ydval3=='0'||ydval2=='1'&&ydval3=='0'">
  701. <el-form-item label="无量刚速率" :label-width="formLabelWidth7">
  702. <el-input v-model="form.name" autocomplete="off"></el-input>
  703. </el-form-item>
  704. <el-form-item label="无量刚速率" :label-width="formLabelWidth7">
  705. <el-input v-model="form.name" autocomplete="off"></el-input>
  706. </el-form-item>
  707. </div>
  708. <div v-if="ydval2=='1'&&ydval3=='0'||ydval2=='1'&&ydval3=='1'">
  709. <el-form-item label="相位/度" :label-width="formLabelWidth7">
  710. <el-input v-model="form.name" autocomplete="off"></el-input>
  711. </el-form-item>
  712. <el-form-item label="幅值/度" :label-width="formLabelWidth7">
  713. <el-input v-model="form.name" autocomplete="off"></el-input>
  714. </el-form-item>
  715. </div>
  716. <div v-if="ydval2=='1'&&ydval3=='0'||ydval2=='1'&&ydval3=='1'">
  717. <el-form-item label="旋转中心坐标X" :label-width="formLabelWidth7">
  718. <el-input v-model="form.name" autocomplete="off"></el-input>
  719. </el-form-item>
  720. <el-form-item label="旋转中心坐标Y" :label-width="formLabelWidth7">
  721. <el-input v-model="form.name" autocomplete="off"></el-input>
  722. </el-form-item>
  723. <el-form-item label="旋转中心坐标Z" :label-width="formLabelWidth7">
  724. <el-input v-model="form.name" autocomplete="off"></el-input>
  725. </el-form-item>
  726. </div>
  727. <el-form-item label="旋转轴单位矢量X分量" :label-width="formLabelWidth7">
  728. <el-input v-model="form.name" autocomplete="off"></el-input>
  729. </el-form-item>
  730. <el-form-item label="旋转轴单位矢量Y分量" :label-width="formLabelWidth7">
  731. <el-input v-model="form.name" autocomplete="off"></el-input>
  732. </el-form-item>
  733. <el-form-item label="旋转轴单位矢量Z分量" :label-width="formLabelWidth7">
  734. <el-input v-model="form.name" autocomplete="off"></el-input>
  735. </el-form-item>
  736. <el-form-item label="无量纲旋转起始时间" :label-width="formLabelWidth7">
  737. <el-input v-model="form.name" autocomplete="off"></el-input>
  738. </el-form-item>
  739. <el-form-item label="无量纲旋转持续时间" :label-width="formLabelWidth7">
  740. <el-input v-model="form.name" autocomplete="off"></el-input>
  741. </el-form-item>
  742. <div class="line">
  743. <div class="linetext">t=0时刻力矩中心</div>
  744. </div>
  745. <el-form-item label="X-coordinate" :label-width="formLabelWidth7">
  746. <el-input v-model="form.name" autocomplete="off"></el-input>
  747. </el-form-item>
  748. <el-form-item label="Y-coordinate" :label-width="formLabelWidth7">
  749. <el-input v-model="form.name" autocomplete="off"></el-input>
  750. </el-form-item>
  751. <el-form-item label="Z-coordinate" :label-width="formLabelWidth7">
  752. <el-input v-model="form.name" autocomplete="off"></el-input>
  753. </el-form-item>
  754. <el-form-item label="力矩中心状态" :label-width="formLabelWidth7">
  755. <el-select v-model="ydval4" placeholder="请选择">
  756. <el-option
  757. v-for="item in ydlist4"
  758. :key="item.value"
  759. :label="item.name"
  760. :value="item.value"
  761. >
  762. </el-option>
  763. </el-select>
  764. </el-form-item>
  765. <div class="line">
  766. <div class="linetext">力/力矩无量纲化</div>
  767. </div>
  768. <el-form-item label="无量纲参考面积" :label-width="formLabelWidth7">
  769. <el-input v-model="form.name" autocomplete="off"></el-input>
  770. </el-form-item>
  771. <el-form-item label="无量纲参考弦长" :label-width="formLabelWidth7">
  772. <el-input v-model="form.name" autocomplete="off"></el-input>
  773. </el-form-item>
  774. <el-form-item label="无量纲参考展长" :label-width="formLabelWidth7">
  775. <el-input v-model="form.name" autocomplete="off"></el-input>
  776. </el-form-item>
  777. <div class="line">
  778. <div class="linetext">有量纲物理量</div>
  779. </div>
  780. <div class="liangf">
  781. <div class="classfelx text_color" style="line-height: 2;">
  782. 输出运动体有量纲物理量
  783. </div>
  784. <div class="classfelx">
  785. <el-radio
  786. v-model="parameterObj.nmlParam.dynamic_Mesh"
  787. label="on"
  788. >on</el-radio
  789. >
  790. <el-radio
  791. v-model="parameterObj.nmlParam.dynamic_Mesh"
  792. label="off"
  793. >off</el-radio
  794. >
  795. </div>
  796. </div>
  797. <el-checkbox v-model="checked">预览网格运动</el-checkbox>
  798. </div>
  799. </el-form>
  800. <div slot="footer" class="dialog-footer">
  801. <el-button
  802. @click="dialog.dynamic_visiable = false"
  803. >{{ $t("HCFD.file.cancel")}} </el-button
  804. >
  805. <el-button type="primary" @click="hcfdparam(); dialog.dynamic_visiable = false"
  806. >{{ $t("HCFD.file.ok")}}</el-button
  807. >
  808. </div>
  809. </el-dialog>
  810. <!--非惯性参考条件 -->
  811. <el-dialog
  812. class="lg-y-z"
  813. :visible.sync="dialog.nonitertial_visiable"
  814. :close-on-click-modal="false"
  815. @close='activecleer()'
  816. v-if="active=='three1-1'"
  817. :modal='false'
  818. custom-class='dialoglocation dialog_color'
  819. width="385px"
  820. :style="styX"
  821. >
  822. <div slot="title" class=dialog_header>
  823. <el-image class="imge" :src="w6" fit="cover" />
  824. <span class="text-color">{{$t('HCFD.physics.nonitertial')}}</span>
  825. </div>
  826. <el-form>
  827. <div class="radio_text text_color liangf">
  828. <div class="classfelx">
  829. <el-radio
  830. v-model="parameterObj.nmlParam.noninertial_Reference_Frame"
  831. label="on"
  832. >on</el-radio>
  833. </div>
  834. <div class="classfelx">
  835. <el-radio
  836. v-model="parameterObj.nmlParam.noninertial_Reference_Frame"
  837. label="off"
  838. >off</el-radio
  839. >
  840. </div>
  841. </div>
  842. <div v-if="parameterObj.nmlParam.noninertial_Reference_Frame=='on'">
  843. <div class="line">
  844. <div class="linetext">旋转中心</div>
  845. </div>
  846. <el-form-item label="坐标X" :label-width="formLabelWidth2">
  847. <el-input v-model="form.name" autocomplete="off"></el-input>
  848. </el-form-item>
  849. <el-form-item label="坐标Y" :label-width="formLabelWidth2">
  850. <el-input v-model="form.name" autocomplete="off"></el-input>
  851. </el-form-item>
  852. <el-form-item label="坐标Z" :label-width="formLabelWidth2">
  853. <el-input v-model="form.name" autocomplete="off"></el-input>
  854. </el-form-item>
  855. <div class="line">
  856. <div class="linetext">旋转矢量</div>
  857. </div>
  858. <el-form-item label="X方向分量" :label-width="formLabelWidth2">
  859. <el-input v-model="form.name" autocomplete="off"></el-input>
  860. </el-form-item>
  861. <el-form-item label="Y方向分量" :label-width="formLabelWidth2">
  862. <el-input v-model="form.name" autocomplete="off"></el-input>
  863. </el-form-item>
  864. <el-form-item label="Z方向分量" :label-width="formLabelWidth2">
  865. <el-input v-model="form.name" autocomplete="off"></el-input>
  866. </el-form-item>
  867. </div>
  868. </el-form>
  869. <div slot="footer" class="dialog-footer">
  870. <el-button
  871. @click="dialog.nonitertial_visiable = false"
  872. >{{ $t("HCFD.file.cancel")}} </el-button
  873. >
  874. <el-button type="primary" @click="hcfdparam(); dialog.nonitertial_visiable = false"
  875. >{{ $t("HCFD.file.ok")}}</el-button
  876. >
  877. </div>
  878. </el-dialog>
  879. <!-- 通量残差构造方法 -->
  880. <el-dialog
  881. class="lg-Solution"
  882. :visible.sync="dialog.fluxrc_visiable"
  883. :close-on-click-modal="false"
  884. @close='activecleer()'
  885. v-if="active=='four-0'"
  886. :modal='false'
  887. custom-class='dialoglocation dialog_color'
  888. width="385px"
  889. :style="styX"
  890. >
  891. <div slot="title" class=dialog_header>
  892. <el-image class="imge" :src="q1" fit="cover" />
  893. <span class="text-color">{{$t('HCFD.solution.invis')}}</span>
  894. </div>
  895. <el-form class="groupradio selecr">
  896. <div class="line">
  897. <div class="linetext">属性</div>
  898. </div>
  899. <el-form-item label="通量残差构造方法" :label-width="formLabelWidth7">
  900. <el-select v-model="parameterObj.nmlParam.flux_construction" placeholder="请选择">
  901. <el-option
  902. v-for="item in qjklist"
  903. :key="item.value"
  904. :label="item.name"
  905. :value="item.value"
  906. >
  907. </el-option>
  908. </el-select>
  909. </el-form-item>
  910. <el-form-item label="通量雅可比构造方法" :label-width="formLabelWidth7">
  911. <el-select v-model="parameterObj.nmlParam.flux_construction_lhs" placeholder="请选择">
  912. <el-option
  913. v-for="item in qjklist3"
  914. :key="item.value"
  915. :label="item.name"
  916. :value="item.value"
  917. >
  918. </el-option>
  919. </el-select>
  920. </el-form-item>
  921. <el-form-item label="MUSCL重构格式" :label-width="formLabelWidth7">
  922. <el-input v-model="form.name" autocomplete="off"></el-input>
  923. </el-form-item>
  924. <el-form-item label="通量限制" :label-width="formLabelWidth7">
  925. <el-select v-model="parameterObj.nmlParam.flux_limiter" placeholder="请选择">
  926. <el-option
  927. v-for="item in qjklist2"
  928. :key="item.value"
  929. :label="item.name"
  930. :value="item.value"
  931. >
  932. </el-option>
  933. </el-select>
  934. </el-form-item>
  935. <el-form-item :label="$t('HCFD.solution.firstOrderNum') " :label-width="formLabelWidth7">
  936. <el-input v-model="parameterObj.nmlParam.first_order_iterations" autocomplete="off"></el-input>
  937. </el-form-item>
  938. </el-form>
  939. <div slot="footer" class="dialog-footer">
  940. <el-button @click="referencevisiable((dialog.fluxrc_visiable = false))"
  941. > {{ $t("HCFD.file.cancel")}} </el-button
  942. >
  943. <el-button type="primary" @click="hcfdparam(); dialog.fluxrc_visiable = false"
  944. >{{ $t("HCFD.file.ok")}}</el-button
  945. >
  946. </div>
  947. </el-dialog>
  948. <!-- 时间格式 -->
  949. <el-dialog
  950. :visible.sync="dialog.time_visiable"
  951. class="lg-Solution"
  952. :close-on-click-modal="false"
  953. @close='activecleer()'
  954. v-if="active=='four-1'"
  955. :modal='false'
  956. custom-class='dialoglocation dialog_color'
  957. width="385px"
  958. :style="styX"
  959. >
  960. <div slot="title" class=dialog_header>
  961. <el-image class="imge" :src="q2" fit="cover" />
  962. <span class="text-color">{{$t('HCFD.solution.timeScheme')}}</span>
  963. </div>
  964. <el-form class="lg-form">
  965. <div class="line">
  966. <div class="linetext">属性</div>
  967. </div>
  968. <el-form-item label="时间格式" :label-width="formLabelWidth7" style=" text-align: left;">
  969. <el-select v-model="parameterObj.nmlParam.time_accuracy" placeholder="请选择">
  970. <el-option
  971. v-for="item in tlist1"
  972. :key="item.value"
  973. :label="item.name"
  974. :value="item.value"
  975. >
  976. </el-option>
  977. </el-select>
  978. </el-form-item>
  979. <li class="lheig34 disflex liitem liangf" style="padding:5px 0">
  980. <span class="formLabelWidth8">{{$t('HCFD.solution.stepping')}}</span>
  981. <el-radio-group class="inpw35" style="display:flex" v-model="parameterObj.nmlParam.pseudo_time_stepping">
  982. <el-radio :label="'on'">On</el-radio>
  983. <el-radio :label="'off'">Off</el-radio>
  984. </el-radio-group>
  985. </li>
  986. <li class="disflex liitem liangf">
  987. <span class="formLabelWidth8">{{$t('HCFD.solution.nondim')}}</span>
  988. <el-input v-model="parameterObj.nmlParam.time_step_nondim"></el-input>
  989. </li>
  990. <li class="disflex liitem liangf">
  991. <span class="formLabelWidth8">{{$t('HCFD.solution.subiterations')}}</span>
  992. <el-input v-model="parameterObj.nmlParam.subiterations"></el-input>
  993. </li>
  994. <li class="disflex liitem liangf">
  995. <span class="formLabelWidth8">{{$t('HCFD.solution.cfl')}}</span>
  996. <el-input
  997. v-model="parameterObj.nmlParam.schedule_iteration[0]"
  998. ></el-input>
  999. <el-input
  1000. v-model="parameterObj.nmlParam.schedule_iteration[1]"
  1001. ></el-input>
  1002. </li>
  1003. <li class="disflex liitem liangf">
  1004. <span class="formLabelWidth8">{{$t('HCFD.solution.Schedulecfl')}}</span>
  1005. <el-input v-model="parameterObj.nmlParam.schedule_cfl[0]"></el-input>
  1006. <el-input v-model="parameterObj.nmlParam.schedule_cfl[1]"></el-input>
  1007. </li>
  1008. <li class="disflex liitem liangf">
  1009. <span class="formLabelWidth8">{{$t('HCFD.solution.cflturb')}}</span>
  1010. <el-input
  1011. v-model="parameterObj.nmlParam.schedule_cflturb[0]"
  1012. ></el-input>
  1013. <el-input
  1014. v-model="parameterObj.nmlParam.schedule_cflturb[1]"
  1015. ></el-input>
  1016. </li>
  1017. </el-form>
  1018. <div slot="footer" class="dialog-footer">
  1019. <el-button @click="referencevisiable((dialog.time_visiable = false))"
  1020. >{{ $t("HCFD.file.cancel")}} </el-button
  1021. >
  1022. <el-button type="primary" @click="hcfdparam(); dialog.time_visiable = false"
  1023. >{{ $t("HCFD.file.ok")}}</el-button
  1024. >
  1025. </div>
  1026. </el-dialog>
  1027. <!-- 边界条件 -->
  1028. <el-dialog
  1029. class="dialog-block"
  1030. :visible.sync="dialog.border_visiable"
  1031. :close-on-click-modal="false"
  1032. @close='activecleer()'
  1033. v-if="active=='three2-1'"
  1034. :modal='false'
  1035. custom-class='dialoglocation dialog_color'
  1036. width="384px"
  1037. :style="styX"
  1038. >
  1039. <div slot="title" class=dialog_header>
  1040. <el-image class="imge" :src="w2" fit="cover" />
  1041. <span class="text-color">{{$t('HCFD.physics.boundary')}}</span>
  1042. </div>
  1043. <el-form >
  1044. <div class="selecr">
  1045. <div>
  1046. <vue-uploader
  1047. ref="mapbc"
  1048. :projectId="project.projectId"
  1049. :solverType="'hcfd'"
  1050. :accept="'.mapbc,.dat'"
  1051. :name="'Load BC File'"
  1052. :upId="'1'"
  1053.  @changedesc="changedesc1($event)"
  1054. ></vue-uploader>
  1055. </div>
  1056. <div class="desc">
  1057. <li class="descitem" v-for="(item,index) in desclist" :key="index" >{{item.id}}--{{item.conditionsCode}}--{{item.name}}</li>
  1058. </div>
  1059. <el-form-item label=" 边界类型" :label-width="formLabelWidth2">
  1060. <el-select
  1061. size="mini"
  1062. @change="boundaryChange"
  1063. v-model="Physics.Boundary.bquery"
  1064. placeholder="select boundary"
  1065. >
  1066. <el-option
  1067. v-for="hcfdBoundary in parameterObj.hcfdBoundarys"
  1068. :key="hcfdBoundary.id"
  1069. :label="hcfdBoundary.name"
  1070. :value="hcfdBoundary.id"
  1071. >
  1072. </el-option>
  1073. </el-select>
  1074. </el-form-item>
  1075. <el-form-item label=" 外流类型" :label-width="formLabelWidth2">
  1076. <el-select
  1077. size="mini"
  1078. @change="conditionsChange"
  1079. v-model="Physics.Boundary.cquery"
  1080. placeholder="select Conditions"
  1081. >
  1082. <el-option
  1083. v-for="Condition in Physics.Boundary.Conditions"
  1084. :key="Condition.conditionsCode"
  1085. :label="Condition.name"
  1086. :value="Condition.conditionsCode"
  1087. >
  1088. </el-option>
  1089. </el-select>
  1090. </el-form-item>
  1091. <div v-if="Physics.Boundary.bquery=='WING1'">
  1092. <el-form-item label=" 总压比" :label-width="formLabelWidth">
  1093. <el-input v-model="form.name" autocomplete="off"></el-input>
  1094. </el-form-item>
  1095. <el-form-item label=" 总温比" :label-width="formLabelWidth">
  1096. <el-input v-model="form.name" autocomplete="off"></el-input>
  1097. </el-form-item>
  1098. <el-form-item label="法向" :label-width="formLabelWidth">
  1099. <el-input v-model="form.name" autocomplete="off"></el-input>
  1100. </el-form-item>
  1101. <el-form-item label="入流角(Alpha)" :label-width="formLabelWidth">
  1102. <el-input v-model="form.name" autocomplete="off"></el-input>
  1103. </el-form-item>
  1104. <el-form-item label="入流角(Beta)" :label-width="formLabelWidth">
  1105. <el-input v-model="form.name" autocomplete="off"></el-input>
  1106. </el-form-item>
  1107. <el-form-item label=" 欧拉角(Theta1)" :label-width="formLabelWidth">
  1108. <el-input v-model="form.name" autocomplete="off"></el-input>
  1109. </el-form-item>
  1110. <el-form-item label=" 欧拉角(Theta2)" :label-width="formLabelWidth">
  1111. <el-input v-model="form.name" autocomplete="off"></el-input>
  1112. </el-form-item>
  1113. <el-form-item label="欧拉角(Theta3)" :label-width="formLabelWidth">
  1114. <el-input v-model="form.name" autocomplete="off"></el-input>
  1115. </el-form-item>
  1116. </div>
  1117. </div>
  1118. </el-form>
  1119. <div slot="footer" class="dialog-footer">
  1120. <el-button
  1121. @click="dialog.border_visiable = false"
  1122. >{{ $t("HCFD.file.cancel")}} </el-button
  1123. >
  1124. <el-button type="primary" @click="hcfdparam(); dialog.border_visiable = false"
  1125. >{{ $t("HCFD.file.ok")}} </el-button
  1126. >
  1127. </div>
  1128. </el-dialog>
  1129. <!-- 参考条件 -->
  1130. <el-dialog
  1131. class="dialog-block"
  1132. :visible.sync="dialog.reference_visiable"
  1133. :close-on-click-modal="false"
  1134. @close='activecleer()'
  1135. v-if="active=='three1-0'"
  1136. :modal='false'
  1137. custom-class='dialoglocation dialog_color heightclass'
  1138. width="385px"
  1139. height="400px"
  1140. :style="styX"
  1141. >
  1142. <div slot="title" class=dialog_header>
  1143. <el-image class="imge" :src="w5" fit="cover" />
  1144. <span class="text-color">{{$t('HCFD.physics.reference')}}</span>
  1145. </div>
  1146. <el-form class="groupradio">
  1147. <div class="line">
  1148. <div class="linetext">属性</div>
  1149. </div>
  1150. <li class="disflex liitem liangf">
  1151. <span class="formLabelWidth8">{{ $t("HCFD.physics.machNum") }}</span>
  1152. <el-input
  1153. class="inpw50"
  1154. size="mini"
  1155. v-model="parameterObj.nmlParam.mach_number"
  1156. ></el-input>
  1157. </li>
  1158. <li class=" liitem liangf">
  1159. <span class="formLabelWidth8">{{ $t("HCFD.physics.reyNum") }}</span>
  1160. <el-input
  1161. class="inpw50"
  1162. size="mini"
  1163. v-model="parameterObj.nmlParam.reynolds_number"
  1164. ></el-input>
  1165. </li>
  1166. <li class=" liitem liangf">
  1167. <span class="formLabelWidth8">{{ $t("HCFD.physics.temperature") }}</span>
  1168. </li>
  1169. <li class=" liitem liangf">
  1170. <el-radio-group v-model="parameterObj.nmlParam.temperature_units" style=" width: 100%;">
  1171. <el-radio :label="'Kelvin'">{{ $t("HCFD.physics.kelvin") }}</el-radio>
  1172. <el-radio :label="'Rankine'">{{ $t("HCFD.physics.rankine") }}</el-radio>
  1173. </el-radio-group>
  1174. <el-input v-model="parameterObj.nmlParam.temperature"></el-input>
  1175. </li>
  1176. <li class=" liitem liangf">
  1177. <span class="formLabelWidth8">{{ $t("HCFD.physics.attack") }}</span>
  1178. <el-input v-model="parameterObj.nmlParam.angle_of_attack"></el-input>
  1179. </li>
  1180. <li class=" liitem liangf">
  1181. <span class="formLabelWidth8">{{ $t("HCFD.physics.yaw") }} </span>
  1182. <el-input v-model="parameterObj.nmlParam.angle_of_yaw"></el-input>
  1183. </li>
  1184. <li class=" liitem liangf">
  1185. <span class="formLabelWidth8">{{ $t("HCFD.physics.area") }}</span>
  1186. <el-input v-model="parameterObj.nmlParam.area_reference"></el-input>
  1187. </li>
  1188. <li class=" liitem liangf">
  1189. <span class="formLabelWidth8">{{ $t("HCFD.physics.yaxis") }}</span>
  1190. <el-input v-model="parameterObj.nmlParam.x_moment_length"></el-input>
  1191. </li>
  1192. <li class=" liitem liangf">
  1193. <span class="formLabelWidth8">{{ $t("HCFD.physics.zaxis") }}</span>
  1194. <el-input v-model="parameterObj.nmlParam.y_moment_length"></el-input>
  1195. </li>
  1196. <li class=" liitem liangf">
  1197. <span class="formLabelWidth8">{{ $t("HCFD.physics.momentc") }}</span>
  1198. <el-input v-model="parameterObj.nmlParam.x_moment_center"></el-input>
  1199. </li>
  1200. <li class=" liitem liangf">
  1201. <span class="formLabelWidth8">{{ $t("HCFD.physics.xcoordinate") }}</span>
  1202. <el-input v-model="parameterObj.nmlParam.x_moment_center"></el-input>
  1203. </li>
  1204. <li class=" liitem liangf">
  1205. <span class="formLabelWidth8">{{ $t("HCFD.physics.ycoordinate") }}</span>
  1206. <el-input v-model="parameterObj.nmlParam.y_moment_center"></el-input>
  1207. </li>
  1208. <li class=" liitem liangf">
  1209. <span class="formLabelWidth8">{{ $t("HCFD.physics.zcoordinate") }}</span>
  1210. <el-input v-model="parameterObj.nmlParam.z_moment_center"></el-input>
  1211. </li>
  1212. </el-form>
  1213. <div slot="footer" class="dialog-footer">
  1214. <el-button
  1215. @click="dialog.reference_visiable = false"
  1216. >{{ $t("HCFD.file.cancel")}} </el-button
  1217. >
  1218. <el-button type="primary" @click="hcfdparam(); dialog.reference_visiable = false"
  1219. >{{ $t("HCFD.file.ok")}}</el-button
  1220. >
  1221. </div>
  1222. </el-dialog>
  1223. <!-- 线性方程组求解参数 -->
  1224. <el-dialog
  1225. class="lg-Solution"
  1226. :visible.sync="dialog.xian_visiable"
  1227. :close-on-click-modal="false"
  1228. @close='activecleer()'
  1229. v-if="active=='four2-0'"
  1230. :modal='false'
  1231. custom-class='dialoglocation dialog_color'
  1232. width="385px"
  1233. :style="styX"
  1234. >
  1235. <div slot="title" class=dialog_header>
  1236. <el-image class="imge" :src="q3" fit="cover" />
  1237. <span class="text-color">{{$t('HCFD.solution.linearSol')}}</span>
  1238. </div>
  1239. <el-form >
  1240. <li class="disflex liitem liangf ">
  1241. <span class="formLabelWidth8">
  1242. {{ $t("HCFD.solution.meanflow") }}
  1243. </span>
  1244. <el-input
  1245. class="inpw75"
  1246. size="mini"
  1247. v-model="parameterObj.nmlParam.meanflow_sweeps"
  1248. ></el-input>
  1249. </li>
  1250. <li class="disflex liitem liangf ">
  1251. <span class="formLabelWidth8">
  1252. {{ $t("HCFD.solution.turbulence") }}
  1253. </span>
  1254. <el-input
  1255. class="inpw75"
  1256. size="mini"
  1257. v-model="parameterObj.nmlParam.turbulence_sweeps"
  1258. ></el-input>
  1259. </li>
  1260. <el-form-item :label="$t('HCFD.solution.gcr')" :label-width="formLabelWidth6" class="iemradio" >
  1261. <el-radio-group v-model="parameterObj.nmlParam.line_implicit">
  1262. <el-radio label="off">Off</el-radio>
  1263. <el-radio label="on" class="radiooff">On</el-radio>
  1264. </el-radio-group>
  1265. </el-form-item>
  1266. </el-form>
  1267. <div slot="footer" class="dialog-footer">
  1268. <el-button @click="referencevisiable((dialog.xian_visiable = false))"
  1269. >{{ $t("HCFD.file.cancel")}} </el-button
  1270. >
  1271. <el-button type="primary" @click="hcfdparam(); dialog.xian_visiable = false"
  1272. >{{ $t("HCFD.file.ok")}} </el-button
  1273. >
  1274. </div>
  1275. </el-dialog>
  1276. <!-- 初始化 -->
  1277. <el-dialog
  1278. class="lg-y-z"
  1279. :visible.sync="dialog.initialization_visiable "
  1280. :close-on-click-modal="false"
  1281. @close='activecleer()'
  1282. v-if="active=='four2-10'"
  1283. :modal='false'
  1284. custom-class='dialoglocation dialog_color'
  1285. width="385px"
  1286. :style="styX"
  1287. >
  1288. <div slot="title" class=dialog_header>
  1289. <el-image class="imge" :src="q4" fit="cover" />
  1290. <span class="text-color">{{$t('HCFD.solution.initialization')}}</span>
  1291. </div>
  1292. <el-form>
  1293. <div class="radio_text text_color liangf radiogroup " >
  1294. <el-radio-group v-model="initialization" size="mini">
  1295. <el-radio label="freestreams" style="flex:1">{{
  1296. $t("HCFD.solution.freestreams")
  1297. }}</el-radio>
  1298. <el-radio label="specified" style="flex:1">{{
  1299. $t("HCFD.solution.specified")
  1300. }}</el-radio>
  1301. </el-radio-group>
  1302. </div>
  1303. <div v-if="initialization=='specified'">
  1304. <div class="line">
  1305. <div class="linetext">属性</div>
  1306. </div>
  1307. <el-form-item label="区域数量" :label-width="formLabelWidth2">
  1308. <el-input v-model="form.name" autocomplete="off"></el-input>
  1309. </el-form-item>
  1310. <div class="selecr">
  1311. <el-form-item label=" 区域类型" :label-width="formLabelWidth2">
  1312. <el-select @change="changest" v-model="loadval" placeholder="请选择">
  1313. <el-option
  1314. v-for="item in loadlist"
  1315. :key="item.value"
  1316. :label="item.name"
  1317. :value="item.value"
  1318. >
  1319. </el-option>
  1320. </el-select>
  1321. </el-form-item>
  1322. <div v-if="loadval=='0'">
  1323. <el-form-item label="顶点1" :label-width="formLabelWidth2">
  1324. <el-input v-model="form.name" autocomplete="off"></el-input>
  1325. </el-form-item>
  1326. <el-form-item label="顶点2" :label-width="formLabelWidth2">
  1327. <el-input v-model="form.name" autocomplete="off"></el-input>
  1328. </el-form-item>
  1329. </div>
  1330. <div v-if="loadval=='1'">
  1331. <el-form-item label="球心" :label-width="formLabelWidth2">
  1332. <el-input v-model="form.name" autocomplete="off"></el-input>
  1333. </el-form-item>
  1334. <el-form-item label="半径" :label-width="formLabelWidth2">
  1335. <el-input v-model="form.name" autocomplete="off"></el-input>
  1336. </el-form-item>
  1337. </div>
  1338. <div v-if="loadval=='2'">
  1339. <el-form-item label="球心" :label-width="formLabelWidth2">
  1340. <el-input v-model="form.name" autocomplete="off"></el-input>
  1341. </el-form-item>
  1342. <el-form-item label="端点1" :label-width="formLabelWidth2">
  1343. <el-input v-model="form.name" autocomplete="off"></el-input>
  1344. </el-form-item>
  1345. <el-form-item label="端点2" :label-width="formLabelWidth2">
  1346. <el-input v-model="form.name" autocomplete="off"></el-input>
  1347. </el-form-item>
  1348. </div>
  1349. <div v-if="loadval=='2'">
  1350. <el-form-item label="端点1" :label-width="formLabelWidth2">
  1351. <el-input v-model="form.name" autocomplete="off"></el-input>
  1352. </el-form-item>
  1353. <el-form-item label="半径1" :label-width="formLabelWidth2">
  1354. <el-input v-model="form.name" autocomplete="off"></el-input>
  1355. </el-form-item>
  1356. <el-form-item label="端点2" :label-width="formLabelWidth2">
  1357. <el-input v-model="form.name" autocomplete="off"></el-input>
  1358. </el-form-item>
  1359. <el-form-item label="半径2" :label-width="formLabelWidth2">
  1360. <el-input v-model="form.name" autocomplete="off"></el-input>
  1361. </el-form-item>
  1362. </div>
  1363. </div>
  1364. <div class="line">
  1365. <div class="linetext">区域变量</div>
  1366. </div>
  1367. <el-form-item label="无量纲密度" :label-width="formLabelWidth7">
  1368. <el-input v-model="form.name" autocomplete="off"></el-input>
  1369. </el-form-item>
  1370. <el-form-item label="无量纲声速" :label-width="formLabelWidth7">
  1371. <el-input v-model="form.name" autocomplete="off"></el-input>
  1372. </el-form-item>
  1373. <el-form-item label="X方向无量纲速度分量" :label-width="formLabelWidth7">
  1374. <el-input v-model="form.name" autocomplete="off"></el-input>
  1375. </el-form-item>
  1376. <el-form-item label="Y方向无量纲速度分量" :label-width="formLabelWidth7">
  1377. <el-input v-model="form.name" autocomplete="off"></el-input>
  1378. </el-form-item>
  1379. <el-form-item label="Z方向无量纲速度分量" :label-width="formLabelWidth7">
  1380. <el-input v-model="form.name" autocomplete="off"></el-input>
  1381. </el-form-item>
  1382. </div>
  1383. </el-form>
  1384. <div slot="footer" class="dialog-footer">
  1385. <el-button
  1386. @click="dialog.initialization_visiable = false"
  1387. >{{ $t("HCFD.file.cancel")}} </el-button
  1388. >
  1389. <el-button type="primary" @click="hcfdparam(); dialog.initialization_visiable = false"
  1390. >{{ $t("HCFD.file.ok")}}</el-button
  1391. >
  1392. </div>
  1393. </el-dialog>
  1394. <!-- 运行控制Run Control -->
  1395. <el-dialog
  1396. :visible.sync="dialog.runc_visiable"
  1397. :close-on-click-modal="false"
  1398. @close='activecleer()'
  1399. v-if="active=='four3-0'"
  1400. :modal='false'
  1401. custom-class='dialoglocation dialog_color'
  1402. width="385px"
  1403. :style="styX"
  1404. >
  1405. <div slot="title" class=dialog_header>
  1406. <el-image class="imge" :src="q5" fit="cover" />
  1407. <span class="text-color">{{$t('HCFD.solution.run')}}</span>
  1408. </div>
  1409. <el-form class="lg-form text_color">
  1410. <el-form-item :label="$t('HCFD.solution.iterNum')" :label-width="formLabelWidth6">
  1411. <el-input v-model="parameterObj.nmlParam.steps" autocomplete="off"></el-input>
  1412. </el-form-item>
  1413. <el-form-item :label="$t('HCFD.solution.stopToler')" :label-width="formLabelWidth6">
  1414. <el-input v-model="parameterObj.nmlParam.stopping_tolerance" autocomplete="off"></el-input>
  1415. </el-form-item>
  1416. <el-form-item :label="$t('HCFD.solution.writeFreq')" :label-width="formLabelWidth6">
  1417. <el-input v-model="parameterObj.nmlParam.restart_write_freq" autocomplete="off"></el-input>
  1418. </el-form-item>
  1419. <el-form-item :label="$t('HCFD.solution.evaluate')" :label-width="formLabelWidth6">
  1420. <el-input v-model="parameterObj.nmlParam.jacobian_eval_freq" autocomplete="off"></el-input>
  1421. </el-form-item>
  1422. <el-form-item :label="$t('HCFD.solution.Restart')" :label-width="formLabelWidth6">
  1423. <el-radio-group class="inpw35" v-model="parameterObj.nmlParam.restart_read">
  1424. <el-radio label="off">Off</el-radio>
  1425. <el-radio label="on">On</el-radio>
  1426. </el-radio-group>
  1427. </el-form-item>
  1428. <el-button type="info" @click="hcfdparam()"> 运行</el-button>
  1429. </el-form>
  1430. <div slot="footer" class="dialog-footer">
  1431. <el-button @click="runcvisiable()"> {{ $t("HCFD.file.cancel")}} </el-button>
  1432. <el-button type="primary" @click="Runsolve()"
  1433. >{{ $t("HCFD.file.ok")}}</el-button
  1434. >
  1435. </div>
  1436. </el-dialog>
  1437. <!-- 物面输出 -->
  1438. <el-dialog
  1439. :visible.sync="dialog.boundaryo_visiable"
  1440. :close-on-click-modal="false"
  1441. @close='activecleer()'
  1442. class="Conditions lg-out-h"
  1443. v-if="active=='four3-1'"
  1444. :modal='false'
  1445. custom-class='dialoglocation dialog_color'
  1446. width="385px"
  1447. :style="styX"
  1448. >
  1449. <div slot="title" class=dialog_header>
  1450. <el-image class="imge" :src="q6" fit="cover" />
  1451. <span class="text-color">{{$t('HCFD.solution.bounOut')}}</span>
  1452. </div>
  1453. <el-form>
  1454. <div class="selecr">
  1455. <el-form-item label=" 特征" :label-width="formLabelWidth2">
  1456. <el-select @change="changest" v-model="objectplaneval" placeholder="请选择">
  1457. <el-option
  1458. v-for="item in objectplanelist"
  1459. :key="item.value"
  1460. :label="item.name"
  1461. :value="item.value"
  1462. >
  1463. </el-option>
  1464. </el-select>
  1465. </el-form-item>
  1466. </div>
  1467. <div v-if="objectplaneval=='0'">
  1468. <el-form-item :label=" $t('HCFD.solution.outputfreq')" :label-width="formLabelWidth2">
  1469. <el-input v-model="parameterObj.nmlParam.animation_freq" autocomplete="off"></el-input>
  1470. </el-form-item>
  1471. </div>
  1472. <div v-else>
  1473. <el-form-item :label=" $t('HCFD.solution.outputfreq')" :label-width="formLabelWidth2">
  1474. <el-input v-model="parameterObj.nmlParam.volume_animation_freq" autocomplete="off"></el-input>
  1475. </el-form-item>
  1476. </div>
  1477. <div class="line">
  1478. <div class="linetext">{{ $t("HCFD.solution.Variables")}}</div>
  1479. </div>
  1480. <div v-if="objectplaneval=='0'">
  1481. <el-checkbox
  1482. :indeterminate="Solution.boundaryout.isIndeterminate"
  1483. v-model="Solution.boundaryout.checkAll"
  1484. @change="solutionbCheckAllChange"
  1485. >{{ $t("HCFD.solution.all")}}</el-checkbox
  1486. >
  1487. <div class="displanblock">
  1488. <el-checkbox
  1489. v-model="parameterObj.nmlParam.a_u">
  1490. {{ $t("HCFD.solution.Xcomponent")}}</el-checkbox>
  1491. <el-checkbox
  1492. v-model="parameterObj.nmlParam.a_v"
  1493. >{{ $t("HCFD.solution.Ycomponent")}}</el-checkbox>
  1494. <el-checkbox
  1495. v-model="parameterObj.nmlParam.a_w"
  1496. >{{ $t("HCFD.solution.Zcomponent")}}</el-checkbox>
  1497. <el-checkbox
  1498. v-model="parameterObj.nmlParam.a_p"
  1499. >{{ $t("HCFD.solution.Press")}}</el-checkbox>
  1500. <el-checkbox
  1501. v-model="parameterObj.nmlParam.a_cp"
  1502. >{{ $t("HCFD.solution.presscoefficient")}}</el-checkbox>
  1503. <el-checkbox
  1504. v-model="parameterObj.nmlParam.a_mach"
  1505. >{{ $t("HCFD.solution.mnumber")}}</el-checkbox>
  1506. <el-checkbox
  1507. v-model="parameterObj.nmlParam.a_vort_mag"
  1508. >{{ $t("HCFD.solution.magnitude")}}</el-checkbox>
  1509. <el-checkbox
  1510. v-model="parameterObj.nmlParam.a_vort_x "
  1511. >{{ $t("HCFD.solution.Xvorticity")}}</el-checkbox>
  1512. <el-checkbox
  1513. v-model="parameterObj.nmlParam.a_vort_y"
  1514. >{{ $t("HCFD.solution.Yvorticity")}}</el-checkbox>
  1515. <el-checkbox
  1516. v-model="parameterObj.nmlParam.a_vort_z "
  1517. >{{ $t("HCFD.solution.Zvorticity")}}</el-checkbox>
  1518. <el-checkbox
  1519. v-model="parameterObj.nmlParam.a_q_criterion"
  1520. >{{ $t("HCFD.solution.Criterion")}}</el-checkbox>
  1521. </div>
  1522. </div>
  1523. <div v-else>
  1524. <el-checkbox
  1525. :indeterminate="Solution.volumout.isIndeterminate"
  1526. v-model="Solution.volumout.checkAll"
  1527. @change="solutionvCheckAllChange"
  1528. >{{ $t("HCFD.solution.all")}}</el-checkbox
  1529. >
  1530. <div class="displanblock">
  1531. <el-checkbox
  1532. v-model="parameterObj.nmlParam.v_u">{{ $t("HCFD.solution.Xcomponent")}}</el-checkbox>
  1533. <el-checkbox
  1534. v-model="parameterObj.nmlParam.v_v "
  1535. >{{ $t("HCFD.solution.Ycomponent")}}</el-checkbox>
  1536. <el-checkbox
  1537. v-model="parameterObj.nmlParam.v_w"
  1538. >{{ $t("HCFD.solution.Zcomponent")}}</el-checkbox>
  1539. <el-checkbox
  1540. v-model="parameterObj.nmlParam.v_p "
  1541. >{{ $t("HCFD.solution.Press")}}</el-checkbox>
  1542. <el-checkbox
  1543. v-model="parameterObj.nmlParam.v_cp"
  1544. >{{ $t("HCFD.solution.presscoefficient")}}</el-checkbox>
  1545. <el-checkbox
  1546. v-model="parameterObj.nmlParam.v_mach"
  1547. >{{ $t("HCFD.solution.mnumber")}}</el-checkbox>
  1548. <el-checkbox
  1549. v-model="parameterObj.nmlParam.v_vort_mag"
  1550. >{{ $t("HCFD.solution.magnitude")}}</el-checkbox>
  1551. <el-checkbox
  1552. v-model="parameterObj.nmlParam.v_vort_x "
  1553. >{{ $t("HCFD.solution.Xvorticity")}}</el-checkbox>
  1554. <el-checkbox
  1555. v-model="parameterObj.nmlParam.v_vort_y"
  1556. >{{ $t("HCFD.solution.Yvorticity")}}</el-checkbox>
  1557. <el-checkbox
  1558. v-model="parameterObj.nmlParam.v_vort_z "
  1559. >{{ $t("HCFD.solution.Zvorticity")}}</el-checkbox>
  1560. <el-checkbox
  1561. v-model="parameterObj.nmlParam.v_q_criterion"
  1562. >{{ $t("HCFD.solution.Criterion")}}</el-checkbox>
  1563. </div>
  1564. </div>
  1565. </el-form>
  1566. <div slot="footer" class="dialog-footer">
  1567. <el-button
  1568. @click="referencevisiable(dialog.boundaryo_visiable = false)"
  1569. >{{ $t("HCFD.file.cancel")}} </el-button
  1570. >
  1571. <el-button type="primary" @click="hcfdparam(); dialog.boundaryo_visiable = false"
  1572. >{{ $t("HCFD.file.ok")}}</el-button
  1573. >
  1574. </div>
  1575. </el-dialog>
  1576. <!-- 流场输出 -->
  1577. <el-dialog
  1578. class="lg-y-z"
  1579. :title="$t('HCFD.solution.specialPara')"
  1580. :visible.sync="dialog.specialp_visiable"
  1581. :close-on-click-modal="false"
  1582. @close='activecleer()'
  1583. v-if="active=='four4-0'"
  1584. :modal='false'
  1585. custom-class='dialoglocation dialog_color'
  1586. width="385px"
  1587. :style="styX"
  1588. >
  1589. <el-form>
  1590. <el-radio-group v-model="parameterObj.nmlParam.large_angle_fix">
  1591. <el-radio label="off">Off</el-radio>
  1592. <el-radio label="on">On</el-radio>
  1593. </el-radio-group>
  1594. </el-form>
  1595. <div slot="footer" class="dialog-footer">
  1596. <el-button
  1597. @click="referencevisiable((dialog.specialp_visiable = false))"
  1598. >{{ $t("HCFD.file.cancel")}} </el-button
  1599. >
  1600. <el-button type="primary" @click="dialog.specialp_visiable = false"
  1601. >{{ $t("HCFD.file.ok")}}</el-button
  1602. >
  1603. </div>
  1604. </el-dialog>
  1605. <el-dialog
  1606. title="Swap Y-Z Axres"
  1607. :visible.sync="dialog.swap_visiable"
  1608. class="lg-y-z"
  1609. :close-on-click-modal="false"
  1610. @close='activecleer()'
  1611. v-if="active=='four4-1'"
  1612. :modal='false'
  1613. custom-class='dialoglocation dialog_color'
  1614. width="385px"
  1615.  :style="styX"
  1616. >
  1617. <el-form>
  1618. <el-radio-group v-model="parameterObj.nmlParam.swap_yz_axes">
  1619. <el-radio label="false">Off</el-radio>
  1620. <el-radio label="true">On</el-radio>
  1621. </el-radio-group>
  1622. </el-form>
  1623. <div slot="footer" class="dialog-footer">
  1624. <el-button @click="referencevisiable((dialog.swap_visiable = false))"
  1625. > {{ $t("HCFD.file.cancel")}} </el-button
  1626. >
  1627. <el-button type="primary" @click="dialog.swap_visiable = false"
  1628. >{{ $t("HCFD.file.ok")}}</el-button
  1629. >
  1630. </div>
  1631. </el-dialog>
  1632. <!-- 资源选择 -->
  1633. <el-dialog
  1634. :close-on-click-modal="false"
  1635. @close='activecleer()'
  1636. :title="$t('HCFD.solution.Resource')"
  1637. :visible.sync="dialog.ziyuan"
  1638. width="45%"
  1639. class="dialog"
  1640. custom-class='dialog_color'
  1641. >
  1642. <el-form>
  1643. <el-table
  1644. :data="ziyprojects"
  1645. border
  1646. :row-key="getRowKeys"
  1647. height="250"
  1648. row-class-name='table-color'
  1649. ref="multipleTable"
  1650. @selection-change="ziySelectionChange"
  1651. @select="ziySelectionSelect"
  1652. size="mini"
  1653. :fit="true"
  1654. >
  1655. <el-table-column type="selection" label="选择" :reserve-selection="true"/>
  1656. <el-table-column property="id" label="ID" />
  1657. <el-table-column property="resIp" label="资源内网IP" />
  1658. <el-table-column property="resShortname" label="资源简称" />
  1659. </el-table>
  1660. </el-form>
  1661. <div class="pagination">
  1662. <Pagination
  1663. :pagination-config="paginationConfig"
  1664. @putPagination="getPagination"
  1665. ></Pagination>
  1666. </div>
  1667. <div slot="footer" class="dialog-footer">
  1668. <el-button @click="dialog.ziyuan = false"> {{ $t("HCFD.file.cancel")}} </el-button>
  1669. <el-button type="primary" @click='resourceOK()'>{{ $t("HCFD.file.ok")}} </el-button>
  1670. </div>
  1671. </el-dialog>
  1672. <!-- 求解表面 -->
  1673. <el-dialog
  1674. :visible.sync="dialog.SurfaceGrid_visiable"
  1675. class="lg-y-z"
  1676. :close-on-click-modal="false"
  1677. :modal-append-to-body="false"
  1678. :append-to-body="false"
  1679. @close='activecleer()'
  1680. v-if="active=='five-0'"
  1681. :modal='false'
  1682. custom-class='dialoglocation dialog_color'
  1683. width="385px"
  1684.  :style="styX"
  1685. >
  1686. <div slot="title" class=dialog_header>
  1687. <el-image class="imge" :src="j1" fit="cover" />
  1688. <span class="text-color">{{$t('HCFD.results.Surfacegrid')}}</span>
  1689. </div>
  1690. <div class="flexpad30">
  1691. <div class="selecr">
  1692. <el-form>
  1693. <el-form-item :label="$t('HCFD.results.steps') " :label-width="formLabelWidth2">
  1694. <el-select size="mini" v-model="bStep" @change="bStepChange" placeholder="请选择">
  1695. <el-option
  1696. v-for="setep in boundaryStep"
  1697. :key="setep"
  1698. :label="setep"
  1699. :value="setep"
  1700. >
  1701. </el-option>
  1702. </el-select>
  1703. </el-form-item>
  1704. <el-form-item :label=" $t('HCFD.results.scalar') " :label-width="formLabelWidth2">
  1705. <el-select size="mini" v-model="bScalar" placeholder="请选择">
  1706. <el-option
  1707. v-for="scalar in boundaryScalars"
  1708. :key="scalar"
  1709. :label="scalar"
  1710. :value="scalar"
  1711. >
  1712. </el-option>
  1713. </el-select>
  1714. </el-form-item>
  1715. <div>
  1716. <el-form-item :label=" $t('HCFD.results.contour')" :label-width="formLabelWidth2">
  1717. <el-input-number v-model="Surfacenum" @change="SurfaceChange" :min="1" :max="10" label="描述文字"></el-input-number>
  1718. </el-form-item>
  1719. <li class="disflex lheig34 liitem">
  1720. <span class="span100 marb5 formLabelWidth15">{{ $t("HCFD.results.vector")}} </span>
  1721. <el-checkbox checked>Velocity</el-checkbox>
  1722. </li>
  1723. <li class="disflex lheig34 liitem">
  1724. <span class='span100 marb5 formLabelWidth15' >{{ $t("HCFD.results.show")}} </span>
  1725. <el-checkbox-group v-model="belementCheckeds" style="display:flex">
  1726. <el-checkbox label="Mesh" @change="Contourval('Mesh')"
  1727. ></el-checkbox>
  1728. <el-checkbox label="Contour" @change="Contourval('Contour')"
  1729. ></el-checkbox>
  1730. </el-checkbox-group>
  1731. </li>
  1732. </div>
  1733. <el-button
  1734. size="mini"
  1735. type="primary"
  1736. style="margin:30px 0 30px 40%"
  1737. @click="boundaryShow()"
  1738. > {{ $t("HCFD.results.Surface")}} </el-button>
  1739. >
  1740. </el-form>
  1741. </div>
  1742. </div>
  1743. <div slot="footer" class="dialog-footer">
  1744. <el-button @click="referencevisiable((dialog.SurfaceGrid_visiable = false))"
  1745. >{{ $t("HCFD.file.cancel")}} </el-button
  1746. >
  1747. <el-button type="primary" @click="dialog.SurfaceGrid_visiable = false"
  1748. >{{ $t("HCFD.file.ok")}}</el-button
  1749. >
  1750. </div>
  1751. </el-dialog>
  1752. <!-- 流场数据 -->
  1753. <el-dialog
  1754. :visible.sync="dialog.VolumeGrid_visiable"
  1755. class="lg-y-z"
  1756. :close-on-click-modal="false"
  1757. @close='activecleer()'
  1758. v-if="active=='five-1'"
  1759. :modal='false'
  1760. custom-class='dialoglocation dialog_color'
  1761. width="385px"
  1762.  :style="styX"
  1763. >
  1764. <div slot="title" class=dialog_header>
  1765. <el-image class="imge" :src="j2" fit="cover" />
  1766. <span class="text-color">{{$t('HCFD.results.volume')}}</span>
  1767. </div>
  1768. <div class="selecr">
  1769. <el-form>
  1770. <el-form-item :label="$t('HCFD.results.steps') " :label-width="formLabelWidth2">
  1771. <el-select size="mini" v-model="vStep" @change="vStepChange" placeholder="请选择">
  1772. <el-option
  1773. label="请选择"
  1774. :value="0"
  1775. >
  1776. </el-option>
  1777. <el-option
  1778. v-for="setep in volumStep"
  1779. :key="setep"
  1780. :label="setep"
  1781. :value="setep"
  1782. >
  1783. </el-option>
  1784. </el-select>
  1785. </el-form-item>
  1786. <el-form-item :label="$t('HCFD.results.scalar') " :label-width="formLabelWidth2">
  1787. <el-select size="mini" v-model="vSalar" placeholder="请选择">
  1788. <el-option
  1789. v-for="scalar in volumScalars"
  1790. :key="scalar"
  1791. :label="scalar"
  1792. :value="scalar"
  1793. >
  1794. </el-option>
  1795. </el-select>
  1796. </el-form-item>
  1797. <div>
  1798. <li class="disflex lheig34 liitem">
  1799. <span class="span100 marb5 formLabelWidth15">{{ $t("HCFD.results.vector")}} </span>
  1800. <el-checkbox checked>Velocity</el-checkbox>
  1801. </li>
  1802. <el-form-item :label=" $t('HCFD.results.contour')" :label-width="formLabelWidth2">
  1803. <el-input-number v-model="Volumenum" @change="VolumenumChange" :min="1" :max="10" label="描述文字"></el-input-number>
  1804. </el-form-item>
  1805. <li class="disflex lheig34 liitem">
  1806. <span class="span100 marb5 formLabelWidth15">{{ $t("HCFD.results.show")}}</span>
  1807. <el-checkbox-group v-model="velementCheckeds" style="display:flex">
  1808. <el-checkbox
  1809. label="Mesh"
  1810. @change="ContourvalVolume('Mesh')"
  1811. ></el-checkbox>
  1812. <el-checkbox
  1813. label="Contour"
  1814. @change="ContourvalVolume('Contour')"
  1815. ></el-checkbox>
  1816. </el-checkbox-group>
  1817. </li>
  1818. </div>
  1819. <el-button
  1820. type="primary"
  1821. size="mini"
  1822. style="margin:30px 0 30px 40%"
  1823. @click="showVolume()"
  1824. >{{ $t("HCFD.results.ShowVolume")}}</el-button
  1825. >
  1826. </el-form>
  1827. </div>
  1828. <div slot="footer" class="dialog-footer">
  1829. <el-button @click="referencevisiable((dialog.VolumeGrid_visiable = false))"
  1830. >{{ $t("HCFD.file.cancel")}}</el-button
  1831. >
  1832. <el-button type="primary" @click="dialog.VolumeGrid_visiable = false"
  1833. >{{ $t("HCFD.file.ok")}}</el-button
  1834. >
  1835. </div>
  1836. </el-dialog>
  1837. <!--轮廓显示 Contour Displsy-->
  1838. <el-dialog :visible.sync="dialog.contour_visiable"
  1839. v-if="active=='five7-0'"
  1840. :modal='false'
  1841. :close-on-click-modal="false"
  1842. @close='activecleer()'
  1843. custom-class='dialoglocation dialog_color'
  1844. width="385px"
  1845. :style="styX"
  1846. >
  1847. <div slot="title" class=dialog_header>
  1848. <el-image class="imge" :src="p3" fit="cover" />
  1849. <span class="text-color">轮廓显示</span>
  1850. </div>
  1851. <el-form>
  1852. <div class="line">
  1853. <div class="linetext">轮廓</div>
  1854. </div>
  1855. <div class="Squareline selecr">
  1856. <el-form-item label="名称" :label-width="formLabelWidth2" >
  1857. <el-input value="PingYi" autocomplete="off"></el-input>
  1858. </el-form-item>
  1859. <el-form-item label="类型" :label-width="formLabelWidth2" >
  1860. <el-input value="PingYi" autocomplete="off"></el-input>
  1861. </el-form-item>
  1862. <el-form-item :label="$t('HCFD.results.scalar') " :label-width="formLabelWidth2">
  1863. <el-select
  1864. size="mini"
  1865. v-model="vSalar"
  1866. placeholder="select boundary"
  1867. >
  1868. <el-option
  1869. v-for="scalar in volumScalars"
  1870. :key="scalar"
  1871. :label="scalar"
  1872. :value="scalar"
  1873. >
  1874. </el-option>
  1875. </el-select>
  1876. </el-form-item>
  1877. </div>
  1878. <div class="line">
  1879. <div class="linetext"> 标量集</div>
  1880. </div>
  1881. <el-form-item label="水平" :label-width="formLabelWidth2" >
  1882. <el-input value="" autocomplete="off"></el-input>
  1883. </el-form-item>
  1884. <div class="disflex lheig34 liitem">
  1885. <el-checkbox-group v-model="velementCheckeds" style="display:flex">
  1886. <el-checkbox
  1887. label="Horizontal"
  1888. @change="ContourvalVolume('Mesh')"
  1889. ></el-checkbox>
  1890. <el-checkbox
  1891. label="Velocity"
  1892. @change="ContourvalVolume('Contour')"
  1893. ></el-checkbox>
  1894. </el-checkbox-group>
  1895. </div>
  1896. <div class="line">
  1897. <div class="linetext"> 范围</div>
  1898. </div>
  1899. <el-form-item label="最大范围" :label-width="formLabelWidth2" >
  1900. <el-input value="0" autocomplete="off"></el-input>
  1901. </el-form-item>
  1902. <el-form-item label="最小范围" :label-width="formLabelWidth2" >
  1903. <el-input value="0" autocomplete="off"></el-input>
  1904. </el-form-item>
  1905. </el-form>
  1906. <div slot="footer" class="dialog-footer">
  1907. <el-button @click="dialog.contour_visiable= false"
  1908. >{{ $t("HCFD.file.cancel")}}</el-button
  1909. >
  1910. <el-button type="primary" @click="dialog.contour_visiable = false"
  1911. >{{ $t("HCFD.file.ok")}}</el-button
  1912. >
  1913. </div>
  1914. </el-dialog>
  1915. <!--线条显示 Line Displsy-->
  1916. <el-dialog :visible.sync="dialog.Line_visiable"
  1917. v-if="active=='five7-1'"
  1918. :modal='false'
  1919. :close-on-click-modal="false"
  1920. @close='activecleer()'
  1921. custom-class='dialoglocation dialog_color'
  1922. width="385px"
  1923. :style="styX"
  1924. >
  1925. <div slot="title" class=dialog_header>
  1926. <el-image class="imge" :src="p9" fit="cover" />
  1927. <span class="text-color">线显示</span>
  1928. </div>
  1929. <el-form>
  1930. <div class="line">
  1931. <div class="linetext">线</div>
  1932. </div>
  1933. <div class="Squareline selecr">
  1934. <el-form-item label="名称" :label-width="formLabelWidth2" >
  1935. <el-input value="PingYi" autocomplete="off"></el-input>
  1936. </el-form-item>
  1937. <el-form-item label="类型" :label-width="formLabelWidth2" >
  1938. <el-input value="PingYi" autocomplete="off"></el-input>
  1939. </el-form-item>
  1940. <el-form-item :label="$t('HCFD.results.scalar') " :label-width="formLabelWidth2">
  1941. <el-select
  1942. size="mini"
  1943. v-model="vSalar"
  1944. placeholder="select boundary"
  1945. >
  1946. <el-option
  1947. v-for="scalar in volumScalars"
  1948. :key="scalar"
  1949. :label="scalar"
  1950. :value="scalar"
  1951. >
  1952. </el-option>
  1953. </el-select>
  1954. </el-form-item>
  1955. </div>
  1956. <div class="line">
  1957. <div class="linetext"> 标量集</div>
  1958. </div>
  1959. <el-form-item label="水平" :label-width="formLabelWidth2" >
  1960. <el-input value="" autocomplete="off"></el-input>
  1961. </el-form-item>
  1962. <div class="line">
  1963. <div class="linetext"> 范围</div>
  1964. </div>
  1965. <el-form-item label="最大范围" :label-width="formLabelWidth2" >
  1966. <el-input value="0" autocomplete="off"></el-input>
  1967. </el-form-item>
  1968. <el-form-item label="最小范围" :label-width="formLabelWidth2" >
  1969. <el-input value="0" autocomplete="off"></el-input>
  1970. </el-form-item>
  1971. </el-form>
  1972. <div slot="footer" class="dialog-footer">
  1973. <el-button @click="dialog.Line_visiable= false"
  1974. >{{ $t("HCFD.file.cancel")}}</el-button
  1975. >
  1976. <el-button type="primary" @click="dialog.Line_visiable = false"
  1977. >{{ $t("HCFD.file.ok")}}</el-button
  1978. >
  1979. </div>
  1980. </el-dialog>
  1981. <!--Vector 矢量 -->
  1982. <el-dialog :visible.sync="dialog.Vector_visiable"
  1983. v-if="active=='five7-2'"
  1984. :modal='false'
  1985. :close-on-click-modal="false"
  1986. @close='activecleer()'
  1987. custom-class='dialoglocation dialog_color'
  1988. width="385px"
  1989. :style="styX"
  1990. >
  1991. <div slot="title" class=dialog_header>
  1992. <el-image class="imge" :src="p4" fit="cover" />
  1993. <span class="text-color">矢量</span>
  1994. </div>
  1995. <el-form>
  1996. <div class="line">
  1997. <div class="linetext">矢量</div>
  1998. </div>
  1999. <div class="Squareline selecr">
  2000. <el-form-item label="u" :label-width="formLabelWidth2">
  2001. <el-select
  2002. size="mini"
  2003. v-model="vSalar"
  2004. placeholder="select boundary"
  2005. >
  2006. <el-option
  2007. v-for="scalar in volumScalars"
  2008. :key="scalar"
  2009. :label="scalar"
  2010. :value="scalar"
  2011. >
  2012. </el-option>
  2013. </el-select>
  2014. </el-form-item>
  2015. <el-form-item label="v" :label-width="formLabelWidth2">
  2016. <el-select
  2017. size="mini"
  2018. v-model="vSalar"
  2019. placeholder="select boundary"
  2020. >
  2021. <el-option
  2022. v-for="scalar in volumScalars"
  2023. :key="scalar"
  2024. :label="scalar"
  2025. :value="scalar"
  2026. >
  2027. </el-option>
  2028. </el-select>
  2029. </el-form-item>
  2030. <el-form-item label="w" :label-width="formLabelWidth2">
  2031. <el-select
  2032. size="mini"
  2033. v-model="vSalar"
  2034. placeholder="select boundary"
  2035. >
  2036. <el-option
  2037. v-for="scalar in volumScalars"
  2038. :key="scalar"
  2039. :label="scalar"
  2040. :value="scalar"
  2041. >
  2042. </el-option>
  2043. </el-select>
  2044. </el-form-item>
  2045. </div>
  2046. <div class="line">
  2047. <div class="linetext"> 参数设置</div>
  2048. </div>
  2049. <el-form-item label="标度因子" :label-width="formLabelWidth2" >
  2050. <el-input value="" autocomplete="off"></el-input>
  2051. </el-form-item>
  2052. </el-form>
  2053. <div slot="footer" class="dialog-footer">
  2054. <el-button @click="dialog.Vector_visiable= false"
  2055. >{{ $t("HCFD.file.cancel")}}</el-button
  2056. >
  2057. <el-button type="primary" @click="dialog.Vector_visiable = false"
  2058. >{{ $t("HCFD.file.ok")}}</el-button
  2059. >
  2060. <el-button type="primary" @click="dialog.Vector_visiable = false"
  2061. >Apply</el-button
  2062. >
  2063. </div>
  2064. </el-dialog>
  2065. <!--Solid Surface固体 -->
  2066. <el-dialog :visible.sync="dialog.Solid_Surface"
  2067. v-if="active=='five8-0'"
  2068. :modal='false'
  2069. :close-on-click-modal="false"
  2070. @close='activecleer()'
  2071. custom-class='dialoglocation dialog_color'
  2072. width="385px"
  2073. :style="styX"
  2074. >
  2075. <div slot="title" class=dialog_header>
  2076. <el-image class="imge" :src="p4" fit="cover" />
  2077. <span class="text-color">Solid Surface</span>
  2078. </div>
  2079. <el-form :model="form">
  2080. <div class="heigeinput">
  2081. <el-form-item label="颜色">
  2082. <div class="saninput titleinput"> R
  2083. <el-input v-model="form.name" autocomplete="off"></el-input>G
  2084. <el-input v-model="form.name" autocomplete="off"></el-input>B
  2085. <el-input v-model="form.name" autocomplete="off"></el-input>
  2086. <el-color-picker
  2087. v-model="lineColor"
  2088. show-alpha
  2089. :predefine="predefineColors">
  2090. </el-color-picker>
  2091. </div>
  2092. </el-form-item>
  2093. <div class="yiinpu heigeinput">
  2094. <el-form-item label="透明度" :label-width="formLabelWidth2">
  2095. <el-input v-model="form.name" autocomplete="off"></el-input>
  2096. <span style="width:80px">值范围0~1</span>
  2097. </el-form-item>
  2098. </div>
  2099. <div class="radio_text text_color liangf">
  2100. <div class="classfelx" style="text-align: center;">
  2101. <el-radio
  2102. v-model="parameterObj.nmlParam.noninertial_Reference_Frame"
  2103. label="on"
  2104. >hide</el-radio>
  2105. </div>
  2106. <div class="classfelx">
  2107. <el-radio
  2108. v-model="parameterObj.nmlParam.noninertial_Reference_Frame"
  2109. label="off"
  2110. >show</el-radio
  2111. >
  2112. </div>
  2113. </div>
  2114. </div>
  2115. </el-form>
  2116. <div slot="footer" class="dialog-footer">
  2117. <el-button @click="dialog.Solid_Surface= false"
  2118. >{{ $t("HCFD.file.cancel")}}</el-button
  2119. >
  2120. <el-button type="primary" @click="dialog.Solid_Surface= false"
  2121. >{{ $t("HCFD.file.ok")}}</el-button
  2122. >
  2123. <el-button type="primary" @click="dialog.Solid_Surface = false"
  2124. >Apply</el-button
  2125. >
  2126. </div>
  2127. </el-dialog>
  2128. <!--Curve Select曲线选择 -->
  2129. <el-dialog :visible.sync="dialog.Curve_Select"
  2130. v-if="active=='five10-0'"
  2131. :modal='false'
  2132. :close-on-click-modal="false"
  2133. @close='activecleer()'
  2134. custom-class='dialoglocation dialog_color'
  2135. width="385px"
  2136. :style="styX"
  2137. >
  2138. <div slot="title" class=dialog_header>
  2139. <el-image class="imge" :src="p9" fit="cover" />
  2140. <span class="text-color"> 选择</span>
  2141. </div>
  2142. <el-form :model="form">
  2143. <div class="heigeinput selecr">
  2144. <div class="line">
  2145. <div class="linetext">结果曲线</div>
  2146. </div>
  2147. <el-form-item label="选择区域" :label-width="formLabelWidth2">
  2148. <el-select
  2149. size="mini"
  2150. v-model="vSalar"
  2151. placeholder="select boundary"
  2152. >
  2153. <el-option
  2154. v-for="scalar in volumScalars"
  2155. :key="scalar"
  2156. :label="scalar"
  2157. :value="scalar"
  2158. >
  2159. </el-option>
  2160. </el-select>
  2161. </el-form-item>
  2162. <div class="line">
  2163. <div class="linetext">类型</div>
  2164. </div>
  2165. <div class="listbtn">
  2166. <el-button plain class="anniu">点</el-button>
  2167. <el-button plain class="anniu">Cells</el-button>
  2168. </div>
  2169. <el-form-item label="标量名称" :label-width="formLabelWidth2">
  2170. <el-select
  2171. size="mini"
  2172. v-model="vSalar"
  2173. placeholder="select boundary"
  2174. >
  2175. <el-option
  2176. v-for="scalar in volumScalars"
  2177. :key="scalar"
  2178. :label="scalar"
  2179. :value="scalar"
  2180. >
  2181. </el-option>
  2182. </el-select>
  2183. </el-form-item>
  2184. <div class="listbtn">
  2185. <el-button plain class="anniu">清除</el-button>
  2186. <el-button plain class="anniu">输出量</el-button>
  2187. </div>
  2188. </div>
  2189. </el-form>
  2190. <div slot="footer" class="dialog-footer">
  2191. <el-button @click="dialog.Curve_Select= false"
  2192. >{{ $t("HCFD.file.cancel")}}</el-button
  2193. >
  2194. <el-button type="primary" @click="dialog.Curve_Select= false"
  2195. >{{ $t("HCFD.file.ok")}}</el-button
  2196. >
  2197. <el-button type="primary" @click="dialog.Curve_Select = false"
  2198. >Apply</el-button
  2199. >
  2200. </div>
  2201. </el-dialog>
  2202. <!--Curve Disp1ay曲线
  2203. 曲线选择 -->
  2204. <!-- :modal='false'
  2205. :close-on-click-modal="false"
  2206. :modal-append-to-body='false'
  2207. @close='activecleer()'
  2208. :style="styX"
  2209. -->
  2210. <el-dialog :visible.sync="dialog.Curve_Disp1ay"
  2211. v-if="active=='five10-1'"
  2212. custom-class='dialoglocation dialog_color'
  2213. width="385px"
  2214. >
  2215. <div slot="title" class=dialog_header>
  2216. <el-image class="imge" :src="p13" fit="cover" />
  2217. <span class="text-color"> 选择</span>
  2218. </div>
  2219. <el-form :model="form">
  2220. <div class="Squareline selecr " >
  2221. <div class="line">
  2222. <div class="linetext">结果曲线</div>
  2223. </div>
  2224. </div>
  2225. <div class="heigeinput selecr">
  2226. </div>
  2227. </el-form>
  2228. <div slot="footer" class="dialog-footer">
  2229. <el-button @click="dialog.Curve_Disp1ay= false"
  2230. >{{ $t("HCFD.file.cancel")}}</el-button
  2231. >
  2232. <el-button type="primary" @click="dialog.Curve_Disp1ay= false"
  2233. >{{ $t("HCFD.file.ok")}}</el-button
  2234. >
  2235. <el-button type="primary" @click="dialog.Curve_Disp1ay = false"
  2236. >Apply</el-button
  2237. >
  2238. </div>
  2239. </el-dialog>
  2240. <!-- 单位计算开始 -->
  2241. <el-dialog :visible.sync="visiable"
  2242. v-if="active=='six-0'"
  2243. :modal='false'
  2244. :close-on-click-modal="false"
  2245. @close='activecleer()'
  2246. custom-class='dialoglocation dialog_color'
  2247. width="385px"
  2248. :style="styX"
  2249. >
  2250. <div slot="title" class=dialog_header>
  2251. <el-image class="imge" :src="d1" fit="cover" />
  2252. <span class="text-color">单位换算</span>
  2253. </div>
  2254. <el-form :model="form1">
  2255. <el-form-item label="kelvin" :label-width="formLabelWidth1">
  2256. <el-input v-model="form1.kelvins" type="number" autocomplete="off"></el-input>
  2257. </el-form-item>
  2258. <el-form-item label="℃" :label-width="formLabelWidth1">
  2259. <el-input v-model="form1.ssd" type="number" autocomplete="off"></el-input>
  2260. </el-form-item>
  2261. <div>
  2262. <el-button @click="dialogbtnkew" style="margin:10px 0 0 65px" size="mini">摄氏度</el-button>
  2263. <el-button @click="dialogbtnssd" size="mini">开尔文</el-button>
  2264. </div>
  2265. </el-form>
  2266. </el-dialog>
  2267. <!-- Y+ Calculator -->
  2268. <el-dialog
  2269. :visible.sync="Yvisiable"
  2270. :close-on-click-modal="false"
  2271. @close='activecleer()'
  2272. v-if="active=='six-1'"
  2273. :modal='false'
  2274. custom-class='dialoglocation dialog_color'
  2275. width="385px"
  2276. :style="styX"
  2277. >
  2278. <div slot="title" class=dialog_header>
  2279. <el-image class="imge" :src="d2" fit="cover" />
  2280. <span class="text-color">Y+值计算</span>
  2281. </div>
  2282. <el-form :model="form" class="gongju">
  2283. <!-- Freestream velocity流速度U∞ -->
  2284. <el-form-item label="自由流速度U∞(m/s):" :label-width="formLabelWidth3">
  2285. <el-input v-model="form.u_freestream" autocomplete="off"></el-input>
  2286. </el-form-item>
  2287. <!--Density 自由氣流密度ρ -->
  2288. <el-form-item label="自由氣流密度ρ(kg/m^3):" :label-width="formLabelWidth3">
  2289. <el-input v-model="form.rho" autocomplete="off"></el-input>
  2290. </el-form-item>
  2291. <!-- Characteristic length 特征长度L-->
  2292. <el-form-item label="特征长度L:(m):" :label-width="formLabelWidth3">
  2293. <el-input
  2294. v-model="form.L"
  2295. type="number"
  2296. autocomplete="off"
  2297. ></el-input>
  2298. </el-form-item>
  2299. <!-- Dynamic viscosity表流运动粘贴系数μ: -->
  2300. <el-form-item label="表流运动粘贴系数μ(Pa·s):" :label-width="formLabelWidth3">
  2301. <el-input v-model="form.mu" autocomplete="off"></el-input>
  2302. </el-form-item>
  2303. <!-- Desired Y+ value: -->
  2304. <el-form-item label="Y+:" :label-width="formLabelWidth3">
  2305. <el-input
  2306. v-model="form.y_plus_desired"
  2307. type="number"
  2308. autocomplete="off"
  2309. ></el-input>
  2310. </el-form-item>
  2311. <!-- Reynolds number -->
  2312. <h3 class="Rex">雷诺数:&nbsp;&nbsp;&nbsp;&nbsp;{{ form.Rex }}</h3>
  2313. <!-- Estimated wall distance: -->
  2314. <h3 class="Rex">估计墙距:&nbsp;&nbsp;&nbsp;&nbsp;{{ form.dtc }}</h3>
  2315. <el-form-item style="margin-left: 0">
  2316. <!-- <el-input v-model="form.lys" type="number" autocomplete="off"></el-input> -->
  2317. <el-button type="primary" @click="dialogbtny" style="margin:0 0 0 55px">计算</el-button>
  2318. </el-form-item>
  2319. </el-form>
  2320. </el-dialog>
  2321. <!-- r雷诺数计算 -->
  2322. <el-dialog
  2323. :visible.sync="llsvisiable"
  2324. :close-on-click-modal="false"
  2325. v-if="active=='six-2'"
  2326. :modal='false'
  2327. custom-class='dialoglocation dialog_color'
  2328. width="385px"
  2329. :style="styX"
  2330. >
  2331. <div slot="title" class=dialog_header>
  2332. <el-image class="imge" :src="d3" fit="cover" />
  2333. <span class="text-color">雷诺数计算</span>
  2334. </div>
  2335. <el-form :model="form" class="leiluoshu">
  2336. <el-form-item label="流速v(m/s):" :label-width="formLabelWidth3">
  2337. <el-input v-model="form.lls" autocomplete="off" ></el-input>
  2338. </el-form-item>
  2339. <el-form-item label="密度ρ(kg/m^3)" :label-width="formLabelWidth3">
  2340. <el-input v-model="form.lmi" autocomplete="off"></el-input>
  2341. </el-form-item>
  2342. <el-form-item label="动力黏性系数η(Pa·s)" :label-width="formLabelWidth3">
  2343. <el-input v-model="form.ldlzxxs" autocomplete="off"></el-input>
  2344. </el-form-item>
  2345. <el-form-item label="特征长度(内径)d(m):" :label-width="formLabelWidth3">
  2346. <el-input v-model="form.lld" autocomplete="off"></el-input>
  2347. </el-form-item>
  2348. <el-form-item label="">
  2349. <!-- <el-input v-model="form.lys" type="number" autocomplete="off"></el-input> -->
  2350. <h3 class="Rex">雷诺数Re:{{ form.Re }}</h3>
  2351. <el-button type="primary" style="margin:0 0 0 60px" @click="leinsdialogbtny">计算</el-button>
  2352. </el-form-item>
  2353. </el-form>
  2354. </el-dialog>
  2355. <!-- 组件 -->
  2356. <filesload
  2357. ref="filesload"
  2358. :fileurls="fileurls"
  2359. @fileLoadeState="fileLoadeState($event)"
  2360. ></filesload>
  2361. <loading ref="loading" :loadObjs="loadObjs"></loading>
  2362. <!-- <hcfd-Calculator ref="Calculator"></hcfd-Calculator> -->
  2363. </div>
  2364. </template>
  2365. <script>
  2366. // 引入组件
  2367. import geometry from '../geometry/index.vue'
  2368. import meshindex from '../meshindex/index.vue'
  2369. import t1 from '@/assets/icon/u9588.png'
  2370. import t2 from '@/assets/icon/u9616.png'
  2371. import t3 from '@/assets/icon/u9637.png'
  2372. import t4 from '@/assets/icon/u212.png'
  2373. import t5 from '@/assets/icon/u3284.png'
  2374. import w1 from '@/assets/icon/u3250.png'
  2375. import w2 from '@/assets/icon/u9700.png'
  2376. import w3 from '@/assets/icon/u9872.png'
  2377. import w4 from '@/assets/icon/u3877.png'
  2378. import w5 from '@/assets/icon/u9823.png'
  2379. import w6 from '@/assets/icon/u3742.png'
  2380. import d1 from '@/assets/icon/u10148.png'
  2381. import d2 from '@/assets/icon/u10152.png'
  2382. import d3 from '@/assets/icon/u10156.png'
  2383. import d4 from '@/assets/icon/u10160.png'
  2384. import j1 from '@/assets/icon/u10140.png'
  2385. import j2 from '@/assets/icon/u10144.png'
  2386. import q1 from '@/assets/icon/u9681.png'
  2387. import q2 from '@/assets/icon/u10115.png'
  2388. import q3 from '@/assets/icon/u9987.png'
  2389. import q4 from '@/assets/icon/u3868.png'
  2390. import q5 from '@/assets/icon/u10048.png'
  2391. import q6 from '@/assets/icon/u10068.png'
  2392. import p1 from '@/assets/icon/7.png'
  2393. import p2 from '@/assets/icon/zoomtowindow.png'
  2394. import p3 from '@/assets/icon/1.png'
  2395. import p4 from '@/assets/icon/3.png'
  2396. import p5 from '@/assets/icon/13.png'
  2397. import p6 from '@/assets/icon/14.png'
  2398. import p7 from '@/assets/icon/19.png'
  2399. import p8 from '@/assets/icon/12.png'
  2400. import p9 from '@/assets/icon/15.png'
  2401. import p10 from '@/assets/icon/6.png'
  2402. import p11 from '@/assets/icon/9.png'
  2403. import p12 from '@/assets/icon/2.png'
  2404. import p13 from '@/assets/icon/18.png'
  2405. import adilog from "@/assets/hcfd_images/adilog.png";
  2406. import Pagination from '@/components/Pagination'
  2407. import { Message, MessageBox } from "element-ui";
  2408. import store from "@/store";
  2409. import UgridLoad from "./loads/UgridLoad.vue";
  2410. import VolumLoad from "./loads/VolumLoad.vue";
  2411. import { request, uploadFile } from "@/utils/request";
  2412. import vueUploader from "./fileupload.vue";
  2413. import filesload from "./filesload.vue";
  2414. import { Caegw_ProUrl } from "@/settings"; // 引入settings.js
  2415. import loading from "./loading.vue";
  2416. import transformtool from "./loads/transformtool.vue";
  2417. import echartsHFCD from "./echartsHFCD.vue";
  2418. import TFileStream from "./TFileStream.vue";
  2419. export default {
  2420. components:{geometry,meshindex, vueUploader,
  2421. filesload,
  2422. loading,
  2423. UgridLoad,
  2424. VolumLoad,
  2425. transformtool,
  2426. Pagination,
  2427. // vtkLoad,
  2428. echartsHFCD,
  2429. TFileStream,},
  2430. // websocket,},
  2431. props:{
  2432. objopp:String,
  2433. pid:String,
  2434. femnum:String,
  2435. elodingfalse:{
  2436. type:Boolean,
  2437. default(){
  2438. return false
  2439. }
  2440. }
  2441. },
  2442. data() {
  2443. return {
  2444. desclist:[],
  2445. boundaryid:'',
  2446. desc:'' ,
  2447. checked:false,
  2448. solverConfigid:'',
  2449. mcnames:'apply1',
  2450. formLabelWidth: '60px',
  2451. formLabelWidth2:'73px',
  2452. formLabelWidth4:'37px',
  2453. formLabelWidth5:'100px',
  2454. formLabelWidth6:'120px',
  2455. formLabelWidth7:'170px',
  2456. switchvalue: '1',
  2457. styX:{
  2458. left:''
  2459. },
  2460. t1,t2,t3,t4,t5,
  2461. w1,w2,w3,w4,w5,w6,
  2462. d1,d2,d3,d4,
  2463. j1,j2,
  2464. q1, q2,q3,q4,q5,q6,
  2465. p1,p2,p3,p4,p5,p6,p7,p8,p9,p10,p11,p12,p13,
  2466. visibles:false,
  2467. restime:'',
  2468. numzhexian:'',
  2469. newlog:'',
  2470. luobj:{
  2471. projectName:'',
  2472. projectId:'',
  2473. projectDesc:'',
  2474. },
  2475. // 颜色选择
  2476. lineColor: 'rgba(255, 69, 0, 0.68)',
  2477. predefineColors: [
  2478. '#ff4500',
  2479. '#ff8c00',
  2480. '#ffd700',
  2481. '#90ee90',
  2482. '#00ced1',
  2483. '#1e90ff',
  2484. '#c71585',
  2485. 'rgba(255, 69, 0, 0.68)',
  2486. 'rgb(255, 120, 0)',
  2487. 'hsv(51, 100, 98)',
  2488. 'hsva(120, 40, 94, 0.5)',
  2489. 'hsl(181, 100%, 37%)',
  2490. 'hsla(209, 100%, 56%, 0.73)',
  2491. '#c7158577'
  2492. ],
  2493. // current:0,
  2494. lsolverState:"2",
  2495. footerShow:true,
  2496. bMesh:0,
  2497. bContour:1,
  2498. vMesh:0,
  2499. vContour:1,
  2500. name:"New",
  2501. xiugai:{},
  2502. Surfacenum: 3,
  2503. Volumenum:3,
  2504. clearobj:{
  2505. projectId:'',
  2506. fileType:'',
  2507. step:Number
  2508. },
  2509. servertype:'ugrid',
  2510. tstep:Number,
  2511. wstep:'0',
  2512. step:'0',
  2513. srsurl:'ugrid',
  2514. footerval:'on',
  2515. top:'50px',
  2516. formLabelWidth1:'70px',
  2517. formLabelWidth3:'180px',
  2518. visiable:false,
  2519. dialogFormVisible: false,
  2520. form1: {
  2521. ssd: '',
  2522. kelvins:'',
  2523. delivery: false,
  2524. type: [],
  2525. resource: '',
  2526. desc: ''
  2527. },
  2528. sum:"",
  2529. formLabelWidth: '120px',
  2530. adilog: adilog,
  2531. activeName: 'one',
  2532. tabPosition: 'bottom',
  2533. showtrue:true,
  2534. drawer: true,
  2535. direction: 'rtl',
  2536. twolist:[
  2537. { icon:t1, titlie:'缩放'},
  2538. {icon:t2, titlie:'平移'},
  2539. {icon:t3, titlie:'旋转'},
  2540. // {icon:t4, titlie:'分析类型'},
  2541. // {icon:t5, titlie:'并行类型'},
  2542. ],
  2543. meshlist:[
  2544. { icon:q4, titlie:'文件上传'},
  2545. ],
  2546. physicslist:[
  2547. { icon:w1, titlie:'控制方程'},
  2548. ],
  2549. physicslist2:[
  2550. { icon:w2, titlie:'粘性模型'},
  2551. // {icon:"icon-d-glassware", titlie:'层流'},
  2552. // {icon:"icon-xunhuanbofang", titlie:'湍流'},
  2553. { icon:w3, titlie:'边界条件'},
  2554. {icon:w4, titlie:'运动网格'},
  2555. ],
  2556. physicslist1:[
  2557. { icon:w5, titlie:'参考条件'},
  2558. { icon:w6, titlie:'非惯性参考系'}
  2559. ],
  2560. solutionlist:[
  2561. { icon:q1, titlie:'无粘通量方法'},
  2562. { icon:q2, titlie:'时间推进格式'},
  2563. ],
  2564. solutionlist2:[
  2565. { icon:q3, titlie:'线性方程组求解参数'},
  2566. ],
  2567. solutionlist21:[
  2568. { icon:q4, titlie:'初始化'},
  2569. ],
  2570. solutionlist3:[
  2571. { icon:q5, titlie:'运行控制'},
  2572. { icon:q6, titlie:'输出控制'},
  2573. ],
  2574. solutionlist4:[
  2575. { icon:"icon-xitongcanshupeizhi", titlie:'Advanced Option_特殊的参数'},
  2576. { icon:"icon-icon", titlie:'Advanced Option_Swap Y-Z Axres'},
  2577. { icon:"icon-yunhang", titlie:'运行'},
  2578. { icon:"icon-quxiantu", titlie:'Monitor'},
  2579. { icon:"icon-tuxingtuxiangchuli", titlie:'资源选择'},
  2580. ],
  2581. resultslist:[
  2582. // { icon:"icon-cankaowenjian", titlie:'下载求解结果'},
  2583. { icon:j1, titlie:'物面数据'},
  2584. { icon:j2, titlie:'流场数据'},
  2585. ],
  2586. plotslsit:[
  2587. { icon:p1, titlie:'Model plot'},
  2588. { icon:p2, titlie:'path plot'},
  2589. { icon:p3, titlie:'Global variables'},
  2590. ],
  2591. plotslsit1:[
  2592. { icon:p4, titlie:'Design plot'},
  2593. { icon:p5, titlie:'Gentralized Y Plot'},
  2594. { icon:p6, titlie:'Import'},
  2595. ],
  2596. plotslsit2:[
  2597. { icon:p6, titlie:'Length Unit'},
  2598. { icon:p7, titlie:'History rlot'},
  2599. { icon:p6, titlie:'Import IYPlot'},
  2600. ],
  2601. samplelist:[
  2602. { icon:p8, titlie:'采样点'},
  2603. ],
  2604. generatelist:[
  2605. { icon:p9, titlie:'工具'},
  2606. { icon:p10, titlie:'动画'},
  2607. { icon:p11, titlie:'Movies'},
  2608. ],
  2609. generatelist2:[
  2610. { icon:p3, titlie:'报告'},
  2611. { icon:p4, titlie:'几何距离'},
  2612. ],
  2613. displaylist:[
  2614. { icon:p3, titlie:'轮廓显示'},
  2615. { icon:p9, titlie:'线'},
  2616. { icon:p4, titlie:'矢量'},
  2617. ],
  2618. displaylist2:[
  2619. { icon:p9, titlie:'Solid Surface'},
  2620. { icon:p12, titlie:'Slice'},
  2621. { icon:p13, titlie:'Stream'},
  2622. ],
  2623. animationlist:[
  2624. { icon:p9, titlie:'Solid Surface'},
  2625. ],
  2626. Cuelist:[
  2627. { icon:p9, titlie:'Curve Select'},
  2628. { icon:p13, titlie:'Curve Display'},
  2629. ],
  2630. unitlist:[
  2631. { icon:d1, titlie:'单位换算'},
  2632. { icon:d2, titlie:'Y+计算器'},
  2633. { icon:d3, titlie:'雷诺数计算'},
  2634. ],
  2635. selectlist1:[
  2636. {value:'inviscid',name:'无粘'},
  2637. {value:'laminar',name:'层流'},
  2638. {value:'turbulent',name:'湍流'},
  2639. ],
  2640. selectlist2:[
  2641. {value:'sa',name:'SA'},
  2642. {value:'k-omega-sst',name:'Menter-SST'},
  2643. {value:'sa-des',name:'SA-DES'},
  2644. {value:'k-omega-des',name:'k-omega-DES'},
  2645. {value:'linear-k-epsilon',name:'Linear-k-epsilon'},
  2646. {value:'abid-k-epsilon',name:'Abid-k-epsilon'},
  2647. {value:'menter-sst-les',name:'Menter-SST-LES'},
  2648. {value:'Wilcox-les',name:'Wilcox-LES'},
  2649. ],
  2650. qjklist:[
  2651. {value:'roe',name:'Roe'},
  2652. {value:'vanleer',name:'vanleer'},
  2653. {value:'hllc',name:'HLLC'},
  2654. {value:'aufs',name:'AUFS'},
  2655. {value:'central_diss',name:'Central_Diss'},
  2656. {value:'dlfss',name:'LDFSS'},
  2657. {value:'stvd',name:'STVD'},
  2658. {value:'stvd_modified',name:'STVD_modified'},
  2659. ],
  2660. qjklist2:[
  2661. {value:'none',name:'none'},
  2662. {value:'barth',name:'barth'},
  2663. {value:'venkat',name:'venkat'},
  2664. {value:'minmod',name:'minmod'},
  2665. {value:'vanleer',name:'vanleer'},
  2666. {value:'vanalbada',name:'vanalbada'},
  2667. {value:'smooth',name:'smooth'},
  2668. {value:'hminmod',name:'hminmod'},
  2669. {value:'hvanleer',name:'hvanleer'},
  2670. {value:'hvanalbada',name:'hvanalbada'},
  2671. {value:'hsmooth',name:'hsmooth'},
  2672. {value:'hvenkat',name:'hvenkat'},
  2673. ],
  2674. qjklist3:[
  2675. {value:'roe',name:'Roe'},
  2676. {value:'central_difference',name:'Central_Difference'},
  2677. {value:'hllc',name:'HLLC'},
  2678. {value:'aufs',name:'AUFS'},
  2679. {value:'dlfss',name:'LDFSS'},
  2680. ],
  2681. ydlist:[
  2682. {value:'0',name:'刚体'},
  2683. {value:'1',name:'变形'},
  2684. ],
  2685. tlist1:[
  2686. {value:'steady',name:"定常"},
  2687. {value:'1storder',name:'1阶差分'},
  2688. {value:'2ndorder',name:'2阶差分'},
  2689. {value:'2ndorderOPT',name:'最优2阶差分'},
  2690. {value:'3rdorder',name:'4阶差分'},
  2691. {value:'4thorderMEBDF4',name:'4阶差分'},
  2692. {value:'4thorderESDIRK4',name:'4阶差分'},
  2693. ],
  2694. ydval:'0',
  2695. ydlist2:[
  2696. {value:'0',name:'平动'},
  2697. {value:'1',name:'转动'},
  2698. ],
  2699. ydval2:'0',
  2700. ydlist3:[
  2701. {value:'0',name:'匀速'},
  2702. {value:'1',name:'正弦'},
  2703. ],
  2704. ydval3:'0',
  2705. ydlist4:[
  2706. {value:'0',name:'随体运动'},
  2707. {value:'1',name:'空间固定'},
  2708. ],
  2709. ydval4:'0',
  2710. loadlist:[
  2711. {value:'0',name:'盒子'},
  2712. {value:'1',name:'球'},
  2713. {value:'2',name:'圆柱'},
  2714. {value:'4',name:'圆锥'},
  2715. ],
  2716. loadval:'0',
  2717. objectplanelist:[
  2718. {value:'0',name:' 物面输出'},
  2719. {value:'1',name:'流场输出'},
  2720. ],
  2721. objectplaneval:'0',
  2722. active:'',
  2723. //大对象
  2724. ziyprojects:[],
  2725. paginationConfig: {
  2726. hideSinglePage: false,
  2727. page: 1,
  2728. size: 15,
  2729. sizeList: [10, 15, 30, 50],
  2730. layout: 'total, sizes, prev, pager, next, jumper',
  2731. total: 0,
  2732. },
  2733. getRowKeys(row) {
  2734. return row.id;
  2735. },
  2736. selsectid:[],
  2737. missType:true,
  2738. initialization: "freestreams",
  2739. upVisible: false,
  2740. Yvisiable: false,
  2741. llsvisiable: false,
  2742. newload: true,
  2743. runMonitor: true,
  2744. contourLevel: 3,
  2745. form: {
  2746. u_freestream: "",
  2747. rho: "",
  2748. L: "",
  2749. mu: "",
  2750. y_plus_desired: "",
  2751. dtc: "",
  2752. md: "",
  2753. ls: "",
  2754. cd: "",
  2755. Rex: "",
  2756. Re: "",
  2757. lys: "",
  2758. lmi: "",
  2759. ldlzxxs: "",
  2760. lld: "",
  2761. Re: "",
  2762. dtc: "",
  2763. lls: "",
  2764. },
  2765. uploadlist: [
  2766. {
  2767. name: "mapbc",
  2768. percentage: 0,
  2769. },
  2770. {
  2771. name: "ugrid",
  2772. percentage: 0,
  2773. },
  2774. ],
  2775. ContourSurface: false,
  2776. adilog: adilog,
  2777. loading: loading,
  2778. headMenu_2Show: false,
  2779. leftMenu_2Show: false,
  2780. gennealShow: false,
  2781. physicsShow: false,
  2782. solutionShow: false,
  2783. resultShow: false,
  2784. Consoleshow: true,
  2785. openshow:false,
  2786. TaskGenealshow: false,
  2787. TaskPhysicsshow: false,
  2788. TaskSolutionshow: false,
  2789. TaskSurfaceshow: false,
  2790. TaskVolumeshow: false,
  2791. ugridUrl: "",
  2792. bload: null,
  2793. websock: null,
  2794. logs: "欢迎来到HCFD",
  2795. islogload: true, //控制log请求(ture 发起 false 不发起)
  2796. outline: "OutLine",
  2797. fileNames: [],
  2798. belementCheckeds: ["Contour"],
  2799. boundaryStep: [],
  2800. bStep: 0,
  2801. boundaryScalars: [],
  2802. bScalar: "cp",
  2803. velementCheckeds: ["Contour"],
  2804. vStep: 0,
  2805. volumStep: [],
  2806. volumScalars: [],
  2807. vSalar: "p",
  2808. isSolverEnd: false, //判断是否求解完成
  2809. solverState: "0", //求解状态(0-未求解 1-求解中 2-求解完成)
  2810. menuList: [
  2811. {
  2812. id: "1",
  2813. label: "Setup",
  2814. children: [
  2815. {
  2816. id: "2",
  2817. label: "General",
  2818. },
  2819. {
  2820. id: "3",
  2821. label: "Physics",
  2822. },
  2823. {
  2824. id: "4",
  2825. label: "Solution",
  2826. },
  2827. ],
  2828. },
  2829. {
  2830. id: "5",
  2831. label: "Results",
  2832. children: [
  2833. {
  2834. id: "6",
  2835. label: "Monitor",
  2836. },
  2837. {
  2838. id: "7",
  2839. label: "Surface Grid",
  2840. },
  2841. {
  2842. id: "8",
  2843. label: "Volume Grid",
  2844. },
  2845. {
  2846. id: "9",
  2847. label: "Ugrid",
  2848. },
  2849. ],
  2850. },
  2851. ],
  2852. dialog: {
  2853. //弹出框 控制
  2854. new_visiable: false,
  2855. load_visiable: false,
  2856. ziyuan:false,
  2857. upload_visiable: false,
  2858. scale_visiable: false,
  2859. translation_visiable: false,
  2860. rotation_visiable: false,
  2861. type_visiable:false,
  2862. parallel_visiable:false,
  2863. equation_visiable:false,
  2864. inviscid_visiable:false,
  2865. laminar_visiable: false,
  2866. turbulent_visiable: false,
  2867. dynamic_visiable:false,
  2868. nonitertial_visiable:false,
  2869. border_visiable:false,
  2870. reference_visiable: false,
  2871. fluxrc_visiable: false,
  2872. time_visiable: false,
  2873. timeasm_visiable: false,
  2874. xian_visiable:false,
  2875. initialization_visiable:false,
  2876. specified_visiable: false, //未完成
  2877. runc_visiable: false,
  2878. boundaryo_visiable: false,
  2879. volumeo_visiable: false,
  2880. specialp_visiable: false,
  2881. swap_visiable: false,
  2882. SurfaceGrid_visiable:false,
  2883. VolumeGrid_visiable:false,
  2884. contour_visiable:false,
  2885. Line_visiable:false,
  2886. Vector_visiable:false,
  2887. Solid_Surface:false,
  2888. Curve_Select:false,
  2889. Curve_Disp1ay:false,
  2890. },
  2891. geneal: {
  2892. //数据存储
  2893. MeshTransform: {
  2894. Scale: {
  2895. Factor: 0,
  2896. },
  2897. Translation: {
  2898. Distance: 0,
  2899. X: 1,
  2900. Y: 0,
  2901. Z: 0,
  2902. },
  2903. Rotation: {
  2904. Angle: 0,
  2905. X: 0,
  2906. Y: 0,
  2907. Z: 0,
  2908. X1: 1,
  2909. Y1: 0,
  2910. Z1: 0,
  2911. },
  2912. },
  2913. },
  2914. Physics: {
  2915. Turbulent: {
  2916. TurbulentPrandtlNumber: 0.9,
  2917. },
  2918. Boundary: {
  2919. bquery: null, //hcfdBoundary 选中数据 id
  2920. hcfdBoundaryquery: null, //hcfdBoundary 选中数据
  2921. cquery: null,
  2922. /* 黎曼远场边界(Farfield) 5000
  2923. * 自由来流边界(Freestream)5050
  2924. * 无粘壁面(Inviscous Wall) 3000
  2925. * 粘性壁面(Viscous Wall)4000
  2926. * X-对称平面(X-symmetry Plane)6661
  2927. * Y-对称平面(Y-symmetry Plane ) 6662
  2928. * Z-对称平面Z-symmetry Plane) 6663
  2929. * 周期边界(Periodic) 6100*/
  2930. Conditions: [
  2931. { conditionsCode: 5000, name: "Farfield" },
  2932. { conditionsCode: 5050, name: "Freestream" },
  2933. { conditionsCode: 3000, name: "Inviscous Wall" },
  2934. { conditionsCode: 4000, name: "Viscous Wall" },
  2935. { conditionsCode: 6661, name: "X-symmetry Plane" },
  2936. { conditionsCode: 6662, name: "Y-symmetry Plane" },
  2937. { conditionsCode: 6663, name: "Z-symmetry Plane" },
  2938. { conditionsCode: 6100, name: "Periodic" },
  2939. ],
  2940. },
  2941. },
  2942. Solution: {
  2943. boundaryout: {
  2944. checkAll: false,
  2945. checkeds: [],
  2946. lists: [
  2947. "X-component of velocity",
  2948. "Y-component of velocity",
  2949. "Z-component of velocity",
  2950. "Press",
  2951. "Press coefficient",
  2952. "Mach Number",
  2953. "Vorticity magnitude",
  2954. "X-component of vorticity",
  2955. "Y-component of vorticity",
  2956. "Z-component of vorticity",
  2957. "Q Criterion",
  2958. ],
  2959. isIndeterminate: true,
  2960. },
  2961. volumout: {
  2962. checkAll: false,
  2963. checkeds: [],
  2964. lists: [
  2965. "X-component of velocity",
  2966. "Y-component of velocity",
  2967. "Z-component of velocity",
  2968. "Press",
  2969. "Press coefficient",
  2970. "Mach Number",
  2971. "Vorticity magnitude",
  2972. "X-component of vorticity",
  2973. "Y-component of vorticity",
  2974. "Z-component of vorticity",
  2975. "Q Criterion",
  2976. ],
  2977. isIndeterminate: true,
  2978. },
  2979. },
  2980. //state -1,0 ,1
  2981. //message
  2982. //type 1 一般 2 下载
  2983. loadObjs: [],
  2984. loadVVisiable: false,
  2985. loading: false,
  2986. fileurls: [],
  2987. project: {
  2988. projectId: "",
  2989. lesseeId:'',
  2990. projectName: "",
  2991. projectType: "hcfd",
  2992. projectDesc: "",
  2993. fileType: "ascii",
  2994. solverfiles: [],
  2995. solverVolumUrls: [],
  2996. solverBoundaryUrls: [],
  2997. loadfils: [],
  2998. converge: "",
  2999. uid: "",
  3000. },
  3001. projects: [],
  3002. parameterObjclone: [],
  3003. parameterObj: {
  3004. hcfdBoundarys: [
  3005. // {
  3006. // name: "WING1",
  3007. // id: 1,
  3008. // conditionsCode: 3000,
  3009. // },
  3010. ],
  3011. nmlParam: {
  3012. a_vort_mag: "false",
  3013. case_title: "case_name",
  3014. angle_of_yaw: 0,
  3015. x_moment_center: 0,
  3016. eqn_type: "cal_perf_incompress",
  3017. schedule_cfl: [0, 0],
  3018. swap_yz_axes: "false",
  3019. v_vort_mag: "false",
  3020. pseudo_time_stepping: "on",
  3021. meanflow_sweeps: 15,
  3022. a_p: "true",
  3023. a_u: true,
  3024. a_w: "true",
  3025. a_v: "true",
  3026. dynamic_Mesh: "off",
  3027. jacobian_eval_freq: 10,
  3028. turb_model: "menter-sst",
  3029. grid_format: "aflr3",
  3030. turbulence_sweeps: 10,
  3031. mach_number: 0.5,
  3032. y_moment_length: 1,
  3033. area_reference: 1,
  3034. flux_limiter: "none",
  3035. a_cp: "true",
  3036. viscous_terms: "turbulent",
  3037. volume_animation_freq: 100,
  3038. steps: 1500,
  3039. flux_construction_lhs: "roe",
  3040. stopping_tolerance: 2.0e-1,
  3041. prandtlnumber_molecular: 0.72,
  3042. restart_write_freq: 250,
  3043. v_vort_x: "false",
  3044. schedule_iteration: [1, 50],
  3045. v_vort_y: "false",
  3046. v_vort_z: "false",
  3047. line_implicit: "off",
  3048. temperature_units: "Rankine",
  3049. number_of_Processors: 2,
  3050. x_moment_length: 1,
  3051. time_accuracy: "steady",
  3052. angle_of_attack: 0,
  3053. subiterations: 0,
  3054. artificial_compress: 15,
  3055. a_q_criterion: "false",
  3056. schedule_cflturb: [50, 50],
  3057. schedule: 1,
  3058. first_order_iterations: 0,
  3059. restart_read: "off",
  3060. temperature: 490,
  3061. input_version: 2.2,
  3062. namelist_verbosity: "off",
  3063. ignore_euler_number: "false",
  3064. data_format: "ascii",
  3065. v_cp: "true",
  3066. time_step_nondim: 0,
  3067. a_mach: "true",
  3068. large_angle_fix: "off",
  3069. v_p: "true",
  3070. animation_freq: 100,
  3071. v_mach: "true",
  3072. project_rootname: "tf",
  3073. v_v: "true",
  3074. v_q_criterion: "false",
  3075. v_u: "true",
  3076. y_moment_center: 0,
  3077. v_w: true,
  3078. z_moment_center: 0,
  3079. parallel_Optional: "Serial",
  3080. analysis_Type: "Steady",
  3081. noninertial_Reference_Frame: "off",
  3082. flux_construction: "roe",
  3083. a_vort_z: "false",
  3084. a_vort_y: "false",
  3085. a_vort_x: "false",
  3086. reynolds_number: 1000000,
  3087. },
  3088. },
  3089. renderer_hight: 500,
  3090. renderer_width: 500,
  3091. showUgridflag: false, //ugrid 是否显示过
  3092. showSurfaceflag: false, //surface 是否显示过
  3093. showVolumeflage: false, //Volume 是否显示过
  3094. showMonitorflage: false, //Monitor是否显示过
  3095. };
  3096. },
  3097. created(){
  3098. },
  3099. mounted() {
  3100. this.init();
  3101. },
  3102. // destroyed() {
  3103. // this.websock.close() //离开路由之后断开websocket连接
  3104. // },
  3105. methods:{
  3106. changedesc1(val){
  3107. this.desclist=JSON.parse(val);
  3108. this.parameterObj.hcfdBoundarys= this.desclist;
  3109. },
  3110. leixingchange(val){
  3111. if(val=='MPI Parallel'){
  3112. this.dialog.parallel_visiable=true;
  3113. }else{
  3114. this.dialog.parallel_visiable=false;
  3115. }
  3116. console.log(val)
  3117. },
  3118. //数据加载参数配置obj
  3119. hcfdchange(obj,solverConfigid){
  3120. this.parameterObj = JSON.parse(obj);
  3121. this.desclist=this.parameterObj.hcfdBoundarys;
  3122. console.log( this.desclist);
  3123. sessionStorage.setItem("res", obj);
  3124. this.solverConfigid=solverConfigid;
  3125. sessionStorage.setItem("solverConfigid", solverConfigid);
  3126. },
  3127. //更新参数配置
  3128. hcfdparam(){
  3129. const params = {
  3130. transCode: 'C00004',
  3131. solverConfigid: this.solverConfigid,
  3132. parameterObj: JSON.stringify(this.parameterObj),
  3133. }
  3134. request(params)
  3135. .then((res) => {
  3136. this.$parent.solverchange(this.femnum);
  3137. })
  3138. .catch((err) => {
  3139. })
  3140. },
  3141. // 新版求解控制
  3142. Runsolve(){
  3143. this.hcfdparam();
  3144. this.dialog.runc_visiable = false;
  3145. // this.hcfdExe();
  3146. this.hcfdrun();
  3147. },
  3148. hcfdExe(){
  3149. var _this = this;
  3150. let params = {
  3151. transCode: "C00005",
  3152. solverConfigId:this.solverConfigid,
  3153. };
  3154. request(params)
  3155. .then((res) => {
  3156. // this.getlog();
  3157. Message({
  3158. type: "success",
  3159. message:res.returnMsg,
  3160. });
  3161. })
  3162. .catch((err) => {
  3163. setTimeout(function () {
  3164. _this.$refs.loading.visiable = false;
  3165. }, 4000);
  3166. if (err.returnCode == "EB8100017") {
  3167. MessageBox.confirm("你还未分配资源?", "提示", {
  3168. confirmButtonText: "分配资源",
  3169. cancelButtonText: "取消",
  3170. type: "warning",
  3171. })
  3172. .then(() => {
  3173. let errUril =
  3174. _this.$store.getters.proUrl +
  3175. "?projectId=" +
  3176. _this.project.projectId;
  3177. let params2 = {
  3178. transCode: "A00118",
  3179. lesseeId: _this.$store.getters.lesseeId
  3180. };
  3181. request(params2)
  3182. .then((res) => {
  3183. window.location.href =
  3184. errUril + "&authCode=" + res.authCode;
  3185. })
  3186. .catch((err) => {});
  3187. })
  3188. .catch(() => {
  3189. _this.$refs.loading.visiable = false;
  3190. Message({
  3191. type: "info",
  3192. message: "已取消",
  3193. });
  3194. });
  3195. }
  3196. });
  3197. },
  3198. reUpload() {
  3199. this.$refs.mapbc.uploader.upload();
  3200. this.$refs.ugrid.uploader.upload();
  3201. },
  3202. /**
  3203. * 更新配置 并求解
  3204. */
  3205. async hcfdrun() {
  3206. if (this.solverState == "2") {
  3207. //上次求解完成
  3208. MessageBox.confirm(
  3209. "已完成计算,是否放弃上次计算结果,重新计算? 如果不放弃请自行下载上次结果文件!",
  3210. "提示",
  3211. {
  3212. confirmButtonText: "重新计算",
  3213. cancelButtonText: "取消",
  3214. type: "warning",
  3215. }
  3216. )
  3217. .then(() => {
  3218. MessageBox.close();
  3219. this.$emit("exlodingfalse",true)
  3220. this.isSolverEnd = false;
  3221. this.hcfdExe();
  3222. let _this = this;
  3223. let isStop = false;
  3224. // if (!isStop && !_this.isSolverEnd) {
  3225. this.$parent.fun();
  3226. // }
  3227. })
  3228. .catch(() => {
  3229. Message.info("已取消!");
  3230. MessageBox.close();
  3231. this.$emit("exlodingfalse",false)
  3232. });
  3233. } else {
  3234. this.$emit("exlodingfalse",true)
  3235. this.isSolverEnd = false;
  3236. this.hcfdExe();
  3237. let _this = this;
  3238. let isStop = false;
  3239. // if (!isStop && !_this.isSolverEnd) {
  3240. isStop = true;
  3241. this.$parent.fun();
  3242. // }
  3243. }
  3244. },
  3245. // 求解的日志
  3246. getlog(){
  3247. let params = {
  3248. transCode: "C00006",
  3249. pid:this.project.projectId,
  3250. };
  3251. request(params)
  3252. .then((res) => {
  3253. let rows = res.rows;
  3254. console.log(rows);
  3255. })
  3256. .catch((err) => {
  3257. });
  3258. },
  3259. handleClick(tab, event) {
  3260. // if(this.activeName=='five'){
  3261. // let params = {
  3262. // transCode: "A00107",
  3263. // projectId: this.project.projectId,
  3264. // };
  3265. // request(params)
  3266. // .then((res) => {
  3267. // this.lsolverState=res.solverState;
  3268. // } )
  3269. // if(this.lsolverState=='2'){
  3270. // // this.resultdata();
  3271. // }else{
  3272. // Message({
  3273. // type: "warning",
  3274. // message: "求解未完成,请完成求解",
  3275. // });
  3276. // }
  3277. // }else{
  3278. // }
  3279. // this.activecleer();
  3280. },
  3281. activecleer(){
  3282. this.active=11;
  3283. },
  3284. //模块选择
  3285. clickgeometry(e,index,key){
  3286. var e=e||window.Event
  3287. console.log(e.screenX)
  3288. console.log(122222)
  3289. this.styX.left=e.clientX+'px';
  3290. this.active=key;
  3291. console.log(key);
  3292. switch(key){
  3293. case 'info1-0':
  3294. this.name="New"
  3295. this.clickNew();
  3296. break;
  3297. case 'info1-1':
  3298. this.loadProjects();
  3299. break;
  3300. case 'info1-2':
  3301. this.name="amend"
  3302. this.clickNew();
  3303. break;
  3304. case 'one-0':
  3305. this.dialog.upload_visiable = true;
  3306. break;
  3307. case 'two-0':
  3308. this.dialog.scale_visiable = true;
  3309. break;
  3310. case 'two-1':
  3311. this.dialog.translation_visiable= true;
  3312. break;
  3313. case 'two-2':
  3314. this.dialog.rotation_visiable= true;
  3315. case 'two-3':
  3316. this.dialog.type_visiable= true;
  3317. break;
  3318. case 'two-4':
  3319. this.dialog.parallel_visiable= true;
  3320. break;
  3321. case 'three-0':
  3322. this.dialog.equation_visiable= true;
  3323. break;
  3324. case 'three2-0':
  3325. this.dialog.inviscid_visiable= true;
  3326. break;
  3327. case 'three2-1':
  3328. this.dialog.border_visiable= true;
  3329. break;
  3330. case 'three2-2':
  3331. this.dialog.dynamic_visiable= true;
  3332. break;
  3333. case 'three1-0':
  3334. this.dialog.reference_visiable = true;
  3335. break;
  3336. case 'three1-1':
  3337. this.dialog.nonitertial_visiable = true;
  3338. break;
  3339. case 'four-0':
  3340. this.dialog.fluxrc_visiable = true;
  3341. break;
  3342. case 'four-1':
  3343. this.dialog.time_visiable = true;
  3344. break;
  3345. case 'four2-0':
  3346. this.dialog.xian_visiable = true;
  3347. break;
  3348. case 'four2-10':
  3349. this.dialog.initialization_visiable = true;
  3350. break;
  3351. case 'four3-0':
  3352. this.dialog.runc_visiable = true;
  3353. break;
  3354. case 'four3-1':
  3355. this.dialog.boundaryo_visiable = true;
  3356. break;
  3357. case 'four4-0':
  3358. this.dialog.specialp_visiable = true;
  3359. break;
  3360. case 'four4-1':
  3361. this.dialog.swap_visiable = true;
  3362. break;
  3363. case 'four4-2':
  3364. this.hcfdrun(true);
  3365. break;
  3366. // case 'four4-3':
  3367. // break;
  3368. // case 'four4-4':
  3369. // break;
  3370. case 'five-0':
  3371. this.dialog.SurfaceGrid_visiable = true;
  3372. break;
  3373. case 'five-1':
  3374. this.dialog.VolumeGrid_visiable = true;
  3375. break;
  3376. case 'five7-0':
  3377. this.dialog.contour_visiable = true;
  3378. break;
  3379. case 'five7-1':
  3380. this.dialog.Line_visiable = true;
  3381. break;
  3382. case 'five7-2':
  3383. this.dialog.Vector_visiable = true;
  3384. break;
  3385. case 'five8-0':
  3386. this.dialog.Solid_Surface = true;
  3387. break;
  3388. case 'five10-0':
  3389. this.dialog.Curve_Select = true;
  3390. break;
  3391. case 'five10-1':
  3392. this.dialog.Curve_Disp1ay = true;
  3393. break;
  3394. // case 'six-0':
  3395. // this.visiable=true;
  3396. // break;
  3397. // case 'six-1':
  3398. // this.Yvisiable= true;
  3399. // break;
  3400. // case 'six-2':
  3401. // this.llsvisiable = true;
  3402. // break;
  3403. }
  3404. },
  3405. //清除相关信息
  3406. clearAll() {
  3407. this.showUgridflag = false; //ugrid 是否显示过
  3408. this.showSurfaceflag = false; //surface 是否显示过
  3409. this.showVolumeflage = false; //Volume 是否显示过
  3410. this.showMonitorflage = false;
  3411. this.islogload = true;
  3412. this.logs = "";
  3413. this.project = {
  3414. projectId: "",
  3415. projectName: "",
  3416. projectType: "hcfd",
  3417. projectDesc: "",
  3418. fileType: "ascii",
  3419. solverfiles: [],
  3420. solverVolumUrls: [],
  3421. solverBoundaryUrls: [],
  3422. loadfils: [],
  3423. converge: "",
  3424. };
  3425. },
  3426. init() {
  3427. this.project.projectId = this.pid; //获取url 参数
  3428. this.project.lesseeId = this.$store.getters.lesseeId; //获取url 参数
  3429. if (
  3430. this.project.projectId != undefined &&
  3431. this.project.projectId != null
  3432. ) {
  3433. // this.selectProjectOK();
  3434. }
  3435. this.missType=true
  3436. },
  3437. logtime(){
  3438. let self = this;
  3439. let projectId = self.project.projectId;
  3440. if (projectId != null && projectId != "" && self.islogload) {
  3441. self.islogload = false;
  3442. let params = {
  3443. transCode: "A00112",
  3444. projectId: projectId,
  3445. page: 0,
  3446. count: 30,
  3447. };
  3448. request(params)
  3449. .then((res) => {
  3450. console.log(res)
  3451. let rows = res.rows;
  3452. self.logs = ""; //只显示最新的数据
  3453. rows.forEach((row) => {
  3454. self.logs = row.log + "\n" + self.logs;
  3455. if (row.log.indexOf("Solver end") > 0) {
  3456. self.isSolverEnd = true;
  3457. }
  3458. });
  3459. self.islogload = true;
  3460. })
  3461. .catch((err) => {
  3462. self.islogload = true;
  3463. });
  3464. }
  3465. },
  3466. setVolumScalars(scalars) {
  3467. console.log(scalars)
  3468. this.volumScalars = scalars;
  3469. },
  3470. // 工具栏的点击事件
  3471. yCalchange() {
  3472. this.Yvisiable = true;
  3473. },
  3474. reyCalchange() {
  3475. this.llsvisiable = true;
  3476. },
  3477. atmoCalchange() {},
  3478. // 弹框执行事件
  3479. // 弹框执行事件
  3480. referencevisiable() {
  3481. this.parameterObjclone = JSON.parse(sessionStorage.getItem("res"));
  3482. this.parameterObj.nmlParam = this.parameterObjclone.nmlParam;
  3483. // this.dialog.scale_visiable = false;
  3484. },
  3485. timeasmvisiable() {
  3486. this.parameterObjclone = JSON.parse(sessionStorage.getItem("res"));
  3487. this.parameterObj.nmlParam = this.parameterObjclone.nmlParam;
  3488. this.dialog.timeasm_visiable = false;
  3489. },
  3490. runcvisiable() {
  3491. this.parameterObjclone = JSON.parse(sessionStorage.getItem("res"));
  3492. this.parameterObj.nmlParam = this.parameterObjclone.nmlParam;
  3493. this.dialog.runc_visiable = false;
  3494. },
  3495. // this.$emit("visiable",this.visiable);
  3496. dialogbtnkew(){
  3497. this.form1.ssd="";
  3498. var kelvins=parseFloat(this.form1.kelvins)
  3499. this.form1.ssd = this.accAdd(kelvins,273.15);
  3500. // this.form.ssd = Math.floor((parseInt(this.form.kelvins) * 100) / 100)-273.15
  3501. if( this.form1.ssd <0){
  3502. this.form1.ssd =0;
  3503. }
  3504. },
  3505. accAdd(arg1,arg2){
  3506. var r1,r2,m;
  3507. try{r1=arg1.toString().split(".")[1].length}catch(e){r1=0}
  3508. try{r2=arg2.toString().split(".")[1].length}catch(e){r2=0}
  3509. m=Math.pow(10,Math.max(r1,r2))
  3510. return (arg1*m-arg2*m)/m
  3511. },
  3512. dialogbtnssd(){
  3513. this.form1.kelvins="";
  3514. var ssd=parseFloat(this.form1.ssd)
  3515. this.form1.kelvins= this.accAdd(ssd ,-273.15);
  3516. //this.form.kelvins = Math.floor((parseInt(this.form.ssd) * 100) / 100) +273.15
  3517. },
  3518. dialogbtny() {
  3519. let u_freestream = eval(this.form.u_freestream);
  3520. if (u_freestream <= 0.0) {
  3521. alert("Free stream velocity must be greater than zero");
  3522. return;
  3523. }
  3524. let rho = eval(this.form.rho);
  3525. if (rho <= 0.0) {
  3526. alert("Density must be greater than zero");
  3527. return;
  3528. }
  3529. let L = eval(this.form.L);
  3530. if (L <= 0.0) {
  3531. alert("Boundary layer reference length must be greater than zero");
  3532. return;
  3533. }
  3534. let mu = eval(this.form.mu);
  3535. if (mu <= 0.0) {
  3536. alert("Dynamic viscosity must be greater than zero");
  3537. return;
  3538. }
  3539. let y_plus_desired = eval(this.form.y_plus_desired);
  3540. if (y_plus_desired <= 0.0) {
  3541. alert("Desired y+ value must be greater than zero");
  3542. return;
  3543. }
  3544. let Re = (rho * u_freestream * L) / mu;
  3545. let C_f = 0.026 * Math.pow(Re, -(1.0 / 7.0));
  3546. C_f = 0.0576 * Math.pow(Re, -1.0 / 5.0);
  3547. C_f = 0.37 * Math.pow(Math.log(Re) / Math.log(10), -2.584);
  3548. C_f = Math.pow((2 * Math.log(Re)) / Math.log(10) - 0.65, -2.3);
  3549. let tau_w = C_f * 0.5 * rho * u_freestream * u_freestream;
  3550. let U_f = Math.sqrt(tau_w / rho);
  3551. let wall_distance_estimation = (y_plus_desired * mu) / (U_f * rho);
  3552. this.form.Rex = Re.toExponential(1);
  3553. this.form.dtc = wall_distance_estimation.toExponential(1);
  3554. },
  3555. leinsdialogbtny() {
  3556. this.form.Re =
  3557. (this.form.lmi * this.form.lls * this.form.lld) / this.form.ldlzxxs;
  3558. // console.log(this.form.Re);
  3559. },
  3560. unitConversion() {
  3561. this.$refs.Calculator.visiable = true;
  3562. },
  3563. taskchangGeneal() {
  3564. this.TaskGenealshow = false;
  3565. },
  3566. taskchangPhysics() {
  3567. this.TaskPhysicsshow = false;
  3568. },
  3569. taskchangSolution() {
  3570. this.TaskSolutionshow = false;
  3571. },
  3572. taskchangSurface() {
  3573. this.TaskSurfaceshow = false;
  3574. },
  3575. taskchangVolume() {
  3576. this.TaskVolumeshow = false;
  3577. },
  3578. // Contour
  3579. showLeftMenu(emt) {
  3580. this.leftMenu_2Show = true;
  3581. },
  3582. uploadRequest1(params) {
  3583. let param = new FormData();
  3584. param.append("transCode", "A00102");
  3585. param.append("file", params.file);
  3586. param.append("projectId", this.project.projectId);
  3587. uploadFile(param)
  3588. .then((res) => {
  3589. // console.log(res);
  3590. // this.fileId = res.fileId
  3591. this.findParam();
  3592. this.getHCFDLoadFiles();
  3593. })
  3594. .catch((err) => {});
  3595. },
  3596. uploadRequest2(params) {
  3597. let param = new FormData();
  3598. param.append("transCode", "A00102");
  3599. param.append("file", params.file);
  3600. param.append("projectId", this.project.projectId);
  3601. uploadFile(param)
  3602. .then((res) => {
  3603. // console.log(res);
  3604. // this.fileId = res.fileId
  3605. this.findParam();
  3606. })
  3607. .catch((err) => {});
  3608. },
  3609. //获取上传文件
  3610. async getHCFDLoadFiles() {
  3611. let params = {
  3612. transCode: "A00110",
  3613. projectId: this.project.projectId,
  3614. };
  3615. await request(params)
  3616. .then((res) => {
  3617. this.project.loadfils = res.files;
  3618. this.fileNames = [];
  3619. res.files.forEach((url) => {
  3620. let names = url.filepath.split("/");
  3621. let name = names[names.length - 1];
  3622. this.fileNames.push(name);
  3623. });
  3624. })
  3625. .catch((err) => {});
  3626. },
  3627. /**
  3628. * 更新配置 并求解
  3629. */
  3630. //选择step
  3631. bStepChange(val){
  3632. this.bStep=val;
  3633. if(this.bStep==0){
  3634. Message({
  3635. type: "warning",
  3636. message: "请选择setp有效值",
  3637. });
  3638. }else{
  3639. this.showboundary();
  3640. }
  3641. },
  3642. //选择step
  3643. vStepChange(val){
  3644. this.vStep=val;
  3645. if(val==0){
  3646. Message({
  3647. type: "warning",
  3648. message: "请选择setp有效值",
  3649. });
  3650. }else{
  3651. this.Volumeshow();
  3652. }
  3653. },
  3654. // 表面加载
  3655. SurfaceChange(value){// 选择色条个数
  3656. this.Surfacenum=value;
  3657. },
  3658. // 体积
  3659. VolumenumChange(value){// 选择色条个数
  3660. this.Volumenum=value;
  3661. },
  3662. async reUpload() {
  3663. this.$refs.mapbc.uploader.upload();
  3664. this.$refs.ugrid.uploader.upload();
  3665. },
  3666. async ugridShow() {
  3667. if (
  3668. this.project.projectId == "" ||
  3669. this.project.projectId == undefined ||
  3670. this.project.projectId == null
  3671. ) {
  3672. Message({
  3673. type: "error",
  3674. message: "缺少文件,请检查修改",
  3675. });
  3676. } else {
  3677. this.dialog.new_visiable = false;
  3678. this.tstep=0;
  3679. this.clearserver();
  3680. this.initWebSocket();
  3681. }
  3682. },
  3683. async findParam() {
  3684. let params = {
  3685. transCode: "A00107",
  3686. projectId: this.project.projectId,
  3687. };
  3688. // console.log(params);
  3689. await request(params)
  3690. .then((res) => {
  3691. // console.log("findParam:" + res);
  3692. this.project.projectName = res.projectName;
  3693. this.project.uid = res.uid;
  3694. let cjuserid = this.$route.query.cjuserid;
  3695. sessionStorage.setItem('projectName',res.projectName)
  3696. if(res.missionType==='3'||res.missionType==='4'){
  3697. this.missType=false
  3698. }else{
  3699. this.missType=true
  3700. }
  3701. console.log(this.parameterObj)
  3702. this.parameterObj = JSON.parse(res.parameterObj);
  3703. sessionStorage.setItem("res", res.parameterObj);
  3704. this.lsolverState=res.solverState;
  3705. })
  3706. .catch((err) => {});
  3707. },
  3708. //上传配置参数
  3709. async updateParam() {
  3710. delete this.parameterObj.nmlParam.initialization;
  3711. let params = {
  3712. transCode: "A00104",
  3713. parameterObj: JSON.stringify(this.parameterObj),
  3714. projectId: this.project.projectId,
  3715. lesseeId: this.$store.getters.lesseeId
  3716. };
  3717. console.log(this.parameterObj.nmlParam.a_u);
  3718. console.log(this.parameterObj);
  3719. await request(params)
  3720. .then((res) => {
  3721. this.solverState = res.solverState;
  3722. })
  3723. .catch((err) => {});
  3724. },
  3725. loadProjects() {
  3726. this.dialog.load_visiable=true;
  3727. let params = {
  3728. transCode: "A00101",
  3729. page: 1,
  3730. size: 1,
  3731. projectType: "hcfd",
  3732. lesseeId: this.$store.getters.lesseeId
  3733. };
  3734. this.loading = true;
  3735. request(params)
  3736. .then((res) => {
  3737. this.projects = res.rows;
  3738. this.loading = false;
  3739. })
  3740. .catch((err) => {});
  3741. },
  3742. projectsSelectionChange(val) {
  3743. this.clearAll();
  3744. if (val.length == 1) {
  3745. this.project.projectId = val[0].projectId;;
  3746. this.project.projectName =val[0].projectName;
  3747. this.project.projectDesc = val[0].projectDesc;
  3748. this.xiugai=val[0];
  3749. } else if (val.length > 1) {
  3750. this.project.projectId = val[1].projectId;;
  3751. this.project.projectName =val[1].projectName;
  3752. this.project.projectDesc = val[1].projectDesc;
  3753. this.xiugai=val[1];
  3754. }
  3755. },
  3756. projectsSelectionSelect(selection, row) {
  3757. if (selection.length <= 1) return;
  3758. this.$refs.projectsTable.clearSelection();
  3759. this.$refs.projectsTable.toggleRowSelection(row, true);
  3760. },
  3761. //load状态回调
  3762. fileLoadeState(files) {
  3763. files.forEach((file) => {
  3764. this.loadObjs.forEach((obj) => {
  3765. if (obj.type == 2) {
  3766. if (obj.filename === file.name) {
  3767. obj.percentage = file.percentage;
  3768. }
  3769. }
  3770. if (obj.type == 1) {
  3771. // obj.message=file.message;
  3772. }
  3773. });
  3774. });
  3775. },
  3776. boundaryChange(boundaryid) {
  3777. this.boundaryid=boundaryid;
  3778. this.parameterObj.hcfdBoundarys.forEach((hcfdBoundary) => {
  3779. if (hcfdBoundary.id === boundaryid) {
  3780. this.Physics.hcfdBoundaryquery = hcfdBoundary;
  3781. this.Physics.Boundary.cquery = hcfdBoundary.conditionsCode;
  3782. return;
  3783. }
  3784. });
  3785. },
  3786. conditionsChange(conditionsCode) {
  3787. this.Physics.hcfdBoundaryquery.conditionsCode = conditionsCode;
  3788. this.parameterObj.hcfdBoundarys.forEach((hcfdBoundary) => {
  3789. if (hcfdBoundary.id === this.boundaryid) {
  3790. this.Physics.hcfdBoundaryquery = hcfdBoundary;
  3791. this.Physics.Boundary.cquery = hcfdBoundary.conditionsCode;
  3792. return;
  3793. }
  3794. });
  3795. },
  3796. solutionbCheckAllChange(val) {
  3797. if(val==true){
  3798. this.parameterObj.nmlParam.a_u = true;
  3799. this.parameterObj.nmlParam.a_v = true;
  3800. this.parameterObj.nmlParam.a_w = true;
  3801. this.parameterObj.nmlParam.a_p = true;
  3802. this.parameterObj.nmlParam.a_cp = true;
  3803. this.parameterObj.nmlParam.a_mach = true;
  3804. this.parameterObj.nmlParam.a_vort_mag = true;
  3805. this.parameterObj.nmlParam.a_vort_x = true;
  3806. this.parameterObj.nmlParam.a_vort_y = true;
  3807. this.parameterObj.nmlParam.a_vort_z = true;
  3808. this.parameterObj.nmlParam.a_q_criterion = true;
  3809. this.Solution.boundaryout.isIndeterminate = false;
  3810. //this.solutionbSetParam();
  3811. }else {
  3812. this.parameterObj.nmlParam.a_u = false;
  3813. this.parameterObj.nmlParam.a_v = false;
  3814. this.parameterObj.nmlParam.a_w = false;
  3815. this.parameterObj.nmlParam.a_p = false;
  3816. this.parameterObj.nmlParam.a_cp = false;
  3817. this.parameterObj.nmlParam.a_mach = false;
  3818. this.parameterObj.nmlParam.a_vort_mag = false;
  3819. this.parameterObj.nmlParam.a_vort_x = false;
  3820. this.parameterObj.nmlParam.a_vort_y = false;
  3821. this.parameterObj.nmlParam.a_vort_z = false;
  3822. this.parameterObj.nmlParam.a_q_criterion = false;
  3823. this.Solution.boundaryout.isIndeterminate = false;
  3824. }
  3825. },
  3826. solutionbCheckedCitiesChange(value) {
  3827. let checkedCount = value.length;
  3828. this.Solution.boundaryout.checkAll =
  3829. checkedCount === this.Solution.boundaryout.lists.length;
  3830. this.Solution.boundaryout.isIndeterminate =
  3831. checkedCount > 0 &&
  3832. checkedCount < this.Solution.boundaryout.lists.length;
  3833. this.solutionbSetParam();
  3834. },
  3835. solutionbSetParam() {
  3836. this.Solution.boundaryout.checkeds.forEach((cell) => {
  3837. switch (cell) {
  3838. case "X-component of velocity":
  3839. console.log( this.parameterObj.nmlParam.a_u);
  3840. this.parameterObj.nmlParam.a_u = true;
  3841. break;
  3842. case "Y-component of velocity":
  3843. this.parameterObj.nmlParam.a_v = true;
  3844. break;
  3845. case "Z-component of velocity":
  3846. this.parameterObj.nmlParam.a_w = true;
  3847. break;
  3848. case "Press":
  3849. this.parameterObj.nmlParam.a_p = true;
  3850. break;
  3851. case "Press coefficient":
  3852. this.parameterObj.nmlParam.a_cp = true;
  3853. break;
  3854. case "Mach Number":
  3855. this.parameterObj.nmlParam.a_mach = true;
  3856. break;
  3857. case "Vorticity magnitude":
  3858. this.parameterObj.nmlParam.a_vort_mag = true;
  3859. break;
  3860. case "X-component of vorticity":
  3861. this.parameterObj.nmlParam.a_vort_x = true;
  3862. break;
  3863. case "Y-component of vorticity":
  3864. this.parameterObj.nmlParam.a_vort_y = true;
  3865. break;
  3866. case "Z-component of vorticity":
  3867. this.parameterObj.nmlParam.a_vort_z = true;
  3868. break;
  3869. case "Q Criterion":
  3870. this.parameterObj.nmlParam.a_q_criterion = true;
  3871. break;
  3872. default:
  3873. break;
  3874. }
  3875. });
  3876. },
  3877. solutionvCheckAllChange(val) {
  3878. // this.Solution.volumout.checkeds = val ? this.Solution.volumout.lists : [];
  3879. // this.Solution.volumout.isIndeterminate = false;
  3880. // this.solutionbSetParam();
  3881. if(val==true){
  3882. this.parameterObj.nmlParam.v_u = true;
  3883. this.parameterObj.nmlParam.v_v = true;
  3884. this.parameterObj.nmlParam.v_w = true;
  3885. this.parameterObj.nmlParam.v_p = true;
  3886. this.parameterObj.nmlParam.v_cp = true;
  3887. this.parameterObj.nmlParam.v_mach = true;
  3888. this.parameterObj.nmlParam.v_vort_mag = true;
  3889. this.parameterObj.nmlParam.v_vort_x = true;
  3890. this.parameterObj.nmlParam.v_vort_y = true;
  3891. this.parameterObj.nmlParam.v_vort_z = true;
  3892. this.parameterObj.nmlParam.v_q_criterion = true;
  3893. }else{
  3894. this.parameterObj.nmlParam.v_u = false;
  3895. this.parameterObj.nmlParam.v_v = false;
  3896. this.parameterObj.nmlParam.v_w = false;
  3897. this.parameterObj.nmlParam.v_p = false;
  3898. this.parameterObj.nmlParam.v_cp = false;
  3899. this.parameterObj.nmlParam.v_mach = false;
  3900. this.parameterObj.nmlParam.v_vort_mag = false;
  3901. this.parameterObj.nmlParam.v_vort_x = false;
  3902. this.parameterObj.nmlParam.v_vort_y = false;
  3903. this.parameterObj.nmlParam.v_vort_z = false;
  3904. this.parameterObj.nmlParam.v_q_criterion = false;
  3905. this.Solution.volumout.isIndeterminate = false;
  3906. }
  3907. },
  3908. solutionvCheckedCitiesChange(value) {
  3909. let checkedCount = value.length;
  3910. console.log(value);
  3911. this.Solution.volumout.checkAll =
  3912. checkedCount === this.Solution.volumout.lists.length;
  3913. this.Solution.volumout.isIndeterminate =
  3914. checkedCount > 0 && checkedCount < this.Solution.volumout.lists.length;
  3915. this.solutionvSetParam();
  3916. },
  3917. solutionvSetParam() {
  3918. this.Solution.volumout.checkeds.forEach((cell) => {
  3919. switch (cell) {
  3920. case "X-component of velocity":
  3921. this.parameterObj.nmlParam.v_u = true;
  3922. break;
  3923. case "Y-component of velocity":
  3924. this.parameterObj.nmlParam.v_v = true;
  3925. break;
  3926. case "Z-component of velocity":
  3927. this.parameterObj.nmlParam.v_w = true;
  3928. break;
  3929. case "Press":
  3930. this.parameterObj.nmlParam.v_p = true;
  3931. break;
  3932. case "Press coefficient":
  3933. this.parameterObj.nmlParam.v_cp = true;
  3934. break;
  3935. case "Mach Number":
  3936. this.parameterObj.nmlParam.v_mach = true;
  3937. break;
  3938. case "Vorticity magnitude":
  3939. this.parameterObj.nmlParam.v_vort_mag = true;
  3940. break;
  3941. case "X-component of vorticity":
  3942. this.parameterObj.nmlParam.v_vort_x = true;
  3943. break;
  3944. case "Y-component of vorticity":
  3945. this.parameterObj.nmlParam.v_vort_y = true;
  3946. break;
  3947. case "Z-component of vorticity":
  3948. this.parameterObj.nmlParam.v_vort_z = true;
  3949. break;
  3950. case "Q Criterion":
  3951. this.parameterObj.nmlParam.v_q_criterion = true;
  3952. break;
  3953. default:
  3954. break;
  3955. }
  3956. });
  3957. },
  3958. //显示 UgridLoad
  3959. async showUgrid() {
  3960. console.log(this.showUgridflag);
  3961. this.$refs.monitor.hiden();
  3962. if (!this.showUgridflag) {
  3963. //是否显示过
  3964. this.$refs.ugridLoad.clear();
  3965. if (this.project.loadfils.length == 0) {
  3966. await this.getHCFDLoadFiles();
  3967. }
  3968. this.project.loadfils.forEach((url) => {
  3969. if (url.filepath.indexOf(".ugrid") > 0) {
  3970. this.ugridUrl = url.filepath;
  3971. }
  3972. });
  3973. this.$refs.ugridLoad.loadUgrid(this.ugridUrl, 1);
  3974. this.showUgridflag = true;
  3975. } else {
  3976. this.$refs.ugridLoad.nhiden();
  3977. }
  3978. },
  3979. //显示 Surface
  3980. async showSurface() {
  3981. let mesh = false;
  3982. let contour = false;
  3983. this.belementCheckeds.forEach((ele) => {
  3984. if ("Mesh" == ele) {
  3985. mesh = true;
  3986. } else if ("Contour" == ele) {
  3987. contour = true;
  3988. }
  3989. });
  3990. this.$refs.ugridLoad.hiden();
  3991. this.$refs.volumLoad.hiden();
  3992. this.$refs.monitor.hiden();
  3993. if (!this.showSurfaceflag) {
  3994. if (this.project.solverfiles.length == 0) {
  3995. }
  3996. let burl;
  3997. this.project.solverBoundaryUrls.forEach((url) => {
  3998. if (url.indexOf(this.bStep + ".dat") > 0) {
  3999. burl = url;
  4000. }
  4001. });
  4002. if (mesh) {
  4003. this.$refs.boundaryLoad.loadBoundary(burl, 1, this.bScalar);
  4004. }
  4005. if (contour) {
  4006. this.$refs.boundaryLoad.loadBoundary(burl, 2, this.bScalar);
  4007. }
  4008. this.showSurfaceflag = true;
  4009. } else {
  4010. this.$refs.boundaryLoad.clear();
  4011. this.$refs.boundaryLoad.nhiden();
  4012. if (mesh) {
  4013. this.$refs.boundaryLoad.mesh(this.bScalar);
  4014. }
  4015. if (contour) {
  4016. // console.log(222);
  4017. this.$refs.volumLoad.vdivb = false;
  4018. this.$refs.boundaryLoad.divb = true;
  4019. this.$refs.boundaryLoad.contour(this.bScalar);
  4020. }
  4021. }
  4022. },
  4023. large() {
  4024. this.$refs.ugridLoad.large();
  4025. this.$refs.boundaryLoad.large();
  4026. this.$refs.volumLoad.large();
  4027. },
  4028. small() {
  4029. this.$refs.ugridLoad.small();
  4030. this.$refs.boundaryLoad.small();
  4031. this.$refs.volumLoad.small();
  4032. },
  4033. positive(axis) {
  4034. this.$refs.ugridLoad.positive(axis);
  4035. this.$refs.boundaryLoad.positive(axis);
  4036. this.$refs.volumLoad.positive(axis);
  4037. },
  4038. negative(axis) {
  4039. this.$refs.ugridLoad.negative(axis);
  4040. this.$refs.boundaryLoad.negative(axis);
  4041. this.$refs.volumLoad.negative(axis);
  4042. },
  4043. // 资源选择代码
  4044. showresource(){
  4045. this.dialog.ziyuan=true;
  4046. this.getresource();
  4047. },
  4048. //获取资源代码
  4049. getresource(){
  4050. const loading = this.$loading({
  4051. lock: true,
  4052. text: 'Loading',
  4053. spinner: 'el-icon-loading',
  4054. background: 'rgba(0, 0, 0, 0.7)',
  4055. })
  4056. setTimeout(() => {
  4057. const params = {
  4058. transCode: 'HG00000',
  4059. page: this.paginationConfig.page,
  4060. count: this.paginationConfig.size,
  4061. lesseeId:this.$store.getters.lesseeId,
  4062. }
  4063. request(params)
  4064. .then((res) => {
  4065. loading.close()
  4066. this.ziyprojects = res.rows;
  4067. this.paginationConfig.total = res.total
  4068. this.resourcelook();
  4069. })
  4070. .catch((err) => {
  4071. loading.close()
  4072. })
  4073. }, 500)
  4074. },
  4075. getPagination(data) {
  4076. this.paginationConfig = data
  4077. this.getresource()
  4078. },
  4079. //选中
  4080. ziySelectionChange (val) {
  4081. let id= []
  4082. val.map((item)=> {
  4083. id.push(item.id)
  4084. })
  4085. this.selsectid= id.join(',')
  4086. },
  4087. ziySelectionSelect(selection, row) {
  4088. },
  4089. // 日志的文本框
  4090. footerShows(evt) {
  4091. if(evt=='claer'){
  4092. this.logs='';
  4093. }else{
  4094. this.footerShow=!this.footerShow
  4095. }
  4096. },
  4097. //保存
  4098. resourceOK(){
  4099. const params = {
  4100. transCode: 'HG00002',
  4101. otherId:this.project.projectId,
  4102. type:'1',
  4103. resourceIds:this.selsectid,
  4104. lesseeId:this.$store.getters.lesseeId,
  4105. }
  4106. request(params)
  4107. .then((res) => {
  4108. Message({
  4109. type: "success",
  4110. message: "保存成功",
  4111. });
  4112. this.dialog.ziyuan=false;
  4113. })
  4114. .catch((err) => {
  4115. })
  4116. },
  4117. changest(val){
  4118. },
  4119. // 查看已经中的
  4120. resourcelook(){
  4121. const loading = this.$loading({
  4122. lock: true,
  4123. text: 'Loading',
  4124. spinner: 'el-icon-loading',
  4125. background: 'rgba(0, 0, 0, 0.7)',
  4126. })
  4127. const params = {
  4128. transCode: 'HG00001',
  4129. otherId: this.project.projectId,
  4130. type:'1',
  4131. lesseeId:this.$store.getters.lesseeId,
  4132. }
  4133. request(params)
  4134. .then((res) => {
  4135. loading.close()
  4136. let rst=res.rows;
  4137. console.log(res)
  4138. this.$refs.multipleTable.clearSelection();
  4139. if (rst.length > 0) {
  4140. for (var i = 0; i < rst.length; i++) {
  4141. for ( let j = 0 ; j < this.ziyprojects.length; j++ ){
  4142. if (this.ziyprojects[j].id === rst[i].resourceId) {
  4143. this.$refs.multipleTable.toggleRowSelection(this.ziyprojects[j],true);
  4144. }
  4145. }
  4146. }
  4147. }else{
  4148. consolog.log(2222)
  4149. }
  4150. })
  4151. .catch((err) => {
  4152. loading.close()
  4153. })
  4154. },
  4155. closeOff(val){
  4156. if(val=='on'){
  4157. this.Consoleshow=true;
  4158. this.openshow=false;
  4159. }else{
  4160. console.log(val);
  4161. this.Consoleshow=false;
  4162. this.openshow=true;
  4163. }
  4164. },
  4165. }
  4166. }
  4167. </script>
  4168. <style lang="scss" >
  4169. @import '@/styles/variables.scss';
  4170. @import '@/styles/mixin.scss';
  4171. .hcfdlab{
  4172. .el-input__inner{
  4173. line-height: 30px;
  4174. height: 30px;
  4175. }
  4176. }
  4177. html,body{
  4178. width: 100%;
  4179. height: 100%;
  4180. }
  4181. .el-tabs__content{
  4182. padding: 0 5px;
  4183. }
  4184. .content{
  4185. display: flex;
  4186. height: 100%;
  4187. position: relative;
  4188. .left{
  4189. width: 200px;
  4190. height: 100%;
  4191. flex-direction: column;
  4192. padding: 15px;
  4193. position: relative;
  4194. height: 88vh;
  4195. }
  4196. .part-panel-collapse-handle {
  4197. position: absolute;
  4198. // right: -56px;
  4199. left: -38px;
  4200. top: 44%;
  4201. width: 94px;
  4202. height: 0;
  4203. cursor: pointer;
  4204. text-align: center;
  4205. border-width: 0 20px 18px;
  4206. line-height: 18px;
  4207. border-style: none solid solid;
  4208. transform: rotateZ(
  4209. 90deg);
  4210. font-size: 19px;
  4211. }
  4212. .lbg_color3 i:before{
  4213. transform: rotateZ(
  4214. 0);
  4215. }
  4216. .right{
  4217. flex: 1;
  4218. height: 100%;
  4219. height: 85vh;
  4220. position: relative;
  4221. }
  4222. .imgcontent img{
  4223. font-size: 16px;
  4224. }
  4225. .slide-fade-enter-active {
  4226. transition: all .3s ease;
  4227. }
  4228. }
  4229. .tablist{
  4230. border-bottom:1px solid #999;
  4231. padding: 3px 0;
  4232. }
  4233. .tablist .tabitem{
  4234. color: #b6b6b6;
  4235. font-size: 16px;
  4236. padding-right: 5px;
  4237. cursor: pointer;
  4238. &.current{
  4239. color: #Fff ;
  4240. }
  4241. }
  4242. .imgzong{
  4243. display: flex;
  4244. padding-top: 4px;
  4245. overflow: auto;
  4246. white-space: nowrap;
  4247. .el-image{
  4248. width:30px;
  4249. vertical-align: middle;
  4250. }
  4251. }
  4252. .imgzong::-webkit-scrollbar {/*滚动条整体样式*/
  4253. width:4px;/*高宽分别对应横竖滚动条的尺寸*/
  4254. height:4px;
  4255. }
  4256. .imgzong::-webkit-scrollbar-thumb {/*滚动条里面小方块*/
  4257. border-radius:5px;
  4258. -webkit-box-shadow: inset005pxrgba(0,0,0,0.2);
  4259. background:rgba(0,0,0,0.2); /*设置滚动条颜色*/
  4260. }
  4261. .imgzong::-webkit-scrollbar-track {/*滚动条里面轨道*/
  4262. -webkit-box-shadow: inset005pxrgba(0,0,0,0.2);
  4263. border-radius:0;
  4264. // background:rgba(255,255,255,0.1);
  4265. background:rgba(255,255,255,0);
  4266. }
  4267. .item1,.item2{
  4268. cursor: pointer;
  4269. }
  4270. .imgzong .item1{
  4271. padding-right: 4px;
  4272. padding: 4px 4px ;
  4273. }
  4274. .shu{
  4275. padding: 4px 10px;
  4276. color: #666;
  4277. }
  4278. .el-tabs__item{
  4279. color:#b6b6b6;
  4280. font-size: 16px;
  4281. }
  4282. .textlab{
  4283. display: inline-block;
  4284. vertical-align: middle;
  4285. margin-top: -28px;
  4286. }
  4287. </style>
  4288. <style lang="scss" scoped>
  4289. .bkcolor3{
  4290. // background-color: rgba(255, 255, 255, 0.3);
  4291. // color:#333;
  4292. }
  4293. .activeOrange{
  4294. background-color:rgba(255, 255, 255, 0.3);
  4295. border:2px solid #fff;
  4296. border-radius: 5px;
  4297. box-sizing: border-box;
  4298. }
  4299. .imgzong{
  4300. padding-top: 4px;
  4301. .radiocontent{
  4302. display: flex;
  4303. justify-content: center;
  4304. align-items: center;
  4305. }
  4306. .listitem{
  4307. width: auto;
  4308. height:92px;
  4309. margin: 5px;
  4310. padding: 2px 6px 2px 2px;
  4311. .el-image{
  4312. width:18px;
  4313. vertical-align: middle;
  4314. }
  4315. span{
  4316. font-size: 14px;
  4317. }
  4318. }
  4319. .item2 {
  4320. .el-image{
  4321. margin: 0 19px;
  4322. width:60px;
  4323. vertical-align: middle;
  4324. padding: 9px;
  4325. }
  4326. span{
  4327. display: block;
  4328. text-align: center;
  4329. }
  4330. }
  4331. }
  4332. </style>
  4333. <style>
  4334. .itemimg{
  4335. display: flex;
  4336. justify-content: center;
  4337. padding: 8px;
  4338. }
  4339. .el-input-number__decrease, .el-input-number__increase{
  4340. position: absolute;
  4341. z-index: 1;
  4342. top: 4px;
  4343. width: 31px;
  4344. height: 30px;
  4345. text-align: center;
  4346. background: #F5F7FA;
  4347. color: #606266;
  4348. cursor: pointer;
  4349. font-size: 13px;
  4350. }
  4351. .el-tabs--bottom .el-tabs__header.is-bottom{
  4352. margin: 0;
  4353. }
  4354. .el-tabs__header{
  4355. margin: 0;
  4356. }
  4357. .imgcontent{
  4358. padding: 0 15px;
  4359. }
  4360. .el-tabs__item{
  4361. height: 30px;
  4362. line-height: 30px;
  4363. padding: 0 8px;
  4364. font-size: 12px;
  4365. }
  4366. .el-tabs--border-card{
  4367. background-color: none;
  4368. }
  4369. .baoshi{
  4370. margin-top: 4px;
  4371. color: #b6b6b6;
  4372. }
  4373. .el-tabs--border-card>.el-tabs__header .el-tabs__item.is-active{
  4374. background-color: #757070;
  4375. }
  4376. .el-dialog__header{
  4377. padding: 15px 20px 10px;
  4378. }
  4379. .textselsect{
  4380. position: absolute;
  4381. z-index: 9;
  4382. bottom: 1px;
  4383. right: 7px;
  4384. z-index: 9;
  4385. }
  4386. .dialoglocation{
  4387. position: absolute;
  4388. top: -15vh;
  4389. left: 10px;
  4390. }
  4391. .el-dialog__wrapper{
  4392. top: 15vh;
  4393. }
  4394. </style>
  4395. // 样式大全
  4396. <style lang="scss" scoped>
  4397. .el-dialog__wrapper{
  4398. top: 20vh;
  4399. }
  4400. /deep/.textselsect .el-input__inner{
  4401. background-color: rgba(0, 0, 0, 0) !important;
  4402. }
  4403. .diyi i{
  4404. font-size: 14px;
  4405. color: #C0C4CC;
  4406. }
  4407. .tupian{
  4408. display: flex;
  4409. justify-content: center;
  4410. align-items: center;
  4411. }
  4412. .red{
  4413. color: red;
  4414. }
  4415. .dialog_header{
  4416. align-items: center;
  4417. display: flex;
  4418. }
  4419. .juli{
  4420. margin-top: 15px;
  4421. width: 100%
  4422. }
  4423. </style>
  4424. <style lang="scss">
  4425. @import '@/styles/variables.scss';
  4426. @import '@/styles/mixin.scss';
  4427. .heigeinput
  4428. {
  4429. .el-form-item{
  4430. margin-bottom: 5px;
  4431. }
  4432. }
  4433. .el-dialog__body{
  4434. padding: 10px 20px 10px 20px;
  4435. }
  4436. .line{
  4437. width: 100%;
  4438. height: 1px;
  4439. background-color: #999;
  4440. position: relative;
  4441. margin: 30px 0;
  4442. .linetext{
  4443. position: absolute;
  4444. left: 50%;
  4445. transform: translateX(-50%);
  4446. background-color: #ffff;
  4447. padding: 5px;
  4448. font-size: 12px;
  4449. top: -10px;
  4450. font-weight: 700;
  4451. }
  4452. }
  4453. .ulist ul{
  4454. display: flex;
  4455. margin: 0;
  4456. padding: 0;
  4457. li{
  4458. flex: 1;
  4459. border: 1px solid #666;
  4460. }
  4461. }
  4462. .liitem{
  4463. margin-bottom: 5px;
  4464. }
  4465. .inputwithd .el-input__inner{
  4466. width: 74px;
  4467. }
  4468. .inputtext .el-input{
  4469. margin-top: 5px;
  4470. }
  4471. .dancentent{
  4472. display: flex;
  4473. justify-content:center;
  4474. align-items: center;
  4475. }
  4476. .titleinput .el-input{
  4477. width: 100px;
  4478. }
  4479. .itemlist{
  4480. display: flex;
  4481. }
  4482. .listbtn{
  4483. display: flex;
  4484. margin-bottom: 5px;
  4485. .anniu{
  4486. flex: 1;
  4487. }
  4488. .el-checkbox{
  4489. flex: 1;
  4490. }
  4491. }
  4492. .anniu{
  4493. padding: 5px 28px;
  4494. font-size: 12px;
  4495. margin: 0;
  4496. }
  4497. .titleinput{
  4498. .el-row{
  4499. padding-left: 10px;
  4500. }
  4501. .el-button{
  4502. padding: 8px 28px;
  4503. font-size: 12px;
  4504. }
  4505. .el-button+.el-button{
  4506. margin: 0;
  4507. }
  4508. }
  4509. .el-dialog__wrapper{
  4510. z-index: 2300;
  4511. }
  4512. .tiele{
  4513. width: 324px;
  4514. background-color: #fff;
  4515. position: fixed;
  4516. top: 50%;
  4517. left: 50%;
  4518. z-index: 2049;
  4519. padding: 20px;
  4520. .heder{
  4521. width: 100%;
  4522. height: 40px;
  4523. line-height: 40px;
  4524. font-size: 14px;
  4525. padding: 0 20px;
  4526. border-bottom: 1px solid #eee;
  4527. }
  4528. .tiele_content{
  4529. padding: 20px 20px;
  4530. .el-checkbox{
  4531. display: block;
  4532. }
  4533. }
  4534. p{
  4535. text-align: center;
  4536. }
  4537. }
  4538. .el-form-item{
  4539. margin: 0;
  4540. }
  4541. .btntext{
  4542. text-align: center;
  4543. background-color: #757070;
  4544. color:#d5d5d5 ;
  4545. font-size: 12px;
  4546. padding: 4px 0;
  4547. margin: 5px 0;
  4548. border-radius: 5px;
  4549. }
  4550. .btnyiban{
  4551. width: 50%;
  4552. background-color: #757070;
  4553. color:#d5d5d5 ;
  4554. }
  4555. .fangxiang .el-row{
  4556. display: flex;
  4557. padding-bottom: 10px;
  4558. }
  4559. .input3{
  4560. display: flex;
  4561. flex-wrap:nowrap;
  4562. justify-content: space-around;
  4563. padding-bottom: 5px;
  4564. .el-input{
  4565. width: 30%;
  4566. }
  4567. }
  4568. .yiinpu .el-form-item__content{
  4569. display:flex;
  4570. .el-input{
  4571. margin-right: 5px;
  4572. }
  4573. }
  4574. .saninput{
  4575. display: flex;
  4576. flex-wrap:nowrap;
  4577. justify-content: space-around;
  4578. .el-input{
  4579. margin-right: 5px;
  4580. }
  4581. .el-form-item__label{
  4582. text-align: left;
  4583. }
  4584. }
  4585. // select样式
  4586. .selecr{
  4587. font-size: 12px;
  4588. .el-select{
  4589. width: 100%;
  4590. }
  4591. }
  4592. .btnringth{
  4593. text-align: right;
  4594. }
  4595. .juli .el-input__inner{
  4596. margin-bottom: 5px;
  4597. width:100%;
  4598. }
  4599. </style>
  4600. <style lang="scss" scoped>
  4601. /deep/.toolbar-part-detail{
  4602. position: relative;
  4603. }
  4604. /deep/ .el-form-item__label{
  4605. font-size: 12px;
  4606. line-height: 30px;
  4607. }
  4608. /deep/.el-form-item__content{
  4609. line-height: 30px;
  4610. font-size: 12px;
  4611. }
  4612. /deep/ .el-input-number__decrease{
  4613. width: 30px;
  4614. line-height: 28px;
  4615. }
  4616. /deep/ .el-input-number__increase{
  4617. width: 30px;
  4618. line-height: 28px;
  4619. }
  4620. /deep/ .el-dialog__headerbtn:hover .el-dialog__close{
  4621. color: #fff !important;
  4622. }
  4623. .el-form-item{
  4624. margin-bottom: 5px;
  4625. }
  4626. </style>
  4627. <style lang="scss" scoped>
  4628. .femFooter {
  4629. height: 135px !important;
  4630. padding: 0;
  4631. position: relative;
  4632. }
  4633. .footerTitle {
  4634. display: flex;
  4635. justify-content: space-between;
  4636. padding: 5px 20px;
  4637. font-size: 20px;
  4638. height: 30px !important;
  4639. background-color: #bbb;
  4640. }
  4641. .footerTitle div {
  4642. display: flex;
  4643. justify-content: space-around;
  4644. align-items: center;
  4645. }
  4646. .footerTitle p {
  4647. margin: 0;
  4648. }
  4649. .footerTitle span {
  4650. padding: 5px 10px;
  4651. cursor: default;
  4652. }
  4653. /deep/.footerText .el-textarea__inner{
  4654. width: 100%;
  4655. height: 135px !important;
  4656. border: 0;
  4657. font-size: 12px;
  4658. color: #333;
  4659. padding: 2px;
  4660. }
  4661. .radio_text{
  4662. line-height: 28px;
  4663. .el-radio__label{
  4664. color: #d5d5d5;
  4665. }
  4666. .disacent{
  4667. padding: 6px 0 6px 3.125vw;
  4668. font-size:12px;
  4669. }
  4670. }
  4671. .iemradio .el-radio-group{
  4672. padding-left: 50px;
  4673. }
  4674. .radiooff{
  4675. padding-left: 50px;
  4676. }
  4677. .el-table th, .el-table tr{
  4678. background-color: #535353;
  4679. }
  4680. .beij-container {
  4681. width: 100%;
  4682. height: 100%;
  4683. background: linear-gradient(180deg, #ccd3e2 0%, rgba(255, 255, 255, 0) 100%);
  4684. }
  4685. .el-footer {
  4686. padding: 0;
  4687. height: 149px;
  4688. overflow-y: auto;
  4689. }
  4690. .radiogroup .el-radio-group{
  4691. display: contents;
  4692. }
  4693. .logs_title {
  4694. background: #bfc5cb;
  4695. padding: 10px;
  4696. font-size: 16px;
  4697. }
  4698. .x {
  4699. cursor: default;
  4700. float: right;
  4701. }
  4702. .exloadbox {
  4703. float: right;
  4704. margin-right: 100px;
  4705. display: flex;
  4706. }
  4707. .maxh221{
  4708. max-height: calc(100vh - 10px);
  4709. }
  4710. .maxh400{
  4711. max-height: calc(100vh - 410px);
  4712. }
  4713. body {
  4714. position: relative;
  4715. background-color: #eceef0;
  4716. }
  4717. .el-loading-mask {
  4718. background: none;
  4719. }
  4720. .sblock{
  4721. width: 100px;
  4722. display: inline-block;
  4723. }
  4724. .groupradio .el-radio{
  4725. display: block;
  4726. padding: 5px;
  4727. }
  4728. .desc{
  4729. width: 100%;
  4730. height: 130px;
  4731. border:1px solid #000;
  4732. padding: 20px;
  4733. overflow: auto;
  4734. }
  4735. .Squareline{
  4736. border: 1px solid;
  4737. padding: 10px;
  4738. // transform: translateX(-50%);
  4739. }
  4740. .radiogroup{
  4741. display:flex;
  4742. }
  4743. .radiogroup label{
  4744. flex: 1;
  4745. }
  4746. .el-radio+.el-radio{
  4747. margin-left:0;
  4748. }
  4749. /deep/ .radiogroup .el-radio-button--mini .el-radio-button__inner{
  4750. border-radius: 5px;
  4751. }
  4752. /deep/ .radiogroup .el-radio-button:last-child .el-radio-button__inner{
  4753. border-radius: 4px ;
  4754. }
  4755. /deep/ .heightclass{
  4756. height: 450px;
  4757. overflow-y: auto;
  4758. }
  4759. /deep/ .heightclass .el-dialog__header{
  4760. position: fixed;
  4761. z-index: 99;
  4762. width: 385px;
  4763. }
  4764. /deep/ .heightclass .el-dialog__body{
  4765. margin-top: 60px;
  4766. }
  4767. .displanblock .el-checkbox{
  4768. display: block;
  4769. }
  4770. .outline{
  4771. margin-left: 50px;
  4772. font-size: 20px;
  4773. }
  4774. /deep/.el-dialog__wrapper{
  4775. pointer-events:none;
  4776. }
  4777. /deep/.el-dialog{
  4778. pointer-events:auto;
  4779. }
  4780. /deep/ .asideTag2{
  4781. left: auto;
  4782. right: 10px;
  4783. top: 21px;
  4784. ul{
  4785. display: flex;
  4786. li{
  4787. margin-left: 4px;
  4788. width: 28px;
  4789. height: 28px;
  4790. }
  4791. }
  4792. }
  4793. .asideTag{
  4794. top: 30px;
  4795. }
  4796. /deep/ .asideTag ul{
  4797. display: flex;
  4798. li{
  4799. margin-left: 4px;
  4800. width: 28px;
  4801. height: 28px;
  4802. }
  4803. }
  4804. @media screen and (max-width:1330px){
  4805. .headMenu_2 .el-col{
  4806. transform:scale(0.8);
  4807. transform-origin: 0 0;
  4808. }
  4809. .headMenu_2{
  4810. height: 150px !important;
  4811. }
  4812. .asideTag2,.asideTag {
  4813. transform:scale(0.7);
  4814. transform-origin: 0 0;
  4815. }
  4816. }
  4817. @media screen and (max-width:1160px){
  4818. .headMenu_2 .el-col{
  4819. transform:scale(0.7);
  4820. transform-origin: 0 0;
  4821. }
  4822. .asideTag2{
  4823. left: 91%;
  4824. }
  4825. .el-aside{
  4826. width:170px !important;
  4827. }
  4828. .headMenu_2{
  4829. height: 135px !important;
  4830. }
  4831. }
  4832. .text{
  4833. color: #fff;
  4834. font-size:14px;
  4835. margin: 0;
  4836. }
  4837. .y{
  4838. width:100%;
  4839. height:100%;
  4840. background-image: url('../../../assets/3d_images/y.png') center 100%;
  4841. }
  4842. .y2{
  4843. background-image: url('../../../assets/3d_images/y2.png');
  4844. }
  4845. body{
  4846. font-family:'微软雅黑'
  4847. }
  4848. .classfelx{
  4849. flex:1;
  4850. }
  4851. .liitem .formLabelWidth8{
  4852. width: 343px;
  4853. }
  4854. .formLabelWidth15{
  4855. width:70px;
  4856. text-align:center;
  4857. }
  4858. </style>
  4859. <style>
  4860. .imge{
  4861. width:25px;
  4862. vertical-align:middle;
  4863. }
  4864. .textselsect .el-input__inner{
  4865. background-color: rgba(255, 255, 255, 0);
  4866. }
  4867. .el-color-picker__trigger{
  4868. height: 30px;
  4869. width: 33px;
  4870. padding: 3px;
  4871. }
  4872. </style>