前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >Android自定义动画根据控件Y轴旋转动画(仿红包)

Android自定义动画根据控件Y轴旋转动画(仿红包)

作者头像
砸漏
发布2020-11-05 14:50:04
9430
发布2020-11-05 14:50:04
举报
文章被收录于专栏:恩蓝脚本

这里给正在学安卓的小白们分享一个动画吧,用处挺多,代码也不多,还望各位大佬不要打击。

进入正题,先看看效果

效果很炫酷很美好

好了 来看代码吧 该说的都在代码注释里面 这个不用多说 代码极其简单

代码语言:javascript
复制
//自定义一个类继承Animation(android.view.animation.Animation)抽象类

public class MyAnimation extends Animation {

  // 先定义成员变量 //X轴的中心坐标 int center_X;

  //Y轴的中心坐标 int center_Y;

  // 初始化Camera Camera camera = new Camera();

}

接下来要注意了

重写initialize()方法

代码语言:javascript
复制
/** * 在initialize对变量进行初始化

* @param width

* @param height

* @param parentWidth

* @param parentHeight

*/

@Override

public void initialize(int width, int height, int parentWidth, int parentHeight) {

  super.initialize(width, height, parentWidth, parentHeight);

  //获取X Y 中心点坐标 center_X = width/ 2; center_Y = height / 2;

  //动画的执行时间,3000毫秒

  setDuration(3000L);

  setInterpolator(new AccelerateInterpolator());

}

写完这些以后就到了最关键的核心代码了

代码语言:javascript
复制
/** * 在applyTransformation通过矩阵修改动画

* 这里是自定义动画的核心,动画执行的过程中一直在回调这个方法

* 每次回调这个方法interpolatedTime都会改变

* @param interpolatedTime

* @param t

*/

@Override

protected void applyTransformation(float interpolatedTime, Transformation t) {

  final Matrix matrix = t.getMatrix();

  //储蓄 camera.save();

  //中心是绕Y轴旋转,这里可以自行设置其他轴

  camera.rotateY(1080 * interpolatedTime);

  //加在变换矩阵上 camera.getMatrix(matrix);

  //设置翻转中心点 matrix.preTranslate(-center_X, -center_Y);

  matrix.postTranslate(center_X, center_Y); //恢复 camera.restore();

}

怎么样 看完以后是不是了解了很多

以上就是本文的全部内容,希望对大家的学习有所帮助。

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2020-09-11 ,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档