holding CTRL + ALT + SHIFT will now release the mouse. Also fixed mouse re-centering issue (i believe. I cannot test for sure on my system)

This commit is contained in:
Diego Waxemberg
2013-12-12 19:45:35 -05:00
parent af3369ec5c
commit c8235da7bb
3 changed files with 149 additions and 95 deletions
@@ -33,7 +33,7 @@ public class StreamFrame extends JFrame {
private MouseHandler mouse;
private JProgressBar spinner;
private JLabel spinnerLabel;
private Cursor noCursor;
private NvConnection conn;
public StreamFrame() {
@@ -43,6 +43,16 @@ public class StreamFrame extends JFrame {
centerY = dim.height/2-this.getSize().height/2;
}
public void freeMouse() {
mouse.free();
showCursor();
}
public void captureMouse() {
mouse.capture();
hideCursor();
}
public void build(NvConnection conn, boolean fullscreen) {
this.conn = conn;
@@ -83,17 +93,23 @@ public class StreamFrame extends JFrame {
}
}
private void hideCursor() {
public void hideCursor() {
if (noCursor == null) {
// Transparent 16 x 16 pixel cursor image.
BufferedImage cursorImg = new BufferedImage(16, 16, BufferedImage.TYPE_INT_ARGB);
// Create a new blank cursor.
Cursor blankCursor = Toolkit.getDefaultToolkit().createCustomCursor(
noCursor = Toolkit.getDefaultToolkit().createCustomCursor(
cursorImg, new Point(0, 0), "blank cursor");
}
// Set the blank cursor to the JFrame.
this.getContentPane().setCursor(blankCursor);
this.setCursor(noCursor);
this.getContentPane().setCursor(noCursor);
}
public void showCursor() {
this.setCursor(Cursor.getDefaultCursor());
this.getContentPane().setCursor(Cursor.getDefaultCursor());
}
public void showSpinner(Stage stage) {
@@ -40,18 +40,32 @@ public class KeyboardHandler implements KeyListener {
event.getKeyCode() == KeyEvent.VK_Q) {
System.out.println("quitting");
parent.close();
} else if (
(modifiers & KeyEvent.SHIFT_DOWN_MASK) != 0 &&
(modifiers & KeyEvent.ALT_DOWN_MASK) != 0 &&
(modifiers & KeyEvent.CTRL_DOWN_MASK) != 0) {
parent.freeMouse();
}
translator.sendKeyDown(keyMap, modifier);
}
@Override
public void keyReleased(KeyEvent event) {
int modifiers = event.getModifiersEx();
if ((modifiers & KeyEvent.SHIFT_DOWN_MASK) != 0 ||
(modifiers & KeyEvent.ALT_DOWN_MASK) != 0 ||
(modifiers & KeyEvent.CTRL_DOWN_MASK) != 0) {
parent.captureMouse();
}
short keyMap = translator.translate(event.getKeyCode());
byte modifier = 0x0;
int modifiers = event.getModifiersEx();
if ((modifiers & KeyEvent.SHIFT_DOWN_MASK) != 0) {
modifier |= KeyboardPacket.MODIFIER_SHIFT;
}
@@ -10,6 +10,7 @@ import java.awt.event.MouseMotionListener;
import javax.swing.JFrame;
import javax.swing.SwingUtilities;
import com.limelight.gui.StreamFrame;
import com.limelight.nvstream.NvConnection;
import com.limelight.nvstream.input.MouseButtonPacket;
@@ -17,11 +18,12 @@ public class MouseHandler implements MouseListener, MouseMotionListener {
private NvConnection conn;
private Robot robot;
private Dimension size;
private JFrame parent;
private StreamFrame parent;
private int lastX = 0;
private int lastY = 0;
private boolean captureMouse = true;
public MouseHandler(NvConnection conn, JFrame parent) {
public MouseHandler(NvConnection conn, StreamFrame parent) {
this.conn = conn;
this.parent = parent;
try {
@@ -33,8 +35,21 @@ public class MouseHandler implements MouseListener, MouseMotionListener {
}
public void free() {
captureMouse = false;
}
public void capture() {
moveMouse((int)parent.getLocationOnScreen().getX() + (size.width/2),
(int)parent.getLocationOnScreen().getY() + (size.height/2));
captureMouse = true;
}
@Override
public void mouseClicked(MouseEvent e) {
if (captureMouse) {
parent.hideCursor();
}
}
@Override
@@ -43,13 +58,16 @@ public class MouseHandler implements MouseListener, MouseMotionListener {
@Override
public void mouseExited(MouseEvent e) {
if (captureMouse) {
parent.getSize(size);
moveMouse((int)parent.getLocation().getX() + (size.width/2),
(int)parent.getLocation().getY() + (size.height/2));
moveMouse((int)parent.getLocationOnScreen().getX() + (size.width/2),
(int)parent.getLocationOnScreen().getY() + (size.height/2));
}
}
@Override
public void mousePressed(MouseEvent e) {
if (captureMouse) {
byte mouseButton = 0x0;
if (SwingUtilities.isLeftMouseButton(e)) {
@@ -68,9 +86,11 @@ public class MouseHandler implements MouseListener, MouseMotionListener {
conn.sendMouseButtonDown(mouseButton);
}
}
}
@Override
public void mouseReleased(MouseEvent e) {
if (captureMouse) {
byte mouseButton = 0x0;
if (SwingUtilities.isLeftMouseButton(e)) {
@@ -89,14 +109,18 @@ public class MouseHandler implements MouseListener, MouseMotionListener {
conn.sendMouseButtonUp(mouseButton);
}
}
}
@Override
public void mouseDragged(MouseEvent e) {
if (captureMouse) {
mouseMoved(e);
}
}
@Override
public void mouseMoved(MouseEvent e) {
if (captureMouse) {
int x = e.getX();
int y = e.getY();
conn.sendMouseMove((short)(x - lastX), (short)(y - lastY));
@@ -105,9 +129,9 @@ public class MouseHandler implements MouseListener, MouseMotionListener {
parent.getSize(size);
int leftEdge = (int) parent.getLocation().getX();
int leftEdge = (int) parent.getLocationOnScreen().getX();
int rightEdge = leftEdge + size.width;
int upperEdge = (int) parent.getLocation().getY();
int upperEdge = (int) parent.getLocationOnScreen().getY();
int lowerEdge = upperEdge + size.height;
if (x < leftEdge + 100 || x > rightEdge - 100) {
@@ -116,7 +140,7 @@ public class MouseHandler implements MouseListener, MouseMotionListener {
if (y < upperEdge + 100 || y > lowerEdge - 100) {
moveMouse((leftEdge+rightEdge)/2, (upperEdge+lowerEdge)/2);
}
}
}
private void moveMouse(int x, int y) {