Android实现页面翻转和自动翻转功能

1. 效果图,本功能用了ViewFlipper和GestureDetector (手势检测器)两个关键技术点:

2. 先写好布局文件,这里用到了ViewFlipper类,用于切换视图,毕竟ViewFlipper见得少,先介绍一下。

在xml布局中的方法介绍:

android:autoStart: 设置自动加载下一个View 
android:flipInterval:设置View之间切换的时间间隔
android:inAnimation: 设置切换View的进入动画
android:outAnimation:设置切换View的退出动画

当然同样的在代码中也可以设置:

isFlipping: 判断View切换是否正在进行
setFilpInterval:设置View之间切换的时间间隔
startFlipping: 开始View的切换,而且会循环进行
stopFlipping: 停止View的切换
setOutAnimation:设置切换View的退出动画
setInAnimation: 设置切换View的进入动画
showNext: 显示ViewFlipper里的下一个View
showPrevious: 显示ViewFlipper里的上一个View

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
 xmlns:app="http://schemas.android.com/apk/res-auto"
 xmlns:tools="http://schemas.android.com/tools"
 android:layout_width="match_parent"
 android:layout_height="match_parent"
 android:orientation="vertical"
 tools:context=".slide.Main2Activity">
 <LinearLayout
  android:layout_width="match_parent"
  android:layout_height="wrap_content">
  <Button
   android:layout_width="0dp"
   android:layout_height="wrap_content"
   android:layout_weight="1"
   android:onClick="start"
   android:text="开始自动翻页" />
  <Button
   android:layout_width="0dp"
   android:layout_height="wrap_content"
   android:layout_weight="1"
   android:onClick="stop"
   android:text="停止自动翻页" />
 </LinearLayout>
 <ViewFlipper
  android:id="@+id/activity_main2_vf"
  android:layout_width="match_parent"
  android:layout_height="match_parent"
  android:flipInterval="1500"></ViewFlipper> //flipInterval 实现自动翻转时添加,值为每页翻转的时间
</LinearLayout>

3. 接下来是代码部分,首页介绍一下GestureDetector :

GestureDetector.OnGestureListener里包含的事件处理方法如下:
➢boolean onDown(MotionEvent e):当触碰事件按下时触发该方法。
➢boolean onFling(MotionEvent e1, MotionEvent e2, float velocityX, float velocityY):当用户手指在触摸屏_上“拖过”时触发该方法。其中velocityX、velocityY 代表“拖过”动作在横向、纵向,上的速度。
➢abstract void onL ongPress(MotionEvente):当用户手指在屏幕上长按时触发该方法。
➢boolean onScroll(MotionEvent e1, MotionEvent e2, float distanceX, float distanceY):当用户手指在屏幕上“滚动”时触发该方法。
➢void onShowPress(MotionEvent e):当用户手指在触摸屏上按下,而且还未移动和松开时触发该方法。
➢boolean onSingleTapUp(MotionEvent e): 用户手指在触摸屏上的轻击事件将会触发该方法。

*使用Android的手势检测只需两个步骤。

➊创建一个GestureDetector 对象。创建该对象时必须实现一个GestureDetector.OnGestureListener监听器实例。

❷为应用程序的Activity (偶尔也可为特定组件)的TouchEvent事件绑定监听器(对应gestureDetector = new GestureDetector(this, this);),在事件处理中指定把Activity (或特定组件),上的TouchEvent事件交给GestureDetector处理。(对应return gestureDetector.onTouchEvent(event);)*

package com.example.mygesture.slide;
import android.support.v7.app.AppCompatActivity;
import android.os.Bundle;
import android.view.GestureDetector;
import android.view.LayoutInflater;
import android.view.MotionEvent;
import android.view.View;
import android.view.animation.Animation;
import android.view.animation.AnimationUtils;
import android.widget.ImageView;
import android.widget.ViewFlipper;
import com.example.mygesture.R;
public class Main2Activity extends AppCompatActivity implements GestureDetector.OnGestureListener { //实现手势检测器接口
 GestureDetector gestureDetector; //定义手势检测器
 ViewFlipper viewFlipper;
// Animation[] animations=new Animation[4]; //注释的部分为添加动画效果
 int distance=50;
 @Override
 protected void onCreate(Bundle savedInstanceState) {
  super.onCreate(savedInstanceState);
  setContentView(R.layout.activity_main2);
  init();
 }
 private void init() {
  gestureDetector = new GestureDetector(this, this);//实例化GestureDetector
  viewFlipper=findViewById(R.id.activity_main2_vf);
  viewFlipper.addView(addImageView(R.drawable.q1));//添加图片
  viewFlipper.addView(addImageView(R.drawable.q2));
  viewFlipper.addView(addImageView(R.drawable.q3));
  viewFlipper.addView(addImageView(R.drawable.q4));
//  animations[0]=AnimationUtils.loadAnimation(this,R.anim.left_in);
//  animations[1]=AnimationUtils.loadAnimation(this,R.anim.left_out);
//  animations[2]=AnimationUtils.loadAnimation(this,R.anim.right_in);
//  animations[3]=AnimationUtils.loadAnimation(this,R.anim.right_out);
 }
 private View addImageView(int resId) {
  ImageView imageView=new ImageView(this);
  imageView.setImageResource(resId);
  imageView.setScaleType(ImageView.ScaleType.CENTER);
  return imageView;
 }
 @Override
 public boolean onFling(MotionEvent e1, MotionEvent e2, float velocityX, float velocityY) {
  viewFlipper.stopFlipping();  //当滑动时停止自动翻转
  if (e1.getX()-e2.getX()>distance){  //当从右向左滑动时
//   viewFlipper.setInAnimation(animations[0]);
//   viewFlipper.setOutAnimation(animations[1]);
   viewFlipper.showPrevious();  //返回上一张视图
   return true;
  }if (e2.getX()-e1.getX()>distance){  //当从左向右滑动时
//   viewFlipper.setInAnimation(animations[2]);
//   viewFlipper.setOutAnimation(animations[3]);
   viewFlipper.showNext();  //切换下一张视图
   return true;
  }
  return false;
 }
 @Override
 public boolean onTouchEvent(MotionEvent event) {
  return gestureDetector.onTouchEvent(event); //绑定触摸事件
 }
 public void start(View view) {
  viewFlipper.startFlipping();  //开始自动翻转,与flipInterval配套使用,缺一不可
 }
 public void stop(View view) {
  viewFlipper.stopFlipping();  //停止自动翻转
 }
 @Override
 public boolean onDown(MotionEvent e) {
  return false;
 }
 @Override
 public void onShowPress(MotionEvent e) {
 }
 @Override
 public boolean onSingleTapUp(MotionEvent e) {
  return false;
 }
 @Override
 public boolean onScroll(MotionEvent e1, MotionEvent e2, float distanceX, float distanceY) {
  return false;
 }
 @Override
 public void onLongPress(MotionEvent e) {
 }
}

简单的翻页效果已经完成了

总结

以上所述是小编给大家介绍的Android实现页面翻转和自动翻转功能,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对我们网站的支持!
如果你觉得本文对你有帮助,欢迎转载,烦请注明出处,谢谢!

(0)

相关推荐

  • Android实现文字翻转动画的效果

    本文实现了Android程序文字翻转动画的小程序,具体代码如下: 先上效果图如下: 要求: 沿Y轴正方向看,数值减1时动画逆时针旋转,数值加1时动画顺时针旋转. 实现动画的具体细节见"RotateAnimation.Java".为方便查看动画旋转方向,可以将RotateAnimation.DEBUG值设置为true即可.
 RotateAnimation参考自APIDemos的Rotate3DAnimation
 RotateAnimation的构造函数需有三个参数,分别说明动画组件的

  • Android实现图片反转、翻转、旋转、放大和缩小

    ********************************************************************** android 实现图片的翻转 ********************************************************************** Resources res = this.getContext().getResources(); img = BitmapFactory.decodeResource(res, R.

  • Android实现Flip翻转动画效果

    本文实例讲述了Android实现Flip翻转动画效果的方法,分享给大家供大家学习借鉴. 具体实现代码如下: LinearLayout locationLL = (LinearLayout) findViewById(R.id.locationLL); LinearLayout baseLL = (LinearLayout) findViewById(R.id.baseLL); private void flipit() { Interpolator accelerator = new Accel

  • Android利用Camera实现中轴3D卡牌翻转效果

    在Android系统API中,有两个Camera类: android.graphics.Camera android.hardware.Camera 第二个应用于手机硬件中的相机相关的操作,本文讲述的是利用第一个Camera类实现中轴3D转换的卡牌翻转效果,开始之前,先看一下Android系统中的坐标系: 对应于三维坐标系中的三个方向,Camera提供了三种旋转方法: rotateX() rotateY() rotateX() 调用这三种方法,传入旋转角度参数,即可实现视图沿着坐标轴旋转的功能.

  • Android动画之3D翻转效果实现函数分析

    Android中的翻转动画效果的实现,首先看一下运行效果如上图所示. Android中并没有提供直接做3D翻转的动画,所以关于3D翻转的动画效果需要我们自己实现,那么我们首先来分析一下Animation 和 Transformation. Animation动画的主要接口,其中主要定义了动画的一些属性比如开始时间,持续时间,是否重复播放等等.而Transformation中则包含一个矩阵和alpha值,矩阵是用来做平移,旋转和缩放动画的,而alpha值是用来做alpha动画的,要实现3D旋转动画

  • Android实现卡片翻转动画

    最近项目上用到了卡片的翻转效果,大致研究了下,也参考了网上的一些Demo,简单实现如下: activity_main.xml <?xml version="1.0" encoding="utf-8"?> <FrameLayout xmlns:android="http://schemas.android.com/apk/res/android" android:id="@+id/card_main_container&

  • Android图片翻转动画简易实现代码

    下面给大家分享一个有趣的动画:这里比较适合一张图片的翻转,如果是多张图片,可以参考APIDemo里的例子,就是加个ArrayAdapter,还是简单的,也可以自己发挥修改,实现自己想要的.这里的代码基本上可以直接运行项目了. 在main.xml里加个ImageView,如 复制代码 代码如下: <?xml version="1.0" encoding="utf-8"?> <FrameLayout xmlns:android="http:/

  • Android实现页面翻转和自动翻转功能

    1. 效果图,本功能用了ViewFlipper和GestureDetector (手势检测器)两个关键技术点: 2. 先写好布局文件,这里用到了ViewFlipper类,用于切换视图,毕竟ViewFlipper见得少,先介绍一下. 在xml布局中的方法介绍: android:autoStart: 设置自动加载下一个View  android:flipInterval:设置View之间切换的时间间隔 android:inAnimation: 设置切换View的进入动画 android:outAni

  • Android开发之文本内容自动朗读功能实现方法

    本文实例讲述了Android开发之文本内容自动朗读功能实现方法.分享给大家供大家参考,具体如下: Android提供了自动朗读支持.自动朗读支持可以对指定文本内容进行朗读,从而发生声音:不仅如此,Android的自动朗读支持还允许把文本对应的音频录制成音频文件,方便以后播放.这种自动朗读支持的英文名称为TextToSpeech,简称TTS. 借助于TTS的支持,可以在应用程序中动态地增加音频输出,从而改善用户体验. Android的自动朗读支持主要通过TextTospeech来完成,该累提供了如

  • Android编程实现输入框动态自动提示功能

    本文实例讲述了Android编程实现输入框动态自动提示功能.分享给大家供大家参考,具体如下: 关于AutoCompleteTextView的使用,我想大家并不陌生,对其设定上Adapter后系统便能自己识别与匹配了.近期 一个项目中,需要做到匹配通迅录中的电话号码和联系人,由于通迅录中数据量大,所以把所有的数据在自己提示之前就查询出来并加入到 AutoCompleteTextView中是不现实的,所以我们可以使用cursor来动态加载AutoCompleteTextView的数据,从而 实现时时

  • Android实现短信验证码自动填写功能

    本实例为大家分享了Android实现短信验证码自动填写功能,供大家参考,具体内容如下 实现思路很简单: 1.在需要输入验证码的Activity代码注册监听短信的广播 2.拦截短信,获取其中的验证码 3.回写到EditText private SmsReciver smsReciver = new SmsReciver(); /** 收到短信Action **/ String ACTION_SMS_RECIVER = "android.provider.Telephony.SMS_RECEIVED

  • Android编程实现TextView垂直自动滚动功能【附demo源码下载】

    本文实例讲述了Android编程实现TextView垂直自动滚动功能.分享给大家供大家参考,具体如下: 在做android 应用的开发的时候,横向滚动或者要做出跑马灯的效果很简单,textview本身的属性就支持,只要设置准确就会滚动,开发起来比较简单,但是textview 不支持垂直滚动,那么垂直滚动就需要自己来实现了,很多网友提供的垂直滚 动方案都是千篇一律,使用ScrollView来进行滚动,但是都不完美,做起来有些别扭.有一位网友给出的歌词的滚动思路明确,能从根本上解决问题,因此我实现的

  • Android 取消蓝牙配对框实现自动配对功能

    我看了几个文章,主要是接受配对广播,然后设置pin,实现配对,但是网上的大部分手机是不可以的,Android.bluetoothdevice 下 action_pair_request ,没有定义这个,开始困扰了我一点时间,实现难度:是否能进入那个广播响应 定义了一个类,这个是网上的可以直接用 package zicox.esc; import java.lang.reflect.Method; import java.lang.reflect.Field; import android.blu

  • Android应用自动更新功能实现的方法

    本文给大家分享Android里应用版本更新功能这一块的实现. 一个好的应用软件都是需要好的维护,从初出版本到最后精品,这个过程需要版本不停的更新,那么如何让用户第一时间获取最新的应用安装包呢?那么就要求我们从第一个版本就要实现升级模块这一功能. 自动更新功能的实现原理,就是我们事先和后台协商好一个接口,我们在应用的主Activity里,去访问这个接口,如果需要更新,后台会返回一些数据(比如,提示语:最新版本的url等).然后我们给出提示框,用户点击开始下载,下载完成开始覆盖安装程序,这样用户的应

  • Android实现登录邮箱的自动补全功能

    本文实例为大家分享了Android登录邮箱自动补全功能的实现方法,供大家参考,具体内容如下 效果: 实现原理: 1.继承重写简单控件AutoCompleteTextView 2.编写自定义数据适配器和布局文件,并实现文字变化监听器 3.通过组合方式,实现右侧的删除图标.并根据焦点和文字的变化,动态显示右侧删除图标. 1.通过继承自简单控件AutoCompleteTextView实现帐号自动补全 关键代码: public class AutoComplete extends AutoComplet

  • Android实现获取短信验证码并自动填写功能

    本文实例为大家分享了Android短信验证码获取并自动填写功能的具体代码,供大家参考,具体内容如下 代码如下: MainActivity public class MainActivity extends AppCompatActivity { public static TextView mText; private SmsContent content; @Override protected void onCreate(Bundle savedInstanceState) { super.

  • Android程序自动更新功能模块的实现方法【附完整demo源码下载】

    本文实例讲述了Android程序自动更新功能模块的实现方法.分享给大家供大家参考,具体如下: 在程序启动的时候检测服务器上有没有对应版本更新,如果有更新,提示用户是否更新. 在程序启动的时候首先调用更新模块检测服务器上存放的版本号跟当前程序的版本号如果大于当前版本号,弹出更新对话框,如果用户选择更新,则显示当前更新状态,然后替换当前程序. 程序调用版本更新检测: private UpdateManager updateMan; private ProgressDialog updateProgr

随机推荐