diff options
author | Brian P. Hinz <bphinz@users.sf.net> | 2020-08-09 13:08:54 -0400 |
---|---|---|
committer | Brian P. Hinz <bphinz@users.sf.net> | 2020-08-09 13:12:00 -0400 |
commit | 6d5915d3ca9e37fd602d5a7eb1653440ed536c68 (patch) | |
tree | 50f04a848f1bd5bac95aecae2e11b011649ef99b | |
parent | 201fc4227ef76014b772d2e9f241c36fc1149556 (diff) | |
download | tigervnc-6d5915d3ca9e37fd602d5a7eb1653440ed536c68.tar.gz tigervnc-6d5915d3ca9e37fd602d5a7eb1653440ed536c68.zip |
Fixes for Java 11. SocketDescriptor change was a workaround for a previous java problem that no longer seems necessary
-rw-r--r-- | java/com/tigervnc/network/SocketDescriptor.java | 6 | ||||
-rw-r--r-- | java/com/tigervnc/vncviewer/UserDialog.java | 44 |
2 files changed, 14 insertions, 36 deletions
diff --git a/java/com/tigervnc/network/SocketDescriptor.java b/java/com/tigervnc/network/SocketDescriptor.java index b4c99c74..42e785ec 100644 --- a/java/com/tigervnc/network/SocketDescriptor.java +++ b/java/com/tigervnc/network/SocketDescriptor.java @@ -68,9 +68,9 @@ public class SocketDescriptor implements FileDescriptor { private static SelectorProvider DefaultSelectorProvider() { // kqueue() selector provider on OS X is not working, fall back to select() for now - String os = System.getProperty("os.name"); - if (os.startsWith("Mac OS X")) - System.setProperty("java.nio.channels.spi.SelectorProvider","sun.nio.ch.PollSelectorProvider"); + //String os = System.getProperty("os.name"); + //if (os.startsWith("Mac OS X")) + // System.setProperty("java.nio.channels.spi.SelectorProvider","sun.nio.ch.PollSelectorProvider"); return SelectorProvider.provider(); } diff --git a/java/com/tigervnc/vncviewer/UserDialog.java b/java/com/tigervnc/vncviewer/UserDialog.java index f3ca726a..9804aafa 100644 --- a/java/com/tigervnc/vncviewer/UserDialog.java +++ b/java/com/tigervnc/vncviewer/UserDialog.java @@ -42,32 +42,6 @@ import static javax.swing.JOptionPane.*; public class UserDialog implements UserPasswdGetter, UserMsgBox { - private class MyLayerUI extends LayerUI { - // Using a JButton for the "?" icon yields the best look, but there - // does not seem to be any reasonable way to disable a JButton without - // also changing the color. This wrapper just intercepts any mouse - // click events so that the button just looks like an icon. - @Override - public void eventDispatched(AWTEvent e, JLayer l) { - if (e instanceof InputEvent) - ((InputEvent) e).consume(); - } - - @Override - public void installUI(JComponent c) { - super.installUI(c); - if (c instanceof JLayer) { - JLayer<?> layer = (JLayer<?>)c; - layer.setLayerEventMask(AWTEvent.MOUSE_EVENT_MASK); - } - } - - @Override - protected void processMouseEvent(MouseEvent e, JLayer l) { - super.processMouseEvent(e, l); - } - } - public final void getUserPasswd(boolean secure, StringBuffer user, StringBuffer password) { String passwordFileStr = passwordFile.getValue(); @@ -100,7 +74,6 @@ public class UserDialog implements UserPasswdGetter, UserMsgBox JDialog win; JLabel banner; JTextField username = null; - JLayer icon; int y; @@ -129,13 +102,18 @@ public class UserDialog implements UserPasswdGetter, UserMsgBox y = 20 + 10; - JButton iconb = new JButton("?"); - iconb.setVerticalAlignment(JLabel.CENTER); - iconb.setFont(new Font("Times", Font.BOLD, 34)); - iconb.setForeground(Color.BLUE); - LayerUI ui = new MyLayerUI(); - icon = new JLayer(iconb, ui); + JButton icon = new JButton("?"); + icon.setVerticalAlignment(JLabel.CENTER); + icon.setFont(new Font("Times", Font.BOLD, 34)); + icon.setForeground(Color.BLUE); icon.setBounds(10, y, 50, 50); + // the following disables the "?" icon without changing the color + UIDefaults defaults = UIManager.getLookAndFeelDefaults(); + Painter painter = (Painter)defaults.get("Button[Enabled].backgroundPainter"); + defaults.put("Button[Disabled].backgroundPainter", painter); + icon.putClientProperty("Nimbus.Overrides.InheritDefaults", Boolean.TRUE); + icon.putClientProperty("Nimbus.Overrides", defaults); + icon.setEnabled(false); msg.add(icon); y += 5; |