看了下android viewfillper + GestureDetector 做指引界面效果还不错。图片自己添加。布局很简单
package com.example.test.game; import java.io.File; import java.util.Timer; import java.util.TimerTask; import android.app.Activity; import android.content.Intent; import android.net.Uri; import android.os.Bundle; import android.view.GestureDetector; import android.view.GestureDetector.OnGestureListener; import android.view.MotionEvent; import android.view.View; import android.view.Window; import android.view.WindowManager; import android.view.animation.AnimationUtils; import android.webkit.MimeTypeMap; import android.widget.ImageView; import android.widget.ViewFlipper; import com.example.test.FileUtils; import com.example.test.R; public class TestActivity extends Activity { GestureDetector gesture; ViewFlipper flipper; @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); this.requestWindowFeature(Window.FEATURE_NO_TITLE); getWindow().setFlags(WindowManager.LayoutParams.FLAG_FULLSCREEN, WindowManager.LayoutParams.FLAG_FULLSCREEN); setContentView(R.layout.test_img); flipper = (ViewFlipper) findViewById(R.id.flipper); //添加图片 flipper.addView(getImageView(R.drawable.i20130806162515)); flipper.addView(getImageView(R.drawable.i20130806162840)); flipper.addView(getImageView(R.drawable.i20130806164717)); gesture = new GestureDetector(this, new OnGestureListener() { // 用户(轻触触摸屏后)松开,由一个1个MotionEvent ACTION_UP触发 @Override public boolean onSingleTapUp(MotionEvent e) { System.out.println("onSingleTapUp"); return false; } // 用户轻触触摸屏,尚未松开或拖动,由一个1个MotionEvent ACTION_DOWN触发 // 注意和onDown()的区别,强调的是没有松开或者拖动的状态 @Override public void onShowPress(MotionEvent e) { System.out.println("onShowPress"); } // 用户按下触摸屏,并拖动,由1个MotionEvent ACTION_DOWN, 多个ACTION_MOVE触发 @Override public boolean onScroll(MotionEvent e1, MotionEvent e2, float distanceX, float distanceY) { System.out.println("onScroll"); return false; } // 用户长按触摸屏,由多个MotionEvent ACTION_DOWN触发 @Override public void onLongPress(MotionEvent e) { System.out.println("onLongPress"); } // 用户按下触摸屏、快速移动后松开,由1个MotionEvent ACTION_DOWN, 多个ACTION_MOVE, // 1个ACTION_UP触发 @Override public boolean onFling(MotionEvent e1, MotionEvent e2, float velocityX, float velocityY) { System.out.println("onFling"); if (e1.getX() - e2.getX() > 120) {// 向右滑动 flipper.setInAnimation(AnimationUtils.loadAnimation(TestActivity.this, R.anim.push_left_in)); flipper.setOutAnimation(AnimationUtils.loadAnimation(TestActivity.this, R.anim.push_left_out)); //当前是不是最后一个 可以进行滑 if(flipper.getCurrentView().getId() != R.drawable.i20130806164717) { flipper.showNext(); } } else if (e2.getX() - e1.getX() > 120) {// 向左滑动 /*flipper.setInAnimation(AnimationUtils.loadAnimation(TestActivity.this, R.anim.push_right_in)); flipper.setOutAnimation(AnimationUtils.loadAnimation(TestActivity.this, R.anim.push_right_out)); flipper.showPrevious();*/ } return false; } // 用户轻触触摸屏,由1个MotionEvent ACTION_DOWN触发 @Override public boolean onDown(MotionEvent e) { System.out.println("onDown"); return false; } }); gesture.setOnDoubleTapListener(new GestureDetector.OnDoubleTapListener() { // 短快的点击算一次单击 @Override public boolean onSingleTapConfirmed(MotionEvent e) { System.out.println("onSingleTapConfirmed"); return false; } // 双击时产生一次 @Override public boolean onDoubleTapEvent(MotionEvent e) { System.out.println("onDoubleTapEvent"); return false; } // 双击时产生两次 @Override public boolean onDoubleTap(MotionEvent e) { System.out.println("onDoubleTap"); return false; } }); } @Override public boolean onTouchEvent(MotionEvent event) { return gesture.onTouchEvent(event); } private View getImageView(int id) { ImageView imgView = new ImageView(this); imgView.setId(id); imgView.setImageResource(id); return imgView; } }
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.1" 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.1" android:duration="500"/></set>
相关推荐
android ViewFlipper使用示例(注册引导页)。做设定好的流程类的填写注册(就例如用户注册,帮助手册,引导页面也可以)。我的博客地址:http://blog.csdn.net/qq_16064871。
简单的android ViewFlipper实现工程。
android viewflipper手势拖动效果(An-Beer工作室)
Android ViewFlipper Animation 使用
Android GridView + ViewFlipper布局界面,模仿“机锋市场.
手机开发的时候在应用第一次运行的时候都有一个指引页面,这个指引页面通常都是有几张图片组成来告诉用户如何操作,此例子就是以五张图片为例,利用viewflipper来实现图片的左右滑动
增加ViewFlipper中view的复用,完成ViewFlipper的优化使用
NULL 博文链接:https://iaiai.iteye.com/blog/1209525
Android 滑动效果ViewFlipper Android 滑动效果ViewFlipper
源码参考,欢迎下载
Android GridView + ViewFlipper布局界面,模仿“机锋市场.rar
Android GridView + ViewFlipper布局界面,模仿“机锋市场.zip源码资源下载Android GridView + ViewFlipper布局界面,模仿“机锋市场.zip源码资源下载
Android GridView + ViewFlipper布局界面,模仿“机锋市
AndroidGridView-ViewFlipper布局界面,模仿“机锋市场.zip
Android GridView + ViewFlipper布局界面,模仿“机锋市.zip
Android GridView + ViewFlipper布局界面,模仿“机锋市场.zip项目安卓应用源码下载Android GridView + ViewFlipper布局界面,模仿“机锋市场.zip项目安卓应用源码下载 1.适合学生毕业设计研究参考 2.适合个人学习...
Android ViewFlipper水平滑动Demo.zip
Android系统自带有一个多页面管理的控件:ViewFlipper. 它可以简单实现子页面的切换,,, 它只需使用addView方法添加几个View,每个View对应的是一个页面,即可完成对于多页面的管理,,, 在android上实现手势...
Android源码——GridView + ViewFlipper布局界面,模仿“机锋市场.zip