Android启动内置APK和动态发送接收自定义广播实例详解
android启动内置apk和动态发送接收自定义广播实例详解
工作中遇到这样一个需求,需要为按键添加一个亲情号,提供一个接口启动内置的apk,思考再三决定更改framework,利用广播机制去实现。
一、代码动态自主启动内置apk
我们都知道android系统为我们提供了很多服务管理类,packagemanager主要是管理应用程序包,通过它就可以获取应用程序信息并构建intent,启动对应的应用。除此之外android还未我们提供了一些对应的类来管理相关的xml文件,比如说可以通过packageinfo来获取androidmanifest.xml文件的信息;packageiteminfo——androidmanifest.xml文件中所有节点的基类,提供了这些节点的基本信息比如label、icon、 meta-data。但它并不直接使用,而是由子类继承然后调用相应方法;applicationinfo继承自 packageiteminfo用于获取一个特定程序中节点的信息,比如常见的字段:flags字段: **flag_system 系统应用程序、flag_external_storage 表示该应用安装在sdcard中;activityinfo也继承自 packageiteminfo用于获得应用程序中或者 节点的信息 。我们可以通过它来获取我们设置的任何属性比如:theme 、launchmode、launchmode等,还有serviceinfo与activityinfo类似,只不过是用于获取节点的信息;最后一个resolveinfo是基于节点来获取其上一层目录的信息,比如说、、节点信息。
1、packagemanager简介
packagemanager主要用于管理应用程序包,获取程序中所安装的应用程序包的相关信息,而且是一个抽象类,但是我们可以通过getpackagemanager()方法来获取packagemanager对象。
2、代码实现
包名和mainactivity未知时:
/* ** @param packagename 将要去启动第三方app的package */ private void runappbypackage(@nonnull string packagename) { packageinfo packageinfo = null; packagemanager packagemanager=getpackagemanager();//获取packagemanager对象 try { packageinfo = packagemanager.getpackageinfo(packagename, 0);//通过包名获取packinfo } catch (packagemanager.namenotfoundexception e) { e.printstacktrace(); } intent resolveintent = new intent(intent.action_main, null); resolveintent.addcategory(intent.category_launcher); resolveintent.setpackage(packageinfo.packagename); list<resolveinfo> apps = packagemanager.queryintentactivities(resolveintent, 0); resolveinfo resolveinfo = apps.iterator().next(); if (resolveinfo != null ) { string pkgename = resolveinfo.activityinfo.packagename; string classname = resolveinfo.activityinfo.name; intent intent = new intent(intent.action_main); intent.addcategory(intent.category_launcher); componentname cn = new componentname(pkgename, classname); intent.setcomponent(cn); startactivity(intent); } }
包名和mainactivity已知时:
private void startlenoveplan(){ componentname componetname = new componentname( "com.lenovo.ue.service", "com.lenovo.ue.service.lenovoueserviceactivity"); try { intent intent = new intent(); intent.setcomponent(componetname); startactivity(intent); } catch (exception e) { } }
**二、动态发送和接收广播
1、发送自定义广播**
intent intent = new intent("android.intent.action.cart_broadcast_silent"); mcontext.sendbroadcast(intent);
2、定义广播接收器并处理
private static string broadcast_filter="android.intent.action.cart_broadcast_silent"; private audiomanager maudiomanager=(audiomanager) (getactivity().getapplicationcontext().getsystemservice(context.audio_service)); private broadcastreceiver zenmodereceiver = new broadcastreceiver() { //定义接收广播接收器 @override public void onreceive(context contex, intent intent) { string action = intent.getaction(); preferencescreen sound = (preferencescreen) findpreference("hq_ringtone_volume_settings"); if (action.equals(broadcast_filter)) { int ringmode = maudiomanager.getringermode(); if (ringmode == audiomanager.ringer_mode_silent) { if (findpreference(key_ring_volume) != null && findpreference(key_notification_volume) != null) { ((volumeseekbarpreference) findpreference(key_ring_volume)).setseekbarstatus(false, 0); } } else { if (findpreference(key_ring_volume) != null && findpreference(key_notification_volume) != null) { findpreference(key_ring_volume).setenabled(false); } } } } };
3、注册广播接收器
@override public void oncreate(bundle icicle) { super.oncreate(icicle); addpreferencesfromresource(r.xml.hq_volume_fragment_prefs); initvolume(getpreferencescreen()); intentfilter intent = new intentfilter(); intent.addaction(broadcast_filter); getactivity().getapplicationcontext().registerreceiver(zenmodereceiver,intent);// 注册广播接收器 }
4、使用完毕之后记得释放掉广播,否则会有oom的隐患
unregisterreceiver(receiver);
这是最简单的内置apk和发送广播方式,
感谢阅读,希望能帮助到大家,谢谢大家对本站的支持!