位置: 编程技术 - 正文

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

  • 附加税税负
  • 红冲以后怎么做账
  • 服务费发票需要交印花税吗
  • 实收资本能直接转出来吗
  • 非正常户发票管理
  • 企业所得税公益捐赠扣除限额
  • 车子按揭利息
  • 公司租的员工宿舍退租,现在要开发票给人家退房租
  • 增值税税控系统的税务处理
  • 发票红冲钱怎么退给对方
  • 房地产企业增值税税率是多少
  • 农村合作社开具的专用发票免税吗
  • 上个月有留抵税这个月怎么结转税金
  • 广告费扣除年限
  • 注册公司之后需要交社保吗
  • 旅行社成本票没有收到,怎么挂账
  • 非全日制员工个税扣除标准
  • 权益净利率计算公式推导
  • 期望值E(X)怎么算例题
  • 电商企业收入成本如何核算
  • 跨月发票作废怎么红冲
  • 视同内销发票重开要带税吗
  • 苹果mac切换桌面快捷键
  • 员工垫付公司钱怎么入账
  • 员工可以一起辞职吗
  • appdata如何移动
  • php使用pdo连接数据库
  • php string函数
  • 日记账登记错了怎么办
  • 施工企业自建自用的工程
  • php require的用法
  • 公司出租房屋租赁发票税率
  • 材料采购计入资产负债表哪里
  • 未到期的应收票据办理贴现会计分录
  • web安全如何入门
  • 结霜的早晨
  • laravel create
  • php操作json
  • php序列化和反序列化函数
  • 结转工资费用
  • 杭州西湖古风
  • yolov3 pytorch详解
  • php 后端
  • php红包源码
  • wordpress限制邮箱注册
  • 注册资本增加了怎么做账
  • 错账的类型及对应的更正方法
  • 简述跨期摊提账户
  • 什么叫做归属
  • 代收的运输费用怎么入账
  • 企业之间借贷是否合法有效
  • 原材料账户该如何做账
  • 发行公司债券发生的折价
  • ms-sql-s
  • mysql怎么替换某个值
  • 待抵扣进项税额是二级还是三级
  • 厂房出租自用各种费用
  • 当月发生逾期押金收入12870元
  • 租金摊销会计分录
  • 多计的人工成本怎么做账
  • 存货换入无形资产账务处理
  • 房产经纪公司有哪些部门组成
  • 年底暂估收入,年初怎么做
  • 5000以下固定资产一次性计提折旧政策
  • 文化事业建设费逾期未申报怎么办
  • 航天信息服务费280元如何申报
  • win8恢复出厂设置方法
  • mac红
  • linux ifconfig命令详解
  • linux系统怎么停止ping
  • 使用和启动故障的区别
  • 深入理解ffmpeg pdf
  • require jquery
  • nodejs vue
  • 常见python函数
  • javascript如何学
  • python3连接pg执行命令
  • 如何加强税务系统财务管理工作
  • 税务师事务所牌匾
  • 郑州房子契税退税
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设