game(scripts): [big] standardise
just format and add placeholder xml comments where not placed
This commit is contained in:
parent
6f91c582c3
commit
51148ef5e2
9 changed files with 323 additions and 64 deletions
|
@ -1,7 +1,7 @@
|
|||
/*
|
||||
* author: lin hengrui ryan
|
||||
* author: ryan lin
|
||||
* date: 30/7/2024
|
||||
* description: AI code for the different AI in the game
|
||||
* description: 'standard' npc ai behaviour
|
||||
*/
|
||||
|
||||
using System.Collections;
|
||||
|
@ -9,6 +9,9 @@ using UnityEngine;
|
|||
using UnityEngine.AI;
|
||||
using Random = System.Random;
|
||||
|
||||
/// <summary>
|
||||
/// TODO
|
||||
/// </summary>
|
||||
public class AI : MonoBehaviour
|
||||
{
|
||||
/// <summary>
|
||||
|
@ -16,7 +19,6 @@ public class AI : MonoBehaviour
|
|||
/// </summary>
|
||||
private static readonly int AnimatorSpeed = Animator.StringToHash("Speed");
|
||||
|
||||
|
||||
/// <summary>
|
||||
/// set the layers the AI can be on
|
||||
/// </summary>
|
||||
|
|
|
@ -1,24 +1,96 @@
|
|||
using System.Collections;
|
||||
/*
|
||||
* author: ryan lin
|
||||
* date: 30/7/2024
|
||||
* description: vehicular ai behaviour
|
||||
*/
|
||||
|
||||
using System.Collections;
|
||||
using UnityEngine;
|
||||
|
||||
/// <summary>
|
||||
/// TODO
|
||||
/// </summary>
|
||||
public class AICar : MonoBehaviour
|
||||
{
|
||||
/// <summary>
|
||||
/// TODO
|
||||
/// </summary>
|
||||
[SerializeField] private Transform carPosition;
|
||||
|
||||
/// <summary>
|
||||
/// TODO
|
||||
/// </summary>
|
||||
[SerializeField] private float stoppingDistance;
|
||||
|
||||
/// <summary>
|
||||
/// TODO
|
||||
/// </summary>
|
||||
[SerializeField] private float slowingSpeed;
|
||||
|
||||
/// <summary>
|
||||
/// TODO
|
||||
/// </summary>
|
||||
[SerializeField] private float slowingDistance;
|
||||
|
||||
/// <summary>
|
||||
/// TODO
|
||||
/// </summary>
|
||||
[SerializeField] private float reverseDist;
|
||||
private string _currentState;
|
||||
private string _nextState;
|
||||
|
||||
/// <summary>
|
||||
/// TODO
|
||||
/// </summary>
|
||||
private float _accelerationInput;
|
||||
private CarController _car;
|
||||
|
||||
/// <summary>
|
||||
/// TODO
|
||||
/// </summary>
|
||||
private float _angularDirection;
|
||||
|
||||
/// <summary>
|
||||
/// TODO
|
||||
/// </summary>
|
||||
private CarController _car;
|
||||
|
||||
/// <summary>
|
||||
/// TODO
|
||||
/// </summary>
|
||||
private string _currentState;
|
||||
|
||||
/// <summary>
|
||||
/// TODO
|
||||
/// </summary>
|
||||
private Vector3 _dirToMove;
|
||||
|
||||
/// <summary>
|
||||
/// TODO
|
||||
/// </summary>
|
||||
private float _distanceToTarget;
|
||||
|
||||
/// <summary>
|
||||
/// TODO
|
||||
/// </summary>
|
||||
private Transform _driveTarget;
|
||||
|
||||
/// <summary>
|
||||
/// TODO
|
||||
/// </summary>
|
||||
// FIXME: use an enum or something
|
||||
private string _nextState;
|
||||
|
||||
/// <summary>
|
||||
/// TODO
|
||||
/// </summary>
|
||||
private float _turnInput;
|
||||
|
||||
/// <summary>
|
||||
/// TODO
|
||||
/// </summary>
|
||||
private float _verticalDirection;
|
||||
|
||||
/// <summary>
|
||||
/// TODO
|
||||
/// </summary>
|
||||
private void Awake()
|
||||
{
|
||||
var hasChild = false;
|
||||
|
@ -44,16 +116,25 @@ public class AICar : MonoBehaviour
|
|||
ChangeState();
|
||||
}
|
||||
|
||||
/// <summary>
|
||||
/// TODO
|
||||
/// </summary>
|
||||
private void Update()
|
||||
{
|
||||
_currentState = _nextState;
|
||||
}
|
||||
|
||||
/// <summary>
|
||||
/// TODO
|
||||
/// </summary>
|
||||
private void ChangeState()
|
||||
{
|
||||
StartCoroutine(_currentState);
|
||||
}
|
||||
|
||||
/// <summary>
|
||||
/// TODO
|
||||
/// </summary>
|
||||
private void Steering()
|
||||
{
|
||||
_angularDirection = Vector3.SignedAngle(carPosition.transform.forward,
|
||||
|
@ -64,34 +145,36 @@ public class AICar : MonoBehaviour
|
|||
_turnInput = 1;
|
||||
}
|
||||
|
||||
/// <summary>
|
||||
/// TODO
|
||||
/// </summary>
|
||||
private IEnumerator Stopped()
|
||||
{
|
||||
|
||||
while (_currentState == "Stopped")
|
||||
{
|
||||
_distanceToTarget=Vector3.Distance(carPosition.position, _driveTarget.position);
|
||||
_distanceToTarget = Vector3.Distance(carPosition.position, _driveTarget.position);
|
||||
_car.braking = true;
|
||||
_accelerationInput = 0f;
|
||||
_turnInput = 0f;
|
||||
if (_distanceToTarget>stoppingDistance)
|
||||
{
|
||||
_nextState = "Slowed";
|
||||
}
|
||||
if (_distanceToTarget > stoppingDistance) _nextState = "Slowed";
|
||||
yield return new WaitForSeconds(1);
|
||||
}
|
||||
|
||||
ChangeState();
|
||||
}
|
||||
|
||||
/// <summary>
|
||||
/// TODO
|
||||
/// </summary>
|
||||
private IEnumerator Slowed()
|
||||
{
|
||||
_car.braking = false;
|
||||
while (_currentState == "Slowed")
|
||||
{
|
||||
|
||||
_verticalDirection = Vector3.Dot(carPosition.transform.forward,
|
||||
(_driveTarget.position - carPosition.transform.position).normalized);
|
||||
_distanceToTarget = Vector3.Distance(carPosition.position, _driveTarget.position);
|
||||
if (_verticalDirection>0)
|
||||
if (_verticalDirection > 0)
|
||||
{
|
||||
if (carPosition.GetComponent<Rigidbody>().velocity.magnitude > slowingSpeed)
|
||||
_accelerationInput = -1;
|
||||
|
@ -105,15 +188,19 @@ public class AICar : MonoBehaviour
|
|||
else
|
||||
_accelerationInput = 1;
|
||||
}
|
||||
|
||||
|
||||
Steering();
|
||||
SlowedCheck();
|
||||
_car.SetInputs(_accelerationInput, _turnInput);
|
||||
yield return new WaitForEndOfFrame();
|
||||
}
|
||||
|
||||
ChangeState();
|
||||
}
|
||||
|
||||
/// <summary>
|
||||
/// TODO
|
||||
/// </summary>
|
||||
private IEnumerator Driving()
|
||||
{
|
||||
_car.braking = false;
|
||||
|
@ -122,30 +209,25 @@ public class AICar : MonoBehaviour
|
|||
_verticalDirection = Vector3.Dot(carPosition.transform.forward,
|
||||
(_driveTarget.position - carPosition.transform.position).normalized);
|
||||
_distanceToTarget = Vector3.Distance(carPosition.position, _driveTarget.position);
|
||||
_accelerationInput = 1;
|
||||
|
||||
|
||||
_accelerationInput = 1;
|
||||
|
||||
|
||||
Steering();
|
||||
if (_distanceToTarget < slowingDistance) _nextState = "Slowed";
|
||||
_car.SetInputs(_accelerationInput, _turnInput);
|
||||
yield return new WaitForEndOfFrame();
|
||||
}
|
||||
|
||||
ChangeState();
|
||||
}
|
||||
|
||||
/// <summary>
|
||||
/// TODO
|
||||
/// </summary>
|
||||
private void SlowedCheck()
|
||||
{
|
||||
if (_distanceToTarget < stoppingDistance)
|
||||
{
|
||||
_nextState = "Stopped";
|
||||
}
|
||||
if (_distanceToTarget < stoppingDistance) _nextState = "Stopped";
|
||||
|
||||
if (_distanceToTarget > slowingDistance) _nextState = "Driving";
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
}
|
||||
}
|
|
@ -1,32 +1,71 @@
|
|||
/*
|
||||
* author: ryan lin
|
||||
* date: TODO
|
||||
* description: TODO
|
||||
*/
|
||||
|
||||
using System.Collections;
|
||||
using UnityEngine;
|
||||
|
||||
public class AiManager : MonoBehaviour
|
||||
public class AIManager : MonoBehaviour
|
||||
{
|
||||
/// <summary>
|
||||
/// TODO
|
||||
/// </summary>
|
||||
public Transform player;
|
||||
|
||||
/// <summary>
|
||||
/// TODO
|
||||
/// </summary>
|
||||
public float cullingDistance;
|
||||
|
||||
/// <summary>
|
||||
/// TODO
|
||||
/// </summary>
|
||||
public GameObject aiPrefab;
|
||||
private GameObject[] _ais;
|
||||
private float _distance;
|
||||
|
||||
/// <summary>
|
||||
/// TODO
|
||||
/// </summary>
|
||||
public int maxAI;
|
||||
|
||||
/// <summary>
|
||||
/// TODO
|
||||
/// </summary>
|
||||
private GameObject[] _ais;
|
||||
|
||||
/// <summary>
|
||||
/// TODO
|
||||
/// </summary>
|
||||
private float _distance;
|
||||
|
||||
/// <summary>
|
||||
/// TODO
|
||||
/// </summary>
|
||||
private void Start()
|
||||
{
|
||||
StartCoroutine(Manager());
|
||||
}
|
||||
|
||||
/// <summary>
|
||||
/// TODO
|
||||
/// </summary>
|
||||
private void OnDrawGizmos()
|
||||
{
|
||||
Gizmos.color = Color.yellow;
|
||||
Gizmos.DrawWireSphere(player.position, cullingDistance);
|
||||
}
|
||||
|
||||
// ReSharper disable Unity.PerformanceAnalysis
|
||||
/// <summary>
|
||||
/// TODO
|
||||
/// </summary>
|
||||
private IEnumerator Manager()
|
||||
{
|
||||
while (true)
|
||||
{
|
||||
// FIXME: feels weird
|
||||
_ais = GameObject.FindGameObjectsWithTag("AIs");
|
||||
if (_ais.Length < maxAI )
|
||||
if (_ais.Length < maxAI)
|
||||
{
|
||||
var instance = Instantiate(aiPrefab, gameObject.transform);
|
||||
}
|
||||
|
@ -38,6 +77,7 @@ public class AiManager : MonoBehaviour
|
|||
}
|
||||
|
||||
yield return new WaitForSeconds(1);
|
||||
}
|
||||
}
|
||||
// TODO: iterator never returns? is this intended?
|
||||
}
|
||||
}
|
|
@ -1,25 +1,65 @@
|
|||
/*
|
||||
* author: ryan lin
|
||||
* date: TODO
|
||||
* description: TODO
|
||||
*/
|
||||
|
||||
using System;
|
||||
using System.Collections.Generic;
|
||||
using UnityEngine;
|
||||
|
||||
/// <summary>
|
||||
/// TODO
|
||||
/// </summary>
|
||||
public class CarController : MonoBehaviour
|
||||
{
|
||||
/// <summary>
|
||||
/// TODO
|
||||
/// </summary>
|
||||
public enum Axel
|
||||
{
|
||||
Front,
|
||||
Rear
|
||||
}
|
||||
|
||||
/// <summary>
|
||||
/// TODO
|
||||
/// </summary>
|
||||
public float acceleration;
|
||||
|
||||
/// <summary>
|
||||
/// TODO
|
||||
/// </summary>
|
||||
public float turnAngle;
|
||||
|
||||
/// <summary>
|
||||
/// TODO
|
||||
/// </summary>
|
||||
public List<Wheel> wheels;
|
||||
|
||||
/// <summary>
|
||||
/// TODO
|
||||
/// </summary>
|
||||
public float brakeForce;
|
||||
|
||||
/// <summary>
|
||||
/// TODO
|
||||
/// </summary>
|
||||
public bool braking;
|
||||
|
||||
/// <summary>
|
||||
/// TODO
|
||||
/// </summary>
|
||||
private float _currentAcceleration;
|
||||
|
||||
/// <summary>
|
||||
/// TODO
|
||||
/// </summary>
|
||||
private float _currentTurn;
|
||||
|
||||
|
||||
/// <summary>
|
||||
/// TODO
|
||||
/// </summary>
|
||||
private void FixedUpdate()
|
||||
{
|
||||
Move();
|
||||
|
@ -27,18 +67,26 @@ public class CarController : MonoBehaviour
|
|||
Brake();
|
||||
}
|
||||
|
||||
/// <summary>
|
||||
/// TODO
|
||||
/// </summary>
|
||||
public void SetInputs(float forwardAmount, float turnAmount)
|
||||
{
|
||||
_currentAcceleration = forwardAmount * acceleration;
|
||||
_currentTurn = turnAmount * turnAngle;
|
||||
}
|
||||
|
||||
|
||||
/// <summary>
|
||||
/// TODO
|
||||
/// </summary>
|
||||
public void Move()
|
||||
{
|
||||
foreach (var wheel in wheels) wheel.wheelCollider.motorTorque = _currentAcceleration;
|
||||
}
|
||||
|
||||
/// <summary>
|
||||
/// TODO
|
||||
/// </summary>
|
||||
public void Brake()
|
||||
{
|
||||
if (braking)
|
||||
|
@ -49,6 +97,9 @@ public class CarController : MonoBehaviour
|
|||
wheel.wheelCollider.brakeTorque = 0f;
|
||||
}
|
||||
|
||||
/// <summary>
|
||||
/// TODO
|
||||
/// </summary>
|
||||
public void Steering()
|
||||
{
|
||||
foreach (var wheel in wheels)
|
||||
|
@ -56,6 +107,10 @@ public class CarController : MonoBehaviour
|
|||
wheel.wheelCollider.steerAngle = _currentTurn;
|
||||
}
|
||||
|
||||
/// <summary>
|
||||
/// TODO
|
||||
/// </summary>
|
||||
// NOTE: once again, why is this at the bottom lol
|
||||
[Serializable]
|
||||
public struct Wheel
|
||||
{
|
||||
|
|
20
RunningLateGame/Assets/Scripts/CommonInteractable.cs
Normal file
20
RunningLateGame/Assets/Scripts/CommonInteractable.cs
Normal file
|
@ -0,0 +1,20 @@
|
|||
/*
|
||||
* authors: ryan lin, mark joshwel
|
||||
* date: 10/8/2024
|
||||
* description: common interactable behaviour class
|
||||
*/
|
||||
|
||||
using UnityEngine;
|
||||
|
||||
/// <summary>
|
||||
/// TODO
|
||||
/// </summary>
|
||||
public class CommonInteractable : MonoBehaviour
|
||||
{
|
||||
/// <summary>
|
||||
/// TODO
|
||||
/// </summary>
|
||||
public virtual void Interact()
|
||||
{
|
||||
}
|
||||
}
|
|
@ -1,29 +1,64 @@
|
|||
/*
|
||||
* author: ryan lin
|
||||
* date: 8/8/2024
|
||||
* description: door interaction and animation
|
||||
*/
|
||||
|
||||
using System;
|
||||
using System.Collections;
|
||||
using System.Collections.Generic;
|
||||
using UnityEngine;
|
||||
|
||||
public class Door : Interactable
|
||||
/// <summary>
|
||||
/// TODO
|
||||
/// </summary>
|
||||
public class Door : CommonInteractable
|
||||
{
|
||||
/// <summary>
|
||||
/// TODO
|
||||
/// </summary>
|
||||
public enum DoorType
|
||||
{
|
||||
Sliding,
|
||||
Rotating
|
||||
}
|
||||
|
||||
/// <summary>
|
||||
/// TODO
|
||||
/// </summary>
|
||||
public List<DoorInput> doors;
|
||||
|
||||
/// <summary>
|
||||
/// TODO
|
||||
/// </summary>
|
||||
public float duration;
|
||||
|
||||
/// <summary>
|
||||
/// TODO
|
||||
/// </summary>
|
||||
public AnimationCurve curve;
|
||||
|
||||
/// <summary>
|
||||
/// TODO
|
||||
/// </summary>
|
||||
private bool _isOpen;
|
||||
|
||||
/// <summary>
|
||||
/// TODO
|
||||
/// </summary>
|
||||
private bool _opening;
|
||||
|
||||
|
||||
/// <summary>
|
||||
/// TODO
|
||||
/// </summary>
|
||||
public override void Interact()
|
||||
{
|
||||
if (!_opening) StartCoroutine(OpenDoor());
|
||||
}
|
||||
|
||||
/// <summary>
|
||||
/// TODO
|
||||
/// </summary>
|
||||
private IEnumerator OpenDoor()
|
||||
{
|
||||
_opening = true;
|
||||
|
@ -62,19 +97,19 @@ public class Door : Interactable
|
|||
currentDuration = 0;
|
||||
_opening = false;
|
||||
if (_isOpen)
|
||||
{
|
||||
_isOpen = false;
|
||||
}
|
||||
else
|
||||
{
|
||||
_isOpen = true;
|
||||
}
|
||||
}
|
||||
|
||||
yield return new WaitForEndOfFrame();
|
||||
}
|
||||
}
|
||||
|
||||
/// <summary>
|
||||
/// TODO
|
||||
/// </summary>
|
||||
// NOTE: why is this at the bottom lol
|
||||
[Serializable]
|
||||
public struct DoorInput
|
||||
{
|
||||
|
|
|
@ -1,11 +0,0 @@
|
|||
using System.Collections;
|
||||
using System.Collections.Generic;
|
||||
using UnityEngine;
|
||||
|
||||
public class Interactable : MonoBehaviour
|
||||
{
|
||||
public virtual void Interact()
|
||||
{
|
||||
|
||||
}
|
||||
}
|
|
@ -1,17 +1,54 @@
|
|||
/*
|
||||
* author: ryan lin
|
||||
* date: 8/8/2024
|
||||
* description: TODO
|
||||
*/
|
||||
|
||||
using UnityEngine;
|
||||
|
||||
|
||||
/// <summary>
|
||||
/// TODO
|
||||
/// </summary>
|
||||
public class Player : MonoBehaviour
|
||||
{
|
||||
public RaycastHit Hit;
|
||||
/// <summary>
|
||||
/// TODO
|
||||
/// </summary>
|
||||
[SerializeField] private Transform playerPosition;
|
||||
|
||||
/// <summary>
|
||||
/// TODO
|
||||
/// </summary>
|
||||
[SerializeField] private float seeDistance;
|
||||
private Interactable _currentInteractable;
|
||||
private bool _active;
|
||||
private bool _raycast;
|
||||
|
||||
/// <summary>
|
||||
/// TODO
|
||||
/// </summary>
|
||||
public LayerMask raycastLayers;
|
||||
|
||||
/// <summary>
|
||||
/// TODO
|
||||
/// </summary>
|
||||
private bool _active;
|
||||
|
||||
/// <summary>
|
||||
/// TODO
|
||||
/// </summary>
|
||||
private CommonInteractable _currentInteractable;
|
||||
|
||||
/// <summary>
|
||||
/// TODO
|
||||
/// </summary>
|
||||
private bool _raycast;
|
||||
|
||||
/// <summary>
|
||||
/// TODO
|
||||
/// </summary>
|
||||
public RaycastHit Hit;
|
||||
|
||||
|
||||
/// <summary>
|
||||
/// TODO
|
||||
/// </summary>
|
||||
private void Update()
|
||||
{
|
||||
_raycast = Physics.Raycast(
|
||||
|
@ -28,15 +65,14 @@ public class Player : MonoBehaviour
|
|||
);
|
||||
}
|
||||
|
||||
/// <summary>
|
||||
/// TODO
|
||||
/// </summary>
|
||||
private void OnAction()
|
||||
{
|
||||
Debug.Log("test");
|
||||
if (_raycast)
|
||||
{
|
||||
if (Hit.transform.CompareTag("Interactable"))
|
||||
{
|
||||
Hit.transform.GetComponent<Interactable>().Interact();
|
||||
}
|
||||
}
|
||||
Hit.transform.GetComponent<CommonInteractable>().Interact();
|
||||
}
|
||||
}
|
Reference in a new issue