在JFrame中生成方波

时间:2016-05-24 14:34:46

标签: java swing jframe wave

我的方波代码效率低。我有2个按钮,1个桌子和类似坐标系统的东西。我希望波形实时滚动/移动直到它到达坐标系统的末端而不是仅通过选择两个按钮出现。另外,如果有人有更好的绘制方波的方法,请告诉我。

public void paint(Graphics g) {
    super.paint(g);
    Graphics2D g2d = (Graphics2D) g;
    g2d.drawLine(20, 300, 20, 450);
    g2d.drawLine(20, 350, 400, 350);
    g2d.drawLine(20, 400, 400, 400);
    g2d.drawLine(20, 450, 400, 450);

    if (this.jButtonSTART.isSelected() & this.jButtonAND.isSelected()) {
            this.draw(g2d);
        }
}

public void draw(Graphics2D g2d) {
    boolean up = true;
    while (x <= 380) {
        g2d.setColor(Color.blue);
        if (x > 0 && x % 95 == 0) {
            up = !up;
            g2d.drawLine(20 + x, up ? 315 : 350 + y, 20 + x, up ? 350 : 315 + y);
        } else {
            if (up) {
                g2d.drawLine(20 + x, 315 + y, 21 + x, y + 315);
            } else {
                g2d.drawLine(20 + x, 350 + y, 21 + x, y + 350);
            }
        }
        x++;
    }
    x = 0;
}

1 个答案:

答案 0 :(得分:0)

绘制方波并移动它的简单方法:

  1. 创建一个比GUI更长的BufferedImage。它的长度应该与方波的周期相匹配,并且至少是它显示的GUI组件的两倍。
  2. 在paintAonent方法中覆盖JPanel,而不是绘制方法。
  3. 首先在覆盖中调用super的paintComponent方法。
  4. 您将使用g.drawImage(myImage, imageX, imageY, this)绘制图像,其中imageX和imageY是JPanel扩展绘图类的私有实例字段。
  5. 在Swing Timer中,使用Timer的每个tick来提前imageX,即每次调用其ActionListener的actionPerformed方法时。
  6. 然后在同一actionPerformed方法中的绘图JPanel上调用repaint()
  7. 完成。
  8. 例如,请注意,此代码并不完全符合您的要求,但确实使用Swing Timer和paintComponent显示了Swing动画的示例。

    import java.awt.Color;
    import java.awt.Dimension;
    import java.awt.GradientPaint;
    import java.awt.Graphics;
    import java.awt.Graphics2D;
    import java.awt.RenderingHints;
    import java.awt.event.ActionEvent;
    import java.awt.event.ActionListener;
    import java.awt.image.BufferedImage;
    import javax.swing.*;
    
    @SuppressWarnings("serial")
    public class MoveWave extends JPanel {
        private static final int PREF_W = 400;
        private static final int PREF_H = 200;
        private static final int TIMER_DELAY = 40;
        public static final int DELTA_X = 2;
        public static final int STARTING_MY_IMAGE_X = -PREF_W;
        private static final Color COLOR_1 = Color.RED;
        private static final Color COLOR_2 = Color.BLUE;
        private static final Color BG = Color.BLACK;
        private static final int CIRCLE_COUNT = 10;
        private BufferedImage myImage = null;
        private int myImageX = STARTING_MY_IMAGE_X;
        private int myImageY = 0;
    
        public MoveWave() {
            setBackground(BG);
            myImage = new BufferedImage(2 * PREF_W, PREF_H, BufferedImage.TYPE_INT_ARGB);
            Graphics2D g2 = myImage.createGraphics();
            g2.setRenderingHint(RenderingHints.KEY_ANTIALIASING, RenderingHints.VALUE_ANTIALIAS_ON);
            g2.setPaint(new GradientPaint(0, 0, COLOR_1, 20, 20, COLOR_2, true));
            for (int i = 0; i < CIRCLE_COUNT; i++) {
                int x = (i * 2 * PREF_W) / CIRCLE_COUNT;
                int y = PREF_H / 4;
                int width = (2 * PREF_W) / CIRCLE_COUNT;
                int height = PREF_H / 2;
                g2.fillOval(x, y, width, height);
            }
            g2.dispose();
            new Timer(TIMER_DELAY, new TimerListener()).start();
        }
    
        @Override
        protected void paintComponent(Graphics g) {
            super.paintComponent(g);
            if (myImage != null) {
                g.drawImage(myImage, myImageX, myImageY, this);
            }
        }
        @Override
        public Dimension getPreferredSize() {
            if (isPreferredSizeSet()) {
                return super.getPreferredSize();
            }
            return new Dimension(PREF_W, PREF_H);
        }
    
        private class TimerListener implements ActionListener {
            @Override
            public void actionPerformed(ActionEvent e) {
                myImageX += DELTA_X;
                if (myImageX >= 0) {
                    myImageX = STARTING_MY_IMAGE_X;                        
                }
                repaint();
            }
        }
    
        private static void createAndShowGui() {
            JFrame frame = new JFrame("MoveWave");
            frame.setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE);
            frame.getContentPane().add(new MoveWave());
            frame.setResizable(false);
            frame.pack();
            frame.setLocationRelativeTo(null);
            frame.setVisible(true);
        }
    
        public static void main(String[] args) {
            SwingUtilities.invokeLater(() -> createAndShowGui());
        }
    }