investHome.js 61 KB

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