自定义环形图表

本文介绍了如何在Android开发中自定义环形图表。通过画两个圆弧并首尾相连形成圆环,再结合画线和文字显示,详细阐述了实现环形图表的基本思路和关键代码。涉及到的关键类包括Path,同时也提及了如果需要处理点击事件,可以使用Region类。
摘要由CSDN通过智能技术生成

自定义环形图表

前言: Android开发中,原生的控件只能满足大多时候的需求,对于一些特殊的样式需要自定义控件去实现,接下来实现一个环形的图标,需要用到的关键类Paint,RectF,Matrix,Path

这里写图片描述

基本思路

1.圆环
可以看到圆环有不通过的扇形区域,我们可以理解画两个圆弧然后首尾连接就可以形成该形状

Path path = new Path();
path.addArc(mMaxRect, startAngle, allData.get(i).getAngle());
path.arcTo(mMinRect, startAngle + allData.get(i).getAngle(), -allData.get(i).getAngle());
path.close();

2.画线
调用drawLine()方法

canvas.drawLine(startX, startY, endX, endY, mPaint);

3.画文字

换文字要注意基类线的位置

 mPaint.setTextAlign(Paint.Align.LEFT);
canvas.drawText(tmpText, endX + defaultS, endY + mTmpRect.height() / 2, mPaint);

所有代码

/**
 * Description:环形饼状图
 * Created by Buuu on 2018/04/27.
 */

public class CirclePieChart extends View {
   
    private List<PieChartPart> allData;
    private Paint mPaint;
    private RectF mMinRect;
    private RectF mMaxRect;
    private Matrix mMatrix;
    private List<Path> mPathsList;
    private int mWH;
    private int mMaxWH;
    private int defaultSpace = 250;//周围宽度
    private float startAngle = 0f; //初始角度
    private float lineLength = 50; //指示线的长度

    public CirclePieChart(Context context) {
        this(context, null);
    }

    
  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值