123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117 |
- using UnityEngine;
- using System.Collections;
- public class CameraView
- {
-
- public float upperDistance = 8.5f;
-
- public float lowerDistance = 12.0f;
- private Transform tx;
- void Start()
- {
- }
- void Update()
- {
-
-
- }
- public static Vector3 PosChange(float a, float b,float dic,Transform cam)
- {
- Vector3[] v3List = GetCorners(dic, cam);
- Vector3 posX = Vector3.zero;
- float juli = Vector3.Distance(v3List[1],v3List[0]);
- Vector3 vector = (v3List[1] - v3List[0]).normalized;
- float rand = juli*a;
- posX = vector * rand;
- posX += v3List[0];
- Vector3[] v3ListY = GetCorners(1f, cam);
- Vector3 posY = Vector3.zero;
- float juliY = Vector3.Distance(v3List[2], v3List[0]);
- Vector3 vectorY = (v3List[0] - v3List[2]).normalized;
- float randY = b * juliY;
- posY = vectorY * randY;
- posY += v3List[2];
- Vector3[] v3ListZ = GetCorners(1.5f, cam);
- Vector3 posZ = Vector3.zero;
- float juliZ = Vector3.Distance(v3List[2], v3List[0]);
- Vector3 vectorZ = (v3List[0] - v3List[2]).normalized;
- float randZ = b * juliZ;
- posZ = vectorZ * randZ;
- posZ += v3List[2];
- return cam.TransformPoint(new Vector3(posX.x, posY.y, posZ.z));
- }
- void FindUpperCorners()
- {
-
-
-
-
-
-
- }
- void FindLowerCorners()
- {
-
-
-
-
-
-
- }
- public static Vector3[] GetCorners(float distance,Transform cam)
- {
- Vector3[] corners = new Vector3[4];
- Debug.Log(" DGJ ===> "+GHZRTCCamera.Instance.cam.name);
- float halfFOV = (GHZRTCCamera.Instance.cam.fieldOfView * 0.5f) * Mathf.Deg2Rad;
- float aspect = GHZRTCCamera.Instance.cam.aspect;
- float height = distance * Mathf.Tan(halfFOV);
- float width = height * aspect;
-
- corners[0] = GHZRTCCamera.Instance.cam.transform.position - (GHZRTCCamera.Instance.cam.transform.right * width);
- corners[0] += GHZRTCCamera.Instance.cam.transform.up * height;
- corners[0] += GHZRTCCamera.Instance.cam.transform.forward * distance;
- corners[0] = cam.InverseTransformPoint(corners[0]);
-
- corners[1] = GHZRTCCamera.Instance.cam.transform.position + (GHZRTCCamera.Instance.cam.transform.right * width);
- corners[1] += GHZRTCCamera.Instance.cam.transform.up * height;
- corners[1] += GHZRTCCamera.Instance.cam.transform.forward * distance;
- corners[1] = cam.InverseTransformPoint(corners[1]);
-
- corners[2] = GHZRTCCamera.Instance.cam.transform.position - (GHZRTCCamera.Instance.cam.transform.right * width);
- corners[2] -= GHZRTCCamera.Instance.cam.transform.up * height;
- corners[2] += GHZRTCCamera.Instance.cam.transform.forward * distance;
- corners[2] = cam.InverseTransformPoint(corners[2]);
-
- corners[3] = GHZRTCCamera.Instance.cam.transform.position + (GHZRTCCamera.Instance.cam.transform.right * width);
- corners[3] -= GHZRTCCamera.Instance.cam.transform.up * height;
- corners[3] += GHZRTCCamera.Instance.cam.transform.forward * distance;
- corners[3] = cam.InverseTransformPoint(corners[3]);
- return corners;
- }
- }
|