zoukankan      html  css  js  c++  java
  • Android报表库aChartEngine系列(pie chart)

    1、pie chart介绍

    aChartEngine中的pie Chart其实就是一个饼状图,是数据显示的一种。效果如图:

    2、如何使用pie chart。

    其实aChartEngine是使用是非常简单的,不同的chart的使用方式都是一样的,并不需要我们根据不同的chart调用不同的接口,接口都是统一的。那么我们应该如何使用呢?总结了一下分为两步:

    ①获取数据dataSet;

    ②获取渲染器render。

    其实这很好理解,一个图表其实本来就是一些数据的显示方式。所以你必须得有数据(dataset),有了数据之后你总得知道应该以什么样的方式来显示吧(render)。这么看来这两部分是缺一不可的,而且功能很明确。

    3、demo。

    package com.example.test;
    
    import org.achartengine.ChartFactory;
    import org.achartengine.model.CategorySeries;
    import org.achartengine.renderer.DefaultRenderer;
    import org.achartengine.renderer.SimpleSeriesRenderer;
    
    import android.app.Activity;
    import android.graphics.Color;
    import android.os.Bundle;
    import android.view.View;
    
    public class MainActivity extends Activity {
    
        @Override
        public void onCreate(Bundle savedInstanceState) {
            super.onCreate(savedInstanceState);
            double[] values = new double[] { 12, 14, 11, 10, 19 };
            int[] colors = new int[] { Color.BLUE, Color.GREEN, Color.MAGENTA, Color.YELLOW, Color.CYAN };
            DefaultRenderer renderer = buildCategoryRenderer(colors);
            renderer.setZoomButtonsVisible(true);
            renderer.setZoomEnabled(true);
            renderer.setChartTitleTextSize(20);
            //        Intent intent = ChartFactory.getPieChartIntent(this, buildCategoryDataset("Project budget", values), renderer, "Budget");
            //        startActivity(intent);
            View view = ChartFactory.getPieChartView(this, buildCategoryDataset("Project budget", values), renderer);
            view.setBackgroundColor(Color.BLACK);
            setContentView(view);
        }
    
        protected DefaultRenderer buildCategoryRenderer(int[] colors) {
            DefaultRenderer renderer = new DefaultRenderer();
            renderer.setLabelsTextSize(15);
            renderer.setLegendTextSize(15);
            renderer.setMargins(new int[] { 20, 30, 15, 0 });
            for (int color : colors) {
                SimpleSeriesRenderer r = new SimpleSeriesRenderer();
                r.setColor(color);
                renderer.addSeriesRenderer(r);
            }
            return renderer;
        }
    
        protected CategorySeries buildCategoryDataset(String title, double[] values) {
            CategorySeries series = new CategorySeries(title);
            int k = 0;
            for (double value : values) {
                series.add("Project " + ++k + " (" + value + ")", value);
            }
            return series;
        }
    }

    4、分析demo。

    代码中比较关键的地方其实是 ChartFactory.getPieChartView,它返回一个view,也就是我们需要显示的chart。那么我们看看这个方法(在doc上有开发说明):

    public static final GraphicalView getPieChartView(android.content.Context context,
                                                      CategorySeries dataset,
                                                      DefaultRenderer renderer)

    Creates a pie chart intent that can be used to start the graphical view activity. 
    Parameters:
    context - the context
    dataset - the category series dataset (cannot be null)
    renderer - the series renderer (cannot be null)
    Returns:
    a pie chart view
    Throws:
    java.lang.IllegalArgumentException - if dataset is null or renderer is null or if the dataset number of items is different than the number of series renderer。

    所以需要两个非常重要的参数,也就是开始我们提到的dataset、renderer。具体是如何构造的见代码。

    这里需要值一提的是dataset中的item数应该和renderer中的SeriesRenderer数相等。每组数据应该对已一个renderer,也就是说每一组数据都应有自己独立的显示样式。

     

    5、总结。

    pie Chart 是achartengine里面最简单的chart,使用起来很方便。它需要的dataset中需要离散的几个数,而不是离散的几个点。

    在使用上面的代码前一定要引入achartengine1.0.0.jar包,如果运行时有找不到类、类定义这样的问题,也许我的博文http://www.cnblogs.com/vanezkw/archive/2012/06/25/2561393.html可以帮助到你。

    我的另一篇博文http://www.cnblogs.com/vanezkw/archive/2012/07/27/2611177.html对achartengine做了简单的介绍。

    欢迎交流。期待你的宝贵意见。

  • 相关阅读:
    js对象深拷贝
    数组去重
    css布局之双飞翼布局
    css布局之圣杯布局
    在浏览器中输入URL并回车后都发生了什么?
    浮动和清除浮动
    Javascript 构造函数模式、原型模式
    Javascript之对象组合继承
    js可以随意拖拽的div的实现
    博客美化 之博客的魔方效果
  • 原文地址:https://www.cnblogs.com/vanezkw/p/2611677.html
Copyright © 2011-2022 走看看