android音乐播放简单实现的简单示例(MediaPlayer)

发布时间 - 2026-01-11 02:57:20    点击率:

利用MediaPlayer完成一个最简单的音乐播放。这个基本的控制掌握后,可直接利用为背景乐的控制。

为了能够实现播放,在界面方面,我们需要三个控制按钮,分别是:Play(播放)、Pause(暂停)、Stop(停止)

请看activity_main.xml

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
  xmlns:tools="http://schemas.android.com/tools"
  android:orientation="vertical"
  android:layout_width="match_parent"
  android:layout_height="match_parent"
  tools:context="com.cofox.myaudio.MainActivity">

  <Button
    android:id="@+id/btnPlay"
    android:layout_width="match_parent"
    android:layout_height="wrap_content"
    android:textAllCaps="false"
    android:text="Play"/>
  <Button
    android:id="@+id/btnPause"
    android:layout_width="match_parent"
    android:layout_height="wrap_content"
    android:textAllCaps="false"
    android:text="Pause"/>
  <Button
    android:id="@+id/btnStop"
    android:layout_width="match_parent"
    android:layout_height="wrap_content"
    android:textAllCaps="false"
    android:text="Stop"/>

</LinearLayout>

在MainActivity.java首先声明一个 MediaPlayer 播放器。

private MediaPlayer mediaPlayer = new MediaPlayer();

由于音乐播放也是需要专门的权限的,所以在 onCreate 中动态申请权限,然后才初始化播放器。

//权限判断,如果没有权限就请求权限
    if (ContextCompat.checkSelfPermission(MainActivity.this, Manifest.permission.WRITE_EXTERNAL_STORAGE) != PackageManager.PERMISSION_GRANTED) {
      ActivityCompat.requestPermissions(MainActivity.this, new String[]{Manifest.permission.WRITE_EXTERNAL_STORAGE}, 1);
    } else {
      initMediaPlayer();//初始化播放器 MediaPlayer
    }

播放器的初始化方法

private void initMediaPlayer() {
    try {
      File file = new File(Environment.getExternalStorageDirectory(), "music.mp3");
      mediaPlayer.setDataSource(file.getPath());//指定音频文件路径
      mediaPlayer.setLooping(true);//设置为循环播放
      mediaPlayer.prepare();//初始化播放器MediaPlayer

    } catch (Exception e) {
      e.printStackTrace();
    }
  }

在 onCreate中需要实例化三个按钮

    Button btnPlay = (Button) findViewById(R.id.btnPlay);
    Button btnPause = (Button) findViewById(R.id.btnPause);
    Button btnStop = (Button) findViewById(R.id.btnStop);

    btnPlay.setOnClickListener(this);
    btnPause.setOnClickListener(this);
    btnStop.setOnClickListener(this);

btnPlay.setOnClickListener(this) 这种写法,需要类的扩展支持。所以,MainActivity 增加了 implements View.OnClickListener

复制代码 代码如下:
public class MainActivity extends AppCompatActivity implements View.OnClickListener {

获取权限的部分,需要用户操作,根据权限的给予情况,软件要做出不同的反应。获得了权限,就去初始化;没获得权限,就去通知用户。

  @Override
  public void onRequestPermissionsResult(int requestCode, @NonNull String[] permissions, @NonNull int[] grantResults) {
    switch (requestCode){
      case 1:
        if(grantResults.length > 0 && grantResults[0] == PackageManager.PERMISSION_GRANTED){
          initMediaPlayer();
        }else{
          Toast.makeText(this, "拒绝权限,将无法使用程序。", Toast.LENGTH_LONG).show();
          finish();
        }
        break;
      default:
    }

  }

统一在一个 onClick 方法内处理界面所有按钮的点击事件。

  @Override
  public void onClick(View v) {
    switch (v.getId()){
      case R.id.btnPlay:

        //如果没在播放中,立刻开始播放。
        if(!mediaPlayer.isPlaying()){
          mediaPlayer.start();
        }
        break;
      case R.id.btnPause:
        //如果在播放中,立刻暂停。
        if(mediaPlayer.isPlaying()){
          mediaPlayer.pause();
        }
        break;
      case R.id.btnStop:
        //如果在播放中,立刻停止。
        if(mediaPlayer.isPlaying()){
          mediaPlayer.reset();
          initMediaPlayer();//初始化播放器 MediaPlayer
        }
        break;
      default:
        break;
    }
  }

注意 case R.id.btnStop 中,mediaPlayer.reset() 后,我们重新对播放器进行了初始化。如果没有这条语句,实测的效果是点击了停止按钮后,再点击开始按钮是无法顺利播放音乐的。感兴趣的朋友可以实验一下。

onDestroy() 的逻辑很容易理解,就是彻底清理音乐播放占用的资源了。

@Override
  protected void onDestroy() {
    super.onDestroy();
    if(mediaPlayer != null){
      mediaPlayer.stop();
      mediaPlayer.release();
    }
  }

完整代码示例:

package com.cofox.myaudio;

import android.Manifest;
import android.content.pm.PackageManager;
import android.media.MediaPlayer;
import android.os.Environment;
import android.support.annotation.NonNull;
import android.support.v4.app.ActivityCompat;
import android.support.v4.content.ContextCompat;
import android.support.v7.app.AppCompatActivity;
import android.os.Bundle;
import android.view.View;
import android.widget.Button;
import android.widget.Toast;

import java.io.File;

public class MainActivity extends AppCompatActivity implements View.OnClickListener {

  private MediaPlayer mediaPlayer = new MediaPlayer();

  @Override
  protected void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    setContentView(R.layout.activity_main);

    Button btnPlay = (Button) findViewById(R.id.btnPlay);
    Button btnPause = (Button) findViewById(R.id.btnPause);
    Button btnStop = (Button) findViewById(R.id.btnStop);

    btnPlay.setOnClickListener(this);
    btnPause.setOnClickListener(this);
    btnStop.setOnClickListener(this);


    //权限判断,如果没有权限就请求权限
    if (ContextCompat.checkSelfPermission(MainActivity.this, Manifest.permission.WRITE_EXTERNAL_STORAGE) != PackageManager.PERMISSION_GRANTED) {
      ActivityCompat.requestPermissions(MainActivity.this, new String[]{Manifest.permission.WRITE_EXTERNAL_STORAGE}, 1);
    } else {
      initMediaPlayer();//初始化播放器 MediaPlayer
    }


  }

  private void initMediaPlayer() {
    try {
      File file = new File(Environment.getExternalStorageDirectory(), "music.mp3");
      mediaPlayer.setDataSource(file.getPath());//指定音频文件路径
      mediaPlayer.setLooping(true);//设置为循环播放
      mediaPlayer.prepare();//初始化播放器MediaPlayer

    } catch (Exception e) {
      e.printStackTrace();
    }
  }

  @Override
  public void onRequestPermissionsResult(int requestCode, @NonNull String[] permissions, @NonNull int[] grantResults) {
    switch (requestCode){
      case 1:
        if(grantResults.length > 0 && grantResults[0] == PackageManager.PERMISSION_GRANTED){
          initMediaPlayer();
        }else{
          Toast.makeText(this, "拒绝权限,将无法使用程序。", Toast.LENGTH_LONG).show();
          finish();
        }
        break;
      default:
    }

  }

  @Override
  public void onClick(View v) {
    switch (v.getId()){
      case R.id.btnPlay:

        //如果没在播放中,立刻开始播放。
        if(!mediaPlayer.isPlaying()){
          mediaPlayer.start();
        }
        break;
      case R.id.btnPause:
        //如果在播放中,立刻暂停。
        if(mediaPlayer.isPlaying()){
          mediaPlayer.pause();
        }
        break;
      case R.id.btnStop:
        //如果在播放中,立刻停止。
        if(mediaPlayer.isPlaying()){
          mediaPlayer.reset();
          initMediaPlayer();//初始化播放器 MediaPlayer
        }
        break;
      default:
        break;
    }
  }

  @Override
  protected void onDestroy() {
    super.onDestroy();
    if(mediaPlayer != null){
      mediaPlayer.stop();
      mediaPlayer.release();
    }
  }
}

当然,你不能忘记了在 AndroidManifest.xml 添加权限声明。

<?xml version="1.0" encoding="utf-8"?>
<manifest xmlns:android="http://schemas.android.com/apk/res/android"
  package="com.cofox.myaudio">
  <uses-permission android:name="android.permission.WRITE_EXTERNAL_STORAGE"/>
...

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。


# android  # 音乐播放  # 播放音乐  # 音乐播放器  # Android开发之MediaPlayer多媒体(音频  # 视频)播放工具类  # Android音视频开发之MediaPlayer使用教程  # android使用surfaceview+MediaPlayer播放视频  # Android使用MediaPlayer和TextureView实现视频无缝切换  # Android MediaPlayer 音频倍速播放 调整播放速度问题  # Android MediaPlayer 播放音频的方式  # MediaPlayer音频与视频播放方法示例介绍  # 播放器  # 就去  # 设置为  # 没有权限  # 很容易  # 感兴趣  # 这条  # 要做  # 如果没有  # 可直接  # 最简单  # 大家多多  # 进行了  # 再点  # 增加了  # 获得了  # 忘记了  # textAllCaps  # onCreate 


相关栏目: 【 网站优化151355 】 【 网络推广146373 】 【 网络技术251813 】 【 AI营销90571


相关推荐: Laravel如何使用withoutEvents方法临时禁用模型事件  香港服务器建站指南:外贸独立站搭建与跨境电商配置流程  无锡营销型网站制作公司,无锡网选车牌流程?  Laravel策略(Policy)如何控制权限_Laravel Gates与Policies实现用户授权  如何快速查询域名建站关键信息?  利用JavaScript实现拖拽改变元素大小  香港代理服务器配置指南:高匿IP选择、跨境加速与SEO优化技巧  php做exe能调用系统命令吗_执行cmd指令实现方式【详解】  DeepSeek是免费使用的吗 DeepSeek收费模式与Pro版本功能详解  Laravel Eloquent关联是什么_Laravel模型一对一与一对多关系精讲  如何在阿里云域名上完成建站全流程?  如何快速配置高效服务器建站软件?  Laravel如何使用Telescope进行调试?(安装和使用教程)  JavaScript模板引擎Template.js使用详解  如何在云主机快速搭建网站站点?  香港服务器租用费用高吗?如何避免常见误区?  Laravel如何与Docker(Sail)协同开发?(环境搭建教程)  韩国网站服务器搭建指南:VPS选购、域名解析与DNS配置推荐  Laravel Telescope怎么调试_使用Laravel Telescope进行应用监控与调试  打开php文件提示内存不足_怎么调整php内存限制【解决方案】  Win11怎么恢复误删照片_Win11数据恢复工具使用【推荐】  如何在Windows 2008云服务器安全搭建网站?  ,交易猫的商品怎么发布到网站上去?  如何在橙子建站中快速调整背景颜色?  Linux虚拟化技术教程_KVMQEMU虚拟机安装与调优  网站制作壁纸教程视频,电脑壁纸网站?  打造顶配客厅影院,这份100寸电视推荐名单请查收  Bootstrap整体框架之CSS12栅格系统  深圳网站制作设计招聘,关于服装设计的流行趋势,哪里的资料比较全面?  如何快速建站并高效导出源代码?  Win11怎么关闭透明效果_Windows11辅助功能视觉效果设置  如何在阿里云虚拟机上搭建网站?步骤解析与避坑指南  JavaScript如何实现音频处理_Web Audio API如何工作?  Java Adapter 适配器模式(类适配器,对象适配器)优缺点对比  Java解压缩zip - 解压缩多个文件或文件夹实例  Laravel如何配置Horizon来管理队列?(安装和使用)  QQ浏览器网页版登录入口 个人中心在线进入  谷歌浏览器如何更改浏览器主题 Google Chrome主题设置教程  Laravel如何使用Spatie Media Library_Laravel图片上传管理与缩略图生成【步骤】  Laravel如何保护应用免受CSRF攻击?(原理和示例)  网站制作企业,网站的banner和导航栏是指什么?  Linux系统运维自动化项目教程_Ansible批量管理实战  如何在景安服务器上快速搭建个人网站?  Python正则表达式进阶教程_复杂匹配与分组替换解析  深圳网站制作平台,深圳市做网站好的公司有哪些?  猪八戒网站制作视频,开发一个猪八戒网站,大约需要多少?或者自己请程序员,需要什么程序员,多少程序员能完成?  公司门户网站制作公司有哪些,怎样使用wordpress制作一个企业网站?  laravel怎么使用数据库工厂(Factory)生成带有关联模型的数据_laravel Factory生成关联数据方法  如何在VPS电脑上快速搭建网站?  实现点击下箭头变上箭头来回切换的两种方法【推荐】