提交 07a5c521 编写于 作者: S serb

8147994: [macosx] JScrollPane jitters up/down during trackpad scrolling on MacOS/Aqua

Reviewed-by: alexp, aivanov
上级 e6526463
/* /*
* Copyright (c) 1997, 2013, Oracle and/or its affiliates. All rights reserved. * Copyright (c) 1997, 2016, Oracle and/or its affiliates. All rights reserved.
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
* *
* This code is free software; you can redistribute it and/or modify it * This code is free software; you can redistribute it and/or modify it
...@@ -870,18 +870,13 @@ public class BasicScrollPaneUI ...@@ -870,18 +870,13 @@ public class BasicScrollPaneUI
int orientation = SwingConstants.VERTICAL; int orientation = SwingConstants.VERTICAL;
// find which scrollbar to scroll, or return if none // find which scrollbar to scroll, or return if none
if (toScroll == null || !toScroll.isVisible()) { if (toScroll == null || !toScroll.isVisible()
|| e.isShiftDown()) {
toScroll = scrollpane.getHorizontalScrollBar(); toScroll = scrollpane.getHorizontalScrollBar();
if (toScroll == null || !toScroll.isVisible()) { if (toScroll == null || !toScroll.isVisible()) {
return; return;
} }
orientation = SwingConstants.HORIZONTAL; orientation = SwingConstants.HORIZONTAL;
} else if(e.isShiftDown()){
JScrollBar hScroll = scrollpane.getHorizontalScrollBar();
if (hScroll != null && hScroll.isVisible()) {
toScroll = hScroll;
orientation = SwingConstants.HORIZONTAL;
}
} }
e.consume(); e.consume();
......
/* /*
* Copyright (c) 2015, Oracle and/or its affiliates. All rights reserved. * Copyright (c) 2015, 2016, Oracle and/or its affiliates. All rights reserved.
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
* *
* This code is free software; you can redistribute it and/or modify it * This code is free software; you can redistribute it and/or modify it
...@@ -20,6 +20,7 @@ ...@@ -20,6 +20,7 @@
* or visit www.oracle.com if you need additional information or have any * or visit www.oracle.com if you need additional information or have any
* questions. * questions.
*/ */
import java.awt.BorderLayout; import java.awt.BorderLayout;
import java.awt.Point; import java.awt.Point;
import java.awt.Robot; import java.awt.Robot;
...@@ -29,22 +30,23 @@ import javax.swing.JPanel; ...@@ -29,22 +30,23 @@ import javax.swing.JPanel;
import javax.swing.JScrollPane; import javax.swing.JScrollPane;
import javax.swing.JTextArea; import javax.swing.JTextArea;
import javax.swing.SwingUtilities; import javax.swing.SwingUtilities;
import javax.swing.UIManager;
import sun.awt.OSInfo; import sun.awt.OSInfo;
/** /**
* @test * @test
* @bug 8033000 * @bug 8033000 8147994
* @author Alexander Scherbatiy * @author Alexander Scherbatiy
* @summary No Horizontal Mouse Wheel Support In BasicScrollPaneUI * @summary No Horizontal Mouse Wheel Support In BasicScrollPaneUI
* @run main bug8033000 * @run main HorizontalMouseWheelOnShiftPressed
*/ */
public class bug8033000 { public class HorizontalMouseWheelOnShiftPressed {
private static JScrollPane scrollPane; private static JScrollPane scrollPane;
private static JTextArea textArea; private static JTextArea textArea;
private static Point point; private static Point point;
private static final int delta; private static final int delta;
private static JFrame frame;
static { static {
delta = OSInfo.getOSType().equals(OSInfo.OSType.MACOSX) ? -30 : 30; delta = OSInfo.getOSType().equals(OSInfo.OSType.MACOSX) ? -30 : 30;
...@@ -55,9 +57,17 @@ public class bug8033000 { ...@@ -55,9 +57,17 @@ public class bug8033000 {
Robot robot = new Robot(); Robot robot = new Robot();
robot.setAutoDelay(50); robot.setAutoDelay(50);
SwingUtilities.invokeAndWait(bug8033000::createAndShowGUI); SwingUtilities.invokeAndWait(
HorizontalMouseWheelOnShiftPressed::createAndShowGUI);
robot.waitForIdle(); robot.waitForIdle();
try {
test(robot);
} finally {
frame.dispose();
}
}
private static void test(Robot robot) throws Exception {
SwingUtilities.invokeAndWait(() -> { SwingUtilities.invokeAndWait(() -> {
Point locationOnScreen = scrollPane.getLocationOnScreen(); Point locationOnScreen = scrollPane.getLocationOnScreen();
point = new Point( point = new Point(
...@@ -73,7 +83,7 @@ public class bug8033000 { ...@@ -73,7 +83,7 @@ public class bug8033000 {
robot.waitForIdle(); robot.waitForIdle();
robot.mouseWheel(delta); robot.mouseWheel(delta);
robot.waitForIdle(); robot.waitForIdle();
checkScrollPane(true); checkScrollPane(true, false);
// vertical scroll bar is enabled + shift // vertical scroll bar is enabled + shift
initScrollPane(true, false); initScrollPane(true, false);
...@@ -82,14 +92,14 @@ public class bug8033000 { ...@@ -82,14 +92,14 @@ public class bug8033000 {
robot.mouseWheel(delta); robot.mouseWheel(delta);
robot.keyRelease(KeyEvent.VK_SHIFT); robot.keyRelease(KeyEvent.VK_SHIFT);
robot.waitForIdle(); robot.waitForIdle();
checkScrollPane(true); checkScrollPane(false, false);
// horizontal scroll bar is enabled // horizontal scroll bar is enabled
initScrollPane(false, true); initScrollPane(false, true);
robot.waitForIdle(); robot.waitForIdle();
robot.mouseWheel(delta); robot.mouseWheel(delta);
robot.waitForIdle(); robot.waitForIdle();
checkScrollPane(false); checkScrollPane(false, true);
// horizontal scroll bar is enabled + shift // horizontal scroll bar is enabled + shift
initScrollPane(false, true); initScrollPane(false, true);
...@@ -98,14 +108,14 @@ public class bug8033000 { ...@@ -98,14 +108,14 @@ public class bug8033000 {
robot.mouseWheel(delta); robot.mouseWheel(delta);
robot.keyRelease(KeyEvent.VK_SHIFT); robot.keyRelease(KeyEvent.VK_SHIFT);
robot.waitForIdle(); robot.waitForIdle();
checkScrollPane(false); checkScrollPane(false, true);
// both scroll bars are enabled // both scroll bars are enabled
initScrollPane(true, true); initScrollPane(true, true);
robot.waitForIdle(); robot.waitForIdle();
robot.mouseWheel(delta); robot.mouseWheel(delta);
robot.waitForIdle(); robot.waitForIdle();
checkScrollPane(true); checkScrollPane(true, false);
// both scroll bars are enabled + shift // both scroll bars are enabled + shift
initScrollPane(true, true); initScrollPane(true, true);
...@@ -114,7 +124,7 @@ public class bug8033000 { ...@@ -114,7 +124,7 @@ public class bug8033000 {
robot.mouseWheel(delta); robot.mouseWheel(delta);
robot.keyRelease(KeyEvent.VK_SHIFT); robot.keyRelease(KeyEvent.VK_SHIFT);
robot.waitForIdle(); robot.waitForIdle();
checkScrollPane(false); checkScrollPane(false, true);
} }
static void initScrollPane(boolean vVisible, boolean hVisible) throws Exception { static void initScrollPane(boolean vVisible, boolean hVisible) throws Exception {
...@@ -129,17 +139,25 @@ public class bug8033000 { ...@@ -129,17 +139,25 @@ public class bug8033000 {
}); });
} }
static void checkScrollPane(boolean verticalScrolled) throws Exception { static void checkScrollPane(boolean verticalScrolled,
boolean horizontalScrolled) throws Exception {
SwingUtilities.invokeAndWait(() -> { SwingUtilities.invokeAndWait(() -> {
if (verticalScrolled) { if (verticalScrolled) {
if (scrollPane.getVerticalScrollBar().getValue() == 0 if (scrollPane.getVerticalScrollBar().getValue() == 0) {
|| scrollPane.getHorizontalScrollBar().getValue() != 0) { throw new RuntimeException("Wrong vertical scrolling!");
}
} else{
if (scrollPane.getVerticalScrollBar().getValue() != 0) {
throw new RuntimeException("Wrong vertical scrolling!"); throw new RuntimeException("Wrong vertical scrolling!");
} }
}
if (horizontalScrolled) {
if (scrollPane.getHorizontalScrollBar().getValue() == 0) {
throw new RuntimeException("Wrong horizontal scrolling!");
}
} else { } else {
if (scrollPane.getVerticalScrollBar().getValue() != 0 if (scrollPane.getHorizontalScrollBar().getValue() != 0) {
|| scrollPane.getHorizontalScrollBar().getValue() == 0) {
throw new RuntimeException("Wrong horizontal scrolling!"); throw new RuntimeException("Wrong horizontal scrolling!");
} }
} }
...@@ -147,9 +165,10 @@ public class bug8033000 { ...@@ -147,9 +165,10 @@ public class bug8033000 {
} }
static void createAndShowGUI() { static void createAndShowGUI() {
JFrame frame = new JFrame(); frame = new JFrame();
frame.setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE); frame.setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE);
frame.setSize(300, 300); frame.setSize(300, 300);
frame.setLocationRelativeTo(null);
textArea = new JTextArea("Hello World!"); textArea = new JTextArea("Hello World!");
scrollPane = new JScrollPane(textArea); scrollPane = new JScrollPane(textArea);
JPanel panel = new JPanel(new BorderLayout()); JPanel panel = new JPanel(new BorderLayout());
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册