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

最简单的ViewFlipper实现图片跟随手势滑动

阅读更多
说到android的左右滑动效果我们可以说是在每个应用上面都可以看到这样的效果,不管是微博,还是QQ等。实现左右滑动的方式很多,有ViewPaer(不过这个和需要android-support-v4.jar的支持),自定义实现Viewgroup,gallery等都可以达到这种效果。这里做下ViewFliper实现左右滑动的效果。

以下会会用到的技术有:
1、ViewFlipper
2、GestureDetector
3、Animation
第一次在iteye写博文,本人又是菜鸟,不喜勿喷,虚心听取建议。

原理:向左向右滑动主要是依赖手势来控制,手势向右滑动就调用 viewFlipper.showNext();方法,同理,向左滑动就会去调用viewFlipper.showPrevious();方法。
话不多少,直接上代码。

main_activity.xml:
<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"
    android:paddingBottom="@dimen/activity_vertical_margin"
    android:paddingLeft="@dimen/activity_horizontal_margin"
    android:paddingRight="@dimen/activity_horizontal_margin"
    android:paddingTop="@dimen/activity_vertical_margin"
    tools:context=".MainActivity" >
    
    <ViewFlipper 
        android:id="@+id/viewFlipper"
        android:layout_width="fill_parent"
        android:layout_height="fill_parent"></ViewFlipper>

</RelativeLayout>


下面是MainActivity内容:
package com.zls.viewflipper;

import android.os.Bundle;
import android.app.Activity;
import android.view.GestureDetector;
import android.view.GestureDetector.OnGestureListener;
import android.view.Menu;
import android.view.MotionEvent;
import android.view.Window;
import android.view.animation.Animation;
import android.view.animation.AnimationUtils;
import android.widget.ImageView;
import android.widget.ViewFlipper;
/**
 * 这个程序的功能:手势滑动
 * @author zls
 *
 */
public class MainActivity extends Activity implements OnGestureListener{


	private Animation left_in,left_out,right_in,right_out;
	private ViewFlipper viewFilpper; 
	private GestureDetector detector;									//手势监听

	@Override
	protected void onCreate(Bundle savedInstanceState) {
		super.onCreate(savedInstanceState);
		this.requestWindowFeature(Window.FEATURE_NO_TITLE);
		setContentView(R.layout.activity_main);
		
		//动画效果
		left_in = AnimationUtils.loadAnimation(this, R.anim.left_in);
		left_out = AnimationUtils.loadAnimation(this, R.anim.left_out);
		right_in = AnimationUtils.loadAnimation(this, R.anim.right_in);
		right_out = AnimationUtils.loadAnimation(this, R.anim.right_out);
		
		//获得viewFlipper
		viewFilpper = (ViewFlipper) findViewById(R.id.viewFlipper);
		detector = new GestureDetector(this);
		
																		//给viewFlipper添加ImageView
		viewFilpper.addView(getImageView(R.drawable.lufei));
		viewFilpper.addView(getImageView(R.drawable.namei));
		viewFilpper.addView(getImageView(R.drawable.solong));
		
	}
	
																		//touch事件交给手势处理
	@Override
	public boolean onTouchEvent(MotionEvent event) {
		// TODO Auto-generated method stub
		return this.detector.onTouchEvent(event);
	}
	
	public ImageView getImageView(int id)
	{
		ImageView imageView = new ImageView(this);
		imageView.setImageResource(id);
		return imageView;
	}

	@Override
	public boolean onCreateOptionsMenu(Menu menu) {
		// Inflate the menu; this adds items to the action bar if it is present.
		getMenuInflater().inflate(R.menu.main, menu);
		return true;
	}

	@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) {
		if(e2.getX()-e1.getX()<-120)
		{
			viewFilpper.setInAnimation(left_in);
			viewFilpper.setOutAnimation(left_out);
			viewFilpper.showNext();
			return true;
		}
		else if(e2.getX()-e1.getX()>120){
			viewFilpper.setInAnimation(right_in);
			viewFilpper.setOutAnimation(right_out);
			viewFilpper.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;
	}

}


在res文件夹下新建anim文件夹,在里面建4个animation动画的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%p" android:duration="500"/>
    <alpha android:fromAlpha="0.1" android:toAlpha="1.0" android:duration="500"/>

</set>

Left_out.xnl:
<?xml version="1.0" encoding="utf-8"?>
<set xmlns:android="http://schemas.android.com/apk/res/android">
    <translate android:fromXDelta="0%p" android:toXDelta="-100%p" android:duration="500"/>
    <alpha android:fromAlpha="1.0" android:toAlpha="0.1" android:duration="500"/>

</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%p" android:duration="500"/>
    <alpha android:fromAlpha="0.1" android:toAlpha="1.0" android:duration="500"/>

</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%p" android:toXDelta="100%p" android:duration="500"/>
    <alpha android:fromAlpha="1.0" android:toAlpha="0.1" android:duration="500"/>

</set>
分享到:
评论

相关推荐

    ViewPager和ViewFlipper实现图片左右滑动

    总结,"ViewPager和ViewFlipper实现图片左右滑动"主要是利用这两个组件的特性,结合数据适配和手势处理,创建一个可滑动浏览的图片导航界面。在实际项目中,开发者应根据需求选择合适的组件,比如,如果需要实现多页...

    使用ViewFlipper实现图片左右滑动效果

    ViewFlipper,不妨把它看做一个容器吧,你可以把许多的View放在这个容器中,让它展示给...这个demo是一个手动滑动屏幕查看图片的粒子,共有10张图片,左右滑动可以查看图片,效果不是很好。其实用ViewPager会更好些。

    Android使用ViewFlipper做页面切换,与手势滑动切换的使用

    在android上实现手势的识别也比较简单,可以实现OnTouchListener和OnGuestureListener接口, 然后在OnTouch函数中注册GestureDetector来判别手势动作, http://wang-peng1.iteye.com/blog/572886 ...

    ViewFlipper简单实现横屏滑动

    在Android开发中,ViewFlipper是一个非常实用的控件,用于在多个视图之间进行平滑切换,常用于实现类似轮播图或者横向滑动页面的效果。本教程将详细介绍如何利用ViewFlipper来实现横屏滑动,以及屏幕局部滑动的实现...

    ViewFlipper+AsyncImageLoader实现页面滑动及页面图片异步加载

    在"ViewFlipper+AsyncImageLoader实现页面滑动及页面图片异步加载"这个主题中,我们将深入探讨如何结合这两者来创建一个高性能的用户界面。 首先,`ViewFlipper`是Android SDK中的一个视图容器,它可以包含多个子...

    ViewFlipper实现图片轮播

    本篇文章将深入探讨如何使用`ViewFlipper`来实现图片轮播,并添加手势滑动切换图片的功能。 首先,`ViewFlipper`是`ViewGroup`的一个子类,它可以包含多个子视图(例如`ImageView`),并能通过设置动画效果在这些子...

    ViewFlipper实现滑动轮播

    在Android开发中,ViewFlipper是一个非常有用的布局组件,它允许开发者轻松地实现视图间的切换,例如在图片轮播、广告展示等场景下。本文将深入探讨如何使用ViewFlipper来实现滑动轮播效果,并结合实际示例进行详细...

    Android ViewFlipper实现页面的滑动切换

    综上所述,Android中的ViewFlipper提供了一种简单有效的方式实现页面滑动切换。通过组合不同的动画效果、手动切换、自动翻页以及手势识别,开发者可以创建出丰富多样的用户界面。在实际项目中,可以根据需求灵活运用...

    TabHost + ViewFlipper实现滑动翻页

    `TabHost` 用于创建底部的标签栏,而 `ViewFlipper` 可以实现页面之间的滑动切换。接下来,我们将深入探讨这两个组件以及如何将它们结合使用来实现滑动翻页效果。 `TabHost` 是Android SDK提供的一种容器,它可以...

    Android使用ViewFlipper实现左右滑动效果面

    在这个场景中,我们将探讨如何利用ViewFlipper来实现左右滑动的效果。 首先,我们需要理解ViewFlipper的基本概念。ViewFlipper是LinearLayout的子类,它可以包含多个子视图(views),并且能够自动或手动在这些子...

    ViewFlipper实现界面滑动切换

    以上就是使用ViewFlipper实现界面滑动切换的基本步骤,结合实际需求,你可以进一步定制动画效果,或者添加更多的交互元素,如指示器、手势识别等,以提升用户体验。在项目`MyViewFlipper`中,你将能看到具体的实现...

    android viewflipper 图片滑动demo

    本示例“android viewflipper 图片滑动demo”正是这样一个应用场景,用于展示如何用ViewFlipper实现在应用首次启动时的图片引导页面。 首先,我们需要了解ViewFlipper的基本概念。ViewFlipper是ViewGroup的一个子类...

    ViewFlipper图片滑屏双击放大 图片旋转

    本教程将详细介绍如何利用ViewFlipper实现图片的左右滑动、双击放大以及图片旋转功能。 1. **ViewFlipper基本使用** ViewFlipper继承自ViewGroup,可以包含多个子视图(例如ImageView)。默认情况下,ViewFlipper...

    android中使用ViewFlipper实现滑动翻页示例

    在Android开发中,ViewFlipper是一个非常有用的布局控件,它允许我们轻松地实现滑动翻页的效果。这个示例将向我们展示如何在应用程序中使用ViewFlipper来创建一个动态翻页界面,使得用户可以通过手势或编程方式切换...

    Android手势滑动图片浏览

    在Android开发中,实现手势滑动图片浏览是一种常见的需求,特别是在设计用户界面时,如相册应用或展示产品图片的场景。本教程将详细介绍如何利用`ViewFlipper`组件结合手势识别来创建一个平滑的手势滑动图片浏览功能...

    android GridView+ViewFlipper实现图片浏览

    通过监听ViewFlipper的动画事件,我们可以实现左右滑动来切换图片,模拟图片浏览的效果。 实现这个功能的步骤如下: 1. **获取SD卡图片**:使用`Environment.getExternalStorageDirectory()`获取SD卡根目录,再...

    ViewFlipper和ViewPage实现滑动切换界面

    在Android开发中,创建动态和交互丰富的用户界面是至关重要的,`ViewFlipper`和`ViewPager`组件就提供了这样的功能,让开发者能够实现界面之间的滑动切换效果。这两个组件各有特点,适合不同的应用场景。 首先,`...

    android 利用ViewFlipper来实现滑动切换

    总结一下,Android中的ViewFlipper组件为开发者提供了一种简单且高效的方式来实现视图之间的滑动切换效果。通过合理设置动画和控制切换时机,我们可以创建出丰富的用户交互体验。在实际项目中,你可以根据需求调整...

    ViewFlipper实现滑屏切换View

    ViewFlipper是Android SDK提供的一种布局管理器,主要用于在多个视图之间进行平滑的切换,常用于实现滑动翻页效果,如相册、广告轮播等场景。本篇文章将详细探讨如何利用ViewFlipper来实现滑屏切换View的功能。 ...

Global site tag (gtag.js) - Google Analytics