提交 dc5debbe 编写于 作者: L lana

Merge

...@@ -758,6 +758,11 @@ public class RepaintManager ...@@ -758,6 +758,11 @@ public class RepaintManager
for(i=0 ; i < count ; i++) { for(i=0 ; i < count ; i++) {
dirtyComponent = roots.get(i); dirtyComponent = roots.get(i);
rect = tmpDirtyComponents.get(dirtyComponent); rect = tmpDirtyComponents.get(dirtyComponent);
// Sometimes when RepaintManager is changed during the painting
// we may get null here, see #6995769 for details
if (rect == null) {
continue;
}
localBoundsH = dirtyComponent.getHeight(); localBoundsH = dirtyComponent.getHeight();
localBoundsW = dirtyComponent.getWidth(); localBoundsW = dirtyComponent.getWidth();
......
...@@ -2167,7 +2167,7 @@ public class MetalLookAndFeel extends BasicLookAndFeel ...@@ -2167,7 +2167,7 @@ public class MetalLookAndFeel extends BasicLookAndFeel
/** /**
* Returns a {@code LayoutStyle} implementing the Java look and feel * Returns a {@code LayoutStyle} implementing the Java look and feel
* design guidelines as specified at * design guidelines as specified at
* <a href="http://java.sun.com/products/jlf/ed2/book/HIG.Visual2.html">http://java.sun.com/products/jlf/ed2/book/HIG.Visual2.html</a>. * <a href="http://www.oracle.com/technetwork/java/hig-136467.html">http://www.oracle.com/technetwork/java/hig-136467.html</a>.
* *
* @return LayoutStyle implementing the Java look and feel design * @return LayoutStyle implementing the Java look and feel design
* guidelines * guidelines
......
...@@ -48,10 +48,12 @@ public class DefaultLayoutStyle extends LayoutStyle { ...@@ -48,10 +48,12 @@ public class DefaultLayoutStyle extends LayoutStyle {
@Override @Override
public int getPreferredGap(JComponent component1, JComponent component2, public int getPreferredGap(JComponent component1, JComponent component2,
ComponentPlacement type, int position, Container parent) { ComponentPlacement type, int position, Container parent) {
if (component1 == null || component2 == null || type == null) { if (component1 == null || component2 == null || type == null) {
throw new NullPointerException(); throw new NullPointerException();
} }
checkPosition(position);
if (type == ComponentPlacement.INDENT && if (type == ComponentPlacement.INDENT &&
(position == SwingConstants.EAST || (position == SwingConstants.EAST ||
position == SwingConstants.WEST)) { position == SwingConstants.WEST)) {
......
/*
* Copyright (c) 2011, Oracle and/or its affiliates. All rights reserved.
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
*
* This code is free software; you can redistribute it and/or modify it
* under the terms of the GNU General Public License version 2 only, as
* published by the Free Software Foundation.
*
* This code is distributed in the hope that it will be useful, but WITHOUT
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
* version 2 for more details (a copy is included in the LICENSE file that
* accompanied this code).
*
* You should have received a copy of the GNU General Public License version
* 2 along with this work; if not, write to the Free Software Foundation,
* Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
*
* Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
* or visit www.oracle.com if you need additional information or have any
* questions.
*/
import sun.awt.SunToolkit;
import java.awt.Button;
import java.awt.CardLayout;
import java.awt.Font;
import java.awt.Frame;
import java.awt.Menu;
import java.awt.MenuBar;
import java.awt.Point;
import java.awt.Robot;
import java.awt.Toolkit;
import java.awt.event.ActionEvent;
import java.awt.event.ActionListener;
import java.awt.event.InputEvent;
/**
* @test
* @bug 6263470
* @summary Tries to change font of MenuBar. Test passes if the font has changed
* fails otherwise.
* @author Vyacheslav.Baranov: area=menu
* @run main MenuBarSetFont
*/
public final class MenuBarSetFont {
private static final Frame frame = new Frame();
private static final MenuBar mb = new MenuBar();
private static volatile boolean clicked;
private static final class Listener implements ActionListener {
@Override
public void actionPerformed(final ActionEvent e) {
//Click on this button is performed
//_only_ if font of MenuBar is not changed on time
MenuBarSetFont.clicked = true;
}
}
private static void addMenu() {
mb.add(new Menu("w"));
frame.validate();
}
public static void main(final String[] args) throws Exception {
//Components initialization.
frame.setMenuBar(mb);
mb.setFont(new Font("Helvetica", Font.ITALIC, 5));
final Button button = new Button("Click Me");
button.addActionListener(new Listener());
frame.setLayout(new CardLayout());
frame.add(button, "First");
frame.setSize(400, 400);
frame.setVisible(true);
sleep();
final int fInsets = frame.getInsets().top; //Frame insets without menu.
addMenu();
final int fMenuInsets = frame.getInsets().top; //Frame insets with menu.
final int menuBarHeight = fMenuInsets - fInsets;
// There is no way to change menubar height on windows. But on windows
// we can try to split menubar in 2 rows.
for (int i = 0; i < 100 && fMenuInsets == frame.getInsets().top; ++i) {
// Fill whole menubar.
addMenu();
}
mb.remove(0);
frame.validate();
sleep();
// Test execution.
// On XToolkit, menubar font should be changed to 60.
// On WToolkit, menubar font should be changed to default and menubar
// should be splitted in 2 rows.
mb.setFont(new Font("Helvetica", Font.ITALIC, 60));
sleep();
final Robot r = new Robot();
r.setAutoDelay(200);
final Point pt = frame.getLocation();
r.mouseMove(pt.x + frame.getWidth() / 2,
pt.y + fMenuInsets + menuBarHeight / 2);
r.mousePress(InputEvent.BUTTON1_MASK);
r.mouseRelease(InputEvent.BUTTON1_MASK);
sleep();
frame.dispose();
if (clicked) {
fail("Font was not changed");
}
}
private static void sleep() {
((SunToolkit) Toolkit.getDefaultToolkit()).realSync();
try {
Thread.sleep(500L);
} catch (InterruptedException ignored) {
}
}
private static void fail(final String message) {
throw new RuntimeException(message);
}
}
/*
* Copyright (c) 2011, Oracle and/or its affiliates. All rights reserved.
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
*
* This code is free software; you can redistribute it and/or modify it
* under the terms of the GNU General Public License version 2 only, as
* published by the Free Software Foundation.
*
* This code is distributed in the hope that it will be useful, but WITHOUT
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
* version 2 for more details (a copy is included in the LICENSE file that
* accompanied this code).
*
* You should have received a copy of the GNU General Public License version
* 2 along with this work; if not, write to the Free Software Foundation,
* Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
*
* Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
* or visit www.oracle.com if you need additional information or have any
* questions.
*/
/*
* @test
* @bug 7071166
* @summary LayoutStyle.getPreferredGap() - IAE is expected but not thrown
* @author Pavel Porvatov
*/
import javax.swing.*;
import static javax.swing.SwingConstants.*;
import java.awt.*;
public class bug7071166 {
private static final int[] POSITIONS = {NORTH, EAST, SOUTH, WEST, // valid positions
NORTH_EAST, SOUTH_EAST, SOUTH_WEST, NORTH_WEST, 123, -456}; // invalid positions
public static void main(String[] args) throws Exception {
for (UIManager.LookAndFeelInfo lookAndFeelInfo : UIManager.getInstalledLookAndFeels()) {
UIManager.setLookAndFeel(lookAndFeelInfo.getClassName());
System.out.println("LookAndFeel: " + lookAndFeelInfo.getName());
SwingUtilities.invokeAndWait(new Runnable() {
public void run() {
LayoutStyle layoutStyle = LayoutStyle.getInstance();
System.out.println("LayoutStyle: " + layoutStyle);
for (int i = 0; i < POSITIONS.length; i++) {
int position = POSITIONS[i];
try {
layoutStyle.getPreferredGap(new JButton(), new JButton(),
LayoutStyle.ComponentPlacement.RELATED, position, new Container());
if (i > 3) {
throw new RuntimeException("IllegalArgumentException is not thrown for position " +
position);
}
} catch (IllegalArgumentException e) {
if (i <= 3) {
throw new RuntimeException("IllegalArgumentException is thrown for position " +
position);
}
}
}
}
});
System.out.println("passed");
}
}
}
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册