位置: 编程技术 - 正文

【cocos2d-js官方文档】十八、Cocos2d-js v3.0的对象构造和类继承(cocos creator js ts)

编辑:rootadmin

推荐整理分享【cocos2d-js官方文档】十八、Cocos2d-js v3.0的对象构造和类继承(cocos creator js ts),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:cocos creator javascript,cocos2d-js教程,cocos2d-js教程,cocos jsc,cocos2d-js-min.js,cocos2d-js教程,cocos js,cocos2d-js-min.js,内容如对您有帮助,希望把文章链接给更多的朋友!

在Cocos2d-JS中,对象的构造方式和Cocos2d-x一样,使用各个类的create函数来构造。在Cocos2d-JS v3.0我们还将为你带来一种传统的方式,即使用new操作符。另外,在v3.0 alpha1版本中,因为我们还没有找到较好的解决办法,所以不能继承JSB中的引擎类。但是在v3.0 alpha2中,这个问题已经解决了。由于使用new操作符,编写继承代码也更加容易了。

在这篇文档中,我们将会介绍如何使用它们,以及简要的实现原理。

1. 弃用的create函数

由于Cocos2d-JS v3.0支持了更简单方便的new构造方式,所有create以及createWithXXX函数都被弃用了,调用它们将会收到警告消息。new构造方式支持所有类型的旧create函数的参数。

开发者有两种方式构造一个Sprite对象:统一的create函数和new操作符调用构造函数,它们接受相同的参数。在html5和jsb中都支持这2种方式,但是他们的实现原理大不相同。

2. 构造函数

我们现在可以直接使用new操作符来调用类的构造函数了。例如,开发者们应该使用new cc.Sprite(...)来创建一个cc.Sprite对象,在html5和jsb中都支持这种方式,但是他们的实现原理大不相同:

在html5引擎中,我们重构了所有引擎类的ctor函数,使它们可以接受和create函数相同的参数。

在JSB中如果使用new操作符来调用cc.Sprite的构造函数,我们实际上在C&#;&#;层会调用js_cocos2dx_Sprite_constructor函数。在这个C&#;&#;函数中,会为这个精灵对象分配内存,并把它添加到自动回收池,然后调用js层的_ctor函数来完成初始化。在_ctor函数中会根据参数类型和数量调用不同的init函数,这些init函数也是C&#;&#;函数的绑定:

JavascriptJSBCocos2d-xcc.Sprite.initWithSpriteFrameNamejs_cocos2dx_Sprite_initWithSpriteFrameNamecocos2d::Sprite::initWithSpriteFrameNamecc.Sprite.initWithSpriteFramejs_cocos2dx_Sprite_initWithSpriteFramecocos2d::Sprite::initWithSpriteFramecc.Sprite.initWithFilejs_cocos2dx_Sprite_initWithFilecocos2d::Sprite::initWithFilecc.Sprite.initWithTexturejs_cocos2dx_Sprite_initWithTexturecocos2d::Sprite::initWithTexture【cocos2d-js官方文档】十八、Cocos2d-js v3.0的对象构造和类继承(cocos creator js ts)

这个过程的顺序图如下:

3. 继承

在Cocos2d-html5 2.x中,当我们继承一个类时,我们需要在create函数中使用不同的init函数,例如:

在Cocos2d-JS中,我们只需要编写带有正确参数的ctor函数,并调用_super函数就可以了。

在html5引擎中这很好理解,因为我们支持使用new操作符。

但在JSB中这有点复杂,在_super函数中我们会调用Sprite的C&#;&#;层ctor函数:js_cocos2dx_Sprite_ctor,这个函数不仅实例化精灵对象,也会调用cc.Sprite.prototype._ctor并传递参数。_ctor函数对精灵类真正的初始化函数做了封装,会根据传递的参数来调用不同的初始化函数,这样我们最终就完成了自定义ctor函数的执行。

这个过程的顺序图如下:

转载:

【cocos2d-js官方文档】二十一、v3相对于v2版本的api变动 CCAudio.jsSimpleAudioEngine.js改名为CCAudio.js。AudioEngine中删除了以下几个方法:preloadMusicpreloadEffectisFormatSupportedpreloadSoundcc.AudioEngine.end被移到了实例中,而不

【cocos2d-js官方文档】二十、moduleConfig.json 概述该配置文件相当于v2版本中的jsloader.js。改造的目的是为了使得配置纯粹化,同时也能比较好的支持cocos-console、cocos-utils甚至是用户自定义脚本工具

【cocos2d-js官方文档】十九、Cocos2d-JS单文件引擎使用指引 这篇指引主要介绍如何使用从在线下载工具下载下来的Cocos2d-JS的单文件引擎。你有可能下载了下面三个版本中的一个:Cocos2d-JSFullVersion:完整版引擎包含

标签: cocos creator js ts

本文链接地址:https://www.jiuchutong.com/biancheng/369119.html 转载请保留说明!

上一篇:【cocos2d-js官方文档】十八、Cocos2d-JS v3.0中的属性风格API(cocos2d官网)

下一篇:【cocos2d-js官方文档】二十一、v3相对于v2版本的api变动(cocos2d官网)

  • 居民企业投资收益免征企业所得税
  • 随机赠送礼品个人所得税
  • 国税地税合并是成功的还是失败的
  • 劳务外包人员在本公司可报销吗
  • 出售可供出售金融资产的利得属于什么活动
  • 更正个税申报需要做账吗
  • 建筑企业有哪些
  • 信息技术费如何做账
  • 发票一年不能开超多少才不扣税费
  • 直接计入当期损益的利得和损失,是指( )的利得或损失
  • 全年一次性奖金税收计算器
  • 银行属于个人吗
  • 应付税款法账务处理
  • 企业土地是不是都应该缴纳房产税?
  • 延迟抵扣的税务风险
  • 总资产报酬率可以用净利润计算吗
  • 有子公司一定要交社保吗
  • 固定资产合并抵扣增值税
  • 商誉减值测试的方法有哪些
  • 冲减材料采购成本
  • 怎么在电脑上设置输入法
  • 已达到计算机的连接数最大值win7
  • 偶然所得是什么科目
  • 高新技术研发的会议有哪些
  • 购买预付卡如何记账
  • 总公司人员的工资子公司可以发吗
  • vim diff对比
  • 存货退回账务处理
  • php://input用法
  • 接受赠品的账务处理流程
  • wordpress文章分页插件
  • 资本化计入
  • php处理数组的函数
  • yii2带搜索功能的下拉框实例详解
  • vue路由用法
  • 创建数据的命令是
  • 提取企业所得税怎么做会计科目
  • 免征和抵扣税额的区别
  • python中如何创建一个新文件
  • 差旅费报销有哪些
  • 企业向合伙企业分红怎么交税
  • php 操作mongodb
  • 专用发票跨月冲红流程
  • 承兑汇票私人贴息双方都违法吗
  • 印花税会计处理办法
  • SQL Server实时同步更新远程数据库遇到的问题小结
  • 加盟费明细
  • 坏账准备?
  • 什么时候开始取卵
  • 未分配利润太多的危害
  • 英飞拓拟2.1亿出售子公司股权
  • 缴纳房产税和城镇房产税
  • 生物资产转让增值税
  • 报销单会计分录怎么写
  • 无形资产自行开发
  • 会计中的一级科员是什么
  • 三栏明细账本怎样填写
  • 净资产=资产-负债
  • 存货跌价准备怎么结转成本
  • mysql5.5怎么用
  • 用命令创建文件夹
  • ubuntu安装超详细教程
  • Ubuntu系统怎么截图
  • winproxy.exe - winproxy是什么进程
  • dvd-rom drive是什么意思
  • win8系统崩溃按f8没用
  • win7系统在那个文件夹
  • win10怎么添加游戏手柄
  • win7升win8要钱吗
  • opengl顶点坐标纹理坐标关系
  • 代码的历史
  • 使用jquery操作dom
  • bat批处理命令大全
  • 你有一份来信
  • jquery怎么写
  • centos创建shell脚本
  • 冒烟测试和接口测试
  • python中for循环写法
  • 机动车发票怎样开
  • 深圳市福田区行政代码是多少
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设