废话不多说 关于android图表制作引擎AchartEngine的介绍我这里直接略去 大家想要了解它可以直接百度。
网上关于AChartEngine绘制柱状图的介绍非差稀少,而AchartEngine它本身Api帮助文档写的非常的简略,给我们学习带来很大的不便。所以我在这里凭借个人的理解,以一个简单的柱状图的例子来解释AchartEngine绘制柱图的一个过程,希望会对大家有所帮助。
首先简略的理解一下AchartEngine的API。
AchartEngine的提供的Api非常的简单,其中最重要的两个概念就是数据设置器(dataset)和所谓的描绘器(renderer)。顾名思义,数据设置器就是为我们提供了一系列对图表进行值传入的方法,而描绘器为我们提供了修改图表外观的一些方法。
本例结合简单的SQLite数据库表来建立一张柱状图
以下是我们要用到的数据库表的信息:
其实待会我们要用到的 只有_name和money两个字段,大家只要关注这两个字段即可
首先 我们打开本地数据库 得到游标:
接下去我们要声明一个数据设置器 和一个描绘器
其中getBarRenderer()函数是我们自定义的方法,用于初始化描绘器,其方法具体如下:
//描绘器设置 public XYMultipleSeriesRenderer getBarRenderer() { XYMultipleSeriesRenderer renderer = new XYMultipleSeriesRenderer(); //通过SimpleSeriesDenderer设置描绘器的颜色 SimpleSeriesRenderer r = new SimpleSeriesRenderer(); r.setColor(Color.RED); renderer.addSeriesRenderer(r); setChartSettings(renderer);//设置描绘器的其他属性 return renderer; } private void setChartSettings(XYMultipleSeriesRenderer renderer) { renderer.setChartTitle( "个人收支表" );//设置柱图名称 renderer.setXTitle( "名单" );//设置X轴名称 renderer.setYTitle( "金额" );//设置Y轴名称 renderer.setXAxisMin(0.5);//设置X轴的最小值为0.5 renderer.setXAxisMax(5.5);//设置X轴的最大值为5 renderer.setYAxisMin(0);//设置Y轴的最小值为0 renderer.setYAxisMax(500);//设置Y轴最大值为500 renderer.setDisplayChartValues(true); //设置是否在柱体上方显示值 renderer.setShowGrid(true);//设置是否在图表中显示网格 renderer.setXLabels(0);//设置X轴显示的刻度标签的个数 }
接下去我们再来看数据设置器
//数据设置 private XYMultipleSeriesDataset getBarDataset(Cursor cur) { XYMultipleSeriesDataset dataset = new XYMultipleSeriesDataset(); CategorySeries series = new CategorySeries( "本月金额"); //声明一个柱形图 //为柱形图添加值 while(cur.moveToNext()) series.add(cur.getDouble(cur.getColumnIndex("money"))); dataset.addSeries(series.toXYSeries());//添加该柱形图到数据设置列表 return dataset; }
现在我们一张简单图表就建立好了,但是我们会发现我们并没有用到_name这个字段,所以为了让X轴上面的刻度标签显示为_name这个字段中的值,我们需要写这样一段代码:
cur.moveToFirst(); int count=1; do{ renderer.addTextLabel(count,cur.getString(cur.getColumnIndex("_name))); count++; }while(cur.moveToNext)
另外需要注意的是
在初始化描绘器的时候一定要加上renderer.setXLabels(0);
现在大功告成 ,我们再为这个Activity添加一个跳转图表的Intent就完成了
Intent intent = ChartFactory.getBarChartIntent (this , dataset, renderer, Type.DEFAULT );
效果如图: