为什么这个打印行命令执行两次?

时间:2011-03-05 15:08:19

标签: java graphics queue

我有以下代码。

一切正常,但令人讨厌的是,while循环中的print line命令运行了两次。有(我已经测试过),队列中只有唯一的项目,没有重复项。

public void paint(Graphics g) {

    boolean isParent;

    int drawCount = 1;

    int x = 0, y = 0, width = 0, height = 0;
    Color colour;

    while (!qtreeQueue.empty()) {

        drawNode = (QuadTreeNode) qtreeQueue.deque();
        isParent = drawNode.getIsParent();

        if (!isParent) {
            x = drawNode.getRectangle().x;
            y = drawNode.getRectangle().y;
            width = drawNode.getRectangle().width;
            height = drawNode.getRectangle().height;
            colour = getRectangleColour(drawNode);
            System.out.println(drawCount + ". Drawing: x = " + x + "; y = " + y + 
                    "; width = " + width + "; height = " + height + 
                    "; colour = " + colour.toString());
            minMax(drawNode);
            g.setColor(colour);
            g.fillRect(x, y, width, height);
            drawCount++;
        }
    }
    System.out.println("Minimum level of tree: " + min + "\nMaximum level: " + max);
}

感谢帮助。

1 个答案:

答案 0 :(得分:6)

这意味着paint方法被调用两次,这是完全正常的。系统可以根据需要多次调用paint,因此您不应执行任何可能会改变该方法中程序状态的操作。