ImageVerifierCode 换一换
格式:DOC , 页数:7 ,大小:177KB ,
资源ID:3179193      下载积分:20 文钱
快捷下载
登录下载
邮箱/手机:
温馨提示:
快捷下载时,用户名和密码都是您填写的邮箱或者手机号,方便查询和重复下载(系统自动生成)。 如填写123,账号就是123,密码也是123。
特别说明:
请自助下载,系统不会自动发送文件的哦; 如果您已付费,想二次下载,请登录后访问:我的下载记录
支付方式: 支付宝    微信支付   
验证码:   换一换

加入VIP,省得不是一点点
 

温馨提示:由于个人手机设置不同,如果发现不能下载,请复制以下地址【https://www.wenke99.com/d-3179193.html】到电脑端继续下载(重复下载不扣费)。

已注册用户请登录:
账号:
密码:
验证码:   换一换
  忘记密码?
三方登录: QQ登录   微博登录 

下载须知

1: 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。
2: 试题试卷类文档,如果标题没有明确说明有答案则都视为没有答案,请知晓。
3: 文件的所有权益归上传用户所有。
4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
5. 本站仅提供交流平台,并不能对任何下载内容负责。
6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

版权提示 | 免责声明

本文(Android动画.doc)为本站会员(11****ws)主动上传,文客久久仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。 若此文所含内容侵犯了您的版权或隐私,请立即通知文客久久(发送邮件至hr@wenke99.com或直接QQ联系客服),我们立即给予删除!

Android动画.doc

1、Android Animation关于动画的实现,Android 提供了 Animation,在 Android SDK 介绍了 2 种 Animation 模式:1. Tween Animation:通过对场景里的对象不断做图像变换(平移、缩放、旋转)产生动画效果,即是一种渐变动画;2. Frame Animation:顺序播放事先做好的图像,是一种画面转换动画。动画类型下面先来看看 Android 提供的动画类型。Android 的 animation 由四种类型组成在 XML 文件中: alpha 渐变透明度动画效果 scale 渐变尺寸伸缩动画效果 translate 画面转换位置移动

2、动画效果 rotate 画面转移旋转动画效果在 Java 源码中定义了相应的类,可以使用这些类的方法来获取和操作相应的属性: AlphaAnimation 渐变透明度动画效果 ScaleAnimation 渐变尺寸伸缩动画效果 TranslateAnimation 画面转换位置移动动画效果 RotateAnimation 画面转移旋转动画效果Tween Animation一个 tween 动画将对视图对象中的内容进行一系列简单的转换(位置,大小,旋转,透明性)。如果你有一个文本视图对象,你可以移动它,旋转它,让它变大或让它变小,如果文字下面还有背景图像,背景图像也会随着文件进行转换。使用 XM

3、L 来定义 Tween Animation动画的 XML 文件在工程中 res/anim 目录,这个文件必须包含一个根元素,可以使 插值元素或者是把上面的元素都放入元 素组中,默认情况下,所以的动画指令都是同时发生的,为了让他们按序列发生,需要设置一个特殊的属性 startOffset。动画的指令定义了你想要发生 什么样的转换,当他们发生了,应该执行多长时间,转换可以是连续的也可以使同时的。例如,你让文本内容从左边移动到右边,然后旋转 180 度,或者在移动的 过程中同时旋转,没个转换需要设置一些特殊的参数(开始和结束的大小尺寸的大小变化,开始和结束的旋转角度等等,也可以设置些基本的参数(例如

4、,开始时间 与周期),如果让几个转换同时发生,可以给它们设置相同的开始时间,如果按序列的话,计算开始时间加上其周期。Tween Animation 共同的节点属性属性类型 功能 备注Durationlong 属性为动画持续时间 时间以毫秒为单位fillAfter boolean 当设置为 true ,该动画转化在动画结束后被应用fillBeforeboolean当设置为 true ,该动画转化在动画开始前被应用interpolator 指定一个动画的插入器有一些常见的插入器accelerate_decelerate_interpolator 加速- 减速 动画插入器accelerate_int

5、erpolator 加速-动画插入器decelerate_interpolator 减速- 动画插入器其他的属于特定的动画效果repeatCountint 动画的重复次数RepeatModeint 定义重复的行为 1:重新开始 2:plays backwardstartOffsetlong 动画之间的时间间隔,从上次动画停多少时间开始执行下个动画zAdjustmentint 定义动画的 Z Order 的改变0:保持 Z Order 不变1:保持在最上层-1:保持在最下层表二XML 节点 功能说明alpha 渐变透明度动画效果fromAlpha属性为动画起始时透明度toAlpha 属性为动画结

6、束时透明度0.0 表示完全透明 1.0 表示完全不透明 以上值取 0.0-1.0 之间的 float 数据类型的数字 duration 为动画持续时间,ms 单位表三scale 渐变尺寸伸缩动画效果fromXScalefloat fromYScalefloat为动画起始时,X、Y坐标上的伸缩尺寸toXScale floattoYScalefloat为动画结束时,X、Y坐标上的伸缩尺寸0.0 表示收缩到没有1.0 表示正常无伸缩值小于 1.0 表示收缩值大于 1.0 表示放大pivotXfloatpivotYfloat为动画相对于物件的X、Y 坐标的开始位置属性值说明:从 0%-100%中取值,

7、50%为物件的 X或 Y 方向坐标上的中点位置表四translate 画面转换位置移动动画效果fromXDeltatoXDelta为动画、结束起始时 X 坐标上的位置fromYDeltatoYDelta为动画、结束起始时 Y 坐标上的位置表五rotate 画面转移旋转动画效果fromDegrees为动画起始时物件的角度toDegrees 属性为动画结束时物件旋转的角度 可以大于 360 度说明当角度为负数表示逆时针旋转当角度为正数表示顺时针旋转(负数 fromto 正数:顺时针旋转 )(负数 fromto 负数:逆时针旋转 )(正数 fromto 正数:顺时针旋转 )(正数 fromto 负数

8、:逆时针旋转 )pivotXpivotY为动画相对于物件的 X、Y坐标的开始位说明:以上两个属性值 从 0%-100%中取值50%为物件的 X 或 Y 方向坐标上的中点位置下面给出一个完整的 XML 定义(SDK 提供)Tween Animation 如何使用使用 AnimationUtils 类的静态方法 loadAnimation()来加载 XML 中的动画 XML 文件/main.xml 中的 ImageView ImageView spaceshipImage = (ImageView) findViewById(R.id.spaceshipImage); /加载动画 Animatio

9、n hyperspaceJumpAnimation =AnimationUtils.loadAnimation(this, R.anim.hyperspace_jump); /使用 ImageView 显示动画 spaceshipImage.startAnimation(hyperspaceJumpAnimation);如何在 Java 代码中定义动画/在代码中定义 动画实例对象 private Animation myAnimation_Alpha; private Animation myAnimation_Scale; private Animation myAnimation_Tran

10、slate; private Animation myAnimation_Rotate; /根据各自的构造方法来初始化一个实例对象 myAnimation_Alpha=new AlphaAnimation(0.1f, 1.0f); myAnimation_Scale =new ScaleAnimation(0.0f, 1.4f, 0.0f, 1.4f, Animation.RELATIVE_TO_SELF, 0.5f, Animation.RELATIVE_TO_SELF, 0.5f); myAnimation_Translate=new TranslateAnimation(30.0f, -

11、80.0f, 30.0f, 300.0f); myAnimation_Rotate=new RotateAnimation(0.0f, +350.0f, Animation.RELATIVE_TO_SELF,0.5f,Animation.RELATIVE_TO_SELF, 0.5f);interpolator 的解释interpolator 定义一个动画的变化率(the rate of change)。这使得基本的动画效果(alpha, scale, translate, rotate)得以加速,减速,重复等。Interpolator 定义了动画的变化速度,可以实现匀速、正加速、负加速、无规则

12、变加速等。Interpolator 是基类,封装了所有 Interpolator 的共同方法,它只有一个方法,即 getInterpolation (float input),该方法 maps a point on the timeline to a multiplier to be applied to the transformations of an animation。Android 提供了几个 Interpolator 子类,实现了不同的速度曲线,如下:AccelerateDecelerateInterpolator在动画开始与介绍的地方速率改变比较慢,在中间的时候加速Acceler

13、ateInterpolator 在动画开始的地方速率改变比较慢,然后开始加速CycleInterpolator 动画循环播放特定的次数,速率改变沿着正弦曲线DecelerateInterpolator 在动画开始的地方速率改变比较慢,然后开始减速LinearInterpolator 在动画的以均匀的速率改变Frame AnimationFrame Animation 是顺序播放事先做好的图像,跟电影类似。不同于 animation package, Android SDK提供了另外一个类 AnimationDrawable 来定义、使用 Frame Animation。Frame Animat

14、ion 可以在 XML Resource 定义(还是存放到 resanim 文件夹下),也可以使用AnimationDrawable 中的 API 定义。由于 Tween Animation 与 Frame Animation 有着很大的不同,因此XML 定义的格式也完全不一样,其格式是:首先是 animation-list 根节点,animation-list 根节点中包含多个 item 子节点,每个 item节点定义一帧动画,当前帧的 drawable 资源和当前帧持续的时间。下面对节点的元素加以说明: XML 属性 说明drawable 当前帧引用的 drawable 资源duratio

15、n 当前帧显示的时间(毫秒为单位)oneshot 如果为 true,表示动画只播放一次停止在最后一帧上,如果设置为 false 表示动画循环播放。variablePaddingIf true, allows the drawables padding to change based on the current state that is selected.visible 规定 drawable 的初始可见性,默认为 flase;下面就给个具体的 XML 例子,来定义一帧一帧的动画:上面的 XML 就定义了一个 Frame Animation,其包含 3 帧动画, 3 帧动画中分别应用了 dr

16、awable 中的 3 张图片:rocket_thrust1,rocket_thrust2,rocket_thrust3,每帧动画持续 200 毫秒。然后我们将以上 XML 保存在 res/anim/文件夹下,命名为 rocket_thrust.xml,显示动画的代码:AnimationDrawable rocketAnimation;public void onCreate(Bundle savedInstanceState) super.onCreate(savedInstanceState);setContentView(R.layout.main);ImageView rocketIm

17、age = (ImageView) findViewById(R.id.rocket_image);rocketImage.setBackgroundResource(R.anim.rocket_thrust);rocketAnimation = (AnimationDrawable) rocketImage.getBackground();public boolean onTouchEvent(MotionEvent event) if (event.getAction() = MotionEvent.ACTION_DOWN) rocketAnimation.start();return t

18、rue;return super.onTouchEvent(event);代码运行的结果:3 张图片按照顺序的播放一次 .有 一点需要强调的是:启动 Frame Animation 动画的代码 rocketAnimation.start();不能在OnCreate()中,因为在 OnCreate()中 AnimationDrawable 还没有完全的与 ImageView 绑定,在OnCreate()中启动动画,就只能看到第一张图片。这里实在拖曳事件 中实现的。下面,阅读 Android SDK 中对 AnimationDrawable 的介绍,有个简单的了解:AnimationDrawabl

19、e获取、设置动画的属性int getDuration() 获取动画的时长int getNumberOfFrames() 获取动画的帧数boolean isOneShot()Void setOneShot(boolean oneshot)获取 oneshot 属性设置 oneshot 属性void inflate(Resurce r,XmlPullParser p,AttributeSet attrs)增加、获取帧动画Drawable getFrame(int index)获取某帧的 Drawable 资源void addFrame(Drawable frame,int duration)为当前动画增加帧(资源,持续时长)动画控制void start() 开始动画void run() 外界不能直接掉调用,使用 start()替代boolean isRunning() 当前动画是否在运行void stop() 停止当前动画

Copyright © 2018-2021 Wenke99.com All rights reserved

工信部备案号浙ICP备20026746号-2  

公安局备案号:浙公网安备33038302330469号

本站为C2C交文档易平台,即用户上传的文档直接卖给下载用户,本站只是网络服务中间平台,所有原创文档下载所得归上传人所有,若您发现上传作品侵犯了您的权利,请立刻联系网站客服并提供证据,平台将在3个工作日内予以改正。