animationlistener听名字就知道是对animation设置监听器,说简单点就是在animation动画效果开始执行前,执行完毕和重复执行时可以触发监听器,从而执行对应的函数。
开发环境为android4.1.
animaitonlistener的使用方法主要是在animation上设置一个监听器,即采用animation的方法成员setanimationlistener().其参数就是监听器的函数。
现在来说说本次实验的功能,主要有2个按钮,一个是增加图片的按钮,一个是删除图片的按钮,还有一个imageview的控件,用来显示图片的。当增加图片的按钮按下时,图片会以无到全尺寸的尺寸大小变化出现,而删除按钮按下时,图片会从全尺寸到0尺寸逐渐退出,最后删除掉。
程序界面如下:
这里值得一提的是viewgroup这个控件,感觉就是layout控件一样,本次实验的图片控件imageview里面的图片的增加和删除就是采用的viewgrop中的addview()和removeview()方法。这2种方法里面传入的参数就是imageview.
另外,mars老师资料中在增加图片监听器函数中,重新定义了一个imageview,重新把这个imageview加入到viewgroup中,这样会导致一个问题,那就是当我们把图片删除后且又重新加载后就删除不掉了,因为我们在删除的时候删的是布局文件中的imageview,但是增加按钮增加的是另外一个imageview,所以我们虽然删除掉了布局文件中的imageview,但是屏幕上还是会显示图片的。因此解决的方法就是在增加按钮函数中直接使用布局文件中的imageview,这样程序中可以一直增加图片和删除图片,且在屏幕中还能看到效果。
程序主要代码如下:
mainactivity.java:
package com.example.anim_5;
import android.app.activity;
import android.os.bundle;
import android.view.menu;
import android.view.view;
import android.view.view.onclicklistener;
import android.view.viewgroup;
import android.view.viewgroup.layoutparams;
import android.view.animation.animation;
import android.view.animation.animation.animationlistener;
import android.view.animation.scaleanimation;
import android.widget.button;
import android.widget.imageview;
public class mainactivity extends activity {
private button add = null;
private button delete = null;
private viewgroup viewgroup = null;
private imageview imageview = null;
@override
public void oncreate(bundle savedinstancestate) {
super.oncreate(savedinstancestate);
setcontentview(r.layout.activity_main);
add = (button)findviewbyid(r.id.add);
delete = (button)findviewbyid(r.id.delete);
imageview = (imageview)findviewbyid(r.id.image);
viewgroup = (viewgroup)findviewbyid(r.id.main_layout);
add.setonclicklistener(new addonclicklistener());
delete.setonclicklistener(new deleteonclicklistener());
}
private class addonclicklistener implements onclicklistener{
public void onclick(view v) {
// todo auto-generated method stub
//数字后面必须全部加f,否则报错
scaleanimation animation = new scaleanimation(0.0f, 1.0f, 0.0f, 1.0f,
animation.relative_to_self, 0.5f,
animation.relative_to_self, 0.5f);
animation.setstartoffset(500);
animation.setduration(1000);
// imageview image_add = new imageview(mainactivity.this);
// image_add.setimageresource(r.drawable.london_olympic);
// viewgroup.addview(image_add, new layoutparams(layoutparams.wrap_content, layoutparams.wrap_content));
// image_add.setanimation(animation);
//还是直接用布局文件中的imageview比较好,否则加入的图片用后面的方法视觉上是删不掉的
//这里是采用setimageresource方法加载图片到imageview控件上的。
imageview.setimageresource(r.drawable.london_olympic);
//用viewgroup将imageview加载到activity中
viewgroup.addview(imageview, new layoutparams(layoutparams.wrap_content, layoutparams.wrap_content));
//启动imageview的animation
imageview.startanimation(animation);
}
}
private class deleteonclicklistener implements onclicklistener{
public void onclick(view v) {
// todo auto-generated method stub
scaleanimation animation = new scaleanimation(1.0f, 0.0f, 1.0f, 0.0f,
animation.relative_to_self, 0.5f,
animation.relative_to_self, 0.5f);
animation.setstartoffset(500);
animation.setduration(1000);
//设置animationlistener
animation.setanimationlistener(new deleteanimationlistener());
imageview.startanimation(animation);
}
}
private class deleteanimationlistener implements animationlistener{
public void onanimationend(animation animation) {
// todo auto-generated method stub
viewgroup.removeview(imageview);
}
public void onanimationrepeat(animation animation) {
// todo auto-generated method stub
}
public void onanimationstart(animation animation) {
// todo auto-generated method stub
}
}
@override
public boolean oncreateoptionsmenu(menu menu) {
getmenuinflater().inflate(r.menu.activity_main, menu);
return true;
}
}
activity_main.xml:
<relativelayout xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:tools="http://schemas.android.com/tools"
android:id="@+id/main_layout"
android:layout_width="match_parent"
android:layout_height="match_parent" >
<button
android:id="@+id/delete"
android:layout_width="fill_parent"
android:layout_height="wrap_content"
android:layout_alignparentbottom="true"
android:text="delete image"
/>
<button
android:id="@+id/add"
android:layout_width="fill_parent"
android:layout_height="wrap_content"
android:layout_above="@+id/delete"
android:text="add image" />
<imageview
android:id= "@+id/image"
android:layout_width="wrap_content"
android:layout_height="310dip"
android:src="@drawable/london_olympic"
/>
</relativelayout>
总结:通过本次实验,可以了解到animationlistener的基本使用方法。
作者:tornadomeet