investHome.js 63 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798991001011021031041051061071081091101111121131141151161171181191201211221231241251261271281291301311321331341351361371381391401411421431441451461471481491501511521531541551561571581591601611621631641651661671681691701711721731741751761771781791801811821831841851861871881891901911921931941951961971981992002012022032042052062072082092102112122132142152162172182192202212222232242252262272282292302312322332342352362372382392402412422432442452462472482492502512522532542552562572582592602612622632642652662672682692702712722732742752762772782792802812822832842852862872882892902912922932942952962972982993003013023033043053063073083093103113123133143153163173183193203213223233243253263273283293303313323333343353363373383393403413423433443453463473483493503513523533543553563573583593603613623633643653663673683693703713723733743753763773783793803813823833843853863873883893903913923933943953963973983994004014024034044054064074084094104114124134144154164174184194204214224234244254264274284294304314324334344354364374384394404414424434444454464474484494504514524534544554564574584594604614624634644654664674684694704714724734744754764774784794804814824834844854864874884894904914924934944954964974984995005015025035045055065075085095105115125135145155165175185195205215225235245255265275285295305315325335345355365375385395405415425435445455465475485495505515525535545555565575585595605615625635645655665675685695705715725735745755765775785795805815825835845855865875885895905915925935945955965975985996006016026036046056066076086096106116126136146156166176186196206216226236246256266276286296306316326336346356366376386396406416426436446456466476486496506516526536546556566576586596606616626636646656666676686696706716726736746756766776786796806816826836846856866876886896906916926936946956966976986997007017027037047057067077087097107117127137147157167177187197207217227237247257267277287297307317327337347357367377387397407417427437447457467477487497507517527537547557567577587597607617627637647657667677687697707717727737747757767777787797807817827837847857867877887897907917927937947957967977987998008018028038048058068078088098108118128138148158168178188198208218228238248258268278288298308318328338348358368378388398408418428438448458468478488498508518528538548558568578588598608618628638648658668678688698708718728738748758768778788798808818828838848858868878888898908918928938948958968978988999009019029039049059069079089099109119129139149159169179189199209219229239249259269279289299309319329339349359369379389399409419429439449459469479489499509519529539549559569579589599609619629639649659669679689699709719729739749759769779789799809819829839849859869879889899909919929939949959969979989991000100110021003100410051006100710081009101010111012101310141015101610171018101910201021102210231024102510261027102810291030103110321033103410351036103710381039104010411042104310441045104610471048104910501051105210531054105510561057105810591060106110621063106410651066106710681069107010711072107310741075107610771078107910801081108210831084108510861087108810891090109110921093109410951096109710981099110011011102110311041105110611071108110911101111111211131114111511161117111811191120112111221123112411251126112711281129113011311132113311341135113611371138113911401141114211431144114511461147114811491150115111521153115411551156115711581159116011611162116311641165116611671168116911701171117211731174117511761177117811791180118111821183118411851186118711881189119011911192119311941195119611971198119912001201120212031204120512061207120812091210121112121213121412151216121712181219122012211222122312241225122612271228122912301231123212331234123512361237123812391240124112421243124412451246124712481249125012511252125312541255125612571258125912601261126212631264126512661267126812691270127112721273127412751276127712781279128012811282128312841285128612871288128912901291129212931294129512961297129812991300130113021303130413051306130713081309131013111312131313141315131613171318131913201321132213231324132513261327132813291330133113321333133413351336133713381339134013411342134313441345134613471348134913501351135213531354135513561357135813591360136113621363136413651366136713681369137013711372137313741375137613771378137913801381138213831384138513861387138813891390139113921393139413951396139713981399140014011402140314041405140614071408140914101411141214131414141514161417141814191420142114221423142414251426142714281429143014311432143314341435143614371438143914401441144214431444144514461447144814491450145114521453145414551456145714581459146014611462146314641465146614671468146914701471147214731474147514761477147814791480148114821483148414851486148714881489149014911492149314941495149614971498149915001501150215031504150515061507150815091510151115121513151415151516151715181519152015211522152315241525152615271528152915301531153215331534153515361537153815391540154115421543154415451546154715481549155015511552155315541555155615571558155915601561156215631564156515661567156815691570157115721573157415751576157715781579158015811582158315841585158615871588158915901591159215931594159515961597159815991600160116021603160416051606160716081609161016111612161316141615161616171618161916201621162216231624162516261627162816291630163116321633163416351636163716381639164016411642164316441645164616471648164916501651165216531654165516561657165816591660166116621663166416651666166716681669167016711672167316741675167616771678167916801681168216831684168516861687168816891690169116921693169416951696169716981699170017011702170317041705170617071708170917101711171217131714171517161717171817191720172117221723172417251726172717281729173017311732173317341735173617371738173917401741174217431744174517461747174817491750175117521753175417551756175717581759176017611762176317641765176617671768176917701771177217731774177517761777177817791780178117821783178417851786178717881789179017911792179317941795179617971798179918001801180218031804180518061807180818091810181118121813181418151816181718181819182018211822182318241825182618271828182918301831183218331834183518361837183818391840184118421843184418451846184718481849185018511852185318541855185618571858185918601861186218631864186518661867186818691870187118721873187418751876187718781879188018811882188318841885188618871888188918901891189218931894189518961897189818991900190119021903190419051906190719081909191019111912191319141915
  1. let app = new Vue({
  2. el: '#app',
  3. data() {
  4. return {
  5. showTip: false,
  6. showTip2: false,
  7. tipTitle: '',
  8. tipTitle2: '',
  9. year: '2022',
  10. time: '',
  11. timer: '',
  12. mapName: 'shanxi',
  13. geoCoordMap: {},
  14. config1: {
  15. number: [100],
  16. content: '{nt}个',
  17. },
  18. storageRecordConfig: null,
  19. companyList: [
  20. { name: '山西焦煤' },
  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. ],
  39. amountList: amountList,
  40. amountTotal: 0,
  41. classOption: {
  42. step: 0.5
  43. }
  44. }
  45. },
  46. created() {
  47. this.amountList.map(item => {
  48. this.amountTotal += Number(item.value)
  49. })
  50. this.time = formatDate()
  51. this.timer = setInterval(() => {
  52. this.time = formatDate()
  53. }, 1000)
  54. },
  55. beforeDestroy() {
  56. if (this.timer) {
  57. clearInterval(this.timer);
  58. }
  59. },
  60. mounted() {
  61. setTimeout(() => {
  62. // 左侧图表
  63. //this.initChartTip()
  64. this.initChartTip2()
  65. this.initChartTip3()
  66. this.initChartTip4()
  67. this.initChartL1()
  68. this.initChartL2()
  69. this.initChartR1()
  70. this.initChartR2()
  71. this.initChinaChart()
  72. this.initProjectList()
  73. }, 0)
  74. },
  75. methods: {
  76. numFormat(value) {
  77. if (!value) return '0'
  78. var intPart = Number(value).toFixed(0) // 获取整数部分
  79. var intPartFormat = intPart.toString().replace(/(\d)(?=(?:\d{3})+$)/g, '$1,') // 将整数部分逢三一断
  80. var floatPart = '.00' // 预定义小数部分
  81. var value2Array = value.toString().split('.')
  82. // =2表示数据有小数位
  83. if (value2Array.length === 2) {
  84. floatPart = value2Array[1].toString() // 拿到小数部分
  85. if (floatPart.length === 1) {
  86. // 补0
  87. return intPartFormat + '.' + floatPart + '0'
  88. } else {
  89. return intPartFormat + '.' + floatPart
  90. }
  91. } else {
  92. return intPartFormat
  93. }
  94. },
  95. convertData(data) {
  96. var res = []
  97. for (var i = 0; i < data.length; i++) {
  98. var geoCoord = this.geoCoordMap[data[i].name]
  99. if (geoCoord) {
  100. res.push({
  101. name: data[i].name,
  102. value: geoCoord.concat(data[i].value),
  103. })
  104. }
  105. }
  106. return res
  107. },
  108. initChinaChart() {
  109. var data = [
  110. { name: '大同市', value: 60.35 },
  111. { name: '朔州市', value: 33.61 },
  112. { name: '忻州市', value: 73.35 },
  113. { name: '吕梁市', value: 109.04 },
  114. { name: '太原市', value: 251.67 },
  115. { name: '阳泉市', value: 25.12 },
  116. { name: '晋中市', value: 148.57 },
  117. { name: '临汾市', value: 130.55 },
  118. { name: '长治市', value: 103.00 },
  119. { name: '运城市', value: 41.06 },
  120. { name: '晋城市', value: 45.43 }
  121. ]
  122. var moveLine = {
  123. normal: [
  124. {
  125. fromName: '太原市',
  126. toName: '吕梁市',
  127. coords: [
  128. [112.3352, 37.9413],
  129. [111.3574, 37.7325],
  130. ],
  131. },
  132. {
  133. fromName: '太原市',
  134. toName: '忻州市',
  135. coords: [
  136. [112.3352, 37.9413],
  137. [112.4561, 38.8971],
  138. ],
  139. },
  140. {
  141. fromName: '太原市',
  142. toName: '临汾市',
  143. coords: [
  144. [112.3352, 37.9413],
  145. [111.4783, 36.1615],
  146. ],
  147. },
  148. {
  149. fromName: '太原市',
  150. toName: '阳泉市',
  151. coords: [
  152. [112.3352, 37.9413],
  153. [113.4778, 38.0951],
  154. ],
  155. },
  156. {
  157. fromName: '太原市',
  158. toName: '晋中市',
  159. coords: [
  160. [112.3352, 37.9413],
  161. [112.7747, 37.37],
  162. ],
  163. },
  164. {
  165. fromName: '太原市',
  166. toName: '运城市',
  167. coords: [
  168. [112.3352, 37.9413],
  169. [111.1487, 35.2002],
  170. ],
  171. },
  172. {
  173. fromName: '太原市',
  174. toName: '大同市',
  175. coords: [
  176. [112.3352, 37.9413],
  177. [113.7854, 39.8035],
  178. ],
  179. },
  180. {
  181. fromName: '太原市',
  182. toName: '晋城市',
  183. coords: [
  184. [112.3352, 37.9413],
  185. [112.7856, 35.6342],
  186. ],
  187. },
  188. {
  189. fromName: '太原市',
  190. toName: '长治市',
  191. coords: [
  192. [112.3352, 37.9413],
  193. [112.8625, 36.4746],
  194. ],
  195. },
  196. {
  197. fromName: '太原市',
  198. toName: '朔州市',
  199. coords: [
  200. [112.3352, 37.9413],
  201. [113.0713, 39.6991],
  202. ],
  203. },
  204. ],
  205. }
  206. /*获取地图数据*/
  207. let myChart = echarts.init(this.$refs['echarts-map'])
  208. echarts.registerMap('shanxi', {
  209. type: 'FeatureCollection',
  210. features: [
  211. {
  212. type: 'Feature',
  213. id: '1409',
  214. properties: { name: '忻州市', cp: [112.4561, 38.8971], childNum: 14 },
  215. geometry: {
  216. type: 'Polygon',
  217. coordinates: [
  218. '@@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',
  219. ],
  220. encodeOffsets: [[113614, 39657]],
  221. },
  222. },
  223. {
  224. type: 'Feature',
  225. id: '1411',
  226. properties: { name: '吕梁市', cp: [111.3574, 37.7325], childNum: 13 },
  227. geometry: {
  228. type: 'Polygon',
  229. coordinates: [
  230. '@@@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',
  231. ],
  232. encodeOffsets: [[113614, 39657]],
  233. },
  234. },
  235. {
  236. type: 'Feature',
  237. id: '1410',
  238. properties: { name: '临汾市', cp: [111.4783, 36.1615], childNum: 17 },
  239. geometry: {
  240. type: 'Polygon',
  241. coordinates: [
  242. '@@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',
  243. ],
  244. encodeOffsets: [[113063, 37784]],
  245. },
  246. },
  247. {
  248. type: 'Feature',
  249. id: '1407',
  250. properties: { name: '晋中市', cp: [112.7747, 37.37], childNum: 11 },
  251. geometry: {
  252. type: 'Polygon',
  253. coordinates: [
  254. '@@@š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@',
  255. ],
  256. encodeOffsets: [[114087, 37682]],
  257. },
  258. },
  259. {
  260. type: 'Feature',
  261. id: '1408',
  262. properties: { name: '运城市', cp: [111.1487, 35.2002], childNum: 13 },
  263. geometry: {
  264. type: 'Polygon',
  265. coordinates: [
  266. '@@„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@„',
  267. ],
  268. encodeOffsets: [[113232, 36597]],
  269. },
  270. },
  271. {
  272. type: 'Feature',
  273. id: '1402',
  274. properties: { name: '大同市', cp: [113.7854, 39.8035], childNum: 8 },
  275. geometry: {
  276. type: 'Polygon',
  277. coordinates: [
  278. '@@²£š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',
  279. ],
  280. encodeOffsets: [[115335, 41209]],
  281. },
  282. },
  283. {
  284. type: 'Feature',
  285. id: '1404',
  286. properties: { name: '长治市', cp: [112.8625, 36.4746], childNum: 12 },
  287. geometry: {
  288. type: 'Polygon',
  289. coordinates: [
  290. '@@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',
  291. ],
  292. encodeOffsets: [[116269, 37637]],
  293. },
  294. },
  295. {
  296. type: 'Feature',
  297. id: '1406',
  298. properties: { name: '朔州市', cp: [113.0713, 39.6991], childNum: 5 },
  299. geometry: {
  300. type: 'Polygon',
  301. coordinates: [
  302. '@@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‚',
  303. ],
  304. encodeOffsets: [[114615, 40562]],
  305. },
  306. },
  307. {
  308. type: 'Feature',
  309. id: '1405',
  310. properties: { name: '晋城市', cp: [112.7856, 35.6342], childNum: 6 },
  311. geometry: {
  312. type: 'Polygon',
  313. coordinates: [
  314. '@@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°',
  315. ],
  316. encodeOffsets: [[115223, 36895]],
  317. },
  318. },
  319. {
  320. type: 'Feature',
  321. id: '1401',
  322. properties: { name: '太原市', cp: [112.3352, 37.9413], childNum: 5 },
  323. geometry: {
  324. type: 'Polygon',
  325. coordinates: [
  326. '@@„@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š@°',
  327. ],
  328. encodeOffsets: [[114503, 39134]],
  329. },
  330. },
  331. {
  332. type: 'Feature',
  333. id: '1403',
  334. properties: { name: '阳泉市', cp: [113.4778, 38.0951], childNum: 3 },
  335. geometry: {
  336. type: 'Polygon',
  337. coordinates: [
  338. '@@°@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',
  339. ],
  340. encodeOffsets: [[115864, 39336]],
  341. },
  342. },
  343. ],
  344. UTF8Encoding: true,
  345. })
  346. var mapFeatures = echarts.getMap(this.mapName).geoJson.features
  347. mapFeatures.forEach(v => {
  348. // 地区名称
  349. var name = v.properties.name
  350. // 地区经纬度
  351. this.geoCoordMap[name] = v.properties.cp
  352. })
  353. // <p>当前阶段:<span>可论证阶段</span></p>
  354. // <p>时间节点:<span>2021.10-2022.10</span></p>
  355. let option = {
  356. tooltip: {
  357. padding: 15,
  358. enterable: true,
  359. transitionDuration: 1,
  360. formatter: (params, ticket, callback) => {
  361. // 清空所有轮播
  362. for (var k in this.geoCoordMap) {
  363. myChart.dispatchAction({
  364. // type: 'geoUnSelect',
  365. type: 'downplay',
  366. name: k,
  367. })
  368. }
  369. // 如果鼠标滑动到线线上面,则返回空
  370. myChart.dispatchAction({
  371. // type: 'geoSelect',
  372. type: 'highlight',
  373. name: params.name,
  374. })
  375. if (params.componentSubType == 'lines') {
  376. return
  377. }
  378. if (params.componentSubType == 'scatter') {
  379. let tipHtml = `
  380. <div class="tooltip-cont">
  381. <p>新开工:<span>工程建设项目</span></p>
  382. <p>总投资额:<span>${params.data.value[2]}亿</span></p>
  383. </div>`
  384. callback(ticket, tipHtml)
  385. return tipHtml
  386. }
  387. if (params.componentSubType == 'map') {
  388. let tipHtml = `
  389. <div class="tooltip-cont">
  390. <p>新开工:<span>工程建设项目</span></p>
  391. <p>总投资额:<span>${params.data.value}亿</span></p>
  392. </div>`
  393. callback(ticket, tipHtml)
  394. return tipHtml
  395. }
  396. },
  397. },
  398. visualMap: {
  399. show: false,
  400. min: 0,
  401. max: 300,
  402. right: 0,
  403. bottom: 0,
  404. text: ['高', '低'],
  405. textStyle: {
  406. color: '#f1f1f1'
  407. },
  408. realtime: false,
  409. calculable: false,
  410. inRange: {
  411. color: ['lightskyblue', '#2754b7']
  412. }
  413. },
  414. geo: {
  415. show: true,
  416. map: 'shanxi',
  417. layoutCenter: ['50%', '50%'], //地图位置
  418. layoutSize: '100%',
  419. label: {
  420. normal: {
  421. show: false,
  422. },
  423. emphasis: {
  424. show: false,
  425. },
  426. },
  427. roam: false,
  428. itemStyle: {
  429. normal: {
  430. areaColor: '#1946a8',
  431. shadowColor: '#1946a8',
  432. borderWidth: 1, //设置外层边框
  433. borderColor: '#1946a8',
  434. shadowOffsetX: 10,
  435. shadowOffsetY: 5,
  436. shadowBlur: 2,
  437. },
  438. emphasis: {
  439. areaColor: '#1946a8',
  440. borderColor: '#d4bc1d',
  441. borderWidth: 2, //设置外层边框
  442. },
  443. },
  444. },
  445. series: [
  446. {
  447. name: '散点',
  448. type: 'scatter',
  449. coordinateSystem: 'geo',
  450. data: this.convertData(data),
  451. symbolSize: function (val) {
  452. return 10
  453. },
  454. label: {
  455. normal: {
  456. formatter: '{b}',
  457. position: [10, 10],
  458. fontSize: 15,
  459. fontWeight: 600,
  460. fontStyle: 'italic',
  461. color: '#fff',
  462. show: true,
  463. },
  464. emphasis: {
  465. show: true,
  466. },
  467. },
  468. itemStyle: {
  469. normal: {
  470. color: '#000',
  471. borderWidth: 2,
  472. borderColor: '#fff',
  473. },
  474. },
  475. },
  476. {
  477. type: 'map',
  478. map: this.mapName,
  479. geoIndex: 0,
  480. aspectScale: 1.5, //长宽比
  481. showLegendSymbol: true, // 存在legend时显示
  482. label: {
  483. normal: {
  484. show: true,
  485. },
  486. emphasis: {
  487. show: false,
  488. textStyle: {
  489. color: '#fff',
  490. },
  491. },
  492. },
  493. roam: true,
  494. itemStyle: {
  495. normal: {
  496. areaColor: '#031525',
  497. borderColor: '#3B5077',
  498. },
  499. emphasis: {
  500. areaColor: '#2B91B7',
  501. },
  502. },
  503. animation: false,
  504. data: data,
  505. },
  506. {
  507. name: '点',
  508. type: 'scatter',
  509. coordinateSystem: 'geo',
  510. zlevel: 6,
  511. },
  512. {
  513. name: 'Top 5',
  514. type: 'effectScatter',
  515. coordinateSystem: 'geo',
  516. data: this.convertData(
  517. data
  518. .sort(function (a, b) {
  519. return b.value - a.value
  520. })
  521. .slice(0, 5)
  522. ),
  523. symbolSize: function (val) {
  524. return 15
  525. },
  526. showEffectOn: 'render',
  527. rippleEffect: {
  528. brushType: 'stroke',
  529. },
  530. hoverAnimation: true,
  531. label: {
  532. normal: {
  533. formatter: '{b}',
  534. position: 'left',
  535. show: false,
  536. },
  537. },
  538. itemStyle: {
  539. normal: {
  540. color: 'yellow',
  541. shadowBlur: 10,
  542. shadowColor: 'yellow',
  543. },
  544. },
  545. zlevel: 1000,
  546. },
  547. {
  548. name: '线路',
  549. type: 'lines',
  550. zlevel: 2,
  551. effect: {
  552. show: true,
  553. period: 4, //箭头指向速度,值越小速度越快
  554. trailLength: 0.02, //特效尾迹长度[0,1]值越大,尾迹越长重
  555. symbol: 'arrow', //箭头图标
  556. symbolSize: 5, //图标大小
  557. },
  558. lineStyle: {
  559. normal: {
  560. color: '#00FFFF',
  561. width: 1,
  562. type: 'dashed',
  563. opacity: 0.5, //尾迹线条透明度
  564. curveness: -0.3, //尾迹线条曲直度
  565. },
  566. },
  567. data: moveLine.normal,
  568. },
  569. ],
  570. }
  571. let that = this
  572. myChart.on('click', function (params) {
  573. console.log(params)
  574. if (params.name == '太原市') {
  575. that.showTip = true
  576. }
  577. // window.open('https://www.baidu.com')
  578. })
  579. tools.loopShowTooltip(myChart, option, {
  580. interval: 2000,
  581. loopSeries: false,
  582. });
  583. myChart.setOption(option)
  584. },
  585. // initChartTip(){
  586. // let myChart = echarts.init(this.$refs['echartTip'])
  587. // let option = {
  588. // tooltip: {
  589. // trigger: 'item',
  590. // },
  591. // color: ['#6682f5', '#69c0ff', '#43ede3','#8ba2ff'],
  592. // legend: {
  593. // top: '0',
  594. // orient: 'vertical',
  595. // left: '2%',
  596. // textStyle: {
  597. // color: '#9DB9EB',
  598. // },
  599. // },
  600. // series: [
  601. // {
  602. // name: '',
  603. // type: 'pie',
  604. // center: ['45%','40%'],
  605. // radius: ['35%', '50%'],
  606. // labelLine: {
  607. // normal: {
  608. // lineStyle: {
  609. // width: 1,
  610. // },
  611. // },
  612. // },
  613. // data: statusList,
  614. // },
  615. // ],
  616. // }
  617. // myChart.setOption(option)
  618. // tools.loopShowTooltip(myChart, option, {
  619. // nterval: 2000,
  620. // loopSeries: true,
  621. // })
  622. // myChart.on('click', function(param) {
  623. // console.log(param)
  624. // window.open('https://www.baidu.com')
  625. // })
  626. // },
  627. initChartTip2() {
  628. let myChart = echarts.init(this.$refs['echartTip2'])
  629. let option = {
  630. tooltip: {
  631. trigger: 'axis',
  632. axisPointer: {
  633. type: 'cross',
  634. },
  635. },
  636. // dataZoom:[
  637. // {
  638. // // start: 9,//默认为@
  639. // // end: 100,//黑认认为1@0
  640. // type: "slider",
  641. // show: true,
  642. // // xAxisIndex: [0]
  643. // handlesize: 0,//滑动条的 左右2个滑动条的大小
  644. // startValue: 9,// 初始显示值
  645. // endValue: 6,// 结束显示值
  646. // height: 10,//组件高度
  647. // left:"5%",
  648. // right: "4%",//右边的距离
  649. // bottom: "25%",//底边的距离
  650. // borderColor:"#939",
  651. // fillerColor:"#269cdb",
  652. // borderRadius: 5,
  653. // backgroundColor: "#33384b",//两边未选中的滑动条区域的额色
  654. // showDataShadow: false,//是否显示数据阴影
  655. // showDetail: false,//即拖拽时候是否显示详细数值信息
  656. // truerealtime: false,//是否实时更新
  657. // filterMode: "filter"
  658. // },{
  659. // type:'inside',
  660. // show: true,
  661. // start: 1,
  662. // end: 100
  663. // }
  664. // ],
  665. grid: {
  666. top: '10%',
  667. right: '3%',
  668. left: '10%',
  669. bottom: '30%',
  670. },
  671. legend: {
  672. top: '1',
  673. right: '20',
  674. textStyle: {
  675. color: 'rgba(250,250,250,0.6)',
  676. },
  677. },
  678. xAxis: {
  679. data: tipData.map(item => item.name),
  680. axisLine: {
  681. show: true, //隐藏X轴轴线
  682. lineStyle: {
  683. color: '#005094',
  684. width: 1,
  685. },
  686. },
  687. axisTick: {
  688. show: false, //隐藏X轴刻度
  689. },
  690. axisLabel: {
  691. show: true,
  692. rotate: 40,
  693. textStyle: {
  694. color: '#fff',//'rgba(255,255,255,0.6)', //X轴文字颜色
  695. },
  696. },
  697. },
  698. yAxis: [
  699. {
  700. type: 'value',
  701. nameTextStyle: {
  702. color: '#ebf8ac',
  703. },
  704. splitLine: {
  705. show: true,
  706. lineStyle: {
  707. color: '#68b4dd66',
  708. type: 'dashed',
  709. },
  710. },
  711. axisLine: {
  712. show: true,
  713. lineStyle: {
  714. color: '#3D7495',
  715. },
  716. },
  717. axisLabel: {
  718. show: true,
  719. formatter: '{value} 亿',
  720. textStyle: {
  721. color: 'rgba(250,250,250,0.6)',
  722. },
  723. },
  724. },
  725. ],
  726. series: [
  727. {
  728. name: '投资金额',
  729. type: 'bar',
  730. barWidth: 15,
  731. itemStyle: {
  732. normal: {
  733. color: new echarts.graphic.LinearGradient(0, 0, 0, 1, [
  734. {
  735. offset: 0,
  736. color: '#69c0ff',
  737. },
  738. {
  739. offset: 1,
  740. color: '#082550',
  741. },
  742. ]),
  743. },
  744. },
  745. data: tipData.map(item => item.value),
  746. },
  747. // {
  748. // name: '实际投资',
  749. // type: 'bar',
  750. // barWidth: 10,
  751. // itemStyle: {
  752. // normal: {
  753. // color: new echarts.graphic.LinearGradient(0, 0, 0, 1, [
  754. // {
  755. // offset: 0,
  756. // color: '#957DFF',
  757. // },
  758. // {
  759. // offset: 1,
  760. // color: '#082550',
  761. // },
  762. // ]),
  763. // },
  764. // },
  765. // data: executeList.map(item=>item.value2),
  766. // },
  767. ],
  768. }
  769. myChart.on('click', function (data) {
  770. if (data.name == '交控集团') {
  771. window.location.href = './investHomeChild.html?type=1'
  772. }
  773. })
  774. tools.loopShowTooltip(myChart, option, {
  775. nterval: 2000,
  776. loopSeries: true,
  777. })
  778. myChart.setOption(option)
  779. },
  780. initChartTip3() {
  781. let myChart = echarts.init(this.$refs['echartTip3'])
  782. let option = {
  783. title: {
  784. //text : '产业类别',
  785. x: 'center',
  786. textStyle: {
  787. color: '#fff'
  788. }
  789. },
  790. tooltip: {
  791. trigger: 'axis',
  792. axisPointer: {
  793. type: 'cross',
  794. },
  795. },
  796. grid: {
  797. top: '15%',
  798. right: '3%',
  799. left: '10%',
  800. bottom: '30%',
  801. },
  802. legend: {
  803. top: '1',
  804. right: '15',
  805. textStyle: {
  806. color: 'rgba(250,250,250,0.6)',
  807. },
  808. },
  809. xAxis: {
  810. data: tipTopData.map(item => item.name),
  811. axisLine: {
  812. show: true, //隐藏X轴轴线
  813. lineStyle: {
  814. color: '#005094',
  815. width: 1,
  816. },
  817. },
  818. axisTick: {
  819. show: false, //隐藏X轴刻度
  820. },
  821. axisLabel: {
  822. show: true,
  823. rotate: 30,
  824. textStyle: {
  825. color: '#fff'//color: 'rgba(255,255,255,0.6)', //X轴文字颜色
  826. },
  827. },
  828. },
  829. yAxis: [
  830. {
  831. type: 'value',
  832. nameTextStyle: {
  833. color: '#ebf8ac',
  834. },
  835. splitLine: {
  836. show: true,
  837. lineStyle: {
  838. color: '#68b4dd66',
  839. type: 'dashed',
  840. },
  841. },
  842. axisLine: {
  843. show: true,
  844. lineStyle: {
  845. color: '#3D7495',
  846. },
  847. },
  848. axisLabel: {
  849. show: true,
  850. formatter: '{value} 亿',
  851. textStyle: {
  852. color: 'rgba(250,250,250,0.6)',
  853. },
  854. },
  855. },
  856. ],
  857. series: [
  858. {
  859. name: '2022年投资完成额',
  860. type: 'line',
  861. barWidth: 15,
  862. itemStyle: {
  863. normal: {
  864. color: new echarts.graphic.LinearGradient(0, 0, 0, 1, [
  865. {
  866. offset: 0,
  867. color: '#69c0ff',
  868. },
  869. {
  870. offset: 1,
  871. color: '#69c0ff',
  872. },
  873. ]),
  874. },
  875. },
  876. data: tipTopData.map(item => item.value),
  877. },
  878. // {
  879. // name: '实际投资',
  880. // type: 'bar',
  881. // barWidth: 10,
  882. // itemStyle: {
  883. // normal: {
  884. // color: new echarts.graphic.LinearGradient(0, 0, 0, 1, [
  885. // {
  886. // offset: 0,
  887. // color: '#957DFF',
  888. // },
  889. // {
  890. // offset: 1,
  891. // color: '#082550',
  892. // },
  893. // ]),
  894. // },
  895. // },
  896. // data: executeList.map(item=>item.value2),
  897. // },
  898. ],
  899. }
  900. myChart.setOption(option)
  901. tools.loopShowTooltip(myChart, option, {
  902. nterval: 2000,
  903. loopSeries: true,
  904. })
  905. },
  906. initChartTip4() {
  907. let myChart = echarts.init(this.$refs['echartTip4'])
  908. let option = {
  909. title: {
  910. //text : '投资项目列表',
  911. x: 'center',
  912. textStyle: {
  913. color: '#fff'
  914. }
  915. },
  916. tooltip: {
  917. trigger: 'axis',
  918. axisPointer: {
  919. type: 'cross',
  920. },
  921. },
  922. // dataZoom:[
  923. // {
  924. // // start: 9,//默认为@
  925. // // end: 100,//黑认认为1@0
  926. // type: "slider",
  927. // show: true,
  928. // // xAxisIndex: [0]
  929. // handlesize: 0,//滑动条的 左右2个滑动条的大小
  930. // startValue: 9,// 初始显示值
  931. // endValue: 6,// 结束显示值
  932. // height: 10,//组件高度
  933. // left:"5%",
  934. // right: "4%",//右边的距离
  935. // bottom: "25%",//底边的距离
  936. // borderColor:"#939",
  937. // fillerColor:"#269cdb",
  938. // borderRadius: 5,
  939. // backgroundColor: "#33384b",//两边未选中的滑动条区域的额色
  940. // showDataShadow: false,//是否显示数据阴影
  941. // showDetail: false,//即拖拽时候是否显示详细数值信息
  942. // truerealtime: false,//是否实时更新
  943. // filterMode: "filter"
  944. // },{
  945. // type:'inside',
  946. // show: true,
  947. // start: 1,
  948. // end: 100
  949. // }
  950. // ],
  951. grid: {
  952. top: '15%',
  953. right: '3%',
  954. left: '10%',
  955. bottom: '20%',
  956. },
  957. legend: {
  958. top: '0',
  959. right: '20',
  960. textStyle: {
  961. color: 'rgba(250,250,250,0.6)',
  962. },
  963. },
  964. xAxis: {
  965. data: tipBottomData.map(item => item.name),
  966. axisLine: {
  967. show: true, //隐藏X轴轴线
  968. lineStyle: {
  969. color: '#005094',
  970. width: 1,
  971. },
  972. },
  973. axisTick: {
  974. show: false, //隐藏X轴刻度
  975. },
  976. axisLabel: {
  977. show: true,
  978. rotate: 30,
  979. textStyle: {
  980. color: '#fff'//color: 'rgba(255,255,255,0.6)', //X轴文字颜色
  981. },
  982. },
  983. },
  984. yAxis: [
  985. {
  986. type: 'value',
  987. nameTextStyle: {
  988. color: '#ebf8ac',
  989. },
  990. splitLine: {
  991. show: true,
  992. lineStyle: {
  993. color: '#68b4dd66',
  994. type: 'dashed',
  995. },
  996. },
  997. axisLine: {
  998. show: true,
  999. lineStyle: {
  1000. color: '#3D7495',
  1001. },
  1002. },
  1003. axisLabel: {
  1004. show: true,
  1005. formatter: '{value} 亿',
  1006. textStyle: {
  1007. color: 'rgba(250,250,250,0.6)',
  1008. },
  1009. },
  1010. },
  1011. ],
  1012. series: [
  1013. {
  1014. name: '2022年投资完成额',
  1015. type: 'bar',
  1016. barWidth: 15,
  1017. itemStyle: {
  1018. normal: {
  1019. color: new echarts.graphic.LinearGradient(0, 0, 0, 1, [
  1020. {
  1021. offset: 0,
  1022. color: '#69c0ff',
  1023. },
  1024. {
  1025. offset: 1,
  1026. color: '#082550',
  1027. },
  1028. ]),
  1029. },
  1030. },
  1031. data: tipBottomData.map(item => item.value),
  1032. },
  1033. ],
  1034. }
  1035. myChart.on('click', function (data) {
  1036. if (data.name == '华阳新材') {
  1037. window.location.href = './investHomeChild.html?type=2'
  1038. }
  1039. })
  1040. myChart.setOption(option)
  1041. tools.loopShowTooltip(myChart, option, {
  1042. nterval: 2000,
  1043. loopSeries: true,
  1044. })
  1045. },
  1046. // initChartL1() {
  1047. // let myChart = echarts.init(this.$refs['echartR1'])
  1048. // // 生成扇形的曲面参数方程,用于 series-surface.parametricEquation
  1049. // function getParametricEquation(startRatio, endRatio, isSelected, isHovered, k) {
  1050. // // 计算
  1051. // let midRatio = (startRatio + endRatio) / 2;
  1052. // let startRadian = startRatio * Math.PI * 2;
  1053. // let endRadian = endRatio * Math.PI * 2;
  1054. // let midRadian = midRatio * Math.PI * 2;
  1055. // // 如果只有一个扇形,则不实现选中效果。
  1056. // if (startRatio === 0 && endRatio === 1) {
  1057. // isSelected = false;
  1058. // }
  1059. // // 通过扇形内径/外径的值,换算出辅助参数 k(默认值 1/3)
  1060. // k = typeof k !== 'undefined' ? k : 1 / 3;
  1061. // // 计算选中效果分别在 x 轴、y 轴方向上的位移(未选中,则位移均为 0)
  1062. // let offsetX = isSelected ? Math.cos(midRadian) * 0.1 : 0;
  1063. // let offsetY = isSelected ? Math.sin(midRadian) * 0.1 : 0;
  1064. // // 计算高亮效果的放大比例(未高亮,则比例为 1)
  1065. // let hoverRate = isHovered ? 1.07 : 1;
  1066. // // 返回曲面参数方程
  1067. // return {
  1068. // u: {
  1069. // min: -Math.PI,
  1070. // max: Math.PI * 3,
  1071. // step: Math.PI / 32,
  1072. // },
  1073. // v: {
  1074. // min: 0,
  1075. // max: Math.PI * 2,
  1076. // step: Math.PI / 20,
  1077. // },
  1078. // x: function (u, v) {
  1079. // if (u < startRadian) {
  1080. // return offsetX + Math.cos(startRadian) * (1 + Math.cos(v) * k) * hoverRate;
  1081. // }
  1082. // if (u > endRadian) {
  1083. // return offsetX + Math.cos(endRadian) * (1 + Math.cos(v) * k) * hoverRate;
  1084. // }
  1085. // return offsetX + Math.cos(u) * (1 + Math.cos(v) * k) * hoverRate;
  1086. // },
  1087. // y: function (u, v) {
  1088. // if (u < startRadian) {
  1089. // return offsetY + Math.sin(startRadian) * (1 + Math.cos(v) * k) * hoverRate;
  1090. // }
  1091. // if (u > endRadian) {
  1092. // return offsetY + Math.sin(endRadian) * (1 + Math.cos(v) * k) * hoverRate;
  1093. // }
  1094. // return offsetY + Math.sin(u) * (1 + Math.cos(v) * k) * hoverRate;
  1095. // },
  1096. // z: function (u, v) {
  1097. // if (u < -Math.PI * 0.5) {
  1098. // return Math.sin(u);
  1099. // }
  1100. // if (u > Math.PI * 2.5) {
  1101. // return Math.sin(u);
  1102. // }
  1103. // return Math.sin(v) > 0 ? 1 : -1;
  1104. // },
  1105. // };
  1106. // }
  1107. // // 生成模拟 3D 饼图的配置项
  1108. // function getPie3D(pieData, internalDiameterRatio) {
  1109. // let series = [];
  1110. // let sumValue = 0;
  1111. // let startValue = 0;
  1112. // let endValue = 0;
  1113. // let legendData = [];
  1114. // let k =
  1115. // typeof internalDiameterRatio !== 'undefined'
  1116. // ? (1 - internalDiameterRatio) / (1 + internalDiameterRatio)
  1117. // : 1 / 3;
  1118. // // 新增标签 series @20210613
  1119. // let labelSeries = {
  1120. // id: 'labelSeries',
  1121. // type: 'bar3D',
  1122. // //zlevel:-9,
  1123. // barSize: [0.1, 0.1],
  1124. // data: [],
  1125. // label: {
  1126. // show: true,
  1127. // formatter: function (params) {
  1128. // return `${params.name}\n${params.value[3]}`;
  1129. // },
  1130. // backgroundColor: '#fff',
  1131. // },
  1132. // };
  1133. // // 为每一个饼图数据,生成一个 series-surface 配置
  1134. // for (let i = 0; i < pieData.length; i++) {
  1135. // sumValue += pieData[i].value;
  1136. // let seriesItem = {
  1137. // name: typeof pieData[i].name === 'undefined' ? `series${i}` : pieData[i].name,
  1138. // type: 'surface',
  1139. // parametric: true,
  1140. // wireframe: {
  1141. // show: false,
  1142. // },
  1143. // pieData: pieData[i],
  1144. // pieStatus: {
  1145. // selected: false,
  1146. // hovered: false,
  1147. // k: k,
  1148. // },
  1149. // };
  1150. // if (typeof pieData[i].itemStyle != 'undefined') {
  1151. // let itemStyle = {};
  1152. // typeof pieData[i].itemStyle.color != 'undefined' ? (itemStyle.color = pieData[i].itemStyle.color) : null;
  1153. // typeof pieData[i].itemStyle.opacity != 'undefined'
  1154. // ? (itemStyle.opacity = pieData[i].itemStyle.opacity)
  1155. // : null;
  1156. // seriesItem.itemStyle = itemStyle;
  1157. // }
  1158. // series.push(seriesItem);
  1159. // }
  1160. // // 使用上一次遍历时,计算出的数据和 sumValue,调用 getParametricEquation 函数,
  1161. // // 向每个 series-surface 传入不同的参数方程 series-surface.parametricEquation,也就是实现每一个扇形。
  1162. // for (let i = 0; i < series.length; i++) {
  1163. // endValue = startValue + series[i].pieData.value;
  1164. // series[i].pieData.startRatio = startValue / sumValue;
  1165. // series[i].pieData.endRatio = endValue / sumValue;
  1166. // series[i].parametricEquation = getParametricEquation(
  1167. // series[i].pieData.startRatio,
  1168. // series[i].pieData.endRatio,
  1169. // false,
  1170. // false,
  1171. // k
  1172. // );
  1173. // startValue = endValue;
  1174. // legendData.push(series[i].name);
  1175. // // 判断增加 label 效果 @20210613
  1176. // if (pieData[i].label && pieData[i].label.show) {
  1177. // labelRadian = (series[i].pieData.startRatio + series[i].pieData.endRatio) * Math.PI;
  1178. // labelSeries.data.push({
  1179. // name: series[i].name,
  1180. // value: [Math.cos(labelRadian), Math.sin(labelRadian), 1.2, series[i].pieData.value],
  1181. // itemStyle: {
  1182. // opacity: 1,
  1183. // },
  1184. // });
  1185. // }
  1186. // }
  1187. // // 补充一个透明的圆环,用于支撑高亮功能的近似实现。
  1188. // series.push({
  1189. // name: 'mouseoutSeries',
  1190. // type: 'surface',
  1191. // parametric: true,
  1192. // wireframe: {
  1193. // show: false,
  1194. // },
  1195. // itemStyle: {
  1196. // opacity: 0,
  1197. // },
  1198. // parametricEquation: {
  1199. // u: {
  1200. // min: 0,
  1201. // max: Math.PI * 2,
  1202. // step: Math.PI / 20,
  1203. // },
  1204. // v: {
  1205. // min: 0,
  1206. // max: Math.PI,
  1207. // step: Math.PI / 20,
  1208. // },
  1209. // x: function (u, v) {
  1210. // return Math.sin(v) * Math.sin(u) + Math.sin(u);
  1211. // },
  1212. // y: function (u, v) {
  1213. // return Math.sin(v) * Math.cos(u) + Math.cos(u);
  1214. // },
  1215. // z: function (u, v) {
  1216. // return Math.cos(v) > 0 ? 0.1 : -0.1;
  1217. // },
  1218. // },
  1219. // });
  1220. // // 将 labelSeries 添加进去 @20210613
  1221. // series.push(labelSeries);
  1222. // // 准备待返回的配置项,把准备好的 legendData、series 传入。
  1223. // let option = {
  1224. // //animation: false,
  1225. // legend: {
  1226. // data: legendData,
  1227. // op: '5%',
  1228. // //orient: 'vertical',
  1229. // textStyle: {
  1230. // color: '#fff',
  1231. // },
  1232. // },
  1233. // tooltip: {
  1234. // formatter: (params) => {
  1235. // if (params.seriesName !== 'mouseoutSeries') {
  1236. // return `${
  1237. // params.seriesName
  1238. // }<br/><span style="display:inline-block;margin-right:5px;border-radius:10px;width:10px;height:10px;background-color:${
  1239. // params.color
  1240. // };"></span>${option.series[params.seriesIndex].pieData.value}`;
  1241. // }
  1242. // },
  1243. // },
  1244. // // 增加渐变色尝试(手动通过 seriesIndex 指定系列) @20211228
  1245. // xAxis3D: {
  1246. // min: -1,
  1247. // max: 1,
  1248. // },
  1249. // yAxis3D: {
  1250. // min: -1,
  1251. // max: 1,
  1252. // },
  1253. // zAxis3D: {
  1254. // min: -1,
  1255. // max: 1,
  1256. // },
  1257. // grid3D: {
  1258. // show: false,
  1259. // boxHeight: 10,
  1260. // //top: '30%',
  1261. // bottom: '50%',
  1262. // viewControl: {
  1263. // //3d效果可以放大、旋转等,请自己去查看官方配置
  1264. // alpha: 30, //角度
  1265. // distance: 150, //调整视角到主体的距离,类似调整zoom
  1266. // rotateSensitivity: 0, //设置为0无法旋转
  1267. // zoomSensitivity: 0, //设置为0无法缩放
  1268. // panSensitivity: 0, //设置为0无法平移
  1269. // autoRotate: false, //自动旋转
  1270. // },
  1271. // },
  1272. // series: series,
  1273. // };
  1274. // return option;
  1275. // }
  1276. // // 传入数据生成 option
  1277. // option = getPie3D([
  1278. // {
  1279. // name: '传统产业投资',
  1280. // value: 405.29,
  1281. // itemStyle: {
  1282. // color: '#6682f5'
  1283. // }
  1284. // }, {
  1285. // name: '战略新兴产业投资',
  1286. // value: 196.44,
  1287. // itemStyle: {
  1288. // color: '#69c0ff'
  1289. // }
  1290. // }, {
  1291. // name: '基础产业投资',
  1292. // value: 722.34,
  1293. // itemStyle: {
  1294. // color: '#43ede3'
  1295. // }
  1296. // }
  1297. // ]);
  1298. // myChart.setOption(option);
  1299. // // 监听鼠标事件,实现饼图选中效果(单选),近似实现高亮(放大)效果。
  1300. // let selectedIndex = '';
  1301. // let hoveredIndex = '';
  1302. // let that = this
  1303. // // 监听点击事件,实现选中效果(单选)
  1304. // myChart.on('click', function (param) {
  1305. // console.log(param)
  1306. // if (param.seriesName == '战略新兴产业投资') {
  1307. // that.tipTitle2 = param.seriesName
  1308. // that.showTip2 = true
  1309. // }
  1310. // // 从 option.series 中读取重新渲染扇形所需的参数,将是否选中取反。
  1311. // // let isSelected = !option.series[params.seriesIndex].pieStatus.selected;
  1312. // // let isHovered = option.series[params.seriesIndex].pieStatus.hovered;
  1313. // // let k = option.series[params.seriesIndex].pieStatus.k;
  1314. // // let startRatio = option.series[params.seriesIndex].pieData.startRatio;
  1315. // // let endRatio = option.series[params.seriesIndex].pieData.endRatio;
  1316. // // // 如果之前选中过其他扇形,将其取消选中(对 option 更新)
  1317. // // if (selectedIndex !== '' && selectedIndex !== params.seriesIndex) {
  1318. // // option.series[selectedIndex].parametricEquation = getParametricEquation(
  1319. // // option.series[selectedIndex].pieData.startRatio,
  1320. // // option.series[selectedIndex].pieData.endRatio,
  1321. // // false,
  1322. // // false,
  1323. // // k
  1324. // // );
  1325. // // option.series[selectedIndex].pieStatus.selected = false;
  1326. // // }
  1327. // // // 对当前点击的扇形,执行选中/取消选中操作(对 option 更新)
  1328. // // option.series[params.seriesIndex].parametricEquation = getParametricEquation(
  1329. // // startRatio,
  1330. // // endRatio,
  1331. // // isSelected,
  1332. // // isHovered,
  1333. // // k
  1334. // // );
  1335. // // option.series[params.seriesIndex].pieStatus.selected = isSelected;
  1336. // // // 如果本次是选中操作,记录上次选中的扇形对应的系列号 seriesIndex
  1337. // // isSelected ? (selectedIndex = params.seriesIndex) : null;
  1338. // // // 使用更新后的 option,渲染图表
  1339. // // myChart.setOption(option);
  1340. // });
  1341. // // 监听 mouseover,近似实现高亮(放大)效果
  1342. // myChart.on('mouseover', function (params) {
  1343. // // 准备重新渲染扇形所需的参数
  1344. // let isSelected;
  1345. // let isHovered;
  1346. // let startRatio;
  1347. // let endRatio;
  1348. // let k;
  1349. // // 如果触发 mouseover 的扇形当前已高亮,则不做操作
  1350. // if (hoveredIndex === params.seriesIndex) {
  1351. // return;
  1352. // // 否则进行高亮及必要的取消高亮操作
  1353. // } else {
  1354. // // 如果当前有高亮的扇形,取消其高亮状态(对 option 更新)
  1355. // if (hoveredIndex !== '') {
  1356. // // 从 option.series 中读取重新渲染扇形所需的参数,将是否高亮设置为 false。
  1357. // isSelected = option.series[hoveredIndex].pieStatus.selected;
  1358. // isHovered = false;
  1359. // startRatio = option.series[hoveredIndex].pieData.startRatio;
  1360. // endRatio = option.series[hoveredIndex].pieData.endRatio;
  1361. // k = option.series[hoveredIndex].pieStatus.k;
  1362. // // 对当前点击的扇形,执行取消高亮操作(对 option 更新)
  1363. // option.series[hoveredIndex].parametricEquation = getParametricEquation(
  1364. // startRatio,
  1365. // endRatio,
  1366. // isSelected,
  1367. // isHovered,
  1368. // k
  1369. // );
  1370. // option.series[hoveredIndex].pieStatus.hovered = isHovered;
  1371. // // 将此前记录的上次选中的扇形对应的系列号 seriesIndex 清空
  1372. // hoveredIndex = '';
  1373. // }
  1374. // // 如果触发 mouseover 的扇形不是透明圆环,将其高亮(对 option 更新)
  1375. // if (params.seriesName !== 'mouseoutSeries') {
  1376. // // 从 option.series 中读取重新渲染扇形所需的参数,将是否高亮设置为 true。
  1377. // isSelected = option.series[params.seriesIndex].pieStatus.selected;
  1378. // isHovered = true;
  1379. // startRatio = option.series[params.seriesIndex].pieData.startRatio;
  1380. // endRatio = option.series[params.seriesIndex].pieData.endRatio;
  1381. // k = option.series[params.seriesIndex].pieStatus.k;
  1382. // // 对当前点击的扇形,执行高亮操作(对 option 更新)
  1383. // option.series[params.seriesIndex].parametricEquation = getParametricEquation(
  1384. // startRatio,
  1385. // endRatio,
  1386. // isSelected,
  1387. // isHovered,
  1388. // k
  1389. // );
  1390. // option.series[params.seriesIndex].pieStatus.hovered = isHovered;
  1391. // // 记录上次高亮的扇形对应的系列号 seriesIndex
  1392. // hoveredIndex = params.seriesIndex;
  1393. // }
  1394. // // 使用更新后的 option,渲染图表
  1395. // myChart.setOption(option);
  1396. // }
  1397. // });
  1398. // // 修正取消高亮失败的 bug
  1399. // myChart.on('globalout', function () {
  1400. // if (hoveredIndex !== '') {
  1401. // // 从 option.series 中读取重新渲染扇形所需的参数,将是否高亮设置为 true。
  1402. // isSelected = option.series[hoveredIndex].pieStatus.selected;
  1403. // isHovered = false;
  1404. // k = option.series[hoveredIndex].pieStatus.k;
  1405. // startRatio = option.series[hoveredIndex].pieData.startRatio;
  1406. // endRatio = option.series[hoveredIndex].pieData.endRatio;
  1407. // // 对当前点击的扇形,执行取消高亮操作(对 option 更新)
  1408. // option.series[hoveredIndex].parametricEquation = getParametricEquation(
  1409. // startRatio,
  1410. // endRatio,
  1411. // isSelected,
  1412. // isHovered,
  1413. // k
  1414. // );
  1415. // option.series[hoveredIndex].pieStatus.hovered = isHovered;
  1416. // // 将此前记录的上次选中的扇形对应的系列号 seriesIndex 清空
  1417. // hoveredIndex = '';
  1418. // }
  1419. // // 使用更新后的 option,渲染图表
  1420. // myChart.setOption(option);
  1421. // });
  1422. // // 新增监听图例事件,同步显示隐藏对应 label @20210613
  1423. // myChart.on('legendselectchanged', function (params) {
  1424. // let seriesLength = option.series.length;
  1425. // console.log(option.series[seriesLength - 1].data);
  1426. // for (let i = 0; i < option.series[seriesLength - 1].data.length; i++) {
  1427. // console.log(option.series[seriesLength - 1].data[i]);
  1428. // if (option.series[seriesLength - 1].data[i].name == params.name) {
  1429. // console.log(option.series[seriesLength - 1].data[i]);
  1430. // params.selected[params.name]
  1431. // ? (option.series[seriesLength - 1].data[i].itemStyle.opacity = 1)
  1432. // : (option.series[seriesLength - 1].data[i].itemStyle.opacity = 0);
  1433. // }
  1434. // }
  1435. // myChart.setOption(option);
  1436. // });
  1437. // console.log('66', myChart);
  1438. // },
  1439. initChartL1 () {
  1440. let myChart = echarts.init(this.$refs['echartR1'])
  1441. let option = {
  1442. tooltip: {
  1443. trigger: 'item',
  1444. position: ['65%', '42%'],
  1445. formatter: params => {
  1446. 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}%`
  1447. }, //+ '<br/>'+ '{a1}:{c1}' + '%',
  1448. axisPointer: {
  1449. type: 'cross',
  1450. },
  1451. },
  1452. color: ['#6682f5', '#69c0ff', '#43ede3', '#8ba2ff'],
  1453. legend: {
  1454. left: '2%',
  1455. bottom: '2%',
  1456. orient: 'vertical',
  1457. //right: '2%',
  1458. textStyle: {
  1459. color: '#9DB9EB',
  1460. },
  1461. },
  1462. series: [
  1463. // {
  1464. // hoverOffset: 0,
  1465. // startAngle: 90,
  1466. // type: "pie",
  1467. // radius: [48, 55],
  1468. // center: ["50%", "50%"],
  1469. // itemStyle: {
  1470. // normal: {
  1471. // borderColor: 'rgba(1,31,6,0.7)',
  1472. // borderWidth: 4
  1473. // }
  1474. // },
  1475. // tooltip: {
  1476. // show: false
  1477. // },
  1478. // labelLine: {
  1479. // show: false
  1480. // },
  1481. // label: {
  1482. // show: false
  1483. // },
  1484. // data: industryList
  1485. // },
  1486. {
  1487. name: '',
  1488. type: 'pie',
  1489. radius: ['50%', '75%'],
  1490. center: ["45%", "50%"],
  1491. label:{
  1492. show: false,
  1493. },
  1494. itemStyle: {
  1495. normal: {
  1496. borderColor: 'rgba(1,31,64,0.7)',
  1497. borderWidth: 6
  1498. }
  1499. },
  1500. labelLine: {
  1501. show: false,
  1502. },
  1503. data: industryList,
  1504. },
  1505. ],
  1506. }
  1507. let that = this
  1508. myChart.on('click', function (param) {
  1509. console.log(param)
  1510. if (param.name == '战略新兴产业投资') {
  1511. that.tipTitle2 = param.name
  1512. that.showTip2 = true
  1513. }
  1514. })
  1515. myChart.setOption(option)
  1516. tools.loopShowTooltip(myChart, option, {
  1517. nterval: 2000,
  1518. loopSeries: true,
  1519. })
  1520. },
  1521. initChartL2() {
  1522. let myChart = echarts.init(this.$refs['echartL2'])
  1523. let option = {
  1524. tooltip: {
  1525. trigger: 'axis',
  1526. axisPointer: {
  1527. type: 'cross',
  1528. },
  1529. },
  1530. grid: {
  1531. top: '16%',
  1532. right: '3%',
  1533. left: '10%',
  1534. bottom: '23%',
  1535. },
  1536. legend: {
  1537. top: '1',
  1538. right: '10',
  1539. textStyle: {
  1540. color: 'rgba(250,250,250,0.6)',
  1541. },
  1542. },
  1543. xAxis: {
  1544. data: executeList.map(item => item.name),
  1545. axisLine: {
  1546. show: true, //隐藏X轴轴线
  1547. lineStyle: {
  1548. color: '#005094',
  1549. width: 1,
  1550. },
  1551. },
  1552. axisTick: {
  1553. show: false, //隐藏X轴刻度
  1554. },
  1555. axisLabel: {
  1556. show: true,
  1557. rotate: 40,
  1558. textStyle: {
  1559. color: '#fff',//'rgba(255,255,255,0.6)', //X轴文字颜色
  1560. },
  1561. },
  1562. },
  1563. yAxis: [
  1564. {
  1565. type: 'value',
  1566. nameTextStyle: {
  1567. color: '#ebf8ac',
  1568. },
  1569. splitLine: {
  1570. show: true,
  1571. lineStyle: {
  1572. color: '#68b4dd66',
  1573. type: 'dashed',
  1574. },
  1575. },
  1576. axisLine: {
  1577. show: true,
  1578. lineStyle: {
  1579. color: '#3D7495',
  1580. },
  1581. },
  1582. axisLabel: {
  1583. show: true,
  1584. textStyle: {
  1585. color: 'rgba(250,250,250,0.6)',
  1586. },
  1587. },
  1588. },
  1589. ],
  1590. series: [
  1591. {
  1592. name: '计划投资',
  1593. type: 'bar',
  1594. barWidth: 10,
  1595. itemStyle: {
  1596. normal: {
  1597. color: new echarts.graphic.LinearGradient(0, 0, 0, 1, [
  1598. {
  1599. offset: 0,
  1600. color: '#69c0ff',
  1601. },
  1602. {
  1603. offset: 1,
  1604. color: '#082550',
  1605. },
  1606. ]),
  1607. },
  1608. },
  1609. data: executeList.map(item => item.value),
  1610. },
  1611. {
  1612. name: '实际投资',
  1613. type: 'bar',
  1614. barWidth: 10,
  1615. itemStyle: {
  1616. normal: {
  1617. color: new echarts.graphic.LinearGradient(0, 0, 0, 1, [
  1618. {
  1619. offset: 0,
  1620. color: '#957DFF',
  1621. },
  1622. {
  1623. offset: 1,
  1624. color: '#082550',
  1625. },
  1626. ]),
  1627. },
  1628. },
  1629. data: executeList.map(item => item.value2),
  1630. },
  1631. ],
  1632. }
  1633. myChart.setOption(option)
  1634. tools.loopShowTooltip(myChart, option, {
  1635. nterval: 2000,
  1636. loopSeries: true,
  1637. })
  1638. },
  1639. initChartR1() {
  1640. let myChart = echarts.init(this.$refs['echartL1'])
  1641. let option = {
  1642. tooltip: {
  1643. trigger: 'axis',
  1644. formatter: '{a0}:{c0}' + '亿元', //+ '<br/>'+ '{a1}:{c1}' + '%',
  1645. axisPointer: {
  1646. type: 'cross',
  1647. },
  1648. },
  1649. grid: {
  1650. top: '16%',
  1651. right: '10%',
  1652. left: '10%',
  1653. bottom: '22%',
  1654. },
  1655. // legend: {
  1656. // top: '1',
  1657. // textStyle: {
  1658. // color: 'rgba(250,250,250,0.6)',
  1659. // },
  1660. // },
  1661. xAxis: {
  1662. data: statusList.map(item => item.name),
  1663. axisLine: {
  1664. show: true, //隐藏X轴轴线
  1665. lineStyle: {
  1666. color: '#005094',
  1667. width: 1,
  1668. },
  1669. },
  1670. axisTick: {
  1671. show: false, //隐藏X轴刻度
  1672. },
  1673. axisLabel: {
  1674. show: true,
  1675. rotate: 20,
  1676. textStyle: {
  1677. color: '#fff',//'rgba(255,255,255,0.6)', //X轴文字颜色
  1678. },
  1679. },
  1680. },
  1681. yAxis: [
  1682. {
  1683. type: 'value',
  1684. name: '亿元',
  1685. nameTextStyle: {
  1686. color: 'rgba(255,255,255,0.6)',
  1687. },
  1688. splitLine: {
  1689. show: true,
  1690. lineStyle: {
  1691. color: '#68b4dd66',
  1692. type: 'dashed',
  1693. },
  1694. },
  1695. axisLine: {
  1696. show: true,
  1697. lineStyle: {
  1698. color: '#3D7495',
  1699. },
  1700. },
  1701. axisLabel: {
  1702. show: true,
  1703. textStyle: {
  1704. color: 'rgba(250,250,250,0.6)',
  1705. },
  1706. },
  1707. },
  1708. {
  1709. type: 'value',
  1710. axisLine: {
  1711. show: false,
  1712. },
  1713. splitLine: {
  1714. show: false,
  1715. },
  1716. axisLabel: {
  1717. show: true,
  1718. formatter: '{value} %',
  1719. textStyle: {
  1720. color: 'rgba(250,250,250,0.6)',
  1721. },
  1722. },
  1723. },
  1724. ],
  1725. series: [
  1726. {
  1727. type: 'bar',
  1728. name: '投资金额',
  1729. barWidth: 15,
  1730. itemStyle: {
  1731. normal: {
  1732. color: new echarts.graphic.LinearGradient(0, 0, 0, 1, [
  1733. {
  1734. offset: 0,
  1735. color: '#69c0ff',
  1736. },
  1737. {
  1738. offset: 1,
  1739. color: '#082550',
  1740. },
  1741. ]),
  1742. },
  1743. },
  1744. data: statusList.map(item => item.value),
  1745. },
  1746. ],
  1747. }
  1748. myChart.setOption(option)
  1749. tools.loopShowTooltip(myChart, option, {
  1750. nterval: 2000,
  1751. loopSeries: true,
  1752. })
  1753. },
  1754. initChartR2() {
  1755. let myChart = echarts.init(this.$refs['echartR2'])
  1756. let option = {
  1757. tooltip: {
  1758. trigger: 'item',
  1759. position: ['65%', '42%'],
  1760. formatter: params => {
  1761. 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}%`
  1762. }, //+ '<br/>'+ '{a1}:{c1}' + '%',
  1763. axisPointer: {
  1764. type: 'cross',
  1765. },
  1766. },
  1767. color: ['#6682f5', '#69c0ff', '#43ede3', '#8ba2ff'],
  1768. legend: {
  1769. left: '2%',
  1770. bottom: '2%',
  1771. orient: 'vertical',
  1772. //right: '2%',
  1773. textStyle: {
  1774. color: '#9DB9EB',
  1775. },
  1776. },
  1777. series: [
  1778. // {
  1779. // hoverOffset: 0,
  1780. // startAngle: 90,
  1781. // type: "pie",
  1782. // radius: [48, 55],
  1783. // center: ["50%", "50%"],
  1784. // itemStyle: {
  1785. // normal: {
  1786. // borderColor: 'rgba(1,31,6,0.7)',
  1787. // borderWidth: 4
  1788. // }
  1789. // },
  1790. // tooltip: {
  1791. // show: false
  1792. // },
  1793. // labelLine: {
  1794. // show: false
  1795. // },
  1796. // label: {
  1797. // show: false
  1798. // },
  1799. // data: industryList
  1800. // },
  1801. {
  1802. name: '',
  1803. type: 'pie',
  1804. radius: ['50%', '75%'],
  1805. center: ["45%", "50%"],
  1806. label:{
  1807. show: false,
  1808. },
  1809. itemStyle: {
  1810. normal: {
  1811. borderColor: 'rgba(1,31,64,0.7)',
  1812. borderWidth: 6
  1813. }
  1814. },
  1815. labelLine: {
  1816. show: false,
  1817. },
  1818. data: industryList,
  1819. },
  1820. ],
  1821. }
  1822. let that = this
  1823. myChart.on('click', function (param) {
  1824. console.log(param)
  1825. if (param.name == '战略新兴产业投资') {
  1826. that.tipTitle2 = param.name
  1827. that.showTip2 = true
  1828. }
  1829. })
  1830. myChart.setOption(option)
  1831. tools.loopShowTooltip(myChart, option, {
  1832. nterval: 2000,
  1833. loopSeries: true,
  1834. })
  1835. myChart.setOption(option)
  1836. tools.loopShowTooltip(myChart, option, {
  1837. nterval: 2000,
  1838. loopSeries: true,
  1839. })
  1840. },
  1841. initProjectList() {
  1842. let dataList = []
  1843. projectList.map(item => {
  1844. dataList.push([item.office,item.name, item.value + '亿'])
  1845. })
  1846. this.storageRecordConfig = {
  1847. header: ['企业集团', '项目名称', '投资金额'],
  1848. headerBGC: '#05507b33',
  1849. oddRowBGC: '#05507b33',
  1850. evenRowBGC: '',
  1851. headerHeight: '40',
  1852. rowNum: 5,
  1853. columnWidth: [100, 350],
  1854. align: ['center', 'center', 'center'],
  1855. data: dataList,
  1856. }
  1857. }
  1858. },
  1859. })