Подтвердить что ты не робот

Как показать MediaController во время воспроизведения аудио в Android?

Как я могу показать MediaController во время воспроизведения аудиофайла? Я создаю экземпляр MediaController и вызывая его метод show(), но он не отображается. Может ли кто-нибудь помочь мне в решении этой проблемы?

4b9b3361

Ответ 1

Вот пример Activity, который использует MediaPlayer и MediaController для воспроизведения звука.

import android.app.Activity;
import android.media.MediaPlayer;
import android.os.Bundle;
import android.os.Handler;
import android.util.Log;

import android.media.MediaPlayer.OnPreparedListener;
import android.view.MotionEvent;
import android.widget.MediaController;
import android.widget.TextView;

import java.io.IOException;

public class AudioPlayer extends Activity implements OnPreparedListener, MediaController.MediaPlayerControl{
  private static final String TAG = "AudioPlayer";

  public static final String AUDIO_FILE_NAME = "audioFileName";

  private MediaPlayer mediaPlayer;
  private MediaController mediaController;
  private String audioFile;

  private Handler handler = new Handler();

  public void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    setContentView(R.layout.audio_player);

    audioFile = this.getIntent().getStringExtra(AUDIO_FILE_NAME);
    ((TextView)findViewById(R.id.now_playing_text)).setText(audioFile);

    mediaPlayer = new MediaPlayer();
    mediaPlayer.setOnPreparedListener(this);

    mediaController = new MediaController(this);

    try {
      mediaPlayer.setDataSource(audioFile);
      mediaPlayer.prepare();
      mediaPlayer.start();
    } catch (IOException e) {
      Log.e(TAG, "Could not open file " + audioFile + " for playback.", e);
    }

  }

  @Override
  protected void onStop() {
    super.onStop();
    mediaController.hide();
    mediaPlayer.stop();
    mediaPlayer.release();
  }

  @Override
  public boolean onTouchEvent(MotionEvent event) {
    //the MediaController will hide after 3 seconds - tap the screen to make it appear again
    mediaController.show();
    return false;
  }

  //--MediaPlayerControl methods----------------------------------------------------
  public void start() {
    mediaPlayer.start();
  }

  public void pause() {
    mediaPlayer.pause();
  }

  public int getDuration() {
    return mediaPlayer.getDuration();
  }

  public int getCurrentPosition() {
    return mediaPlayer.getCurrentPosition();
  }

  public void seekTo(int i) {
    mediaPlayer.seekTo(i);
  }

  public boolean isPlaying() {
    return mediaPlayer.isPlaying();
  }

  public int getBufferPercentage() {
    return 0;
  }

  public boolean canPause() {
    return true;
  }

  public boolean canSeekBackward() {
    return true;
  }

  public boolean canSeekForward() {
    return true;
  }
  //--------------------------------------------------------------------------------

  public void onPrepared(MediaPlayer mediaPlayer) {
    Log.d(TAG, "onPrepared");
    mediaController.setMediaPlayer(this);
    mediaController.setAnchorView(findViewById(R.id.main_audio_view));

    handler.post(new Runnable() {
      public void run() {
        mediaController.setEnabled(true);
        mediaController.show();
      }
    });
  }
}

Вот макет, который можно использовать с приведенным выше кодом:

<?xml version="1.0" encoding="utf-8"?>

<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
              android:id="@+id/main_audio_view"
              android:layout_width="fill_parent"
              android:layout_height="wrap_content"
              android:layout_gravity="center"
              android:orientation="vertical">
  <TextView
    android:layout_width="wrap_content"
    android:layout_height="wrap_content"
    android:layout_gravity="center"
    android:text="Now playing:"
    android:textSize="25sp"
    android:textStyle="bold"
    />
  <TextView
    android:id="@+id/now_playing_text"
    android:layout_width="wrap_content"
    android:layout_height="wrap_content"
    android:layout_marginTop="20dip"
    android:layout_marginLeft="10dip"
    android:layout_marginRight="10dip"
    android:layout_gravity="center"
    android:text="Now playing.."
    android:textSize="16sp"
    android:textStyle="italic"
    />
</LinearLayout>

Ответ 2

Мне до сих пор не хватает репутации для комментариев, поэтому я должен просто опубликовать это как ответ.

@user229487 ответ

вам нужно добавить mediaController.hide(); в метод onStop(). Если вы этого не сделаете, и вам придется вращать окно или закрывать окно, пока оно отображается, вы получите ошибку Activity x has leaked window

Новый метод должен выглядеть так:

@Override
protected void onStop() {
    super.onStop();
    mediaController.hide();
    mediaPlayer.stop();
    mediaPlayer.release();
}

Ответ 3

Я скопировал код выше с user229487 дословно, но не смог заставить его работать. Учитывая, что я новичок в Android-разработчике, я обнаружил, что вам нужно как можно больше умыться, а также несколько других вещей. Я также не совсем понимаю, как намерение будет работать с пользовательским интерфейсом (опять же я новичок), но будет работать над ним.

Немногие вещи для других нубов, подобных мне, чтобы заставить код выше работать (я, по крайней мере, получил его, чтобы он не разбился и не сыграл песню:)):

  • Не будет компилироваться без этого:

    @Override
    public int getAudioSessionId() {
    return 0;
    }

  • Чтобы установить звук вручную: (изменить строку на:)

    public static final String AUDIO_FILE_NAME = Environment.getExternalStorageDirectory()+"/MusicFolder/Song.mp3";

  • Задание настройки
    Добавьте эту строку: this.getIntent().putExtra(AUDIO_FILE_NAME,AUDIO_FILE_NAME);
    Перед этой строкой: audioFile = this.getIntent().getStringExtra(AUDIO_FILE_NAME);

Теперь нужно скомпилировать и воспроизвести песню.

Ответ 4

Мне еще не разрешено комментировать... поэтому я пишу здесь. Вышеприведенный код превосходный. Мне нужно было только вынуть

mediaPlayer.prepare();

бит в try catch, иначе активность сработает. Не уверенный, что этот бит должен делать, он работает очень хорошо без него. Спасибо!!