AChartEngine是一个针对Android程序开发的免费图表开发库,目前已经发布了4个版本。支持散点图、折线图、饼图、气泡图、柱状图、短棒图、仪表图等多种图表。Android开发者可以很方便的试用AChartEngine Chart库画出各种图表。
该项目地址位于:
http://code.google.com/p/achartengine/
你可以选择合适的版本下载,每个版本都有一个jar包、实例源代码和java doc提供下载。当前最新版本为1.0。
更详细的介绍请查看http://blog.csdn.net/lk_blog/article/details/7645509
在下载的achartengine-1.0.0-demo-source官方的demo文档里面有了详细的代码演示了使用
其demo 类模型如下
1. ChartDemo这个类是整个应用程序的入口,运行之后的效果显示一个list.
2. IDemoChart接口,这个接口定义了三个方法,
getName()返回值是listitem上显示的标题;
getDesc()返回值是listitem上显示的描述内容.
excute(context)返回值是一个Intent,当点击listitem后跳转到此Intent.
3. AbstractDemoChart类是一个抽象类,实现接口IDemoChart接口,这个类中封装了构建DataSet和renderer的方法,目的快速构建我们的dataset和renderer.
/**
* 报表统一信息接口
* *
*/
public interface IChart {
String NAME = "name";
String DESC = "desc";
/**
* 报表名
*
* @return
*/
String getName();
/**
* 报表描述
*
* @return
*/
String getDesc();
/**
* 返回值是一个Intent,当点击后跳转到此Intent.
*
* @param context
* @return
*/
Intent execute(Context context);
}
/**
* *
*/
public abstract class AbstractChart implements IChart {
/**
* Builds an XY multiple dataset using the provided values. 构建
* XYMultipleSeriesDataset
*
* @param titles
* 每个序列的图例
* @param xValues
* X轴的坐标
*
* @param yValues
* y轴的坐标
*
* @return the XY multiple dataset
*/
protected XYMultipleSeriesDataset buildDataset(String[] titles, List<double[]> xValues, List<double[]> yValues) {
XYMultipleSeriesDataset dataset = new XYMultipleSeriesDataset();
addXYSeries(dataset, titles, xValues, yValues, 0);
return dataset;
}
// 向DataSet中添加序列.
public void addXYSeries(XYMultipleSeriesDataset dataset, String[] titles, List<double[]> xValues, List<double[]> yValues, int scale) {
int length = titles.length;
for (int i = 0; i < length; i++) {
XYSeries series = new XYSeries(titles[i], scale);// 这里注意与TimeSeries区别.
double[] xV = xValues.get(i);
double[] yV = yValues.get(i);
int seriesLength = xV.length;
for (int k = 0; k < seriesLength; k++) {
series.add(xV[k], yV[k]);
}
dataset.addSeries(series);
}
}
/**
* Builds an XY multiple series renderer. 构建XYMultipleSeriesRenderer.
*
* @param colors
* 每个序列的颜色
* @param styles
* 每个序列点的类型(可设置三角,圆点,菱形,方块等多种)
* @return XYMultipleSeriesRenderer
*/
protected XYMultipleSeriesRenderer buildRenderer(int[] colors, PointStyle[] styles) {
XYMultipleSeriesRenderer renderer = new XYMultipleSeriesRenderer();
setRenderer(renderer, colors, styles);
return renderer;
}
// 整个图表属性设置
protected void setRenderer(XYMultipleSeriesRenderer renderer, int[] colors, PointStyle[] styles) {
// -->start
renderer.setAxisTitleTextSize(16);// 设置轴标题文字的大小
renderer.setChartTitleTextSize(20); // 设置整个图表标题文字的大小
renderer.setLabelsTextSize(15); // 设置轴刻度文字的大小
renderer.setLegendTextSize(15);// 设置图例文字大小
renderer.setPointSize(5f);// 设置点的大小(图上显示的点的大小和图例中点的大小都会被设置)
renderer.setMargins(new int[] { 20, 30, 15, 20 });// 设置图表的外边框(上/左/下/右)
// -->end
// 以下代码设置每个序列的颜色.
// -->start
int length = colors.length;
for (int i = 0; i < length; i++) {
XYSeriesRenderer r = new XYSeriesRenderer();
r.setColor(colors[i]);// 设置颜色
r.setPointStyle(styles[i]);
renderer.addSeriesRenderer(r);
}
// -->end
}
/**
* 设置renderer的一些属性.
*
* @param renderer
* 要设置的renderer
* @param title
* 图表标题
* @param xTitle
* X轴标题
* @param yTitle
* Y轴标题
* @param xMin
* X轴最小值
* @param xMax
* X轴最大值
* @param yMin
* Y轴最小值
* @param yMax
* Y轴最大值
* @param axesColor
* X轴颜色
* @param labelsColor
* Y轴颜色
*/
protected void setChartSettings(XYMultipleSeriesRenderer renderer, String title, String xTitle, String yTitle, double xMin, double xMax, double yMin, double yMax, int axesColor, int labelsColor) {
renderer.setChartTitle(title);
renderer.setXTitle(xTitle);
renderer.setYTitle(yTitle);
renderer.setXAxisMin(xMin);
renderer.setXAxisMax(xMax);
renderer.setYAxisMin(yMin);
renderer.setYAxisMax(yMax);
renderer.setAxesColor(axesColor);
renderer.setLabelsColor(labelsColor);
}
/**
* 构建和时间有关的XYMultipleSeriesDataset,这个方法与buildDataset在参数上区别是需要List<Date[]>作参数
* .
*
* @param titles
* 序列图例
* @param xValues
* X轴值
* @param yValues
* Y轴值
* @return XYMultipleSeriesDataset
*/
protected XYMultipleSeriesDataset buildDateDataset(String[] titles, List<Date[]> xValues, List<double[]> yValues) {
XYMultipleSeriesDataset dataset = new XYMultipleSeriesDataset();
int length = titles.length;
for (int i = 0; i < length; i++) {
TimeSeries series = new TimeSeries(titles[i]);// 构建时间序列TimeSeries
Date[] xV = xValues.get(i);
double[] yV = yValues.get(i);
int seriesLength = xV.length;
for (int k = 0; k < seriesLength; k++) {
series.add(xV[k], yV[k]);
}
dataset.addSeries(series);
}
return dataset;
}
/**
* 构建单个CategorySeries,可用于生成饼图,注意与buildMultipleCategoryDataset(构建圆环图)相区别.
*
* @param titles
* the series titles
* @param values
* the values
* @return the category series
*/
protected CategorySeries buildCategoryDataset(String title, double[] values) {
CategorySeries series = new CategorySeries(title);
int k = 0;
for (double value : values) {
series.add("Project " + ++k, value);
}
return series;
}
/**
* 构建MultipleCategorySeries,可用于构建圆环图(每个环是一个序列)
*
* @param titles
* the series titles
* @param values
* the values
* @return the category series
*/
protected MultipleCategorySeries buildMultipleCategoryDataset(String title, List<String[]> titles, List<double[]> values) {
MultipleCategorySeries series = new MultipleCategorySeries(title);
int k = 0;
for (double[] value : values) {
series.add(2007 + k + "", titles.get(k), value);
k++;
}
return series;
}
/**
* 构建DefaultRenderer.
*
* @param colors
* 每个序列的颜色
* @return DefaultRenderer
*/
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;
}
/**
* 构建XYMultipleSeriesDataset,适用于柱状图.
*
* @param titles
* 每中柱子序列的图列
* @param values
* 柱子的高度值
* @return XYMultipleSeriesDataset
*/
protected XYMultipleSeriesDataset buildBarDataset(String[] titles, List<double[]> values) {
XYMultipleSeriesDataset dataset = new XYMultipleSeriesDataset();
int length = titles.length;
for (int i = 0; i < length; i++) {
CategorySeries series = new CategorySeries(titles[i]);
double[] v = values.get(i);
int seriesLength = v.length;
for (int k = 0; k < seriesLength; k++) {
series.add(v[k]);
}
dataset.addSeries(series.toXYSeries());
}
return dataset;
}
/**
* 构建XYMultipleSeriesRenderer,适用于柱状图.
*
* @param colors
* 每个序列的颜色
* @return XYMultipleSeriesRenderer
*/
protected XYMultipleSeriesRenderer buildBarRenderer(int[] colors) {
XYMultipleSeriesRenderer renderer = new XYMultipleSeriesRenderer();
renderer.setAxisTitleTextSize(16);
renderer.setChartTitleTextSize(20);
renderer.setLabelsTextSize(15);
renderer.setLegendTextSize(15);
int length = colors.length;
for (int i = 0; i < length; i++) {
SimpleSeriesRenderer r = new SimpleSeriesRenderer();
r.setColor(colors[i]);
renderer.addSeriesRenderer(r);
}
return renderer;
}
}
- 大小: 29.9 KB
- 大小: 12.4 KB
分享到:
相关推荐
**Android报表库aChartEngine详解:打造时间曲线图表** 在Android应用开发中,数据可视化是一项重要的功能,能够帮助用户直观地理解复杂的数据信息。aChartEngine是一个强大的开源库,专门用于在Android平台上创建...
AChartEngine是一款强大的开源报表库,专为Android平台设计,允许开发者轻松地在应用程序中创建各种图表,如折线图、柱状图、饼图、散点图等。在1.0.0版本中,AChartEngine提供了一系列改进和增强,旨在提升图表的...
《Android报表开发与AChartEngine库详解》 在Android应用开发中,数据的可视化是至关重要的,它能够帮助用户更直观地理解复杂的信息。AChartEngine是一个强大的开源库,专门用于在Android平台上创建各种类型的图表...
AChartEngine是一款强大的开源库,专为Android平台设计,用于创建各种类型的图表,如柱状图、线形图、饼图等。它提供了丰富的功能,使得开发者能够轻松地在应用程序中集成图表,用于数据可视化。在本文中,我们将...
在Android开发中,数据可视化是十分重要的,AChartEngine是一个流行的开源库,它为开发者提供了在Android应用中绘制各种图表的能力,包括折线图、饼图、柱状图等。这篇博客“Android学习之AChartEngine折线图”将...
`AChartEngine`是一个强大的开源库,专为Android平台设计,用于创建各种类型的图表,包括折线图、柱状图、饼图等。本文将深入探讨`AChartEngine`在Android图形报表中的应用,并通过提供的`AChartEngineTest`源码来...
`achartengine`是一个强大的开源库,专为Android平台设计,提供了丰富的图表绘制功能,使得开发者能够轻松地在应用程序中集成各种图表,如折线图、柱状图、饼图、散点图等。 `achartengine`库的核心概念是图表引擎...
本资源"安卓图表报表相关-Android饼图控件1.2.rar"包含了一个专用于在Android平台上绘制饼图的控件,版本为1.2。尽管无法确保每个组件都能直接运行,但它们提供了丰富的代码示例,适合开发者进行学习和参考,以实现...
Android中使用AChartEngine 来绘图的demo,比google code上的demo简单易懂。相关文章请看: http://blog.csdn.net/suiyuansanren/article/details/19819437
`ACHARTENGINE`是一个用Java编写的库,专为Android平台设计,支持多种类型的图表,包括折线图(LineChart)、饼图(PieChart)、柱状图(BarChart)、散点图(ScatterChart)以及更多其他图表类型。它简化了Android...
`AChartEngine`是一个强大的库,它为Android开发者提供了一种简单的方式来创建各种类型的图表,包括折线图。本篇文章将深入探讨如何使用`AChartEngine`在Android应用中实现折线图的功能,并强调动态加载数据的实现。...
android图表绘制工具,功能非常强大,几乎涵盖了所有的图表种类。 这是目前最新的版本:1.1.0 包含了3个文件: achartengine-1.1.0.jar, achartengine-1.1.0-demo-source.zip, achartengine-1.1.0-javadocs.zip ...
AChartEngine是一款在Android平台上用于创建各种图表的强大框架,其1.1.0版本提供了丰富的图表类型和高度自定义的功能。这个框架使得开发者能够轻松地在Android应用中集成数据可视化,使得用户可以直观地理解和分析...
AChartEngine是一个强大的开源图表库,专为Android平台设计,用于在应用程序中生成高质量的图形。这个库提供了多种图表类型,包括线图、散点图、条形图、饼图、甘特图等,适用于数据可视化的需求。标题提及的...
Achartengine是一个强大的开源图表库,专为Android平台设计,用于快速轻松地创建各种图表,如折线图、柱状图、饼图等。在Android应用开发中,它提供了丰富的功能,帮助开发者可视化数据,使得应用程序更加直观和交互...
接下来,我们介绍iChartJS,这是一个基于JavaScript的图表库,主要用于Web端,但也可以在Android的WebView中使用。如果你需要在Android应用中展示交互式且视觉效果丰富的图表,iChartJS是一个不错的选择。以下是使用...
Android使用AChartEngine制作动态心电图效果
本文主要探讨了几个常用的Android报表控件,特别是AchartEngine,以及如何利用它们实现报表打印。 AchartEngine是一个强大的图表库,专为Android应用程序设计。它支持多种图表类型,包括线图、面积图、散点图、时间...
在此背景下,AChartEngine作为一款专为Android平台设计的开源图表库,以其简洁的API、丰富的图表类型以及详实的文档支持,成为了开发者制作安卓报表的得力助手。 AChartEngine 1.1.0版本作为该库的一个成熟稳定版本...