Organised and added fan art

This commit is contained in:
2026-03-31 11:52:26 +01:00
parent dbd7414f8f
commit b92f4d1189
25 changed files with 235 additions and 7 deletions

View File

@@ -0,0 +1,44 @@
using Fruitomation.Global;
using UnityEngine.UI;
using UnityEngine;
namespace Fruitomation.UI
{
public class FruitBowlController : MonoBehaviour
{
[Header("UI Elements")]
[SerializeField] private Button UpgradesButton;
[SerializeField] private Button SimulateButton;
[SerializeField] private Button BuildButton;
[SerializeField] private Button PauseButton;
[SerializeField] private Text MoneyText;
private void Awake()
{
UpgradesButton.onClick.AddListener(() =>
{
GameStateController.State = GameState.UpgradeMenu;
});
SimulateButton.onClick.AddListener(() =>
{
GameStateController.State = GameState.Simulation;
});
BuildButton.onClick.AddListener(() =>
{
GameStateController.State = GameState.Building;
});
PauseButton.onClick.AddListener(() =>
{
GameStateController.State = GameState.Paused;
});
}
private void Update()
{
MoneyText.text = $"Current Money: ${MoneyController.Current}";
}
}
}

View File

@@ -0,0 +1,11 @@
fileFormatVersion: 2
guid: 4b0d01280f650064a9dc9ef817c8930a
MonoImporter:
externalObjects: {}
serializedVersion: 2
defaultReferences: []
executionOrder: 0
icon: {instanceID: 0}
userData:
assetBundleName:
assetBundleVariant:

View File

@@ -0,0 +1,79 @@
using System.Collections.Generic;
using Fruitomation.Game;
using UnityEngine;
namespace Fruitomation.UI
{
public class GameCursor : MonoBehaviour
{
[Header("References")]
[SerializeField] private Camera ActiveCamera;
[SerializeField] private CircleCollider2D CursorCollider;
[SerializeField] private RectTransform RectTransform;
private readonly ContactFilter2D ContactFilter = new();
private readonly List<Collider2D> Colliders = new();
private float CurrentMouseClickStrength;
private float StartOfMouseClick;
private void UpdatePosition()
{
Ray ray = ActiveCamera.ScreenPointToRay(Input.mousePosition);
float t = -ray.origin.z / ray.direction.z;
Vector2 position = ray.origin + t * ray.direction;
transform.position = position;
}
private void UpdateMouseState()
{
const float MIN_STRENGTH = 0.5f;
if (Input.GetMouseButtonUp(0))
{
CurrentMouseClickStrength = MIN_STRENGTH;
CursorCollider.radius = CurrentMouseClickStrength * 30f;
Physics2D.OverlapCollider(CursorCollider, ContactFilter, Colliders);
foreach (Collider2D col in Colliders)
{
if (col.transform.name == "Sprite")
{
FruitBehaviour fruit = col.GetComponentInParent<FruitBehaviour>();
Debug.Assert(fruit != null, "Couldn't find FruitBehaviour");
fruit.TriggerDestruction();
}
}
}
if (Input.GetMouseButton(0))
{
if (Input.GetMouseButtonDown(0))
{
StartOfMouseClick = Time.time;
CurrentMouseClickStrength = MIN_STRENGTH;
return;
}
CurrentMouseClickStrength = Time.time - StartOfMouseClick;
CurrentMouseClickStrength = Mathf.Clamp(CurrentMouseClickStrength, MIN_STRENGTH, 1.7f);
}
else
{
CurrentMouseClickStrength = MIN_STRENGTH;
}
}
private void Update()
{
UpdateMouseState();
UpdatePosition();
RectTransform.localScale = new Vector3(CurrentMouseClickStrength, CurrentMouseClickStrength, 1f);
}
}
}

View File

@@ -0,0 +1,3 @@
fileFormatVersion: 2
guid: 4c69710c42ff4ee0bb660893e59c12fe
timeCreated: 1774874748

View File

@@ -1,4 +1,5 @@
using UnityEngine.UI;
using Fruitomation.Global;
using UnityEngine.UI;
using UnityEngine;
namespace Fruitomation.UI