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,如需转载请自行联系原作者

相关文章
|
5月前
|
存储 缓存 Android开发
安卓Jetpack Compose+Kotlin, 使用ExoPlayer播放多个【远程url】音频,搭配Okhttp库进行下载和缓存,播放完随机播放下一首
这是一个Kotlin项目,使用Jetpack Compose和ExoPlayer框架开发Android应用,功能是播放远程URL音频列表。应用会检查本地缓存,如果文件存在且大小与远程文件一致则使用缓存,否则下载文件并播放。播放完成后或遇到异常,会随机播放下一首音频,并在播放前随机设置播放速度(0.9到1.2倍速)。代码包括ViewModel,负责音频管理和播放逻辑,以及UI层,包含播放和停止按钮。
|
5月前
|
存储 数据库 Android开发
安卓Jetpack Compose+Kotlin,支持从本地添加音频文件到播放列表,支持删除,使用ExoPlayer播放音乐
为了在UI界面添加用于添加和删除本地音乐文件的按钮,以及相关的播放功能,你需要实现以下几个步骤: 1. **集成用户选择本地音乐**:允许用户从设备中选择音乐文件。 2. **创建UI按钮**:在界面中创建添加和删除按钮。 3. **数据库功能**:使用Room数据库来存储音频文件信息。 4. **更新ViewModel**:处理添加、删除和播放音频文件的逻辑。 5. **UI实现**:在UI层支持添加、删除音乐以及播放功能。
|
5月前
|
XML 存储 数据库
如何使用Android Studio创建一个基本的音乐播放器应用
如何使用Android Studio创建一个基本的音乐播放器应用
224 0
|
3月前
|
Android开发
Android 利用MediaPlayer实现音乐播放
本文提供了一个简单的Android MediaPlayer音乐播放示例,包括创建PlayerActivity、配置AndroidManifest.xml和activity_player.xml布局,以及实现播放和暂停功能的代码。
26 0
Android 利用MediaPlayer实现音乐播放
|
3月前
|
编解码 网络协议 开发工具
Android平台如何实现多路低延迟RTSP|RTMP播放?
本文档详细介绍了大牛直播SDK在Android平台上实现RTSP与RTMP流媒体播放及录像功能的技术细节。早在2015年,SDK的第一版就已经支持了多实例播放,并且通过简单的实例封装就能轻松实现。文档中提供了代码示例,展示了如何开启播放、停止播放以及开始和停止录像等功能。此外,SDK还提供了丰富的配置选项,例如设置录像目录、文件大小限制、转码选项等。总结部分列出了该SDK的关键特性,包括但不限于高稳定性和低延迟的播放能力、多实例支持、事件回调、硬解码支持、网络状态监控以及复杂的网络环境处理等。这些功能使得SDK能够应对各种应用场景,特别是在对延迟和稳定性有极高要求的情况下表现优异。
|
3月前
|
编解码 网络协议 vr&ar
Android平台下VR头显如何低延迟播放4K以上超高分辨率RTSP|RTMP流
这段内容讲述了VR头显中实现高分辨率视频播放的技术背景与实现方法,并强调了其重要性。高分辨率对于提升VR体验至关重要,它能提供更清晰的画面、增强沉浸感、补偿透镜放大效应,并维持宽广视场角下的图像质量。文中提到的大牛直播SDK具备极低的延迟(200-400ms),支持多种协议与格式,并具有丰富的功能特性,如多实例播放、事件回调、视频及音频格式支持等。此外,提供了基于Unity的播放器示例代码,展示了如何配置播放参数并开始播放。最后,作者指出此类技术在远程控制、虚拟仿真等应用场景中的重要意义。
|
5月前
|
缓存 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,并处理相关依赖和权限。
|
6月前
|
Java Android开发
Android 触摸音的播放
Android 触摸音的播放
45 5
下一篇
无影云桌面