图三

export default {
props: {
data: {
type: Array,
default() {
return [{
name:'九监区',
value1:20,
value2:2
}, {
name:'十一监区',
value1:20,
value2:2
}, {
name:'十二监区',
value1:20,
value2:2
}, {
name:'十三监区',
value1:20,
value2:2
}, {
name:'十四监区',
value1:20,
value2:2
}, {
name:'十五监区',
value1:20,
value2:2
}];
}
},
legend:{
type: Array,
default() {
return [{
name:'本月办理减刑数',
key:'value1'
}, {
name:'本月办理假释数',
key:'value2'
}];
}
}
},
data() {
return {
myEchart: null,
dataList: [],
options: {}
};
},
mounted() {
this.init();
},
destroyed() {
this.destroyedChart();
},
methods: {
setDefaultOptions() {
this.options = {
barWidth: 15,
yAxis: {
type: 'value',
splitLine: {show: false},
axisTick: {show: false},
axisLabel: {show: false},
axisLine:{show: false}
},
xAxis: {
type: 'category',
axisTick: {show: false},
axisLine: {show: false},
offset:20,
axisLabel: {
interval:0,
textStyle: {
interval:0,
color: '#b9eff8',
fontWeight: 'normal',
fontSize: 18
},
align:'center',
formatter:function (params) {
const text = params.slice(0, 4);
return text;
}
},
data: []
},
grid: {
top: '25%',
left: '5%',
bottom: '8%',
right: '5%',
containLabel: true
},
series: [{
type: 'bar',
name: 'bar1',
barWidth : 24,
itemStyle: {
normal: {
label: {
show: true,
position:'top',
formatter: function (value) {
if (parseFloat(value.data)) {
return value.data;
}
return '';
},
textStyle: {
color: '#d4fbfd',
fontSize: 18
}
},
color: new echarts.graphic.LinearGradient(0, 0, 0, 1, [{
offset: 0,
color: '#00f2fe'
}, {
offset: 1,
color: '#4facfe'
}]),
barBorderRadius:[12, 0, 0, 0]
}
},
data: []
}, {
z: 15,
type: 'pictorialBar',
animation: true,
hoverAnimation: false,
data: [],
symbolSize: [24, 44],
symbolOffset: [0, 20],
symbolRepeat: true,
symbolClip:true,
symbol:'image://',
barWidth: 24,
itemStyle: {
normal: {
label: {show: false},
barBorderRadius:[12, 0, 0, 0]
}
}
}, {
type: 'bar',
name: 'bar2',
barWidth : 24,
z: 10,
barGap: '30%',
itemStyle: {
normal: {
label: {
show: true,
position:'top',
formatter: function (value) {
if (parseFloat(value.data)) {
return value.data;
}
return '';
},
textStyle: {
color: '#d4fbfd',
fontSize: 18
}
},
color: new echarts.graphic.LinearGradient(0, 0, 0, 1, [{
offset: 0,
color: '#fbdd97'
}, {
offset: 1,
color: '#d3fbfb'
}]),
barBorderRadius:[0, 12, 0, 0]
}
},
data: []
}, {
z: 30,
type: 'pictorialBar',
animation: true,
barGap: '30%',
hoverAnimation: false,
symbolSize: [24, 48],
symbolOffset: [0, 20],
data: [],
symbolRepeat: true,
symbolClip:true,
symbol: 'image://',
barWidth: 24,
itemStyle: {
normal: {
label: {show: false},
barBorderRadius:[12, 0, 0, 0]
}
}
}]
};
},
setDataList(dataList) {
this.dataList = dataList;
},
init() {
this.update(this.data);
},
refresh() {
if (this.myEchart) {
this.update(this.dataList);
}
},
update(data) {
if (!Array.isArray(data)) {
return false;
}
this.setDataList(data);
if (!this.myEchart) {
this.myEchart = window.echarts.init(this.$refs.jsEchart);
this.bindResizeEvent();
}
this.setDefaultOptions();
const _data = data;
this.updateData(_data);
this.myEchart.clear();
this.myEchart.setOption(this.options);
},
updateData(data) {
const legendKey = {};
const xAxis = [];
const _num = 2;
this.legend.forEach(item => {
legendKey[item.key] = [];
});
data.forEach(item => {
xAxis.push(item.name);
for (const i in legendKey) {
legendKey[i].push(item[i]);
}
});
this.options.series.forEach((item, index) => {
if (index < _num) {
item.name = this.legend[0].name;
item.data = legendKey[this.legend[0].key];
} else {
item.name = this.legend[1].name;
item.data = legendKey[this.legend[1].key];
}
});
this.options.xAxis.data = xAxis;
},
resizeHandler() {
if (this.myEchart) {
this.myEchart.resize();
}
},
bindResizeEvent() {
window.eventHandler.on(window, 'resize', this.resizeHandler);
},
unbindResizeEvent() {
window.eventHandler.off(window, 'resize', this.resizeHandler);
},
destroyedChart() {
if (this.myEchart) {
this.myEchart.dispose();
this.myEchart = null;
this.unbindResizeEvent();
}
}
}
};
图四

export default {
props: {
data: {
type: Array,
default() {
return [{
name:'一监区',
value:80
}, {
name:'二监区',
value:20
}, {
name:'三监区',
value:30
}, {
name:'四监区',
value:50
}, {
name:'五监区',
value:60
}, {
name:'六监区',
value:20
}];
}
}
},
data() {
return {
myEchart: null,
dataList: [],
options: {},
itemStyle: {
normal: {
color: {
x: 0,
y: 0,
x2: 1,
y2: 0,
type: 'linear',
global: false,
colorStops: [
{
offset: 0,
color: '#025ec4'
},
{
offset: 1,
color: '#00ecfd'
}
]
},
barBorderColor: 'transparent',
barBorderWidth: 10,
barBorderRadius: 2
}
}
};
},
mounted() {
this.init();
},
destroyed() {
this.destroyedChart();
},
methods: {
setDefaultOptions() {
this.options = {
grid: {
top: '8%',
bottom: -15,
right: 30,
left: 30,
containLabel: true
},
xAxis: {show: false},
yAxis: [{
show: true,
data: [],
axisLine: {show: false},
splitLine: {show: false},
axisTick: {show: false},
axisLabel: {
show:true,
color: '#b9eff8',
lineHeight: 40,
fontSize: 20,
fontWeight:'normal',
formatter: function (value) {
return value;
}
}
}, {
show: true,
data: [],
axisLine: {show: false},
splitLine: {show: false},
axisTick: {show: false},
axisLabel: {
margin: 20,
color: '#fff',
align: 'left',
lineHeight: 40,
fontSize: 20,
fontWeight:'normal',
formatter: function (value) {
return value;
}
}
}],
series: [{
name: 'XXX',
type: 'pictorialBar',
symbolSize: [34, 33],
symbolOffset: [10, -1],
z: 12,
data: []
}, {
name: 'bar',
type: 'bar',
yAxisIndex: 0,
data: [],
barWidth: 20
},
{
name: 'border',
type: 'bar',
barGap: '-100%',
barWidth: 20,
itemStyle: {
normal: {
color: 'rgba(2,250,254,0.08)',
barBorderColor: 'rgba(0,255,246,0.35)',
barBorderWidth: 1,
barBorderRadius: 2,
label: {
show: false,
position: 'top'
}
}
},
data: [],
z: 0
}]
};
},
setDataList(dataList) {
this.dataList = dataList;
},
init() {
this.update(this.data);
},
refresh() {
if (this.myEchart) {
this.update(this.dataList);
}
},
update(data) {
if (!Array.isArray(data)) {
return false;
}
this.setDataList(data);
if (!this.myEchart) {
this.myEchart = window.echarts.init(this.$refs.jsEchart);
this.bindResizeEvent();
}
this.setDefaultOptions();
const _data = data;
this.updateData(_data);
this.myEchart.clear();
this.myEchart.setOption(this.options);
},
updateData(data) {
const _data = data.sort(this.compare('value')).reverse();
const nameArr = [];
const number = [];
const guangArr = [];
_data.forEach((item, index) => {
nameArr.push(item.name);
number.push(item.value);
const guangItem = {
value:item.value,
symbolPosition:'end'
};
item.itemStyle = JSON.parse(JSON.stringify(this.itemStyle));
switch (index) {
case 0:
item.itemStyle.normal.color.colorStops = [{
offset: 0,
color: '#db500d'
},
{
offset: 1,
color: '#dba212'
}];
guangItem.symbol = 'image://';
break;
case 1:
item.itemStyle.normal.color.colorStops = [{
offset: 0,
color: '#a39f17'
},
{
offset: 1,
color: '#d7c913'
}];
guangItem.symbol = 'image://';
break;
case 2:
item.itemStyle.normal.color.colorStops = [{
offset: 0,
color: '#008e9e'
},
{
offset: 1,
color: '#07fda5'
}];
guangItem.symbol = 'image://';
break;
default:
guangItem.symbol = 'image://';
}
guangArr.push(guangItem);
});
const maxNum = Math.max.apply(null, number);
this.options.yAxis.forEach((item, index) => {
item.data = nameArr;
if (index) {
item.axisLabel.formatter = function (value, index) {
return `${number[index]}分`;
};
}
});
this.options.series[0].data = guangArr;
this.options.series[1].data = _data;
this.options.series[2].data = new Array(nameArr.length).fill(maxNum);
},
compare(property) {
return function (a, b) {
const value1 = a[property];
const value2 = b[property];
return value2 - value1;
};
},
resizeHandler() {
if (this.myEchart) {
this.myEchart.resize();
}
},
bindResizeEvent() {
window.eventHandler.on(window, 'resize', this.resizeHandler);
},
unbindResizeEvent() {
window.eventHandler.off(window, 'resize', this.resizeHandler);
},
destroyedChart() {
if (this.myEchart) {
this.myEchart.dispose();
this.myEchart = null;
this.unbindResizeEvent();
}
}
}
};