Android ApiDemos示例解析(124):Views->ImageSwitcher

本文介绍了Android中的ImageSwitcher组件,它是ViewSwitcher的子类,用于实现两个图像之间的切换,并支持自定义动画效果。文中详细解释了如何设置图像资源及动画,并通过Gallery组件实现了用户交互。

前面介绍Android ApiDemos示例解析(97):Views->Animation->Push 时用到了ViewFlipper ,ViewFlipper 和ViewSwitcher 都是ViewAnimator 的子类,ViewAnimator (FrameLayout的子类)提供了不同View之间切换时的动画效果支持,应为ViewAnimator 为FrameLayout的子类,因此ViewAnimator中包含的子View都是叠放在一起,一般情况下支持看到最上面的一个View。

ViewFlipper 可以包括2个以上的子View,自动定时切换显示每个子View。而ViewSwitcher只能最多包括两个子View。每次只显示其中一个View,它有两个子类TextSwitcher 和ImageSwitcher 。本例使用ImageSwitcher 用于在包含在其中的两个图像之间切换.

ImageSwitcher 定义了setImageDrawable, setImageResource,setImageURI 可以通过不同的方式为ImageSwitcher指定图像,每次调用这些方法,新添加的图像和原来显示的图像之间切换时将采用由setInAnimation和setOutAnimation指定的动画效果:

mSwitcher = (ImageSwitcher) findViewById(R.id.switcher);
mSwitcher.setFactory(this);
mSwitcher.setInAnimation(AnimationUtils.loadAnimation(this,
 android.R.anim.fade_in));
mSwitcher.setOutAnimation(AnimationUtils.loadAnimation(this,
 android.R.anim.fade_out));


本例的Layout ,上方显示ImageSwitcher,下面是用Gallery显示图像的缩略图。Gallery用法参见Android ApiDemos示例解析(119):Views->Gallery->1. Photos

用户选择Gallery中某个缩略图时,将使用ImageSwitcher显示其对应大图:

public void onItemSelected(AdapterView parent,
 View v, int position, long id) {
 mSwitcher.setImageResource(mImageIds[position]);
}


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值