Android 4.0及以上如果想接受系统广播至少要先运行程序一次。(其实Android 3.1就开始了,这么说是为了针对我们开发最多android 4.0);这样是是为了防止开机启动恶意程序,优化启动。(防止病毒等开机启动程序危害系统,所以andoird4.0不允许没有被用户手动启动过的程序进行开机启动);Android 4.0 无法接收开机广播的问题本身是因为,如果应用程序安装上始终没有被打开过,那么在Android启动时,该应用无法接收到开机时的系统广播android.permission.RECEIVE_BOOT_COMPLETED。经过验证发现,系统级的应用程序是可以接收到开机启动广播的。
该平台定义了两个新的Intent的Flag,控制发送者指定的Intent是否应该被允许激活停止的应用程序的组件。
?FLAG_INCLUDE_STOPPED_PACKAGES -包括在停止的应用程序列表中。
?FLAG_EXCLUDE_STOPPED_PACKAGES -排除在停止的应用程序列表中。
当两个Flag都不设置或都设置的时候,默认操作是FLAG_INCLUDE_STOPPED_PACKAGES。请注意,系统会将FLAG_EXCLUDE_STOPPED_PACKAGES添加到所有的广播Intent中去。它这样做是为了防止广播无意中的或不必要地开展组件的stoppped应用程序的后台服务。后台服务或应用程序可以通过向广播Intent添加FLAG_INCLUDE_STOPPED_PACKAGES标志来唤醒处于停止状态(stopped state)的应用程序。
<!-- 获取获得系统开机的广播的权限 ,当Android系统完成BOOT阶段之后,就会发出开机广播 -->
<uses-permission android:name="android.permission.RECEIVE_BOOT_COMPLETED" />
开机自启动很简单。不过首先需要明确一点:没有Activity的Android程序,是启动不了滴,不过,你可以指定一个Activity,或者,指定一个桌面挂件呀,就是Widgets,知道吧?
那么,我们就有两种方法来实现你的功能:
第一,写一个很简单的程序,就一个Activity,指此Activity标题栏去掉,背景全透明,然后在此Activity的OnCreate将自己finish()掉,什么都不用干,只要在Manifest.xml中申明开机服务就OK,然后在程序内部响应此开机服务。
第二,不要Activity了,直接将程序写成一个Widgets……
该平台定义了两个新的Intent的Flag,控制发送者指定的Intent是否应该被允许激活停止的应用程序的组件。
?FLAG_INCLUDE_STOPPED_PACKAGES -包括在停止的应用程序列表中。
?FLAG_EXCLUDE_STOPPED_PACKAGES -排除在停止的应用程序列表中。
当两个Flag都不设置或都设置的时候,默认操作是FLAG_INCLUDE_STOPPED_PACKAGES。请注意,系统会将FLAG_EXCLUDE_STOPPED_PACKAGES添加到所有的广播Intent中去。它这样做是为了防止广播无意中的或不必要地开展组件的stoppped应用程序的后台服务。后台服务或应用程序可以通过向广播Intent添加FLAG_INCLUDE_STOPPED_PACKAGES标志来唤醒处于停止状态(stopped state)的应用程序。
<!-- 获取获得系统开机的广播的权限 ,当Android系统完成BOOT阶段之后,就会发出开机广播 -->
<uses-permission android:name="android.permission.RECEIVE_BOOT_COMPLETED" />
开机自启动很简单。不过首先需要明确一点:没有Activity的Android程序,是启动不了滴,不过,你可以指定一个Activity,或者,指定一个桌面挂件呀,就是Widgets,知道吧?
那么,我们就有两种方法来实现你的功能:
第一,写一个很简单的程序,就一个Activity,指此Activity标题栏去掉,背景全透明,然后在此Activity的OnCreate将自己finish()掉,什么都不用干,只要在Manifest.xml中申明开机服务就OK,然后在程序内部响应此开机服务。
第二,不要Activity了,直接将程序写成一个Widgets……