Search code examples
javaandroidmedia-playerplayback

Android Buggy Media Playback Timer


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);

 }

Solution

  • 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.