android插件化-apkplug框架启动-02
2014-09-21 10:57
260 查看
本文章基于apkplugv1.6.7版本号编写,最新方式以官网最新消息为准
一apkplug框架所须要的库文件(宿主)可从http://git.oschina.net/plug/apkplugSDK获取最新库文件
同一时候可下载最新的apkplugdemo源代码http://git.oschina.net/plug/apkplugDemos
libs--
--libndkfoo.soarmeabiarmeabi-v7amipsx86
--Bundle(版本).jar
将以上的文件增加宿主应用的libs文件夹下
二AndroidManifest.xml权限配置
插件平台须要几个基础的权限配置,请将下面的几个权限增加到project的AndroidManifest.xml中
<!--插件平台须要的权限!-->
<uses-permissionandroid:name="android.permission.WRITE_EXTERNAL_STORAGE"></uses-permission>
<uses-permissionandroid:name="android.permission.MOUNT_UNMOUNT_FILESYSTEMS"/>
<uses-permissionandroid:name="android.permission.INTERNET"/>
另外将一下增加到<application></application>节点中
<!--插件平台须要的配置!-->
<activity
android:name="org.apkplug.app.apkplugActivity"
android:theme="@style/android:Theme.Light"
android:configChanges="orientation|keyboardHidden"
/>
三启动apkplug框架
你能够在应用的Application中启动框架详细代码例如以下(并不限制在Application中)
publicFrameworkInstancestart(ListactivatorList,ContextappContext,PropertyInstanceproperty)
publicFrameworkInstancestart(ListactivatorList,ContextappContext,PropertyInstanceproperty,DisplayMetricsdm2)
1.activatorList是一个BundleActivator的List(能够为null)这些BundleActivator在框架启动时启动(系统级别)
2.PropertyInstance框架保存配置信息的接口
//框架通过该接口获取本地保存的变量
publicStringgetProperty(Stringkey);//框架通过该接口设置本地变量
publicvoidsetProperty(Stringkey,Stringv);//框架启动时将自己主动安装该该函数提供的文件"file:"+apk文件路径(1.6.7以后不建议使用可用BundleControl取代)
publicString[]AutoInstall();//框架启动时将自己主动安装并启动该该函数提供的文件"file:"+apk文件路径(1.6.7以后不建议使用可用BundleControl取代)
publicString[]AutoStart();//调试模式调试模式中退出APP时调用FrameworkInstance.shutdown();将删除全部插件
publicbooleanDebug();
四框架启动成功获取FrameworkInstance接口
框架启动成功以后会返回org.apkplug.app.FrameworkInstance接口,它是宿主应用与apkplug框架和插件通信的接口。
//停止框架
publicvoidshutdown();//获取框架的SystemBundleapkplug框架启动时会创建一个SystemBundle它的BundleID为0同一时候它不可停止和卸载,我们科通过它与其它插件通信
publicBundlegetSystemBundle();//SystemBundle插件的上下文BundleContext
publicBundleContextgetSystemBundleContext();
启动代码:
viewsource
print?
至此框架便嵌入到应用中并启动成功了,下一篇文章将解说如何通过SystemBundle获取已插件和信息等操作
一apkplug框架所须要的库文件(宿主)可从
同一时候可下载最新的apkplugdemo源代码
libs--
--libndkfoo.soarmeabiarmeabi-v7amipsx86
--Bundle(版本).jar
将以上的文件增加宿主应用的libs文件夹下
二AndroidManifest.xml权限配置
插件平台须要几个基础的权限配置,请将下面的几个权限增加到project的AndroidManifest.xml中
<!--插件平台须要的权限!-->
<uses-permissionandroid:name="android.permission.WRITE_EXTERNAL_STORAGE"></uses-permission>
<uses-permissionandroid:name="android.permission.MOUNT_UNMOUNT_FILESYSTEMS"/>
<uses-permissionandroid:name="android.permission.INTERNET"/>
另外将一下增加到<application></application>节点中
<!--插件平台须要的配置!-->
<activity
android:name="org.apkplug.app.apkplugActivity"
android:theme="@style/android:Theme.Light"
android:configChanges="orientation|keyboardHidden"
/>
三启动apkplug框架
你能够在应用的Application中启动框架详细代码例如以下(并不限制在Application中)
publicFrameworkInstancestart(ListactivatorList,ContextappContext,PropertyInstanceproperty)
publicFrameworkInstancestart(ListactivatorList,ContextappContext,PropertyInstanceproperty,DisplayMetricsdm2)
1.activatorList是一个BundleActivator的List(能够为null)这些BundleActivator在框架启动时启动(系统级别)
2.PropertyInstance框架保存配置信息的接口
//框架通过该接口获取本地保存的变量
publicStringgetProperty(Stringkey);//框架通过该接口设置本地变量
publicvoidsetProperty(Stringkey,Stringv);//框架启动时将自己主动安装该该函数提供的文件"file:"+apk文件路径(1.6.7以后不建议使用可用BundleControl取代)
publicString[]AutoInstall();//框架启动时将自己主动安装并启动该该函数提供的文件"file:"+apk文件路径(1.6.7以后不建议使用可用BundleControl取代)
publicString[]AutoStart();//调试模式调试模式中退出APP时调用FrameworkInstance.shutdown();将删除全部插件
publicbooleanDebug();
四框架启动成功获取FrameworkInstance接口
框架启动成功以后会返回org.apkplug.app.FrameworkInstance接口,它是宿主应用与apkplug框架和插件通信的接口。
//停止框架
publicvoidshutdown();//获取框架的SystemBundleapkplug框架启动时会创建一个SystemBundle它的BundleID为0同一时候它不可停止和卸载,我们科通过它与其它插件通信
publicBundlegetSystemBundle();//SystemBundle插件的上下文BundleContext
publicBundleContextgetSystemBundleContext();
启动代码:
01 | try |
02 | { |
03 | FrameworkInstanceframe=FrameworkFactory.getInstance().start( null ,Launcher. this ,MyProperty.getInstance( this .getApplicationContext())); |
04 | } catch (Exceptionex){ |
05 | System.err.println( "Couldnotcreate:" +ex); |
06 | ex.printStackTrace(); |
07 | StringBufferbuf= new StringBuffer(); |
08 | buf.append( "插件平台启动失败:\n" ); |
09 | buf.append(ex.getMessage()); |
10 | Toast.makeText( this , "插件平台启动失败" ,Toast.LENGTH_SHORT).show(); |
11 | } |
相关文章推荐
- android插件化-apkplug框架启动-02
- android插件化-apkplug框架基本结构-01
- android插件化-apkplug从宿主启动插件Activity-06
- android插件化-获取apkplug框架已安装插件-03
- android插件化-apkplug从宿主启动插件Activity-06
- android插件化-获取apkplug框架已安装插件-03
- [置顶] 滴滴开源Android插件化框架VirtualAPK原理分析
- 《Android 插件化框架VirtualAPK :(二)原理分析》
- Android Small插件化框架--启动插件Activity源码解析(上)
- android利用apkplug框架实现主应用与插件通讯(传递随意对象)实现UI替换
- Android 插件化框架 DynamicLoadApk 源码解析
- android 插件化 模块化开发(apkplug)
- Android Small插件化框架--启动插件Activity源码解析(上)
- android插件化-apkplugdemo源代码阅读指南-10
- android使用apkplug实现插件化开发
- android插件化-安装apkplug插件-04
- android插件化-apkplug中以监听方式获取OSGI服务-09
- android插件化-apkplug中OSGI服务基本原理-08
- android利用apkplug框架实现主应用与插件通讯(传递任意对象)实现UI替换
- 使用apkplug实现Android客户端插件化