777
京東網上商城
ViewFlipper實現多頁麵切換
1、屏幕切換指的是在同一個Activity內屏幕見的切換,最長見的情況就是在一個FrameLayout內有多個頁麵,比如一個係統設置頁麵;一個個性化設置頁麵。
2、介紹ViewFilpper類
ViewFlipper
extends ViewAnimator
java.lang.Object
↳ android.view.View
↳ android.view.ViewGroup
↳ android.widget.FrameLayout
↳ android.widget.ViewAnimator
↳ android.widget.ViewFlipper
Class Overview
Simple ViewAnimator that will animate between two or more views that have been added to it. Only one child is shown at a time. If requested, can automatically flip between each child at a regular interval.
意思是:簡單的ViewAnimator之間,兩個或兩個以上的view加上動畫效果。隻有一個小孩會顯示在一個時間。如果需要,每個孩子能自動翻轉之間在固定的時間間隔。
該類繼承了Framelayout類,ViewAnimator類的作用是為FrameLayout裏麵的View切換提供動畫效果。
該類有如下幾個和動畫相關的函數:
setInAnimation:設置View進入屏幕時候使用的動畫,該函數有兩個版本,一個接受單個參數,類型為android.view.animation.Animation;一個接受兩個參數,類型為Context和int,分別為Context對象和定義Animation的resourceID。
setOutAnimation: 設置View退出屏幕時候使用的動畫,參數setInAnimation函數一樣。
showNext: 調用該函數來顯示FrameLayout裏麵的下一個View。
showPrevious: 調用該函數來顯示FrameLayout裏麵的上一個View。
3、首選看一下定義四個動畫的xml文件:
in_left_right.xml——從左到右進入屏幕
- <?xml version="1.0" encoding="utf-8"?>
- <set
- xmlns:android="https://schemas.android.com/apk/res/android"
- >
- <translate
- android:fromXDelta="-100%p"
- android:toXDelta="0"
- android:duration="2000"
- />
- </set>
out_left_right.xml——從左到右出去屏幕
- <?xml version="1.0" encoding="utf-8"?>
- <set
- xmlns:android="https://schemas.android.com/apk/res/android"
- >
- <translate
- android:fromXDelta="0"
- android:toXDelta="100%p"
- android:duration="2000"
- />
- </set>
in_right_left.xml——從右到左進入屏幕
- <?xml version="1.0" encoding="utf-8"?>
- <set
- xmlns:android="https://schemas.android.com/apk/res/android"
- >
- <translate
- android:fromXDelta="100%p"
- android:toXDelta="0"
- android:duration="2000"
- />
- </set>
out_right_left.xml——從右到左出去屏幕
- <?xml version="1.0" encoding="utf-8"?>
- <set
- xmlns:android="https://schemas.android.com/apk/res/android"
- >
- <translate
- android:fromXDelta="0"
- android:toXDelta="-100%p"
- android:duration="2000"
- />
- </set>
4、定義main.xml文件
- <?xml version="1.0" encoding="utf-8"?>
- <LinearLayout xmlns:android="https://schemas.android.com/apk/res/android"
- android:layout_width="fill_parent"
- android:layout_height="fill_parent"
- android:background="#ffffff"
- android:orientation="vertical"
- android:padding="15dp" >
- <ViewFlipper
- android:id="@+id/flipper"
- android:layout_width="fill_parent"
- android:layout_height="fill_parent" >
- <!-- 第一個頁麵 -->
- <LinearLayout
- android:id="@+id/layout1"
- android:layout_width="fill_parent"
- android:layout_height="fill_parent"
- android:orientation="vertical">
- <Spinner
- android:id="@+id/spinner"
- android:layout_width="fill_parent"
- android:layout_height="wrap_content" />
- <com.tiantang.testandroid1.MyTextView
- android:id="@+id/mytext"
- android:layout_width="fill_parent"
- android:layout_height="wrap_content"
- android:clickable="true"
- android:ellipsize="marquee"
- android:focusable="true"
- android:focusableInTouchMode="true"
- android:lines="1"
- android:marqueeRepeatLimit="marquee_forever"
- android:scrollHorizontally="true"
- android:text="1234567890987654321234556778909876765453234567898765322"
- android:textColor="#000000"
- android:textSize="20dp" />
- </LinearLayout>
- <!-- 第二個頁麵 -->
- <SlidingDrawer
- android:id="@+id/drawer"
- android:layout_width="fill_parent"
- android:layout_height="fill_parent"
- android:content="@+id/content"
- android:handle="@+id/handle" >
- <ImageView
- android:id="@id/handle"
- android:layout_width="50dp"
- android:layout_height="50dp"
- android:src="@drawable/info" />
- <ImageView
- android:id="@id/content"
- android:layout_width="fill_parent"
- android:layout_height="fill_parent"
- android:src="@drawable/confirm_bg" />
- </SlidingDrawer>
- </ViewFlipper>
- </LinearLayout>
5、java代碼實現:
- package com.tiantang.testandroid1;
- import android.app.Activity;
- import android.content.Context;
- import android.os.Bundle;
- import android.view.GestureDetector;
- import android.view.GestureDetector.OnGestureListener;
- import android.view.LayoutInflater;
- import android.view.MotionEvent;
- import android.view.View;
- import android.view.View.OnTouchListener;
- import android.view.ViewGroup;
- import android.widget.ArrayAdapter;
- import android.widget.BaseAdapter;
- import android.widget.Button;
- import android.widget.EditText;
- import android.widget.ListView;
- import android.widget.RadioButton;
- import android.widget.SlidingDrawer;
- import android.widget.Spinner;
- import android.widget.TextView;
- import android.widget.ViewFlipper;
- public class TestAndroid1Activity extends Activity {
- /** Called when the activity is first created. */
- private Spinner spinner;
- private ViewFlipper flipper;
- private MyAdapter adapter;
- private TextView text;
- private SlidingDrawer drawer;
- private GestureDetector detector;
- @Override
- public void onCreate(Bundle savedInstanceState) {
- super.onCreate(savedInstanceState);
- setContentView(R.layout.main);
- spinner = (Spinner) findViewById(R.id.spinner);
- drawer = (SlidingDrawer) findViewById(R.id.drawer);
- flipper = (ViewFlipper) findViewById(R.id.flipper);
- String[] strs = new String[]{"1234567890987654321234556778909876765453234567898765322"};
- ArrayAdapter<String> adapter = new ArrayAdapter<String>(this, R.layout.mytext, strs);
- spinner.setAdapter(adapter);
- flipper.setLongClickable(true);
- flipper.setOnTouchListener(new OnTouchListener() {
- @Override
- public boolean onTouch(View v, MotionEvent event) {
- // TODO Auto-generated method stub
- detector.onTouchEvent(event);
- return false;
- }
- });
- detector = new GestureDetector(this, new OnGestureListener(){
- @Override
- public boolean onDown(MotionEvent e) {
- //用戶輕觸屏幕。(單擊)
- return true;
- }
- @Override
- public boolean onFling(MotionEvent e1, MotionEvent e2, float velocityX, float velocityY) {
- //用戶按下屏幕,快速移動後鬆開(就是在屏幕上滑動)
- //e1:第一個ACTION_DOWN事件(手指按下的那一點)
- //e2:最後一個ACTION_MOVE事件 (手指鬆開的那一點)
- //velocityX:手指在x軸移動的速度 單位:像素/秒
- //velocityY:手指在y軸移動的速度 單位:像素/秒
- int x = (int) (e2.getX() - e1.getX());
- if(x>0){
- flipper.setInAnimation(TestAndroid1Activity.this,R.anim.in_left_right );
- flipper.setOutAnimation(TestAndroid1Activity.this,R.anim.out_left_right );
- flipper.showPrevious();
- }else{
- flipper.setInAnimation(TestAndroid1Activity.this,R.anim.in_right_left );
- flipper.setOutAnimation(TestAndroid1Activity.this,R.anim.out_right_left );
- flipper.showNext();
- }
- return true;
- }
- @Override
- public void onLongPress(MotionEvent e) {
- // TODO Auto-generated method stub
- //用戶長按屏幕
- }
- @Override
- public boolean onScroll(MotionEvent e1, MotionEvent e2, float distanceX, float distanceY) {
- // TODO Auto-generated method stub
- return false;//用戶按下屏幕並拖動
- }
- @Override
- public void onShowPress(MotionEvent e) {
- // TODO Auto-generated method stub
- //用戶輕觸屏幕,尚末鬆開或拖動,注意,強調的是沒有沒有鬆開或者拖動狀態
- }
- @Override
- public boolean onSingleTapUp(MotionEvent e) {
- // TODO Auto-generated method stub
- return false;//用戶輕觸屏幕後鬆開。
- }
- });
- }
最後更新:2017-04-03 16:49:10