掌桥专利:专业的专利平台
掌桥专利
首页

技术领域

本申请涉及计算机技术领域,特别是涉及一种原生平台功能调用方法、装置和计算机设备。

背景技术

插件是谷歌公司开源的图像代码工具包,帮助开发者通过领域特定语言(DomainSpecific Language,DSL)编写高效构建精美应用,支持iOS,android,web,桌面和嵌入式等众多原生平台。插件例如可以是Flutter插件,语言可以实任意的编程语言。Flutter作为一个图形工具包并不具备定位,蓝牙连接等基础能力,而Flutter插件是官方提供用于解决框架本身能力不足需要桥接原有平台能力的方案。

利用插件能解决原生功能不足的问题,但由于编写代码约束比较松散,存在部分缺陷:(1)插件通过方法字符串比较来找到对应的原生平台实现,由于原生平台的编程语言不同,所以每一个原生平台都需要去编写桥接的胶水代码;(2)和原生平台任意一方的方法字符串调整并不会让另一端感知,可能导致插件无法正常调用到原生能力;(3)原生平台实现不统一,在适配其他跨端方案(React Native,H5,小程序)的时候需要重新实现;(4)原生平台实现不统一,需要维护多份对外接口文档。

目前针对相关技术中存在的上述问题,尚未提出有效的解决方案。

发明内容

本申请实施例提供了一种原生平台功能调用方法、装置和计算机设备,以至少解决相关技术中调用原生平台功能存在的问题。

第一方面,本申请实施例提供了一种原生平台功能调用方法,所述方法包括:

利用脚本工具生成多个原生平台的统一接口文档,多个所述原生平台的编程语言不同;

通过所述原生平台的统一接口文档,调用对应所述原生平台的功能。

在其中一些实施例中,所述利用脚本工具生成多个原生平台的统一接口文档,包括:

建立仓库,所述仓库用于描述调用方法的声明和注释,以及所述调用方法所需要的模型和枚举;

触发脚本工具,利用所述脚本工具分析所述仓库中的抽象语法树和注释,并通过抽象语法树和注释分别生成多个所述原生平台的统一接口文档。

在其中一些实施例中,所述通过所述原生平台的统一接口文档,调用对应所述原生平台的功能,包括:

在所述仓库中建立配置文件,所述配置文件用于记录每一所述原生平台的子仓库;

将所述脚本工具生成的各原生平台的接口文档主动推送到对应原生平台的子仓库;

分别拉取所述子仓库的代码,获取对应的接口文档;

根据所述接口文档调用对应所述原生平台的功能。

在其中一些实施例中,所述原生平台包括:iOS平台,Android平台和嵌入式平台。

在其中一些实施例中,所述方法还包括更新所述仓库,具体包括:

重新编辑所述仓库中的代码;

所述脚本工具重新解析所述更新后代码对应的抽象语法树和注释,生成更新仓库。

在其中一些实施例中,开发者通过领域特定语言在仓库中描述了调用方法的声明和注释后,通过领域特定语言的语法解析库解析所述仓库中调用方法名称和注释;

根据所述调用方法名称和注释,通过脚本工具自动化生成各个原生平台语言的接口和各个原生平台的注释;

通过gitLab的钩子将各个原生平台语言的接口和各个原生平台的注释推送到对应原生平台的子仓库。

在其中一些实施例中,所述配置文件包括通用调用层,根据所述接口文档,通过所述通用调用层调用对应原生平台的功能。

第二方面,本申请实施例提供了一种原生平台功能调用装置,包括:接口生成模块和调用模块;其中:

接口文档生成模块,用于利用脚本工具生成多个原生平台的统一接口文档,多个所述原生平台的编程语言不同;

功能调用模块,用于通过所述原生平台的统一接口文档,调用对应所述原生平台的功能。

第三方面,本申请实施例提供了一种计算机设备,包括存储器、处理器以及存储在所述存储器上并可在所述处理器上运行的计算机程序,所述处理器执行所述计算机程序时实现如上述第一方面所述的方法。

第四方面,本申请实施例提供了一种计算机可读存储介质,其上存储有计算机程序,该程序被处理器执行时实现如上述第一方面所述的方法。

相比于相关技术,本申请实施例提供的原生平台功能调用方法、装置和计算机设备,包括:利用脚本工具生成多个原生平台的统一接口文档,多个所述原生平台的编程语言不同;通过所述原生平台的统一接口文档,调用对应所述原生平台的功能,解决了调用原生平台功能需要各自对接的问题。

本申请的一个或多个实施例的细节在以下附图和描述中提出,以使本申请的其他特征、目的和优点更加简明易懂。

附图说明

此处所说明的附图用来提供对本申请的进一步理解,构成本申请的一部分,本申请的示意性实施例及其说明用于解释本申请,并不构成对本申请的不当限定。在附图中:

图1是本申请实施例提供的原生平台功能调用方法流程图;

图2是现有的Flutter插件桥接示意图;

图3是现有的Flutter插件通过接口约束桥接方式的示意图;

图4是本申请实施例提供的原生平台功能调用方法的示意图;

图5是本申请实施例提供的原生平台功能调用装置的示意图;

图6是本申请实施例提供的计算机设备的内部结构图。

具体实施方式

为了使本申请的目的、技术方案及优点更加清楚明白,以下结合附图及实施例,对本申请进行描述和说明。应当理解,此处所描述的具体实施例仅仅用以解释本申请,并不用于限定本申请。基于本申请提供的实施例,本领域普通技术人员在没有作出创造性劳动的前提下所获得的所有其他实施例,都属于本申请保护的范围。

显而易见地,下面描述中的附图仅仅是本申请的一些示例或实施例,对于本领域的普通技术人员而言,在不付出创造性劳动的前提下,还可以根据这些附图将本申请应用于其他类似情景。此外,还可以理解的是,虽然这种开发过程中所作出的努力可能是复杂并且冗长的,然而对于与本申请公开的内容相关的本领域的普通技术人员而言,在本申请揭露的技术内容的基础上进行的一些设计,制造或者生产等变更只是常规的技术手段,不应当理解为本申请公开的内容不充分。

在本申请中提及“实施例”意味着,结合实施例描述的特定特征、结构或特性可以包含在本申请的至少一个实施例中。在说明书中的各个位置出现该短语并不一定均是指相同的实施例,也不是与其它实施例互斥的独立的或备选的实施例。本领域普通技术人员显式地和隐式地理解的是,本申请所描述的实施例在不冲突的情况下,可以与其它实施例相结合。

除非另作定义,本申请所涉及的技术术语或者科学术语应当为本申请所属技术领域内具有一般技能的人士所理解的通常意义。本申请所涉及的“一”、“一个”、“一种”、“该”等类似词语并不表示数量限制,可表示单数或复数。本申请所涉及的术语“包括”、“包含”、“具有”以及它们任何变形,意图在于覆盖不排他的包含;例如包含了一系列步骤或模块(单元)的过程、方法、系统、产品或设备没有限定于已列出的步骤或单元,而是可以还包括没有列出的步骤或单元,或可以还包括对于这些过程、方法、产品或设备固有的其它步骤或单元。本申请所涉及的“连接”、“相连”、“耦接”等类似的词语并非限定于物理的或者机械的连接,而是可以包括电气的连接,不管是直接的还是间接的。本申请所涉及的“多个”是指两个或两个以上。“和/或”描述关联对象的关联关系,表示可以存在三种关系,例如,“A和/或B”可以表示:单独存在A,同时存在A和B,单独存在B这三种情况。字符“/”一般表示前后关联对象是一种“或”的关系。本申请所涉及的术语“第一”、“第二”、“第三”等仅仅是区别类似的对象,不代表针对对象的特定排序。

本实施例还提供了一种原生平台功能调用方法。如图1所示,原生平台功能调用方法包括如下步骤:

步骤110,利用脚本工具生成多个原生平台的统一接口文档,多个所述原生平台的编程语言不同。

步骤120,通过所述原生平台的统一接口文档,调用对应所述原生平台的功能。

本申请中的插件不仅限使用Flutter插件,可以包含任何需要原生平台能力的跨平台方案,包括但不仅限于React Native,Weex,H5,小程序,本申请以Flutter插件为例进行说明。

现有的,如图2所示,Flutter插件开发者需要调用原生平台某项能力的时候,通过【MethodChannel.invoke(“funcA”)】的方式发起调用,而每一个原生平台需要通过比较字符串的方式【if(name==“funcA”)】返回给Flutter开发者。上述方案通过使用字符串比较的方式,无法约束开发者的行为,同时每个原生平台开发者需要一一对接,如图3所示。

本申请通过引入面向接口的思想,原生开发者不再需要通过比较字符串的方式来桥接原生平台,而是使用主动生成接口来约束原生开发者的行为,该接口可以统一调用其他各原生平台的功能。另外,平台开发者不用关心Flutter桥接代码,通过面向接口编程的约束,只需关注具体的实现。原生平台的接口文档,统一由自动化语法解析工具生成,无需人工维护。另外,本申请通过一份描述语言,将各个平台的接口主动生成,让原生平台只需要关注实现即可。另外由于原有的Flutter框架层设计上未考虑同步问题,导致Flutter端和原生平台修改无法同步。本申请通过自动化工具绑定各自实现,当有一方发生改变的时候,另一方会被动更新。

在其中一些实施例中,参考图4,所述利用脚本工具生成多个原生平台的统一接口文档,包括:

建立仓库,所述仓库用于描述调用方法的声明和注释,以及所述调用方法所需要的模型和枚举;

触发脚本工具,利用所述脚本工具分析所述仓库中的抽象语法树和注释,并通过抽象语法树和注释分别生成多个所述原生平台的接口文档。

本申请可以在代码仓库GitLab上建立一个仓库,对于Flutter插件,仓库A可以由Flutter开发者定义,并使用Dart语言编写。可以理解的是,在其他实施例中,也可以是其他插件,使用其他语言编写仓库,例如TypeScript语言。仓库A用来描述业务需要暴露的接口,模型,枚举以及加入对这些接口,模型,枚举的代码注释。

脚本工具是一种使用高级脚本语言实现的软件工具。典型地,以脚本工具编写的脚本可以在运行时由执行环境解释以执行特定编程任务。本申请通过脚本工具解析仓库中的抽象语法树和注释,并通过抽象语法树和注释分别生成多个所述原生平台的接口文档。

抽象语法树(Abstract Syntax Tree,AST)是源代码语法结构的一种抽象表示。它以树状的形式表现编程语言的语法结构,树上的每个节点都表示源代码中的一种结构。

注释就是对代码的解释和说明。目的是为了让别人和自己很容易看懂,一看就知道这段代码是做什么用的。正确的程序注释一般包括序言性注释和功能性注释。序言性注释的主要内容包括模块的接口、数据的描述和模块的功能。模块的功能性注释的主要内容包括程序段的功能、语句的功能和数据的状态。

统一接口文档中包括调用方法、各个原生平台的调用接口和文档,通过该统一接口文档。原生开发者根据脚本工具生成的接口和文档去实现真正需要插件的功能。Flutter开发者根据脚本工具生成的调用代码去实现来自市场或者产品的需求。

在一些实施例中,使用TypeScript语言作为DSL的为插件提供一套描述规范,用来约束同步方法、异步方法的签名及其入参、出参,还有数据实体类,从而严格限制方法的实现,规范各端工程师的具体实现逻辑。通过这套规范还能自动生成接口注释及文档,方便查阅。

由于各端支持的数据类型不一样,我们在DSL使用自定义数据结构以便各端都可以使用,并且通过注解方式确定接口支持的版本、是否废弃、参数是否必选,为后续开发及问题回溯提供便利。

使用TypeScript语言开发CLI,将DSL翻译成Android、iOS及JavaScript接口代码,保证各端代码逻辑一致性。

在其中一些实施例中,所述通过所述调用方法和所述原生平台的统一接口文档,调用对应所述原生平台的功能,包括:

在仓库中建立配置文件,所述配置文件用于记录每一所述原生平台的子仓库;

将所述脚本工具生成的各原生平台的接口文档主动推送到对应原生平台的子仓库;

各原生平台开发者分别拉取所述子仓库的代码,获取对应的接口文档;

根据所述接口文档调用对应原生平台的功能。

因为各个原生平台生成的功能是一样的,所以统一接口文档只是从仓库中提取出来的一份,但是原生平台的接口和注释有各自实现的语言(例如iOS-Objective-C,Android-Java,嵌入式-C)所以存在多份,即配置文件中会维护多个原生平台的子仓库,每个子仓库中有对应原生平台的接口和文档。当Flutter开发者在使用的时候,无需关心各个原生平台的接口以及实现,只需要关注生成的文档去调用。

另外,一个Flutter开发者实现的功能会跑在很多个原生平台上,原生平台会由不同开发者实现,如果把Flutter开发者的代码和各原生开发者的代码放入到同一个仓库,那大大提供了这个仓库的管理复杂度,所以本申请把原生仓库独立开,使原生开发者只关注自己平台的实现可以大大的减小代码的耦合,降低代码管理的复杂度。在原生仓库独立的情况下,原生平台就不再关心其他平台的代码仓库地址,只需要在自己平台的代码仓库修改,提交即可。

在其中一些实施例中,所述原生平台包括:iOS平台,Android平台和嵌入式平台。

在其中一些实施例中,所述方法还包括更新所述仓库,具体包括:

重新编辑仓库的代码;

所述脚本工具重新解析所述更新后的代码对应的抽象语法树和注释,生成更新仓库。

当需求发生变化需要更改Flutter插件的接口时,Flutter开发者重新编辑仓库的Dart代码,脚本工具重新解析Dart语言的重新语法树和注释,生成相关内容重新提交。

在其中一些实施例中,开发者通过领域特定语言在仓库中描述了调用方法的声明和注释后,通过领域特定语言的语法解析库解析所述仓库中调用方法名称和注释;

根据调用方法名称和注释,通过脚本工具自动化生成各个原生平台语言的接口和各个原生平台的注释;

通过gitLab的钩子推送到各个原生平台的子仓库。

Flutter开发者通过Dart语言在仓库中描述了调用方法的声明和注释后,通过Dart的语法解析库analyzer(不同的语言由各自语法解析库)来解析仓库中方法名称,注释,通过方法名称,注释通过脚本工具可以自动化的生成各个原生平台语言的接口和各个平台的注释,在通过gitLab的钩子推送到各个原生平台的仓库。

在其中一些实施例中,所述配置文件包括通用调用层,根据所述接口文档,通过所述通用调用层调用对应原生平台的功能。现有的跨端方案比较分散,不会考虑其他框架的兼容,本申请将描述语言统一接口后,各个原生平台只需要在多一层中间层去适配。本申请针对flutter、小程序、rn、web等跨端平台编写了一套通用调用层,以适用不同的原生平台。

需要说明的是,在上述流程中或者附图的流程图中示出的步骤可以在诸如一组计算机可执行指令的计算机系统中执行,并且,虽然在流程图中示出了逻辑顺序,但是在某些情况下,可以以不同于此处的顺序执行所示出或描述的步骤。

本实施例还提供了一种原生平台功能调用装置,该装置用于实现上述实施例及优选实施方式,已经进行过说明的不再赘述。如以下所使用的,术语“模块”、“单元”、“子单元”等可以实现预定功能的软件和/或硬件的组合。尽管以下实施例所描述的装置较佳地以软件来实现,但是硬件,或者软件和硬件的组合的实现也是可能并被构想的。

图5是根据本申请实施例的原生平台功能调用装置的结构框图,如图5所示,该装置包括:接口生成模块510和功能调用模块520;其中:

接口文档生成模块510,用于利用脚本工具生成多个原生平台的统一接口文档,多个所述原生平台的编程语言不同;

功能调用模块520,用于通过所述原生平台的统一接口文档,调用对应所述原生平台的功能。

本实施例通过引入面向接口的思想,原生开发者不再需要通过比较字符串的方式来桥接原生平台,而是使用主动生成接口来约束原生开发者的行为,该接口可以统一调用其他各原生平台的功能。另外,平台开发者不用关心Flutter桥接代码,通过面向接口编程的约束,只需关注具体的实现。原生平台的接口文档,统一由自动化语法解析工具生成,无需人工维护。

在其中一些实施例中,接口文档生成模块510还用于:

建立仓库,所述仓库用于描述调用方法的声明和注释,以及所述调用方法所需要的模型和枚举;

触发脚本工具,利用所述脚本工具分析所述仓库中的抽象语法树和注释,并通过抽象语法树和注释分别生成多个所述原生平台的统一接口文档。

在其中一些实施例中,功能调用模块520还用于:

在所述仓库中建立配置文件,所述配置文件用于记录每一所述原生平台的子仓库;

将所述脚本工具生成的各原生平台的接口文档主动推送到对应原生平台的子仓库;

分别拉取所述子仓库的代码,获取对应的接口文档;

根据所述接口文档调用对应所述原生平台的功能。

在其中一些实施例中,所述原生平台包括:iOS平台,Android平台和嵌入式平台。

在其中一些实施例中,还包括更新模块,用于:

重新编辑所述仓库中的代码;

所述脚本工具重新解析所述更新后代码对应的抽象语法树和注释,生成更新仓库。

在其中一些实施例中,接口文档生成模块510还用于:

通过领域特定语言的语法解析库解析所述仓库中调用方法名称和注释;

根据所述调用方法名称和注释,通过脚本工具自动化生成各个原生平台语言的接口和各个原生平台的注释;

通过gitLab的钩子将各个原生平台语言的接口和各个原生平台的注释推送到对应原生平台的子仓库。

在其中一些实施例中,所述配置文件包括通用调用层,根据所述接口文档,通过所述通用调用层调用对应原生平台的功能。

需要说明的是,上述各个模块可以是功能模块也可以是程序模块,既可以通过软件来实现,也可以通过硬件来实现。对于通过硬件来实现的模块而言,上述各个模块可以位于同一处理器中;或者上述各个模块还可以按照任意组合的形式分别位于不同的处理器中。

另外,结合图1描述的本申请实施例原生平台功能调用方法可以由计算机设备来实现。图6为根据本申请实施例的计算机设备的硬件结构示意图。

计算机设备可以包括处理器61以及存储有计算机程序指令的存储器62。

具体地,上述处理器61可以包括中央处理器(CPU),或者特定集成电路(Application Specific Integrated Circuit,简称为ASIC),或者可以被配置成实施本申请实施例的一个或多个集成电路。

其中,存储器62可以包括用于数据或指令的大容量存储器。举例来说而非限制,存储器62可包括硬盘驱动器(Hard Disk Drive,简称为HDD)、软盘驱动器、固态驱动器(SolidState Drive,简称为SSD)、闪存、光盘、磁光盘、磁带或通用串行总线(Universal SerialBus,简称为USB)驱动器或者两个或更多个以上这些的组合。在合适的情况下,存储器62可包括可移除或不可移除(或固定)的介质。在合适的情况下,存储器62可在数据处理装置的内部或外部。在特定实施例中,存储器62是非易失性(Non-Volatile)存储器。在特定实施例中,存储器62包括只读存储器(Read-Only Memory,简称为ROM)和随机存取存储器(RandomAccess Memory,简称为RAM)。在合适的情况下,该ROM可以是掩模编程的ROM、可编程ROM(ProgrammableRead-Only Memory,简称为PROM)、可擦除PROM(Erasable ProgrammableRead-Only Memory,简称为EPROM)、电可擦除PROM(Electrically Erasable ProgrammableRead-Only Memory,简称为EEPROM)、电可改写ROM(Electrically Alterable Read-OnlyMemory,简称为EAROM)或闪存(FLASH)或者两个或更多个以上这些的组合。在合适的情况下,该RAM可以是静态随机存取存储器(Static Random-Access Memory,简称为SRAM)或动态随机存取存储器(Dynamic Random Access Memory,简称为DRAM),其中,DRAM可以是快速页模式动态随机存取存储器(Fast Page Mode Dynamic Random Access Memory,简称为FPMDRAM)、扩展数据输出动态随机存取存储器(Extended Date Out Dynamic RandomAccess Memory,简称为EDODRAM)、同步动态随机存取内存(Synchronous Dynamic Random-Access Memory,简称SDRAM)等。

存储器62可以用来存储或者缓存需要处理和/或通信使用的各种数据文件,以及处理器61所执行的可能的计算机程序指令。

处理器61通过读取并执行存储器62中存储的计算机程序指令,以实现上述实施例中的任意一种原生平台功能调用方法。

在其中一些实施例中,计算机设备还可包括通信接口63和总线60。其中,如图6所示,处理器61、存储器62、通信接口63通过总线60连接并完成相互间的通信。

通信接口63用于实现本申请实施例中各模块、装置、单元和/或设备之间的通信。通信接口63还可以实现与其他部件例如:外接设备、图像/数据采集设备、数据库、外部存储以及图像/数据处理工作站等之间进行数据通信。

总线60包括硬件、软件或两者,将计算机设备的部件彼此耦接在一起。总线60包括但不限于以下至少之一:数据总线(Data Bus)、地址总线(Address Bus)、控制总线(Control Bus)、扩展总线(Expansion Bus)、局部总线(Local Bus)。举例来说而非限制,总线60可包括图形加速接口(Accelerated Graphics Port,简称为AGP)或其他图形总线、增强工业标准架构(Extended Industry Standard Architecture,简称为EISA)总线、前端总线(Front Side Bus,简称为FSB)、超传输(Hyper Transport,简称为HT)互连、工业标准架构(Industry Standard Architecture,简称为ISA)总线、无线带宽(InfiniBand)互连、低引脚数(Low Pin Count,简称为LPC)总线、存储器总线、微信道架构(Micro ChannelArchitecture,简称为MCA)总线、外围组件互连(Peripheral Component Interconnect,简称为PCI)总线、PCI-Express(PCI-X)总线、串行高级技术附件(Serial AdvancedTechnology Attachment,简称为SATA)总线、视频电子标准协会局部(Video ElectronicsStandards Association Local Bus,简称为VLB)总线或其他合适的总线或者两个或更多个以上这些的组合。在合适的情况下,总线60可包括一个或多个总线。尽管本申请实施例描述和示出了特定的总线,但本申请考虑任何合适的总线或互连。

该计算机设备可以基于获取到的程序指令,执行本申请实施例中的原生平台功能调用方法,从而实现结合图1描述的原生平台功能调用方法。

另外,结合上述实施例中的原生平台功能调用方法,本申请实施例可提供一种计算机可读存储介质来实现。该计算机可读存储介质上存储有计算机程序指令;该计算机程序指令被处理器执行时实现上述实施例中的任意一种原生平台功能调用方法。

以上所述实施例的各技术特征可以进行任意的组合,为使描述简洁,未对上述实施例中的各个技术特征所有可能的组合都进行描述,然而,只要这些技术特征的组合不存在矛盾,都应当认为是本说明书记载的范围。

以上所述实施例仅表达了本申请的几种实施方式,其描述较为具体和详细,但并不能因此而理解为对发明专利范围的限制。应当指出的是,对于本领域的普通技术人员来说,在不脱离本申请构思的前提下,还可以做出若干变形和改进,这些都属于本申请的保护范围。因此,本申请专利的保护范围应以所附权利要求为准。

技术分类

06120114609359