1.在布局文件中加入LinearLayout布局,如下:

<LinearLayout android:id="@+id/chart"
android:orientation="horizontal"
android:layout_width="fill_parent"
android:layout_height="fill_parent"
android:background="@color/white"
android:layout_weight="1"
/>

2.写一个类,封装了画图函数:AchartViewUtil

<pre name="code" class="java">package ujs.testchart.view;

import org.achartengine.chart.PointStyle;
import org.achartengine.model.XYMultipleSeriesDataset;
import org.achartengine.model.XYSeries;
import org.achartengine.renderer.XYMultipleSeriesRenderer;
import org.achartengine.renderer.XYSeriesRenderer; import android.graphics.Color;
import android.graphics.Paint.Align; public class AchartViewUtil {
/**
* 获取数据
*
* @return 返回XYMultipleSeriesDataset
* @yData 设置y轴的数据
*/
public static XYMultipleSeriesDataset getBarDemoDataset(double[] xData,
double[] yData) {
XYMultipleSeriesDataset dataset = new XYMultipleSeriesDataset();
XYSeries series = new XYSeries("Demo series " + 1);
int length = 255;
series.clear();
if (yData == null) {
yData = xData;
}
for (int k = 0; k < length; k++) {
series.add(xData[k], yData[k]);
}
dataset.addSeries(series);
return dataset;
} public static XYMultipleSeriesRenderer getBarDemoRenderer(double yStart,
double yEnd) {
XYMultipleSeriesRenderer renderer = new XYMultipleSeriesRenderer();
XYSeriesRenderer r = new XYSeriesRenderer();
r.setColor(Color.GREEN);
renderer.addSeriesRenderer(r);
r.setPointStyle(PointStyle.POINT);// 点的类型(圆形、方形或者没有)
r.setFillPoints(false);// 设置点是否实心
r.setLineWidth(3);
setChartSettings(renderer, yStart, yEnd);
return renderer;
} public static void setChartSettings(XYMultipleSeriesRenderer renderer,
double yStart, double yEnd) {
renderer.setMargins(new int[] { 50, 70, 50, 30 }); // 设置图表的外边框(上/左/下/右)
renderer.setApplyBackgroundColor(true); // 设置是否显示背景色
renderer.setBackgroundColor(Color.argb(00, 265, 265, 265));// 设置背景颜色
renderer.setAxisTitleTextSize(16); // 设置轴标题文字的大小
renderer.setChartTitleTextSize(10); // 设置整个图表标题文字大小
renderer.setLabelsTextSize(22); // 设置刻度显示文字的大小(XY轴都会被设置)
renderer.setLegendTextSize(15); // 图例文字大小
renderer.setZoomButtonsVisible(false); // 是否显示放大缩小按钮
renderer.setPointSize((float) 2); // 设置点的大小(图上显示的点的大小和图例中点的大小都会被设置)
renderer.setXAxisMin(320); // 设置X轴的最小值
renderer.setXAxisMax(780); // 设置X轴的最大值
renderer.setYAxisMin(yStart); // 设置Y轴的最小值
renderer.setYAxisMax(yEnd); // 设置Y轴的最大值
renderer.setAxesColor(Color.GREEN); // 设置X轴的颜色
renderer.setLabelsColor(Color.GREEN); // 设置Y轴的颜色
// renderer.setXLabels(6);
// //设置x轴显示6个点,根据setChartSettings的最大值和最小值自动计算点的间隔
// renderer.setYLabels(8);
// //设置y轴显示6个点,根据setChartSettings的最大值和最小值自动计算点的间隔
renderer.setShowGridY(false); // 是否显示Y网格
renderer.setShowGridX(true); // 是否显示X方向的网格
renderer.setGridColor(Color.GRAY); // 设置网格的颜色
renderer.setXLabelsAlign(Align.CENTER); // 刻度线与刻度标注之间的相对位置关系
renderer.setYLabelsAlign(Align.RIGHT); // 刻度线与刻度标注之间的相对位置关系
renderer.setZoomButtonsVisible(false); // 是否显示放大缩小按钮
renderer.setPanEnabled(false, true); // 设置是否允许XY轴方向移动
renderer.setShowLegend(false); // 设置是否显示图例
renderer.setMarginsColor(Color.WHITE); // 设置外框颜色穿透背景色
renderer.setXTitle("波长(nm)"); // 设置xy轴的坐标
renderer.setYTitle("A/D counts");
}
}

然后有进一步封装了一下:这个就比较简单了:SimplifyUtil.java,这样对数据的支持更好一些

package ujs.nir.jpminispec;

import org.achartengine.ChartFactory;
import org.achartengine.GraphicalView;
import org.achartengine.renderer.XYMultipleSeriesRenderer; import ujs.testchart.view.AchartViewUtil;
import android.app.ActionBar.LayoutParams;
import android.content.Context;
import android.widget.LinearLayout; public class SimplifyUtil {
// 依据AchartViewUtil封装的类进一步简化画图步骤
public void showView(Context context, LinearLayout layout, double x[],
double y[]) {
// 图表工具
XYMultipleSeriesRenderer renderer = AchartViewUtil.getBarDemoRenderer(
0, 50000);
layout.removeAllViews(); // 这个方法是用来辅助实现刷新功能
GraphicalView mChartView = ChartFactory.getCubeLineChartView(context,
AchartViewUtil.getBarDemoDataset(x, y), renderer, 0.3f);// 设置曲线的平滑smooth
// mChartView.postInvalidate();
layout.addView(mChartView, new LayoutParams(LayoutParams.WRAP_CONTENT,
LayoutParams.WRAP_CONTENT)); }
}

3.在Activity中加入代码,显示出控件:

package com.example.achartview;

import org.achartengine.ChartFactory;
import org.achartengine.GraphicalView;
import org.achartengine.renderer.XYMultipleSeriesRenderer; import android.app.ActionBar.LayoutParams;
import android.os.Bundle;
import android.support.v7.app.ActionBarActivity;
import android.view.Menu;
import android.view.MenuItem;
import android.widget.LinearLayout; public class MainActivity extends ActionBarActivity {
double yData[] = new double[]{0,2,3,4,5,8,9,10};
String[] date = new String[]{"0","1","2","3","4","5","6","7"};
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
XYMultipleSeriesRenderer renderer = DrawableUtil.getBarDemoRenderer(date,0,10);
LinearLayout layout = (LinearLayout) findViewById(R.id.chart); //绑定控件
SimplifyUtil simplifyUtil = new SimplifyUtil();
<span style="white-space:pre"> </span>simplifyUtil.showView(ScanSpec.this, layout, xv, resultData);//最后两个对应的是将要填充的x、y的数据,可能会报错,因为android机制的原因:不能UI线程中,需要自己写个新的线程
} @Override
public boolean onCreateOptionsMenu(Menu menu) {
// Inflate the menu; this adds items to the action bar if it is present.
getMenuInflater().inflate(R.menu.main, menu);
return true;
} @Override
public boolean onOptionsItemSelected(MenuItem item) {
// Handle action bar item clicks here. The action bar will
// automatically handle clicks on the Home/Up button, so long
// as you specify a parent activity in AndroidManifest.xml.
int id = item.getItemId();
if (id == R.id.action_settings) {
return true;
}
return super.onOptionsItemSelected(item);
}
}

注意AchartEngine是一个开源插件,点击访问

Android使用AchartEngine绘制曲线图的更多相关文章

  1. 【Android】achartengine的柱状图和饼状图的使用

    本文介绍了android中如何使用achartengine绘制饼图和柱状图,请分别尝试饼图和柱状图,曲线图. 先看效果图: 先看看获取数据: Workbook workbook = Workbook. ...

  2. AChartEngine绘制图形

    AChartEngine是Android作图的方法之一,要使用AChartEngine,首先下载AChartEngine,按照以下方法将其jar包添加到工程中: 1.将achartengine-1.1 ...

  3. Android实现图表绘制和展示

    本文演示在Android平台中绘制和展示图表示例,本示例是基于RChart 2实现的. 在一个系统中经常要用到图表统计数据,在WEB开发中图表绘制是一件简单的事情,因为有比较多的开源方案.但在Andr ...

  4. Android View 如何绘制

    上文说道了Android如何测量,但是一个漂亮的控件我只知道您长到哪儿,这当然不行.只需要简单重写OnDraw方法,并在Canvas(画布)对象上调用那根五颜六色的画笔就能够画出这控件"性感 ...

  5. Android View的绘制机制流程深入详解(四)

    本系列文章主要着重深入介绍Android View的绘制机制及流程,第四篇主要介绍Android自定义View及ViewGroup的实现方法和流程. 主要介绍了自绘控件.自定义组合控件.自定义继承控件 ...

  6. Android View的绘制机制流程深入详解(三)

    本系列文章主要着重深入介绍Android View的绘制机制及流程,第三篇主要介绍并分析视图状态以及重绘流程,首先剖析了 视图的几种状态,然后在深入分析视图的重绘机制流程. 真题园网:http://w ...

  7. Android View的绘制机制流程深入详解(二)

    本系列文章主要着重深入介绍Android View的绘制机制及流程,第二篇主要介绍并分析Android视图的绘制的原理和流程.主要从 onMeasure().onLayout()和onDraw()这三 ...

  8. Android View的绘制机制流程深入详解(一)

    本系列文章主要着重深入介绍Android View的绘制机制及流程,第一篇主要介绍并分析LayoutInflater的原理, 从而理解setContentView的加载原理.对于LayoutInfla ...

  9. 使用.net 的Chart控件绘制曲线图

    在进行软件开发过程中我们可能会碰到需要生成图表的情况,在.NET中以前经常用GDI去绘制,虽然效果也不错,自从.NET 4.0开始,专门为绘制图表而生的Chart控件出现了,有了它,就可以轻松的绘制你 ...

随机推荐

  1. 【Lintcode】038.Search a 2D Matrix II

    题目: Write an efficient algorithm that searches for a value in an m x n matrix, return the occurrence ...

  2. Trie 树内存消耗问题

    大家都知道,Trie树(又称字典树)是一种树型数据结构,用于保存大量的字符串.它的优点是:利用字符串的公共前缀来节约存储空间. 相对来说,Trie树是一种比较简单的数据结构,比较易于理解.话说上帝是公 ...

  3. [poj3071]football概率dp

    题意:n支队伍两两进行比赛,求最有可能获得冠军的队伍. 解题关键:概率dp,转移方程:$dp[i][j] +  = dp[i][j]*dp[i][k]*p[j][k]$表示第$i$回合$j$获胜的概率 ...

  4. HDU - 1171 Big Event in HDU 多重背包

    B - Big Event in HDU Nowadays, we all know that Computer College is the biggest department in HDU. B ...

  5. [UE4]如何替换角色Mesh上的Material材质

    http://www.dawnarc.com/2016/10/ue4%E5%A6%82%E4%BD%95%E6%9B%BF%E6%8D%A2%E8%A7%92%E8%89%B2mesh%E4%B8%8 ...

  6. Spfa算法模板

    输入点数n,边数m,起点终点边权 输出1号节点到所有点的最短路径长度 #include<iostream> #include<queue> #include<cstrin ...

  7. 洛谷P3190 [HNOI2007]神奇游乐园(插头dp)

    传送门 大概是算第一道自己做出来的插头dp? (虽然都是照着抄板子的) (虽然有个地方死活没调出来最后只能看题解才发现自己错在哪里的) 我就当你们都会插头dp了…… 因为必须得是一条路径,所以扫描线上 ...

  8. 4.Python的不堪一击到初学乍练(列表,元组)

    Python(列表,元组) 一.列表 列表初识 列表是python的基础数据类型之一,其他编程语言也有类似的数据类型. 比如JS中的数组, java中的数组等等,它是以[ ]括起来, 每个元素用&qu ...

  9. Solidity 最新 0.5.8 中文文档发布

    本文首发于深入浅出区块链社区 热烈祝贺 Solidity 最新 0.5.8 中文文档发布, 这不单是一份 Solidity 速查手册,更是一份深入以太坊智能合约开发宝典. 翻译说明 Solidity ...

  10. MySQL事务学习