欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页

Cordova 3.x 源码分析(7) -- CordovaLib概要

程序员文章站 2022-03-02 18:41:01
...
http://rensanning.iteye.com/blog/2020843已经介绍过通过Cordova CLI创建Cordova工程。

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)
Cordova 3.x 源码分析(7) -- CordovaLib概要
            
    
    博客分类: Cordova CordovaPhoneGap

基础类:
  • 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
****这些文件中有些Java文件已经不再建议使用,在未来的某个版本将会被删除!!!

其他:
  • 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());
    }
}


启动序列图:
Cordova 3.x 源码分析(7) -- CordovaLib概要
            
    
    博客分类: Cordova CordovaPhoneGap

Plugin序列图:
Cordova 3.x 源码分析(7) -- CordovaLib概要
            
    
    博客分类: Cordova CordovaPhoneGap
  • Cordova 3.x 源码分析(7) -- CordovaLib概要
            
    
    博客分类: Cordova CordovaPhoneGap
  • 大小: 8.8 KB
  • Cordova 3.x 源码分析(7) -- CordovaLib概要
            
    
    博客分类: Cordova CordovaPhoneGap
  • 大小: 129.5 KB
  • Cordova 3.x 源码分析(7) -- CordovaLib概要
            
    
    博客分类: Cordova CordovaPhoneGap
  • 大小: 104 KB
相关标签: Cordova PhoneGap