123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849 |
- let app = new Vue({
- el: '#app',
- data () {
- return {
- year: '2022',
- time: '',
- timer: '',
- mapName: 'shanxi',
- geoCoordMap: {},
- config1: {
- number: [100],
- content: '{nt}个',
- },
- storageRecordConfig: null,
- companyList: [
- { name: '山西焦煤' },
- { name: '晋能控股' },
- { name: '华新燃气' },
- { name: '山西建投' },
- { name: '潞安化工' },
- { name: '华远陆港' },
- { name: '航产集团' },
- { name: '大地控股' },
- { name: '国新能源' },
- { name: '汾酒集团' },
- { name: '云时代' },
- { name: '神农科技' },
- { name: '华阳新材' },
- { name: '华舰体育' },
- { name: '交控集团' },
- { name: '文旅集团' },
- { name: '水控集团' },
- { name: '太重集团' },
- ],
- amountList: amountList,
- amountTotal: 0,
- classOption: {
- step: 0.5
- }
- }
- },
- created () {
- this.amountList.map(item=> {
- this.amountTotal += Number(item.value)
- })
- this.time = formatDate()
- this.timer = setInterval(() => {
- this.time = formatDate()
- }, 1000)
- },
- beforeDestroy () {
- if (this.timer) {
- clearInterval(this.timer);
- }
- },
- mounted () {
- setTimeout(() => {
- // 左侧图表
- this.initChartL1()
- this.initChartL2()
- this.initChartR1()
- this.initChinaChart()
- this.initProjectList()
- },0)
- },
- methods: {
- numFormat (value) {
- if (!value) return '0'
- var intPart = Number(value).toFixed(0) // 获取整数部分
- var intPartFormat = intPart.toString().replace(/(\d)(?=(?:\d{3})+$)/g, '$1,') // 将整数部分逢三一断
- var floatPart = '.00' // 预定义小数部分
- var value2Array = value.toString().split('.')
- // =2表示数据有小数位
- if (value2Array.length === 2) {
- floatPart = value2Array[1].toString() // 拿到小数部分
- if (floatPart.length === 1) {
- // 补0
- return intPartFormat + '.' + floatPart + '0'
- } else {
- return intPartFormat + '.' + floatPart
- }
- } else {
- return intPartFormat
- }
- },
- convertData (data) {
- var res = []
- for (var i = 0; i < data.length; i++) {
- var geoCoord = this.geoCoordMap[data[i].name]
- if (geoCoord) {
- res.push({
- name: data[i].name,
- value: geoCoord.concat(data[i].value),
- })
- }
- }
- return res
- },
- initChinaChart () {
- var data = [
- { name: '吕梁市', value: 150 },
- { name: '大同市', value: 190 },
- { name: '忻州市', value: 140 },
- { name: '朔州市', value: 160 },
- { name: '晋中市', value: 100 },
- { name: '太原市', value: 300 },
- { name: '临汾市', value: 190 },
- { name: '长治市', value: 100 },
- { name: '晋城市', value: 280 },
- { name: '运城市', value: 180 },
- { name: '阳泉市', value: 110 },
- ]
- var moveLine = {
- normal: [
- {
- fromName: '太原市',
- toName: '吕梁市',
- coords: [
- [112.3352, 37.9413],
- [111.3574, 37.7325],
- ],
- },
- {
- fromName: '太原市',
- toName: '忻州市',
- coords: [
- [112.3352, 37.9413],
- [112.4561, 38.8971],
- ],
- },
- {
- fromName: '太原市',
- toName: '临汾市',
- coords: [
- [112.3352, 37.9413],
- [111.4783, 36.1615],
- ],
- },
- {
- fromName: '太原市',
- toName: '阳泉市',
- coords: [
- [112.3352, 37.9413],
- [113.4778, 38.0951],
- ],
- },
- {
- fromName: '太原市',
- toName: '晋中市',
- coords: [
- [112.3352, 37.9413],
- [112.7747, 37.37],
- ],
- },
- {
- fromName: '太原市',
- toName: '运城市',
- coords: [
- [112.3352, 37.9413],
- [111.1487, 35.2002],
- ],
- },
- {
- fromName: '太原市',
- toName: '大同市',
- coords: [
- [112.3352, 37.9413],
- [113.7854, 39.8035],
- ],
- },
- {
- fromName: '太原市',
- toName: '晋城市',
- coords: [
- [112.3352, 37.9413],
- [112.7856, 35.6342],
- ],
- },
- {
- fromName: '太原市',
- toName: '长治市',
- coords: [
- [112.3352, 37.9413],
- [112.8625, 36.4746],
- ],
- },
- {
- fromName: '太原市',
- toName: '朔州市',
- coords: [
- [112.3352, 37.9413],
- [113.0713, 39.6991],
- ],
- },
- ],
- }
- /*获取地图数据*/
- let myChart = echarts.init(this.$refs['echarts-map'])
- echarts.registerMap('shanxi', {
- type: 'FeatureCollection',
- features: [
- {
- type: 'Feature',
- id: '1409',
- properties: { name: '忻州市', cp: [112.4561, 38.8971], childNum: 14 },
- geometry: {
- type: 'Polygon',
- coordinates: [
- '@@Vx@lnbn¦WlnnUm°²VVVVVnUnºlz@l@J@kXWVXl@La@KULlbnKlLnKLnKÆXn°bVV@bUVl°Un@LnaVJUbW@UX²l@ČwlVVIWnkÆa°anVKn°UW¯@aVUVk@Un@aV@ValwUanmWUk@WVUUanaVwnLVl°@nk@mVU@UVK@wLVKVU@K@UUKVUV@@bnLaVaôlIXmlKX_°KVV@bVV@zV`kblIVUlL@bnV@VĊllVlIXW@kaU²blKVnIlJalbXXlWVn°JnnL@l@XlJlaX@XW²@l_VmnKUblU@mnkVK¯@U@ma@kX¥VmakkLa@a@WIUUVXWWnk@a°a@kkm@kUUmJm@WUUUIk`m@VkaWWkXKmXk¯@WKLkak@±bw@aa@aka@ma¯@LKÇÅkKWbkmġ±ÅULUKVVkm¯LUVVbUwUW¯bmULxWJ@klmkUm@@KnwVkVK@akw@@a¯bKknVUIb¯mmbk@UbmKUL@xUU@klmLUlVXIVVVUVUU`mLXVWbXnW`Ų°xmxU@mĉwU@mbU@UmbkVW¦kJ@X@`¯Im@UlUVVnb@bWJXnmbJUUUUa@UamIkax@@x@b',
- ],
- encodeOffsets: [[113614, 39657]],
- },
- },
- {
- type: 'Feature',
- id: '1411',
- properties: { name: '吕梁市', cp: [111.3574, 37.7325], childNum: 13 },
- geometry: {
- type: 'Polygon',
- coordinates: [
- '@@@a@w@wlbnJVb@VbVVVInaWmXI@aaUmVUVkn@°J@_W@lIX¥lUnaVV@naV@xĊnV@wn¯wƱX_WmXaWUnKV_VVUUUUWJkUVnKlk¯@@kmKUaűKkU@WmI@WUIlUUmVwXw@UlUVwV@LnbW@anU@UaVkô@l»n@naJnUÈLVaÆUUVmVKV²L@mU_lK@UVWkUa@a@U¯aUaÑóÑUbKk@@ak¯mVaUwVÑkWUmK@UUKmXUWÝwUaLUU@aWJUUU@UaÝU@WL@VKVaVI@WnU@alIVK@kImIkJ@m@@@_K@x@kaW@U@Vmn@UK@mIJUXV¤XXWlkKkkK@XmJVakImJU@ó¯LWKUV@nUVLkxmKkLma@kXKmmLabLmK@V@mXVÆUxX@`nLaV@@VmLUVnLlLb@°²nx@bVUxlb@V¯bUV@zVXVĊXVx@lVn@VnnmU@LlJXVz¯VWVXbV@bmnVUVkÇþÅ@XVxmbUlVUlnW@Xl@VLXÒ@bÞJ°¦Lò@nUb@°X@XbmVUVnb@xx',
- ],
- encodeOffsets: [[113614, 39657]],
- },
- },
- {
- type: 'Feature',
- id: '1410',
- properties: { name: '临汾市', cp: [111.4783, 36.1615], childNum: 17 },
- geometry: {
- type: 'Polygon',
- coordinates: [
- '@@nW@@UnLKabKnnWL@lnblKnLlwKVU@mVUXL°KôV@nIlJUbnI@WlLllLXkWWU£VWInJ@VL@nm@UVX@lb@@wL@`@n@V@lw@nVmVXWmwnUla@_lKwVlUn°xVKVXXWlUVVI@K@Kn°KwlVlU@kna@V_WnmUVm@kXml_@mLlKXw°m@_ôJVUV@Xl@UaV@Va°Ilk»VwUkVmwUmmVn@V¯@KUwmK@U¯wUVÝ@mJUnWK@@UnKVa_lykUmKÛnm@x@UUlwVkXW@a@U@@K@kIVnammVakUl@wX@@k¯@VVbml@°UbULmlVbnbÅK±VKVXUJWa@ULWaUU@@U@aWK@UkxUKLUUUJ±UkL@V±kk@kam@UV@l@LWl@n@VVUxLlUUx@VUVU@aIUlL@°mLUbkUUaWUUaUU@aWKLWJ@bUL@VUVVbU@m@a@kmKmnĉlUKXWUblbxmIkU@xWb@lkVxLXmzVV@bklVVUzm@bk@Vx@xlU@lUbVnl@Wxnl@n@UbVmLmb@`X@lUX@@xlnkLWaUJnnWVVn@l@bULVV@lV@XnJVX',
- ],
- encodeOffsets: [[113063, 37784]],
- },
- },
- {
- type: 'Feature',
- id: '1407',
- properties: { name: '晋中市', cp: [112.7747, 37.37], childNum: 11 },
- geometry: {
- type: 'Polygon',
- coordinates: [
- '@@@lInJlJ@ULkJ@bmV@XUJUbL@UXKV@ÞVbV@VVXI@bVVKVbÞxVXnWVL@VnLVlXÒUVxUb°nl@bl@LVaôÒÒVb°b@VnLnnV@lmn@lbUV@JUVVXkl@lUzmJ@xXklbUnJVUbnUlbV@nlLX@lakV`Ub°@XVJnUL²KlxnI@KV@lbUbVVKnVl@zlm@U@nI@WUaVl@@mVU@XkW@nkVKV_Vwy@knwVa@XalU@Vnml@X@VLKVaÞbnnlJImVKnVVVInVlU@m@mXK@UmyUI@mWUUakamw@wUwmLkakwVmKw@wUam£y@am_W@UU@knmmamU@WUa@knw@UUUUV@nJm@mVUkKVUUUkKmwKULKUImV@lUnnm@mbUK@°bUnmbUmkkWUb@am@UXkK@a±@V@ĉÅVUXVxUVkLWl¯@@bULUlm@@nm`XlWakIkmVUbUL@Vm@kI@@Km@VaXI@W@aU@kUVU_KbJkkÇb@nkKmLwÅW@kVUUVU@WUIJmIXmma@_kyVaUUlkUm@kUx¯Lm@L@LUJUkVWXUWUL¯wVmUkxkL@`bkmVnxXUWUnm@kxU@',
- ],
- encodeOffsets: [[114087, 37682]],
- },
- },
- {
- type: 'Feature',
- id: '1408',
- properties: { name: '运城市', cp: [111.1487, 35.2002], childNum: 13 },
- geometry: {
- type: 'Polygon',
- coordinates: [
- '@@VlnJwkaVaXWVLĊknmnLl@@bnV@UaVU@UVK@aXIKXL@bVVVbXVVblVaVnK@¯KVkJ@bVVU@UVwkVKVwUUm@@Xk@K@kVUn@lbl@²l@UlK²VVIVVKVLlw@VXL@b@VV@VXbVK@XbVIUWLU²ÆLmaUankVKVa¯@nkUaU°@n@@kWaUVaXUW@IXKVw@UWU@W@@UUU@mn@`m@UUULkUmJIU@@UK@U@anak_@wmKUwmakVkmKVk¯bw`kwUIÇx¯»ÇaÅmn@@mmUkV@wkKW@kxmLUkĉLÝkxÝw¯lóVUmV@ĀVVX¦W¤kz@`Vx°²ĸ@Ul@xêĸNJ°¤VVlXLWnXxmV@nUl@',
- ],
- encodeOffsets: [[113232, 36597]],
- },
- },
- {
- type: 'Feature',
- id: '1402',
- properties: { name: '大同市', cp: [113.7854, 39.8035], childNum: 8 },
- geometry: {
- type: 'Polygon',
- coordinates: [
- '@@²£yl@ČĖ@bĸĢbĸXaKŤnn@ŎôllÈxnVnÞÇV@bnXllL°KbVb@J@b@UxlKXLlKlXk@UlkJlkUVKXUÇVIVm@_nÇLalwVnU@UUwma@aaÝaLmUk@@W@U@@XwVWÝUUUk@@VmLKV»nwUwaUL@`mzJUIVUaUwKUaVIlJôanÑlLVUn@a@VV@@UUwVK°Vn_lJÆLéW@UUUÅ@»lm@aÞIVwXWUUkkm@U@aU@mwU£VWU_kWmXwW_°yUkkK@UÇK@kkUVymóKU@KWIbUak@mJ@bkbmLkUmkVUW¦@lnb@@V°ULml@nkVaVmLUnk`±@XWW@kbǦX¯WxI@xmbmxXlWV@bÅUz@Jb@bÞbU@Wbk@xk@WX¯VÛWÝbÝUkVUU@alI@a@akLWam@U¯UUmÇL@K@aU@¯VUkKmX@`@kJ@nVUb@lbVÆXVWULU`VbkLUV@XWl@bXJ@VbV@Vl',
- ],
- encodeOffsets: [[115335, 41209]],
- },
- },
- {
- type: 'Feature',
- id: '1404',
- properties: { name: '长治市', cp: [112.8625, 36.4746], childNum: 12 },
- geometry: {
- type: 'Polygon',
- coordinates: [
- '@@UkLky@IJVa@mÞaWy@_W@_WXVlUVw@nw°K@mUVamVkU@mmmnLVUmKXaU@IlKVUnK@UmWkX@WV_V@akU@aKWIXyIUVmUnUa@WaXUVKVmkUWVkULU@@VbKbIUm@mbVLxWUUkn±V¯wbÅJUbmLkbmKÅKbVnUbVKUbKUbmLKmbaKkUm@UnnVnxUVlUxl¼k¯JUbU@Vbk@WU@UVóI@`¯nWxkLK@nk`Wn@lUnVnmXU`@mb@lkV@VnklVVUblz@`nbWnnJIVJ@XUVVUV@lÆXxnKlL@maÈllIaLV`UlVV@@b@XJWUb@n@L@lJn@@UVKVaUlnlJXbkWn_@mn@VkVK@a°@XklKVUUwVWUĊÆ@U²@@blLVWn@@bVaXllVnnaVma@¯VLnan@mVm@knUVJ',
- ],
- encodeOffsets: [[116269, 37637]],
- },
- },
- {
- type: 'Feature',
- id: '1406',
- properties: { name: '朔州市', cp: [113.0713, 39.6991], childNum: 5 },
- geometry: {
- type: 'Polygon',
- coordinates: [
- '@@XXWVXVWnnlnn@èƼ@xlVnblVÈUVl@blnLÜĊmUkU@Ua@WI@aXk@WVUlKUaV_VKXWUUÅka@VaU@mlI@@_nWLVl°UV@@b@LÈKVn°V@VnXblK@b@bkJ@bVVlUÞVÞaXÜ°UXWl@wl@XaV@Ýa@aa@IVyÆ@aXUWknwna@wJXw°WÈ¥kI@W@kmKm¯IUmkXWWkabkImJUkL±aVb@lWXkJUkĉk@UmU@aKkVUkJlaU_y@UU@aUU¯LW`kLWnkJóbUbmK@aU@UVVL@VL@UVULK@xUL@VUV@nml¯@UkmKUxmbVbUV@XlXVmnVbkxUbU@bm@@VUlUVb°@VX¯m',
- ],
- encodeOffsets: [[114615, 40562]],
- },
- },
- {
- type: 'Feature',
- id: '1405',
- properties: { name: '晋城市', cp: [112.7856, 35.6342], childNum: 6 },
- geometry: {
- type: 'Polygon',
- coordinates: [
- '@@lVLbanLnKVaLVaLUVaUmaÆLnLlanKVaÆIa°x²UlmVVXwUKna@VnJaLa@UV@@alUkKVKnkmmVwUkw@@kxWUXW@@mk@aUa@a¯aLkKmwkUm@kL@K@aWIXmVXWkUVakL@UVKw@aUK@UUKmLU@¯nKUwVUIWJUWmka@UXJk@UkmW@kLWKVx@bmI@VUaVU@a¯@UUmVKmX@±`kÝKVxUL±akL@VbLkKmV@XWVUbVXb@lm@@lW@@xklVUbnnmbUlJ@@L@@Vb@WXUlkxVV@wn@ÜmnLlVkz`UbmL@V@XLmVnIÞ@VU°x@VnLxV@LU°',
- ],
- encodeOffsets: [[115223, 36895]],
- },
- },
- {
- type: 'Feature',
- id: '1401',
- properties: { name: '太原市', cp: [112.3352, 37.9413], childNum: 5 },
- geometry: {
- type: 'Polygon',
- coordinates: [
- '@@@VV@wVKnLVal@na°naVJUlmL°a@b@lx@bULUlmx@Ln@lVknl@XIwKVn°aVXVxUaVU°KnUlUVLKÆV²ĢlnXalLÈÆLKUaVkUanmWUa@WwkUWU¯y¯Ñ@anIl@@aVUmIymULUUVakaU@@LmJkw±LKmVUI@W¯VaU_lkbW@kK@mUkaVmVaUIVmalkW@wnIVy@klkWUUVI@UVkam@knU@mmmK@bblVUX@VkLV`@n±KUULUnVVÅUbÇKmVImbm@k¼ó@Ulb@VmV@bXmaK@UUxkVV@xWUxVnkVVJ@XnJ@XlV²LÆVbnL@l@°',
- ],
- encodeOffsets: [[114503, 39134]],
- },
- },
- {
- type: 'Feature',
- id: '1403',
- properties: { name: '阳泉市', cp: [113.4778, 38.0951], childNum: 3 },
- geometry: {
- type: 'Polygon',
- coordinates: [
- '@@°@nb@lb@bbb@x²al@lbKXU@mkUWkkmUUVwV@XUW@naVklKXblKnLnLVanImaXKlLaV@U@KUKWalXK@£WKXUV@VUUUVW_V@W@@K@UIWmXUmULnJkImmÝaUbLK@UWk@mnU@kVWb@Ubmx@lzUx`UULml@XWl@UV@nk@UVb@XJm@@Vknyk@zJnUV@bk@mJ@b°Ò°zXVlVXx@bXVmnVbUlVb',
- ],
- encodeOffsets: [[115864, 39336]],
- },
- },
- ],
- UTF8Encoding: true,
- })
- var mapFeatures = echarts.getMap(this.mapName).geoJson.features
- mapFeatures.forEach(v => {
- // 地区名称
- var name = v.properties.name
- // 地区经纬度
- this.geoCoordMap[name] = v.properties.cp
- })
- // <p>当前阶段:<span>可论证阶段</span></p>
- // <p>时间节点:<span>2021.10-2022.10</span></p>
- let option = {
- tooltip: {
- padding: 15,
- enterable: true,
- transitionDuration: 1,
- formatter: (params, ticket, callback) => {
- let tipHtml = `
- <div class="tooltip-cont">
- <p>新开工:<span>工程建设项目</span></p>
- <p>总投资额:<span>${params.data.value}亿</span></p>
- </div>`
- callback(ticket, tipHtml)
- return tipHtml
- },
- },
- visualMap: {
- show: false,
- min: 0,
- max: 300,
- right: 0,
- bottom: 0,
- text: ['高', '低'],
- textStyle: {
- color: '#f1f1f1'
- },
- realtime: false,
- calculable: false,
- inRange: {
- color: ['lightskyblue', '#2754b7']
- }
- },
- geo: {
- show: true,
- map: 'shanxi',
- layoutCenter: ['50%', '50%'], //地图位置
- layoutSize: '100%',
- label: {
- normal: {
- show: false,
- },
- emphasis: {
- show: false,
- },
- },
- roam: false,
- itemStyle: {
- normal: {
- areaColor: '#1946a8',
- shadowColor: '#1946a8',
- borderWidth: 1, //设置外层边框
- borderColor: '#1946a8',
- shadowOffsetX: 10,
- shadowOffsetY: 5,
- shadowBlur: 2,
- },
- emphasis: {
- areaColor: '#1946a8',
- borderColor: '#d4bc1d',
- borderWidth: 2, //设置外层边框
- },
- },
- },
- series: [
- {
- name: '散点',
- type: 'scatter',
- coordinateSystem: 'geo',
- data: this.convertData(data),
- symbolSize: function (val) {
- return 10
- },
- label: {
- normal: {
- formatter: '{b}',
- position: [10, 10],
- fontSize: 15,
- fontWeight: 600,
- fontStyle: 'italic',
- color: '#fff',
- show: true,
- },
- emphasis: {
- show: true,
- },
- },
- itemStyle: {
- normal: {
- color: '#000',
- borderWidth: 2,
- borderColor: '#fff',
- },
- },
- },
- {
- type: 'map',
- map: this.mapName,
- geoIndex: 0,
- aspectScale: 1.5, //长宽比
- showLegendSymbol: true, // 存在legend时显示
- label: {
- normal: {
- show: true,
- },
- emphasis: {
- show: false,
- textStyle: {
- color: '#fff',
- },
- },
- },
- roam: true,
- itemStyle: {
- normal: {
- areaColor: '#031525',
- borderColor: '#3B5077',
- },
- emphasis: {
- areaColor: '#2B91B7',
- },
- },
- animation: false,
- data: data,
- },
- {
- name: '点',
- type: 'scatter',
- coordinateSystem: 'geo',
- zlevel: 6,
- },
- {
- name: 'Top 5',
- type: 'effectScatter',
- coordinateSystem: 'geo',
- data: this.convertData(
- data
- .sort(function (a, b) {
- return b.value - a.value
- })
- .slice(0, 5)
- ),
- symbolSize: function (val) {
- return 15
- },
- showEffectOn: 'render',
- rippleEffect: {
- brushType: 'stroke',
- },
- hoverAnimation: true,
- label: {
- normal: {
- formatter: '{b}',
- position: 'left',
- show: false,
- },
- },
- itemStyle: {
- normal: {
- color: 'yellow',
- shadowBlur: 10,
- shadowColor: 'yellow',
- },
- },
- zlevel: 1000,
- },
- {
- name: '线路',
- type: 'lines',
- zlevel: 2,
- effect: {
- show: true,
- period: 4, //箭头指向速度,值越小速度越快
- trailLength: 0.02, //特效尾迹长度[0,1]值越大,尾迹越长重
- symbol: 'arrow', //箭头图标
- symbolSize: 5, //图标大小
- },
- lineStyle: {
- normal: {
- color: '#00FFFF',
- width: 1,
- type: 'dashed',
- opacity: 0.5, //尾迹线条透明度
- curveness: -0.3, //尾迹线条曲直度
- },
- },
- data: moveLine.normal,
- },
- ],
- }
- myChart.setOption(option)
- },
- initChartL1 () {
- let myChart = echarts.init(this.$refs['echartL1'])
- let option = {
- tooltip: {
- trigger: 'item',
- },
- color: ['#6682f5', '#69c0ff', '#43ede3','#8ba2ff'],
- legend: {
- top: 'center',
- orient: 'vertical',
- right: '2%',
- textStyle: {
- color: '#9DB9EB',
- },
- },
- series: [
- {
- name: '',
- type: 'pie',
- radius: ['55%', '80%'],
- labelLine: {
- normal: {
- lineStyle: {
- width: 1,
- },
- },
- },
- data: statusList,
- },
- ],
- }
- myChart.setOption(option)
- tools.loopShowTooltip(myChart, option, {
- nterval: 2000,
- loopSeries: true,
- })
- },
- initChartL2 () {
- let myChart = echarts.init(this.$refs['echartL2'])
- let option = {
- tooltip: {
- trigger: 'axis',
- axisPointer: {
- type: 'cross',
- },
- },
- grid: {
- top: '16%',
- right: '3%',
- left: '10%',
- bottom: '23%',
- },
- legend: {
- top: '1',
- right: '10',
- textStyle: {
- color: 'rgba(250,250,250,0.6)',
- },
- },
- xAxis: {
- data: executeList.map(item=>item.name),
- axisLine: {
- show: true, //隐藏X轴轴线
- lineStyle: {
- color: '#005094',
- width: 1,
- },
- },
- axisTick: {
- show: false, //隐藏X轴刻度
- },
- axisLabel: {
- show: true,
- rotate: 40,
- textStyle: {
- color: 'rgba(255,255,255,0.6)', //X轴文字颜色
- },
- },
- },
- yAxis: [
- {
- type: 'value',
- nameTextStyle: {
- color: '#ebf8ac',
- },
- splitLine: {
- show: true,
- lineStyle: {
- color: '#68b4dd66',
- type: 'dashed',
- },
- },
- axisLine: {
- show: true,
- lineStyle: {
- color: '#3D7495',
- },
- },
- axisLabel: {
- show: true,
- textStyle: {
- color: 'rgba(250,250,250,0.6)',
- },
- },
- },
- ],
- series: [
- {
- name: '计划投资',
- type: 'bar',
- barWidth: 10,
- itemStyle: {
- normal: {
- color: new echarts.graphic.LinearGradient(0, 0, 0, 1, [
- {
- offset: 0,
- color: '#69c0ff',
- },
- {
- offset: 1,
- color: '#082550',
- },
- ]),
- },
- },
- data: executeList.map(item=>item.value),
- },
- {
- name: '实际投资',
- type: 'bar',
- barWidth: 10,
- itemStyle: {
- normal: {
- color: new echarts.graphic.LinearGradient(0, 0, 0, 1, [
- {
- offset: 0,
- color: '#957DFF',
- },
- {
- offset: 1,
- color: '#082550',
- },
- ]),
- },
- },
- data: executeList.map(item=>item.value2),
- },
- ],
- }
- myChart.setOption(option)
- tools.loopShowTooltip(myChart, option, {
- nterval: 2000,
- loopSeries: true,
- })
- },
- initChartR1 () {
- let myChart = echarts.init(this.$refs['echartR1'])
- let option = {
- tooltip: {
- trigger: 'axis',
- formatter: '{a0}:{c0}' + '亿元' + '<br/>' + '{a1}:{c1}' + '%',
- axisPointer: {
- type: 'cross',
- },
- },
- grid: {
- top: '16%',
- right: '10%',
- left: '10%',
- bottom: '10%',
- },
- legend: {
- top: '1',
- textStyle: {
- color: 'rgba(250,250,250,0.6)',
- },
- },
- xAxis: {
- data: industryList.map(item=> item.name),
- axisLine: {
- show: true, //隐藏X轴轴线
- lineStyle: {
- color: '#005094',
- width: 1,
- },
- },
- axisTick: {
- show: false, //隐藏X轴刻度
- },
- axisLabel: {
- show: true,
- // rotate: 20,
- textStyle: {
- color: 'rgba(255,255,255,0.6)', //X轴文字颜色
- },
- },
- },
- yAxis: [
- {
- type: 'value',
- name: '亿元',
- nameTextStyle: {
- color: 'rgba(255,255,255,0.6)',
- },
- splitLine: {
- show: true,
- lineStyle: {
- color: '#68b4dd66',
- type: 'dashed',
- },
- },
- axisLine: {
- show: true,
- lineStyle: {
- color: '#3D7495',
- },
- },
- axisLabel: {
- show: true,
- textStyle: {
- color: 'rgba(250,250,250,0.6)',
- },
- },
- },
- {
- type: 'value',
- axisLine: {
- show: false,
- },
- splitLine: {
- show: false,
- },
- axisLabel: {
- show: true,
- formatter: '{value} %',
- textStyle: {
- color: 'rgba(250,250,250,0.6)',
- },
- },
- },
- ],
- series: [
- {
- type: 'bar',
- name: '投资金额',
- barWidth: 15,
- itemStyle: {
- normal: {
- color: new echarts.graphic.LinearGradient(0, 0, 0, 1, [
- {
- offset: 0,
- color: '#69c0ff',
- },
- {
- offset: 1,
- color: '#082550',
- },
- ]),
- },
- },
- data: industryList.map(item=> item.value),
- },
- {
- type: 'line',
- name: '投资占比',
- type: 'line',
- yAxisIndex: 1,
- smooth: true, //平滑曲线显示
- showAllSymbol: true, //显示所有图形。
- symbol: 'circle', //标记的图形为实心圆
- symbolSize: 4, //标记的大小
- smooth: false,
- itemStyle: {
- //折线拐点标志的样式
- color: '#fbe138',
- borderColor: '#fbe138',
- width: 1,
- shadowColor: '#fbe138',
- shadowBlur: 2,
- },
- lineStyle: {
- color: '#fbe138',
- width: 1,
- },
- data: industryList.map(item=> item.value2),
- },
- ],
- }
- myChart.setOption(option)
- tools.loopShowTooltip(myChart, option, {
- nterval: 2000,
- loopSeries: true,
- })
- },
- initProjectList() {
- let dataList = []
- projectList.map(item=> {
- dataList.push([item.name,item.value+'亿',item.status])
- })
- this.storageRecordConfig = {
- header: ['项目名称', '投资金额', '项目进度'],
- headerBGC: '#05507b33',
- oddRowBGC: '#05507b33',
- evenRowBGC: '',
- headerHeight: '40',
- rowNum: 5,
- columnWidth: [350,100],
- align: ['center', 'center', 'center'],
- data: dataList,
- }
- }
- },
- })
|