編輯:關於Android編程
package com.demo.internet.musicapp; import android.app.Service; import android.content.Intent; import android.os.IBinder; import android.util.Log; /** * Created by monster on 2015/7/2. * 通過Start方式啟動服務,這種服務的特點: * 1.服務跟啟動源沒有任何聯系 * 2.無法得到服務對象 */ public class MusicService extends Service { @Override public void onCreate() { Log.i("info", "Service--onCreate()"); super.onCreate(); } @Override public IBinder onBind(Intent intent) { Log.i("info", "Service--onBind()"); return null; } @Override public int onStartCommand(Intent intent, int flags, int startId) { Log.i("info", "Service--onStartCommand()"); return super.onStartCommand(intent, flags, startId); } @Override public void onDestroy() { Log.i("info", "Service--onDestroy()"); super.onDestroy(); } }
調用: intent1 =new Intent(MainActivity.this, MyStartService.class); startService(intent1); startActivity ------------------------------------------------------------------------------------------------------------------------------------------- 下面小編通過使用bindService方式來實現播放音樂的demo ①.布局不予講述 ②.創建BindMusicService.java 繼承Service ,並且進行注冊
package com.demo.internet.musicapp; import android.app.Service; import android.content.Intent; import android.content.ServiceConnection; import android.media.MediaPlayer; import android.os.Binder; import android.os.IBinder; import android.util.Log; /** * Created by monster on 2015/7/2. * 方式特點: * 1.通過Ibinder接口實例,返回一個ServiceConnection對象給啟動源 * 2.通過ServiceConnection對象的相關方法可以得到Service對象 */ public class BindMusicService extends Service { private MediaPlayer mPlayer; //聲明一個mediaPlayer對象 @Override public IBinder onBind(Intent intent) { Log.i("info", "BindService--onBind()"); return new MyBinder(); } @Override public void unbindService(ServiceConnection conn) { Log.i("info", "BindService--unbindService()"); super.unbindService(conn); } @Override public void onCreate() { Log.i("info", "BindService--onCreate()"); super.onCreate(); mPlayer=MediaPlayer.create(getApplicationContext(),R.raw.meizu_music); //實例化對象 //設置可以重復播放 mPlayer.setLooping(true); } @Override public void onDestroy() { Log.i("info", "BindService--onDestroy()"); super.onDestroy(); mPlayer.stop(); } //必須通過繼承Binder的方式才可以獲得binderService服務 public class MyBinder extends Binder{ public BindMusicService getService(){ return BindMusicService.this; } } public void Play(){ Log.i("info", "播放"); mPlayer.start(); } public void Pause(){ Log.i("info", "暫停"); mPlayer.pause(); } }
③. 在MainActivity中創建ServiceConnection接口並且實現未實現的方法,然後創建BindMusicService的聲明,調用的時候bindService方法進行調用
package com.demo.internet.musicapp; import android.app.Activity; import android.content.ComponentName; import android.content.Intent; import android.content.ServiceConnection; import android.os.Bundle; import android.os.IBinder; import android.view.View; import android.widget.Button; import android.widget.Toast; public class MainActivity extends Activity implements View.OnClickListener{ private Button btn_start,btn_stop,bind_btn_start,bind_btn_stop,bind_btn_play,bind_btn_pause; Intent intent1; Intent intent2; BindMusicService service; ServiceConnection con=new ServiceConnection() { @Override public void onServiceConnected(ComponentName name, IBinder binder) { //當服務跟啟動源連接的時候 會自動回調 service=((BindMusicService.MyBinder)binder).getService(); } @Override public void onServiceDisconnected(ComponentName name) { //當服務跟啟動源斷開的時候 會自動回調 } }; @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_main); initView(); } private void initView() { btn_start= (Button) findViewById(R.id.btn_start); btn_stop= (Button) findViewById(R.id.btn_stop); bind_btn_start= (Button) findViewById(R.id.bind_btn_start); bind_btn_stop= (Button) findViewById(R.id.bind_btn_stop); bind_btn_play= (Button) findViewById(R.id.bind_btn_play); bind_btn_pause= (Button) findViewById(R.id.bind_btn_pause); //綁定監聽事件 btn_start.setOnClickListener(this); btn_stop.setOnClickListener(this); bind_btn_start.setOnClickListener(this); bind_btn_stop.setOnClickListener(this); bind_btn_play.setOnClickListener(this); bind_btn_pause.setOnClickListener(this); } @Override public void onClick(View v) { switch (v.getId()){ case R.id.btn_start: //intent1=new Intent(MainActivity.this,MusicService.class); //startService(intent1); break; case R.id.btn_stop: //stopService(intent1); break; case R.id.bind_btn_start: intent2=new Intent(MainActivity.this,BindMusicService.class); bindService(intent2,con,BIND_AUTO_CREATE);//綁定服務 break; case R.id.bind_btn_play: service.Play(); break; case R.id.bind_btn_pause: service.Pause(); break; case R.id.bind_btn_stop: unbindService(con);//解除綁定服務 break; } } }
一、前言在Android客戶端開發中,使用網絡請求是非常常見的事情,一般我們使用HttpURLConnection是可以滿足需求的,不過隨著業務邏輯復雜,依然還是有很多不
為什麼要修改路徑呢……因為我之前裝過Eclipse,也裝過Android SDK,但是昨天裝Android Studio的時候不小心又裝了一個
最近在做一個歪果仁給我外包的項目,主頁需要做一個類似於IOS那種上拉菜單的功能,於是一時間試了各種方法,什麼Spinner、Drawlayout,SlidingMenu等
本文實例講述了Android實現多線程下載文件的方法。分享給大家供大家參考。具體如下:多線程下載大概思路就是通過Range 屬性實現文件分段,然後用RandomAcces