我尝试使用Thread.sleep()
,但它没有用。当我使用它时,应用程序停止响应。
我需要在代码中加入一些延迟:
public void inicioJogo(){
for (int jogada = 1; jogada <= 50; jogada++) {
for (int contador = 0; contador < jogada; contador++){
// HERE - Wait 1 sec before go to next line.
btPedra[sequencia[contador]].setBackgroundResource(imagensHover[sequencia[contador]]);
// HERE - Wait 1 sec before go to next line.
btPedra[sequencia[contador]].setBackgroundResource(imagensNormal[sequencia[contador]]);
// Now continue looping.
}
}
}
我尝试使用Handler,就像这样:
private Handler handler = new Handler();
for (int jogada = 1; jogada <= 50; jogada++) {
for (int contador = 0; contador < jogada; contador++){
handler.postDelayed(new Runnable () {
@Override
public void run() {
btPedra[sequencia[contador]].setBackgroundResource(imagensHover[sequencia[contador]]);
}
}, 1000);
}
}
但是当我使用它时,循环在等待1秒之前继续。我需要一个可以停止循环1秒的延迟,转到下一行,然后继续循环。
答案 0 :(得分:1)
您可以使用ScheduledExecutorService
之类的
ScheduledExecutorService scheduledExecutorService =
Executors.newScheduledThreadPool(NO_OF_THREADS);
ScheduledFuture scheduledFuture =
scheduledExecutorService.schedule(task, NO_OF_SECONDS_TO_WAIT, TimeUnit.SECONDS);
现在&#34;任务&#34;在NO_OF_SECONDS_TO_WAIT延迟
之后执行答案 1 :(得分:0)
它没有响应的原因是因为你在当前线程上调用了sleep。你正在处理的当前线程是UI线程。所以基本上你试着改变背景然后睡觉线程,防止它实际被改变,直到睡眠完成。
你需要在另一个线程中运行你的循环并在那里睡觉,这样它就不会影响主线程:
final Handler handler = new Handler();
new Thread(new Runnable() {
@Override
public void run() {
for (int jogada = 1; jogada <= 50; jogada++) {
for (int contador = 0; contador < jogada; contador++){
try {
Thread.sleep(1000);
} catch (InterruptedException e) {
e.printStackTrace();
}
handler.post(new Runnable() {
@Override
public void run() {
btPedra[sequencia[contador]].setBackgroundResource(imagensHover[sequencia[contador]]);
}
});
}
}
}
}).start();
请注意,后台更改是通过您在启动新线程之前创建的处理程序完成的。该处理程序是在当前线程上创建的,该线程是UI线程,发布到它的每条消息都将在该线程上运行。
所以基本上你循环并等待另一个线程,但在UI线程上进行背景更改。