Остановить Runnable
В моем предыдущем вопросе " Сделайте метод кнопки", если кнопка нажата или не нажата, я нашел свой ответ следующим образом:
Handler visibilityToggler;
Runnable visivilityRunnable;
visibilityToggler = new Handler();
visivilityRunnable = new Runnable() {
@Override
public void run() {
// isUserClickedButton is used to keep record if user has pressed button within 1 sec
// keep isUserClickedButton = true for first time as it will run
if (!isUserClickedButton) {
// user not pressed button
Toast.makeText(context,"You are not pressed the Button",Toast.LENGHT_LONG).show();
}
// toggle visibility
Random generator = new Random();
number = generator.nextInt(16);
for (int i = 0; i < buttons.length; i++) {
if (i == number)
buttons[i].setVisibility(View.VISIBLE);
else
buttons[i].setVisibility(View.INVISIBLE);
}
// again start the visibility
visibilityToggler.postDelayed(visivilityRunnable,1000);
// make it false as visibility is toggled and we want to track button pressed from start
isUserClickedButton = false;
}
};
visibilityToggler.postDelayed(visivilityRunnable,1000);
Теперь мой вопрос: как остановить Runnable?
Может кто-нибудь может дать пример кода?
ОБНОВИТЬ:
я должен был использовать removecallbacks() на кнопке
public void onClick(View v){
visibilityToggler.removeCallbacks(visivilityRunnable);
}
а бегать не остановить, кто-нибудь может помочь?
2 ответа
Решение
Я не уверен, хотите ли вы разорвать цикл, но если я вас понимаю, я бы предложил вам сделать статическую логическую переменную и остановить ее всякий раз, когда вы захотите
public static boolean isWorking=true;
for (int i = 0; i < buttons.length; i++) {
if(isWork){
if (i == number)
buttons[i].setVisibility(View.VISIBLE);
else
buttons[i].setVisibility(View.INVISIBLE);
}else break;}
Теперь, если вы хотите разорвать петлю, просто измените isWork
ложно
Определите runnable вне обработчика. Тогда позвони handler.removeCallbacks(visivilityRunnable);
где вы хотите остановить обработчик.