investHomeGroup.js 284 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941942943944945946947948949950951952953954955956957958959960961962963964965966967968969970971972973974975976977978979980981982983984985986987988989990991992993994995996997998999100010011002100310041005100610071008100910101011101210131014101510161017101810191020102110221023102410251026102710281029103010311032103310341035103610371038103910401041104210431044104510461047104810491050105110521053105410551056105710581059106010611062106310641065106610671068106910701071107210731074107510761077107810791080108110821083108410851086108710881089109010911092109310941095109610971098109911001101110211031104110511061107110811091110111111121113111411151116111711181119112011211122112311241125112611271128112911301131113211331134113511361137113811391140114111421143114411451146114711481149115011511152115311541155115611571158115911601161116211631164116511661167116811691170117111721173117411751176117711781179118011811182118311841185118611871188118911901191119211931194119511961197119811991200120112021203120412051206120712081209121012111212121312141215121612171218121912201221122212231224122512261227122812291230123112321233123412351236123712381239124012411242124312441245124612471248124912501251125212531254125512561257125812591260126112621263126412651266126712681269127012711272127312741275127612771278127912801281128212831284128512861287128812891290129112921293129412951296129712981299130013011302130313041305130613071308130913101311131213131314131513161317131813191320132113221323132413251326132713281329133013311332133313341335133613371338133913401341134213431344134513461347134813491350135113521353135413551356135713581359136013611362136313641365136613671368136913701371137213731374137513761377137813791380138113821383138413851386138713881389139013911392139313941395139613971398139914001401140214031404140514061407140814091410141114121413141414151416141714181419142014211422142314241425142614271428142914301431143214331434143514361437143814391440144114421443144414451446144714481449145014511452145314541455145614571458145914601461146214631464146514661467146814691470147114721473147414751476147714781479148014811482148314841485148614871488148914901491149214931494149514961497149814991500150115021503150415051506150715081509151015111512151315141515151615171518151915201521152215231524152515261527152815291530153115321533153415351536153715381539154015411542154315441545154615471548154915501551155215531554155515561557155815591560156115621563156415651566156715681569157015711572157315741575157615771578157915801581158215831584158515861587158815891590159115921593159415951596159715981599160016011602160316041605160616071608160916101611161216131614161516161617161816191620162116221623162416251626162716281629163016311632163316341635163616371638163916401641164216431644164516461647164816491650165116521653165416551656165716581659166016611662166316641665166616671668166916701671167216731674167516761677167816791680168116821683168416851686168716881689169016911692169316941695169616971698169917001701170217031704170517061707170817091710171117121713171417151716171717181719172017211722172317241725172617271728172917301731173217331734173517361737173817391740174117421743174417451746174717481749175017511752175317541755175617571758175917601761176217631764176517661767176817691770177117721773177417751776177717781779178017811782178317841785178617871788178917901791179217931794179517961797179817991800180118021803180418051806180718081809181018111812181318141815181618171818181918201821182218231824182518261827182818291830183118321833183418351836183718381839184018411842184318441845184618471848184918501851185218531854185518561857185818591860186118621863186418651866186718681869187018711872187318741875187618771878187918801881188218831884188518861887188818891890189118921893189418951896189718981899190019011902190319041905190619071908190919101911191219131914191519161917191819191920192119221923192419251926192719281929193019311932193319341935193619371938193919401941194219431944194519461947194819491950195119521953195419551956195719581959196019611962196319641965196619671968196919701971197219731974197519761977197819791980198119821983198419851986198719881989199019911992199319941995199619971998199920002001200220032004200520062007200820092010201120122013201420152016201720182019202020212022202320242025202620272028202920302031203220332034203520362037203820392040204120422043204420452046204720482049205020512052205320542055205620572058205920602061206220632064206520662067206820692070207120722073207420752076207720782079208020812082208320842085208620872088208920902091209220932094209520962097209820992100210121022103210421052106210721082109211021112112211321142115211621172118211921202121212221232124212521262127212821292130213121322133213421352136213721382139214021412142214321442145214621472148214921502151215221532154215521562157215821592160216121622163216421652166216721682169217021712172217321742175217621772178217921802181218221832184218521862187218821892190219121922193219421952196219721982199220022012202220322042205220622072208220922102211221222132214221522162217221822192220222122222223222422252226222722282229223022312232223322342235223622372238223922402241224222432244224522462247224822492250225122522253225422552256225722582259226022612262226322642265226622672268226922702271227222732274227522762277227822792280228122822283228422852286228722882289229022912292229322942295229622972298229923002301230223032304230523062307230823092310231123122313231423152316231723182319232023212322232323242325232623272328232923302331233223332334233523362337233823392340234123422343234423452346234723482349235023512352235323542355235623572358235923602361236223632364236523662367236823692370237123722373237423752376237723782379238023812382238323842385238623872388238923902391239223932394239523962397239823992400240124022403240424052406240724082409241024112412241324142415241624172418241924202421242224232424242524262427242824292430243124322433243424352436243724382439244024412442244324442445244624472448244924502451245224532454245524562457245824592460246124622463246424652466246724682469247024712472247324742475247624772478247924802481248224832484248524862487248824892490249124922493249424952496249724982499250025012502250325042505250625072508250925102511251225132514251525162517251825192520252125222523252425252526252725282529253025312532253325342535253625372538253925402541254225432544254525462547254825492550255125522553255425552556255725582559256025612562256325642565256625672568256925702571257225732574257525762577257825792580258125822583258425852586258725882589259025912592259325942595259625972598259926002601260226032604260526062607260826092610261126122613261426152616261726182619262026212622262326242625262626272628262926302631263226332634263526362637263826392640264126422643264426452646264726482649265026512652265326542655265626572658265926602661266226632664266526662667266826692670267126722673267426752676267726782679268026812682268326842685268626872688268926902691269226932694269526962697269826992700270127022703270427052706270727082709271027112712271327142715271627172718271927202721272227232724272527262727272827292730273127322733273427352736273727382739274027412742274327442745274627472748274927502751275227532754275527562757275827592760276127622763276427652766276727682769277027712772277327742775277627772778277927802781278227832784278527862787278827892790279127922793279427952796279727982799280028012802280328042805280628072808280928102811281228132814281528162817281828192820282128222823282428252826282728282829283028312832283328342835283628372838283928402841284228432844284528462847284828492850285128522853285428552856285728582859286028612862286328642865286628672868286928702871287228732874287528762877287828792880288128822883288428852886288728882889289028912892289328942895289628972898289929002901290229032904290529062907290829092910291129122913291429152916291729182919292029212922292329242925292629272928292929302931293229332934293529362937293829392940294129422943294429452946294729482949295029512952295329542955295629572958295929602961296229632964296529662967296829692970297129722973297429752976297729782979298029812982298329842985298629872988298929902991299229932994299529962997299829993000300130023003300430053006300730083009301030113012301330143015301630173018301930203021302230233024302530263027302830293030303130323033303430353036303730383039304030413042304330443045304630473048304930503051305230533054305530563057305830593060306130623063306430653066306730683069307030713072307330743075307630773078307930803081308230833084308530863087308830893090309130923093309430953096309730983099310031013102310331043105310631073108310931103111311231133114311531163117311831193120312131223123312431253126312731283129313031313132313331343135313631373138313931403141314231433144314531463147314831493150315131523153315431553156315731583159316031613162316331643165316631673168316931703171317231733174317531763177317831793180318131823183318431853186318731883189319031913192319331943195319631973198319932003201320232033204320532063207320832093210321132123213321432153216321732183219322032213222322332243225322632273228322932303231323232333234323532363237323832393240324132423243324432453246324732483249325032513252325332543255325632573258325932603261326232633264326532663267326832693270327132723273327432753276327732783279328032813282328332843285328632873288328932903291329232933294329532963297329832993300330133023303330433053306330733083309331033113312331333143315331633173318331933203321332233233324332533263327332833293330333133323333333433353336333733383339334033413342334333443345334633473348334933503351335233533354335533563357335833593360336133623363336433653366336733683369337033713372337333743375337633773378337933803381338233833384338533863387338833893390339133923393339433953396339733983399340034013402340334043405340634073408340934103411341234133414341534163417341834193420342134223423342434253426342734283429343034313432343334343435343634373438343934403441344234433444344534463447344834493450345134523453345434553456345734583459346034613462346334643465346634673468346934703471347234733474347534763477347834793480348134823483348434853486348734883489349034913492349334943495349634973498349935003501350235033504350535063507350835093510351135123513351435153516351735183519352035213522352335243525352635273528352935303531353235333534353535363537353835393540354135423543354435453546354735483549355035513552355335543555355635573558355935603561356235633564356535663567356835693570357135723573357435753576357735783579358035813582358335843585358635873588358935903591359235933594359535963597359835993600360136023603360436053606360736083609361036113612361336143615361636173618361936203621362236233624362536263627362836293630363136323633363436353636363736383639364036413642364336443645364636473648364936503651365236533654365536563657365836593660366136623663366436653666366736683669367036713672367336743675367636773678367936803681368236833684368536863687368836893690369136923693369436953696369736983699370037013702370337043705370637073708370937103711371237133714371537163717371837193720372137223723372437253726372737283729373037313732373337343735373637373738373937403741374237433744374537463747374837493750375137523753375437553756375737583759376037613762376337643765376637673768376937703771377237733774377537763777377837793780378137823783378437853786378737883789379037913792379337943795379637973798379938003801380238033804380538063807380838093810381138123813381438153816381738183819382038213822382338243825382638273828382938303831383238333834383538363837383838393840384138423843384438453846384738483849385038513852385338543855385638573858385938603861386238633864386538663867386838693870387138723873387438753876387738783879388038813882388338843885388638873888388938903891389238933894389538963897389838993900390139023903390439053906390739083909391039113912391339143915391639173918391939203921392239233924392539263927392839293930393139323933393439353936393739383939394039413942394339443945394639473948394939503951395239533954395539563957395839593960396139623963396439653966396739683969397039713972397339743975397639773978397939803981398239833984398539863987398839893990399139923993399439953996399739983999400040014002400340044005400640074008400940104011401240134014401540164017401840194020402140224023402440254026402740284029403040314032403340344035403640374038403940404041404240434044404540464047404840494050405140524053405440554056405740584059406040614062406340644065406640674068406940704071407240734074407540764077407840794080408140824083408440854086408740884089409040914092409340944095409640974098409941004101410241034104410541064107410841094110411141124113411441154116411741184119412041214122412341244125412641274128412941304131413241334134413541364137413841394140414141424143414441454146414741484149415041514152415341544155415641574158415941604161416241634164416541664167416841694170417141724173417441754176417741784179418041814182418341844185418641874188418941904191419241934194419541964197419841994200420142024203420442054206420742084209421042114212421342144215421642174218421942204221422242234224422542264227422842294230423142324233423442354236423742384239424042414242424342444245424642474248424942504251425242534254425542564257425842594260426142624263426442654266426742684269427042714272427342744275427642774278427942804281428242834284428542864287428842894290429142924293429442954296429742984299430043014302430343044305430643074308430943104311431243134314431543164317431843194320432143224323432443254326432743284329433043314332433343344335433643374338433943404341434243434344434543464347434843494350435143524353435443554356435743584359436043614362436343644365436643674368436943704371437243734374437543764377437843794380438143824383438443854386438743884389439043914392439343944395439643974398439944004401440244034404440544064407440844094410441144124413441444154416441744184419442044214422442344244425442644274428442944304431443244334434443544364437443844394440444144424443444444454446444744484449445044514452445344544455445644574458445944604461446244634464446544664467446844694470447144724473447444754476447744784479448044814482448344844485448644874488448944904491449244934494449544964497449844994500450145024503450445054506450745084509451045114512451345144515451645174518451945204521452245234524452545264527452845294530453145324533453445354536453745384539454045414542454345444545454645474548454945504551455245534554455545564557455845594560456145624563456445654566456745684569457045714572457345744575457645774578457945804581458245834584458545864587458845894590459145924593459445954596459745984599460046014602460346044605460646074608460946104611461246134614461546164617461846194620462146224623462446254626462746284629463046314632463346344635463646374638463946404641464246434644464546464647464846494650465146524653465446554656465746584659466046614662466346644665466646674668466946704671467246734674467546764677467846794680468146824683468446854686468746884689469046914692469346944695469646974698469947004701470247034704470547064707470847094710471147124713471447154716471747184719472047214722472347244725472647274728472947304731473247334734473547364737473847394740474147424743474447454746474747484749475047514752475347544755475647574758475947604761476247634764476547664767476847694770477147724773477447754776477747784779478047814782478347844785478647874788478947904791479247934794479547964797479847994800480148024803480448054806480748084809481048114812481348144815481648174818481948204821482248234824482548264827482848294830483148324833483448354836483748384839484048414842484348444845484648474848484948504851485248534854485548564857485848594860486148624863486448654866486748684869487048714872487348744875487648774878487948804881488248834884488548864887488848894890489148924893489448954896489748984899490049014902490349044905490649074908490949104911491249134914491549164917491849194920492149224923492449254926492749284929493049314932493349344935493649374938493949404941494249434944494549464947494849494950495149524953495449554956495749584959496049614962496349644965496649674968496949704971497249734974497549764977497849794980498149824983498449854986498749884989499049914992499349944995499649974998499950005001500250035004500550065007500850095010501150125013501450155016501750185019502050215022502350245025502650275028502950305031503250335034503550365037503850395040504150425043504450455046504750485049505050515052505350545055505650575058505950605061506250635064506550665067506850695070507150725073507450755076507750785079508050815082508350845085508650875088508950905091509250935094509550965097509850995100510151025103510451055106510751085109511051115112511351145115511651175118511951205121512251235124512551265127512851295130513151325133513451355136513751385139514051415142514351445145514651475148514951505151515251535154515551565157515851595160516151625163516451655166516751685169517051715172517351745175517651775178517951805181518251835184518551865187518851895190519151925193519451955196519751985199520052015202520352045205520652075208520952105211521252135214521552165217521852195220522152225223522452255226522752285229523052315232523352345235523652375238523952405241524252435244524552465247524852495250525152525253525452555256525752585259526052615262526352645265526652675268526952705271527252735274527552765277527852795280528152825283528452855286528752885289529052915292529352945295529652975298529953005301530253035304530553065307530853095310531153125313531453155316531753185319532053215322532353245325532653275328532953305331533253335334533553365337533853395340534153425343534453455346534753485349535053515352535353545355535653575358535953605361536253635364536553665367536853695370537153725373537453755376537753785379538053815382538353845385538653875388538953905391539253935394539553965397539853995400540154025403540454055406540754085409541054115412541354145415541654175418541954205421542254235424542554265427542854295430543154325433543454355436543754385439544054415442544354445445544654475448544954505451545254535454545554565457545854595460546154625463546454655466546754685469547054715472547354745475547654775478547954805481548254835484548554865487548854895490549154925493549454955496549754985499550055015502550355045505550655075508550955105511551255135514551555165517551855195520552155225523552455255526552755285529553055315532553355345535553655375538553955405541554255435544554555465547554855495550555155525553555455555556555755585559556055615562556355645565556655675568556955705571557255735574557555765577557855795580558155825583558455855586558755885589559055915592559355945595559655975598559956005601560256035604560556065607560856095610561156125613561456155616561756185619562056215622562356245625562656275628562956305631563256335634563556365637563856395640564156425643564456455646564756485649565056515652565356545655565656575658565956605661566256635664566556665667566856695670567156725673567456755676567756785679568056815682568356845685568656875688568956905691569256935694569556965697569856995700570157025703570457055706570757085709571057115712571357145715571657175718571957205721572257235724572557265727572857295730573157325733573457355736573757385739574057415742574357445745574657475748574957505751575257535754575557565757575857595760576157625763576457655766576757685769577057715772577357745775577657775778577957805781578257835784578557865787578857895790579157925793579457955796579757985799580058015802580358045805580658075808580958105811581258135814581558165817581858195820582158225823582458255826582758285829583058315832583358345835583658375838583958405841584258435844584558465847584858495850585158525853585458555856585758585859586058615862586358645865586658675868586958705871587258735874587558765877587858795880588158825883588458855886588758885889589058915892589358945895589658975898589959005901590259035904590559065907590859095910591159125913591459155916591759185919592059215922592359245925592659275928592959305931593259335934593559365937593859395940594159425943594459455946594759485949595059515952595359545955595659575958595959605961596259635964596559665967596859695970597159725973597459755976597759785979598059815982598359845985598659875988598959905991599259935994599559965997599859996000600160026003600460056006600760086009601060116012601360146015601660176018601960206021602260236024602560266027602860296030603160326033603460356036603760386039604060416042604360446045604660476048604960506051605260536054605560566057605860596060606160626063606460656066606760686069607060716072607360746075607660776078607960806081608260836084608560866087608860896090609160926093609460956096609760986099610061016102610361046105610661076108610961106111611261136114611561166117611861196120612161226123612461256126612761286129613061316132613361346135613661376138613961406141614261436144614561466147614861496150615161526153615461556156615761586159616061616162616361646165616661676168616961706171617261736174617561766177617861796180618161826183618461856186618761886189619061916192619361946195619661976198619962006201620262036204620562066207620862096210621162126213621462156216621762186219622062216222622362246225622662276228622962306231623262336234623562366237623862396240624162426243624462456246624762486249625062516252625362546255625662576258625962606261626262636264626562666267626862696270627162726273627462756276627762786279628062816282628362846285628662876288628962906291629262936294629562966297629862996300630163026303630463056306630763086309631063116312631363146315631663176318631963206321632263236324632563266327632863296330633163326333633463356336633763386339634063416342634363446345634663476348634963506351635263536354635563566357635863596360636163626363636463656366636763686369637063716372637363746375637663776378637963806381638263836384638563866387638863896390639163926393639463956396639763986399640064016402640364046405640664076408640964106411641264136414641564166417641864196420642164226423642464256426642764286429643064316432643364346435643664376438643964406441644264436444644564466447644864496450645164526453645464556456645764586459646064616462646364646465646664676468646964706471647264736474647564766477647864796480648164826483648464856486648764886489649064916492649364946495649664976498649965006501650265036504650565066507650865096510651165126513651465156516651765186519652065216522652365246525652665276528652965306531653265336534653565366537653865396540654165426543654465456546654765486549655065516552655365546555655665576558655965606561656265636564656565666567656865696570657165726573657465756576657765786579658065816582658365846585658665876588658965906591659265936594659565966597659865996600660166026603660466056606660766086609661066116612661366146615661666176618661966206621662266236624662566266627662866296630663166326633663466356636663766386639664066416642664366446645664666476648664966506651665266536654665566566657665866596660666166626663666466656666666766686669667066716672667366746675667666776678667966806681668266836684668566866687668866896690669166926693669466956696669766986699670067016702670367046705670667076708670967106711671267136714671567166717671867196720672167226723672467256726672767286729673067316732673367346735673667376738673967406741674267436744674567466747674867496750675167526753675467556756675767586759676067616762676367646765676667676768676967706771677267736774677567766777677867796780678167826783678467856786678767886789679067916792679367946795679667976798679968006801680268036804680568066807680868096810681168126813681468156816681768186819682068216822682368246825682668276828682968306831683268336834683568366837683868396840684168426843684468456846
  1. let app = new Vue({
  2. el: '#app',
  3. data () {
  4. return {
  5. centerOriginalConfig6: '',
  6. rightAdd: {},// 左边新增筛选参数
  7. projectNum: '', // 项目列表弹窗顶部类目筛选条件
  8. centerType: true, // 中间3D饼图
  9. boardType: '', // 哪边的项目看板
  10. pullShow: false, // 选择年份弹窗
  11. pollList: [],
  12. mockData: false,// 是否使用修改的数据
  13. year: '', // 选择的年份
  14. boardUrl: '', // 跳转路径
  15. boardTipShow: false, // 项目看板弹窗专用
  16. lineCommonCompany: [], //双柱状图弹窗上面的折线图x轴
  17. commonCompanyAll: [], // 公司包括编码
  18. changeLine: true,
  19. versions: true, // 是否使用接口数据数据
  20. app_token: '',
  21. centerShow: false, // 中间内容显示
  22. echartR4Chart: '',// 倒数第二个专用
  23. echartR5Chart: '', // 倒是第一个专用
  24. myChartTip1: '', // 弹窗单个柱状图专用
  25. myChartTip2: '', // 弹窗两个柱状图专用
  26. myChartTip3: '', // 弹窗两个柱状图专用
  27. echartEnterpriseShow: false, // 企业额度分析控制
  28. mapChart: '',//地图专用echarts
  29. chartCarousel: '',//做大屏轮播专用echarts
  30. mapTipShow: false,
  31. echartSingleTipShow: false,
  32. echartDoubleTipShow: false,
  33. projectListTipShow: false, //项目列表专属弹窗
  34. titleUrl: '',
  35. titleName: '',
  36. yellowCount: 0, // 黄圈轮播参数
  37. yellowPosition: 40,// 黄圈悬浮窗位置参数
  38. yellowType: true, // 黄圈悬浮停止轮播
  39. echartR1Fd: true,
  40. echartR2Fd: true,
  41. echartC2Fd: true,
  42. echartR3Fd: true,
  43. time: '', // 页面上绑定的时间
  44. timer: '', // 页面上的时间一秒定时器
  45. timer2: '', // 黄圈专用2秒定时器
  46. pieTime1: '', // 饼图轮播专用
  47. pieTime2: '', // 饼图轮播专用
  48. pieTime3: '', // 饼图轮播专用
  49. pieTime4: '', // 饼图轮播专用
  50. pieTime5: '', // 饼图轮播专用
  51. pieTime6: '', // 饼图轮播专用
  52. center1: center1,
  53. showTip2: false,
  54. showTip3: false,
  55. list: [],
  56. count: 0,
  57. countType: 0,
  58. geoCoordMap: {},
  59. storageRecordConfig2: center9,
  60. titleList: right1,
  61. centerLeftList: right3,
  62. storageRecordConfig: left11,
  63. config5: {
  64. rowNum: 9,
  65. waitTime: 2000,
  66. headerHeight: '40',
  67. header: ["项目名称", "所属组织", '实施主体', '建设性质(新建/续建)', '产业类别', '建设地点', '2022年投资完成额(万元)'],
  68. data: [
  69. ["青银二广高速公路太原联络线建设PPP项目", "交控集团", "山西路桥建设集团有限公司", "新建", "交通运输业", "山西省太原市、晋中市", "148,086.00"],
  70. ["国道241、省道岚马线汾河水库段改线工程", "交控集团", "太原国省道汾河水库段建设管理有限公司", "续建", "交通运输业", "山西省 太原市、吕梁市", "165,314.33"],
  71. ["路桥科技中心", "交控集团", "山西路桥集团多经营有限公司", "续建", "建筑房地产", "山西省太原市", "8,098.26"],
  72. ["路桥科研基地", "交控集团", "山西路桥集团多经有限公司", "续建", "建筑房地产", "山西省太原市", "6,596.56"],
  73. ["武宿高速充电站建设", "交控集团", "山西交通运输投融资集团有限责任公司", "新建", "新能源", "山西省太原市", "100.00"],
  74. ["山西交通研创商务基地项目", "交控集团", "山西交通物流集团有限公司", "续建", "建筑房地产", "山西省太原市", "4,097.00"],
  75. ["山西省交通科学研究院产业化基地", "交控集团", "山西省交通科技研发有限公司", "续建", "建筑房地产", "山西省太原市武洛街27号", "3,242.00"],
  76. ["太长高速公路太原南收费站(二期工程暨龙城服务区)项目", "交控集团", "山西省交通开发投资集团有限公司龙城服务区发展分公司", "续建", "建筑房地产", "山西省太原市", "3,580.00"],
  77. ["山西转型综改示范区中小企业产业园项目", "交控集团", "山西交投综改园区开发有限公司", "续建", "建筑房地产", "山西省太原市", "14,432.00"]
  78. ],
  79. align: ["center", "center", "center", "center", "center", "center", "center"],
  80. headerBGC: "#153A62",
  81. oddRowBGC: "#061F42",
  82. evenRowBGC: "#0C284A",
  83. },
  84. originalConfig6: [],
  85. config6: listPop
  86. }
  87. },
  88. created () {
  89. this.time = formatDate()
  90. this.timer = setInterval(() => {
  91. this.time = formatDate()
  92. }, 1000)
  93. this.timer2 = setInterval(() => {
  94. this.yellowType && this.changeYellow()
  95. }, 2000)
  96. },
  97. beforeDestroy () {
  98. if (this.timer) {
  99. clearInterval(this.timer);
  100. }
  101. if (this.timer2) {
  102. clearInterval(this.timer2);
  103. }
  104. },
  105. mounted () {
  106. this.getUrlParams()
  107. this.countYear()
  108. this.comeIn()
  109. },
  110. methods: {
  111. // 获取地址栏参数
  112. getUrlParams (id) {
  113. let url = window.location.href
  114. // 通过 ? 分割获取后面的参数字符串
  115. let urlStr = url.split('?')[1]
  116. if (!urlStr) {
  117. return
  118. }
  119. // 创建空对象存储参数
  120. let obj = {};
  121. // 再通过 & 将每一个参数单独分割出来
  122. let paramsArr = urlStr.split('&')
  123. for (let i = 0, len = paramsArr.length; i < len; i++) {
  124. // 再通过 = 将每一个参数分割为 key:value 的形式
  125. let arr = paramsArr[i].split('=')
  126. obj[arr[0]] = arr[1];
  127. }
  128. if (obj.model) {
  129. obj.model == 'A' || obj.model == 'a' ? this.mockData = false : this.mockData = true
  130. }
  131. },
  132. // 计算展示的年份
  133. countYear () {
  134. this.year = new Date().getFullYear()
  135. for (i = 2022; true; i++) {
  136. if (i == this.year + 3) {
  137. this.pollList.push(i)
  138. return
  139. } else {
  140. this.pollList.push(i)
  141. }
  142. }
  143. },
  144. comeIn () {
  145. if (this.versions) {
  146. // 接口版
  147. this.getAppToken()
  148. setTimeout(() => {
  149. this.changeTopColor()
  150. // 大屏三
  151. this.initChartR5()
  152. this.changeYellow()
  153. })
  154. } else {
  155. // 假数据版
  156. setTimeout(() => {
  157. this.initChartL1()
  158. this.initChartL2()
  159. this.initChartL3()
  160. this.initChartL4()
  161. this.initChartL5()
  162. this.initChartL6()
  163. this.initChartL7()
  164. this.initChartL8()
  165. this.initChartL10()
  166. this.initChartL11()
  167. this.changeTopColor()
  168. // 大屏二
  169. this.initChinaChart()
  170. // 大屏三
  171. this.initChartR1()
  172. this.initChartR2()
  173. this.initChartR3()
  174. this.changeYellow()
  175. })
  176. }
  177. },
  178. chooseTime (value) {
  179. let that = this
  180. this.year = value
  181. that.destroyCharts()
  182. this.pullShow = false
  183. setTimeout(item => {
  184. that.comeIn()
  185. })
  186. },
  187. destroyCharts () {
  188. this.pieTime1 && clearInterval(this.pieTime1);
  189. this.pieTime2 && clearInterval(this.pieTime2);
  190. this.pieTime3 && clearInterval(this.pieTime3);
  191. this.pieTime4 && clearInterval(this.pieTime4);
  192. this.pieTime5 && clearInterval(this.pieTime5);
  193. this.pieTime6 && clearInterval(this.pieTime6);
  194. this.left10Chart ? this.left10Chart.dispose() : ''
  195. this.left1Chart ? (this.left1Chart.destroy(), this.left1Chart = '') : ''
  196. this.left2Chart ? (this.left2Chart.destroy(), this.left2Chart = '') : ''
  197. this.left3Chart ? (this.left3Chart.destroy(), this.left3Chart = '') : ''
  198. this.left4Chart ? (this.left4Chart.destroy(), this.left4Chart = '') : ''
  199. this.left5Chart ? (this.left5Chart.destroy(), this.left5Chart = '') : ''
  200. this.left6Chart ? (this.left6Chart.destroy(), this.left6Chart = '') : ''
  201. this.left7Chart ? this.left7Chart.dispose() : ''
  202. this.left8Chart ? this.left8Chart.dispose() : ''
  203. this.left9Chart ? this.left9Chart.dispose() : ''
  204. this.chartCarousel ? this.chartCarousel.dispose() : ''
  205. this.myChartTip1 ? this.myChartTip1.dispose() : ''
  206. this.myChartTip2 ? this.myChartTip2.dispose() : ''
  207. this.myChartTip3 ? this.myChartTip3.dispose() : ''
  208. this.left11Chart ? this.left11Chart.dispose() : ''
  209. this.right1Chart ? this.right1Chart.dispose() : ''
  210. this.right2Chart ? this.right2Chart.dispose() : ''
  211. this.right3Chart ? this.right3Chart.dispose() : ''
  212. this.echartR4Chart ? this.echartR4Chart.dispose() : ''
  213. this.echartR5Chart ? this.echartR5Chart.dispose() : ''
  214. // this.center1Chart ? this.center1Chart.destroy() : ''
  215. this.center1Chart ? this.center1Chart.dispose() : ''
  216. this.center2Chart ? this.center2Chart.dispose() : ''
  217. this.center3Chart ? this.center3Chart.dispose() : ''
  218. // this.center4Chart ? this.center4Chart.destroy() : ''
  219. this.center4Chart ? this.center4Chart.dispose() : ''
  220. this.mapChart ? this.mapChart.dispose() : ''
  221. },
  222. // 获取token
  223. getAppToken () {
  224. // dev环境
  225. // let value = {
  226. // "appId": "xilan1014", //系统编码
  227. // "appSecret": "12345678910Aa@Bb@Cc", //AccessToken加密认证密钥
  228. // "tenantid": "", //租户id
  229. // "accountId": "", //数据中心id
  230. // "language": "zh_CN"
  231. // }
  232. // SIT环境
  233. let value = {
  234. "appId": "68dp",
  235. "appSecret": "9ErhY^O{n?@Pc#eb7HYX",
  236. "tenantid": "",
  237. // "accountId": "1635498801198269440",
  238. "accountId": "1686324824621711360", // 新
  239. "language": "zh_CN"
  240. }
  241. post('/ierp/api/getAppToken.do', value).then(res => {
  242. this.app_token = res.data.app_token
  243. this.getAccessToken()
  244. })
  245. },
  246. // 获取AccessToken
  247. getAccessToken () {
  248. let value = {
  249. // "user": "19900000001", //登录用户手机号
  250. "user": "15835113238", // 新
  251. "apptoken": this.app_token, //应用令牌
  252. "tenantid": "", //租户id
  253. // "accountId": "1635498801198269440",//数据中心id
  254. "accountId": "1686324824621711360",// 新
  255. "usertype": "Mobile"
  256. }
  257. post('/ierp/api/login.do', value).then(res => {
  258. this.access_token = res.data.access_token
  259. this.getOrg()
  260. })
  261. },
  262. // 获取组织架构列表
  263. getOrg () {
  264. return new Promise((resolve, err) => {
  265. let value = {
  266. access_token: this.access_token,
  267. }
  268. get('/ierp/kapi/v2/mdnb/mdnb_xmkb/mdnb_manager_middle/getOrgName', value).then(res => {
  269. this.commonCompanyAll = res.data
  270. commonCompany = res.data.map(item => item.simplename)
  271. // 左边
  272. this.getDate1()
  273. this.getDate2()
  274. this.getDate3()
  275. this.getDate4()
  276. this.getDate5()
  277. this.getDate6()
  278. // 右边
  279. this.getDate7()
  280. this.getDate8()
  281. this.getDate9()
  282. this.getDate10()
  283. // this.getDate11() // 右下A
  284. this.getDate12() // 右下B
  285. // 中间
  286. this.getDate14()
  287. resolve(1);
  288. })
  289. });
  290. },
  291. // 获取左边企业额度分析
  292. getDate1 () {
  293. let that = this
  294. return new Promise((resolve, err) => {
  295. let value = {
  296. access_token: this.access_token,
  297. "data": {
  298. "mdnb_combofield": this.mockData ? 'B' : 'A',
  299. "mdnb_datefield": this.year - 1 + '-01-01',
  300. },
  301. pageSize: 1000
  302. }
  303. post('/ierp/kapi/v2/mdnb/mdnb_xmkb/mdnb_manager_preinvest/tqqyedfx', value).then(res => {
  304. if (res.data.rows.length > 0) {
  305. let dataList = res.data.rows[0].entryentity
  306. left3 = [[], [], []]
  307. dataList.forEach(item => {
  308. // 已用额度
  309. left3[0].push(that.yuanChange(item.mdnb_amountfield26))
  310. // 剩余额度
  311. left3[1].push(that.yuanChange(item.mdnb_amountfield27))
  312. // 总额度
  313. left3[2].push(that.yuanChange(item.mdnb_amountfield25))
  314. })
  315. this.initChartL4(dataList)
  316. }
  317. resolve(1);
  318. })
  319. });
  320. },
  321. // 获取左边投资计划分析
  322. getDate2 () {
  323. let that = this
  324. return new Promise((resolve, err) => {
  325. let value = {
  326. access_token: this.access_token,
  327. "data": {
  328. "mdnb_combofield": this.mockData ? 'B' : 'A',
  329. "mdnb_datefield": this.year - 1 + '-01-01',
  330. },
  331. pageSize: 1000
  332. }
  333. post('/ierp/kapi/v2/mdnb/mdnb_xmkb/mdnb_manager_preinvest/tqtzjhfx', value).then(res => {
  334. console.log(res)
  335. if (res.data.rows.length > 0) {
  336. let dataList = res.data.rows[0]
  337. left4 = []
  338. left4[0] = dataList.mdnb_amountfield7
  339. left4[1] = dataList.mdnb_amountfield13
  340. left4[2] = dataList.mdnb_amountfield23
  341. left4[3] = dataList.mdnb_amountfield43
  342. left4[4] = dataList.mdnb_integerfield14
  343. left5[0].y = that.yuanChange(dataList.mdnb_amountfield9)
  344. left5[0].num = dataList.mdnb_integerfield15
  345. left5[1].y = that.yuanChange(dataList.mdnb_amountfield43)
  346. left5[1].num = dataList.mdnb_integerfield14
  347. left6[0].y = that.yuanChange(dataList.mdnb_amountfield15)
  348. left6[0].num = dataList.mdnb_integerfield16
  349. left6[1].y = that.yuanChange(dataList.mdnb_amountfield16)
  350. left6[1].num = dataList.mdnb_integerfield17
  351. that.initChartL2()
  352. that.initChartL3()
  353. }
  354. resolve(1);
  355. })
  356. });
  357. },
  358. // 获取左边产业布局分析
  359. getDate3 () {
  360. let that = this
  361. return new Promise((resolve, err) => {
  362. let value = {
  363. access_token: this.access_token,
  364. "data": {
  365. "mdnb_combofield": this.mockData ? 'B' : 'A',
  366. "mdnb_datefield": this.year - 1 + '-01-01',
  367. },
  368. pageSize: 1000
  369. }
  370. post('/ierp/kapi/v2/mdnb/mdnb_xmkb/mdnb_manager_preinvest/tqcebjfx', value).then(res => {
  371. if (res.data.rows.length > 0) {
  372. let dataList = this.classify(res.data.rows[0].mdnb_entryentity, 'mdnb_textfield1')
  373. // 传统产业分析
  374. // if (dataList[0].data.length > left7.length || dataList[0].data.length == left7.length) {
  375. // for (let i = 0; i < left7.length; i++) {
  376. // left7[i].num = dataList[0].data[i].mdnb_integerfield13
  377. // left7[i].y = dataList[0].data[i].mdnb_amountfield8
  378. // }
  379. // this.initChartL5()
  380. // }
  381. dataList[0].data.forEach((item, i) => {
  382. left7[i] = {}
  383. left7[i].num = item.mdnb_integerfield13
  384. left7[i].y = item.mdnb_amountfield8
  385. left7[i].name = item.mdnb_textfield2
  386. })
  387. this.initChartL5()
  388. // 战略性新兴产业
  389. // if (dataList[1].data.length > left8.length || dataList[1].data.length == left8.length) {
  390. // for (let i = 0; i < left8.length; i++) {
  391. // left8[i].num = dataList[1].data[i].mdnb_integerfield13
  392. // left8[i].y = dataList[1].data[i].mdnb_amountfield8
  393. // }
  394. // this.initChartL6()
  395. // }
  396. dataList[1].data.forEach((item, i) => {
  397. left8[i] = {}
  398. left8[i].num = item.mdnb_integerfield13
  399. left8[i].y = item.mdnb_amountfield8
  400. left8[i].name = item.mdnb_textfield2
  401. })
  402. this.initChartL6()
  403. // 特色优势产业
  404. // if (dataList[2].data.length > left9.length || dataList[2].data.length == left9.length) {
  405. // for (let i = 0; i < left9.length; i++) {
  406. // left9[i].num = dataList[2].data[i].mdnb_integerfield13
  407. // left9[i].y = dataList[2].data[i].mdnb_amountfield8
  408. // }
  409. // this.initChartL7()
  410. // }
  411. dataList[2].data.forEach((item, i) => {
  412. left9[i] = {}
  413. left9[i].num = item.mdnb_integerfield13
  414. left9[i].y = item.mdnb_amountfield8
  415. left9[i].name = item.mdnb_textfield2
  416. })
  417. this.initChartL7()
  418. // 公共基础等产业
  419. if (dataList[3].data.length > left10.length || dataList[3].data.length == left10.length) {
  420. for (let i = 0; i < left10.length; i++) {
  421. left10[i].num = dataList[3].data[i].mdnb_integerfield13
  422. left10[i].y = dataList[3].data[i].mdnb_amountfield8
  423. }
  424. this.initChartL8()
  425. }
  426. }
  427. resolve(1);
  428. })
  429. });
  430. },
  431. // 获取左边项目阶段分析
  432. getDate4 () {
  433. let that = this
  434. return new Promise((resolve, err) => {
  435. let value = {
  436. access_token: this.access_token,
  437. "data": {
  438. "mdnb_combofield": this.mockData ? 'B' : 'A',
  439. "mdnb_datefield": this.year - 1 + '-01-01',
  440. },
  441. pageSize: 1000
  442. }
  443. post('/ierp/kapi/v2/mdnb/mdnb_xmkb/mdnb_manager_preinvest/tqxmjdfx', value).then(res => {
  444. if (res.data.rows.length > 0) {
  445. let dataList = res.data.rows[0]
  446. // 固定资产进度分布
  447. // 特别监管
  448. left13[0][0][2] = dataList.mdnb_integerfield1
  449. left13[0][0][3] = this.yuanChange(dataList.mdnb_amountfield241)
  450. left13[0][1][2] = dataList.mdnb_integerfield3
  451. left13[0][1][3] = this.yuanChange(dataList.mdnb_amountfield5)
  452. left13[0][2][2] = dataList.mdnb_integerfield5
  453. left13[0][2][3] = this.yuanChange(dataList.mdnb_amountfield21)
  454. left13[0][3][2] = dataList.mdnb_integerfield7
  455. left13[0][3][3] = this.yuanChange(dataList.mdnb_amountfield29)
  456. // 备案
  457. left13[1][0][2] = dataList.mdnb_integerfield2
  458. left13[1][0][3] = this.yuanChange(dataList.mdnb_amountfield341)
  459. left13[1][1][2] = dataList.mdnb_integerfield4
  460. left13[1][1][3] = this.yuanChange(dataList.mdnb_amountfield11)
  461. left13[1][2][2] = dataList.mdnb_integerfield6
  462. left13[1][2][3] = this.yuanChange(dataList.mdnb_amountfield28)
  463. left13[1][3][2] = dataList.mdnb_integerfield8
  464. left13[1][3][3] = this.yuanChange(dataList.mdnb_amountfield30)
  465. // 股权类进度分布
  466. // 特别监管
  467. left14[0][0][2] = dataList.mdnb_integerfield11
  468. left14[0][0][3] = this.yuanChange(dataList.mdnb_amountfield2411)
  469. left14[0][1][2] = dataList.mdnb_integerfield31
  470. left14[0][1][3] = this.yuanChange(dataList.mdnb_amountfield51)
  471. left14[0][2][2] = dataList.mdnb_integerfield51
  472. left14[0][2][3] = this.yuanChange(dataList.mdnb_amountfield211)
  473. left14[0][3][2] = dataList.mdnb_integerfield71
  474. left14[0][3][3] = this.yuanChange(dataList.mdnb_amountfield291)
  475. // 备案
  476. left14[1][0][2] = dataList.mdnb_integerfield21
  477. left14[1][0][3] = this.yuanChange(dataList.mdnb_amountfield3411)
  478. left14[1][1][2] = dataList.mdnb_integerfield41
  479. left14[1][1][3] = this.yuanChange(dataList.mdnb_amountfield111)
  480. left14[1][2][2] = dataList.mdnb_integerfield61
  481. left14[1][2][3] = this.yuanChange(dataList.mdnb_amountfield281)
  482. left14[1][3][2] = dataList.mdnb_integerfield81
  483. left14[1][3][3] = this.yuanChange(dataList.mdnb_amountfield301)
  484. this.initChartL10()
  485. this.initChartL11()
  486. }
  487. resolve(1);
  488. })
  489. });
  490. },
  491. // 获取左边投资额度分析
  492. getDate5 () {
  493. let that = this
  494. return new Promise((resolve, err) => {
  495. let value = {
  496. access_token: this.access_token,
  497. "data": {
  498. "mdnb_combofield": this.mockData ? 'B' : 'A',
  499. "mdnb_datefield": this.year - 1 + '-01-01',
  500. },
  501. pageSize: 1000
  502. }
  503. post('/ierp/kapi/v2/mdnb/mdnb_xmkb/mdnb_manager_preinvest/tqtzedfx', value).then(res => {
  504. if (res.data.rows.length > 0) {
  505. let dataList = res.data.rows[0]
  506. left1[0] = dataList.mdnb_amountfield
  507. left1[1] = dataList.mdnb_amountfield1
  508. left1[2] = dataList.mdnb_amountfield2
  509. left2[0] = dataList.mdnb_decimalfield
  510. left2[1] = dataList.mdnb_amountfield3
  511. this.initChartL1()
  512. }
  513. resolve(1);
  514. })
  515. });
  516. },
  517. // 获取左边重点项目两线指标
  518. getDate6 () {
  519. let that = this
  520. return new Promise((resolve, err) => {
  521. let value = {
  522. access_token: this.access_token,
  523. "data": {
  524. "mdnb_combofield": this.mockData ? 'B' : 'A',
  525. "mdnb_datefield": this.year - 1 + '-01-01',
  526. },
  527. pageSize: 1000
  528. }
  529. post('/ierp/kapi/v2/mdnb/mdnb_xmkb/mdnb_manager_preinvest/tqzdlxzb', value).then(res => {
  530. if (res.data.rows.length > 0) {
  531. let dataList2 = this.classify(res.data.rows[0].mdnb_entryentity1, 'mdnb_textfield3')
  532. // 右边的柱状图
  533. left12 = []
  534. dataList2.forEach((item, index) => {
  535. left12[index] = [[], [], []]
  536. for (let i = 0; i < 5; i++) {
  537. left12[index][0].push(item.data[i].mdnb_integerfield10)
  538. left12[index][1].push(item.data[i].mdnb_integerfield12)
  539. left12[index][2].push(item.data[i].mdnb_integerfield9)
  540. }
  541. })
  542. that.initChartL9()
  543. // 左边的轮播
  544. let dataList = []
  545. dataList2.forEach((item, index) => {
  546. dataList[index] = []
  547. dataList[index][0] = item.data[0].mdnb_textfield18
  548. dataList[index][1] = item.data[0].mdnb_textfield3
  549. dataList[index][2] = that.yuanChange(item.data[0].mdnb_amountfield24) + '亿'
  550. })
  551. this.storageRecordConfig.data = dataList
  552. this.storageRecordConfig = { ...this.storageRecordConfig }
  553. }
  554. resolve(1);
  555. })
  556. });
  557. },
  558. // 获取右边顶部条数据
  559. getDate7 () {
  560. return new Promise((resolve, err) => {
  561. let value = {
  562. access_token: this.access_token,
  563. "request": {
  564. isInsert: this.mockData ? '1' : '0',
  565. },
  566. pageSize: 1000
  567. }
  568. post('/ierp/kapi/v2/mdnb/mdnb_xmkb/mdnb_manager_middle/getTabpageap', value).then(res => {
  569. right1[0].number = res.data.mdnb_one_step
  570. right1[2].number = res.data.mdnb_two_step
  571. right1[4].number = res.data.mdnb_three_step
  572. right1[6].number = res.data.mdnb_four_step
  573. right1[8].number = res.data.mdnb_five_step
  574. right1[10].number = res.data.mdnb_six_step
  575. right1[12].number = res.data.mdnb_seven_step
  576. right1[14].number = res.data.mdnb_eight_step
  577. resolve(1);
  578. })
  579. });
  580. },
  581. // 获取右边中间左边的(正偏差/容差内/负偏差)
  582. getDate8 () {
  583. return new Promise((resolve, err) => {
  584. let value = {
  585. access_token: this.access_token,
  586. "request": {
  587. isInsert: this.mockData ? '1' : '0',
  588. },
  589. pageSize: 1000
  590. }
  591. post('/ierp/kapi/v2/mdnb/mdnb_xmkb/mdnb_manager_middle/getInvestSunstraction', value).then(res => {
  592. right3[0].value = res.data.mdnb_projectnum_z
  593. right3[0].value2 = res.data.mdnb_amountall_z
  594. right3[1].value = res.data.mdnb_projectnum_r
  595. right3[1].value2 = res.data.mdnb_amountall_r
  596. right3[2].value = res.data.mdnb_projectnum_f
  597. right3[2].value2 = res.data.mdnb_amountall_f
  598. resolve(1);
  599. })
  600. });
  601. },
  602. // 获取右边中间右边的(预算额/已签合同额。。。)
  603. getDate9 () {
  604. return new Promise((resolve, err) => {
  605. let value = {
  606. access_token: this.access_token,
  607. "request": {
  608. isInsert: this.mockData ? '1' : '0',
  609. },
  610. pageSize: 1000
  611. }
  612. post('/ierp/kapi/v2/mdnb/mdnb_xmkb/mdnb_manager_middle/getUnitBudgetExecuteDate', value).then(res => {
  613. res.data.forEach((item, index) => {
  614. right4[index].value = this.yuanChange(item.mdnb_aheadmoney)
  615. right4[index].value2 = this.yuanChange(item.mdnb_edmoney)
  616. right4[index].value3 = this.yuanChange(item.mdnb_smoney)
  617. right4[index].value4 = this.yuanChange(item.mdnb_jmoney)
  618. right4[index].value5 = this.yuanChange(item.mdnb_fkmoney)
  619. })
  620. this.initChartR1()
  621. resolve(1);
  622. })
  623. });
  624. },
  625. // 进度成本偏差
  626. getDate10 () {
  627. let that = this
  628. return new Promise((resolve, err) => {
  629. let value = {
  630. access_token: this.access_token,
  631. "request": {
  632. isInsert: this.mockData ? '1' : '0',
  633. },
  634. pageSize: 1000
  635. }
  636. post('/ierp/kapi/v2/mdnb/mdnb_xmkb/mdnb_manager_middle/getInvestSunstractionGas', value).then(res => {
  637. res.data.forEach((item, index) => {
  638. right5[0][index][1] = item.mdnb_amount_zb
  639. right5[0][index][2] = that.yuanChange(item.mdnb_amount_z)
  640. right5[1][index][1] = item.mdnb_amount_nb
  641. right5[1][index][2] = that.yuanChange(item.mdnb_amount_n)
  642. right5[2][index][1] = item.mdnb_amount_fb
  643. right5[2][index][2] = that.yuanChange(item.mdnb_amount_f)
  644. })
  645. this.initChartR2()
  646. resolve(1);
  647. })
  648. });
  649. },
  650. // 项目风险分析A
  651. getDate11 () {
  652. return new Promise((resolve, err) => {
  653. let value = {
  654. access_token: this.access_token,
  655. "request": {
  656. isInsert: this.mockData ? '1' : '0',
  657. },
  658. pageSize: 1000
  659. }
  660. post('/ierp/kapi/v2/mdnb/mdnb_xmkb/mdnb_manager_middle/getUnitNoSolveDangerDate', value).then(res => {
  661. res.data.forEach((item, index) => {
  662. right6[index].value = item.mdnb_height
  663. right6[index].value2 = item.mdnb_midle
  664. right6[index].value3 = item.mdnb_bottom
  665. })
  666. this.initChartR3()
  667. resolve(1);
  668. })
  669. });
  670. },
  671. // 项目风险分析B(雷达图)
  672. getDate12 () {
  673. return new Promise((resolve, err) => {
  674. let value = {
  675. access_token: this.access_token,
  676. "request": {
  677. isInsert: this.mockData ? '1' : '0',
  678. },
  679. pageSize: 1000
  680. }
  681. post('/ierp/kapi/v2/mdnb/mdnb_xmkb/mdnb_manager_middle/getUnitDangerPoraitDate', value).then(res => {
  682. res.data.forEach((item, index) => {
  683. right7[index][0] = item.mdnb_anquan
  684. right7[index][1] = item.mdnb_fukuan
  685. right7[index][2] = item.mdnb_hetong
  686. right7[index][3] = item.mdnb_jiesuan
  687. right7[index][4] = item.mdnb_jindu
  688. right7[index][5] = item.mdnb_securty
  689. })
  690. this.getDate11()
  691. resolve(1);
  692. })
  693. });
  694. },
  695. // 中间大屏数据
  696. getDate14 () {
  697. let that = this
  698. return new Promise((resolve, err) => {
  699. let value = {
  700. access_token: this.access_token,
  701. mock: this.mockData,
  702. presetYear: this.year
  703. }
  704. get('/ierp/kapi/v2/mdnb/mdnb_xmkb/presetdata/getKeyData', value).then(res => {
  705. console.log(res.data, '???????????')
  706. // 头部指标
  707. if (!res.data) {
  708. return
  709. }
  710. center4[0] = res.data.transformations.estateAmount
  711. center4[1] = res.data.transformations.estateNum
  712. center4[2] = res.data.transformations.figureAmount
  713. center4[3] = res.data.transformations.figureNum
  714. // 左投部指标
  715. center1[0] = res.data.keyIndicators.totalSum
  716. center1[1] = res.data.keyIndicators.total
  717. center1[2] = res.data.keyIndicators.property
  718. center1[3] = res.data.keyIndicators.invest
  719. // 投资产业分布
  720. console.log(res.data.distribution, '________')
  721. if (res.data.distribution.length != 0) {
  722. for (let i = 0; i < center2.length; i++) {
  723. center2[i].y = that.yuanChange(res.data.distribution[i].amount)
  724. center2[i].value = that.yuanChange(res.data.distribution[i].amount)
  725. center2[i].num = res.data.distribution[i].count
  726. center2[i].typeno = res.data.distribution[i].typeno
  727. }
  728. }
  729. // 投资执行情况
  730. res.data.implementationStatus.forEach((item, index) => {
  731. center3[index].value = that.yuanChange(item.plan)
  732. center3[index].value2 = that.yuanChange(item.reality)
  733. })
  734. // 五个一体化
  735. res.data.five.forEach((item, index) => {
  736. center6[index] = { name: item.type, value: that.yuanChange(item.amount), typeno: item.typeno }
  737. })
  738. // 投资阶段分析
  739. res.data.investmentStage.forEach((item, index) => {
  740. center7[index] = { name: item.type, value: Number(item.num), value2: that.yuanChange(item.amount), typeno: item.typeno, sliced: false, selected: false }
  741. })
  742. // 重点项目监控
  743. center8 = []
  744. this.originalConfig6 = res.data.projectMonitoring
  745. this.centerOriginalConfig6 = res.data.projectMonitoring
  746. res.data.projectMonitoring.forEach((item, index) => {
  747. center8.push({ value: item.amount, name: item.projectname, office: item.orgName })
  748. })
  749. // 中国地图
  750. centerChina = []
  751. res.data.investmentMap.forEach((item, index) => {
  752. centerChina.push({ name: item.address, value: that.yuanChange(item.amount), value2: item.value2 })
  753. })
  754. // 项目状态
  755. proState.projectStatus1 = res.data.projectStatus.projectStatus1
  756. proState.projectStatus2 = res.data.projectStatus.projectStatus2
  757. proState.projectStatus3 = res.data.projectStatus.projectStatus3
  758. setTimeout(() => {
  759. that.initChinaChart()
  760. })
  761. resolve(1);
  762. })
  763. });
  764. },
  765. // 右边穿透一级
  766. rightPenetrateOne () {
  767. this.boardType = 'right'
  768. return new Promise((resolve, err) => {
  769. let value = {
  770. access_token: this.access_token,
  771. "request": {
  772. isInsert: this.mockData ? '1' : '0'
  773. },
  774. pageSize: 1000
  775. }
  776. post('/ierp/kapi/v2/mdnb/mdnb_xmkb/mdnb_manager_middle/getOneLevelData', value).then(res => {
  777. res.data.forEach((item, index) => {
  778. common4[index] = item.mdnb_projects
  779. common5[index] = item.mdnb_amount_sl
  780. })
  781. setTimeout(() => {
  782. this.initChartLTip2('right')
  783. this.initChartLTip3('right')
  784. })
  785. resolve(1);
  786. })
  787. });
  788. },
  789. // 右边穿透二级
  790. rightPenetrateTwo (modelName, substraction, orgName) {
  791. this.boardType = 'right'
  792. let that = this
  793. return new Promise((resolve, err) => {
  794. let value = {
  795. access_token: this.access_token,
  796. "request": {
  797. isInsert: this.mockData ? '1' : '0',
  798. modelName: this.rightAdd.modelName,
  799. projectStepCode: this.rightAdd.projectStepCode,
  800. substraction: this.rightAdd.substraction,
  801. orgName
  802. },
  803. pageSize: 1000
  804. }
  805. post('/ierp/kapi/v2/mdnb/mdnb_xmkb/mdnb_manager_middle/getTwoLevelData', value).then(res => {
  806. that.originalConfig6 = res.data
  807. that.config6.data = []
  808. if (this.projectNum == 311) {
  809. that.config6.header = ["所属集团", "项目名称", '实施主体', '投中项目阶段', '投资总额(万元)']
  810. res.data.forEach((item, index) => {
  811. that.config6.data[index] = []
  812. that.config6.data[index][0] = item.mdnb_unitcompany
  813. that.config6.data[index][1] = item.mdnb_project_name
  814. that.config6.data[index][2] = item.mdnb_implement_org
  815. that.config6.data[index][3] = item.mdnb_projectstep_mid
  816. that.config6.data[index][4] = item.mdnb_investment_money / 10000
  817. })
  818. } else if (this.projectNum == 312 || this.projectNum == 313) {
  819. that.config6.header = ["所属集团", "项目名称", '实施主体', '容差百分比', '投资总额(万元)']
  820. res.data.forEach((item, index) => {
  821. that.config6.data[index] = []
  822. that.config6.data[index][0] = item.mdnb_unitcompany
  823. that.config6.data[index][1] = item.mdnb_project_name
  824. that.config6.data[index][2] = item.mdnb_implement_org
  825. that.config6.data[index][3] = item.mdnb_percentagetolerance
  826. that.config6.data[index][4] = item.mdnb_investment_money / 10000
  827. })
  828. } else if (this.projectNum == 314) {
  829. that.config6.header = ["所属集团", "项目名称", '实施主体', '预算额(万元)', '已签订合同额(万元)', '产值认定额(万元)', '结算额(万元)', '付款申请额(万元)', '实际付款额(万元)']
  830. res.data.forEach((item, index) => {
  831. that.config6.data[index] = []
  832. that.config6.data[index][0] = item.mdnb_unitcompany
  833. that.config6.data[index][1] = item.mdnb_project_name
  834. that.config6.data[index][2] = item.mdnb_implement_org
  835. that.config6.data[index][3] = item.mdnb_budgetamount / 10000
  836. that.config6.data[index][4] = item.mdnb_contractamount / 10000
  837. that.config6.data[index][5] = item.mdnb_outputamount / 10000
  838. that.config6.data[index][6] = item.mdnb_settlementamount / 10000
  839. that.config6.data[index][7] = item.mdnb_paymentamount / 10000
  840. that.config6.data[index][8] = item.mdnb_actualpayamount / 10000
  841. })
  842. } else if (this.projectNum == 315) {
  843. that.config6.header = ["所属集团", "项目名称", '实施主体', '高风险项', '中风险项', '低风险项', '投资总额(万元)']
  844. res.data.forEach((item, index) => {
  845. that.config6.data[index] = []
  846. that.config6.data[index][0] = item.mdnb_unitcompany
  847. that.config6.data[index][1] = item.mdnb_project_name
  848. that.config6.data[index][2] = item.mdnb_implement_org
  849. that.config6.data[index][3] = item.mdnb_heigtdanger
  850. that.config6.data[index][4] = item.mdnb_middledanger
  851. that.config6.data[index][5] = item.mdnb_lowdanger
  852. that.config6.data[index][6] = item.mdnb_investment_money / 10000
  853. })
  854. }
  855. that.config6 = { ...that.config6 }
  856. that.projectListTipShow = true
  857. resolve(1);
  858. })
  859. });
  860. },
  861. // 左边穿透一级
  862. leftPenetrateOne (mdnb_textfield11, mdnb_textfield13, mdnb_textfield16, mdnb_textfield23, typeNum, type, param, typeCTwo, paramCTwo) {
  863. this.boardType = 'left'
  864. return new Promise((resolve, err) => {
  865. let value = {
  866. access_token: this.access_token,
  867. "data": {
  868. mdnb_combofield: this.mockData ? 'B' : 'A',
  869. mdnb_textfield11,
  870. mdnb_textfield13,
  871. mdnb_textfield16,
  872. mdnb_textfield23,
  873. mdnb_datefield: this.year - 1 + '-01-01'
  874. },
  875. pageSize: 1000
  876. }
  877. post('/ierp/kapi/v2/mdnb/mdnb_xmkb/mdnb_manager_preinvest/yjct', value).then(res => {
  878. if (res.data.rows.length > 0) {
  879. if (typeNum == 2) {
  880. common4 = []
  881. common5 = []
  882. res.data.rows[0].mdnb_entryentity12.forEach((item, index) => {
  883. common4.push(item.mdnb_integerfield18)
  884. common5.push(item.mdnb_amountfield12)
  885. })
  886. setTimeout(() => {
  887. this.initChartLTip2('left', mdnb_textfield11, mdnb_textfield13, mdnb_textfield16, mdnb_textfield23, type, param, typeCTwo, paramCTwo)
  888. this.initChartLTip3('left', mdnb_textfield11, mdnb_textfield13, mdnb_textfield16, mdnb_textfield23, type, param, typeCTwo, paramCTwo)
  889. })
  890. } else if (typeNum == 1) {
  891. this.initChartLTip('left', mdnb_textfield11, mdnb_textfield13, mdnb_textfield16, mdnb_textfield23, type, param, typeCTwo, paramCTwo)
  892. }
  893. }
  894. resolve(1);
  895. })
  896. });
  897. },
  898. // 左边穿透二级
  899. leftPenetrateTwo (mdnb_textfield12, mdnb_textfield19, mdnb_textfield15, mdnb_textfield17, mdnb_textfield20, num) {
  900. num && (this.projectNum = num)
  901. this.boardType = 'left'
  902. let that = this
  903. if (that.versions) {
  904. return new Promise((resolve, err) => {
  905. let value = {
  906. access_token: this.access_token,
  907. "data": {
  908. mdnb_combofield: this.mockData ? 'B' : 'A',
  909. mdnb_datefield: this.year - 1 + '-01-01',
  910. mdnb_textfield12,
  911. mdnb_textfield19,
  912. mdnb_textfield15,
  913. mdnb_textfield17,
  914. mdnb_textfield20
  915. },
  916. pageSize: 1000
  917. }
  918. if (mdnb_textfield20) {
  919. post('/ierp/kapi/v2/mdnb/mdnb_xmkb/mdnb_manager_preinvest/ejct', value).then(res => {
  920. that.config6.data = []
  921. if (res.data.rows.length > 0) {
  922. that.originalConfig6 = res.data.rows[0].mdnb_entryentity11
  923. that.config6.data = []
  924. console.log(this.projectNum,res.data.rows,'???????????')
  925. if (this.projectNum == 211 || this.projectNum == 212) {
  926. that.config6.header = ["所属集团", "项目名称", '投资主体', '项目类型', '项目性质', '已占用额度(万元)']
  927. res.data.rows[0].mdnb_entryentity11.forEach((item, index) => {
  928. that.config6.data[index] = []
  929. that.config6.data[index][0] = item.mdnb_textfield7
  930. that.config6.data[index][1] = item.mdnb_textfield6
  931. that.config6.data[index][2] = item.mdnb_textfield8
  932. that.config6.data[index][3] = item.mdnb_textfield25
  933. that.config6.data[index][4] = item.mdnb_textfield26
  934. that.config6.data[index][5] = item.mdnb_amountfield22 / 10000
  935. })
  936. } else if (this.projectNum == 2141) {
  937. that.config6.header = ["所属集团", "项目名称", '投资主体', '项目类型', '项目性质', '本年度计划投资额(万元)']
  938. res.data.rows[0].mdnb_entryentity11.forEach((item, index) => {
  939. that.config6.data[index] = []
  940. that.config6.data[index][0] = item.mdnb_textfield7
  941. that.config6.data[index][1] = item.mdnb_textfield6
  942. that.config6.data[index][2] = item.mdnb_textfield8
  943. that.config6.data[index][3] = item.mdnb_textfield25
  944. that.config6.data[index][4] = item.mdnb_textfield26
  945. that.config6.data[index][5] = item.mdnb_amountfield22 / 10000
  946. })
  947. } else if (this.projectNum == 2142) {
  948. that.config6.header = ["所属集团", "项目名称", '投资主体', '项目类型', '项目性质', '是否主业', '本年度计划投资额(万元)']
  949. res.data.rows[0].mdnb_entryentity11.forEach((item, index) => {
  950. that.config6.data[index] = []
  951. that.config6.data[index][0] = item.mdnb_textfield7
  952. that.config6.data[index][1] = item.mdnb_textfield6
  953. that.config6.data[index][2] = item.mdnb_textfield8
  954. that.config6.data[index][3] = item.mdnb_textfield25
  955. that.config6.data[index][4] = item.mdnb_textfield26
  956. that.config6.data[index][5] = item.mdnb_textfield21
  957. that.config6.data[index][6] = item.mdnb_amountfield22 / 10000
  958. })
  959. } else if (this.projectNum == 2143) {
  960. that.config6.header = ["所属集团", "项目名称", '投资主体', '项目类型', '项目性质', '项目管理类型', '本年度计划投资额(万元)']
  961. res.data.rows[0].mdnb_entryentity11.forEach((item, index) => {
  962. that.config6.data[index] = []
  963. that.config6.data[index][0] = item.mdnb_textfield7
  964. that.config6.data[index][1] = item.mdnb_textfield6
  965. that.config6.data[index][2] = item.mdnb_textfield8
  966. that.config6.data[index][3] = item.mdnb_textfield25
  967. that.config6.data[index][4] = item.mdnb_textfield26
  968. that.config6.data[index][5] = item.mdnb_textfield22
  969. that.config6.data[index][6] = item.mdnb_amountfield22 / 10000
  970. })
  971. } else if (this.projectNum == 215) {
  972. that.config6.header = ["所属集团", "项目名称", '投资主体', '产业类别I级', '产业类别II级', '本年度计划投资额(万元)']
  973. res.data.rows[0].mdnb_entryentity11.forEach((item, index) => {
  974. that.config6.data[index] = []
  975. that.config6.data[index][0] = item.mdnb_textfield7
  976. that.config6.data[index][1] = item.mdnb_textfield6
  977. that.config6.data[index][2] = item.mdnb_textfield8
  978. that.config6.data[index][3] = item.mdnb_textfield9
  979. that.config6.data[index][4] = item.mdnb_textfield10
  980. that.config6.data[index][5] = item.mdnb_amountfield22 / 10000
  981. })
  982. } else if (this.projectNum == 216) {
  983. that.config6.header = ["所属集团", "项目名称", '投资主体', '项目类型', '项目性质', '项目阶段', '本年度计划投资额(万元)']
  984. res.data.rows[0].mdnb_entryentity11.forEach((item, index) => {
  985. that.config6.data[index] = []
  986. that.config6.data[index][0] = item.mdnb_textfield7
  987. that.config6.data[index][1] = item.mdnb_textfield6
  988. that.config6.data[index][2] = item.mdnb_textfield8
  989. that.config6.data[index][3] = item.mdnb_textfield25
  990. that.config6.data[index][4] = item.mdnb_textfield26
  991. that.config6.data[index][5] = item.mdnb_textfield24
  992. that.config6.data[index][6] = item.mdnb_amountfield22 / 10000
  993. })
  994. }
  995. }
  996. that.config6 = { ...that.config6 }
  997. that.projectListTipShow = true
  998. resolve(1);
  999. })
  1000. } else {
  1001. post('/ierp/kapi/v2/mdnb/mdnb_xmkb/mdnb_manager_preinvest/tzedfxzed', value).then(res => {
  1002. if (res.data.rows.length > 0) {
  1003. that.originalConfig6 = res.data.rows[0].mdnb_entryentity11
  1004. that.config6.data = []
  1005. if (this.projectNum == 211 || this.projectNum == 212) {
  1006. that.config6.header = ["所属集团", "项目名称", '投资主体', '项目类型', '项目性质', '已占用额度(万元)']
  1007. res.data.rows[0].mdnb_entryentity11.forEach((item, index) => {
  1008. that.config6.data[index] = []
  1009. that.config6.data[index][0] = item.mdnb_textfield7
  1010. that.config6.data[index][1] = item.mdnb_textfield6
  1011. that.config6.data[index][2] = item.mdnb_textfield8
  1012. that.config6.data[index][3] = item.mdnb_textfield25
  1013. that.config6.data[index][4] = item.mdnb_textfield26
  1014. that.config6.data[index][5] = item.mdnb_amountfield22 / 10000
  1015. })
  1016. } else if (this.projectNum == 2141) {
  1017. that.config6.header = ["所属集团", "项目名称", '投资主体', '项目类型', '项目性质', '本年度计划投资额(万元)']
  1018. res.data.rows[0].mdnb_entryentity11.forEach((item, index) => {
  1019. that.config6.data[index] = []
  1020. that.config6.data[index][0] = item.mdnb_textfield7
  1021. that.config6.data[index][1] = item.mdnb_textfield6
  1022. that.config6.data[index][2] = item.mdnb_textfield8
  1023. that.config6.data[index][3] = item.mdnb_textfield25
  1024. that.config6.data[index][4] = item.mdnb_textfield26
  1025. that.config6.data[index][5] = item.mdnb_amountfield22 / 10000
  1026. })
  1027. } else if (this.projectNum == 2142) {
  1028. that.config6.header = ["所属集团", "项目名称", '投资主体', '项目类型', '项目性质', '是否主业', '本年度计划投资额(万元)']
  1029. res.data.rows[0].mdnb_entryentity11.forEach((item, index) => {
  1030. that.config6.data[index] = []
  1031. that.config6.data[index][0] = item.mdnb_textfield7
  1032. that.config6.data[index][1] = item.mdnb_textfield6
  1033. that.config6.data[index][2] = item.mdnb_textfield8
  1034. that.config6.data[index][3] = item.mdnb_textfield25
  1035. that.config6.data[index][4] = item.mdnb_textfield26
  1036. that.config6.data[index][5] = item.mdnb_textfield21
  1037. that.config6.data[index][6] = item.mdnb_amountfield22 / 10000
  1038. })
  1039. } else if (this.projectNum == 2143) {
  1040. that.config6.header = ["所属集团", "项目名称", '投资主体', '项目类型', '项目性质', '项目管理类型', '本年度计划投资额(万元)']
  1041. res.data.rows[0].mdnb_entryentity11.forEach((item, index) => {
  1042. that.config6.data[index] = []
  1043. that.config6.data[index][0] = item.mdnb_textfield7
  1044. that.config6.data[index][1] = item.mdnb_textfield6
  1045. that.config6.data[index][2] = item.mdnb_textfield8
  1046. that.config6.data[index][3] = item.mdnb_textfield25
  1047. that.config6.data[index][4] = item.mdnb_textfield26
  1048. that.config6.data[index][5] = item.mdnb_textfield22
  1049. that.config6.data[index][6] = item.mdnb_amountfield22 / 10000
  1050. })
  1051. } else if (this.projectNum == 215) {
  1052. that.config6.header = ["所属集团", "项目名称", '投资主体', '产业类别I级', '产业类别II级', '本年度计划投资额(万元)']
  1053. res.data.rows[0].mdnb_entryentity11.forEach((item, index) => {
  1054. that.config6.data[index] = []
  1055. that.config6.data[index][0] = item.mdnb_textfield7
  1056. that.config6.data[index][1] = item.mdnb_textfield6
  1057. that.config6.data[index][2] = item.mdnb_textfield8
  1058. that.config6.data[index][3] = item.mdnb_textfield9
  1059. that.config6.data[index][4] = item.mdnb_textfield10
  1060. that.config6.data[index][5] = item.mdnb_amountfield22 / 10000
  1061. })
  1062. } else if (this.projectNum == 216) {
  1063. that.config6.header = ["所属集团", "项目名称", '投资主体', '项目类型', '项目性质', '项目阶段', '本年度计划投资额(万元)']
  1064. res.data.rows[0].mdnb_entryentity11.forEach((item, index) => {
  1065. that.config6.data[index] = []
  1066. that.config6.data[index][0] = item.mdnb_textfield7
  1067. that.config6.data[index][1] = item.mdnb_textfield6
  1068. that.config6.data[index][2] = item.mdnb_textfield8
  1069. that.config6.data[index][3] = item.mdnb_textfield25
  1070. that.config6.data[index][4] = item.mdnb_textfield26
  1071. that.config6.data[index][5] = item.mdnb_textfield24
  1072. that.config6.data[index][6] = item.mdnb_amountfield22 / 10000
  1073. })
  1074. }
  1075. that.config6 = { ...that.config6 }
  1076. that.projectListTipShow = true
  1077. }
  1078. resolve(1);
  1079. })
  1080. }
  1081. });
  1082. } else {
  1083. that.projectListTipShow = true
  1084. }
  1085. },
  1086. // 中间穿透一级 一个柱状图还是两个
  1087. centerPenetrateOne (type, param, typeNum, typeCTwo, paramCTwo, portType) {
  1088. this.boardType = 'center'
  1089. let that = this
  1090. return new Promise((resolve, err) => {
  1091. let value = {
  1092. access_token: this.access_token,
  1093. mock: this.mockData,
  1094. presetYear: this.year,
  1095. type,
  1096. param
  1097. }
  1098. get('/ierp/kapi/v2/mdnb/mdnb_xmkb/presetdata/getPenetrationLevel1', value).then(res => {
  1099. if (typeNum == 1) {
  1100. common3 = []
  1101. res.data.keyIndicators.forEach((item, index) => {
  1102. if (param == 'cyplanamount') {
  1103. common3.push(item.cyplanamount)
  1104. }
  1105. if (param == 'cyplancount') {
  1106. common3.push(item.cyplanamount)
  1107. }
  1108. if (param == 'szplanamount') {
  1109. common3.push(item.cyplanamount)
  1110. }
  1111. if (param == 'szplancount') {
  1112. common3.push(item.szplancount)
  1113. }
  1114. if (param == 'investamount') {
  1115. common3.push(item.investamount)
  1116. }
  1117. if (param == 'projectcount') {
  1118. common3.push(item.projectcount)
  1119. }
  1120. if (param == 'gdzcamount') {
  1121. common3.push(item.projectcount)
  1122. }
  1123. if (param == 'gqtzamount') {
  1124. common3.push(item.projectcount)
  1125. }
  1126. if (param == 'ceiamount') {
  1127. common3.push(item.ceiamount)
  1128. }
  1129. if (param == 'cpneiamount') {
  1130. common3.push(item.cpneiamount)
  1131. }
  1132. if (param == 'ccheiamount') {
  1133. common3.push(item.ccheiamount)
  1134. }
  1135. if (param == 'cdiamount') {
  1136. common3.push(item.cdiamount)
  1137. }
  1138. if (param == 'cciamount') {
  1139. common3.push(item.cciamount)
  1140. }
  1141. })
  1142. setTimeout(() => {
  1143. this.initChartLTip('center', '', '', '', '', typeCTwo, paramCTwo, portType)
  1144. })
  1145. } else if (typeNum == 2) {
  1146. common4 = []
  1147. common5 = []
  1148. if (type == 'distribution') {
  1149. that.changeLine = false
  1150. that.lineCommonCompany = res.data.topData.map(item => item.type)
  1151. common4 = res.data.topData.map(item => item.amount)
  1152. common5 = res.data.bottomData.map(item => item.amount)
  1153. } else {
  1154. if (param == 'new') {
  1155. res.data.keyIndicators.forEach((item, index) => {
  1156. common4.push(item.newamount)
  1157. common5.push(item.newcount)
  1158. })
  1159. } else if (param == 'renew') {
  1160. res.data.keyIndicators.forEach((item, index) => {
  1161. common4.push(item.renewamount)
  1162. common5.push(item.renewcount)
  1163. })
  1164. } else if (param == '太原市') {
  1165. res.data.investmentMap.forEach((item, index) => {
  1166. common4.push(item.value2)
  1167. common5.push(item.amount)
  1168. })
  1169. }
  1170. }
  1171. setTimeout(() => {
  1172. this.initChartLTip2('center', '', '', '', '', type, param, typeCTwo, paramCTwo, portType)
  1173. this.initChartLTip3('center', '', '', '', '', type, param, typeCTwo, paramCTwo, portType)
  1174. })
  1175. } else if (typeNum == 3) {
  1176. // 山西地图
  1177. center5 = []
  1178. res.data.investmentMap.forEach((item, index) => {
  1179. center5.push({ name: item.address, value: that.yuanChange(item.amount), value2: item.value2 })
  1180. })
  1181. setTimeout(() => {
  1182. that.initProvinceChart()
  1183. });
  1184. }
  1185. resolve(1);
  1186. })
  1187. });
  1188. },
  1189. // 中间穿透二级
  1190. centerPenetrateTwo (type, param, orgNum, portType) {
  1191. this.boardType = 'center'
  1192. let that = this
  1193. return new Promise((resolve, err) => {
  1194. let value = {
  1195. access_token: this.access_token,
  1196. mock: this.mockData,
  1197. presetYear: this.year,
  1198. type,
  1199. param,
  1200. orgNum
  1201. }
  1202. that.config6.header[2] = '投资主体'
  1203. that.config6.header[5] = '年投资完成额(亿)'
  1204. if (portType == 1) {
  1205. get('/ierp/kapi/v2/mdnb/mdnb_xmkb/presetdata/MainPageMonthReportProject', value).then(res => {
  1206. that.config6.data = []
  1207. that.originalConfig6 = res.data
  1208. if (this.projectNum == 111) {
  1209. that.config6.header = ["所属集团", "项目名称", "投资主体", "项目类型", "项目性质", "投资完成额(万元)"]
  1210. res.data.forEach((item, index) => {
  1211. that.config6.data[index] = []
  1212. that.config6.data[index][0] = item.orgName
  1213. that.config6.data[index][1] = item.projectname
  1214. that.config6.data[index][2] = item.tzzt
  1215. that.config6.data[index][3] = item.projectkind
  1216. that.config6.data[index][4] = item.projectkinddetail
  1217. that.config6.data[index][5] = item.amount / 10000
  1218. })
  1219. } else if (this.projectNum == 112) {
  1220. that.config6.header = ["所属集团", "项目名称", "投资主体", "产业类别I级", "产业类别II级", "投资完成额(万元)"]
  1221. res.data.forEach((item, index) => {
  1222. that.config6.data[index] = []
  1223. that.config6.data[index][0] = item.orgName
  1224. that.config6.data[index][1] = item.projectname
  1225. that.config6.data[index][2] = item.tzzt
  1226. that.config6.data[index][3] = item.cylb
  1227. that.config6.data[index][4] = item.cylb2
  1228. that.config6.data[index][5] = item.amount / 10000
  1229. })
  1230. } else if (this.projectNum == 1131) {
  1231. that.config6.header = ["所属集团", "项目名称", "投资主体", "项目类型", "项目性质", "本年度计划投资额(万元)"]
  1232. res.data.forEach((item, index) => {
  1233. that.config6.data[index] = []
  1234. that.config6.data[index][0] = item.orgName
  1235. that.config6.data[index][1] = item.projectname
  1236. that.config6.data[index][2] = item.tzzt
  1237. that.config6.data[index][3] = item.projectkind
  1238. that.config6.data[index][4] = item.projectkinddetail
  1239. that.config6.data[index][5] = item.amount / 10000
  1240. })
  1241. } else if (this.projectNum == 1132) {
  1242. that.config6.header = ["所属集团", "项目名称", "投资主体", "项目类型", "项目性质", "投资完成额 (万元)"]
  1243. res.data.forEach((item, index) => {
  1244. that.config6.data[index] = []
  1245. that.config6.data[index][0] = item.orgName
  1246. that.config6.data[index][1] = item.projectname
  1247. that.config6.data[index][2] = item.tzzt
  1248. that.config6.data[index][3] = item.projectkind
  1249. that.config6.data[index][4] = item.projectkinddetail
  1250. that.config6.data[index][5] = item.amount / 10000
  1251. })
  1252. } else if (this.projectNum == 114) {
  1253. that.config6.header = ["所属集团", "项目名称", "投资主体", "项目类型", "项目性质", "是否“两个转型”", "本年度计划投资额 (万元)"]
  1254. res.data.forEach((item, index) => {
  1255. that.config6.data[index] = []
  1256. that.config6.data[index][0] = item.orgName
  1257. that.config6.data[index][1] = item.projectname
  1258. that.config6.data[index][2] = item.tzzt
  1259. that.config6.data[index][3] = item.projectkind
  1260. that.config6.data[index][4] = item.projectkinddetail
  1261. that.config6.data[index][5] = item.lgz
  1262. that.config6.data[index][6] = item.amount / 10000
  1263. })
  1264. } else if (this.projectNum == 115) {
  1265. that.config6.header = ["所属集团", "项目名称", "投资主体", "项目类型", "项目性质", "是否“五个一体化”", "本年度计划投资额 (万元)"]
  1266. res.data.forEach((item, index) => {
  1267. that.config6.data[index] = []
  1268. that.config6.data[index][0] = item.orgName
  1269. that.config6.data[index][1] = item.projectname
  1270. that.config6.data[index][2] = item.tzzt
  1271. that.config6.data[index][3] = item.projectkind
  1272. that.config6.data[index][4] = item.projectkinddetail
  1273. that.config6.data[index][5] = item.wgy
  1274. that.config6.data[index][6] = item.amount / 10000
  1275. })
  1276. } else if (this.projectNum == 116) {
  1277. that.config6.header = ["所属集团", "项目名称", "投资主体", "项目类型", "项目性质", "建设阶段", "投资完成额 (万元)"]
  1278. res.data.forEach((item, index) => {
  1279. that.config6.data[index] = []
  1280. that.config6.data[index][0] = item.orgName
  1281. that.config6.data[index][1] = item.projectname
  1282. that.config6.data[index][2] = item.tzzt
  1283. that.config6.data[index][3] = item.projectkind
  1284. that.config6.data[index][4] = item.projectkinddetail
  1285. that.config6.data[index][5] = item.mdnb_quality
  1286. that.config6.data[index][6] = item.amount / 10000
  1287. })
  1288. } else if (this.projectNum == 118) {
  1289. that.config6.header = ["所属集团", "项目名称", "投资主体", "项目类型", "项目性质", "建设地点", "投资完成额 (万元)"]
  1290. res.data.forEach((item, index) => {
  1291. that.config6.data[index] = []
  1292. that.config6.data[index][0] = item.orgName
  1293. that.config6.data[index][1] = item.projectname
  1294. that.config6.data[index][2] = item.tzzt
  1295. that.config6.data[index][3] = item.projectkind
  1296. that.config6.data[index][4] = item.projectkinddetail
  1297. that.config6.data[index][5] = item.buildaddr
  1298. that.config6.data[index][6] = item.amount / 10000
  1299. })
  1300. }
  1301. that.config6 = { ...that.config6 }
  1302. that.projectListTipShow = true
  1303. resolve(1);
  1304. })
  1305. } else if (portType == 2) {
  1306. get('/ierp/kapi/v2/mdnb/mdnb_xmkb/presetdata/MainPagePlanProject', value).then(res => {
  1307. that.config6.data = []
  1308. that.originalConfig6 = res.data
  1309. if (this.projectNum == 111) {
  1310. that.config6.header = ["所属集团", "项目名称", "投资主体", "项目类型", "项目性质", "投资完成额(万元)"]
  1311. res.data.forEach((item, index) => {
  1312. that.config6.data[index] = []
  1313. that.config6.data[index][0] = item.orgName
  1314. that.config6.data[index][1] = item.projectname
  1315. that.config6.data[index][2] = item.tzzt
  1316. that.config6.data[index][3] = item.projectkind
  1317. that.config6.data[index][4] = item.projectkinddetail
  1318. that.config6.data[index][5] = item.amount / 10000
  1319. })
  1320. } else if (this.projectNum == 112) {
  1321. that.config6.header = ["所属集团", "项目名称", "投资主体", "产业类别I级", "产业类别II级", "投资完成额(万元)"]
  1322. res.data.forEach((item, index) => {
  1323. that.config6.data[index] = []
  1324. that.config6.data[index][0] = item.orgName
  1325. that.config6.data[index][1] = item.projectname
  1326. that.config6.data[index][2] = item.tzzt
  1327. that.config6.data[index][3] = item.cylb
  1328. that.config6.data[index][4] = item.cylb2
  1329. that.config6.data[index][5] = item.amount / 10000
  1330. })
  1331. } else if (this.projectNum == 1131) {
  1332. that.config6.header = ["所属集团", "项目名称", "投资主体", "项目类型", "项目性质", "本年度计划投资额(万元)"]
  1333. res.data.forEach((item, index) => {
  1334. that.config6.data[index] = []
  1335. that.config6.data[index][0] = item.orgName
  1336. that.config6.data[index][1] = item.projectname
  1337. that.config6.data[index][2] = item.tzzt
  1338. that.config6.data[index][3] = item.projectkind
  1339. that.config6.data[index][4] = item.projectkinddetail
  1340. that.config6.data[index][5] = item.amount / 10000
  1341. })
  1342. } else if (this.projectNum == 1132) {
  1343. that.config6.header = ["所属集团", "项目名称", "投资主体", "项目类型", "项目性质", "投资完成额 (万元)"]
  1344. res.data.forEach((item, index) => {
  1345. that.config6.data[index] = []
  1346. that.config6.data[index][0] = item.orgName
  1347. that.config6.data[index][1] = item.projectname
  1348. that.config6.data[index][2] = item.tzzt
  1349. that.config6.data[index][3] = item.projectkind
  1350. that.config6.data[index][4] = item.projectkinddetail
  1351. that.config6.data[index][5] = item.amount / 10000
  1352. })
  1353. } else if (this.projectNum == 114) {
  1354. that.config6.header = ["所属集团", "项目名称", "投资主体", "项目类型", "项目性质", "是否“两个转型”", "本年度计划投资额 (万元)"]
  1355. res.data.forEach((item, index) => {
  1356. that.config6.data[index] = []
  1357. that.config6.data[index][0] = item.orgName
  1358. that.config6.data[index][1] = item.projectname
  1359. that.config6.data[index][2] = item.tzzt
  1360. that.config6.data[index][3] = item.projectkind
  1361. that.config6.data[index][4] = item.projectkinddetail
  1362. that.config6.data[index][5] = item.lgz
  1363. that.config6.data[index][6] = item.amount / 10000
  1364. })
  1365. } else if (this.projectNum == 115) {
  1366. that.config6.header = ["所属集团", "项目名称", "投资主体", "项目类型", "项目性质", "是否“五个一体化”", "本年度计划投资额 (万元)"]
  1367. res.data.forEach((item, index) => {
  1368. that.config6.data[index] = []
  1369. that.config6.data[index][0] = item.orgName
  1370. that.config6.data[index][1] = item.projectname
  1371. that.config6.data[index][2] = item.tzzt
  1372. that.config6.data[index][3] = item.projectkind
  1373. that.config6.data[index][4] = item.projectkinddetail
  1374. that.config6.data[index][5] = item.wgy
  1375. that.config6.data[index][6] = item.amount / 10000
  1376. })
  1377. } else if (this.projectNum == 116) {
  1378. that.config6.header = ["所属集团", "项目名称", "投资主体", "项目类型", "项目性质", "建设阶段", "投资完成额 (万元)"]
  1379. res.data.forEach((item, index) => {
  1380. that.config6.data[index] = []
  1381. that.config6.data[index][0] = item.orgName
  1382. that.config6.data[index][1] = item.projectname
  1383. that.config6.data[index][2] = item.tzzt
  1384. that.config6.data[index][3] = item.projectkind
  1385. that.config6.data[index][4] = item.projectkinddetail
  1386. that.config6.data[index][5] = item.mdnb_quality
  1387. that.config6.data[index][6] = item.amount / 10000
  1388. })
  1389. } else if (this.projectNum == 118) {
  1390. that.config6.header = ["所属集团", "项目名称", "投资主体", "项目类型", "项目性质", "建设地点", "投资完成额 (万元)"]
  1391. res.data.forEach((item, index) => {
  1392. that.config6.data[index] = []
  1393. that.config6.data[index][0] = item.orgName
  1394. that.config6.data[index][1] = item.projectname
  1395. that.config6.data[index][2] = item.tzzt
  1396. that.config6.data[index][3] = item.projectkind
  1397. that.config6.data[index][4] = item.projectkinddetail
  1398. that.config6.data[index][5] = item.buildaddr
  1399. that.config6.data[index][6] = item.amount / 10000
  1400. })
  1401. }
  1402. that.config6 = { ...that.config6 }
  1403. that.projectListTipShow = true
  1404. resolve(1);
  1405. })
  1406. } else {
  1407. value = {
  1408. access_token: this.access_token,
  1409. mock: this.mockData,
  1410. presetYear: this.year,
  1411. type: 'investmentMap',
  1412. param: '太原市',
  1413. orgNum
  1414. }
  1415. get('/ierp/kapi/v2/mdnb/mdnb_xmkb/presetdata/MainPageMonthReportProject', value).then(res => {
  1416. that.config6.data = []
  1417. that.originalConfig6 = res.data
  1418. if (this.projectNum == 118) {
  1419. that.config6.header = ["所属集团", "项目名称", "投资主体", "项目类型", "项目性质", "建设地点", "投资完成额 (万元)"]
  1420. res.data.forEach((item, index) => {
  1421. that.config6.data[index] = []
  1422. that.config6.data[index][0] = item.orgName
  1423. that.config6.data[index][1] = item.projectname
  1424. that.config6.data[index][2] = item.tzzt
  1425. that.config6.data[index][3] = item.projectkind
  1426. that.config6.data[index][4] = item.projectkinddetail
  1427. that.config6.data[index][5] = item.buildaddr
  1428. that.config6.data[index][6] = item.amount / 10000
  1429. })
  1430. }
  1431. that.config6 = { ...that.config6 }
  1432. that.projectListTipShow = true
  1433. resolve(1);
  1434. })
  1435. }
  1436. });
  1437. },
  1438. yellowMouse (index) {
  1439. if (index % 2 == 0) {
  1440. this.yellowCount = index
  1441. this.yellowPosition = (index / 2 - 1) * 315 + 40
  1442. this.yellowType = false
  1443. this.changeYellow()
  1444. }
  1445. },
  1446. // 回到中国地图
  1447. backChina () {
  1448. this.centerShow = false
  1449. this.mapChart.dispose()
  1450. setTimeout(() => {
  1451. this.initChinaChart()
  1452. });
  1453. },
  1454. // 找公司编码
  1455. findCode (code) {
  1456. let a = this.commonCompanyAll.find((item, index) => {
  1457. return item.simplename == code
  1458. })
  1459. return a ? a.number.slice(0, 4) : ''
  1460. },
  1461. // 找项目编码
  1462. findProjectCode (a, b, type) {
  1463. console.log(a, b, type, this.originalConfig6)
  1464. if (type == 'center') {
  1465. let c = this.originalConfig6.find(item => {
  1466. return item.orgName == a && item.projectname == b
  1467. })
  1468. return c.projectno
  1469. } else if (type == 'right') {
  1470. let c = this.originalConfig6.find(item => {
  1471. return item.mdnb_unitcompany == a && item.mdnb_project_name == b
  1472. })
  1473. return c.mdnb_projectnumber
  1474. } else if (type == 'left') {
  1475. let c = this.originalConfig6.find(item => {
  1476. return item.mdnb_textfield7 == a && item.mdnb_textfield6 == b
  1477. })
  1478. return c.mdnb_textfield14
  1479. } else if (type == 'center2') {
  1480. let c = this.centerOriginalConfig6.find(item => {
  1481. return item.orgName == a && item.projectname == b
  1482. })
  1483. return c.projectno
  1484. }
  1485. },
  1486. // 去项目看板
  1487. goLookBoard (e, f) {
  1488. console.log(e, f, '看看E')
  1489. if (f) {
  1490. this.boardType = f
  1491. this.boardUrl = `http://172.21.3.68:8081/ierp/accessTokenLogin.do?access_token=${this.access_token}&redirect=http://172.21.3.68:8081/ierp/index.html?formId=mdnb_threetoproject&prj=${this.findProjectCode(e.row[0], e.row[1], this.boardType)}`
  1492. } else {
  1493. this.boardUrl = `http://172.21.3.68:8081/ierp/accessTokenLogin.do?access_token=${this.access_token}&redirect=http://172.21.3.68:8081/ierp/index.html?formId=mdnb_threetoproject&prj=${this.findProjectCode(e.row[0], e.row[1], f)}`
  1494. }
  1495. // this.findProjectCode(e.row[0],e.row[2])
  1496. // 当前页面打开
  1497. // window.location.href = `http://192.168.2.111:8080/ierp/accessTokenLogin.do?access_token=${this.access_token}&redirect=http://192.168.2.111:8080/ierp/index.html?formId=mdnb_threetoproject&prj=PL_ZZGY_0_2023_000036`
  1498. // 新页面打开
  1499. // window.open('http://192.168.2.111:8080/ierp/accessTokenLogin.do?access_token=${this.access_token}&redirect=http://192.168.2.111:8080/ierp/index.html?formId=mdnb_threetoproject&prj=PL_ZZGY_0_2023_000036')
  1500. this.boardTipShow = true
  1501. console.log(this.boardUrl, '跳转去的项目看板地址')
  1502. },
  1503. // 根据key分组
  1504. classify (arr, k) {
  1505. let map = {};
  1506. let myArr = [];
  1507. for (let i = 0; i < arr.length; i++) {
  1508. if (!map[arr[i][k]]) {
  1509. let a = {}
  1510. a[k] = arr[i][k]
  1511. a.data = [arr[i]]
  1512. myArr.push(a)
  1513. map[arr[i][k]] = arr[i]
  1514. } else {
  1515. for (let j = 0; j < myArr.length; j++) {
  1516. if (arr[i][k] === myArr[j][k]) {
  1517. myArr[j].data.push(arr[i]);
  1518. break
  1519. }
  1520. }
  1521. }
  1522. }
  1523. return myArr
  1524. },
  1525. // 两个柱状图的弹窗
  1526. showChartLTipDouble (e, location, mdnb_textfield11, mdnb_textfield13, mdnb_textfield16, mdnb_textfield23, type, param, typeCTwo, paramCTwo, portType, num, modelName, projectStepCode, substraction) {
  1527. modelName ? this.rightAdd.modelName = modelName : this.rightAdd.modelName = ''
  1528. projectStepCode ? this.rightAdd.projectStepCode = projectStepCode : this.rightAdd.projectStepCode = ''
  1529. substraction ? this.rightAdd.substraction = substraction : this.rightAdd.substraction = ''
  1530. num && (this.projectNum = num)
  1531. this.titleName = e
  1532. this.closeTap()
  1533. this.echartDoubleTipShow = true
  1534. if (this.versions) {
  1535. if (location == 'right') {
  1536. this.rightPenetrateOne()
  1537. }
  1538. if (location == 'left') {
  1539. this.leftPenetrateOne(mdnb_textfield11, mdnb_textfield13, mdnb_textfield16, mdnb_textfield23, 2)
  1540. }
  1541. if (location == 'center') {
  1542. this.centerPenetrateOne(type, param, 2, typeCTwo, paramCTwo, portType)
  1543. }
  1544. } else {
  1545. setTimeout(() => {
  1546. this.initChartLTip2()
  1547. this.initChartLTip3()
  1548. })
  1549. }
  1550. },
  1551. // 单个柱状图的弹窗
  1552. showChartLTipSingle (e, location, type, param, mdnb_textfield11, mdnb_textfield13, mdnb_textfield16, mdnb_textfield23, typeCTwo, paramCTwo, portType, num) {
  1553. this.projectNum = num
  1554. this.closeTap()
  1555. this.titleName = e
  1556. this.echartSingleTipShow = true
  1557. if (this.versions) {
  1558. if (location == 'center') {
  1559. this.centerPenetrateOne(type, param, 1, typeCTwo, paramCTwo, portType)
  1560. }
  1561. if (location == 'left') {
  1562. this.leftPenetrateOne(mdnb_textfield11, mdnb_textfield13, mdnb_textfield16, mdnb_textfield23, 1, type, param)
  1563. }
  1564. } else {
  1565. setTimeout(() => {
  1566. this.initChartLTip(location)
  1567. })
  1568. }
  1569. },
  1570. initChartLTip (location, mdnb_textfield11, mdnb_textfield13, mdnb_textfield16, mdnb_textfield23, typeCTwo, paramCTwo, portType) {
  1571. this.myChartTip1 = echarts.init(document.getElementById("echartSingleTip"));
  1572. let option = {
  1573. grid: {
  1574. top: 40,
  1575. right: 0,
  1576. left: 60,
  1577. bottom: 70,
  1578. },
  1579. tooltip: {
  1580. show: true,
  1581. trigger: "axis",
  1582. axisPointer: {
  1583. // 坐标轴指示器,坐标轴触发有效
  1584. type: "shadow", // 默认为直线,可选为:'line' | 'shadow'
  1585. },
  1586. textStyle: {
  1587. color: '#FFF', // 文字的颜色
  1588. fontSize: '20', // 文字字体大小
  1589. fontFamily: 'Microsoft YaHei'
  1590. },
  1591. },
  1592. xAxis: {
  1593. data: commonCompany,
  1594. axisTick: {
  1595. show: false,
  1596. },
  1597. // x轴的字体颜色
  1598. axisLabel: {
  1599. rotate: 40,
  1600. textStyle: {
  1601. color: "white",
  1602. fontSize: '20',
  1603. fontFamily: 'Microsoft YaHei'
  1604. },
  1605. },
  1606. //y轴线的颜色以及宽度
  1607. axisLine: {
  1608. show: true,
  1609. lineStyle: {
  1610. color: "#1E5389",
  1611. width: 1,
  1612. type: "solid",
  1613. },
  1614. },
  1615. },
  1616. yAxis: {
  1617. name: '亿',
  1618. nameTextStyle: {//y轴上方单位的颜色
  1619. color: '#fff',
  1620. fontSize: '20',
  1621. fontFamily: 'Microsoft YaHei'
  1622. },
  1623. axisTick: {
  1624. lineStyle: {
  1625. color: "#18416F",
  1626. },
  1627. },
  1628. // y轴的字体颜色
  1629. axisLabel: {
  1630. textStyle: {
  1631. color: "white",
  1632. fontSize: '20'
  1633. },
  1634. },
  1635. splitLine: {
  1636. show: true,
  1637. lineStyle: {
  1638. color: '#68b4dd66',
  1639. type: 'dashed',
  1640. },
  1641. },
  1642. //y轴线的颜色以及宽度
  1643. axisLine: {
  1644. show: true,
  1645. lineStyle: {
  1646. color: "#1E5389",
  1647. width: 1,
  1648. type: "solid",
  1649. },
  1650. },
  1651. },
  1652. series: [
  1653. // {
  1654. // name: "2022年额度",
  1655. // type: "bar",
  1656. // data: [263.23, 402.18, 73.28, 144.80, 25.56, 8.23, 0, 12.97, 8.56, -1.72, 0, 0, 0, 76.90, 5.03, 9.14, 0, 0],
  1657. // showBackground: false,
  1658. // backgroundStyle: {
  1659. // color: "#18416F",
  1660. // },
  1661. // barWidth: "10%",
  1662. // itemStyle: {
  1663. // barBorderRadius: [10, 10, 0, 0],
  1664. // color: new echarts.graphic.LinearGradient(0, 1, 0, 0, [
  1665. // {
  1666. // offset: 0,
  1667. // color: '#082550',
  1668. // },
  1669. // {
  1670. // offset: 1,
  1671. // color: '#69c0ff',
  1672. // },
  1673. // ]),
  1674. // },
  1675. // },
  1676. {
  1677. name: "总额度",
  1678. type: "bar",
  1679. data: common3,
  1680. showBackground: false,
  1681. backgroundStyle: {
  1682. color: "#18416F",
  1683. },
  1684. barWidth: "30%",
  1685. itemStyle: {
  1686. // barBorderRadius: [10, 10, 0, 0],
  1687. color: new echarts.graphic.LinearGradient(0, 1, 0, 0, [
  1688. {
  1689. offset: 0,
  1690. color: '#082550',
  1691. },
  1692. {
  1693. offset: 1,
  1694. color: '#957DFF',
  1695. },
  1696. ]),
  1697. },
  1698. },
  1699. ],
  1700. legend: {
  1701. // data: ["2022年额度", "2023年额度"],
  1702. data: ["总额度"],
  1703. textStyle: {
  1704. // 图列内容样式
  1705. color: "#fff", // 字体颜色
  1706. fontSize: "20",
  1707. fontFamily: 'Microsoft YaHei'
  1708. },
  1709. right: 'center',
  1710. y: 5,
  1711. // 小图标的宽高
  1712. },
  1713. };
  1714. tools.loopShowTooltip(this.myChartTip1, option, {
  1715. nterval: 2000,
  1716. loopSeries: true,
  1717. })
  1718. let that = this
  1719. that.myChartTip1.on('click', function (param) {
  1720. if (that.versions) {
  1721. if (location == 'right') {
  1722. that.rightPenetrateTwo(that.rightPenetrateTwo.modelName, '', that.findCode(param.name))
  1723. } else if (location == 'left') {
  1724. that.leftPenetrateTwo(mdnb_textfield11, mdnb_textfield13, mdnb_textfield16, mdnb_textfield23, param.name, that.projectNum)
  1725. } else if (location == 'center') {
  1726. that.centerPenetrateTwo(typeCTwo, paramCTwo, that.findCode(param.name), portType)
  1727. }
  1728. } else {
  1729. that.projectListTipShow = true
  1730. }
  1731. })
  1732. that.myChartTip1.setOption(option);
  1733. },
  1734. initChartLTip2 (location, mdnb_textfield11, mdnb_textfield13, mdnb_textfield16, mdnb_textfield23, type, param, typeCTwo, paramCTwo, portType) {
  1735. this.myChartTip2 = echarts.init(document.getElementById("echartSingleTip2"));
  1736. let option = {
  1737. grid: {
  1738. top: 40,
  1739. right: 0,
  1740. left: 60,
  1741. bottom: '15%',
  1742. },
  1743. tooltip: {
  1744. show: true,
  1745. trigger: "axis",
  1746. axisPointer: {
  1747. // 坐标轴指示器,坐标轴触发有效
  1748. type: "shadow", // 默认为直线,可选为:'line' | 'shadow'
  1749. },
  1750. textStyle: {
  1751. color: '#FFF', // 文字的颜色
  1752. fontSize: '20', // 文字字体大小
  1753. fontFamily: 'Microsoft YaHei'
  1754. },
  1755. },
  1756. xAxis: {
  1757. data: this.changeLine ? commonCompany : this.lineCommonCompany,
  1758. axisTick: {
  1759. show: false,
  1760. },
  1761. // x轴的字体颜色
  1762. axisLabel: {
  1763. rotate: 40,
  1764. textStyle: {
  1765. color: "white",
  1766. fontSize: '20',
  1767. fontFamily: 'Microsoft YaHei'
  1768. },
  1769. },
  1770. //y轴线的颜色以及宽度
  1771. axisLine: {
  1772. show: true,
  1773. lineStyle: {
  1774. color: "#1E5389",
  1775. width: 1,
  1776. type: "solid",
  1777. },
  1778. },
  1779. },
  1780. yAxis: {
  1781. name: '个',
  1782. nameTextStyle: {//y轴上方单位的颜色
  1783. color: '#fff',
  1784. fontSize: '20',
  1785. fontFamily: 'Microsoft YaHei'
  1786. },
  1787. axisTick: {
  1788. lineStyle: {
  1789. color: "#18416F",
  1790. },
  1791. },
  1792. // y轴的字体颜色
  1793. axisLabel: {
  1794. textStyle: {
  1795. color: "#fff",
  1796. fontSize: '20',
  1797. fontFamily: 'Microsoft YaHei'
  1798. },
  1799. },
  1800. splitLine: {
  1801. show: true,
  1802. lineStyle: {
  1803. color: '#68b4dd66',
  1804. type: 'dashed',
  1805. },
  1806. },
  1807. //y轴线的颜色以及宽度
  1808. axisLine: {
  1809. show: true,
  1810. lineStyle: {
  1811. color: "#1E5389",
  1812. width: 1,
  1813. type: "solid",
  1814. },
  1815. },
  1816. },
  1817. series: [
  1818. {
  1819. name: "总数量",
  1820. type: this.changeLine ? "bar" : 'line',
  1821. data: common4,
  1822. showBackground: false,
  1823. backgroundStyle: {
  1824. color: "#18416F",
  1825. },
  1826. barWidth: "30%",
  1827. itemStyle: {
  1828. // barBorderRadius: [10, 10, 0, 0],
  1829. color: new echarts.graphic.LinearGradient(0, 1, 0, 0, [
  1830. {
  1831. offset: 0,
  1832. color: '#082550',
  1833. },
  1834. {
  1835. offset: 1,
  1836. color: '#957DFF',
  1837. },
  1838. ]),
  1839. },
  1840. },
  1841. ],
  1842. legend: {
  1843. // data: ["2022年额度", "2023年额度"],
  1844. data: ["总数量"],
  1845. textStyle: {
  1846. // 图列内容样式
  1847. color: "#fff", // 字体颜色
  1848. fontSize: "20",
  1849. fontFamily: 'Microsoft YaHei'
  1850. },
  1851. right: 'center',
  1852. y: 0,
  1853. // 小图标的宽高
  1854. },
  1855. };
  1856. tools.loopShowTooltip(this.myChartTip2, option, {
  1857. nterval: 2000,
  1858. loopSeries: true,
  1859. })
  1860. let that = this
  1861. that.myChartTip2.on('click', function (param) {
  1862. if (that.versions) {
  1863. if (location == 'right') {
  1864. that.rightPenetrateTwo(that.rightPenetrateTwo.modelName, '', that.findCode(param.name))
  1865. } else if (location == 'left') {
  1866. that.leftPenetrateTwo(mdnb_textfield11, mdnb_textfield13, mdnb_textfield16, mdnb_textfield23, param.name, that.projectNum)
  1867. } else if (location == 'center') {
  1868. that.centerPenetrateTwo(typeCTwo, paramCTwo, that.findCode(param.name), portType)
  1869. }
  1870. } else {
  1871. that.projectListTipShow = true
  1872. }
  1873. })
  1874. that.myChartTip2.setOption(option);
  1875. },
  1876. initChartLTip3 (location, mdnb_textfield11, mdnb_textfield13, mdnb_textfield16, mdnb_textfield23, type, param, typeCTwo, paramCTwo, portType) {
  1877. this.myChartTip3 = echarts.init(document.getElementById("echartSingleTip3"));
  1878. let option = {
  1879. grid: {
  1880. top: 40,
  1881. right: 0,
  1882. left: 60,
  1883. bottom: '15%',
  1884. },
  1885. tooltip: {
  1886. show: true,
  1887. trigger: "axis",
  1888. axisPointer: {
  1889. // 坐标轴指示器,坐标轴触发有效
  1890. type: "shadow", // 默认为直线,可选为:'line' | 'shadow'
  1891. },
  1892. textStyle: {
  1893. color: '#FFF', // 文字的颜色
  1894. fontSize: '20', // 文字字体大小
  1895. fontFamily: 'Microsoft YaHei'
  1896. },
  1897. },
  1898. xAxis: {
  1899. data: commonCompany,
  1900. axisTick: {
  1901. show: false,
  1902. },
  1903. // x轴的字体颜色
  1904. axisLabel: {
  1905. rotate: 40,
  1906. textStyle: {
  1907. color: "#fff",
  1908. fontSize: '20',
  1909. fontFamily: 'Microsoft YaHei'
  1910. },
  1911. },
  1912. //y轴线的颜色以及宽度
  1913. axisLine: {
  1914. show: true,
  1915. lineStyle: {
  1916. color: "#1E5389",
  1917. width: 1,
  1918. type: "solid",
  1919. },
  1920. },
  1921. },
  1922. yAxis: {
  1923. name: '亿',
  1924. nameTextStyle: {//y轴上方单位的颜色
  1925. color: '#fff',
  1926. fontSize: '20',
  1927. fontFamily: 'Microsoft YaHei'
  1928. },
  1929. axisTick: {
  1930. lineStyle: {
  1931. color: "#18416F",
  1932. },
  1933. },
  1934. // y轴的字体颜色
  1935. axisLabel: {
  1936. textStyle: {
  1937. color: "#fff",
  1938. fontSize: '20',
  1939. fontFamily: 'Microsoft YaHei'
  1940. },
  1941. },
  1942. splitLine: {
  1943. show: true,
  1944. lineStyle: {
  1945. color: '#68b4dd66',
  1946. type: 'dashed',
  1947. },
  1948. },
  1949. //y轴线的颜色以及宽度
  1950. axisLine: {
  1951. show: true,
  1952. lineStyle: {
  1953. color: "#1E5389",
  1954. width: 1,
  1955. type: "solid",
  1956. },
  1957. },
  1958. },
  1959. series: [,
  1960. {
  1961. name: "总额度",
  1962. type: "bar",
  1963. data: common5,
  1964. showBackground: false,
  1965. backgroundStyle: {
  1966. color: "#18416F",
  1967. },
  1968. barWidth: "30%",
  1969. itemStyle: {
  1970. // barBorderRadius: [10, 10, 0, 0],
  1971. color: new echarts.graphic.LinearGradient(0, 1, 0, 0, [
  1972. {
  1973. offset: 0,
  1974. color: '#082550',
  1975. },
  1976. {
  1977. offset: 1,
  1978. color: '#69c0ff',
  1979. },
  1980. ]),
  1981. },
  1982. },
  1983. ],
  1984. legend: {
  1985. data: ["总额度"],
  1986. textStyle: {
  1987. // 图列内容样式
  1988. color: "#fff", // 字体颜色
  1989. fontSize: "20",
  1990. fontFamily: 'Microsoft YaHei'
  1991. },
  1992. right: 'center',
  1993. y: 5,
  1994. },
  1995. };
  1996. tools.loopShowTooltip(this.myChartTip3, option, {
  1997. nterval: 2000,
  1998. loopSeries: true,
  1999. })
  2000. let that = this
  2001. that.myChartTip3.on('click', function (param) {
  2002. if (that.versions) {
  2003. if (location == 'right') {
  2004. that.rightPenetrateTwo(that.rightPenetrateTwo.modelName, '', that.findCode(param.name))
  2005. } else if (location == 'left') {
  2006. that.leftPenetrateTwo(mdnb_textfield11, mdnb_textfield13, mdnb_textfield16, mdnb_textfield23, param.name, that.projectNum)
  2007. } else if (location == 'center') {
  2008. that.centerPenetrateTwo(typeCTwo, paramCTwo, that.findCode(param.name), portType)
  2009. }
  2010. } else {
  2011. that.projectListTipShow = true
  2012. }
  2013. })
  2014. that.myChartTip3.setOption(option);
  2015. },
  2016. closeTap () {
  2017. this.changeLine = true
  2018. this.echartEnterpriseShow = false
  2019. this.mapTipShow = false
  2020. this.echartSingleTipShow = false
  2021. this.echartDoubleTipShow = false
  2022. this.projectListTipShow = false
  2023. this.myChartTip1 ? this.myChartTip1.dispose() : ''
  2024. this.myChartTip2 ? this.myChartTip2.dispose() : ''
  2025. this.myChartTip3 ? this.myChartTip3.dispose() : ''
  2026. },
  2027. //点击弹窗左半部分
  2028. popLeftClick () {
  2029. if (this.titleUrl == '2.png') {
  2030. this.titleUrl = '3.png'
  2031. } else if (this.titleUrl == '7.png') {
  2032. this.titleUrl = '8.png'
  2033. } else if (this.titleUrl == '3.png') {
  2034. this.titleUrl = '2.png'
  2035. } else if (this.titleUrl == '8.png') {
  2036. this.titleUrl = '7.png'
  2037. } else if (this.titleUrl == '5.png') {
  2038. this.titleUrl = '2.png'
  2039. } else if (this.titleUrl == '10.png') {
  2040. this.titleUrl = '7.png'
  2041. }
  2042. },
  2043. //点击弹窗右半部分
  2044. poprightClick () {
  2045. if (this.titleUrl == '2.png') {
  2046. this.titleUrl = '5.png'
  2047. } else if (this.titleUrl == '7.png') {
  2048. this.titleUrl = '10.png'
  2049. } else if (this.titleUrl == '5.png') {
  2050. this.titleUrl = '2.png'
  2051. } else if (this.titleUrl == '10.png') {
  2052. this.titleUrl = '7.png'
  2053. } else if (this.titleUrl == '3.png') {
  2054. this.titleUrl = '2.png'
  2055. } else if (this.titleUrl == '8.png') {
  2056. this.titleUrl = '7.png'
  2057. }
  2058. },
  2059. // 标题弹窗
  2060. showTitlePop (e, name) {
  2061. this.closeTap()
  2062. this.titleUrl = e
  2063. this.titleName = name
  2064. this.$nextTick(() => {
  2065. this.mapTipShow = true
  2066. })
  2067. },
  2068. changeYellow () {
  2069. this.titleList.forEach((item, index) => {
  2070. this.$set(this.titleList[index], 'type', 1)
  2071. })
  2072. this.$set(this.titleList[this.yellowCount], 'type', 2)
  2073. if (this.yellowCount == 14) {
  2074. this.yellowCount = 0
  2075. this.yellowPosition += 315
  2076. } else {
  2077. if (this.yellowCount != 0) {
  2078. this.yellowPosition += 315
  2079. } else {
  2080. this.yellowPosition = 40
  2081. }
  2082. this.yellowCount += 2
  2083. }
  2084. },
  2085. numFormat (value) {
  2086. if (!value) return '0'
  2087. // var intPart = Number(value).toFixed(0) // 获取整数部分
  2088. var intPart = parseInt(value)// 获取整数部分
  2089. var intPartFormat = intPart.toString().replace(/(\d)(?=(?:\d{3})+$)/g, '$1,') // 将整数部分逢三一断
  2090. var floatPart = '.00' // 预定义小数部分
  2091. var value2Array = value.toString().split('.')
  2092. // =2表示数据有小数位
  2093. if (value2Array.length === 2) {
  2094. floatPart = value2Array[1].toString() // 拿到小数部分
  2095. if (floatPart.length === 1) {
  2096. // 补0
  2097. return intPartFormat + '.' + floatPart + '0'
  2098. } else {
  2099. return intPartFormat + '.' + floatPart
  2100. }
  2101. } else {
  2102. return intPartFormat
  2103. }
  2104. },
  2105. changeTopColor () {
  2106. this.list = document.getElementsByClassName('row-item')
  2107. for (var i = 0; i < this.list.length; i++) {
  2108. if (i == 1) {
  2109. this.list[i].classList.add('light')
  2110. } else {
  2111. this.list[i].classList.remove('light')
  2112. }
  2113. }
  2114. this.initChartL9()
  2115. },
  2116. scrollChange (index) {
  2117. if (index == 18) {
  2118. this.count = -1
  2119. } else {
  2120. this.count = index
  2121. }
  2122. if (this.count > 12 && this.count != 18) {
  2123. this.countType = 1
  2124. } else {
  2125. this.countType = 0
  2126. }
  2127. for (var i = 0; i < this.list.length; i++) {
  2128. if (i == 2) {
  2129. this.list[i].classList.add('light')
  2130. } else {
  2131. this.list[i].classList.remove('light')
  2132. }
  2133. }
  2134. this.chartCarousel.dispose()
  2135. this.initChartL9()
  2136. },
  2137. initChartBall () {
  2138. this.left11Chart = echarts.init(this.$refs['echartBall'])
  2139. option = {
  2140. series: [
  2141. {
  2142. type: "liquidFill",
  2143. radius: "80%",
  2144. data: [left2[0], left2[0] + 0.02, left2[0] - 0.02],
  2145. amplitude: '4%',
  2146. waveLength: '20%', //波浪长度
  2147. // data: [
  2148. // {}
  2149. // ],
  2150. backgroundStyle: {
  2151. color: {
  2152. type: "radial",
  2153. x: 0.5,
  2154. y: 0.5,
  2155. r: 0.5,
  2156. // 水球体颜色
  2157. colorStops: [
  2158. {
  2159. offset: 0,
  2160. color: "#010a11",
  2161. },
  2162. {
  2163. offset: 0.9,
  2164. color: "#1a2f45",
  2165. },
  2166. {
  2167. offset: 1,
  2168. color: "#2b405a",
  2169. },
  2170. ],
  2171. globalCoord: false,
  2172. },
  2173. },
  2174. outline: {
  2175. borderDistance: 0,
  2176. itemStyle: {
  2177. borderWidth: 0,
  2178. borderColor: {
  2179. type: "linear",
  2180. x: 0,
  2181. y: 0,
  2182. x2: 0,
  2183. y2: 1,
  2184. colorStops: [
  2185. ],
  2186. globalCoord: false,
  2187. },
  2188. },
  2189. },
  2190. color: [
  2191. {
  2192. x: 0,
  2193. y: 0,
  2194. x2: 0,
  2195. y2: 1,
  2196. colorStops: [{
  2197. offset: 0,
  2198. color: '#237386',
  2199. },
  2200. {
  2201. offset: 1,
  2202. color: '#0078C8',
  2203. },],
  2204. },
  2205. {
  2206. x: 0,
  2207. y: 0,
  2208. x2: 0,
  2209. y2: 1,
  2210. colorStops: [{
  2211. offset: 0,
  2212. color: '#2F97A9',
  2213. },
  2214. {
  2215. offset: 1,
  2216. color: '#0078C8',
  2217. },],
  2218. },
  2219. {
  2220. x: 0,
  2221. y: 0,
  2222. x2: 0,
  2223. y2: 1,
  2224. colorStops: [{
  2225. offset: 0,
  2226. color: '#48E0ED',
  2227. },
  2228. {
  2229. offset: 1,
  2230. color: '#0078C8',
  2231. },],
  2232. }
  2233. ],
  2234. label: {
  2235. normal: {
  2236. textStyle: {
  2237. color: "#fff", // x轴文字颜色
  2238. fontSize: '70'
  2239. },
  2240. },
  2241. },
  2242. },
  2243. ],
  2244. };
  2245. this.left11Chart.setOption(option)
  2246. },
  2247. initChartL1 () {
  2248. this.left9Chart = echarts.init(this.$refs['echartL1'])
  2249. option = {
  2250. series: [
  2251. {
  2252. type: "liquidFill",
  2253. radius: "80%",
  2254. data: [left2[0], left2[0] + 0.02, left2[0] - 0.02],
  2255. amplitude: '4%',
  2256. // period:'1500',
  2257. waveLength: '20%', //波浪长度
  2258. // data: [
  2259. // {}
  2260. // ],
  2261. backgroundStyle: {
  2262. color: {
  2263. type: "radial",
  2264. x: 0.5,
  2265. y: 0.5,
  2266. r: 0.5,
  2267. // 水球体颜色
  2268. colorStops: [
  2269. {
  2270. offset: 0,
  2271. color: "#010a11",
  2272. },
  2273. {
  2274. offset: 0.9,
  2275. // color: "#203852",
  2276. color: "#1a2f45",
  2277. },
  2278. {
  2279. offset: 1,
  2280. // color: "#354e6d",
  2281. color: "#2b405a",
  2282. // color: "#314967",
  2283. },
  2284. ],
  2285. globalCoord: false,
  2286. },
  2287. },
  2288. outline: {
  2289. borderDistance: 0,
  2290. itemStyle: {
  2291. borderWidth: 0,
  2292. borderColor: {
  2293. type: "linear",
  2294. x: 0,
  2295. y: 0,
  2296. x2: 0,
  2297. y2: 1,
  2298. colorStops: [
  2299. ],
  2300. globalCoord: false,
  2301. },
  2302. },
  2303. },
  2304. color: [
  2305. {
  2306. x: 0,
  2307. y: 0,
  2308. x2: 0,
  2309. y2: 1,
  2310. colorStops: [{
  2311. offset: 0,
  2312. color: '#237386',
  2313. },
  2314. {
  2315. offset: 1,
  2316. color: '#0078C8',
  2317. },],
  2318. },
  2319. {
  2320. x: 0,
  2321. y: 0,
  2322. x2: 0,
  2323. y2: 1,
  2324. colorStops: [{
  2325. offset: 0,
  2326. color: '#2F97A9',
  2327. },
  2328. {
  2329. offset: 1,
  2330. color: '#0078C8',
  2331. },],
  2332. },
  2333. {
  2334. x: 0,
  2335. y: 0,
  2336. x2: 0,
  2337. y2: 1,
  2338. colorStops: [{
  2339. offset: 0,
  2340. color: '#48E0ED',
  2341. },
  2342. {
  2343. offset: 1,
  2344. color: '#0078C8',
  2345. },],
  2346. }
  2347. ],
  2348. label: {
  2349. normal: {
  2350. textStyle: {
  2351. color: "#fff", // x轴文字颜色
  2352. },
  2353. },
  2354. },
  2355. },
  2356. ],
  2357. };
  2358. this.left9Chart.setOption(option)
  2359. },
  2360. initChartL2 () {
  2361. var chartData = left5
  2362. var i = 0;
  2363. let that = this
  2364. var option = {
  2365. colors: ['#064F78', '#BDB35D', '#623726', '#955773', '#B57C63', '#73A88E', '#09736D', '#13400B', '#0D3265'],
  2366. chart: {
  2367. type: 'pie',
  2368. backgroundColor: 'rgba(0,0,0,0)',
  2369. options3d: {
  2370. enabled: true,
  2371. alpha: 45,
  2372. //beta: 0
  2373. },
  2374. events: {
  2375. // load,图表加载完成时触发
  2376. load: function () {
  2377. var chart = this;
  2378. var points = chart.series[0].points;
  2379. var len = points.length;
  2380. that.pieTime1 && clearInterval(that.pieTime1);
  2381. that.pieTime1 = setInterval(function () {
  2382. autoTooltip(points[i]);
  2383. chartData.forEach((item, index) => {
  2384. item.sliced = false
  2385. item.selected = false
  2386. if (index == i) {
  2387. // item.sliced = true
  2388. // item.selected = true
  2389. }
  2390. })
  2391. that.left1Chart.update({
  2392. series: [{
  2393. type: 'pie',
  2394. name: '占比',
  2395. point: {
  2396. events: {
  2397. click: function (e) {
  2398. that.projectNum = 2142
  2399. that.showChartLTipDouble(e.point.name, 'left', '投资计划分析', e.point.name, '', '')
  2400. }
  2401. }
  2402. },
  2403. data: chartData
  2404. }]
  2405. })
  2406. i++;
  2407. if (i === len) {
  2408. i = 0;
  2409. chartData.forEach((item, index) => {
  2410. // item.sliced = false
  2411. // item.selected = false
  2412. })
  2413. that.left1Chart.update({
  2414. series: [{
  2415. type: 'pie',
  2416. name: '占比',
  2417. point: {
  2418. events: {
  2419. click: function (e) {
  2420. that.projectNum = 2142
  2421. that.showChartLTipDouble(e.point.name, 'left', '投资计划分析', e.point.name, '', '')
  2422. }
  2423. }
  2424. },
  2425. data: chartData
  2426. }]
  2427. })
  2428. }
  2429. }, 2000);
  2430. },
  2431. legendItemClick: function (event) {
  2432. return true;
  2433. }
  2434. }
  2435. },
  2436. credits: {
  2437. enabled: false //去掉hightchats水印
  2438. },
  2439. legend: {
  2440. // labelFormatter: function() {
  2441. // return 123;
  2442. // },
  2443. align: 'right',//横向位置
  2444. verticalAlign: 'middle', // 纵向位置
  2445. layout: "vertical",//横排还是竖排
  2446. x: -110,
  2447. y: 90,
  2448. symbolWidth: 50,
  2449. itemStyle: {
  2450. fontSize: '20px',
  2451. color: '#fff',
  2452. x: 20,
  2453. fontWeight: 0,
  2454. fontFamily: 'Microsoft YaHei'
  2455. },
  2456. },
  2457. title: {
  2458. text: '主辅业计划占比',
  2459. style: {
  2460. color: '#fff',
  2461. fontSize: 24,
  2462. fontFamily: 'Microsoft YaHei',
  2463. },
  2464. align: 'center',
  2465. verticalAlign: "bottom",
  2466. x: -120
  2467. },
  2468. tooltip: {
  2469. crosshairs: false,
  2470. backgroundColor: 'rgba(0,0,0,0.5)',
  2471. // positioner: function(e){
  2472. // console.log(e, this)
  2473. // },
  2474. // useHTML: false, //开启html模式
  2475. style: {
  2476. color: '#fff',
  2477. fontSize: '20',
  2478. fontWeight: 0,
  2479. fontFamily: 'Microsoft YaHei'
  2480. },
  2481. formatter: function (e) {
  2482. let num = chartData[this.colorIndex].num
  2483. this.percentage = this.percentage.toFixed(2) //Math.round(this.percentage)
  2484. return `${this.key}:<b>${this.percentage}%</b><br/><b>${this.y}</b>亿,<b>${num}个</b>`
  2485. },
  2486. //pointFormat:
  2487. },
  2488. plotOptions: {
  2489. pie: {
  2490. allowPointSelect: true,
  2491. showInLegend: true, // 图例
  2492. cursor: 'pointer',
  2493. size: 220,
  2494. innerSize: 150, //环形图中间空白,0为饼图
  2495. depth: 25, //立体高度
  2496. slicedOffset: 21, //动画距离
  2497. dataLabels: {
  2498. enabled: false, // 是否展示指示线
  2499. format: '{point.name}: {point.percentage}'
  2500. }
  2501. },
  2502. },
  2503. series: [{
  2504. type: 'pie',
  2505. name: '占比',
  2506. center: ['50%', '50%'],
  2507. point: {
  2508. events: {
  2509. click: function (e) { //点击事件
  2510. that.projectNum = 2142
  2511. that.showChartLTipDouble(e.point.name, 'left', '投资计划分析', e.point.name, '', '')
  2512. },
  2513. mouseOver: function (e) { //鼠标移入停止轮播并且找到移入的当前数据设为选中
  2514. chartData.forEach((item, index) => {
  2515. // item.sliced = false
  2516. // item.selected = false
  2517. })
  2518. // chartData[e.target.index].sliced = true
  2519. // chartData[e.target.index].selected = true
  2520. that.left1Chart.update({
  2521. series: [{
  2522. type: 'pie',
  2523. name: '占比',
  2524. point: {
  2525. events: {
  2526. click: function (e) {
  2527. that.projectNum = 2142
  2528. that.showChartLTipDouble(e.point.name, 'left', '投资计划分析', e.point.name, '', '')
  2529. }
  2530. }
  2531. },
  2532. data: chartData
  2533. }]
  2534. })
  2535. that.pieTime1 && clearInterval(that.pieTime1);
  2536. },
  2537. mouseOut: function () { // 鼠标移出后需要继续执行轮播
  2538. var points = that.left1Chart.series[0].points;
  2539. var len = points.length;
  2540. that.pieTime1 && clearInterval(that.pieTime1);
  2541. that.pieTime1 = setInterval(function () {
  2542. autoTooltip(points[i]);
  2543. chartData.forEach((item, index) => {
  2544. // item.sliced = false
  2545. // item.selected = false
  2546. if (index == i) {
  2547. // item.sliced = true
  2548. // item.selected = true
  2549. }
  2550. })
  2551. that.left1Chart.update({
  2552. series: [{
  2553. type: 'pie',
  2554. name: '占比',
  2555. point: {
  2556. events: {
  2557. click: function (e) {
  2558. that.projectNum = 2142
  2559. that.showChartLTipDouble(e.point.name, 'left', '投资计划分析', e.point.name, '', '')
  2560. }
  2561. }
  2562. },
  2563. data: chartData
  2564. }]
  2565. })
  2566. i++;
  2567. if (i === len) {
  2568. i = 0;
  2569. chartData.forEach((item, index) => {
  2570. item.sliced = false
  2571. item.selected = false
  2572. })
  2573. that.left1Chart.update({
  2574. series: [{
  2575. type: 'pie',
  2576. name: '占比',
  2577. point: {
  2578. events: {
  2579. click: function (e) {
  2580. that.projectNum = 2142
  2581. that.showChartLTipDouble(e.point.name, 'left', '投资计划分析', e.point.name, '', '')
  2582. }
  2583. }
  2584. },
  2585. data: chartData
  2586. }]
  2587. })
  2588. }
  2589. }, 2000);
  2590. }
  2591. }
  2592. },
  2593. data: chartData
  2594. }]
  2595. }
  2596. that.left1Chart = Highcharts.chart('echartL2', option);
  2597. function autoTooltip (point) {
  2598. that.left1Chart.tooltip.refresh(point);
  2599. }
  2600. },
  2601. initChartL3 () {
  2602. var chartData = left6
  2603. var i = 0;
  2604. let that = this
  2605. that.left2Chart = Highcharts.chart('echartL3', {
  2606. colors: ['#064F78', '#BDB35D', '#623726', '#955773', '#B57C63', '#73A88E', '#09736D', '#13400B', '#0D3265'],
  2607. chart: {
  2608. type: 'pie',
  2609. backgroundColor: 'rgba(0,0,0,0)',
  2610. options3d: {
  2611. enabled: true,
  2612. alpha: 45,
  2613. //beta: 0
  2614. },
  2615. events: {
  2616. // load,图表加载完成时触发
  2617. load: function () {
  2618. var chart = this;
  2619. var points = chart.series[0].points;
  2620. var len = points.length;
  2621. that.pieTime2 && clearInterval(that.pieTime2);
  2622. that.pieTime2 = setInterval(function () {
  2623. autoTooltip(points[i]);
  2624. chartData.forEach((item, index) => {
  2625. item.sliced = false
  2626. item.selected = false
  2627. if (index == i) {
  2628. // item.sliced = true
  2629. // item.selected = true
  2630. }
  2631. })
  2632. that.left2Chart.update({
  2633. series: [{
  2634. type: 'pie',
  2635. name: '占比',
  2636. point: {
  2637. events: {
  2638. click: function (e) {
  2639. that.projectNum = 2143
  2640. that.showChartLTipDouble(e.point.name, 'left', '投资计划分析', e.point.name, '', '')
  2641. }
  2642. }
  2643. },
  2644. data: chartData
  2645. }]
  2646. })
  2647. i++;
  2648. if (i === len) {
  2649. i = 0;
  2650. chartData.forEach((item, index) => {
  2651. // item.sliced = false
  2652. // item.selected = false
  2653. })
  2654. that.left2Chart.update({
  2655. series: [{
  2656. type: 'pie',
  2657. name: '占比',
  2658. point: {
  2659. events: {
  2660. click: function (e) {
  2661. that.projectNum = 2143
  2662. that.showChartLTipDouble(e.point.name, 'left', '投资计划分析', e.point.name, '', '')
  2663. }
  2664. }
  2665. },
  2666. data: chartData
  2667. }]
  2668. })
  2669. }
  2670. }, 2000);
  2671. },
  2672. legendItemClick: function (event) {
  2673. that.projectNum = 2143
  2674. that.showChartLTipDouble(e.point.name, 'left', '投资计划分析', e.point.name, '', '')
  2675. return true;
  2676. }
  2677. }
  2678. },
  2679. credits: {
  2680. enabled: false //去掉hightchats水印
  2681. },
  2682. legend: {
  2683. // labelFormatter: function() {
  2684. // return 123;
  2685. // },
  2686. align: 'right',//横向位置
  2687. verticalAlign: 'middle', // 纵向位置
  2688. layout: "vertical",//横排还是竖排
  2689. x: -70,
  2690. y: 90,
  2691. symbolWidth: 50,
  2692. itemStyle: {
  2693. fontSize: '20px',
  2694. color: '#fff',
  2695. x: 20,
  2696. fontWeight: 0,
  2697. fontFamily: 'Microsoft YaHei'
  2698. },
  2699. },
  2700. title: {
  2701. text: '项目管理类型',
  2702. style: {
  2703. color: '#fff',
  2704. fontSize: 24,
  2705. fontFamily: 'Microsoft YaHei'
  2706. },
  2707. align: 'center',
  2708. verticalAlign: "bottom",
  2709. x: -120
  2710. },
  2711. tooltip: {
  2712. crosshairs: true,
  2713. backgroundColor: 'rgba(0,0,0,0.5)',
  2714. // positioner: function(e){
  2715. // console.log(e, this)
  2716. // },
  2717. useHTML: false, //开启html模式
  2718. style: {
  2719. color: '#fff',
  2720. fontSize: '20',
  2721. fontFamily: 'Microsoft YaHei'
  2722. },
  2723. formatter: function (e) {
  2724. //console.log(this)
  2725. let num = chartData[this.colorIndex].num
  2726. this.percentage = this.percentage.toFixed(2) //Math.round(this.percentage)
  2727. return `${this.key}:<b>${this.percentage}%</b><br/><b>${this.y}</b>亿,<b>${num}个</b>`
  2728. },
  2729. //pointFormat:
  2730. },
  2731. plotOptions: {
  2732. pie: {
  2733. allowPointSelect: true,
  2734. showInLegend: true, // 图例
  2735. cursor: 'pointer',
  2736. size: 220,
  2737. innerSize: 150, //环形图中间空白,0为饼图
  2738. depth: 25, //立体高度
  2739. slicedOffset: 21, //动画距离
  2740. dataLabels: {
  2741. enabled: false, // 是否展示指示线
  2742. format: '{point.name}: {point.percentage}'
  2743. }
  2744. },
  2745. },
  2746. series: [{
  2747. type: 'pie',
  2748. name: '占比',
  2749. // center: ['70%', '50%'],
  2750. point: {
  2751. events: {
  2752. click: function (e) { //点击事件
  2753. that.projectNum = 2143
  2754. that.showChartLTipDouble(e.point.name, 'left', '投资计划分析', e.point.name, '', '')
  2755. },
  2756. mouseOver: function (e) { //鼠标移入停止轮播并且找到移入的当前数据设为选中
  2757. //console.log(e)
  2758. chartData.forEach((item, index) => {
  2759. item.sliced = false
  2760. item.selected = false
  2761. })
  2762. // chartData[e.target.index].sliced = true
  2763. // chartData[e.target.index].selected = true
  2764. that.left2Chart.update({
  2765. series: [{
  2766. type: 'pie',
  2767. name: '占比',
  2768. point: {
  2769. events: {
  2770. click: function (e) {
  2771. that.projectNum = 2143
  2772. that.showChartLTipDouble(e.point.name, 'left', '投资计划分析', e.point.name, '', '')
  2773. }
  2774. }
  2775. },
  2776. data: chartData
  2777. }]
  2778. })
  2779. that.pieTime2 && clearInterval(that.pieTime2);
  2780. },
  2781. mouseOut: function () { // 鼠标移出后需要继续执行轮播
  2782. var points = that.left2Chart.series[0].points;
  2783. var len = points.length;
  2784. that.pieTime2 && clearInterval(that.pieTime2);
  2785. that.pieTime2 = setInterval(function () {
  2786. autoTooltip(points[i]);
  2787. chartData.forEach((item, index) => {
  2788. item.sliced = false
  2789. item.selected = false
  2790. if (index == i) {
  2791. // item.sliced = true
  2792. // item.selected = true
  2793. }
  2794. })
  2795. that.left2Chart.update({
  2796. series: [{
  2797. type: 'pie',
  2798. name: '占比',
  2799. point: {
  2800. events: {
  2801. click: function (e) {
  2802. that.projectNum = 2143
  2803. that.showChartLTipDouble(e.point.name, 'left', '投资计划分析', e.point.name, '', '')
  2804. }
  2805. }
  2806. },
  2807. data: chartData
  2808. }]
  2809. })
  2810. i++;
  2811. if (i === len) {
  2812. i = 0;
  2813. chartData.forEach((item, index) => {
  2814. item.sliced = false
  2815. item.selected = false
  2816. })
  2817. that.left2Chart.update({
  2818. series: [{
  2819. type: 'pie',
  2820. name: '占比',
  2821. point: {
  2822. events: {
  2823. click: function (e) {
  2824. console.log(e)
  2825. }
  2826. }
  2827. },
  2828. data: chartData
  2829. }]
  2830. })
  2831. }
  2832. }, 2000);
  2833. }
  2834. }
  2835. },
  2836. data: chartData
  2837. }]
  2838. });
  2839. function autoTooltip (point) {
  2840. that.left2Chart.tooltip.refresh(point);
  2841. }
  2842. },
  2843. initChartL4 (dataList) {
  2844. this.left10Chart = echarts.init(document.getElementById("echartL4"));
  2845. let option = {
  2846. grid: {
  2847. top: 45,
  2848. right: 0,
  2849. left: 60,
  2850. bottom: 80,
  2851. },
  2852. tooltip: {
  2853. show: true,
  2854. trigger: "axis",
  2855. formatter: data => {
  2856. return `${data[0].name}<br /><span style="display:inline-block;border-radius:50%; width:7px;height:7px;background-color:${data[0].color.colorStops[0].color}"></span> ${data[0].seriesName}:${data[0].value}亿<br/><span style="display:inline-block;border-radius:50%; width:7px;height:7px;background-color:${data[1].color.colorStops[0].color}"></span> ${data[1].seriesName}:${data[1].value + data[0].value}亿`
  2857. },
  2858. axisPointer: {
  2859. // 坐标轴指示器,坐标轴触发有效
  2860. type: "shadow", // 默认为直线,可选为:'line' | 'shadow'
  2861. },
  2862. textStyle: {
  2863. color: '#FFF', // 文字的颜色
  2864. fontSize: '20', // 文字字体大小
  2865. fontFamily: 'Microsoft YaHei'
  2866. },
  2867. },
  2868. xAxis: {
  2869. data: commonCompany,
  2870. axisTick: {
  2871. show: false,
  2872. },
  2873. // x轴的字体颜色
  2874. axisLabel: {
  2875. rotate: 40,
  2876. textStyle: {
  2877. color: "white",
  2878. fontSize: '20',
  2879. fontFamily: 'Microsoft YaHei'
  2880. },
  2881. },
  2882. //y轴线的颜色以及宽度
  2883. axisLine: {
  2884. show: true,
  2885. lineStyle: {
  2886. color: "#1E5389",
  2887. width: 1,
  2888. type: "solid",
  2889. },
  2890. },
  2891. },
  2892. yAxis: {
  2893. name: '亿',
  2894. axisTick: {
  2895. lineStyle: {
  2896. color: "#18416F",
  2897. },
  2898. },
  2899. // y轴的字体颜色
  2900. axisLabel: {
  2901. textStyle: {
  2902. color: "white",
  2903. fontSize: '20',
  2904. fontFamily: 'Microsoft YaHei'
  2905. },
  2906. },
  2907. splitLine: {
  2908. show: true,
  2909. lineStyle: {
  2910. color: "#68b4dd66",
  2911. width: 1,
  2912. type: "dashed",
  2913. },
  2914. },
  2915. //y轴线的颜色以及宽度
  2916. axisLine: {
  2917. show: true,
  2918. lineStyle: {
  2919. color: "#1E5389",
  2920. width: 1,
  2921. type: "solid",
  2922. },
  2923. },
  2924. nameTextStyle: {
  2925. color: '#fff',
  2926. fontSize: 20,
  2927. fontFamily: 'Microsoft YaHei'
  2928. },
  2929. },
  2930. series: [
  2931. {
  2932. name: "已用额度",
  2933. type: "bar",
  2934. data: left3[0],
  2935. stack: 'Ad',
  2936. showBackground: false,
  2937. backgroundStyle: {
  2938. color: "#18416F",
  2939. },
  2940. barWidth: "20",
  2941. itemStyle: {
  2942. // barBorderRadius: [10, 10, 0, 0],
  2943. color: new echarts.graphic.LinearGradient(0, 1, 0, 0, [
  2944. {
  2945. offset: 0,
  2946. color: '#082550',
  2947. },
  2948. {
  2949. offset: 1,
  2950. color: '#3986F8',
  2951. },
  2952. ]),
  2953. },
  2954. },
  2955. {
  2956. name: "总额度",
  2957. type: "bar",
  2958. data: left3[1],
  2959. stack: 'Ad',
  2960. showBackground: false,
  2961. backgroundStyle: {
  2962. color: "#18416F",
  2963. },
  2964. barWidth: "20",
  2965. itemStyle: {
  2966. // barBorderRadius: [10, 10, 0, 0],
  2967. color: new echarts.graphic.LinearGradient(0, 1, 0, 0, [
  2968. {
  2969. offset: 0,
  2970. color: '#b9b7c060',
  2971. },
  2972. {
  2973. offset: 1,
  2974. color: '#b9b7c060',
  2975. },
  2976. ]),
  2977. },
  2978. },
  2979. ],
  2980. legend: {
  2981. // data: ["2022年额度", "2023年额度"],
  2982. data: ["2023年额度"],
  2983. textStyle: {
  2984. // 图列内容样式
  2985. color: "#fff", // 字体颜色
  2986. fontSize: "20",
  2987. fontFamily: 'Microsoft YaHei'
  2988. },
  2989. right: 'center',
  2990. y: 5,
  2991. // icon: "roundRect",
  2992. // 小图标的宽高
  2993. },
  2994. };
  2995. let that = this
  2996. tools.loopShowTooltip(that.left10Chart, option, {
  2997. nterval: 2000,
  2998. loopSeries: true,
  2999. })
  3000. that.left10Chart.on('click', function (param) {
  3001. that.titleName = param.name
  3002. that.echartEnterpriseShow = true
  3003. // 如果是接口版数据版
  3004. if (that.versions) {
  3005. let findData = dataList.find(item => {
  3006. return item.mdnb_textfield == param.name
  3007. })
  3008. common1[0] = findData.mdnb_amountfield18
  3009. common1[1] = findData.mdnb_amountfield20
  3010. common1[2] = findData.mdnb_amountfield19
  3011. common1[3] = findData.mdnb_amountfield26
  3012. common1[4] = findData.mdnb_amountfield27
  3013. common1[5] = findData.mdnb_amountfield25
  3014. common2[0] = findData.mdnb_decimalfield6
  3015. }
  3016. setTimeout(() => {
  3017. that.initChartBall()
  3018. });
  3019. })
  3020. that.left10Chart.setOption(option);
  3021. },
  3022. initChartL5 () {
  3023. var chartData = left7
  3024. var i = 0;
  3025. let that = this
  3026. var option = {
  3027. colors: ['#064F78', '#BDB35D', '#623726', '#955773', '#B57C63', '#73A88E', '#09736D', '#13400B', '#0D3265'],
  3028. chart: {
  3029. type: 'pie',
  3030. backgroundColor: 'rgba(0,0,0,0)',
  3031. options3d: {
  3032. enabled: true,
  3033. alpha: 45,
  3034. //beta: 0
  3035. },
  3036. events: {
  3037. // load,图表加载完成时触发
  3038. load: function () {
  3039. var chart = this;
  3040. var points = chart.series[0].points;
  3041. var len = points.length;
  3042. that.pieTime3 && clearInterval(that.pieTime3);
  3043. that.pieTime3 = setInterval(function () {
  3044. autoTooltip(points[i]);
  3045. chartData.forEach((item, index) => {
  3046. item.sliced = false
  3047. item.selected = false
  3048. if (index == i) {
  3049. item.sliced = true
  3050. item.selected = true
  3051. }
  3052. })
  3053. that.left3Chart.update({
  3054. series: [{
  3055. type: 'pie',
  3056. name: '占比',
  3057. point: {
  3058. events: {
  3059. click: function (e) {
  3060. that.showChartLTipDouble(e.point.name, 'left', '产业布局分析', '传统产业分析', e.point.name, '', '', '', '', '', '', 215)
  3061. // that.showChartLTipDouble(e.point.name, 'left', '产业布局分析', '优势特色产业', '体育产业', '')
  3062. }
  3063. }
  3064. },
  3065. data: chartData
  3066. }]
  3067. })
  3068. i++;
  3069. if (i === len) {
  3070. i = 0;
  3071. }
  3072. }, 2000);
  3073. },
  3074. legendItemClick: function (event) {
  3075. console.log(event);
  3076. return true;
  3077. }
  3078. }
  3079. },
  3080. credits: {
  3081. enabled: false //去掉hightchats水印
  3082. },
  3083. legend: {
  3084. // labelFormatter: function() {
  3085. // return 123;
  3086. // },
  3087. align: 'right',//横向位置
  3088. verticalAlign: 'middle', // 纵向位置
  3089. layout: "vertical",//横排还是竖排
  3090. // x: -110,
  3091. // y: 50,
  3092. symbolWidth: 50,
  3093. itemDistance: 50,
  3094. itemStyle: {
  3095. fontSize: '20px',
  3096. color: '#fff',
  3097. x: 20,
  3098. fontWeight: 0,
  3099. fontFamily: 'Microsoft YaHei'
  3100. },
  3101. },
  3102. title: {
  3103. text: '传统产业分析',
  3104. style: {
  3105. color: '#fff',
  3106. fontSize: 24,
  3107. fontFamily: 'Microsoft YaHei'
  3108. },
  3109. align: 'center',
  3110. verticalAlign: "bottom",
  3111. x: -120
  3112. },
  3113. tooltip: {
  3114. crosshairs: true,
  3115. backgroundColor: 'rgba(0,0,0,0.5)',
  3116. // positioner: function(e){
  3117. // console.log(e, this)
  3118. // },
  3119. useHTML: false, //开启html模式
  3120. style: {
  3121. color: '#fff',
  3122. fontSize: '20',
  3123. fontFamily: 'Microsoft YaHei'
  3124. },
  3125. formatter: function (e) {
  3126. //console.log(this)
  3127. let num = chartData[this.colorIndex].num
  3128. this.percentage = this.percentage.toFixed(2) //Math.round(this.percentage)
  3129. return `${this.key}:<b>${this.percentage}%</b><br/><b>${this.y}</b>亿,<b>${num}个</b>`
  3130. },
  3131. //pointFormat:
  3132. },
  3133. plotOptions: {
  3134. pie: {
  3135. allowPointSelect: true,
  3136. showInLegend: true, // 图例
  3137. cursor: 'pointer',
  3138. size: 220,
  3139. innerSize: 150, //环形图中间空白,0为饼图
  3140. depth: 25, //立体高度
  3141. slicedOffset: 21, //动画距离
  3142. dataLabels: {
  3143. enabled: false, // 是否展示指示线
  3144. format: '{point.name}: {point.percentage}'
  3145. }
  3146. },
  3147. },
  3148. series: [{
  3149. type: 'pie',
  3150. name: '占比',
  3151. //center: ['35%','50%'],
  3152. point: {
  3153. events: {
  3154. click: function (e) { //点击事件
  3155. that.showChartLTipDouble(e.point.name, 'left', '产业布局分析', '传统产业分析', e.point.name, '', '', '', '', '', '', 215)
  3156. // that.showChartLTipDouble(e.point.name, 'left', '产业布局分析', '优势特色产业', '体育产业', '')
  3157. },
  3158. mouseOver: function (e) { //鼠标移入停止轮播并且找到移入的当前数据设为选中
  3159. //console.log(e)
  3160. chartData.forEach((item, index) => {
  3161. item.sliced = false
  3162. item.selected = false
  3163. })
  3164. chartData[e.target.index].sliced = true
  3165. chartData[e.target.index].selected = true
  3166. that.left3Chart.update({
  3167. series: [{
  3168. type: 'pie',
  3169. name: '占比',
  3170. point: {
  3171. events: {
  3172. click: function (e) {
  3173. that.showChartLTipDouble(e.point.name, 'left', '产业布局分析', '传统产业分析', e.point.name, '', '', '', '', '', '', 215)
  3174. // that.showChartLTipDouble(e.point.name, 'left', '产业布局分析', '优势特色产业', '体育产业', '')
  3175. }
  3176. }
  3177. },
  3178. data: chartData
  3179. }]
  3180. })
  3181. that.pieTime3 && clearInterval(that.pieTime3);
  3182. },
  3183. mouseOut: function () { // 鼠标移出后需要继续执行轮播
  3184. var points = that.left3Chart.series[0].points;
  3185. var len = points.length;
  3186. that.pieTime3 && clearInterval(that.pieTime3);
  3187. that.pieTime3 = setInterval(function () {
  3188. autoTooltip(points[i]);
  3189. chartData.forEach((item, index) => {
  3190. item.sliced = false
  3191. item.selected = false
  3192. if (index == i) {
  3193. item.sliced = true
  3194. item.selected = true
  3195. }
  3196. })
  3197. that.left3Chart.update({
  3198. series: [{
  3199. type: 'pie',
  3200. name: '占比',
  3201. point: {
  3202. events: {
  3203. click: function (e) {
  3204. that.showChartLTipDouble(e.point.name, 'left', '产业布局分析', '传统产业分析', e.point.name, '', '', '', '', '', '', 215)
  3205. // that.showChartLTipDouble(e.point.name, 'left', '产业布局分析', '优势特色产业', '体育产业', '')
  3206. }
  3207. }
  3208. },
  3209. data: chartData
  3210. }]
  3211. })
  3212. i++;
  3213. if (i === len) {
  3214. i = 0;
  3215. }
  3216. }, 2000);
  3217. }
  3218. }
  3219. },
  3220. data: chartData
  3221. }]
  3222. }
  3223. that.left3Chart = Highcharts.chart('echartL5', option);
  3224. function autoTooltip (point) {
  3225. that.left3Chart.tooltip.refresh(point);
  3226. }
  3227. },
  3228. initChartL6 () {
  3229. var chartData = left8
  3230. var i = 0;
  3231. let that = this
  3232. var option = {
  3233. colors: ['#064F78', '#BDB35D', '#623726', '#955773', '#B57C63', '#73A88E', '#09736D', '#13400B', '#0D3265'],
  3234. chart: {
  3235. type: 'pie',
  3236. backgroundColor: 'rgba(0,0,0,0)',
  3237. options3d: {
  3238. enabled: true,
  3239. alpha: 45,
  3240. //beta: 0
  3241. },
  3242. events: {
  3243. // load,图表加载完成时触发
  3244. load: function () {
  3245. var chart = this;
  3246. var points = chart.series[0].points;
  3247. var len = points.length;
  3248. that.pieTime4 && clearInterval(that.pieTime4);
  3249. that.pieTime4 = setInterval(function () {
  3250. autoTooltip(points[i]);
  3251. chartData.forEach((item, index) => {
  3252. item.sliced = false
  3253. item.selected = false
  3254. if (index == i) {
  3255. item.sliced = true
  3256. item.selected = true
  3257. }
  3258. })
  3259. that.left4Chart.update({
  3260. series: [{
  3261. type: 'pie',
  3262. name: '占比',
  3263. point: {
  3264. events: {
  3265. click: function (e) {
  3266. that.showChartLTipDouble(e.point.name, 'left', '产业布局分析', '战略性新兴产业', e.point.name, '', '', '', '', '', '', 215)
  3267. }
  3268. }
  3269. },
  3270. data: chartData
  3271. }]
  3272. })
  3273. i++;
  3274. if (i === len) {
  3275. i = 0;
  3276. }
  3277. }, 2000);
  3278. },
  3279. legendItemClick: function (event) {
  3280. console.log(event);
  3281. return true;
  3282. }
  3283. }
  3284. },
  3285. credits: {
  3286. enabled: false //去掉hightchats水印
  3287. },
  3288. legend: {
  3289. // labelFormatter: function() {
  3290. // return 123;
  3291. // },
  3292. align: 'right',//横向位置
  3293. verticalAlign: 'middle', // 纵向位置
  3294. layout: "vertical",//横排还是竖排
  3295. // x: -30,
  3296. // y: 30,
  3297. symbolWidth: 50,
  3298. itemDistance: 50,
  3299. itemStyle: {
  3300. fontSize: '20px',
  3301. color: '#fff',
  3302. x: 20,
  3303. fontWeight: 0,
  3304. fontFamily: 'Microsoft YaHei'
  3305. },
  3306. },
  3307. title: {
  3308. text: '战略性新兴产业',
  3309. style: {
  3310. color: '#fff',
  3311. fontSize: 24,
  3312. fontFamily: 'Microsoft YaHei'
  3313. },
  3314. align: 'center',
  3315. verticalAlign: "bottom",
  3316. x: -120
  3317. },
  3318. tooltip: {
  3319. crosshairs: true,
  3320. backgroundColor: 'rgba(0,0,0,0.5)',
  3321. // positioner: function(e){
  3322. // console.log(e, this)
  3323. // },
  3324. useHTML: false, //开启html模式
  3325. style: {
  3326. color: '#fff',
  3327. fontSize: '20',
  3328. fontFamily: 'Microsoft YaHei'
  3329. },
  3330. formatter: function (e) {
  3331. //console.log(this)
  3332. let num = chartData[this.colorIndex].num
  3333. this.percentage = this.percentage.toFixed(2) //Math.round(this.percentage)
  3334. return `${this.key}:<b>${this.percentage}%</b><br/><b>${this.y}</b>亿,<b>${num}个</b>`
  3335. },
  3336. //pointFormat:
  3337. },
  3338. plotOptions: {
  3339. pie: {
  3340. allowPointSelect: true,
  3341. showInLegend: true, // 图例
  3342. cursor: 'pointer',
  3343. size: 220,
  3344. innerSize: 150, //环形图中间空白,0为饼图
  3345. depth: 25, //立体高度
  3346. slicedOffset: 21, //动画距离
  3347. dataLabels: {
  3348. enabled: false, // 是否展示指示线
  3349. format: '{point.name}: {point.percentage}'
  3350. }
  3351. },
  3352. },
  3353. series: [{
  3354. type: 'pie',
  3355. name: '占比',
  3356. //center: ['35%','50%'],
  3357. point: {
  3358. events: {
  3359. click: function (e) { //点击事件
  3360. that.showChartLTipDouble(e.point.name, 'left', '产业布局分析', '战略性新兴产业', e.point.name, '', '', '', '', '', '', 215)
  3361. },
  3362. mouseOver: function (e) { //鼠标移入停止轮播并且找到移入的当前数据设为选中
  3363. //console.log(e)
  3364. chartData.forEach((item, index) => {
  3365. item.sliced = false
  3366. item.selected = false
  3367. })
  3368. chartData[e.target.index].sliced = true
  3369. chartData[e.target.index].selected = true
  3370. that.left4Chart.update({
  3371. series: [{
  3372. type: 'pie',
  3373. name: '占比',
  3374. point: {
  3375. events: {
  3376. click: function (e) {
  3377. that.showChartLTipDouble(e.point.name, 'left', '产业布局分析', '战略性新兴产业', e.point.name, '', '', '', '', '', '', 215)
  3378. }
  3379. }
  3380. },
  3381. data: chartData
  3382. }]
  3383. })
  3384. that.pieTime4 && clearInterval(that.pieTime4);
  3385. },
  3386. mouseOut: function () { // 鼠标移出后需要继续执行轮播
  3387. var points = that.left4Chart.series[0].points;
  3388. var len = points.length;
  3389. that.pieTime4 && clearInterval(that.pieTime4);
  3390. that.pieTime4 = setInterval(function () {
  3391. autoTooltip(points[i]);
  3392. chartData.forEach((item, index) => {
  3393. item.sliced = false
  3394. item.selected = false
  3395. if (index == i) {
  3396. item.sliced = true
  3397. item.selected = true
  3398. }
  3399. })
  3400. that.left4Chart.update({
  3401. series: [{
  3402. type: 'pie',
  3403. name: '占比',
  3404. point: {
  3405. events: {
  3406. click: function (e) {
  3407. that.showChartLTipDouble(e.point.name, 'left', '产业布局分析', '战略性新兴产业', e.point.name, '', '', '', '', '', '', 215)
  3408. }
  3409. }
  3410. },
  3411. data: chartData
  3412. }]
  3413. })
  3414. i++;
  3415. if (i === len) {
  3416. i = 0;
  3417. }
  3418. }, 2000);
  3419. }
  3420. }
  3421. },
  3422. data: chartData
  3423. }]
  3424. }
  3425. that.left4Chart = Highcharts.chart('echartL6', option);
  3426. function autoTooltip (point) {
  3427. that.left4Chart.tooltip.refresh(point);
  3428. }
  3429. },
  3430. initChartL7 () {
  3431. var chartData = left9
  3432. var i = 0;
  3433. let that = this
  3434. var option = {
  3435. colors: ['#064F78', '#BDB35D', '#623726', '#955773', '#B57C63', '#73A88E', '#09736D', '#13400B', '#0D3265'],
  3436. chart: {
  3437. type: 'pie',
  3438. backgroundColor: 'rgba(0,0,0,0)',
  3439. options3d: {
  3440. enabled: true,
  3441. alpha: 45,
  3442. //beta: 0
  3443. },
  3444. events: {
  3445. // load,图表加载完成时触发
  3446. load: function () {
  3447. var chart = this;
  3448. var points = chart.series[0].points;
  3449. var len = points.length;
  3450. that.pieTime5 && clearInterval(that.pieTime5);
  3451. that.pieTime5 = setInterval(function () {
  3452. autoTooltip(points[i]);
  3453. chartData.forEach((item, index) => {
  3454. item.sliced = false
  3455. item.selected = false
  3456. if (index == i) {
  3457. item.sliced = true
  3458. item.selected = true
  3459. }
  3460. })
  3461. that.left5Chart.update({
  3462. series: [{
  3463. type: 'pie',
  3464. name: '占比',
  3465. point: {
  3466. events: {
  3467. click: function (e) {
  3468. that.showChartLTipDouble(e.point.name, 'left', '产业布局分析', '特色优势产业', e.point.name, '', '', '', '', '', '', 215)
  3469. }
  3470. }
  3471. },
  3472. data: chartData
  3473. }]
  3474. })
  3475. i++;
  3476. if (i === len) {
  3477. i = 0;
  3478. }
  3479. }, 2000);
  3480. },
  3481. legendItemClick: function (event) {
  3482. console.log(event);
  3483. return true;
  3484. }
  3485. }
  3486. },
  3487. credits: {
  3488. enabled: false //去掉hightchats水印
  3489. },
  3490. title: {
  3491. text: '特色优势产业',
  3492. style: {
  3493. color: '#fff',
  3494. fontSize: 24,
  3495. fontFamily: 'Microsoft YaHei'
  3496. },
  3497. align: 'center',
  3498. verticalAlign: "bottom",
  3499. x: -120
  3500. },
  3501. legend: {
  3502. // labelFormatter: function() {
  3503. // return 123;
  3504. // },
  3505. align: 'right',//横向位置
  3506. verticalAlign: 'middle', // 纵向位置
  3507. layout: "vertical",//横排还是竖排
  3508. // x: -50,
  3509. // y: 30,
  3510. symbolWidth: 50,
  3511. itemDistance: 50,
  3512. itemStyle: {
  3513. fontSize: '20px',
  3514. color: '#fff',
  3515. x: 20,
  3516. fontWeight: 0,
  3517. fontFamily: 'Microsoft YaHei'
  3518. },
  3519. },
  3520. tooltip: {
  3521. crosshairs: true,
  3522. backgroundColor: 'rgba(0,0,0,0.5)',
  3523. // positioner: function(e){
  3524. // console.log(e, this)
  3525. // },
  3526. useHTML: false, //开启html模式
  3527. style: {
  3528. color: '#fff',
  3529. fontSize: '20',
  3530. fontFamily: 'Microsoft YaHei'
  3531. },
  3532. formatter: function (e) {
  3533. //console.log(this)
  3534. let num = chartData[this.colorIndex].num
  3535. this.percentage = this.percentage.toFixed(2) //Math.round(this.percentage)
  3536. return `${this.key}:<b>${this.percentage}%</b><br/><b>${this.y}</b>亿,<b>${num}个</b>`
  3537. },
  3538. //pointFormat:
  3539. },
  3540. plotOptions: {
  3541. pie: {
  3542. allowPointSelect: true,
  3543. showInLegend: true, // 图例
  3544. cursor: 'pointer',
  3545. size: 220,
  3546. innerSize: 150, //环形图中间空白,0为饼图
  3547. depth: 25, //立体高度
  3548. slicedOffset: 21, //动画距离
  3549. dataLabels: {
  3550. enabled: false, // 是否展示指示线
  3551. format: '{point.name}: {point.percentage}'
  3552. }
  3553. },
  3554. },
  3555. series: [{
  3556. type: 'pie',
  3557. name: '占比',
  3558. //center: ['35%','50%'],
  3559. point: {
  3560. events: {
  3561. click: function (e) { //点击事件
  3562. that.showChartLTipDouble(e.point.name, 'left', '产业布局分析', '特色优势产业', e.point.name, '', '', '', '', '', '', 215)
  3563. },
  3564. mouseOver: function (e) { //鼠标移入停止轮播并且找到移入的当前数据设为选中
  3565. //console.log(e)
  3566. chartData.forEach((item, index) => {
  3567. item.sliced = false
  3568. item.selected = false
  3569. })
  3570. chartData[e.target.index].sliced = true
  3571. chartData[e.target.index].selected = true
  3572. that.left5Chart.update({
  3573. series: [{
  3574. type: 'pie',
  3575. name: '占比',
  3576. point: {
  3577. events: {
  3578. click: function (e) {
  3579. that.showChartLTipDouble(e.point.name, 'left', '产业布局分析', '特色优势产业', e.point.name, '', '', '', '', '', '', 215)
  3580. }
  3581. }
  3582. },
  3583. data: chartData
  3584. }]
  3585. })
  3586. that.pieTime5 && clearInterval(that.pieTime5);
  3587. },
  3588. mouseOut: function () { // 鼠标移出后需要继续执行轮播
  3589. var points = that.left5Chart.series[0].points;
  3590. var len = points.length;
  3591. that.pieTime5 && clearInterval(that.pieTime5);
  3592. that.pieTime5 = setInterval(function () {
  3593. autoTooltip(points[i]);
  3594. chartData.forEach((item, index) => {
  3595. item.sliced = false
  3596. item.selected = false
  3597. if (index == i) {
  3598. item.sliced = true
  3599. item.selected = true
  3600. }
  3601. })
  3602. that.left5Chart.update({
  3603. series: [{
  3604. type: 'pie',
  3605. name: '占比',
  3606. point: {
  3607. events: {
  3608. click: function (e) {
  3609. that.showChartLTipDouble(e.point.name, 'left', '产业布局分析', '特色优势产业', e.point.name, '', '', '', '', '', '', 215)
  3610. }
  3611. }
  3612. },
  3613. data: chartData
  3614. }]
  3615. })
  3616. i++;
  3617. if (i === len) {
  3618. i = 0;
  3619. }
  3620. }, 2000);
  3621. }
  3622. }
  3623. },
  3624. data: chartData
  3625. }]
  3626. }
  3627. that.left5Chart = Highcharts.chart('echartL7', option);
  3628. function autoTooltip (point) {
  3629. that.left5Chart.tooltip.refresh(point);
  3630. }
  3631. },
  3632. initChartL8 () {
  3633. var chartData = left10
  3634. var i = 0;
  3635. let that = this
  3636. var option = {
  3637. colors: ['#064F78', '#BDB35D', '#623726', '#955773', '#B57C63', '#73A88E', '#09736D', '#13400B', '#0D3265'],
  3638. chart: {
  3639. type: 'pie',
  3640. backgroundColor: 'rgba(0,0,0,0)',
  3641. options3d: {
  3642. enabled: true,
  3643. alpha: 45,
  3644. //beta: 0
  3645. },
  3646. events: {
  3647. // load,图表加载完成时触发
  3648. load: function () {
  3649. var chart = this;
  3650. var points = chart.series[0].points;
  3651. var len = points.length;
  3652. that.pieTime6 && clearInterval(that.pieTime6);
  3653. that.pieTime6 = setInterval(function () {
  3654. autoTooltip(points[i]);
  3655. chartData.forEach((item, index) => {
  3656. item.sliced = false
  3657. item.selected = false
  3658. if (index == i) {
  3659. item.sliced = true
  3660. item.selected = true
  3661. }
  3662. })
  3663. that.left6Chart.update({
  3664. series: [{
  3665. type: 'pie',
  3666. name: '占比',
  3667. point: {
  3668. events: {
  3669. click: function (e) {
  3670. that.showChartLTipDouble(e.point.name, 'left', '产业布局分析', '公共基础等产业', e.point.name, '', '', '', '', '', '', 215)
  3671. }
  3672. }
  3673. },
  3674. data: chartData
  3675. }]
  3676. })
  3677. i++;
  3678. if (i === len) {
  3679. i = 0;
  3680. }
  3681. }, 2000);
  3682. },
  3683. legendItemClick: function (event) {
  3684. console.log(event);
  3685. return true;
  3686. }
  3687. }
  3688. },
  3689. credits: {
  3690. enabled: false //去掉hightchats水印
  3691. },
  3692. title: {
  3693. text: '公共基础等产业',
  3694. style: {
  3695. color: '#fff',
  3696. fontSize: 24,
  3697. fontFamily: 'Microsoft YaHei'
  3698. },
  3699. align: 'center',
  3700. verticalAlign: "bottom",
  3701. x: -120
  3702. },
  3703. legend: {
  3704. // labelFormatter: function() {
  3705. // return 123;
  3706. // },
  3707. align: 'right',//横向位置
  3708. verticalAlign: 'middle', // 纵向位置
  3709. layout: "vertical",//横排还是竖排
  3710. // x: -70,
  3711. // y: 50,
  3712. symbolWidth: 50,
  3713. itemDistance: 50,
  3714. itemStyle: {
  3715. fontSize: '20px',
  3716. color: '#fff',
  3717. x: 20,
  3718. fontWeight: 0,
  3719. fontFamily: 'Microsoft YaHei'
  3720. },
  3721. },
  3722. tooltip: {
  3723. crosshairs: true,
  3724. backgroundColor: 'rgba(0,0,0,0.5)',
  3725. // positioner: function(e){
  3726. // console.log(e, this)
  3727. // },
  3728. useHTML: false, //开启html模式
  3729. style: {
  3730. color: '#fff',
  3731. fontSize: '20',
  3732. fontFamily: 'Microsoft YaHei'
  3733. },
  3734. formatter: function (e) {
  3735. //console.log(this)
  3736. let num = chartData[this.colorIndex].num
  3737. this.percentage = this.percentage.toFixed(2) //Math.round(this.percentage)
  3738. return `${this.key}:<b>${this.percentage}%</b><br/><b>${this.y}</b>亿,<b>${num}个</b>`
  3739. },
  3740. //pointFormat:
  3741. },
  3742. plotOptions: {
  3743. pie: {
  3744. allowPointSelect: true,
  3745. showInLegend: true, // 图例
  3746. cursor: 'pointer',
  3747. size: 220,
  3748. innerSize: 150, //环形图中间空白,0为饼图
  3749. depth: 25, //立体高度
  3750. slicedOffset: 21, //动画距离
  3751. dataLabels: {
  3752. enabled: false, // 是否展示指示线
  3753. format: '{point.name}: {point.percentage}'
  3754. }
  3755. },
  3756. },
  3757. series: [{
  3758. type: 'pie',
  3759. name: '占比',
  3760. // center: ['35%','50%'],
  3761. point: {
  3762. events: {
  3763. click: function (e) { //点击事件
  3764. that.showChartLTipDouble(e.point.name, 'left', '产业布局分析', '公共基础等产业', e.point.name, '', '', '', '', '', '', 215)
  3765. },
  3766. mouseOver: function (e) { //鼠标移入停止轮播并且找到移入的当前数据设为选中
  3767. //console.log(e)
  3768. chartData.forEach((item, index) => {
  3769. item.sliced = false
  3770. item.selected = false
  3771. })
  3772. chartData[e.target.index].sliced = true
  3773. chartData[e.target.index].selected = true
  3774. that.left6Chart.update({
  3775. series: [{
  3776. type: 'pie',
  3777. name: '占比',
  3778. point: {
  3779. events: {
  3780. click: function (e) {
  3781. that.showChartLTipDouble(e.point.name, 'left', '产业布局分析', '公共基础等产业', e.point.name, '', '', '', '', '', '', 215)
  3782. }
  3783. }
  3784. },
  3785. data: chartData
  3786. }]
  3787. })
  3788. that.pieTime6 && clearInterval(that.pieTime6);
  3789. },
  3790. mouseOut: function () { // 鼠标移出后需要继续执行轮播
  3791. var points = that.left6Chart.series[0].points;
  3792. var len = points.length;
  3793. that.pieTime6 && clearInterval(that.pieTime6);
  3794. that.pieTime6 = setInterval(function () {
  3795. autoTooltip(points[i]);
  3796. chartData.forEach((item, index) => {
  3797. item.sliced = false
  3798. item.selected = false
  3799. if (index == i) {
  3800. item.sliced = true
  3801. item.selected = true
  3802. }
  3803. })
  3804. that.left6Chart.update({
  3805. series: [{
  3806. type: 'pie',
  3807. name: '占比',
  3808. point: {
  3809. events: {
  3810. click: function (e) {
  3811. that.showChartLTipDouble(e.point.name, 'left', '产业布局分析', '公共基础等产业', e.point.name, '', '', '', '', '', '', 215)
  3812. }
  3813. }
  3814. },
  3815. data: chartData
  3816. }]
  3817. })
  3818. i++;
  3819. if (i === len) {
  3820. i = 0;
  3821. }
  3822. }, 2000);
  3823. }
  3824. }
  3825. },
  3826. data: chartData
  3827. }]
  3828. }
  3829. that.left6Chart = Highcharts.chart('echartL8', option);
  3830. function autoTooltip (point) {
  3831. that.left6Chart.tooltip.refresh(point);
  3832. }
  3833. },
  3834. initChartL9 () {
  3835. this.chartCarousel = echarts.init(document.getElementById("echartL9"));
  3836. option = {
  3837. tooltip: {
  3838. trigger: 'axis',
  3839. formatter: '指标:' + '{c0}' + '<br/>' + '发展线:' + '{c1}' + '<br/>' + '生存线:' + '{c2}', //+ '<br/>'+ '{a1}:{c1}' + '%',
  3840. axisPointer: {
  3841. type: 'shadow',
  3842. },
  3843. },
  3844. grid: {
  3845. top: '10%',
  3846. right: '5%',
  3847. left: '12%',
  3848. bottom: '15%',
  3849. },
  3850. xAxis: {
  3851. // data: ['总投资收益率', '销售利润率', '成本费用利润率', '总资产周转率', '财务内部收益率'],
  3852. data: left15[this.countType],
  3853. axisLine: {
  3854. show: true, //隐藏X轴轴线
  3855. lineStyle: {
  3856. color: '#005094',
  3857. width: 1,
  3858. },
  3859. },
  3860. axisTick: {
  3861. show: true, //隐藏X轴刻度
  3862. },
  3863. axisLabel: {
  3864. show: true,
  3865. rotate: 30,
  3866. textStyle: {
  3867. color: '#fff', //X轴文字颜色
  3868. fontSize: 20,
  3869. fontFamily: 'Microsoft YaHei'
  3870. },
  3871. },
  3872. },
  3873. yAxis: [
  3874. {
  3875. type: 'value',
  3876. splitLine: {
  3877. show: true,
  3878. lineStyle: {
  3879. color: '#68b4dd66',
  3880. type: 'dashed',
  3881. },
  3882. },
  3883. axisLine: {
  3884. show: false
  3885. },
  3886. axisLabel: {
  3887. show: true,
  3888. formatter: '{value}%',
  3889. textStyle: {
  3890. color: '#fff',
  3891. fontSize: 20,
  3892. fontFamily: 'Microsoft YaHei'
  3893. },
  3894. },
  3895. nameTextStyle: {
  3896. color: '#ebf8ac',
  3897. fontSize: 16,
  3898. fontFamily: 'Microsoft YaHei'
  3899. },
  3900. },
  3901. ],
  3902. series: [
  3903. {
  3904. name: '实际值',
  3905. type: 'bar',
  3906. barWidth: 20,
  3907. itemStyle: {
  3908. normal: {
  3909. color: new echarts.graphic.LinearGradient(0, 0, 0, 1, [
  3910. {
  3911. offset: 0,
  3912. color: '#69c0ff',
  3913. },
  3914. {
  3915. offset: 1,
  3916. color: '#082550',
  3917. },
  3918. ]),
  3919. },
  3920. },
  3921. // data: [70, 52, 33, 41, 52],
  3922. data: left12[this.count + 1][2]
  3923. },
  3924. {
  3925. name: '',
  3926. type: 'line',
  3927. barWidth: 15,
  3928. itemStyle: {
  3929. normal: {
  3930. color: new echarts.graphic.LinearGradient(0, 0, 0, 1, [
  3931. {
  3932. offset: 0,
  3933. color: '#69c0ff',
  3934. },
  3935. {
  3936. offset: 1,
  3937. color: 'green',
  3938. },
  3939. ]),
  3940. },
  3941. },
  3942. // data: [20, 30, 15, 28, 36],
  3943. data: left12[this.count + 1][1]
  3944. },
  3945. {
  3946. name: '',
  3947. type: 'line',
  3948. barWidth: 15,
  3949. itemStyle: {
  3950. normal: {
  3951. color: new echarts.graphic.LinearGradient(0, 0, 0, 1, [
  3952. {
  3953. offset: 0,
  3954. color: '#69c0ff',
  3955. },
  3956. {
  3957. offset: 1,
  3958. color: 'yellow',
  3959. },
  3960. ]),
  3961. },
  3962. },
  3963. // data: [15, 22, 17, 33, 14],
  3964. data: left12[this.count + 1][0]
  3965. },
  3966. ],
  3967. }
  3968. let that = this
  3969. // this.chartCarousel.on('click', function (param) {
  3970. // that.titleName = param.name
  3971. // that.echartSingleTipShow = true
  3972. // setTimeout(() => {
  3973. // that.initChartLTip()
  3974. // });
  3975. // })
  3976. // this.chartCarousel.on('mouseover', (params) => {
  3977. // that.$refs.indicator.handleHover(true, 1, 2, 3, 4)
  3978. // })
  3979. // this.chartCarousel.on('mouseout', (params) => {
  3980. // that.$refs.indicator.handleHover(false, 1, 2, 3, 4)
  3981. // })
  3982. this.chartCarousel.setOption(option)
  3983. // tools.loopShowTooltip(myChart, option, {
  3984. // nterval: 2000,
  3985. // loopSeries: true,
  3986. // })
  3987. },
  3988. initChartL10 () {
  3989. this.left7Chart = echarts.init(document.getElementById("echartL10"));
  3990. let option = {
  3991. title: {
  3992. text: '固定资产进度分布',
  3993. textStyle: {
  3994. color: '#69C0FF',
  3995. fontSize: 30,
  3996. fontWeight: 500,
  3997. fontFamily: 'Microsoft YaHei'
  3998. },
  3999. top: '20',
  4000. left: '20'
  4001. },
  4002. textStyle: {
  4003. color: '#fff',
  4004. },
  4005. tooltip: {
  4006. trigger: "axis",
  4007. formatter: function (params) {
  4008. var tip = params[0].axisValue + '<br/>' + params[0].marker + params[0].data[1] + ':' + params[0].data[2] + '个,' + params[0].data[3] + '亿' + '<br/>' + params[1].marker + params[1].data[1] + ':' + params[1].data[2] + '个,' + params[1].data[3] + '亿';
  4009. return tip
  4010. },
  4011. textStyle: {
  4012. color: '#ffffff', // 文字的颜色
  4013. fontSize: '20', // 文字字体大小
  4014. fontFamily: 'Microsoft YaHei'
  4015. },
  4016. axisPointer: {
  4017. // lineStyle: {
  4018. // type: 'dashed',
  4019. // width: 2,
  4020. // color: 'rgba(255,255,255,0.6)'
  4021. // },
  4022. animation: false
  4023. }
  4024. },
  4025. grid: {
  4026. top: '0%',
  4027. right: '5%',
  4028. left: '15%',
  4029. bottom: '-10%',
  4030. },
  4031. yAxis: {
  4032. data: ['备案', '特别监管'],
  4033. splitLine: {
  4034. show: false,
  4035. lineStyle: {
  4036. color: '#68b4dd66',
  4037. type: 'dashed',
  4038. },
  4039. },
  4040. axisLine: {
  4041. show: false
  4042. },
  4043. axisLabel: {
  4044. show: true,
  4045. formatter: '{value}',
  4046. textStyle: {
  4047. color: '#fff',
  4048. fontSize: 20,
  4049. padding: [0, -10, 0, 0],
  4050. fontFamily: 'Microsoft YaHei',
  4051. },
  4052. },
  4053. nameTextStyle: {
  4054. color: '#ebf8ac',
  4055. fontSize: 16,
  4056. fontFamily: 'Microsoft YaHei'
  4057. },
  4058. },
  4059. xAxis: {
  4060. data: ['项目储备', '项目立项', '可研论证', '投资决策'],
  4061. axisLine: {
  4062. show: true, //隐藏X轴轴线
  4063. lineStyle: {
  4064. color: '#005094',
  4065. width: 1,
  4066. },
  4067. },
  4068. axisTick: {
  4069. show: false, //隐藏X轴刻度
  4070. },
  4071. axisLabel: {
  4072. show: true,
  4073. textStyle: {
  4074. color: '#fff', //X轴文字颜色
  4075. fontSize: 20,
  4076. padding: [-320, 0, 0, 0],
  4077. fontFamily: 'Microsoft YaHei'
  4078. },
  4079. }
  4080. },
  4081. series: [
  4082. {
  4083. name: '特别监管',
  4084. type: 'scatter',
  4085. symbol: 'circle',//'circle', 'rect', 'roundRect', 'triangle', 'diamond', 'pin', 'arrow'
  4086. symbolSize: function (data) {
  4087. return Math.sqrt(data[2]) * 5;
  4088. },
  4089. // label: {
  4090. // emphasis: {
  4091. // show: true,
  4092. // formatter: function (param) {
  4093. // return param.data[2];
  4094. // },
  4095. // position: 'top'
  4096. // }
  4097. // },
  4098. itemStyle: {
  4099. normal: {
  4100. color: '#69c0ff'
  4101. }
  4102. },
  4103. data: left13[0]
  4104. },
  4105. {
  4106. name: '备案',
  4107. type: 'scatter',
  4108. symbol: 'circle',//'circle', 'rect', 'roundRect', 'triangle', 'diamond', 'pin', 'arrow'
  4109. symbolSize: function (data) {
  4110. return Math.sqrt(data[2]) * 5;
  4111. },
  4112. // label: {
  4113. // emphasis: {
  4114. // show: true,
  4115. // formatter: function (param) {
  4116. // return param.data[2];
  4117. // },
  4118. // position: 'top'
  4119. // }
  4120. // },
  4121. itemStyle: {
  4122. normal: {
  4123. color: '#957DFF'
  4124. }
  4125. },
  4126. data: left13[1]
  4127. },
  4128. ]
  4129. }
  4130. let that = this
  4131. that.left7Chart.on('click', function (param) {
  4132. that.showChartLTipDouble(param.name, 'left', '项目阶段分析', '固定资产', param.name, param.seriesName, '', '', '', '', '', 216)
  4133. })
  4134. that.left7Chart.setOption(option)
  4135. tools.loopShowTooltip(that.left7Chart, option, {
  4136. nterval: 2000,
  4137. loopSeries: true,
  4138. })
  4139. },
  4140. initChartL11 () {
  4141. this.left8Chart = echarts.init(document.getElementById("echartL11"));
  4142. let option = {
  4143. title: {
  4144. text: '股权类进度分布',
  4145. textStyle: {
  4146. color: '#69C0FF',
  4147. fontSize: 30,
  4148. fontWeight: 500,
  4149. fontFamily: 'Microsoft YaHei'
  4150. },
  4151. top: '20',
  4152. left: '20'
  4153. },
  4154. textStyle: {
  4155. color: '#fff',
  4156. },
  4157. tooltip: {
  4158. trigger: "axis",
  4159. formatter: function (params) {
  4160. var tip = params[0].axisValue + '<br/>' + params[0].marker + params[0].data[1] + ':' + params[0].data[2] + '个,' + params[0].data[3] + '亿' + '<br/>' + params[1].marker + params[1].data[1] + ':' + params[1].data[2] + '个,' + params[1].data[3] + '亿';
  4161. return tip
  4162. },
  4163. textStyle: {
  4164. color: '#FFF', // 文字的颜色
  4165. fontSize: '20', // 文字字体大小
  4166. fontFamily: 'Microsoft YaHei'
  4167. },
  4168. axisPointer: {
  4169. // lineStyle: {
  4170. // type: 'dashed',
  4171. // width: 2,
  4172. // color: 'rgba(255,255,255,0.6)'
  4173. // },
  4174. animation: true
  4175. }
  4176. },
  4177. grid: {
  4178. top: '0%',
  4179. right: '5%',
  4180. left: '15%',
  4181. bottom: '-10%',
  4182. },
  4183. yAxis: {
  4184. data: ['备案', '特别监管'],
  4185. splitLine: {
  4186. show: false,
  4187. lineStyle: {
  4188. color: '#68b4dd66',
  4189. type: 'dashed',
  4190. },
  4191. },
  4192. axisLine: {
  4193. show: false
  4194. },
  4195. axisLabel: {
  4196. show: true,
  4197. formatter: '{value}',
  4198. textStyle: {
  4199. fontSize: 20,
  4200. padding: [0, -10, 0, 0],
  4201. fontFamily: 'Microsoft YaHei'
  4202. },
  4203. },
  4204. nameTextStyle: {
  4205. color: '#ebf8ac',
  4206. fontSize: 16,
  4207. fontFamily: 'Microsoft YaHei'
  4208. },
  4209. },
  4210. xAxis: {
  4211. data: ['项目储备', '项目立项', '可研论证', '投资决策'],
  4212. axisLine: {
  4213. show: true, //隐藏X轴轴线
  4214. lineStyle: {
  4215. color: '#005094',
  4216. width: 1,
  4217. },
  4218. },
  4219. axisTick: {
  4220. show: true, //隐藏X轴刻度
  4221. },
  4222. axisLabel: {
  4223. show: true,
  4224. textStyle: {
  4225. color: '#fff', //X轴文字颜色
  4226. fontSize: 20,
  4227. padding: [-320, 0, 0, 0],
  4228. fontFamily: 'Microsoft YaHei'
  4229. },
  4230. },
  4231. },
  4232. series: [
  4233. {
  4234. name: '',
  4235. type: 'scatter',
  4236. symbol: 'circle',
  4237. symbolSize: function (data) {
  4238. return Math.sqrt(data[2]) * 5;
  4239. },
  4240. // label: {
  4241. // emphasis: {
  4242. // show: true,
  4243. // formatter: function (param) {
  4244. // return param.data[2];
  4245. // },
  4246. // position: 'top'
  4247. // }
  4248. // },
  4249. itemStyle: {
  4250. normal: {
  4251. color: '#40A9FF'
  4252. }
  4253. },
  4254. data: left14[0]
  4255. },
  4256. {
  4257. name: '',
  4258. type: 'scatter',
  4259. symbol: 'circle',
  4260. symbolSize: function (data) {
  4261. return Math.sqrt(data[2]) * 5;
  4262. },
  4263. // label: {
  4264. // emphasis: {
  4265. // show: true,
  4266. // formatter: function (param) {
  4267. // return param.data[2];
  4268. // },
  4269. // position: 'top'
  4270. // }
  4271. // },
  4272. itemStyle: {
  4273. normal: {
  4274. color: '#957DFF'
  4275. }
  4276. },
  4277. data: left14[1]
  4278. },
  4279. ]
  4280. }
  4281. let that = this
  4282. that.left8Chart.on('click', function (param) {
  4283. that.showChartLTipDouble(param.name, 'left', '项目阶段分析', '股权类进度分布', param.name, param.seriesName, '', '', '', '', '', 216)
  4284. })
  4285. that.left8Chart.setOption(option)
  4286. tools.loopShowTooltip(that.left8Chart, option, {
  4287. nterval: 2000,
  4288. loopSeries: true,
  4289. })
  4290. },
  4291. // 大屏二
  4292. initChartC1 () {
  4293. if (this.centerType) {
  4294. //3D饼图
  4295. var chartData = center2
  4296. var timer = null;
  4297. var i = 0;
  4298. let that = this
  4299. var option = {
  4300. colors: ['#064F78', '#BDB35D', '#623726', '#955773', '#B57C63', '#73A88E', '#09736D', '#13400B', '#0D3265'],
  4301. chart: {
  4302. type: 'pie',
  4303. backgroundColor: 'rgba(0,0,0,0)',
  4304. options3d: {
  4305. enabled: true,
  4306. alpha: 60,
  4307. //beta: 0
  4308. },
  4309. events: {
  4310. // load,图表加载完成时触发
  4311. load: function () {
  4312. var chart = this;
  4313. var points = chart.series[0].points;
  4314. var len = points.length;
  4315. timer && clearInterval(timer);
  4316. timer = setInterval(function () {
  4317. autoTooltip(points[i]);
  4318. chartData.forEach((item, index) => {
  4319. item.sliced = false
  4320. item.selected = false
  4321. if (index == i) {
  4322. item.sliced = true
  4323. item.selected = true
  4324. }
  4325. })
  4326. that.center1Chart.update({
  4327. series: [{
  4328. type: 'pie',
  4329. name: '占比',
  4330. point: {
  4331. events: {
  4332. click: function (e) {
  4333. that.showChartLTipDouble(e.point.name, 'center', '', '', '', '', 'distribution', e.point.options.typeno, 'industry', e.point.options.typeno, 1, 112)
  4334. }
  4335. }
  4336. },
  4337. data: chartData
  4338. }]
  4339. })
  4340. i++;
  4341. if (i === len) {
  4342. i = 0;
  4343. }
  4344. }, 2000);
  4345. },
  4346. legendItemClick: function (event) {
  4347. console.log(event);
  4348. return true;
  4349. }
  4350. }
  4351. },
  4352. credits: {
  4353. enabled: false //去掉hightchats水印
  4354. },
  4355. legend: {
  4356. layout: 'vertical',
  4357. align: 'right',
  4358. y: -10,
  4359. verticalAlign: 'bottom',
  4360. itemStyle: {
  4361. fontSize: '20px',
  4362. color: '#fff',
  4363. fontWeight: 0,
  4364. fontFamily: 'Microsoft YaHei'
  4365. }
  4366. },
  4367. tooltip: {
  4368. crosshairs: true,
  4369. backgroundColor: 'rgba(0,0,0,0.5)',
  4370. useHTML: false, //开启html模式
  4371. style: {
  4372. color: '#fff',
  4373. fontSize: '20',
  4374. fontFamily: 'Microsoft YaHei'
  4375. },
  4376. formatter: function (e) {
  4377. let num = chartData[this.colorIndex].num
  4378. this.percentage = this.percentage.toFixed(2) //Math.round(this.percentage)
  4379. return `${this.key}:<b>${this.percentage}%</b><br/>投资完成额:<b>${this.y}</b>亿<br/>投资数量:<b>${num}个</b>`
  4380. },
  4381. //pointFormat:
  4382. },
  4383. plotOptions: {
  4384. pie: {
  4385. allowPointSelect: true,
  4386. showInLegend: true, // 图例
  4387. cursor: 'pointer',
  4388. size: 500,
  4389. // innerSize: 330, //环形图中间空白,0为饼图
  4390. innerSize: 0, //环形图中间空白,0为饼图
  4391. depth: 75, //立体高度
  4392. slicedOffset: 40, //动画距离
  4393. dataLabels: {
  4394. enabled: false, // 是否展示指示线
  4395. format: '{point.name}: {point.percentage}'
  4396. }
  4397. },
  4398. },
  4399. title: {
  4400. text: '',
  4401. style: {
  4402. color: '#fff',
  4403. fontSize: 24,
  4404. fontFamily: 'Microsoft YaHei'
  4405. },
  4406. align: 'center',
  4407. verticalAlign: "bottom",
  4408. x: -120
  4409. },
  4410. series: [{
  4411. type: 'pie',
  4412. name: '占比',
  4413. center: ['74%', '50%'],
  4414. point: {
  4415. events: {
  4416. click: function (e) { //点击事件
  4417. that.showChartLTipDouble(e.point.name, 'center', '', '', '', '', 'distribution', e.point.options.typeno, 'industry', e.point.options.typeno, 1, 112)
  4418. },
  4419. mouseOver: function (e) { //鼠标移入停止轮播并且找到移入的当前数据设为选中
  4420. //console.log(e)
  4421. chartData.forEach((item, index) => {
  4422. item.sliced = false
  4423. item.selected = false
  4424. })
  4425. chartData[e.target.index].sliced = true
  4426. chartData[e.target.index].selected = true
  4427. that.center1Chart.update({
  4428. series: [{
  4429. type: 'pie',
  4430. name: '占比',
  4431. point: {
  4432. events: {
  4433. click: function (e) {
  4434. that.showChartLTipDouble(e.point.name, 'center', '', '', '', '', 'distribution', e.point.options.typeno, 'industry', e.point.options.typeno, 1, 112)
  4435. }
  4436. }
  4437. },
  4438. data: chartData
  4439. }]
  4440. })
  4441. timer && clearInterval(timer);
  4442. },
  4443. mouseOut: function () { // 鼠标移出后需要继续执行轮播
  4444. var points = that.center1Chart.series[0].points;
  4445. var len = points.length;
  4446. timer && clearInterval(timer);
  4447. timer = setInterval(function () {
  4448. autoTooltip(points[i]);
  4449. chartData.forEach((item, index) => {
  4450. item.sliced = false
  4451. item.selected = false
  4452. if (index == i) {
  4453. item.sliced = true
  4454. item.selected = true
  4455. }
  4456. })
  4457. that.center1Chart.update({
  4458. series: [{
  4459. type: 'pie',
  4460. name: '占比',
  4461. point: {
  4462. events: {
  4463. click: function (e) {
  4464. that.showChartLTipDouble(e.point.name, 'center', '', '', '', '', 'distribution', e.point.options.typeno, 'industry', e.point.options.typeno, 1, 112)
  4465. }
  4466. }
  4467. },
  4468. data: chartData
  4469. }]
  4470. })
  4471. i++;
  4472. if (i === len) {
  4473. i = 0;
  4474. }
  4475. }, 2000);
  4476. }
  4477. }
  4478. },
  4479. data: chartData
  4480. }]
  4481. }
  4482. that.center1Chart = Highcharts.chart('echartC1', option);
  4483. function autoTooltip (point) {
  4484. that.center1Chart.tooltip.refresh(point);
  4485. }
  4486. } else {
  4487. let that = this
  4488. that.center1Chart = echarts.init(this.$refs['echartC1'])
  4489. data = center2
  4490. console.log(data, '??????????????????')
  4491. arrName = getArrayValue(data, "name");
  4492. arrValue = getArrayValue(data, "value");
  4493. sumValue = eval(arrValue.join("+"));
  4494. objData = array2obj(data, "name");
  4495. optionData = getData(data);
  4496. function getArrayValue (array, key) {
  4497. var key = key || "value";
  4498. var res = [];
  4499. if (array) {
  4500. array.forEach(function (t) {
  4501. res.push(t[key]);
  4502. });
  4503. }
  4504. return res;
  4505. }
  4506. function array2obj (array, key) {
  4507. var resObj = {};
  4508. for (var i = 0; i < array.length; i++) {
  4509. resObj[array[i][key]] = array[i];
  4510. }
  4511. return resObj;
  4512. }
  4513. function getData (data) {
  4514. var res = {
  4515. series: [],
  4516. yAxis: [],
  4517. };
  4518. for (let i = 0; i < data.length; i++) {
  4519. // console.log([70 - i * 15 + '%', 67 - i * 15 + '%']);
  4520. res.series.push({
  4521. name: "",
  4522. type: "pie",
  4523. clockWise: false, //顺时加载
  4524. hoverAnimation: false, //鼠标移入变大
  4525. radius: [55 - i * 15 + "%", 50 - i * 15 + "%"],
  4526. center: ["25%", "60%"],
  4527. label: {
  4528. show: false,
  4529. },
  4530. itemStyle: {
  4531. label: {
  4532. show: false,
  4533. },
  4534. labelLine: {
  4535. show: false,
  4536. },
  4537. borderWidth: 5,
  4538. },
  4539. data: [
  4540. {
  4541. value: data[i].value,
  4542. name: data[i].name,
  4543. typeno: data[i].typeno
  4544. },
  4545. {
  4546. value: sumValue - data[i].value,
  4547. name: "",
  4548. itemStyle: {
  4549. color: "rgba(0,0,0,0)",
  4550. borderWidth: 0,
  4551. },
  4552. tooltip: {
  4553. show: false,
  4554. },
  4555. hoverAnimation: false,
  4556. },
  4557. ],
  4558. });
  4559. res.series.push({
  4560. name: "",
  4561. type: "pie",
  4562. silent: true,
  4563. z: 1,
  4564. clockWise: false, //顺时加载
  4565. hoverAnimation: false, //鼠标移入变大
  4566. radius: [55 - i * 15 + "%", 50 - i * 15 + "%"],
  4567. center: ["25%", "60%"],
  4568. label: {
  4569. show: false,
  4570. },
  4571. itemStyle: {
  4572. label: {
  4573. show: false,
  4574. },
  4575. labelLine: {
  4576. show: false,
  4577. },
  4578. borderWidth: 5,
  4579. },
  4580. data: [
  4581. {
  4582. value: 7.5,
  4583. itemStyle: {
  4584. color: "#4d638050",
  4585. borderWidth: 0,
  4586. },
  4587. tooltip: {
  4588. show: false,
  4589. },
  4590. hoverAnimation: false,
  4591. },
  4592. {
  4593. value: 2.5,
  4594. name: "",
  4595. itemStyle: {
  4596. color: "rgba(0,0,0,0)",
  4597. borderWidth: 0,
  4598. },
  4599. tooltip: {
  4600. show: false,
  4601. },
  4602. hoverAnimation: false,
  4603. },
  4604. ],
  4605. });
  4606. res.yAxis.push(((data[i].value / sumValue) * 100).toFixed(2) + "%");
  4607. }
  4608. return res;
  4609. }
  4610. let option = {
  4611. // graphic: {
  4612. // elements: [{
  4613. // type: 'image',//需要填充图片,配置image,如果不需要图片可以配置其他的, text, circle, sector, ring, polygon, polyline, rect, line, bezierCurve, arc, group,
  4614. // style: {
  4615. // image: './images/loop.png', //这里添加图片地址
  4616. // width: 320,
  4617. // height: 320
  4618. // },
  4619. // left: '30',//
  4620. // top: 'middle' //配置图片居中
  4621. // }]
  4622. // },
  4623. legend: {
  4624. show: false,
  4625. trigger: 'item',
  4626. icon: "circle",
  4627. top: "center",
  4628. left: "70%",
  4629. data: arrName,
  4630. width: 50,
  4631. padding: [0, 5],
  4632. itemGap: 25,
  4633. formatter: function (data) {
  4634. let a = center2.find(item => item.name == data)
  4635. console.log(a)
  4636. // return `${data}<br/><span style="display:inline-block;border-radius:50%; width:7px;height:7px;background-color:${a.color}"></span> ${a.value}亿 <br/><span style="display:inline-block;border-radius:50%; width:7px;height:7px;background-color:${a.color}"></span> ${a.num}个`
  4637. return `${data}<br/>`
  4638. },
  4639. textStyle: {
  4640. fontSize: 20,
  4641. color: '#fff',
  4642. fontFamily: 'Microsoft YaHei'
  4643. // rich: {
  4644. // title: {
  4645. // fontSize: 14,
  4646. // lineHeight: 15,
  4647. // color: "rgb(0, 178, 246)",
  4648. // },
  4649. // value: {
  4650. // fontSize: 18,
  4651. // lineHeight: 20,
  4652. // color: "#fff",
  4653. // },
  4654. // },
  4655. },
  4656. },
  4657. // tooltip: {
  4658. // show: false,
  4659. // normal: {
  4660. // show: false,
  4661. // trigger: "item",
  4662. // label: {
  4663. // margin: 10, // label 距离轴的距离
  4664. // color: '#FFF', // 文字的颜色
  4665. // fontStyle: 'normal', // 文字字体的风格('normal',无样式;'italic',斜体;'oblique',倾斜字体)
  4666. // fontWeight: 'normal', // 文字字体的粗细('normal',无样式;'bold',加粗;'bolder',加粗的基础上再加粗;'lighter',变细;数字定义粗细也可以,取值范围100至700)
  4667. // fontSize: '20', // 文字字体大小
  4668. // lineHeight: '50', // 行高
  4669. // },
  4670. // },
  4671. // // formatter: "{a}<br>{b}:{c}({d}%)666",
  4672. // textStyle: {
  4673. // color: '#FFF', // 文字的颜色
  4674. // fontStyle: 'normal', // 文字字体的风格('normal',无样式;'italic',斜体;'oblique',倾斜字体)
  4675. // fontWeight: 'normal', // 文字字体的粗细('normal',无样式;'bold',加粗;'bolder',加粗的基础上再加粗;'lighter',变细;数字定义粗细也可以,取值范围100至700)
  4676. // },
  4677. // formatter: data => {
  4678. // console.log(data)
  4679. // // 小圆点
  4680. // return `<br /><span style="display:inline-block;border-radius:50%;margin-right:10px; width:7px;height:7px;background-color:blue"></span>${data.name}:${data.percent}`
  4681. // },
  4682. // },
  4683. color: ['#43a5f1', '#e9d443', '#5a78e0', '#955773', '#B57C63', '#73A88E', '#09736D', '#13400B', '#0D3265'],
  4684. grid: {
  4685. top: "30%",
  4686. bottom: "47%",
  4687. left: "26%",
  4688. containLabel: false,
  4689. },
  4690. yAxis: [
  4691. {
  4692. type: "category",
  4693. inverse: true,
  4694. axisLine: {
  4695. show: false,
  4696. },
  4697. axisTick: {
  4698. show: false,
  4699. },
  4700. axisLabel: {
  4701. interval: 0,
  4702. inside: true,
  4703. textStyle: {
  4704. color: "#fff",
  4705. fontSize: 20,
  4706. fontFamily: 'Microsoft YaHei'
  4707. },
  4708. show: true,
  4709. formatter: data => {
  4710. return `----- ${data}`
  4711. },
  4712. },
  4713. data: optionData.yAxis,
  4714. },
  4715. ],
  4716. xAxis: [
  4717. {
  4718. show: false,
  4719. },
  4720. ],
  4721. series: optionData.series,
  4722. }
  4723. that.center1Chart.on('click', (params) => {
  4724. that.showChartLTipDouble(params.data.name, 'center', '', '', '', '', 'distribution', params.data.typeno, 'industry', params.data.typeno, 1, 112)
  4725. })
  4726. that.center1Chart.setOption(option)
  4727. // tools.loopShowTooltip(myChart, option, {
  4728. // interval: 500,
  4729. // loopSeries: true,
  4730. // });
  4731. }
  4732. },
  4733. initChartC2 () {
  4734. let that = this
  4735. that.center2Chart = echarts.init(this.$refs['echartC2'])
  4736. that.center2Chart.on('showTip', (params) => {
  4737. // 如果是7或者15并且满足防抖则切换
  4738. if ((params.dataIndex == 5 || params.dataIndex == 11) && that.echartC2Fd) {
  4739. that.echartC2Fd = false
  4740. setTimeout(() => {
  4741. option.dataZoom[0].endValue = option.dataZoom[0].endValue + 6
  4742. option.dataZoom[0].startValue = option.dataZoom[0].startValue + 6
  4743. that.center2Chart.setOption(option);
  4744. // 防止勿刷新做的防抖
  4745. setTimeout(() => {
  4746. that.echartC2Fd = true
  4747. }, 2000)
  4748. }, 1900);
  4749. // 如果是17表示到了最后一个,那么重新来一遍
  4750. } else if (params.dataIndex == 17 && that.echartC2Fd) {
  4751. that.echartC2Fd = false
  4752. setTimeout(() => {
  4753. option.dataZoom[0].endValue = 0
  4754. option.dataZoom[0].startValue = 5
  4755. that.center2Chart.setOption(option);
  4756. // 防止勿刷新做的防抖
  4757. setTimeout(() => {
  4758. that.echartC2Fd = true
  4759. }, 2000)
  4760. }, 1900)
  4761. }
  4762. })
  4763. let option = {
  4764. tooltip: {
  4765. formatter: data => {
  4766. return `${data[0].name}<br /><span style="display:inline-block;border-radius:50%; width:7px;height:7px;background-color:${data[0].color.colorStops[0].color}"></span> ${data[0].seriesName}:${data[0].value}亿 <br/><span style="display:inline-block;border-radius:50%; width:7px;height:7px;background-color:${data[1].color.colorStops[0].color}"></span> ${data[1].seriesName}:${data[1].value}亿`
  4767. },
  4768. trigger: 'axis',
  4769. axisPointer: {
  4770. // type: 'cross',',
  4771. },
  4772. textStyle: {
  4773. color: '#FFF', // 文字的颜色
  4774. fontSize: '20', // 文字字体大小
  4775. fontFamily: 'Microsoft YaHei'
  4776. },
  4777. },
  4778. dataZoom: [
  4779. {
  4780. // start: 9,//默认为@
  4781. // end: 100,//黑认认为1@0
  4782. type: "slider",
  4783. show: false,
  4784. // xAxisIndex: [0]
  4785. handlesize: 0,//滑动条的 左右2个滑动条的大小
  4786. startValue: 5,// 初始显示值
  4787. endValue: 0,// 结束显示值
  4788. height: 10,//组件高度
  4789. left: "5%",
  4790. right: "4%",//右边的距离
  4791. bottom: "25%",//底边的距离
  4792. borderColor: "#939",
  4793. fillerColor: "#269cdb",
  4794. borderRadius: 5,
  4795. backgroundColor: "#33384b",//两边未选中的滑动条区域的额色
  4796. showDataShadow: false,//是否显示数据阴影
  4797. showDetail: false,//即拖拽时候是否显示详细数值信息
  4798. truerealtime: true,//是否实时更新
  4799. filterMode: "filter"
  4800. }, {
  4801. type: 'inside',
  4802. show: true,
  4803. start: 1,
  4804. end: 100,
  4805. zoomOnMouseWheel: false, //滚轮是否触发缩放
  4806. moveOnMouseMove: false, //鼠标滚轮触发滚动
  4807. }
  4808. ],
  4809. grid: {
  4810. top: '10%',
  4811. right: '3%',
  4812. left: '7%',
  4813. bottom: '15%',
  4814. },
  4815. legend: {
  4816. top: '1',
  4817. right: 'center',
  4818. textStyle: {
  4819. color: '#fff',
  4820. fontSize: '20',
  4821. fontFamily: 'Microsoft YaHei'
  4822. },
  4823. },
  4824. xAxis: {
  4825. data: commonCompany,
  4826. // data: center3.map(item => item.name),
  4827. axisLine: {
  4828. show: true, //隐藏X轴轴线
  4829. lineStyle: {
  4830. color: '#005094',
  4831. width: 1,
  4832. },
  4833. },
  4834. axisTick: {
  4835. show: false, //隐藏X轴刻度
  4836. },
  4837. axisLabel: {
  4838. show: true,
  4839. rotate: 40,
  4840. textStyle: {
  4841. color: '#fff',//'rgba(255,255,255,0.6)', //X轴文字颜色
  4842. fontSize: '20',
  4843. fontFamily: 'Microsoft YaHei'
  4844. },
  4845. },
  4846. },
  4847. yAxis: [
  4848. {
  4849. type: 'value',
  4850. name: '亿',
  4851. splitLine: {
  4852. show: true,
  4853. lineStyle: {
  4854. color: '#68b4dd66',
  4855. type: 'dashed',
  4856. },
  4857. },
  4858. axisLine: {
  4859. show: true,
  4860. lineStyle: {
  4861. color: '#3D7495',
  4862. },
  4863. },
  4864. axisLabel: {
  4865. show: true,
  4866. textStyle: {
  4867. color: '#fff',
  4868. fontSize: '20',
  4869. fontFamily: 'Microsoft YaHei'
  4870. },
  4871. },
  4872. nameTextStyle: {
  4873. color: '#fff',
  4874. fontSize: 20,
  4875. fontFamily: 'Microsoft YaHei'
  4876. },
  4877. },
  4878. ],
  4879. series: [
  4880. {
  4881. name: '计划投资',
  4882. type: 'bar',
  4883. barWidth: 10,
  4884. itemStyle: {
  4885. normal: {
  4886. color: new echarts.graphic.LinearGradient(0, 0, 0, 1, [
  4887. {
  4888. offset: 0,
  4889. color: '#69c0ff',
  4890. },
  4891. {
  4892. offset: 1,
  4893. color: '#082550',
  4894. },
  4895. ]),
  4896. },
  4897. },
  4898. data: center3.map(item => item.value),
  4899. },
  4900. {
  4901. name: '实际投资',
  4902. type: 'bar',
  4903. barWidth: 10,
  4904. itemStyle: {
  4905. normal: {
  4906. color: new echarts.graphic.LinearGradient(0, 0, 0, 1, [
  4907. {
  4908. offset: 0,
  4909. color: '#957DFF',
  4910. },
  4911. {
  4912. offset: 1,
  4913. color: '#082550',
  4914. },
  4915. ]),
  4916. },
  4917. },
  4918. data: center3.map(item => item.value2),
  4919. },
  4920. ],
  4921. }
  4922. that.center2Chart.on('click', function (param) {
  4923. that.projectListTipShow = true
  4924. param.seriesName == '计划投资' ? that.projectNum = 1131 : that.projectNum = 1132
  4925. that.centerPenetrateTwo('', '', that.findCode(param.name), param.seriesName == '计划投资' ? 2 : 1)
  4926. })
  4927. that.center2Chart.setOption(option)
  4928. tools.loopShowTooltip(that.center2Chart, option, {
  4929. nterval: 2000,
  4930. loopSeries: true,
  4931. })
  4932. // let arr = center3.map(item => item.value2)
  4933. // this.timeOut = setInterval(function () {
  4934. // let startValue = myChart.getModel().option.dataZoom[0].startValue;
  4935. // let endValue = myChart.getModel().option.dataZoom[0].endValue;
  4936. // let start = myChart.getModel().option.xAxis[0].data[startValue];//起始X轴
  4937. // let end = myChart.getModel().option.xAxis[0].data[endValue];//结束X轴
  4938. // // 每次向后滚动一个,最后一个从头开始。
  4939. // // console.log(option.dataZoom[0].endValue);
  4940. // if (option.dataZoom[0].endValue >= 12) {
  4941. // option.dataZoom[0].endValue = 5
  4942. // option.dataZoom[0].startValue = 0
  4943. // } else {
  4944. // option.dataZoom[0].endValue = option.dataZoom[0].endValue + 6
  4945. // option.dataZoom[0].startValue = option.dataZoom[0].startValue + 6
  4946. // }
  4947. // // myChart.dispatchAction({
  4948. // // type: 'showTip',
  4949. // // seriesIndex: 0,
  4950. // // dataIndex: startValue +1,
  4951. // // });
  4952. // myChart.setOption(option);
  4953. // }, 12000);
  4954. },
  4955. convertData (data) {
  4956. var res = []
  4957. for (var i = 0; i < data.length; i++) {
  4958. var geoCoord = this.geoCoordMap[data[i].name]
  4959. if (geoCoord) {
  4960. res.push({
  4961. name: data[i].name,
  4962. value: geoCoord.concat(data[i].value),
  4963. })
  4964. }
  4965. }
  4966. return res
  4967. },
  4968. yuanChange (value) {
  4969. return Number((value / 100000000).toFixed(2))
  4970. },
  4971. // 逢三折断
  4972. numFormat (value) {
  4973. if (!value) return '0'
  4974. // var intPart = Number(value).toFixed(0) // 获取整数部分
  4975. var intPart = parseInt(value)// 获取整数部分
  4976. var intPartFormat = intPart.toString().replace(/(\d)(?=(?:\d{3})+$)/g, '$1,') // 将整数部分逢三一断
  4977. var floatPart = '.00' // 预定义小数部分
  4978. var value2Array = value.toString().split('.')
  4979. // =2表示数据有小数位
  4980. if (value2Array.length === 2) {
  4981. floatPart = value2Array[1].toString() // 拿到小数部分
  4982. if (floatPart.length === 1) {
  4983. // 补0
  4984. return intPartFormat + '.' + floatPart + '0'
  4985. } else {
  4986. return intPartFormat + '.' + floatPart
  4987. }
  4988. } else {
  4989. return intPartFormat
  4990. }
  4991. },
  4992. initProvinceChart () {
  4993. var data = center5
  4994. this.geoCoordMap = []
  4995. /*获取地图数据*/
  4996. this.mapChart = echarts.init(this.$refs['echarts-map'])
  4997. echarts.registerMap('shanxi', shanxi)
  4998. var mapFeatures = echarts.getMap('shanxi').geoJson.features
  4999. mapFeatures.forEach(v => {
  5000. // 地区名称
  5001. var name = v.properties.name
  5002. // 地区经纬度
  5003. this.geoCoordMap[name] = v.properties.centroid
  5004. // 按照地图乱序
  5005. // data.push({ name: v.properties.name, value: v.properties.centroid[0], value2: v.properties.centroid[1] })
  5006. })
  5007. let option = {
  5008. tooltip: {
  5009. padding: 15,
  5010. enterable: true,
  5011. transitionDuration: 1,
  5012. formatter: (params, ticket, callback) => {
  5013. // 清空所有轮播
  5014. for (var k in this.geoCoordMap) {
  5015. this.mapChart.dispatchAction({
  5016. // type: 'geoUnSelect',
  5017. type: 'downplay',
  5018. name: k,
  5019. })
  5020. }
  5021. // 如果鼠标滑动到线线上面,则返回空
  5022. this.mapChart.dispatchAction({
  5023. // type: 'geoSelect',
  5024. type: 'highlight',
  5025. name: params.name,
  5026. })
  5027. if (params.componentSubType == 'lines') {
  5028. return
  5029. }
  5030. if (params.componentSubType == 'scatter') {
  5031. let tipHtml = `
  5032. <div class="tooltip-cont">
  5033. <p>项目数量:<span>${data[params.dataIndex].value2}个</span></p>
  5034. <p>总投资额:<span>${params.data.value[2]}亿</span></p>
  5035. </div>`
  5036. callback(ticket, tipHtml)
  5037. return tipHtml
  5038. }
  5039. if (params.componentSubType == 'map') {
  5040. let tipHtml = `
  5041. <div class="tooltip-cont">
  5042. <p>项目数量:<span>${data[params.dataIndex].value2}个</span></p>
  5043. <p>总投资额:<span>${params.data.value}亿</span></p>
  5044. </div>`
  5045. callback(ticket, tipHtml)
  5046. return tipHtml
  5047. }
  5048. },
  5049. },
  5050. visualMap: {
  5051. show: false,
  5052. min: 0,
  5053. max: 300,
  5054. right: 0,
  5055. bottom: 0,
  5056. text: ['高', '低'],
  5057. textStyle: {
  5058. color: '#f1f1f1'
  5059. },
  5060. realtime: false,
  5061. calculable: false,
  5062. inRange: {
  5063. color: ['lightskyblue', '#2754b7']
  5064. }
  5065. },
  5066. geo: {
  5067. show: true,
  5068. map: 'shanxi',
  5069. layoutCenter: ['50%', '50%'], //地图位置
  5070. layoutSize: '140%',
  5071. label: {
  5072. normal: {
  5073. position: [100, 100],
  5074. fontSize: 25,
  5075. fontFamily: 'Microsoft YaHei',
  5076. fontWeight: 600,
  5077. color: '#fff',
  5078. show: true,
  5079. },
  5080. emphasis: {
  5081. show: true,
  5082. color: '#e7e1a0',
  5083. fontSize: 30,
  5084. },
  5085. },
  5086. roam: false,
  5087. itemStyle: {
  5088. normal: {
  5089. areaColor: '#1946a8',
  5090. shadowColor: '#1946a8',
  5091. borderWidth: 2, //设置外层边框
  5092. borderColor: '#1946a8',
  5093. shadowOffsetX: 0,
  5094. shadowOffsetY: 0,
  5095. shadowBlur: 0,
  5096. },
  5097. emphasis: {
  5098. areaColor: '#013d95',
  5099. borderColor: '#e7e1a0',
  5100. borderWidth: 4, //设置外层边框
  5101. },
  5102. },
  5103. },
  5104. series: [
  5105. {
  5106. type: 'map',
  5107. map: 'shanxi',
  5108. geoIndex: 0,
  5109. aspectScale: 1.5, //长宽比
  5110. data: data,
  5111. },
  5112. ],
  5113. }
  5114. let that = this
  5115. this.mapChart.on('click', function (params) {
  5116. if (params.name == '太原市') {
  5117. that.showChartLTipDouble(params.name, 'center', '', '', '', '', 'investmentMap', '太原市', '山西省', '', '', 118)
  5118. }
  5119. })
  5120. tools.loopShowTooltip(this.mapChart, option, {
  5121. interval: 2000,
  5122. loopSeries: false,
  5123. });
  5124. this.mapChart.setOption(option)
  5125. },
  5126. initChinaChart () {
  5127. var data = centerChina
  5128. this.geoCoordMap = []
  5129. /*获取地图数据*/
  5130. this.mapChart = echarts.init(this.$refs['chinaMap'])
  5131. echarts.registerMap('china', china)
  5132. var mapFeatures = echarts.getMap('china').geoJson.features
  5133. mapFeatures.forEach(v => {
  5134. // 地区名称
  5135. var name = v.properties.name
  5136. // 地区经纬度
  5137. this.geoCoordMap[name] = v.properties.cp
  5138. data.push({ name: v.properties.name, value: v.properties.cp[0], value2: v.properties.cp[1] })
  5139. })
  5140. let option = {
  5141. tooltip: {
  5142. padding: 15,
  5143. enterable: true,
  5144. transitionDuration: 1,
  5145. formatter: (params, ticket, callback) => {
  5146. // 清空所有轮播
  5147. this.mapChart.dispatchAction({
  5148. // type: 'geoUnSelect',
  5149. type: 'downplay',
  5150. name: '南海诸岛',
  5151. })
  5152. for (var k in this.geoCoordMap) {
  5153. this.mapChart.dispatchAction({
  5154. // type: 'geoUnSelect',
  5155. type: 'downplay',
  5156. name: k,
  5157. })
  5158. }
  5159. // 如果鼠标滑动到线线上面,则返回空
  5160. this.mapChart.dispatchAction({
  5161. // type: 'geoSelect',
  5162. type: 'highlight',
  5163. name: params.name,
  5164. })
  5165. if (params.componentSubType == 'lines') {
  5166. return
  5167. }
  5168. if (params.componentSubType == 'scatter') {
  5169. let tipHtml = `
  5170. <div class="tooltip-cont">
  5171. <p>项目数量:<span>${data[params.dataIndex].value2}个</span></p>
  5172. <p>总投资额:<span>${params.data.value[2]}亿</span></p>
  5173. </div>`
  5174. callback(ticket, tipHtml)
  5175. return tipHtml
  5176. }
  5177. if (params.componentSubType == 'map') {
  5178. let tipHtml = `
  5179. <div class="tooltip-cont">
  5180. <p>项目数量:<span>${data[params.dataIndex].value2}个</span></p>
  5181. <p>总投资额:<span>${params.data.value}亿</span></p>
  5182. </div>`
  5183. callback(ticket, tipHtml)
  5184. return tipHtml
  5185. }
  5186. },
  5187. },
  5188. visualMap: {
  5189. show: false,
  5190. min: 0,
  5191. max: 1000,
  5192. left: '100',
  5193. bottom: 100,
  5194. text: ['高', '低'],
  5195. textStyle: {
  5196. color: '#f1f1f1'
  5197. },
  5198. realtime: true, //拖拽时,是否实时更新
  5199. calculable: false,
  5200. inRange: {
  5201. color: ['lightskyblue', '#2754b7']
  5202. },
  5203. itemWidth: 50, //图形的宽度,即长条的宽度。
  5204. itemHeight: 400, //图形的高度,即长条的高度。
  5205. textStyle: {
  5206. fontSize: 30,
  5207. color: '#fff'
  5208. }
  5209. },
  5210. geo: {
  5211. show: true,
  5212. map: 'china',
  5213. layoutCenter: ['50%', '50%'], //地图位置
  5214. layoutSize: '110%',
  5215. label: {
  5216. normal: {
  5217. position: [100, 100],
  5218. fontSize: 25,
  5219. fontFamily: 'Microsoft YaHei',
  5220. fontWeight: 600,
  5221. color: '#fff',
  5222. show: true,
  5223. },
  5224. emphasis: {
  5225. show: true,
  5226. color: '#e7e1a0',
  5227. fontSize: 30,
  5228. },
  5229. },
  5230. // 滑轮缩放
  5231. roam: false,
  5232. itemStyle: {
  5233. normal: {
  5234. areaColor: '#1946a8',
  5235. shadowColor: '#1946a8',
  5236. borderWidth: 2, //设置外层边框
  5237. borderColor: '#0b245b',
  5238. shadowOffsetX: 0,
  5239. shadowOffsetY: 0,
  5240. shadowBlur: 0,
  5241. },
  5242. emphasis: {
  5243. areaColor: '#013d95',
  5244. borderColor: '#e7e1a0',
  5245. borderWidth: 4, //设置外层边框
  5246. },
  5247. },
  5248. },
  5249. series: [
  5250. {
  5251. type: 'map',
  5252. map: 'china',
  5253. geoIndex: 0,
  5254. data: data,
  5255. },
  5256. ],
  5257. }
  5258. let that = this
  5259. this.mapChart.on('click', function (params) {
  5260. if (params.name == '山西') {
  5261. // that.showChartLTipDouble(params.name, 'center', '', '', '', '', '', 'investmentMap', '山西省')
  5262. that.mapChart.dispose()
  5263. that.centerShow = true
  5264. setTimeout(() => {
  5265. that.initChartC1()
  5266. that.initChartC2()
  5267. that.initChartC3()
  5268. that.initChartC4()
  5269. if (that.versions) {
  5270. that.centerPenetrateOne('investmentMap', params.name, 3, '', '')
  5271. } else {
  5272. that.initProvinceChart()
  5273. }
  5274. that.initProjectList()
  5275. })
  5276. }
  5277. })
  5278. tools.loopShowTooltip(this.mapChart, option, {
  5279. interval: 2000,
  5280. loopSeries: false,
  5281. });
  5282. this.mapChart.setOption(option)
  5283. },
  5284. initChartC3 () {
  5285. this.center3Chart = echarts.init(this.$refs['echartC3'])
  5286. let option = {
  5287. tooltip: {
  5288. trigger: 'axis',
  5289. formatter: '{a0}:{c0}' + '亿', //+ '<br/>'+ '{a1}:{c1}' + '%',
  5290. axisPointer: {
  5291. // type: 'cross',',
  5292. },
  5293. textStyle: {
  5294. color: '#FFF', // 文字的颜色
  5295. fontSize: '20', // 文字字体大小
  5296. fontFamily: 'Microsoft YaHei'
  5297. },
  5298. },
  5299. grid: {
  5300. top: '8%',
  5301. right: '3%',
  5302. left: '7%',
  5303. bottom: '10%',
  5304. },
  5305. // legend: {
  5306. // top: '1',
  5307. // textStyle: {
  5308. // color: 'rgba(250,250,250,0.6)',
  5309. // },
  5310. // },
  5311. xAxis: {
  5312. data: center6.map(item => item.name),
  5313. axisLine: {
  5314. show: true, //隐藏X轴轴线
  5315. lineStyle: {
  5316. color: '#005094',
  5317. width: 1,
  5318. },
  5319. },
  5320. axisTick: {
  5321. show: false, //隐藏X轴刻度
  5322. },
  5323. axisLabel: {
  5324. show: true,
  5325. rotate: 20,
  5326. textStyle: {
  5327. color: '#fff',//'rgba(255,255,255,0.6)', //X轴文字颜色
  5328. fontSize: '20',
  5329. fontFamily: 'Microsoft YaHei'
  5330. },
  5331. },
  5332. },
  5333. yAxis: [
  5334. {
  5335. type: 'value',
  5336. name: '亿',
  5337. splitLine: {
  5338. show: true,
  5339. lineStyle: {
  5340. color: '#68b4dd66',
  5341. type: 'dashed',
  5342. },
  5343. },
  5344. axisLine: {
  5345. show: true,
  5346. lineStyle: {
  5347. color: '#3D7495',
  5348. },
  5349. },
  5350. axisLabel: {
  5351. show: true,
  5352. textStyle: {
  5353. color: '#fff',
  5354. fontSize: '20',
  5355. fontFamily: 'Microsoft YaHei'
  5356. },
  5357. },
  5358. nameTextStyle: {
  5359. color: '#fff',
  5360. fontSize: 20,
  5361. fontFamily: 'Microsoft YaHei'
  5362. },
  5363. },
  5364. {
  5365. type: 'value',
  5366. axisLine: {
  5367. show: false,
  5368. },
  5369. splitLine: {
  5370. show: false,
  5371. },
  5372. axisLabel: {
  5373. show: true,
  5374. formatter: '{value} %',
  5375. textStyle: {
  5376. color: 'rgba(250,250,250,0.6)',
  5377. fontFamily: 'Microsoft YaHei'
  5378. },
  5379. },
  5380. },
  5381. ],
  5382. series: [
  5383. {
  5384. type: 'bar',
  5385. name: '投资金额',
  5386. barWidth: 15,
  5387. itemStyle: {
  5388. normal: {
  5389. color: new echarts.graphic.LinearGradient(0, 0, 0, 1, [
  5390. {
  5391. offset: 0,
  5392. color: '#69c0ff',
  5393. },
  5394. {
  5395. offset: 1,
  5396. color: '#082550',
  5397. },
  5398. ]),
  5399. },
  5400. },
  5401. data: center6.map(item => item.value),
  5402. },
  5403. ],
  5404. }
  5405. let that = this
  5406. that.center3Chart.on('click', function (param) {
  5407. if (param.name == '煤炭和煤电') {
  5408. that.showChartLTipSingle(param.name, 'center', 'keyIndicators', 'ceiamount', '', '', '', '', 'five', '1', 2, 115)
  5409. } else if (param.name == '煤电和新能源') {
  5410. that.showChartLTipSingle(param.name, 'center', 'keyIndicators', 'cpneiamount', '', '', '', '', 'five', '2', 2, 115)
  5411. } else if (param.name == '煤炭和化工') {
  5412. that.showChartLTipSingle(param.name, 'center', 'keyIndicators', 'ccheiamount', '', '', '', '', 'five', '3', 2, 115)
  5413. } else if (param.name == '煤炭和数字') {
  5414. that.showChartLTipSingle(param.name, 'center', 'keyIndicators', 'cdiamount', '', '', '', '', 'five', '4', 2, 115)
  5415. } else if (param.name == '煤炭和降炭') {
  5416. that.showChartLTipSingle(param.name, 'center', 'keyIndicators', 'cciamount', '', '', '', '', 'five', '5', 2, 115)
  5417. }
  5418. })
  5419. that.center3Chart.setOption(option)
  5420. tools.loopShowTooltip(that.center3Chart, option, {
  5421. nterval: 2000,
  5422. loopSeries: true,
  5423. })
  5424. },
  5425. initChartC4 () {
  5426. let that = this
  5427. if (this.centerType) {
  5428. // 3D饼图
  5429. var chartData = []
  5430. var timer = null;
  5431. var timer2 = null;
  5432. var i = 0;
  5433. center7.forEach((item, index) => {
  5434. let obj = {
  5435. name: item.name,
  5436. y: item.value2,
  5437. num: item.value,
  5438. typeno: item.typeno,
  5439. sliced: false,
  5440. selected: false,
  5441. color: index == 0 ? '#064F78' : '#BDB35D'
  5442. }
  5443. chartData.push(obj)
  5444. })
  5445. let that = this
  5446. that.center4Chart = Highcharts.chart('echartC4', {
  5447. chart: {
  5448. type: 'pie',
  5449. backgroundColor: 'rgba(0,0,0,0)',
  5450. options3d: {
  5451. enabled: true,
  5452. alpha: 60,
  5453. //beta: 0
  5454. },
  5455. events: {
  5456. // load,图表加载完成时触发
  5457. load: function () {
  5458. var chart = this;
  5459. var points = chart.series[0].points;
  5460. var len = points.length;
  5461. timer && clearInterval(timer);
  5462. timer = setInterval(function () {
  5463. autoTooltip(points[i]);
  5464. chartData.forEach((item, index) => {
  5465. item.sliced = false
  5466. item.selected = false
  5467. if (index == i) {
  5468. item.sliced = true
  5469. item.selected = true
  5470. }
  5471. })
  5472. that.center4Chart.update({
  5473. series: [{
  5474. type: 'pie',
  5475. name: '占比',
  5476. point: {
  5477. events: {
  5478. click: function (e) {
  5479. that.showChartLTipDouble(e.point.name, 'center', '', '', '', '', 'keyIndicators', e.point.options.typeno, 'state', e.point.name == '新建' ? 'new' : 'renew', 1, 116)
  5480. }
  5481. }
  5482. },
  5483. data: chartData
  5484. }]
  5485. })
  5486. i++;
  5487. if (i === len) {
  5488. i = 0;
  5489. chartData.forEach((item, index) => {
  5490. item.sliced = false
  5491. item.selected = false
  5492. })
  5493. that.center4Chart.update({
  5494. series: [{
  5495. type: 'pie',
  5496. name: '占比',
  5497. point: {
  5498. events: {
  5499. click: function (e) {
  5500. that.showChartLTipDouble(e.point.name, 'center', '', '', '', '', 'keyIndicators', e.point.options.typeno, 'state', e.point.name == '新建' ? 'new' : 'renew', 1, 116)
  5501. }
  5502. }
  5503. },
  5504. data: chartData
  5505. }]
  5506. })
  5507. }
  5508. }, 2000);
  5509. },
  5510. legendItemClick: function (event) {
  5511. console.log(event);
  5512. return true;
  5513. }
  5514. }
  5515. },
  5516. credits: {
  5517. enabled: false //去掉hightchats水印
  5518. },
  5519. title: {
  5520. text: null
  5521. },
  5522. tooltip: {
  5523. crosshairs: true,
  5524. backgroundColor: 'rgba(0,0,0,0.5)',
  5525. // positioner: function(e){
  5526. // console.log(e, this)
  5527. // },
  5528. useHTML: false, //开启html模式
  5529. style: {
  5530. color: '#fff',
  5531. fontSize: '20',
  5532. fontFamily: 'Microsoft YaHei'
  5533. },
  5534. formatter: function (e) {
  5535. //console.log(this)
  5536. let num = chartData[this.colorIndex].num
  5537. this.percentage = Math.round(this.percentage)
  5538. return `${this.key}:<b>${this.percentage}%</b><br/>投资完成额:<b>${this.y}</b>亿<br/>投资数量:<b>${num}个</b>`
  5539. },
  5540. //pointFormat:
  5541. },
  5542. legend: {
  5543. layout: 'vertical',
  5544. align: 'right',
  5545. y: -10,
  5546. verticalAlign: 'bottom',
  5547. itemStyle: {
  5548. fontSize: '20px',
  5549. color: '#fff',
  5550. fontWeight: 0,
  5551. fontFamily: 'Microsoft YaHei'
  5552. }
  5553. },
  5554. plotOptions: {
  5555. pie: {
  5556. allowPointSelect: true,
  5557. showInLegend: true, // 图例
  5558. cursor: 'pointer',
  5559. size: 500,
  5560. // innerSize: 330, //环形图中间空白,0为饼图
  5561. innerSize: 0, //环形图中间空白,0为饼图
  5562. depth: 75, //立体高度
  5563. slicedOffset: 40, //动画距离
  5564. dataLabels: {
  5565. enabled: false, // 是否展示指示线
  5566. format: '{point.name}: {point.percentage}'
  5567. }
  5568. },
  5569. },
  5570. series: [{
  5571. type: 'pie',
  5572. name: '占比',
  5573. center: ['60%', '50%'],
  5574. y: -10,
  5575. point: {
  5576. events: {
  5577. click: function (e) { //点击事件
  5578. that.showChartLTipDouble(e.point.name, 'center', '', '', '', '', 'keyIndicators', e.point.options.typeno, 'state', e.point.name == '新建' ? 'new' : 'renew', 1, 116)
  5579. },
  5580. mouseOver: function (e) { //鼠标移入停止轮播并且找到移入的当前数据设为选中
  5581. //console.log(e)
  5582. chartData.forEach((item, index) => {
  5583. item.sliced = false
  5584. item.selected = false
  5585. })
  5586. chartData[e.target.index].sliced = true
  5587. chartData[e.target.index].selected = true
  5588. that.center4Chart.update({
  5589. series: [{
  5590. type: 'pie',
  5591. name: '占比',
  5592. point: {
  5593. events: {
  5594. click: function (e) {
  5595. that.showChartLTipDouble(e.point.name, 'center', '', '', '', '', 'keyIndicators', e.point.options.typeno, 'state', e.point.name == '新建' ? 'new' : 'renew', 1, 116)
  5596. }
  5597. }
  5598. },
  5599. data: chartData
  5600. }]
  5601. })
  5602. timer && clearInterval(timer);
  5603. },
  5604. mouseOut: function () { // 鼠标移出后需要继续执行轮播
  5605. var points = that.center4Chart.series[0].points;
  5606. var len = points.length;
  5607. timer && clearInterval(timer);
  5608. timer = setInterval(function () {
  5609. autoTooltip(points[i]);
  5610. chartData.forEach((item, index) => {
  5611. item.sliced = false
  5612. item.selected = false
  5613. if (index == i) {
  5614. item.sliced = true
  5615. item.selected = true
  5616. }
  5617. })
  5618. that.center4Chart.update({
  5619. series: [{
  5620. type: 'pie',
  5621. name: '占比',
  5622. point: {
  5623. events: {
  5624. click: function (e) {
  5625. that.showChartLTipDouble(e.point.name, 'center', '', '', '', '', 'keyIndicators', e.point.options.typeno, 'state', e.point.name == '新建' ? 'new' : 'renew', 1, 116)
  5626. }
  5627. }
  5628. },
  5629. data: chartData
  5630. }]
  5631. })
  5632. i++;
  5633. if (i === len) {
  5634. i = 0;
  5635. chartData.forEach((item, index) => {
  5636. item.sliced = false
  5637. item.selected = false
  5638. })
  5639. that.center4Chart.update({
  5640. series: [{
  5641. type: 'pie',
  5642. name: '占比',
  5643. point: {
  5644. events: {
  5645. click: function (e) {
  5646. that.showChartLTipDouble(e.point.name, 'center', '', '', '', '', 'keyIndicators', e.point.options.typeno, 'state', e.point.name == '新建' ? 'new' : 'renew', 1, 116)
  5647. }
  5648. }
  5649. },
  5650. data: chartData
  5651. }]
  5652. })
  5653. }
  5654. }, 2000);
  5655. }
  5656. }
  5657. },
  5658. data: chartData
  5659. }]
  5660. });
  5661. function autoTooltip (point) {
  5662. that.center4Chart.tooltip.refresh(point);
  5663. }
  5664. } else {
  5665. that.center4Chart = echarts.init(this.$refs['echartC4'])
  5666. const base64_1 =
  5667. ''
  5668. const base64_2 =
  5669. ''
  5670. const base64_3 =
  5671. ''
  5672. const base64_4 =
  5673. ''
  5674. const chartData = [62, 0, 86, 825, 2672];
  5675. const xAxisData = ['新建-投资完成额', '续建-投资完成额', '新建-项目数量', '续建-项目数量'];
  5676. option = {
  5677. tooltip: {
  5678. trigger: 'item',
  5679. },
  5680. tooltip: {
  5681. show: false,
  5682. formatter: function (params) {
  5683. return `${params.name}:${chartData[params.dataIndex]}`;
  5684. }
  5685. },
  5686. xAxis: {
  5687. show: false,
  5688. data: xAxisData,
  5689. axisTick: {
  5690. show: false
  5691. },
  5692. axisLabel: {
  5693. color: '#5EA2ED',
  5694. interval: 0
  5695. },
  5696. axisLine: {
  5697. lineStyle: {
  5698. color: '#1B5BBA'
  5699. }
  5700. }
  5701. },
  5702. yAxis: {
  5703. show: false,
  5704. splitLine: { show: false },
  5705. axisLine: {
  5706. lineStyle: {
  5707. color: '#1B5BBA'
  5708. }
  5709. },
  5710. axisLabel: {
  5711. color: '#5EA2ED',
  5712. interval: 0
  5713. }
  5714. },
  5715. series: [
  5716. {
  5717. type: 'pictorialBar',
  5718. data: [
  5719. {
  5720. name: '新建-投资完成额',
  5721. z: 100,
  5722. value: 120,
  5723. value2: center7[0].typeno,
  5724. symbolSize: [115, 100],
  5725. symbolPosition: 'center',
  5726. symbolOffset: [90, -130],
  5727. symbol: 'image://' + base64_1
  5728. },
  5729. {
  5730. name: '续建-投资完成额',
  5731. z: 90,
  5732. value: 57,
  5733. symbolSize: [200, 112],
  5734. symbolPosition: 'center',
  5735. symbolOffset: [-53, -173],
  5736. symbol: 'image://' + base64_2
  5737. },
  5738. {
  5739. name: '新建-项目数量',
  5740. z: 80,
  5741. value: 42,
  5742. symbolSize: [295, 145],
  5743. symbolPosition: 'center',
  5744. symbolOffset: [-196, -135],
  5745. symbol: 'image://' + base64_3
  5746. },
  5747. {
  5748. name: '续建-项目数量',
  5749. z: 70,
  5750. value: 27,
  5751. symbolSize: [480, 500],
  5752. symbolPosition: 'center',
  5753. symbolOffset: [-340, -170],
  5754. symbol: 'image://' + base64_4
  5755. }
  5756. ]
  5757. }
  5758. ]
  5759. };
  5760. that.center4Chart.on('click', (params) => {
  5761. that.showChartLTipDouble(params.name, 'center', '', '', '', '', 'keyIndicators', params.value2, 'state', params.value2 == '新建' ? 'new' : 'renew', 1, 116)
  5762. })
  5763. that.center4Chart.setOption(option)
  5764. tools.loopShowTooltip(that.center4Chart, option, {
  5765. nterval: 2000,
  5766. loopSeries: true,
  5767. });
  5768. }
  5769. },
  5770. initProjectList () {
  5771. let dataList = []
  5772. console.log(center8, '?????????')
  5773. center8.map(item => {
  5774. if (this.versions) {
  5775. dataList.push([item.office, item.name, this.yuanChange(item.value) + '亿', item.typeno])
  5776. } else {
  5777. dataList.push([item.office, item.name, item.value + '亿'])
  5778. }
  5779. })
  5780. this.storageRecordConfig2.data = dataList
  5781. this.storageRecordConfig2 = { ...this.storageRecordConfig2 }
  5782. },
  5783. // 大屏三
  5784. initChartR1 () {
  5785. let that = this
  5786. that.right1Chart = echarts.init(this.$refs['echartR1'])
  5787. that.right1Chart.on('showTip', (params) => {
  5788. // 如果是7或者15并且满足防抖则切换
  5789. if ((params.dataIndex == 5 || params.dataIndex == 11) && that.echartR1Fd) {
  5790. that.echartR1Fd = false
  5791. setTimeout(() => {
  5792. option.dataZoom[0].endValue = option.dataZoom[0].endValue + 6
  5793. option.dataZoom[0].startValue = option.dataZoom[0].startValue + 6
  5794. that.right1Chart.setOption(option);
  5795. // 防止勿刷新做的防抖
  5796. setTimeout(() => {
  5797. that.echartR1Fd = true
  5798. }, 2000)
  5799. }, 1900);
  5800. // 如果是17表示到了最后一个,那么重新来一遍
  5801. } else if (params.dataIndex == 17 && that.echartR1Fd) {
  5802. that.echartR1Fd = false
  5803. setTimeout(() => {
  5804. option.dataZoom[0].endValue = 0
  5805. option.dataZoom[0].startValue = 5
  5806. that.right1Chart.setOption(option);
  5807. // 防止勿刷新做的防抖
  5808. setTimeout(() => {
  5809. that.echartR1Fd = true
  5810. }, 2000)
  5811. }, 1900)
  5812. }
  5813. })
  5814. let option = {
  5815. tooltip: {
  5816. formatter: data => {
  5817. return `${data[0].name}<br /><span style="display:inline-block;border-radius:50%; width:7px;height:7px;background-color:${data[0].color.colorStops[0].color}"></span> ${data[0].seriesName}:${data[0].value}亿<br/><span style="display:inline-block;border-radius:50%; width:7px;height:7px;background-color:${data[1].color.colorStops[0].color}"></span> ${data[1].seriesName}:${data[1].value}亿<br/><span style="display:inline-block;border-radius:50%; width:7px;height:7px;background-color:${data[2].color.colorStops[0].color}"></span> ${data[2].seriesName}:${data[2].value}亿<br/><span style="display:inline-block;border-radius:50%; width:7px;height:7px;background-color:${data[3].color.colorStops[0].color}"></span> ${data[3].seriesName}:${data[3].value}亿<br/><span style="display:inline-block;border-radius:50%; width:7px;height:7px;background-color:${data[4].color.colorStops[0].color}"></span> ${data[4].seriesName}:${data[4].value}亿`
  5818. },
  5819. textStyle: {
  5820. color: '#FFF', // 文字的颜色
  5821. fontSize: '20', // 文字字体大小
  5822. fontFamily: 'Microsoft YaHei'
  5823. },
  5824. trigger: 'axis',
  5825. axisPointer: {
  5826. // type: 'cross',',
  5827. },
  5828. },
  5829. dataZoom: [
  5830. {
  5831. // start: 9,//默认为@
  5832. // end: 100,//黑认认为1@0
  5833. type: "slider",
  5834. show: false,
  5835. // xAxisIndex: [0]
  5836. handlesize: 0,//滑动条的 左右2个滑动条的大小
  5837. startValue: 5,// 初始显示值
  5838. endValue: 0,// 结束显示值
  5839. height: 10,//组件高度
  5840. left: "5%",
  5841. right: "4%",//右边的距离
  5842. bottom: "25%",//底边的距离
  5843. borderColor: "#939",
  5844. fillerColor: "#269cdb",
  5845. borderRadius: 5,
  5846. backgroundColor: "#33384b",//两边未选中的滑动条区域的额色
  5847. showDataShadow: false,//是否显示数据阴影
  5848. showDetail: false,//即拖拽时候是否显示详细数值信息
  5849. truerealtime: true,//是否实时更新
  5850. filterMode: "filter"
  5851. }, {
  5852. type: 'inside',
  5853. show: true,
  5854. start: 1,
  5855. end: 100,
  5856. zoomOnMouseWheel: false, //滚轮是否触发缩放
  5857. moveOnMouseMove: false, //鼠标滚轮触发滚动
  5858. }
  5859. ],
  5860. grid: {
  5861. top: '10%',
  5862. right: '3%',
  5863. left: '5%',
  5864. bottom: '5%',
  5865. },
  5866. legend: {
  5867. data: ["预算额", "已签合同额", '产值认定额', '结算额', '付款额'],
  5868. x: 'center',
  5869. y: '0px',
  5870. textStyle: {
  5871. color: '#fff',
  5872. fontSize: "20",
  5873. fontFamily: 'Microsoft YaHei'
  5874. },
  5875. },
  5876. xAxis: {
  5877. data: commonCompany,
  5878. // data: right4.map(item => item.name),
  5879. axisLine: {
  5880. show: true, //隐藏X轴轴线
  5881. lineStyle: {
  5882. color: '#005094',
  5883. width: 1,
  5884. },
  5885. },
  5886. axisTick: {
  5887. show: false, //隐藏X轴刻度
  5888. },
  5889. axisLabel: {
  5890. show: true,
  5891. // rotate: 40,
  5892. textStyle: {
  5893. color: '#fff',//'rgba(255,255,255,0.6)', //X轴文字颜色
  5894. fontSize: "20",
  5895. fontFamily: 'Microsoft YaHei'
  5896. },
  5897. },
  5898. },
  5899. yAxis: [
  5900. {
  5901. type: 'value',
  5902. name: '亿',
  5903. nameTextStyle: {
  5904. color: 'rgba(255,255,255,0.6)',
  5905. },
  5906. splitLine: {
  5907. show: true,
  5908. lineStyle: {
  5909. color: '#68b4dd66',
  5910. type: 'dashed',
  5911. },
  5912. },
  5913. axisLine: {
  5914. show: true,
  5915. lineStyle: {
  5916. color: '#3D7495',
  5917. },
  5918. },
  5919. axisLabel: {
  5920. show: true,
  5921. textStyle: {
  5922. color: '#fff',
  5923. fontSize: "20",
  5924. fontFamily: 'Microsoft YaHei'
  5925. },
  5926. },
  5927. nameTextStyle: {
  5928. color: '#fff',
  5929. fontSize: 20,
  5930. fontFamily: 'Microsoft YaHei'
  5931. },
  5932. },
  5933. ],
  5934. series: [
  5935. {
  5936. name: '预算额',
  5937. type: 'bar',
  5938. barWidth: 10,
  5939. itemStyle: {
  5940. normal: {
  5941. color: new echarts.graphic.LinearGradient(0, 0, 0, 1, [
  5942. {
  5943. offset: 0,
  5944. color: '#064F78',
  5945. },
  5946. {
  5947. offset: 1,
  5948. color: '#082550',
  5949. },
  5950. ]),
  5951. },
  5952. },
  5953. data: right4.map(item => item.value),
  5954. },
  5955. {
  5956. name: '已签合同额',
  5957. type: 'bar',
  5958. barWidth: 10,
  5959. itemStyle: {
  5960. normal: {
  5961. color: new echarts.graphic.LinearGradient(0, 0, 0, 1, [
  5962. {
  5963. offset: 0,
  5964. color: '#BDB35D',
  5965. },
  5966. {
  5967. offset: 1,
  5968. color: '#082550',
  5969. },
  5970. ]),
  5971. },
  5972. },
  5973. data: right4.map(item => item.value2),
  5974. },
  5975. {
  5976. name: '产值认定额',
  5977. type: 'bar',
  5978. barWidth: 10,
  5979. itemStyle: {
  5980. normal: {
  5981. color: new echarts.graphic.LinearGradient(0, 0, 0, 1, [
  5982. {
  5983. offset: 0,
  5984. color: '#623726',
  5985. },
  5986. {
  5987. offset: 1,
  5988. color: '#082550',
  5989. },
  5990. ]),
  5991. },
  5992. },
  5993. data: right4.map(item => item.value3),
  5994. },
  5995. {
  5996. name: '结算额',
  5997. type: 'bar',
  5998. barWidth: 10,
  5999. itemStyle: {
  6000. normal: {
  6001. color: new echarts.graphic.LinearGradient(0, 0, 0, 1, [
  6002. {
  6003. offset: 0,
  6004. color: '#13400B',
  6005. },
  6006. {
  6007. offset: 1,
  6008. color: '#082550',
  6009. },
  6010. ]),
  6011. },
  6012. },
  6013. data: right4.map(item => item.value4),
  6014. },
  6015. {
  6016. name: '付款额',
  6017. type: 'bar',
  6018. barWidth: 10,
  6019. itemStyle: {
  6020. normal: {
  6021. color: new echarts.graphic.LinearGradient(0, 0, 0, 1, [
  6022. {
  6023. offset: 0,
  6024. color: '#B57C63',
  6025. },
  6026. {
  6027. offset: 1,
  6028. color: '#082550',
  6029. },
  6030. ]),
  6031. },
  6032. },
  6033. data: right4.map(item => item.value5),
  6034. },
  6035. ],
  6036. }
  6037. that.right1Chart.on('click', function (param) {
  6038. if (that.versions) {
  6039. that.rightAdd.modelName = 2
  6040. that.rightAdd.substraction = ''
  6041. that.rightAdd.projectStepCode = ''
  6042. that.projectNum = 314
  6043. that.rightPenetrateTwo(2, '', that.findCode(param.name), 'right')
  6044. } else {
  6045. that.projectListTipShow = true
  6046. }
  6047. })
  6048. that.right1Chart.setOption(option)
  6049. tools.loopShowTooltip(that.right1Chart, option, {
  6050. interval: 2000,
  6051. loopSeries: true,
  6052. })
  6053. },
  6054. initChartR2 () {
  6055. let that = this
  6056. const itemStyle = {
  6057. // opacity: 0.8,
  6058. shadowBlur: 10,
  6059. shadowOffsetX: 0,
  6060. shadowOffsetY: 0,
  6061. shadowColor: 'rgba(0,0,0,0.3)'
  6062. };
  6063. that.right2Chart = echarts.init(this.$refs['echartR2'])
  6064. that.right2Chart.on('showTip', (params) => {
  6065. // 如果是7或者15并且满足防抖则切换
  6066. if ((params.dataIndex == 5 || params.dataIndex == 11) && that.echartR2Fd) {
  6067. that.echartR2Fd = false
  6068. setTimeout(() => {
  6069. option.dataZoom[0].endValue = option.dataZoom[0].endValue + 6
  6070. option.dataZoom[0].startValue = option.dataZoom[0].startValue + 6
  6071. that.right2Chart.setOption(option);
  6072. // 防止勿刷新做的防抖
  6073. setTimeout(() => {
  6074. that.echartR2Fd = true
  6075. }, 2000)
  6076. }, 1900);
  6077. // 如果是17表示到了最后一个,那么重新来一遍
  6078. } else if (params.dataIndex == 17 && that.echartR2Fd) {
  6079. that.echartR2Fd = false
  6080. setTimeout(() => {
  6081. option.dataZoom[0].endValue = 0
  6082. option.dataZoom[0].startValue = 5
  6083. that.right2Chart.setOption(option);
  6084. // 防止勿刷新做的防抖
  6085. setTimeout(() => {
  6086. that.echartR2Fd = true
  6087. }, 2000)
  6088. }, 1900)
  6089. }
  6090. })
  6091. let option = {
  6092. color: ['#04635E', '#697143', '#4A3042'],
  6093. dataZoom: [
  6094. {
  6095. // start: 9,//默认为@
  6096. // end: 100,//黑认认为1@0
  6097. type: "slider",
  6098. show: false,
  6099. // xAxisIndex: [0]
  6100. handlesize: 0,//滑动条的 左右2个滑动条的大小
  6101. startValue: 5,// 初始显示值
  6102. endValue: 0,// 结束显示值
  6103. height: 10,//组件高度
  6104. left: "5%",
  6105. right: "4%",//右边的距离
  6106. bottom: "25%",//底边的距离
  6107. borderColor: "#939",
  6108. fillerColor: "#269cdb",
  6109. borderRadius: 5,
  6110. backgroundColor: "#33384b",//两边未选中的滑动条区域的额色
  6111. showDataShadow: false,//是否显示数据阴影
  6112. showDetail: false,//即拖拽时候是否显示详细数值信息
  6113. truerealtime: true,//是否实时更新
  6114. filterMode: "filter"
  6115. }, {
  6116. type: 'inside',
  6117. show: true,
  6118. start: 1,
  6119. end: 100,
  6120. zoomOnMouseWheel: false, //滚轮是否触发缩放
  6121. moveOnMouseMove: false, //鼠标滚轮触发滚动
  6122. }
  6123. ],
  6124. legend: {
  6125. top: 10,
  6126. data: ['正偏差', '容差', '负偏差'],
  6127. textStyle: {
  6128. fontSize: 20,
  6129. color: '#fff',
  6130. fontFamily: 'Microsoft YaHei'
  6131. }
  6132. },
  6133. textStyle: {
  6134. color: '#fff',
  6135. },
  6136. tooltip: {
  6137. show: true,
  6138. trigger: "axis",
  6139. textStyle: {
  6140. color: '#FFF', // 文字的颜色
  6141. fontSize: '20', // 文字字体大小
  6142. fontFamily: 'Microsoft YaHei'
  6143. },
  6144. formatter: data => {
  6145. return `${data[0].value[0]}<br /><span style="display:inline-block;border-radius:50%; width:7px;height:7px;background-color:${data[0].color}"></span> ${data[0].seriesName}:${data[0].data[2]}亿<br /><span style="display:inline-block;border-radius:50%; width:7px;height:7px;background-color:${data[1].color}"></span> ${data[1].seriesName}:${data[1].data[2]}亿<br /><span style="display:inline-block;border-radius:50%; width:7px;height:7px;background-color:${data[2].color}"></span> ${data[2].seriesName}:${data[2].data[2]}亿`
  6146. },
  6147. axisPointer: {
  6148. // // type: 'cross',',
  6149. },
  6150. },
  6151. grid: {
  6152. top: '10%',
  6153. right: '4%',
  6154. left: '5%',
  6155. bottom: '5%',
  6156. },
  6157. yAxis: {
  6158. name: '',
  6159. splitLine: {
  6160. show: true,
  6161. lineStyle: {
  6162. color: '#68b4dd66',
  6163. type: 'dashed',
  6164. },
  6165. },
  6166. axisLine: {
  6167. show: false
  6168. },
  6169. axisLabel: {
  6170. show: true,
  6171. formatter: '{value}%',
  6172. textStyle: {
  6173. color: '#fff',
  6174. fontSize: '20',
  6175. fontFamily: 'Microsoft YaHei'
  6176. },
  6177. },
  6178. nameTextStyle: {
  6179. color: '#fff',
  6180. fontSize: 20,
  6181. fontFamily: 'Microsoft YaHei'
  6182. },
  6183. },
  6184. xAxis: {
  6185. data: commonCompany,
  6186. // data: right5[0].map(item => item[0]),
  6187. axisLine: {
  6188. show: true, //隐藏X轴轴线
  6189. lineStyle: {
  6190. color: '#005094',
  6191. width: 1,
  6192. },
  6193. },
  6194. splitLine: {
  6195. show: true,
  6196. lineStyle: {
  6197. color: '#68b4dd66',
  6198. type: 'dashed',
  6199. },
  6200. },
  6201. axisTick: {
  6202. show: false, //隐藏X轴刻度
  6203. },
  6204. axisLabel: {
  6205. show: true,
  6206. // rotate: 40,
  6207. padding: [0, 0, 0, 0],
  6208. textStyle: {
  6209. color: '#fff', //X轴文字颜色
  6210. fontSize: 20,
  6211. fontFamily: 'Microsoft YaHei'
  6212. },
  6213. },
  6214. },
  6215. series: [
  6216. {
  6217. name: '正偏差',
  6218. type: 'scatter',
  6219. itemStyle: itemStyle,
  6220. data: right5[0],
  6221. symbolSize: function (data) {
  6222. return Math.sqrt(Math.abs(data[2])) * 9;
  6223. },
  6224. },
  6225. {
  6226. name: '容差',
  6227. type: 'scatter',
  6228. itemStyle: itemStyle,
  6229. data: right5[1],
  6230. symbolSize: function (data) {
  6231. return Math.sqrt(Math.abs(data[2])) * 9;
  6232. },
  6233. },
  6234. {
  6235. name: '负偏差',
  6236. type: 'scatter',
  6237. itemStyle: itemStyle,
  6238. data: right5[2],
  6239. symbolSize: function (data) {
  6240. return Math.sqrt(Math.abs(data[2])) * 9;
  6241. },
  6242. }
  6243. ]
  6244. }
  6245. that.right2Chart.on('click', function (param) {
  6246. if (that.versions) {
  6247. that.rightAdd.modelName = 1
  6248. that.rightAdd.substraction = param.seriesName == '正偏差' ? 1 : param.seriesName == '容差' ? 2 : 3
  6249. that.rightAdd.projectStepCode = ''
  6250. that.projectNum = 313
  6251. that.rightPenetrateTwo(1, param.seriesName == '正偏差' ? 1 : param.seriesName == '容差' ? 2 : 3, that.findCode(param.name), 'right')
  6252. } else {
  6253. that.projectListTipShow = true
  6254. }
  6255. })
  6256. that.right2Chart.setOption(option)
  6257. tools.loopShowTooltip(that.right2Chart, option, {
  6258. interval: 2000,
  6259. loopSeries: true,
  6260. })
  6261. },
  6262. initChartR3 () {
  6263. let that = this
  6264. that.right3Chart = echarts.init(this.$refs['echartR3'])
  6265. that.right3Chart.on('showTip', (params) => {
  6266. this.echartR4Chart ? this.echartR4Chart.dispose() : ''
  6267. this.echartR5Chart ? this.echartR5Chart.dispose() : ''
  6268. that.initChartR4(params.dataIndex)
  6269. that.initChartR5(params.dataIndex)
  6270. // 如果是7或者15并且满足防抖则切换
  6271. if ((params.dataIndex == 5 || params.dataIndex == 11) && that.echartR3Fd) {
  6272. that.echartR3Fd = false
  6273. setTimeout(() => {
  6274. option.dataZoom[0].endValue = option.dataZoom[0].endValue + 6
  6275. option.dataZoom[0].startValue = option.dataZoom[0].startValue + 6
  6276. that.right3Chart.setOption(option);
  6277. // 防止勿刷新做的防抖
  6278. setTimeout(() => {
  6279. that.echartR3Fd = true
  6280. }, 2000)
  6281. }, 7900);
  6282. // 如果是17表示到了最后一个,那么重新来一遍
  6283. } else if (params.dataIndex == 17 && that.echartR3Fd) {
  6284. that.echartR3Fd = false
  6285. setTimeout(() => {
  6286. option.dataZoom[0].endValue = 0
  6287. option.dataZoom[0].startValue = 5
  6288. that.right3Chart.setOption(option);
  6289. // 防止勿刷新做的防抖
  6290. setTimeout(() => {
  6291. that.echartR3Fd = true
  6292. }, 2000)
  6293. }, 7900)
  6294. }
  6295. })
  6296. let option = {
  6297. tooltip: {
  6298. formatter: data => {
  6299. return `${data[0].name}<br /><span style="display:inline-block;border-radius:50%; width:7px;height:7px;background-color:${data[0].color.colorStops[0].color}"></span> ${data[0].seriesName}:${data[0].value}亿<br/><span style="display:inline-block;border-radius:50%; width:7px;height:7px;background-color:${data[1].color.colorStops[0].color}"></span> ${data[1].seriesName}:${data[1].value}亿<br/><span style="display:inline-block;border-radius:50%; width:7px;height:7px;background-color:${data[2].color.colorStops[0].color}"></span> ${data[2].seriesName}:${data[2].value}亿`
  6300. },
  6301. trigger: 'axis',
  6302. axisPointer: {
  6303. // type: 'cross',',
  6304. },
  6305. position: (params) => {
  6306. return [params[0] + 10, 60]
  6307. },
  6308. textStyle: {
  6309. color: '#FFF', // 文字的颜色
  6310. fontSize: '20', // 文字字体大小
  6311. fontFamily: 'Microsoft YaHei'
  6312. },
  6313. confine: true
  6314. },
  6315. dataZoom: [
  6316. {
  6317. // start: 9,//默认为@
  6318. // end: 100,//黑认认为1@0
  6319. type: "slider",
  6320. show: false,
  6321. // xAxisIndex: [0]
  6322. handlesize: 0,//滑动条的 左右2个滑动条的大小
  6323. startValue: 5,// 初始显示值
  6324. endValue: 0,// 结束显示值
  6325. height: 10,//组件高度
  6326. left: "5%",
  6327. right: "4%",//右边的距离
  6328. bottom: "25%",//底边的距离
  6329. borderColor: "#939",
  6330. fillerColor: "#269cdb",
  6331. borderRadius: 5,
  6332. backgroundColor: "#33384b",//两边未选中的滑动条区域的额色
  6333. showDataShadow: false,//是否显示数据阴影
  6334. showDetail: false,//即拖拽时候是否显示详细数值信息
  6335. truerealtime: true,//是否实时更新
  6336. filterMode: "filter"
  6337. }, {
  6338. type: 'inside',
  6339. show: true,
  6340. start: 1,
  6341. end: 100,
  6342. zoomOnMouseWheel: false, //滚轮是否触发缩放
  6343. moveOnMouseMove: false, //鼠标滚轮触发滚动
  6344. }
  6345. ],
  6346. grid: {
  6347. top: '25%',
  6348. right: '3%',
  6349. left: '10%',
  6350. bottom: '20%',
  6351. },
  6352. legend: {
  6353. data: ["低风险", "中风险", '高风险'],
  6354. x: 'center',
  6355. y: '15px',
  6356. textStyle: {
  6357. // color: 'rgba(250,250,250,0.6)',
  6358. color: '#fff',
  6359. fontSize: "20",
  6360. fontFamily: 'Microsoft YaHei'
  6361. },
  6362. },
  6363. xAxis: {
  6364. data: commonCompany,
  6365. // data: right4.map(item => item.name),
  6366. axisLine: {
  6367. show: true, //隐藏X轴轴线
  6368. lineStyle: {
  6369. color: '#005094',
  6370. width: 1,
  6371. },
  6372. },
  6373. axisTick: {
  6374. show: false, //隐藏X轴刻度
  6375. },
  6376. axisLabel: {
  6377. show: true,
  6378. rotate: 40,
  6379. textStyle: {
  6380. color: '#fff',//'rgba(255,255,255,0.6)', //X轴文字颜色
  6381. fontSize: '20',
  6382. fontFamily: 'Microsoft YaHei'
  6383. },
  6384. },
  6385. },
  6386. yAxis: [
  6387. {
  6388. type: 'value',
  6389. name: '亿',
  6390. nameTextStyle: {
  6391. color: 'rgba(255,255,255,0.6)',
  6392. },
  6393. splitLine: {
  6394. show: true,
  6395. lineStyle: {
  6396. color: '#68b4dd66',
  6397. type: 'dashed',
  6398. },
  6399. },
  6400. axisLine: {
  6401. show: true,
  6402. lineStyle: {
  6403. color: '#3D7495',
  6404. },
  6405. },
  6406. axisLabel: {
  6407. show: true,
  6408. textStyle: {
  6409. color: '#fff',
  6410. fontSize: '20',
  6411. fontFamily: 'Microsoft YaHei'
  6412. },
  6413. },
  6414. nameTextStyle: {
  6415. color: '#fff',
  6416. fontSize: 20,
  6417. fontFamily: 'Microsoft YaHei'
  6418. },
  6419. },
  6420. ],
  6421. series: [
  6422. {
  6423. name: '高风险',
  6424. type: 'bar',
  6425. stack: 'Ad',
  6426. barWidth: 10,
  6427. itemStyle: {
  6428. normal: {
  6429. color: new echarts.graphic.LinearGradient(0, 0, 0, 1, [
  6430. {
  6431. offset: 0,
  6432. color: '#4A3042',
  6433. },
  6434. {
  6435. offset: 1,
  6436. color: '#4A3042',
  6437. },
  6438. ]),
  6439. },
  6440. },
  6441. data: right6.map(item => item.value),
  6442. },
  6443. {
  6444. name: '中风险',
  6445. type: 'bar',
  6446. stack: 'Ad',
  6447. barWidth: 10,
  6448. itemStyle: {
  6449. normal: {
  6450. color: new echarts.graphic.LinearGradient(0, 0, 0, 1, [
  6451. {
  6452. offset: 0,
  6453. color: '#697143',
  6454. },
  6455. {
  6456. offset: 1,
  6457. color: '#697143',
  6458. },
  6459. ]),
  6460. },
  6461. },
  6462. data: right6.map(item => item.value2),
  6463. },
  6464. {
  6465. name: '低风险',
  6466. type: 'bar',
  6467. stack: 'Ad',
  6468. barWidth: 10,
  6469. itemStyle: {
  6470. normal: {
  6471. color: new echarts.graphic.LinearGradient(0, 0, 0, 1, [
  6472. {
  6473. offset: 0,
  6474. color: '#04635E',
  6475. },
  6476. {
  6477. offset: 1,
  6478. color: '#04635E',
  6479. },
  6480. ]),
  6481. },
  6482. },
  6483. data: right6.map(item => item.value3),
  6484. },
  6485. ],
  6486. }
  6487. that.right3Chart.on('click', function (param) {
  6488. if (that.versions) {
  6489. that.rightAdd.modelName = 3
  6490. that.rightAdd.substraction = ''
  6491. that.rightAdd.projectStepCode = ''
  6492. that.projectNum = 315
  6493. that.rightPenetrateTwo(that.rightPenetrateTwo.modelName, '', that.findCode(param.name), 'right')
  6494. } else {
  6495. that.projectListTipShow = true
  6496. }
  6497. })
  6498. that.right3Chart.setOption(option)
  6499. tools.loopShowTooltip(that.right3Chart, option, {
  6500. interval: 8000,
  6501. loopSeries: true,
  6502. })
  6503. },
  6504. initChartR4 (indexValue) {
  6505. this.echartR4Chart = echarts.init(this.$refs['echartR4'])
  6506. option = {
  6507. title: {
  6508. text: ''
  6509. },
  6510. radar: {
  6511. center: ['50%', '50%'],
  6512. radius: 135,
  6513. indicator: [
  6514. { name: '安全风险', max: 100000 },
  6515. { name: '付款风险', max: 100000 },
  6516. { name: '合同风险', max: 100000 },
  6517. { name: '结算风险', max: 100000 },
  6518. { name: '进度风险', max: 100000 },
  6519. { name: '质量风险', max: 100000 },
  6520. ],
  6521. axisLine: { // 设置雷达图中间射线的颜色
  6522. lineStyle: {
  6523. color: '#887d33',
  6524. },
  6525. },
  6526. splitLine: { //网格颜色设置
  6527. show: true,
  6528. lineStyle: {
  6529. width: 1,
  6530. color: ['#871b1a', '#638f41', '#d29e35', '#b6802b']
  6531. },
  6532. },
  6533. name: { //修改indicator文字的颜色
  6534. textStyle: {
  6535. color: "#fff",
  6536. fontSize: '20',
  6537. fontFamily: 'Microsoft YaHei'
  6538. }
  6539. },
  6540. splitNumber: 4, //有几个圈
  6541. splitArea: { //设置图表颜色,show的值为true
  6542. show: true,
  6543. areaStyle: {
  6544. // color:"#c1ddf8", //一般设置方式
  6545. //设置渐变背景色 new echarts.graphic.LinearGradient(a,b,c,d,arr)
  6546. //a ,b,c,d值可为0,1 a:1表示arr中的颜色右到左;c:1 arr中的颜色左到右
  6547. //b:1表示arr中的颜色下到上;d:1表示arr中的颜色上到下
  6548. // color: new echarts.graphic.LinearGradient(0, 1, 0, 0, [
  6549. // { offset: 0, color: '#887D33' }, // 0% 处的颜色
  6550. // { offset: 0.75, color: '#7D4216' }, // 0% 处的颜色
  6551. // { offset: 1, color: '#430705' }// 100% 处的颜色
  6552. // ], false)
  6553. color: ['#638f41', '#887d33', '#7d4216', '#430705'],
  6554. }
  6555. }
  6556. },
  6557. series: [
  6558. {
  6559. name: '',
  6560. type: 'radar',
  6561. symbol: 'circle', // 单个数值点的样式,还可以取值'rect','angle'等
  6562. symbolSize: 0, // 数值点的大小
  6563. data: [
  6564. {
  6565. value: right7[indexValue],
  6566. name: '安全风险',
  6567. itemStyle: { //该数值区域样式设置
  6568. normal: {
  6569. color: 'rgb(44,198,255,0.8)', //背景颜色,还需设置areaStyle
  6570. lineStyle: {
  6571. color: 'rgb(44,198,255,0.8)', //边框颜色
  6572. },
  6573. },
  6574. },
  6575. label: { //显示value中具体的数值
  6576. normal: {
  6577. show: false,
  6578. textStyle: { //更改数值样式
  6579. color: '#43EDE3'
  6580. }
  6581. },
  6582. },
  6583. areaStyle: { //设置区域背景颜色透明度
  6584. normal: {
  6585. width: 1,
  6586. opacity: 0.8,
  6587. },
  6588. },
  6589. }
  6590. ]
  6591. }
  6592. ]
  6593. };
  6594. // tools.loopShowTooltip(myChart, option, {
  6595. // interval: 2000,
  6596. // loopSeries: true,
  6597. // });
  6598. this.echartR4Chart.setOption(option)
  6599. },
  6600. initChartR5 () {
  6601. this.echartR5Chart = echarts.init(this.$refs['echartR5'])
  6602. let option = {
  6603. tooltip: {
  6604. formatter: data => {
  6605. return `${data[0].name}<br /><span style="display:inline-block;border-radius:50%; width:7px;height:7px;background-color:${data[0].color.colorStops[0].color}"></span> ${data[0].seriesName}:${data[0].value}亿<br/><span style="display:inline-block;border-radius:50%; width:7px;height:7px;background-color:${data[1].color.colorStops[0].color}"></span> ${data[1].seriesName}:${data[1].value}亿<br/><span style="display:inline-block;border-radius:50%; width:7px;height:7px;background-color:${data[2].color.colorStops[0].color}"></span> ${data[2].seriesName}:${data[2].value}亿<br/><span style="display:inline-block;border-radius:50%; width:7px;height:7px;background-color:${data[3].color.colorStops[0].color}"></span> ${data[3].seriesName}:${data[3].value}亿`
  6606. },
  6607. trigger: 'axis',
  6608. axisPointer: {
  6609. // type: 'cross',',
  6610. },
  6611. textStyle: {
  6612. color: '#FFF', // 文字的颜色
  6613. fontSize: '20', // 文字字体大小
  6614. fontFamily: 'Microsoft YaHei'
  6615. },
  6616. },
  6617. grid: {
  6618. top: '15%',
  6619. right: '3%',
  6620. left: '5%',
  6621. bottom: '35',
  6622. },
  6623. legend: {
  6624. data: ["预算额", "合同额", "结算额", "支付额"],
  6625. x: 'center',
  6626. y: '10px',
  6627. textStyle: {
  6628. // color: 'rgba(250,250,250,0.6)',
  6629. color: '#fff',
  6630. fontSize: "20",
  6631. fontFamily: 'Microsoft YaHei'
  6632. },
  6633. },
  6634. xAxis: {
  6635. data: ['设备费', '设计费', '施工费', '材料费'],
  6636. axisLine: {
  6637. show: true, //隐藏X轴轴线
  6638. lineStyle: {
  6639. color: '#005094',
  6640. width: 1,
  6641. },
  6642. },
  6643. axisTick: {
  6644. show: false, //隐藏X轴刻度
  6645. },
  6646. axisLabel: {
  6647. show: true,
  6648. // rotate: 40,
  6649. textStyle: {
  6650. color: '#fff',//'rgba(255,255,255,0.6)', //X轴文字颜色
  6651. fontSize: '20', // 文字字体大小
  6652. fontFamily: 'Microsoft YaHei'
  6653. },
  6654. },
  6655. },
  6656. yAxis: [
  6657. {
  6658. type: 'value',
  6659. name: '亿',
  6660. nameTextStyle: {
  6661. color: 'rgba(255,255,255,0.6)',
  6662. },
  6663. splitLine: {
  6664. show: true,
  6665. lineStyle: {
  6666. color: '#68b4dd66',
  6667. type: 'dashed',
  6668. },
  6669. },
  6670. axisLine: {
  6671. show: true,
  6672. lineStyle: {
  6673. color: '#3D7495',
  6674. },
  6675. },
  6676. axisLabel: {
  6677. show: true,
  6678. textStyle: {
  6679. color: '#fff',
  6680. fontSize: '20', // 文字字体大小
  6681. fontFamily: 'Microsoft YaHei'
  6682. },
  6683. },
  6684. nameTextStyle: {
  6685. color: '#fff',
  6686. fontSize: 20,
  6687. fontFamily: 'Microsoft YaHei'
  6688. },
  6689. },
  6690. ],
  6691. series: [
  6692. {
  6693. name: '预算额',
  6694. type: 'bar',
  6695. barWidth: 10,
  6696. itemStyle: {
  6697. normal: {
  6698. color: new echarts.graphic.LinearGradient(0, 0, 0, 1, [
  6699. {
  6700. offset: 0,
  6701. color: '#064F78',
  6702. },
  6703. {
  6704. offset: 1,
  6705. color: '#082550',
  6706. },
  6707. ]),
  6708. },
  6709. },
  6710. data: right8.map(item => item.value),
  6711. },
  6712. {
  6713. name: '合同额',
  6714. type: 'bar',
  6715. barWidth: 10,
  6716. itemStyle: {
  6717. normal: {
  6718. color: new echarts.graphic.LinearGradient(0, 0, 0, 1, [
  6719. {
  6720. offset: 0,
  6721. color: '#BDB35D',
  6722. },
  6723. {
  6724. offset: 1,
  6725. color: '#082550',
  6726. },
  6727. ]),
  6728. },
  6729. },
  6730. data: right8.map(item => item.value2),
  6731. },
  6732. {
  6733. name: '结算额',
  6734. type: 'bar',
  6735. barWidth: 10,
  6736. itemStyle: {
  6737. normal: {
  6738. color: new echarts.graphic.LinearGradient(0, 0, 0, 1, [
  6739. {
  6740. offset: 0,
  6741. color: '#623726',
  6742. },
  6743. {
  6744. offset: 1,
  6745. color: '#082550',
  6746. },
  6747. ]),
  6748. },
  6749. },
  6750. data: right8.map(item => item.value3),
  6751. },
  6752. {
  6753. name: '支付额',
  6754. type: 'bar',
  6755. barWidth: 10,
  6756. itemStyle: {
  6757. normal: {
  6758. color: new echarts.graphic.LinearGradient(0, 0, 0, 1, [
  6759. {
  6760. offset: 0,
  6761. color: '#955773',
  6762. },
  6763. {
  6764. offset: 1,
  6765. color: '#082550',
  6766. },
  6767. ]),
  6768. },
  6769. },
  6770. data: right8.map(item => item.value4),
  6771. },
  6772. ],
  6773. }
  6774. this.echartR5Chart.setOption(option)
  6775. tools.loopShowTooltip(this.echartR5Chart, option, {
  6776. interval: 2000,
  6777. loopSeries: true,
  6778. })
  6779. },
  6780. },
  6781. })