android 动画 ——视图动画(View Animation)

2024-09-07 08:48

本文主要是介绍android 动画 ——视图动画(View Animation),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

android动画分为视图动画(View Animation)、属性动画(Property Animation)

想看属性动画(Property Animation):请移步至http://blog.csdn.net/u013424496/article/details/51700312

这里我们来说下视图动画(View Animation)的纯代码写法,还有一种是xml调用,

对于xml调用可以去看 http://blog.csdn.net/u013424496/article/details/51144171

相对与属性动画视图动画使用环境:

view animation system提供的能力只能够为View添加动画。因此如果你想为非View对象添加动画,就必须自己去实现,
view animation system在View动画的展现方面也是有约束的,只暴露了View的很少方面。比如View支持缩放和旋转,但不支持背景颜色的动画。
view animation system的另一劣势是,其改变的是View的绘制效果,真正的View的属性保持不变,比如无论你在对话中如何缩放Button的大小,Button的有效点击区域还是没有应用到动画时的区域,其位置与大小都不变。
但是View animation system只需花费很少时间创建而且只需很少的代码。如果View 动画完成了你所有的动作,或者你存在的代码已经达到了你想要的效果,就没必要使用property 动画系统了。

图解类结构

大致分为4种:缩放ScaleAnimation、平移TranslateAnimation、渐变AlphaAnimation、旋转RotateAnimation,(当然非得说还有一个种也能凑出来AnimationSet可以让将前面4个视图动画组合起来应用到某个View上)

下面就来一一简单聊聊这几个动画的纯代码实现方式吧

animation.setFillAfter(true);//让动画结束的是时候保持现状,不会回到动画开始的显示状态

缩放ScaleAnimation

1)
//以View左上角作为缩放中心,水平方向扩大一倍,垂直方向缩小为原来的一半float fromXScale = 1.0f;float toScaleX = 2.0f;float fromYScale = 1.0f;float toScaleY = 0.5f;Animation animation = new ScaleAnimation(fromXScale, toScaleX, fromYScale, toScaleY);//设置动画持续时间animation.setDuration(3000);//通过View的startAnimation方法将动画立即应用到View上textView.startAnimation(animation);

效果图:
2)
//以View中心点作为缩放中心,水平方向和垂直方向都缩小为原来的一半
float fromXScale = 1.0f;
float toScaleX = 0.5f;
float fromYScale = 1.0f;
float toScaleY = 0.5f;
float pivotX = textView.getWidth() / 2;
float pivotY = textView.getHeight() / 2;
Animation animation = new ScaleAnimation(fromXScale, toScaleX,fromYScale, toScaleY,pivotX, pivotY
);//设置动画持续时间animation.setDuration(3000);//通过View的startAnimation方法将动画立即应用到View上textView.startAnimation(animation);

效果图:
3)
//以View中心点作为缩放中心,水平方向和垂直方向都缩小为原来的一半
float fromXScale = 1.0f;
float toScaleX = 0.5f;
float fromYScale = 1.0f;
float toScaleY = 0.5f;
int pivotXType = Animation.RELATIVE_TO_SELF;
float pivotXValue = 0.5f;
int pivotYType = Animation.RELATIVE_TO_SELF;
float pivotYValue = 0.5f;
Animation animation = new ScaleAnimation(fromXScale, toScaleX,fromYScale, toScaleY,pivotXType, pivotXValue,pivotYType, pivotYValue
);
//设置动画持续时间
animation.setDuration(3000);
//通过View的startAnimation方法将动画立即应用到View上
textView.startAnimation(animation);

效果图:

平移TranslateAnimation

有两种构造方法:
1)
		int fromXDelta = 0;int toXDelta = getResources().getDisplayMetrics().widthPixels / 2;int fromYDelta = 0;int toYDelta = 0;//让动画在水平位置上沿X轴平移toXDelta个像素Animation animation = new TranslateAnimation(fromXDelta, toXDelta, fromYDelta, toYDelta);//设置动画持续时间为5000毫秒animation.setDuration(5000);textView.startAnimation(animation);
效果图:
部分代码介绍:
  • fromXDelta 表示动画开始时View相对于原来位置X轴方向的偏移坐标

  • toXDelta 表示动画结束时View相对于原来位置X轴方向的偏移坐标

  • fromYDelta 表示动画开始时View相对于原来位置Y轴方向的偏移坐标

  • toYDelta 表示动画结束时View相对于原来位置Y轴方向的偏移坐标

2)
//设置fromX
int fromXType = Animation.ABSOLUTE;
float fromXValue = textView.getX();
//设置toX
int toXType = Animation.RELATIVE_TO_PARENT;
float toXValue = 0.5f;
//设置fromY
int fromYType = Animation.ABSOLUTE;
float fromYValue = textView.getY();
//设置toY
int toYType = Animation.RELATIVE_TO_SELF;
float toYValue = 3.0f;
//创建动画
Animation animation = new TranslateAnimation(fromXType, fromXValue,toXType, toXValue,fromYType, fromYValue,toYType, toYValue);
//设置动画持续时间为3000毫秒
animation.setDuration(3000);
//通过View的startAnimation方法将动画立即应用到View上
textView.startAnimation(animation);

效果图:

部分代码介绍:

fromXType和fromXValue进行说明,fromXType的取值类型决定了如何设置fromXValue的值。fromXType的取值有三种,分别是:ABSOLUTE、RELATIVE_TO_PARENT和RELATIVE_TO_SELF。

  • ABSOLUTE 
    当fromXType取值为ABSOLUTE时,表示fromXValue的值是在该View的父控件的坐标系的绝对值,比如fromXValue为200,表示动画开始时,View的左侧到其父控件左侧的距离是200个像素。

  • RELATIVE_TO_PARENT 
    当fromXType取值为RELATIVE_TO_PARENT时,表示fromXValue的值是相对于其父控件尺寸的百分比。比如fromXValue为0,表示动画开始时,View的左侧紧靠父控件的左侧;fromXValue为0.5时,表示动画开始时,View的左侧位置在父控件水平方向中间的位置;fromXValue为1时,表示动画开始时,View的左侧位置与父控件的右侧位置完全重合。

  • RELATIVE_TO_SELF 
    当fromXType取值为RELATIVE_TO_SELF时,表示fromXValue的值是相对于其自身尺寸的百分比。比如fromXValue为0,表示动画开始时,View的X坐标和初始位置的X坐标相同;fromXValue为0.5时,表示动画开始时,View的左侧位置在初始View状态下水平方向中间的位置,即向右偏移了View宽度的一半;fromXValue为1时,表示动画开始时,View的左侧位置正好与初始View状态下的右侧位置重合,即向右偏移了正好View的宽度大小的距离。

渐变AlphaAnimation

代码:
//1.0表示完全不透明,0.0表示完全透明
float fromAlpha = 0.0f;
float toAlpha = 1.0f;
//1.0 => 0.0表示View从完全不透明渐变到完全透明
Animation animation = new AlphaAnimation(fromAlpha, toAlpha);
//设置动画持续时间为3000毫秒
animation.setDuration(5000);
//通过View的startAnimation方法将动画立即应用到View上
textView.startAnimation(animation);


效果图:




旋转RotateAnimation

1)
//以View左上角为旋转轴,创建旋转60度的动画
Animation animation = new RotateAnimation(0, 60);
//设置动画持续时间
animation.setDuration(3000);
//通过View的startAnimation方法将动画立即应用到View上
textView.startAnimation(animation);
效果图:


2)hava problem(这种方式中我在使用的时候涉及到一个问题

解决在onCreate()过程中获取View的width和Height为0的4种方法

<pre name="code" class="html">	//以View中心点作为旋转轴,创建旋转90度的动画textView.post(new Runnable() {@Overridepublic void run() {float pivotX = textView.getWidth() / 2;float pivotY = textView.getHeight() / 2;Animation animation = new RotateAnimation(0, 90, pivotX, pivotY);//设置动画持续时间animation.setDuration(3000);//通过View的startAnimation方法将动画立即应用到View上textView.startAnimation(animation);}});

 效果图: 
3)
//以View的父控件中心点作为旋转轴,创建旋转360度的动画
int pivotXType = Animation.RELATIVE_TO_PARENT;
float pivotXValue = 0.5f;
int pivotYType = Animation.RELATIVE_TO_PARENT;
float pivotYValue = 0.5f;
Animation animation = new RotateAnimation(0, 360,pivotXType, pivotXValue,pivotYType, pivotYValue
);
//设置动画持续时间
animation.setDuration(3000);
//通过View的startAnimation方法将动画立即应用到View上
textView.startAnimation(animation);

效果图:

总结:主要就是三部吧:
  1)创建Animation某个子类的实例
  2)通过Animation的setDuration方法设置动画持续时间
  3)最后通过View的startAnimation方法启动动画
对了还有最后一个(说算也不算的。。)

AnimationSet
	//初始化 Translate动画  TranslateAnimation	translateAnimation = new TranslateAnimation(0.1f, 100.0f,0.1f,100.0f);  //初始化 Alpha动画  AlphaAnimation alphaAnimation = new AlphaAnimation(0.0f, 1.0f);  //动画集  AnimationSet set = new AnimationSet(true);  set.addAnimation(translateAnimation);  set.addAnimation(alphaAnimation);  //设置动画时间 (作用到每个动画)  set.setDuration(3000);  //通过View的startAnimation方法将动画立即应用到View上textView.startAnimation(set);  

效果图





这篇关于android 动画 ——视图动画(View Animation)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1144612

相关文章

Android使用ImageView.ScaleType实现图片的缩放与裁剪功能

《Android使用ImageView.ScaleType实现图片的缩放与裁剪功能》ImageView是最常用的控件之一,它用于展示各种类型的图片,为了能够根据需求调整图片的显示效果,Android提... 目录什么是 ImageView.ScaleType?FIT_XYFIT_STARTFIT_CENTE

Android实现在线预览office文档的示例详解

《Android实现在线预览office文档的示例详解》在移动端展示在线Office文档(如Word、Excel、PPT)是一项常见需求,这篇文章为大家重点介绍了两种方案的实现方法,希望对大家有一定的... 目录一、项目概述二、相关技术知识三、实现思路3.1 方案一:WebView + Office Onl

Android实现两台手机屏幕共享和远程控制功能

《Android实现两台手机屏幕共享和远程控制功能》在远程协助、在线教学、技术支持等多种场景下,实时获得另一部移动设备的屏幕画面,并对其进行操作,具有极高的应用价值,本项目旨在实现两台Android手... 目录一、项目概述二、相关知识2.1 MediaProjection API2.2 Socket 网络

Android实现悬浮按钮功能

《Android实现悬浮按钮功能》在很多场景中,我们希望在应用或系统任意界面上都能看到一个小的“悬浮按钮”(FloatingButton),用来快速启动工具、展示未读信息或快捷操作,所以本文给大家介绍... 目录一、项目概述二、相关技术知识三、实现思路四、整合代码4.1 Java 代码(MainActivi

Android Mainline基础简介

《AndroidMainline基础简介》AndroidMainline是通过模块化更新Android核心组件的框架,可能提高安全性,本文给大家介绍AndroidMainline基础简介,感兴趣的朋... 目录关键要点什么是 android Mainline?Android Mainline 的工作原理关键

如何解决idea的Module:‘:app‘platform‘android-32‘not found.问题

《如何解决idea的Module:‘:app‘platform‘android-32‘notfound.问题》:本文主要介绍如何解决idea的Module:‘:app‘platform‘andr... 目录idea的Module:‘:app‘pwww.chinasem.cnlatform‘android-32

Android实现打开本地pdf文件的两种方式

《Android实现打开本地pdf文件的两种方式》在现代应用中,PDF格式因其跨平台、稳定性好、展示内容一致等特点,在Android平台上,如何高效地打开本地PDF文件,不仅关系到用户体验,也直接影响... 目录一、项目概述二、相关知识2.1 PDF文件基本概述2.2 android 文件访问与存储权限2.

Android Studio 配置国内镜像源的实现步骤

《AndroidStudio配置国内镜像源的实现步骤》本文主要介绍了AndroidStudio配置国内镜像源的实现步骤,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,... 目录一、修改 hosts,解决 SDK 下载失败的问题二、修改 gradle 地址,解决 gradle

在Android平台上实现消息推送功能

《在Android平台上实现消息推送功能》随着移动互联网应用的飞速发展,消息推送已成为移动应用中不可或缺的功能,在Android平台上,实现消息推送涉及到服务端的消息发送、客户端的消息接收、通知渠道(... 目录一、项目概述二、相关知识介绍2.1 消息推送的基本原理2.2 Firebase Cloud Me

Android中Dialog的使用详解

《Android中Dialog的使用详解》Dialog(对话框)是Android中常用的UI组件,用于临时显示重要信息或获取用户输入,本文给大家介绍Android中Dialog的使用,感兴趣的朋友一起... 目录android中Dialog的使用详解1. 基本Dialog类型1.1 AlertDialog(