`
hualikejava
  • 浏览: 171501 次
  • 性别: Icon_minigender_1
  • 来自: 深圳
社区版块
存档分类
最新评论

android viewflipper引导界面

 
阅读更多
看了下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> 

   

 

 

  • 大小: 19.4 KB
分享到:
评论

相关推荐

    android viewflipper 图片滑动demo

    在Android开发中,ViewFlipper是一个非常有用的布局组件,它允许开发者轻松地在多个视图之间切换,常用于实现滑动浏览效果,如教程、引导页或者轮播图等。本示例“android viewflipper 图片滑动demo”正是这样一个...

    Android 应用开始引导界面

    在Android应用开发中,引导界面(Splash Screen)通常被用于应用程序启动时展示品牌形象或提示用户新功能,同时加载应用程序的主要组件。"Android 应用开始引导界面"是这样一个实现,它提供了一个可以直接使用的引导...

    android_ViewFlipper的使用

    ### Android ViewFlipper 的使用详解 #### 一、概述 `ViewFlipper` 是 Android 开发中的一个重要组件,主要用于在同一个 `Activity` 内实现不同视图(`View`)之间的切换,尤其适用于需要频繁更新内容的应用场景。...

    Android常见的4种引导页splash、viewpage,viewflipper,scrollview

    本文将详细介绍Android应用中四种常见的引导页实现方式:Splash、ViewPager、ViewFlipper以及ScrollView,并探讨它们的优缺点。 1. **Splash Screen(水波纹启动页)** Splash Screen是最传统的引导页形式,它通常...

    android ViewPager实现引导页效果

    在Android应用开发中,引导页(也称为欢迎页或新手引导)是一种常见的设计模式,用于初次启动应用时向用户介绍其主要功能和界面操作。在本教程中,我们将深入探讨如何利用ViewPager组件来实现这样的效果。ViewPager...

    app引导界面

    【Android 应用程序引导界面详解】 在移动应用开发领域,Android 平台上的 app 引导界面(也称为启动页或欢迎页)是用户首次打开应用时常见的一种设计元素。这种界面通常用来展示产品的核心功能、品牌形象或者引导...

    使用ViewFlipper+GestureDetector实现轮播图(APP引导页面)

    在Android应用开发中,轮播图(也称为滑动页面或引导页面)通常用于展示APP的新功能、使用提示或者吸引用户的注意力。本教程将详细讲解如何利用`ViewFlipper`和`GestureDetector`来实现这样一个功能。`ViewFlipper`...

    android安卓app界面UI开发教程.zip

    android安卓app界面UI开发教程 1.九宫格 10.锁屏 11.圆泡泡 12.动画 13.滑动切屏 14.在桌面上生成可移动的悬浮框 15.loading界面 2.多级列表 3.弹出窗口 4.微信聊天样式 5.列表 6.滑动Tab 7.相册 8.ViewFlipper 9....

    安卓欢迎界面引导页面viewpager相关-Android的APP应用中最常用的APP启动引导页常见的4种引导项目方式splashviewpageviewflipperscrollview.rar

    Android的APP应用中最常用的APP启动引导页,常见的4种引导项目方式:splash,viewpage,viewflipper,scrollview.rar,太多无法一一验证是否可用,程序如果跑不起来需要自调,部分代码功能进行参考学习。

    Android -- 引导页面的实现.zip

    在Android应用开发中,引导页面(也称为启动页或引导屏幕)是用户首次打开应用时看到的介绍性界面,用于展示应用特色、功能或者引导用户了解如何操作。本教程将详细讲解如何实现四种常见的Android引导页面:Splash ...

    ViewFlipper

    ViewFlipper是Android SDK中的一个布局视图组件,主要用于创建具有翻页效果的用户界面。在Android应用开发中,它通常被用作展示教程、欢迎界面或者轮播图的工具,因为它可以轻松地在多个视图之间切换,给用户提供...

    AndroidGuide:APP的引导界面

    在Android应用开发中,引导界面(也称为启动页或引导页)是用户首次打开应用程序时看到的页面,它通常用来展示品牌特色、介绍主要功能或提供用户教程。本指南将详细探讨Android平台上的四种常见的引导界面实现方式:...

    Android绕球心旋转引导页效果

    总的来说,实现“Android绕球心旋转引导页效果”涉及到对`ViewFlipper`组件的理解和使用,以及Android动画机制的掌握。通过结合布局设计和动画配置,开发者可以创造出各种富有创意的引导页动画,提升用户的第一印象...

    Android 引导页面

    3. **添加过渡效果**:如果引导页面包含多个场景,可以使用`ViewFlipper`或`ViewPager`实现页面间的滑动过渡。 三、实现引导逻辑 1. **判断是否展示**:通常,我们只在应用首次启动或者更新后展示引导页面。可以...

    APP引导页大全

    3. **ViewFlipper**:ViewFlipper是Android中的一个视图切换组件,它可以自动或手动在多个子视图之间进行切换,适用于创建简单的翻页引导页。与ViewPager相比,ViewFlipper的切换效果可能相对有限,但它易于理解和...

    Android-简易的Banners内置多种切换效果支持自定义切换效果支持纵向播放的引导组件

    在Android中,我们可以利用ViewFlipper、ViewPager等控件来实现类似的功能。 在"Android-简易的Banners内置多种切换效果支持自定义切换效果支持纵向播放的引导组件"项目中,开发者已经创建了一个定制化的Banner组件...

    Android -- 引导页面的实现

    3. **ViewFlipper引导页**: ViewFlipper是一个可以自动或手动切换子视图的容器。类似于ViewPager,但不支持滑动切换,通常用在动画效果丰富的引导页中。每个子视图代表一个引导页面,通过设置定时器和动画效果,使...

    Android实现单页显示3个Item的ViewPager炫酷切换效果

    ViewPager 通常用于实现图片轮播、新闻列表、应用程序引导等效果。 二、ViewPager 的基本使用 使用 ViewPager 需要在 layout 文件中声明 ViewPager 组件,并在 Activity 中实例化它。例如: ```xml &lt;android....

    图片实现滑动切换

    在Android开发中,图片滑动切换是一种常见的交互方式,尤其在展示相册、广告轮播或者用户引导界面等场景中非常普遍。标题“图片实现滑动切换”所指的就是通过编程技术实现在Android设备上,用户可以左右滑动来浏览多...

    Android实现绕球心旋转的引导页效果

    在Android开发中,创建引人入胜的用户体验至关重要,而引导页则是吸引用户关注并介绍应用功能的一种常见方式。本篇将详细讲解如何实现绕球心旋转的引导页效果,这种效果通常用于展示APP的核心特色或操作流程,给用户...

Global site tag (gtag.js) - Google Analytics