6

我打算制作一个 ContentPanel 为 600x600 的 JFrame,并且我希望 JFrame 不能重新调整大小。在这个盒子里,我画了一个 600x600 的红色轮廓矩形,以确保在我运行程序时一切都匹配。在限制 JFrame 的大小调整之前,我通过执行以下操作来设置 JFrame 的大小:

getContentPane().setPreferredSize( new Dimension(600,600));
pack();

当我启动程序时,我的矩形边界与 JFrame 的尺寸完美契合。但是,当我将 isResizable(false) 添加到等式中时,矩形的右边缘和矩形的底边缘之间似乎存在像素缓冲区。通过一些试验和错误,似乎 isResizable(false) 在高度和宽度上增加了 10 个像素。(因此 contentPane 的尺寸为 590x590 + 额外的 10 是我的解决方法)

我的问题 为什么会这样?我似乎在任何地方都找不到关于额外 10 像素的任何文档?

注意:通过在不修改大小的情况下制作 JFrame 也观察到此异常。如果不使其不可调整大小,则没有可观察的面板/内容窗格,但是当使用 isResizable(false) 时,面板/窗格的可见部分。

4

1 回答 1

6

你是对的,将一个框架设置为 un-resiable 似乎确实为其高度和宽度增加了 10 个像素,至于为什么,我不能说,这似乎是更新本机对等体的副作用,但是......

JFrame#pack您可以在调用后通过调用重置它JFrame#setResizable

public class TestResizableFrame {

    public static void main(String[] args) {
        new TestResizableFrame();
    }

    public TestResizableFrame() {
        EventQueue.invokeLater(new Runnable() {
            @Override
            public void run() {
                try {
                    UIManager.setLookAndFeel(UIManager.getSystemLookAndFeelClassName());
                } catch (ClassNotFoundException | InstantiationException | IllegalAccessException | UnsupportedLookAndFeelException ex) {
                }

                JFrame frame = new JFrame();
                frame.setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE);
                frame.setLayout(new BorderLayout());
                frame.add(new FixedPane());
                frame.setResizable(false);
                frame.pack();
                frame.setLocationRelativeTo(null);
                frame.setVisible(true);
            }
        });
    }

    public class FixedPane extends JPanel {

        @Override
        public Dimension getPreferredSize() {
            return new Dimension(200, 200);
        }

        @Override
        protected void paintComponent(Graphics g) {
            super.paintComponent(g);
            Dimension size = getSize();
            String text = size.width + "x" + size.height;
            FontMetrics fm = g.getFontMetrics();
            int x = (getWidth()- fm.stringWidth(text)) / 2;
            int y = ((getHeight() - fm.getHeight()) / 2) + fm.getAscent();
            g.drawString(text, x, y);
            g.setColor(Color.RED);
            g.drawRect(0, 0, getWidth() - 1, getHeight() - 1);
        }

    }

}
于 2012-11-22T06:35:15.620 回答