android动画的透明度渐变、旋转动画、缩放动画、评议动画

这是我在学习android的时候做的一个小小的东西可以实现图片的旋转、平移、缩放、透明度的渐变

首先我们要创建一个android的项目 

在自己的drawable-mdpi中添加自己的图片

然后在res目录中,创建一个名称是anim(动画)的目录,并且在该目录中实现图片的操作

首先是anim_alpha.xml定义一个实现透明渐变的动画该动画实现的是完全不透明——>完全透明————>完全不透明

<pre name="code" class="html"><?xml version="1.0" encoding="utf-8"?>
<set xmlns:android="http://schemas.android.com/apk/res/android">
	<alpha android:fromAlpha="1"
	    android:toAlpha="0"
	    android:fillAfter="true"
	    android:repeatMode="reverse"
	    android:repeatCount="1"
	    android:duration="2000"/>
</set>

 
 

然后是创建anim_rotate.xml的文件,在该文件中定义一个实现旋转的动画,实现从零到720再从360到零的旋转

<?xml version="1.0" encoding="utf-8"?>
<set xmlns:android="http://schemas.android.com/apk/res/android">
	<rotate 
	    android:interpolator="@android:anim/accelerate_interpolator"
	    android:fromDegrees="0"
	    android:toDegrees="720"
	    android:pivotX="50%"
	    android:pivotY="50%"
	    android:duration="2000">
	</rotate>
	<rotate 
	    android:interpolator="@android:anim/accelerate_interpolator"
	    android:startOffset="2000"
	    android:fromDegrees="360"
	    android:toDegrees="0"
	    android:pivotX="50%"
	    android:pivotY="50%"
	    android:duration="2000">
	</rotate>	
</set>

创建名称是anim_scale.xml的文件定义一个实现缩放的动画,该动画首先将原来的图像放大两倍再将其缩小到原来的尺寸;

<?xml version="1.0" encoding="utf-8"?>
<set  xmlns:android="http://schemas.android.com/apk/res/android">
	<scale android:fromXScale="1"
	    android:interpolator="@android:anim/decelerate_interpolator"
	    android:fromYScale="1"
	    android:toXScale="2.0"
	    android:toYScale="2.0"
	    android:pivotX="50%"
	    android:pivotY="50%"
	    android:fillAfter="true"
	    android:repeatCount="1"
	    android:repeatMode="reverse"
	    android:duration="2000"/>
</set>

创建名称是anim_translate.xml的文件实现图片的平移从左侧移动到右侧然后从右侧移动到左侧

<?xml version="1.0" encoding="utf-8"?>
<set xmlns:android="http://schemas.android.com/apk/res/android">
<translate 
    android:fromXDelta="0"
    android:toXDelta="860"
    android:fromYDelta="0"
    android:toYDelta="0"
    android:fillAfter="true"
    android:repeatMode="reverse"
    android:repeatCount="1"
    android:duration="2000">
</translate> 
</set>

这样   我们接下来就写main.XML:

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:id="@+id/linearLayout1"
   
    android:layout_width="fill_parent"
    android:layout_height="fill_parent"
    android:orientation="vertical" >

    <LinearLayout
        android:id="@+id/linearLayout2"
        android:orientation="horizontal"
        android:layout_width="match_parent"
        android:layout_height="wrap_content" >
    <Button
        android:id="@+id/button1"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:text="旋转" />
    <Button
        android:id="@+id/button2"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:text="平移" />

    <Button
        android:id="@+id/button3"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:text="缩放" />

    <Button
        android:id="@+id/button4"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:text="透明度渐变" />        
    </LinearLayout>
	
    <ImageView
        android:id="@+id/imageView1"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_marginLeft="50px"
        android:src="@drawable/cat" />
</LinearLayout>

然后就是修改MainActivity.java

package com.mingrisoft;

import android.app.Activity;
import android.os.Bundle;
import android.view.View;
import android.view.View.OnClickListener;
import android.view.animation.Animation;
import android.view.animation.AnimationUtils;
import android.widget.Button;
import android.widget.ImageView;

public class MainActivity extends Activity {
	@Override
	public void onCreate(Bundle savedInstanceState) {
		super.onCreate(savedInstanceState);
		setContentView(R.layout.main);
		
		final Animation rotate=AnimationUtils.loadAnimation(this, R.anim.anim_rotate);	//获取“旋转”动画资源
		final Animation translate=AnimationUtils.loadAnimation(this, R.anim.anim_translate);	//获取“平移”动画资源
		final Animation scale=AnimationUtils.loadAnimation(this, R.anim.anim_scale);	//获取“缩放”动画资源
		final Animation alpha=AnimationUtils.loadAnimation(this, R.anim.anim_alpha);	//获取“透明度变化”动画资源
		final ImageView iv=(ImageView)findViewById(R.id.imageView1);	//获取要应用动画效果的ImageView
		Button button1=(Button)findViewById(R.id.button1);	//获取“旋转”按钮
		button1.setOnClickListener(new OnClickListener() {
			
			
			public void onClick(View v) {
				iv.startAnimation(rotate);		//播放“旋转”动画
				
			}
		});	
		Button button2=(Button)findViewById(R.id.button2);	//获取“平移”按钮
		button2.setOnClickListener(new OnClickListener() {
			
			
			public void onClick(View v) {
				iv.startAnimation(translate);	//播放“平移”动画
				
			}
		});
		Button button3=(Button)findViewById(R.id.button3);	//获取“缩放”按钮
		button3.setOnClickListener(new OnClickListener() {
			
			
			public void onClick(View v) {
				iv.startAnimation(scale);	//播放“缩放”动画
				
			}
		});		
		Button button4=(Button)findViewById(R.id.button4);	//获取“透明度渐变”按钮
		button4.setOnClickListener(new OnClickListener() {
			
			
			public void onClick(View v) {
				iv.startAnimation(alpha);	//播放“透明度渐变”动画
				
			}
		});			
	}
}

这样我们的小小的动画制作就完成了 



你可能感兴趣的:(java,android,动画,图片,开放)