zoukankan      html  css  js  c++  java
  • 自动旋转的饼图(echarts)

    const list=[
        {value: 1048, name: '搜索引擎'},
        {value: 735, name: '直接访问'},
        {value: 580, name: '邮件营销'},
        {value: 484, name: '联盟广告'},
        {value: 300, name: '视频广告'}    
    ]
    const values=list.map(o=>o.value)
    option = {
        title: {
            text: '某站点用户访问来源',
            subtext: '纯属虚构',
            left: 'center'
        },
        selectedOffset:100,
        clockwise:true,
        tooltip: {
            trigger: 'item'
        },
        legend: {
            orient: 'vertical',
            left: 'left',
        },
        series: [
            {
                name: '访问来源',
                type: 'pie',
                // roseType:true,
                startAngle:152,
                radius: ['25%', '40%'],
                data: list,
                itemStyle:{
                    // shadowOffsetX: 10,
                    borderWidth:20,
                    borderColor:"pink",
                    decal:{
                        symbolSize:0.2
                    } 
                },
                emphasis: {
                    itemStyle: {
                        shadowBlur: 10,
                        shadowOffsetX: 0,
                        shadowColor: 'rgba(0, 0, 0, 0.5)'
                    }
                }
            }
        ]
    };
    
    const sum=list=>list.reduce((a,b)=>a+b,0)
    
    var idx =0
    var angle=0
    setInterval(()=>{
        idx++
        if(idx>=list.length){
            idx=0
        }
        angle=(360*(sum(values.slice(0,idx))+values[idx]/2)/sum(values)+90)%360
        console.log(currentAngle,angle)
        myChart.setOption({
            series:[{
                startAngle:angle,
                selectedOffset:0,
                selectedMode:true,
                // datasetIndex:idx,
                select:{
                    focus: 'series',
                    label:{
                        show:true,
                    },
                    itemStyle: {
                        shadowBlur: 10,
                        shadowColor: 'rgba(0, 0, 0, 0.5)'
                    }
                }
                
            }]
        });
        myChart.dispatchAction({
            type: 'select',
            dataIndex:idx,
        });
    },5000)
    
    myChart.on('click',(args)=>{
        console.log(args,angle)
        const index=args.dataIndex
        angle=(360*(sum(values.slice(0,index))+values[index]/2)/sum(values)+90)%360
        //点击后自动旋转的时候就在指定的扇面后旋转
        idx = index
        myChart.setOption({
            series:[{
                startAngle:angle
            }]
        })
    })
    积累小的知识,才能成就大的智慧,希望网上少一些复制多一些原创有用的答案
  • 相关阅读:
    作业四:结对编程项目---四则运算
    作业三: 代码规范、代码复审、PSP
    自动生成四则运算题目
    源程序版本管理软件和项目管理软件的优缺点
    学习进度表
    第一周随笔
    对之前问题的回答
    结对编程——四则运算
    PSP
    代码复审
  • 原文地址:https://www.cnblogs.com/llcdbk/p/15802748.html
Copyright © 2011-2022 走看看