summaryrefslogtreecommitdiff
path: root/Assembly_CSharp/GamePlay/ProjectileFX.cs
diff options
context:
space:
mode:
authorchai <215380520@qq.com>2023-11-26 23:52:30 +0800
committerchai <215380520@qq.com>2023-11-26 23:52:30 +0800
commit626381f061cde0c78564f6336e3131835cf20a5b (patch)
treed9991d6eda6ae5d7649ac91ecaa3b4dc833cd4c3 /Assembly_CSharp/GamePlay/ProjectileFX.cs
parent0e63c4a2c6dec8dfa260501fb7d73750261ea7b7 (diff)
* move
Diffstat (limited to 'Assembly_CSharp/GamePlay/ProjectileFX.cs')
-rw-r--r--Assembly_CSharp/GamePlay/ProjectileFX.cs47
1 files changed, 47 insertions, 0 deletions
diff --git a/Assembly_CSharp/GamePlay/ProjectileFX.cs b/Assembly_CSharp/GamePlay/ProjectileFX.cs
new file mode 100644
index 0000000..df82c3d
--- /dev/null
+++ b/Assembly_CSharp/GamePlay/ProjectileFX.cs
@@ -0,0 +1,47 @@
+using System.Collections;
+using UnityEngine;
+
+public class ProjectileFX : MonoBehaviour
+{
+ [SerializeField]
+ private GameObject bleedingPS;
+
+ [SerializeField]
+ private GameObject burrningPS;
+
+ [SerializeField]
+ private GameObject poisonPS;
+
+ public void SetFX(float bleeding, float burning, float poison, float slow, bool arcane)
+ {
+ if (OptionsMenu.instance.extraProjectileEffects)
+ {
+ if (bleeding > 0f)
+ {
+ bleedingPS.SetActive(value: true);
+ }
+ if (burning > 0f)
+ {
+ burrningPS.SetActive(value: true);
+ }
+ if (poison > 0f)
+ {
+ poisonPS.SetActive(value: true);
+ }
+ }
+ }
+
+ public void OnDetach()
+ {
+ StartCoroutine(Die());
+ }
+
+ private IEnumerator Die()
+ {
+ bleedingPS.GetComponent<ParticleSystem>().Stop(withChildren: true);
+ burrningPS.GetComponent<ParticleSystem>().Stop(withChildren: true);
+ poisonPS.GetComponent<ParticleSystem>().Stop(withChildren: true);
+ yield return new WaitForSeconds(1.1f);
+ Object.Destroy(base.gameObject);
+ }
+}