首页 > 其他分享 >可滚动的塔状图,包含单个或者多个,颜色可变或者一致,或者渐变,详见代码:

可滚动的塔状图,包含单个或者多个,颜色可变或者一致,或者渐变,详见代码:

时间:2024-01-29 10:44:53浏览次数:28  
标签:xAxis 或者 show default 渐变 yAxis rgba type 状图




相关组件代码:

<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:30
        },
        //grid的设置修改
        grid:{
            type:Object,
            default:()=>{
                return{
                    bottom:40,
                    top:30,
                    left:20,
                    right:10
                }
            }
        },
        //xAxis相关变量
        xAxis:{
            type:Object,
            default:()=>{
                return{
                    max:4,
                    axisLineShow:true,
                    axisLineColor:'rgba(188, 198, 207, 0.4)',
                    axisLabelColor:'#B8C5D2',
                    axisLabelSize:12,
                    axisLabelRotate:20,
                    splitLineShow:false,
                    splitLineColor:'rgba(255,255,255,0.1)',
                    splitLineType:'',
                    axisLabelColorLabel:'#B8C5D2',   //居于背景最上方的时候的文字颜色
                    axisLabelSizeLabel:12,
                    axisLabelRotateLabel:0,
                    axisLabelShowLabel:false,
                }
            }
        },
        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,
                }
            }
        },
        colors:{  //非渐变下的数组颜色
            type:Array,
            default:()=>['#48D0F5','#FFF445','#17DA45','#F93358','#FF9829','#F842FF','#48D0F5','#FFF445','#17DA45','#F93358','#FF9829','#F842FF','#48D0F5','#FFF445','#17DA45','#F93358','#FF9829','#F842FF']
        },
        colorsJian:{          //渐变下的数组颜色设置
            type:Array,
            default:()=>[
                ["rgba(44, 124, 245, 1)", "rgba(0, 72, 181, 1)"],
                ["rgba(252, 86, 89, 1)", "rgba(182, 51, 54, 1)"],
                ["rgba(242, 155, 118, 1)", "rgba(225, 128, 86, 1)"],
                ["rgba(240, 197, 92, 1)", "rgba(198, 161, 71, 1)"],
                ["rgba(52, 179, 110, 1)", "rgba(34, 142, 83, 1) "],
                ["rgba(61, 136, 227, 1)", "rgba(71, 181, 228, 1)"],
                ["rgba(119, 122, 253, 1)", "rgba(78, 81, 239, 1)"],
                ["rgba(44, 124, 245, 1)", "rgba(0, 72, 181, 1)"],
                ["rgba(252, 86, 89, 1)", "rgba(182, 51, 54, 1)"],
                ["rgba(242, 155, 118, 1)", "rgba(225, 128, 86, 1)"],
            ]
        },
        isSingleColor:{   //是否单条数据多个颜色
            type:Boolean,
            default:true
        },
        showNum:{   //开始展示几条数据
            type:Number,
            default:4
        },
        barBorderRadius:{   //柱子的radius
            type:Array,
            default:()=>[0,0,0,0]
        },
        isJian:{   //颜色是否时渐变模式
            type:Boolean,
            default:true
        },
        jianLength:{   //颜色渐变从哪里开始,默认是0.2,一般设置为1
            type:Number,
            default:1
        },
        series:{    //跟在柱子后的value,且不是在最上方的时候
            type:Object,
            default:()=>{
                return{
                    show:true,     //主子上方跟的值
                    color:'#B8C5D2',
                    fontSize:12,
                    distance:5,  //文字距离
                    // symbol:'path://M0,10 L10,10 C5.5,10 5.5,5 5,0 C4.5,5 4.5,10 0,10 z',  //带曲线的三角,triangle是三角形
                    symbol:'triangle'
                }
            }
        },
        bgData:{   //柱状图背景
            type:Object,
            default:()=>{
                return{
                    show:false,
                    bgColor:'rgba(0,0,0,0)',
                }
            }
        },
        ciecleImg:{   //上方小圆点是否展示
            type:Object,
            default:()=>{
                return{
                    // symbolSize: [50, 50],
                    symbolSize:[0,0],
                    symbolOffset: [0, -25],
                    imgUrl:'image://'
                }
            }
        },
        dataObj:{   //相关数据的整理
            type:Object,
            default:()=>{
                return{
                    // name:['活力邻里','活力队伍','活力组织','活力服务','活力发展'],
                    // name:['活力邻里'],
                    name:['活力邻里','活力队伍'],
                    xData:['天水社区','悦来社区','金融港社区','很多社区','金水社区','哈哈社区','丽日社区'],
                    data1:[65,55,60,25,45,50,30],
                    data2:[30,50,20,55,10,40,35],
                    data3:[45,25,35,12,5,15,5],
                    data4:[66,44,33,25,77,22,11],
                    data5:[33,11,22,45,15,10,33]
                }
            }
        },
        legend:{   //legend的相关字段
            type:Object,
            default:()=>{
                return{
                    show:false,
                    type:'roundRect',   //circle圆形,rect矩形,roundRect圆角矩形,triangle三角形,diamond菱形,pin,arrow箭头,square正方形,pin雨滴
                    itemWidth:15,
                    itemHeight:10,
                    itemGap:15,
                    fontSize:12,
                    color:'#ffffff'
                }
            }
        },
    },
    data(){
        return{
            surveyInit:'',
            BgDataData:[],
            colorsLegend:[]
        }
    },
    methods:{

        initMoreColorZhu(){
            let that=this;
            var typeData = this.dataObj.name
            var xData = that.dataObj.xData,yData = [], maxData = [],circleData = [],colorsLegend = [];

            var squares = new Array();
            for(var v = 0; v < typeData.length; v++){
                //依次创建数组
                squares[v] = new Array();
                squares[v] = that.dataObj['data'+(v+1)]
            }
            //左侧name的展示
            var max=Math.max.apply(null, yData);  //最大值
            yData.forEach(item=>{
                maxData.push(max)    //最大值组成的数组
            })

            //创建series
            function creatArr(squares){
                var seriesArr = []
                let serOne = {
                    name: '数量',
                    type: 'bar',
                    barWidth:that.barWidth,
                    barCategoryGap: '10%',
                    tooltip:{show:false},
                    barGap: '-100%',
                    z:1,
                    label: {
                        show: false,
                    },
                    itemStyle: {
                        barBorderRadius: that.barBorderRadius,
                        color:  that.bgData.bgColor,
                    },
                    data: maxData
                }
                let circle = {
                    name: 'XXX',
                    type: 'pictorialBar',
                    tooltip: {
                        show: false
                    },
                    symbol: that.ciecleImg.imgUrl,
                    symbolSize: that.ciecleImg.symbolSize,
                    symbolOffset: that.ciecleImg.symbolOffset,
                    z: 12,
                    barGap: '-100%',
                    data: circleData
                }
                seriesArr.push(circle)
                for(var i = 0;i<squares.length;i++){
                    let item = {
                        name: typeData[i],
                        type: 'pictorialBar',
                        barWidth:that.barWidth,
                        // barCategoryGap: '10%',
                        // stack: '总量',
                        barCategoryGap: "60%",
                        barGap:i!=0?'-60%':'0',
                        symbol:that.series.symbol,
                        z:2,
                        show:false,
                        label: {
                            show: that.series.show,
                            position: 'top',
                            color: that.series.color,
                            fontSize: that.series.fontSize,
                            distance:that.series.distance
                        },
                        itemStyle: {
                            barBorderRadius: that.barBorderRadius,
                            color: function(params){
                                    if(!that.isJian){
                                        //非渐变情况下的颜色赋值
                                        if(that.isSingleColor&&typeData.length==1){
                                            that.colorsLegend.push(that.colors[params.dataIndex])
                                            return that.colors[params.dataIndex]
                                        }else{
                                            that.colorsLegend.push(that.colors[params.componentIndex])
                                            return that.colors[params.componentIndex]
                                        }

                                    }else{
                                        // console.log(that.isSingleColor,params)
                                        //渐变颜色下的赋值
                                        if(that.isSingleColor&&typeData.length==1){
                                            that.colorsLegend.push(that.colorsJian[params.dataIndex])
                                            return new that.$echarts.graphic.LinearGradient(0, 0, 0, 1, [{
                                                offset: 0,
                                                color:  that.colorsJian[params.dataIndex][0]// 0% 处的颜色
                                            }, {
                                                offset: that.jianLength,
                                                color: that.colorsJian[params.dataIndex][1] // 100% 处的颜色
                                            }], false)
                                        }else{
                                            that.colorsLegend.push(that.colorsJian[params.componentIndex-1])
                                            return new that.$echarts.graphic.LinearGradient(0, 0, 0, 1, [{
                                                offset: that.jianLength,
                                                color:  that.colorsJian[params.componentIndex-1][0]// 0% 处的颜色
                                            }, {
                                                offset: 1,
                                                color: that.colorsJian[params.componentIndex-1][1] // 100% 处的颜色
                                            }], false)
                                        }

                                    }
                                },
                        },
                        data: squares[i]
                    }
                    seriesArr.push(item)
                }
                seriesArr.push(serOne)
                return seriesArr
            }
            that.surveyInit = that.$echarts.init(document.getElementById(this.histogramId));
            // 指定图表的配置项和数据
            var option = {
                tooltip: {
                    trigger: 'axis',
                    axisPointer: {
                        type: 'none',
                    },
                },
                grid:{
                    top: that.grid.top,
                    left: that.grid.left,
                    right: that.grid.right,
                    bottom: that.grid.bottom,
                    containLabel: false,
                },

                legend: {
                        show:that.legend.show,
                        // icon: that.legend.type,
                        itemWidth: that.legend.itemWidth,
                        itemHeight: that.legend.itemHeight,
                        itemGap: that.legend.itemGap,
                        data: typeData,
                        // right: 'center',
                        textStyle: {
                            fontSize: that.legend.fontSize,
                            color: that.legend.color
                        }
                    },
                xAxis: [
                    {
                        // type: 'category',
                        // boundaryGap: false,
                        // boundaryGap: 100,
                        min: -1,
                        max: this.xAxis.max,
                        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,
                        },
                        splitLine: {
                            show: this.xAxis.splitLineShow,
                            lineStyle: {
                                color: this.xAxis.splitLineColor,
                                type:this.xAxis.splitLineType
                            },
                        },
                        // triggerEvent: true,
                        data: xData,
                    },
                    {
                        // type: 'category',
                        // boundaryGap: false,
                        // boundaryGap: 100,
                        min: -1,
                        max: this.xAxis.max,
                        axisLine:'none',
                        axisTick:'none',
                        axisLabel: {
                            color: this.xAxis.axisLabelColorLabel,
                            fontSize: this.xAxis.axisLabelSizeLabel,
                            rotate:this.xAxis.axisLabelRotateLabel,
                            show:this.xAxis.axisLabelShowLabel
                        },
                        splitLine:'none',
                        data: yData,
                    }
                ],

                yAxis: [{
                    show:this.yAxis.show,
                    axisLine: {
                        show:this.yAxis.axisLineShow,
                        lineStyle: {
                            color: this.yAxis.axisLineColor,
                        }
                    },
                    axisLabel: {
                        color: this.yAxis.axisLabelColor,
                        fontSize: this.yAxis.axisLabelSize,
                        show:this.yAxis.axisLabelShow
                    },
                    splitLine: {
                        show:this.yAxis.splitLineShow,
                        lineStyle: {
                            color: this.yAxis.splitLineColor,
                            type:  this.yAxis.splitLineType,
                        }
                    }
                }],
                // 滑动条
                dataZoom:[{
                    type:'slider',
                    show:false,
                    realtime:true,
                    startValue:0,
                    endValue:that.showNum,
                }],
                series:creatArr(squares)
            };

            that.surveyInit.setOption(option);
            //滚动
            var key = 0;
            setInterval(function() {
                // 通过动态改变数据实现不停循环播放
                let y1 = option.xAxis[0].data,
                    y2 = option.xAxis[1].data;
                y1.push(y1.shift());
                y2.push(y2.shift());
                var newArr = new Array()
                for(var i = 0;i<option.series.length;i++){
                    newArr[i] = option.series[i].data
                    newArr[i].push(newArr[i].shift())
                }
                if(that.isSingleColor&&typeData.length==1){
                    that.colors.push(that.colors.shift())
                    that.colorsJian.push(that.colorsJian.shift())
                }
                circleData.push(circleData.shift())
                that.surveyInit.setOption(option);
            }, 3000);


        },
    },
    watch:{
        width:function(){
            this.surveyInit.resize()
        },
    },
    mounted(){
        // 新建一个promise对象
        let newPromise = new Promise((resolve) => {
            resolve()
        })
        //然后异步执行echarts的初始化函数
        newPromise.then(() => {
            //  此dom为echarts图标展示dom
            this.initMoreColorZhu()
        })
    },
}
</script>

标签:xAxis,或者,show,default,渐变,yAxis,rgba,type,状图
From: https://www.cnblogs.com/xuelinomen/p/17993996

相关文章

  • 【亲测管用】解决GitHub clone太慢或者远端意外挂断
    目录解决办法1使用GitHub的镜像,将代码库链接中的“github.com”替换为“github.com.cnpmjs.org”,如图所示:解决办法2将GitHub中的代码库导入码云,然后再进行clone返回目录方案1:github.com.cnpmjs.org返回目录使用GitHub的镜像,将代码库链接中的“github.com”替换为......
  • 【秀米教程8】设置背景渐变色,添加渐变色
    添加渐变色1、点击控件,直到出现属性栏2、点击【“+”号】-【渐变色】-【输入代码】-【加入调色板】3、此时调色板最下面就会出现新的渐变色代码看不懂?linear-gradient()函数用于创建一个表示两种或多种颜色线性渐变。渐变轴为45度,从蓝色渐变到红色linear-gradient(45deg,blue,re......
  • 在 `tkinter` 中,我们经常使用匿名函数(也称为 `lambda` 函数)来处理按钮点击等事件的回
    在`tkinter`中,我们经常使用匿名函数(也称为`lambda`函数)来处理按钮点击等事件的回调函数¹²。当你使用`tkinter`的`.bind()`或者`Button`的`command`参数来绑定一个函数时,`tkinter`会自动传递一个事件对象给这个函数¹。如果你的函数需要接受额外的参数,或者你不希望......
  • flutter 实现 “信用卡毛玻璃渐变新拟物设计卡片”
    信用卡毛玻璃渐变新拟物卡片在即时设计上看见了这样的一个信用卡毛玻璃渐变风格设计决定把这个风格的设计用flutter实现一下一、创建项目选择fluttersdk路径起一个项目名字,这里我叫ground_glass_card,然后点击next修改项目文件夹的查看方式,要不然误以为android项目文......
  • 其他设备唤醒Linux系统的S3或者S4
    如果你的键盘可以唤醒,但是鼠标去不能cat/proc/acpi/wakeup DeviceS-stateStatusSysfsnodeGP18 S4 *disabledSIO1 S3 *disabledpnp:00:03GPP0 S4 *enabledpci:0000:00:01.1GPP1 S4 *disabledGPP2 S4 *disabledGPP4 S4 *enabledpci:0000:00:02.2GPP5 ......
  • 数据挖掘||利用SQL Server 2012或者Excel 2013采用聚类和时序挖掘模型和算法,对自行车
    1.实验要求 利用SQLServer2012或者Excel2013(二者选择其一即可)进行数据挖掘实验,采用聚类和时序挖掘模型和算法,可以对附件中给定的excel数据进行聚类和时序挖掘实验,也可以采用自己采集的数据(如采用自选请说明数据来源)。 2.实验环境 操作系统:windows11;软件:Excel2019;SQLServer......
  • 无涯教程-CSS3 - 渐变属性(Gradients)
    渐变显示两种或更多种颜色的组合,如下所示-线性渐变线性渐变用于以线性格式(如从上到下)排列两种或多种颜色。Toptobottom(从上到下)<html><head><style>#grad1{height:100px;background:-webkit-linear-gradient(pink,......
  • 不能在此路径中使用此配置节。如果在父级别上锁定了该节,便会出现这种情况。锁定是默认
    今天运行项目的时候出现了这个错误....查了一下解决的方法。具体方案如下: 1、先确认安装IIS的时候有没有装Asp.Net,如果没安装的话,安装上即可。(XTHS:采用这步,就可以了!) 2、IIS采用了更安全的web.config管理机制,默认情况下会锁住配置项不允许更改。用超级管理员的身份执......
  • 突然连不上Github或者连接超时的解决办法
    问题描述当进行仓库pull或者push时,报错如下(连接失败/被拒绝/超时等):Failedtoconnecttogithub.comport443:Connectionrefused解决方法如下:方法一:关闭代理一开始查找解决方法以为是开梯子或者其他代理工具等原因,然后就试了重置代理或者取消代理的方式gitconfig--global-......
  • 2024-01-24:用go语言,已知一个n*n的01矩阵, 只能通过通过行交换、或者列交换的方式调整矩
    2024-01-24:用go语言,已知一个n*n的01矩阵,只能通过通过行交换、或者列交换的方式调整矩阵,判断这个矩阵的对角线是否能全为1,如果能返回true,不能返回false。我们升级一下:已知一个n*n的01矩阵,只能通过通过行交换、或者列交换的方式调整矩阵,判断这个矩阵的对角线是否能全为1,如果......