心形曲线java简易表示法
import java.awt.Color;
import java.awt.Graphics;
import java.awt.Image;
import java.awt.Toolkit;
import javax.swing.JFrame;
@SuppressWarnings("serial")
public class Demo extends JFrame implements Runnable {
public static final int GAME_WIDTH = 500;
public static final int GAME_HEIGHT = 500;
public static final int WIDTH = Toolkit.getDefaultToolkit()
.getScreenSize().width;
public static final int HEIGHT = Toolkit.getDefaultToolkit()
.getScreenSize().height;
public Demo() {
this.setTitle("心形曲线");
this.setLocation((WIDTH - GAME_WIDTH) / 2, (HEIGHT - GAME_HEIGHT) / 2);
this.setSize(GAME_WIDTH, GAME_HEIGHT);
this.setBackground(Color.BLACK);
this.setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE);
this.setVisible(true);
}
@Override
public void paint(Graphics g) {
double x, y, r;
Image OffScreen = createImage(GAME_WIDTH, GAME_HEIGHT);
Graphics drawOffScreen = OffScreen.getGraphics();
for (int i = 0; i < 90; i++) {
for (int j = 0; j < 90; j++) {
r = Math.PI / 45 * i * (1 - Math.sin(Math.PI / 45 * j)) * 18;
x = r * Math.cos(Math.PI / 45 * j) * Math.sin(Math.PI / 45 * i)
+ GAME_WIDTH / 2;
y = -r * Math.sin(Math.PI / 45 * j) + GAME_HEIGHT / 4;
drawOffScreen.setColor(Color.PINK);
drawOffScreen.fillOval((int) x, (int) y, 2, 2);
}
g.drawImage(OffScreen, 0, 0, this);
}
}
public static void main(String[] args) {
Demo demo = new Demo();
Thread t = new Thread(demo);
t.start();
}
@Override
public void run() {
while (true) {
try {
Thread.sleep(2000);
this.repaint();
} catch (InterruptedException e) {
e.printStackTrace();
}
}
}
}
效果图
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)