echarts 实现环形进度图

效果如图:

094349_AZ8W_2499632.png

typescript部分:

import {Component, OnInit} from "@angular/core";
import {EchartsDirective} from "../../libs/echarts/echarts.component";


@Component({
    selector: 'circle-loading',
    template: `
        <div echarts [eoption]="eoption" style="height: 300px;width: 300px;"></div>
    `,
    directives: [
        EchartsDirective
    ]
})

export class CircleLoadingComponent implements OnInit {

    eoption: any;
    name: string;
    value:number = 2;

    ngOnInit() {
        this.getInterval();
    }

    getInterval() {
        setInterval(() => this.generateData(), 1000);
    }

    generateData() {
        this.value = this.value < 100 ? this.value + 2 : 10;
        this.eoption = this.getOption();
    }

    getOption() {
        var option = {
            legend: {
                orient: 'vertical',
                x: 'left'
            },
            series: [
                {
                    name:'访问来源',
                    type:'pie',
                    selectedMode: 'single',
                    radius: [0, '39%'],
                    hoverAnimation: false,
                    label: {
                        normal: {
                            position: 'inner'
                        }
                    },
                    labelLine: {
                        normal: {
                            show: false
                        }
                    },
                    animation: false,
                    data:[
                        {value:100, name:this.value + '%',
                            itemStyle: {
                                normal: {
                                    color: '#6a5acd'
                                }
                            },
                            label: {
                                normal: {
                                    show: true,
                                    position: 'center',
                                    textStyle: {
                                        color: '#f8f8f8',
                                        fontSize: 20
                                    }
                                }
                            }
                        }
                    ]
                },
                {

                    type:'pie',
                    radius: ['40%', '43%'],
                    itemStyle: {
                        normal: {
                            color: '#6a5acd'
                        }
                    },
                    labelLine: {
                        normal: {
                            show: false
                        }
                    },
                    hoverAnimation: false,
                    animationEasing: 'cubicOut',
                    data:[
                        {value:this.value,
                            itemStyle: {
                                emphasis: {
                                    color: '#6a5acd'
                                }
                            }
                        },
                        {value:100 - this.value,
                            itemStyle: {
                                normal: {
                                    color: '#d3d3d3'
                                }
                            }
                        },
                    ]
                }
            ]
        };
        return option;
    }


}

效果如图:

 

转载于:https://my.oschina.net/u/2499632/blog/745576

  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值