From aab46e4d39935ca3d6ebdf3ba5c589aff2dfa144 Mon Sep 17 00:00:00 2001 From: Daniel Lovell Date: Mon, 23 Sep 2024 22:00:18 -0700 Subject: [PATCH] Completed InputManager refactor Separate InputManager from CameraController InputManager is one, consolidated input handling object CameraController provides an interface for keystrokes & mouse movements detected/handled by InputManager --- Assets/Scenes/MainScene.unity | 124 ++++++++++++++---- Assets/Scripts/Managers/InputManager.cs | 26 +--- Assets/Scripts/UI/CameraController.cs | 166 +++++++----------------- ProjectSettings/TagManager.asset | 2 +- 4 files changed, 154 insertions(+), 164 deletions(-) diff --git a/Assets/Scenes/MainScene.unity b/Assets/Scenes/MainScene.unity index 027d58f..e2b9cc6 100644 --- a/Assets/Scenes/MainScene.unity +++ b/Assets/Scenes/MainScene.unity @@ -159,12 +159,12 @@ Transform: m_PrefabAsset: {fileID: 0} m_GameObject: {fileID: 17322847} serializedVersion: 2 - m_LocalRotation: {x: 0, y: 0, z: 0, w: 1} + m_LocalRotation: {x: -0, y: -0, z: -0, w: 1} m_LocalPosition: {x: 0, y: 0, z: 0} m_LocalScale: {x: 1, y: 1, z: 1} m_ConstrainProportionsScale: 0 m_Children: [] - m_Father: {fileID: 0} + m_Father: {fileID: 1457077473} m_LocalEulerAnglesHint: {x: 0, y: 0, z: 0} --- !u!1 &61846315 GameObject: @@ -734,12 +734,12 @@ Transform: m_PrefabAsset: {fileID: 0} m_GameObject: {fileID: 253946925} serializedVersion: 2 - m_LocalRotation: {x: 0, y: 0, z: 0, w: 1} - m_LocalPosition: {x: 0.12123265, y: 0.17553951, z: -8.531889} + m_LocalRotation: {x: -0, y: -0, z: -0, w: 1} + m_LocalPosition: {x: 0, y: 0, z: 0} m_LocalScale: {x: 1, y: 1, z: 1} m_ConstrainProportionsScale: 0 m_Children: [] - m_Father: {fileID: 0} + m_Father: {fileID: 1457077473} m_LocalEulerAnglesHint: {x: 0, y: 0, z: 0} --- !u!1 &320210793 GameObject: @@ -753,7 +753,7 @@ GameObject: - component: {fileID: 320210797} - component: {fileID: 320210796} - component: {fileID: 320210795} - m_Layer: 0 + m_Layer: 6 m_Name: Floor m_TagString: Untagged m_Icon: {fileID: 0} @@ -1677,30 +1677,29 @@ MonoBehaviour: m_GameObject: {fileID: 963194225} m_Enabled: 1 m_EditorHideFlags: 0 - m_Script: {fileID: 11500000, guid: 6a028bd12cca23f45a9eeb9fb0c4d1f1, type: 3} + m_Script: {fileID: 11500000, guid: b9e222cf9df32df4196f08036d68d740, type: 3} m_Name: m_EditorClassIdentifier: mouseActive: 1 - autoplayCamSpeed: 2 - xAutoRotateTime: 5 - yAutoRotateTime: 5 lockUserInput: 0 _cameraSpeedNormal: 100 _cameraSpeedMax: 1000 - _speedH: 2 - _speedV: 2 - autoRotate: 0 + _speedH: 1 + _speedV: 1 + _autoRotate: 0 target: {fileID: 1255004942} - targetRenderer: {fileID: 1255004940} - floorRenderer: {fileID: 394856875} - matAlpha: 0 - orbitDistance: 5000 - orbitXSpeed: 0.1 - orbitYSpeed: 0.1 + _orbitDistance: 5 + _orbitXSpeed: 0.1 + _orbitYSpeed: 0.1 + _zoomSpeed: 5 orbitYMinLimit: -20 orbitYMaxLimit: 80 - orbitDistanceMin: 10 - orbitDistanceMax: 10000 + targetRenderer: {fileID: 1255004940} + floorRenderer: {fileID: 320210796} + matAlpha: 0 + autoplayCamSpeed: 2 + xAutoRotateTime: 5 + yAutoRotateTime: 5 forwardToCameraAngle: 0 --- !u!1 &986996500 GameObject: @@ -1875,6 +1874,52 @@ MeshRenderer: m_SortingLayer: 0 m_SortingOrder: 0 m_AdditionalVertexStreams: {fileID: 0} +--- !u!1 &1036072789 +GameObject: + m_ObjectHideFlags: 0 + m_CorrespondingSourceObject: {fileID: 0} + m_PrefabInstance: {fileID: 0} + m_PrefabAsset: {fileID: 0} + serializedVersion: 6 + m_Component: + - component: {fileID: 1036072790} + - component: {fileID: 1036072791} + m_Layer: 0 + m_Name: InputManager + m_TagString: Untagged + m_Icon: {fileID: 0} + m_NavMeshLayer: 0 + m_StaticEditorFlags: 0 + m_IsActive: 1 +--- !u!4 &1036072790 +Transform: + m_ObjectHideFlags: 0 + m_CorrespondingSourceObject: {fileID: 0} + m_PrefabInstance: {fileID: 0} + m_PrefabAsset: {fileID: 0} + m_GameObject: {fileID: 1036072789} + serializedVersion: 2 + m_LocalRotation: {x: -0, y: -0, z: -0, w: 1} + m_LocalPosition: {x: 1715.5709, y: 1660.0452, z: 811.7122} + m_LocalScale: {x: 1, y: 1, z: 1} + m_ConstrainProportionsScale: 0 + m_Children: [] + m_Father: {fileID: 1457077473} + m_LocalEulerAnglesHint: {x: 0, y: 0, z: 0} +--- !u!114 &1036072791 +MonoBehaviour: + m_ObjectHideFlags: 0 + m_CorrespondingSourceObject: {fileID: 0} + m_PrefabInstance: {fileID: 0} + m_PrefabAsset: {fileID: 0} + m_GameObject: {fileID: 1036072789} + m_Enabled: 1 + m_EditorHideFlags: 0 + m_Script: {fileID: 11500000, guid: 6a028bd12cca23f45a9eeb9fb0c4d1f1, type: 3} + m_Name: + m_EditorClassIdentifier: + mouseActive: 1 + lockUserInput: 0 --- !u!1 &1254435375 GameObject: m_ObjectHideFlags: 0 @@ -2268,6 +2313,40 @@ MeshRenderer: m_SortingLayer: 0 m_SortingOrder: 0 m_AdditionalVertexStreams: {fileID: 0} +--- !u!1 &1457077472 +GameObject: + m_ObjectHideFlags: 0 + m_CorrespondingSourceObject: {fileID: 0} + m_PrefabInstance: {fileID: 0} + m_PrefabAsset: {fileID: 0} + serializedVersion: 6 + m_Component: + - component: {fileID: 1457077473} + m_Layer: 0 + m_Name: Managers + m_TagString: Untagged + m_Icon: {fileID: 0} + m_NavMeshLayer: 0 + m_StaticEditorFlags: 0 + m_IsActive: 1 +--- !u!4 &1457077473 +Transform: + m_ObjectHideFlags: 0 + m_CorrespondingSourceObject: {fileID: 0} + m_PrefabInstance: {fileID: 0} + m_PrefabAsset: {fileID: 0} + m_GameObject: {fileID: 1457077472} + serializedVersion: 2 + m_LocalRotation: {x: 0, y: 0, z: 0, w: 1} + m_LocalPosition: {x: 0, y: 0, z: 0} + m_LocalScale: {x: 1, y: 1, z: 1} + m_ConstrainProportionsScale: 0 + m_Children: + - {fileID: 253946927} + - {fileID: 1036072790} + - {fileID: 17322849} + m_Father: {fileID: 0} + m_LocalEulerAnglesHint: {x: 0, y: 0, z: 0} --- !u!1 &1658847972 GameObject: m_ObjectHideFlags: 0 @@ -2622,8 +2701,7 @@ SceneRoots: - {fileID: 963194228} - {fileID: 705507995} - {fileID: 674567085} - - {fileID: 253946927} - {fileID: 2052906806} - - {fileID: 17322849} - {fileID: 1255004942} - {fileID: 564968303} + - {fileID: 1457077473} diff --git a/Assets/Scripts/Managers/InputManager.cs b/Assets/Scripts/Managers/InputManager.cs index fd059ab..258a9c8 100644 --- a/Assets/Scripts/Managers/InputManager.cs +++ b/Assets/Scripts/Managers/InputManager.cs @@ -17,19 +17,9 @@ public class InputManager : MonoBehaviour public Vector3 position; public Quaternion rotation; } - - public float autoplayCamSpeed = 2f; - public float xAutoRotateTime = 5f; - public float yAutoRotateTime = 5f; - private Coroutine autoplayRoutine; - public bool lockUserInput = false; - private float _yaw = 0.0f; - private float _pitch = 0.0f; - - private float reloadModifier; private void Awake() { @@ -92,13 +82,11 @@ public class InputManager : MonoBehaviour HandleMouseInput(); if (Input.GetKey(KeyCode.LeftShift)) { - reloadModifier = -.1f; - _cameraSpeed = _cameraSpeedMax; + CameraController.Instance.SetCameraSpeed(CameraController.Instance.GetCameraSpeedMax()); } else { - reloadModifier = .1f; - _cameraSpeed = _cameraSpeedNormal; + CameraController.Instance.SetCameraSpeed(CameraController.Instance.GetCameraSpeedNormal()); } // TRANSLATIONAL MOVEMENT @@ -152,15 +140,7 @@ public class InputManager : MonoBehaviour if (Input.GetKeyDown(KeyCode.P)) { - autoRotate = !autoRotate; - if (autoRotate) - { - autoplayRoutine = StartCoroutine(AutoPlayRoutine()); - } - else - { - StopCoroutine( autoplayRoutine ); - } + CameraController.Instance.SetAutoRotate(!CameraController.Instance.IsAutoRotate()); } if (Input.GetKeyDown(KeyCode.Alpha1)) diff --git a/Assets/Scripts/UI/CameraController.cs b/Assets/Scripts/UI/CameraController.cs index 059a82f..3784838 100644 --- a/Assets/Scripts/UI/CameraController.cs +++ b/Assets/Scripts/UI/CameraController.cs @@ -67,7 +67,7 @@ public class CameraController : MonoBehaviour /// /// Determines if the camera should auto-rotate. /// - public bool autoRotate = false; + public bool _autoRotate = false; /// /// Target transform for orbit rotation. @@ -239,6 +239,37 @@ public class CameraController : MonoBehaviour _yaw = rotation.eulerAngles.y; } + public void SetCameraSpeed(float speed) + { + _cameraSpeed = speed; + } + + public float GetCameraSpeedMax() + { + return _cameraSpeedMax; + } + + public float GetCameraSpeedNormal() + { + return _cameraSpeedNormal; + } + + public bool IsAutoRotate() + { + return _autoRotate; + } + + public void SetAutoRotate(bool autoRotate) + { + if (autoRotate && !_autoRotate) { + _autoRotate = true; + autoplayRoutine = StartCoroutine(AutoPlayRoutine()); + } else if (!autoRotate && _autoRotate) { + _autoRotate = false; + StopCoroutine(autoplayRoutine); + } + } + public static float ClampAngle(float angle, float min, float max) { if (angle < -360F) @@ -282,6 +313,7 @@ public class CameraController : MonoBehaviour _orbitY = angles.x; UpdateTargetAlpha(); + ResetCameraTarget(); } IEnumerator AutoPlayRoutine() @@ -410,31 +442,31 @@ public class CameraController : MonoBehaviour if(forwardToCameraAngle >-45f && forwardToCameraAngle <= 45f) { - wVector = Vector3.forward; - aVector = Vector3.left; - sVector = Vector3.back; - dVector = Vector3.right; + _translationInputToVectorMap[TranslationInput.Forward] = Vector3.forward; + _translationInputToVectorMap[TranslationInput.Left] = Vector3.left; + _translationInputToVectorMap[TranslationInput.Back] = Vector3.back; + _translationInputToVectorMap[TranslationInput.Right] = Vector3.right; } else if(forwardToCameraAngle > 45f && forwardToCameraAngle <= 135f) { - wVector = Vector3.left; - aVector = Vector3.back; - sVector = Vector3.right; - dVector = Vector3.forward; + _translationInputToVectorMap[TranslationInput.Forward] = Vector3.left; + _translationInputToVectorMap[TranslationInput.Left] = Vector3.back; + _translationInputToVectorMap[TranslationInput.Back] = Vector3.right; + _translationInputToVectorMap[TranslationInput.Right] = Vector3.forward; } else if(forwardToCameraAngle > 135f || forwardToCameraAngle <= -135f) { - wVector = Vector3.back; - aVector = Vector3.right; - sVector = Vector3.forward; - dVector = Vector3.left; + _translationInputToVectorMap[TranslationInput.Forward] = Vector3.back; + _translationInputToVectorMap[TranslationInput.Left] = Vector3.right; + _translationInputToVectorMap[TranslationInput.Back] = Vector3.forward; + _translationInputToVectorMap[TranslationInput.Right] = Vector3.left; } else if(forwardToCameraAngle > -135f && forwardToCameraAngle <= -45f) { - wVector = Vector3.right; - aVector = Vector3.forward; - sVector = Vector3.left; - dVector = Vector3.back; + _translationInputToVectorMap[TranslationInput.Forward] = Vector3.right; + _translationInputToVectorMap[TranslationInput.Left] = Vector3.forward; + _translationInputToVectorMap[TranslationInput.Back] = Vector3.left; + _translationInputToVectorMap[TranslationInput.Right] = Vector3.back; } } @@ -448,110 +480,10 @@ public class CameraController : MonoBehaviour Down } - - public void TranslateCamera(TranslationInput input) { UpdateDirectionVectors(); target.Translate(_translationInputToVectorMap[input] * Time.unscaledDeltaTime * _cameraSpeed); UpdateCamPosition(_orbitX, _orbitY); } - void HandleLockableInput() - { - - if (Input.GetKey(KeyCode.LeftShift)) - { - _cameraSpeed = _cameraSpeedMax; - } - else - { - _cameraSpeed = _cameraSpeedNormal; - } - - - } - - void HandleNonLockableInput() - { - if (Input.GetKeyDown(KeyCode.P)) - { - autoRotate = !autoRotate; - if (autoRotate) - { - autoplayRoutine = StartCoroutine(AutoPlayRoutine()); - } - else - { - StopCoroutine( autoplayRoutine ); - } - } - - if (Input.GetKeyDown(KeyCode.Alpha1)) - { - // ORIGIN - transform.position = new Vector3(0, 20, -20); - SetCameraRotation(Quaternion.Euler(24f, -0.5f, 0)); - Camera.main.fieldOfView = 45f; - ResetCameraTarget(); - } - - if (Input.GetKeyDown(KeyCode.Alpha2)) - { - transform.position = new Vector3(0, 30, -20); - SetCameraRotation(Quaternion.Euler(36.6f, -0.5f, 0)); - Camera.main.fieldOfView = 60f; - ResetCameraTarget(); - - } - - - if (Input.GetKeyDown(KeyCode.Alpha4)) - { - if (Input.GetKey(KeyCode.LeftShift)) - { - fourPos.position = transform.position; - fourPos.rotation = transform.rotation; - } - else - { - transform.position = fourPos.position; - SetCameraRotation(fourPos.rotation); - ResetCameraTarget(); - } - - } - - if (Input.GetKeyDown(KeyCode.Alpha5)) - { - if (Input.GetKey(KeyCode.LeftShift)) - { - fivePos.position = transform.position; - fivePos.rotation = transform.rotation; - } - else - { - transform.position = fivePos.position; - SetCameraRotation(fivePos.rotation); - ResetCameraTarget(); - } - } - - if (Input.GetKeyDown(KeyCode.Alpha6)) - { - if (Input.GetKey(KeyCode.LeftShift)) - { - sixPos.position = transform.position; - sixPos.rotation = transform.rotation; - } - else - { - transform.position = sixPos.position; - SetCameraRotation(sixPos.rotation); - ResetCameraTarget(); - } - } - - - } - } diff --git a/ProjectSettings/TagManager.asset b/ProjectSettings/TagManager.asset index 1c92a78..b0e9a0a 100644 --- a/ProjectSettings/TagManager.asset +++ b/ProjectSettings/TagManager.asset @@ -11,7 +11,7 @@ TagManager: - - Water - UI - - + - Floor - - -