- 浏览: 5836100 次
- 性别:
- 来自: 上海
-
文章分类
- 全部博客 (890)
- WindowsPhone (0)
- android (88)
- android快速迭代 (17)
- android基础 (34)
- android进阶 (172)
- android高级 (0)
- android拾遗 (85)
- android动画&效果 (68)
- Material Design (13)
- LUA (5)
- j2me (32)
- jQuery (39)
- spring (26)
- hibernate (20)
- struts (26)
- tomcat (9)
- javascript+css+html (62)
- jsp+servlet+javabean (14)
- java (37)
- velocity+FCKeditor (13)
- linux+批处理 (9)
- mysql (19)
- MyEclipse (9)
- ajax (7)
- wap (8)
- j2ee+apache (24)
- 其他 (13)
- phonegap (35)
最新评论
-
Memories_NC:
本地lua脚本终于执行成功了,虽然不是通过redis
java中调用lua脚本语言1 -
ZHOU452840622:
大神://处理返回的接收状态 这个好像没有监听到 遇 ...
android 发送短信的两种方式 -
PXY:
拦截部分地址,怎么写的for(int i=0;i<lis ...
判断是否登录的拦截器SessionFilter -
maotou1988:
Android控件之带清空按钮(功能)的AutoComplet ...
自定义AutoCompleteTextView -
yangmaolinpl:
希望有表例子更好。。。,不过也看明白了。
浅谈onInterceptTouchEvent、onTouchEvent与onTouch
先要了解ViewFlipper,详细见:
http://gundumw100.iteye.com/admin/blogs/896840
OnGestureListener和OnDoubleTapListener接口定义:
实例:
main.xml
4个动画文件:
http://gundumw100.iteye.com/admin/blogs/896840
OnGestureListener和OnDoubleTapListener接口定义:
public interface OnGestureListener { // Touch down时触发, e为down时的MotionEvent boolean onDown(MotionEvent e); // 在Touch down之后一定时间(115ms)触发,e为down时的MotionEvent void onShowPress(MotionEvent e); // Touch up时触发,e为up时的MotionEvent boolean onSingleTapUp(MotionEvent e); // 滑动时触发,e1为down时的MotionEvent,e2为move时的MotionEvent boolean onScroll(MotionEvent e1, MotionEvent e2, float distanceX, float distanceY); // 在Touch down之后一定时间(500ms)触发,e为down时的MotionEvent void onLongPress(MotionEvent e); // 滑动一段距离,up时触发,e1为down时的MotionEvent,e2为up时的MotionEvent boolean onFling(MotionEvent e1, MotionEvent e2, float velocityX, float velocityY); } public interface OnDoubleTapListener { // 完成一次单击,并确定没有二击事件后触发(300ms),e为down时的MotionEvent boolean onSingleTapConfirmed(MotionEvent e); // 第二次单击down时触发,e为第一次down时的MotionEvent boolean onDoubleTap(MotionEvent e); // 第二次单击down,move和up时都触发,e为不同时机下的MotionEvent boolean onDoubleTapEvent(MotionEvent e); }
实例:
import android.app.Activity; import android.os.Bundle; import android.view.GestureDetector; import android.view.MotionEvent; import android.view.View; import android.widget.Button; import android.widget.ViewFlipper; public class FlingSlideActivity extends Activity implements GestureDetector.OnGestureListener,GestureDetector.OnDoubleTapListener{ private ViewFlipper mViewFlipper; private GestureDetector mGestureDetector; /** Called when the activity is first created. */ @Override public void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.main); mViewFlipper = (ViewFlipper) findViewById(R.id.flipper); Button button1 = (Button) findViewById(R.id.Button1); button1.setOnClickListener(new View.OnClickListener() { public void onClick(View view) { mViewFlipper.showNext(); } }); Button button2 = (Button) findViewById(R.id.Button2); button2.setOnClickListener(new View.OnClickListener() { public void onClick(View view) { mViewFlipper.showNext(); } }); Button button3 = (Button) findViewById(R.id.Button3); button3.setOnClickListener(new View.OnClickListener() { public void onClick(View view) { mViewFlipper.showNext(); } }); mGestureDetector = new GestureDetector(this); } //别忘了覆盖onTouchEvent方法 @Override public boolean onTouchEvent(MotionEvent event) { return mGestureDetector.onTouchEvent(event); } //以下是OnGestureListener需要实现的方法 public boolean onDown(MotionEvent e) { // TODO Auto-generated method stub return false; } public boolean onFling(MotionEvent e1, MotionEvent e2, float velocityX, float velocityY) { // TODO Auto-generated method stub if(e1.getX() > e2.getX()) {//向左滑动 mViewFlipper.setInAnimation(getApplicationContext(), R.anim.push_left_in); mViewFlipper.setOutAnimation(getApplicationContext(), R.anim.push_left_out); mViewFlipper.showNext(); }else if(e1.getX() < e2.getX()) {//向右滑动 mViewFlipper.setInAnimation(getApplicationContext(), R.anim.push_right_in); mViewFlipper.setOutAnimation(getApplicationContext(), R.anim.push_right_out); mViewFlipper.showPrevious(); }else { return false; } return true; } public void onLongPress(MotionEvent e) { // TODO Auto-generated method stub } public boolean onScroll(MotionEvent e1, MotionEvent e2, float distanceX, float distanceY) { // TODO Auto-generated method stub return false; } public void onShowPress(MotionEvent e) { // TODO Auto-generated method stub } public boolean onSingleTapUp(MotionEvent e) { // TODO Auto-generated method stub return false; } //以下是OnDoubleTapListener需要实现的方法 public boolean onDoubleTap(MotionEvent e) { // TODO Auto-generated method stub mViewFlipper.startFlipping(); //双击自动切换界面 return true; } public boolean onDoubleTapEvent(MotionEvent e) { // TODO Auto-generated method stub return false; } public boolean onSingleTapConfirmed(MotionEvent e) { // TODO Auto-generated method stub if(mViewFlipper.isFlipping()){ //单击结束自动切换 mViewFlipper.stopFlipping(); } return false; } }
main.xml
<?xml version="1.0" encoding="utf-8"?> <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" android:orientation="vertical" android:layout_width="fill_parent" android:layout_height="fill_parent" > <ViewFlipper android:id="@+id/flipper" android:layout_width="fill_parent" android:layout_height="fill_parent" android:persistentDrawingCache="animation" android:flipInterval="3000" android:inAnimation="@anim/push_left_in" android:outAnimation="@anim/push_left_out" > <LinearLayout android:orientation="vertical" android:layout_width="fill_parent" android:layout_height="fill_parent"> <Button android:text="Next1" android:id="@+id/Button1" android:layout_width="fill_parent" android:layout_height="wrap_content"> </Button> <ImageView android:id="@+id/image1" android:src="@drawable/icon" android:layout_width="fill_parent" android:layout_height="wrap_content"> </ImageView> </LinearLayout> <LinearLayout android:orientation="vertical" android:layout_width="fill_parent" android:layout_height="fill_parent"> <Button android:text="Next2" android:id="@+id/Button2" android:layout_width="fill_parent" android:layout_height="wrap_content"> </Button> <ImageView android:id="@+id/image2" android:src="@drawable/icon" android:layout_width="fill_parent" android:layout_height="wrap_content"> </ImageView> </LinearLayout> <LinearLayout android:orientation="vertical" android:layout_width="fill_parent" android:layout_height="fill_parent"> <Button android:text="Next3" android:id="@+id/Button3" android:layout_width="fill_parent" android:layout_height="wrap_content"> </Button> <ImageView android:id="@+id/image3" android:src="@drawable/icon" android:layout_width="fill_parent" android:layout_height="wrap_content"> </ImageView> </LinearLayout> </ViewFlipper> </LinearLayout>
4个动画文件:
push_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.0" android:toAlpha="1.0" android:duration="500" /> </set> push_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.0" android:duration="500" /> </set> push_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.0" android:toAlpha="1.0" android:duration="500" /> </set> push_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.0" android:duration="500" /> </set>
- AndroidFlingSlide.rar (48 KB)
- 下载次数: 492
发表评论
-
http://www.android-studio.org/
2018-08-06 09:25 0http://www.android-studio.org/ ... -
SlidingDrawer源码
2012-03-14 10:13 3818我把SlidingDrawer源码提了出来,希望对1.5的朋友 ... -
简单拖动效果(带Cache,需要完善)
2011-10-13 15:10 4238如何去实现一个具有幻象的拖拽效果? 所谓”幻象“就是当你按下去 ... -
Android Activity中启动另一应用程序的方法,无需得到类名
2011-08-02 14:46 17284在网上搜索了一会相关的实现代码,发现所有的文章都说是需要包名和 ... -
java-universal-tween-engine,一个动画系统库
2011-06-29 09:21 6756http://code.google.com/p/java-u ... -
网上发现的一个android UI包
2011-05-24 12:21 4147里面有些UI和效果 -
android中使用代码启动其他程序
2011-04-29 23:15 5330你要訪問其他的程序,那麼這個程序要先裝載到模擬器或真機上面,因 ... -
listView背景问题以及限制editText字数以及如果想通知别人已经不能在写
2011-04-29 22:44 32211.在listView设置好背景之后 你如果点击空白出 你会发 ... -
Android键盘和触摸事件处理
2011-04-29 22:32 7014activity和VIEW都能接收触摸和按键,如果响应事件只需 ... -
Android的绘制文本对象FontMetrics的介绍及绘制文本
2011-04-29 22:29 11506一。Android绘制文本对象FontMetrics介绍 ... -
Android View 拖动&插入
2011-04-29 22:20 3557View 拖动&插入 即: 支持 拖动图标 然后 ... -
使TextView文本可以水平和垂直滚动
2011-04-29 21:59 14448在做一个小的电子书程序,要求电子书具有放大缩小的功能,所以肯定 ... -
ArrayAdapter源码
2011-04-29 12:29 6316看看人家怎么写的。 /* * Copyright (C ... -
Android下获取开机时间
2011-04-02 21:51 6243找了一圈没发现能得到开机启动时间资料,于是乎突发奇想,得到了解 ... -
AutoCompleteTextView连接到数据库
2011-03-30 20:49 4749AutoCompleteTextView可以根据输入 ... -
改变屏幕Brightness(亮度)
2011-03-30 12:48 4612http://www.eoeandroid.com/forum ... -
android 拖拽图片&拖动浮动按钮到处跑
2011-02-24 20:55 31793来自老外: import android.app.Acti ... -
拖动一个控件在另一个控件(layout)上,并固定位置在几个位置显示
2011-02-24 20:51 5904实现效果: 鼠标拖动btn SSS,SSS在水平的layo ... -
Handler与Message类,实现n秒后无操作自动消失功能
2011-02-24 20:45 4658实现功能:某控件不操作10秒后,自动消失。如照相机变焦条出现后 ... -
带删除按钮的ListView
2011-02-24 10:33 6160不用说了,上图先: import java.util.A ...
相关推荐
5. onFling(MotionEvent e1, MotionEvent e2, float velocityX, float velocityY):滑动手势事件; 6. onScroll(MotionEvent e1, MotionEvent e2, float distanceX, float distanceY):在屏幕上拖动事件。 主要判断...
在本案例中,`ViewFlipper`被与`OnGestureListener`结合使用,通过监听用户的手势来触发视图的切换,从而提供更加直观和自然的用户体验。 首先,我们需要了解`OnGestureListener`。这是Android SDK中的一个接口,它...
通过结合使用 `GestureDetector`、`OnGestureListener` 和 `ViewFlipper`,我们可以创建出流畅且互动性强的滑动屏幕效果。这种效果通常应用于新闻应用、相册应用或者任何需要展示多个页面并允许用户通过滑动手势切换...
利用viwflipper来将多个activity封装在一个view中,通过实现OnGestureListener接口的onTouchEvent()方法和onFling() 方法,即可通过手持滑动切换activity。
在Android开发中,ViewFlipper是一个非常有用的布局组件,它允许开发者轻松地在多个视图之间切换,通常用于实现翻页、轮播图或者动画效果。在这个场景中,我们将探讨如何利用ViewFlipper来实现左右滑动的效果。 ...
本篇将深入探讨如何利用ViewFlipper组件和GestureDetector类实现左右滑动切换视图的效果,这在主页面或多个内容区域展示的场景中非常常见。 ViewFlipper是Android提供的一个布局容器,它可以方便地在多个子视图之间...
5. **额外优化**:为了提供更好的用户体验,可以考虑添加一些额外的逻辑,比如限制页面回滚到第一张或最后一张时是否继续滑动,或者在滑动过程中禁用ViewFlipper的自动切换。 通过以上步骤,我们就可以创建一个基于...
在Android开发中,ViewFlipper是一个非常有用的布局组件,它允许开发者轻松地在多个视图之间切换,常用于实现滑动浏览效果,如教程、引导页或者轮播图等。本示例“android viewflipper 图片滑动demo”正是这样一个...
例如,我们可以监听用户的左右滑动手势,用以切换`ViewFlipper` 中的视图。 为了实现手势识别,首先需要创建一个`GestureDetector` 的实例,并重写其内部的 `onDown(MotionEvent event)`、`onFling(MotionEvent e1,...
在这个项目中,`ViewFlipper`可能被用来展示一系列可以滑动切换的页面或内容。 要实现手势滑动效果,首先我们需要集成`GestureDetector`类。`GestureDetector`是Android中处理基本手势的工具,它可以检测出用户的...
`ViewFlipper`是Android SDK提供的一种布局容器,它可以轻松地在多个子视图之间进行切换,通常用于实现动画效果,如左右滑动切换页面。`ViewFlipper`继承自`ViewGroup`,因此它可以包含多个子视图,并自动管理它们的...
- 可以通过实现`OnGestureListener`接口并附加到`ViewFlipper`来处理手势事件,例如滑动切换。 6. **源码解析**: - 在`ViewFlipper`的源码中,`startFlipping()`和`stopFlipping()`方法控制了自动切换的开关。`...
ViewFlipper是Android SDK提供的一种布局管理器,用于在多个视图之间进行切换,通常用于创建滑动浏览或动画效果,比如左右滑动切换页面。它继承自ViewGroup,因此可以容纳多个子视图(Views),并且能方便地在这些子...
总结来说,实现"android手势翻页效果"涉及的关键技术点有`ViewFlipper`的使用,以及`GestureDetector`配合`OnGestureListener`来检测和处理滑动手势。通过对这些知识点的深入理解和实践,开发者可以创建出更加生动、...
ViewFlipper是Android SDK中的一个视图容器,用于在多个视图之间进行切换,它可以包含多个子视图,如ImageView、TextView等,并且可以轻松地实现动画效果,比如左右滑动来展示不同的视图。在Android开发中,...
TestFlip可能是一个展示滑动手势效果的应用实例,可能包括翻页、滑动切换视图等功能。在实际项目中,你可能会结合ViewFlipper、ViewPager或其他视图容器来实现滑动效果。例如,使用ViewPager,你可以设置一个...
本文将深入探讨如何利用这两个组件实现Activity之间的滑屏切换,并通过`GestureDetector`添加手势滑动功能。 首先,`ActivityGroup`是Android API Level 13之前的一个类,它允许开发者在同一个父`Activity`中管理多...
总结来说,ViewFlipper是Android中实现多视图切换的利器,配合手势识别,可以轻松地创建出具有滑动效果的图片轮播或其他动画效果。通过灵活运用不同的Animation,我们可以实现更加丰富多彩的用户界面。记得在实际...
总的来说,通过组合使用 `ViewFlipper`, `GestureDetector` 和 `Animation`,我们可以轻松地在 Android 应用中实现左右滑动切换页面的效果。这种方式既简单又高效,适用于大多数需要滑动切换的场景。同时,开发者还...
ViewFlipper提供了方便的视图切换功能,而GestrueDetector使得我们可以识别并响应用户的触摸手势,两者结合可以创建出流畅且交互性强的滑屏界面。通过自定义动画和监听不同手势,可以进一步增强用户体验。