Browse Source

事件处理分析图表

shibei_master
jiangyy 3 years ago
parent
commit
0b0a63a5c4
  1. 4
      src/assets/scss/modules/visual/shijianchulifenxi.scss
  2. 31
      src/views/modules/visual/communityGovern/shijianchuli/chart.js
  3. 108
      src/views/modules/visual/communityGovern/shijianchuli/lineOption.js
  4. 204
      src/views/modules/visual/communityGovern/shijianchuli/shijianchulifenxi.vue

4
src/assets/scss/modules/visual/shijianchulifenxi.scss

@ -21,8 +21,8 @@
} }
.l_bottom { .l_bottom {
height: calc(100vh - 200px - 355px); height: calc(100vh - 200px - 365px);
margin-top: 20px; margin-top: 0;
} }
} }

31
src/views/modules/visual/communityGovern/shijianchuli/chart.js

@ -120,21 +120,22 @@
fontSize: 13 fontSize: 13
}, },
formatter: params => { formatter: params => {
if (
params.seriesName !== 'mouseoutSeries' && // if (
params.seriesName !== 'pie2d' // params.seriesName !== 'mouseoutSeries' &&
) { // params.seriesName !== 'pie2d'
const bfb = ( // ) {
(option.series[params.seriesIndex].pieData.endRatio - // const bfb = (
option.series[params.seriesIndex].pieData.startRatio) * // (option.series[params.seriesIndex].pieData.endRatio -
100 // option.series[params.seriesIndex].pieData.startRatio) *
).toFixed(2) // 100
return ( // ).toFixed(2)
`${params.seriesName}<br/>` + // return (
`<span style="display:inline-block;margin-right:5px;border-radius:10px;width:10px;height:10px;background-color:${params.color};"></span>` + // `${params.seriesName}<br/>` +
`${bfb}%` // `<span style="display:inline-block;margin-right:5px;border-radius:10px;width:10px;height:10px;background-color:${params.color};"></span>` +
) // `${bfb}%`
} // )
// }
} }
}, },
xAxis3D: { xAxis3D: {

108
src/views/modules/visual/communityGovern/shijianchuli/lineOption.js

@ -1,4 +1,11 @@
import * as echarts from 'echarts' import * as echarts from 'echarts'
let circleList = [
'image://',
'image://'
]
let className = ['1号停车场', '2号停车场', '3号停车场', '4号停车场', '5号停车场', '6号停车场', '7号停车场']
let serviceCount = [50, 28, 17, 38, 90, 73, 39]
export function lineOption () { export function lineOption () {
return { return {
@ -11,6 +18,13 @@ export function lineOption () {
} }
} }
}, },
// grid: {
// left: '5%',
// right: '5%',
// bottom: '5%',
// top: '10%',
// containLabel: true
// },
xAxis: { xAxis: {
type: 'category', type: 'category',
// boundaryGap: false, // boundaryGap: false,
@ -25,7 +39,8 @@ export function lineOption () {
lineStyle: { lineStyle: {
color: '#0c4b59' color: '#0c4b59'
} }
} },
// data: className
}, },
yAxis: { yAxis: {
nameTextStyle: { nameTextStyle: {
@ -58,29 +73,82 @@ export function lineOption () {
} }
} }
}, },
// series: [
// {
// name: '项目数',
// type: 'line',
// smooth: true,
// barWidth: 15,
// areaStyle: {},
// itemStyle: {
// color: new echarts.graphic.LinearGradient(
// 0, 1, 0, 0,
// [
// { offset: 0, color: 'rgba(121, 55, 255, 0)' },
// { offset: 1, color: '#6339FF' }
// ]
// )
// }
// },
// // {
// // data: [820, 932, 901, 934, 1290, 1330, 1320],
// // type: 'line',
// // areaStyle: {}
// // }
// ]
series: [ series: [
{ {
name: '项目数', name: '',
type: 'line', type: 'bar',
smooth: true, zlevel: 1,
barWidth: 15, itemStyle: {
areaStyle: {},
itemStyle: { normal: {
color: new echarts.graphic.LinearGradient( barBorderRadius: 0,
0, 1, 0, 0, color: function (params) {
[ // 大于等于50%的是黄色 反之为蓝色
{ offset: 0, color: 'rgba(121, 55, 255, 0)' }, var colorList = [
{ offset: 1, color: '#6339FF' } ['rgba(252, 210, 152, .2)', 'rgba(252, 210, 152, 1)'],
] ['rgba(36, 253, 231, .2)', 'rgba(36, 253, 231, 1)'],
) ];
} var colorItem
colorItem = colorList[1];
// 设置线条渐变色
return new echarts.graphic.LinearGradient(0, 1, 0, 0, [{
offset: 0,
color: colorItem[0]
},
{
offset: 1,
color: colorItem[1]
}
], false);
}
},
},
barWidth: 4,
// data: serviceCount
},
{
name: 'XXX',
type: 'pictorialBar',
symbol: function (params, value) {
// 设置图片
return circleList[1]
}, },
// { symbolPosition: 'end',
// data: [820, 932, 901, 934, 1290, 1330, 1320], symbolSize: [30, 30],
// type: 'line', symbolOffset: [0, -12],
// areaStyle: {} z: 20,
// } // data: serviceCount
}
] ]
} }
} }

204
src/views/modules/visual/communityGovern/shijianchuli/shijianchulifenxi.vue

@ -590,6 +590,7 @@ export default {
xAxis: { data: this.lineXaxis }, xAxis: { data: this.lineXaxis },
series: [ series: [
{ data: this.lineSeriesData }, { data: this.lineSeriesData },
{ data: this.lineSeriesData },
] ]
}, true) }, true)
@ -792,6 +793,7 @@ export default {
let hoveredIndex = '' let hoveredIndex = ''
// //
myChart.on('click', (params) => { myChart.on('click', (params) => {
debugger
// option.series // option.series
const isSelected = !this[optionName].series[params.seriesIndex].pieStatus const isSelected = !this[optionName].series[params.seriesIndex].pieStatus
.selected .selected
@ -834,107 +836,107 @@ export default {
myChart.setOption(this[optionName]) myChart.setOption(this[optionName])
}) })
// mouseover // mouseover
// myChart.on('mouseover', (params) => { myChart.on('mouseover', (params) => {
// // //
// let isSelected let isSelected
// let isHovered let isHovered
// let startRatio let startRatio
// let endRatio let endRatio
// let k let k
// // mouseover // mouseover
// if (hoveredIndex === params.seriesIndex) { if (hoveredIndex === params.seriesIndex) {
// // //
// } else { } else {
// // option // option
// if (hoveredIndex !== '') { if (hoveredIndex !== '') {
// // option.series false // option.series false
// isSelected = this[optionName].series[hoveredIndex].pieStatus.selected isSelected = this[optionName].series[hoveredIndex].pieStatus.selected
// isHovered = false isHovered = false
// startRatio = this[optionName].series[hoveredIndex].pieData.startRatio startRatio = this[optionName].series[hoveredIndex].pieData.startRatio
// endRatio = this[optionName].series[hoveredIndex].pieData.endRatio endRatio = this[optionName].series[hoveredIndex].pieData.endRatio
// k = this[optionName].series[hoveredIndex].pieStatus.k k = this[optionName].series[hoveredIndex].pieStatus.k
// // option // option
// this[optionName].series[ this[optionName].series[
// hoveredIndex hoveredIndex
// ].parametricEquation = getParametricEquation( ].parametricEquation = getParametricEquation(
// startRatio, startRatio,
// endRatio, endRatio,
// isSelected, isSelected,
// isHovered, isHovered,
// k, k,
// this[optionName].series[hoveredIndex].pieData.value this[optionName].series[hoveredIndex].pieData.value
// ) )
// this[optionName].series[hoveredIndex].pieStatus.hovered = isHovered this[optionName].series[hoveredIndex].pieStatus.hovered = isHovered
// // seriesIndex // seriesIndex
// hoveredIndex = '' hoveredIndex = ''
// } }
// // mouseover option // mouseover option
// if ( if (
// params.seriesName !== 'mouseoutSeries' && params.seriesName !== 'mouseoutSeries' &&
// params.seriesName !== 'pie2d' params.seriesName !== 'pie2d'
// ) { ) {
// // option.series true // option.series true
// isSelected = isSelected =
// this[optionName].series[params.seriesIndex].pieStatus.selected this[optionName].series[params.seriesIndex].pieStatus.selected
// isHovered = true isHovered = true
// startRatio = startRatio =
// this[optionName].series[params.seriesIndex].pieData.startRatio this[optionName].series[params.seriesIndex].pieData.startRatio
// endRatio = this[optionName].series[params.seriesIndex].pieData.endRatio endRatio = this[optionName].series[params.seriesIndex].pieData.endRatio
// k = this[optionName].series[params.seriesIndex].pieStatus.k k = this[optionName].series[params.seriesIndex].pieStatus.k
// // option // option
// this[optionName].series[ this[optionName].series[
// params.seriesIndex params.seriesIndex
// ].parametricEquation = getParametricEquation( ].parametricEquation = getParametricEquation(
// startRatio, startRatio,
// endRatio, endRatio,
// isSelected, isSelected,
// isHovered, isHovered,
// k, k,
// this[optionName].series[params.seriesIndex].pieData.value + 60 this[optionName].series[params.seriesIndex].pieData.value + 60
// ) )
// this[optionName].series[ this[optionName].series[
// params.seriesIndex params.seriesIndex
// ].pieStatus.hovered = isHovered ].pieStatus.hovered = isHovered
// // seriesIndex // seriesIndex
// hoveredIndex = params.seriesIndex hoveredIndex = params.seriesIndex
// } }
// // 使 option // 使 option
// myChart.setOption(this[optionName]) myChart.setOption(this[optionName])
// } }
// }) })
// // bug // bug
// myChart.on('globalout', () => { myChart.on('globalout', () => {
// // //
// let isSelected let isSelected
// let isHovered let isHovered
// let startRatio let startRatio
// let endRatio let endRatio
// let k let k
// if (hoveredIndex !== '') { if (hoveredIndex !== '') {
// // option.series true // option.series true
// isSelected = this[optionName].series[hoveredIndex].pieStatus.selected isSelected = this[optionName].series[hoveredIndex].pieStatus.selected
// isHovered = false isHovered = false
// k = this[optionName].series[hoveredIndex].pieStatus.k k = this[optionName].series[hoveredIndex].pieStatus.k
// startRatio = this[optionName].series[hoveredIndex].pieData.startRatio startRatio = this[optionName].series[hoveredIndex].pieData.startRatio
// endRatio = this[optionName].series[hoveredIndex].pieData.endRatio endRatio = this[optionName].series[hoveredIndex].pieData.endRatio
// // option // option
// this[optionName].series[ this[optionName].series[
// hoveredIndex hoveredIndex
// ].parametricEquation = getParametricEquation( ].parametricEquation = getParametricEquation(
// startRatio, startRatio,
// endRatio, endRatio,
// isSelected, isSelected,
// isHovered, isHovered,
// k, k,
// this[optionName].series[hoveredIndex].pieData.value this[optionName].series[hoveredIndex].pieData.value
// ) )
// this[optionName].series[hoveredIndex].pieStatus.hovered = isHovered this[optionName].series[hoveredIndex].pieStatus.hovered = isHovered
// // seriesIndex // seriesIndex
// hoveredIndex = '' hoveredIndex = ''
// } }
// // 使 option // 使 option
// myChart.setOption(this[optionName]) myChart.setOption(this[optionName])
// }) })
}, },

Loading…
Cancel
Save