У меня есть код, который импортирует изображение мозга, я хотел бы знать, как можно использовать третью ось, то есть ось z (дальняя и ближняя оси), чтобы я мог расположить изображение вверх (нелицом к пользователю), так что контур изображения виден.
import java.awt.*;
import java.awt.event.*;
import javax.swing.*;
import java.awt.geom.*;
import java.applet.*;
import java.net.URL;
public class Brain extends JComponent {
static int x = 200;
static int y = 200;
static int currentAngle = 0;
static double hspeed, vspeed;
static int speed = 0;
double hangle, vangle;
Image brain;
Image getImage(String filename) {
URL url = getClass().getResource(filename);
ImageIcon icon = new ImageIcon(url);
return icon.getImage();
}
public Brain() {
brain = getImage("brainz.png");
}
public void CreateBase() {
JFrame frame = new JFrame("BRAIN");
frame.setBounds(70, 30, 650, 500);
frame.setVisible(true);
frame.setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE);
Container c = frame.getContentPane();
c.add(new Brain());
frame.addKeyListener(new adapter());
c.setBackground(Color.BLACK);
}
public void rotate() {
currentAngle += 1;
if (currentAngle >= 360) {
currentAngle = 0;
}
repaint();
}
public void paint(Graphics g) {
super.paint(g);
Graphics2D g2d = (Graphics2D) g;
AffineTransform origXform = g2d.getTransform();
AffineTransform newXform = (AffineTransform) (origXform.clone());
newXform.rotate(Math.toRadians(currentAngle), x, y);
g2d.setTransform(newXform);
g2d.drawImage(brain, x, y, this);
g2d.setTransform(origXform);
repaint();
}
class adapter extends KeyAdapter {
public void keyPressed(KeyEvent e) {
switch (e.getKeyCode()) {
case KeyEvent.VK_LEFT:
currentAngle--;
repaint();
break;
case KeyEvent.VK_RIGHT:
currentAngle++;
repaint();
break;
case KeyEvent.VK_UP:
speed++;
hangle = Math.toRadians(currentAngle);
vangle = Math.toRadians(currentAngle);
hspeed = ((double) speed) * Math.cos(hangle);
vspeed = ((double) speed) * Math.sin(vangle);
x = x - (int) hspeed;
y = y - (int) vspeed;
repaint();
break;
case KeyEvent.VK_DOWN:
speed--;
hangle = Math.toRadians(currentAngle);
vangle = Math.toRadians(currentAngle);
hspeed = ((double) speed) * Math.cos(hangle);
vspeed = ((double) speed) * Math.sin(vangle);
x = x + (int) hspeed;
y = y + (int) vspeed;
repaint();
break;
}
}
}
public static void main(String[] args) {
Brain br = new Brain();
br.CreateBase();
//br.setDoubleBuffered(true);
}
}