Version: 2021.2
言語: 日本語
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 衝突平面を定義する拡張可能な Transform のリスト。
Visualization 衝突平面の Gizmo をシーンビューでグリッド、ソリッドの何で表示するかのを選択します。
Scale Plane Visualization で使用する平面のサイズ。
Dampen 衝突の後、パーティクルを減速させるのに掛けられる少数の値。
Bounce 衝突後に、表面から跳ね返るパーティクルに加わる力。
Lifetime Loss 衝突後に失われるパーティクルの生存期間。
Min Kill Speed 衝突後に、この値よりも遅い速度で移動しているパーティクルは削除されます。
Max Kill Speed 衝突後に、この速度よりも速く移動するパーティクルは、システムから削除されます。
Radius Scale パーティクル衝突スフィアの半径を調整します。これにより、パーティクルグラフィックスの視覚的なエッジをきれいに一致させることができます。
Send Collision Messages この値を有効にすると、OnParticleCollision 関数を使用してスクリプトからパーティクルの衝突を検知することができます。
Visualize Bounds シーンビュー上で、各パーティクルの衝突範囲をワイヤーフレームの形状で描画します。

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 3D か 2D を選択します。
Collision Quality ドロップダウンを使ってパーティクルの衝突判定の質を設定します。これは、コライダーを通り抜けるパーティクルの数に影響します。質が低いと、パーティクルはコライダーをときどき通り抜けてしまいます。しかし、計算の負担は軽くなります。
    High Collision QualityHigh に設定すると、衝突判定で常に物理演算システムが使用されます。これは、もっともリソースへの負担が高いですが、もっとも正確な結果が得られます。
    Medium (Static Colliders) Collision QualityMedium (Static Colliders) に設定すると、ボクセルのグリッドを使用して以前の衝突をキャッシュし、後のフレームで素早く再使用します。この方法に関しては、後述の World の衝突 を参照してください。

MediumLow の違いは、各フレームで何回、パーティクルシステムが物理計算システムにクエリするかだけです。 Medium では、各フレームで Low よりも多くクエリを投げます。

この設定は、決して移動しない静的なコライダーにのみ適切です。
    Low (Static Colliders) Collision QualityLow (Static Colliders) に設定すると、ボクセルのグリッドを使用して以前の衝突をキャッシュし、後のフレームで素早く再使用します。この方法に関しては、後述の World の衝突 を参照してください。

MediumLow の違いは、各フレームで何回、パーティクルシステムが物理計算システムにクエリするかだけです。 Medium では、各フレームで Low よりも多くクエリを投げます。

この設定は、決して移動しない静的なコライダーにのみ適しています。
Collides With パーティクルは選択したレイヤーのオブジェクトにのみ衝突します。
Max Collision Shapes パーティクル衝突判定に使用される衝突形状の数。超過したシェイプは無視され、テレインが優先されます。
Enable Dynamic Colliders パーティクルが動的オブジェクトと衝突することが可能になります (これが有効でない場合は、静的オブジェクトのみと衝突します)。
Enable Dynamic Colliders キネマティックに設定されていないコライダーはすべて動的コライダーです (コライダーの種類に関しては コライダー を参照してください)。
衝突時にパーティクルが反応するオブジェクトの中にこのコライダーの種類を含む場合は、このオプションを有効にします。このオプションを無効にすると、パーティクルは静的コライダーに対する衝突にのみ反応します。
Voxel Size ボクセルは、3次元空間の標準グリッドの値を示します。MediumLow 品質の衝突を使用するとき、Unity はグリッド構造で衝突をキャッシュします。この設定はグリッドサイズを制御します。グリッドサイズが小さい方がより正確ですが、メモリを多く消費し効率が落ちます。

ノート: Collision QualityMediumLow に設定しているときのみ、このプロパティが表示されます。
Collider Force パーティクルの衝突後に物理コライダーに力を適用します。 パーティクルでコライダーを押すときに役立ちます。
Multiply by Collision Angle コライダーに力を適用するとき、パーティクルとコライダーの間の衝突角度に基づいて力を拡大します。グレージング角は正面衝突よりも小さな力を生成します。
Multiply by Particle Speed コライダーに力を適用するとき、パーティクルの速度に基づいて力を拡大します。高速で動くパーティクルは低速のものよりも大きな力を生成します。
Multiply by Particle Size コライダーに力を適用するとき、パーティクルのサイズに基づいて力を拡大します。サイズの大きなパーティクルは小さいものよりも大きな力を生成します。
Send Collision Messages これを有効にすると、OnParticleCollision 関数を使用してスクリプトからパーティクルの衝突を検知することができます。
Visualize Bounds シーンビューで各パーティクルの衝突判定のスフィアをプレビューします。

説明

パーティクルの周辺にオブジェクトが存在するとき、パーティクルがそれらのオブジェクトと相互作用するほうが、効果はより現実的に見えます。例えば水や破片などは、壁を簡単に通り抜けるよりも堅固な壁に阻まれるほうが現実的です。Collision モジュールを有効にすると、パーティクルはシーンのオブジェクトと衝突することができます。

パーティクルシステムを設定して、 World モードを選択すると、発生したパーティクルがシーン内のどのコライダーとも衝突するように設定することができます。また、 Collides With プロパティを使ってレイヤーごとにコライダーを無効にもできます。Planes モードオプションもあり、それによってコライダーを持つ必要がない平面のセットをシーンに加えることができます。このオプションは簡易な床、壁、それらと似たオブジェクトに利用でき、 World モードよりプロセッサーのオーバーヘッドを低くできます。

Planes モードが有効なとき、 Planes プロパティを通してトランスフォーム(一般的には空のゲームオブジェクト)のリストを加えることができます。平面は、オブジェクトのローカルの XZ 平面で、平面の法線ベクトルを示す Y 軸の正の方向に無限に拡張します。開発を補助するために、平面は、オブジェクト自体が可視のメッシュを持っているか否かに関係無く、ギズモとしてシーンに表示されます。ギズモはワイヤーフレームグリッド、ソリッドの平面オブジェクトとして表示され、大きさをスケールすることもできます。ただし、スケールは見た目にしか適用されません。つまり、衝突する平面自体はシーンを通して無限に広がっているのです。

衝突が有効なときパーティクルの大きさが問題になる場合もあります。表面と接触する際にグラフィックスを切り取られる可能性があるからです。この場合、停止するか跳ねる前にパーティクルは表面の半ばまで「沈んでいる」ように表示されます。Radius Scale プロパティはパーティクルのためにおおよその円状の半径を実際のサイズのパーセンテージで定義することで、この問題を解決します。このサイズ情報は、切り取り、沈み込み効果を防止するのに使われます。

DampenBounce プロパティはパーティクルがソリッド (固形) のオブジェクトを表示するときに便利です。例えば、砂利を投げたとき固い表面では跳ね返りますが、雪玉のパーティクルは衝突の間、速度を失います。Lifetime LossMin Kill Speed を使うと、衝突の後に続く残りのパーティクルのエフェクトを削減することができます。例えば、火の玉は空中を飛んでいる間、数秒間は存在しているかもしれませんが、衝突の後は、ばらばらになった火のパーティクルはすぐに消えます。

Send Collision Messages が有効になっている場合、スクリプトからパーティクルコリジョンを検知することもできます。スクリプトは、パーティクルシステムが設定されたオブジェクト、コライダーが設定されたオブジェクト、またはその両方が設定されたオブジェクトにアタッチ可能です。衝突を検知することで、ゲームプレイで弾丸、魔法、パワーアップアイテムなどのアクティブなオブジェクトとしてパーティクルを使用することができます。より詳細な情報や例についてはスクリプトリファレンスの MonoBehaviour.OnParticleCollision ページを参照してください。

World の Collision Quality

World Collision モジュールには Collision Quality プロパティがあり、High,Medium , Low に設定できます。 Collision QualityMedium (Static Colliders)Low (Static Colliders) に設定すると、衝突はボクセルのグリッド (3D グリッドの値) を使用し、後のフレームで素早く再使用するために前の衝突をキャッシュします。

このキャッシュは各ボクセルの平面からなり、平面はその位置の衝突表面を示します。各フレームで、 Unity はパーティクルの位置で平面のキャッシュを確認します。存在する場合は、 Unity はそれを衝突の検出に使用します。存在しない場合は、物理演算システムを使用します。衝突が返された場合は、後に続くフレームで素早く再使用するためにキャッシュに加えます。

これは、おおよその処理なので、衝突を見逃すこともあります。Voxel Size の値を低くしてこれを改善することができます。ただし、そうするとメモリが余分に消費されるので、効率が落ちます。

MediumLow の違いは、各フレームでシステムが物理演算システムにクエリする回数だけです。Low では、Medium に比べ、フレームごとに少ない回数のクエリを行います。回数が上限に達すると、残りのパーティクルにはキャッシュだけを利用します。この結果、キャッシュがさらに包括的に増えるまで衝突を検知し損なうことが多くなります。


  • 2017–05–30 修正されたページ

  • Collision モジュールは Unity 2017.1 で変更NewIn20171

External Forces モジュール
Triggers モジュール
Copyright © 2023 Unity Technologies
优美缔软件(上海)有限公司 版权所有
"Unity"、Unity 徽标及其他 Unity 商标是 Unity Technologies 或其附属机构在美国及其他地区的商标或注册商标。其他名称或品牌是其各自所有者的商标。
公安部备案号:
31010902002961