Cordova源码深入分析-第四讲

2024-05-15 20:38

本文主要是介绍Cordova源码深入分析-第四讲,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

前面把插件在js端的初始化,与js->Native->js端的通信都介绍了一下

本章介绍一下,在native端的插件初始化流程

在介绍所有的之前,我想先上一段代码(插件配置):

<?xml version='1.0' encoding='utf-8'?>
<widget id="io.cordova.hellocordova" version="1.0.0" xmlns="http://www.w3.org/ns/widgets" xmlns:cdv="http://cordova.apache.org/ns/1.0"><feature name="Whitelist"><param name="android-package" value="org.apache.cordova.whitelist.WhitelistPlugin" /><param name="onload" value="true" /></feature><feature name="Camera"><param name="android-package" value="org.apache.cordova.camera.CameraLauncher" /></feature><feature name="SMS"><param name="android-package" value="com.rjfun.cordova.sms.SMSPlugin" /></feature><feature name="Notification"><param name="android-package" value="org.apache.cordova.dialogs.Notification" /></feature><name>HelloCordova</name><description>A sample Apache Cordova application that responds to the deviceready event.</description><author email="dev@cordova.apache.org" href="http://cordova.io">Apache Cordova Team</author><content src="index.html" /><access origin="*" /><allow-intent href="http://*/*" /><allow-intent href="https://*/*" /><allow-intent href="tel:*" /><allow-intent href="sms:*" /><allow-intent href="mailto:*" /><allow-intent href="geo:*" /><allow-intent href="market:*" /><preference name="loglevel" value="DEBUG" />
</widget>

还是从Activity的onCrete开始分析,首先调用的是CordovaActivity.java的loadUrl

代码段:1

    public void loadUrl(String url) {if (appView == null) {init(); //第一次肯定需要初始化 跳转到代码段2}// If keepRunningthis.keepRunning = preferences.getBoolean("KeepRunning", true);appView.loadUrlIntoView(url, true);}
代码段2:
    protected void init() {appView = makeWebView();//构建整个架构框架,代码段3createViews(); //创建view的地方,没有太多逻辑,不关注了if (!appView.isInitialized()) {appView.init(cordovaInterface, pluginEntries, preferences);//这里是重点,代码段4}cordovaInterface.onCordovaInit(appView.getPluginManager());// Wire the hardware volume controls to control media if desired.String volumePref = preferences.getString("DefaultVolumeStream", "");if ("media".equals(volumePref.toLowerCase(Locale.ENGLISH))) {setVolumeControlStream(AudioManager.STREAM_MUSIC);}}

代码段3:

    protected CordovaWebView makeWebView() {return new CordovaWebViewImpl(makeWebViewEngine());}
这里涉及到两个类,CordovaWebViewImpl 和  SystemWebViewEngine

engine是整个架构和核心的干活的类,所有WebView的设置和操作都在这里实现

Impl则是整个架构的核心管理模块,负责协调各个功能之间的交互,包括消息中心,插件管理中心等等的初始化和调用

代码段4:

入参,都是在CordovaActivity的onCreate中早就初始化好了,这里只是传入的,插件的所有信息都记录在
res/xml/config.xml中,这个逻辑比较简单,就一笔带过了。

    public void init(CordovaInterface cordova, List<PluginEntry> pluginEntries, CordovaPreferences preferences) {if (this.cordova != null) {throw new IllegalStateException();}this.cordova = cordova;this.preferences = preferences;//配置中的preference参数pluginManager = new PluginManager(this, this.cordova, pluginEntries);//所有的插件信息都在这里管理resourceApi = new CordovaResourceApi(engine.getView().getContext(), pluginManager);//可以理解为工具类(资源读取)nativeToJsMessageQueue = new NativeToJsMessageQueue();//之前介绍过的消息队列,负责native给js的方法调用nativeToJsMessageQueue.addBridgeMode(new NativeToJsMessageQueue.NoOpBridgeMode());//封装成js的方法,nativeToJsMessageQueue.addBridgeMode(new NativeToJsMessageQueue.LoadUrlBridgeMode(engine, cordova));if (preferences.getBoolean("DisallowOverscroll", false)) {engine.getView().setOverScrollMode(View.OVER_SCROLL_NEVER);//滑动是否出现弧形光环}engine.init(this, cordova, engineClient, resourceApi, pluginManager, nativeToJsMessageQueue);//将所有信息传给Engine// This isn't enforced by the compiler, so assert here.assert engine.getView() instanceof CordovaWebViewEngine.EngineView;pluginManager.addService(CoreAndroid.PLUGIN_NAME, "org.apache.cordova.CoreAndroid");//增加一个插件(这属于基础插件)pluginManager.init(); //初始化 代码段5}

代码段5:

    public void init() {LOG.d(TAG, "init()");isInitialized = true;this.onPause(false);//停止this.onDestroy();//之前加载的插件先调用onDestroypluginMap.clear();this.startupPlugins();//这里实际上就是将插件的类对象加入到pluginMap中(LinkedHashMap<String, CordovaPlugin> pluginMap)}

这里在初始化的时候,有两点需要提一下,插件分为onLoad插件和其他插件,onLoad插件是启动时就直接加载的,

其他插件只有在调用的时候,再去初始化后加载。

我们之前的代码逻辑调用过exec方法,其实就是到这里的是,再去提取插件,然后执行固定的代码。


到目前位置,应该是所有有疑问的点都已经分析过了,出去cli部分,我们自己构建一套属于我们自己的架构应该也是没有问题了

下面就根据我们自己的需求设计我们自己的架构吧。

这篇关于Cordova源码深入分析-第四讲的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/992867

相关文章

Java汇编源码如何查看环境搭建

《Java汇编源码如何查看环境搭建》:本文主要介绍如何在IntelliJIDEA开发环境中搭建字节码和汇编环境,以便更好地进行代码调优和JVM学习,首先,介绍了如何配置IntelliJIDEA以方... 目录一、简介二、在IDEA开发环境中搭建汇编环境2.1 在IDEA中搭建字节码查看环境2.1.1 搭建步

JAVA智听未来一站式有声阅读平台听书系统小程序源码

智听未来,一站式有声阅读平台听书系统 🌟&nbsp;开篇:遇见未来,从“智听”开始 在这个快节奏的时代,你是否渴望在忙碌的间隙,找到一片属于自己的宁静角落?是否梦想着能随时随地,沉浸在知识的海洋,或是故事的奇幻世界里?今天,就让我带你一起探索“智听未来”——这一站式有声阅读平台听书系统,它正悄悄改变着我们的阅读方式,让未来触手可及! 📚&nbsp;第一站:海量资源,应有尽有 走进“智听

Java ArrayList扩容机制 (源码解读)

结论:初始长度为10,若所需长度小于1.5倍原长度,则按照1.5倍扩容。若不够用则按照所需长度扩容。 一. 明确类内部重要变量含义         1:数组默认长度         2:这是一个共享的空数组实例,用于明确创建长度为0时的ArrayList ,比如通过 new ArrayList<>(0),ArrayList 内部的数组 elementData 会指向这个 EMPTY_EL

如何在Visual Studio中调试.NET源码

今天偶然在看别人代码时,发现在他的代码里使用了Any判断List<T>是否为空。 我一般的做法是先判断是否为null,再判断Count。 看了一下Count的源码如下: 1 [__DynamicallyInvokable]2 public int Count3 {4 [__DynamicallyInvokable]5 get

工厂ERP管理系统实现源码(JAVA)

工厂进销存管理系统是一个集采购管理、仓库管理、生产管理和销售管理于一体的综合解决方案。该系统旨在帮助企业优化流程、提高效率、降低成本,并实时掌握各环节的运营状况。 在采购管理方面,系统能够处理采购订单、供应商管理和采购入库等流程,确保采购过程的透明和高效。仓库管理方面,实现库存的精准管理,包括入库、出库、盘点等操作,确保库存数据的准确性和实时性。 生产管理模块则涵盖了生产计划制定、物料需求计划、

Spring 源码解读:自定义实现Bean定义的注册与解析

引言 在Spring框架中,Bean的注册与解析是整个依赖注入流程的核心步骤。通过Bean定义,Spring容器知道如何创建、配置和管理每个Bean实例。本篇文章将通过实现一个简化版的Bean定义注册与解析机制,帮助你理解Spring框架背后的设计逻辑。我们还将对比Spring中的BeanDefinition和BeanDefinitionRegistry,以全面掌握Bean注册和解析的核心原理。

音视频入门基础:WAV专题(10)——FFmpeg源码中计算WAV音频文件每个packet的pts、dts的实现

一、引言 从文章《音视频入门基础:WAV专题(6)——通过FFprobe显示WAV音频文件每个数据包的信息》中我们可以知道,通过FFprobe命令可以打印WAV音频文件每个packet(也称为数据包或多媒体包)的信息,这些信息包含该packet的pts、dts: 打印出来的“pts”实际是AVPacket结构体中的成员变量pts,是以AVStream->time_base为单位的显

kubelet组件的启动流程源码分析

概述 摘要: 本文将总结kubelet的作用以及原理,在有一定基础认识的前提下,通过阅读kubelet源码,对kubelet组件的启动流程进行分析。 正文 kubelet的作用 这里对kubelet的作用做一个简单总结。 节点管理 节点的注册 节点状态更新 容器管理(pod生命周期管理) 监听apiserver的容器事件 容器的创建、删除(CRI) 容器的网络的创建与删除

red5-server源码

red5-server源码:https://github.com/Red5/red5-server

TL-Tomcat中长连接的底层源码原理实现

长连接:浏览器告诉tomcat不要将请求关掉。  如果不是长连接,tomcat响应后会告诉浏览器把这个连接关掉。    tomcat中有一个缓冲区  如果发送大批量数据后 又不处理  那么会堆积缓冲区 后面的请求会越来越慢。