zoukankan      html  css  js  c++  java
  • android MPAndroidChart饼图实现图例后加数字或文本(定制图例)

    转载请注明:http://blog.csdn.net/ly20116/article/details/50905789

    MPAndroidChart是一个非常优秀的开源图表库,MPAndroidChart可以绘制各种常用的图表类型:折线图、柱形图、饼图、散点图等等。 
    github地址:https://github.com/PhilJay/MPAndroidChart 
    具体的导入方式就不再详细的说了,本文主要解决在图例后面加上数字或文本或占的百分比等,也就是定制想要的图例。 
    MPAndroidChart的提供的饼图图例是这种: (注:图片为引用) 
    这里写图片描述 

    而我们想要实现的效果是这种: 
    这里写图片描述

    就是在图例后面加上数字或文本

    通过借鉴Stackoverflow上的大神的解决方案: 
    https://stackoverflow.com/questions/29139061/mpandroidchart-legend-customization

    下面来开始我们的项目: 
    一、获取Legend,使Legend不显示

    Legend legend=mPieChart.getLegend();//设置比例图
    legend.setEnabled(false);//图例不显示
    • 1
    • 2

    二、定义数组colors和labels及数据datas

    private int[] colors;//颜色集合
    private String[] labels;//标签文本
    private float[] datas={16912f,2488f,600f};//数据,可以是任何类型的数据,如String,int
    • 1
    • 2
    • 3

    三、获取Legend中的colors和labels

    colors=legend.getColors();
    labels=legend.getLabels();
    • 1
    • 2

    四、定义customizeLegend()方法,实现图例的绘制

    /**
         * 定制图例,通过代码生成布局
         */
        private void customizeLegend(){
            for(int i=0;i<datas.length;i++){
                LinearLayout.LayoutParams lp=new LinearLayout.
                        LayoutParams(LayoutParams.MATCH_PARENT,LayoutParams.MATCH_PARENT);
                lp.weight=1;//设置比重为1
                LinearLayout layout=new LinearLayout(this);//单个图例的布局
                layout.setOrientation(LinearLayout.HORIZONTAL);//水平排列
                layout.setGravity(Gravity.CENTER_VERTICAL);//垂直居中
                layout.setLayoutParams(lp);
    
                //添加color
                LinearLayout.LayoutParams colorLP=new LinearLayout.
                        LayoutParams(20,20);
                colorLP.setMargins(0, 0, 20, 0);
                LinearLayout colorLayout=new LinearLayout(this);
                colorLayout.setLayoutParams(colorLP);
                colorLayout.setBackgroundColor(colors[i]);
                layout.addView(colorLayout);
    
                //添加label
                TextView labelTV=new TextView(this);
                labelTV.setText(labels[i]+" ");
                layout.addView(labelTV);
    
                //添加data
                TextView dataTV=new TextView(this);
                dataTV.setText(datas[i]+"");
                layout.addView(dataTV);
    
                legendLayout.addView(layout);//legendLayout为外层布局即整个图例布局,是在xml文件中定义
    
            }
        }
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
    • 19
    • 20
    • 21
    • 22
    • 23
    • 24
    • 25
    • 26
    • 27
    • 28
    • 29
    • 30
    • 31
    • 32
    • 33
    • 34
    • 35
    • 36

    图例示意图: 
    这里写图片描述

    customizeLegend()方法的调用可在设置图例不显示的后面,也可以在其它地方调用,但是必须在PieChart调用setData()方法的后面,这样才能获取到colors和labels.

    总结: 
    简而言之,就是获取legend的颜色colors和标签文本labels,然后结合自己的数据,在新的布局中绘制即可。 
    你可以在图例后面添加更多的类型的数据。 
    图例布局的位置可以在xml文件中设置。 
    也可以实现各种布局的图例

  • 相关阅读:
    在Android studio中使用“.jpg”图片
    杨辉三角形简便代码
    Java中对象的理解
    对数据库的简单操作
    通过分析周榜前100名专家的博客文章 手把手教你写出爆款文章
    【Spring】4.助你跟面试官侃一个小时的IOC
    【Spring】3.助你跟面试官侃一个小时的AOP
    【Spring】2.如何给面试官讲SpringBean的声明周期
    【Spring】1. Spring概要综述
    【Java并发编程】8.面试不扯点JMM怎么显得专业呢
  • 原文地址:https://www.cnblogs.com/wangfeng520/p/5664442.html
Copyright © 2011-2022 走看看