public static float GetPitchAngle(CameraData cameraData, BezierPosition bezierPosition) { float f = bezierPosition.elevationAngle - 0.1745329f; if (f < 0f) { f = 0f; } float collisionDistanceRatio = cameraData.collisionDistanceRatio; if ((collisionDistanceRatio >= 1f) || ((f < 0.08726647f) || !cameraData.pitchCorrectionEnabled)) { return(-f); } float num3 = bezierPosition.GetDistanceToPivot() * Mathf.Sin(f); return(-Mathf.Atan2(collisionDistanceRatio * num3, (1f * num3) * ((1f / Mathf.Tan(f)) - ((1f - collisionDistanceRatio) / Mathf.Tan(bezierPosition.elevationAngle))))); }
public static Vector3 CalculateCameraPosition(Transform target, BaseRendererComponent tankRendererComponent, Vector3 tankBoundsCenter, BezierPosition bezierPosition, CameraData cameraData, Vector3 cameraOffset, float additionalAngle) { GameObject gameObject = target.gameObject; Vector3 position = target.position; Vector3 localPosition = target.parent.localPosition; float z = tankRendererComponent.Mesh.bounds.extents.z; float num3 = z * Mathf.Max((float)0f, (float)((z - 1.2f) / 1.981962f)); if (target.parent != null) { Vector3 vector4 = target.parent.InverseTransformPoint(tankBoundsCenter); num3 -= vector4.z - localPosition.z; } Vector3 vector5 = new Vector3(0f, 0f, -num3); Quaternion quaternion = Quaternion.Euler(target.rotation.eulerAngles + new Vector3(0f, additionalAngle, 0f)); Vector3 vector6 = (Vector3)(quaternion * (vector5 - new Vector3(0f, 0f, localPosition.z))); Vector3 targetPosition = (position + (quaternion * (localPosition + cameraOffset))) + (Vector3.up * 0.2f); bool hasCollision = false; bool flag2 = false; Vector3 vector11 = CalculateCollisionPoint(targetPosition, CalculateCameraDirection(bezierPosition.GetCameraHeight() / bezierPosition.GetCameraHorizontalDistance(), (Vector3)(Quaternion.Euler(new Vector3(0f, additionalAngle, 0f)) * target.forward)), bezierPosition.GetDistanceToPivot(), gameObject, out hasCollision); float magnitude = (targetPosition - vector11).magnitude; cameraData.collisionDistanceRatio = magnitude / bezierPosition.GetDistanceToPivot(); if (magnitude < 3f) { float rayLength = 3f - magnitude; vector11 = CalculateCollisionPoint(vector11, -Vector3.up, rayLength, gameObject, out flag2); } else { RaycastHit hit; int layerMask = LayerMasksUtils.RemoveLayerFromMask(LayerMasks.STATIC, gameObject.layer); Vector3 normalized = vector6.normalized; vector11 = !Physics.Raycast(vector11, normalized, out hit, vector6.magnitude, layerMask) ? (vector11 + vector6) : (vector11 + (Mathf.Max((float)(hit.distance - 0.5f), (float)0f) * normalized)); } return(vector11); }