位置: 编程技术 - 正文

【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官网)

  • 税务会计常用会计科目
  • 企业转出多交增值税吗
  • 如何做好存货管理,从哪方面去做
  • 股份有限公司个人所得税缴纳比例
  • 税控盘清卡失败
  • 民非企业是否可以盈利
  • 个体户个税计算方法2022税率表
  • 留存收益总额不变
  • 可以采用三栏式的明细账的有
  • 商业承兑汇票可以提前承兑吗
  • 长期股权投资的交易费用计入哪里
  • 出售资产时递延所得税怎么处理
  • 应收账款资产减值损失转回和核销的区别
  • 支付土地流转费
  • 商业企业购货分录
  • 未取得正式发票怎么整改
  • 重置申报清册是什么意思
  • 直系亲属之间转账要交税吗
  • 债权投资属于其他非流动金融资产嘛
  • 财产保险费计入什么科目
  • 企业或公司的证明怎么弄
  • 服务业核定征收税率表
  • txt文档乱码怎么办
  • 公司的职工教育是指什么
  • 关联企业需要计提坏账
  • 以前年度应付账款做到制造费用如何改账
  • DxDebugService.exe是什么进程 DxDebugService进程安全吗
  • PHP:pg_field_type_oid()的用法_PostgreSQL函数
  • 有留抵税额怎么做分录
  • lstm多对多
  • 凭证包括几个部分
  • 无法支付的货款如何处理
  • php中的异常和错误怎么写
  • 购买税控盘后要交税吗
  • 核电站弃置费用怎么算
  • 前端技巧
  • 购入库存商品会计分录摘要
  • 小微企业免征增值税报表填写
  • 母公司子公司合并
  • 公司股票买卖账务处理
  • js回调函数如何返回值
  • 会务费如何入账
  • 出租人在融资租赁中需要处理的会计问题
  • 信息技术服务费怎么做会计分录
  • sql中循环语句怎么写
  • 为什么收到要发1
  • 建筑安装印花
  • 专项应付款如何记账
  • 被挂靠方并收取管理费的公司怎样处理账务?
  • 低值易耗品属于周转材料吗
  • 收到返还工会经费账务处理
  • 如何操作开具红字发票
  • 银行账户是不是卡号
  • 判断成本法核算方法
  • mysql几天能学会
  • mysql group order
  • 如何给电脑重装系统win7系统
  • ubuntu18.04单网卡多ip
  • win10安装 升级
  • macbook的qq怎么更换背景
  • QuiteRSS: Linux桌面的RSS阅读器 你值得拥有
  • 如何修改windows密码策略
  • win10系统怎么修改字体大小
  • linux使用语言
  • js动态表格可修改表格数据
  • jquery刷新局部页面
  • 服务器总是自动关机
  • 转换什么
  • jquery 鼠标
  • 关于两个人感情文案
  • jquery鼠标点击
  • javascript基本语法
  • 珠海市中心
  • 北京税务机关代码查询
  • 工会经费什么时候交
  • 税务局房屋评估怎样做低
  • 高新区税务局发工资时间
  • 税控盘百旺怎样清卡
  • 优化营商环境关于人才工作
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设