使用ViewSwitcher和ViewFlipper在不同佈局中切換

很簡單,廢話不多說,直接貼代碼:

xml佈局:

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

    <ViewSwitcher
        android:id="@+id/switcher"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:inAnimation="@anim/slide_in_top"
        android:outAnimation="@anim/slide_out_bottom" >

        <RelativeLayout
            android:layout_width="wrap_content"
            android:layout_height="wrap_content" >

            <TextView
                android:layout_width="fill_parent"
                android:layout_height="100dp"
                android:background="#123456"
                android:text="11111111"
                android:textSize="32sp" >
            </TextView>
        </RelativeLayout>

        <RelativeLayout
            android:layout_width="wrap_content"
            android:layout_height="wrap_content" >

            <TextView
                android:layout_width="fill_parent"
                android:layout_height="100dp"
                android:background="#FFFFFFFF"
                android:text="22222222"
                android:textSize="32sp" >
            </TextView>
        </RelativeLayout>
    </ViewSwitcher>

    <Button
        android:id="@+id/prev"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:text="prev" />

    <Button
        android:id="@+id/next"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:text="next" />

</LinearLayout>

自定義的動畫,也可以用系統自帶的,在@android:anim/目錄:

slide_in_top.xml

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

    <translate
        android:duration="2000"
        android:fromYDelta="-100%p"
        android:toYDelta="0" />

</set>

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

    <translate
        android:duration="2000"
        android:fromYDelta="0"
        android:toYDelta="100%p" />

</set>

Java代碼:

package com.arnold.activity;

import android.app.Activity;
import android.os.Bundle;
import android.view.View;
import android.widget.Button;
import android.widget.ViewSwitcher;

public class MainActivity extends Activity {
	/** Called when the activity is first created. */

	private ViewSwitcher mSwitcher;
	private Button btn_prev, btn_next;

	@Override
	public void onCreate(Bundle savedInstanceState) {
		super.onCreate(savedInstanceState);
		setContentView(R.layout.main);

		mSwitcher = (ViewSwitcher) findViewById(R.id.switcher);
		mSwitcher.setDisplayedChild(0);

		btn_next = (Button) findViewById(R.id.next);
		btn_prev = (Button) findViewById(R.id.prev);

		btn_next.setOnClickListener(new View.OnClickListener() {

			@Override
			public void onClick(View v) {
				mSwitcher.showNext();
			}
		});
		btn_prev.setOnClickListener(new View.OnClickListener() {

			@Override
			public void onClick(View v) {
				mSwitcher.showPrevious();
			}
		});
	}

}

注意:ViewSwitcher只可以在兩種佈局中切換,ViewFlipper可以應用多種佈局,用法基本一樣但後者多出幾個方法:

isFlipping:用來判斷View切換是否正在進行
setFilpInterval:設置View之間切換的時間間隔
startFlipping:使用上面設置的時間間隔來開始切換所有的View,切換會循環進行
stopFlipping:停止View切換


發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章