gpt4 book ai didi

java - 不能使无法通行 'wall'

转载 作者:行者123 更新时间:2023-11-29 03:34:46 26 4
gpt4 key购买 nike

我有一个基本程序,您可以在其中使用箭头键绕圆圈移动。我正在努力使球(蓝色矩形)无法进入某个区域,但它不起作用。我正在使用 Eclipse。

package TLOT;
import java.awt.BorderLayout;
import javax.swing.JFrame;
import javax.swing.JPanel;
import javax.swing.JLabel;
import javax.swing.Timer;
import java.awt.*;
import java.awt.event.ActionListener;
import java.awt.event.ActionEvent;
import java.awt.event.KeyEvent;
import java.awt.event.KeyListener;

public class Movement extends JPanel implements ActionListener, KeyListener
{
Timer tm = new Timer(5,this);
int x = 0, velX = 0;
int y = 0, velY = 0;

public Movement()
{
tm.start();
addKeyListener(this);
setFocusable(true);
setFocusTraversalKeysEnabled(false);

}

public void actionPerformed(ActionEvent e)
{
if (x < 0){
velX = 0;
x = 0;
}
if (x > 633){
velX = 0;
x = 533;
}
if (y < 0){
velY = 0;
y = 0;
}
if (y > 410){
velY = 0;
y = 310;
}
//this is that part thats supposed to make it stop if it hits a certain point.
if (50 < x && x < 100 && y > 50 && y > 100){
velX = 0; //700 , 500
velY = 0;
}

x = x + velX;
y = y + velY;
repaint();
}

public void keyPressed(KeyEvent e){
int c = e.getKeyCode();
if (c == KeyEvent.VK_LEFT || c == KeyEvent.VK_A){
velX = -1;
velY = 0;
}
if (c == KeyEvent.VK_UP || c == KeyEvent.VK_W){
velX = 0;
velY = -1;
}
if (c == KeyEvent.VK_RIGHT || c == KeyEvent.VK_D){
velX = 1;
velY = 0;
}
if (c == KeyEvent.VK_DOWN || c == KeyEvent.VK_S){
velX = 0;
velY = 1;
}
}

public void keyTyped(KeyEvent e){}
public void keyReleased(KeyEvent e){
velX = 0;
velY = 0;
}

public void paintComponent(Graphics g){
super.paintComponent(g);
g.setColor(Color.red);
g.fillOval(x, y, 50, 50);
g.setColor(Color.blue);
g.fillRect(320, 200, 40, 60);
tm.start();
}


public static void main(String[] args) {
Movement q = new Movement();
JFrame jf = new JFrame();
jf.setTitle("Movement Test");
jf.setSize(700,500);
jf.setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE);
jf.add(q);
jf.setVisible(true);
}

}

最佳答案

这可能是问题所在:

y > 50 && y > 100

当然应该

y > 50 && y < 100

这就是单元测试、调试器、桌面检查等都存在的原因——程序员的大脑与计算机的接口(interface)存在错误且不准确;)

此外,最好检查添加 velX 和 velY 是否会将您嵌入墙中,而不是您是否已经嵌入墙中。否则,您会在第一次介入时陷入困境:

50 < (x+velX) && (x+velX) < 100 && (y+velY) > 50 && (y+velY) < 100

更好的行为是迈出更小的一步,这样你就完全靠墙了。执行此操作的方法包括进行几何交集计算(圆/矩形、圆/圆、矩形/矩形、多边形/多边形...),或者尝试在二进制搜索中越来越小的步长,直到足够接近为止。

关于java - 不能使无法通行 'wall',我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/16158663/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com