/PieView

Android自定义控件(饼状图)

Primary LanguageJava

PieView

一个自定义的饼状表格图View

效果图

LinePieView效果图

LinePieView LinePieView

PercentPieView效果图

PercentPieView PercentPieView

AnimationPercentPieView

AnimationPercentPieView

基本使用

1.在gradle中添加依赖

compile 'com.zhijieeeeee:pieviewlibrary:2.0.3'

2.布局中使用

使用默认的样式,其中宽高可根据自己的需求设置,支持wrap_content,match_parent,固定尺寸。

一共有如下三种显示类型:

1.折现类型显示数据LinePieView:

<com.don.pieviewlibrary.LinePieView
    android:id="@+id/pieView"
    android:layout_width="match_parent"
    android:layout_height="wrap_content" />

2.百分比类型显示数据PercentPieView:

<com.don.pieviewlibrary.PercentPieView
    android:id="@+id/pieView2"
    android:layout_width="match_parent"
    android:layout_height="wrap_content" />

3.带动画的百分比类型显示数据AnimationPercentPieView:

<com.don.pieviewlibrary.AnimationPercentPieView
    android:id="@+id/pieView3"
    android:layout_width="match_parent"
    android:layout_height="wrap_content" />

自定义样式,根据自己的需求设置各种属性:

<com.don.pieviewlibrary.LinePieView
    android:id="@+id/pieView"
    android:layout_width="match_parent"
    android:layout_height="wrap_content"
    don:centerTextColor="#000000"
    don:centerTextSize="24sp"
    don:circleWidth="20dp"
    don:dataTextColor="#ff00ff"
    don:dataTextSize="12sp" />

<com.don.pieviewlibrary.PercentPieView
    android:id="@+id/pieView2"
    android:layout_width="match_parent"
    android:layout_height="wrap_content"
    don:centerTextColor="#000000"
    don:centerTextSize="24sp"
    don:circleWidth="40dp"
    don:dataTextColor="#ffffff"
    don:dataTextSize="10sp" />
  • centerTextColor:中间字体颜色

  • centerTextSize:中间字体大小

  • circleWidth:圆圈的厚度

  • dataTextColor:数据字体颜色

  • dataTextSize:数据字体大小

3.代码中设置数据源

int[] data = new int[]{10, 10, 10, 40};
String[] name = new String[]{"兄弟", "姐妹", "情侣", "基友"};
int[] color = new int[]{
            getResources().getColor(R.color.blue),
            getResources().getColor(R.color.red),
            getResources().getColor(R.color.green),
            getResources().getColor(R.color.purple)};

LinePieView pieView = (LinePieView) findViewById(R.id.pieView);
//设置指定颜色
pieView.setData(data, name, color);

PercentPieView pieView2 = (PercentPieView) findViewById(R.id.pieView2);
//使用随机颜色
pieView2.setData(data, name);

更新日志

V2.0.3

  • 修复AnimationPercentPieView无法自定义颜色的BUG
  • 调整了一些默认值

V2.0.2

  • 修改重复setData出现的数据叠加Bug
  • 添加设置指定颜色的方法

V2.0.1

  • 添加AnimationPercentPieView,为百分比形式显示添加动画
  • 重命名控件名称

V2.0.0

  • 添加PieView2,使用百分比形式显示
  • 重构代码

V1.0.0

  • 饼状表格图View

License

    Copyright 2016 zhijieeeeee

    Licensed under the Apache License, Version 2.0 (the "License");
    you may not use this file except in compliance with the License.
    You may obtain a copy of the License at

      http://www.apache.org/licenses/LICENSE-2.0

    Unless required by applicable law or agreed to in writing, software
    distributed under the License is distributed on an "AS IS" BASIS,
    WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
    See the License for the specific language governing permissions and
    limitations under the License.