Java でチェッカー ゲームを開発していますが、問題に遭遇しました。私が作成しようとしているのは、チェッカーピースが押されると、その前にある利用可能な 2 つのスポットが 2 秒間灰色に変わることです。
灰色に変えるのは簡単ですが、Thread.sleep(2000) を使用して 2 秒後に元に戻したい場合、実際にスリープする前に、このスイッチで残りのケースを最初に実行することに気付きました (したがって、新しい灰色の正方形に変わります)すぐに黒に戻ります)
何が悪かったのか?前もって感謝します!
switch (bord[ypos][xpos]) {
case 0:
break;
case 1:
break;
case 2:
if (bord[ypos + 1][xpos - 1] == 1) {
bord[ypos + 1][xpos - 1] = 4;
}
if (bord[ypos + 1][xpos + 1] == 1) {
bord[ypos + 1][xpos + 1] = 4;
}
repaint();
try {
Thread.sleep(2000);
} catch (InterruptedException e) {
}
if (bord[ypos + 1][xpos - 1] == 4) {
bord[ypos + 1][xpos - 1] = 1;
}
if (bord[ypos + 1][xpos + 1] == 4) {
bord[ypos + 1][xpos + 1] = 1;
}
break;
case 3:
break;
}
タイマーで試してみます(私はこれらに慣れていないので、手のひらを強く握りすぎないでください)
/*
* To change this template, choose Tools | Templates
* and open the template in the editor.
*/
package dammen;
import java.awt.Color;
import java.awt.Dimension;
import java.awt.Graphics;
import java.awt.event.ActionEvent;
import java.awt.event.ActionListener;
import java.awt.event.MouseEvent;
import java.awt.event.MouseListener;
import java.util.logging.Level;
import java.util.logging.Logger;
import javax.swing.JPanel;
import javax.swing.Timer;
/**
*
* @author Boyen
*/
public class Board extends JPanel implements MouseListener {
boolean test;
boolean black = false;
boolean redpiece = false;
boolean bluepiece = true;
Timer timer;
private int[][] bord = {{0, 2, 0, 2, 0, 2, 0, 2},
{2, 0, 2, 0, 2, 0, 2, 0},
{0, 2, 0, 2, 0, 2, 0, 2},
{1, 0, 1, 0, 1, 0, 1, 0},
{0, 1, 0, 1, 0, 1, 0, 1},
{3, 0, 3, 0, 3, 0, 3, 0},
{0, 3, 0, 3, 0, 3, 0, 3},
{3, 0, 3, 0, 3, 0, 3, 0}};
public Board(Dammen parent) {
addMouseListener(this);
timer = new Timer(100,taskPerformer);
timer.setRepeats(false);
}
public void start() {
}
public void paint(Graphics g) {
super.paint(g);
Dimension size = getSize();
for (int i = 0; i < 8; i++) {
for (int j = 0; j < 8; j++) {
switch (bord[i][j]) {
case 0:
g.setColor(Color.WHITE);
break;
case 1:
g.setColor(Color.BLACK);
break;
case 2:
g.setColor(Color.RED);
break;
case 3:
g.setColor(Color.BLUE);
break;
case 4:
g.setColor(Color.gray);
break;
}
g.fillRect((size.width / 8) * j, (size.height / 8) * i, size.width / 8, size.height / 8);
}
}
}
int mouseX, mouseY;
@Override
public void mouseClicked(MouseEvent e) {
mouseX = e.getX();
mouseY = e.getY();
zoekmogelijkespots(mouseX, mouseY);
}
ActionListener taskPerformer = new ActionListener() {
@Override
public void actionPerformed(ActionEvent e) {
}
};
public void zoekmogelijkespots(int mouseX, int mouseY) {
Dimension size = getSize();
System.out.println(mouseX + "," + mouseY);
int xpos;
int ypos;
xpos = (int) (mouseX / (size.width / 8));
ypos = (int) (mouseY / (size.height / 8));
System.out.println(ypos + "," + xpos);
System.out.println(bord[ypos][xpos]);
switch (bord[ypos][xpos]) {
case 0:
break;
case 1:
break;
case 2:
if (bord[ypos + 1][xpos - 1] == 1) {
bord[ypos + 1][xpos - 1] = 4;
}
if (bord[ypos + 1][xpos + 1] == 1) {
bord[ypos + 1][xpos + 1] = 4;
}
repaint();
timer.start();
if (bord[ypos + 1][xpos - 1] == 4) {
bord[ypos + 1][xpos - 1] = 1;
}
if (bord[ypos + 1][xpos + 1] == 4) {
bord[ypos + 1][xpos + 1] = 1;
}
break;
case 3:
break;
}
}
@Override
public void mousePressed(MouseEvent e) {
}
@Override
public void mouseReleased(MouseEvent e) {
}
@Override
public void mouseEntered(MouseEvent e) {
}
@Override
public void mouseExited(MouseEvent e) {
}
}