Android实现View平移动画的方式

Android实现View平移动画的方式,第1张

平移动画,大概是我们最容易想到的实现方式,但并非能满足所有需求。这种方式不能控制进度,设置好动画持续时间后,就会一直到结束。

通过drawBitmap在不同的位置画出,适合作为平移动画的需求。经测试,使用Matrix方式对部分待透明度以及过大的无法绘制,通过计算位置直接绘制正常。

改变长度和改变位置是一个道理。获取View的位置,然后通过进度计算出View的宽度,再通过setLayoutParams改变View大小。这个方式满足我们的需求,采用的此方式。

以上。如有错误,欢迎指正!

个人简介:

在 Android 动画中,总共有两种类型的动画View Animation(视图动画)和Property Animator(属性动画);其中

View Animation包括Tween Animation(补间动画)和Frame Animation(逐帧动画);

Property Animator包括ValueAnimator和ObjectAnimation;

首先,直观上,他们有如下三点不同:

1、引入时间不同: View Animation是API Level 1就引入的。Property Animation是API Level 11引入的,即Android 30才开始有Property Animation相关的API。

2、所在包名不同: View Animation在包androidviewanimation中。而Property Animation API在包 androidanimation中。

3、动画类的命名不同: View Animation中动画类取名都叫XXXXAnimation,而在Property Animator中动画类的取名则叫XXXXAnimator大家都知道逐帧动画主要是用来实现动画的,而补间动画才能实现控件的渐入渐出、移动、旋转和缩放的;而Property Animator是在Android 30版本才引入的,之前是没有的。

为什么还要引入Property Animator呢?

1、为什么引入Property Animator(属性动画)

我提出一个假设:请问大家,如何利用补间动画来将一个控件的背景色在一分钟内从绿色变为红色?这个效果想必没办法仅仅通过改变控件的渐入渐出、移动、旋转和缩放来实现吧,而这个效果是可以通过Property Animator完美实现的

这就是第一个原因:Property Animator能实现补间动画无法实现的功能 大家都知道,补间动画和逐帧动画统称为View Animation,也就是说这两个动画只能对派生自View的控件实例起作用;而Property Animator则不同,从名字中可以看出属性动画,应该是作用于控件属性的!正因为属性动画能够只针对控件的某一个属性来做动画,所以也就造就了他能单独改变控件的某一个属性的值!比如颜色!这就是Property Animator能实现补间动画无法实现的功能的最重要原因。

我们得到了第二点不同:View Animation仅能对指定的控件做动画,而Property Animator是通过改变控件某一属性值来做动画的。

假设我们将一个按钮从左上角利用补间动画将其移动到右下角,在移动过程中和移动后,这个按钮都是不会响应点击事件的。这是为什么呢?因为补间动画仅仅转变的是控件的显示位置而已,并没有改变控件本身的值。View Animation的动画实现是通过其Parent View实现的,在View被drawn时Parents View改变它的绘制参数,这样虽然View的大小或旋转角度等改变了,但View的实际属性没变,所以有效区域还是应用动画之前的区域;我们看到的效果仅仅是系统作用在按钮上的显示效果,利用动画把按钮从原来的位置移到了右下角,但按钮内部的任何值是没有变化的,所以按钮所捕捉的点击区域仍是原来的点击区域。(下面会举例来说明这个问题)

这就得到了第三点不同:补间动画虽能对控件做动画,但并没有改变控件内部的属性值。而Property Animator则是恰恰相反,Property Animator是通过改变控件内部的属性值来达到动画效果的

我们前面讲了Property Animator包括ValueAnimator和ObjectAnimator;这篇文章就主要来看看ValueAnimator的使用方法吧。

我觉得谷歌那帮老头是最会起名字的人,单从命名上,就能看出来这个东东的含义。ValueAnimator从名字可以看出,这个Animation是针对值的! ValueAnimator不会对控件做任何 *** 作,我们可以给它设定从哪个值运动到哪个值,通过监听这些值的渐变过程来自己 *** 作控件。 它会自己计算动画的过程,然后我们需要监听它的动画过程来自己 *** 作控件。

这就是ValueAnimator的功能:ValueAnimator对指定值区间做动画运算,我们通过对运算过程做监听来自己 *** 作控件。

总而言之就是两点:

1 ValueAnimator只负责对指定的数字区间进行动画运算

2 我们需要对运算过程进行监听,然后自己对控件做动画 *** 作

插值器的意义其实就相当于物理公式中的加速度参数,所以这也就是它也叫加速的原因。 如何自定义插值器:

input参数与任何我们设定的值没关系,只与时间有关,随着时间的增长,动画的进度也自然的增加,input参数就代表了当前动画的进度。而返回值则表示动画的当前数值进度

在getInterpolation函数中,我们将进度反转过来,当传0的时候,我们让它数值进度在完成的位置,当完成的时候,我们让它在开始的位置

ObjectAnimator是派生自ValueAnimator的,所以ValueAnimator中所能使用的方法,在ObjectAnimator中都可以正常使用。ObjectAnimator重写了几个方法,比如ofInt(),ofFloat()等。利用ObjectAnimator重写的ofFloat方法如何实现一个动画:(改变透明度)

前面我们都是定义多个值,即至少两个值之间的变化,那如果我们只定义一个值呢,如下面的方式:(同样以MyPointView为例)

仅且仅当我们只给动画设置一个值时,程序才会调用属性对应的get函数来得到动画初始值。如果动画没有初始值,那么就会使用系统默认值。比如ofInt()中使用的参数类型是int类型的,而系统的Int值的默认值是0,所以动画就会从0运动到100;也就是系统虽然在找到不到属性对应的get函数时,会给出警告,但同时会用系统默认值做为动画初始值。

如果通过给自定义控件MyPointView设置了get函数,那么将会以get函数的返回值做为初始值。

根据 View setBackGroundColor() 方法可以自定义条用属性动画。

通过AnimationListener可以监听Animation的运行过程,有三个方法分别是Animation开始的时候调用,完成的时候调用,重复的时候调用。

AnimationSet,动画集合。 我们最常用的是调用其 addAnimation 将一个个不一样的动画组织到一起来,然后调用view 的 startAnimation 方法触发这些动画执行。

setAnimation是告诉该控件我待会要执行什么动画,而要执行的的动画,是需要手动添加的。并且需要父view在动画快要开启的时候,调用invalidate。需要一定的条件限制。

而startAnimation告诉该控件,我要立马执行该动画,该动画就是已经设置好的动画。调用它时就会立即开始动画。

参看这篇文章: Android动画之Interpolator插补器和TypeEvaluator估值器

Property Animation提供了AnimatorAnimatorListener和AnimatorAnimatorUpdateListener两个监听器用于动画在播放过程中的重要动画事件。下面是两个监听器接口和方法的一些介绍和说明:

上面讲到ViewAnimation有许多xml加载,当然PropertyAnimation也可以对应xml加载,位置为 res/animator/

animatorxml

调用就用到了AnimatorInflater类了

组合动画也可以xml加载

在 Android 30 中给 View 增加了一些新的属性以及相应的 getter、setter 方法。Property Animation系统可以通过修改 View 对象实际的属性值来实现屏幕上的动画效果。此外,当属性值发生变化时,Views 也会自动调用 invalidate() 方法来刷新屏幕。 View 类中新增的便于实现 property 动画的属性包括:

1 第一个参数:设置目标对象,即 *** 纵的view

2 第二个参数:设置 *** 作的动画的属性值(见上面讲解的动画属性值)

3 第三个参数:可变数组参数 (初始值,中间值,结束值)。可以有一个到N个,如果是一个值的话默认这个值是动画过渡值的结束值。如果有N个值,动画就在这N个值之间过渡。

针对同一个对象多个属性,同时作用多种动画

可以调用其playTogether(同时执行)、playSequentially(顺序执行)、play、before、with、after 等方法设置动画的执行顺序,然后调用其start 触发动画执行。

Android 30后,谷歌给View增加animate方法直接驱动属性动画。

首相要new一个这个image对象

然后用TranslateAnimation animation = new TranslateAnimation(fromXDelta, toXDelta, fromYDelta, toYDelta)函数,将现在的的坐标和要移到的坐标写进去,然后用animationsetFillAfter(true);让停留在那。最后imagestartAnimation(animation )就可以了,我是看见QQ 2011以前用过这个移动的动画做了一下,就是这么实现的

Android的动画属性有4种:

Alpha:渐变透明度动画效果

Scale:渐变尺寸伸缩动画效果

Translate:画面转换位置移动动画效果

Rotate:画面旋转动画效果

TweenAnimation 通用属性[类型] 功能 Duration[long] 属性为动画持续时间 时间以毫秒为单位

fillAfter[boolean] 当设置为true ,该动画转化在动画结束后被应用

fillBefore[boolean]当设置为true ,该动画转化在动画开始前被应用

interpolator 指定一个动画的插入器 有一些常见的插入器

accelerate_decelerate_interpolator

加速-减速动画插入器

accelerate_interpolator

加速-动画插入器

decelerate_interpolator

减速- 动画插入器

其他的属于特定的动画效果

repeatCount[int] 动画的重复次数

RepeatMode[int]定义重复的行为 1:重新开始 2:playsbackward

startOffset[long] 动画之间的时间间隔,从上次动画停多少时间开始执行下个动画

zAdjustment[int] 定义动画的Z Order的改变0:保持Z Order不变

1:保持在最上层

-1:保持在最下层

-->

<!-- 尺寸伸缩动画效果 scale

属性:interpolator 指定一个动画的插入器

有三种动画插入器:

accelerate_decelerate_interpolator 加速-减速动画插入器

accelerate_interpolator 加速-动画插入器

decelerate_interpolator 减速- 动画插入器

其他的属于特定的动画效果

fromXScale属性为动画起始时X坐标上的伸缩尺寸

toXScale 属性为动画结束时X坐标上的伸缩尺寸

fromYScale属性为动画起始时Y坐标上的伸缩尺寸

toYScale 属性为动画结束时Y坐标上的伸缩尺寸

说明:

以上四种属性值

00表示收缩到没有

10表示正常无伸缩

值小于10表示收缩

值大于10表示放大

pivotX 属性为动画相对于物件的X坐标的开始位置

pivotY 属性为动画相对于物件的Y坐标的开始位置

说明:

以上两个属性值从0%-100%中取值

50%为物件的X或Y方向坐标上的中点位置

长整型值:

duration 属性为动画持续时间

说明: 时间以毫秒为单位

布尔型值:

fillAfter属性当设置为true ,该动画转化在动画结束后被应用

-->

<!--

画面转换位置移动动画效果translate

fromXDeltatoXDelta 为动画、结束起始时 X坐标上的位置

fromYDeltatoYDelta 为动画、结束起始时 Y坐标上的位置

-->

<!--

画面转移旋转动画效果rotate

fromDegrees为动画起始时物件的角度 说明

当角度为负数——表示逆时针旋转

当角度为正数——表示顺时针旋转

(负数from——to正数:顺时针旋转)

(负数from——to负数:逆时针旋转)

(正数from——to正数:顺时针旋转)

(正数from——to负数:逆时针旋转)

toDegrees 属性为动画结束时物件旋转的角度 可以大于360度

pivotX

pivotY 为动画相对于物件的X、Y坐标的开始位 说明:以上两个属性值从0%-100%中取值

50%为物件的X或Y方向坐标上的中点位置

-->

以上就是关于Android实现View平移动画的方式全部的内容,包括:Android实现View平移动画的方式、android属性动画详解、吐血总结【Android动画】必知必会等相关内容解答,如果想了解更多相关内容,可以关注我们,你们的支持是我们更新的动力!

欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/web/9730193.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-05-01
下一篇 2023-05-01

发表评论

登录后才能评论

评论列表(0条)

保存