zoukankan      html  css  js  c++  java
  • android开源图表库MPAndroidChart(曲线图、直方图、饼状图)

    github地址:https://github.com/PhilJay/MPAndroidChart


    添加依赖:

    • Add the following to your project level build.gradle:
    allprojects {
    	repositories {
    		maven { url "https://jitpack.io" }
    	}
    }
    • Add this to your app build.gradle:
    dependencies {
    	compile 'com.github.PhilJay:MPAndroidChart:v3.0.2'
    }

    下载Demo演示,修改成自己的需求即可
    如饼图的示例代码:
    import android.graphics.Color;
    import android.os.Bundle;
    import android.support.v7.app.AppCompatActivity;
    import android.util.DisplayMetrics;
    
    import com.github.mikephil.charting.charts.PieChart;
    import com.github.mikephil.charting.components.Description;
    import com.github.mikephil.charting.components.Legend;
    import com.github.mikephil.charting.data.PieData;
    import com.github.mikephil.charting.data.PieDataSet;
    import com.github.mikephil.charting.data.PieEntry;
    
    import java.util.ArrayList;
    
    public class MainActivity extends AppCompatActivity {
        private PieChart mChart;
        @Override
        protected void onCreate(Bundle savedInstanceState) {
            super.onCreate(savedInstanceState);
            setContentView(R.layout.activity_main);
            mChart = (PieChart) findViewById(R.id.pieChart);
            PieData mPieData = getPieData(4, 100);
            showChart(mChart, mPieData);
        }
    
        private void showChart(PieChart pieChart, PieData pieData) {
            pieChart.setHoleColor(Color.TRANSPARENT);
            pieChart.setHoleRadius(60f);  //半径
            pieChart.setTransparentCircleRadius(64f); // 半透明圈
            //pieChart.setHoleRadius(0)  //实心圆
            Description description = new Description();
            description.setText("测试饼状图");
            pieChart.setDescription(description);
            // mChart.setDrawYValues(true);
            pieChart.setDrawCenterText(true);  //饼状图中间可以添加文字
            pieChart.setDrawHoleEnabled(true);
            pieChart.setRotationAngle(90); // 初始旋转角度
            pieChart.setRotationEnabled(true); // 可以手动旋转
            pieChart.setUsePercentValues(true);  //显示成百分比
            pieChart.setCenterText("测试");  //饼状图中间的文字
            pieChart.setCenterTextSize(18);
            //设置数据
            pieChart.setData(pieData);
            Legend mLegend = pieChart.getLegend();  //设置比例图
            mLegend.setPosition(Legend.LegendPosition.RIGHT_OF_CHART);  //最右边显示
            //      mLegend.setForm(LegendForm.LINE);  //设置比例图的形状,默认是方形
            mLegend.setXEntrySpace(7f);
            mLegend.setYEntrySpace(5f);
            pieChart.animateXY(1000, 1000);  //设置动画
        }
    
        /**
         *
         * @param count 分成几部分
         * @param range
         */
        private PieData getPieData(int count, float range) {
            ArrayList<String> xValues = new ArrayList<String>();  //xVals用来表示每个饼块上的内容
            for (int i = 0; i < count; i++) {
                xValues.add("Quarterly" + (i + 1));  //饼块上显示成Quarterly1, Quarterly2, Quarterly3, Quarterly4
            }
    
            ArrayList<PieEntry> yValues = new ArrayList();  //yVals用来表示封装每个饼块的实际数据
            // 饼图数据
            /**
             * 将一个饼形图分成四部分, 四部分的数值比例为14:14:34:38
             * 所以 14代表的百分比就是14%
             */
            float quarterly1 = 14;
            float quarterly2 = 14;
            float quarterly3 = 34;
            float quarterly4 = 38;
            yValues.add(new PieEntry(quarterly1, 0));
            yValues.add(new PieEntry(quarterly2, 1));
            yValues.add(new PieEntry(quarterly3, 2));
            yValues.add(new PieEntry(quarterly4, 3));
            //y轴的集合
            PieDataSet pieDataSet = new PieDataSet(yValues, "Quarterly Revenue 2014"/*显示在比例图上*/);
            pieDataSet.setSliceSpace(0f); //设置个饼状图之间的距离
            ArrayList<Integer> colors = new ArrayList<Integer>();
            // 饼图颜色
            colors.add(Color.rgb(205, 205, 205));
            colors.add(Color.rgb(114, 188, 223));
            colors.add(Color.rgb(255, 123, 124));
            colors.add(Color.rgb(57, 135, 200));
            pieDataSet.setColors(colors);
            DisplayMetrics metrics = getResources().getDisplayMetrics();
            float px = 5 * (metrics.densityDpi / 160f);
            pieDataSet.setSelectionShift(px); // 选中态多出的长度
            PieData pieData = new PieData(pieDataSet);
            return pieData;
        }
    }
    

     activity_main.xml

     <com.github.mikephil.charting.charts.PieChart
            android:id="@+id/pieChart"
            android:layout_width="match_parent"
            android:layout_height="320dp"
           />
    
     
  • 相关阅读:
    Next.js文档自定义App、Document,getInitialProps翻译
    使用fetch进行数据请求时报json错误
    菜单制作:ul li横向排列
    Django Auth组件->扩展用户
    001.Django_Model.整理
    PyCharm中的django项目的引入
    Css3 里的弹性盒的比例关系
    vue的组件通讯 父传子 -- 子传父-- 兄弟组件的传值 vue的组件传值
    新手如何创建一个vue项目 ---vue---新手创建第一个项目
    如何自学计算机前端开发?精细的自学步骤是什么样的?
  • 原文地址:https://www.cnblogs.com/loaderman/p/6927706.html
Copyright © 2011-2022 走看看