说到android的左右滑动效果我们可以说是在每个应用上面都可以看到这样的效果,不管是微博,还是QQ等。实现左右滑动的方式很多,有ViewPaer(不过这个和需要android-support-v4.jar的支持),自定义实现Viewgroup,gallery等都可以达到这种效果。这里做下ViewFliper实现左右滑动的效果。
以下会会用到的技术有: 1、ViewFlipper 2、GestureDetector 3、Animation 主要是这三个类再起作用。
原理:向左向右滑动主要是依赖手势来控制,手势向右滑动就调用 viewFlipper.showNext();方法,同理,向左滑动就会去调用viewFlipper.showPrevious();方法。
接下来直接上代码:
首先在布局文件中添加ViewFlipper的标签:

复制内容到剪贴板

代码:

<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" >
   <ViewFlipper        android:id="@+id/viewFlipper"        android:layout_width="match_parent"        android:layout_height="match_parent"        ></ViewFlipper>
< /RelativeLayout>

编写代码:

复制内容到剪贴板

代码:

package com.xzw.ui;
import android.app.Activity; import android.os.Bundle; import android.util.Log; import android.view.GestureDetector; import android.view.GestureDetector.OnGestureListener; import android.view.MotionEvent; import android.view.View; import android.view.ViewGroup; import android.view.Window; import android.view.animation.Animation; import android.view.animation.AnimationUtils; import android.widget.ImageView; import android.widget.ViewFlipper; /** * 左右滑动demo * @author xzw * */ public class MainActivity extends Activity implements OnGestureListener {                  private static final String TAG = "MainActivity";                  private ViewFlipper viewFlipper;         private GestureDetector detector; //手势检测
        Animation leftInAnimation;         Animation leftOutAnimation;         Animation rightInAnimation;         Animation rightOutAnimation;     @Override     public void onCreate(Bundle savedInstanceState) {         super.onCreate(savedInstanceState);         requestWindowFeature(Window.FEATURE_NO_TITLE);         setContentView(R.layout.activity_main);                  viewFlipper = (ViewFlipper)findViewById(R.id.viewFlipper);         detector = new GestureDetector(this);                  //往viewFlipper添加View         viewFlipper.addView(getImageView(R.drawable.new_feature_1));         viewFlipper.addView(getImageView(R.drawable.new_feature_2));         viewFlipper.addView(getImageView(R.drawable.new_feature_3));         viewFlipper.addView(getImageView(R.drawable.new_feature_4));         viewFlipper.addView(getImageView(R.drawable.new_feature_5));         viewFlipper.addView(getImageView(R.drawable.new_feature_6));                  //动画效果             leftInAnimation = AnimationUtils.loadAnimation(this, R.anim.left_in);                 leftOutAnimation = AnimationUtils.loadAnimation(this, R.anim.left_out);                 rightInAnimation = AnimationUtils.loadAnimation(this, R.anim.right_in);                 rightOutAnimation = AnimationUtils.loadAnimation(this, R.anim.right_out);     }
    private ImageView getImageView(int id){             ImageView imageView = new ImageView(this);             imageView.setImageResource(id);             return imageView;     }
    @Override     public boolean onTouchEvent(MotionEvent event) {                   return this.detector.onTouchEvent(event); //touch事件交给手势处理。     }             @Override         public boolean onDown(MotionEvent e) {                 // TODO Auto-generated method stub                 return false;         }
        @Override         public boolean onFling(MotionEvent e1, MotionEvent e2, float velocityX,                         float velocityY) {                 Log.i(TAG, "e1="+e1.getX()+" e2="+e2.getX()+" e1-e2="+(e1.getX()-e2.getX()));                                                          if(e1.getX()-e2.getX()>120){                         viewFlipper.setInAnimation(leftInAnimation);                         viewFlipper.setOutAnimation(leftOutAnimation);                     viewFlipper.showNext();//向右滑动                     return true;                 }else if(e1.getX()-e2.getY()<-120){                         viewFlipper.setInAnimation(rightInAnimation);                         viewFlipper.setOutAnimation(rightOutAnimation);                         viewFlipper.showPrevious();//向左滑动                         return true;                 }                 return false;         }
        @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;         }         }

接下来我们编写动画效果的xml文件,你也可以通过代码实现,这里使用xml配置,个人感觉比较简单。
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="600"         />     <alpha         android:fromAlpha="0.1"         android:toAlpha="1.0"         android:duration="600"         />
< /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="600"         />     <alpha         android:fromAlpha="1.0"         android:toAlpha="0.1"         android:duration="600"         />
< /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="600"         />     <alpha         android:fromAlpha="0.1"         android:toAlpha="1.0"         android:duration="600"         />
< /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="600"         />     <alpha         android:fromAlpha="1.0"         android:toAlpha="0.1"         android:duration="600"         />
< /set>

以上就是完整的代码,看起来很简单吧。 看下面的效果图吧,秋天到了,图片也选择的有秋意点儿哈。 附上源代码:http://down.51cto.com/data/579206

android的左右滑动效果实现-ViewFlipper的更多相关文章

  1. Android 实现左右滑动效果ViewFlipper终结【转】

    本示例演示在Android中实现图片左右滑动效果.   关于滑动效果,在Android中用得比较多,本示例实现的滑动效果是使用ViewFlipper来实现的,当然也可以使用其它的View来实现.接下来 ...

  2. Android实现左右滑动效果

    本示例演示在Android中实现图片左右滑动效果.   关于滑动效果,在Android中用得比较多,本示例实现的滑动效果是使用ViewFlipper来实现的,当然也可以使用其它的View来实现.接下来 ...

  3. Android Scroll分析——滑动效果产生

    相对于在Android2.x版本上出现的长按.点击事件的效果,不得不说,滑动操作具有更好的用户体验.因此,从Android 4.X版本开始,出现了更多滑动操作的效果.越来越多第三方应用模仿这样的效果, ...

  4. 十六、Android 滑动效果汇总

    Android 滑动效果入门篇(一)—— ViewFlipper Android 滑动效果入门篇(二)—— Gallery Android 滑动效果基础篇(三)—— Gallery仿图像集浏览 And ...

  5. Android实现左右滑动指引效果

    本文介绍Android中实现左右滑动的指引效果. 关于左右滑动效果,我在以前的一篇博文中提到过,有兴趣的朋友可以查看:http://www.cnblogs.com/hanyonglu/archive/ ...

  6. Android中实现滑动翻页—使用ViewFlipper(dp和px之间进行转换)

    Android中实现滑动翻页—使用ViewFlipper(dp和px之间进行转换) Android中dp和px之间进行转换 在xml布局文件中,我们既可以设置px,也可以设置dp(或者dip).一般情 ...

  7. Android三种左右滑动效果 手势识别

    Android三种左右滑动效果 手势识别(转)   手势识别 1.onCreate中添加GestureDetector mGestureDetector; //监听手势事件 mGestureDetec ...

  8. Android实现渐显按钮的左右滑动效果

    本示例演示在Android中实现带渐显按钮的左右滑动效果. 关于滑动效果,在我的上一篇博文中提到过,有兴趣的朋友可以访问: http://www.cnblogs.com/hanyonglu/archi ...

  9. Android三种左右滑动效果 手势识别(转)

    本示例演示在Android中实现带渐显按钮的左右滑动效果. 关于滑动效果,在我的上一篇博文中提到过,有兴趣的朋友可以访问: http://www.cnblogs.com/hanyonglu/archi ...

随机推荐

  1. HDU 1348 Wall 【凸包】

    <题目链接> 题目大意: 给出二维坐标轴上 n 个点,这 n 个点构成了一个城堡,国王想建一堵墙,城墙与城堡之间的距离总不小于一个数 L ,求城墙的最小长度,答案四舍五入. 解题分析: 求 ...

  2. RabbitMQ消息可靠性分析和应用

    RabbitMQ流程简介(带Exchange) RabbitMQ使用一些机制来保证可靠性,如持久化.消费确认及发布确认等. 先看以下这个图: P为生产者,X为中转站(Exchange),红色部分为消息 ...

  3. [漏洞案例]thinkcmf 2.x从sql注入到getshell实战

    0X00 前言 这个案例是某项目的漏洞,涉及敏感的地方将会打码. 很久没更新博客了,放一篇上来除除草,新的一年会有所转变,以后会有更多领域的研究. 下面是正文 0X01 正文 某厂商某个网站用的是th ...

  4. hashCode方法的作用?

    (1)前言,想要明白hashCode的作用,你必须要先知道Java中的集合. Java中的集合(Collection)有两类,一类是List,再有一类是Set. 前者集合内的元素是有序的,元素可以重复 ...

  5. iOS 11开发教程(二十二)iOS11应用视图实现按钮的响应(2)

    iOS 11开发教程(二十二)iOS11应用视图实现按钮的响应(2) 此时,当用户轻拍按钮后,一个叫tapButton()的方法就会被触发. 注意:以上这一种方式是动作声明和关联一起进行的,还有一种先 ...

  6. 卡特兰数 Catalan 笔记

    一.公式 卡特兰数一般公式 令h(0)=1,h(1)=1,catalan数满足递推式.h(n) = h(0)*h(n-1)+h(1)*h(n-2) + ... + h(n-1)h(0) (n>= ...

  7. 理清cordova插件的调用流程

    从调用的角度看流程  前端调用(clobbers)——>cordova_plugins.js(clobbers对应插件id和插件文件所在的路径)—–>js部分(配置着插件的名字,已经插件里 ...

  8. Windows平台交叉编译Arm Linux平台的QT5.7库

    1.准备交叉编译环境 环境说明:Windows 7 64位 此过程需要: (1)Qt库开源代码,我使用的是5.7.0版本: (2)Perl语言环境5.12版本以上: (3)Python语言环境 2.7 ...

  9. 10款免费开源PHP框架

    NO.1 Laravel - 巨匠级PHP开发框架 现在最流行的一款PHP框架,功能强大,学习和使用也非常简单方便,即使你是PHP新手,也不用担心入门问题. NO.2 Phalcon - 最快的PHP ...

  10. 删除weblogic应用缓存,weblogic 缓存的删除方法

    security (注意:security目录下为安全认证文件,切不可删除!) 正常情况下只需删除tmp目录下缓存文件(不同的工程在tmp下面有不同的路径,如果不清楚的话可以一起删除). 个别情况下会 ...