【问题标题】:Airplane Mode Receiver in Manifest?清单中的飞行模式接收器?
【发布时间】:2013-02-21 10:51:31
【问题描述】:

我正在开发一款 Android 应用程序,该应用程序将用作工业环境中的手持控制器。为了让平板电脑不太适合带回家,我打算一直尝试以编程方式打开飞行模式,但在 4.2 中已弃用,这也是我们使用 Android Open Accessory 的版本。但是我在想,如果我可以在清单中注册一个接收器,这样它就会在更改飞行模式时启动我的应用程序,然后检查它是否已关闭并提示用户重新打开它。

我尝试了以下解决方案,也找到了this问题的答案。

<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 here 发现为 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 ATTACHEDMAIN 启动器工作正常,并从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;
        }
    }
};

但据我了解,这仅在应用程序运行时注册,我想要一个即使在应用程序未运行时也注册的接收器。

【问题讨论】:

  • 是的,它可能的用途
  • @DjHacktorReborn 我需要有任何uses-permission 标签吗?谢谢。
  • @DjHacktorReborn 谢谢你的回答,但是当飞行模式改变时,这似乎并没有启动我的应用程序。
  • 贴出需要更换的接收器
  • 我已经发布了我的完整清单文件

标签: android android-intent airplane


【解决方案1】:

通过更好地理解Intents 和XML 定义的接收器,我能够弄清楚这一点。这仅在 API 17 上进行了测试。这是清单的代码:

<receiver android:name="com.example.i2c.AirplaneModeReceiver">
     <intent-filter>
         <action android:name="android.intent.action.AIRPLANE_MODE"/>
     </intent-filter>
</receiver>

然后创建一个名为AirplaneModeReceiver的java类文件,并在其中放入以下内容:

public class AirplaneModeReceiver extends BroadcastReceiver {
   public void onReceive(Context context, Intent intent) {
       Intent startActivityIntent = new Intent(context, MainActivity.class);
       startActivityIntent.addFlags(Intent.FLAG_ACTIVITY_NEW_TASK);
       context.startActivity(startActivityIntent);
   }    
}

现在这将在飞行模式发生变化时启动活动,无论是打开还是关闭。自从切换到主屏幕启动器样式的应用程序后,我没有继续编写代码来检查飞行模式是否关闭,然后再开始活动。

【讨论】:

  • 任何人都可以确认上述是否适用于早期的 API 版本(例如 - Android 2.3),因为我有一个与上述相同的接收器,虽然类似的接收器工作正常,但飞行模式一没有'似乎根本没有触发,我也不知道为什么。
【解决方案2】:

这是接收者的 sn-p

public void onReceive(Context context, Intent intent) {
        if (intent.getAction().intern() == Intent.ACTION_AIRPLANE_MODE_CHANGED) {
// Launch your app here
}

【讨论】:

    猜你喜欢
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 2013-12-09
    • 2016-09-05
    • 2010-12-09
    • 2016-08-29
    • 1970-01-01
    • 1970-01-01
    相关资源
    最近更新 更多