Version: 2023.1
External Forces 模块
Triggers 模块

Collision 模块

This module controls how particles collide with GameObjects in the Scene. Use the first drop-down to define whether your collision settings apply to Planes or to the World. If you choose World, use the Collision Mode drop-down to define whether your collision settings apply for a 2D or 3D world.

Using the Collision module

This module is part of the Particle System component. When you create a new Particle System GameObject, or add a Particle System component to an exiting GameObject, Unity adds the Collision module to the Particle System. By default, Unity disables this module. To create a new Particle System and enable this module:

  1. Click GameObject > Effects > Particle System.
  2. In the Inspector, find the Particle System component.
  3. In the Particle System component, find the Collision module fold-out.
  4. To the left of the fold-out header, enable the checkbox.

API

Since this module is part of the Particle System component, you access it through the ParticleSystem class. For information on how to access it and change values at runtime, see the Collision module API documentation.

Planes module properties

For some properties in this section, you can use different modes to set their value. For information on the modes you can use, see Varying properties over time.

属性 功能
Planes 弹出菜单 选择 Planes 模式。
Planes 用于定义碰撞平面的变换的可扩展列表。
Visualization 选择要将 Scene 视图中的碰撞平面辅助图标显示为线框网格还是实体平面。
Scale Plane 用于可视化的平面大小。
Dampen 粒子碰撞后损失的速度比例。
Bounce 粒子碰撞后从表面反弹的速度比例。
Lifetime Loss 粒子碰撞后损失的总生命周期比例。
Min Kill Speed 碰撞后运动速度低于此速度的粒子将从系统中予以移除。
Max Kill Speed 碰撞后运动速度高于此速度的粒子将从系统中予以移除。
Radius Scale 允许调整粒子碰撞球体的半径,使其更贴近粒子图形的可视边缘。
Send Collision Messages 如果启用此属性,则可从脚本中通过 OnParticleCollision 函数检测粒子碰撞。
Visualize Bounds 在 Scene 视图中将每个粒子的碰撞边界渲染为线框形状。

World module properties

For some properties in this section, you can use different modes to set their value. For information on the modes you can use, see Varying properties over time.

属性 功能
World 弹出菜单 选择 World 模式。
Collision Mode 3D 或 2D。
Dampen 粒子碰撞后损失的速度比例。
Bounce 粒子碰撞后从表面反弹的速度比例。
Lifetime Loss 粒子碰撞后损失的总生命周期比例。
Min Kill Speed 碰撞后运动速度低于此速度的粒子将从系统中予以移除。
Max Kill Speed 碰撞后运动速度高于此速度的粒子将从系统中予以移除。
Radius Scale 2D 或 3D 的设置。
Collision Quality 使用下拉选单来设置粒子碰撞的质量。此设置会影响有多少粒子可以穿过碰撞体。在较低的质量水平下,粒子有时会穿过碰撞体,但需要的计算资源较少。
    High Collision Quality 设置为 High 时,碰撞始终使用物理系统来检测碰撞结果。此设置是最耗费资源但也是最准确的选项。
    Medium (Static Colliders) Collision Quality 设置为 Medium (Static Colliders) 时,碰撞使用一组体素来缓存先前的碰撞,从而在以后的帧中更快地重用。请参阅下方的世界碰撞以了解与此缓存相关的更多信息。

MediumLow 之间的唯一区别是粒子系统在每帧查询物理系统的次数。Medium 每帧的查询次数多于 Low

请注意,此设置仅适用于从不移动的静态碰撞体。
    Low (Static Colliders) Collision Quality 设置为 Low (Static Colliders) 时,碰撞使用一组体素来缓存先前的碰撞,从而在以后的帧中更快地重用。请参阅下方的世界碰撞以了解与此缓存相关的更多信息。

MediumLow 之间的唯一区别是粒子系统在每帧查询物理系统的次数。Medium 每帧的查询次数多于 Low

请注意,此设置仅适用于从不移动的静态碰撞体。
Collides With 粒子只会与所选层上的对象发生碰撞。
Max Collision Shapes 粒子碰撞可包括的碰撞形状个数。多余的形状将被忽略,且地形优先。
Enable Dynamic Colliders Dynamic colliders are any collider not configured as Kinematic (see documentation on colliders for further information on collider types).

Check this option to include these collider types in the set of objects that the particles respond to in collisions. If you uncheck this option, the particles only respond to collisions against static colliders.
Voxel Size 体素 (voxel) 表示三维空间中的常规网格上的值。使用 MediumLow 质量碰撞时,Unity 会在网格结构中缓存碰撞。此设置控制着网格大小。较小的值可提供更高的准确性,但会占用更多内存,效率也会降低。

注意:仅当 Collision Quality 设置为 MediumLow 时,才能访问此属性。
Collider Force 在粒子碰撞后对物理碰撞体施力。这对于用粒子推动碰撞体很有用。
Multiply by Collision Angle 向碰撞体施力时,根据粒子与碰撞体之间的碰撞角度来缩放力的强度。掠射角将比正面碰撞产生更小的力。
Multiply by Particle Speed 向碰撞体施力时,根据粒子的速度来缩放力的强度。快速移动的粒子会比较慢的粒子产生更大的力。
Multiply by Particle Size 向碰撞体施力时,根据粒子的大小来缩放力的强度。较大的粒子会比较小的粒子产生更大的力。
Send Collision Messages 如果选中此复选框,则允许从脚本中通过 OnParticleCollision 函数检测粒子碰撞。
Visualize Bounds 在 Scene 视图中预览每个粒子的碰撞球体。

详细信息

当其他对象围绕粒子系统时,通常情况下,粒子与这些对象相互作用才会使效果更有说服力。例如,水或碎片应该被坚固的墙壁阻挡而非直接穿过墙壁。启用 Collision 模块后,粒子可与场景中的对象发生碰撞。

通过从弹出菜单中选择 World 模式,可设置粒子系统来使其粒子与场景中的任何碰撞体碰撞。此外,也可使用 Collides With 属性根据碰撞体所在的层来禁用碰撞体。弹出菜单还有一个 Planes 模式选项,可用于向场景中添加一组不需要碰撞体的平面。此选项对于简单的地板、墙壁和类似对象非常有用,并且处理器开销低于 World 模式。

启用 Planes 模式后,可通过 Planes 属性添加一组变换(通常为空游戏对象)。平面在对象的局部 XZ 平面中无限延伸,其中以正 Y 轴表示平面的法线矢量。为了协助开发,无论对象本身是否具有任何可见的网格,平面都将在场景中显示为辅助图标。辅助图标可显示为线框网格或实体平面,也可进行缩放。但是,缩放仅适用于可视化;碰撞平面本身在场景中无限延伸。

启用碰撞后,粒子的大小有时会成为问题,因为它的图形在与表面接触时可能被裁剪。这种情况可能导致粒子在停止或反弹之前在一定程度上“下沉”到表面中。Radius Scale 属性通过定义粒子的近似圆形半径(以其实际大小的百分比形式)来解决此问题。此大小信息用于防止裁剪并避免下沉效应。

当粒子表示实体对象时,__Dampen__ 和 Bounce 属性非常有用。例如,砾石在抛出时往往会在坚硬的表面上反弹,但是雪球粒子在碰撞时可能会失去速度。Lifetime LossMin Kill Speed 有助于减少碰撞后残留颗粒的影响。例如,火球在空中飞行时可能会持续几秒钟,但在碰撞后,单独的火焰粒子应该快速消散。

如果启用了 __Send Collision Messages__,还可从脚本中检测粒子碰撞。脚本可附加到带有粒子系统的对象,也可附加到带有碰撞体的对象。通过检测碰撞,可将粒子用作游戏中的活动对象,例如飞弹、魔法和能量块 (power-up)。请参阅 MonoBehaviour.OnParticleCollision 脚本参考页面以了解更多详细信息和示例。

World Collision Quality

World Collision 模块具有 Collision Quality 属性,可将其设置为 HighMediumLow。当 Collision Quality 设置为 Medium (Static Colliders) 或 Low (Static Colliders) 时,碰撞使用一组体素(3D 网格上的值)来缓存先前的碰撞,从而在以后的帧中快速重用。

该缓存由每个体素中的平面组成,其中的平面表示该位置处的碰撞表面。在每个帧上,Unity 都会检查缓存中是否有该粒子位置的平面,如果有,则 Unity 将其用于碰撞检测。否则会查询物理系统。如果返回了碰撞,则会将其添加到缓存中,以便在后续帧上快速进行查询。

这是近似算法,因此可能存在一些缺失的碰撞。可通过减小 Voxel Size 值来帮助解决这个问题;但是,这样做会占用额外的内存,效率也会降低。

MediumLow 之间的唯一区别是允许系统在每帧查询物理系统的次数。Low 每帧的查询次数少于 Medium。一旦超出每帧预算,只能将缓存用于所有其余粒子。这样一来可能导致缺失的碰撞增加,直到更全面填充缓存为止。


  • 2017–05–30 页面已修订

  • 在 Unity 2017.1 中更改了 Collision 模块的功能 NewIn20171

External Forces 模块
Triggers 模块