6721088: Bad window size calculation after using pack()
Reviewed-by: anthony
This commit is contained in:
parent
3247a31478
commit
9ea7492522
@ -32,10 +32,18 @@ class WindowDimensions {
|
|||||||
private Insets insets;
|
private Insets insets;
|
||||||
private boolean isClientSizeSet;
|
private boolean isClientSizeSet;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* If isClient is true, the bounds represent the client window area.
|
||||||
|
* Otherwise, they represent the entire window area, with the insets included
|
||||||
|
*/
|
||||||
public WindowDimensions(int x, int y, int width, int height, boolean isClient) {
|
public WindowDimensions(int x, int y, int width, int height, boolean isClient) {
|
||||||
this(new Rectangle(x, y, width, height), null, isClient);
|
this(new Rectangle(x, y, width, height), null, isClient);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* If isClient is true, the bounds represent the client window area.
|
||||||
|
* Otherwise, they represent the entire window area, with the insets included
|
||||||
|
*/
|
||||||
public WindowDimensions(Rectangle rec, Insets ins, boolean isClient) {
|
public WindowDimensions(Rectangle rec, Insets ins, boolean isClient) {
|
||||||
if (rec == null) {
|
if (rec == null) {
|
||||||
throw new IllegalArgumentException("Client bounds can't be null");
|
throw new IllegalArgumentException("Client bounds can't be null");
|
||||||
@ -46,10 +54,18 @@ class WindowDimensions {
|
|||||||
setInsets(ins);
|
setInsets(ins);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* If isClient is true, the bounds represent the client window area.
|
||||||
|
* Otherwise, they represent the entire window area, with the insets included
|
||||||
|
*/
|
||||||
public WindowDimensions(Point loc, Dimension size, Insets in, boolean isClient) {
|
public WindowDimensions(Point loc, Dimension size, Insets in, boolean isClient) {
|
||||||
this(new Rectangle(loc, size), in, isClient);
|
this(new Rectangle(loc, size), in, isClient);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* If isClient is true, the bounds represent the client window area.
|
||||||
|
* Otherwise, they represent the entire window area, with the insets included
|
||||||
|
*/
|
||||||
public WindowDimensions(Rectangle bounds, boolean isClient) {
|
public WindowDimensions(Rectangle bounds, boolean isClient) {
|
||||||
this(bounds, null, isClient);
|
this(bounds, null, isClient);
|
||||||
}
|
}
|
||||||
|
@ -492,7 +492,14 @@ abstract class XDecoratedPeer extends XWindowPeer {
|
|||||||
// do nothing but accept it.
|
// do nothing but accept it.
|
||||||
Rectangle reqBounds = newDimensions.getBounds();
|
Rectangle reqBounds = newDimensions.getBounds();
|
||||||
Rectangle newBounds = constrainBounds(reqBounds.x, reqBounds.y, reqBounds.width, reqBounds.height);
|
Rectangle newBounds = constrainBounds(reqBounds.x, reqBounds.y, reqBounds.width, reqBounds.height);
|
||||||
newDimensions = new WindowDimensions(newBounds, newDimensions.getInsets(), newDimensions.isClientSizeSet());
|
Insets insets = newDimensions.getInsets();
|
||||||
|
// Inherit isClientSizeSet from newDimensions
|
||||||
|
if (newDimensions.isClientSizeSet()) {
|
||||||
|
newBounds = new Rectangle(newBounds.x, newBounds.y,
|
||||||
|
newBounds.width - insets.left - insets.right,
|
||||||
|
newBounds.height - insets.top - insets.bottom);
|
||||||
|
}
|
||||||
|
newDimensions = new WindowDimensions(newBounds, insets, newDimensions.isClientSizeSet());
|
||||||
}
|
}
|
||||||
XToolkit.awtLock();
|
XToolkit.awtLock();
|
||||||
try {
|
try {
|
||||||
|
67
jdk/test/java/awt/Frame/FrameSize/TestFrameSize.java
Normal file
67
jdk/test/java/awt/Frame/FrameSize/TestFrameSize.java
Normal file
@ -0,0 +1,67 @@
|
|||||||
|
/*
|
||||||
|
* Copyright 2009 Red Hat, Inc. 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.
|
||||||
|
*/
|
||||||
|
|
||||||
|
/*
|
||||||
|
@test
|
||||||
|
@bug 6721088
|
||||||
|
@summary X11 Window sizes should be what we set them to
|
||||||
|
@author Omair Majid <omajid@redhat.com>: area=awt.toplevel
|
||||||
|
@run main TestFrameSize
|
||||||
|
*/
|
||||||
|
|
||||||
|
/**
|
||||||
|
* TestFrameSize.java
|
||||||
|
*
|
||||||
|
* Summary: test that X11 Awt windows are drawn with correct sizes
|
||||||
|
*
|
||||||
|
* Test fails if size of window is wrong
|
||||||
|
*/
|
||||||
|
|
||||||
|
import java.awt.Dimension;
|
||||||
|
import java.awt.Frame;
|
||||||
|
|
||||||
|
public class TestFrameSize {
|
||||||
|
|
||||||
|
static Dimension desiredDimensions = new Dimension(200, 200);
|
||||||
|
static int ERROR_MARGIN = 15;
|
||||||
|
static Frame mainWindow;
|
||||||
|
|
||||||
|
public static void drawGui() {
|
||||||
|
mainWindow = new Frame("");
|
||||||
|
mainWindow.setPreferredSize(desiredDimensions);
|
||||||
|
mainWindow.pack();
|
||||||
|
|
||||||
|
Dimension actualDimensions = mainWindow.getSize();
|
||||||
|
System.out.println("Desired dimensions: " + desiredDimensions.toString());
|
||||||
|
System.out.println("Actual dimensions: " + actualDimensions.toString());
|
||||||
|
if (Math.abs(actualDimensions.height - desiredDimensions.height) > ERROR_MARGIN) {
|
||||||
|
throw new RuntimeException("Incorrect widow size");
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public static void main(String[] args) {
|
||||||
|
try {
|
||||||
|
drawGui();
|
||||||
|
} finally {
|
||||||
|
if (mainWindow != null) {
|
||||||
|
mainWindow.dispose();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
Loading…
x
Reference in New Issue
Block a user