android 动画总结一
一、补间动画
补间动画就是指开发者指定动画的开始、动画的结束的"关键帧",而动画变化的"中间帧"由系统计算,并补齐。
补间动画分为四种:平移动画(TranslateAnimation)、缩放动画(ScaleAnimation)、旋转动画(RotateAnimation)、透明度动画(AlphaAnimation)
注:如何实现此处不细说,
1、平移动画(TranslateAnimation)
TranslateAnimation(0,500,0,500),参数1:视图在水平方向x 移动的起始值,
参数2:视图在水平方向x 移动的结束值
参数3:视图在竖直方向y 移动的起始值
参数4:视图在竖直方向y 移动的结束值
2、缩放动画(ScaleAnimation)
new ScaleAnimation(0,2,0,2,Animation.RELATIVE_TO_SELF,0.5f,Animation.RELATIVE_TO_SELF,0.5f)
参数1:动画在水平方向X的起始缩放倍数
参数2:动画在水平方向X的结束缩放倍数
参数3:动画开始前在竖直方向Y的起始缩放倍数
参数4:动画在竖直方向Y的结束缩放倍数
参数5:缩放轴点的x坐标的模式
参数6:缩放轴点x坐标的相对值
参数7:缩放轴点的y坐标的模式
参数8:缩放轴点y坐标的相对值
注:参数5说明: Animation.ABSOLUTE:缩放轴点的x坐标 = View左上角的原点 在x方向 加上参数6数值的点(y方向同理)
Animation.RELATIVE_TO_SELF:缩放轴点的x坐标 = View左上角的原点 在x方向 加上 自身宽度乘上参数6数值的值(y方向同理)
Animation.RELATIVE_TO_PARENT:缩放轴点的x坐标 = View左上角的原点 在x方向 加上 父控件宽度乘上参数6数值的值
3、旋转动画(RotateAnimation)
RotateAnimation(0,270,Animation.RELATIVE_TO_SELF,0.5f,Animation.RELATIVE_TO_SELF,0.5f);
参数1. 动画开始时 视图的旋转角度(正数 = 顺时针,负数 = 逆时针)
参数2. 动画结束时 视图的旋转角度(正数 = 顺时针,负数 = 逆时针)
参数3. 旋转轴点的x坐标的模式
参数4. 旋转轴点x坐标的相对值
参数5. 旋转轴点的y坐标的模式
参数6. 旋转轴点y坐标的相对值
注:参数3:Animation.ABSOLUTE:旋转轴点的x坐标 = View左上角的原点 在x方向 加上 pivotXValue数值的点
Animation.RELATIVE_TO_SELF:旋转轴点的x坐标 = View左上角的原点 在x方向 加上 自身宽度乘上pivotXValue数值的值
Animation.RELATIVE_TO_PARENT:旋转轴点的x坐标 = View左上角的原点 在x方向 加上 父控件宽度乘上pivotXValue数值的值
4、透明度动画(AlphaAnimation)
new AlphaAnimation(1,0); 参数1. 动画开始时视图的透明度(取值范围: -1 ~ 1)
参数2:动画结束时视图的透明度(取值范围: -1 ~ 1)
此时此刻就是重点:
说明:TranslateAnimation、ScaleAnimation、RotateAnimation、AlphaAnimation它们共同的特点是都是 Animation的子类,它们各自没有特别的操作,全部
借助父类,所以如何运用它们其实就需要看Animation。
Animation类
首先,它有一个AnimationListener接口,是用来监听动画的运行状态的,onAnimationStart监听动画开始状态,onAnimationEnd监听动画结束状态,
onAnimationRepeat监听动画重复状态。该监听可以实现动画之间交互。
方法:
setInterpolator 主要是为动画设置插值器,插值器的种类有很多,主要是让动画在不同的时间节点展示不同的效果,用于丰富动画效果。
setDuration 主要设置动画运行时间。
setRepeatMode 设置重复模式,1、Animation.RESTART,从头开始重复。2、Animation.REVERSE,反方向执行
setRepeatCount 设置重复次数
setFillAfter 设置动画结束后位置淡出 动画链中用到
setFillBefore 设置动画开始位置淡出
setZAdjustment 允许在动画播放期间,调整播放内容在Z轴方向的顺序
setStartOffset 设置动画启动时间
restrictDuration 限制动画的运行时间
暂时用到的就这么多,其他一些get方法也是相对获取一些信息的,这里不做详细的说明。
android 动画总结一的更多相关文章
- Android动画效果之自定义ViewGroup添加布局动画
前言: 前面几篇文章介绍了补间动画.逐帧动画.属性动画,大部分都是针对View来实现的动画,那么该如何为了一个ViewGroup添加动画呢?今天结合自定义ViewGroup来学习一下布局动画.本文将通 ...
- Android动画效果之Property Animation进阶(属性动画)
前言: 前面初步认识了Android的Property Animation(属性动画)Android动画效果之初识Property Animation(属性动画)(三),并且利用属性动画简单了补间动画 ...
- Android动画效果之初识Property Animation(属性动画)
前言: 前面两篇介绍了Android的Tween Animation(补间动画) Android动画效果之Tween Animation(补间动画).Frame Animation(逐帧动画)Andr ...
- Android动画效果之Frame Animation(逐帧动画)
前言: 上一篇介绍了Android的Tween Animation(补间动画) Android动画效果之Tween Animation(补间动画),今天来总结下Android的另外一种动画Frame ...
- Android动画效果之Tween Animation(补间动画)
前言: 最近公司项目下个版本迭代里面设计了很多动画效果,在以往的项目中开发中也会经常用到动画,所以在公司下个版本迭代开始之前,抽空总结一下Android动画.今天主要总结Tween Animation ...
- Android动画
[浅谈Android动画] 总共四种:Tween Animation变换动画.Frame Animation帧动画 Layout Animation布局动画.Property Animation 属性 ...
- Android动画学习(二)——Tween Animation
前两天写过一篇Android动画学习的概述,大致的划分了下Android Animation的主要分类,没有看过的同学请移步:Android动画学习(一)——Android动画系统框架简介.今天接着来 ...
- Android动画学习(一)——Android动画系统框架简介
2015-11-09补充:Drawable Animation极有可能是Frame Animation 这几天在找工作,面试的时候被问到了Android动画,之前完全没接触过这部分,直接给懵了,当然其 ...
- Android动画的理解
基础知识 在我们开始讲Android动画这个知识点之前,我们了解下相应的基础知识点. Shape篇 一般用Shape定义的XML文件是存放在Drawable目录下,广泛应用于在Button.TextV ...
- Android动画之淡入淡出
为了更好的说明Android动画的淡入淡出效果,这里以一个场景为例: 界面上有两个View 控件,两个View交替显示,当一个View淡入显示,另一个View淡出不可见. 我们把当前要显示的View叫 ...
随机推荐
- 002——Angular 目录结构分析、app.module.ts 详解、以及 Angular 中创建组件、组件 详解、 绑定数据
一.目录结构分析 二. app.module.ts.组件分析 1.app.module.ts 定义 AppModule,这个根模块会告诉 Angular 如何组装该应用. 目前,它只声明了 AppCo ...
- 【Linux】宝塔上 GitLab数据迁移修改配置后nginx无法启动
背景: 服务器A 向 服务器B 迁移数据,修改配置重启.发现gitlab的 nginx 无法启动. 查找原因 gitlab-ctl tail 错误信息: 网上查了查,似乎是宝塔的问题, 原因应该是为了 ...
- Django架站的16堂課
Django架站的16堂課-活用Django+Web+Framework快速构建移动网站 目录 第1堂 网站开发环境的建立 1 1.1 网站的基础知识 1 1.1.1 网站的运行流程 1 1.1.2 ...
- 戒邪淫利器:《楞严经 四种清净明诲》实例及原经文 (转自学佛网:http://www.xuefo.net/nr/article55/545256.html)
今日得持首楞严,不读天下糟粕书! 当你读完楞严经后就会很真实的升起这个感觉!根本觉得其他书都是多余的!所以<楞严经>还是要多读,多看!并且<楞严经>戒淫的效果特别好!好好的珍惜 ...
- 【2B设计】途牛商旅全案设计
整体设计方案: 途牛商旅全案设计 https://www.uisdc.com/tuniu-business-travel
- 【CSS3练习】3D盒子制作
先发个3D盒子最终效果图 在线效果预览:http://dtdxrk.github.io/game/css3-demo/box-3d.html 制作步骤1:创建基本结构 分布把6个面定义到3×3的画布上 ...
- CSS控制元素背景透明度总结
方法一:CSS3的background rgba filter:progid:DXImageTransform.Microsoft.gradient(enabled='true',startColor ...
- idea安装svn
idea不像eclipse那样是用插件,idea是直接指向已经安装好的svn.exe.
- 使用派生镜像(qcow2)
当创建的虚拟机越来越多,并且你发现好多虚拟机都是同一个操作系统,它们的区别就是安装的软件不大一样,那么你肯定会希望把他们公共的部分提取出来,只保存那些与公共部分不同的东西,这样镜像大小下去了,空间变多 ...
- TCP/IP学习笔记6--TCP/IP模型
"五月的风慢慢地吹过湖面,泛起波浪层层,一只鸟儿飞过来,在我面前婉转歌唱" TCP/IP是当今计算机网络世界使用最为广泛的协议.该方面的知识对于那些想做网络编程的人来说是只至关重要 ...