Java Swing呈现问题(空格和双倍呈现)
我在使用Java Swing的JFrame/JPanel时遇到了一点呈现问题。 我想在自己身上渲染一条线,所以我已经创建了一个方法来使用Graphics g渲染很多点,并且它工作得非常好(在我的第二台显示器上)。 现在我正在使用我的笔记本电脑主显示器,我收到了一些该死的东西: Rendering Issue
它应该只是一条连续的线,但是它有这些令人讨厌的小缺口,而且它显示了两次……这不会发生在我的另一个(更大的)显示器上,但我想不应该是这样的(它只与一些显示器一起工作)。所以代码没问题(我想),我的监视器也是…你能帮我吗? 感谢回答各位:)
CODE ON PASTEBIN:
https://pastebin.com/kBVSjpCA
https://pastebin.com/svuhSXGw
https://pastebin.com/ftga7v2L
https://pastebin.com/fHtYj35G
https://pastebin.com/zA0N1LqE
解决方案
Oracle有一个很棒的教程Creating a GUI With Swing。跳过NetBeans部分。本教程中介绍自定义绘图的部分是Performing Custom Painting。
这是我为前面的一个问题匆忙准备的一个秋千绘图示例。
一般思路是创建一个JFrame
并创建一个单独的绘图JPanel
。绘图JPanel
将扩展JPanel
并重写paintComponent
方法。
paintComponent
方法的第一行必须是对super
paintComponent
方法的调用。之后,您可以使用所需的任何Graphics
或Graphics2D
方法。
以下是完整的可运行代码。
import java.awt.Dimension;
import java.awt.Graphics;
import javax.swing.JFrame;
import javax.swing.JPanel;
import javax.swing.SwingUtilities;
public class DrawingPanelExample implements Runnable {
public static void main(String[] args) {
SwingUtilities.invokeLater(new DrawingPanelExample());
}
@Override
public void run() {
JFrame frame = new JFrame("My Empty Window");
frame.setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE);
DrawingPanel panel = new DrawingPanel();
frame.add(panel);
frame.pack();
frame.setLocationByPlatform(true);
frame.setVisible(true);
}
public class DrawingPanel extends JPanel {
private static final long serialVersionUID = 1L;
public DrawingPanel() {
this.setPreferredSize(new Dimension(350, 300));
}
@Override
protected void paintComponent(Graphics pen) {
super.paintComponent(pen);
pen.drawRect(50, 50, 20, 20);
pen.drawRect(100, 50, 40, 20);
pen.drawOval(200, 50, 20, 20);
pen.drawOval(250, 50, 40, 20);
pen.drawString("Square", 50, 90);
pen.drawString("Rectangle", 100, 90);
pen.drawString("Circle", 200, 90);
pen.drawString("Oval", 250, 90);
pen.fillRect(50, 100, 20, 20);
pen.fillRect(100, 100, 40, 20);
pen.fillOval(200, 100, 20, 20);
pen.fillOval(250, 100, 40, 20);
pen.drawLine(50, 150, 300, 150);
pen.drawArc(50, 150, 200, 100, 0, 180);
pen.fillArc(100, 175, 200, 75, 90, 45);
}
}
}
相关文章