1,請問怎樣顯示折線上點的數值?
render.setDisplayChartValues(true) ;
2,請問,怎麼設置 線的粗細?
XYSeriesRenderer.setLineWidth(float lineWidth)方法
3,可不可以禁止報表的拖動
renderer.setPanEnabled(false, false);
就一個Activity
Java代碼
package com.zzl.test;
import java.util.ArrayList;
import java.util.HashMap;
import java.util.Map;
import java.util.Random;
import org.achartengine.ChartFactory;
import org.achartengine.chart.BarChart.Type;
import org.achartengine.model.CategorySeries;
import org.achartengine.model.XYMultipleSeriesDataset;
import org.achartengine.model.XYSeries;
import org.achartengine.renderer.SimpleSeriesRenderer;
import org.achartengine.renderer.XYMultipleSeriesRenderer;
import org.achartengine.renderer.XYSeriesRenderer;
import android.app.Activity;
import android.app.ListActivity;
import android.content.Intent;
import android.graphics.Color;
import android.os.Bundle;
import android.view.View;
import android.widget.ListView;
import android.widget.SimpleAdapter;
/**
* 折線圖測試
* @author 無敵小鋼炮
* 2月28日
*/
public class MainActivity extends ListActivity {
private static final int SERIES_NR = 2;
private ArrayList<Map<String, String>> maps = new ArrayList<Map<String, String>>();
@Override
public void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
// setContentView(R.layout.main);
// 加入ListItem “調度查詢”
HashMap<String, String> map = new HashMap<String, String>();
map.put("name", "折線圖");
map.put("desc", "顯示折線圖");
maps.add(map);
// 構建listView的適配器
SimpleAdapter adapter = new SimpleAdapter(this, maps,
android.R.layout.simple_list_item_2,// SDK庫中提供的一個包含兩個TextView的layout
new String[] { "name", "desc" },// maps中的兩個key
new int[] { android.R.id.text1, android.R.id.text2 }// 兩個TextView的id
);
this.setListAdapter(adapter);
}
// ListItem監聽器方法
protected void onListItemClick(ListView l, View v, int position, long id) {
super.onListItemClick(l, v, position, id);
Intent intent = ChartFactory.getLineChartIntent(this, getDataset(),
getRenderer());
startActivity(intent);
}
private XYMultipleSeriesDataset getDataset() {
XYMultipleSeriesDataset dataset = new XYMultipleSeriesDataset();
final int nr = 10;// 每個系列種包含10個隨機數
Random r = new Random();
for (int i = 0; i < SERIES_NR; i++) {
// 新建一個系列(線條)
XYSeries series = new XYSeries("Series" + (i + 1));
for (int k = 0; k < nr; k++) {
int x = r.nextInt() % 10;// x:0-10之間的隨機整數
int y = 50 + r.nextInt() % 50;// y:50-100之間的隨機整數
series.add(x, y);// 往系列中加入一個隨機分佈的點
}
// 把添加了點的折線放入dataset
dataset.addSeries(series);
}
return dataset;
}
/**
* 構建了XYMultipleSeriesRenderer,在其中加入了兩個Series。
* 注意,這裏的Series要用XYSeriesRenderer ,而不能使用 SimpleSeriesRenderer。
*/
public XYMultipleSeriesRenderer getRenderer() {
// 新建一個xymultipleseries
XYMultipleSeriesRenderer renderer = new XYMultipleSeriesRenderer();
renderer.setAxisTitleTextSize(16);// 設置座標軸標題文本大小
renderer.setChartTitleTextSize(20); // 設置圖表標題文本大小
renderer.setLabelsTextSize(15); // 設置軸標籤文本大小
renderer.setLegendTextSize(15); // 設置圖例文本大小
renderer.setMargins(new int[] { 20, 30, 15, 0 }); // 設置4邊留白
// 設置一個系列的顏色爲藍色
XYSeriesRenderer r = new XYSeriesRenderer();
r.setColor(Color.BLUE);
// 往xymultiplerender中增加一個系列
renderer.addSeriesRenderer(r);
// 設置另一個系列的顏色爲紅色
r = new XYSeriesRenderer();
r.setColor(Color.GREEN);
// 往xymultiplerender中增加另一個系列
renderer.addSeriesRenderer(r);
return renderer;
}
}