[英]Starting Android application at boot completion: is my solution overly complicated?
我有一個想要在啟動完成后自動啟動的應用程序。 以下代碼似乎過於復雜,滑動到相鄰工作區時,我的應用程序啟動不穩定。
我在這里想念什么? 我有一個活動類,一個服務類以及一個廣播接收器。 下面是我的代碼(按此順序),然后是清單。
public class BlueDoor extends Activity implements OnClickListener{
Button btnExit;
@Override
public void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
requestWindowFeature(Window.FEATURE_NO_TITLE);
getWindow().setFlags(WindowManager.LayoutParams.FLAG_FULLSCREEN,
WindowManager.LayoutParams.FLAG_FULLSCREEN);
setRequestedOrientation(ActivityInfo.SCREEN_ORIENTATION_PORTRAIT);
setContentView(R.layout.main);
btnExit = (Button) this.findViewById(R.id.ExitButton);
btnExit.setOnClickListener(this);
}
@Override
public void onClick(View v) {
switch (v.getId()) {
case R.id.ExitButton:
System.exit(0);
break;
}
}
}
服務類
public class BlueDoorStartService extends Service {
@Override
public IBinder onBind(Intent intent) {
return null;
}
@Override
public void onCreate() {
super.onCreate();
Toast.makeText(this, "Service Started", Toast.LENGTH_LONG).show();
Intent callIntent = new Intent(Intent.ACTION_CALL);
callIntent.setFlags(Intent.FLAG_ACTIVITY_NEW_TASK);
callIntent.setClass(this, BlueDoor.class);
startActivity(callIntent);
// do something when the service is created
}
}
廣播接收器
public class StartBlueDoorAtBootReceiver extends BroadcastReceiver {
@Override
public void onReceive(Context context, Intent intent) {
if (Intent.ACTION_BOOT_COMPLETED.equals(intent.getAction())) {
Intent serviceIntent = new Intent(context, BlueDoorStartService.class);
context.startService(serviceIntent);
}
}
}
Manifest.xml
<?xml version="1.0" encoding="utf-8"?>
<manifest xmlns:android="http://schemas.android.com/apk/res/android"
package="com.example.bluedoor"
android:versionCode="1"
android:versionName="1.0" >
<uses-permission android:name="android.permission.RECEIVE_BOOT_COMPLETED" />
<uses-sdk
android:minSdkVersion="8"
android:targetSdkVersion="21" />
<application
android:allowBackup="true"
android:icon="@drawable/ic_launcher"
android:label="@string/app_name"
android:theme="@style/AppTheme" >
<receiver
android:name=".StartBlueDoorAtBootReceiver"
android:enabled="true"
android:exported="false" >
<intent-filter>
<action android:name="android.intent.action.BOOT_COMPLETED" />
</intent-filter>
</receiver>
<service android:name=".BlueDoorStartService" >
</service>
<activity
android:name=".BlueDoor"
android:label="@string/app_name" >
<intent-filter>
<action android:name="android.intent.action.MAIN" />
<category android:name="android.intent.category.LAUNCHER" />
</intent-filter>
</activity>
</application>
更新解決方案,2015年10月22日:
將服務更改為:
public class BlueDoorStartService extends Service {
@Override
public IBinder onBind(Intent intent) {
throw new UnsupportedOperationException("Not yet implemented");
}
@Override
public void onCreate() {
super.onCreate();
}
@Override
public void onDestroy() {
super.onDestroy();
}
@Override
public int onStartCommand(Intent intent, int flags, int startId) {
return super.onStartCommand(intent, flags, startId);
}
}
接收方:
public class StartBlueDoorAtBootReceiver extends BroadcastReceiver {
@Override
public void onReceive(Context context, Intent intent) {
// Start Service On Boot Start Up
Intent serviceIntent = new Intent(context, BlueDoorStartService.class);
context.startService(serviceIntent);
//Start App On Boot Start Up
Intent App = new Intent(context, BlueDoor.class);
App.addFlags(Intent.FLAG_ACTIVITY_NEW_TASK);
context.startActivity(App);
}
}
導致使用服務的正常配置而不會出現任何錯誤行為。 但是 ,一起刪除服務並修改接收者:
public class StartBlueDoorAtBootReceiver extends BroadcastReceiver {
@Override
public void onReceive(Context context, Intent intent) {
Intent App = new Intent(context, BlueDoor.class);
App.addFlags(Intent.FLAG_ACTIVITY_NEW_TASK);
context.startActivity(App);
}
}
還導致了功能以及更簡潔的配置,這些配置可以在啟動完成后啟動應用程序。
您的BroadcastReceiver呼叫
context.startService(serviceIntent)
因此,如果服務尚不存在,則會創建該服務(啟動后不久就是這種情況),並因此從其onCreate()
方法啟動活動。 因此該應用在一定程度上可以正常工作。
但是,當您調用startService()
,系統始終會調用服務的onStartCommand()
方法。 您沒有重寫該方法,因此系統使用android.app.Service
類中的標准實現。
如您在grepcode.com上所讀 ,默認情況下,該方法將返回類似START_STICKY
的值。 這告訴系統將服務保持活動狀態,直到明確停止該服務為止。
對於您的情況,我想系統通過暫時終止然后重新設置服務的生命(即創建)來對刷卡做出反應,這反過來又開始了您的活動。
有關服務生命周期的一些信息可以在這里找到。
您可以做什么:覆蓋onStartCommand()
以從那里開始活動,而不是從onCreate()
。 然后使用stopSelf(int)
等中描述的在這里
最后一件事:從活動中退出時,請勿使用System.exit(0)
而是調用finish()
,請參閱此SO答案以了解“為什么” 。
聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.