Merge branch 'develop' of bitbucket.org:usaya/popcorn into develop
This commit is contained in:
		
						commit
						d688994475
					
				|  | @ -7981,8 +7981,10 @@ MonoBehaviour: | |||
|   cornPrefab: {fileID: 5499754490129207122, guid: 2b790fd908bd14de4a601c21374fb55b, | ||||
|     type: 3} | ||||
|   cornSpawnCount: 20 | ||||
|   cornGrowSpeed: 0 | ||||
|   cornHotGrowSpeed: 0 | ||||
|   baseGrowSpeed: 1 | ||||
|   hotGrowSpeed: 1.5 | ||||
|   baseCornPopTime: 10 | ||||
|   cornBurntDuration: 3 | ||||
| --- !u!1 &1928679189 | ||||
| GameObject: | ||||
|   m_ObjectHideFlags: 0 | ||||
|  |  | |||
|  | @ -1,9 +1,19 @@ | |||
| using System; | ||||
| using System.Collections; | ||||
| using System.Collections.Generic; | ||||
| using UniRx; | ||||
| using UniRx.Triggers; | ||||
| using UnityEngine; | ||||
| using Random = UnityEngine.Random; | ||||
| 
 | ||||
| public enum CornCondition | ||||
| { | ||||
|     Seed, | ||||
|     Simple, | ||||
|     Burnt, | ||||
|     Spilled | ||||
| } | ||||
| 
 | ||||
| [RequireComponent(typeof(Rigidbody2D))] | ||||
| public class Corn : MonoBehaviour | ||||
| { | ||||
|  | @ -11,83 +21,119 @@ public class Corn : MonoBehaviour | |||
|     [SerializeField] private Sprite cornSeedSprite; | ||||
|     [SerializeField] private Sprite cornSimpleSprite; | ||||
|     [SerializeField] private Sprite cornBurntSprite; | ||||
|     // コーン速度 | ||||
|     [SerializeField] private float cornVelocity; | ||||
|     // コーンがスポーンしてからの時間 | ||||
|     [SerializeField] private float cornLifeTime; | ||||
|     // コーン弾ける時間! | ||||
|     private float cornPopTime; | ||||
|     // コーンが停まってる時間(焦げる判定 | ||||
|     private float cornStopTime; | ||||
|     private float maxCornStopTime = 5f; | ||||
|     // コーンが動いている総時間 | ||||
|     private float cornMovingTime => cornLifeTime - cornStopTime; | ||||
|     // コーン誕生時間 | ||||
|     private float cornSpawnTime; | ||||
|     private bool isPop; | ||||
|      | ||||
|     private Rigidbody2D rigidbody2D; | ||||
|     private Rigidbody2D rigidbody; | ||||
|     private float cornPopTime; | ||||
|     private float cornBurntTime; | ||||
|     private float cornGrowTime; | ||||
|     private float cornGrowSpeed; | ||||
|     private float maxSpeed = 50f; | ||||
|     private float popSpeed = 20f; | ||||
|      | ||||
|     public IReadOnlyReactiveProperty<CornCondition> Condition => condition; | ||||
|     private readonly ReactiveProperty<CornCondition> condition = new ReactiveProperty<CornCondition>(CornCondition.Seed); | ||||
| 
 | ||||
|      | ||||
|     // 角度調整 | ||||
|     private Transform rotationResolverTransform; | ||||
|     private Transform spriteTransform; | ||||
| 
 | ||||
|     // Start is called before the first frame update | ||||
|     void Start() | ||||
|     private void Awake() | ||||
|     { | ||||
|         rigidbody2D = GetComponent<Rigidbody2D>(); | ||||
|         spriteTransform = spriteRenderer.transform; | ||||
|         rotationResolverTransform = spriteRenderer.transform.parent.parent; | ||||
|         condition.AddTo(this); | ||||
|         rigidbody = GetComponent<Rigidbody2D>(); | ||||
|         spriteRenderer.sprite = cornSeedSprite; | ||||
|         cornSpawnTime = Time.time; | ||||
|         var cornPopBasicTime = 5f; | ||||
|         cornPopTime = cornPopBasicTime + Random.Range(0, 5f); | ||||
|          | ||||
|         rigidbody2D.position = new Vector2(Random.value, Random.value); | ||||
|         spriteTransform = spriteRenderer.transform; | ||||
|         rotationResolverTransform = spriteTransform.parent.parent; | ||||
|     } | ||||
| 
 | ||||
|     private float maxVelocity; | ||||
|     private void Update() | ||||
|     private void Start() | ||||
|     { | ||||
|         cornVelocity = rigidbody2D.velocity.magnitude; | ||||
|         cornLifeTime = Time.time - cornSpawnTime; | ||||
|         rigidbody.MovePosition(new Vector2(Random.value * 2 - 1, Random.value * 2 - 1)); | ||||
| 
 | ||||
|         if (rigidbody2D.velocity.magnitude > maxVelocity) | ||||
|         // コーンが飛んでいく | ||||
|         this.ObserveEveryValueChanged(x => x.rigidbody.velocity.magnitude) | ||||
|             .Where(x => x >= maxSpeed) | ||||
|             .FirstOrDefault() | ||||
|             .Subscribe(_ => | ||||
|         { | ||||
|             maxVelocity = Mathf.Max(rigidbody2D.velocity.magnitude, maxVelocity); | ||||
|             Debug.Log(maxVelocity); | ||||
|             condition.Value = CornCondition.Spilled; | ||||
|         }).AddTo(this); | ||||
| 
 | ||||
|         condition.Subscribe(x => | ||||
|         { | ||||
|             switch (x) | ||||
|             { | ||||
|                 case CornCondition.Seed: | ||||
|                     break; | ||||
|                 case CornCondition.Simple: | ||||
|                     CornPop(); | ||||
|                     break; | ||||
|                 case CornCondition.Burnt: | ||||
|                     CornBurnt(); | ||||
|                     break; | ||||
|                 case CornCondition.Spilled: | ||||
|                     CornSpilled(); | ||||
|                     break; | ||||
|                 default: | ||||
|                     throw new ArgumentOutOfRangeException(nameof(x), x, null); | ||||
|             } | ||||
|         }).AddTo(this); | ||||
|          | ||||
|         if (maxVelocity >= 50f) | ||||
|         this.UpdateAsObservable().Subscribe(_ => | ||||
|         { | ||||
|             GetComponent<Collider2D>().enabled = false; | ||||
|         } | ||||
| 
 | ||||
|             // アニメーション向けに回転をリセット | ||||
|             rotationResolverTransform.rotation = Quaternion.identity; | ||||
|             // コーンの回転を伝搬 | ||||
|             spriteTransform.localRotation = transform.localRotation; | ||||
| 
 | ||||
|         if (cornVelocity <= 0.2f) | ||||
|         { | ||||
|             cornStopTime += Time.deltaTime; | ||||
|         }).AddTo(this); | ||||
|     } | ||||
| 
 | ||||
|         if (cornStopTime >= maxCornStopTime && isPop) | ||||
|     private void Update() | ||||
|     { | ||||
|             spriteRenderer.sprite = cornBurntSprite; | ||||
|         if (condition.Value == CornCondition.Spilled) | ||||
|         { | ||||
|             return; | ||||
|         } | ||||
|         if (cornLifeTime >= cornPopTime) | ||||
| 
 | ||||
|         cornGrowTime += Time.deltaTime * cornGrowSpeed; | ||||
|         if (cornGrowTime >= cornBurntTime) | ||||
|         { | ||||
|             CornPop(); | ||||
|             condition.Value = CornCondition.Burnt; | ||||
|         } | ||||
|         else if (cornGrowTime >= cornPopTime) | ||||
|         { | ||||
|             condition.Value = CornCondition.Simple; | ||||
|         } | ||||
|     } | ||||
| 
 | ||||
|     private void CornPop() | ||||
|     { | ||||
|         if (isPop) return; | ||||
|         isPop = true; | ||||
|         var popVelocity = 20f; | ||||
|         var popDirection = new Vector2(Random.value * 2 - 1, Random.value * 2 - 1); | ||||
|         rigidbody2D.AddForce(popVelocity * popDirection, ForceMode2D.Impulse); | ||||
|         spriteRenderer.sprite = cornSimpleSprite; | ||||
|         rigidbody.AddForce(popSpeed * new Vector2(Random.value * 2 - 1, Random.value * 2 - 1), ForceMode2D.Impulse); | ||||
|     } | ||||
| 
 | ||||
|     private void CornBurnt() | ||||
|     { | ||||
|         spriteRenderer.sprite = cornBurntSprite; | ||||
|     } | ||||
| 
 | ||||
|     private void CornSpilled() | ||||
|     { | ||||
|         GetComponent<Collider2D>().enabled = false; | ||||
|         // アニメーション消す | ||||
|     } | ||||
| 
 | ||||
|     public void SetCornProperty(float popTime, float burntDuration) | ||||
|     { | ||||
|         cornPopTime = popTime + Random.Range(0, 2f); | ||||
|         cornBurntTime = cornPopTime + burntDuration + Random.Range(0, 1f); | ||||
|     } | ||||
| 
 | ||||
|     public void ChangeGrowSpeed(float speed) | ||||
|     { | ||||
|         Debug.Log($"{speed:F}"); | ||||
|         cornGrowSpeed = speed; | ||||
|     } | ||||
| } | ||||
|  |  | |||
|  | @ -1,4 +1,5 @@ | |||
| using System; | ||||
| using UniRx; | ||||
| using UnityEngine; | ||||
| 
 | ||||
| public class CornManager : MonoBehaviour | ||||
|  | @ -6,25 +7,55 @@ public class CornManager : MonoBehaviour | |||
|     [SerializeField] private Transform cornSpawnTarget; | ||||
|     [SerializeField] private Corn cornPrefab; | ||||
|     [SerializeField] private int cornSpawnCount = 20; | ||||
|     [SerializeField] private float cornGrowSpeed; | ||||
|     [SerializeField] private float cornHotGrowSpeed; | ||||
|     [SerializeField, ReadOnly] private float baseGrowSpeed = 1f; | ||||
|     [SerializeField] private float hotGrowSpeed; | ||||
|     [SerializeField] private float baseCornPopTime = 5f; | ||||
|     [SerializeField] private float cornBurntDuration = 5f; | ||||
| 
 | ||||
|     private Corn[] cornArray; | ||||
|     private readonly ReactiveProperty<float> cornGrowSpeed = new FloatReactiveProperty(0f); | ||||
|     private bool isHot; | ||||
|      | ||||
|     private void Start() | ||||
|     { | ||||
|     } | ||||
|     // クリア判定を通知 | ||||
|      | ||||
|     public void Initialize() | ||||
|     // コーンの状態を取得する | ||||
| 
 | ||||
|     private void Awake() | ||||
|     { | ||||
|         cornArray = new Corn[cornSpawnCount]; | ||||
|     } | ||||
| 
 | ||||
|     public void GenerateCorn() | ||||
|     public void RespawnCorn() | ||||
|     { | ||||
|         for (int i = 0; i < cornSpawnCount; i++) | ||||
|         { | ||||
|             cornArray[i] = Instantiate(cornPrefab, cornSpawnTarget); | ||||
|             var corn = Instantiate(cornPrefab, cornSpawnTarget); | ||||
|             cornArray[i] = corn; | ||||
|             corn.SetCornProperty(baseCornPopTime, cornBurntDuration); | ||||
|              | ||||
|             cornGrowSpeed.Subscribe(x => | ||||
|             { | ||||
|                 Debug.Log($"corn: {corn.Condition.Value} isHot: {isHot}"); | ||||
|                 // コーンが弾けた後はRedの場合のみ焦げ進行する | ||||
|                 if (corn.Condition.Value == CornCondition.Simple && !isHot) | ||||
|                 { | ||||
|                     corn.ChangeGrowSpeed(0f); | ||||
|                     return; | ||||
|                 } | ||||
|                 corn.ChangeGrowSpeed(x); | ||||
|             }).AddTo(this); | ||||
|              | ||||
|             // コーンが弾けたとき、GrowSpeedを再設定する | ||||
|             corn.Condition | ||||
|                 .Where(x => x == CornCondition.Simple) | ||||
|                 .FirstOrDefault() | ||||
|                 .Subscribe(_ => | ||||
|                 { | ||||
|                     if (!isHot) | ||||
|                     { | ||||
|                         corn.ChangeGrowSpeed(0f); | ||||
|                     } | ||||
|                 }).AddTo(this); | ||||
|         } | ||||
|     } | ||||
| 
 | ||||
|  | @ -33,10 +64,16 @@ public class CornManager : MonoBehaviour | |||
|         switch (condition) | ||||
|         { | ||||
|             case ThermalCondition.Cold: | ||||
|                 isHot = false; | ||||
|                 cornGrowSpeed.Value = 0f; | ||||
|                 break; | ||||
|             case ThermalCondition.Yellow: | ||||
|                 isHot = false; | ||||
|                 cornGrowSpeed.Value = baseGrowSpeed; | ||||
|                 break; | ||||
|             case ThermalCondition.Hot: | ||||
|                 isHot = true; | ||||
|                 cornGrowSpeed.Value = hotGrowSpeed; | ||||
|                 break; | ||||
|             default: | ||||
|                 throw new ArgumentOutOfRangeException(nameof(condition), condition, null); | ||||
|  |  | |||
|  | @ -1,8 +1,6 @@ | |||
| using System; | ||||
| using UnityEngine; | ||||
| 
 | ||||
| namespace MyGame.Scenes.Main | ||||
| { | ||||
| public class Pan : MonoBehaviour | ||||
| { | ||||
|     [SerializeField] private PanController controller; | ||||
|  | @ -18,4 +16,3 @@ namespace MyGame.Scenes.Main | |||
|         other.attachedRigidbody.AddForce(controller.Delta * thrust * direct, ForceMode2D.Impulse); | ||||
|     } | ||||
| } | ||||
| } | ||||
		Loading…
	
		Reference in New Issue