test #47
191
src/views/equipment/timing-diagram/components/gantt.js
Normal file
191
src/views/equipment/timing-diagram/components/gantt.js
Normal file
@ -0,0 +1,191 @@
|
|||||||
|
|
||||||
|
// filename: gantt.vue
|
||||||
|
// author: liubin
|
||||||
|
// date: 2023 -09 - 25 14: 28: 12
|
||||||
|
// description: 甘特图
|
||||||
|
|
||||||
|
|
||||||
|
import * as echarts from 'echarts';
|
||||||
|
|
||||||
|
/**
|
||||||
|
*
|
||||||
|
* @param {*} params
|
||||||
|
* @param {*} api
|
||||||
|
*
|
||||||
|
* https://echarts.apache.org/zh/option.html#series-custom.renderItem.arguments.params
|
||||||
|
*/
|
||||||
|
function renderItem(params, api) { }
|
||||||
|
|
||||||
|
export default class Gantt {
|
||||||
|
constructor(el) {
|
||||||
|
this.chart = echarts.init(el);
|
||||||
|
let options = {
|
||||||
|
series: [
|
||||||
|
{
|
||||||
|
type: 'custom',
|
||||||
|
coordinateSystem: 'cartesian2d',
|
||||||
|
renderItem: renderItem,
|
||||||
|
}
|
||||||
|
]
|
||||||
|
}
|
||||||
|
this.chart.setOption(options);
|
||||||
|
}
|
||||||
|
|
||||||
|
update(options) {
|
||||||
|
this.chart.setOption(options);
|
||||||
|
}
|
||||||
|
|
||||||
|
resize() {
|
||||||
|
// todo
|
||||||
|
}
|
||||||
|
|
||||||
|
destroy() {
|
||||||
|
this.chart.dispose();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
var data = [];
|
||||||
|
var categories = ['设备1', '设备2', '设备3'];
|
||||||
|
var types = [
|
||||||
|
{ name: '运行', color: '#7b9ce1' },
|
||||||
|
{ name: '故障', color: '#bd6d6c' },
|
||||||
|
{ name: '停机', color: '#75d874' },
|
||||||
|
];
|
||||||
|
// return new Date(new Date(timestamp).toLocaleDateString()).getTime()
|
||||||
|
// })(1691568181000))
|
||||||
|
function getStartTime(timestamp) {
|
||||||
|
return new Date(new Date(timestamp).toLocaleDateString()).getTime()
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
data.push({
|
||||||
|
name: 'running',
|
||||||
|
value: [0, 1691568181000, 1691568181000 + 60 * 60 * 1000, 60],
|
||||||
|
itemStyle: {
|
||||||
|
normal: {
|
||||||
|
color: types[0].color
|
||||||
|
}
|
||||||
|
}
|
||||||
|
})
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
function renderItem(params, api) {
|
||||||
|
var categoryIndex = api.value(0);
|
||||||
|
var start = api.coord([api.value(1), categoryIndex]);
|
||||||
|
var end = api.coord([api.value(2), categoryIndex]);
|
||||||
|
var height = api.size([0, 1])[1] * 0.8;
|
||||||
|
var rectShape = echarts.graphic.clipRectByRect(
|
||||||
|
{
|
||||||
|
x: start[0],
|
||||||
|
y: start[1] - height / 2,
|
||||||
|
width: end[0] - start[0],
|
||||||
|
height: height
|
||||||
|
},
|
||||||
|
{
|
||||||
|
x: params.coordSys.x,
|
||||||
|
y: params.coordSys.y,
|
||||||
|
width: params.coordSys.width,
|
||||||
|
height: params.coordSys.height
|
||||||
|
}
|
||||||
|
);
|
||||||
|
return (
|
||||||
|
rectShape && {
|
||||||
|
type: 'rect',
|
||||||
|
transition: ['shape'],
|
||||||
|
shape: rectShape,
|
||||||
|
style: api.style()
|
||||||
|
}
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
|
option = {
|
||||||
|
tooltip: {
|
||||||
|
// show: false,
|
||||||
|
formatter: function (params) {
|
||||||
|
return params.marker + params.name + ': ' + new Date(params.value[1]).toLocaleTimeString() + ' - ' + new Date(params.value[2]).toLocaleTimeString();
|
||||||
|
}
|
||||||
|
},
|
||||||
|
// title: {
|
||||||
|
// text: 'Profile',
|
||||||
|
// left: 'center'
|
||||||
|
// },
|
||||||
|
// dataZoom: [
|
||||||
|
// {
|
||||||
|
// type: 'slider',
|
||||||
|
// filterMode: 'weakFilter',
|
||||||
|
// showDataShadow: false,
|
||||||
|
// top: 400,
|
||||||
|
// labelFormatter: ''
|
||||||
|
// },
|
||||||
|
// {
|
||||||
|
// type: 'inside',
|
||||||
|
// filterMode: 'weakFilter'
|
||||||
|
// }
|
||||||
|
// ],
|
||||||
|
grid: {
|
||||||
|
height: 300
|
||||||
|
},
|
||||||
|
xAxis: {
|
||||||
|
type: 'time',
|
||||||
|
min: getStartTime(1691568181000),
|
||||||
|
max: getStartTime(1691568181000 + 3600 * 24 * 1000),
|
||||||
|
splitNumber: 10,
|
||||||
|
// interval: 60*3600*1000,
|
||||||
|
// scale: true,
|
||||||
|
axisLabel: {
|
||||||
|
// rotate: -15,
|
||||||
|
formatter: function (val) {
|
||||||
|
return new Date(val).toLocaleTimeString()
|
||||||
|
}
|
||||||
|
},
|
||||||
|
axisTick: {
|
||||||
|
show: true
|
||||||
|
},
|
||||||
|
splitLine: {
|
||||||
|
show: false,
|
||||||
|
}
|
||||||
|
},
|
||||||
|
yAxis: [{
|
||||||
|
axisLine: {
|
||||||
|
// show: false,
|
||||||
|
lineStyle: {
|
||||||
|
color: ''
|
||||||
|
}
|
||||||
|
},
|
||||||
|
axisLabel: {
|
||||||
|
fontSize: 14,
|
||||||
|
},
|
||||||
|
axisTick: {
|
||||||
|
show: false,
|
||||||
|
},
|
||||||
|
splitLine: {
|
||||||
|
show: true
|
||||||
|
},
|
||||||
|
data: categories
|
||||||
|
}, {
|
||||||
|
axisLine: {
|
||||||
|
// show: false,
|
||||||
|
lineStyle: {
|
||||||
|
color: ''
|
||||||
|
}
|
||||||
|
},
|
||||||
|
data: []
|
||||||
|
}],
|
||||||
|
series: [
|
||||||
|
{
|
||||||
|
type: 'custom',
|
||||||
|
renderItem: renderItem,
|
||||||
|
itemStyle: {
|
||||||
|
opacity: 0.8
|
||||||
|
},
|
||||||
|
encode: {
|
||||||
|
x: [1, 2],
|
||||||
|
y: 0
|
||||||
|
},
|
||||||
|
data: data
|
||||||
|
}
|
||||||
|
]
|
||||||
|
};
|
Loading…
Reference in New Issue
Block a user