Hack6 为ViewGroup添加动画效果

此例中以一个RelativeLayout作为父级容器,其中纵向设置4个TextView。由于在onCreate中设定了动画效果,所以在启动时,会产生类似瀑布流的效果。

layout文件如下:

<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:tools="http://schemas.android.com/tools" android:layout_width="match_parent"
    android:layout_height="match_parent" android:paddingLeft="@dimen/activity_horizontal_margin"
    android:paddingRight="@dimen/activity_horizontal_margin"
    android:paddingTop="@dimen/activity_vertical_margin"
    android:paddingBottom="@dimen/activity_vertical_margin" tools:context=".MainActivity">

 <RelativeLayout
     android:id="@+id/subLayout"
     android:layout_centerInParent="true"
     android:gravity="center"
     android:layout_width="200dp"
     android:layout_height="200dp">

     <TextView
         android:id="@+id/txt1"
         android:layout_width="100dp"
         android:layout_height="20dp"
         android:background="#f00"/>
     <TextView
         android:id="@+id/txt2"
         android:layout_marginTop="20dp"
         android:layout_below="@+id/txt1"
         android:layout_width="100dp"
         android:layout_height="20dp"
         android:background="#0f0"/>
     <TextView
         android:id="@+id/txt3"
         android:layout_marginTop="20dp"
         android:layout_below="@+id/txt2"
         android:layout_width="100dp"
         android:layout_height="20dp"
         android:background="#00f"/>
     <TextView
         android:id="@+id/txt4"
         android:layout_marginTop="20dp"
         android:layout_below="@+id/txt3"
         android:layout_width="100dp"
         android:layout_height="20dp"
         android:background="#f0e000"/>

 </RelativeLayout>
</RelativeLayout> 
java代码如下所示:

@Override
protected void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    setContentView(R.layout.activity_main);

    RelativeLayout layout = (RelativeLayout) findViewById(R.id.subLayout);

    AnimationSet animationSet = new AnimationSet(true);

    TranslateAnimation animation1 = new TranslateAnimation(Animation.RELATIVE_TO_SELF,0.0f,
            Animation.RELATIVE_TO_SELF,0.0f,Animation.RELATIVE_TO_SELF,-1.0f,
            Animation.RELATIVE_TO_SELF,0.0f);
    animation1.setDuration(4000);
    AlphaAnimation animation2 = new AlphaAnimation(0.0f,1.0f);
    animation2.setDuration(4000);

    animationSet.addAnimation(animation1);
    animationSet.addAnimation(animation2);

    LayoutAnimationController layoutAnimationController = new LayoutAnimationController(
            animationSet,0.5f);

    layout.setLayoutAnimation(layoutAnimationController);

}

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值