折线图

可滚动的折线图,包含是否仅显示折线,显示阴影,显示文字,显示个数,显示自定义圆点图片等,相关变量详见组件代码:

<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>

 

posted @ 2026-01-29 11:20  星宝攸宁  阅读(1)  评论(0)    收藏  举报