Merge branch 'develop' of bitbucket.org:usaya/popcorn into develop

# Conflicts:
#	popcorn/Assets/MyGame/Scenes/Cooking/Cooking.unity
This commit is contained in:
koya_15 2021-07-02 18:48:28 +09:00
commit 36c36079c6
4 changed files with 82 additions and 5212 deletions

File diff suppressed because it is too large Load Diff

View File

@ -1,20 +1,45 @@
using System; using System;
using UnityEngine; using UnityEngine;
namespace MyGame.Scenes.Main public class CornManager : MonoBehaviour
{ {
public class CornManager : MonoBehaviour
{
[SerializeField] private Transform cornSpawnTarget; [SerializeField] private Transform cornSpawnTarget;
[SerializeField] private Corn cornPrefab; [SerializeField] private Corn cornPrefab;
[SerializeField] private int cornSpawnCount = 20; [SerializeField] private int cornSpawnCount = 20;
[SerializeField] private float cornGrowSpeed;
[SerializeField] private float cornHotGrowSpeed;
private Corn[] cornArray;
private void Start() private void Start()
{
}
public void Initialize()
{
cornArray = new Corn[cornSpawnCount];
}
public void GenerateCorn()
{ {
for (int i = 0; i < cornSpawnCount; i++) for (int i = 0; i < cornSpawnCount; i++)
{ {
Instantiate(cornPrefab, cornSpawnTarget); cornArray[i] = Instantiate(cornPrefab, cornSpawnTarget);
} }
} }
public void ChangeGrowSpeed(ThermalCondition condition)
{
switch (condition)
{
case ThermalCondition.Cold:
break;
case ThermalCondition.Yellow:
break;
case ThermalCondition.Hot:
break;
default:
throw new ArgumentOutOfRangeException(nameof(condition), condition, null);
}
} }
} }

View File

@ -1,4 +1,5 @@
using System; using System;
using UniRx;
using Unity.Mathematics; using Unity.Mathematics;
using UnityEngine; using UnityEngine;
@ -29,17 +30,25 @@ public class ThermalControl : MonoBehaviour
[SerializeField] private float coldValue = 0.32f; [SerializeField] private float coldValue = 0.32f;
[SerializeField] private float hotValue = 0.67f; [SerializeField] private float hotValue = 0.67f;
public IReadOnlyReactiveProperty<ThermalCondition> Condition => condition;
private ReactiveProperty<ThermalCondition> condition;
private void Start() private void Start()
{ {
temperature = 0f; temperature = 0f;
condition = new ReactiveProperty<ThermalCondition>(ThermalCondition.Cold);
thermoMeter.SetScale(coldValue, hotValue); thermoMeter.SetScale(coldValue, hotValue);
condition.DistinctUntilChanged().Subscribe(x =>
{
Debug.Log($"cond :{x} temp: {temperature}");
}).AddTo(this);
} }
private ThermalCondition prevCond; private ThermalCondition prevCond;
private void Update() private void Update()
{ {
var cond = GetCondition();
panSpeed = panController.Delta.magnitude * panFactor; panSpeed = panController.Delta.magnitude * panFactor;
if (panSpeed > deadZone) if (panSpeed > deadZone)
{ {
@ -47,7 +56,7 @@ public class ThermalControl : MonoBehaviour
} }
else else
{ {
if (cond == ThermalCondition.Hot) if (condition.Value == ThermalCondition.Hot)
{ {
temperature += hotIncreaseSpeed * Time.deltaTime; temperature += hotIncreaseSpeed * Time.deltaTime;
} }
@ -58,12 +67,7 @@ public class ThermalControl : MonoBehaviour
} }
temperature = Mathf.Clamp01(temperature); temperature = Mathf.Clamp01(temperature);
thermoMeter.SetValue(temperature); thermoMeter.SetValue(temperature);
condition.Value = GetCondition();
if (cond != prevCond)
{
Debug.Log($"cond :{cond} temp: {temperature}");
prevCond = cond;
}
} }
public ThermalCondition GetCondition() public ThermalCondition GetCondition()

View File

@ -1,5 +1,6 @@
using System; using System;
using System.Collections.Generic; using System.Collections.Generic;
using UniRx;
using UnityEngine; using UnityEngine;
using UnityEngine.EventSystems; using UnityEngine.EventSystems;
using UnityEngine.SceneManagement; using UnityEngine.SceneManagement;
@ -8,143 +9,45 @@ using UnityEngine.UI;
public class PopcornGameManager : MonoBehaviour public class PopcornGameManager : MonoBehaviour
{ {
[SerializeField] private GameObject startingGuide; [SerializeField] private GameObject startingGuide;
[SerializeField] private PowerMeter powerMeter; // [SerializeField] private Text powerResultText;
[SerializeField] private Text powerResultText;
[SerializeField] private Text gameResultText; [SerializeField] private Text gameResultText;
[SerializeField] private PanController panController;
[SerializeField] private ThermalControl thermalControl;
[SerializeField] private ThermoMeter thermoMeter;
[SerializeField] private CornManager cornManager;
private Action tapAction; private Action tapAction;
private bool isProgress; private bool isProgress;
private int gameCount;
private int failCount;
private bool isPerfect;
private readonly int maxGameCount = 3;
private readonly int maxFailCount = 2;
// Start is called before the first frame update // Start is called before the first frame update
void Start() void Start()
{ {
powerResultText.text = "";
gameResultText.text = ""; gameResultText.text = "";
startingGuide.SetActive(true); // startingGuide.SetActive(true);
powerMeter.StopMove();
isProgress = false; isProgress = false;
panController.enabled = false; cornManager.Initialize();
// タップしたら案内非表示&ゲーム開始 thermalControl.Condition.DistinctUntilChanged().Subscribe(x =>
tapAction = () =>
{ {
startingGuide.SetActive(false); cornManager.ChangeGrowSpeed(x);
// panController.enabled = true; }).AddTo(this);
GameStart();
};
GameReset();
// タップ後スタート
GameStart();
}
private void Update()
{
}
private void GameReset()
{
cornManager.GenerateCorn();
} }
private void GameStart() private void GameStart()
{ {
gameCount = 0;
failCount = 0;
isPerfect = true;
powerMeter.StartMove();
tapAction = () =>
{
isProgress = true;
powerMeter.StopMove();
gameCount++;
var pos = powerMeter.GetCurrentPosisiton();
Debug.Log($"tap! {pos}");
// 判定
CheckQuality(pos);
this.CallWaitForSeconds(1f, () =>
{
powerResultText.text = "";
// 失敗
if (failCount >= maxFailCount)
{
gameResultText.text = "失敗!";
powerMeter.gameObject.SetActive(false);
tapAction = () => { };
panController.enabled = false;
this.CallWaitForSeconds(2f, () =>
{
gameResultText.text = "タップでリスタート";
tapAction = () => {
{
SceneManager.LoadScene("Main");
}};
isProgress = false;
});
return;
}
// 成功
if (gameCount >= maxGameCount)
{
gameResultText.text = "成功!";
if (isPerfect)
{
gameResultText.text = "大成功!";
}
powerMeter.gameObject.SetActive(false);
tapAction = () => { };
panController.enabled = false;
this.CallWaitForSeconds(2f, () =>
{
gameResultText.text = "タップでリスタート";
tapAction = () => {
{
SceneManager.LoadScene("Main");
}};
isProgress = false;
});
return;
}
isProgress = false;
powerMeter.StartMove();
});
};
}
private void CheckQuality(float pos)
{
//Perfect=0.45~0.5
//Good=0.3
if (pos <= 0.05f)
{
powerResultText.text = "パーフェクト";
return;
}
if (pos <= 0.2)
{
powerResultText.text = "グッド";
isPerfect = false;
return;
}
powerResultText.text = "ミス!";
isPerfect = false;
failCount++;
}
// Update is called once per frame
void Update()
{
if(Input.GetMouseButtonDown(0))
{
if (!isProgress)
{
tapAction.Invoke();
}
}
}
private bool CheckTap(Vector2 position){
var eventSystem = EventSystem.current;
var eventDataCurrentPosition = new PointerEventData(eventSystem);
eventDataCurrentPosition.position = position;
List<RaycastResult> raycastResults = new List<RaycastResult>();
eventSystem.RaycastAll(eventDataCurrentPosition, raycastResults);
return raycastResults.Count == 0;
} }
} }