Android音乐播放-MediaPlayer

简介:

当你坐公交无聊的时候,当你淹没在地铁中人潮中的时候,你是否想内心保持一份的安静呢,那么请带上耳机,打开你的音乐播放器,听一首老歌带你进入宁静的世界,音乐播放这个功能在智能手机出现之前,诺基亚时代,甚至追溯到最开始的大哥大的时候都是属于音频的范畴。Android中播放音频不可避免的使用的一个类是Mediaplayer,视频调用也是这个类。扯远了,开始正题吧:

基础维护

首先这个时候来看看要实现的效果吧:

 

 

布局如下:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
<LinearLayout xmlns:android= "http://schemas.android.com/apk/res/android"
     xmlns:tools= "http://schemas.android.com/tools"
     android:layout_width= "match_parent"
     android:layout_height= "match_parent"
     android:orientation= "vertical"
     tools:context= "com.example.googlemedia.MainActivity"  >
 
     <EditText
         android:id= "@+id/edit_musicPath"
         android:layout_width= "match_parent"
         android:layout_height= "wrap_content"
         android:hint= "输入你喜欢歌曲的路径"  />
 
     <LinearLayout
         android:layout_width= "match_parent"
         android:layout_height= "wrap_content"
         android:orientation= "horizontal"  >
 
         <Button
             android:id= "@+id/btn_Play"
             android:layout_width= "wrap_content"
             android:layout_height= "wrap_content"
             android:onClick= "playEvent"
             android:text= "播放"  />
 
         <Button
             android:id= "@+id/btn_Pause"
             android:layout_width= "wrap_content"
             android:layout_height= "wrap_content"
             android:onClick= "pauseEvent"
             android:text= "暂停"  />
 
         <Button
             android:id= "@+id/btn_Stop"
             android:layout_width= "wrap_content"
             android:layout_height= "wrap_content"
             android:onClick= "stopEvent"
             android:text= "停止"  />
 
         <Button
             android:id= "@+id/btn_Replay"
             android:layout_width= "wrap_content"
             android:layout_height= "wrap_content"
             android:onClick= "replayEvent"
             android:text= "重播"  />
     </LinearLayout>
 
</LinearLayout>

Demo完成

音频文件:

 

播放按钮事件:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
public   void  playEvent(View view){
      editText=(EditText) findViewById(R.id.edit_musicPath);
      String pathString=editText.getText().toString().trim();
      File file= new  File(pathString);
      if  (file.exists()) {
          try  {
              mediaPlayer =  new  MediaPlayer();
              mediaPlayer.setAudioStreamType(AudioManager.STREAM_MUSIC);
              mediaPlayer.setDataSource(pathString);
              mediaPlayer.prepare();
              mediaPlayer.start();
              //多次点击播放按钮容易混音
              btn_PlayButton.setEnabled( false );
              //播放完之后需要回调的时候设置显示
              mediaPlayer.setOnCompletionListener( new  OnCompletionListener() {
                
                @Override
                public  void  onCompletion(MediaPlayer mp) {
                    // TODO Auto-generated method stub
                      btn_PlayButton.setEnabled( true );
                }
            });
        catch  (IllegalArgumentException e) {
            // TODO Auto-generated catch block
            e.printStackTrace();
        catch  (SecurityException e) {
            // TODO Auto-generated catch block
            e.printStackTrace();
        catch  (IllegalStateException e) {
            // TODO Auto-generated catch block
            e.printStackTrace();
        catch  (IOException e) {
            // TODO Auto-generated catch block
            e.printStackTrace();
        }
    } else  {
        Toast.makeText( this "Sorry,你输入的路径有问题,请仔细检查" ,Toast.LENGTH_SHORT).show();
    }
}

 播放效果:

暂停和继续事件:

1
2
3
4
5
6
7
8
9
10
11
public   void   pauseEvent(View view){
     if  ( btn_PauseButton.getText().equals( "继续" )) {
        mediaPlayer.start();
         btn_PauseButton.setText( "暂停" );
        return ;
    }
     if  (mediaPlayer!= null &&mediaPlayer.isPlaying()) {
         mediaPlayer.pause();
         btn_PauseButton.setText( "继续" );
    }
}

暂停和继续效果:

停止事件:

1
2
3
4
5
6
7
8
9
10
11
public   void  stopEvent(View view){
      if  (mediaPlayer!= null &&mediaPlayer.isPlaying()) {
          btn_PlayButton.setEnabled( true );
          mediaPlayer.stop();
          //释放mediaplayer否则的话会占用内存
          mediaPlayer.release();
          mediaPlayer= null ;
     }
      btn_PauseButton.setText( "暂停" );
      btn_PlayButton.setEnabled( true );
  }

 重播事件:

1
2
3
4
5
6
7
8
9
public   void   replayEvent(View view){
     if  (mediaPlayer!= null &&mediaPlayer.isPlaying()) {
         mediaPlayer.seekTo( 0 );
    } else  {
        playEvent(view);
    }
     //重播的时候应该设置播放的状态
     btn_PlayButton.setEnabled( true );
}

  稍微简单的写了写,如果有不当之处,请大家多多指教~

本文转自Fly_Elephant博客园博客,原文链接:http://www.cnblogs.com/xiaofeixiang/p/4088637.html,如需转载请自行联系原作者

相关文章
|
4天前
|
存储 缓存 Android开发
安卓Jetpack Compose+Kotlin, 使用ExoPlayer播放多个【远程url】音频,搭配Okhttp库进行下载和缓存,播放完随机播放下一首
这是一个Kotlin项目,使用Jetpack Compose和ExoPlayer框架开发Android应用,功能是播放远程URL音频列表。应用会检查本地缓存,如果文件存在且大小与远程文件一致则使用缓存,否则下载文件并播放。播放完成后或遇到异常,会随机播放下一首音频,并在播放前随机设置播放速度(0.9到1.2倍速)。代码包括ViewModel,负责音频管理和播放逻辑,以及UI层,包含播放和停止按钮。
|
9月前
|
编解码 Android开发 数据安全/隐私保护
Android平台外部编码数据(H264/H265/AAC/PCMA/PCMU)实时预览播放技术实现
好多开发者可能疑惑,外部数据实时预览播放,到底有什么用? 是的,一般场景是用不到的,我们在开发这块前几年已经开发了非常稳定的RTMP、RTSP直播播放模块,不过也遇到这样的场景,部分设备输出编码后(视频:H.264/H.265,音频:AAC/PCMA/PCMU)的数据,比如无人机或部分智能硬件设备,回调出来的H.264/H.265数据,除了想转推到RTMP、轻量级RTSP服务或GB28181外,还需要本地预览甚至对数据做二次处理(视频分析、实时水印字符叠加等,然后二次编码),基于这样的场景诉求,我们开发了Android平台外部编码数据实时预览播放模块。
104 0
|
1月前
|
XML Java Android开发
Android Studio App开发中使用录音机、MediaRecorder录制音频和MediaPlayer播放音频讲解及实战(附源码)
Android Studio App开发中使用录音机、MediaRecorder录制音频和MediaPlayer播放音频讲解及实战(附源码)
130 0
|
4天前
|
存储 数据库 Android开发
安卓Jetpack Compose+Kotlin,支持从本地添加音频文件到播放列表,支持删除,使用ExoPlayer播放音乐
为了在UI界面添加用于添加和删除本地音乐文件的按钮,以及相关的播放功能,你需要实现以下几个步骤: 1. **集成用户选择本地音乐**:允许用户从设备中选择音乐文件。 2. **创建UI按钮**:在界面中创建添加和删除按钮。 3. **数据库功能**:使用Room数据库来存储音频文件信息。 4. **更新ViewModel**:处理添加、删除和播放音频文件的逻辑。 5. **UI实现**:在UI层支持添加、删除音乐以及播放功能。
|
4天前
|
存储 Android开发 Kotlin
Kotlin开发安卓app,在使用 MediaPlayer 播放 res/raw 中的音乐时遇到突然中断的问题,而 onErrorListener 没有接收到任何报错
在使用 Android MediaPlayer 播放 res/raw 中的音乐时遇到中断问题,可能的原因包括资源问题、媒体文件编码格式、生命周期管理和设备资源配置。要排查问题,检查音频文件是否正确包含,格式编码是否支持,MediaPlayer 是否正确管理及释放,以及设备是否有足够存储和配置。通过设置 onErrorListener 日志和确保在 onDestroy 中释放资源来调试。如果文件过大,考虑使用 AssetManager。遵循这些步骤可帮助诊断并解决播放中断的问题。
|
4天前
|
Android开发 Kotlin
安卓Jetpack Compose+Kotlin, 使用ExoPlayer播放多个【本地】音频,播放完随机播放下一首,遇到播放错误,也自动播放下一首
使用Kotlin和Jetpack Compose开发的安卓应用中,实现了两个EvoPlayer同时播放res/raw目录下的音频。一个音轨播放人声(顺序播放),另一个播放背景音乐(随机播放)。每个音轨都有独立的播放和停止控制,且在播放结束或遇到错误时会自动切换到下一首。MediaPlayer置于ViewModel中,UI界面包含播放和停止按钮,控制两个音轨。每次切换音频前,还会随机调整播放速度在0.9到1.2之间。代码示例展示了如何创建ViewModel和UI以实现这一功能。
|
4天前
|
缓存 Android开发 Kotlin
【安卓app开发】kotlin Jetpack Compose框架 | 先用OKhttp下载远程音频文件再使用ExoPlayer播放
使用 Kotlin 的 Jetpack Compose 开发安卓应用时,可以结合 OkHttp 下载远程音频文件和 ExoPlayer 进行播放。在 `build.gradle` 添加相关依赖后,示例代码展示了如何下载音频并用 ExoPlayer 播放。代码包括添加依赖、下载文件、播放文件及简单的 Compose UI。注意,示例未包含完整错误处理和资源释放,实际应用需补充这些内容。
|
5天前
|
存储 Android开发 Kotlin
开发安卓app OKhttp下载后使用MediaPlayer播放
在Android Jetpack Compose应用程序中,要使用OkHttp下载远程音频文件并在本地播放,你需要完成以下几个步骤: 1. **添加依赖**:确保`build.gradle`文件包含OkHttp和Jetpack Compose的相关依赖。 2. **下载逻辑**:创建一个`suspend`函数,使用OkHttp发起网络请求下载音频文件到本地。 3. **播放逻辑**:利用`MediaPlayer`管理音频播放状态。 4. **Compose UI**:构建用户界面,包含下载和播放音频的按钮。
|
5天前
|
存储 Android开发
安卓app,MediaPlayer播放本地音频 | 按钮控制播放和停止
在Jetpack Compose中,不直接操作原生Android组件如`Button`和`MediaPlayer`,而是使用Compose UI构建器定义界面并结合ViewModel管理音频播放逻辑。以下示例展示如何播放本地音频并用按钮控制播放/停止:创建一个`AudioPlayerViewModel`管理`MediaPlayer`实例和播放状态,然后在Compose UI中使用`Button`根据`isPlaying`状态控制播放。记得在`MainActivity`设置Compose UI,并处理相关依赖和权限。
|
13天前
|
API Android开发 UED
56. 【Android教程】媒体播放器:MediaPlayer
56. 【Android教程】媒体播放器:MediaPlayer
18 0