AndroidStudio4.3 安卓手势编程

一、学习目标

  • 能理解手势操作原理
  • 能利用手势操作实现切换功能

二、概括

  • 现代智能手机都支持触屏手势操作,可以方便地实现多种功能,最常见的是通过上下左右滑动手势实现切换功能。

三、讲解

(一)安卓手势操作原理

  • 在安卓系统中,每一次手势交互都会依照以下顺序执行,这个顺序可以说就是安卓手势操作的原理。
  • 触屏一刹那,触发一个MotionEvent事件。该事件被OnTouchListener监听,在其onTouch()方法里获得该MotionEvent对象。
  • 通过GestureDetector(手势侦测器)将此MotionEvent对象移交给OnGestureListener。
  • OnGestureListener监听器获得该事件对象,然后根据该对象封装的信息,做出合适的处理。

(二)安卓手势类与接口

1、MotionEvent

  • 动作事件类,用于封装手势、触摸笔、轨迹球等等的动作事件。其内部封装了两个重要的属性X和Y,这两个属性分别用于记录横轴和纵轴的坐标。

2、GestureDetector

  • 手势侦测器,用于识别各种手势。

3、OnGestureListener

  • 手势监听器,是一个手势交互的监听接口,其中提供了多个抽象方法,并根据GestureDetector的手势识别结果调用相对应的方法。

(三)教学案例:利用手势切换美女图片

1、创建安卓应用

  • 基于Empty Activity模板创建安卓应用 - SwtichBelleImageByGesture
    在这里插入图片描述
  • 单击【Finish】按钮
    在这里插入图片描述

2、准备图片素材

  • 将科比图片素材拷贝到drawable目录
    在这里插入图片描述

3、字符串资源文件

  • 字符串资源文件 - strings.xml
    在这里插入图片描述
<resources>
    <string name="app_name">通过手势切换科比图片</string>
</resources>

4、主布局资源文件

  • 主布局资源文件activity_main.xml
    在这里插入图片描述
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:tools="http://schemas.android.com/tools"
    android:id="@+id/root"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:background="@drawable/kb5"
    android:orientation="vertical"
    tools:context=".MainActivity">

</LinearLayout>
  • 查看预览效果
    在这里插入图片描述

5、主界面类实现功能

  • 主界面类 - MainActivity
    在这里插入图片描述

  • 定义常量和变量
    在这里插入图片描述

  • 通过资源标识符获取控件实例
    在这里插入图片描述

  • 初始化图像资源标识符数组
    在这里插入图片描述

  • 实例化手势侦测器,每个事件处理方法输出一条调试信息
    在这里插入图片描述

  • 针对手势滑动,我们编写onFling()事件处理方法,通过手势切换图片。这个事件处理方法有四个参数,滑动起点信息封装在e1里,滑动终点信息封装在e2里,第3个参数是手势横向滑动速度,第4个参数是手势纵向滑动速度
    在这里插入图片描述

  • 将窗口的触摸事件交给手势侦测器来处理
    在这里插入图片描述

package net.fzy.swtichbelleimagebygesture;

import androidx.appcompat.app.AppCompatActivity;

import android.os.Bundle;
import android.util.Log;
import android.view.GestureDetector;
import android.view.MotionEvent;
import android.widget.LinearLayout;

public class MainActivity extends AppCompatActivity {
    
    

    private LinearLayout root;//线性根布局
    private int[] imgIds;//图像资源标识符数组
    private int imgIndex;//图像索引,在图像资源标识符数组的位置
    private GestureDetector detector;//手势侦测器
    private final int IMG_COUNT=9;//图片总数
    private final String TAC="switch_belle";//标记

    @Override
    protected void onCreate(Bundle savedInstanceState) {
    
    
        super.onCreate(savedInstanceState);
        //利用布局资源文件设置用户界面
        setContentView(R.layout.activity_main);
        //通过资源标识符获取控件实例
        root=findViewById(R.id.root);
        //初始化图像资源标识符数组
        imgIds = new  int[IMG_COUNT];
        for (int i = 0;i<IMG_COUNT;i++){
    
    
            imgIds[i]=getResources().getIdentifier(
                    "img"+(i+1),//标识符名称
                    "drawable",//定义类型
                    "net.fzy.switch_belle"//定义包名
            );
        //实例化手势侦测器(参数1:上下文,参数2:手势监听器对象)
        detector=new GestureDetector(this, new GestureDetector.OnGestureListener() {
    
    
            @Override
            public boolean onDown(MotionEvent e) {
    
    
                Log.d(TAC,"onDown event invoked");
                return false;
            }

            @Override
            public void onShowPress(MotionEvent e) {
    
    
                Log.d(TAC,"onShowPress event invoked");
            }

            @Override
            public boolean onSingleTapUp(MotionEvent e) {
    
    
                Log.d(TAC,"onSingleTapUp event invoked");
                return false;
            }

            @Override
            public boolean onScroll(MotionEvent e1, MotionEvent e2, float distanceX, float distanceY) {
    
    
                Log.d(TAC,"onScroll event invoked");
                return false;
            }

            @Override
            public void onLongPress(MotionEvent e) {
    
    
                Log.d(TAC,"onLongPress event invoked");
            }

            @Override
            public boolean onFling(MotionEvent e1, MotionEvent e2, float velocityX, float velocityY) {
    
    
                Log.d(TAC,"onFling event invoked");
                //手势往左滑10个以上像素,图片切换到下一张
                if (e2.getX() < e1.getX() - 10){
    
    
                    if (imgIndex < IMG_COUNT-1){
    
    
                        imgIndex++;//切换到下一张
                    }else {
    
    
                        imgIndex=0;//回到第一张
                    }
                }
                //手势往右滑动10个以上像素,图片切换大上一张
                if (e2.getX()>e1.getX()+10){
    
    
                    if(imgIndex>0){
    
    
                        imgIndex--;//切换到上一张
                    }else {
    
    
                        imgIndex=IMG_COUNT-1;//切换到最后一张
                    }
                }
                //根据新索引切换根布局背景图片
                root.setBackgroundResource(imgIds[imgIndex]);

                return false;
            }
        });
        }
    }

    @Override
    public boolean onTouchEvent(MotionEvent evenet){
    
    
        return detector.onTouchEvent(evenet);
    }
}```

猜你喜欢

转载自blog.csdn.net/qq_62972842/article/details/127957424
今日推荐