117 lines
		
	
	
		
			4.3 KiB
		
	
	
	
		
			C#
		
	
	
	
	
	
			
		
		
	
	
			117 lines
		
	
	
		
			4.3 KiB
		
	
	
	
		
			C#
		
	
	
	
	
	
| using UnityEngine;
 | |
| 
 | |
| namespace MenteBacata.ScivoloCharacterController.Internal
 | |
| {
 | |
|     public static class GizmosUtility
 | |
|     {
 | |
|         public readonly static Color defaultColliderColor = new Color(0.568f, 0.956f, 0.545f, 0.752f);
 | |
| 
 | |
|         public static void DrawCircle(Vector3 center, Vector3 normal, float radius, int resolution = 9)
 | |
|         {
 | |
|             Vector3 forwardRadius = Vector3.Slerp(normal, -normal, .5f);
 | |
|             Vector3 rightRadius = Vector3.Cross(normal, forwardRadius);
 | |
| 
 | |
|             forwardRadius *= radius;
 | |
|             rightRadius *= radius;
 | |
| 
 | |
|             float a = 0f;
 | |
|             float da = Mathf.PI / (2f * resolution);
 | |
|             float cosa = 1f;
 | |
|             float sena = 0f;
 | |
| 
 | |
|             Vector3 p1 = center + cosa * forwardRadius + sena * rightRadius;
 | |
|             Vector3 p2 = center - cosa * forwardRadius + sena * rightRadius;
 | |
|             Vector3 p3 = center + cosa * forwardRadius - sena * rightRadius;
 | |
|             Vector3 p4 = center - cosa * forwardRadius - sena * rightRadius;
 | |
| 
 | |
|             for (int i = 0; i < resolution; i++)
 | |
|             {
 | |
|                 a += da;
 | |
|                 cosa = Mathf.Cos(a);
 | |
|                 sena = Mathf.Sin(a);
 | |
| 
 | |
|                 Vector3 q1 = center + cosa * forwardRadius + sena * rightRadius;
 | |
|                 Vector3 q2 = center - cosa * forwardRadius + sena * rightRadius;
 | |
|                 Vector3 q3 = center + cosa * forwardRadius - sena * rightRadius;
 | |
|                 Vector3 q4 = center - cosa * forwardRadius - sena * rightRadius;
 | |
| 
 | |
|                 Gizmos.DrawLine(p1, q1);
 | |
|                 Gizmos.DrawLine(p2, q2);
 | |
|                 Gizmos.DrawLine(p3, q3);
 | |
|                 Gizmos.DrawLine(p4, q4);
 | |
| 
 | |
|                 p1 = q1; p2 = q2; p3 = q3; p4 = q4;
 | |
|             }
 | |
|         }
 | |
| 
 | |
|         public static void DrawWireCapsule(Vector3 lowerCenter, Vector3 upperCenter, float radius, int resolution = 9)
 | |
|         {
 | |
|             int iterations = 4 * resolution;
 | |
| 
 | |
|             Vector3 upDirection = (upperCenter - lowerCenter).normalized;
 | |
| 
 | |
|             if (upDirection.magnitude == 0f)
 | |
|                 upDirection = Vector3.up;
 | |
| 
 | |
|             Quaternion rot = Quaternion.FromToRotation(Vector3.up, upDirection);
 | |
|             Vector3 upRadius = radius * upDirection;
 | |
|             Vector3 rightRadius = radius * (rot * Vector3.right);
 | |
|             Vector3 forwardRadius = radius * (rot * Vector3.forward);
 | |
| 
 | |
|             float a = 0f;
 | |
|             float cosa = Mathf.Cos(a);
 | |
|             float sena = Mathf.Sin(a);
 | |
|             float deltaA = 2f * Mathf.PI / iterations;
 | |
|             
 | |
|             Vector3 vRF = cosa * rightRadius + sena * forwardRadius;
 | |
|             Vector3 vRU = cosa * rightRadius + sena * upRadius;
 | |
|             Vector3 vFU = cosa * forwardRadius + sena * upRadius;
 | |
| 
 | |
|             for (int i = 0; i < iterations; i++)
 | |
|             {
 | |
|                 // Every quarter of iterations.
 | |
|                 if (4 * i % iterations == 0)
 | |
|                     Gizmos.DrawLine(upperCenter + vRF, lowerCenter + vRF);
 | |
|                 
 | |
|                 a += deltaA;
 | |
|                 cosa = Mathf.Cos(a);
 | |
|                 sena = Mathf.Sin(a);
 | |
| 
 | |
|                 Vector3 uRF = cosa * rightRadius + sena * forwardRadius;
 | |
|                 Vector3 uRU = cosa * rightRadius + sena * upRadius;
 | |
|                 Vector3 uFU = cosa * forwardRadius + sena * upRadius;
 | |
| 
 | |
|                 Gizmos.DrawLine(lowerCenter + vRF, lowerCenter + uRF);
 | |
|                 Gizmos.DrawLine(upperCenter + vRF, upperCenter + uRF);
 | |
| 
 | |
|                 if (2 * i < iterations)
 | |
|                 {
 | |
|                     Gizmos.DrawLine(upperCenter + vRU, upperCenter + uRU);
 | |
|                     Gizmos.DrawLine(upperCenter + vFU, upperCenter + uFU);
 | |
|                 }
 | |
|                 else
 | |
|                 {
 | |
|                     Gizmos.DrawLine(lowerCenter + vRU, lowerCenter + uRU);
 | |
|                     Gizmos.DrawLine(lowerCenter + vFU, lowerCenter + uFU);
 | |
|                 }
 | |
| 
 | |
|                 vRF = uRF;
 | |
|                 vRU = uRU;
 | |
|                 vFU = uFU;
 | |
|             }
 | |
|         }
 | |
| 
 | |
|         public static void DrawGrid(Vector3 center, Vector3 sideA, Vector3 sideB, int subdivisions = 1)
 | |
|         {
 | |
|             Vector3 o = center - 0.5f * (sideB + sideA);
 | |
|             float subdInv = 1f / subdivisions;
 | |
| 
 | |
|             for (int i = 0; i < subdivisions + 1; i++)
 | |
|             {
 | |
|                 Gizmos.DrawRay(o + i * subdInv * sideB, sideA);
 | |
|                 Gizmos.DrawRay(o + i * subdInv * sideA, sideB);
 | |
|             }
 | |
|         }
 | |
|     } 
 | |
| }
 | 
