ResourceMaker déplace la ressource à ramasser vers un point fixe avant d'augmenter la quantité de ressources du joueur

ResourceTile produit des yields que lorsqu'une yield prefab a été déterminé
This commit is contained in:
Ader Alisma 01 2023-06-23 14:53:21 -04:00
parent ede4cbdf5c
commit 482fc2c178
2 changed files with 44 additions and 22 deletions

View File

@ -10,17 +10,30 @@ public class ResourceMaker : MonoBehaviour
[SerializeField]
private Enum.ResourceChoice _resourceChoice;
private ResourceManager _resourceManagerInstance;
[SerializeField]
private Vector2 _endPosition;
private Vector2 _startPosition;
private float _desiredTime = 1.5f;
private float _timePassed = 0f;
private bool _isPlaying = false;
private void Start()
{
_resourceManagerInstance = ResourceManager.Instance;
_startPosition = transform.position;
}
/// <summary>
/// D'après le choix de resource à générer, choisi le prefab à instancier
/// </summary>
public void GenerateResource()
private void Update()
{
if (_isPlaying)
{
_timePassed += Time.deltaTime;
float duration = _timePassed / _desiredTime;
duration = duration * duration * (3.0f - 2.0f * duration);
transform.position = Vector2.Lerp(_startPosition, _endPosition, duration);
if(Vector2.Distance(transform.position,_endPosition) < 0.01f)
{
_isPlaying = false;
switch (_resourceChoice)
{
case Enum.ResourceChoice.Rock:
@ -35,4 +48,11 @@ public class ResourceMaker : MonoBehaviour
}
Destroy(gameObject);
}
}
}
/// <summary>
/// D'après le choix de resource à générer, choisi le prefab à instancier
/// </summary>
public void GenerateResource(){_isPlaying = true;}
}

View File

@ -23,13 +23,15 @@ public class ResourceTile : LevelTile
{
_yieldCounter += Time.deltaTime * _yieldSpeed;
if (_yieldCounter < 1) return;
if(_yieldPrefab != null)
{
_yieldCounter = 0;
float rangeConfig = 0.5f + _randomPositionConfig;
Vector3 yieldPosition = new Vector3(Position.x + Random.Range(-rangeConfig, rangeConfig), Position.y, Position.z);
var yielded = Instantiate(_yieldPrefab, yieldPosition, Quaternion.identity);
yielded.transform.SetParent(LevelManager.Instance.LevelTransform);
}
}
public override bool Equals(ILevelObject other)
{
return other is ResourceTile otherRes