Android简单音乐播放实例

Service翻译成中文是服务,熟悉Windows 系统的同学一定很熟悉了。Android里的Service跟Windows里的Service功能差不多,就是一个不可见的进程在后台执行。
Android中的服务,它与Activity不同,它是不能与用户交互的,不能自己启动的,运行在后台的程序,如果我们退出应用时,Service进程并没有结束,它仍然在后台运行,例如我们打开一个音乐播放器来听音乐,在听音乐的同时也想做下其它的事情,比如上网聊Q、或者上网浏览新闻之类的事情。这样的话,我们就需要用到Service服务了。下面我们以一个简单的音乐播放器的实例来说明下Service的生命周期和Service的使用。
下面是音乐播放器Demo的程序结构图:

Android Service的生命周期:

Android中Service的生命周期并不是很复杂,只是继承了onCreate(), onStart(), onDestory()三个方法。当我们第一次启动Service服务时,调用onCreate() --> onStart()两个方法,当停止Service服务时,调用onDestory()方法。如果Service已经启动了,第二次再启动同一个服务时,就只是调用 onStart() 这个方法了。
Android Service 的使用:
1、参照上面的程序结构图,我们可以创建一个Android程序,在src目录下创建一个Activity,一个继承自Service类的服务类;同时在资源文件夹res目录下创建一个raw的文件夹存放音频文件,如把music.mp3音乐文件放在该目录下。该程序的主界面如下:

2、layout目录下的main.xml文件的源码:

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
  android:orientation="vertical"
  android:layout_width="fill_parent"
  android:layout_height="fill_parent"
  >
  <TextView
    android:layout_width="fill_parent"
    android:layout_height="wrap_content"
    android:text="Welcome to Andy's blog!"
    android:textSize="16sp"/>
  <TextView
    android:layout_width="fill_parent"
    android:layout_height="wrap_content"
    android:text="音乐播放服务"/>
  <Button
    android:id="@+id/startMusic"
    android:layout_width="wrap_content"
    android:layout_height="wrap_content"
    android:text="开启音乐播放服务"/>
  <Button
    android:id="@+id/stopMusic"
    android:layout_width="wrap_content"
    android:layout_height="wrap_content"
    android:text="停止音乐播放服务"/>
  <Button
   android:id="@+id/bindMusic"
   android:layout_width="wrap_content"
   android:layout_height="wrap_content"
   android:text="绑定音乐播放服务"/>
  <Button
   android:id="@+id/unbindMusic"
   android:layout_width="wrap_content"
   android:layout_height="wrap_content"
   android:text="解除 ——绑定音乐播放服务"/>
</LinearLayout> 

3、src目录下MusicService.java源码:

package com.andyidea.service;
import android.app.Service;
import android.content.Intent;
import android.media.MediaPlayer;
import android.os.IBinder;
import android.util.Log;
import android.widget.Toast;
public class MusicService extends Service {
  //为日志工具设置标签
  private static String TAG = "MusicService";
  //定义音乐播放器变量
  private MediaPlayer mPlayer; 

  //该服务不存在需要被创建时被调用,不管startService()还是bindService()都会启动时调用该方法
  @Override
  public void onCreate() {
    Toast.makeText(this, "MusicSevice onCreate()"
        , Toast.LENGTH_SHORT).show();
    Log.e(TAG, "MusicSerice onCreate()"); 

    mPlayer = MediaPlayer.create(getApplicationContext(), R.raw.music);
    //设置可以重复播放
    mPlayer.setLooping(true);
    super.onCreate();
  } 

  @Override
  public void onStart(Intent intent, int startId) {
    Toast.makeText(this, "MusicSevice onStart()"
        , Toast.LENGTH_SHORT).show();
    Log.e(TAG, "MusicSerice onStart()"); 

    mPlayer.start(); 

    super.onStart(intent, startId);
  }
  @Override
  public void onDestroy() {
    Toast.makeText(this, "MusicSevice onDestroy()"
        , Toast.LENGTH_SHORT).show();
    Log.e(TAG, "MusicSerice onDestroy()"); 

    mPlayer.stop(); 

    super.onDestroy();
  }
  //其他对象通过bindService 方法通知该Service时该方法被调用
  @Override
  public IBinder onBind(Intent intent) {
    Toast.makeText(this, "MusicSevice onBind()"
        , Toast.LENGTH_SHORT).show();
    Log.e(TAG, "MusicSerice onBind()"); 

    mPlayer.start(); 

    return null;
  }
  //其它对象通过unbindService方法通知该Service时该方法被调用
  @Override
  public boolean onUnbind(Intent intent) {
    Toast.makeText(this, "MusicSevice onUnbind()"
        , Toast.LENGTH_SHORT).show();
    Log.e(TAG, "MusicSerice onUnbind()"); 

    mPlayer.stop(); 

    return super.onUnbind(intent);
  } 

}

4、src目录下MusicServiceActivity源码:

package com.andyidea.service;
import android.app.Activity;
import android.content.ComponentName;
import android.content.Context;
import android.content.Intent;
import android.content.ServiceConnection;
import android.os.Bundle;
import android.os.IBinder;
import android.util.Log;
import android.view.View;
import android.view.View.OnClickListener;
import android.widget.Button;
import android.widget.Toast;
public class MusicServiceActivity extends Activity { 

  //为日志工具设置标签
  private static String TAG = "MusicService"; 

  /** Called when the activity is first created. */
  @Override
  public void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    setContentView(R.layout.main); 

    //输出Toast消息和日志记录
    Toast.makeText(this, "MusicServiceActivity",
        Toast.LENGTH_SHORT).show();
    Log.e(TAG, "MusicServiceActivity"); 

    initlizeViews();
  } 

  private void initlizeViews(){
    Button btnStart = (Button)findViewById(R.id.startMusic);
    Button btnStop = (Button)findViewById(R.id.stopMusic);
    Button btnBind = (Button)findViewById(R.id.bindMusic);
    Button btnUnbind = (Button)findViewById(R.id.unbindMusic); 

    //定义点击监听器
    OnClickListener ocl = new OnClickListener() { 

      @Override
      public void onClick(View v) {
        //显示指定 intent所指的对象是个  service
        Intent intent = new Intent(MusicServiceActivity.this,MusicService.class);
        switch(v.getId()){
        case R.id.startMusic:
          //开始服务
          startService(intent);
          break;
        case R.id.stopMusic:
          //停止服务
          stopService(intent);
          break;
        case R.id.bindMusic:
          //绑定服务
          bindService(intent, conn, Context.BIND_AUTO_CREATE);
          break;
        case R.id.unbindMusic:
          //解绑服务
          unbindService(conn);
          break;
        }
      }
    }; 

     //绑定点击监听
    btnStart.setOnClickListener(ocl);
    btnStop.setOnClickListener(ocl);
    btnBind.setOnClickListener(ocl);
    btnUnbind.setOnClickListener(ocl);
  } 

  //定义服务链接对象
  final ServiceConnection conn = new ServiceConnection() { 

    @Override
    public void onServiceDisconnected(ComponentName name) {
      Toast.makeText(MusicServiceActivity.this, "MusicServiceActivity onSeviceDisconnected"
          , Toast.LENGTH_SHORT).show();
      Log.e(TAG, "MusicServiceActivity onSeviceDisconnected");
    } 

    @Override
    public void onServiceConnected(ComponentName name, IBinder service) {
      Toast.makeText(MusicServiceActivity.this, "MusicServiceActivity onServiceConnected"
          ,Toast.LENGTH_SHORT).show();
      Log.e(TAG, "MusicServiceActivity onServiceConnected");
    }
  };
}

5、最后,我们别忘了在AndroidManifest.xml配置文件中添加对Service的注册。即在application节点中添加<service android:name=".MusicService"/> 进行注册。
6、我们来看下程序运行后的Log.e中显示的Service生命周期

7、我们在Android终端设备中查看下刚才启动的音乐播放服务,看看我们退出程序后,是不是该程序的服务还在运行的呢?按如下步骤:Menu --> Settings --> Applications --> Running services 。在弹出的 Running services 中可以看到有哪些服务在运行。

这样我们就看到我们退出程序后,是由于该服务还在后台运行着,所以我们的音乐还可以继续播放着。就这样,我们就可以一边享受音乐,一边可以聊QQ,或者浏览新闻等等。

(0)

相关推荐

  • Android编程实现使用SoundPool播放音乐的方法

    本文实例讲述了Android编程实现使用SoundPool播放音乐的方法.分享给大家供大家参考,具体如下: 如果应用程序要播放密集.短促的音效,这时还用MediaPlayer就显得不合适了.MediaPlayer存在如下缺点: 1.资源占用率较高,延迟时间较长 2.不支持多个音频同时播放 此时我们可以用SoundPool来播放音效,SoundPool使用音效池的概念来管理多个短促的音效,例如它可以开始就加载20个音效,以后在程序中按音效的ID进行播放 SoundPool主要用于播放一些较短的声音

  • Android开发中听筒无法播放音乐的解决方法

    本文实例讲述了Android开发中听筒无法播放音乐的解决方法.分享给大家供大家参考,具体如下: 这个问题让我蛋疼了,既然百度也木有资料. 耗时的主要原因是因为权限不足时,而没有终止程序,只用了一小行日志提醒,没有看到 用听筒播放很简单 AudioManager.setMode(AudioManager.MODE_IN_CALL) //设定为通话中即可 还是这一句代码的事,不过记得要加上权限 Android.permission.MODIFY_AUDIO_SETTINGS 不然会像我一样蛋疼半天

  • Android中播放在线音乐代码

    复制代码 代码如下: Intent intent = new Intent();          Uri uri = Uri.parse("http://mul1.tximg.cn/music/group/bbs/mp3/44/100715/1279159638887.mp3?z=909255638");          intent.setDataAndType(uri, "audio/*");          intent.setAction(Intent

  • android暂停或停止其他音乐播放器的播放实现代码

    代码如下: 复制代码 代码如下: public static final String PLAYSTATE_CHANGED = "com.android.music.playstatechanged";    public static final String META_CHANGED = "com.android.music.metachanged";    public static final String QUEUE_CHANGED = "com

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

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

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

    欣赏一下我们清爽的界面吧~ 如果是只用activity来制作这样的东西简直是太小儿科了,此处我们当然用的是service 首先我们先上service的代码: 1.如果我们要访问service的属性和方法,那么在activity肯定是以bindservice的方法实现的,而在service中的onbind方法也是必须要实现的,onbind返回的Ibinder对象在activity的serviceconnection中得到使用. 2.activity获取到Ibinder对象,可以进一步获取服务对象和

  • Android播放音乐案例分享

    本文实例为大家分享了Android播放音乐案例的具体实现代码,供大家参考,具体内容如下 效果: 分析: 和上一篇文章的结构是一样的,只不过我们需要在这里里面加上播放音乐的一些操作: 其实也就是调用系统的播放音乐的API而已,写在服务里面就好, //媒体播放器 private MediaPlayer player; public void onCreate() { File file=new File(Environment.getExternalStorageDirectory(),"a.mp3

  • 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

  • Android实现多媒体之播放音乐

    闲来无聊,最近了解了一下多媒体的一些初步知识. 音频播放主要设计到MediaPlayer这个类,播放音频的路径可以来源于三个地方. 1.应用内的音频 public class MediaPlayActivity extends AppCompatActivity { private SeekBar seekBar; private MediaPlayer mediaPlayer; @Override protected void onCreate(Bundle savedInstanceStat

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

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

随机推荐