Android---手把手教你撸一个自定义条形图

之前从某网上看了一个描述自定义条形图的视频教程,因为没有源码,所以自己记录了一下,方便以后用到,初学者也可以互相学习.

废话不多说,首先看下效果图:(可能界面比较low哈....)


我们先看一下 画图三要素的介绍

Canvas : 画布, 绘制Bitmap操作;

Paint : 绘制所需的画笔(一般用来规定颜色,样式等);

Path : 路径 轨迹;

那么接下来直接上代码,代码中都有注释,我就不过度赘述了;

设置条形图的样式在styles.xml中:

<!--自定义条形图样式-->
<declare-styleable name="ChartStyle">
    <attr name="graphTitle" format="string"></attr>
    <attr name="xAxisName" format="string"></attr>
    <attr name="yAxisName" format="string"></attr>
    <attr name="axisTextSize" format="dimension|integer"></attr>
    <attr name="axisTextColor" format="color|integer"></attr>
</declare-styleable>

创建抽象类BaseView继承自View

public abstract class BaseView extends View {

    private Context mContext;
    //画笔
    private Paint mPaint;

    //视图的宽
    public int width;
    //视图的高
    public int height;

    //原始起点的X,Y坐标值
    public int originalX = 80;
    public int originalY = 500;


    //X,Y轴等份划分
    public int axisDividedSizeX;
    public int axisDividedSizeY;

    //第一个维度为值,第二个维度为颜色
    public int[][] columnInfo;

    //图表标题
    private String mGraphTitle;
    //XName
    private String mXAxisName;
    //YName
    private String mYAxisName;

    //坐标轴上字体的大小
    private float mAxisTextSize;
    //坐标轴字体的颜色
    public int mAxisTextColor;

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

    public BaseView(Context context, @Nullable AttributeSet attrs) {
        this(context, attrs, -1);
    }

    /**
     * 设置X轴的刻度份数
     * @param axisDividedSizeX
     */
    public void setAxisDividedSizeX(int axisDividedSizeX) {
        this.axisDividedSizeX = axisDividedSizeX;
    }

    /**
     * 设置Y轴的刻度份数
     * @param axisDividedSizeY
     */
    public void setAxisDividedSizeY(int axisDividedSizeY) {
        this.axisDividedSizeY = axisDividedSizeY;
    }

    /**
     * 设置条形图的数值和颜色
     * @param columnInfo
     */
    public void setColumnInfo(int[][] columnInfo) {
        this.columnInfo = columnInfo;
    }

    public BaseView(Context context, @Nullable AttributeSet attrs, int defStyleAttr) {
        super(context, attrs, defStyleAttr);
        mContext = context;

        //获取自定义样式
        TypedArray typedArray = context.obtainStyledAttributes(attrs, R.styleable.ChartStyle);

        //取出自定义的设置
        mGraphTitle = typedArray.getString(R.styleable.ChartStyle_graphTitle);
        mXAxisName = typedArray.getString(R.styleable.ChartStyle_xAxisName);
        mYAxisName = typedArray.getString(R.styleable.ChartStyle_yAxisName);

        mAxisTextColor = typedArray.getColor(R.styleable.
  • 1
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值