教你轻松制作Android音乐播放器

欣赏一下我们清爽的界面吧~

如果是只用activity来制作这样的东西简直是太小儿科了,此处我们当然用的是service
首先我们先上service的代码:
1、如果我们要访问service的属性和方法,那么在activity肯定是以bindservice的方法实现的,而在service中的onbind方法也是必须要实现的,onbind返回的Ibinder对象在activity的serviceconnection中得到使用。
2、activity获取到Ibinder对象,可以进一步获取服务对象和player对象,来进行访问。
3、Environment.getExternalStorageDirectory()是获取sd中的内容的,不管是手机出场就已经内置的sd卡,还是用户后来自己添加的sd卡;而getExternalFilesDir()获取的真正是手机内部的存储空间,,/data/data/your_package/,随着应用的卸载存储的文件会被删除。
4、service通过发送广播与activity进行界面交互

public class MusicService extends Service{

 private List<File> musicList;
 private MediaPlayer player;
 private int curPage;
 public static final String MFILTER = "broadcast.intent.action.text";
 public static final String NAME = "name";
 public static final String TOTALTIME = "totaltime";
 public static final String CURTIME = "curtime";

 @Override
 public IBinder onBind(Intent intent) {//1
 // TODO Auto-generated method stub
 return new MBinder();
 }
 public class MBinder extends Binder{//2
 public MusicService getService(){
  return MusicService.this;
 }
 public MediaPlayer getPlayer(){
  return player;
 }
 }
 @Override
 public void onCreate() {
 // TODO Auto-generated method stub
 super.onCreate();
 musicList = new ArrayList<File>();
 File rootDir = Environment.getExternalStorageDirectory();//3
 Log.d("rootname",rootDir.getName());
 Log.d("rootname",rootDir.getAbsolutePath());
 fillMusicList(rootDir);
 Log.d("musiclist",String.valueOf(musicList.size()));
 player = new MediaPlayer();
 if (musicList.size() != 0) {
  startPlay();
 }

 player.setOnCompletionListener(new OnCompletionListener() {

  @Override
  public void onCompletion(MediaPlayer mp) {
  // TODO Auto-generated method stub
  player.reset();
  curPage = curPage==musicList.size()-1? (curPage+1)%musicList.size() : curPage+1;
  startPlay();
  }
 });
 }
 /*迭代获取 音乐 文件*/
 private void fillMusicList(File dir){
 File[] sourceFiles = dir.listFiles();
 Log.d("长度",String.valueOf(sourceFiles.length));
 for(File file : sourceFiles){
  if (file.isDirectory()) {
  Log.d("文件夹名称",String.valueOf(file.getName()));
//  if (!file.getName().equals("lost+found")) {
   fillMusicList(file);
//  }

  }
  else {
   String name = file.getName();
   Log.d("childname",file.getName());
   if (name.endsWith(".mp3")||name.endsWith(".acc")) {//支持的格式
   musicList.add(file);
   }
  }
 }
 }
 private void startPlay(){
 mSendBroadCast(NAME,musicList.get(curPage).getName());//4
 try {
  player.setDataSource(musicList.get(curPage).getAbsolutePath());
  player.prepare();
  player.start();
  player.getDuration();
  mSendBroadCast(TOTALTIME,player.getDuration());
  Timer timer = new Timer();
  timer.schedule(new TimerTask() {

  @Override
  public void run() {
   // TODO Auto-generated method stub
   mSendBroadCast(CURTIME,player.getCurrentPosition());
  }
  },0,1000);

 } 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();
 }
 }

 public void playNext(){
 curPage = curPage==musicList.size()-1? (curPage+1)%musicList.size() : curPage+1;
 Log.d("curpage",String.valueOf(curPage));
 player.reset();
 startPlay();
 }
 public void playPrevious(){
 curPage = curPage==0? 0 : curPage-1;
 Log.d("curpage",String.valueOf(curPage));
 player.reset();
 startPlay();
 }
 public void parse(){
 player.pause();
 }
 public void restart(){
 player.start();
 }
 private void mSendBroadCast(String key, String value){
 Intent intent = new Intent(MFILTER);
 intent.putExtra(key,value);//发送广播
 sendBroadcast(intent);
 }

 private void mSendBroadCast(String key, int value){
 Intent intent = new Intent(MFILTER);
 intent.putExtra(key,value);//发送广播
 sendBroadcast(intent);
 }
}

接下来上activity代码:
1、通过Ibinder对象获取服务对象
2、获取到服务对象以后,再访问服务的方法。
3、通过receiver刷新页面

public class MainActivity extends Activity implements OnClickListener{

 SeekBar seekBar;
 TextView curTime,totalTime;
 TextView title;

 private ServiceConnection sc;
 private MusicService ms;
 private boolean isStop;
 private double totalTimeInt;
 @Override
 protected void onCreate(Bundle savedInstanceState) {
 super.onCreate(savedInstanceState);
 setContentView(R.layout.activity_main);
 IntentFilter filter = new IntentFilter(MusicService.MFILTER);
 registerReceiver(new MusicReceiver(),filter);
 sc = new ServiceConnection() {

  @Override
  public void onServiceDisconnected(ComponentName name) {
  // TODO Auto-generated method stub
  ms = null;
  }

  @Override
  public void onServiceConnected(ComponentName name, IBinder service) {
  // TODO Auto-generated method stub
  ms = ((MBinder)service).getService();//1

  }
 };
 Button previous = (Button) findViewById(R.id.previous);
 Button next = (Button) findViewById(R.id.next);
 Button stop = (Button) findViewById(R.id.stop);
 Button stopService = (Button) findViewById(R.id.stopService);
 seekBar = (SeekBar) findViewById(R.id.mSeekbar);
 curTime = (TextView) findViewById(R.id.curTime);
 totalTime = (TextView) findViewById(R.id.totalTime);
 title = (TextView) findViewById(R.id.title);

 previous.setOnClickListener(this);
 next.setOnClickListener(this);
 stop.setOnClickListener(this);
 stopService.setOnClickListener(this);
 }

 @Override
 public void onClick(View v) {
 // TODO Auto-generated method stub
 switch (v.getId()) {
 case R.id.previous:
  ms.playPrevious();//2
  break;
 case R.id.next:
  ms.playNext();
  break;
 case R.id.stop:
  if (isStop) {
  ms.restart();
  }
  else {
  ms.parse();
  }
  isStop = !isStop;
  break;
 case R.id.stopService:
  Intent intent = new Intent("com.intent.musicplayer.MusicService");
  unbindService(sc);
  stopService(intent);

  break;
 default:
  break;
 }
 }

 @Override
 protected void onStart() {
 // TODO Auto-generated method stub
 super.onStart();
 Intent intent = new Intent("com.intent.musicplayer.MusicService");
 bindService(intent,sc,Context.BIND_AUTO_CREATE);//当然你可以用startService的方式启动服务,这样结束了activity以后并不会结束service

 }
 private String transferMilliToTime(int millis){
 DateFormat format = new SimpleDateFormat("mm:ss");
 String result = format.format(new Date(millis));
 return result;
 }
 private class MusicReceiver extends BroadcastReceiver{//3

 @Override
 public void onReceive(Context context, Intent intent) {
  // TODO Auto-generated method stub
  if (intent.getIntExtra(MusicService.CURTIME,0)!=0) {
  double curTimeInt = intent.getIntExtra(MusicService.CURTIME,0);
  curTime.setText(transferMilliToTime((int)curTimeInt));
  double result = curTimeInt/totalTimeInt*100;
  seekBar.setProgress((int) Math.floor(result));

  }
  else if(intent.getIntExtra(MusicService.TOTALTIME,0)!=0) {
  totalTimeInt = intent.getIntExtra(MusicService.TOTALTIME,0);
  totalTime.setText(transferMilliToTime((int)(totalTimeInt)));
  }
  else if (!TextUtils.isEmpty(intent.getStringExtra(MusicService.NAME))) {
  title.setText(intent.getStringExtra(MusicService.NAME));
  }
 }

 }
}

4、最后附上xml布局文件,算是代码上传完全了:

<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="${relativePackage}.${activityClass}" >
 <TextView
 android:id="@+id/title"
 android:layout_width="wrap_content"
 android:layout_height="wrap_content"
 android:layout_gravity="center_horizontal"
 android:textSize="25sp"
 android:textColor="#444444"
 />
 <SeekBar
 android:id="@+id/mSeekbar"
 android:layout_gravity="center_horizontal"
 android:layout_width="400dp"
 android:layout_height="wrap_content"
 android:max="100"
 />
 <RelativeLayout
 android:layout_width="match_parent"
 android:layout_height="wrap_content"
 >
 <TextView
 android:id="@+id/curTime"
 android:layout_height="wrap_content"
 android:layout_width="wrap_content"
 android:layout_alignParentLeft="true"

 />
 <TextView
 android:id="@+id/totalTime"
 android:layout_height="wrap_content"
 android:layout_width="wrap_content"
 android:layout_alignParentRight="true"
 />
 </RelativeLayout>
 <RelativeLayout
 android:layout_width="match_parent"
 android:layout_height="wrap_content"
 >
 <Button
 android:id="@+id/previous"
 android:layout_height="wrap_content"
 android:layout_width="wrap_content"
 android:text="上一曲"
 android:layout_alignParentLeft="true"
 />
 <Button
  android:id="@+id/stop"
  android:layout_height="wrap_content"
  android:layout_width="wrap_content"
  android:text="停止音乐"
  android:layout_toRightOf="@id/previous"
  />

 <Button
 android:id="@+id/next"
 android:layout_height="wrap_content"
 android:layout_width="wrap_content"
 android:text="下一曲"
 android:layout_alignParentRight="true"
 />
  <Button
  android:id="@+id/stopService"
  android:layout_height="wrap_content"
  android:layout_width="wrap_content"
  android:text="停止音乐服务"
  android:layout_toLeftOf="@id/next"
  />
 </RelativeLayout> 

</LinearLayout>

更多关于播放器的内容请点击《java播放器功能》进行学习。

以上就是制作Android音乐播放器的全部代码,希望对大家的学习有所帮助。

(0)

相关推荐

  • Android编程开发音乐播放器实例

    本文实例讲述了Android编程开发音乐播放器,分享给大家供大家参考,具体如下: 音乐播放器中综合了以下内容: SeekBar.ListView.广播接收者(以代码的形式注册Receiver).系统服务.MediaPlayer 实现的功能: 1.暂停/播放.下一首/上一首,点击某一首时播放 2.支持拖动进度条快进 3.列表排序 4.来电话时,停止播放,挂断后继续播放 5.可在后台播放 效果图: 界面: main.xml: <?xml version="1.0" encoding=

  • Android基于Service的音乐播放器

    本文开发一个基于Service的音乐播放器,音乐由后台运行的Service负责播放,当后台的播放状态发生变化时,程序将会通过发送广播通知前台Activity更新界面:当点击Activity的界面按钮时,系统将通过发送广播通知后台Service来改变播放状态. 前台Activity界面有两个按钮,分别用于控制播放/暂停.停止,另外还有两个文本框,用于显示正在播放的歌曲名.歌手名.前台Activity的代码如下: public class MainActivity extends AppCompat

  • 简单实现Android本地音乐播放器

    音乐播放需要调用service,在此,只是简单梳理播放流程. public class PlayMusicService extends Service { //绑定服务 调用服务的方法. @Override public IBinder onBind(Intent intent) { return null; } } <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" xmlns:to

  • Android开发实现的简单媒体播放器功能示例

    本文实例讲述了Android开发实现的简单媒体播放器功能.分享给大家供大家参考,具体如下: 一.概述: 因为播放视频需要很大的内存,所以必须使用surfaceview , surfaceview 里实现了双缓冲的功能, 二.全部代码: /** * @描述 使用surfaceview 创建视频 * @项目名称 App_Basic * @包名 com.example.basic.media * @类名 MediaPlayerActivity * @author chenlin * @date 201

  • Android自定义播放器控件VideoView

    介绍 最近要使用播放器做一个简单的视频播放功能,开始学习VideoView,在横竖屏切换的时候碰到了点麻烦,不过在查阅资料后总算是解决了.在写VideoView播放视频时候定义控制的代码全写在Actvity里了,写完一看我靠代码好乱,于是就写了个自定义的播放器控件,支持指定大小,可以横竖屏切换,手动左右滑动快进快退.好了,下面开始. 效果图有点卡,我也不知道为啥..... VideoView介绍 这个是我们实现视频播放最主要的控件,详细的介绍大家百度就去看,这里介绍几个常用的方法. 用于播放视频

  • android音乐播放器监听电话状态实现代码

    如下代码是监听电话的状态,代码简单不做介绍直接看代码: 复制代码 代码如下: private boolean mResumeAfterCall = false; private PhoneStateListener mPhoneStateListener = new PhoneStateListener() {  @Override  public void onCallStateChanged(int state, String incomingNumber) {   if (state ==

  • Android 音乐播放器的开发实例详解

    本文将引导大家做一个音乐播放器,在做这个Android开发实例的过程中,能够帮助大家进一步熟悉和掌握学过的ListView和其他一些组件.为了有更好的学习效果,其中很多功能我们手动实现,例如音乐播放的快进快退等. 先欣赏下本实例完成后运行的界面效果: 首先我们建立项目,我使用的SDK是Android2.2的,然后在XML中进行布局. 上方是一个ListView用来显示我们的音乐列表,中间是一个SeekBar可以拖动当前音乐的播放进度,之所以用SeekBar而不用ProgressBar是因为我们需

  • android webvie指定视频播放器播放网站视频

    过滤掉其他的播放器,使用我自己的播放器来做 复制代码 代码如下: wv.setWebViewClient(new WebViewClient() {            public boolean shouldOverrideUrlLoading(final WebView view,                    final String url) { if (url.contains("3gp") || url.contains("mp4")) {/

  • Android MediaPlayer实现音乐播放器实例代码

    Android MediaPlayer实现音乐播放器 1.布局文件 <?xml version="1.0" encoding="utf-8"?> <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" android:layout_width="fill_parent" android:layout_height=&qu

  • Android简易音乐播放器实现代码

    本文实例为大家分享了Android音乐播放器的具体代码,供大家参考,具体内容如下 1.播放项目内的音乐 package com.thm.g150820_android26_playmusic; import Android.media.MediaPlayer; import android.support.v7.app.AppCompatActivity; import android.os.Bundle; import android.view.View; import android.wid

随机推荐