Android Transition框架使用--Demo(2)

这篇文章接Transition框架介绍,给出一个完整的Demo。

1 Activity代码

public class TransitionActivity2 extends Activity implements View.OnClickListener {
    RelativeLayout rl;
    //scenes to transition
    private Scene scene1, scene2;
    //transition to move between scenes
    private Transition transition;
    //flag to swap between scenes
    private boolean start;

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
//        getWindow().requestFeature(Window.FEATURE_ACTIVITY_TRANSITIONS);
        setContentView(R.layout.activity_transition_start2);
        rl=(RelativeLayout)findViewById(R.id.base);
        rl.setOnClickListener(this);
        //get the layout ID
        RelativeLayout baseLayout = (RelativeLayout)findViewById(R.id.base);
//first scene
        ViewGroup startViews = (ViewGroup)getLayoutInflater()
                .inflate(R.layout.activity_transition_start2, baseLayout, false);

//second scene
        ViewGroup endViews = (ViewGroup)getLayoutInflater()
                .inflate(R.layout.activity_transition_end2, baseLayout, false);
        //create the two scenes

        scene1 = new Scene(baseLayout, startViews);
        scene2 = new Scene(baseLayout, endViews);
        //create transition, set properties
        transition = new AutoTransition();
        transition.setDuration(2000);
        transition.setInterpolator(new AccelerateDecelerateInterpolator());

//initialize flag
        start=true;

    }

    @Override
    public void onClick(View v) {
//check flag
        if(start) {
            TransitionManager.go(scene2, transition);
            start=false;
        }
        else {
            TransitionManager.go(scene1, transition);
            start=true;
        }
    }
}

2 activity_transition_main3.xml

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout  xmlns:android="http://schemas.android.com/apk/res/android"

    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:orientation="vertical"
    android:id="@+id/master_layout">

    <TextView
        android:id="@+id/tv_title"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_alignParentStart="true"


        android:layout_alignParentTop="true"
        android:layout_marginTop="53dp"
        android:text="Title"
        android:textAppearance="?android:attr/textAppearanceLarge" />

    <FrameLayout android:id="@+id/scene_root"
        android:layout_width="match_parent"
        android:layout_height="wrap_content">

        <include layout="@layout/activity_transition_start3" />
    </FrameLayout>
</LinearLayout>

3 activity_transition_start3.xml

 

<?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:background="#ffffff"
    android:id="@+id/base"
    tools:context=".TransitionsActivity">

    <TextView

        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:textAppearance="?android:attr/textAppearanceLarge"
        android:text="Large Text11"
        android:id="@+id/text_view1"
        android:layout_alignParentTop="true"
        android:layout_alignParentStart="true"
        android:layout_marginTop="53dp" />
    <TextView

        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:textAppearance="?android:attr/textAppearanceLarge"
        android:text="Large Text22"
        android:id="@+id/text_view2"


        android:layout_marginTop="53dp"
        android:layout_below="@+id/text_view1"
        />
</RelativeLayout>

4 activity_transition_end3.xml

<?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:background="#ffffff"
    android:id="@+id/base"
    tools:context=".TransitionsActivity">

    <TextView

        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:textAppearance="?android:attr/textAppearanceLarge"
        android:text="Large Text22"
        android:id="@+id/text_view2"
        android:layout_alignParentTop="true"
        android:layout_alignParentStart="true"
        android:layout_marginTop="53dp" />
    <TextView

        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:textAppearance="?android:attr/textAppearanceLarge"
        android:text="Large Text11"
        android:id="@+id/text_view1"
        android:layout_below="@+id/text_view2"
        android:layout_marginTop="53dp" />
</RelativeLayout>

5 res/transition/fade_transition.xml

<transitionSet xmlns:android="http://schemas.android.com/apk/res/android"
    android:transitionOrdering="sequential">
<fade android:fadingMode="fade_out"/>
<changeBounds/>
<fade android:fadingMode="fade_in"/>
    </transitionSet>
<!--<autoTransition-->
    <!--xmlns:android="http://schemas.android.com/apk/res/android"-->
    <!--android:duration="3000"-->
    <!--android:interpolator="@android:interpolator/cycle"/>-->




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

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值