Android ApiDemos示例解析(97):Views->Animation->Push

在例子Android ApiDemos示例解析(95):View->Animation->3D Transition 为了在FrameLayout切换两个View :ListView 和 ImageView, 需要编写很多代码来实现两个View之间的切换。

Android 其实提供了一个更为简便的类ViewFlipper ,ViewFlipper既是FrameLayout 的子类,又是ViewAnimator 的子类,因此在功能上ViewFlipper 和FrameLayout类似,但它可以自动管理包含在ViewFlipper在各个子类之间的切换,而View之间的切换的动画效果可以通过ViewAnimator的功能来实现。

ViewAnimator 运行定义两个Animation动作:

  • inAnimation: 当View显示时动画资源ID
  • outAnimation: 当View隐藏是动画资源ID。

ViewFlipper 自动切换包含在其中的View,同一时间只能显示一个View,在View之间切换时,以inAnimation 动画显示新出现的View,而以outAnimation 动画隐藏先前的View。

本例中ViewFlipper 中定义了四个TextView,每个TextView显示一行文字:

<ViewFlipper android:id=”@+id/flipper”
 android:layout_width=”match_parent”
 android:layout_height=”wrap_content”
 android:flipInterval=”2000″
 android:layout_marginBottom=”20dip” >
 <TextView
 android:layout_width=”match_parent”
 android:layout_height=”wrap_content”
 android:gravity=”center_horizontal”
 android:textSize=”26sp”
 android:text=”@string/animation_2_text_1″/>
 <TextView
 android:layout_width=”match_parent”
 android:layout_height=”wrap_content”
 android:gravity=”center_horizontal”
 android:textSize=”26sp”
 android:text=”@string/animation_2_text_2″/>
 <TextView
 android:layout_width=”match_parent”
 android:layout_height=”wrap_content”
 android:gravity=”center_horizontal”
 android:textSize=”26sp”
 android:text=”@string/animation_2_text_3″/>
 <TextView
 android:layout_width=”match_parent”
 android:layout_height=”wrap_content”
 android:gravity=”center_horizontal”
 android:textSize=”26sp”
 android:text=”@string/animation_2_text_4″/>
 </ViewFlipper>

调用ViewFlipper 的 startFlipping() 开始以相同的间隔顺序显示四个TextView。

mFlipper.startFlipping();

提供一个Spinner(下拉框)允许设置不同inAnimation 和outAnimation 为TextView显示隐藏添加不同的动画效果,如:左边出左边进

mFlipper.setInAnimation(AnimationUtils.loadAnimation(this,
 R.anim.push_left_in));
mFlipper.setOutAnimation(AnimationUtils.loadAnimation(this,
 R.anim.push_left_out));




  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值