3

对于非描述性标题,我很抱歉,但我不知道如何传达这些问题。对于初学者来说,JButton 不时地按照循环应该创建它们的相同顺序多次创建自己。我遇到的另一个问题是,当我使用 setLocation() 方法重新定位它们时,它会在我想要它们的位置创建新的 JButton,但也会将旧的 JButton 留在它们所在的位置。我不知道我是否只需要刷新图形或发生了什么。谢谢您的帮助。

数组 playerHand() 在 Player 类中定义,长度为 5。

public void paintComponent(java.awt.Graphics g){
    setBackground(Color.GREEN);

    // create a Graphics2D object from the graphics object for drawing shape
    Graphics2D gr=(Graphics2D) g;

    for(int x=0;x<Player.hand.size();x++){
        Card c = Player.hand.get(x);                    //c = current element in array
        c.XCenter = 30 + 140*x;                         
        c.XCord = c.XCenter - 30;
        c.YCord = 0;


        //5 pixel thick pen
        gr.setStroke(new java.awt.BasicStroke(3));            
        gr.setColor(Color.black);                       //sets pen color to black
        gr.drawRect(c.XCord, c.YCord, c.cardWidth-1, c.cardHeight-1);          //draws card outline
        gr.setFont(new Font("Serif", Font.PLAIN, 18));

        gr.drawString(c.name, c.XCord+10, c.YCord+20);

        gr.drawString("Atk: ", c.XCord+10, c.YCord+60);
        gr.drawString(""+c.attack, c.XCord+60, c.YCord+60);

        gr.drawString("Def: ", c.XCord+10, c.YCord+80);
        gr.drawString(""+c.defence, c.XCord+60, c.YCord+80);

        gr.drawString("HP: ", c.XCord+10, c.YCord+100);
        gr.drawString(""+c.health, c.XCord+60, c.YCord+100);

        JButton button = new JButton(c.name);
        button.setSize(c.cardWidth, c.cardHeight);
        //button.setLocation(c.XCord, c.YCord);
        this.add(button);
        repaint();
    }
}   //end of paintComponent
4

1 回答 1

5

您的以下方法存在几个问题(标有“!!!!”注释):

public void paintComponent(java.awt.Graphics g){
    setBackground(Color.GREEN); // !!!!
    Graphics2D gr=(Graphics2D) g;
    for(int x=0;x<Player.hand.size();x++){

        // .... etc ....

        JButton button = new JButton(c.name);  // !!!! yikes !!!!
        button.setSize(c.cardWidth, c.cardHeight);
        //button.setLocation(c.XCord, c.YCord);
        this.add(button);  // !!!! yikes !!!!
        repaint();  // !!!!
    }
}
  • 不要在paintComponent(...). 永远不要这样做。曾经。
  • 此方法应仅用于绘图和绘图,绝不能用于程序逻辑或 GUI 构建。
  • 您无法完全控制何时或是否会调用它。
  • 它需要尽可能快,以免您的程序响应不佳。
  • paintComponent(...)尽可能避免在内部创建对象。
  • 在这种方法中避免文件 I/O(尽管上面的代码没有问题)。
  • 不要调用setBackground(...)这个方法。在构造函数或其他方法中执行此操作。
  • repaint()永远不要从这个方法中调用。
  • 不要忘记paintComponent(g)在覆盖中调用 super 的方法。

要解决您的问题:

对于初学者来说,JButton 不时地按照循环应该创建它们的相同顺序多次创建自己。

这是因为您无法控制调用paintComponent 的时间或频率。JVM 可能会调用它以响应来自操作系统的有关脏区的信息,或者程序可能会请求重绘,但出于这个原因,程序逻辑和 gui 构建不应该在此方法中。

我遇到的另一个问题是,当我使用 setLocation() 方法重新定位它们时,它会在我想要它们的位置创建新的 JButton,但也会将旧的 JButton 留在它们所在的位置。

您很可能会因为没有调用 super 的 paintComponent 方法而看到图像残留。如果不这样做,您就不会让 JPanel 重新绘制自身并删除需要替换或刷新的旧图像像素。

我不知道我是否只需要刷新图形或发生了什么。

不,你需要改变一切。

看起来您必须重新考虑 GUI 的程序流程和逻辑并重新编写一些代码。

于 2013-07-23T19:34:50.617 回答