summaryrefslogtreecommitdiffstats
path: root/java
diff options
context:
space:
mode:
authorenikey <enikey@3789f03b-4d11-0410-bbf8-ca57d06f2519>2009-01-20 04:50:55 +0000
committerenikey <enikey@3789f03b-4d11-0410-bbf8-ca57d06f2519>2009-01-20 04:50:55 +0000
commit866b88c8d9002847cdf1cccf02c81fc36cfe7653 (patch)
tree759c21f4c0b850e9c6e376c51018d3f3bc461594 /java
parent2f25d35cfa1a4718a01dfe8e73591d8a3e28fe3c (diff)
downloadtigervnc-866b88c8d9002847cdf1cccf02c81fc36cfe7653.tar.gz
tigervnc-866b88c8d9002847cdf1cccf02c81fc36cfe7653.zip
[BugFix] Fixed: Skipping some mouse events when limiting mouse event sending. Now limiting uses thread.
git-svn-id: svn://svn.code.sf.net/p/tigervnc/code/trunk@3561 3789f03b-4d11-0410-bbf8-ca57d06f2519
Diffstat (limited to 'java')
-rw-r--r--java/src/com/tightvnc/vncviewer/VncCanvas.java40
1 files changed, 36 insertions, 4 deletions
diff --git a/java/src/com/tightvnc/vncviewer/VncCanvas.java b/java/src/com/tightvnc/vncviewer/VncCanvas.java
index 56019be9..4e5460f5 100644
--- a/java/src/com/tightvnc/vncviewer/VncCanvas.java
+++ b/java/src/com/tightvnc/vncviewer/VncCanvas.java
@@ -45,7 +45,7 @@ import java.util.zip.*;
//
class VncCanvas extends Canvas
- implements KeyListener, MouseListener, MouseMotionListener, Repaintable {
+ implements KeyListener, MouseListener, MouseMotionListener, Repaintable, Runnable {
VncViewer viewer;
RfbProto rfb;
@@ -174,6 +174,11 @@ class VncCanvas extends Canvas
addKeyListener(this);
addMouseListener(this);
addMouseMotionListener(this);
+
+ // Create thread, that will send mouse movement events
+ // to VNC server.
+ Thread mouseThread = new Thread(this);
+ mouseThread.start();
}
public VncCanvas(VncViewer v) throws IOException {
@@ -771,6 +776,26 @@ class VncCanvas extends Canvas
processLocalMouseEvent(evt, true);
}
+ private synchronized void trySendPointerEvent() {
+ if ((needToSendMouseEvent) && (mouseEvent!=null)) {
+ sendMouseEvent(mouseEvent, false);
+ needToSendMouseEvent = false;
+ lastMouseEventSendTime = System.currentTimeMillis();
+ }
+ }
+
+ public void run() {
+ while (true) {
+ // Send mouse movement if we have it
+ trySendPointerEvent();
+ // Sleep for some time
+ try {
+ Thread.sleep(1000 / mouseMaxFreq);
+ } catch (InterruptedException ex) {
+ }
+ }
+ }
+
//
// Ignored events.
//
@@ -817,9 +842,15 @@ class VncCanvas extends Canvas
if (viewer.rfb != null && rfb.inNormalProtocol) {
if (!inSelectionMode) {
if (inputEnabled) {
- if (System.currentTimeMillis() - lastMouseEventSendTime >=
- (1000 / mouseMaxFreq)) {
+ // If mouse not moved, but it's click event then
+ // send it to server immideanlty.
+ // Else, it's mouse movement - we can send it in
+ // our thread later.
+ if (!moved) {
sendMouseEvent(evt, moved);
+ } else {
+ mouseEvent = evt;
+ needToSendMouseEvent = true;
}
}
} else {
@@ -880,7 +911,8 @@ class VncCanvas extends Canvas
MemoryImageSource softCursorSource;
Image softCursor;
-
+ MouseEvent mouseEvent = null;
+ boolean needToSendMouseEvent = false;
int cursorX = 0, cursorY = 0;
int cursorWidth, cursorHeight;
int origCursorWidth, origCursorHeight;