android開發圖表achartengine之柱狀圖

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.設置渲染參數和類型

 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 "西安");//在指定座標處顯示文字

        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);// 調整合適的位置

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加載到佈局中

layout=(LinearLayout)findViewById(R.id.linearlayout);
layout.removeAllViews();
layout.setBackgroundColor(Color.BLACK);
layout.addView(graphicalView, new LayoutParams(LayoutParams.FILL_PARENT,LayoutParams.FILL_PARENT));


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