Android教程網
  1. 首頁
  2. Android 技術
  3. Android 手機
  4. Android 系統教程
  5. Android 游戲
 Android教程網 >> Android技術 >> 關於Android編程 >> Android----畫柱狀圖和餅圖

Android----畫柱狀圖和餅圖

編輯:關於Android編程

使用GraphicalView畫柱狀圖和餅圖

 

一.achartengine庫的下載,下載地址:

www.2cto.com

下載完成後,把jar文件粘貼到libs文件夾

achartengine是為Android設計的繪圖工具庫。

二.在android項目中如何使用

先定義一個GraphicalView

GraphicalView graphicalView;

然後,從chartfactory獲取

 

graphicalView=ChartFactory.getBarChartView(getBaseContext(), dataset, renderer, type);//柱狀圖
graphicalView=ChartFactory.getPieChartView(getBaseContext(), dataset, renderer);//餅狀圖

 

其中的dataset表示數據源,renderer表示渲染參數,type表示類型

設置dataset的方法--餅圖

double[] values={412.0,542.0,486.0,900.1};
CategorySeries dataset=buildCategoryDataset(測試餅圖, values);

protected CategorySeries buildCategoryDataset(String title, double[] values) {
        CategorySeries series = new CategorySeries(title);
        series.add(差, values[0]);
        series.add(不達標, values[1]);
        series.add(達標, values[2]);
        series.add(優秀,values[3]);
        return series;
      }

設置dataset的方法--柱狀圖----柱狀圖可以有多組數據

 

1 String[] titles={test};
2         List values=new ArrayList();
3         values.add(new double[]{5120.0,21251.0,25610.0});
4         XYMultipleSeriesDataset dataset=buildBarDataset(titles, values);

protected XYMultipleSeriesDataset buildBarDataset(String[] titles, List 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;
        }

設置renderer的方法--餅圖

 

 

1 int[] colors={Color.BLUE,Color.GREEN,Color.MAGENTA,Color.RED};
2 DefaultRenderer renderer=buildCategoryRenderer(colors);

 

設置renderer的方法----餅圖

protected DefaultRenderer buildCategoryRenderer(int[] colors) {
        DefaultRenderer renderer = new DefaultRenderer();
       
        renderer.setLegendTextSize(20);//設置左下角表注的文字大小
      //renderer.setZoomButtonsVisible(true);//設置顯示放大縮小按鈕  
        renderer.setZoomEnabled(false);//設置不允許放大縮小.  
          renderer.setChartTitleTextSize(30);//設置圖表標題的文字大小
          renderer.setChartTitle(統計結果);//設置圖表的標題  默認是居中頂部顯示
          renderer.setLabelsTextSize(20);//餅圖上標記文字的字體大小
          //renderer.setLabelsColor(Color.WHITE);//餅圖上標記文字的顏色
          renderer.setPanEnabled(false);//設置是否可以平移
          //renderer.setDisplayValues(true);//是否顯示值
          renderer.setClickEnabled(true);//設置是否可以被點擊
        renderer.setMargins(new int[] { 20, 30, 15,0 });
        //margins - an array containing the margin size values, in this order: top, left, bottom, right
        for (int color : colors) {
          SimpleSeriesRenderer r = new SimpleSeriesRenderer();
          r.setColor(color);
          renderer.addSeriesRenderer(r);
        }
        return renderer;
      }

設置renderer的方法----柱狀圖

 

 

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, Color.GRAY, Color.LTGRAY);
        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(2.0, 220kv電力線);//在指定坐標處顯示文字
        // 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;
        }

最後將graphicalView放入指定的layout裡
1 layout=(LinearLayout)findViewById(R.id.linearlayout);
2 layout.removeAllViews();
3 layout.setBackgroundColor(Color.BLACK);
4 layout.addView(graphicalView, new LayoutParams(LayoutParams.FILL_PARENT,LayoutParams.FILL_PARENT));

效果截圖

 

\


  1. 上一頁:
  2. 下一頁:
熱門文章
閱讀排行版
Copyright © Android教程網 All Rights Reserved