私は、産業環境でハンドヘルドコントローラーとして使用されるAndroidアプリの開発に取り組んでいます。タブレットを家に持ち帰るのを難しくするために、私は常に機内モードをプログラムでオンにするつもりでしたが、これは4.2で非推奨になりました。これは、AndroidOpenAccessoryを使用するために使用しているバージョンでもあります。ただし、機内モードが変更されたときにアプリが起動するようにマニフェスト内に受信機を登録し、機内モードがオフになっているかどうかを確認して、ユーザーにオンに戻すように促すことができればと考えていました。
私はこの問題の答えとしても見つかった、次の解決策を試しました。
<uses-permission android:name="android.permission.ACCESS_NETWORK_STATE" />
<receiver android:name=".receiver.ConnectivityReceiver">
<intent-filter>
<action android:name="android.net.conn.CONNECTIVITY_CHANGE" />
</intent-filter>
</receiver>
私もこのコードを試しました:
<receiver android:enabled="true" android:name=".ConnectivityReceiver">
<intent-filter>
<action android:name="android.intent.action.SERVICE_STATE"/>
</intent-filter>
</receiver>
ここでsaxosによってaswerとしても見つかりました。
現在、これらのソリューションのいずれも、機内モードが変更されたときにアプリを起動させません。
マニフェストファイル内に機内モード用のBroadcaseReceiverを登録し、そのインテントでアプリを起動させることは可能ですか?
編集1:アプリがアクティブなときにこの状況を検出できるように、Javaコード内でBroadcastReceiverを動作させています。それは私が探しているものではありません。ありがとう。
編集2:これは現在私のマニフェストファイル全体です:
<?xml version="1.0" encoding="utf-8"?>
<manifest xmlns:android="http://schemas.android.com/apk/res/android"
package="com.example.i2c"
android:versionCode="1"
android:versionName="1.0" >
<uses-sdk
android:minSdkVersion="17"
android:targetSdkVersion="17"
android:maxSdkVersion="17"/>
<!-- SDK 14 = 4.0 ICS
SDK 17 = 4.2 JB -->
<!-- Assures software is not loaded onto unsupported screen size, i.e. phones -->
<supports-screens android:xlargeScreens="true"
android:largeScreens="true"
android:normalScreens="false"
android:smallScreens="false"
android:anyDensity="true"/>
<uses-feature android:name="android.hardware.usb.accessory"/>
<application
android:allowBackup="true"
android:icon="@drawable/ic_launcher"
android:label="@string/app_name"
android:theme="@style/AppTheme" >
<activity
android:name="com.example.i2c.mainActivity"
android:label="@string/app_name"
android:configChanges="keyboardHidden|orientation|screenSize"
android:launchMode="singleTask">
<intent-filter>
<action android:name="android.hardware.usb.action.USB_ACCESSORY_ATTACHED"/>
</intent-filter>
<intent-filter>
<action android:name="android.intent.action.MAIN" />
<category android:name="android.intent.category.LAUNCHER" />
</intent-filter>
<intent-filter>
<action android:name="android.intent.action.AIRPLANE_MODE" />
</intent-filter>
<meta-data android:name="android.hardware.usb.action.USB_ACCESSORY_ATTACHED"
android:resource="@xml/accessory_filter"/>
</activity>
</application>
USB_ACCESSORY ATTACHED
とMAIN
ランチャーは問題なく動作し、ある時点からアプリを起動しますonCreate
。しかし、AIRPLANE_MODE
は何もしていないようです。
そして、これがJavaコード内にある私のBroadcastReceiverです。
private final BroadcastReceiver mUsbReceiver = new BroadcastReceiver(){
@Override
public void onReceive(Context context, Intent intent) {
Log.d("I2CActivity", "onReceive of BroadcastReceiver()");
String action = intent.getAction();
if(ACTION_USB_PERMISSION.equals(action)) {
Log.d("ACTION_USB_PERMISSION", action.toString());
synchronized (this) {
Log.d("syncronized", this.toString());
UsbAccessory accessory = (UsbAccessory) intent.getParcelableExtra(UsbManager.EXTRA_ACCESSORY);
if(intent.getBooleanExtra(UsbManager.EXTRA_PERMISSION_GRANTED, false)) {
if (accessory != null) {
OpenAccessory(accessory);
}
}
else {
Log.d("mUsbReceiver", "permission denied for accessory " + accessory);
}
}
}
else if(UsbManager.ACTION_USB_ACCESSORY_ATTACHED.equals(action)) {
Log.d("ACTION_USB_ACCESSORY_ATTACHED", action.toString());
UsbAccessory accessory = (UsbAccessory)intent.getParcelableExtra(UsbManager.EXTRA_ACCESSORY);
if (accessory != null) {
resumeAccessory();
}
}
else if(UsbManager.ACTION_USB_ACCESSORY_DETACHED.equals(action)) {
Log.d("ACTION_USB_ACCESSORY_DETACHED", action.toString());
UsbAccessory accessory = (UsbAccessory)intent.getParcelableExtra(UsbManager.EXTRA_ACCESSORY);
if (accessory != null) {
closeAccessory();
}
}
else if(Intent.ACTION_AIRPLANE_MODE_CHANGED.equals(action)) {
Log.e("Airplane Mode", "Airplane mode changed");
airplaneMode = Settings.Global.getInt(context.getContentResolver(), Settings.Global.AIRPLANE_MODE_ON, 0) != 0;
}
}
};
しかし、私の理解では、これはアプリが実行されているときにのみ登録されるので、アプリが実行されていないときでも登録されるレシーバーが必要です。