ParticleSystem3D
类型
继承于 RenderComponent
3D 粒子组件
索引
属性(properties)
duration
Number
粒子系统运行时间capacity
Number
粒子系统能生成的最大粒子数量loop
Boolean
粒子系统是否循环播放playOnAwake
Boolean
粒子系统加载后是否自动开始播放prewarm
Boolean
选中之后,粒子系统会以已播放完一轮之后的状态开始播放(仅当循环播放启用时有效)simulationSpace
Space
选择粒子系统所在的坐标系
...simulationSpeed
Number
控制整个粒子系统的更新速度。startDelay
CurveRange
粒子系统开始运行后,延迟粒子发射的时间。startLifetime
CurveRange
粒子生命周期。startColor
GradientRange
粒子初始颜色scaleSpace
Space
缩放空间startSize
CurveRange
粒子初始大小startSpeed
CurveRange
粒子初始速度startRotation
CurveRange
粒子初始旋转角度gravityModifier
CurveRange
粒子受重力影响的重力系数rateOverTime
CurveRange
每秒发射的粒子数rateOverDistance
CurveRange
每移动单位距离发射的粒子数bursts
[Burst]
设定在指定时间发射指定数量的粒子的 Brust 的数量shapeModule
ShapeModule
粒子发射器模块colorOverLifetimeModule
ColorOverLifetimeModule
颜色控制模块sizeOvertimeModule
SizeOvertimeModule
粒子大小模块velocityOvertimeModule
VelocityOvertimeModule
粒子速度模块forceOvertimeModule
ForceOvertimeModule
粒子加速度模块limitVelocityOvertimeModule
LimitVelocityOvertimeModule
粒子限制速度模块(只支持 CPU 粒子)rotationOvertimeModule
RotationOvertimeModule
粒子旋转模块textureAnimationModule
TextureAnimationModule
贴图动画模块trailModule
TrailModule
粒子轨迹模块renderMode
RenderMode
设定粒子生成模式velocityScale
Number
在粒子生成方式为 StrecthedBillboard 时,对粒子在运动方向上按速度大小进行拉伸lengthScale
Number
在粒子生成方式为 StrecthedBillboard 时,对粒子在运动方向上按粒子大小进行拉伸mesh
Mesh
粒子模型particleMaterial
Material
粒子材质trailMaterial
Material
粒子轨迹材质sharedMaterials
[Material]
渲染组件使用的材质。__eventTargets
Array
注册所有相关的 EventTargets,所有事件回调将在_onPreDestroy
中删除。node
Node
该组件被附加到的节点。uuid
String
组件的 uuid,用于编辑器。_enabled
Boolean
enabled
Boolean
表示该组件自身是否启用。enabledInHierarchy
Boolean
表示该组件是否被启用并且所在的节点也处于激活状态。_isOnLoadCalled
Number
返回一个值用来判断 onLoad 是否被调用过,不等于 0 时调用过,等于 0 时未调用。_name
String
_objFlags
Number
name
String
该对象的名称。isValid
Boolean
表示该对象是否可用(被 destroy 后将不可用)。
方法
play
播放粒子效果pause
暂停播放粒子效果stop
停止播放粒子效果clear
将所有粒子从粒子系统中清除getMaterial
根据指定索引获取材质getMaterials
获取所有材质。setMaterial
根据指定索引设置材质update
如果该组件启用,则每帧调用 update。lateUpdate
如果该组件启用,则每帧调用 LateUpdate。__preload
__preload
is called before every onLoad....onLoad
当附加到一个激活的节点上或者其节点第一次激活时候调用。start
如果该组件第一次启用,则在所有组件的 update 之前调用。onEnable
当该组件被启用,并且它的节点也激活时。onDisable
当该组件被禁用或节点变为无效时调用。onDestroy
该方法为生命周期方法,父类未必会有实现。onFocusInEditor
onLostFocusInEditor
resetInEditor
用来初始化组件或节点的一些属性,当该组件被第一次添加到节点上或用户点击了它的 Reset 菜单时调用。addComponent
向节点添加一个组件类,你还可以通过传入脚本的名称来添加组件。getComponent
获取节点上指定类型的组件,如果节点有附加指定类型的组件,则返回,如果没有则为空。getComponents
返回节点上指定类型的所有组件。getComponentInChildren
递归查找所有子节点中第一个匹配指定类型的组件。getComponentsInChildren
递归查找自身或所有子节点中指定类型的组件_getLocalBounds
以便编辑器的场景视图可以正确地执行点选测试。onRestore
onRestore 是用户在检查器菜单点击 Reset 时,对此组件执行撤消操作后调用的。schedule
调度一个自定义的回调函数。scheduleOnce
调度一个只运行一次的回调函数,可以指定 0 让回调函数在下一帧立即执行或者在一定的延时之后执行。unschedule
取消调度一个自定义的回调函数。unscheduleAllCallbacks
取消调度所有已调度的回调函数:定制的回调函数以及update
回调函数。destroy
销毁该对象,并释放所有它对其它对象的引用。_destruct
清除实例中的所有引用。_onPreDestroy
在对象被销毁之前调用。_serialize
为此对象定制序列化。_deserialize
从自定义序列化数据初始化此对象。
Details
属性(properties)
duration
粒子系统运行时间
meta | description |
---|---|
类型 | Number |
定义于 | cocos2d/core/3d/particle/particle-system-3d.ts:76 |
capacity
粒子系统能生成的最大粒子数量
meta | description |
---|---|
类型 | Number |
定义于 | cocos2d/core/3d/particle/particle-system-3d.ts:86 |
loop
粒子系统是否循环播放
meta | description |
---|---|
类型 | Boolean |
定义于 | cocos2d/core/3d/particle/particle-system-3d.ts:103 |
playOnAwake
粒子系统加载后是否自动开始播放
meta | description |
---|---|
类型 | Boolean |
定义于 | cocos2d/core/3d/particle/particle-system-3d.ts:111 |
prewarm
选中之后,粒子系统会以已播放完一轮之后的状态开始播放(仅当循环播放启用时有效)
meta | description |
---|---|
类型 | Boolean |
定义于 | cocos2d/core/3d/particle/particle-system-3d.ts:123 |
simulationSpace
选择粒子系统所在的坐标系
世界坐标(不随其他物体位置改变而变换)
局部坐标(跟随父节点位置改变而移动)
自定坐标(跟随自定义节点的位置改变而移动)
meta | description |
---|---|
类型 | Space |
定义于 | cocos2d/core/3d/particle/particle-system-3d.ts:144 |
simulationSpeed
控制整个粒子系统的更新速度。
meta | description |
---|---|
类型 | Number |
定义于 | cocos2d/core/3d/particle/particle-system-3d.ts:173 |
startDelay
粒子系统开始运行后,延迟粒子发射的时间。
meta | description |
---|---|
类型 | CurveRange |
定义于 | cocos2d/core/3d/particle/particle-system-3d.ts:181 |
startLifetime
粒子生命周期。
meta | description |
---|---|
类型 | CurveRange |
定义于 | cocos2d/core/3d/particle/particle-system-3d.ts:191 |
startColor
粒子初始颜色
meta | description |
---|---|
类型 | GradientRange |
定义于 | cocos2d/core/3d/particle/particle-system-3d.ts:201 |
scaleSpace
缩放空间
meta | description |
---|---|
类型 | Space |
定义于 | cocos2d/core/3d/particle/particle-system-3d.ts:211 |
startSize
粒子初始大小
meta | description |
---|---|
类型 | CurveRange |
定义于 | cocos2d/core/3d/particle/particle-system-3d.ts:221 |
startSpeed
粒子初始速度
meta | description |
---|---|
类型 | CurveRange |
定义于 | cocos2d/core/3d/particle/particle-system-3d.ts:231 |
startRotation
粒子初始旋转角度
meta | description |
---|---|
类型 | CurveRange |
定义于 | cocos2d/core/3d/particle/particle-system-3d.ts:242 |
gravityModifier
粒子受重力影响的重力系数
meta | description |
---|---|
类型 | CurveRange |
定义于 | cocos2d/core/3d/particle/particle-system-3d.ts:254 |
rateOverTime
每秒发射的粒子数
meta | description |
---|---|
类型 | CurveRange |
定义于 | cocos2d/core/3d/particle/particle-system-3d.ts:266 |
rateOverDistance
每移动单位距离发射的粒子数
meta | description |
---|---|
类型 | CurveRange |
定义于 | cocos2d/core/3d/particle/particle-system-3d.ts:276 |
bursts
设定在指定时间发射指定数量的粒子的 Brust 的数量
meta | description |
---|---|
类型 | [Burst] |
定义于 | cocos2d/core/3d/particle/particle-system-3d.ts:286 |
shapeModule
粒子发射器模块
meta | description |
---|---|
类型 | ShapeModule |
定义于 | cocos2d/core/3d/particle/particle-system-3d.ts:316 |
colorOverLifetimeModule
颜色控制模块
meta | description |
---|---|
类型 | ColorOverLifetimeModule |
定义于 | cocos2d/core/3d/particle/particle-system-3d.ts:336 |
sizeOvertimeModule
粒子大小模块
meta | description |
---|---|
类型 | SizeOvertimeModule |
定义于 | cocos2d/core/3d/particle/particle-system-3d.ts:355 |
velocityOvertimeModule
粒子速度模块
meta | description |
---|---|
类型 | VelocityOvertimeModule |
定义于 | cocos2d/core/3d/particle/particle-system-3d.ts:373 |
forceOvertimeModule
粒子加速度模块
meta | description |
---|---|
类型 | ForceOvertimeModule |
定义于 | cocos2d/core/3d/particle/particle-system-3d.ts:392 |
limitVelocityOvertimeModule
粒子限制速度模块(只支持 CPU 粒子)
meta | description |
---|---|
类型 | LimitVelocityOvertimeModule |
定义于 | cocos2d/core/3d/particle/particle-system-3d.ts:410 |
rotationOvertimeModule
粒子旋转模块
meta | description |
---|---|
类型 | RotationOvertimeModule |
定义于 | cocos2d/core/3d/particle/particle-system-3d.ts:428 |
textureAnimationModule
贴图动画模块
meta | description |
---|---|
类型 | TextureAnimationModule |
定义于 | cocos2d/core/3d/particle/particle-system-3d.ts:446 |
trailModule
粒子轨迹模块
meta | description |
---|---|
类型 | TrailModule |
定义于 | cocos2d/core/3d/particle/particle-system-3d.ts:465 |
renderMode
设定粒子生成模式
meta | description |
---|---|
类型 | RenderMode |
定义于 | cocos2d/core/3d/particle/particle-system-3d.ts:485 |
velocityScale
在粒子生成方式为 StrecthedBillboard 时,对粒子在运动方向上按速度大小进行拉伸
meta | description |
---|---|
类型 | Number |
定义于 | cocos2d/core/3d/particle/particle-system-3d.ts:513 |
lengthScale
在粒子生成方式为 StrecthedBillboard 时,对粒子在运动方向上按粒子大小进行拉伸
meta | description |
---|---|
类型 | Number |
定义于 | cocos2d/core/3d/particle/particle-system-3d.ts:532 |
mesh
粒子模型
meta | description |
---|---|
类型 | Mesh |
定义于 | cocos2d/core/3d/particle/particle-system-3d.ts:552 |
particleMaterial
粒子材质
meta | description |
---|---|
类型 | Material |
定义于 | cocos2d/core/3d/particle/particle-system-3d.ts:570 |
trailMaterial
粒子轨迹材质
meta | description |
---|---|
类型 | Material |
定义于 | cocos2d/core/3d/particle/particle-system-3d.ts:588 |
sharedMaterials
渲染组件使用的材质。
meta | description |
---|---|
类型 | [Material] |
定义于 | cocos2d/core/components/CCRenderComponent.js:63 |
__eventTargets
注册所有相关的 EventTargets,所有事件回调将在
_onPreDestroy
中删除。
meta | description |
---|---|
类型 | Array |
定义于 | cocos2d/core/components/CCComponent.js:63 |
node
该组件被附加到的节点。组件总会附加到一个节点。
meta | description |
---|---|
类型 | Node |
定义于 | cocos2d/core/components/CCComponent.js:80 |
示例
cc.log(comp.node);
uuid
组件的 uuid,用于编辑器。
meta | description |
---|---|
类型 | String |
定义于 | cocos2d/core/components/CCComponent.js:111 |
示例
cc.log(comp.uuid);
_enabled
meta | description |
---|---|
类型 | Boolean |
定义于 | cocos2d/core/components/CCComponent.js:152 |
enabled
表示该组件自身是否启用。
meta | description |
---|---|
类型 | Boolean |
定义于 | cocos2d/core/components/CCComponent.js:159 |
示例
comp.enabled = true;
cc.log(comp.enabled);
enabledInHierarchy
表示该组件是否被启用并且所在的节点也处于激活状态。
meta | description |
---|---|
类型 | Boolean |
定义于 | cocos2d/core/components/CCComponent.js:191 |
示例
cc.log(comp.enabledInHierarchy);
_isOnLoadCalled
返回一个值用来判断 onLoad 是否被调用过,不等于 0 时调用过,等于 0 时未调用。
meta | description |
---|---|
类型 | Number |
定义于 | cocos2d/core/components/CCComponent.js:211 |
示例
cc.log(this._isOnLoadCalled > 0);
_name
meta | description |
---|---|
类型 | String |
定义于 | cocos2d/core/platform/CCObject.js:76 |
_objFlags
meta | description |
---|---|
类型 | Number |
定义于 | cocos2d/core/platform/CCObject.js:83 |
name
该对象的名称。
meta | description |
---|---|
类型 | String |
定义于 | cocos2d/core/platform/CCObject.js:240 |
示例
obj.name = "New Obj";
isValid
表示该对象是否可用(被 destroy 后将不可用)。
当一个对象的destroy
调用以后,会在这一帧结束后才真正销毁。因此从下一帧开始isValid
就会返回 false,而当前帧内isValid
仍然会是 true。如果希望判断当前帧是否调用过destroy
,请使用cc.isValid(obj, true)
,不过这往往是特殊的业务需求引起的,通常情况下不需要这样。
meta | description |
---|---|
类型 | Boolean |
定义于 | cocos2d/core/platform/CCObject.js:258 |
示例
var node = new cc.Node();
cc.log(node.isValid); // true
node.destroy();
cc.log(node.isValid); // true, still valid in this frame
// after a frame...
cc.log(node.isValid); // false, destroyed in the end of last frame
方法
play
播放粒子效果
meta | description |
---|---|
定义于 | cocos2d/core/3d/particle/particle-system-3d.ts:669 |
pause
暂停播放粒子效果
meta | description |
---|---|
定义于 | cocos2d/core/3d/particle/particle-system-3d.ts:693 |
stop
停止播放粒子效果
meta | description |
---|---|
定义于 | cocos2d/core/3d/particle/particle-system-3d.ts:710 |
clear
将所有粒子从粒子系统中清除
meta | description |
---|---|
定义于 | cocos2d/core/3d/particle/particle-system-3d.ts:734 |
getMaterial
根据指定索引获取材质
meta | description |
---|---|
返回 | MaterialVariant |
定义于 | cocos2d/core/components/CCRenderComponent.js:156 |
参数列表
index
Number
getMaterials
获取所有材质。
meta | description |
---|---|
返回 | [MaterialVariant] |
定义于 | cocos2d/core/components/CCRenderComponent.js:179 |
setMaterial
根据指定索引设置材质
meta | description |
---|---|
返回 | Material |
定义于 | cocos2d/core/components/CCRenderComponent.js:193 |
参数列表
update
如果该组件启用,则每帧调用 update。
该方法为生命周期方法,父类未必会有实现。并且你只能在该方法内部调用父类的实现,不可在其它地方直接调用该方法。
meta | description |
---|---|
定义于 | cocos2d/core/components/CCComponent.js:232 |
参数列表
dt
Number the delta time in seconds it took to complete the last frame
lateUpdate
如果该组件启用,则每帧调用 LateUpdate。
该方法为生命周期方法,父类未必会有实现。并且你只能在该方法内部调用父类的实现,不可在其它地方直接调用该方法。
meta | description |
---|---|
定义于 | cocos2d/core/components/CCComponent.js:243 |
参数列表
dt
Number the delta time in seconds it took to complete the last frame
__preload
__preload
is called before every onLoad.
It is used to initialize the builtin components internally,
to avoid checking whether onLoad is called before every public method calls.
This method should be removed if script priority is supported.
meta | description |
---|---|
定义于 | cocos2d/core/components/CCComponent.js:254 |
onLoad
当附加到一个激活的节点上或者其节点第一次激活时候调用。onLoad 总是会在任何 start 方法调用前执行,这能用于安排脚本的初始化顺序。
该方法为生命周期方法,父类未必会有实现。并且你只能在该方法内部调用父类的实现,不可在其它地方直接调用该方法。
meta | description |
---|---|
定义于 | cocos2d/core/components/CCComponent.js:265 |
start
如果该组件第一次启用,则在所有组件的 update 之前调用。通常用于需要在所有组件的 onLoad 初始化完毕后执行的逻辑。
该方法为生命周期方法,父类未必会有实现。并且你只能在该方法内部调用父类的实现,不可在其它地方直接调用该方法。
meta | description |
---|---|
定义于 | cocos2d/core/components/CCComponent.js:278 |
onEnable
当该组件被启用,并且它的节点也激活时。
该方法为生命周期方法,父类未必会有实现。并且你只能在该方法内部调用父类的实现,不可在其它地方直接调用该方法。
meta | description |
---|---|
定义于 | cocos2d/core/components/CCComponent.js:291 |
onDisable
当该组件被禁用或节点变为无效时调用。
该方法为生命周期方法,父类未必会有实现。并且你只能在该方法内部调用父类的实现,不可在其它地方直接调用该方法。
meta | description |
---|---|
定义于 | cocos2d/core/components/CCComponent.js:301 |
onDestroy
当该组件被销毁时调用
该方法为生命周期方法,父类未必会有实现。并且你只能在该方法内部调用父类的实现,不可在其它地方直接调用该方法。
meta | description |
---|---|
定义于 | cocos2d/core/components/CCComponent.js:311 |
onFocusInEditor
meta | description |
---|---|
定义于 | cocos2d/core/components/CCComponent.js:321 |
onLostFocusInEditor
meta | description |
---|---|
定义于 | cocos2d/core/components/CCComponent.js:326 |
resetInEditor
用来初始化组件或节点的一些属性,当该组件被第一次添加到节点上或用户点击了它的 Reset 菜单时调用。这个回调只会在编辑器下调用。
meta | description |
---|---|
定义于 | cocos2d/core/components/CCComponent.js:331 |
addComponent
向节点添加一个组件类,你还可以通过传入脚本的名称来添加组件。
meta | description |
---|---|
返回 | Component |
定义于 | cocos2d/core/components/CCComponent.js:341 |
参数列表
示例
var sprite = node.addComponent(cc.Sprite);
var test = node.addComponent("Test");
getComponent
获取节点上指定类型的组件,如果节点有附加指定类型的组件,则返回,如果没有则为空。
传入参数也可以是脚本的名称。
meta | description |
---|---|
返回 | Component |
定义于 | cocos2d/core/components/CCComponent.js:359 |
参数列表
示例
// get sprite component.
var sprite = node.getComponent(cc.Sprite);
// get custom test calss.
var test = node.getComponent("Test");
getComponents
返回节点上指定类型的所有组件。
meta | description |
---|---|
返回 | Component[] |
定义于 | cocos2d/core/components/CCComponent.js:383 |
参数列表
示例
var sprites = node.getComponents(cc.Sprite);
var tests = node.getComponents("Test");
getComponentInChildren
递归查找所有子节点中第一个匹配指定类型的组件。
meta | description |
---|---|
返回 | Component |
定义于 | cocos2d/core/components/CCComponent.js:401 |
参数列表
示例
var sprite = node.getComponentInChildren(cc.Sprite);
var Test = node.getComponentInChildren("Test");
getComponentsInChildren
递归查找自身或所有子节点中指定类型的组件
meta | description |
---|---|
返回 | Component[] |
定义于 | cocos2d/core/components/CCComponent.js:419 |
参数列表
示例
var sprites = node.getComponentsInChildren(cc.Sprite);
var tests = node.getComponentsInChildren("Test");
_getLocalBounds
如果组件的包围盒与节点不同,您可以实现该方法以提供自定义的轴向对齐的包围盒(AABB), 以便编辑器的场景视图可以正确地执行点选测试。
meta | description |
---|---|
定义于 | cocos2d/core/components/CCComponent.js:439 |
参数列表
out_rect
Rect the Rect to receive the bounding box
onRestore
onRestore 是用户在检查器菜单点击 Reset 时,对此组件执行撤消操作后调用的。
如果组件包含了“内部状态”(不在 CCClass 属性中定义的临时成员变量),那么你可能需要实现该方法。
编辑器执行撤销/重做操作时,将调用组件的 get set 来录制和还原组件的状态。然而,在极端的情况下,它可能无法良好运作。
那么你就应该实现这个方法,手动根据组件的属性同步“内部状态”。一旦你实现这个方法,当用户撤销或重做时,组件的所有 get set 都不会再被调用。这意味着仅仅指定了默认值的属性将被编辑器记录和还原。
同样的,编辑可能无法在极端情况下正确地重置您的组件。如果你需要支持组件重置菜单,则需要在该方法中手工同步组件属性到“内部状态”。一旦你实现这个方法,组件的所有 get set 都不会在重置操作时被调用。这意味着仅仅指定了默认值的属性将被编辑器重置。
此方法仅在编辑器下会被调用。
meta | description |
---|---|
定义于 | cocos2d/core/components/CCComponent.js:452 |
schedule
调度一个自定义的回调函数。
如果回调函数已调度,那么将不会重复调度它,只会更新时间间隔参数。
meta | description |
---|---|
定义于 | cocos2d/core/components/CCComponent.js:544 |
参数列表
callback
function The callback functioninterval
Number Tick interval in seconds. 0 means tick every frame.repeat
Number The selector will be executed (repeat + 1) times, you can use cc.macro.REPEAT_FOREVER for tick infinitely.delay
Number The amount of time that the first tick will wait before execution. Unit: s
示例
var timeCallback = function (dt) {
cc.log("time: " + dt);
}
this.schedule(timeCallback, 1);
scheduleOnce
调度一个只运行一次的回调函数,可以指定 0 让回调函数在下一帧立即执行或者在一定的延时之后执行。
meta | description |
---|---|
定义于 | cocos2d/core/components/CCComponent.js:582 |
参数列表
callback
function A function wrapped as a selectordelay
Number The amount of time that the first tick will wait before execution. Unit: s
示例
var timeCallback = function (dt) {
cc.log("time: " + dt);
}
this.scheduleOnce(timeCallback, 2);
unschedule
取消调度一个自定义的回调函数。
meta | description |
---|---|
定义于 | cocos2d/core/components/CCComponent.js:599 |
参数列表
callback_fn
function A function wrapped as a selector
示例
this.unschedule(_callback);
unscheduleAllCallbacks
取消调度所有已调度的回调函数:定制的回调函数以及 update
回调函数。动作不受此方法影响。
meta | description |
---|---|
定义于 | cocos2d/core/components/CCComponent.js:615 |
示例
this.unscheduleAllCallbacks();
destroy
销毁该对象,并释放所有它对其它对象的引用。
实际销毁操作会延迟到当前帧渲染前执行。从下一帧开始,该对象将不再可用。
您可以在访问对象之前使用 cc.isValid(obj)
来检查对象是否已被销毁。
meta | description |
---|---|
返回 | Boolean |
定义于 | cocos2d/core/platform/CCObject.js:293 |
示例
obj.destroy();
_destruct
清除实例中的所有引用。
注意:此方法不会清除在 CCObject
实例中定义的 getter
或 setter
。如果需要,你可以重写 _destruct
方法。例如:
_destruct: function () {
for (var key in this) {
if (this.hasOwnProperty(key)) {
switch (typeof this[key]) {
case 'string':
this[key] = '';
break;
case 'object':
case 'function':
this[key] = null;
break;
}
}
}
meta | description |
---|---|
定义于 | cocos2d/core/platform/CCObject.js:427 |
_onPreDestroy
在对象被销毁之前调用。
meta | description |
---|---|
定义于 | cocos2d/core/platform/CCObject.js:483 |
_serialize
为此对象定制序列化。
meta | description |
---|---|
返回 | object |
定义于 | cocos2d/core/platform/CCObject.js:511 |
参数列表
exporting
Boolean
_deserialize
从自定义序列化数据初始化此对象。
meta | description |
---|---|
定义于 | cocos2d/core/platform/CCObject.js:524 |
参数列表
data
Object the serialized json datactx
_Deserializer