aboutsummaryrefslogtreecommitdiffstats
path: root/app/src/main/java/de
diff options
context:
space:
mode:
authorJeremy Klein <jlklein@google.com>2015-09-29 16:48:05 -0700
committerJeremy Klein <jlklein@google.com>2015-10-01 14:56:39 -0700
commita11834b6021b2d943efeee73b1af38179dcea5a4 (patch)
treeeb5c5849907bc29876a15b5e8f516638c9f2a907 /app/src/main/java/de
parentaa2f25d977eb60c40bb05978a1e9826cd45b5552 (diff)
downloadconnectbot-a11834b6021b2d943efeee73b1af38179dcea5a4.tar.gz
connectbot-a11834b6021b2d943efeee73b1af38179dcea5a4.tar.bz2
connectbot-a11834b6021b2d943efeee73b1af38179dcea5a4.zip
Add support for mouse move event forwarding.
Diffstat (limited to 'app/src/main/java/de')
-rw-r--r--app/src/main/java/de/mud/terminal/vt320.java67
1 files changed, 52 insertions, 15 deletions
diff --git a/app/src/main/java/de/mud/terminal/vt320.java b/app/src/main/java/de/mud/terminal/vt320.java
index 90c7403..ab4a90d 100644
--- a/app/src/main/java/de/mud/terminal/vt320.java
+++ b/app/src/main/java/de/mud/terminal/vt320.java
@@ -385,26 +385,63 @@ public void setScreenSize(int c, int r, boolean broadcast) {
* @param meta
*/
public void mouseWheel(boolean down, int x, int y, boolean ctrl, boolean shift, boolean meta) {
- if (mouserpt == 0 || mouserpt == 9)
- return;
+ if (mouserpt == 0 || mouserpt == 9)
+ return;
+
+ int mods = 0;
+ if (ctrl) mods |= 16;
+ if (shift) mods |= 4;
+ if (meta) mods |= 8;
+
+ int mousecode = ((down ? 0 : 1) + 96) | 0x20 | mods;
+
+ byte b[] = new byte[6];
+
+ b[0] = 27;
+ b[1] = (byte) '[';
+ b[2] = (byte) 'M';
+ b[3] = (byte) mousecode;
+ b[4] = (byte) (0x20 + x + 1);
+ b[5] = (byte) (0x20 + y + 1);
+
+ write(b); // FIXME: writeSpecial here
+ }
+
+ /**
+ * Passes mouse move events to the terminal.
+ * @param button The mouse button pressed. 3 indicates no button is pressed.
+ * @param x
+ * @param y
+ * @param ctrl
+ * @param shift
+ * @param meta
+ */
+ public void mouseMoved(int button, int x, int y, boolean ctrl, boolean shift, boolean meta) {
+ if (mouserpt != 1002 && mouserpt != 1003)
+ return;
- int mods = 0;
- if (ctrl) mods |= 2;
- if (shift) mods |= 1;
- if (meta) mods |= 4;
+ // 1002 only reports drags. 1003 reports any movement.
+ if (mouserpt == 1002 && button == 3)
+ return;
- int mousecode = ((down ? 0 : 1) + 96) | 0x20 | ((mods & 7) << 2);
+ int mods = 0;
+ if (ctrl) mods |= 16;
+ if (shift) mods |= 4;
+ if (meta) mods |= 8;
- byte b[] = new byte[6];
+ // Normal mouse code plus additional 32 to indicate movement.
+ int mousecode = (button + 0x40) | mods;
- b[0] = 27;
- b[1] = (byte) '[';
- b[2] = (byte) 'M';
- b[3] = (byte) mousecode;
- b[4] = (byte) (0x20 + x + 1);
- b[5] = (byte) (0x20 + y + 1);
+ byte b[] = new byte[6];
- write(b); // FIXME: writeSpecial here
+ b[0] = 27;
+ b[1] = (byte) '[';
+ b[2] = (byte) 'M';
+ b[3] = (byte) mousecode;
+ b[4] = (byte) (0x20 + x + 1);
+ b[5] = (byte) (0x20 + y + 1);
+
+ write(b); // FIXME: writeSpecial here
}
/**