您的位置:首页 > 移动开发 > Android开发

Android MPAndroidChart使用教程和源码分析(五)

2016-09-02 17:05 543 查看
一.概述

    MPAndroidChart是一款基于Android的开源图表库,MPAndroidChart不仅可以在Android设备上绘制各种统计图表,而且可以对图表进行拖动和缩放操作,应用起来非常灵活。MPAndroidChart同样拥有常用的图表类型:线型图、饼图、柱状图和散点图。

GitHub地址:
https://github.com/PhilJay/MPAndroidChart
二.实例讲解

下面先以BarChart为例讲解一下在Chart类的基础上,开发者为BarChart准备的实例化好的组成部分。

经过前两篇文章的分析,我们知道一个基本的Chart实例应该是是有这么几部分组成的:

(1)DataRenderer(数据渲染器)

(2)Legend(图例)

(3)Axis(坐标轴)

(4)Listener(一开始我们分析,Chart类的监听器有两个,但是经过源码分析,我们得知Chart的基本监听器有三个)
(5)Animator:动画显示
(6)Data:图表数据(根源的数据怎么能忘记呢)

(7)MarkerView
(8)HighLighter(高亮覆盖显示)
(9)ViewPortHandler(暂时理解为绘图区域)
下面呢,我将以BarChart为例讲解Chart的这些基本组成部分都是怎么被具像化,怎么样工作的:
今天我们把剩下的部分讲解一下,主要有监听器和动画这两个部分。

首先是动画部分,在此图表库中的动画是以属性动画为基础的,动画类主要提供了在X轴和Y轴上以及同时在XY轴上运动的平移和缩放动画

public void animateXY(int durationMillisX, int durationMillisY, EasingFunction easingX,
EasingFunction easingY) {
}

public void animateX(int durationMillis, EasingFunction easing) {

}

public void animateY(int durationMillis, EasingFunction easing) {

}
<
4000
em>
public void animateXY(int durationMillisX, int durationMillisY, Easing.EasingOption easingX,
Easing.EasingOption easingY) {

}

public void animateX(int durationMillis, Easing.EasingOption easing) {

}

public void animateY(int durationMillis, Easing.EasingOption easing) {

}

public void animateXY(int durationMillisX, int durationMillisY) {

}

public void animateX(int durationMillis) {

}

public void animateY(int durationMillis) {

}

然后再讲一下监听器,在图表库中的监听器主要有三个:

/**
* Gesture listener for custom callbacks when making gestures on the chart.
*/
private OnChartGestureListener mGestureListener;

/**
* listener that is called when a value on the chart is selected
*/
protected OnChartValueSelectedListener mSelectionListener;

protected ChartTouchListener mChartTouchListener;


public void highlightValue(Highlight high, boolean callListener) {
Entry e = null;
if (high == null)
mIndicesToHighlight = null;
else {
if (mLogEnabled)
Log.i(LOG_TAG, "Highlighted: " + high.toString());
e = mData.getEntryForHighlight(high);
if (e == null) {
mIndicesToHighlight = null;
high = null;
} else {
if (this instanceof BarLineChartBase
&& ((BarLineChartBase)this).isHighlightFullBarEnabled())
high = new Highlight(high.getXIndex(), Float.NaN, -1, -1, -1);
// set the indices to highlight
mIndicesToHighlight = new Highlight[]{
high
};
}
}

if (callListener && mSelectionListener != null) {
if (!valuesToHighlight())
mSelectionListener.onNothingSelected();
else {
// 当使用到highValue时,在此处通知监听器触发
mSelectionListener.onValueSelected(e, high.getDataSetIndex(), high);
}
}
// redraw the chart
invalidate();
}

public void highlightValues(Highlight[] highs) {
// set the indices to highlight
mIndicesToHighlight = highs;
if (highs == null || highs.length <= 0 || highs[0] == null) {
mChartTouchListener.setLastHighlighted(null);
} else {//当使用到highValues时,通知 mChartTouchListener触发
mChartTouchListener.setLastHighlighted(highs[0]);
}
// redraw the chart
invalidate();
}


这三个监听器声明在Chart基类中的,我们想要执行我们自定义的监听器就需要在Chart类及其子类的实例对象中初始化一个新的监听器然后传入到Chart内部完成监听器工作。我们可以在监听器中得到位置和该位置上的实体等信息

源码分析到着已经将所有的基础部分全部分析完毕,接下来的博客将介绍自己的自定义方法,敬请期待:::::
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息