前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >安卓开发_浅谈Android动画(一)

安卓开发_浅谈Android动画(一)

作者头像
听着music睡
发布2018-05-18 13:55:59
7590
发布2018-05-18 13:55:59
举报
文章被收录于专栏:Android干货

动画效果,针对图片实现

现在学习四种基本的简单动画效果

一、Tween Animation共同属性

  1、Duration:动画持续时间(毫秒单位)   2、fillAfter:设置为true,动画转化在动画结束后被应用   3、fillBefore:设置为true,动画转化在动画开始前被应用   4、interpolator:动画插入器(加速,减速插入器)   5、repeatCount:动画重复次数   6、repateMode:顺序重复/倒序重复   7、startOffset:动画之间的时间间隔

二、Animation实现方式

  1、配置文件(/res/anim)--alpha,scale,translate,rotatae   2、JAVA代码实现--AlphaAnimation,ScaleAnimation,TranslateAnimation,RotateAnimation

三、四种基本动画

 1、AlphaAnimation(透明度动画)   (1)fromAlpha:动画起始时的透明度   (2)toAlpha:动画终止时的透明度   0.0表示完全透明 1.0表示完全不透明

 2、ScaleAnimation(缩放动画)   (1)fromX,toX分别是起始和结束时x坐标上的伸缩尺寸   (2)fromY,toY分别是起始和结束时y坐标上的伸缩尺寸   (3)pivotX,pivotY分别为伸缩动画相对于x,y,坐标开始的位置

 3、TranslateAnimation(位移动画)   (1)、fromXDelta,fromYDelta分别是起始时X,Y的坐标   (2)、toXDelta,toYDelta分别是结束时X,Y的坐标

 4、RotateAnimation(旋转动画)   (1)、fromDegrees 起始的角度   (2)、toDegrees 终止的角度   (3)、pivoteX,pivoteY分别为旋转动画相对于x,y的坐标的开始位置

四、示例

配置文件实现方法

代码语言:javascript
复制
 1 package other;
 2 
 3 import com.example.allcode.ImageTest;
 4 import com.example.allcode.R;
 5 
 6 import android.app.Activity;
 7 import android.os.Bundle;
 8 import android.view.View;
 9 import android.view.View.OnClickListener;
10 import android.view.animation.Animation;
11 import android.view.animation.AnimationUtils;
12 import android.widget.Button;
13 import android.widget.ImageView;
14 
15 public class Donghua extends Activity implements OnClickListener{
16     private Button toumingdu;
17     private Button suofang;
18     private Button weiyi;
19     private Button xuanzhuan;
20 
21     private ImageView donghua_image;
22     private Animation loadAnimation;
23     @Override
24     protected void onCreate(Bundle savedInstanceState) {
25         // TODO Auto-generated method stub
26         super.onCreate(savedInstanceState);
27         setContentView(R.layout.donghua);
28         
29         toumingdu = (Button) findViewById(R.id.donghua_touming);
30         suofang = (Button) findViewById(R.id.donghua_suofang);
31         weiyi= (Button) findViewById(R.id.donghua_weiyi);
32         xuanzhuan= (Button) findViewById(R.id.donghua_xuanzhuan);
33         
34         donghua_image = (ImageView) findViewById(R.id.donghua_image);
35         toumingdu.setOnClickListener(this);
36         donghua_image.setOnClickListener(this);
37         suofang.setOnClickListener(this);
38         weiyi.setOnClickListener(this);
39         xuanzhuan.setOnClickListener(this);
40     }
41     @Override
42     public void onClick(View v) {
43         // TODO Auto-generated method stub
44         switch (v.getId()) {
45         case R.id.donghua_touming:  //透明动画
46             loadAnimation = AnimationUtils.loadAnimation(this, R.anim.alpha);
47             donghua_image.startAnimation(loadAnimation);
48             break;
49         case R.id.donghua_suofang: //缩放动画
50             loadAnimation = AnimationUtils.loadAnimation(this, R.anim.scale);
51             donghua_image.startAnimation(loadAnimation);
52             break;
53         case R.id.donghua_weiyi:   //位移动画
54             loadAnimation = AnimationUtils.loadAnimation(this, R.anim.translate);
55             donghua_image.startAnimation(loadAnimation);
56             break;
57         case R.id.donghua_xuanzhuan: //旋转动画
58             loadAnimation = AnimationUtils.loadAnimation(this, R.anim.rotate);
59             donghua_image.startAnimation(loadAnimation);
60             break;
61         default:
62             break;
63         }
64     }
65 
66 }

布局文件:

代码语言:javascript
复制
 1 <?xml version="1.0" encoding="utf-8"?>
 2 <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
 3     android:layout_width="match_parent"
 4     android:layout_height="match_parent"
 5     android:orientation="vertical" >
 6 
 7     <Button
 8         android:id="@+id/donghua_touming"
 9         android:layout_width="wrap_content"
10         android:layout_height="wrap_content"
11         android:text="AlphaAnimation(透明度动画)" />
12 
13     <Button
14         android:id="@+id/donghua_suofang"
15         android:layout_width="wrap_content"
16         android:layout_height="wrap_content"
17         android:text="ScaleAnimation(缩放动画)" />
18 
19     <Button
20         android:id="@+id/donghua_weiyi"
21         android:layout_width="wrap_content"
22         android:layout_height="wrap_content"
23         android:text="TranslateAnimation(位移动画)" />
24 
25     <Button
26         android:id="@+id/donghua_xuanzhuan"
27         android:layout_width="wrap_content"
28         android:layout_height="wrap_content"
29         android:text="RotateAnimation(旋转动画)" />
30 
31     <ImageView
32         android:id="@+id/donghua_image"
33         android:layout_width="82dp"
34         android:layout_height="wrap_content"
35         android:layout_weight="0.16"
36         android:src="@drawable/icon_72" />
37 
38 </LinearLayout>

配置文件:

目录。res-anim 自己新建

代码语言:javascript
复制
 1 <?xml version="1.0" encoding="utf-8"?>
 2 <set xmlns:android="http://schemas.android.com/apk/res/android" >
 3 
 4     <alpha
 5         android:duration="3000" 
 6         android:fromAlpha="0.1"//初始透明度10%
 7         android:toAlpha="1.0"  //结束透明度100%
 8     >
 9     </alpha>
10 
11 </set>
代码语言:javascript
复制
 1 <?xml version="1.0" encoding="utf-8"?>
 2 <set xmlns:android="http://schemas.android.com/apk/res/android" >
 3 
 4     <scale
 5         android:duration="2000"
 6         android:fillAfter="false"
 7         android:fromXScale="0.0"
 8         android:fromYScale="0.0"
 9         android:interpolator="@android:anim/accelerate_decelerate_interpolator"
10         android:pivotX="50%"
11         android:pivotY="50%"
12         android:toXScale="1.0"
13         android:toYScale="1.0" />
14 
15 </set>
代码语言:javascript
复制
 1 <?xml version="1.0" encoding="utf-8"?>
 2 <set xmlns:android="http://schemas.android.com/apk/res/android" >
 3 
 4     <translate
 5         android:duration="1000"
 6         android:fromXDelta="10"
 7         android:fromYDelta="10"
 8         android:toXDelta="100"
 9         android:toYDelta="100" />
10 
11 </set>
代码语言:javascript
复制
 1 <?xml version="1.0" encoding="utf-8"?>
 2 <set xmlns:android="http://schemas.android.com/apk/res/android" >
 3 
 4     <rotate
 5         android:duration="1000"
 6         android:fromDegrees="0"
 7         android:interpolator="@android:anim/accelerate_decelerate_interpolator"
 8         android:pivotX="50%"
 9         android:pivotY="50%"
10         android:toDegrees="+360" />
11 
12 </set>

效果图:

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2015-01-06 ,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档