本专题讲解MPAndroid的使用, 从具体实例出发, 本节讲解库的基本使用.
参考文献: 官方文档
利用本库来画图的流程分三步: 添加依赖, 创建视图和添加数据.
一. 添加依赖
- 在项目build.gradle文件下
allprojects {
repositories {
maven { url "https://jitpack.io" }
}
}
- 在模块build.gradle文件下
dependencies {
implementation 'com.github.PhilJay:MPAndroidChart:v3.0.3'
}
二. 创建视图
就跟普通控件一样使用, 在.xml文件中定义, 在活动中获取, 比如:
// in this example, a LineChart is initialized from xml
LineChart chart = (LineChart) findViewById(R.id.chart);
三. 添加数据
有了控件, 必须有数据才能画图呀. 这里我们用LineChart来举例.
我们都知道, 画二维图的基本元素是一个点(x, y). 在此框架中, 用Entry类型来封装X轴和Y轴值, 作为最小数据单元. 注意此Entry是框架中的数据类型, 不是容器中的Entry.
YourData[] dataObjects = ...;
List entries = new ArrayList();
for (YourData data : dataObjects) {
// turn your data into Entry objects
entries.add(new Entry(data.getValueX(), data.getValueY()));
}
有了一个List
的数据源后, 需要将其封装到一个LineDataSet数据类型中. 在这个数据类型中做一些画图的个性化操作, 比如设置划线颜色, 设置值的字体颜色等等.
LineDataSet dataSet = new LineDataSet(entries, "Label"); // add entries to dataset
dataSet.setColor(...);
dataSet.setValueTextColor(...); // styling, ...
最后的最后, 把设置完成的DataSet数据封装到一个LineData数据类型中. 此数据类型才能被画图控件识别并加载.
LineData lineData = new LineData(dataSet);
chart.setData(lineData);
chart.invalidate(); // refresh
到此为止, 一张折线图就画出来了