I have an app that does MIDI file playback using android media player. I made a textview as a timer that will change dynamically based on the playback progress. However, it is very buggy as it became stuck at 2s mark
class progressTrack extends AsyncTask<String,Void,String>{
@Override
protected String doInBackground(String... arg0) {
ToggleButton mStartStop;
int currentPosition=0;
int total=mediaPlayer.getDuration();
TextView timer=(TextView) findViewById(R.id.timer);
while (mediaPlayer != null && currentPosition < total) {
try {
Thread.sleep(1000);
currentPosition = mediaPlayer
.getCurrentPosition();
double seconds=currentPosition/1000;
int time= (int) Math.round(seconds);
String timeS=Integer.toString(time);
Log.d("Time",timeS);
timer.setText(timeS+"s");
fSlider.setProgress(currentPosition);
} catch (InterruptedException e) {
} catch (Exception e) {
}
OnSeekBarChangeListener listener = new OnSeekBarChangeListener() {
public void onStopTrackingTouch(SeekBar seekBar) { }
public void onStartTrackingTouch(SeekBar seekBar) { }
public void onProgressChanged(SeekBar seekBar,
int progress,
boolean fromUser) {
if(fromUser)
mediaPlayer.seekTo(progress);
}
};
fSlider.setOnSeekBarChangeListener(listener);
}
The time does display correctly on Logcat but why won't it change on the textview?
SOLVED:
protected void onPostExecute(String result) {
ScheduledExecutorService myScheduledExecutorService = Executors.newScheduledThreadPool(1);
myScheduledExecutorService.scheduleWithFixedDelay(
new Runnable(){
@Override
public void run() {
monitorHandler.sendMessage(monitorHandler.obtainMessage());
}},
200, //initialDelay
200,
TimeUnit.MILLISECONDS//delay TimeUnit.MILLISECONDS
);
}
}
Handler monitorHandler = new Handler(){
@Override
public void handleMessage(Message msg) {
startUI();
}
};
void startUI(){
Log.d("UI", "Started player UI");
ToggleButton mStartStop;
int currentPosition=0;
int total=mediaPlayer.getDuration();
TextView timer=(TextView) findViewById(R.id.timer);
if(mediaPlayer.isPlaying())
try {
currentPosition = mediaPlayer
.getCurrentPosition();
double seconds=currentPosition/1000;
int time= (int) Math.round(seconds);
String timeS=Integer.toString(time);
timer.setText(timeS+"s");
Log.d("position",timeS);
fSlider.setProgress(currentPosition);
} catch (Exception e) {
}
OnSeekBarChangeListener listener = new OnSeekBarChangeListener() {
public void onStopTrackingTouch(SeekBar seekBar) { }
public void onStartTrackingTouch(SeekBar seekBar) { }
public void onProgressChanged(SeekBar seekBar,
int progress,
boolean fromUser) {
if(fromUser)
mediaPlayer.seekTo(progress);
}
};
fSlider.setOnSeekBarChangeListener(listener);
mStartStop= (ToggleButton) findViewById(R.id.toggleButton1);
mStartStop.setOnCheckedChangeListener(pauseListener);
}
You need to do this in a separate thread and post back to the GUI thread via runOnUiThread with a runnable to set text of your timer. As you are presumably setting the text of a GUI component without exception I assume you are not doing this as of now.
Please post the complete method. With the complete method we can help track down why it stops at the 2 second mark.