Android-Native插件扩展机制.docx

上传人:枫** 文档编号:562709674 上传时间:2022-12-12 格式:DOCX 页数:10 大小:157.49KB
返回 下载 相关 举报
Android-Native插件扩展机制.docx_第1页
第1页 / 共10页
Android-Native插件扩展机制.docx_第2页
第2页 / 共10页
Android-Native插件扩展机制.docx_第3页
第3页 / 共10页
Android-Native插件扩展机制.docx_第4页
第4页 / 共10页
Android-Native插件扩展机制.docx_第5页
第5页 / 共10页
点击查看更多>>
资源描述

《Android-Native插件扩展机制.docx》由会员分享,可在线阅读,更多相关《Android-Native插件扩展机制.docx(10页珍藏版)》请在金锄头文库上搜索。

1、Appcan 2.0 Native插件扩展机制功能描述:Native插件机制,是指针对native 开发者封装将具有特定功能但是平台没有封装的接口,封装成js调用Native功能,然后通过js扩展接口调用,以达到功能扩展的目的。2.0的扩展机制与1.2扩展机制有所差别,增加了资源文件的添加,动态获取,Activity回调,自定义View到当前window,接口参数可任意定制等等。代码上,主要体现在EUExBase.java的变化,接口函数的参数个数由0个或者多个改为了1个数据类型为String数组的参数,即所有的扩展对象中的接口必须有且仅有一个参数(String),可在示例代码中查看到。And

2、roid SDKAppcan native插件SDK,由一个基础工程构成,主要包括引擎jar包,接口类,android工程资源文件夹res,插件配置xml,widget文件夹等等。详细描述:1. 引擎jar包AppCanEngine_xxx.jar位于工程目录的libs目录下,是利用appcan平台扩展native plugin的基础。2. 接口类主要包括以下3个:EUExBase.java:封装了JS调用native 以及native回调JS的桥接函数的父类,任何 扩展的对象均需要继承此类;EUExUtil.java:提供动态获取本应用资源id等功能的工具类。注意:Appcan中的 所有资源

3、文件,包括字符串资源等,都必须使用此工具类当中的相 关函数动态获取其资源ID,而不能直接使用R文件引用!具体如何 使用可在示例代码中看到。EUExCallback.java:与plugin的callback相关的一些常量。3. 资源文件夹(res文件夹)此文件夹中(包括子目录)已经定义或者命名的任何资源文件,不允许有任何重命名,删除等操作,这些资源文件属于AppCan平台所使用,一旦平台找不到相关资源文件,将报错退出。4. Error文件夹(assets目录下的error文件夹)error文件夹下存放网页访问错误时候显示的界面,必须拷贝到资源下,如果想定制自己的可以替换文件夹下资源但是不能修改

4、文件名称,有可能导致文件找不到,加载方式同图片资源5. plugin.xmlplugin.xml 文件位于res目录下的xml目录中,是配置自定义native Plugin调用对象的xml文件,如果需要自定义对象和开发natvie plugin,必须在此文件中配置自定义js对象名和java类的包名类名。6. widget 文件夹(assets目录下的widget文件夹)widget 文件夹为网页包,默认有config.xml 文件,基本数据已经默认填写,开发者只需修改部分参数即可,切勿删除config.xml 文件,widget文件也必须加载到工程中;配置工程1. 打开eclipse,将app

5、can android工程导入。如图: 等待eclipse自动编译完后,检查是否报错;如未报错,直接运行即可。其中:UexTestObject.java为自定义plugin的测试实例。API接口平台接入类平台的自带的生命周期函数进行了封装;JS调用Native plugin基础类-EUExBase.javaEUExBase对象成员描述:mBrwView: 由构造函数传入的继承了Webview并封装了appcan 平台接口的EBrowserView的对象实例;mContext:AppCan平台的上下文,AppCan主Activity的实例。EUExBase对象成员函数描述:- public vo

6、id jsCallback(String inCallbackName, int inOpCode, int inDataType, String inData)自定义对象完成一系列操作后回调网页js时的函数,其中:inCallbackName:网页中js函数的名称即所属js对象名称的集合。如:uexDemo.cbFunc1,即为uexDemo对象的func1函数被调用后,java回调js时的callback函数。inOpCode:网页中随机分配的不重复int类型的数值,主要用于区分一个js接口函数多次操作java中不同的对象。由网页调用native接口时传入。inDataType:本次回调网

7、页js时,传给js的数据的数据类型,可参考EUExCallback对象下的静态值:F_C_TEXT,F_C_JSON,F_C_INT,F_C_STATUS。inData:回调给页面js的值。- public void jsCallback(String inCallbackName, int inOpCode, int inDataType, int inData)同上。当返回的数据类型为F_C_INT等数值型时,需走这个callback。- public void errorCallback(int inOpCode, int inErrorCode, String inErrorInfo)

8、当调用接口发生错误时,java层通过此回调通知js。其中:inOpCode:同上inOpCode。inErrorCode:错误码,可自定义。inErrorInfo:返回给js的错误信息。- public void onCallback(String inScript)Java层延时主动回调js的函数。如GPS定位时,会有多次回调,可通过此接口回调。- public String getCookie(String inUrl)获取inUrl对应页面的cookie。- public void setCookie(String inUrl, String cookie)设置inUrl对应页面的coo

9、kie。- public abstract boolean clean()抽象函数,必须实现。当网页切换或者销毁时,AppCan会主动调用此函数,所以应该在此函数中做一些释放你占用的资源的操作。- public void startActivityForResult(Intent intent, int requestCode)运行一个Activity,并要求被运行的Activity在finish时有返回值.你的plugin中,如果需要运行另一个Activity,并且需要此Activity返回数据时,必须要通过此接口调用,返回的数据将通过onActivityResult函数回调,可在onAct

10、ivityResult函数中做相关处理。- public void startActivity(Intent intent)运行一个不需要返回值的Activity。- public void onActivityResult(int requestCode, int resultCode, Intent data)当自定义对象有startActivityForResult操作,目标Activity结束后返回结果时可通过重载这个函数回调。- public void addViewToCurrentWindow(View child, RelativeLayout.LayoutParams par

11、ms)添加一个你的自定义view覆盖到当前window中的最上层。- public void removeViewFromCurrentWindow(View child)从当前window移除一个你的自定义view。Plugin动态获取资源id及提供平台相关功能操作的工具类- EUExUtil.javaEUExUtil对象函数描述:-public static int getResDrawableID(String resName)获取DrawableI类型资源的id。-public static int getResLayoutID(String resName)获取Layout类型资源的

12、id。-public static int getResAnimID(String resName)获取Anim类型资源的id。-public static int getResAttrID(String resName)获取Attr类型资源的id。-public static int getResColorID(String resName)获取Color类型资源的id。-public static int getResDimenID(String resName)获取Dimen类型资源的id。-public static int getResIdID(String resName)获取Id

13、类型资源的id。-public static int getResRawID(String resName)获取Raw类型资源的id。-public static int getResStringID(String resName)获取String类型资源的id。-public static int getResStyleID(String resName)获取Style类型资源的id。-public static int getResXmlID(String resName)获取Xml类型资源的id。以上接口具体使用可参考SDK工程中的示例UexTestObject对象的定义,以及asset

14、s目录下,widget文件中index.html网页的书写。EUExCallback对象成员描述: EUExCallback对象为AppCan引擎为EUExBase配套提供的一个存放常量的类,包括回调js是,当传递数据为json数据时的key值,平台类型,传递给js的数据类型的描述等常量。Samples以下内容以扩展uexDemo对象为例,描述为appcan扩展一个native plugin 的开发流程:1. 配置plugin.xml :找到工程中res目录下的xml目录,在plugin.xml文件中配置你的扩展对象相关信息。(1)、配置自定义对象:示例对象uexDemo对象配置如下:uexN

15、ame: 为封装的js对象的名称,可任意命名;className: 与js对象映射的java对象的路径包名及类名;可定义多个plugin。(2)、定义与js对象映射的java类:此类必须继承自plugin的基础类:EUExBase,并实现或重写相关函数。新建java类UexTestObject.java并继承自EUExBase。其中:UexTestObject.java类似于下图:其中:所有接口函数的参数均为1个string数组。此数组的长度即为js传过来的参数个数,此数组的index与js中参数的index相对应。例如,在js中有类似调用:uexDemo. test_vibrator(p1,p2,p3,p4)那么,当它映射到UexTestObject.java的:public void test_vibrator(String parm)函数中时,parm

展开阅读全文
相关资源
相关搜索

当前位置:首页 > 生活休闲 > 社会民生

电脑版 |金锄头文库版权所有
经营许可证:蜀ICP备13022795号 | 川公网安备 51140202000112号