博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
Android回部古剑之ViewFlipper之翻来覆去
阅读量:5153 次
发布时间:2019-06-13

本文共 3769 字,大约阅读时间需要 12 分钟。

回部古剑

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

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

一、案例技术要点

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

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

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

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

二、案例代码陈列

工程包目录

AndroidManifest.xml

strings.xml
android图片水平滑动ViewFlipper
main.xml
图片左进动画:left_in.xml
图片左出动画:left_out.xml
图片右进动画:right_in.xml

图片右出动画:right_out.xml

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);    };}

三、案例效果展示

  

转载于:https://www.cnblogs.com/innosight/archive/2013/06/14/3271178.html

你可能感兴趣的文章
微博项目学习笔记
查看>>
proxifier 代理bluestack
查看>>
web 前端路线
查看>>
(VC/MFC)多线程(Multi-Threading) -1. 基本概念.
查看>>
快数据时代下,Moka携手DataPipeline提升招聘效能
查看>>
DataPipeline丨构建实时数据集成平台时,在技术选型上的考量点
查看>>
day1 用户登陆三次机会
查看>>
LeetCode 159. Longest Substring with At Most Two Distinct Characters
查看>>
LeetCode Ones and Zeroes
查看>>
CF932E Team Work——第二类斯特林数
查看>>
敏捷开发一千零一问系列之十三:故事点好还是人天好?
查看>>
内置函数— — eval、exec、compile
查看>>
基本算法概论
查看>>
jquery动态移除/增加onclick属性详解
查看>>
第九周作业
查看>>
MiniMagick
查看>>
sqlserver2014无法打开报Cannot find one or more components_修复方案
查看>>
css important
查看>>
KindEditor图片上传到七牛云
查看>>
JavaScript---Promise
查看>>