[Android]Android(安卓)如何绘制图表
16lz
2021-12-17
在日常的统计中,经常要用图表来给用户恰当的数据体验,比如用饼状图,柱型图等。在传统的web中,有比较多的开源的这方面的解决方案。本文将简单介绍如何在Android中,如何使用开源工具库来展示图表。
在Android中,有三种解决方案,分别是:
1) 使用google 图表 api
2) 使用Achartengine库
3) 使用chartdroid库
下面分别进行介绍:
使用google 图表api
第一种方法是使用google的图表API。这个API特别适合去生成饼状图。
其中cht=p3表示生成的是一个饼状图;chd=t:30,60,10表示要生成三个部分的数据,分别是30,60,10,当然也可以其他更复杂的数据形式。
chs=250*100表示的是图型的大小(宽度*高度);chl=cars|bikes|trucks指出了这三部分数据内容的文字标签,即实际上显示在图表上的。
使用方法很简单,只需要在oncreate事件中如下调用即可:
java代码:
在Android中,有三种解决方案,分别是:
1) 使用google 图表 api
2) 使用Achartengine库
3) 使用chartdroid库
下面分别进行介绍:
使用google 图表api
第一种方法是使用google的图表API。这个API特别适合去生成饼状图。
其中cht=p3表示生成的是一个饼状图;chd=t:30,60,10表示要生成三个部分的数据,分别是30,60,10,当然也可以其他更复杂的数据形式。
chs=250*100表示的是图型的大小(宽度*高度);chl=cars|bikes|trucks指出了这三部分数据内容的文字标签,即实际上显示在图表上的。
使用方法很简单,只需要在oncreate事件中如下调用即可:
java代码:
- @Override
- public void onCreate(Bundle savedInstanceState) {
- super.onCreate(savedInstanceState);
- WebView googleChartView = new WebView(this);
- setContentView(googleChartView);
- String mUrl = "http://chart.apis.google.com/chart?cht=p3& chd=t:30,60,10&chs=250x100&chl=cars|bikes|trucks";
- googleChartView.loadUrl(mUrl);
- }
因为要连接网络,所以要在配置文件中允许使用网络,在AndroidManifest.xml中如下配置:
最后效果如下图:
2) 使用Achartengine库
第二种解决方案是使用Achartengine库,将其JAR下载后,放到工程的lib包库中,
java代码:
- public class AChartExample {
- public Intent execute(Context context) {
- int[] colors = new int[] { Color.RED, Color.YELLOW, Color.BLUE };
- DefaultRenderer renderer = buildCategoryRenderer(colors);
- CategorySeries categorySeries = new CategorySeries("Vehicles Chart");
- categorySeries.add("cars ", 30);
- categorySeries.add("trucks", 20);
- categorySeries.add("bikes ", 60);
- return ChartFactory.getPieChartIntent(context, categorySeries, renderer);
- }
- protected DefaultRenderer buildCategoryRenderer(int[] colors) {
- DefaultRenderer renderer = new DefaultRenderer();
- for (int color : colors) {
- SimpleSeriesRenderer r = new SimpleSeriesRenderer();
- r.setColor(color);
- renderer.addSeriesRenderer(r);
- }
- return renderer;
- }
- }
在上面的代码中,首先将初始化了colors数组,这里指定了饼图的三种颜色,然后在buildCategoryRenderer方法中,使用 SimpleSeriesRenderer类实例来进行初始化,分别设置了饼图要显示的系列区域的颜色。而我们将要显示的数据及标签内容都放到categorySeries中进行显示。最后调用ChartFactory的getPieChartIntent方法,传入categorySeries和renderer即可。
在我们的主类中,进行如下调用:
Intent achartIntent = new AChartExample().execute(this);
startActivity(achartIntent);
最后生成的效果如下图:
3) 使用Chartdroid
第三种方法是使用chartdroid,要注意的是,如果使用这种方法的话,下载并将其APK包进行安装。
要使用Chartdroid,必须要使用content provider,我们编写代码如下:
java代码:
- public class ChartDroidDataProvider extends ContentProvider {
- static final String AUTHORITY = "com.xyz.contentprovider.chardroid";
- @Override
- public String getType(Uri uri) {
- return "vnd.android.cursor.dir/vnd.com.googlecode.chartdroid.graphable";
- }
- public static final Uri PROVIDER_URI = new Uri.Builder().scheme(
- ContentResolver.SCHEME_CONTENT).authority(AUTHORITY).build();
- @Override
- public Cursor query(Uri uri, String[] projection, String selection,
- String[] selectionArgs, String sortOrder) {
- //获得实际数据
- MatrixCursor c = new MatrixCursor(new String[] { BaseColumns._ID,
- "COLUMN_AXIS_INDEX", "COLUMN_SERIES_INDEX",
- "COLUMN_DATUM_VALUE", "COLUMN_DATUM_LABEL" });
- c.newRow().add(1).add(0).add(1).add(30).add(null);
- c.newRow().add(2).add(0).add(1).add(10).add(null);
- c.newRow().add(3).add(0).add(1).add(60).add(null);
- return c;
- }
- }
在上面的代码中,我们使用了MatrixCursor生成了相关的数据:30,10,60。关于ChartDroid的详细 ContentProvider信息,接下来,我们看使用的代码,如下:
java代码:
- Intent chartDroidIntent = new Intent(Intent.ACTION_VIEW,ChartDroidDataProvider.PROVIDER_URI);
- chartDroidIntent.putExtra(Intent.EXTRA_TITLE, "Chart droid");
- chartDroidIntent.addCategory("com.googlecode.chartdroid.intent.category.PIE_CHART");
- startActivity(chartDroidIntent);
更多相关文章
- Android切近实战(一)
- 基于 MVP 架构使用Android通用开发框架快速开发微博项目实战
- 想抢先体验Android操作系统的魅力吗?那就使用Android(安卓)LiveCD
- Android通过Socket(TCP/IP)与PC通讯
- Android(安卓)驱动之旅: 第一章 在Android(安卓)内核源代码工程中
- Android学习——uses-sdk标签详解
- 箭头函数的基础使用
- NPM 和webpack 的基础使用
- Python list sort方法的具体使用