Intereting Posts
Ошибка TextView при настройке текста Как выполнить синхронизацию данных между устройствами в Интернете и офлайн с помощью Google App Engine? Как исправить URL-адрес поставщика контента, который не найден в поставщике контента Android? Android: как включить / отключить Wi-Fi или подключение к Интернету программно Как создать статический (только с использованием xml-файла) ExpandableListView на Android Proguard и ошибка Разделить панель действий только в режиме действия (CAB) Как эффективно использовать статические переменные? Не удается получить карту с помощью Google Maps V2 MapView Как установить изображения для ScrollView вместо затухающих ребер? Android резервное копирование и восстановление базы данных с SD-карты и обратно Круговая голосовая анимация в Android Обезьяна Android вызывает исключение уведомления об адаптере в файле android.widget.HeaderViewListAdapter Прослушивание ключевых слов во все времена, например «Ok google» на 4.4 Функциональность панели инструментов панели инструментов

Android Thread для таймера

public class MainActivity extends Activity { int min, sec; /** Called when the activity is first created. */ @Override public void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.main); min = 5; sec = 0; final TextView timer1 = (TextView) findViewById(R.id.timer1); timer1.setText(min + ":" + sec); Thread t = new Thread() { public void run() { sec-=1; if (sec<0) { min-=1; sec=59; } timer1.setText(min + ":" + sec); try { sleep(1000); } catch (InterruptedException e) {} } }; t.start(); } } 

Это код для Thread на Java, но он не работает. Вы можете мне помочь?

Его таймер, который отсчитывает от 5 минут до 0:00.

В вашем случае вы используете потоки. Таким образом, вы не можете обновлять ui из потока, отличного от нити ui. runOnUithread вы используете runOnUithread . Я предлагаю вам использовать таймер обратного отсчета или обработчик.

1.CountDownTimer

http://developer.android.com/reference/android/os/CountDownTimer.html

Вот ссылка на другой пример. Предложите вам проверить ссылку на таймер обратного отсчета.

Countdowntimer в минутах и ​​секундах

Пример:

  public class MainActivity extends Activity { Button b; TextView tv; @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_main); tv = (TextView) findViewById(R.id.textView1); b= (Button) findViewById(R.id.button1); b.setOnClickListener(new OnClickListener() { @Override public void onClick(View v) { // TODO Auto-generated method stub startTimer(200000); } }); } private void startTimer(long time){ CountDownTimer counter = new CountDownTimer(30000, 1000){ public void onTick(long millisUntilDone){ Log.d("counter_label", "Counter text should be changed"); tv.setText("You have " + millisUntilDone + "ms"); } public void onFinish() { tv.setText("DONE!"); } }.start(); } } 

2.Вы можете использовать Handler

Пример :

 Handler m_handler; Runnable m_handlerTask ; int timeleft=100; m_handler = new Handler(); m_handlerTask = new Runnable() { @Override public void run() { if(timeleft>=0) { // do stuff Log.i("timeleft",""+timeleft); timeleft--; } else { m_handler.removeCallbacks(m_handlerTask); // cancel run } m_handler.postDelayed(m_handlerTask, 1000); } }; m_handlerTask.run(); 

3.Timer

Таймер работает в другом потоке. Вы должны обновить ui в потоке ui. Использовать runOnUiThread

Пример :

  int timeleft=100; Timer _t = new Timer(); _t.scheduleAtFixedRate( new TimerTask() { @Override public void run() { runOnUiThread(new Runnable() //run on ui thread { public void run() { Log.i("timeleft",""+timeleft); //update ui } }); if(timeleft>==0) { timeleft--; } else { _t.cancel(); } } }, 1000, 1000 ); 

Вы пытаетесь обновить UI Thread из фонового Thread с помощью

 timer1.setText( 

Которую вы не можете сделать. Вам нужно использовать runOnUiThread() , AsyncTask , CountDownTimer или что-то подобное.

См. Этот ответ для примера runOnUiThread()

Но CountDownTimer хорош для таких вещей.

Кроме того, при публикации вопроса о SO заявления типа «это не работает». Очень расплывчаты и часто бесполезны. Просьба указать ожидаемые результаты по сравнению с фактическими результатами вашего кода и logcat, если приложение рушится.