【Android开发】多媒体应用开发-使用MediaPlayer播放音频

简介:
Android提供了对常用音频和视频格式的支持,它所支持的音频格式有MP3(.mp3)、3GPP(.3gp)、Ogg(.ogg)和WAVE(.ave)等,支持的视频格式有3GPP(.3gp)和MPEG-4(.mp4)等。通过AndroidAPI提供的相关方法,在Android中可以实现音频与视频的播放。

下面介绍使用MediaPlayer播放音频
在Android中,提供了MediaPlayer类来播放音频。使用MediaPlayer类播放音频比较简单,只需要创建该类的对象,并为其指定要播放的音频文件,然后调用该类的start()方法即可,下面进行详细介绍。

1.创建MediaPlayer对象,并装载音频文件
两种方法,都是使用MediaPlayer的静态方法creat()来实现。
a.creat(Context context,int resid)
从资源文件中加载,例如
MediaPlayer player=MediaPlayer.creat(this,R.rwa.d);

b.creat(Context context,Uri uri)
根据指定的URI来装载音频,例如
MediaPlayer player=MediaPlayer.creat("Http://www.musicbox.com/sound/bg.mp3");

使用creat()方法时,已经加载了音频,但是用无参构造方法来创建MediaPlayer对象时,需要单独指定要装载的资源,这可以使用MediaPlayer类的setDataSource()方法来实现。

在使用setDataSource()方法装载音频文件后,实际上MediaPlayer并为真正装载该音频文件,需要调用MediaPlayer的prepare()方法去真正装载音频文件。使用无参构造方法来创建MediaPlayer对象并装载指定的音频文件,可以使用下面的代码:
MediaPlayer player=new MediaPlayer();
try {
	player.setDataSource("/sdcard/suger.mp3");//指定要装载的音频文件
} catch (IllegalArgumentException e) {
	e.printStackTrace();
} catch (SecurityException e) {
	e.printStackTrace();
} catch (IllegalStateException e) {
	e.printStackTrace();
} catch (IOException e) {
	e.printStackTrace();
}


try {
	player.prepare();//预加载音频
	} catch (IllegalStateException e) {
		e.printStackTrace();
	} catch (IOException e) {
		e.printStackTrace();
	}
}

2.开始或恢复播放
开始播放或恢复已经暂停的音频的播放
player.start();


3.停止播放
可以停止正在播放的音频
player.stop();


4.暂停播放
可以暂停正在播放的音频
player.pause();


下面做一个小实例,实现包括播放、暂停/继续和停止功能的简易音乐播放器
将要播放的音频文件上传到SD卡的Music目录中,这里要播放的音频文件为Whistle.mp3

目录如图




布局文件,包括一个文本信息显示控件和三个按钮(播放、暂停/继续和停止按钮)
res/layout/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:id="@+id/ll1"
    android:layout_width="fill_parent"
    android:layout_height="fill_parent"
    android:orientation="vertical" >
    	<LinearLayout 
		android:layout_width="fill_parent"
	        android:layout_height="wrap_content"
		android:orientation="vertical" >	
    	<TextView android:layout_width="wrap_content"
	        android:layout_height="wrap_content"
	        android:text="欢迎使用音乐播放器"
	        android:id="@+id/hint"/>
    	</LinearLayout>
    	<LinearLayout 
		android:layout_width="fill_parent"
		android:layout_height="wrap_content"
		android:orientation="horizontal" >	
	    <Button 
	        android:id="@+id/play"
	        android:layout_width="wrap_content"
	        android:layout_height="wrap_content"
	        android:text="播放"/>
	    <Button 
	        android:id="@+id/pause"
	        android:layout_width="wrap_content"
	        android:layout_height="wrap_content"
	        android:text="暂停"/>
	    <Button 
	        android:id="@+id/stop"
	        android:layout_width="wrap_content"
	        android:layout_height="wrap_content"
	        android:text="停止"/>
	    </LinearLayout>
</LinearLayout>

MainActivity:
package com.example.test;  
  
import java.io.File;


import android.app.Activity;
import android.media.MediaPlayer;
import android.media.MediaPlayer.OnCompletionListener;
import android.net.Uri;
import android.os.Bundle;
import android.os.Environment;
import android.view.View;
import android.view.View.OnClickListener;
import android.widget.Button;
import android.widget.TextView;
  
public class MainActivity extends Activity{  
	private MediaPlayer player;//MediaPlayer对象
	private boolean isPause=false;//是否暂停
	private File file;//要播放的音频文件
	private TextView hint;//声明显示提示信息的文本框
	private Button play;//播放按钮
	private Button pause;//暂停/继续按钮
	private Button stop;//停止按钮
    @Override  
    public void onCreate(Bundle savedInstanceState) {  
        super.onCreate(savedInstanceState);  
        setContentView(R.layout.main);
       
        play=(Button)findViewById(R.id.play);//获取"播放"按钮
        play.setOnClickListener(new OnClickListener() {
			
			@Override
			public void onClick(View arg0) {
				play();//开始播放音乐
				if(isPause){
					pause.setText("暂停");
					isPause=false;//设置暂停标记为false
				}
				
				pause.setEnabled(true);//"暂停/继续"按钮可用
				stop.setEnabled(true);//"停止"按钮可用
				play.setEnabled(false);//"播放"按钮不可用
			}
		});
        
        pause=(Button)findViewById(R.id.pause);//获取"暂停"按钮
        pause.setOnClickListener(new OnClickListener() {
			
			@Override
			public void onClick(View v) {
				if(player.isPlaying()&&!isPause){
					player.pause();//暂停播放
					isPause=true;
					((Button)v).setText("继续");
					hint.setText("暂停播放音频...");
					play.setEnabled(true);//播放按钮可用
				}else{
					player.start();//继续播放
					isPause=false;
					((Button)v).setText("暂停");
					hint.setText("继续播放音频...");
					play.setEnabled(false);//播放按钮不可用
				}
			}
		});
        
        stop=(Button)findViewById(R.id.stop);//获取"停止"按钮
        stop.setOnClickListener(new OnClickListener() {
			
			@Override
			public void onClick(View arg0) {
				player.stop();
				hint.setText("停止播放音频...");
				pause.setEnabled(false);//"暂停/继续"按钮不可用
				stop.setEnabled(false);//"停止"按钮不可用
				play.setEnabled(true);//"播放"按钮可用
				
			}
		});
        
        hint=(TextView)findViewById(R.id.hint);//获取显示提示信息的文本框
        file=new File(getSDPath()+"/"+"Music/Whistle.mp3");
        if(file.exists()){
        	player=MediaPlayer.create(MainActivity.this, 
        	Uri.parse(file.getAbsolutePath()));//创建MediaPlayer对象
        }else{
        	hint.setText("要播放的音频不存在!");
        	play.setEnabled(false);
        	return;
        }
        
        //添加完成事件监听器,用于当音乐播放完毕后,重新开始播放因音乐
        player.setOnCompletionListener(new OnCompletionListener() {
			
			@Override
			public void onCompletion(MediaPlayer arg0) {
				play();//重新开始播放
				
			}
		});
    }
  
    //播放音乐的方法
    public void play(){
		try {
			player.reset();
			player.setDataSource(file.getAbsolutePath());//重新设置要播放的音频
			player.prepare();//预加载音频
			player.start();//开始播放
			hint.setText("正在播放音乐...");
		} catch (Exception e) {
			e.printStackTrace();
		}
		
    }
    
    //获取sdcard根目录的方法
    public String getSDPath(){ 
        File sdDir = null; 
        boolean sdCardExist = Environment.getExternalStorageState()   
                            .equals(android.os.Environment.MEDIA_MOUNTED);   //判断sd卡是否存在 




        if(sdCardExist)      //如果SD卡存在,则获取跟目录
        {                               
          sdDir = Environment.getExternalStorageDirectory();//获取根目录 
       }   
        return sdDir.toString(); 
    }


    //Activity销销毁时,停止正在播放的音频,并释放MediaPlayer所占用的资源
	@Override
	protected void onDestroy() {
		if(player.isPlaying()){
			player.stop();//停止音频的播放
		}
		player.release();//释放资源
		super.onDestroy();
	}
    
}  

播放效果如图


暂停效果如图


继续效果如图


停止效果如图


转载请注明出处:http://blog.csdn.net/acmman/article/details/46509563

相关文章
|
1月前
|
存储 XML 开发工具
探索安卓应用开发:从基础到进阶
在这篇文章中,我们将一起踏上安卓应用开发的旅程。不论你是编程新手还是希望提升技能的开发者,这里都有你需要的东西。我们会从最基础的概念开始,逐步深入到更复杂的主题。文章将涵盖开发环境设置、用户界面设计、数据处理以及性能优化等方面。通过理论与实践的结合,你将能够构建出既美观又高效的安卓应用。让我们一起开启这段技术之旅吧!
|
1月前
|
Android开发 Swift iOS开发
深入探索iOS与Android操作系统的架构差异及其对应用开发的影响
在当今数字化时代,移动设备已经成为我们日常生活和工作不可或缺的一部分。其中,iOS和Android作为全球最流行的两大移动操作系统,各自拥有独特的系统架构和设计理念。本文将深入探讨iOS与Android的系统架构差异,并分析这些差异如何影响应用开发者的开发策略和用户体验设计。通过对两者的比较,我们可以更好地理解它们各自的优势和局限性,从而为开发者提供有价值的见解,帮助他们在这两个平台上开发出更高效、更符合用户需求的应用。
|
2月前
|
Android开发 Swift iOS开发
iOS和安卓作为主流操作系统,开发者需了解两者差异以提高效率并确保优质用户体验。
【10月更文挑战第1天】随着移动互联网的发展,智能手机成为生活必需品,iOS和安卓作为主流操作系统,各有庞大的用户群。开发者需了解两者差异以提高效率并确保优质用户体验。iOS使用Swift或Objective-C开发,强调简洁直观的设计;安卓则采用Java或Kotlin,注重层次与动画。Swift和Kotlin均有现代编程特性。此外,iOS设备更易优化,而安卓需考虑更多兼容性问题。iOS应用仅能通过App Store发布,审核严格;安卓除Google Play外还可通过第三方市场发布,审核较宽松。开发者应根据需求选择合适平台,提供最佳应用体验。
75 3
|
2月前
|
存储 Android开发 开发者
深入理解安卓应用开发的核心组件
【10月更文挑战第8天】探索Android应用开发的精髓,本文带你了解安卓核心组件的奥秘,包括Activity、Service、BroadcastReceiver和ContentProvider。我们将通过代码示例,揭示这些组件如何协同工作,构建出功能强大且响应迅速的应用程序。无论你是初学者还是资深开发者,这篇文章都将为你提供新的视角和深度知识。
|
2月前
|
数据可视化 Android开发 开发者
安卓应用开发中的自定义View组件
【10月更文挑战第5天】在安卓应用开发中,自定义View组件是提升用户交互体验的利器。本篇将深入探讨如何从零开始创建自定义View,包括设计理念、实现步骤以及性能优化技巧,帮助开发者打造流畅且富有创意的用户界面。
101 0
|
21天前
|
搜索推荐 Android开发 开发者
安卓应用开发中的自定义控件实践
在安卓应用开发的广阔天地中,自定义控件如同璀璨的星辰,点亮了用户界面设计的夜空。它们不仅丰富了交互体验,更赋予了应用独特的个性。本文将带你领略自定义控件的魅力,从基础概念到实际应用,一步步揭示其背后的原理与技术细节。我们将通过一个简单的例子——打造一个具有独特动画效果的按钮,来展现自定义控件的强大功能和灵活性。无论你是初学者还是资深开发者,这篇文章都将为你打开一扇通往更高阶UI设计的大门。
|
1月前
|
缓存 监控 前端开发
探索Android应用开发之旅:从新手到专家
【10月更文挑战第42天】本文将带你踏上Android应用开发的旅程,无论你是初学者还是有经验的开发者。我们将一起探索如何从零开始创建你的第一个Android应用,并逐步深入到更高级的主题,如自定义视图、网络编程和性能优化。通过实际示例和清晰的解释,你将学会如何构建高效、吸引人的Android应用。让我们一起开启这段激动人心的旅程吧!
|
1月前
|
开发框架 前端开发 Android开发
探索安卓和iOS应用开发中的跨平台解决方案
【10月更文挑战第42天】在移动应用开发的广阔天地中,安卓和iOS系统如同两座巍峨的山峰,分别占据着半壁江山。开发者们在这两座山峰之间穿梭,努力寻找一种既能节省资源又能提高效率的跨平台开发方案。本文将带你走进跨平台开发的世界,探讨各种解决方案的优势与局限,并分享一些实用的代码示例,助你在应用开发的道路上更加游刃有余。
|
1月前
|
搜索推荐 前端开发 Android开发
安卓应用开发中的自定义视图实现
【10月更文挑战第30天】在安卓开发的海洋中,自定义视图是那抹不可或缺的亮色,它为应用界面的个性化和交互体验的提升提供了无限可能。本文将深入探讨如何在安卓平台创建自定义视图,并展示如何通过代码实现这一过程。我们将从基础出发,逐步引导你理解自定义视图的核心概念,然后通过一个实际的代码示例,详细讲解如何将理论应用于实践,最终实现一个美观且具有良好用户体验的自定义控件。无论你是想提高自己的开发技能,还是仅仅出于对安卓开发的兴趣,这篇文章都将为你提供价值。
|
1月前
|
传感器 XML IDE
探索安卓应用开发:从基础到进阶
【10月更文挑战第23天】在数字化时代的浪潮中,移动应用已成为人们日常生活的延伸。本文以安卓平台为例,深入浅出地介绍了如何从零开始构建一个安卓应用,涵盖了开发环境搭建、基本组件使用、界面设计原则以及进阶技巧等关键步骤。通过实例演示和代码片段,引导读者逐步掌握安卓应用开发的核心技能,旨在激发更多开发者对安卓平台的探索热情,并为初学者提供一条清晰的学习路径。