import * as echarts from 'echarts' /** 255 * 统一样式,加载 * @param {*} id * @param {*} option */ export function loadEcharts(id, option) { var myChart = echarts.init(document.getElementById(id)) if (option.textStyle == null) { option.textStyle = { fontFamily: 'Microsoft YaHei', color: '#ffffff' } } // 使用刚指定的配置项和数据显示图表。 myChart.clear() myChart.setOption(option, true) window.addEventListener('resize', function() { myChart.resize() }) return myChart } const colorX = '#c7e7ff' const colorY = '#7696c5' // 脉链看板 export function mapArea() { } export function pie1(data) { const titleArr = [] const seriesArr = [] const colors = [['#389af4', '#dfeaff'], ['#ff8c37', '#ffdcc3'], ['#ffc257', '#ffedcc'], ['#fd6f97', '#fed4e0'], ['#a181fc', '#e3d9fe']] data.forEach(function(item, index) { titleArr.push( { text: item.name, left: index * 20 + 9.5 + '%', top: '55%', textAlign: 'center', textStyle: { fontWeight: 'normal', fontSize: '16', color: colors[index][0], textAlign: 'center' } } ) seriesArr.push( { name: item.name, type: 'pie', clockWise: false, radius: [50, 60], // 调整饼图大小 itemStyle: { normal: { color: colors[index][0], shadowColor: colors[index][0], shadowBlur: 0, label: { show: false }, labelLine: { show: false } } }, hoverAnimation: false, center: [index * 20 + 10 + '%', '50%'], data: [{ value: item.value, label: { normal: { formatter: function(params) { return params.value + '%' }, position: 'center', show: true, textStyle: { fontSize: '16', fontWeight: 'normal', // fontWeight: 'bold', color: colors[index][0] } } } }, { value: 100 - item.value, name: 'invisible', itemStyle: { normal: { color: colors[index][1] }, emphasis: { color: colors[index][1] } } }] } ) }) const option = { backgroundColor: 'transparent', title: titleArr, series: seriesArr } return option } export function bar1(data1, data2) { const titleText = '工厂人员出勤率' const path = 'path://M214,1079l8-6h16l8,6-8,6H222Z' // const data1 = ['80', '90', '70', '30', '50'] // const data2 = ['70', '60', '50', '40', '30'] const option = { backgroundColor: 'transparent', // tooltip: { // show: false, // trigger: 'axis', // axisPointer: { // 坐标轴指示器,坐标轴触发有效 // type: 'shadow' // 默认为直线,可选为:'line' | 'shadow' // }, // formatter: function(e) { // if (e.length > 1) { // var S = e[1].data - e[0].data // return e[0].axisValue + ':
差额=当前-年初
=' + S // } else if (e.length = 1) { // return e[0].axisValue + ':
' + e[0].seriesName + '=' + e[0].data // } // } // }, title: { text: titleText, x: '40%', y: '0%', textStyle: { // color: '#fff', color: '#00ffff', fontSize: '20', fontWeight: 'bolder' }, subtextStyle: { color: '#90979c', fontSize: '16' } }, grid: { left: '4%', right: '4%', bottom: '4%', top: '15%', containLabel: true }, legend: { show: false, // data: ['title1', 'title2'], data: ['title1'], left: 220, top: 10, textStyle: { color: '#00ffff', fontSize: 14 }, itemWidth: 12, itemHeight: 10, itemGap: 35, color: '#242424' }, xAxis: { type: 'category', // data: ['车间一', '车间二', '车间三', '车间四', '车间五'], data: ['浙江皇冠', '永康皇冠', '北辰电机', '恒泰皇冠园林', '迈拓塑业'], axisLine: { lineStyle: { show: true, lineStyle: { color: '#6A989E' } } }, axisLabel: { // interval: 0, // rotate: 40, textStyle: { fontFamily: 'Microsoft YaHei', color: colorX, // x轴颜色 fontWeight: 'normal', fontSize: '12', lineHeight: 22 } } // splitLine:{ // show:true, // lineStyle: { // type: 'dashed', // color: 'rgba(135,140,147,0.8)' // } // }, }, yAxis: { name: '%', nameTextStyle: { color: colorY, fontSize: 14, lineHeight: 20 }, boundaryGap: false, splitNumber: 4, type: 'value', axisLabel: { textStyle: { fontSize: 14, color: '#7696c5' // color: this.colorY } }, splitLine: { show: true, lineStyle: { color: '#032c58' } }, axisLine: { show: true, lineStyle: { color: '#032c58' } }, axisTick: { show: true } }, // { // type: 'value', // // name: '数量(单位:个)', // name: '', // nameTextStyle: { // color: '#ffffff' // }, // axisLine: { // show: false, // lineStyle: { // type: 'dashed', // color: 'rgba(135,140,147,0.8)' // } // }, // splitLine: { // show: true, // lineStyle: { // color: 'rgba(135,140,147,1)' // 左侧显示线 // } // }, // axisLabel: { // formatter: '{value}', // color: colorY, // fontSize: 14 // } // }, series: [ { type: 'pictorialBar', symbol: path, symbolSize: [30, 8], // symbolOffset: [-18, -4], symbolOffset: [0, -4], symbolPosition: 'end', z: 12, color: '#3440FF', data: data1 }, // { // type: 'pictorialBar', // symbol: path, // symbolSize: [30, 8], // symbolOffset: [18, -4], // // symbolOffset: [20, -5], // symbolPosition: 'end', // z: 12, // color: '#FF1155', // data: data2 // }, { type: 'pictorialBar', symbol: path, symbolSize: [30, 8], // symbolOffset: [-18, 4], symbolOffset: [0, 4], z: 12, color: 'rgba(126,192,238,0.6)', data: data1 }, // { // name: '', // type: 'pictorialBar', // symbol: path, // symbolSize: [30, 8], // // symbolOffset: [20, 4], // symbolOffset: [18, 4], // color: '#FFC0CB', // z: 12, // data: data2 // }, { name: 'title1', type: 'bar', barWidth: '30', itemStyle: { normal: { opacity: 0.7, color: new echarts.graphic.LinearGradient(0, 0, 0, 1, [{ offset: 0, color: 'blue' }, { offset: 1, color: '#7EC0EE' }]), barBorderRadius: 0 } }, label: { show: true, // position: ['-18','-18'], position: 'top', color: '#00f8ff', fontSize: 12 }, data: data1 } // { // name: 'title2', // type: 'bar', // barWidth: '30', // itemStyle: { // normal: { // opacity: 0.7, // color: new echarts.graphic.LinearGradient(0, 0, 0, 1, [{ // offset: 0, // color: '#FF2246' // }, { // offset: 1, // color: '#FFC0CB' // // }]), // barBorderRadius: 0 // } // // }, // label: { // show: true, // // position: ['18','-18'], // position: 'top', // color: '#00f8ff', // fontSize: 12 // }, // data: data2 // } ] } return option } export function line1(dataY, dataY2, dataY3, dataY4, dataY5) { const option = { backgroundColor: 'transparent', grid: { left: '4%', right: '4%', bottom: '4%', top: '15%', containLabel: true }, title: { // text: '销售额概览', text: '各工厂能耗', left: '50%', top: '0%', textAlign: 'center', textStyle: { // color: '#fff', color: '#00ffff', fontSize: '20', fontWeight: 'bolder' } }, tooltip: { trigger: 'axis', axisPointer: { lineStyle: { color: '#ddd' } }, backgroundColor: 'rgba(255,255,255,1)', padding: [5, 10], textStyle: { color: '#7588E4' }, extraCssText: 'box-shadow: 0 0 5px rgba(0,0,0,0.3)' }, legend: { show: false, right: 20, orient: 'vertical', data: ['浙江皇冠', '永康皇冠', '北辰电机', '恒泰皇冠园林', '迈拓塑业'] }, xAxis: { // data: ['00:00','2:00','4:00','6:00','8:00','10:00','12:00','14:00','16:00','18:00','20:00',"22:00"], // data: ['1月', '2月', '3月', '4月', '5月', '6月', '7月', '8月', '9月', '10月', '11月', '12月'], data: ['1月', '2月', '3月', '4月', '5月', '6月', '7月', '8月', '9月', '10月', '11月', '12月'], // type: 'category', // boundaryGap: true, // axisLabel: { // interval: 0, // formatter: '{value}', // fontSize: 14, // margin: 20, // textStyle: { // // color: this.colorX // color: '#c7e7ff' // } // }, // axisLine: { // lineStyle: { // color: '#032c58' // } // }, // splitLine: { // show: false, // lineStyle: { // color: '#032c58' // } // }, // axisTick: { // show: false // } // name: '月', // nameTextStyle: { // color: colorX, // fontSize: 14, // lineHeight: 20 // }, boundaryGap: false, // splitLine: { // show: false, // interval: 'auto', // lineStyle: { // color: ['#D4DFF5'] // } // }, axisTick: { show: false }, axisLine: { lineStyle: { show: true, lineStyle: { color: '#6A989E' } } }, axisLabel: { margin: 10, textStyle: { color: colorX, fontSize: 14 } } }, yAxis: { name: '', nameTextStyle: { color: colorY, fontSize: 14, lineHeight: 20 }, boundaryGap: false, splitNumber: 5, type: 'value', // offset: -30, axisLabel: { textStyle: { fontSize: 14, color: '#7696c5' // color: this.colorY } }, splitLine: { show: true, lineStyle: { color: '#032c58' } }, axisLine: { show: true, lineStyle: { color: '#032c58' } }, axisTick: { show: true } }, series: [ { name: '浙江皇冠', type: 'line', smooth: true, showSymbol: false, symbol: 'circle', symbolSize: 6, // data: ['200', '400', '500', '300', '400', '500', '600', '800', '900', '1000', '1100', '1322'], data: dataY, areaStyle: { normal: { color: new echarts.graphic.LinearGradient(0, 0, 0, 1, [{ offset: 0, color: 'rgba(0,215,236,0.5)' }, { offset: 1, color: 'rgba(0,215,236,0.2)' }], false) } }, itemStyle: { normal: { // color: '#f7b851' // color: `rgb(73, 226, 196)` color: `rgb(0, 215, 236)` } }, lineStyle: { normal: { width: 3 } } }, { name: '永康皇冠', type: 'line', smooth: true, showSymbol: false, symbol: 'circle', symbolSize: 6, // data: ['1200', '1400', '808', '811', '626', '488', '1600', '1100', '500', '300', '1998', '822'], data: dataY2, areaStyle: { normal: { color: new echarts.graphic.LinearGradient(0, 0, 0, 1, [{ offset: 0, color: 'rgba(60,244,184,0.5)' }, { offset: 1, color: 'rgba(60,244,184,0.2)' }], false) } }, itemStyle: { normal: { color: `rgb(60, 244, 184)` } }, lineStyle: { normal: { width: 3 } } }, { name: '北辰电机', type: 'line', smooth: true, showSymbol: false, symbol: 'circle', symbolSize: 6, // data: ['1200', '1400', '808', '811', '626', '488', '1600', '1100', '500', '300', '1998', '822'], data: dataY3, areaStyle: { normal: { color: new echarts.graphic.LinearGradient(0, 0, 0, 1, [{ offset: 0, color: 'rgba(55,183,255,0.5)' }, { offset: 1, color: 'rgba(55,183,255,0.2)' }], false) } }, itemStyle: { normal: { // color: '#58c8da' color: `rgb(55, 183, 255)` } }, lineStyle: { normal: { width: 3 } } }, { name: '恒泰皇冠园林', type: 'line', smooth: true, showSymbol: false, symbol: 'circle', symbolSize: 6, // data: ['1200', '1400', '808', '811', '626', '488', '1600', '1100', '500', '300', '1998', '822'], data: dataY4, areaStyle: { normal: { color: new echarts.graphic.LinearGradient(0, 0, 0, 1, [{ offset: 0, color: 'rgba(26,202,200,0.5)' }, { offset: 1, color: 'rgba(26,202,200,0.2)' }], false) } }, itemStyle: { normal: { // color: '#58c8da' color: `rgb(26, 202, 200)` } }, lineStyle: { normal: { width: 3 } } }, { name: '迈拓塑业', type: 'line', smooth: true, showSymbol: false, symbol: 'circle', symbolSize: 6, // data: ['1200', '1400', '808', '811', '626', '488', '1600', '1100', '500', '300', '1998', '822'], data: dataY5, areaStyle: { normal: { color: new echarts.graphic.LinearGradient(0, 0, 0, 1, [{ offset: 0, color: 'rgba(243,94,94,0.5)' }, { offset: 1, color: 'rgba(243,94,94,0.2)' }], false) } }, itemStyle: { normal: { // color: '#58c8da' color: `rgb(243, 94, 94)` } }, lineStyle: { normal: { width: 3 } } } ] } return option } export function pie2(title, scaleData) { var rich = { white: { color: '#ddd', align: 'center', padding: [5, 0] } } var placeHolderStyle = { normal: { label: { show: false }, labelLine: { show: false }, color: 'rgba(0, 0, 0, 0)', borderColor: 'rgba(0, 0, 0, 0)', borderWidth: 0 } } var data = [] for (var i = 0; i < scaleData.length; i++) { data.push({ value: scaleData[i].value, name: scaleData[i].name, itemStyle: { normal: { borderWidth: 5, shadowBlur: 30, borderColor: new echarts.graphic.LinearGradient(0, 0, 1, 1, [{ offset: 0, color: '#7777eb' }, { offset: 1, color: '#70ffac' }]), shadowColor: 'rgba(142, 152, 241, 0.6)' } } }, { value: 4, name: '', itemStyle: placeHolderStyle }) } var seriesObj = [{ name: '', type: 'pie', clockWise: false, radius: [60, 65], top: '10%', hoverAnimation: false, itemStyle: { normal: { label: { show: true, position: 'outside', // color: '#ddd', color: colorX, formatter: function(params) { var percent = 0 var total = 0 for (var i = 0; i < scaleData.length; i++) { total += scaleData[i].value } percent = ((params.value / total) * 100).toFixed(0) if (params.name !== '') { return params.name + '\n{white|' + '' + percent + '%}' } else { return '' } }, rich: rich }, labelLine: { show: false } } }, data: data }] const option = { backgroundColor: 'transparent', tooltip: { show: false }, top: 'middle', title: { text: title, left: '50%', top: '7%', textAlign: 'center', textStyle: { color: '#00ffff', fontSize: '20', fontWeight: 'bolder' } }, legend: { show: false }, toolbox: { show: false }, series: seriesObj } return option } export function bar2(list) { // const list = [500, 400, 300, 200, 200] const yName = ['浏览客户', '进店客户', '认购客户', '下单客户', '再次购买'] const xData = [500, 400, 300, 200, 100] // const color = ['#ff3259', '#ff6160', '#ffb065', '#fef568', '#1a6df1', '#15a0ff', '#11e2ff', '#58febe'] const color = ['#ff3259', '#ff6160', '#ffb065', '#fef568', '#1a6df1'] const barWidth = 15 const option = { backgroundColor: 'transparent', title: { text: '平台链接客户', left: '50%', top: '5%', textAlign: 'center', textStyle: { // color: '#fff', color: '#00ffff', fontSize: '20', fontWeight: 'bolder' } }, xAxis: { splitLine: { show: false }, axisLabel: { show: false }, axisTick: { show: false }, axisLine: { show: false } }, grid: { left: '4%', right: '4%', bottom: '4%', top: '15%', containLabel: true }, yAxis: [{ inverse: true, axisLine: { show: false }, axisTick: { show: false }, axisLabel: { margin: 10, textStyle: { fontSize: 14, color: colorX } }, data: yName }], series: [{ // 内 type: 'bar', barWidth, legendHoverLink: false, symbolRepeat: true, silent: true, itemStyle: { normal: { // barBorderRadius: [4, 4, 4, 4], color: function(params) { var colorlist = color return colorlist[params.dataIndex] } } }, data: list, z: 1, animationEasing: 'elasticOut' }, { // 背景 type: 'pictorialBar', animationDuration: 0, symbolRepeat: 'fixed', symbolMargin: '20%', symbol: 'roundRect', symbolSize: [6, barWidth], itemStyle: { normal: { color: 'rgba(255,255,255,0.3)' } }, data: xData, z: 0, animationEasing: 'elasticOut' }, { // 分隔 type: 'pictorialBar', itemStyle: { color: '#051e43' }, symbolRepeat: 'fixed', symbolMargin: 4, symbol: 'roundRect', symbolClip: true, symbolSize: [2, barWidth], symbolPosition: 'start', symbolOffset: [0, 0], data: list, z: 2, animationEasing: 'elasticOut' } ] } return option } export function custom1() { } export function bar3() { const a1 = 20 + Math.floor(Math.random() * 80) const a2 = 20 + Math.floor(Math.random() * 80) const a3 = 20 + Math.floor(Math.random() * 80) const a4 = 20 + Math.floor(Math.random() * 80) const a5 = 20 + Math.floor(Math.random() * 80) const a6 = 20 + Math.floor(Math.random() * 80) const a7 = 20 + Math.floor(Math.random() * 80) const a8 = 20 + Math.floor(Math.random() * 80) const a9 = 20 + Math.floor(Math.random() * 80) const a10 = 20 + Math.floor(Math.random() * 80) const a11 = 20 + Math.floor(Math.random() * 80) const a12 = 20 + Math.floor(Math.random() * 80) const list = [ { key: '进货数量', value: [ { value: a1 }, { value: a2 }, { value: a3 }, { value: a4 }, { value: a5 }, { value: a6 }, { value: a8 }, { value: a9 }, { value: a10 }, { value: a11 }, { value: a12 } ] }, { key: '合格数量', value: [ { value: a1 - 2 }, { value: a2 - 3 }, { value: a3 - 5 }, { value: a4 - 1 }, { value: a5 - 2 }, { value: a6 - 4 }, { value: a7 - 5 }, { value: a8 - 2 }, { value: a9 - 2 }, { value: a10 - 6 }, { value: a11 - 1 }, { value: a12 - 3 } ] }, { key: '不合格数量', value: [ { value: 2 }, { value: 3 }, { value: 5 }, { value: 1 }, { value: 2 }, { value: 4 }, { value: 5 }, { value: 2 }, { value: 2 }, { value: 6 }, { value: 1 }, { value: 3 } ] } ] const color = ['26,171,234', '73,226,196', '255,221,97'] // const xList = ['1月', '2月', '3月', '4月', '5月', '6月', '7月', '8月', '9月', '10月', '11月', '12月'] const xList = ['1月', '2月', '3月', '4月', '5月', '6月', '7月', '8月', '9月', '10月', '11月', '12月'] const seriesData = [] list.forEach((r, i) => { var o = { name: r.key, type: 'bar', smooth: false, yAxisIndex: 0, showSymbol: true, showAllSymbol: true, barWidth: 8, zlevel: 3, lineStyle: { normal: { width: 2, color: `rgba(${color[i]})` } }, areaStyle: { normal: { color: { type: 'linear', x: 0, y: 0, x2: 0, y2: 1, colorStops: [ { offset: 0, color: `rgba(${color[i]}, 0.0)`// 0% 处的颜色 }, { offset: 1, color: `rgba(${color[i]}, 0.0)` // 100% 处的颜色 } ], globalCoord: false // 缺省为 false } // 渐变颜色 } }, itemStyle: { normal: { color: { type: 'linear', x: 0, y: 0, x2: 0, y2: 1, colorStops: [ { offset: 0, color: `rgba(${color[i]}, 1)`// 0% 处的颜色 }, { offset: 1, color: `rgba(${color[i]}, 0.2)` // 100% 处的颜色 } ], globalCoord: false // 缺省为 false } // 渐变颜色 } }, data: r.value.map(r => r.value) } // if (i === 0) { // xList = r.value.map(r => r.key) // } // if (r.percent) { // this.$set(o, 'symbolSize', 6) // } else { // this.$set(o, 'symbol', 'path://M0,10 L10,10 L5,0 L0,10 z') // } seriesData.push(o) }) const option = { backgroundColor: 'transparent', legend: { show: true, data: list.map(r => r.key), top: '2%', itemHeight: 20, itemWidth: 20, textStyle: { fontSize: 14, color: 'F1F1F3' // color: colorX }, right: '1%' }, title: { text: '合格率分析', left: '28%', top: '2%', textAlign: 'center', textStyle: { // color: '#fff', color: '#00ffff', fontSize: '20', fontWeight: 'bolder' } }, grid: { left: '4%', right: '4%', bottom: '4%', top: '15%', containLabel: true }, tooltip: { show: true, trigger: 'axis', // axis , item backgroundColor: 'RGBA(0, 0, 0, 0.3)', borderColor: 'rgba(0, 151, 251, 0.6)', borderWidth: 1, borderRadius: 0, textStyle: { color: '#BCE9FC', fontSize: 14, align: 'left' } }, xAxis: [{ type: 'category', boundaryGap: true, axisLabel: { interval: 0, formatter: '{value}', fontSize: 14, margin: 20, textStyle: { // color: this.colorX color: '#c7e7ff' } }, axisLine: { lineStyle: { color: '#032c58' } }, splitLine: { show: false, lineStyle: { color: '#032c58' } }, axisTick: { show: false }, data: xList }], yAxis: [ { boundaryGap: false, splitNumber: 4, type: 'value', name: '%', nameTextStyle: { color: colorY, fontSize: 14, lineHeight: 20 }, axisLabel: { textStyle: { fontSize: 14, color: '#7696c5' // color: this.colorY } }, splitLine: { show: true, lineStyle: { color: '#032c58' } }, axisLine: { show: true, lineStyle: { color: '#032c58' } }, axisTick: { show: true } }, { boundaryGap: false, splitNumber: 4, type: 'value', axisLabel: { textStyle: { fontSize: 14, // color: this.colorY color: '#7696c5' } }, nameTextStyle: { color: '#fff', fontSize: 14, lineHeight: 40 }, splitLine: { lineStyle: { color: '#032c58' } }, axisLine: { show: false }, axisTick: { show: true } } ], series: seriesData } return option } export function bar4() { const data = [{ name: '浙江皇冠', value: Math.floor(Math.random() * 10 + 90) }, { name: '永康皇冠', value: Math.floor(Math.random() * 10 + 90) }, { name: '北辰电机', value: Math.floor(Math.random() * 10 + 90) }, { name: '恒泰皇冠园林', value: Math.floor(Math.random() * 10 + 90) }, { name: '迈拓塑业', value: Math.floor(Math.random() * 10 + 90) } // { // name: '车间五', // value: Math.floor(Math.random() * 10 + 90) // } ] const getArrByKey = (data, k) => { const key = k || 'value' const res = [] if (data) { data.forEach(function(t) { res.push(t[key]) }) } return res } const getSymbolData = (data) => { const arr = [] for (var i = 0; i < data.length; i++) { arr.push({ value: data[i].value, symbolPosition: 'end' }) } return arr } // console.log(getSymbolData(data)); const option = { backgroundColor: 'transparent', grid: { left: '0%', right: '4%', bottom: '4%', top: '15%', containLabel: true }, title: { text: '工厂达成率', x: '46%', y: '5%', textStyle: { // color: '#fff', color: '#00ffff', fontSize: '20', fontWeight: 'bolder' }, subtextStyle: { color: '#90979c', fontSize: '16' } }, xAxis: { show: false }, yAxis: [{ triggerEvent: true, show: true, inverse: true, data: getArrByKey(data, 'name'), axisLine: { show: false }, splitLine: { show: false }, axisTick: { show: false }, axisLabel: { show: true, interval: 0, color: colorY, align: 'left', margin: 60, formatter: function(value, index) { return '{title|' + value + '}' }, rich: { title: { width: 50, align: 'right', fontSize: 18 } } } }, { triggerEvent: true, show: true, inverse: true, data: getArrByKey(data, 'name'), axisLine: { show: false }, splitLine: { show: false }, axisTick: { show: false }, axisLabel: { interval: 0, shadowOffsetX: '-20px', // color: ['#fff'], color: colorX, align: 'left', verticalAlign: 'center', lineHeight: 40, fontSize: 18, formatter: function(value, index) { return data[index].value + '%' } } }], series: [{ name: 'XXX', type: 'pictorialBar', symbol: 'image://', symbolSize: [50, 50], symbolOffset: [20, 0], z: 12, itemStyle: { normal: { color: '#fff' } }, data: getSymbolData(data) }, { name: '条', type: 'bar', showBackground: true, // barBorderRadius: 30, yAxisIndex: 0, data: data, barWidth: 10, // align: left, itemStyle: { normal: { color: 'rgba(41, 162, 245, 1)' // barBorderRadius: 10 } // color: '#A71A2B', // barBorderRadius: 4, } // label: { // normal: { // color: '#fff', // show: true, // position: ["-80px", 0], // textStyle: { // fontSize: 16 // }, // formatter: function(a, b) { // return a.name // } // } // } }] } return option } export function barline1() { return { backgroundColor: 'transparent', tooltip: {}, title: { text: '订单完成总数', left: '50%', top: '5%', textAlign: 'center', textStyle: { // color: '#fff', color: '#00ffff', fontSize: '20', fontWeight: 'bolder' } }, grid: { left: '4%', right: '4%', bottom: '4%', top: '15%', containLabel: true }, legend: { show: false, itemGap: 50, data: ['注册总量', '最新注册量'], textStyle: { color: '#f9f9f9', borderColor: '#fff' } }, xAxis: [{ type: 'category', boundaryGap: true, axisLabel: { interval: 0, formatter: '{value}', fontSize: 14, margin: 20, textStyle: { color: colorX } }, axisLine: { lineStyle: { color: '#032c58' } }, splitLine: { show: false, lineStyle: { color: '#032c58' } }, axisTick: { show: false }, data: ['1月', '2月', '3月', '4月', '5月', '6月', '7月', '8月', '9月', '10月', '11月', '12月'] }], yAxis: [ { max: 800, boundaryGap: false, splitNumber: 4, type: 'value', axisLabel: { textStyle: { fontSize: 14, color: colorY } }, name: '单', nameTextStyle: { color: colorY, fontSize: 14, lineHeight: 20 }, splitLine: { show: true, lineStyle: { color: '#032c58' } }, axisLine: { show: true, lineStyle: { color: '#032c58' } }, axisTick: { show: true } } ], series: [ { name: '注册总量', type: 'line', // smooth: true, //是否平滑曲线显示 // symbol:'circle', // 默认是空心圆(中间是白色的),改成实心圆 showAllSymbol: true, symbol: 'emptyCircle', symbolSize: 6, lineStyle: { normal: { color: '#28ffb3' // 线条颜色 }, borderColor: '#f0f' }, label: { show: true, position: 'top', textStyle: { color: '#fff' } }, itemStyle: { normal: { color: '#28ffb3' } }, tooltip: { show: false }, areaStyle: { // 区域填充样式 normal: { // 线性渐变,前4个参数分别是x0,y0,x2,y2(范围0~1);相当于图形包围盒中的百分比。如果最后一个参数是‘true’,则该四个值是绝对像素位置。 color: new echarts.graphic.LinearGradient(0, 0, 0, 1, [{ offset: 0, color: 'rgba(0,154,120,1)' }, { offset: 1, color: 'rgba(0,0,0, 0)' } ], false), shadowColor: 'rgba(53,142,215, 0.9)', // 阴影颜色 shadowBlur: 20 // shadowBlur设图形阴影的模糊大小。配合shadowColor,shadowOffsetX/Y, 设置图形的阴影效果。 } }, // data: [393, 438, 485, 631, 689, 824, 987] data: [600 + Math.floor(Math.random() * 100), 600 + Math.floor(Math.random() * 100), 600 + Math.floor(Math.random() * 100), 600 + Math.floor(Math.random() * 100), 600 + Math.floor(Math.random() * 100), 600 + Math.floor(Math.random() * 100), 600 + Math.floor(Math.random() * 100), 600 + Math.floor(Math.random() * 100), 600 + Math.floor(Math.random() * 100), 600 + Math.floor(Math.random() * 100), 600 + Math.floor(Math.random() * 100), 600 + Math.floor(Math.random() * 100)] } // { // name: '最新注册量', // type: 'bar', // barWidth: 20, // tooltip: { // show: false // }, // label: { // show: true, // position: 'top', // textStyle: { // color: '#fff', // } // }, // itemStyle: { // normal: { // // barBorderRadius: 5, // // color: new echarts.graphic.LinearGradient( // // 0, 0, 0, 1, // // [{ // // offset: 0, // // color: '#14c8d4' // // }, // // { // // offset: 1, // // color: '#43eec6' // // } // // ] // // ) // color: function (params) { // var colorList = ['#0ec1ff', '#10cdff', '#12daff', '#15ebff', '#17f8ff', '#1cfffb', '#1dfff1']; // return colorList[params.dataIndex]; // } // } // }, // data: [200, 382, 102, 267, 186, 315, 316] // } ] } } // 综合看板 export function zhkb01() { // const zhkb01name = ['计划完成进度(自产)', '计划完成进度(外购)'] // 名称 const zhkb01name = ['', ''] // 名称 const zhkb01Value = [Math.ceil(Math.random() * 10 + 90), Math.ceil(Math.random() * 10 + 90)] // 值 const zhkb01Max = [] const max = Math.ceil(Math.max(...zhkb01Value.map(r => r)) * 1.1) for (let i = 0; i < zhkb01Value.length; i++) { zhkb01Max.push(max * 4) // zhkb01Max.push(100) } const option = { backgroundColor: 'transparent', grid: { left: '4%', right: '4%', bottom: '4%', top: '5%', containLabel: true }, // tooltip: { // formatter: (params) => { // if (params.name !== '') { // return params.name + ' : ' + zhkb01Value[params.dataIndex] // } // }, // textStyle: { // align: 'left' // } // }, xAxis: [ { type: 'value', axisLabel: { show: false, color: '#fff', formatter: function(val) { return val + '' }, textStyle: { fontSize: '13' } }, min: 0, max: max, // 计算最大值 interval: max / 5, // 平均分为5份 splitNumber: 5, splitLine: { show: false, lineStyle: { color: '#fff' } }, axisLine: { show: false, lineStyle: { color: '#fff', width: 1, opacity: 0.3 } }, axisTick: { show: false } }, { type: 'value', axisLabel: { show: false }, min: 0, max: max, // 计算最大值 interval: max / 10, // 平均分为5份 splitNumber: 10, splitLine: { show: false, lineStyle: { type: 'dashed', color: '#D8D8D8' } }, axisLine: { show: false, lineStyle: { color: '#fff' } }, axisTick: { show: false } } ], yAxis: [ { // show: true,//暂时不显示 show: false, inverse: false, data: zhkb01name, axisLabel: { padding: [30, 0, 0, -135], // inside: true textStyle: { fontSize: 16, fontFamily: 'PingFang SC', // fontWeight: 400, color: '#3dffef', align: 'left' } // formatter: '{value}\n{a|占位}', // rich: { // a: { // // color: 'transparent', // color: 'red', // lineHeight: 30, // fontFamily: 'digital', // fontSize: 20, // // shadowColor: 'rgba(0, 0, 0, 1)', // shadowColor: 'red', // shadowBlur: 10 // } // } }, // scale: true, // 自适应 // offset: 50, splitLine: { show: false }, axisTick: { show: false }, axisLine: { show: false } }, { // 左侧柱状图的Y轴 gridIndex: 0, // y轴所在的 grid 的索引 splitLine: 'none', axisTick: 'none', axisLine: 'none', data: zhkb01Value, // inverse: true,//是否是反向坐标轴。 axisLabel: { show: true, verticalAlign: 'center', align: 'left', padding: [0, 0, 0, 0], textStyle: { color: '#fff', fontSize: '20' }, formatter: function(value) { return '{x| ' + value + '} {y|' + '%}' }, rich: { y: { color: '#3dffef', fontFamily: 'Orbitron', fontSize: 16 }, x: { color: '#3dffef', fontFamily: 'Orbitron', fontSize: 16 } } } } ], series: [ { name: '值', type: 'bar', barGap: '-130%', // zlevel: 1, xAxisIndex: 0, label: { show: false, position: 'right', textStyle: { color: '#fff', fontSize: 20 } }, itemStyle: { normal: { barBorderRadius: 4, color: { colorStops: [ { offset: 0, color: '#46B7ED' // 0% 处的颜色 }, { offset: 1, color: '#48EDD3' // 100% 处的颜色 } ] } } }, barWidth: 12, data: zhkb01Value, z: 0 }, { // 分隔 type: 'pictorialBar', symbolRotate: '-20', itemStyle: { normal: { color: 'rgba(1, 12, 38, 0.4)' } }, symbolRepeat: 'fixed', symbolMargin: 10, symbol: 'rect', symbolClip: true, symbolSize: [5, 28], symbolPosition: 'start', symbolOffset: [0, -1], data: zhkb01Value, z: 66, animationEasing: 'elasticOut' }, { name: '背景', type: 'bar', barWidth: 14, barGap: '-110%', data: zhkb01Max, itemStyle: { normal: { color: 'rgba(5,59,113,.7)', barBorderRadius: 6, borderColor: 'rgba(0, 255, 236, 1)' } }, z: -1 } ] } return option } export function zhkb02() { } export function zhkb03(title) { const labelData = [] const labelData1 = [] for (let i = 0; i < 80; ++i) { labelData.push({ value: 1, name: i, itemStyle: { normal: { color: 'rgba(0,209,228,0)' } } }) } for (let i = 0; i < labelData.length; ++i) { if (labelData[i].name < 15) { labelData[i].itemStyle = { normal: { color: new echarts.graphic.LinearGradient( 0, 1, 0, 0, [{ offset: 0, color: '#6dfbff' }, { offset: 1, color: '#02aeff' } ] ) } } } } for (let i = 0; i < 80; ++i) { labelData1.push({ value: 1, name: i, itemStyle: { normal: { color: 'rgba(0,209,228,0)' } } }) } for (let i = 0; i < labelData1.length; ++i) { if (labelData1[i].name < 80) { labelData1[i].itemStyle = { normal: { color: '#464451' } } } } function Pie() { const dataArr = [] for (var i = 0; i < 100; i++) { if (i % 10 === 0) { dataArr.push({ name: (i + 1).toString(), value: 30, itemStyle: { normal: { color: 'rgba(0,255,255,1)', borderWidth: 0, borderColor: 'rgba(0,0,0,0)' } } }) } else { dataArr.push({ name: (i + 1).toString(), value: 100, itemStyle: { normal: { color: 'rgba(0,0,0,0)', borderWidth: 0, borderColor: 'rgba(0,0,0,0)' } } }) } } return dataArr } function Pie1() { const dataArr = [] for (var i = 0; i < 100; i++) { if (i % 5 === 0) { dataArr.push({ name: (i + 1).toString(), value: 20, itemStyle: { normal: { color: 'rgba(0,255,255,1)', borderWidth: 0, borderColor: 'rgba(0,0,0,0)' } } }) } else { dataArr.push({ name: (i + 1).toString(), value: 100, itemStyle: { normal: { color: 'rgba(0,0,0,0)', borderWidth: 0, borderColor: 'rgba(0,0,0,0)' } } }) } } return dataArr } function Pie2() { const dataArr = [] for (var i = 0; i < 100; i++) { if (i % 5 === 0) { dataArr.push({ name: (i + 1).toString(), value: 20, itemStyle: { normal: { color: 'rgba(0,255,255,.3)', borderWidth: 0, borderColor: 'rgba(0,0,0,0)' } } }) } else { dataArr.push({ name: (i + 1).toString(), value: 100, itemStyle: { normal: { color: 'rgba(0,0,0,0)', borderWidth: 0, borderColor: 'rgba(0,0,0,0)' } } }) } } return dataArr } const option = { grid: { left: '0%', right: '0%', bottom: '0%', top: '0%', containLabel: true }, backgroundColor: 'transparent', title: [ { text: title, x: '46%', y: '38%', textAlign: 'center', textStyle: { fontSize: 12, fontWeight: 'normal', color: '#09d8f2' } }, { text: '99%', x: '49%', y: '53%', textAlign: 'center', textStyle: { fontSize: 18, fontWeight: 800, color: '#09d8f2' } }], polar: { radius: ['90%', '85%'], center: ['50%', '50%'] }, angleAxis: { max: 100, show: false, startAngle: 0 }, radiusAxis: { type: 'category', show: true, axisLabel: { show: false }, axisLine: { show: false }, axisTick: { show: false } }, series: [ // 最里圈 { type: 'pie', radius: ['91%', '89%'], center: ['50%', '50%'], data: [{ hoverOffset: 1, value: 100, name: '', itemStyle: { color: '#2f748b' }, label: { show: false }, labelLine: { normal: { smooth: true, lineStyle: { width: 0 } } }, hoverAnimation: false }] }, // 里第二圈 { name: '', type: 'bar', roundCap: true, // 圆角 barWidth: 60, showBackground: true, backgroundStyle: { color: '#3d4767' }, data: [75], coordinateSystem: 'polar', itemStyle: { normal: { color: new echarts.graphic.LinearGradient(1, 0, 0, 0, [{ offset: 0, color: '#0ff' }, { offset: 1, color: '#02aeff' }]) } } }, // 齿轮 { name: '大环', type: 'gauge', splitNumber: 100, radius: '124%', center: ['50%', '50%'], startAngle: 90, endAngle: -269.9999, axisLine: { show: false, lineStyle: { color: [[0.3, '#26a7d4'], [1, '#23395a']] } }, axisTick: { show: false }, splitLine: { show: true, length: 8, lineStyle: { color: 'auto', width: 2.5 } }, axisLabel: { show: false }, detail: { show: false } }, // 外圈装饰 { type: 'pie', zlevel: 0, silent: true, radius: ['110%', '108.5%'], center: ['50%', '50%'], z: 1, label: { normal: { show: false } }, labelLine: { normal: { show: false } }, data: Pie() }, // { // type: 'pie', // zlevel: 0, // silent: true, // startAngle: -150, // radius: ['58.5%', '57%'], // center: ['50%', '50%'], // z: 1, // label: { // normal: { // show: false // } // }, // labelLine: { // normal: { // show: false // } // }, // data: Pie3() // }, { type: 'pie', zlevel: 0, silent: true, startAngle: -140, radius: ['100%', '98.5%'], center: ['50%', '50%'], z: 1, label: { normal: { show: false } }, labelLine: { normal: { show: false } }, data: Pie() }, { type: 'pie', zlevel: 0, silent: true, radius: ['98%', '96.5%'], center: ['50%', '50%'], z: 1, label: { normal: { show: false } }, labelLine: { normal: { show: false } }, data: Pie1() }, { type: 'pie', zlevel: 0, silent: true, startAngle: -140, radius: ['98%', '96.5%'], center: ['50%', '50%'], z: 1, label: { normal: { show: false } }, labelLine: { normal: { show: false } }, data: Pie2() }, { type: 'pie', zlevel: 0, silent: true, startAngle: -147.5, radius: ['98%', '96.5%'], center: ['50%', '50%'], z: 1, label: { normal: { show: false } }, labelLine: { normal: { show: false } }, data: Pie2() } ] } return option } export function zhkb04() { const myColor = ['#d0a00e', '#34da62', '#00e9db', '#00c0e9', '#0096f3'] // const data = [330, 404, 780, 509, 150] const data = [Math.ceil(Math.random() * 100 + 500), Math.ceil(Math.random() * 100 + 600), Math.ceil(Math.random() * 100 + 700), Math.ceil(Math.random() * 400 + 500), Math.ceil(Math.random() * 100 + 200)] const option = { backgroundColor: 'transparent', grid: { left: '10%', right: '4%', bottom: '0%', top: '5%', containLabel: true }, xAxis: [{ show: false }], yAxis: [ { axisTick: 'none', axisLine: 'none', offset: '27', axisLabel: { textStyle: { color: function(value, index) { let temp = '' myColor.forEach((it, ind) => { if (index === ind) { temp = it } }) return temp }, fontSize: 16 } }, data: ['第四季度订单数', '第三季度订单数', '第二季度订单数', '第一季度订单数', '在制订单数量'] }, { axisTick: 'none', axisLine: 'none', axisLabel: { textStyle: { color: function(value, index) { let temp = '' myColor.forEach((it, ind) => { if (index === ind) { temp = it } }) return temp }, fontSize: 16 } }, data: data }, { show: false, name: '单位:件', nameGap: '50', nameTextStyle: { color: '#ffffff', fontSize: '16' }, axisLine: { lineStyle: { color: 'rgba(0,0,0,0)' } }, data: [] } ], series: [ { name: '条', type: 'bar', yAxisIndex: 0, data: data.map(r => r / 10), label: { normal: { show: false, position: 'right', formatter: function(param) { return param.value + '%' }, textStyle: { color: '#ffffff', fontSize: '16' } } }, barWidth: 12, itemStyle: { normal: { color: function(params) { var num = myColor.length return myColor[params.dataIndex % num] } } }, z: 2 }, { name: '白框', type: 'bar', yAxisIndex: 1, barGap: '-100%', data: [99.5, 99.5, 99.5, 99.5, 99.5], barWidth: 20, itemStyle: { normal: { color: '#0e2147', barBorderRadius: 5 } }, z: 1 }, { name: '外框', type: 'bar', yAxisIndex: 2, barGap: '-100%', data: [100, 100, 100, 100, 100], barWidth: 24, itemStyle: { normal: { color: function(params) { var num = myColor.length return myColor[params.dataIndex % num] }, barBorderRadius: 5 } }, z: 0 }, { name: '外圆', type: 'scatter', hoverAnimation: false, data: [0, 0, 0, 0, 0], yAxisIndex: 2, symbolSize: 30, itemStyle: { normal: { color: function(params) { var num = myColor.length return myColor[params.dataIndex % num] }, opacity: 1 } }, z: 2 } ] } return option } export function zhkb05() { // 数据 // var XName = ['周一', '周二', '周三', '周四', '周五', '周六', '周日'] var XName = ['01月', '02月', '03月', '04月', '05月', '06月', '07月', '08月', '09月', '10月', '11月', '12月'] var data1 = [ // [123, 121, 123, 321, 222, 111, 234, 121, 123, 321, 222, 321] [Math.ceil(Math.random() * 100 + 100), Math.ceil(Math.random() * 100 + 200), Math.ceil(Math.random() * 100 + 200), Math.ceil(Math.random() * 100 + 200), Math.ceil(Math.random() * 100 + 300), Math.ceil(Math.random() * 100 + 100), Math.ceil(Math.random() * 100 + 200), Math.ceil(Math.random() * 100 + 200), Math.ceil(Math.random() * 100 + 300), Math.ceil(Math.random() * 100 + 100), Math.ceil(Math.random() * 100 + 200), Math.ceil(Math.random() * 100 + 300)] // [123, 154, 234, 321, 120, 390, 634], // [63, 194, 234, 321, 278, 110, 534], // [53, 254, 234, 321, 118, 240, 434], // [23, 354, 334, 221, 178, 190, 234] ] var Line = ['云篆山水路线', '昕博朗学校路线', '新华小学路线', '云锦五路路线'] var img = [ 'image://', 'image://', 'image://', 'image://' ] // var color = ['#00f8ff', '#00f15a', '#0696f9', '#dcf776'] var color = ['#00f8ff'] // 数据处理 var datas = [] Line.map((item, index) => { datas.push( { symbolSize: 150, symbol: img[index], name: item, type: 'line', yAxisIndex: 1, data: data1[index], itemStyle: { normal: { borderWidth: 5, color: color[index] } } } ) }) const option = { backgroundColor: 'transparent', grid: { left: '5%', top: '20%', bottom: '0%', right: '5%', containLabel: true }, title: { text: '今年每月订单数量', x: '50%', y: '0%', textAlign: 'center', textStyle: { fontSize: 16, fontWeight: 'normal', color: '#00FFFF' } }, legend: { show: false, type: 'scroll', data: Line, itemWidth: 18, itemHeight: 12, textStyle: { color: '#00ffff', fontSize: 14 } }, yAxis: [ { type: 'value', position: 'right', splitLine: { show: false }, axisLine: { show: false }, axisTick: { show: false }, axisLabel: { show: false } }, { // show: false, type: 'value', position: 'left', // name: '今年每月订单数量', nameTextStyle: { color: '#00FFFF', fontSize: 16 }, splitNumber: 3, // nameLocation: 'center', splitLine: { lineStyle: { type: 'dashed', color: 'rgba(135,140,147,0.8)' } }, axisLine: { show: false }, axisTick: { show: false }, axisLabel: { formatter: '{value}', color: '#00FFFF', fontSize: 14 } } ], xAxis: [ { type: 'category', axisTick: { show: false }, axisLine: { show: false, lineStyle: { color: '#6A989E' } }, axisLabel: { inside: false, textStyle: { color: colorX, // x轴颜色 fontWeight: 'normal', fontSize: 16, lineHeight: 22 } }, data: XName }, { type: 'category', axisLine: { show: false }, axisTick: { show: false }, axisLabel: { show: false }, splitArea: { show: false }, splitLine: { show: false }, // ----- data: ['1月', '2月', '3月', '4月', '5月', '6月'] } ], series: datas } // 当点击legend选项时折线上的小图片会消失,为避免这种情况,可以采取以下初始化方法 使用svg // var myCharts = echarts.init(document.getElementById('AnalysisChartLine'), null, {renderer: 'svg'}); // myCharts.clear(); // myCharts.setOption(option) return option } export function zhkb06(title) { const option = { backgroundColor: 'transparent', title: [ { text: title, x: 'center', top: '55%', textStyle: { color: '#FFFFFF', fontSize: 14, fontWeight: 100 } }, { text: '95%', x: 'center', top: '38%', textStyle: { fontSize: 14, color: '#FFFFFF', fontFamily: 'DINAlternate-Bold, DINAlternate', foontWeight: 100 } } ], grid: { left: '0%', top: '0%', bottom: '0%', right: '0%', containLabel: true }, angleAxis: { max: 100, clockwise: false, // 逆时针 // 隐藏刻度线 show: false, boundaryGap: ['40%', '40%'], startAngle: 90 }, radiusAxis: { type: 'category', show: true, axisLabel: { show: false }, axisLine: { show: false }, axisTick: { show: false } }, polar: [ { center: ['50%', '50%'], // 中心点位置 radius: '165%' // 图形大小 } ], series: [ { name: '齿轮', type: 'gauge', splitNumber: 60, radius: '132%', center: ['50%', '50%'], startAngle: 90, endAngle: -269.9999, axisLine: { show: false, lineStyle: { color: [[0.3, '#26a7d4'], [1, '#23395a']] } }, axisTick: { show: false }, splitLine: { show: true, length: 8, lineStyle: { color: 'auto', width: 2.5 } }, axisLabel: { show: false }, detail: { show: false } }, { type: 'bar', z: 10, data: [75], showBackground: false, backgroundStyle: { color: 'blue', borderWidth: 4, width: 4 }, coordinateSystem: 'polar', roundCap: true, barWidth: 6, // 大的占比环 itemStyle: { normal: { opacity: 1, color: new echarts.graphic.LinearGradient(0, 0, 1, 1, [ { offset: 0, color: '#00FFFF' }, { offset: 1, color: '#09d8f2' } ]) } } }, { type: 'pie', name: '内层细圆环', radius: ['82%', '83%'], startAngle: 110, hoverAnimation: false, clockWise: true, itemStyle: { normal: { color: new echarts.graphic.LinearGradient(0, 0, 1, 1, [ { offset: 0, color: 'rgba(151,179,166,0.74)' }, { offset: 1, color: 'rgba(151,179,166,0.74)' } ]), shadowBlur: 20, shadowColor: '#66666a' } }, tooltip: { show: false }, label: { show: false }, data: [100] } ] } return option } export function zhkb07(title, value) { const dataArr = [ { value: value, name: title } ] const color = new echarts.graphic.LinearGradient(0, 0, 1, 0, [ { offset: 0, color: '#1f79b6' // 0% 处的颜色 }, { offset: 1, color: '#0dd2db' // 100% 处的颜色 } ]) const colorSet = [ [value / 100, color], [1, '#15337C'] ] const rich = { white: { fontSize: 14, color: '#fff', fontWeight: '500' }, bule: { fontSize: 14, fontFamily: 'DINBold', color: '#fff', fontWeight: 100 }, radius: { width: 350, height: 80, // lineHeight:80, borderWidth: 1, borderColor: '#0092F2', fontSize: 14, color: '#fff', backgroundColor: '#1B215B', borderRadius: 20, textAlign: 'center' }, size: { height: 400, padding: [100, 0, 0, 0] } } const option = { backgroundColor: 'transparent', tooltip: { formatter: '{a}
{b} : {c}%' }, series: [ { type: 'gauge', radius: '90%', startAngle: '225', endAngle: '-45', pointer: { show: false }, detail: { formatter: function(value) { var num = Math.round(value) return '{bule|' + num + '}{white|%}' }, rich: rich, offsetCenter: ['0%', '0%'] }, data: dataArr, title: { show: true, color: '#fff', offsetCenter: ['0', '75%'], fontSize: 14 }, axisLine: { show: true, lineStyle: { color: colorSet, width: 12, shadowOffsetX: 0, shadowOffsetY: 0, opacity: 1 } }, axisTick: { show: false }, splitLine: { show: false, length: 10, lineStyle: { color: '#00377a', width: 2, type: 'solid' } }, axisLabel: { show: false } } ] } return option } export function zhkb08() { const data = [ { name: '钢材改制车间', value: Math.floor(Math.random() * 10 + 90) }, { name: '冷墩车间', value: Math.floor(Math.random() * 10 + 90) }, { name: '热墩车间', value: Math.floor(Math.random() * 10 + 90) }, { name: '热处理车间', value: Math.floor(Math.random() * 10 + 90) }, { name: '达克罗车间', value: Math.floor(Math.random() * 10 + 90) }, { name: '镀锌车间', value: Math.floor(Math.random() * 10 + 90) } ] const myColor = ['#d0a00e', '#34da62', '#00e9db', '#00c0e9', '#0096f3', '#ff00ff'] const getArrByKey = (data, k) => { const key = k || 'value' const res = [] if (data) { data.forEach(function(t) { res.push(t[key]) }) } return res } const getSymbolData = (data) => { const arr = [] for (var i = 0; i < data.length; i++) { arr.push({ value: data[i].value, symbolPosition: 'end' }) } return arr } // console.log(getSymbolData(data)); const option = { backgroundColor: 'transparent', grid: { left: '0%', right: '0%', bottom: '0%', top: '15%', containLabel: true }, title: { text: '九月能耗用量', x: '44%', y: '0%', textStyle: { color: '#09d8f2', fontSize: 16 } // subtextStyle: { // color: '#90979c', // fontSize: '16' // } }, xAxis: { show: false }, yAxis: [ { triggerEvent: true, show: true, inverse: true, data: getArrByKey(data, 'name'), axisLine: { show: false }, splitLine: { show: false }, axisTick: { show: false }, axisLabel: { show: true, interval: 0, // color: colorY, align: 'left', margin: 30, textStyle: { color: function(value, index) { let temp = '' myColor.forEach((it, ind) => { if (index === ind) { temp = it } }) return temp }, fontSize: 16, align: 'right' // width: 36 } // formatter: function(value, index) { // return '{title|' + value + '}' // }, // rich: { // title: { // width: 36, // align: 'right', // fontSize: 16 // } // } } }, { triggerEvent: true, show: true, inverse: true, data: getArrByKey(data, 'name'), axisLine: { show: false }, splitLine: { show: false }, axisTick: { show: false }, axisLabel: { interval: 0, shadowOffsetX: '-20px', // color: colorX, color: function(value, index) { let temp = '' myColor.forEach((it, ind) => { if (index === ind) { temp = it } }) return temp }, align: 'left', verticalAlign: 'center', lineHeight: 40, fontSize: 16, margin: 20, formatter: function(value, index) { // return data[index].value + '%' return data[index].value + '吨' } } }], series: [ { name: 'XXX', type: 'pictorialBar', symbol: 'image://', symbolSize: [50, 50], symbolOffset: [20, 0], z: 12, itemStyle: { normal: { color: '#fff' } }, data: getSymbolData(data) }, { name: '条', type: 'bar', showBackground: true, yAxisIndex: 0, data: data, barWidth: 10, // align: left, itemStyle: { normal: { color: function(params) { return myColor[params.dataIndex] }, barBorderRadius: 10 } } // label: { // normal: { // color: '#fff', // show: true, // position: ["-80px", 0], // textStyle: { // fontSize: 16 // }, // formatter: function(a, b) { // return a.name // } // } // } }] } return option } // 暂时弃用 export function zhkb092222() { const data = [220, 182, 191, 234, 290, 330, 310, 182, 191, 234, 290, 330] const sideData = data.map(item => item + 4.5) const option = { backgroundColor: 'transparent', // tooltip: { // trigger: 'axis', // formatter: '{b} : {c}', // axisPointer: { // 坐标轴指示器,坐标轴触发有效 // type: 'shadow' // 默认为直线,可选为:'line' | 'shadow' // } // }, grid: { left: '2%', right: '2%', bottom: '2%', top: '15%', containLabel: true }, title: { text: '近一年每月能耗使用', x: '40%', y: '0%', textStyle: { color: '#09d8f2', fontSize: 16 } // subtextStyle: { // color: '#90979c', // fontSize: '16' // } }, xAxis: { data: ['01月', '02月', '03月', '04月', '05月', '06月', '07月', '08月', '09月', '10月', '11月', '12月'], // 坐标轴 axisLine: { lineStyle: { color: '#3eb2e8' } }, // 坐标值标注 axisLabel: { show: true, textStyle: { color: colorX, fontSize: 14 } } }, yAxis: { // 坐标轴 axisLine: { show: false }, // 坐标值标注 axisLabel: { show: true, textStyle: { color: '#09d8f2', fontSize: 14 } }, // 分格线 splitLine: { lineStyle: { type: 'dashed', color: 'rgba(135,140,147,0.8)' } }, splitNumber: 3 }, series: [ { name: 'a', tooltip: { show: false }, type: 'bar', barWidth: 18, itemStyle: { normal: { color: new echarts.graphic.LinearGradient(0, 1, 0, 0, [{ offset: 0, color: '#0B4EC3' // 0% 处的颜色 }, { offset: 0.6, color: '#138CEB' // 60% 处的颜色 }, { offset: 1, color: '#17AAFE' // 100% 处的颜色 }], false) } }, data: data, barGap: 0 }, { type: 'bar', barWidth: 8, itemStyle: { normal: { color: new echarts.graphic.LinearGradient(0, 1, 0, 0, [{ offset: 0, color: '#09337C' // 0% 处的颜色 }, { offset: 0.6, color: '#0761C0' // 60% 处的颜色 }, { offset: 1, color: '#0575DE' // 100% 处的颜色 }], false) } }, barGap: 0, data: sideData }, { name: 'b', tooltip: { show: false }, type: 'pictorialBar', itemStyle: { borderWidth: 1, borderColor: '#0571D5', color: '#1779E0' }, symbol: 'path://M 0,0 l 120,0 l -30,60 l -120,0 z', symbolSize: ['30', '6'], symbolOffset: ['0', '-4'], // symbolRotate: -5, symbolPosition: 'end', data: data, z: 3 } ] } return option } export function zhkb09() { // const dataY = [60, 70, 80, 90, 60, 70, 80, 90, 80, 90, 60, 70, 80, 90] const dataY = [(80 + Math.random() * 10), (90 - Math.random() * 30), (60 + Math.random() * 30), (70 + Math.random() * 20), (80 + Math.random() * 10), (90 - Math.random() * 30), (80 - Math.random() * 30), (90 - Math.random() * 30), (60 + Math.random() * 30), (70 + Math.random() * 20), (80 - Math.random() * 10), (90 - Math.random() * 30)] const option = { backgroundColor: 'transparent', grid: { left: '2%', right: '2%', bottom: '2%', top: '15%', containLabel: true }, title: { text: '近一年每月能耗使用', x: '40%', y: '0%', textStyle: { color: '#09d8f2', fontSize: 16 } }, color: ['#3cefff'], tooltip: {}, xAxis: [ { type: 'category', data: ['01月', '02月', '03月', '04月', '05月', '06月', '07月', '08月', '09月', '10月', '11月', '12月'], axisTick: { alignWithLabel: true }, nameTextStyle: { color: '#82b0ec' }, axisLine: { lineStyle: { color: '#82b0ec' } }, axisLabel: { margin: 20, textStyle: { // color: '#82b0ec' color: colorX, fontSize: 14 } } } ], yAxis: [ { type: 'value', axisLabel: { textStyle: { color: '#09d8f2', fontSize: 14 } // formatter: '{value}%' }, splitLine: { lineStyle: { type: 'dashed', color: 'rgba(135,140,147,0.8)' } }, axisLine: { show: false } } ], series: [ { name: '', type: 'pictorialBar', symbolSize: [20, 10], symbolOffset: [0, -5], symbolPosition: 'end', z: 12, label: { normal: { show: false, position: 'top', formatter: '{c}%' } }, data: dataY }, { name: '', type: 'pictorialBar', symbolSize: [20, 10], symbolOffset: [0, 5], z: 12, data: dataY }, { type: 'bar', itemStyle: { normal: { opacity: 0.7 } }, barWidth: '20', data: dataY // markLine: { // silent: true, // label: { // position: 'middle', // formatter: '{b}', // color: 'red' // }, // data: [ // { // name: '目标值', // yAxis: 80, // lineStyle: { // color: 'red' // }, // itemStyle: { // color: 'red' // }, // label: { // position: 'end', // formatter: '{b}\n {c}%' // } // } // ] // } }, { type: 'effectScatter', silent: true, tooltip: { show: false }, zlevel: 3, symbolSize: 10, showEffectOn: 'render', rippleEffect: { brushType: 'stroke', color: '#3cefff', scale: 5 }, itemStyle: { color: '#3cefff' }, hoverAnimation: true, data: [0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0] } ] } return option } export function zhkb10() { const _legendColor = '#8FD8FF' const _fontSize = 16 const _fontColor = '#8FD8FF' // const data1 = [70, 90, 100, 70, 90, 100] // const data2 = [80, 60, 80, 50, 90, 60] const data1 = [70 + Math.random() * 20, 90 - Math.random() * 20, 100 - Math.random() * 20, 70 + Math.random() * 20, 90 - Math.random() * 20, 80 - Math.random() * 20] const data2 = [80 + Math.random() * 20, 60 + Math.random() * 20, 80 - Math.random() * 20, 50 + Math.random() * 20, 90 - Math.random() * 20, 60 + Math.random() * 20] const option = { backgroundColor: 'transparent', legend: { x: 'right', y: '2%', itemWidth: 10, itemHeight: 10, textStyle: { fontSize: 16, color: 'rgba(255,255,255,.7)' } }, grid: { left: '2%', top: '7%', right: '2%', bottom: '0%', containLabel: true }, yAxis: { // max: Math.ceil(Math.max(...data1) * 1.2), max: 100, type: 'value', position: 'left', axisLine: { show: true, lineStyle: { color: '#4E84AC' } }, axisTick: { show: false }, axisLabel: { formatter: '{value}', color: '#00FFFF', fontSize: 14 }, splitLine: { show: false } }, xAxis: { type: 'category', nameTextStyle: { fontSize: 16, color: '#7dd6ea' }, axisLabel: { show: true, interval: 0, // margin: 20, textStyle: { color: colorX, fontSize: 16 } }, splitLine: { show: false }, axisTick: { show: false }, axisLine: { show: true, lineStyle: { color: '#4E84AC' // width: 3 } }, data: ['钢材改制', '冷墩', '热墩', '热处理', '达克罗', '镀锌'] }, series: [ { name: '人员分析1', type: 'bar', barWidth: 15, barGap: '30%', itemStyle: { normal: { color: new echarts.graphic.LinearGradient(0, 0, 0, 1, [ { offset: 0, color: 'rgba(0,234,255, 1)' }, { offset: 1, color: 'rgba(0,234,255, .1)' } ]) } }, // label: { // show: true, // position: 'top', // textStyle: { // fontSize: 36, // color: '#00EAFF' // }, // formatter: function(params) { // return params.value + '%' // } // }, data: data1, z: 10, zlevel: 0 }, { // 分隔 type: 'pictorialBar', itemStyle: { normal: { color: '#0F375F' } }, symbolRepeat: 'fixed', symbolMargin: 15, symbol: 'rect', symbolClip: true, symbolSize: [15, 2], symbolPosition: 'start', symbolOffset: [-10, 0], data: data1, width: 2, z: 0, zlevel: 1 }, { name: '人员分析2', type: 'bar', barWidth: 15, itemStyle: { normal: { color: new echarts.graphic.LinearGradient(0, 0, 0, 1, [ { offset: 0, color: 'rgba(252,160,0, 1)' }, { offset: 1, color: 'rgba(252,160,0, .1)' } ]) } }, // label: { // show: true, // position: 'top', // textStyle: { // fontSize: 16, // color: '#FFA200' // }, // formatter: function(params) { // return params.value + '%' // } // }, data: data2, z: 10, zlevel: 0 }, { // 分隔 type: 'pictorialBar', itemStyle: { normal: { color: '#0F375F' } }, symbolRepeat: 'fixed', symbolMargin: 15, symbol: 'rect', symbolClip: true, symbolSize: [15, 2], symbolPosition: 'start', symbolOffset: [10, 0], data: data2, width: 2, z: 0, zlevel: 1 } ] } return option } export function zhkb11() { const option = { backgroundColor: 'transparent', // title: { // text: '时段-进出港流量', // left: '5%', // top: '5%', // textStyle: { // color: '#fff', // fontSize: '18px' // } // }, tooltip: { trigger: 'axis', axisPointer: { type: 'shadow' } }, legend: [ { icon: 'react', right: '0%', top: '0%', textStyle: { color: '#fff', fontSize: 14 }, itemGap: 30, itemWidth: 30, itemHeight: 4, data: ['设备利用率', '设备开机率'] } ], grid: { top: '10%', right: '5%', left: '1%', bottom: '0%', containLabel: true }, yAxis: [ { type: 'category', data: ['冷镦车间', '热墩车间', '达克罗车间', '磷化车间', '注塑车间'], axisLine: { lineStyle: { color: '#4E84AC' // width: 2 } }, axisTick: { show: false }, axisLabel: { // margin: 10, color: '#09d8f2', textStyle: { fontSize: 16 } } } ], xAxis: [ { axisLabel: { formatter: '{value}', color: '#6895CA', textStyle: { fontSize: 16, color: colorX } }, axisLine: { show: true, lineStyle: { width: 2, color: '#4E84AC' } }, axisTick: { show: false }, splitLine: { lineStyle: { type: 'dashed', // 使用深浅的间隔色 color: '#184D9A' } } } ], series: [ { name: '设备利用率', type: 'bar', barGap: '70%', data: [Math.ceil(30 + Math.random() * 20), Math.ceil(75 - Math.random() * 20), Math.ceil(77 - Math.random() * 20), Math.ceil(39 + Math.random() * 20), Math.ceil(85 - Math.random() * 20)], barWidth: 12, itemStyle: { normal: { color: { type: 'linear', x: 0, y: 0, x2: 1, y2: 0, colorStops: [ { offset: 0, color: '#00FFFF' // 0% 处的颜色 }, { offset: 1, color: '#00FF00' // 100% 处的颜色 } ], global: false // 缺省为 false }, barBorderRadius: [30, 30, 30, 30], shadowColor: 'rgba(0,160,221,1)', shadowBlur: 4 } }, label: { normal: { show: true, // lineHeight: 20, // width: 80, // height: 20, verticalAlign: 'center', borderRadius: 200, position: 'right', color: '#00FF00', fontSize: 16 } } }, { name: '设备开机率', type: 'bar', data: [Math.ceil(90 - Math.random() * 20), 45 + Math.ceil(Math.random() * 20), Math.ceil(27 + Math.random() * 20), Math.ceil(20 + Math.random() * 60), Math.ceil(85 - Math.random() * 20)], barWidth: 12, itemStyle: { normal: { color: { type: 'linear', x: 0, y: 0, x2: 1, y2: 0, colorStops: [ { offset: 0, color: '#00FFFF' // 0% 处的颜色 }, { offset: 1, color: '#FFFF00' // 100% 处的颜色 } ], global: false // 缺省为 false }, barBorderRadius: [30, 30, 30, 30], shadowColor: 'rgba(0,160,221,1)', shadowBlur: 4 } }, label: { normal: { show: true, // lineHeight: 20, // width: 80, // height: 20, borderRadius: 200, verticalAlign: 'center', // position: ['-0', '-20'], position: 'right', color: '#FFFF00', fontSize: 16 } } } ] } return option } export function zhkb12() { } export function echart01() { return { // title: { // text: '2019年销售水量和主营业务收入对比', // textStyle: { // align: 'center', // color: '#fff', // fontSize: 20 // }, // top: '3%', // left: '10%' // }, backgroundColor: 'transparent', grid: { left: '5%', right: '5%', bottom: '5%', top: '30%', containLabel: true }, tooltip: { trigger: 'axis', axisPointer: { type: 'shadow', label: { show: true } } }, legend: { data: ['成本', '效益'], top: '15%', textStyle: { color: '#ffffff' } }, xAxis: [ { type: 'category', data: ['01月', '02月', '03月', '04月', '05月', '06月', '07月', '08月', '09月', '10月', '11月', '12月'], axisTick: { alignWithLabel: true }, nameTextStyle: { color: '#82b0ec' }, axisLine: { lineStyle: { color: '#82b0ec' } }, axisLabel: { // margin: 5, textStyle: { // color: '#82b0ec' color: colorX, fontSize: 10 } } } ], yAxis: [ // { // type: 'value', // name: '亿元', // nameTextStyle: { // color: '#ebf8ac' // }, // splitLine: { // show: false // }, // axisTick: { // show: true // }, // axisLine: { // show: true, // lineStyle: { // color: '#FFFFFF' // } // }, // axisLabel: { // show: true, // textStyle: { // color: '#ebf8ac' // } // } // // }, { type: 'value', gridIndex: 0, min: 0, max: 100, splitNumber: 8, splitLine: { show: false }, axisLine: { show: false }, axisTick: { show: false }, axisLabel: { show: false }, splitArea: { show: true, areaStyle: { color: ['rgba(250,250,250,0.0)', 'rgba(250,250,250,0.05)'] } } }, { type: 'value', name: '', nameTextStyle: { color: '#ebf8ac' }, position: 'left', splitLine: { show: false }, axisTick: { show: false }, axisLine: { show: false }, axisLabel: { show: true, formatter: '{value} %', // 右侧Y轴文字显示 textStyle: { color: colorX } } } ], series: [ { name: '成本', type: 'line', yAxisIndex: 1, // 使用的 y 轴的 index,在单个图表实例中存在多个 y轴的时候有用 smooth: true, // 平滑曲线显示 showAllSymbol: true, // 显示所有图形。 // symbol: 'circle', // 标记的图形为实心圆 symbolSize: 5, // 标记的大小 itemStyle: { // 折线拐点标志的样式 color: '#058cff' }, lineStyle: { color: '#058cff' }, areaStyle: { color: 'rgba(5,140,255, 0.2)' }, // data: [4.2, 3.8, 4.8, 3.5, 2.9, 2.8, 3, 5, 2.9, 2.8, 3, 5] data: [100, 98, 99, 100, 100, 99, 98, 96, 97, 100, 100, 99] }, { name: '效益', type: 'bar', barWidth: 15, itemStyle: { normal: { color: new echarts.graphic.LinearGradient(0, 0, 0, 1, [{ offset: 0, color: '#00FFE3' }, { offset: 1, color: '#4693EC' } ]) } }, data: [28, 60, 30, 35, 27, 28, 33, 50, 29, 28, 36, 5] // data: [100, 98, 99, 100, 100, 99, 98, 96, 97, 100, 100, 99] } ] } } export function echart02() { var img = '' var trafficWay = [ { name: '压印', value: 20 }, { name: '孔小', value: 10 }, { name: '变形', value: 30 }, { name: '划伤', value: 20 }, { name: '披锋', value: 20 }] var data = [] var color = ['#00ffff', '#00cfff', '#006ced', '#ffe000', '#ffa800', '#ff5b00', '#ff3000'] for (var i = 0; i < trafficWay.length; i++) { data.push({ value: trafficWay[i].value, name: trafficWay[i].name, itemStyle: { normal: { borderWidth: 5, shadowBlur: 20, borderColor: color[i], shadowColor: color[i] } } }, { value: 2, name: '', itemStyle: { normal: { label: { show: false }, labelLine: { show: false }, color: 'rgba(0, 0, 0, 0)', borderColor: 'rgba(0, 0, 0, 0)', borderWidth: 0 } } }) } var seriesOption = [{ name: '', type: 'pie', clockWise: false, radius: [60, 66], hoverAnimation: false, itemStyle: { normal: { label: { show: true, position: 'outside', color: '#ddd', formatter: function(params) { var percent = 0 var total = 0 for (var i = 0; i < trafficWay.length; i++) { total += trafficWay[i].value } percent = ((params.value / total) * 100).toFixed(0) if (params.name !== '') { // return '缺陷名称:' + params.name + '\n' + '\n' + '占百分比:' + percent + '%' return params.name + ' ' + percent + '%' } else { return '' } } }, labelLine: { length: 10, length2: 30, show: true, color: '#00ffff' } } }, data: data }] const option = { backgroundColor: 'transparent', color: color, title: { text: '', top: '48%', textAlign: 'center', left: '49%', textStyle: { color: '#fff', fontSize: 22, fontWeight: '400' } }, graphic: { elements: [{ type: 'image', z: 3, style: { image: img, width: 88, height: 88 }, left: 'center', top: 'center', position: [100, 100] }] }, tooltip: { show: false }, // legend: { // icon: 'circle', // orient: 'horizontal', // // x: 'left', // data: ['压印', '孔小', '变形', '披锋'], // right: 340, // bottom: 150, // align: 'right', // textStyle: { // color: '#fff' // }, // itemGap: 20 // }, toolbox: { show: false }, series: seriesOption } return option } export function echart03() { return { // title: { // text: '2019年销售水量和主营业务收入对比', // textStyle: { // align: 'center', // color: '#fff', // fontSize: 20 // }, // top: '3%', // left: '10%' // }, backgroundColor: 'transparent', grid: { left: '5%', right: '5%', bottom: '5%', top: '20%', containLabel: true }, tooltip: { trigger: 'axis', axisPointer: { type: 'shadow', label: { show: true } } }, xAxis: [ { type: 'category', data: ['压印', '孔小', '变形', '划伤', '披锋'], axisTick: { alignWithLabel: true }, nameTextStyle: { color: '#82b0ec' }, axisLine: { lineStyle: { color: '#82b0ec' } }, axisLabel: { // margin: 5, textStyle: { // color: '#82b0ec' color: colorX, fontSize: 16 } } } ], yAxis: [ { boundaryGap: false, splitNumber: 4, type: 'value', // name: '%', nameTextStyle: { color: colorY, fontSize: 14, lineHeight: 20 }, axisLabel: { textStyle: { fontSize: 14, // color: '#7696c5' color: colorX // color: this.colorY } }, splitLine: { show: true, lineStyle: { color: '#032c58' } }, axisLine: { show: true, lineStyle: { color: '#032c58' } }, axisTick: { show: true } } ], series: [ { name: '数量', type: 'bar', barWidth: 25, itemStyle: { normal: { color: new echarts.graphic.LinearGradient(0, 0, 0, 1, [{ offset: 0, color: '#00FFE3' }, { offset: 1, color: '#4693EC' } ]) } }, data: [228, 260, 230, 235, 227, 228, 233] // data: [100, 98, 99, 100, 100, 99, 98, 96, 97, 100, 100, 99] } ] } } export function echart04() { const indicatorList = [{ name: '人工智能图像识别' }, { name: '开发者工具' }, { name: '自动光学检测' }, { name: '虚拟量测VM' }, { name: '高频海量数据分析' }] const option = { backgroundColor: 'transparent', color: ['#0290ff', '#ffe533', '#ff4d4d', '#06f5bc'], tooltip: { show: false // 弹层数据去掉 }, legend: { data: [ { name: '使用率', icon: 'rect', itemStyle: { color: '#06f5bc', borderWidth: 0 } }, { name: '实际使用率', icon: 'rect', itemStyle: { color: '#0290ff', borderWidth: 0 } } ], top: 30, show: true, y: '1', center: 0, itemWidth: 12, itemHeight: 12, itemGap: 26, z: 3, // orient: 'horizontal', textStyle: { fontSize: 14, color: '#edf8ff' } }, radar: { center: ['50%', '65%'], // 外圆的位置 radius: '55%', name: { textStyle: { color: '#fff', fontSize: 14, fontWeight: 400, fontFamily: 'PingFangSC-Regular,PingFang SC', fontStyle: 'normal' } }, // TODO: indicator: indicatorList, splitArea: { // 坐标轴在 grid 区域中的分隔区域,默认不显示。 show: true, areaStyle: { // 分隔区域的样式设置。 color: ['rgba(255,255,255,0)'] // 分隔区域颜色。分隔区域会按数组中颜色的顺序依次循环设置颜色。默认是一个深浅的间隔色。 } }, axisLine: { // 指向外圈文本的分隔线样式 lineStyle: { color: 'rgba(255,255,255,0)' } }, splitLine: { lineStyle: { type: 'solid', color: '#0ac8ff', // 分隔线颜色 width: 2 // 分隔线线宽 } } }, series: [ { type: 'radar', data: [ { value: [0, 0, 10, 30, 70], name: '使用率', areaStyle: { normal: { color: { type: 'radial', x: 0.5, y: 0.5, r: 0.5, colorStops: [{ offset: 0, color: '#00ffb4' // 0% 处的颜色 }, { offset: 0.15, color: '#00ffb4' // 100% 处的颜色 }, { offset: 0.75, color: '#00ffb4' // 100% 处的颜色 }, { offset: 1, color: '#00ffb4' // 100% 处的颜色 }], global: false // 缺省为 false } } }, symbolSize: [6, 6], lineStyle: { // 边缘颜色 // width: 0 color: 'rgba(13, 248, 172, 0.8)' // shadowBlur:8, // shadowColor:'#ff3838' }, itemStyle: { color: '#fff', borderColor: '#00ffb4', borderWidth: 1, shadowBlur: 8, shadowColor: '#00ffb4' } }, { value: [80, 80, 80, 70, 60], name: '实际使用率', areaStyle: { normal: { color: { type: 'radial', x: 0.5, y: 0.5, r: 0.5, colorStops: [{ offset: 0, color: 'rgba(0,194,255, 0.8)' // 0% 处的颜色 }, { offset: 0.15, color: 'rgba(0,194,255, 0.8)' // 100% 处的颜色 }, { offset: 0.75, color: 'rgba(0,194,255, 0.8)' // 100% 处的颜色 }, { offset: 1, color: 'rgba(0,194,255, 0.8)' // 100% 处的颜色 }], global: false // 缺省为 false } } }, symbolSize: [6, 6], lineStyle: { // 边缘颜色 // width: 0 color: 'rgba(0, 194, 255, 0.8)' // shadowBlur:8, // shadowColor:'#ff3838' }, itemStyle: { color: '#fff', borderColor: '#00c8ff', borderWidth: 1, shadowBlur: 8, shadowColor: '#00c8ff' } } ] } ] } return option } export function echart05() { var img = '' var trafficWay = [ { name: '供应客户', value: 9 }, { name: '现场管理者', value: 30 }, { name: '工厂管理者', value: 25 }, { name: '企业决策者', value: 23 }, { name: '平台开发者', value: 14 }] var data = [] var color = ['#00ffff', '#00cfff', '#006ced', '#ffe000', '#ffa800', '#ff5b00', '#ff3000'] for (var i = 0; i < trafficWay.length; i++) { data.push({ value: trafficWay[i].value, name: trafficWay[i].name, itemStyle: { normal: { borderWidth: 5, shadowBlur: 20, borderColor: color[i], shadowColor: color[i] } } }, { value: 2, name: '', itemStyle: { normal: { label: { show: false }, labelLine: { show: false }, color: 'rgba(0, 0, 0, 0)', borderColor: 'rgba(0, 0, 0, 0)', borderWidth: 0 } } }) } var seriesOption = [{ name: '', type: 'pie', clockWise: false, radius: [60, 66], hoverAnimation: false, itemStyle: { normal: { label: { show: true, position: 'outside', color: '#ddd', formatter: function(params) { var percent = 0 var total = 0 for (var i = 0; i < trafficWay.length; i++) { total += trafficWay[i].value } percent = ((params.value / total) * 100).toFixed(0) if (params.name !== '') { // return '缺陷名称:' + params.name + '\n' + '\n' + '占百分比:' + percent + '%' return params.name + ' ' + percent + '%' } else { return '' } } }, labelLine: { length: 10, length2: 30, show: true, color: '#00ffff' } } }, data: data }] const option = { backgroundColor: 'transparent', color: color, title: { text: '', top: '48%', textAlign: 'center', left: '49%', textStyle: { color: '#fff', fontSize: 22, fontWeight: '400' } }, graphic: { elements: [{ type: 'image', z: 3, style: { image: img, width: 88, height: 88 }, left: 'center', top: 'center', position: [100, 100] }] }, tooltip: { show: false }, // legend: { // icon: 'circle', // orient: 'horizontal', // // x: 'left', // data: ['压印', '孔小', '变形', '披锋'], // right: 340, // bottom: 150, // align: 'right', // textStyle: { // color: '#fff' // }, // itemGap: 20 // }, toolbox: { show: false }, series: seriesOption } return option }