AChartEngine畫折線圖

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;

	}

}


發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章