From 6f30ddc41a71343220c7b1d14c31cdad6fbea907 Mon Sep 17 00:00:00 2001 From: Sven Gothel Date: Wed, 28 Sep 2011 17:20:06 +0200 Subject: NEWT/Android: Send MouseClicked event, MouseEvent enhancement, Demo: real 2 finger zoom MouseEvent: Check array sizes at cstr. Enhance 'toString()', pointer arrays added. GPUUISceneGLListener0A now uses 2 finger distance for zoom --- .../junit/graph/demos/GPUUISceneGLListener0A.java | 48 +++++++++++++++------- .../junit/graph/demos/ui/SceneUIController.java | 9 +++- 2 files changed, 41 insertions(+), 16 deletions(-) (limited to 'src/test/com/jogamp/opengl') diff --git a/src/test/com/jogamp/opengl/test/junit/graph/demos/GPUUISceneGLListener0A.java b/src/test/com/jogamp/opengl/test/junit/graph/demos/GPUUISceneGLListener0A.java index 476bbc04f..63daff27c 100644 --- a/src/test/com/jogamp/opengl/test/junit/graph/demos/GPUUISceneGLListener0A.java +++ b/src/test/com/jogamp/opengl/test/junit/graph/demos/GPUUISceneGLListener0A.java @@ -178,8 +178,11 @@ public class GPUUISceneGLListener0A implements GLEventListener { public void init(GLAutoDrawable drawable) { if(drawable instanceof GLWindow) { + System.err.println("GPUUISceneGLListener0A: init (1)"); final GLWindow glw = (GLWindow) drawable; attachInputListenerTo(glw); + } else { + System.err.println("GPUUISceneGLListener0A: init (0)"); } final int width = drawable.getWidth(); final int height = drawable.getHeight(); @@ -225,8 +228,11 @@ public class GPUUISceneGLListener0A implements GLEventListener { public void dispose(GLAutoDrawable drawable) { if(drawable instanceof GLWindow) { + System.err.println("GPUUISceneGLListener0A: dispose (1)"); final GLWindow glw = (GLWindow) drawable; detachInputListenerFrom(glw); + } else { + System.err.println("GPUUISceneGLListener0A: dispose (0)"); } GL2ES2 gl = drawable.getGL().getGL2ES2(); @@ -235,6 +241,7 @@ public class GPUUISceneGLListener0A implements GLEventListener { } public void display(GLAutoDrawable drawable) { + // System.err.println("GPUUISceneGLListener0A: display"); final int width = drawable.getWidth(); final int height = drawable.getHeight(); GL2ES2 gl = drawable.getGL().getGL2ES2(); @@ -308,6 +315,7 @@ public class GPUUISceneGLListener0A implements GLEventListener { } public void reshape(GLAutoDrawable drawable, int x, int y, int width, int height) { + System.err.println("GPUUISceneGLListener0A: reshape"); GL2ES2 gl = drawable.getGL().getGL2ES2(); gl.glViewport(x, y, width, height); @@ -333,8 +341,7 @@ public class GPUUISceneGLListener0A implements GLEventListener { } private class MultiTouchListener extends MouseAdapter { - int lx = 0; - int ly = 0; + int lv = 0; boolean first = false; @@ -350,22 +357,33 @@ public class GPUUISceneGLListener0A implements GLEventListener { @Override public void mouseDragged(MouseEvent e) { - if(first) { - lx = e.getX(); - ly = e.getY(); - first=false; - return; - } - int dx = lx - e.getX(); - int dy = e.getY() - ly; - if(Math.abs(dx) < Math.abs(dy)) { - zoom += Math.signum(dy); + System.err.println("demo:mousedragged "+e); + if(e.getPointerCount()==2) { + // 2 finger zoom .. + if(first) { + lv = Math.abs(e.getY(0)-e.getY(1)); + first=false; + return; + } + int nv = Math.abs(e.getY(0)-e.getY(1)); + int dy = nv - lv; + + zoom += 2 * Math.signum(dy); + + lv = nv; } else { + // 1 finger drag + if(first) { + lv = e.getX(); + first=false; + return; + } + int nv = e.getX(); + int dx = nv - lv; xTran += Math.signum(dx); + + lv = nv; } - - lx = e.getX(); - ly = e.getY(); } } } \ No newline at end of file diff --git a/src/test/com/jogamp/opengl/test/junit/graph/demos/ui/SceneUIController.java b/src/test/com/jogamp/opengl/test/junit/graph/demos/ui/SceneUIController.java index 9ee1c519e..deefbf783 100644 --- a/src/test/com/jogamp/opengl/test/junit/graph/demos/ui/SceneUIController.java +++ b/src/test/com/jogamp/opengl/test/junit/graph/demos/ui/SceneUIController.java @@ -80,9 +80,11 @@ public class SceneUIController implements GLEventListener{ } public void init(GLAutoDrawable drawable) { + System.err.println("SceneUIController: init"); cDrawable = drawable; } public void display(GLAutoDrawable drawable) { + // System.err.println("SceneUIController: display"); final int width = drawable.getWidth(); final int height = drawable.getHeight(); GL2ES2 gl = drawable.getGL().getGL2ES2(); @@ -91,11 +93,13 @@ public class SceneUIController implements GLEventListener{ } public void dispose(GLAutoDrawable drawable) { - + System.err.println("SceneUIController: dispose"); + cDrawable = null; } public void reshape(GLAutoDrawable drawable, int x, int y, int width, int height) { + System.err.println("SceneUIController: reshape"); GL2ES2 gl = drawable.getGL().getGL2ES2(); renderer.reshapePerspective(gl, 45.0f, width, height, 5f, 70.0f); } @@ -206,6 +210,9 @@ public class SceneUIController implements GLEventListener{ } public void mousePressed(MouseEvent e) { + if(null==cDrawable) { + return; + } mouseX = e.getX(); mouseY = e.getY(); -- cgit v1.2.3