Android实现图表绘制和展示

本文演示在Android平台中绘制和展示图表示例,本示例是基于RChart 2实现的。

        在一个系统中经常要用到图表统计数据,在WEB开发中图表绘制是一件简单的事情,因为有比较多的开源方案。但在Android中开源方案并不多。

       

        Android中绘制图表解决方案:

        1) 使用google 图表 api   

        2) 使用Achartengine库(http://www.achartengine.org/)   

        3) 使用chartdroid库(http://code.google.com/p/chartdroid/)

        4) 使用 RChart 2库实现。

         

        第一种解决方案是使用google的图表API。

        可以到如下这个地址去申请使用google 图表API(http://code.google.com/apis/chart/)。

        这个API特别适合去生成饼状图。调用的格式如下即可:

          http://chart.apis.google.com/chart?cht=p3&chd=t:30,60,10&chs=250x100&chl=cars|bikes|trucks
          其中cht=p3表示生成的是一个饼状图;chd=t:30,60,10表示要生成三个部分的数据,分别是30,60,10,当然也可以其他更复杂的数据形式。
          chs=250*100表示的是图型的大小(宽度*高度);chl=cars|bikes|trucks指出了这三部分数据内容的文字标签,即实际上显示在图表上的。
          使用方法很简单,只需要在oncreate事件中如下调用即可:
  1. @Override 
  2. publicvoid onCreate(Bundle savedInstanceState) { 
  3. super.onCreate(savedInstanceState); 
  4. WebView googleChartView = new WebView(this); 
  5. setContentView(googleChartView); 
  6. String mUrl = "http://chart.apis.google.com/chart?cht=p3& chd=t:30,60,10&chs=250x100&chl=cars|bikes|trucks"; 
  7. googleChartView.loadUrl(mUrl); 
  8. }
复制代码



        由于需要连接网络,需要在配置文件中加入访问网络权限:


  1. <uses-permission android:name="android.permission.INTERNET" />
复制代码

        关于google 图表API更多的资料请参考http://code.google.com/intl/zh-C ... /making_charts.html

       

        缺点:必须连网才能访问API,生成图形。

        示例效果如下图:

          Android实现图表绘制和展示_第1张图片


        第二种解决方案是使用Achartengine库。

        下载地址在:http://code.google.com/p/achartengine/downloads/list ,将其JAR下载后,放到工程的lib包库中,结构如下图:

          

        代码如下显示:

       

  1. public class AChartExample {  
  2. public Intent execute(Context context) { 
  3. int[] colors = new int[] { Color.RED, Color.YELLOW, Color.BLUE }; 
  4. DefaultRenderer renderer = buildCategoryRenderer(colors); 
  5. CategorySeries categorySeries = new CategorySeries("Vehicles Chart"); 
  6. categorySeries.add("cars ", 30); 
  7. categorySeries.add("trucks", 20); 
  8. categorySeries.add("bikes ", 60); 
  9. return ChartFactory.getPieChartIntent(context, categorySeries, renderer); 

  10.   
  11. protected DefaultRenderer buildCategoryRenderer(int[] colors) { 
  12. DefaultRenderer renderer = new DefaultRenderer(); 
  13. for (int color : colors) { 
  14. SimpleSeriesRenderer r = new SimpleSeriesRenderer(); 
  15. r.setColor(color); 
  16. renderer.addSeriesRenderer(r); 

  17. return renderer; 

  18. }
复制代码

        在我们的主类中,进行如下调用:   

       

  1. Intent achartIntent = new AChartExample().execute(this);   
  2.         startActivity(achartIntent);  
复制代码


        最后生成的效果如下图:

          

       

        第三种解决方案是使用chartdroid,要注意的是。

        如果使用这种方法的话,必须先下载并安装Chardroid这个APK,下载地址在:http://code.google.com/p/chartdroid/downloads/list,下载并将其APK包进行安装。

        要使用Chartdroid,必须要使用content provider,代码如下:

  1. public class ChartDroidDataProvider extends ContentProvider {  
  2. staticfinal String AUTHORITY =  "com.xyz.contentprovider.chardroid"; 
  3. @Override
  4. public String getType(Uri uri) { 
  5. return "vnd.android.cursor.dir/vnd.com.googlecode.chartdroid.graphable"; 

  6. public static final Uri PROVIDER_URI = new Uri.Builder().scheme( 
  7. ContentResolver.SCHEME_CONTENT).authority(AUTHORITY).build(); 
  8. @Override
  9. public Cursor query(Uri uri, String[] projection, String selection, 
  10. String[] selectionArgs, String sortOrder) { 
  11.   
  12. //获得实际数据  
  13. MatrixCursor c = new MatrixCursor(new String[]                  { BaseColumns._ID, 
  14. "COLUMN_AXIS_INDEX", "COLUMN_SERIES_INDEX", 
  15. "COLUMN_DATUM_VALUE", "COLUMN_DATUM_LABEL" }); 
  16.   
  17. c.newRow().add(1).add(0).add(1).add(30).add(null); 
  18. c.newRow().add(2).add(0).add(1).add(10).add(null); 
  19. c.newRow().add(3).add(0).add(1).add(60).add(null); 
  20.   
  21. return c; 

  22. }
复制代码


        在上面的代码中,我们使用了MatrixCursor生成了相关的数据:30,10,60。关于ChartDroid的详细ContentProvider信息,请参考http://code.google.com/p/chartdroid/wiki/InterfaceSpecification。

        接下来,代码如下:

  1. Intent chartDroidIntent = new Intent(Intent.ACTION_VIEW,  
  2. ChartDroidDataProvider.PROVIDER_URI); 
  3. chartDroidIntent.putExtra(Intent.EXTRA_TITLE, "Chart droid"); 
  4. chartDroidIntent 
  5. .addCategory("com.googlecode.chartdroid.intent.category.PIE_CHART"); 
  6. startActivity(chartDroidIntent);  
复制代码

        注意,这里要使用charDroidIntent的addCategory方法去指定图表的类型,即   com.googlecode.chartdroid.intent.category.PIE_CHART。下图是运行效果:

          


        第四种解决方案是使用RChart 2 库,关于RChart 2信息访问:http://www.java4less.com/charts/chart.php

        下面是一些示例实现效果:

          Android实现图表绘制和展示_第2张图片

   Android实现图表绘制和展示_第3张图片

2012-4-5 10:27:25 上传
下载附件  (46.07 KB)


2012-4-5 10:27:25 上传
下载附件  (46.07 KB)


你可能感兴趣的:(android,api,String,Google,null,colors)