Android开发之响应触摸事件

移动开发 Android
一般而言,事件是用户与UI(图形界面)进行交互的时候所触发的操作。例如在手机屏幕上触摸特定的区域就会触发对应的事件,在Android 中这些事件将被传送到事件处理器,它是一个专门接受事件对象并对其进行翻译和处理的方法。

让对象按预设程序进行移动确实可以吸引一些注意,比如旋转三角形。但如果你想用OpenGL ES制图实现用户交互,又该怎么做呢?让你的OpenGL ES应用具有触摸交互的关键在于扩展对 GLSurfaceView 类的实现,重写 onTouchEvent() 来监听触摸事件。

本文主要向你展示如何监听触摸事件,从而让用户来旋转一个OpenGL ES对象。

建立一个触摸监听器 - Setup a Touch Listener

为了让你的OpenGL ES应用程序对触摸事件做出响应,你需要实现 GLSurfaceView 类的 onTouchEvent() 方法。下面的一个实现的例子演示了如何监听 MotionEvent.ACTION_MOVE 事件,并把他们转换成图形旋转的一个角度。

  1. @Override 
  2.     public boolean onTouchEvent(MotionEvent e) { 
  3.  
  4.     // MotionEvent提供了触摸的输入的细节以及其他输入控制信息。 
  5.     //在这种情况下,你只需要关心触摸位置改变的事件。 
  6.  
  7.     float x = e.getX(); 
  8.     float y = e.getY(); 
  9.  
  10.     switch (e.getAction()) { 
  11.         case MotionEvent.ACTION_MOVE: 
  12.  
  13.             float dx = x - mPreviousX; 
  14.             float dy = y - mPreviousY; 
  15.  
  16.             //在中线上反向旋转 
  17.             if (y > getHeight() / 2) { 
  18.               dx = dx *  -1 ; 
  19.             } 
  20.  
  21.             //反向旋转至中线左侧 
  22.             if (x < getWidth() / 2) { 
  23.               dy = dy *  -1 ; 
  24.             } 
  25.  
  26.             mRenderer.mAngle +180.0f / 320 
  27.             requestRender(); 
  28.     } 
  29.  
  30.     mPreviousX = x; 
  31.     mPreviousY = y; 
  32.     return true
  33.     } 

需要注意的是,计算好旋转角度后,这个方法调用了 requestRender() 来通知渲染器渲染画面。由于这个画面在没有旋转的变化时无需重绘,因此在本例中使用这种做法最高效。然而,如果你没有用 setRenderMode() 方法请求渲染器仅在数据改变时才重绘,那么这种做法就不会对效率有影响了。因此,确保取消掉渲染器里对这一行代码的注释。

  1. public MyGLSurfaceView(Context context) { 
  2.     ... 
  3.     //仅当绘图数据改变时绘制视图 
  4.     setRenderMode(GLSurfaceView.RENDERMODE_WHEN_DIRTY); 
  5.      } 

显示旋转的角度 - Expose the Rotation Angle

上面的示例代码需要你在渲染器中添加一个公共成员来显示旋转角度。由于渲染器的代码所运行的线程独立于应用程序的用户界面主线程之外,因此,你必须将这个公共变量声明为 volatile。参见下面的代码:

  1. public class MyGLRenderer implements GLSurfaceView.Renderer { 
  2.     ... 
  3.     public volatile float mAngle; 

应用旋转 - Apply Rotation

要让触摸输入产生旋转,就需要注释掉生成角度的代码,改用触摸输入生成的角度 mAngle:

  1. public void onDrawFrame(GL10 gl) { 
  2.     ... 
  3.     //为三角形创建旋转 
  4.     // long time = SystemClock.uptimeMillis() % 4000L; 
  5.     // float angle = 0.090f *  ((int) time); 
  6.     Matrix.setRotateM(mRotationMatrix, 0, mAngle, 00, -1.0f); 
  7.     //将旋转矩阵与投影和相机视图相结合 
  8.     Matrix.multiplyMM(mMVPMatrix, 0, mRotationMatrix, 0, mMVPMatrix, 0); 
  9.     //绘制三角形 
  10.     mTriangle.draw(mMVPMatrix); 
  11.     } 

当你完成了以上步骤,运行程序,就可以在屏幕上拖动来旋转那个三角形了。

图1.三角形在触摸下旋转(圆圈表示触摸位置)

责任编辑:闫佳明 来源: wiki.eoe.cn
相关推荐

2016-12-08 22:59:47

触摸事件android

2017-12-21 15:42:08

iOS传递机制

2011-08-02 16:28:40

iPhone Web开发 事件

2013-04-22 15:40:00

Android开发触摸事件与点击事件区别

2014-04-29 13:58:11

OpenGL ESAndroid响应触屏事件

2023-03-10 16:40:21

Frameworkinput触摸事件

2011-08-03 17:32:17

IOS UIScrollVi touch

2013-05-14 11:08:23

AIR Android触摸事件鼠标事件

2021-08-11 14:29:20

鸿蒙HarmonyOS应用

2013-09-13 13:15:28

AndroidWebViewJavaScript

2017-04-25 09:04:16

2013-05-21 14:22:29

Android游戏开发捕获屏幕双击事件

2011-08-17 10:09:25

iPhone开发UIWebViewTouch事件

2010-11-25 10:57:03

多点触摸Android

2017-01-11 18:44:43

React Nativ触摸事件Android

2017-07-24 14:32:49

2013-05-21 11:33:11

Android游戏开发按键中断事件

2023-10-12 22:44:16

iOS事件响应链

2009-04-14 08:14:09

AndroidGoogle移动OS

2022-02-09 00:08:26

黑客攻击事件响应
点赞
收藏

51CTO技术栈公众号