【cocos2d-x从c++到js】03:hybrid开发模式

简介:

因为苹果是不允许app下载可执行代码的,所以用动态链接库构建插件式引擎并通过网络下载在iOS上是无法实现的。但有一种方式是,在引擎内部集成一个脚本解释器,然后把脚本作为资源来下载(脚本是加密的),如此规避苹果的审核条款。这个方式就叫Hybrid。但这么做没法做到不露痕迹,深层原因应该是,Hybrid牵扯利益太大,苹果也算睁一只眼闭一只眼。

在cocos2d引擎的众多分支中,cocos2d-x的开发是以C++为核心的。而cocos2d-x引擎,就是通过hybrid方式来执行js代码的。为了执行js代码,引擎本身需要一个脚本解释器,引擎集成的脚本解释器就叫:spidermonkey。

spidermonkey是一个历史悠久的基于c/c++编写的js脚本解释器,由Mozilla提供,非常有名的firefox和thunderbird都在用。cocos2d-x集成spidermonkey的开源协议是MPL2.0,没有什么限制,你可以放心使用它。

在AppDelegate::applicationDidFinishLaunching()函数中,我们可以找到启动脚本引擎的代码:

 
  1. ScriptingCore* sc = ScriptingCore::getInstance(); 
  2. sc->addRegisterCallback(register_all_cocos2dx); 
  3. sc->addRegisterCallback(register_cocos2dx_js_extensions); 
  4. sc->addRegisterCallback(register_CCBuilderReader); 
  5. sc->addRegisterCallback(jsb_register_chipmunk); 
  6. sc->start(); 
  7.  
  8. CCScriptEngineProtocol *pEngine = ScriptingCore::getInstance(); 
  9. CCScriptEngineManager::sharedManager()->setScriptEngine(pEngine); 
  10. ScriptingCore::getInstance()->runScript("MoonWarriors-jsb.js"); 

ScriptCore是脚本的核心,他就是我们说的那个JS解释器。cocos2d-x把spidermonkey的解释器封装了一下,以提供对cocos2d-x引擎的相关支持,并简化相应的调用接口。

addRegisterCallback接口用于添加注册函数,注册函数用于在引擎执行时,绑定相应的代码(从JS往C++的映射代码)。每一个注册函数,对应一个库。现在cocos2d-x提供了四个库支持,分别是cocos2d-x核心库,cocos2d-x扩展库,cocosbuilder支持库,clipmunk物理引擎库。将来你可以在这里添加注册自己实现的JS绑定库,来直接扩展这个JS引擎。

start启动脚本引擎。

CCScriptEngineManager::sharedManager()->setScriptEngine 这句是将脚本引擎绑定到引擎管理器上,引擎管理器提供对脚本引擎的一个全局访问点,并且也负责对脚本引擎的卸载。

最后就是运行游戏的主脚本了。

ScriptingCore::getInstance()->runScript("MoonWarriors-jsb.js"); 





 本文转自 老G 51CTO博客,原文链接:http://blog.51cto.com/goldlion/1120219,如需转载请自行联系原作者


相关文章
|
4月前
|
JavaScript 前端开发 Serverless
函数计算只支持Node.js,我用C++写的程序怎么运行?
函数计算只支持Node.js,我用C++写的程序怎么运行?
91 1
|
存储 JavaScript 调度
cocos webview js和c++交互
cocos webview js和c++交互
404 0
|
前端开发 JavaScript Java
C,C++,python,Java,VB,HTML/CSS/JS语言的特点分析(四方面总结)(大学生)
C,C++,python,Java,VB,HTML/CSS/JS语言的特点分析(四方面总结)(大学生)
245 0
|
2月前
|
JavaScript
Node.js【GET/POST请求、http模块、路由、创建客户端、作为中间层、文件系统模块】(二)-全面详解(学习总结---从入门到深化)
Node.js【GET/POST请求、http模块、路由、创建客户端、作为中间层、文件系统模块】(二)-全面详解(学习总结---从入门到深化)
27 0
|
2月前
|
消息中间件 Web App开发 JavaScript
Node.js【简介、安装、运行 Node.js 脚本、事件循环、ES6 作业队列、Buffer(缓冲区)、Stream(流)】(一)-全面详解(学习总结---从入门到深化)
Node.js【简介、安装、运行 Node.js 脚本、事件循环、ES6 作业队列、Buffer(缓冲区)、Stream(流)】(一)-全面详解(学习总结---从入门到深化)
76 0
|
1天前
|
JavaScript 前端开发 测试技术
学习JavaScript
【4月更文挑战第23天】学习JavaScript
7 1
|
9天前
|
JavaScript 前端开发 应用服务中间件
node.js之第一天学习
node.js之第一天学习
|
1月前
|
运维 JavaScript 前端开发
发现了一款宝藏学习项目,包含了Web全栈的知识体系,JS、Vue、React知识就靠它了!
发现了一款宝藏学习项目,包含了Web全栈的知识体系,JS、Vue、React知识就靠它了!