Руководство Android MediaPlayer
1. MediaPlayer
Android предоставляет компонент для воспроизведения аудио, это MediaPlayer. MediaPlayer может воспроизводить аудио и видео, с файлами имеющимися на вашем устройстве или из URL.
Похоже на другие аудиопроигрыватели, которые вы знаете, MediaPlayer предоставляет методы упрвления звуков (control playback of audio/video) включая старт, пауза, перемотка вперед назад,..
Похоже на другие аудиопроигрыватели, которые вы знаете, MediaPlayer предоставляет методы упрвления звуков (control playback of audio/video) включая старт, пауза, перемотка вперед назад,..
Вы так же можете вызвать MediaPlayer из сервиса.
MediaPlayer это компонент не имеющий интерфейс, помогающий вам легко проигрывать музыкальные файлы, но для воспроизведения видео файла вам нужно его скомбинировать с SuffaceView чтобы появились изображения.
MediaPlayer это компонент не имеющий интерфейс, помогающий вам легко проигрывать музыкальные файлы, но для воспроизведения видео файла вам нужно его скомбинировать с SuffaceView чтобы появились изображения.
2. Пример проигрывания музыки с MediaPlayer
Далее простой пример, используем MediaPlayer чтобы воспроизвести файл музыки и некоторые кнопки контроля как старт, остановить, пауза, перемотка вперед и назад.
Создать новый project с названием MediaPlayerTutorial:
- File > New > New Project > Empty Activity
- Name: MediaPlayerTutorial
- Package name: org.o7planning.mediaplayertutorial
- Language: Java
Создать папку raw чтобы содержать музыкальные файлы.
Приготовить музыкальный файл, копировать и вставить в папку raw.
If you want to play a song from a URL you must allow the application to access the network, adding the following XML code to AndroidManifest.xml.
<uses-permission android:name="android.permission.INTERNET" />
Разрешить приложению получить доступ к внешнему хранилищу (external storage) (Например SD Card), если вы хотите воспроизводить мультимедиа здесь.
<uses-permission android:name="android.permission.READ_EXTERNAL_STORAGE"/>
AndroidManifest.xml
<?xml version="1.0" encoding="utf-8"?>
<manifest xmlns:android="http://schemas.android.com/apk/res/android"
package="org.o7planning.mediaplayertutorial">
<uses-permission android:name="android.permission.INTERNET" />
<uses-permission android:name="android.permission.READ_EXTERNAL_STORAGE"/>
<application
android:allowBackup="true"
android:icon="@mipmap/ic_launcher"
android:label="@string/app_name"
android:roundIcon="@mipmap/ic_launcher_round"
android:supportsRtl="true"
android:theme="@style/AppTheme">
<activity android:name=".MainActivity">
<intent-filter>
<action android:name="android.intent.action.MAIN" />
<category android:name="android.intent.category.LAUNCHER" />
</intent-filter>
</activity>
</application>
</manifest>
Дизайн интерфейса:
Если вас интересуют шаги дизайна интерфейса данного приложения, смотрите приложение в конце статьи.
activity_main.xml
<?xml version="1.0" encoding="utf-8"?>
<androidx.constraintlayout.widget.ConstraintLayout
xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:app="http://schemas.android.com/apk/res-auto"
xmlns:tools="http://schemas.android.com/tools"
android:layout_width="match_parent"
android:layout_height="match_parent"
tools:context=".MainActivity">
<SeekBar
android:id="@+id/seekBar"
android:layout_width="0dp"
android:layout_height="37dp"
android:layout_marginStart="16dp"
android:layout_marginLeft="16dp"
android:layout_marginTop="25dp"
android:layout_marginEnd="16dp"
android:layout_marginRight="16dp"
app:layout_constraintEnd_toEndOf="parent"
app:layout_constraintStart_toStartOf="parent"
app:layout_constraintTop_toTopOf="parent" />
<TextView
android:id="@+id/textView_maxTime"
android:layout_width="0dp"
android:layout_height="24dp"
android:layout_marginStart="16dp"
android:layout_marginLeft="16dp"
android:layout_marginTop="39dp"
android:layout_marginEnd="16dp"
android:layout_marginRight="16dp"
android:gravity="center"
android:text="Max Time"
app:layout_constraintEnd_toEndOf="parent"
app:layout_constraintStart_toStartOf="parent"
app:layout_constraintTop_toBottomOf="@+id/seekBar" />
<TextView
android:id="@+id/textView_currentPosition"
android:layout_width="0dp"
android:layout_height="25dp"
android:layout_marginStart="16dp"
android:layout_marginLeft="16dp"
android:layout_marginTop="38dp"
android:layout_marginEnd="16dp"
android:layout_marginRight="16dp"
android:gravity="center"
android:text="Current Possion"
app:layout_constraintEnd_toEndOf="parent"
app:layout_constraintStart_toStartOf="parent"
app:layout_constraintTop_toBottomOf="@+id/textView_maxTime" />
<LinearLayout
android:id="@+id/linearLayout"
android:layout_width="0dp"
android:layout_height="wrap_content"
android:layout_marginStart="16dp"
android:layout_marginLeft="16dp"
android:layout_marginTop="24dp"
android:layout_marginEnd="16dp"
android:layout_marginRight="16dp"
android:orientation="horizontal"
app:layout_constraintEnd_toEndOf="parent"
app:layout_constraintStart_toStartOf="parent"
app:layout_constraintTop_toBottomOf="@+id/textView_currentPosition">
<Space
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_weight="1" />
<Button
android:id="@+id/button_rewind"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_weight="0"
android:text="<<" />
<Button
android:id="@+id/button_start"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_weight="0"
android:text="Start" />
<Button
android:id="@+id/button_pause"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_weight="0"
android:text="Pause" />
<Button
android:id="@+id/button_fastForward"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_weight="0"
android:text=">>" />
<Space
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_weight="1" />
</LinearLayout>
<Button
android:id="@+id/button_select"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_marginTop="51dp"
android:text="Select a Song"
app:layout_constraintEnd_toEndOf="parent"
app:layout_constraintStart_toStartOf="parent"
app:layout_constraintTop_toBottomOf="@+id/linearLayout" />
</androidx.constraintlayout.widget.ConstraintLayout>
MainActivity.java
package org.o7planning.mediaplayertutorial;
import androidx.appcompat.app.AppCompatActivity;
import android.media.AudioManager;
import android.os.Bundle;
import android.media.MediaPlayer;
import android.os.Handler;
import android.view.View;
import android.widget.Button;
import android.widget.SeekBar;
import android.widget.TextView;
import java.util.concurrent.TimeUnit;
public class MainActivity extends AppCompatActivity {
private TextView textMaxTime;
private TextView textCurrentPosition;
private Button buttonPause;
private Button buttonStart;
private Button buttonRewind;
private Button buttonFastForward;
private Button buttonSelect;
private SeekBar seekBar;
private Handler threadHandler = new Handler();
private MediaPlayer mediaPlayer;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
this.textCurrentPosition = (TextView)this.findViewById(R.id.textView_currentPosition);
this.textMaxTime=(TextView) this.findViewById(R.id.textView_maxTime);
this.buttonSelect = (Button) this.findViewById(R.id.button_select);
this.buttonStart= (Button) this.findViewById(R.id.button_start);
this.buttonPause= (Button) this.findViewById(R.id.button_pause);
this.buttonRewind= (Button) this.findViewById(R.id.button_rewind);
this.buttonFastForward= (Button) this.findViewById(R.id.button_fastForward);
this.buttonStart.setEnabled(false);
this.buttonPause.setEnabled(false);
this.buttonRewind.setEnabled(false);
this.buttonFastForward.setEnabled(false);
this.seekBar= (SeekBar) this.findViewById(R.id.seekBar);
this.seekBar.setClickable(false);
this.buttonSelect.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View v) {
// Select new media source.
selectMediaResource();
}
});
this.buttonStart.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View v) {
doStart( );
}
});
this.buttonPause.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View v) {
doPause( );
}
});
this.buttonRewind.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View v) {
doRewind( );
}
});
this.buttonFastForward .setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View v) {
doFastForward( );
}
});
// Create MediaPlayer.
this.mediaPlayer= new MediaPlayer();
this.mediaPlayer.setAudioStreamType(AudioManager.STREAM_MUSIC);
this.mediaPlayer.setOnPreparedListener(new MediaPlayer.OnPreparedListener() {
@Override
public void onPrepared(MediaPlayer mp) {
doStop(); // Stop current media.
}
});
this.mediaPlayer.setOnCompletionListener(new MediaPlayer.OnCompletionListener() {
@Override
public void onCompletion(MediaPlayer mp) {
doComplete();
}
});
}
// When user click "Select Media Source" button.
private void selectMediaResource() {
// this.selectRawMediaSource();
// this.selectURLMediaSource();
// this.selectLocalMediaSource();
this.selectRawMediaSource();
}
private void selectRawMediaSource() {
// "mysong.mp3" ==> resName = "mysong".
String resName = MediaPlayerUtils.RAW_MEDIA_SAMPLE;
MediaPlayerUtils.playRawMedia(this, this.mediaPlayer, resName);
}
private void selectURLMediaSource() {
// http://example.coom/mysong.mp3
String mediaURL = MediaPlayerUtils.URL_MEDIA_SAMPLE;
MediaPlayerUtils.playURLMedia(this, this.mediaPlayer, mediaURL);
}
private void selectLocalMediaSource() {
// @localPath = "/storage/emulated/0/DCIM/Music/mysong.mp3"; (For example).
String localPath = MediaPlayerUtils.LOCAL_MEDIA_SAMPLE;
MediaPlayerUtils.playLocalMedia(this, this.mediaPlayer, localPath);
}
// Convert millisecond to string.
private String millisecondsToString(int milliseconds) {
long minutes = TimeUnit.MILLISECONDS.toMinutes((long) milliseconds);
long seconds = TimeUnit.MILLISECONDS.toSeconds((long) milliseconds) ;
return minutes + ":"+ seconds;
}
private void doStart( ) {
if(this.mediaPlayer.isPlaying()) {
return;
}
// The duration in milliseconds
int duration = this.mediaPlayer.getDuration();
int currentPosition = this.mediaPlayer.getCurrentPosition();
if(currentPosition== 0) {
this.seekBar.setMax(duration);
String maxTimeString = this.millisecondsToString(duration);
this.textMaxTime.setText(maxTimeString);
} else if(currentPosition== duration) {
// Resets the MediaPlayer to its uninitialized state.
this.mediaPlayer.reset();
}
this.mediaPlayer.start();
// Create a thread to update position of SeekBar.
UpdateSeekBarThread updateSeekBarThread= new UpdateSeekBarThread();
threadHandler.postDelayed(updateSeekBarThread,50);
this.buttonPause.setEnabled(true);
this.buttonStart.setEnabled(false);
this.buttonRewind.setEnabled(true);
this.buttonFastForward.setEnabled(true);
}
// Called by MediaPlayer.OnCompletionListener
// When Player cocmplete
private void doComplete() {
buttonStart.setEnabled(true);
buttonPause.setEnabled(false);
buttonRewind.setEnabled(true);
buttonFastForward.setEnabled(false);
}
// Called by MediaPlayer.OnPreparedListener.
// When user select a new media source, then stop current.
private void doStop() {
if(this.mediaPlayer.isPlaying()) {
this.mediaPlayer.stop();
}
buttonStart.setEnabled(true);
buttonPause.setEnabled(false);
buttonRewind.setEnabled(false);
buttonFastForward.setEnabled(false);
}
// When user click to "Pause".
private void doPause( ) {
this.mediaPlayer.pause();
this.buttonPause.setEnabled(false);
this.buttonStart.setEnabled(true);
}
// When user click to "Rewind".
private void doRewind( ) {
int currentPosition = this.mediaPlayer.getCurrentPosition();
int duration = this.mediaPlayer.getDuration();
// 5 seconds.
int SUBTRACT_TIME = 5000;
if(currentPosition - SUBTRACT_TIME > 0 ) {
this.mediaPlayer.seekTo(currentPosition - SUBTRACT_TIME);
}
this.buttonFastForward.setEnabled(true);
}
// When user click to "Fast-Forward".
private void doFastForward( ) {
int currentPosition = this.mediaPlayer.getCurrentPosition();
int duration = this.mediaPlayer.getDuration();
// 5 seconds.
int ADD_TIME = 5000;
if(currentPosition + ADD_TIME < duration) {
this.mediaPlayer.seekTo(currentPosition + ADD_TIME);
}
}
// Thread to Update position for SeekBar.
class UpdateSeekBarThread implements Runnable {
public void run() {
int currentPosition = mediaPlayer.getCurrentPosition();
String currentPositionStr = millisecondsToString(currentPosition);
textCurrentPosition.setText(currentPositionStr);
seekBar.setProgress(currentPosition);
// Delay thread 50 milisecond.
threadHandler.postDelayed(this, 50);
}
}
}
MediaPlayerUtils.java
package org.o7planning.mediaplayertutorial;
import android.content.Context;
import android.media.MediaPlayer;
import android.net.Uri;
import android.util.Log;
import android.widget.Toast;
public class MediaPlayerUtils {
// "mysong.mp3" in directory "raw".
public static final String RAW_MEDIA_SAMPLE = "mysong";
// Example Path: /sdcard/Music/mysong.mp3
// Example Path: /storage/emulated/0/DCIM/Music/mysong.mp3
public static final String LOCAL_MEDIA_SAMPLE ="/sdcard/Music/mysong.mp3";
public static final String URL_MEDIA_SAMPLE = "https://ex1.o7planning.com/_testdatas_/yodel.mp3";
public static final String LOG_TAG= "MediaPlayerTutorial";
// Play a media in directory RAW.
// Media name = "mysong.mp3" ==> resName = "mysong".
public static void playRawMedia(Context context, MediaPlayer mediaPlayer, String resName) {
try {
// ID of video file.
int id = MediaPlayerUtils.getRawResIdByName( context,resName);
Uri uri = Uri.parse("android.resource://" + context.getPackageName() + "/" + id);
Log.i(LOG_TAG, "Media URI: "+ uri);
Toast.makeText(context,"Select source: "+ uri,Toast.LENGTH_SHORT).show();
mediaPlayer.setDataSource(context, uri);
mediaPlayer.prepareAsync();
} catch (Exception e) {
Log.e(LOG_TAG, "Error Play Raw Media: "+e.getMessage());
Toast.makeText(context,"Error Play Raw Media: "+ e.getMessage(),Toast.LENGTH_SHORT).show();
e.printStackTrace();
}
}
// Example Path: /sdcard/Music/mysong.mp3
// Example Path: /storage/emulated/0/DCIM/Music/mysong.mp3
public static void playLocalMedia(Context context, MediaPlayer mediaPlayer, String localPath) {
try {
Uri uri = Uri.parse("android.resource://" + localPath);
Log.i(LOG_TAG, "Media URI: "+ uri);
Toast.makeText(context,"Select source: "+ uri,Toast.LENGTH_SHORT).show();
mediaPlayer.setDataSource(context, uri);
mediaPlayer.prepareAsync();
} catch(Exception e) {
Log.e(LOG_TAG, "Error Play Local Media: "+ e.getMessage());
Toast.makeText(context,"Error Play Local Media: "+ e.getMessage(),Toast.LENGTH_SHORT).show();
e.printStackTrace();
}
}
// String videoURL = "https://ex1.o7planning.com/_testdatas_/yodel.mp3";
public static void playURLMedia(Context context, MediaPlayer mediaPlayer, String videoURL) {
try {
Log.i(LOG_TAG, "Media URL: "+ videoURL);
Uri uri= Uri.parse( videoURL );
Toast.makeText(context,"Select source: "+ uri,Toast.LENGTH_SHORT).show();
mediaPlayer.setDataSource(context, uri);
mediaPlayer.prepareAsync();
} catch(Exception e) {
Log.e(LOG_TAG, "Error Play URL Media: "+ e.getMessage());
Toast.makeText(context,"Error Play URL Media: "+ e.getMessage(),Toast.LENGTH_SHORT).show();
e.printStackTrace();
}
}
// Find ID corresponding to the name of the resource (in the directory RAW).
public static int getRawResIdByName(Context context, String resName) {
String pkgName = context.getPackageName();
// Return 0 if not found.
int resID = context.getResources().getIdentifier(resName, "raw", pkgName);
Log.i(LOG_TAG, "Res Name: " + resName + "==> Res ID = " + resID);
return resID;
}
}
Pуководства Android
- Настроить Android Emulator в Android Studio
- Руководство Android ToggleButton
- Создать простой File Finder Dialog в Android
- Руководство Android TimePickerDialog
- Руководство Android DatePickerDialog
- Что мне нужно для начала работы с Android?
- Установите Android Studio в Windows
- Установите Intel® HAXM для Android Studio
- Руководство Android AsyncTask
- Руководство Android AsyncTaskLoader
- Руководство Android для начинающих - основные примеры
- Как узнать номер телефона Android Emulator и изменить его?
- Руководство Android TextInputLayout
- Руководство Android CardView
- Руководство Android ViewPager2
- Получить номер телефона в Android с помощью TelephonyManager
- Руководство Android Phone Call
- Руководство Android Wifi Scanning
- Руководство Android 2D Game для начинающих
- Руководство Android DialogFragment
- Руководство Android CharacterPickerDialog
- Руководство Android для начинающих - Hello Android
- Использование Android Device File Explorer
- Включить USB Debugging на устройстве Android
- Руководство Android UI Layouts
- Руководство Android SMS
- Руководство Android SQLite Database
- Руководство Google Maps Android API
- Руководство Текст в речь на Android
- Руководство Android Space
- Руководство Android Toast
- Создание пользовательских Android Toast
- Руководство Android SnackBar
- Руководство Android TextView
- Руководство Android TextClock
- Руководство Android EditText
- Руководство Android TextWatcher
- Форматирование номера кредитной карты с помощью Android TextWatcher
- Руководство Android Clipboard
- Создать простой File Chooser в Android
- Руководство Android AutoCompleteTextView и MultiAutoCompleteTextView
- Руководство Android ImageView
- Руководство Android ImageSwitcher
- Руководство Android ScrollView и HorizontalScrollView
- Руководство Android WebView
- Руководство Android SeekBar
- Руководство Android Dialog
- Руководство Android AlertDialog
- Руководство Android RatingBar
- Руководство Android ProgressBar
- Руководство Android Spinner
- Руководство Android Button
- Руководство Android Switch
- Руководство Android ImageButton
- Руководство Android FloatingActionButton
- Руководство Android CheckBox
- Руководство Android RadioGroup и RadioButton
- Руководство Android Chip и ChipGroup
- Использование Image assets и Icon assets Android Studio
- Настройка SD Card для Android Emulator
- Пример ChipGroup и Chip Entry
- Как добавить внешние библиотеки в Android Project в Android Studio?
- Как отключить разрешения, уже предоставленные приложению Android?
- Как удалить приложения из Android Emulator?
- Руководство Android LinearLayout
- Руководство Android TableLayout
- Руководство Android FrameLayout
- Руководство Android QuickContactBadge
- Руководство Android StackView
- Руководство Android Camera
- Руководство Android MediaPlayer
- Руководство Android VideoView
- Воспроизведение звуковых эффектов в Android с помощью SoundPool
- Руководство Android Networking
- Руководство Android JSON Parser
- Руководство Android SharedPreferences
- Руководство Android Internal Storage
- Руководство Android External Storage
- Руководство Android Intents
- Пример явного Android Intent, вызов другого Intent
- Пример неявного Android Intent, откройте URL, отправьте email
- Руководство Android Services
- Использовать оповещения в Android - Android Notification
- Руководство Android DatePicker
- Руководство Android TimePicker
- Руководство Android Chronometer
- Руководство Android OptionMenu
- Руководство Android ContextMenu
- Руководство Android PopupMenu
- Руководство Android Fragment
- Руководство Android ListView
- Android ListView с Checkbox с помощью ArrayAdapter
- Руководство Android GridView
Show More