summaryrefslogtreecommitdiff
path: root/Thronefall_1_0/Decompile/CoinSpawner.cs
diff options
context:
space:
mode:
authorchai <215380520@qq.com>2024-05-19 16:46:27 +0800
committerchai <215380520@qq.com>2024-05-19 16:46:27 +0800
commit8b1fc7063b387542803c6bc214ccf8acb32870bd (patch)
treed310eb99872c8215f1c1f67731ec21f0915cd778 /Thronefall_1_0/Decompile/CoinSpawner.cs
parent8e13e7e2874adc8982e16d1d2ed2e28d7480b45f (diff)
* rename
Diffstat (limited to 'Thronefall_1_0/Decompile/CoinSpawner.cs')
-rw-r--r--Thronefall_1_0/Decompile/CoinSpawner.cs63
1 files changed, 63 insertions, 0 deletions
diff --git a/Thronefall_1_0/Decompile/CoinSpawner.cs b/Thronefall_1_0/Decompile/CoinSpawner.cs
new file mode 100644
index 0000000..0de0c20
--- /dev/null
+++ b/Thronefall_1_0/Decompile/CoinSpawner.cs
@@ -0,0 +1,63 @@
+using System.Collections;
+using System.Collections.Generic;
+using UnityEngine;
+
+public class CoinSpawner : MonoBehaviour
+{
+ public GameObject coinPrefab;
+
+ public float interval = 0.5f;
+
+ private int coinsLeft;
+
+ public static List<CoinSpawner> allCoinSpawners = new List<CoinSpawner>();
+
+ public int CoinsLeft => coinsLeft;
+
+ public static int AllCoinsLeftToBeSpawned
+ {
+ get
+ {
+ int num = 0;
+ for (int num2 = allCoinSpawners.Count - 1; num2 >= 0; num2--)
+ {
+ if (allCoinSpawners[num2] == null)
+ {
+ allCoinSpawners.RemoveAt(num2);
+ }
+ else
+ {
+ num += allCoinSpawners[num2].CoinsLeft;
+ }
+ }
+ return num;
+ }
+ }
+
+ private void OnEnable()
+ {
+ allCoinSpawners.Add(this);
+ }
+
+ private void OnDisable()
+ {
+ allCoinSpawners.Remove(this);
+ }
+
+ public void TriggerCoinSpawn(int amount, PlayerInteraction player)
+ {
+ StartCoroutine(SpawnCoins(amount, interval, player));
+ }
+
+ private IEnumerator SpawnCoins(int amount, float delay, PlayerInteraction player)
+ {
+ coinsLeft = amount;
+ WaitForSeconds wait = new WaitForSeconds(delay);
+ for (int i = 0; i < amount; i++)
+ {
+ coinsLeft--;
+ Object.Instantiate(coinPrefab, base.transform.position, Quaternion.identity).GetComponent<Coin>().SetTarget(player);
+ yield return wait;
+ }
+ }
+}