MPAndroidChart使用API

XML

设置不同的图表
1. 折线图 LineChart
2. 条形图 BarChart
3. 条形折线图 Combined-Chart
4. 圆饼图 PieChart
5. 雷达图 ScatterChart
6. K线图 CandleStickChart
7. 泡泡图 BubbleChart
8. 网状图 RadarChart

Api:

一、获取控件

mChart = (LineChart) findViewById(R.id.chart);

二、给控件绑定数据

lineChart.setDescription("线性统计图");//设置统计图标注
mChart.setData(getLineData());

三、设置数据

private LineData getLineData(){
    final int DATA_COUNT = 5;  //设置折线图横跨距离
    LineDataSet dataSetA = new LineDataSet( getChartData(DATA_COUNT, 1), "A");
    //设置折线数据 getChartData返回一个List<Entry>键值对集合标识 折线点的横纵坐标,"A"代表折线标识
    LineDataSet dataSetB = new LineDataSet( getChartData(DATA_COUNT, 2), "B");

    List<ILineDataSet> dataSets = new ArrayList<>();
    dataSets.add(dataSetA);
    dataSets.add(dataSetB);
    LineData data = new LineData( getLabels(DATA_COUNT), dataSets);
    return data;    
    // 返回LineData类型数据,该类型由标识X轴单位 List<String>的 集合和一个标识折线数据的List<ILineDataSet>组成
}

四、设置X轴的单位与折线的数据

   private List<Entry> getChartData(int count, int ratio){    
         List<Entry> chartData = new ArrayList<>();    
         for(int i=0;i<count;i++){        
           chartData.add(new Entry( i*2*ratio, i));   
          }    
         return chartData;
       }
       //利用循环生成了(0,0) (2,1) (4,2) (6,3) (8,4)
       //(0,0) (4,1) (8,2) (12,3) (16,4) 这两组折线坐标 组成List<Entry>返回
        
    private List<String> getLabels(int count){    
         List<String> chartLabels = new ArrayList<>();    
         for(int i=0;i<count;i++) {        
            chartLabels.add("X" + i);    
         }    
         return chartLabels;
    }
    //生成横坐标的单位显示,(x0 x1 x2 x3 x4)这样的List<String>集合返回

对于List<Entry>和LineData均有添加和移除数据的操作方法

DataSet

    addEntry(Entry e) :在 List 最後增加 Entry
    removeFirst() :移除第一個 Entry
    removeLast() :移除最後一個 Entry
    removeEntry(Entry e) :移除指定的 Entry Object
    removeEntry(int xIndex) :移除指定 Index 的 Entry

ChartData

    addEntry(Entry e, int dataSetIndex) :新增 Entry 到指定的 DataSet
    addDataSet(DataSet d) :增加一個 DataSet
    removeEntry(Entry e, int dataSetIndex) :移除指定的 DataSet 一個 Entry
    removeEntry(int xIndex, int dataSetIndex) :移除指定的 DataSet 中的某 Index 的 Entry
    removeDataSet(DataSet d) :移除一個 DataSet
    removeDataSet(int index) :移除指定 Index 的 DataSet

再完成添加和删除操作之后,必须使用notifyDataSetChanged()和invalidate()方法来刷新View

      mChart.notifyDataSetChanged();
      mChart.invalidate();

五、设置标识及折线的颜色用以区别

      dataSetA.setColor(要设置的颜色);
      dataSetB.setColor(要设置的颜色);

六、设置每一个Entry点的样式

      dataSetA.setCircleColor(要设置的颜色);    //可以设置Entry节点的颜色
      dataSetA.setCircleSize(10f);  //设置节点的大小
      dataSetA.setDrawCircleHole(true); //是否定制节点圆心的颜色,若为false,则节点为单一的同色点,若为true则可以设置节点圆心的颜色
      dataSetA.setCircleColorHole(Color.GREEN);  //设置节点圆心的颜色

七、对图表线条进行样式定制

    dataSetA.setLineWidth(10f); //设置线条宽度
    dataSetB.setDrawCubic(true); //修改线条为平滑 
    dataSetB.enableDashedLine(5f, 5f, 0f); //设置线条为虚线 1.线条宽度2.间隔宽度3.角度
    dataSetB.setCubicIntensity(20f);//曲線彎曲強度

八、 HightLight当点击节点时,将会出现与节点水平和垂直的两条线,可以对其进行定制

      dataSetA.setHighlightLineWidth(8f); //设置线条宽度
      dataSetA.setHighLightColor(Color.CYAN);  //设置线条颜色

若要单独定制某一方向上的线,可以先把关闭线条hightlight显示

    dataSetA.setDrawHighlightIndicators(false);//关闭heightlight
    dataSetA.setDrawVerticalHighlightIndicator(true); //或者使用
    dataSetA.setDrawHorizontalHighlightIndicator(true);//来打开单独某一方向的hightlight

九、Fill填充,可以将折线图一下部分用颜色填满

dataSetA.setDrawFilled( boolean );//设置是否开启填充,默认为false

多个DataSet同时填充时,只显示最后填充的那个DataSet,其余的被覆盖

 dataSetA.setFillColor(Color.RED);//设置填充颜色
 dataSetA.setFillAlpha(85);//设置填充区域透明度,默认值为85

十、格式化Label中的数值

ValueFormat 可以设定给dataset(单一的一条线)或 Linedata(所有的线),除了自定义 ValueFormatter 外,作者提供两个定义好的 ValueFormatter 如:

LargeValueFormatter:超过一千会变成1K
PercentFormatter:显示成百分比,常用于 PieChart饼图

dataSetA.setValueFormatter(new LargeValueFormatter());

或者可以自定义一個 ValueFormatter,如:
新建类实现ValueFormatter接口,重写getFormattedValue方法

  @Override
  public String getFormattedValue(float value, Entry entry, int dataSetIndex,ViewPortHandler viewPortHandler) {
        /* ValueFormatter 一定要实现该方法
        * 此方法會把 value 跟 entry 传过来,在该方法中做一些逻辑上的处理
           回传的 format 字串将会显示在在 Label 上 */
      return mFormat.format("$" + value);
  }

十一、坐标轴Axis

Axis分为x轴和y轴
x轴 只有一个,而y轴分为左右两条轴线

获取x轴:
XAxis mXAxis = lineChart.getXAxis();
获取y轴:有两种方法,这两种方法均可
// Method 1
YAxis mLeftYAxis =lineChart.getAxisLeft();
YAxis mRightYAxis = lineChart.getAxisRight();
// Method 2
YAxis mLeftYAxis = lineChart.getAxis(YAxis.AxisDependency.LEFT);
YAxis mRightYAxis = lineChart.getAxis(YAxis.AxisDependency.RIGHT);

如果不想要出现任何 X 或 Y 轴的东西,可以 setEnabled(false)来关闭轴线

X轴出现的位置有五个:

设置 mXAxis 的位置,可以选择以下位置:

  1. TOP 默认           顶端

  2. TOP_INSIDE        顶端,label显示在x下方

  3. BOTTOM           底部

  4. BOTTOM_INSIDE      底部,Label显示在X轴上方

  5. BOTH_SIDED       上下均显示

    XAxis mXAxis = lineChart.getXAxis();  //获取X轴
    mXAxis.setPosition(XAxis.XAxisPosition.BOTH_SIDED); //设置X轴位置
    
上下均显示

Label标签的设置

mXAxis.setDrawLabels(false); // 显示 或 隐藏 
labelmXAxis.setLabelsToSkip(1); // 要略过几个 Label才会显示一个     
LabelmXAxis.resetLabelsToSkip(); //重新设定略过 Label 的设定
mXAxis.setSpaceBetweenLabels(20); // 每个列 的间距,default=4

mXAxis.setTextColor(颜色); //设置Label标签的颜色
mXAxis.setTextSize(12);//设置字体大小
mXAxis.setTypeface();//设置字体

线条设置------Line分为两种 GridLine和AxisLine

GridLine:背景中每一列与X轴垂直的线
AxisLine : 与X轴重合的线
(Y轴同样适用)
GridLine设置:

 mXAxis.setGridColor(颜色);
 mXAxis.setGridLineWidth(3); //设置垂直线的 宽度
 mXAxis.enableGridDashedLine(10f, 5f, 0f); 
 //设置垂直线为虚线,(长度,间隔,角度)

AxisLine设置:

mXAxis.setAxisLineWidth(5f);
mXAxis.setAxisLineColor(颜色);

如果不想显示线条可以关闭:

GridLinemXAxis.setDrawGridLines(false);
AxisLinemXAxis.setDrawAxisLine(false);
虚线的GridLine

Y轴的设置

y轴有左右两条,大部分时候两边需要同时设定,否則两边显示的数据会不一样,或是 Label 数值线没有对齐的状况

y轴可以设置最大最小值

mLeftYAxis.setStartAtZero(false);
mRightYAxis.setStartAtZero(false);//设置最大最小值需要先将从0开始关闭            
mLeftYAxis.setAxisMaxValue(3);
mRightYAxis.setAxisMaxValue(3);// 设置最小值   
mLeftYAxis.setAxisMinValue(-5f); //如果设置的最小值不是负数就看不到效果
mRightYAxis.setAxisMinValue(-5f);

//使用reset则可以将坐标轴还原
mLeftYAxis.resetAxisMaxValue();
mRightYAxis.resetAxisMaxValue()

如果有特殊需求,只想显示最大/小值,可以设置setShowOnlyMinMax,这个不受setStartAtZero的影响,不需要设为 False

mLeftYAxis.setShowOnlyMinMax(true);
mRightYAxis.setShowOnlyMinMax(true);

Order

设置y轴的Label以升序或者降序排列ASC 或者DESC

mLeftYAxis.setInverted(true);   //true就是升序 反之降序排列
mRightYAxis.setInverted(true);

Space

Space是设置最大值与最小值之外的宽度

设置最大值至TOP顶端的距离

mLeftYAxis.setSpaceTop(100f);
mRightYAxis.setSpaceTop(100f);

设置最小值到Bottom到底端的距离

mLeftYAxis.setSpaceBottom(100f);
mRightYAxis.setSpaceBottom(100f);

Position

设置Y轴的Label显示在图表的内侧还是外侧,默认外侧
1、OUTSIDE_CHART 默认 2、INSIDE_CHART

mRightYAxis.setPosition(YAxis.YAxisLabelPosition.INSIDE_CHART);
mLeftYAxis.setPosition(YAxis.YAxisLabelPosition.INSIDE_CHART);

Count

设置Y轴显示的label个数

mLeftYAxis.setLabelCount(7, true);
mRightYAxis.setLabelCount(7, true);
//第一个参数为Label的个数,最多25个,默认为6 
//第二个参数为 是否均匀显示长度

Offset

设置标签label与坐标轴之间的间距,有时坐标轴与数据字显示重合会影响显示效果,此时可以适当的将Label与坐标轴分开

// 設定 X 軸Offset

mLeftYAxis.setXOffset(40);
mRightYAxis.setXOffset(15);

// 設定 Y 軸Offset

mLeftYAxis.setYOffset(10);
mRightYAxis.setYOffset(10);

设置标尺限制警示线LimitLine

可以在图标上加上额外的线,表示限制或上限等等,在一开始产生 LimitLine时会带入 Value 与 String new LimitLine( flaot value , String showString ),下一步再设定给 mXAxis 或 mYAxis,并设定样式 (特別注意如果是放在 XAxis 的话,value 是指从左数过来第几个 Label)

初始化并且设置Limit外观

    LimitLine ll = new LimitLine(3f, "Limit");//线条颜色宽度等      
    ll.setLineColor(getResources().getColor(R.color.blue_gray));
    ll.setLineWidth(7f);

说明文字的部分,除了设定文字颜色、大小外,还可以设定文字的在 Limit 线的相对位置,有分为:

  1. LEFT_TOP
  2. LEFT_BOTTOM
  3. RIGHT_TOP
  4. RIGHT_BOTTOM
//文字位置

ll.setLabelPosition(LimitLine.LimitLabelPosition.LEFT_BOTTOM)//文字颜色、大小   

ll.setTextColor(getResources().getColor(R.color.blue_gray));

ll.setTextSize(12f);

加入到 mXAxis 或 mYAxis
mXAxis.addLimitLine(ll);
mLeftYAxis.addLimitLine(ll); 

不管是 XAxis 或 YAxis ,他们addLimitLine丟进去的 LimitLine,物件都是参考到同一个,所以如果把 LimitLine修改样式后再丟给其他 Axis 是不行的!

Legend图例设定

图例

通过lineChart.getLegend()取得图例,可以设置图例的大小,形状,位置,以及图例区的间距,图例和说明文字之间的位置。

设置图例位置
Legend le = lineChart.getLegend();
le.setPosition(位置);   //位置常量在Legend.LegendPosition中,还有一个饼图专用的PIECHART_CENTER
设置图例位置
图例的形状有三种
  1. CIRCLE
  2. SQUARE (默认)
  3. LINE
      le.setFormSize(10f); //图例大小
      le.setForm(Legend.LegendForm.CIRCLE); /图例形状
      //设置说明文字的大小和颜色
      le.setTextSize(12f);
      le.setTextColor(Color.GRAY);
设置间距
le.setXEntrySpace(50f); //X轴图例间距
le.setYEntrySpace(50f); //Y轴图例间距
le.setFormToTextSpace(50f); //图例和说明文字之间的间距 
//图例超过图表区长宽时,True = 保留超过部分, False = 裁切超过的部分
le.setWordWrapEnabled(true); 

十二、MakerView设置

当点击图表上的点时,将会弹出一个显示详细信息的View,所以需要设计一个MakerView继承默认的 MakerView 重写样式

public class MyMakerView extends MarkerView { 
    private TextView tvContent; 
    public MyMakerView (Context context, int layoutResource) { 
      super(context, layoutResource);
      tvContent = (TextView) findViewById(R.id.tvContent); 
    } 
  /* 每次画 MakerView 时都会触发 Callback 方法,通常会在此方法内更新 View 的內容 */ 
    @Override 
    public void refreshContent(Entry e, Highlight highlight) { 
      tvContent.setText("" + e.getVal()); 
    } 
  /* * offset 是以点到的那个点(0,0) 中心然后向右下角画出来 * 所以如果要显示在点上方 * X=宽度的一半,负数 * Y=高度的负数 */ 
  @Override 
  public int getXOffset() { 
    // this will center the marker-view horizontally 
      return -(getWidth() / 2); 
  } 
  @Override 
  public int getYOffset() { 
    // this will cause the marker-view to be above the selected value 
    return -getHeight(); 
  }
}

然后在chart里加入此makerview

  MyMakerView makerview = new MyMakerView(this,xxxxid);
  lineChart.setMakerView(makerview);

附上PieChart小例子:

  protected void onCreate(Bundle savedInstanceState) {    
      super.onCreate(savedInstanceState); 
      setContentView(R.layout.activity_pie);   
       pieChart = (PieChart) findViewById(R.id.pie_chart);    
      pieChart.setDescription("饼状图");    
       List<String> labelList = new ArrayList<>();    
       List<Entry>  valueList = new ArrayList<>();   
       for(int x =0;x<3;x++){        
            labelList.add("X"+x);    
      }    
      for (int y=0;y<3;y++){        
            valueList.add(new Entry(30f,y));   
       }    
      PieDataSet dataSet = new PieDataSet(valueList,"%");   
       List<Integer>  colors = new ArrayList<>();    
      colors.add(Color.BLUE);    
      colors.add(Color.GREEN);    
      colors.add(Color.YELLOW);   
       dataSet.setColors(colors);   
       dataSet.setValueTextSize(20f);    
      PieData pieData = new PieData(labelList,dataSet);         
     pieChart.setData(pieData);
}
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 212,686评论 6 492
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 90,668评论 3 385
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 158,160评论 0 348
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 56,736评论 1 284
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 65,847评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,043评论 1 291
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,129评论 3 410
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 37,872评论 0 268
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,318评论 1 303
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,645评论 2 327
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,777评论 1 341
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,470评论 4 333
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,126评论 3 317
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,861评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,095评论 1 267
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,589评论 2 362
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,687评论 2 351

推荐阅读更多精彩内容

  • 一、下载Charts后可以到里面的内容 将下载后解压后的整个文件夹复制到工程里 但是只导入 工程Charts.xc...
    浪周周_f157阅读 1,089评论 0 1
  • 简介 文章较长,点击直达我的博客,浏览效果更好。本文内容基本是来源于STHDA,这是一份十分详细的ggplot2使...
    taoyan阅读 51,036评论 7 159
  • Matplotlib 入门教程 来源:Introduction to Matplotlib and basic l...
    布客飞龙阅读 31,780评论 5 162
  • 每本写唐诗的评论集,都要先写初唐,然后初唐前要带隋代肇始,而又承接自南北朝。 南北朝乐府,颇有魏晋遗风,承接自汉朝...
    BG2BKK阅读 1,157评论 0 0
  • 1不要看见的都是墙 不论在经济上,还是在人际关系上!!!只要多做一点,比你想的更接近真实! 你以为别人都会很冷漠,...
    三不主义阅读 202评论 0 0