Ответ 1
Заменить
mHandler.postAtTime(this, 1000);
с
mHandler.postDelayed(this, 1000);
Я посмотрел на каждое обсуждение и поток, который я могу найти, чтобы заставить это работать, но это не так. У меня есть простой таймер, который обновляет текстовое представление (mTimeTextField в примере ниже). Метод запуска mUpdateTimeTask выполняется правильно (каждую секунду), но поле UI/text не обновляется.
У меня есть код, основанный на информации, найденной здесь:
http://android-developers.blogspot.com/2007/11/stitch-in-time.html http://developer.android.com/resources/articles/timed-ui-updates.html
Вот код:
package com.something.handlertest;
import com.something.handlertest.R;
import android.app.Activity;
import android.content.Intent;
import android.os.Bundle;
import android.os.Handler;
import android.os.SystemClock;
import android.view.View;
import android.widget.Button;
import android.widget.TextView;
public class Test extends Activity {
private Handler mHandler = new Handler();
private int labelNo = 0;
private long currTime = 0L;
private long mStartTime = 0L;
TextView mTimeTextField;
/** Called when the activity is first created. */
@Override
public void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.main);
mTimeTextField = (TextView)findViewById(R.id.timeTextFieldl);
Button startButton = (Button)findViewById(R.id.start_button);
startButton.setOnClickListener(new View.OnClickListener() {
public void onClick(View v) {
if (mStartTime == 0L) {
mStartTime = System.currentTimeMillis();
mHandler.removeCallbacks(mUpdateTimeTask);
mHandler.postDelayed(mUpdateTimeTask, 100);
}
}
});
}
private Runnable mUpdateTimeTask = new Runnable() {
public void run() {
final long start = mStartTime;
//long millis = SystemClock.uptimeMillis() - start;
long millis = SystemClock.uptimeMillis();
int seconds = (int) (millis / 1000);
int minutes = seconds / 60;
seconds = seconds % 60;
//setContentView(mTimeTextField); This will blow up if I use it
if (seconds < 10) {
mTimeTextField.setText("" + minutes + ":0" + seconds);
} else {
mTimeTextField.setText("" + minutes + ":" + seconds);
}
//mHandler.postAtTime(this,
// start + (((minutes * 60) + seconds + 1) * 1000));
mHandler.postAtTime(this, 1000);
}
};
}
В некоторых предложениях я попытался добавить:
setContentView(mTimeLabel);
Но это приведет к сбою жалобы на представление, не имеющее родителя. FYI, у меня есть:
setContentView(R.layout.main);
вызовите мой onCreate()
.
Заменить
mHandler.postAtTime(this, 1000);
с
mHandler.postDelayed(this, 1000);
Это может быть больше в соответствии с тем, что вы ищете:
private Runnable mUpdateTimeTask = new Runnable() {
public void run() {
final long start = mStartTime;
long elapseTime = System.currentTimeMillis() - start;
int seconds = (int) (elapseTime / 1000);
int minutes = seconds / 60;
seconds = seconds % 60;
if (seconds < 10) {
mTimeTextField.setText("" + minutes + ":0" + seconds);
} else {
mTimeTextField.setText("" + minutes + ":" + seconds);
}
// add a delay to adjust for computation time
long delay = (1000 - (elapseTime%1000));
mHandler.postDelayed(this, delay);
}
};
Я нашел, что это хороший способ добавить время к видео
вид может отображаться только в потоке пользовательского интерфейса. вам нужно запустить runnable, используя ru
Пожалуйста, убедитесь, что R.id.timeTextFieldl - правильный идентификатор.
if (seconds < 10) {
mTimeTextField.setText("" + minutes + ":0" + seconds);
} else {
mTimeTextField.setText("" + minutes + ":" + seconds);
}
короче:
mTimeTextField.setText(minutes + ":" + (seconds < 10 ? "0" : "") + seconds);
но лучший способ - использовать String.format ^
mTimeTextField.setText(String.format("%d:%s%d", minutes, (seconds < 10 ? "0" : ""), seconds);