investHome.js 64 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798991001011021031041051061071081091101111121131141151161171181191201211221231241251261271281291301311321331341351361371381391401411421431441451461471481491501511521531541551561571581591601611621631641651661671681691701711721731741751761771781791801811821831841851861871881891901911921931941951961971981992002012022032042052062072082092102112122132142152162172182192202212222232242252262272282292302312322332342352362372382392402412422432442452462472482492502512522532542552562572582592602612622632642652662672682692702712722732742752762772782792802812822832842852862872882892902912922932942952962972982993003013023033043053063073083093103113123133143153163173183193203213223233243253263273283293303313323333343353363373383393403413423433443453463473483493503513523533543553563573583593603613623633643653663673683693703713723733743753763773783793803813823833843853863873883893903913923933943953963973983994004014024034044054064074084094104114124134144154164174184194204214224234244254264274284294304314324334344354364374384394404414424434444454464474484494504514524534544554564574584594604614624634644654664674684694704714724734744754764774784794804814824834844854864874884894904914924934944954964974984995005015025035045055065075085095105115125135145155165175185195205215225235245255265275285295305315325335345355365375385395405415425435445455465475485495505515525535545555565575585595605615625635645655665675685695705715725735745755765775785795805815825835845855865875885895905915925935945955965975985996006016026036046056066076086096106116126136146156166176186196206216226236246256266276286296306316326336346356366376386396406416426436446456466476486496506516526536546556566576586596606616626636646656666676686696706716726736746756766776786796806816826836846856866876886896906916926936946956966976986997007017027037047057067077087097107117127137147157167177187197207217227237247257267277287297307317327337347357367377387397407417427437447457467477487497507517527537547557567577587597607617627637647657667677687697707717727737747757767777787797807817827837847857867877887897907917927937947957967977987998008018028038048058068078088098108118128138148158168178188198208218228238248258268278288298308318328338348358368378388398408418428438448458468478488498508518528538548558568578588598608618628638648658668678688698708718728738748758768778788798808818828838848858868878888898908918928938948958968978988999009019029039049059069079089099109119129139149159169179189199209219229239249259269279289299309319329339349359369379389399409419429439449459469479489499509519529539549559569579589599609619629639649659669679689699709719729739749759769779789799809819829839849859869879889899909919929939949959969979989991000100110021003100410051006100710081009101010111012101310141015101610171018101910201021102210231024102510261027102810291030103110321033103410351036103710381039104010411042104310441045104610471048104910501051105210531054105510561057105810591060106110621063106410651066106710681069107010711072107310741075107610771078107910801081108210831084108510861087108810891090109110921093109410951096109710981099110011011102110311041105110611071108110911101111111211131114111511161117111811191120112111221123112411251126112711281129113011311132113311341135113611371138113911401141114211431144114511461147114811491150115111521153115411551156115711581159116011611162116311641165116611671168116911701171117211731174117511761177117811791180118111821183118411851186118711881189119011911192119311941195119611971198119912001201120212031204120512061207120812091210121112121213121412151216121712181219122012211222122312241225122612271228122912301231123212331234123512361237123812391240124112421243124412451246124712481249125012511252125312541255125612571258125912601261126212631264126512661267126812691270127112721273127412751276127712781279128012811282128312841285128612871288128912901291129212931294129512961297129812991300130113021303130413051306130713081309131013111312131313141315131613171318131913201321132213231324132513261327132813291330133113321333133413351336133713381339134013411342134313441345134613471348134913501351135213531354135513561357135813591360136113621363136413651366136713681369137013711372137313741375137613771378137913801381138213831384138513861387138813891390139113921393139413951396139713981399140014011402140314041405140614071408140914101411141214131414141514161417141814191420142114221423142414251426142714281429143014311432143314341435143614371438143914401441144214431444144514461447144814491450145114521453145414551456145714581459146014611462146314641465146614671468146914701471147214731474147514761477147814791480148114821483148414851486148714881489149014911492149314941495149614971498149915001501150215031504150515061507150815091510151115121513151415151516151715181519152015211522152315241525152615271528152915301531153215331534153515361537153815391540154115421543154415451546154715481549155015511552155315541555155615571558155915601561156215631564156515661567156815691570157115721573157415751576157715781579158015811582158315841585158615871588158915901591159215931594159515961597159815991600160116021603160416051606160716081609161016111612161316141615161616171618161916201621162216231624162516261627162816291630163116321633163416351636163716381639164016411642164316441645164616471648164916501651165216531654165516561657165816591660166116621663166416651666166716681669167016711672167316741675167616771678167916801681168216831684168516861687168816891690169116921693169416951696169716981699170017011702170317041705170617071708170917101711171217131714171517161717171817191720172117221723172417251726172717281729173017311732173317341735173617371738173917401741174217431744174517461747174817491750175117521753175417551756175717581759176017611762176317641765176617671768176917701771177217731774177517761777177817791780178117821783178417851786178717881789179017911792179317941795179617971798179918001801180218031804180518061807180818091810181118121813181418151816181718181819182018211822182318241825182618271828182918301831183218331834183518361837183818391840184118421843184418451846184718481849185018511852185318541855185618571858185918601861186218631864186518661867186818691870187118721873187418751876187718781879188018811882188318841885188618871888188918901891189218931894189518961897189818991900190119021903190419051906190719081909
  1. let app = new Vue({
  2. el: '#app',
  3. data() {
  4. return {
  5. showTip: false,
  6. showTip2: false,
  7. timeOut: '',
  8. tipTitle: '',
  9. tipTitle2: '',
  10. year: '2022',
  11. time: '',
  12. timer: '',
  13. mapName: 'shanxi',
  14. geoCoordMap: {},
  15. config1: {
  16. number: [100],
  17. content: '{nt}个',
  18. },
  19. storageRecordConfig: null,
  20. companyList: [
  21. { name: '山西焦煤' },
  22. { name: '晋能控股' },
  23. { name: '华新燃气' },
  24. { name: '山西建投' },
  25. { name: '潞安化工' },
  26. { name: '华远陆港' },
  27. { name: '航产集团' },
  28. { name: '大地控股' },
  29. { name: '国新能源' },
  30. { name: '汾酒集团' },
  31. { name: '云时代' },
  32. { name: '神农科技' },
  33. { name: '华阳新材' },
  34. { name: '华舰体育' },
  35. { name: '交控集团' },
  36. { name: '文旅集团' },
  37. { name: '水控集团' },
  38. { name: '太重集团' },
  39. ],
  40. amountList: amountList,
  41. amountTotal: 0,
  42. classOption: {
  43. step: 0.5
  44. }
  45. }
  46. },
  47. created() {
  48. this.amountList.map(item => {
  49. this.amountTotal += Number(item.value)
  50. })
  51. this.time = formatDate()
  52. this.timer = setInterval(() => {
  53. this.time = formatDate()
  54. }, 1000)
  55. },
  56. beforeDestroy() {
  57. if (this.timer) {
  58. clearInterval(this.timer);
  59. }
  60. },
  61. mounted() {
  62. setTimeout(() => {
  63. // 左侧图表
  64. //this.initChartTip()
  65. this.initChartTip2()
  66. this.initChartTip3()
  67. this.initChartTip4()
  68. this.initChartL1()
  69. this.initChartL2()
  70. this.initChartR1()
  71. this.initChartR2()
  72. this.initChinaChart()
  73. this.initProjectList()
  74. }, 0)
  75. },
  76. beforeDestroy(){
  77. clearInterval(this.timeOut)
  78. },
  79. methods: {
  80. numFormat(value) {
  81. if (!value) return '0'
  82. var intPart = Number(value).toFixed(0) // 获取整数部分
  83. var intPartFormat = intPart.toString().replace(/(\d)(?=(?:\d{3})+$)/g, '$1,') // 将整数部分逢三一断
  84. var floatPart = '.00' // 预定义小数部分
  85. var value2Array = value.toString().split('.')
  86. // =2表示数据有小数位
  87. if (value2Array.length === 2) {
  88. floatPart = value2Array[1].toString() // 拿到小数部分
  89. if (floatPart.length === 1) {
  90. // 补0
  91. return intPartFormat + '.' + floatPart + '0'
  92. } else {
  93. return intPartFormat + '.' + floatPart
  94. }
  95. } else {
  96. return intPartFormat
  97. }
  98. },
  99. convertData(data) {
  100. var res = []
  101. for (var i = 0; i < data.length; i++) {
  102. var geoCoord = this.geoCoordMap[data[i].name]
  103. if (geoCoord) {
  104. res.push({
  105. name: data[i].name,
  106. value: geoCoord.concat(data[i].value),
  107. })
  108. }
  109. }
  110. return res
  111. },
  112. initChinaChart() {
  113. var data = [
  114. { name: '大同市', value: 60.35, value2: 28 },
  115. { name: '朔州市', value: 33.61, value2: 13 },
  116. { name: '忻州市', value: 73.35, value2: 25 },
  117. { name: '吕梁市', value: 109.04, value2: 45 },
  118. { name: '太原市', value: 251.67, value2: 113 },
  119. { name: '阳泉市', value: 25.12, value2: 28 },
  120. { name: '晋中市', value: 148.57, value2: 52 },
  121. { name: '临汾市', value: 130.55, value2: 30 },
  122. { name: '长治市', value: 103.00, value2: 23 },
  123. { name: '运城市', value: 41.06, value2: 23 },
  124. { name: '晋城市', value: 45.43, value2: 31 }
  125. ]
  126. var moveLine = {
  127. normal: [
  128. {
  129. fromName: '太原市',
  130. toName: '吕梁市',
  131. coords: [
  132. [112.3352, 37.9413],
  133. [111.3574, 37.7325],
  134. ],
  135. },
  136. {
  137. fromName: '太原市',
  138. toName: '忻州市',
  139. coords: [
  140. [112.3352, 37.9413],
  141. [112.4561, 38.8971],
  142. ],
  143. },
  144. {
  145. fromName: '太原市',
  146. toName: '临汾市',
  147. coords: [
  148. [112.3352, 37.9413],
  149. [111.4783, 36.1615],
  150. ],
  151. },
  152. {
  153. fromName: '太原市',
  154. toName: '阳泉市',
  155. coords: [
  156. [112.3352, 37.9413],
  157. [113.4778, 38.0951],
  158. ],
  159. },
  160. {
  161. fromName: '太原市',
  162. toName: '晋中市',
  163. coords: [
  164. [112.3352, 37.9413],
  165. [112.7747, 37.37],
  166. ],
  167. },
  168. {
  169. fromName: '太原市',
  170. toName: '运城市',
  171. coords: [
  172. [112.3352, 37.9413],
  173. [111.1487, 35.2002],
  174. ],
  175. },
  176. {
  177. fromName: '太原市',
  178. toName: '大同市',
  179. coords: [
  180. [112.3352, 37.9413],
  181. [113.7854, 39.8035],
  182. ],
  183. },
  184. {
  185. fromName: '太原市',
  186. toName: '晋城市',
  187. coords: [
  188. [112.3352, 37.9413],
  189. [112.7856, 35.6342],
  190. ],
  191. },
  192. {
  193. fromName: '太原市',
  194. toName: '长治市',
  195. coords: [
  196. [112.3352, 37.9413],
  197. [112.8625, 36.4746],
  198. ],
  199. },
  200. {
  201. fromName: '太原市',
  202. toName: '朔州市',
  203. coords: [
  204. [112.3352, 37.9413],
  205. [113.0713, 39.6991],
  206. ],
  207. },
  208. ],
  209. }
  210. /*获取地图数据*/
  211. let myChart = echarts.init(this.$refs['echarts-map'])
  212. echarts.registerMap('shanxi', {
  213. type: 'FeatureCollection',
  214. features: [
  215. {
  216. type: 'Feature',
  217. id: '1409',
  218. properties: { name: '忻州市', cp: [112.4561, 38.8971], childNum: 14 },
  219. geometry: {
  220. type: 'Polygon',
  221. coordinates: [
  222. '@@Vx@lnbn¦WlnnUšmš°š²VšV‚VVVnUn„ºlz@l„„@Jƒ@kXWVXl@Lƒa@„ƒKUL„ŽlbnKlLnK‚LnKÆXn°šbVV@bUVl°Un@LnaVJUbW@UX²l‚@ČwlVVIšWnkÆa°„„anV‚Kn°™UW¯@™aVUVk@Un@„aV@ValwUanmWU„k@WVUUanaVwnLVl°@nk@mVU@UVK@w„LVKVU@ƒ„K@UUKVUV@@bnL„a‚V„aôšlIXmlKX_°KVV@bVV„@šzV`kblI„V„Ul‚šL@bnV@V„Ċll„„VlIXW@k„a‚U²blKšVnIlJ„albXXlWVn°JnšnL@l@XlJlaX@„X˜W²@l_VmnKšU„blU@mnkVK„¯@U@ƒma@kX¥VƒmakkƒLƒa@aƒ@WIUUVXWWnk@a°a@kkm@kUUmJm@WUUUIk`m@V—kaWWkX™KmƒXk¯ƒ@WKƒLkak@±bƒw@ƒaƒa@akaƒ@ma¯@ƒL—KÇÅkKWbkmġ™±ÅUƒLUK™VVkƒm¯LUVVbƒ„UwUW¯bm„ƒULƒxWJ—@ƒklmkUm@@KnwVkVK@akwƒ@@a¯bƒKkn›VUI™b¯mmbk@UbmKUL@xUUƒ@klmLUŽlVXI‚VVVUVUœU`mLXVWbXnW`Ų°xmŽxU@mĉƒƒwU@mbU@UƒmbkVW¦kJ™@ƒX@`¯Im@UlUVVnb@bWJXnmbƒJUU™UUaƒ@UamIkaƒxƒ@@x@b',
  223. ],
  224. encodeOffsets: [[113614, 39657]],
  225. },
  226. },
  227. {
  228. type: 'Feature',
  229. id: '1411',
  230. properties: { name: '吕梁市', cp: [111.3574, 37.7325], childNum: 13 },
  231. geometry: {
  232. type: 'Polygon',
  233. coordinates: [
  234. '@@@a@w„@„wlbnJVb„@VbšVVV„InaWmXI@a‚aUmVUVkn@°J@_„Wš@lIX¥lUnaV„V@naV@„xĊ„n‚V@‚wn¯wƱX_WmXaWUnKV_V›VUUUUWJkUVnKlk¯™@@kmKUaŁ±KkU@WmI@WUIlUUmVwXƒ‚w@ƒUlUVwœV‚@„Lnb‚W@anU@UšaVkô@l»n@na˜JnUÈLVaƃUUVm„VKVƒ²L@mU_lK@UVWkU‚a@a@U¯aUaƒÑóÑUb™„ƒKk@@aƒk¯mVaUwVƒÑkWUmK@UUKmXUWÝwUa™LUU@aWJUUU@Ua݄U@WL@VKVaVI@WnU@alIVKƒƒ@kIƒmIkJ@™m@ƒ™@@_™K@xƒ@kaW@U„@Vmn@ŽUK@mIƒJUXV¤XXWlkKƒkkK@XmJVakImJU@ó™¯LWKUV@nUVƒLkxmKkLma@kXKmmƒLƒab™LmK@V@mXVÆUxƒX@`nL„aV@@VmLUVnLlLš˜„b@„šŽ°²nx@b‚VUxlb@V¯bUV@zV‚XVĊXVx@lVn@VnnmŽUš@LlJXVƒz¯VWVXbšV@bmn™VUVk„Çþń@XVxmbUlV„Uln„W„@„Xl‚@VLXÒ@bÞJ°¦„L˜ò„@nU‚b@°„X@ŽXbmVU„V„nb@x‚x',
  235. ],
  236. encodeOffsets: [[113614, 39657]],
  237. },
  238. },
  239. {
  240. type: 'Feature',
  241. id: '1410',
  242. properties: { name: '临汾市', cp: [111.4783, 36.1615], childNum: 17 },
  243. geometry: {
  244. type: 'Polygon',
  245. coordinates: [
  246. '@@nW‚@@UnLšK‚a„b„KnnWL@lnblKnLlw„KVU@mVUXL°KôšV@nIlJUbnI@WlL„llLXkWWU£VW„InJ‚@VL@nm@UVƒX@lb„@@wšL@`‚@„šn@V@lw„@n„VmVX„WmwnUlƒœa@_lK„wVlUn°xVKVXXWlUšVVI@K@K„n°KœwlVlU@kna@V_„Wn‚m„UVm@kXml_@m„LlKXw°m@_ôJVUV@X™l@UaV@Va°I„lk»VwUkVmwUmmVn@V¯@KƒU—wmK@U¯wUVÝ@mJƒU—nWK™@@UnKVa„_lykUmKÛnm@™x@ƒUUlwVk™ƒXW@ƒa@Uƒ@@K@ƒkIV™nammVakUlƒ@wX@@kƒ™¯@ƒVVbml@„„°UbULmlVbnbÅK±VƒKVXUJWa@ULWaUU@@U@aWK@UkxUKƒLUUUJ±UkL@V±kk@kam@UV@l@LWl@n@VVUx„LlUUx@VUV™U@aƒIUl™L@°mLU‚ƒbkUUaWUUaUU@aWK—LWJ@bUL@VUVVbU@m@a@kmKmnĉlUK™XƒWUblb—xmIkƒƒU@xWb@lkšVx™LXŽmzVV@bklVVUzm˜@bk„@Vx@xlŽU„@lUbVnl@„Wxnl@n@ŽUbV„mL‚mƒb@`X@lUX@@xlnkLWaUJnnWV™Vn@l„@bULVV@l™V@XnJVX',
  247. ],
  248. encodeOffsets: [[113063, 37784]],
  249. },
  250. },
  251. {
  252. type: 'Feature',
  253. id: '1407',
  254. properties: { name: '晋中市', cp: [112.7747, 37.37], childNum: 11 },
  255. geometry: {
  256. type: 'Polygon',
  257. coordinates: [
  258. '@@@šlInJ„lJ„@‚„ULkJ@bmV@XUJUb‚L@UXKV@ރVbV@VVXI@bVVšKVbÞxVXnWVL@VnLV‚lX„ÒUŽVxUb°n„l@bl@„LšƒVaô҄ÒVb°b@VnLnnV@lmn@lb„U„V@„‚JœUVV‚Xkl@lUzmJ@xšXkl‚bUn„JVšUb„nU‚lb„V@nlLX@lakšV`Ub°š@XVJnU‚L²KlxnI@KV@lbUbVV„KnVl@„zlm@Uš@nŽšI@WUaVl@@mVU„@XkW@ƒnkVKVƒ„_Vw„y@knwVa‚@XalU„@šVnml@„X@V„L‚KVaÞbnnlJšI„mVKn„VVVInVlU„@„m@™mXK@UmyUI@mWUUakamw@wUwmLkakwVƒmK™w@wUam£y@am_ƒW@™UU@knmm„amU@WUa@knw@ƒUUUUV@nƒJm@mVUkKVUUUkKmwƒKULƒKUImV@lUn™nŽm@mbUK@°™bUnmbUmkkƒWUb@am@UXkK@a±@™V™@ĉř„V‚UXVxUVkLWl¯@@bULUlm@@nm`—XƒlWakIkm›VUbUL@Vm@kIƒ@@Kšm@—VaX‚I@W@aU@kUƒVU_™KƒbƒJkkǎ™b@nkKmL™wÅW@kVUUƒVU@WUIƒJmIXmma@_kyVaUUlkUm@ƒkU›x¯Lƒm@L@LUJ™UkVWXUWUL¯wVmUkƒxkL@`›bk„mVnxƒXUWUnmƒƒ@kxU@',
  259. ],
  260. encodeOffsets: [[114087, 37682]],
  261. },
  262. },
  263. {
  264. type: 'Feature',
  265. id: '1408',
  266. properties: { name: '运城市', cp: [111.1487, 35.2002], childNum: 13 },
  267. geometry: {
  268. type: 'Polygon',
  269. coordinates: [
  270. '@@„Vl„nJ˜wkaVa„XšWVLĊknmnL‚l@@bn‚V@UaVU@UVK@aXI˜KXL@bVVVbXVVblV„aVnK@¯šKVk„J@bšVVU@UVwkVƒKVwUUm@@Xk@K@kVUn@lbl@²l@UlK²VVIVV„KVLlw@VXL@b@VV@VŽXbVK‚@XbVIUW„L‚U²ÆLmaUankVKVaƒ¯@ƒnkUa„U°@„š‚n@@kWa„UVaXUW@IXKVw@U™ƒ„™WU@W@@UUƒU@mn@ƒ`m@UUULkUmJ™IUƒ@@UƒK@U@›anƒ™ak_@wmKUwmakV™kmK™V™k¯b™wƒ`kwUIÇx¯»ÇaŃmn@@™mƒmUkV@wkKW@kxmL™UkĉLÝk™xÝw¯lóVU„mV@ĀVVX¦W¤kz@`Vx°„²ĸ‚š@„Ul@x„êĸNJ°¤V„VlXLWnXxmV@nUl@„',
  271. ],
  272. encodeOffsets: [[113232, 36597]],
  273. },
  274. },
  275. {
  276. type: 'Feature',
  277. id: '1402',
  278. properties: { name: '大同市', cp: [113.7854, 39.8035], childNum: 8 },
  279. geometry: {
  280. type: 'Polygon',
  281. coordinates: [
  282. '@@²£šyl@Ȑ˜Ė@bĸŽĢbĸ„˜X„a‚KŤnn@ŎôllÈx„nVnÞDŽV@b‚nXllL°KšbVb@J@b—„‚„@ŽU„„xlKXLlKlXk„@Ulk„JlkUƒVKXUƒÇVIVm@_nǚLšašl‚w„VnU@UUwma@aƒaÝaLmUk@@Wƒ@U@@X™wVWÝUUUk@@VmLƒKV»nwUw™aUL@`mzƒJUIVƒUaUw™KUaVIlJôanÑlLVUn@ša„@VV„@@UUwVK°Vn_lJÆLœéW@UUUÅ@»lm@aÞIVwXW˜UUkkm@U@aƒU@mwU£VWU_kWmƒXwW_°yUkkK@UÇK@kkUVymóK—U@KWIƒbUak@mJ@bkbmLkŽ™UmƒkVU„W¦@lnb@„@Vƒ°ULml@nkVƒa™VmLUnk`±@—XƒWW@kbǦXŽ¯„WxI@xmbmxXlWV„„@bŎUz@J‚b@bÞb™ŽU@Wbk@ƒxk@WX¯VۙƒWÝbÝUkVUU@alI@a@akLWa™m@U¯UUmÇL@K@aU@¯VUkƒKmX@`@œkJ@nV‚Ub@lbVÆXVW„ULU`VbkLUV@XWl@bXJ˜@VbV@Vl',
  283. ],
  284. encodeOffsets: [[115335, 41209]],
  285. },
  286. },
  287. {
  288. type: 'Feature',
  289. id: '1404',
  290. properties: { name: '长治市', cp: [112.8625, 36.4746], childNum: 12 },
  291. geometry: {
  292. type: 'Polygon',
  293. coordinates: [
  294. '@@Uk™Lky@I‚JVa@mÞaWšy@_W@_WƒXVlUVwš@nw°K@m„UƒVaƒmVkU@mmmnLVUmKXa™U@IlKVUnK@UmWkX@WV_Vƒ@akU@a„KWIXyƒIUVmUn™Ua@WaXUVKVmkUWVkUƒLU@@VƒbƒKbƒIUmƒ@mbVL—x›WUUkn±V¯wƒbÅJUbmLkbmKÅKƒbVnUbƒV™KUb™KUbmLKmƒb™aƒKkUm@UŽnn‚VnxUVlUxl¼ƒk¯JUbU@Vbk@WšU@UVóI@`¯nWxkLƒK@nk`Wn@lUnƒVnm‚ƒXU`@mb@lkV@„VnklVVUblz@`nbWnnJ„IVJ@XUVV„UV@lÆXšxnKlL@mšaȍll„I„ašLV`„UlVV@@b@XJWUb@˜™n@L„@lJn@@UVKVaœUlnlJXb„k˜Wn_@mn@VkVK@a°@XklKVUUwVWUšƒĊƚ@šU²@@blLVWn@@bVa„XllVnnaVmša@¯VLnan@‚šmVm@knUVJ',
  295. ],
  296. encodeOffsets: [[116269, 37637]],
  297. },
  298. },
  299. {
  300. type: 'Feature',
  301. id: '1406',
  302. properties: { name: '朔州市', cp: [113.0713, 39.6991], childNum: 5 },
  303. geometry: {
  304. type: 'Polygon',
  305. coordinates: [
  306. '@@XXWVXVWnnlnn@èƼ@„„xlš„ŽV„nblšššVŽÈUVl‚š@„blnœL܃ĊmUkU@Ua‚—@WI@aXk@WVUlKUaV_VKXƒWUUÅka@VaU@mlI@›@_nW„LVl°UV@@b@LÈKVn°V@VšnXblK@b@bkJ@bVVlUÞVÞa„Xܚ°UXWl@„wl@XaV@šÝa@aa@IVyƍ@aƒƒXUWknwna@w‚JXw°ƒWÈ¥kI@W@kmKm™¯IUmkXWWkaƒbkImJ™UkL±aVƒb@lWXkJƒUkƒĉkƒ@UmU@a™KkƒVƒUkJlaU_™yƒ@UU@aUU¯LW`kLWnkJó™ƒbUƒbmK@aU@UVVL@VƒL@„UVULƒK@xUL@VUV@nml¯@UkmKUxmbVbUV@XƒlXVmnVbkxUbU@ƒbm@@VUlUVšb°@VX¯šm‚',
  307. ],
  308. encodeOffsets: [[114615, 40562]],
  309. },
  310. },
  311. {
  312. type: 'Feature',
  313. id: '1405',
  314. properties: { name: '晋城市', cp: [112.7856, 35.6342], childNum: 6 },
  315. geometry: {
  316. type: 'Polygon',
  317. coordinates: [
  318. '@@lV„Lšb„an‚LnKVašLVašL„UVaUm„aÆLnLlanKVaÆI„a°x²UlmVVœX˜wUKna„@Vn„J‚a„L„a@UV@@alUkKVKnkmmVwUk„w@ƒ™@kxWUXƒW@@mƒk@aUa@a¯aƒLkKmwkUm@kL@K@aWIXmƒVƒXƒWkUVakL@UVKƒw@aUK@UUKmLU@¯n™KUwVƒUIWJUWmka™@UXƒJƒk@UkmW@kLWKVƒx@bmI@VUaVU@a¯@UUmVKmX@±`kÝKVxUL±akL@V™bƒLkKmVƒ@XWVUbƒVXb@lm@@lW@@xk„lVUbnnmbUšlJ@„@L„@@V„b@‚WXš„UlkxVV@„šwn@ÜmnLlVkzƒ`UbmL@Vš@XL˜m„VnIÞ@VU°x@VnL˜x„V@LU°',
  319. ],
  320. encodeOffsets: [[115223, 36895]],
  321. },
  322. },
  323. {
  324. type: 'Feature',
  325. id: '1401',
  326. properties: { name: '太原市', cp: [112.3352, 37.9413], childNum: 5 },
  327. geometry: {
  328. type: 'Polygon',
  329. coordinates: [
  330. '@@„@VV@wVKnLVal@na°nšaVJœUlm„L°a@b„@lx@bULUlmx@Ln@lVkn„l˜@XI„w‚K„Vnƒ°aVXVx„ƒUaVU°K„nUlšUVL„KÆVš²Ģ‚lnXalLÈƘL„KUaVkUanmWU™a@WwkUWU¯y¯Ñ@anIl@@aVU„m„I„ymUƒLUUVakaU@@LmJkw±LKmVUI@W¯™VaU_l™kbW@kK@mƒUkaVƒmVaU™ƒIVmalk™W@wnIVy@klkWUU›VI@ƒƒUƒVkam@knU@mmmK@bblVUX@VkLV`@n±KU„ULƒ‚UnVVńUbÇKmV—Imbm@k¼ó@Ul™b@VmV@bXmaƒK@›UUxkV‚V@„xW„UxVnkVVJ@XnJ@XlV²LƂVbnL@lš@°',
  331. ],
  332. encodeOffsets: [[114503, 39134]],
  333. },
  334. },
  335. {
  336. type: 'Feature',
  337. id: '1403',
  338. properties: { name: '阳泉市', cp: [113.4778, 38.0951], childNum: 3 },
  339. geometry: {
  340. type: 'Polygon',
  341. coordinates: [
  342. '@@°@nb„@lb@b„b„b‚@„x²al@lb„KXU@m‚kUWkkmUUƒVwV@XUW@™naVklKXblKnL‚ƒnLVanImaXKlL„ašV@U@KUKW„alƒXK@£WKXUV@VU„ƒUUVW„_V™@W@@K„@šƒUƒƒIWmXUmƒULƒn™JkImmÝaUbLƒK@UƒWk@mn™Uƒ@kVWb@Ubmx@lƒzUxƒ`U„ULml@„XWlƒ@UV@nk@U‚Vb@X™Jm™@@Vknƒyk@ƒzƒJƒnUV@bk@mJ@b°Ò°zXVlVXx‚@šbXVmnVbUlVb',
  343. ],
  344. encodeOffsets: [[115864, 39336]],
  345. },
  346. },
  347. ],
  348. UTF8Encoding: true,
  349. })
  350. var mapFeatures = echarts.getMap(this.mapName).geoJson.features
  351. mapFeatures.forEach(v => {
  352. // 地区名称
  353. var name = v.properties.name
  354. // 地区经纬度
  355. this.geoCoordMap[name] = v.properties.cp
  356. })
  357. // <p>当前阶段:<span>可论证阶段</span></p>
  358. // <p>时间节点:<span>2021.10-2022.10</span></p>
  359. let option = {
  360. tooltip: {
  361. padding: 15,
  362. enterable: true,
  363. transitionDuration: 1,
  364. formatter: (params, ticket, callback) => {
  365. // 清空所有轮播
  366. for (var k in this.geoCoordMap) {
  367. myChart.dispatchAction({
  368. // type: 'geoUnSelect',
  369. type: 'downplay',
  370. name: k,
  371. })
  372. }
  373. // 如果鼠标滑动到线线上面,则返回空
  374. myChart.dispatchAction({
  375. // type: 'geoSelect',
  376. type: 'highlight',
  377. name: params.name,
  378. })
  379. if (params.componentSubType == 'lines') {
  380. return
  381. }
  382. if (params.componentSubType == 'scatter') {
  383. let tipHtml = `
  384. <div class="tooltip-cont">
  385. <p>项目数量:<span>${data[params.dataIndex].value2}个</span></p>
  386. <p>总投资额:<span>${params.data.value[2]}亿</span></p>
  387. </div>`
  388. callback(ticket, tipHtml)
  389. return tipHtml
  390. }
  391. if (params.componentSubType == 'map') {
  392. let tipHtml = `
  393. <div class="tooltip-cont">
  394. <p>项目数量:<span>${data[params.dataIndex].value2}个</span></p>
  395. <p>总投资额:<span>${params.data.value}亿</span></p>
  396. </div>`
  397. callback(ticket, tipHtml)
  398. return tipHtml
  399. }
  400. },
  401. },
  402. visualMap: {
  403. show: false,
  404. min: 0,
  405. max: 300,
  406. right: 0,
  407. bottom: 0,
  408. text: ['高', '低'],
  409. textStyle: {
  410. color: '#f1f1f1'
  411. },
  412. realtime: false,
  413. calculable: false,
  414. inRange: {
  415. color: ['lightskyblue', '#2754b7']
  416. }
  417. },
  418. geo: {
  419. show: true,
  420. map: 'shanxi',
  421. layoutCenter: ['50%', '50%'], //地图位置
  422. layoutSize: '100%',
  423. label: {
  424. normal: {
  425. show: false,
  426. },
  427. emphasis: {
  428. show: false,
  429. },
  430. },
  431. roam: false,
  432. itemStyle: {
  433. normal: {
  434. areaColor: '#1946a8',
  435. shadowColor: '#1946a8',
  436. borderWidth: 1, //设置外层边框
  437. borderColor: '#1946a8',
  438. shadowOffsetX: 10,
  439. shadowOffsetY: 5,
  440. shadowBlur: 2,
  441. },
  442. emphasis: {
  443. areaColor: '#1946a8',
  444. borderColor: '#d4bc1d',
  445. borderWidth: 2, //设置外层边框
  446. },
  447. },
  448. },
  449. series: [
  450. {
  451. name: '散点',
  452. type: 'scatter',
  453. coordinateSystem: 'geo',
  454. data: this.convertData(data),
  455. symbolSize: function (val) {
  456. return 10
  457. },
  458. label: {
  459. normal: {
  460. formatter: '{b}',
  461. position: [10, 10],
  462. fontSize: 15,
  463. fontWeight: 600,
  464. fontStyle: 'italic',
  465. color: '#fff',
  466. show: true,
  467. },
  468. emphasis: {
  469. show: true,
  470. },
  471. },
  472. itemStyle: {
  473. normal: {
  474. color: '#000',
  475. borderWidth: 2,
  476. borderColor: '#fff',
  477. },
  478. },
  479. },
  480. {
  481. type: 'map',
  482. map: this.mapName,
  483. geoIndex: 0,
  484. aspectScale: 1.5, //长宽比
  485. showLegendSymbol: true, // 存在legend时显示
  486. label: {
  487. normal: {
  488. show: true,
  489. },
  490. emphasis: {
  491. show: false,
  492. textStyle: {
  493. color: '#fff',
  494. },
  495. },
  496. },
  497. roam: true,
  498. itemStyle: {
  499. normal: {
  500. areaColor: '#031525',
  501. borderColor: '#3B5077',
  502. },
  503. emphasis: {
  504. areaColor: '#2B91B7',
  505. },
  506. },
  507. animation: false,
  508. data: data,
  509. },
  510. {
  511. name: '点',
  512. type: 'scatter',
  513. coordinateSystem: 'geo',
  514. zlevel: 6,
  515. },
  516. {
  517. name: 'Top 5',
  518. type: 'effectScatter',
  519. coordinateSystem: 'geo',
  520. data: this.convertData(
  521. data
  522. .sort(function (a, b) {
  523. return b.value - a.value
  524. })
  525. .slice(0, 5)
  526. ),
  527. symbolSize: function (val) {
  528. return 15
  529. },
  530. showEffectOn: 'render',
  531. rippleEffect: {
  532. brushType: 'stroke',
  533. },
  534. hoverAnimation: true,
  535. label: {
  536. normal: {
  537. formatter: '{b}',
  538. position: 'left',
  539. show: false,
  540. },
  541. },
  542. itemStyle: {
  543. normal: {
  544. color: 'yellow',
  545. shadowBlur: 10,
  546. shadowColor: 'yellow',
  547. },
  548. },
  549. zlevel: 1000,
  550. },
  551. {
  552. name: '线路',
  553. type: 'lines',
  554. zlevel: 2,
  555. effect: {
  556. show: true,
  557. period: 4, //箭头指向速度,值越小速度越快
  558. trailLength: 0.02, //特效尾迹长度[0,1]值越大,尾迹越长重
  559. symbol: 'arrow', //箭头图标
  560. symbolSize: 5, //图标大小
  561. },
  562. lineStyle: {
  563. normal: {
  564. color: '#00FFFF',
  565. width: 1,
  566. type: 'dashed',
  567. opacity: 0.5, //尾迹线条透明度
  568. curveness: -0.3, //尾迹线条曲直度
  569. },
  570. },
  571. data: moveLine.normal,
  572. },
  573. ],
  574. }
  575. let that = this
  576. myChart.on('click', function (params) {
  577. console.log(params)
  578. if (params.name == '太原市') {
  579. that.showTip = true
  580. }
  581. // window.open('https://www.baidu.com')
  582. })
  583. tools.loopShowTooltip(myChart, option, {
  584. interval: 2000,
  585. loopSeries: false,
  586. });
  587. myChart.setOption(option)
  588. },
  589. // initChartTip(){
  590. // let myChart = echarts.init(this.$refs['echartTip'])
  591. // let option = {
  592. // tooltip: {
  593. // trigger: 'item',
  594. // },
  595. // color: ['#6682f5', '#69c0ff', '#43ede3','#8ba2ff'],
  596. // legend: {
  597. // top: '0',
  598. // orient: 'vertical',
  599. // left: '2%',
  600. // textStyle: {
  601. // color: '#9DB9EB',
  602. // },
  603. // },
  604. // series: [
  605. // {
  606. // name: '',
  607. // type: 'pie',
  608. // center: ['45%','40%'],
  609. // radius: ['35%', '50%'],
  610. // labelLine: {
  611. // normal: {
  612. // lineStyle: {
  613. // width: 1,
  614. // },
  615. // },
  616. // },
  617. // data: statusList,
  618. // },
  619. // ],
  620. // }
  621. // myChart.setOption(option)
  622. // tools.loopShowTooltip(myChart, option, {
  623. // nterval: 2000,
  624. // loopSeries: true,
  625. // })
  626. // myChart.on('click', function(param) {
  627. // console.log(param)
  628. // window.open('https://www.baidu.com')
  629. // })
  630. // },
  631. initChartTip2() {
  632. let myChart = echarts.init(this.$refs['echartTip2'])
  633. let option = {
  634. tooltip: {
  635. trigger: 'axis',
  636. axisPointer: {
  637. type: 'cross',
  638. },
  639. },
  640. // dataZoom:[
  641. // {
  642. // // start: 9,//默认为@
  643. // // end: 100,//黑认认为1@0
  644. // type: "slider",
  645. // show: true,
  646. // // xAxisIndex: [0]
  647. // handlesize: 0,//滑动条的 左右2个滑动条的大小
  648. // startValue: 9,// 初始显示值
  649. // endValue: 6,// 结束显示值
  650. // height: 10,//组件高度
  651. // left:"5%",
  652. // right: "4%",//右边的距离
  653. // bottom: "25%",//底边的距离
  654. // borderColor:"#939",
  655. // fillerColor:"#269cdb",
  656. // borderRadius: 5,
  657. // backgroundColor: "#33384b",//两边未选中的滑动条区域的额色
  658. // showDataShadow: false,//是否显示数据阴影
  659. // showDetail: false,//即拖拽时候是否显示详细数值信息
  660. // truerealtime: false,//是否实时更新
  661. // filterMode: "filter"
  662. // },{
  663. // type:'inside',
  664. // show: true,
  665. // start: 1,
  666. // end: 100
  667. // }
  668. // ],
  669. grid: {
  670. top: '10%',
  671. right: '3%',
  672. left: '10%',
  673. bottom: '30%',
  674. },
  675. legend: {
  676. top: '1',
  677. right: '20',
  678. textStyle: {
  679. color: 'rgba(250,250,250,0.6)',
  680. },
  681. },
  682. xAxis: {
  683. data: tipData.map(item => item.name),
  684. axisLine: {
  685. show: true, //隐藏X轴轴线
  686. lineStyle: {
  687. color: '#005094',
  688. width: 1,
  689. },
  690. },
  691. axisTick: {
  692. show: false, //隐藏X轴刻度
  693. },
  694. axisLabel: {
  695. show: true,
  696. rotate: 40,
  697. textStyle: {
  698. color: '#fff',//'rgba(255,255,255,0.6)', //X轴文字颜色
  699. },
  700. },
  701. },
  702. yAxis: [
  703. {
  704. type: 'value',
  705. nameTextStyle: {
  706. color: '#ebf8ac',
  707. },
  708. splitLine: {
  709. show: true,
  710. lineStyle: {
  711. color: '#68b4dd66',
  712. type: 'dashed',
  713. },
  714. },
  715. axisLine: {
  716. show: true,
  717. lineStyle: {
  718. color: '#3D7495',
  719. },
  720. },
  721. axisLabel: {
  722. show: true,
  723. formatter: '{value} 亿',
  724. textStyle: {
  725. color: 'rgba(250,250,250,0.6)',
  726. },
  727. },
  728. },
  729. ],
  730. series: [
  731. {
  732. name: '投资金额',
  733. type: 'bar',
  734. barWidth: 15,
  735. itemStyle: {
  736. normal: {
  737. color: new echarts.graphic.LinearGradient(0, 0, 0, 1, [
  738. {
  739. offset: 0,
  740. color: '#69c0ff',
  741. },
  742. {
  743. offset: 1,
  744. color: '#082550',
  745. },
  746. ]),
  747. },
  748. },
  749. data: tipData.map(item => item.value),
  750. },
  751. // {
  752. // name: '实际投资',
  753. // type: 'bar',
  754. // barWidth: 10,
  755. // itemStyle: {
  756. // normal: {
  757. // color: new echarts.graphic.LinearGradient(0, 0, 0, 1, [
  758. // {
  759. // offset: 0,
  760. // color: '#957DFF',
  761. // },
  762. // {
  763. // offset: 1,
  764. // color: '#082550',
  765. // },
  766. // ]),
  767. // },
  768. // },
  769. // data: executeList.map(item=>item.value2),
  770. // },
  771. ],
  772. }
  773. myChart.on('click', function (data) {
  774. if (data.name == '交控集团') {
  775. window.location.href = './investHomeChild.html?type=1'
  776. }
  777. })
  778. tools.loopShowTooltip(myChart, option, {
  779. nterval: 2000,
  780. loopSeries: true,
  781. })
  782. myChart.setOption(option)
  783. },
  784. initChartTip3() {
  785. let myChart = echarts.init(this.$refs['echartTip3'])
  786. let option = {
  787. title: {
  788. //text : '产业类别',
  789. x: 'center',
  790. textStyle: {
  791. color: '#fff'
  792. }
  793. },
  794. tooltip: {
  795. trigger: 'axis',
  796. axisPointer: {
  797. type: 'cross',
  798. },
  799. },
  800. grid: {
  801. top: '15%',
  802. right: '3%',
  803. left: '10%',
  804. bottom: '30%',
  805. },
  806. legend: {
  807. top: '1',
  808. right: '15',
  809. textStyle: {
  810. color: 'rgba(250,250,250,0.6)',
  811. },
  812. },
  813. xAxis: {
  814. data: tipTopData.map(item => item.name),
  815. axisLine: {
  816. show: true, //隐藏X轴轴线
  817. lineStyle: {
  818. color: '#005094',
  819. width: 1,
  820. },
  821. },
  822. axisTick: {
  823. show: false, //隐藏X轴刻度
  824. },
  825. axisLabel: {
  826. show: true,
  827. rotate: 30,
  828. textStyle: {
  829. color: '#fff'//color: 'rgba(255,255,255,0.6)', //X轴文字颜色
  830. },
  831. },
  832. },
  833. yAxis: [
  834. {
  835. type: 'value',
  836. nameTextStyle: {
  837. color: '#ebf8ac',
  838. },
  839. splitLine: {
  840. show: true,
  841. lineStyle: {
  842. color: '#68b4dd66',
  843. type: 'dashed',
  844. },
  845. },
  846. axisLine: {
  847. show: true,
  848. lineStyle: {
  849. color: '#3D7495',
  850. },
  851. },
  852. axisLabel: {
  853. show: true,
  854. formatter: '{value} 亿',
  855. textStyle: {
  856. color: 'rgba(250,250,250,0.6)',
  857. },
  858. },
  859. },
  860. ],
  861. series: [
  862. {
  863. name: '2022年投资完成额',
  864. type: 'line',
  865. barWidth: 15,
  866. itemStyle: {
  867. normal: {
  868. color: new echarts.graphic.LinearGradient(0, 0, 0, 1, [
  869. {
  870. offset: 0,
  871. color: '#69c0ff',
  872. },
  873. {
  874. offset: 1,
  875. color: '#69c0ff',
  876. },
  877. ]),
  878. },
  879. },
  880. data: tipTopData.map(item => item.value),
  881. },
  882. // {
  883. // name: '实际投资',
  884. // type: 'bar',
  885. // barWidth: 10,
  886. // itemStyle: {
  887. // normal: {
  888. // color: new echarts.graphic.LinearGradient(0, 0, 0, 1, [
  889. // {
  890. // offset: 0,
  891. // color: '#957DFF',
  892. // },
  893. // {
  894. // offset: 1,
  895. // color: '#082550',
  896. // },
  897. // ]),
  898. // },
  899. // },
  900. // data: executeList.map(item=>item.value2),
  901. // },
  902. ],
  903. }
  904. myChart.setOption(option)
  905. tools.loopShowTooltip(myChart, option, {
  906. nterval: 2000,
  907. loopSeries: true,
  908. })
  909. },
  910. initChartTip4() {
  911. let myChart = echarts.init(this.$refs['echartTip4'])
  912. let option = {
  913. title: {
  914. //text : '投资项目列表',
  915. x: 'center',
  916. textStyle: {
  917. color: '#fff'
  918. }
  919. },
  920. tooltip: {
  921. trigger: 'axis',
  922. axisPointer: {
  923. type: 'cross',
  924. },
  925. },
  926. // dataZoom:[
  927. // {
  928. // // start: 9,//默认为@
  929. // // end: 100,//黑认认为1@0
  930. // type: "slider",
  931. // show: true,
  932. // // xAxisIndex: [0]
  933. // handlesize: 0,//滑动条的 左右2个滑动条的大小
  934. // startValue: 9,// 初始显示值
  935. // endValue: 6,// 结束显示值
  936. // height: 10,//组件高度
  937. // left:"5%",
  938. // right: "4%",//右边的距离
  939. // bottom: "25%",//底边的距离
  940. // borderColor:"#939",
  941. // fillerColor:"#269cdb",
  942. // borderRadius: 5,
  943. // backgroundColor: "#33384b",//两边未选中的滑动条区域的额色
  944. // showDataShadow: false,//是否显示数据阴影
  945. // showDetail: false,//即拖拽时候是否显示详细数值信息
  946. // truerealtime: false,//是否实时更新
  947. // filterMode: "filter"
  948. // },{
  949. // type:'inside',
  950. // show: true,
  951. // start: 1,
  952. // end: 100
  953. // }
  954. // ],
  955. grid: {
  956. top: '15%',
  957. right: '3%',
  958. left: '10%',
  959. bottom: '20%',
  960. },
  961. legend: {
  962. top: '0',
  963. right: '20',
  964. textStyle: {
  965. color: 'rgba(250,250,250,0.6)',
  966. },
  967. },
  968. xAxis: {
  969. data: tipBottomData.map(item => item.name),
  970. axisLine: {
  971. show: true, //隐藏X轴轴线
  972. lineStyle: {
  973. color: '#005094',
  974. width: 1,
  975. },
  976. },
  977. axisTick: {
  978. show: false, //隐藏X轴刻度
  979. },
  980. axisLabel: {
  981. show: true,
  982. rotate: 30,
  983. textStyle: {
  984. color: '#fff'//color: 'rgba(255,255,255,0.6)', //X轴文字颜色
  985. },
  986. },
  987. },
  988. yAxis: [
  989. {
  990. type: 'value',
  991. nameTextStyle: {
  992. color: '#ebf8ac',
  993. },
  994. splitLine: {
  995. show: true,
  996. lineStyle: {
  997. color: '#68b4dd66',
  998. type: 'dashed',
  999. },
  1000. },
  1001. axisLine: {
  1002. show: true,
  1003. lineStyle: {
  1004. color: '#3D7495',
  1005. },
  1006. },
  1007. axisLabel: {
  1008. show: true,
  1009. formatter: '{value} 亿',
  1010. textStyle: {
  1011. color: 'rgba(250,250,250,0.6)',
  1012. },
  1013. },
  1014. },
  1015. ],
  1016. series: [
  1017. {
  1018. name: '2022年投资完成额',
  1019. type: 'bar',
  1020. barWidth: 15,
  1021. itemStyle: {
  1022. normal: {
  1023. color: new echarts.graphic.LinearGradient(0, 0, 0, 1, [
  1024. {
  1025. offset: 0,
  1026. color: '#69c0ff',
  1027. },
  1028. {
  1029. offset: 1,
  1030. color: '#082550',
  1031. },
  1032. ]),
  1033. },
  1034. },
  1035. data: tipBottomData.map(item => item.value),
  1036. },
  1037. ],
  1038. }
  1039. myChart.on('click', function (data) {
  1040. if (data.name == '华阳新材') {
  1041. window.location.href = './investHomeChild.html?type=2'
  1042. }
  1043. })
  1044. myChart.setOption(option)
  1045. tools.loopShowTooltip(myChart, option, {
  1046. nterval: 2000,
  1047. loopSeries: true,
  1048. })
  1049. },
  1050. // initChartL1() {
  1051. // let myChart = echarts.init(this.$refs['echartR1'])
  1052. // // 生成扇形的曲面参数方程,用于 series-surface.parametricEquation
  1053. // function getParametricEquation(startRatio, endRatio, isSelected, isHovered, k) {
  1054. // // 计算
  1055. // let midRatio = (startRatio + endRatio) / 2;
  1056. // let startRadian = startRatio * Math.PI * 2;
  1057. // let endRadian = endRatio * Math.PI * 2;
  1058. // let midRadian = midRatio * Math.PI * 2;
  1059. // // 如果只有一个扇形,则不实现选中效果。
  1060. // if (startRatio === 0 && endRatio === 1) {
  1061. // isSelected = false;
  1062. // }
  1063. // // 通过扇形内径/外径的值,换算出辅助参数 k(默认值 1/3)
  1064. // k = typeof k !== 'undefined' ? k : 1 / 3;
  1065. // // 计算选中效果分别在 x 轴、y 轴方向上的位移(未选中,则位移均为 0)
  1066. // let offsetX = isSelected ? Math.cos(midRadian) * 0.1 : 0;
  1067. // let offsetY = isSelected ? Math.sin(midRadian) * 0.1 : 0;
  1068. // // 计算高亮效果的放大比例(未高亮,则比例为 1)
  1069. // let hoverRate = isHovered ? 1.07 : 1;
  1070. // // 返回曲面参数方程
  1071. // return {
  1072. // u: {
  1073. // min: -Math.PI,
  1074. // max: Math.PI * 3,
  1075. // step: Math.PI / 32,
  1076. // },
  1077. // v: {
  1078. // min: 0,
  1079. // max: Math.PI * 2,
  1080. // step: Math.PI / 20,
  1081. // },
  1082. // x: function (u, v) {
  1083. // if (u < startRadian) {
  1084. // return offsetX + Math.cos(startRadian) * (1 + Math.cos(v) * k) * hoverRate;
  1085. // }
  1086. // if (u > endRadian) {
  1087. // return offsetX + Math.cos(endRadian) * (1 + Math.cos(v) * k) * hoverRate;
  1088. // }
  1089. // return offsetX + Math.cos(u) * (1 + Math.cos(v) * k) * hoverRate;
  1090. // },
  1091. // y: function (u, v) {
  1092. // if (u < startRadian) {
  1093. // return offsetY + Math.sin(startRadian) * (1 + Math.cos(v) * k) * hoverRate;
  1094. // }
  1095. // if (u > endRadian) {
  1096. // return offsetY + Math.sin(endRadian) * (1 + Math.cos(v) * k) * hoverRate;
  1097. // }
  1098. // return offsetY + Math.sin(u) * (1 + Math.cos(v) * k) * hoverRate;
  1099. // },
  1100. // z: function (u, v) {
  1101. // if (u < -Math.PI * 0.5) {
  1102. // return Math.sin(u);
  1103. // }
  1104. // if (u > Math.PI * 2.5) {
  1105. // return Math.sin(u);
  1106. // }
  1107. // return Math.sin(v) > 0 ? 1 : -1;
  1108. // },
  1109. // };
  1110. // }
  1111. // // 生成模拟 3D 饼图的配置项
  1112. // function getPie3D(pieData, internalDiameterRatio) {
  1113. // let series = [];
  1114. // let sumValue = 0;
  1115. // let startValue = 0;
  1116. // let endValue = 0;
  1117. // let legendData = [];
  1118. // let k =
  1119. // typeof internalDiameterRatio !== 'undefined'
  1120. // ? (1 - internalDiameterRatio) / (1 + internalDiameterRatio)
  1121. // : 1 / 3;
  1122. // // 新增标签 series @20210613
  1123. // let labelSeries = {
  1124. // id: 'labelSeries',
  1125. // type: 'bar3D',
  1126. // //zlevel:-9,
  1127. // barSize: [0.1, 0.1],
  1128. // data: [],
  1129. // label: {
  1130. // show: true,
  1131. // formatter: function (params) {
  1132. // return `${params.name}\n${params.value[3]}`;
  1133. // },
  1134. // backgroundColor: '#fff',
  1135. // },
  1136. // };
  1137. // // 为每一个饼图数据,生成一个 series-surface 配置
  1138. // for (let i = 0; i < pieData.length; i++) {
  1139. // sumValue += pieData[i].value;
  1140. // let seriesItem = {
  1141. // name: typeof pieData[i].name === 'undefined' ? `series${i}` : pieData[i].name,
  1142. // type: 'surface',
  1143. // parametric: true,
  1144. // wireframe: {
  1145. // show: false,
  1146. // },
  1147. // pieData: pieData[i],
  1148. // pieStatus: {
  1149. // selected: false,
  1150. // hovered: false,
  1151. // k: k,
  1152. // },
  1153. // };
  1154. // if (typeof pieData[i].itemStyle != 'undefined') {
  1155. // let itemStyle = {};
  1156. // typeof pieData[i].itemStyle.color != 'undefined' ? (itemStyle.color = pieData[i].itemStyle.color) : null;
  1157. // typeof pieData[i].itemStyle.opacity != 'undefined'
  1158. // ? (itemStyle.opacity = pieData[i].itemStyle.opacity)
  1159. // : null;
  1160. // seriesItem.itemStyle = itemStyle;
  1161. // }
  1162. // series.push(seriesItem);
  1163. // }
  1164. // // 使用上一次遍历时,计算出的数据和 sumValue,调用 getParametricEquation 函数,
  1165. // // 向每个 series-surface 传入不同的参数方程 series-surface.parametricEquation,也就是实现每一个扇形。
  1166. // for (let i = 0; i < series.length; i++) {
  1167. // endValue = startValue + series[i].pieData.value;
  1168. // series[i].pieData.startRatio = startValue / sumValue;
  1169. // series[i].pieData.endRatio = endValue / sumValue;
  1170. // series[i].parametricEquation = getParametricEquation(
  1171. // series[i].pieData.startRatio,
  1172. // series[i].pieData.endRatio,
  1173. // false,
  1174. // false,
  1175. // k
  1176. // );
  1177. // startValue = endValue;
  1178. // legendData.push(series[i].name);
  1179. // // 判断增加 label 效果 @20210613
  1180. // if (pieData[i].label && pieData[i].label.show) {
  1181. // labelRadian = (series[i].pieData.startRatio + series[i].pieData.endRatio) * Math.PI;
  1182. // labelSeries.data.push({
  1183. // name: series[i].name,
  1184. // value: [Math.cos(labelRadian), Math.sin(labelRadian), 1.2, series[i].pieData.value],
  1185. // itemStyle: {
  1186. // opacity: 1,
  1187. // },
  1188. // });
  1189. // }
  1190. // }
  1191. // // 补充一个透明的圆环,用于支撑高亮功能的近似实现。
  1192. // series.push({
  1193. // name: 'mouseoutSeries',
  1194. // type: 'surface',
  1195. // parametric: true,
  1196. // wireframe: {
  1197. // show: false,
  1198. // },
  1199. // itemStyle: {
  1200. // opacity: 0,
  1201. // },
  1202. // parametricEquation: {
  1203. // u: {
  1204. // min: 0,
  1205. // max: Math.PI * 2,
  1206. // step: Math.PI / 20,
  1207. // },
  1208. // v: {
  1209. // min: 0,
  1210. // max: Math.PI,
  1211. // step: Math.PI / 20,
  1212. // },
  1213. // x: function (u, v) {
  1214. // return Math.sin(v) * Math.sin(u) + Math.sin(u);
  1215. // },
  1216. // y: function (u, v) {
  1217. // return Math.sin(v) * Math.cos(u) + Math.cos(u);
  1218. // },
  1219. // z: function (u, v) {
  1220. // return Math.cos(v) > 0 ? 0.1 : -0.1;
  1221. // },
  1222. // },
  1223. // });
  1224. // // 将 labelSeries 添加进去 @20210613
  1225. // series.push(labelSeries);
  1226. // // 准备待返回的配置项,把准备好的 legendData、series 传入。
  1227. // let option = {
  1228. // //animation: false,
  1229. // legend: {
  1230. // data: legendData,
  1231. // op: '5%',
  1232. // //orient: 'vertical',
  1233. // textStyle: {
  1234. // color: '#fff',
  1235. // },
  1236. // },
  1237. // tooltip: {
  1238. // formatter: (params) => {
  1239. // if (params.seriesName !== 'mouseoutSeries') {
  1240. // return `${
  1241. // params.seriesName
  1242. // }<br/><span style="display:inline-block;margin-right:5px;border-radius:10px;width:10px;height:10px;background-color:${
  1243. // params.color
  1244. // };"></span>${option.series[params.seriesIndex].pieData.value}`;
  1245. // }
  1246. // },
  1247. // },
  1248. // // 增加渐变色尝试(手动通过 seriesIndex 指定系列) @20211228
  1249. // xAxis3D: {
  1250. // min: -1,
  1251. // max: 1,
  1252. // },
  1253. // yAxis3D: {
  1254. // min: -1,
  1255. // max: 1,
  1256. // },
  1257. // zAxis3D: {
  1258. // min: -1,
  1259. // max: 1,
  1260. // },
  1261. // grid3D: {
  1262. // show: false,
  1263. // boxHeight: 10,
  1264. // //top: '30%',
  1265. // bottom: '50%',
  1266. // viewControl: {
  1267. // //3d效果可以放大、旋转等,请自己去查看官方配置
  1268. // alpha: 30, //角度
  1269. // distance: 150, //调整视角到主体的距离,类似调整zoom
  1270. // rotateSensitivity: 0, //设置为0无法旋转
  1271. // zoomSensitivity: 0, //设置为0无法缩放
  1272. // panSensitivity: 0, //设置为0无法平移
  1273. // autoRotate: false, //自动旋转
  1274. // },
  1275. // },
  1276. // series: series,
  1277. // };
  1278. // return option;
  1279. // }
  1280. // // 传入数据生成 option
  1281. // option = getPie3D([
  1282. // {
  1283. // name: '传统产业投资',
  1284. // value: 405.29,
  1285. // itemStyle: {
  1286. // color: '#6682f5'
  1287. // }
  1288. // }, {
  1289. // name: '战略新兴产业投资',
  1290. // value: 196.44,
  1291. // itemStyle: {
  1292. // color: '#69c0ff'
  1293. // }
  1294. // }, {
  1295. // name: '基础产业投资',
  1296. // value: 722.34,
  1297. // itemStyle: {
  1298. // color: '#43ede3'
  1299. // }
  1300. // }
  1301. // ]);
  1302. // myChart.setOption(option);
  1303. // // 监听鼠标事件,实现饼图选中效果(单选),近似实现高亮(放大)效果。
  1304. // let selectedIndex = '';
  1305. // let hoveredIndex = '';
  1306. // let that = this
  1307. // // 监听点击事件,实现选中效果(单选)
  1308. // myChart.on('click', function (param) {
  1309. // console.log(param)
  1310. // if (param.seriesName == '战略新兴产业投资') {
  1311. // that.tipTitle2 = param.seriesName
  1312. // that.showTip2 = true
  1313. // }
  1314. // // 从 option.series 中读取重新渲染扇形所需的参数,将是否选中取反。
  1315. // // let isSelected = !option.series[params.seriesIndex].pieStatus.selected;
  1316. // // let isHovered = option.series[params.seriesIndex].pieStatus.hovered;
  1317. // // let k = option.series[params.seriesIndex].pieStatus.k;
  1318. // // let startRatio = option.series[params.seriesIndex].pieData.startRatio;
  1319. // // let endRatio = option.series[params.seriesIndex].pieData.endRatio;
  1320. // // // 如果之前选中过其他扇形,将其取消选中(对 option 更新)
  1321. // // if (selectedIndex !== '' && selectedIndex !== params.seriesIndex) {
  1322. // // option.series[selectedIndex].parametricEquation = getParametricEquation(
  1323. // // option.series[selectedIndex].pieData.startRatio,
  1324. // // option.series[selectedIndex].pieData.endRatio,
  1325. // // false,
  1326. // // false,
  1327. // // k
  1328. // // );
  1329. // // option.series[selectedIndex].pieStatus.selected = false;
  1330. // // }
  1331. // // // 对当前点击的扇形,执行选中/取消选中操作(对 option 更新)
  1332. // // option.series[params.seriesIndex].parametricEquation = getParametricEquation(
  1333. // // startRatio,
  1334. // // endRatio,
  1335. // // isSelected,
  1336. // // isHovered,
  1337. // // k
  1338. // // );
  1339. // // option.series[params.seriesIndex].pieStatus.selected = isSelected;
  1340. // // // 如果本次是选中操作,记录上次选中的扇形对应的系列号 seriesIndex
  1341. // // isSelected ? (selectedIndex = params.seriesIndex) : null;
  1342. // // // 使用更新后的 option,渲染图表
  1343. // // myChart.setOption(option);
  1344. // });
  1345. // let i = 0
  1346. // this.timeOut = setInterval(function() {
  1347. // console.log(i)
  1348. // let startRatio = option.series[i].pieData.startRatio;
  1349. // let endRatio = option.series[i].pieData.endRatio;
  1350. // let isSelected = option.series[i].pieStatus.selected;
  1351. // let k = option.series[i].pieStatus.k;
  1352. // if(i == 0){
  1353. // let startRatio2 = option.series[2].pieData.startRatio;
  1354. // let endRatio2 = option.series[2].pieData.endRatio;
  1355. // let isSelected2 = option.series[2].pieStatus.selected;
  1356. // let k2 = option.series[2].pieStatus.k;
  1357. // option.series[2].parametricEquation = getParametricEquation(startRatio2, endRatio2, isSelected2, false, k2)
  1358. // } else {
  1359. // let startRatio3 = option.series[i-1].pieData.startRatio;
  1360. // let endRatio3 = option.series[i-1].pieData.endRatio;
  1361. // let isSelected3 = option.series[i-1].pieStatus.selected;
  1362. // let k3 = option.series[i-1].pieStatus.k;
  1363. // option.series[i-1].parametricEquation = getParametricEquation(startRatio3, endRatio3, isSelected3, false, k3)
  1364. // }
  1365. // option.series[i].parametricEquation = getParametricEquation(startRatio, endRatio, isSelected, true, k)
  1366. // myChart.setOption(option);
  1367. // i ++
  1368. // if(i == 3) {
  1369. // i = 0
  1370. // }
  1371. // }, 3000);
  1372. // // 监听 mouseover,近似实现高亮(放大)效果
  1373. // myChart.on('mouseover', function (params) {
  1374. // // 准备重新渲染扇形所需的参数
  1375. // let isSelected;
  1376. // let isHovered;
  1377. // let startRatio;
  1378. // let endRatio;
  1379. // let k;
  1380. // // 如果触发 mouseover 的扇形当前已高亮,则不做操作
  1381. // if (hoveredIndex === params.seriesIndex) {
  1382. // return;
  1383. // // 否则进行高亮及必要的取消高亮操作
  1384. // } else {
  1385. // // 如果当前有高亮的扇形,取消其高亮状态(对 option 更新)
  1386. // if (hoveredIndex !== '') {
  1387. // // 从 option.series 中读取重新渲染扇形所需的参数,将是否高亮设置为 false。
  1388. // isSelected = option.series[hoveredIndex].pieStatus.selected;
  1389. // isHovered = false;
  1390. // startRatio = option.series[hoveredIndex].pieData.startRatio;
  1391. // endRatio = option.series[hoveredIndex].pieData.endRatio;
  1392. // k = option.series[hoveredIndex].pieStatus.k;
  1393. // // 对当前点击的扇形,执行取消高亮操作(对 option 更新)
  1394. // option.series[hoveredIndex].parametricEquation = getParametricEquation(
  1395. // startRatio,
  1396. // endRatio,
  1397. // isSelected,
  1398. // isHovered,
  1399. // k
  1400. // );
  1401. // option.series[hoveredIndex].pieStatus.hovered = isHovered;
  1402. // // 将此前记录的上次选中的扇形对应的系列号 seriesIndex 清空
  1403. // hoveredIndex = '';
  1404. // }
  1405. // // 如果触发 mouseover 的扇形不是透明圆环,将其高亮(对 option 更新)
  1406. // if (params.seriesName !== 'mouseoutSeries') {
  1407. // // 从 option.series 中读取重新渲染扇形所需的参数,将是否高亮设置为 true。
  1408. // isSelected = option.series[params.seriesIndex].pieStatus.selected;
  1409. // isHovered = true;
  1410. // startRatio = option.series[params.seriesIndex].pieData.startRatio;
  1411. // endRatio = option.series[params.seriesIndex].pieData.endRatio;
  1412. // k = option.series[params.seriesIndex].pieStatus.k;
  1413. // // 对当前点击的扇形,执行高亮操作(对 option 更新)
  1414. // option.series[params.seriesIndex].parametricEquation = getParametricEquation(
  1415. // startRatio,
  1416. // endRatio,
  1417. // isSelected,
  1418. // isHovered,
  1419. // k
  1420. // );
  1421. // option.series[params.seriesIndex].pieStatus.hovered = isHovered;
  1422. // // 记录上次高亮的扇形对应的系列号 seriesIndex
  1423. // hoveredIndex = params.seriesIndex;
  1424. // }
  1425. // // 使用更新后的 option,渲染图表
  1426. // myChart.setOption(option);
  1427. // }
  1428. // });
  1429. // // 修正取消高亮失败的 bug
  1430. // myChart.on('globalout', function () {
  1431. // if (hoveredIndex !== '') {
  1432. // // 从 option.series 中读取重新渲染扇形所需的参数,将是否高亮设置为 true。
  1433. // isSelected = option.series[hoveredIndex].pieStatus.selected;
  1434. // isHovered = false;
  1435. // k = option.series[hoveredIndex].pieStatus.k;
  1436. // startRatio = option.series[hoveredIndex].pieData.startRatio;
  1437. // endRatio = option.series[hoveredIndex].pieData.endRatio;
  1438. // // 对当前点击的扇形,执行取消高亮操作(对 option 更新)
  1439. // option.series[hoveredIndex].parametricEquation = getParametricEquation(
  1440. // startRatio,
  1441. // endRatio,
  1442. // isSelected,
  1443. // isHovered,
  1444. // k
  1445. // );
  1446. // option.series[hoveredIndex].pieStatus.hovered = isHovered;
  1447. // // 将此前记录的上次选中的扇形对应的系列号 seriesIndex 清空
  1448. // hoveredIndex = '';
  1449. // }
  1450. // // 使用更新后的 option,渲染图表
  1451. // myChart.setOption(option);
  1452. // });
  1453. // // 新增监听图例事件,同步显示隐藏对应 label @20210613
  1454. // myChart.on('legendselectchanged', function (params) {
  1455. // let seriesLength = option.series.length;
  1456. // console.log(option.series[seriesLength - 1].data);
  1457. // for (let i = 0; i < option.series[seriesLength - 1].data.length; i++) {
  1458. // console.log(option.series[seriesLength - 1].data[i]);
  1459. // if (option.series[seriesLength - 1].data[i].name == params.name) {
  1460. // console.log(option.series[seriesLength - 1].data[i]);
  1461. // params.selected[params.name]
  1462. // ? (option.series[seriesLength - 1].data[i].itemStyle.opacity = 1)
  1463. // : (option.series[seriesLength - 1].data[i].itemStyle.opacity = 0);
  1464. // }
  1465. // }
  1466. // myChart.setOption(option);
  1467. // });
  1468. // console.log('66', myChart);
  1469. // },
  1470. initChartL1 () {
  1471. let myChart = echarts.init(this.$refs['echartR1'])
  1472. let option = {
  1473. tooltip: {
  1474. trigger: 'item',
  1475. position: ['65%', '42%'],
  1476. formatter: params => {
  1477. return `<span style="display:inline-block;border-radius:50%; width:7px;height:7px;background-color:${params.color}"></span> ${params.name}:${params.value} <br/><span style="display:inline-block;border-radius:50%; width:7px;height:7px;background-color:${params.color}"></span> 投资占比:${params.percent}%`
  1478. }, //+ '<br/>'+ '{a1}:{c1}' + '%',
  1479. axisPointer: {
  1480. type: 'cross',
  1481. },
  1482. },
  1483. color: ['#6682f5', '#69c0ff', '#43ede3', '#8ba2ff'],
  1484. legend: {
  1485. left: '2%',
  1486. bottom: '2%',
  1487. orient: 'vertical',
  1488. //right: '2%',
  1489. textStyle: {
  1490. color: '#9DB9EB',
  1491. },
  1492. },
  1493. series: [
  1494. // {
  1495. // hoverOffset: 0,
  1496. // startAngle: 90,
  1497. // type: "pie",
  1498. // radius: [48, 55],
  1499. // center: ["50%", "50%"],
  1500. // itemStyle: {
  1501. // normal: {
  1502. // borderColor: 'rgba(1,31,6,0.7)',
  1503. // borderWidth: 4
  1504. // }
  1505. // },
  1506. // tooltip: {
  1507. // show: false
  1508. // },
  1509. // labelLine: {
  1510. // show: false
  1511. // },
  1512. // label: {
  1513. // show: false
  1514. // },
  1515. // data: industryList
  1516. // },
  1517. {
  1518. name: '',
  1519. type: 'pie',
  1520. radius: ['50%', '75%'],
  1521. center: ["45%", "50%"],
  1522. label:{
  1523. show: false,
  1524. },
  1525. itemStyle: {
  1526. normal: {
  1527. borderColor: 'rgba(1,31,64,0.7)',
  1528. borderWidth: 6
  1529. }
  1530. },
  1531. labelLine: {
  1532. show: false,
  1533. },
  1534. data: industryList,
  1535. },
  1536. ],
  1537. }
  1538. let that = this
  1539. myChart.on('click', function (param) {
  1540. console.log(param)
  1541. if (param.name == '战略新兴产业') {
  1542. that.tipTitle2 = param.name
  1543. that.showTip2 = true
  1544. }
  1545. })
  1546. myChart.setOption(option)
  1547. tools.loopShowTooltip(myChart, option, {
  1548. nterval: 2000,
  1549. loopSeries: true,
  1550. })
  1551. },
  1552. initChartL2() {
  1553. let myChart = echarts.init(this.$refs['echartL2'])
  1554. let option = {
  1555. tooltip: {
  1556. trigger: 'axis',
  1557. axisPointer: {
  1558. type: 'cross',
  1559. },
  1560. },
  1561. grid: {
  1562. top: '16%',
  1563. right: '3%',
  1564. left: '10%',
  1565. bottom: '23%',
  1566. },
  1567. legend: {
  1568. top: '1',
  1569. right: '10',
  1570. textStyle: {
  1571. color: 'rgba(250,250,250,0.6)',
  1572. },
  1573. },
  1574. xAxis: {
  1575. data: executeList.map(item => item.name),
  1576. axisLine: {
  1577. show: true, //隐藏X轴轴线
  1578. lineStyle: {
  1579. color: '#005094',
  1580. width: 1,
  1581. },
  1582. },
  1583. axisTick: {
  1584. show: false, //隐藏X轴刻度
  1585. },
  1586. axisLabel: {
  1587. show: true,
  1588. rotate: 40,
  1589. textStyle: {
  1590. color: '#fff',//'rgba(255,255,255,0.6)', //X轴文字颜色
  1591. },
  1592. },
  1593. },
  1594. yAxis: [
  1595. {
  1596. type: 'value',
  1597. nameTextStyle: {
  1598. color: '#ebf8ac',
  1599. },
  1600. splitLine: {
  1601. show: true,
  1602. lineStyle: {
  1603. color: '#68b4dd66',
  1604. type: 'dashed',
  1605. },
  1606. },
  1607. axisLine: {
  1608. show: true,
  1609. lineStyle: {
  1610. color: '#3D7495',
  1611. },
  1612. },
  1613. axisLabel: {
  1614. show: true,
  1615. textStyle: {
  1616. color: 'rgba(250,250,250,0.6)',
  1617. },
  1618. },
  1619. },
  1620. ],
  1621. series: [
  1622. {
  1623. name: '计划投资',
  1624. type: 'bar',
  1625. barWidth: 10,
  1626. itemStyle: {
  1627. normal: {
  1628. color: new echarts.graphic.LinearGradient(0, 0, 0, 1, [
  1629. {
  1630. offset: 0,
  1631. color: '#69c0ff',
  1632. },
  1633. {
  1634. offset: 1,
  1635. color: '#082550',
  1636. },
  1637. ]),
  1638. },
  1639. },
  1640. data: executeList.map(item => item.value),
  1641. },
  1642. {
  1643. name: '实际投资',
  1644. type: 'bar',
  1645. barWidth: 10,
  1646. itemStyle: {
  1647. normal: {
  1648. color: new echarts.graphic.LinearGradient(0, 0, 0, 1, [
  1649. {
  1650. offset: 0,
  1651. color: '#957DFF',
  1652. },
  1653. {
  1654. offset: 1,
  1655. color: '#082550',
  1656. },
  1657. ]),
  1658. },
  1659. },
  1660. data: executeList.map(item => item.value2),
  1661. },
  1662. ],
  1663. }
  1664. myChart.setOption(option)
  1665. tools.loopShowTooltip(myChart, option, {
  1666. nterval: 2000,
  1667. loopSeries: true,
  1668. })
  1669. },
  1670. initChartR1() {
  1671. let myChart = echarts.init(this.$refs['echartL1'])
  1672. let option = {
  1673. tooltip: {
  1674. trigger: 'axis',
  1675. formatter: '{a0}:{c0}' + '亿元', //+ '<br/>'+ '{a1}:{c1}' + '%',
  1676. axisPointer: {
  1677. type: 'cross',
  1678. },
  1679. },
  1680. grid: {
  1681. top: '16%',
  1682. right: '10%',
  1683. left: '10%',
  1684. bottom: '22%',
  1685. },
  1686. // legend: {
  1687. // top: '1',
  1688. // textStyle: {
  1689. // color: 'rgba(250,250,250,0.6)',
  1690. // },
  1691. // },
  1692. xAxis: {
  1693. data: statusList.map(item => item.name),
  1694. axisLine: {
  1695. show: true, //隐藏X轴轴线
  1696. lineStyle: {
  1697. color: '#005094',
  1698. width: 1,
  1699. },
  1700. },
  1701. axisTick: {
  1702. show: false, //隐藏X轴刻度
  1703. },
  1704. axisLabel: {
  1705. show: true,
  1706. rotate: 20,
  1707. textStyle: {
  1708. color: '#fff',//'rgba(255,255,255,0.6)', //X轴文字颜色
  1709. },
  1710. },
  1711. },
  1712. yAxis: [
  1713. {
  1714. type: 'value',
  1715. name: '亿元',
  1716. nameTextStyle: {
  1717. color: 'rgba(255,255,255,0.6)',
  1718. },
  1719. splitLine: {
  1720. show: true,
  1721. lineStyle: {
  1722. color: '#68b4dd66',
  1723. type: 'dashed',
  1724. },
  1725. },
  1726. axisLine: {
  1727. show: true,
  1728. lineStyle: {
  1729. color: '#3D7495',
  1730. },
  1731. },
  1732. axisLabel: {
  1733. show: true,
  1734. textStyle: {
  1735. color: 'rgba(250,250,250,0.6)',
  1736. },
  1737. },
  1738. },
  1739. {
  1740. type: 'value',
  1741. axisLine: {
  1742. show: false,
  1743. },
  1744. splitLine: {
  1745. show: false,
  1746. },
  1747. axisLabel: {
  1748. show: true,
  1749. formatter: '{value} %',
  1750. textStyle: {
  1751. color: 'rgba(250,250,250,0.6)',
  1752. },
  1753. },
  1754. },
  1755. ],
  1756. series: [
  1757. {
  1758. type: 'bar',
  1759. name: '投资金额',
  1760. barWidth: 15,
  1761. itemStyle: {
  1762. normal: {
  1763. color: new echarts.graphic.LinearGradient(0, 0, 0, 1, [
  1764. {
  1765. offset: 0,
  1766. color: '#69c0ff',
  1767. },
  1768. {
  1769. offset: 1,
  1770. color: '#082550',
  1771. },
  1772. ]),
  1773. },
  1774. },
  1775. data: statusList.map(item => item.value),
  1776. },
  1777. ],
  1778. }
  1779. myChart.setOption(option)
  1780. tools.loopShowTooltip(myChart, option, {
  1781. nterval: 2000,
  1782. loopSeries: true,
  1783. })
  1784. },
  1785. initChartR2() {
  1786. let myChart = echarts.init(this.$refs['echartR2'])
  1787. let option = {
  1788. tooltip: {
  1789. trigger: 'item',
  1790. position: ['65%', '42%'],
  1791. formatter: params => {
  1792. return `<span style="display:inline-block;border-radius:50%; width:7px;height:7px;background-color:${params.color}"></span> 项目数量:${params.value}个 <br/><span style="display:inline-block;border-radius:50%; width:7px;height:7px;background-color:${params.color}"></span> 投资完成额:${params.data.value2}亿`
  1793. }, //+ '<br/>'+ '{a1}:{c1}' + '%',
  1794. axisPointer: {
  1795. type: 'cross',
  1796. },
  1797. },
  1798. color: [ '#43ede3', '#8ba2ff'],
  1799. legend: {
  1800. left: '5%',
  1801. bottom: '2%',
  1802. orient: 'vertical',
  1803. //right: '2%',
  1804. textStyle: {
  1805. color: '#9DB9EB',
  1806. },
  1807. },
  1808. series: [
  1809. {
  1810. name: '',
  1811. type: 'pie',
  1812. radius: ['50%', '75%'],
  1813. center: ["45%", "50%"],
  1814. label:{
  1815. show: false,
  1816. },
  1817. itemStyle: {
  1818. normal: {
  1819. borderColor: 'rgba(1,31,64,0.7)',
  1820. borderWidth: 6
  1821. }
  1822. },
  1823. labelLine: {
  1824. show: false,
  1825. },
  1826. data: chartDateR2,
  1827. },
  1828. ],
  1829. }
  1830. myChart.setOption(option)
  1831. tools.loopShowTooltip(myChart, option, {
  1832. nterval: 2000,
  1833. loopSeries: true,
  1834. })
  1835. },
  1836. initProjectList() {
  1837. let dataList = []
  1838. projectList.map(item => {
  1839. dataList.push([item.office,item.name, item.value + '亿'])
  1840. })
  1841. this.storageRecordConfig = {
  1842. header: ['企业集团', '项目名称', '投资金额'],
  1843. headerBGC: '#05507b33',
  1844. oddRowBGC: '#05507b33',
  1845. evenRowBGC: '',
  1846. headerHeight: '40',
  1847. rowNum: 5,
  1848. columnWidth: [100, 350],
  1849. align: ['center', 'center', 'center'],
  1850. data: dataList,
  1851. }
  1852. }
  1853. },
  1854. })