今日长缨在手,何时缚住苍龙。这篇文章主要讲述Android仿“守望先锋”加载动画相关的知识,希望能为你提供帮助。
转载请注明本文出自大苞米的博客(
http://blog.csdn.net/a396901990)
,
谢谢支持!
效果图
文章图片
文章图片
【Android仿“守望先锋”加载动画】
文章图片
实现思路
- 画一个小六边形
- 按效果图位置画七个小六边形
- 实现一个小六边形的显示与隐藏动画
- 按顺序播放七个小六边形的动画
画一个六边形只需要知道位置与大小。
位置这里使用中心点, 大小使用中心点到顶点的距离。根据这两个数据就可以通过数学方法很容易的求出6个顶点坐标。
求出6个顶点坐标后可以通过
canvas.drawPath
来画出六边形:
Paint mPaint =
new Paint();
mPaint.setColor(mLoadingView.color);
mPaint.setStrokeWidth(3);
mPaint.setAlpha(0);
CornerPathEffect corEffect =
new CornerPathEffect(length / CORNER_PATH_EFFECT_SCALE);
mPaint.setPathEffect(corEffect);
PointF[] points =
getHexagonPoints(centerPoint, length);
Path mPath =
new Path();
mPath.moveTo(points[1].x, points[1].y);
mPath.lineTo(points[2].x, points[2].y);
mPath.lineTo(points[3].x, points[3].y);
mPath.lineTo(points[4].x, points[4].y);
mPath.lineTo(points[5].x, points[5].y);
mPath.lineTo(points[6].x, points[6].y);
mPath.close();
canvas.drawPath(mPath, mPaint);
按效果图位置画七出个小六边形
仔细观察效果图可以发现七个小六边形其实就是一个旋转后的大六边形的6个顶点+ 1个中心点, 如下图所示:
文章图片
这里有个坑, 就是一定要注意大六边形和小六边形的边长问题!实现一个小六边形的显示与隐藏动画
另外, 其实用纯数学算出6个小六边形的中心点也是很容易的。。。
动画效果分两种, 一个是显示, 一个是隐藏。这里使用ValueAnimator来实现:
显示: 先放大并改变透明度
ValueAnimator mShowAnimation =
ValueAnimator.ofFloat(0, 1);
mShowAnimation.setDuration(ANIMATION_DURATION);
mShowAnimation.setInterpolator(new DecelerateInterpolator());
mShowAnimation.addUpdateListener(new ValueAnimator.AnimatorUpdateListener() {
@
Override
public void onAnimationUpdate(ValueAnimator animation) {
float animValue =
(float) animation.getAnimatedValue();
mScale =
0.5f +
animValue / 2;
mPaint.setAlpha((int) (animValue * 255));
mLoadingView.invalidate();
}
});
隐藏:
ValueAnimator mHideAnimation =
ValueAnimator.ofFloat(1, 0);
mHideAnimation.setDuration(ANIMATION_DURATION);
mHideAnimation.setInterpolator(new DecelerateInterpolator());
mHideAnimation.addUpdateListener(new ValueAnimator.AnimatorUpdateListener() {
@
Override
public void onAnimationUpdate(ValueAnimator animation) {
float animValue =
(float) animation.getAnimatedValue();
mScale =
0.5f +
animValue / 2;
mPaint.setAlpha((int) (animValue * 255));
mLoadingView.invalidate();
}
});
隐藏动画其实就是把显示动画倒过来, 因此直接将显示动画reverse也可。按顺序播放七个小六边形的动画
根据效果图, 我们将7个小六边形编号为1, 2, 3, 4, 5, 6, 7。则一轮动画为:
1显示 -> 2显示 -> 3显示 -> 4显示 -> 5显示 -> 6显示 -> 7显示 -> 1隐藏 -> 2隐藏 -> 3隐藏 -> 4隐藏 -> 5隐藏 -> 6隐藏 -> 7隐藏android中可以使用
AnimatorSet
的playSequentially
方法来播放一组顺序动画,
所以我们只要不停的播放这个动画序列就ok了!
代码如下:
AnimatorSet mPlayAnimator =
new AnimatorSet();
ArrayList<
Animator>
animators =
new ArrayList<
>
();
// add show animation
for (OverWatchViewItem item : items) {
animators.add(item.getShowAnimation());
}// add hide animation
for (OverWatchViewItem item : items) {
animators.add(item.getHideAnimation());
}// 播放动画序列
mPlayAnimator.playSequentially(animators);
mPlayAnimator.start();
最后 Github地址:
https://github.com/a396901990/LoadingView-OverWatch
推荐阅读
- [Android]Android统计Apk ,jar包方法数
- Android studio 第三次作业
- Android实战之旅 006Android中的HTTP通信
- Android之ViewPager 第二课
- Android开发之神奇的Fading Edge,让你的View更有层次感!
- 学习笔记Android中Service通信
- A缓冲法详细指南(图解)
- 算法设计(如何解决布尔矩阵问题(?))
- 算法设计(如何解决布尔数组难题())