aboutsummaryrefslogtreecommitdiffstats
path: root/java/com/tigervnc/vncviewer/DesktopWindow.java
diff options
context:
space:
mode:
Diffstat (limited to 'java/com/tigervnc/vncviewer/DesktopWindow.java')
-rw-r--r--java/com/tigervnc/vncviewer/DesktopWindow.java44
1 files changed, 26 insertions, 18 deletions
diff --git a/java/com/tigervnc/vncviewer/DesktopWindow.java b/java/com/tigervnc/vncviewer/DesktopWindow.java
index 21e2e8ea..8bf718b1 100644
--- a/java/com/tigervnc/vncviewer/DesktopWindow.java
+++ b/java/com/tigervnc/vncviewer/DesktopWindow.java
@@ -55,6 +55,7 @@ class DesktopWindow extends JPanel implements
cc = cc_;
setSize(width, height);
im = new PixelBufferImage(width, height, cc, this);
+ im.image.setAccelerationPriority(1);
cursor = new Cursor();
cursorBacking = new ManagedPixelBuffer();
@@ -69,7 +70,6 @@ class DesktopWindow extends JPanel implements
});
setFocusTraversalKeysEnabled(false);
setFocusable(true);
- setDoubleBuffered(true);
}
public int width() {
@@ -113,6 +113,7 @@ class DesktopWindow extends JPanel implements
synchronized(this) {
if (!cc.viewer.useLocalCursor.getValue()) return;
+ }
hideLocalCursor();
@@ -162,7 +163,6 @@ class DesktopWindow extends JPanel implements
tk.createImage(bitmap).getScaledInstance(cw,ch,hint);
softCursor = tk.createCustomCursor(cursorImage,
new java.awt.Point(hotspot.x,hotspot.y), "Cursor");
- }
if (softCursor != null) {
setCursor(softCursor);
@@ -206,12 +206,14 @@ class DesktopWindow extends JPanel implements
}
// resize() is called when the desktop has changed size
- synchronized public void resize() {
+ public void resize() {
int w = cc.cp.width;
int h = cc.cp.height;
hideLocalCursor();
setSize(w, h);
- im.resize(w, h);
+ synchronized (this) {
+ im.resize(w, h);
+ }
}
final void drawInvalidRect() {
@@ -253,29 +255,35 @@ class DesktopWindow extends JPanel implements
drawInvalidRect();
}
- synchronized final public void fillRect(int x, int y, int w, int h, int pix)
+ final public void fillRect(int x, int y, int w, int h, int pix)
{
if (overlapsCursor(x, y, w, h)) hideLocalCursor();
- im.fillRect(x, y, w, h, pix);
+ synchronized (this) {
+ im.fillRect(x, y, w, h, pix);
+ }
invalidate(x, y, w, h);
if (softCursor == null)
showLocalCursor();
}
- synchronized final public void imageRect(int x, int y, int w, int h,
+ final public void imageRect(int x, int y, int w, int h,
int[] pix) {
if (overlapsCursor(x, y, w, h)) hideLocalCursor();
- im.imageRect(x, y, w, h, pix);
+ synchronized (this) {
+ im.imageRect(x, y, w, h, pix);
+ }
invalidate(x, y, w, h);
if (softCursor == null)
showLocalCursor();
}
- synchronized final public void copyRect(int x, int y, int w, int h,
+ final public void copyRect(int x, int y, int w, int h,
int srcX, int srcY) {
if (overlapsCursor(x, y, w, h) || overlapsCursor(srcX, srcY, w, h))
hideLocalCursor();
- im.copyRect(x, y, w, h, srcX, srcY);
+ synchronized (this) {
+ im.copyRect(x, y, w, h, srcX, srcY);
+ }
if (!cc.viewer.fastCopyRect.getValue()) {
invalidate(x, y, w, h);
}
@@ -293,7 +301,7 @@ class DesktopWindow extends JPanel implements
////////////////////////////////////////////////////////////////////
// The following methods are all called from the GUI thread
- synchronized void resetLocalCursor() {
+ void resetLocalCursor() {
hideLocalCursor();
cursorAvailable = false;
}
@@ -350,7 +358,7 @@ class DesktopWindow extends JPanel implements
scaleHeightRatio = (float)scaledHeight / (float)cc.cp.height;
}
- synchronized public void paintComponent(Graphics g) {
+ public void paintComponent(Graphics g) {
Graphics2D g2 = (Graphics2D) g;
g2.setRenderingHint(RenderingHints.KEY_INTERPOLATION,
RenderingHints.VALUE_INTERPOLATION_BILINEAR);
@@ -362,7 +370,7 @@ class DesktopWindow extends JPanel implements
g2.drawImage(im.image, 0, 0, scaledWidth, scaledHeight, null);
}
}
-
+
String oldContents = "";
synchronized public void checkClipboard() {
@@ -395,11 +403,11 @@ class DesktopWindow extends JPanel implements
if (!cc.viewer.viewOnly.getValue())
cc.writePointerEvent(e);
// - If local cursor rendering is enabled then use it
- synchronized(this) {
- if (cursorAvailable) {
- // - Render the cursor!
- if (e.getX() != cursorPosX || e.getY() != cursorPosY) {
- hideLocalCursor();
+ if (cursorAvailable) {
+ // - Render the cursor!
+ if (e.getX() != cursorPosX || e.getY() != cursorPosY) {
+ hideLocalCursor();
+ synchronized(this) {
if (e.getX() >= 0 && e.getX() < im.width() &&
e.getY() >= 0 && e.getY() < im.height()) {
cursorPosX = e.getX();