折线图
可滚动的折线图,包含是否仅显示折线,显示阴影,显示文字,显示个数,显示自定义圆点图片等,相关变量详见组件代码:
<template>
<!-- 柱状图 横向滚动柱状图 -->
<div :id="histogramId" v-bind:style="{height:height,width:width}"></div>
</template>
<script type="text/ecmascript-6">
export default {
props:{
histogramId:{
type:String,
default:''
},
//组件的高度
height: {
type: String,
default: '230px'
},
//组件的宽度
width: {
type: String,
default: '100%'
},
barWidth:{
type:Number,
default:15
},
//grid的设置修改
grid:{
type:Object,
default:()=>{
return{
bottom:40,
top:30,
left:40,
right:20
}
}
},
//xAxis相关变量
xAxis:{
type:Object,
default:()=>{
return{
max:5,
axisLineShow:true,
axisLineColor:'rgba(188, 198, 207, 0.4)',
axisLabelColor:'#B8C5D2',
axisLabelSize:12,
axisLabelRotate:0,
splitLineShow:false,
splitLineColor:'rgba(255,255,255,0.1)',
splitLineType:'',
axisLabelShow:true,
}
}
},
yAxis:{
type:Object,
default:()=>{
return{
show:true,
axisLineShow:false,
axisLineColor:'rgba(188, 198, 207, 0.4)',
axisLabelColor:'rgba(255,255,255,0.6)',
axisLabelSize:12,
splitLineShow:true,
splitLineColor:'rgba(255,255,255,0.1)',
splitLineType:'dashed',
axisLabelShow:true,
axisLabelMargin:5
}
}
},
colorsJian:{ //颜色渐变有背景色
type:Array,
default:()=>[
["rgba(72, 208, 245, 1)", "rgba(72, 208, 245, 0.1)"], //颜色都为0的话即为仅保留折线
["rgba(255, 244, 69, 1)", "rgba(255, 244, 69, 0.1)"],
["rgba(23, 218, 69, 1)", "rgba(23, 218, 69, 0.1)"],
["rgba(249, 51, 88, 1)", "rgba(249, 51, 88, 0.1)"],
["rgba(255, 152, 41, 1)", "rgba(255, 152, 41, 0.1) "],
["rgba(248, 66, 255, 1)", "rgba(248, 66, 255, 0.1)"],
]
},
colors:{ //没有背景色只有一根线
type:Array,
default:()=>['#48D0F5','#FFF445','#17DA45','#F93358','#FF9829','#F842FF']
},
showNum:{ //开始展示几条数据
type:Number,
default:4
},
legend:{ //legend的相关字段
type:Object,
default:()=>{
return{
show:true,
type:'roundRect', //circle圆形,rect矩形,roundRect圆角矩形,triangle三角形,diamond菱形,pin,arrow箭头,square正方形,pin雨滴
itemWidth:15,
itemHeight:10,
itemGap:15,
fontSize:12,
color:'#ffffff'
}
}
},
isJian:{ //颜色是否时渐变模式
type:Boolean,
default:false
},
series:{ //相关series中的设置
type:Object,
default:()=>{
return{
smooth:false, //是否圆滑
symbolSize:3, //大小
lineWidth:1,
borderWidth:3,
symbol:'circle', //圆点的大小
lableShow:true, //文字是否显示
fontSize:12, //文字大小
labelColor:'#ffffff', //如果是空的话就展示线的颜色,否则就展示自定义的颜色
}
}
},
dataObj:{ //所需要的数值组成的对象
type:Object,
default:()=>{
return{
name:['抓拍','进出','访客'],
xData:['10-11','10-12','10-13','10-14','10-15','10-16','10-17','10-18','10-19','10-20','10-21','10-22'],
data1:[1,2,3,1,1,1,1,1,2,3,4,5],
data2:[3,4,5,6,7,1,2,3,4,5,6,1],
data3:[6,7,8,9,0,1,2,3,4,5,6,7]
}
}
},
isImg:{ //是否圆点图片自定义
type:Boolean,
default:false
},
imgCustom:{ //圆点图片自定义
type:Array,
default:()=>[
'image://',
'image://',
'image://',
'image://',
]
},
},
data(){
return{
surveyInit:'',
BgDataData:[],
itemA:0,
}
},
methods:{
initMoreColorZhu(){
let that=this;
var name=this.dataObj.name;
var xData=this.dataObj.xData;
var squares = new Array();
for(var v = 0; v < name.length; v++){
//依次创建数组
squares[v] = new Array();
squares[v] = that.dataObj['data'+(v+1)]
}
//循环创建相对应的折线的数目,是一条还是两条还是更多
function createArr(squares){
let img = '';
var serArr = [],labelColor;
for(var i = 0;i<squares.length;i++){
//如果是自定义图片那就展示自定义图片否则就展示圆点
if(that.isImg){
img = that.imgCustom[i]
}else{
img = that.series.symbol
}
//如果是空的话就展示线的颜色,否则就展示自定义的颜色
if(that.series.labelColor == ''){
labelColor = that.colors[i]
}else{
labelColor = that.series.labelColor
}
let seriesItem = {
name:name[i],
type: 'line',
smooth: that.series.smooth,
symbol:img,
// symbol:that.imgCustom[i],
// symbol: that.series.symbol,
symbolSize:that.series.symbolSize,
lineStyle: {
normal: {
width: that.series.lineWidth,
color:that.colors[i],
}
},
areaStyle: {
normal: {
color: new that.$echarts.graphic.LinearGradient(0, 0, 0, 1, [{
offset: 0,
color: that.colorsJian[i][0]
}, {
offset: 0.3,
color: that.colorsJian[i][1]
}], false),
}
},
label: {
show: that.series.lableShow,
position: 'top',
textStyle: {
color: labelColor,
fontSize:that.series.fontSize,
}
},
itemStyle: {
normal: {
color: that.colors[i],//图例颜色
borderColor:that.colors[i],
borderWidth:that.series.borderWidth
}
},
data: squares[i]
}
serArr.push(seriesItem)
}
return serArr
}
that.surveyInit = that.$echarts.init(document.getElementById(this.histogramId));
// 指定图表的配置项和数据
var option = {
tooltip: {
trigger: 'axis',
axisPointer: {
lineStyle: {
color: 'rgba(0,0,0,0)'
}
},
},
grid:this.grid,
legend: {
show:that.legend.show,
icon: that.legend.type,
itemWidth: that.legend.itemWidth,
itemHeight: that.legend.itemHeight,
itemGap: that.legend.itemGap,
data: name,
// right: 'center',
textStyle: {
fontSize: that.legend.fontSize,
color: that.legend.color
}
},
// 滑动条
dataZoom:[{
type:'slider',
show:false,
realtime:true,
startValue:0,
endValue:that.showNum,
}],
xAxis: [{
type: 'category',
boundaryGap: false,
axisLine: {
show:this.xAxis.axisLineShow,
lineStyle: {
color: this.xAxis.axisLineColor,
},
},
axisTick: {
show:false,
interval: (index) => {
if (index === -1 || index === this.xAxis.max) {
return false;
} else {
return true;
}
}
},
axisLabel: {
color: this.xAxis.axisLabelColor,
fontSize: this.xAxis.axisLabelSize,
rotate:this.xAxis.axisLabelRotate,
show:this.xAxis.axisLabelShow
},
splitLine: {
show: this.xAxis.splitLineShow,
lineStyle: {
color: this.xAxis.splitLineColor,
type:this.xAxis.splitLineType
},
},
data: xData,
}],
yAxis: [{
type: 'value',
boundaryGap: true,
axisTick:{
show:that.yAxis.axisTickShow,
},
axisLine: {
show:that.yAxis.axisLineShow,
lineStyle: {
color: that.yAxis.axisLineColor
}
},
splitLine:{
show:that.yAxis.splitLineShow,
lineStyle: {
color: that.yAxis.splitLineColor,
type:that.yAxis.splitLineType
}
},
axisLabel: {
color: this.yAxis.axisLabelColor,
fontSize: this.yAxis.axisLabelSize,
show:this.yAxis.axisLabelShow,
margin: this.yAxis.axisLabelMargin, //距离相对应的宽度
},
}],
series:createArr(squares)
};
that.surveyInit.setOption(option);
//滚动
var key = 0;
setInterval(function() {
var aa = xData.shift();
xData.push(aa);
//数值重组
var squaresA = new Array();
var bb;
for(var v = 0; v < name.length; v++){
//依次创建数组
squaresA[v] = new Array();
squaresA[v] = that.dataObj['data'+(v+1)]
bb = squaresA[v].shift()
squaresA[v].push(bb);
}
//重新加载
if(key>xData.length){key=0}
key++;
that.surveyInit.setOption({
xAxis: {
data: xData
},
series:createArr(squaresA)
});
}, 3000);
},
},
watch:{
width:function(){
this.surveyInit.resize()
},
},
mounted(){
// 新建一个promise对象
let newPromise = new Promise((resolve) => {
resolve()
})
//然后异步执行echarts的初始化函数
newPromise.then(() => {
// 此dom为echarts图标展示dom
this.initMoreColorZhu()
})
},
}
</script>

浙公网安备 33010602011771号