1.下載achartengine庫 http://code.google.com/p/achartengine/downloads/list 2.GraphicalView graphicalView; graphicalView=ChartFactory.getBarChartView(getBaseContext(), dataset, renderer, type);//柱狀圖 graphicalView=ChartFactory.getPieChartView(getBaseContext(), dataset, renderer);//餅狀圖 註解:dataset表示數據源,renderer表示渲染參數,type表示類型 3.設置dataset數據源 String[] titles={"test"}; List<double[]> values=new ArrayList<double[]>(); values.add(new double[]{5120.0,21251.0,25610.0}); XYMultipleSeriesDataset dataset=buildBarDataset(titles, values); 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; }
4.設置渲染參數和類型ide
int[] colors={Color.BLUE};
XYMultipleSeriesRenderer renderer=buildBarRenderer(colors);
Type type=Type.DEFAULT;
//renderer.setZoomEnabled(false);//怎麼失效了----使用下面的方式
renderer.setZoomEnabled(false, false);//成功控制--嘿嘿
setChartSettings(renderer, "我是柱狀圖的標題", "", "統計結果", 0, 6, 0, 30000);
renderer.getSeriesRendererAt(0).setDisplayChartValues(true);
//renderer.getSeriesRendererAt(1).setDisplayChartValues(true);
renderer.setXLabels(0);//設置x軸上的下標數量
renderer.setYLabels(10); //設置y軸上的下標數量
renderer.setXLabelsAlign(Align.RIGHT);
renderer.setYLabelsAlign(Align.LEFT);//y軸 數字表示在座標仍是右邊
renderer.setPanEnabled(false, false);//設置是否容許平移
renderer.addXTextLabel(1 "成都");//在指定座標處顯示文字佈局
renderer.addXTextLabel(2 "西安");//在指定座標處顯示文字ui
renderer.addXTextLabel(3 "富平");//在指定座標處顯示文字
// renderer.clearXTextLabels();//清除 labels
//renderer.setZoomRate(1.1f);//設置放縮比
renderer.setBarSpacing(1f);// 設置柱狀的間距
//renderer.setLabelsTextSize(30);//設置座標軸上數字的大小
renderer.setXLabelsAngle(300.0f);//設置文字旋轉角度 對文字順時針旋轉
renderer.setXLabelsPadding(10);//設置文字和軸的距離
renderer.setFitLegend(true);// 調整合適的位置google
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; }private void setChartSettings(XYMultipleSeriesRenderer renderer, String title, String xlable, String ylable, int xmin, int xmax, int ymin, int ymax) { renderer.setChartTitle(title); renderer.setXTitle(xlable); renderer.setYTitle(ylable); renderer.setXAxisMin(xmin); renderer.setXAxisMax(xmax); renderer.setYAxisMin(ymin); renderer.setYAxisMax(ymax); }
5,將graphicalView加載到佈局中code
layout=(LinearLayout)findViewById(R.id.linearlayout); layout.removeAllViews(); layout.setBackgroundColor(Color.BLACK); layout.addView(graphicalView, new LayoutParams(LayoutParams.FILL_PARENT,LayoutParams.FILL_PARENT));