Cordova 3.x 源码分析(7) -- CordovaLib概要
程序员文章站
2022-03-02 18:41:01
...
在http://rensanning.iteye.com/blog/2020843已经介绍过通过Cordova CLI创建Cordova工程。
Cordova生成的Android工程主要来自于以下目录:
其中所用的CordovaLib来自于以下目录:
从Cordova 3.3.0以后,方便调试,CordovaLib的提供形式从jar文件变成了Android Library。
参考:https://issues.apache.org/jira/browse/CB-5232
CordovaLib中的代码主要包括:
com.squareup.okhttp: 导入HTTP+SPDY客户端的OkHTTP,获取网络资源。
org.apache.cordova: 剩下的所有代码都在该包下(以前还有过org.apache.cordova.api)
基础类:
Webview相关:
Plugin相关:
无用类:
其他:
Android WebView由于版本的问题,存在很多局限和Bug,而Android 4.4开始默认搭载Google的最新渲染引擎Blink/Chromium。
①ChromeView使用Chromium代替WebView的一个实现,也有cordova-android-chromeview,不过更新比较慢。
②Intel Crosswalk构建于Chromium之上,提供更加丰富的功能。同时提供了crosswalk-cordova-android。
使用以上2中解决方案都能改善Webview的问题,但是同时你的apk文件的大小将增加20M左右。
程序入口:
启动序列图:
Plugin序列图:
Cordova生成的Android工程主要来自于以下目录:
引用
C:\Documents and Settings\RenSanNing\.cordova\lib\android\cordova\3.4.0\bin\templates\project
其中所用的CordovaLib来自于以下目录:
引用
C:\Documents and Settings\RenSanNing\.cordova\lib\android\cordova\3.4.0\framework
从Cordova 3.3.0以后,方便调试,CordovaLib的提供形式从jar文件变成了Android Library。
参考:https://issues.apache.org/jira/browse/CB-5232
CordovaLib中的代码主要包括:
com.squareup.okhttp: 导入HTTP+SPDY客户端的OkHTTP,获取网络资源。
org.apache.cordova: 剩下的所有代码都在该包下(以前还有过org.apache.cordova.api)
基础类:
- CordovaInterface.java CordovaActivity的接口(使plugin不依赖CordovaLib更独立)
- CordovaActivity.java 应用的主Activity需要继承自该类。
- Config.java 解析config.xml
- Whitelist.java 白名单列表
- LinearLayoutSoftKeyboardDetect.java 布局(检测软键盘)
Webview相关:
- CordovaWebView.java 核心Webview类
- CordovaWebViewClient.java 捕获Webview事件回调(2.x版本没有WebResourceResponse)
- IceCreamCordovaWebViewClient.java 在3.x、4.x版本中拦截网页中资源请求,比如js,css,img,ajax
- CordovaChromeClient.java 捕获JavaScript事件,其中onJsPrompt() 对应2.3模拟器的交互Bug
- AuthenticationToken.java Http请求的认证
- ScrollEvent.java 回传onScrollChanged事件坐标
- CordovaResourceApi.java 获取资源
Plugin相关:
- PluginManager.java 插件管理
- PluginEntry.java 插件实体
- CordovaPlugin.java Plugin的基类
- CordovaArgs.java 接收JSON参数
- PluginResult.java 执行结果
- CallbackContext.java 通过sendPluginResult回传结果
- ExposedJsApi.java JS桥接
- NativeToJsMessageQueue.java 回传结果的消息队列
无用类:
- DirectoryManager.java 3.1开始@Deprecated,移动了file的plugin中
- ExifHelper.java 3.1开始@Deprecated,移动了camera的plugin中
- FileHelper.java 3.1开始@Deprecated,移动了camera和file的plugin中
- JSONUtils.java 3.1开始@Deprecated,无用类
- DroidGap.java 2.7开始@Deprecated,DroidGap.java名字太难听,改成了CordovaActivity。参考:https://issues.apache.org/jira/browse/CB-2657
其他:
- App.java 清缓存、loadUrl、退出程序等的plugin(以后会被单做成一个plugin)
- LOG.java 日志util
Android WebView由于版本的问题,存在很多局限和Bug,而Android 4.4开始默认搭载Google的最新渲染引擎Blink/Chromium。
①ChromeView使用Chromium代替WebView的一个实现,也有cordova-android-chromeview,不过更新比较慢。
②Intel Crosswalk构建于Chromium之上,提供更加丰富的功能。同时提供了crosswalk-cordova-android。
使用以上2中解决方案都能改善Webview的问题,但是同时你的apk文件的大小将增加20M左右。
程序入口:
public class CordovaSample extends CordovaActivity { @Override public void onCreate(Bundle savedInstanceState) { // 读取config.xml,设置UI super.onCreate(savedInstanceState); // 初始化Webview后添加到UI中 super.init(); // 加载首页file:///android_asset/www/index.html // 其中index.html是在config.xml中配置的。 super.loadUrl(Config.getStartUrl()); } }
启动序列图:
Plugin序列图:
推荐阅读
-
Cordova 3.x 源码分析(7) -- CordovaLib概要
-
Cordova 3.x 源码分析(1) -- Cordova CLI
-
Cordova 3.x 源码分析(5) -- cordova.js导入、初始化、启动、加载插件
-
Cordova 3.x 源码分析(6) -- cordova.js本地交互JS<->Native
-
Cordova 3.x 源码分析(3) -- cordova.js模块系统require/define
-
Cordova 3.x 源码分析(4) -- cordova.js事件通道pub/sub
-
Cordova 3.x 源码分析(2) -- cordova.js概要
-
Cordova 3.x 源码分析(5) -- cordova.js导入、初始化、启动、加载插件
-
Cordova 3.x 源码分析(4) -- cordova.js事件通道pub/sub
-
Cordova 3.x 源码分析(3) -- cordova.js模块系统require/define