手势Gesture

所谓手势,是指用户手指或触摸笔在触摸屏幕上的连续触碰行为。

Androi对两种手势行为都提供了支持:

1.对于第一种手势而言,android提供了手势检测,并为手势检测提供了相应的监听器

2.对于第二种手势而言,android允许开发者添加手势,并提供了相应的API识别用户手势

手势检测

android为手势检测提供了一个GestureDetector类,GestureDetector实例代表了一个手势检测器,创建GestureDetector时需要传入一个GestureDetector.OnGestureListener实例,

GestureDetector.OnGestureListener就是一个监听器、负责对用户的手势行为提供响应。

GestureDetector.OnGestureListener包含的事件处理方法如下:

boolean onDown(MotionEvent e) 当触碰事件按下时触发该方法
boolean onFling(MotionEvent e1,MotionEvent e2,float velocityX,float velocityY) 当用户在触摸屏上“拖过”时触发该方法。其中velocityX、velocityY代表“拖过”动作在横向、纵向上的速度
abstract onLongPress(MotionEvent e) 当用户在屏幕上长按时触发该方法
boolean onScroll(MotionEvent e1,MotionEvent e2,float velocityX,float velocityY) 当用户在屏幕上滚动时触发该方法
void onShowPress(MotionEvent e) 用户在触摸屏上按下、而且还未移动和松开时触发该方法
boolean onSingleTapUp(MotionEvent e) 用户在触摸屏上的轻击事件将会触发该方法

关于GestureDetector.OnGestureListener监听器里的各种方法的触发时机,仅从文字上表述显得还是比较抽象和不易理解,看如下实例理解触发各种事件。

使用android手势检测只需要两个步骤:

1.创建一个GestureDetector对象,创建该对象时必须实现一个GestureDetector.OnGestureLinstener监听器;

2.为应用程序的Activity(偶尔可为特定组件)的TouchEvent事件绑定监听器,在事件处理中指定把Activity/特定组件上的TouchEvent事件交给GestureDetector处理,

 GestureDetector就会检测是否触发了特定的手势动作。  

实例如下:

package com.example.mygesturedetector;

import android.os.Bundle;
import android.app.Activity;
import android.view.GestureDetector;
import android.view.Menu;
import android.view.MotionEvent;
import android.widget.Toast; public class MainActivity extends Activity implements
android.view.GestureDetector.OnGestureListener
{
// 定义手势
GestureDetector detector; @SuppressWarnings("deprecation")
@Override
protected void onCreate(Bundle savedInstanceState)
{
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main); detector = new GestureDetector(this);
} @Override
public boolean onTouchEvent(MotionEvent event)
{
// 将该Activity上的触屏事件交给GestureDetector处理
return detector.onTouchEvent(event);
} @Override
public boolean onDown(MotionEvent e)
{
Toast.makeText(this, "onDown", 5000).show();
return false;
} @Override
public void onShowPress(MotionEvent e)
{
Toast.makeText(this, "onShowPress", 5000).show();
} @Override
public boolean onSingleTapUp(MotionEvent e)
{
Toast.makeText(this, "onSingleTapUp", 5000).show();
return false;
} @Override
public boolean onScroll(MotionEvent e1, MotionEvent e2, float distanceX, float distanceY)
{
Toast.makeText(this, "onScroll", 5000).show();
return false;
} @Override
public void onLongPress(MotionEvent e)
{
Toast.makeText(this, "onLongPress", 5000).show();
} @Override
public boolean onFling(MotionEvent e1, MotionEvent e2, float velocityX, float velocityY)
{
Toast.makeText(this, "onFling", 5000).show();
return false;
} }

实例二:通过手势缩放图片

布局文件==》
<LinearLayout 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:orientation="vertical"
tools:context=".MainActivity" > <ImageView
android:id="@+id/image"
android:layout_gravity="center_vertical|center_horizontal"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
/> </LinearLayout> 代码实现==》
package com.example.mygesturedetector2; import android.os.Bundle;
import android.app.Activity;
import android.graphics.Bitmap;
import android.graphics.BitmapFactory;
import android.graphics.Matrix;
import android.graphics.drawable.BitmapDrawable;
import android.view.GestureDetector;
import android.view.GestureDetector.OnGestureListener;
import android.view.MotionEvent;
import android.widget.ImageView; public class MainActivity extends Activity implements OnGestureListener
{
GestureDetector detector;
ImageView image;
Bitmap bitmap;
int width, height;
float currentScale = 1;
Matrix matrix; @SuppressWarnings("deprecation")
@Override
protected void onCreate(Bundle savedInstanceState)
{
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
// 创建手势检测器
detector = new GestureDetector(this);
matrix = new Matrix();
image = (ImageView) this.findViewById(R.id.image);
bitmap = BitmapFactory.decodeResource(this.getResources(), R.drawable.photo12);
width = bitmap.getWidth();
height = bitmap.getHeight();
image.setImageBitmap(BitmapFactory.decodeResource(this.getResources(), R.drawable.photo12));
} @Override
public boolean onTouchEvent(MotionEvent e)
{
// 将Activity上的触碰事件交给GestureDetector处理
return detector.onTouchEvent(e);
} @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)
{
} @Override
public boolean onFling(MotionEvent e1, MotionEvent e2, float velocityX, float velocityY)
{
velocityX = velocityX > 5000 ? 5000 : velocityX;
velocityX = velocityX < -5000 ? -5000 : velocityX;
// 根据手势的速度来计算缩放比,当velocityX>0,放大图片,否则缩小图片
currentScale += currentScale * velocityX / 5000.0f;
// 保证currentScale不会等于0
currentScale = currentScale > 0.01 ? currentScale : 0.01f;
// 重置Matrix
matrix.reset();
matrix.setScale(currentScale, currentScale, 160, 200);
BitmapDrawable tmp = (BitmapDrawable) image.getDrawable();
// 如果图片还没有回收,强制回收图片
if (!tmp.getBitmap().isRecycled())
tmp.getBitmap().recycle();
// 根据原始位图和Matrix创建新图片
Bitmap bitmap2 = Bitmap.createBitmap(bitmap, 0, 0, width, height, matrix, true);
image.setImageBitmap(bitmap2);
return false;
} }

运行效果如下:

实例三:通过手势实现翻页效果

ViewFlipper组件是一个容器组件,因此可调用addView(View v)添加多个组件,一旦向其添加了多个组件之后,ViewFlipper可使用动画控制多个组件直接的切换效果。

本程序通过GestureDetector来检测用户的手势,并根据手势动作来控制ViewFlipper包含的View组件的切换,从而实现翻页效果。

 布局文件main.xml==>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="fill_parent"
android:layout_height="fill_parent"
android:orientation="vertical" > <ViewFlipper
android:id="@+id/ViewFlipper01"
android:layout_width="fill_parent"
android:layout_height="fill_parent" >
</ViewFlipper> </LinearLayout>
动画文件==》
res目录添加anim文件夹,并添加对应的动画xml
==>
left_in.xml
<?xml version="1.0" encoding="utf-8"?>
<set xmlns:android="http://schemas.android.com/apk/res/android" > <translate
android:duration="500"
android:fromXDelta="100%p"
android:toXDelta="0" /> </set> left_out.xml
<?xml version="1.0" encoding="utf-8"?>
<set xmlns:android="http://schemas.android.com/apk/res/android" > <translate
android:duration="500"
android:fromXDelta="0"
android:toXDelta="-100%p" /> </set> right_in.xml
<?xml version="1.0" encoding="utf-8"?>
<set xmlns:android="http://schemas.android.com/apk/res/android" > <translate
android:duration="500"
android:fromXDelta="-100%p"
android:toXDelta="0" /> </set>
right_out.xml
<?xml version="1.0" encoding="utf-8"?>
<set xmlns:android="http://schemas.android.com/apk/res/android" > <translate
android:duration="500"
android:fromXDelta="0"
android:toXDelta="100%p" /> </set>
代码实现==》
package com.example.mygesturedetector3; import android.os.Bundle;
import android.app.Activity;
import android.view.GestureDetector;
import android.view.GestureDetector.OnGestureListener;
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.TextView;
import android.widget.ViewFlipper; public class MainActivity extends Activity implements OnGestureListener
{
ViewFlipper flipper;
GestureDetector detector;
Animation[] animations = new Animation[4];
// 定义手势动作两点直接的最小距离
final int FLIP_DISTANCE = 50; @SuppressWarnings("deprecation")
@Override
protected void onCreate(Bundle savedInstanceState)
{
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main); detector = new GestureDetector(this);
flipper = (ViewFlipper) this.findViewById(R.id.ViewFlipper01); // flipper.addView(addTextView("step 1"));// 将View添加到flipper队列中
// flipper.addView(addTextView("step 2"));
// flipper.addView(addTextView("step 3"));
// flipper.addView(addTextView("step 4"));
// flipper.addView(addTextView("step 5"));
flipper.addView(addImageView(R.drawable.photo8));
flipper.addView(addImageView(R.drawable.photo9));
flipper.addView(addImageView(R.drawable.photo10));
flipper.addView(addImageView(R.drawable.photo11));
flipper.addView(addImageView(R.drawable.photo12));
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 addTextView(String text)
{
TextView tv = new TextView(this);
tv.setText(text);
tv.setGravity(1);
return tv;
} @Override
public boolean onTouchEvent(MotionEvent event)
{
return detector.onTouchEvent(event);
} private View addImageView(int resId)
{
ImageView img = new ImageView(this);
img.setImageResource(resId);
img.setScaleType(ImageView.ScaleType.CENTER);
return img;
} @Override
public boolean onFling(MotionEvent e1, MotionEvent e2, float velocityX, float velocityY)
{
if (e1.getX() - e2.getX() > FLIP_DISTANCE)
{
// 如果是从右向左滑动
// 注册flipper的进出效果
flipper.setInAnimation(AnimationUtils.loadAnimation(this, R.anim.left_in));
flipper.setOutAnimation(AnimationUtils.loadAnimation(this, R.anim.left_out));
flipper.showNext();
return true;
}
if (e1.getX() - e2.getX() < -FLIP_DISTANCE)
{
// 如果是从左向右滑动
flipper.setInAnimation(AnimationUtils.loadAnimation(this, R.anim.right_in));
flipper.setOutAnimation(AnimationUtils.loadAnimation(this, R.anim.right_out));
flipper.showPrevious();
return true;
}
return false;
} @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学习笔记51——SQLite 手势Gesture的更多相关文章

  1. android学习笔记48——SQLite

    SQLite SQLite试试一个嵌入式的数据库引擎,专门用于资源有限的设备(如手机.PDA)上适量数据存取. SQLite支持绝大部分SQL92语法,同样允许开发者使用SQL语句操作数据库中的数据, ...

  2. Android学习笔记(SQLite的简单使用)

    1.SQLite介绍 SQLite,是一款轻型的数据库,是遵守ACID的关系型数据库管理系统,它包含在一个相对小的C库中.它是D.RichardHipp建立的公有领域项目.它的设计目标是嵌入式的,而且 ...

  3. Android学习笔记36:使用SQLite方式存储数据

    在Android中一共提供了5种数据存储方式,分别为: (1)Files:通过FileInputStream和FileOutputStream对文件进行操作.具体使用方法可以参阅博文<Andro ...

  4. 【转】 Pro Android学习笔记(五五):调试和分析(3):adb命令、模拟器控制台和StrictMode

    目录(?)[-] adb命令 模拟器Console StrictMode adb命令 我们在学习SQLite的使用,介绍过部分adb命令的使用,见Pro Android学习笔记(五):了解Conten ...

  5. 【转】Pro Android学习笔记(七):了解Content Provider(下上)

    我们通过一个Content Provider小例子进行详细说明.数据源是一个SQLite数据库,名字为books.db,该数据库只含有一个表格,名字为books.表格中含有name,isbn,auth ...

  6. 【转】Pro Android学习笔记(五):了解Content Provider(上)

    Content Provider是抽象数据封装和数据访问机制,例如SQLite是Android设备带有的数据源,可以封装到一个content provider中.要通过content provider ...

  7. udacity android 学习笔记: lesson 4 part a

    udacity android 学习笔记: lesson 4 part a 作者:干货店打杂的 /titer1 /Archimedes 出处:https://code.csdn.net/titer1 ...

  8. Android学习笔记之滑动翻页(屏幕切换)

    如何实现手机上手动滑动翻页效果呢?呵呵,在这里我们就给你们介绍一下吧. 一般实现这个特效会用到一个控件:ViewFlipper <1>View切换的控件—ViewFlipper 这个控件是 ...

  9. Android 学习笔记之Volley(七)实现Json数据加载和解析...

    学习内容: 1.使用Volley实现异步加载Json数据...   Volley的第二大请求就是通过发送请求异步实现Json数据信息的加载,加载Json数据有两种方式,一种是通过获取Json对象,然后 ...

随机推荐

  1. JS重要知识点

    这里列出了一些JS重要知识点(不全面,但自己感觉很重要).彻底理解并掌握这些知识点,对于每个想要深入学习JS的朋友应该都是必须的. 讲解还是以示例代码搭配注释的形式,这里做个小目录: JS代码预解析原 ...

  2. SAP物料批次管理配置及操作手册(轉載)

    这个有待学习 业务说明需要先熟悉基本的物料管理(MM).生产计划管理(PP).销售与分销管理(SD)的相关知识.在化工.制药.快消.汽车零部件等行业,为了进行质量的跟踪,往往需要使用批次管理来监控质量 ...

  3. Objective-C( Foundation框架 一 常见的结构体)

    常见的结构体 (NSPoint,CGPoint).(NSRange,CGRange).(NSSize,CGSize) 苹果官方推荐使用CG开头的结构体 NSRange是Foundation框架中常见的 ...

  4. iOS开发网络篇—搭建本地服务器

    iOS开发网络篇—搭建本地服务器 一.简单说明 说明:提前下载好相关软件,且安装目录最好安装在全英文路径下.如果路径有中文名,那么可能会出现一些莫名其妙的问题. 提示:提前准备好的软件 apache- ...

  5. [最短路径SPFA] POJ 1847 Tram

    Tram Time Limit: 1000MS Memory Limit: 30000K Total Submissions: 14630 Accepted: 5397 Description Tra ...

  6. 把字典的key value 拼接成字符串加上签名加密

    - (NSString *)getSianKeyWithDic:(NSDictionary *)dic { //按字典排序 NSArray* arr = [dic allKeys]; arr = [a ...

  7. log4net.config 单独文件

    使用的命名空间下添加 [assembly: log4net.Config.DOMConfigurator(ConfigFile = "log4net.config", Watch ...

  8. android 分享或者调用系统或者其他app时 应注意! startActivityForResult() 使用

    //判断是否有相应的Activity来接受intentPackageManager packageManager = getPackageManager();List<ResolveInfo&g ...

  9. php超全局数组变量

    (1)$_SERVER 服务器的相关信息 (2)$_GET 接收用户通过url向服务器传的参数  $POST 接收用户通过http协议向服务器传递的参数 发送get请求 <a href=&quo ...

  10. 删除ubuntu旧版本内核

    方法一: 1.查看系统下可使用的内核有哪些 dpkg --get-selectiongs|grep linux-image liming@CM:~$ dpkg --get-selections|gre ...