3

我正在用 Java 构建一个国际象棋游戏,我目前在使用 Swing 完全按照我想要的方式获取 GUI 时遇到了一些麻烦。我正在使用 aGridLayout来组织一个 8x8ChessButton的网格(它覆盖了 ,JButton以便我可以在其中存储额外的信息,例如坐标)。最初,ChessButton除非我将鼠标悬停在它们上,否则 s 不会出现,但我通过将每个按钮ChessButton放在一个单独的内部JPanel并将每个按钮设置setPreferredSize()为设定的高度和宽度来解决这个问题。

现在,我的问题是每个按钮上方(和/或下方?)似乎有一个小的边距或填充。我已经确定为 设置setHgap(0)setVgap(0)GridLayout所以我很确定神秘的边距来自按钮或JPanels。但是,我似乎无法摆脱它们,ChessButton每当我鼠标移动它们时,它们似乎都会导致它们上下移动一点。

我意识到这个问题的描述可能有点难以形象化,所以我截取了一张截图(使用JButtons 而不是ChessButtons 所以差距更容易识别):http: //img3.imageshack.us/img3/ 6656/jbuttonmargins.png

这是我用来初始化每个的代码ChessButton

    chessBoard = new JPanel(new GridLayout(8, 8, 0, 0));
    chessBoard.setBorder(BorderFactory.createEmptyBorder());

    for (int i = 0; i <= 65; i++) {
            //Create a new ChessButton
            ChessButton button = new ChessButton("hi");
            button.setBorder(BorderFactory.createEmptyBorder());
            button.setPreferredSize(new Dimension(75, 75));
            button.setMargin(new Insets(0, 0, 0, 0));

            //Create a new JPanel that the ChessButton will go into
            JPanel buttonPanel = new JPanel();
            buttonPanel.setPreferredSize(new Dimension(75, 75));
            buttonPanel.setBorder(BorderFactory.createEmptyBorder());
            buttonPanel.add(button);

            //Add the buttonPanel to the grid
            chessBoard.add(buttonPanel);
    }

那么,我怎样才能摆脱按钮之间的这些垂直空间呢?我对 Swing 比较陌生,所以如果答案非常明显,我很抱歉,但如果有人提供任何帮助,我将不胜感激!提前致谢!

4

3 回答 3

16

不要添加空边框;使用setBorderPainted(false).

附录:正如@camickr 所指出的,面板的布局可能包括默认间隙。下面的示例相应地使用无间隙GridLayout

替代文字

import java.awt.Color;
import java.awt.Dimension;
import java.awt.EventQueue;
import java.awt.GridLayout;
import javax.swing.JButton;
import javax.swing.JFrame;
import javax.swing.JPanel;

/** @see http://stackoverflow.com/questions/4331699 */
public class ButtonBorder extends JPanel {

    private static final int N = 8;
    private static final int SIZE = 75;

    public ButtonBorder() {
        super(new GridLayout(N, N));
        this.setPreferredSize(new Dimension(N * SIZE, N * SIZE));
        for (int i = 0; i < N * N; i++) {
            this.add(new ChessButton(i));
        }
    }

    private static class ChessButton extends JButton {

        public ChessButton(int i) {
            super(i / N + "," + i % N);
            this.setOpaque(true);
            this.setBorderPainted(false);
            if ((i / N + i % N) % 2 == 1) {
                this.setBackground(Color.gray);
            }
        }
    }

    private void display() {
        JFrame f = new JFrame("ButtonBorder");
        f.setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE);
        f.add(this);
        f.pack();
        f.setLocationRelativeTo(null);
        f.setVisible(true);
    }

    public static void main(String[] args) {
        EventQueue.invokeLater(new Runnable() {

            @Override
            public void run() {
                new ButtonBorder().display();
            }
        });
    }
}
于 2010-12-02T04:59:28.557 回答
3

最初,除非我将鼠标悬停在 ChessButtons 上,否则它们不会出现,但我通过将每个 ChessButton 放置在单独的 JPanel 中并将每个按钮的 setPreferredSize() 设置为设定的高度和宽度来解决了这个问题

这不是正确的解决方案。没有理由使用 JPanel 来按住按钮。事实上,这可能是问题的原因。当您将按钮添加到 GridLayout 时,它们应该会显示出来。如果它们没有显示,可能是因为您在使 GUI 可见后将按钮添加到了 GUI。组件应在其可见之前添加到 GUI。

现在,我的问题是每个按钮上方(和/或下方?)似乎有一个小的边距或填充

我不明白为什么也没有水平间隙。创建 JPanel 时,默认情况下它使用 FlowLayout,其中还包含 5 个像素的水平/垂直间隙。所以我明白为什么你可能有 10 像素的垂直间隙。我不明白为什么没有水平间隙。

如果您需要更多帮助,请发布您的SSCCE 来证明问题。SSCCE 应该使用常规的 JButton。在开始使用自定义组件之前,先了解使用标准组件的基础知识。这样您就知道问题是否出在您的自定义代码上。

于 2010-12-02T05:22:58.257 回答
1

尝试添加 chessBoard.setPreferredSize(600, 600) 为棋盘创建一个 JPanel,该棋盘只有容纳按钮的空间(单向 8 个按钮 * 按钮单向 75 大小)。

于 2010-12-02T04:43:39.140 回答