CocosCreator3.8研究笔记(六)CocosCreator 脚本装饰器的理解

news2024/12/25 23:55:42

一、什么是装饰器?


装饰器是TypeScript脚本语言中的概念。

TypeScript的解释:在一些场景下,我们需要额外的特性来支持标注或修改类及其成员。装饰器(Decorators)为我们在类的声明及成员上通过元编程语法添加标注提供了一种方式。


在TypeScript中,装饰器分为:类装饰器、属性装饰器、方法装饰器、方法参数装饰器。


由此可知:

  • 装饰器的作用:标注或修改类及其成员
  • 装饰器作用的目标:类及其成员(类,方法, 访问符,属性或参数)

大家都知道,从Cocos Creator3.x 开始,开发语言主要是:TypeScript,那么装饰器也是需要必须理解的。


二、CocosCreator 的装饰器


在理解CocosCreator 的装饰器之前,我们需要先了解几个知识点:CocosCreator序列化Cocos Creator 的脚本编译时机CocosCreator装饰器执行时机


  • CocosCreator序列化: 编辑器中设置好了属性,会被保存到资源文件中,在使用的时候,自动还原成设置好的属性。这就是CocosCreator的序列化。

  • 脚本编译时机: 在前面介绍vs code 脚本编辑工具的时候,我们也有介绍到 ,脚本编译的时机:修改项目脚本后,重新返回 Cocos Creator 会自动的触发脚本编译。然后我们也配置了 VS Code 编译任务, 配置完成后,在VS Code 中按下快捷键 Ctrl + Shift + B 便会自动显示 CocosCreator compile,执行即可编译。

感兴趣的朋友请前往查看CocosCreator3.8研究笔记(二)windows环境 VS Code 编辑器的配置。


  • 装饰器执行时机:装饰器对类行为的改变,是代码编译时发生的,而不是在运行时。也就是说,装饰器的本质就是编译时执行的函数。

1、CC 类


(1)、什么是cc类?

将ccclass 关键词做为注解,添加在类上时,这个类被称为CC类。


语法如下:

@ccclass('name')  

如图,PlayerControl 为cc类:


在这里插入图片描述


(2)、CC 类的作用

CC 类注入了控制cocos creator 对该类对象的序列化、编辑器对此类对象的显示。


(3)、CC 类注意事项

  • CC类的名称是唯一的

  • 不能以 cc.internal. 作为前缀,这是 Cocos Creator 的保留类名前缀

  • 没声明 ccclass 的组件类,无法作为组件添加到节点上

  • 当CC类是组件时,Node 可以通过组件类的CC类名查找到该组件


2、组件类装饰器

组件类装饰器只能用来修饰 Component 的子类。


(1)、executeInEditMode

正常情况下,所有组件只会在运行时执行, 在编辑器模式下并不会触发,executeInEditMode 默认值为 false

如果需要在编辑器模式下就执行,我们可以将executeInEditMode 设置为’true’,表示允许在编辑器模式下运行。


如下代码:

const { ccclass, executeInEditMode } = _decorator;
@ccclass('Example')
@executeInEditMode(true)
export class Example extends Component {
    update (dt: number) {
        // 在编辑器下每帧执行
    }
}

(2)、requireComponent

requireComponent 参数用来指定当前组件的依赖组件,默认值为 null

当组件添加到节点上时,如果依赖的组件不存在,引擎会自动将依赖组件添加到同一个节点,防止脚本出错。


const { ccclass, requireComponent } = _decorator;

@ccclass('Example')
@requireComponent(Sprite)
export class Example extends Component {
}

(3)、executionOrder

executionOrder 用来指定脚本生命周期回调的执行优先级。

该优先级设定只对 onLoadonEnablestartupdatelateUpdate 有效,对 onDisableonDestroy 无效。

  • 对于同一节点上的不同组件,数值小的先执行,数值相同的按组件添加先后顺序执行
  • 对于不同节点上的同一组件,按节点树排列决定执行的先后顺序。

const { ccclass, executionOrder } = _decorator;

@ccclass('Example')
@executionOrder(3)
export class Example extends Component {
}

(4)、disallowMultiple

同一节点上只允许添加一个同类型(含子类)的组件,防止逻辑发生冲突,默认值为 false。

const { ccclass, disallowMultiple } = _decorator;

@ccclass('Example')
@disallowMultiple(true)
export class Example extends Component {
}

(5)、menu

@menu(path) 用来将当前组件添加到组件菜单中。

该菜单:是添加在 属性检查器 面板中按下添加组件按钮后的下拉框内。


在这里插入图片描述


在这里插入图片描述


const { ccclass, menu } = _decorator;

@ccclass('Example')
@menu('foo/bar')
export class Example extends Component {
}

(6)、help

指定当前组件的帮助文档的 URL。

设置完成后,在 属性检查器 中就会出现一个帮助图标,点击即可打开帮助文档的 URL。


const { ccclass, help } = _decorator;
@ccclass('Example')
@help('https://docs.cocos.com/creator/3.8/manual/zh/scripting/decorator.html')
export class Example extends Component {
}

3、属性装饰器(property)

属性装饰器用于控制 Cocos Creator 编辑器中对该属性的序列化、属性检查器 中对该属性的展示等。


属性装饰器 property 可以被应用在 cc 类的属性或访问器上。


(1)、属性编辑器常见属性类型

  • 基础属性:CCInteger、CCFloat、CCBoolean、CCString

  • cc 类型

  • 数组类型:[CCInteger]、[Node]


当使用基础属性类型或者 cc 类作为数组元素时,将分别以整数数组和节点数组的形式在 属性检查器 中展示。


  • 若值的类型是 JavaScript 原始类型 numberstringboolean,则其类型分别对应 Creator 的CCFloatCCStringCCBoolean

语法如下:

@property({ type:Node,visible:true})

@property({type:CCInteger,visible:true})
n:number=5;

@property({ type:[Node],visible:true})


下图是脚本文件 PlayerControl.ts 与Creator 编辑器属性检查器中属性展示:

在这里插入图片描述


Cocos Creator额外提供几种装饰器可以快速声明 cc 类型。

装饰器对应的 property 写法
@type(t)@property(t)
@integer@property(CCInteger)
@float@property(CCFloat)


以下声明,可以替代 @property 的写法:

@integer // 声明属性的 cc 类型为整数
index = 0;

@type([Node]) // 声明属性 children 的 cc 类型为 Node 数组
children: Node[] = [];

@type(String) // 警告:不应该使用构造函数 String。等价于 CCString。也可以选择不声明类型
text = '';

(2)、属性检查器中属性的可见性


需要注意的是:不是所有定义的属性装饰器都是可见的,在以下两种情况,是不会显示在属性检查器:

  • 属性名是否以 _ 开头 ,会识别为 private 属性,private 属性不会在编辑器组件属性面板上显示。
  • visible属性值为false

(3)、序列化(serializable)


属性默认情况下都会被序列化,序列化后就会将编辑器中设置好的属性值保存到场景等资源文件中,之后在加载场景时就会自动还原成设置好的属性值。如果不想序列化,可以设置 serializable: false。

@property({ serializable: false })
num = 0;

(4)、override

所有属性都会被子类继承,如果子类要覆盖父类同名属性,需要显式设置 override 参数,否则会有重名警告:

@property({ tooltip: "my id", override: true })
id = "";

(5)、group

当脚本中定义的属性过多且杂时,可通过 group 对属性进行分组、排序,方便管理。

同时还支持对组内属性进行分类。


group 写法包括以下两种:

@property({ group: { name } })
@property({ group: { id, name, displayOrder, style } })


参数说明
id分组 ID,string 类型,是属性分组组号的唯一标识,默认为 default
name组内属性分类的名称,string 类型。
displayOrder对分组进行排序,number 类型,数字越小,排序越靠前。默认为 Infinity,表示排在最后面。 若存在多个未设置的分组,则以在脚本中声明的先后顺序进行排序。
style分组样式,目前支持 tabsection 样式。 默认为 tab

(6)、get/set 使用

@property
_num:number=1;
set num(val){
    this._num=val;
}
get num(){
    return this._num;
}

(7)、Cocos Creator 常用内置属性

  • Color(颜色)
  @property(Color)
  color:Color
  • Gradient (渐变)
  @property(Gradient)
  gradient = new Gradient();
  • GradientRange (渐变色范围)

通过颜色、渐变色、双颜色或双渐变色控制颜色

  @property(GradientRange)
  gradientRange:GradientRange = new GradientRange();

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/972713.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

Java23种设计模式之【单例模式】

目录 一.单例模式的起源,和应用场景 1.单例模式的前世今生! 2.什么是单例模式? 2.1使用单例模式的注意事项 2.2如何理解单例模式? 2.3单例模式的优势以及不足! 2.4使用场景 二.实现 1.实现思路 1.1创建一个 S…

华为OD机试-贪吃蛇

题目描述 【贪吃蛇】贪吃蛇是一个经典游戏,蛇的身体由若干方格连接而成,身体随蛇头移动。蛇头触碰到食物时,蛇的长度会增加一格。蛇头和身体的任一方格或者游戏版图边界碰撞时,游戏结束。 下面让我们来完成贪吃蛇游戏的模拟&…

Ajax + Promise复习简单小结simple

axios使用 先看看老朋友 axios axios是基于Ajaxpromise封装的 看一下他的简单使用 安装:npm install axios --save 引入:import axios from axios GitHub地址 基本使用 axios({url: http://hmajax.itheima.net/api/province}).then(function (result…

接口自动化测试系列-yml管理测试用例

项目源码 目录结构及项目介绍 整体目录结构,目录说明参考 测试用例结构类似httprunner写法,可参考demo 主要核心函数 用例读取转换json import yaml import main import os def yaml_r():curpath f{main.BASE_DIR}/quality_management_logic/ops_ne…

centos7挂载nfs存储

centos7挂载nfs存储 小白教程,一看就会,一做就成。 1.安装NFS服务 #安装nfs yum -y install rpcbind nfs-utils#创建目录(我这边是/data/upload) mkdir -p /data/upload#写/etc/fstab文件,添加要挂载的nfs盘 172.16.…

Ubuntu18.04系统下通过ROS控制Kinova真实机械臂-多种实现方式

所用测试工作空间test_ws:包含官网最原始的功能包 一、使用Kinova官方Development center控制真实机械臂 0.在ubuntu系统安装Kinova机械臂的Development center,这一步自行安装,很简单。 1.使用USB连接机械臂和电脑 2.Development center…

【力扣周赛】第 361 场周赛(⭐前缀和+哈希表 树上倍增、LCA⭐)

文章目录 竞赛链接Q1:7020. 统计对称整数的数目竞赛时代码——枚举预处理 Q2:8040. 生成特殊数字的最少操作(倒序遍历、贪心)竞赛时代码——检查0、00、25、50、75 Q3:2845. 统计趣味子数组的数目竞赛时代码——前缀和…

jQuery成功之路——jQuery动画效果和遍历效果概述

一、jQuery动画效果 1.1显示效果 方法 方法名称解释show([speed],[easing],[fn]])显示元素方法hide([speed],[easing],[fn]])隐藏元素方法toggle([speed],[easing],[fn])切换元素方法,显示的使之隐藏,隐藏的使之显示 参数 参数名称解释speed三种预…

CocosCreator3.8研究笔记(五)CocosCreator 脚本说明及使用(下)

在Cocos Creator中,脚本代码文件分为模块和插件两种方式: 模块一般就是项目的脚本,包含项目中创建的代码、引擎模块、第三方模块。 插件脚本,是指从 Cocos Creator 属性检查器中导入的插件,一般是引入第三方引入库文件…

管理类联考——数学——汇总篇——知识点突破——数据分析——排列组合

角度——🐴 角度——👩 排列组合的基本步骤(固定解题体系) 先取后排:即先取出元素,后排列元素,切勿边取边排. 逐次进行:按照一定的顺序逐次进行排列组合. 实验结束:整个…

vscode保存格式化自动去掉分号、逗号、双引号

之前每次写完代码都是双引号还有分号,看着很难受,就像修改一下,让它变成单引号,并且不加上引号:如下形式,看着简洁清晰明了 修改方式:更改 settings.json 文件 快捷键“Ctrl Shift P”打开命令…

UmeTrack: Unified multi-view end-to-end hand tracking for VR 复现踩坑记录

在 github 上找到了开源代码:https://github.com/facebookresearch/UmeTrack/tree/main 环境配置 运行第三行,报错,缺少torch。改成先运行第四行,成功。 再运行第三行,报错,required to install pyproj…

uniapp 集成蓝牙打印功能(个人测试佳博打印机)

uniapp 集成蓝牙打印功能(个人测试京博打印机) uniapp 集成蓝牙打印功能集成佳博内置的接口 uniapp 集成蓝牙打印功能 大家好今天分析的是uniapp 集成蓝牙打印功能,个人开发是app,应该是支持H5(没试过) 集成佳博内置的接口 下载dome地址&…

空间复杂度和时间复杂度

😜作 者:是江迪呀✒️本文关键词:时间复杂度、空间复杂度、算法☀️每日 一言:车到山前必有路,船到码头自然直! 一、前言 时间复杂度和空间复杂度是算法和数据结构领域中两个重要的概念&#…

服务器(I/O)之多路转接

五种IO模型 1、阻塞等待:在内核将数据准备好之前,系统调用会一直等待。所有的套接字,默认都是阻塞方式。 2、非阻塞等待:如果内核没有将数据准备好,系统调用仍然会返回,并且会返回EWUOLDBLOCK或者EAGAIN错…

springboot邮件发送和接收验证码

springboot邮件篇 要在Internet上提供电子邮件功能,必须有专门的电子邮件服务器。例如现在Internet很多提供邮件服务的厂商:新浪、搜狐、163、QQ邮箱等,他们都有自己的邮件服务器。这些服务器类似于现实生活中的邮局,它主要负责接…

【C语言】辗转相除法求最大公约数(详解)

辗转相除法求最大公约数 辗转相除法(又称欧几里德算法)是一种用于求解两个整数的最大公约数的方法。本文将使用C语言来实现辗转相除法,并对其原理进行解释。 辗转相除法的原理 辗转相除法的原理非常简单。假设有两个整数a和b,其…

Vue+Element-ui+SpringBoot搭建后端汽车租赁管理系统

最近在做项目,花了一周的时间搭建了一个十分完备的汽车租赁后端管理系统。页面采用纯Vue2Element-ui搭建,后端采用SpringbootMybatis搭建,数据库采用Mysql。包括了登录验证,根据不同权限进入不同界面、数据增删改查、表格分页、表…

iOS实时监控与报警器

在现代信息化社会中,即使我们不在电脑前面也能随时获取到最新的数据。而苹果公司提供的iOS推送通知功能为我们带来了一种全新的方式——通过手机接收实时监控和报警信息。 首先让我们了解一下iOS推送通知。它是一个强大且灵活可定制化程度高、适用于各类应用场景&a…

(二十一)大数据实战——Flume数据采集之复制和多路复用案例实战

前言 本节内容我们完成Flume数据采集的一个多路复用案例,使用三台服务器,一台服务器负责采集本地日志数据,通过使用Replicating ChannelSelector选择器,将采集到的数据分发到另外俩台服务器,一台服务器将数据存储到hd…