苗のロジックとビューを分割
This commit is contained in:
		
							parent
							
								
									fc104b6235
								
							
						
					
					
						commit
						9bcf9a9597
					
				|  | @ -314,6 +314,7 @@ GameObject: | ||||||
|   - component: {fileID: 875275074368017840} |   - component: {fileID: 875275074368017840} | ||||||
|   - component: {fileID: 875275074368017842} |   - component: {fileID: 875275074368017842} | ||||||
|   - component: {fileID: 875275074368017841} |   - component: {fileID: 875275074368017841} | ||||||
|  |   - component: {fileID: 3560956324713403295} | ||||||
|   m_Layer: 0 |   m_Layer: 0 | ||||||
|   m_Name: one_d |   m_Name: one_d | ||||||
|   m_TagString: Untagged |   m_TagString: Untagged | ||||||
|  | @ -404,6 +405,32 @@ Animator: | ||||||
|   m_HasTransformHierarchy: 1 |   m_HasTransformHierarchy: 1 | ||||||
|   m_AllowConstantClipSamplingOptimization: 1 |   m_AllowConstantClipSamplingOptimization: 1 | ||||||
|   m_KeepAnimatorControllerStateOnDisable: 0 |   m_KeepAnimatorControllerStateOnDisable: 0 | ||||||
|  | --- !u!61 &3560956324713403295 | ||||||
|  | BoxCollider2D: | ||||||
|  |   m_ObjectHideFlags: 0 | ||||||
|  |   m_CorrespondingSourceObject: {fileID: 0} | ||||||
|  |   m_PrefabInstance: {fileID: 0} | ||||||
|  |   m_PrefabAsset: {fileID: 0} | ||||||
|  |   m_GameObject: {fileID: 875275074368017847} | ||||||
|  |   m_Enabled: 1 | ||||||
|  |   m_Density: 1 | ||||||
|  |   m_Material: {fileID: 0} | ||||||
|  |   m_IsTrigger: 0 | ||||||
|  |   m_UsedByEffector: 0 | ||||||
|  |   m_UsedByComposite: 0 | ||||||
|  |   m_Offset: {x: 0, y: -0.74168634} | ||||||
|  |   m_SpriteTilingProperty: | ||||||
|  |     border: {x: 0, y: 0, z: 0, w: 0} | ||||||
|  |     pivot: {x: 0.5, y: 0.5} | ||||||
|  |     oldSize: {x: 1.7, y: 4.04} | ||||||
|  |     newSize: {x: 1.7, y: 4.04} | ||||||
|  |     adaptiveTilingThreshold: 0.5 | ||||||
|  |     drawMode: 0 | ||||||
|  |     adaptiveTiling: 0 | ||||||
|  |   m_AutoTiling: 0 | ||||||
|  |   serializedVersion: 2 | ||||||
|  |   m_Size: {x: 1.0807116, y: 2.404545} | ||||||
|  |   m_EdgeRadius: 0 | ||||||
| --- !u!1 &875275074515791082 | --- !u!1 &875275074515791082 | ||||||
| GameObject: | GameObject: | ||||||
|   m_ObjectHideFlags: 0 |   m_ObjectHideFlags: 0 | ||||||
|  | @ -414,6 +441,7 @@ GameObject: | ||||||
|   m_Component: |   m_Component: | ||||||
|   - component: {fileID: 875275074515791083} |   - component: {fileID: 875275074515791083} | ||||||
|   - component: {fileID: 3152473785108484531} |   - component: {fileID: 3152473785108484531} | ||||||
|  |   - component: {fileID: 1162919361388578994} | ||||||
|   m_Layer: 0 |   m_Layer: 0 | ||||||
|   m_Name: Seedling |   m_Name: Seedling | ||||||
|   m_TagString: Untagged |   m_TagString: Untagged | ||||||
|  | @ -451,9 +479,23 @@ MonoBehaviour: | ||||||
|   m_Script: {fileID: 11500000, guid: 1b5e732e57e34b97a8adc725ce004566, type: 3} |   m_Script: {fileID: 11500000, guid: 1b5e732e57e34b97a8adc725ce004566, type: 3} | ||||||
|   m_Name:  |   m_Name:  | ||||||
|   m_EditorClassIdentifier:  |   m_EditorClassIdentifier:  | ||||||
|  |   seedlingView: {fileID: 1162919361388578994} | ||||||
|  | --- !u!114 &1162919361388578994 | ||||||
|  | MonoBehaviour: | ||||||
|  |   m_ObjectHideFlags: 0 | ||||||
|  |   m_CorrespondingSourceObject: {fileID: 0} | ||||||
|  |   m_PrefabInstance: {fileID: 0} | ||||||
|  |   m_PrefabAsset: {fileID: 0} | ||||||
|  |   m_GameObject: {fileID: 875275074515791082} | ||||||
|  |   m_Enabled: 1 | ||||||
|  |   m_EditorHideFlags: 0 | ||||||
|  |   m_Script: {fileID: 11500000, guid: dc986cc5c74043e08218a00c53d6f418, type: 3} | ||||||
|  |   m_Name:  | ||||||
|  |   m_EditorClassIdentifier:  | ||||||
|   seedlingStage1: {fileID: 875275074110174225} |   seedlingStage1: {fileID: 875275074110174225} | ||||||
|   seedlingStage2: {fileID: 875275074190396077} |   seedlingStage2: {fileID: 875275074190396077} | ||||||
|   seedlingStage3: {fileID: 875275073577674106} |   seedlingStage3: {fileID: 875275073577674106} | ||||||
|   seedlingStage4: {fileID: 875275074368017847} |   seedlingStage4: {fileID: 875275074368017847} | ||||||
|  |   stage4Collider: {fileID: 3560956324713403295} | ||||||
|   growingArrowPrefab: {fileID: 4493492865567033234, guid: b3d641214f420f74290147d368b221fa, |   growingArrowPrefab: {fileID: 4493492865567033234, guid: b3d641214f420f74290147d368b221fa, | ||||||
|     type: 3} |     type: 3} | ||||||
|  |  | ||||||
|  | @ -1,10 +1,10 @@ | ||||||
| using System; | using System; | ||||||
| using UniRx; | using UniRx; | ||||||
| using UnityEngine; | using UnityEngine; | ||||||
| using Random = UnityEngine.Random; |  | ||||||
| 
 | 
 | ||||||
| public enum SeedlingStage | public enum SeedlingStage | ||||||
| { | { | ||||||
|  |     Stage0, | ||||||
|     Stage1, |     Stage1, | ||||||
|     Stage2, |     Stage2, | ||||||
|     Stage3, |     Stage3, | ||||||
|  | @ -20,14 +20,10 @@ public enum SeedlingRank | ||||||
| 
 | 
 | ||||||
| public class CornSeedling : MonoBehaviour | public class CornSeedling : MonoBehaviour | ||||||
| { | { | ||||||
|     [SerializeField] private GameObject seedlingStage1; |     [SerializeField] private CornSeedlingView seedlingView; | ||||||
|     [SerializeField] private GameObject seedlingStage2; |     private static readonly float stage0End = 0.25f; | ||||||
|     [SerializeField] private GameObject seedlingStage3; |     private static readonly float stage1End = 0.50f; | ||||||
|     [SerializeField] private GameObject seedlingStage4; |     private static readonly float stage2End = 0.75f; | ||||||
|     [SerializeField] private GameObject growingArrowPrefab; |  | ||||||
|     private readonly int nextStageTriggerHash = Animator.StringToHash("NextStageTrigger"); |  | ||||||
|     private static readonly float stage1End = 0.32f; |  | ||||||
|     private static readonly float stage2End = 0.67f; |  | ||||||
|     private static readonly float stage3End = 1f; |     private static readonly float stage3End = 1f; | ||||||
| 
 | 
 | ||||||
|     private int period; |     private int period; | ||||||
|  | @ -46,10 +42,7 @@ public class CornSeedling : MonoBehaviour | ||||||
| 
 | 
 | ||||||
|     private void ResetGrowth() |     private void ResetGrowth() | ||||||
|     { |     { | ||||||
|         seedlingStage1.SetActive(false); |         seedlingView.ResetView(); | ||||||
|         seedlingStage2.SetActive(false); |  | ||||||
|         seedlingStage3.SetActive(false); |  | ||||||
|         seedlingStage4.SetActive(false); |  | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     public void PromoteGrowth(DateTime newTime) |     public void PromoteGrowth(DateTime newTime) | ||||||
|  | @ -60,8 +53,7 @@ public class CornSeedling : MonoBehaviour | ||||||
|         } |         } | ||||||
|         beginTime = newTime; |         beginTime = newTime; | ||||||
|         UpdateStage(); |         UpdateStage(); | ||||||
|         var arrow = Instantiate(growingArrowPrefab, transform); |         seedlingView.EffectGrowth(); | ||||||
|         this.CallWaitForSeconds(0.5f, () => Destroy(arrow)); |  | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     public void SetSeedlingGene(DateTime dateTime, int periodTime, SeedlingRank rank) |     public void SetSeedlingGene(DateTime dateTime, int periodTime, SeedlingRank rank) | ||||||
|  | @ -69,65 +61,24 @@ public class CornSeedling : MonoBehaviour | ||||||
|         completed = false; |         completed = false; | ||||||
|         compositeDisposable.Clear(); |         compositeDisposable.Clear(); | ||||||
|         ResetGrowth(); |         ResetGrowth(); | ||||||
|  |         seedlingStage.SetValueAndForceNotify(SeedlingStage.Stage0); | ||||||
|         beginTime = dateTime; |         beginTime = dateTime; | ||||||
|         period = periodTime; |         period = periodTime; | ||||||
|         seedlingRank = rank; |         seedlingRank = rank; | ||||||
|          |          | ||||||
|         // resume対応 |         // resume対応 | ||||||
|         // 途中からの場合アニメーションを勧めておく処理 |         // 途中からの場合アニメーションを勧めておく処理 | ||||||
|         var stage = GetCurrentStage(); |         seedlingView.SetView(GetCurrentStage()); | ||||||
|         seedlingStage.SetValueAndForceNotify(stage); |  | ||||||
|         switch (stage) |  | ||||||
|         { |  | ||||||
|             case SeedlingStage.Stage1: |  | ||||||
|                 seedlingStage1.SetActive(true); |  | ||||||
|                 break; |  | ||||||
|             case SeedlingStage.Stage2: |  | ||||||
|                 seedlingStage2.SetActive(true); |  | ||||||
|                 break; |  | ||||||
|             case SeedlingStage.Stage3: |  | ||||||
|                 seedlingStage3.SetActive(true); |  | ||||||
|                 break; |  | ||||||
|             case SeedlingStage.Stage4: |  | ||||||
|                 seedlingStage4.SetActive(true); |  | ||||||
|                 break; |  | ||||||
|             default: |  | ||||||
|                 throw new ArgumentOutOfRangeException(); |  | ||||||
|         } |  | ||||||
| 
 | 
 | ||||||
|         // 成長ロジック |         // 成長ロジック | ||||||
|         seedlingStage |         seedlingStage | ||||||
|             .TakeWhile(_ => !completed) |             .TakeWhile(_ => !completed) | ||||||
|             .Subscribe(x => |             .Subscribe(x => | ||||||
|             { |             { | ||||||
|                 switch (x) |                 seedlingView.ChangeState(x); | ||||||
|  |                 if (x == SeedlingStage.Stage4) | ||||||
|                 { |                 { | ||||||
|                     case SeedlingStage.Stage1: |                     completed = true; | ||||||
|                         break; |  | ||||||
|                     case SeedlingStage.Stage2: |  | ||||||
|                         seedlingStage1.GetComponent<Animator>().SetTrigger(nextStageTriggerHash); |  | ||||||
|                         this.CallWaitForSeconds(.25f, () => |  | ||||||
|                         { |  | ||||||
|                             seedlingStage2.SetActive(true); |  | ||||||
|                         }); |  | ||||||
|                         break; |  | ||||||
|                     case SeedlingStage.Stage3: |  | ||||||
|                         seedlingStage2.GetComponent<Animator>().SetTrigger(nextStageTriggerHash); |  | ||||||
|                         this.CallWaitForSeconds(.25f, () => |  | ||||||
|                         { |  | ||||||
|                             seedlingStage3.SetActive(true); |  | ||||||
|                         }); |  | ||||||
|                         break; |  | ||||||
|                     case SeedlingStage.Stage4: |  | ||||||
|                         seedlingStage3.GetComponent<Animator>().SetTrigger(nextStageTriggerHash); |  | ||||||
|                         this.CallWaitForSeconds(.25f, () => |  | ||||||
|                         { |  | ||||||
|                             completed = true; |  | ||||||
|                             seedlingStage4.SetActive(true); |  | ||||||
|                         }); |  | ||||||
|                         break; |  | ||||||
|                     default: |  | ||||||
|                         throw new ArgumentOutOfRangeException(nameof(x), x, null); |  | ||||||
|                 } |                 } | ||||||
|             }).AddTo(compositeDisposable); |             }).AddTo(compositeDisposable); | ||||||
| 
 | 
 | ||||||
|  | @ -161,6 +112,10 @@ public class CornSeedling : MonoBehaviour | ||||||
|         { |         { | ||||||
|             return SeedlingStage.Stage2; |             return SeedlingStage.Stage2; | ||||||
|         } |         } | ||||||
|         return SeedlingStage.Stage1; |         if (elapsed >= stage0End) | ||||||
|  |         { | ||||||
|  |             return SeedlingStage.Stage1; | ||||||
|  |         } | ||||||
|  |         return SeedlingStage.Stage0; | ||||||
|     } |     } | ||||||
| } | } | ||||||
|  | @ -0,0 +1,87 @@ | ||||||
|  | using System; | ||||||
|  | using UnityEngine; | ||||||
|  | 
 | ||||||
|  | public class CornSeedlingView : MonoBehaviour | ||||||
|  | { | ||||||
|  |     [SerializeField] private GameObject seedlingStage1; | ||||||
|  |     [SerializeField] private GameObject seedlingStage2; | ||||||
|  |     [SerializeField] private GameObject seedlingStage3; | ||||||
|  |     [SerializeField] private GameObject seedlingStage4; | ||||||
|  |     [SerializeField] private Collider2D stage4Collider; | ||||||
|  |     [SerializeField] private GameObject growingArrowPrefab; | ||||||
|  |     private readonly int nextStageTriggerHash = Animator.StringToHash("NextStageTrigger"); | ||||||
|  |      | ||||||
|  |     public void ResetView() | ||||||
|  |     { | ||||||
|  |         seedlingStage1.SetActive(false); | ||||||
|  |         seedlingStage2.SetActive(false); | ||||||
|  |         seedlingStage3.SetActive(false); | ||||||
|  |         seedlingStage4.SetActive(false); | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     public void SetView(SeedlingStage stage) | ||||||
|  |     { | ||||||
|  |         switch (stage) | ||||||
|  |         { | ||||||
|  |             case SeedlingStage.Stage0: | ||||||
|  |                 break; | ||||||
|  |             case SeedlingStage.Stage1: | ||||||
|  |                 seedlingStage1.SetActive(true); | ||||||
|  |                 break; | ||||||
|  |             case SeedlingStage.Stage2: | ||||||
|  |                 seedlingStage2.SetActive(true); | ||||||
|  |                 break; | ||||||
|  |             case SeedlingStage.Stage3: | ||||||
|  |                 seedlingStage3.SetActive(true); | ||||||
|  |                 break; | ||||||
|  |             case SeedlingStage.Stage4: | ||||||
|  |                 seedlingStage4.SetActive(true); | ||||||
|  |                 break; | ||||||
|  |             default: | ||||||
|  |                 throw new ArgumentOutOfRangeException(); | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     // 一段階成長するときアニメーションを再生して次の段階の素材に切り替え | ||||||
|  |     // アニメーション再生中0:15で次の段階の素材に切り替え、アニメーションは最後まで再生 | ||||||
|  |     public void ChangeState(SeedlingStage stage) | ||||||
|  |     { | ||||||
|  |         switch (stage) | ||||||
|  |         { | ||||||
|  |             case SeedlingStage.Stage0: | ||||||
|  |                 break; | ||||||
|  |             case SeedlingStage.Stage1: | ||||||
|  |                 seedlingStage1.SetActive(true); | ||||||
|  |                 break; | ||||||
|  |             case SeedlingStage.Stage2: | ||||||
|  |                 seedlingStage1.GetComponent<Animator>().SetTrigger(nextStageTriggerHash); | ||||||
|  |                 this.CallWaitForSeconds(.25f, () => | ||||||
|  |                 { | ||||||
|  |                     seedlingStage2.SetActive(true); | ||||||
|  |                 }); | ||||||
|  |                 break; | ||||||
|  |             case SeedlingStage.Stage3: | ||||||
|  |                 seedlingStage2.GetComponent<Animator>().SetTrigger(nextStageTriggerHash); | ||||||
|  |                 this.CallWaitForSeconds(.25f, () => | ||||||
|  |                 { | ||||||
|  |                     seedlingStage3.SetActive(true); | ||||||
|  |                 }); | ||||||
|  |                 break; | ||||||
|  |             case SeedlingStage.Stage4: | ||||||
|  |                 seedlingStage3.GetComponent<Animator>().SetTrigger(nextStageTriggerHash); | ||||||
|  |                 this.CallWaitForSeconds(.25f, () => | ||||||
|  |                 { | ||||||
|  |                     seedlingStage4.SetActive(true); | ||||||
|  |                 }); | ||||||
|  |                 break; | ||||||
|  |             default: | ||||||
|  |                 throw new ArgumentOutOfRangeException(nameof(stage), stage, null); | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     public void EffectGrowth() | ||||||
|  |     { | ||||||
|  |         var arrow = Instantiate(growingArrowPrefab, transform); | ||||||
|  |         this.CallWaitForSeconds(0.5f, () => Destroy(arrow)); | ||||||
|  |     } | ||||||
|  | } | ||||||
|  | @ -0,0 +1,3 @@ | ||||||
|  | fileFormatVersion: 2 | ||||||
|  | guid: dc986cc5c74043e08218a00c53d6f418 | ||||||
|  | timeCreated: 1626832646 | ||||||
		Loading…
	
		Reference in New Issue