Android使用Service實(shí)現(xiàn)簡(jiǎn)單音樂(lè)播放實(shí)例
Service翻譯成中文是服務(wù),熟悉Windows 系統(tǒng)的同學(xué)一定很熟悉了。Android里的Service跟Windows里的Service功能差不多,就是一個(gè)不可見(jiàn)的進(jìn)程在后臺(tái)執(zhí)行。
Android中的服務(wù),它與Activity不同,它是不能與用戶交互的,不能自己?jiǎn)?dòng)的,運(yùn)行在后臺(tái)的程序,如果我們退出應(yīng)用時(shí),Service進(jìn)程并沒(méi)有結(jié)束,它仍然在后臺(tái)運(yùn)行,例如我們打開(kāi)一個(gè)音樂(lè)播放器來(lái)聽(tīng)音樂(lè),在聽(tīng)音樂(lè)的同時(shí)也想做下其它的事情,比如上網(wǎng)聊Q、或者上網(wǎng)瀏覽新聞之類的事情。這樣的話,我們就需要用到Service服務(wù)了。下面我們以一個(gè)簡(jiǎn)單的音樂(lè)播放器的實(shí)例來(lái)說(shuō)明下Service的生命周期和Service的使用。
下面是音樂(lè)播放器Demo的程序結(jié)構(gòu)圖:
Android Service 的生命周期:
Android中Service的生命周期并不是很復(fù)雜,只是繼承了onCreate(), onStart(), onDestory()三個(gè)方法。當(dāng)我們第一次啟動(dòng)Service服務(wù)時(shí),調(diào)用onCreate() --> onStart()兩個(gè)方法,當(dāng)停止Service服務(wù)時(shí),調(diào)用onDestory()方法。如果Service已經(jīng)啟動(dòng)了,第二次再啟動(dòng)同一個(gè)服務(wù)時(shí),就只是調(diào)用 onStart() 這個(gè)方法了。
Android Service 的使用:
[1] 參照上面的程序結(jié)構(gòu)圖,我們可以創(chuàng)建一個(gè)Android程序,在src目錄下創(chuàng)建一個(gè)Activity,一個(gè)繼承自Service類的服務(wù)類;同時(shí)在資源文件夾res目錄下創(chuàng)建一個(gè)raw的文件夾存放音頻文件,如把music.mp3音樂(lè)文件放在該目錄下。該程序的主界面如下:
[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="音樂(lè)播放服務(wù)"/> <Button android:id="@+id/startMusic" android:layout_width="wrap_content" android:layout_height="wrap_content" android:text="開(kāi)啟音樂(lè)播放服務(wù)"/> <Button android:id="@+id/stopMusic" android:layout_width="wrap_content" android:layout_height="wrap_content" android:text="停止音樂(lè)播放服務(wù)"/> <Button android:id="@+id/bindMusic" android:layout_width="wrap_content" android:layout_height="wrap_content" android:text="綁定音樂(lè)播放服務(wù)"/> <Button android:id="@+id/unbindMusic" android:layout_width="wrap_content" android:layout_height="wrap_content" android:text="解除 ——綁定音樂(lè)播放服務(wù)"/> </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 { //為日志工具設(shè)置標(biāo)簽 private static String TAG = "MusicService"; //定義音樂(lè)播放器變量 private MediaPlayer mPlayer; //該服務(wù)不存在需要被創(chuàng)建時(shí)被調(diào)用,不管startService()還是bindService()都會(huì)啟動(dòng)時(shí)調(diào)用該方法 @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); //設(shè)置可以重復(fù)播放 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(); } //其他對(duì)象通過(guò)bindService 方法通知該Service時(shí)該方法被調(diào)用 @Override public IBinder onBind(Intent intent) { Toast.makeText(this, "MusicSevice onBind()" , Toast.LENGTH_SHORT).show(); Log.e(TAG, "MusicSerice onBind()"); mPlayer.start(); return null; } //其它對(duì)象通過(guò)unbindService方法通知該Service時(shí)該方法被調(diào)用 @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 { //為日志工具設(shè)置標(biāo)簽 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); //定義點(diǎn)擊監(jiān)聽(tīng)器 OnClickListener ocl = new OnClickListener() { @Override public void onClick(View v) { //顯示指定 intent所指的對(duì)象是個(gè) service Intent intent = new Intent(MusicServiceActivity.this,MusicService.class); switch(v.getId()){ case R.id.startMusic: //開(kāi)始服務(wù) startService(intent); break; case R.id.stopMusic: //停止服務(wù) stopService(intent); break; case R.id.bindMusic: //綁定服務(wù) bindService(intent, conn, Context.BIND_AUTO_CREATE); break; case R.id.unbindMusic: //解綁服務(wù) unbindService(conn); break; } } }; //綁定點(diǎn)擊監(jiān)聽(tīng) btnStart.setOnClickListener(ocl); btnStop.setOnClickListener(ocl); btnBind.setOnClickListener(ocl); btnUnbind.setOnClickListener(ocl); } //定義服務(wù)鏈接對(duì)象 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配置文件中添加對(duì)Service的注冊(cè)。即在application節(jié)點(diǎn)中添加
<service android:name=".MusicService"/> 進(jìn)行注冊(cè)。
[6] 我們來(lái)看下程序運(yùn)行后的Log.e中顯示的Service生命周期
[7] 我們?cè)贏ndroid終端設(shè)備中查看下剛才啟動(dòng)的音樂(lè)播放服務(wù),看看我們退出程序后,是不是該程序的服務(wù)還在運(yùn)行的呢?按如下步驟:Menu --> Settings --> Applications --> Running services 。在彈出的 Running services 中可以看到有哪些服務(wù)在運(yùn)行。
這樣我們就看到我們退出程序后,是由于該服務(wù)還在后臺(tái)運(yùn)行著,所以我們的音樂(lè)還可以繼續(xù)播放著。就這樣,我們就可以一邊享受音樂(lè),一邊可以聊QQ,或者瀏覽新聞等等。
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
- Android入門之Service的使用詳解
- Android?NotificationListenerService通知監(jiān)聽(tīng)服務(wù)使用
- Android Google AutoService框架使用詳解
- Android使用Service實(shí)現(xiàn)IPC通信的2種方式
- 說(shuō)說(shuō)在Android如何使用服務(wù)(Service)的方法
- 淺談Android中Service的注冊(cè)方式及使用
- Android編程使用Service實(shí)現(xiàn)Notification定時(shí)發(fā)送功能示例
- Android 通知使用權(quán)(NotificationListenerService)的使用
- Android Service功能使用示例代碼
相關(guān)文章
android計(jì)算pad或手機(jī)的分辨率/像素/密度/屏幕尺寸/DPI值的方法
本文將介紹手機(jī)布局/界面設(shè)計(jì)/分辨率/密度相關(guān),接下來(lái)介紹android計(jì)算pad或手機(jī)的分辨率像素等等的方法,感興趣的朋友可以了解下,希望本文可以幫助你2013-01-01Android Studio項(xiàng)目中導(dǎo)入開(kāi)源庫(kù)的方法
這篇文章主要介紹了Android Studio項(xiàng)目中導(dǎo)入開(kāi)源庫(kù)的方法,即使用第三方庫(kù)、第三廣場(chǎng)框架的方法,需要的朋友可以參考下2015-06-06在android開(kāi)發(fā)中進(jìn)行數(shù)據(jù)存儲(chǔ)與訪問(wèn)的多種方式介紹
很多時(shí)候我們的軟件需要對(duì)處理后的數(shù)據(jù)進(jìn)行存儲(chǔ)或再次訪問(wèn),Android為數(shù)據(jù)存儲(chǔ)提供了多種方式,首先給大家介紹使用文件如何對(duì)數(shù)據(jù)進(jìn)行存儲(chǔ),感興趣的朋友可以了解下哈2013-06-06Android7.0 MTK設(shè)置默認(rèn)桌面
這篇文章主要為大家詳細(xì)介紹了Android7.0 MTK設(shè)置默認(rèn)桌面,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2019-07-07Android編程中Handler原理及用法實(shí)例分析
這篇文章主要介紹了Android編程中Handler用法,結(jié)合實(shí)例形式分析了Handler的功能,原理及使用技巧,需要的朋友可以參考下2016-01-01Android開(kāi)發(fā)實(shí)現(xiàn)的IntentUtil跳轉(zhuǎn)多功能工具類【包含視頻、音頻、圖片、攝像頭等操作功能】
這篇文章主要介紹了Android開(kāi)發(fā)實(shí)現(xiàn)的IntentUtil跳轉(zhuǎn)多功能工具類,該封裝類還包含視頻、音頻、圖片、攝像頭等操作功能,需要的朋友可以參考下2017-11-11基于Flutter實(shí)現(xiàn)圖片選擇和圖片上傳
Flutter?的圖片選擇插件很多,包括了官方的?image_picker,multi_image_picker(基于2.0出了?multi_image_picker2)等等。本文將利用這些插件實(shí)現(xiàn)圖片選擇和圖片上傳,需要的可以參考一下2022-03-03