Android自定义控件开发入门与实战(5)KeyFrame和ViewPropertyAnimator

  1. 链式设置方法。每个接口方法都会返回一个ViewPropertyAnimator实例。

关于其别的API如下图所示:

在这里插入图片描述

其中对于像scaleX()、scaleY()等这些方法,还有其对应的 scaleXBy()… 它们的区别跟scrollTo和scrollBy的区别一样。

scaleXBy等带By的都是增量。

比如每次使用scaleX(2),目标view都是原来大小的两倍,而每次使用scaleXBy(2),增量放大两倍。

性能考量

(1)ViewPropertyAnimator并没有像ObjectAnimator一样使用反射或者JNI技术。

(2)它会根据每一个动画帧计算出对应的所有属性值,并设置给控件,然后调用一次invalidate()函数重绘,从而解决了在使用ObjectAnimator时每个属性都要单独计算单独重绘的问题。

(3)所以ViePropertyAnimator相对于ObjectAnimator和组合动画,性能有所提升。

并且在构造动画时会更加轻便。

但是ViewPropertyAnimator并不会取代属性动画。

ObjectAnimator更加的灵活、方便,可以作用在任何对象、属性上,而当需要对View的多个属性(SDK提供的,并非自定义的)进行操作时,ViewPropertyAnimator会更加便捷。

ViewGroup内的组件添加


我佛了…昨天敲了一个小时,最后忘记保存去跑步了,然后一个小时白敲了…QAQ…

Viewgroup动画就是对Viewgroup内部的子控件做动画效果。

比如一个listview在的每个item在每次进场、退场、添加、删除时使用的动画,上述的那些动画很难实现出来。

实现ViewGroup的动画有四个

  1. layoutAnimation标签和LayoutAnimationController

API 1引入,子控件进场、退场都可以做动画,但是添加控件后,新的控件不能做出动画效果

  1. gridLayoutAnimation标签和GridLayoutAnimationController

API 1引入,作用于GridView,优缺点和上述一样。

  1. android:animateLayoutChanges属性

API 11引入,是解决上述两个动画的问题而出现的,可以在添加新控件后,新控件依然有动画,缺点是动画不能自定义。

  1. LayoutTransition

API 11引入,解决上述的所有问题。

综上所述,LayoutTransition是最强的。

第三个 android:animateLayoutChanges设置为true时,可以带来动画,但是是系统默认的,如果我们想要实现自定义动画那就得使用LayoutTranstition。

LayoutTransition使用的三个步骤

  1. 创建实例

LayoutTransition transition = new LayoutTransition();

  1. 创建动画并进行设置

PropertyValuesHolder pivLeft = PropertyValuesHolder.ofInt(“left”,0,0);

PropertyValuesHolder pivTop = PropertyValuesHolder.ofInt(“top”,0,0);

PropertyValuesHolder pivScaleX = PropertyValuesHolder.ofFloat(“scaleX”,1f,0f,1f);

Animator animator = ObjectAnimator.ofPropertyValuesHolder(ll,pivLeft,pivTop,pivScaleX);

transition.setAnimator(LayoutTransition.CHANGE_APPEARING,animator);

  1. 将LayoutTransition添加到ViewGroup中

ll.setLayoutTransition(transition);

然后设置监听事件

private void deleteView() {

if (i > 0) {

ll.removeViewAt(0);

}

i–;

}

private void addView() {

i++;

Button button = new Button(this);

button.setText(“Button”+i);

LinearLayout.LayoutParams params = new LinearLayout.LayoutParams(ViewGroup.LayoutParams.WRAP_CONTENT, ViewGroup.LayoutParams.WRAP_CONTENT);

button.setLayoutParams(params);

ll.addView(button,0);

}

就有下面的效果:

在这里插入图片描述

其中在setAnimator这一步中填入了参数,表示的是应用动画的对象范围:

  • APPEARING:元素在容器中出现时定义的动画

  • DISAPPEARING:元素在容器中消失时定义的动画

  • CHANGE_APPEARING:元素在添加新的元素时,其他需要变化的元素所应用的动画。

  • CHANGE_DISAPPEARING:容器某个元素消失时,其他需要变化的元素所应用的动画。

自我介绍一下,小编13年上海交大毕业,曾经在小公司待过,也去过华为、OPPO等大厂,18年进入阿里一直到现在。

深知大多数初中级安卓工程师,想要提升技能,往往是自己摸索成长,但自己不成体系的自学效果低效又漫长,而且极易碰到天花板技术停滞不前!

因此收集整理了一份《2024年最新Android移动开发全套学习资料》送给大家,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友,同时减轻大家的负担。
img
img
img
img

由于文件比较大,这里只是将部分目录截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频
如果你觉得这些内容对你有帮助,可以添加下面V无偿领取!(备注Android)
img

320102)]
[外链图片转存中…(img-LkFNklff-1710921320103)]

由于文件比较大,这里只是将部分目录截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频
如果你觉得这些内容对你有帮助,可以添加下面V无偿领取!(备注Android)
[外链图片转存中…(img-WGEc6xvP-1710921320103)]

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值