summaryrefslogtreecommitdiff
path: root/Assets/ThirdParty/MaterializeFX/MaterializationFX/Scripts/Utils/MouseOrbitController.cs
diff options
context:
space:
mode:
authorchai <chaifix@163.com>2020-10-23 13:08:43 +0800
committerchai <chaifix@163.com>2020-10-23 13:08:43 +0800
commitb82da95b5181ac8bbae38efb13e950d5e88a4caa (patch)
tree48a6f3269276484bbc7cfc95f0651f40a2176aa1 /Assets/ThirdParty/MaterializeFX/MaterializationFX/Scripts/Utils/MouseOrbitController.cs
parent917e9e0b320775634dc2e710f7deac74fd0822f0 (diff)
*移动amplify shader editor到third party目录
Diffstat (limited to 'Assets/ThirdParty/MaterializeFX/MaterializationFX/Scripts/Utils/MouseOrbitController.cs')
-rw-r--r--Assets/ThirdParty/MaterializeFX/MaterializationFX/Scripts/Utils/MouseOrbitController.cs58
1 files changed, 58 insertions, 0 deletions
diff --git a/Assets/ThirdParty/MaterializeFX/MaterializationFX/Scripts/Utils/MouseOrbitController.cs b/Assets/ThirdParty/MaterializeFX/MaterializationFX/Scripts/Utils/MouseOrbitController.cs
new file mode 100644
index 00000000..052f76c3
--- /dev/null
+++ b/Assets/ThirdParty/MaterializeFX/MaterializationFX/Scripts/Utils/MouseOrbitController.cs
@@ -0,0 +1,58 @@
+using UnityEngine;
+
+namespace MaterializationFX.Scripts.Utils
+{
+ internal sealed class MouseOrbitController : MonoBehaviour
+ {
+ public Transform Target;
+ public float Distance = 5.0f;
+ public float XSpeed = 120.0f;
+ public float YSpeed = 120.0f;
+
+ public float YMinLimit = 20f;
+ public float YMaxLimit = 80f;
+
+ public float DistanceMin = .5f;
+ public float DistanceMax = 15f;
+
+ private float _x;
+ private float _y;
+
+ private void Start()
+ {
+ var angles = transform.eulerAngles;
+ _x = angles.y;
+ _y = angles.x;
+ }
+
+ private void LateUpdate()
+ {
+ if (!Input.GetMouseButton(0))
+ return;
+
+ _x += Input.GetAxis("Mouse X") * XSpeed * Distance * 0.02f;
+ _y -= Input.GetAxis("Mouse Y") * YSpeed * 0.02f;
+
+ _y = ClampAngle(_y, YMinLimit, YMaxLimit);
+
+ var rotation = Quaternion.Euler(_y, _x, 0);
+
+ Distance -= Input.GetAxis("Mouse ScrollWheel") * 5;
+
+ var negDistance = new Vector3(0.0f, 0.0f, -Distance);
+ var position = rotation * negDistance + Target.position;
+
+ transform.rotation = rotation;
+ transform.position = position;
+ }
+
+ private static float ClampAngle(float angle, float min, float max)
+ {
+ if (angle < -360F)
+ angle += 360F;
+ if (angle > 360F)
+ angle -= 360F;
+ return Mathf.Clamp(angle, min, max);
+ }
+ }
+}