Android----画柱状图和饼图

使用GraphicalView画柱状图和饼图

一.achartengine库的下载,下载地址:

http://code.google.com/p/achartengine/downloads/list

下载完成后,把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<double[]> values=new ArrayList<double[]>();
3         values.add(new double[]{5120.0,21251.0,25610.0});
4         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;
        }

设置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));

效果截图

技术分享


郑重声明:本站内容如果来自互联网及其他传播媒体,其版权均属原媒体及文章作者所有。转载目的在于传递更多信息及用于网络分享,并不代表本站赞同其观点和对其真实性负责,也不构成任何其他建议。