[置顶] Android回部古剑之ViewFlipper之翻来覆去

传送门 ☞ 仙人指路

回部古剑

        陈家洛英雄救美后,霍青桐送给他的定情之物回部古剑。陈家洛见霍阿伊方面大耳,满脸浓须,霍青桐却体态婀娜,娇如春花,丽若朝霞,先前专心观看她剑法,此时临近当面,不意人间竟有如此好女子,一时不由得心跳加剧。

        今天我们学习如何利用Android平台“回部古剑”ViewFlipper配合手势Gesture操作来实现左右滑动浏览图片的功能。像我们平日里在手机上查看电子相册、浏览电子书时所使用滑动翻页操作,都可以用它来实现。下面给出该情景的案例:

一、案例技术要点

1.创建一个ViewFlipper控件,并为其添加用于显示的图片内容。

2.为ViewFlipper控件所在Activity设置手势监听器OnGestureListener,并复写其手势滑动回调方法onFling()。

3.将Activity的触摸事件的回调方法onTouchEvent()指派给手指探测器GestureDetector对象调度。

4.为ViewFlipper对象依次添加左右滑进滑出屏幕的动画效果。

二、案例代码陈列

工程包目录

[置顶] Android回部古剑之ViewFlipper之翻来覆去

AndroidManifest.xml

<manifest xmlns:android="http://schemas.android.com/apk/res/android"

    package="cn.lynn.viewflipper"

    android:versionCode="1"

    android:versionName="1.0" >



    <uses-sdk

        android:minSdkVersion="8"

        android:targetSdkVersion="15" />



    <application

        android:icon="@drawable/ic_launcher"

        android:label="@string/app_name" >

        <activity

            android:name=".ViewFlipperMainActivity"

            android:label="@string/app_name" >

            <intent-filter>

                <action android:name="android.intent.action.MAIN" />



                <category android:name="android.intent.category.LAUNCHER" />

            </intent-filter>

        </activity>

    </application>



</manifest>

strings.xml

<resources>



    <string name="app_name">android图片水平滑动ViewFlipper</string>



</resources>

main.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:gravity="center" >



    <ViewFlipper 

        android:id="@+id/viewFlipper"

        android:layout_width="match_parent"

        android:layout_height="240dp"/>



</LinearLayout>

图片左进动画:left_in.xml

<?xml version="1.0" encoding="utf-8"?>  

<set xmlns:android="http://schemas.android.com/apk/res/android">

    <translate android:fromXDelta="100%p" android:toXDelta="0"

        android:duration="500" />

    <alpha android:fromAlpha="0.1" android:toAlpha="1.0"

        android:duration="500" />

</set>

图片左出动画:left_out.xml

<?xml version="1.0" encoding="utf-8"?> 

<set xmlns:android="http://schemas.android.com/apk/res/android">

    <translate android:fromXDelta="0" android:toXDelta="-100%p"

        android:duration="500" />

    <alpha android:fromAlpha="1.0" android:toAlpha="0.1"

        android:duration="500" />

</set>

图片右进动画:right_in.xml

<?xml version="1.0" encoding="utf-8"?> 

<set xmlns:android="http://schemas.android.com/apk/res/android">

    <translate android:fromXDelta="-100%p" android:toXDelta="0"

        android:duration="500" />

    <alpha android:fromAlpha="0.1" android:toAlpha="1.0"

        android:duration="500" />

</set>

图片右出动画:right_out.xml

<?xml version="1.0" encoding="utf-8"?> 

<set xmlns:android="http://schemas.android.com/apk/res/android">

    <translate android:fromXDelta="0" android:toXDelta="100%p"

        android:duration="500" />

    <alpha android:fromAlpha="1.0" android:toAlpha="0.1"

        android:duration="500" />

</set>

ViewFlipperMainActivity.java

package cn.lynn.viewflipper;



import android.app.Activity;

import android.os.Bundle;

import android.view.GestureDetector;

import android.view.GestureDetector.OnGestureListener;

import android.view.MotionEvent;

import android.view.View;

import android.view.animation.AnimationUtils;

import android.widget.ImageView;

import android.widget.ViewFlipper;



/**

 * ViewFlipper实现水平滑动图片

 * @author lynnli1229

 */

public class ViewFlipperMainActivity extends Activity implements OnGestureListener {

    private ViewFlipper viewFlipper;

    private GestureDetector gestureDetector;

    

    // 声明图片资源数组

    private int[] imageResIds = { R.drawable.item1, R.drawable.item2,

        R.drawable.item3, R.drawable.item4, R.drawable.item5};



    @Override

    public void onCreate(Bundle savedInstanceState) {

        super.onCreate(savedInstanceState);

        setContentView(R.layout.main);

        

        gestureDetector = new GestureDetector(this);

        viewFlipper = (ViewFlipper) findViewById(R.id.viewFlipper);



        for (int i = 0; i < imageResIds.length; i++) {

            viewFlipper.addView(addImageView(i));

        }



    }

    

    /**

     * 为ViewFlipper添加图片视图

     */

    private View addImageView(int position) {

        ImageView imageView = new ImageView(this);

        imageView.setImageResource(imageResIds[position]);

        return imageView;

    }



    @Override

    public boolean onDown(MotionEvent e) {

        return false;

    }



    @Override

    public void onShowPress(MotionEvent e) {

    }



    @Override

    public boolean onSingleTapUp(MotionEvent e) {

        return false;

    }



    @Override

    public boolean onScroll(MotionEvent e1, MotionEvent e2, float distanceX, float distanceY) {

        return false;

    }



    @Override

    public void onLongPress(MotionEvent e) {

    }



    /**

     * 手指滑动事件回调方法

     */

    @Override

    public boolean onFling(MotionEvent e1, MotionEvent e2, float velocityX, float velocityY) {

        if(e1.getX() - e2.getX() > 100.0f) { // 向左(前)滑动,显示下一张图片

            viewFlipper.setInAnimation(AnimationUtils.loadAnimation(this, R.anim.left_in));

            viewFlipper.setInAnimation(AnimationUtils.loadAnimation(this, R.anim.left_out));

            viewFlipper.showNext();

            return true;

        } else if(e1.getX() - e2.getX() < -100.0f) { // 向后(右)滑动,显示上一张图片

            viewFlipper.setInAnimation(AnimationUtils.loadAnimation(this, R.anim.right_in));

            viewFlipper.setInAnimation(AnimationUtils.loadAnimation(this, R.anim.right_out));

            viewFlipper.showPrevious();

            return true;

        }



        return false;

    }

    

    /**

     * 将当前Activity的触摸事件回调方法指派由gestureDetector对象进行调度

     */

    @Override

    public boolean onTouchEvent(MotionEvent event) {

        return gestureDetector.onTouchEvent(event);

    };

}

三、案例效果展示

[置顶] Android回部古剑之ViewFlipper之翻来覆去 [置顶] Android回部古剑之ViewFlipper之翻来覆去 [置顶] Android回部古剑之ViewFlipper之翻来覆去

你可能感兴趣的:(viewflipper)