我有一个应用程序,用户可以在其中调用自定义锁定屏幕来锁定他/她的手机,这是一个名为LockScreen.class的活动。
加载此屏幕的屏幕之一,即设备已锁定,名为SharedPreferencesIsLocked被分配为true。
一旦用户使用锁定屏幕执行了所需的操作,此islocked就会变为假,并且移动设备将恢复正常。

一切都按预期进行。

问题是,如果出于某种原因在lock屏幕处于活动状态时已重新启动了移动设备,则它在重新启动后不会重新运行。

因此,我创建了一个BootReciever,如下所示,在重新启动过程完成后,它仍然可以正常工作,并且用户可以在加载之前做很多事情,我的问题是how can I make it loaded faster?,以便移动屏幕再次被锁定定制活动之前,用户是否有机会使用手机进行任何操作?

public class BootReciever extends BroadcastReceiver
{

    SharedPreferences mPrefs;
    final String IsLockedPref = "IsLocked";

    @Override
    public void onReceive(Context context, Intent intent) {

        mPrefs = PreferenceManager.getDefaultSharedPreferences(context);
        Boolean islocked = mPrefs.getBoolean(IsLockedPref, false);

        Intent i;
        if (islocked)
            i = new Intent(context, LockScreen.class);
        else
            i = new Intent(context, MainActivity.class);

        i.setFlags(Intent.FLAG_ACTIVITY_NEW_TASK);
        context.startActivity(i);
    }
}


清单文件的一部分是:

<receiver android:name=".BootReciever"
          android:enabled="true"
          android:exported="true">
     <intent-filter >
            <action android:name="android.intent.action.BOOT_COMPLETED"/>
            <action android:name="android.intent.action.QUICKBOOT_POWERON" />
     </intent-filter>
</receiver>

<uses-permission android:name="android.permission.RECEIVE_BOOT_COMPLETED" />


更新

我尝试通过添加以下内容来授予Device Admin来使用this,但没有任何改善:

在主要活动中:

    private static final int ADMIN_INTENT = 15;
    private static final String description = "Some Description About Your Admin";
    private DevicePolicyManager mDevicePolicyManager;
    private ComponentName mComponentName;

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);

       mDevicePolicyManager = (DevicePolicyManager)getSystemService(
                this.DEVICE_POLICY_SERVICE);
        mComponentName = new ComponentName(this, AdminReceiver.class);
        Intent intent = new Intent(DevicePolicyManager.ACTION_ADD_DEVICE_ADMIN);
        intent.putExtra(DevicePolicyManager.EXTRA_DEVICE_ADMIN, mComponentName);
        intent.putExtra(DevicePolicyManager.EXTRA_ADD_EXPLANATION,description);
        startActivityForResult(intent, ADMIN_INTENT);
.
.
}

    @Override
    protected void onActivityResult(int requestCode, int resultCode, Intent data) {
        if (requestCode == ADMIN_INTENT) {
            if (resultCode == RESULT_OK) {
                Toast.makeText(getApplicationContext(), "Registered As Admin", Toast.LENGTH_SHORT).show();
            }else{
                Toast.makeText(getApplicationContext(), "Failed to register as Admin", Toast.LENGTH_SHORT).show();
            }
        }
    }


并创建了空接收器以将DeviceAdminReceiver扩展为:

public class AdminReceiver extends DeviceAdminReceiver {

}


并将以下内容添加到清单中:

<receiver
    android:name="AdminReceiver"
    android:permission="android.permission.BIND_DEVICE_ADMIN">
    <meta-data
        android:name="android.app.device_admin"
        android:resource="@xml/admin"/>

    <intent-filter>
        <action android:name="android.app.action.DEVICE_ADMIN_ENABLED" />
    </intent-filter>
</receiver>

最佳答案

您可以做的一件事是为intent-filter设置优先级。来自documentation


  它控制执行广播接收器以接收广播消息的顺序。具有较高优先级值的那些优先于具有较低优先级的那些。


<intent-filter
    android:priority="100">
        ...
</intent-filter>



  该值必须是整数,例如“ 100”。数字越高优先级越高。缺省值为0。该值必须大于-1000并且小于1000。

07-28 04:03
查看更多