編輯:關於Android編程
public interface ICount {
public int getcount();
}
2.接下來我們需要一個Service的子類實現本接口,定義一個ServiceBinder的內部類,通過它的對象來綁定數據,要注意的是我們如果要進行耗時操作的話,仍然需要在Service中創建線程,Service自身就是運行在主線程中的。還有一個就是OnBind的返回值是IBinder,但是這裡我使用ServiceBinder對象是繼承Binder的,那為什麼這裡可以這麼寫呢?因為Binder是Base class for a remotable object, the core part of a lightweight remote procedure call mechanism defined by IBinder,是直接從IBinder這裡的直接子類。
public class BackGroundService extends Service implements ICount {
private boolean disable; //線程是否執行的標識位
private int count; //計數
private ServiceBinder serviceBinder = new ServiceBinder();
public class ServiceBinder extends Binder implements ICount {
@Override
public int getcount() {
// TODO Auto-generated method stub
return 0;
}
}
@Override
public IBinder onBind(Intent intent) {
// TODO Auto-generated method stub
return serviceBinder;
}
@Override
public void onCreate() {
// TODO Auto-generated method stub
super.onCreate();
new Thread(new Runnable() {
// @Override
public void run() {
while (!disable) {
try {
Thread.sleep(1000);
} catch (InterruptedException e) {
}
count++;
System.out.println("CountService Count is " + count);
}
}
}).start();
}
@Override
public int onStartCommand(Intent intent, int flags, int startId) {
// TODO Auto-generated method stub
return super.onStartCommand(intent, flags, startId);
}
@Override
public int getcount() {
return count;
// TODO Auto-generated method stub
}
@Override
public void onDestroy() {
// TODO Auto-generated method stub
this.disable = true;
// Log.v(" CountService ", " on destroy ");
System.out.println("Service destroy...");
super.onDestroy();
}
}
3.定義完了Service這一部分的內容,接下來就需要在AndroidManifest.xml中注冊了,需要注意的是這裡不僅要對我們包類的Service進行聲明,同時還需要聲明intent的過濾器
<service android:name="com.yqc.testservice.BackGroundService">
<intent-filter>
<action android:name="com.yqc.testservice.BackGroundService" />
</intent-filter>
</service>
4.定義完畢以後,接下來需要在Activity中的交互部分了,剛才在配置文件中定義的Intent的過濾器這裡就用到了,在bindService方法中,這就是他的一個參數,然後通過ServiceConnetion的對象與Service建立連接並取得後台的參數。
public class MainActivity extends Activity {
Button btn_start;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
this.bindService(new Intent("com.yqc.testservice.BackGroundService"),
this.serviceConnection, BIND_AUTO_CREATE);
btn_start = (Button) findViewById(R.id.btn_start);
btn_start.setOnClickListener(new OnClickListener() {
@Override
public void onClick(View v) {
// TODO Auto-generated method stub
}
});
}
@Override
protected void onDestroy() {
// TODO Auto-generated method stub
this.unbindService(serviceConnection);
System.out.println("Activity Destroy...");
super.onDestroy();
}
private ICount countentity;
private ServiceConnection serviceConnection = new ServiceConnection() {
@Override
public void onServiceConnected(ComponentName name, IBinder service) {
// TODO Auto-generated method stub
countentity = (ICount) service;
System.out.println(" CountService on serivce connected, count is "
+ countentity.getcount());
}
@Override
public void onServiceDisconnected(ComponentName name) {
// TODO Auto-generated method stub
countentity = null;
}
};
}
Android利用ObjectAnimator實現ArcMenu
本文介紹利用ObjectAnimator簡單地實現ArcMenu,直接使用本文的ArcMenu類即可快捷地實現菜單功能。 最終使用效果:先看下最終的使用效果:
Android使用開源框架Fresco處理圖片
關於Fresco的優點大家自行谷歌吧,它太強大太優秀了,我這一片小博文容納不下啊羨慕,今天主要給大家簡單介紹下Fresco的使用以及一些屬性的介紹。 Fresc
Android登陸界面實現-支持輸入框清楚和震動效果功能
演示效果主要代碼如下自定義的一個EditText,用於實現有文字的時候顯示可以清楚的按鈕:import android.content.Context;import an
Android Intent 序列化和反序列化
[java] view plaincopyprint? //序列化 intent.toURI(); //反序列 化使用: Inte