Sinonomple Camera Controller
Sinonomple Camera Controller
#define USE_INPUT_SYSTEM
using [Link];
using [Link];
#endif
using UnityEngine;
namespace UnityTemplateProjects
{
public class SimpleCameraController : MonoBehaviour
{
class CameraState
{
public float yaw;
public float pitch;
public float roll;
public float x;
public float y;
public float z;
x += rotatedTranslation.x;
y += rotatedTranslation.y;
z += rotatedTranslation.z;
}
[Header("Movement Settings")]
[Tooltip("Exponential boost factor on translation, controllable by mouse
wheel.")]
public float boost = 3.5f;
[Header("Rotation Settings")]
[Tooltip("X = Change in mouse position.\nY = Multiplicative factor for
camera rotation.")]
public AnimationCurve mouseSensitivityCurve = new AnimationCurve(new
Keyframe(0f, 0.5f, 0f, 5f), new Keyframe(1f, 2.5f, 0f, 0f));
void OnEnable()
{
m_TargetCameraState.SetFromTransform(transform);
m_InterpolatingCameraState.SetFromTransform(transform);
}
Vector3 GetInputTranslationDirection()
{
Vector3 direction = new Vector3();
if ([Link](KeyCode.W))
{
direction += [Link];
}
if ([Link](KeyCode.S))
{
direction += [Link];
}
if ([Link](KeyCode.A))
{
direction += [Link];
}
if ([Link](KeyCode.D))
{
direction += [Link];
}
if ([Link](KeyCode.Q))
{
direction += [Link];
}
if ([Link](KeyCode.E))
{
direction += [Link];
}
return direction;
}
void Update()
{
Vector3 translation = [Link];
#if ENABLE_LEGACY_INPUT_MANAGER
// Exit Sample
if ([Link]([Link]))
{
[Link]();
#if UNITY_EDITOR
[Link] = false;
#endif
}
// Hide and lock cursor when right mouse button pressed
if ([Link](1))
{
[Link] = [Link];
}
// Rotation
if ([Link](1))
{
var mouseMovement = new Vector2([Link]("Mouse X"),
[Link]("Mouse Y") * (invertY ? 1 : -1));
var mouseSensitivityFactor =
[Link]([Link]);
m_TargetCameraState.yaw += mouseMovement.x *
mouseSensitivityFactor;
m_TargetCameraState.pitch += mouseMovement.y *
mouseSensitivityFactor;
}
// Translation
translation = GetInputTranslationDirection() * [Link];
m_TargetCameraState.Translate(translation);
// Framerate-independent interpolation
// Calculate the lerp amount, such that we get 99% of the way to our
target in the specified time
var positionLerpPct = 1f - [Link](([Link](1f - 0.99f) /
positionLerpTime) * [Link]);
var rotationLerpPct = 1f - [Link](([Link](1f - 0.99f) /
rotationLerpTime) * [Link]);
m_InterpolatingCameraState.LerpTowards(m_TargetCameraState,
positionLerpPct, rotationLerpPct);
m_InterpolatingCameraState.UpdateTransform(transform);
}
}
using UnityEngine;
namespace UnityTemplateProjects
{
public class SimpleCameraController : MonoBehaviour
{
class CameraState
{
public float yaw;
public float pitch;
public float roll;
public float x;
public float y;
public float z;
x += rotatedTranslation.x;
y += rotatedTranslation.y;
z += rotatedTranslation.z;
}
[Header("Movement Settings")]
[Tooltip("Exponential boost factor on translation, controllable by mouse
wheel.")]
public float boost = 3.5f;
[Header("Rotation Settings")]
[Tooltip("X = Change in mouse position.\nY = Multiplicative factor for
camera rotation.")]
public AnimationCurve mouseSensitivityCurve = new AnimationCurve(new
Keyframe(0f, 0.5f, 0f, 5f), new Keyframe(1f, 2.5f, 0f, 0f));
void OnEnable()
{
m_TargetCameraState.SetFromTransform(transform);
m_InterpolatingCameraState.SetFromTransform(transform);
}
Vector3 GetInputTranslationDirection()
{
Vector3 direction = new Vector3();
if ([Link](KeyCode.W))
{
direction += [Link];
}
if ([Link](KeyCode.S))
{
direction += [Link];
}
if ([Link](KeyCode.A))
{
direction += [Link];
}
if ([Link](KeyCode.D))
{
direction += [Link];
}
if ([Link](KeyCode.Q))
{
direction += [Link];
}
if ([Link](KeyCode.E))
{
direction += [Link];
}
return direction;
}
void Update()
{
Vector3 translation = [Link];
#if ENABLE_LEGACY_INPUT_MANAGER
// Exit Sample
if ([Link]([Link]))
{
[Link]();
#if UNITY_EDITOR
[Link] = false;
#endif
}
// Hide and lock cursor when right mouse button pressed
if ([Link](1))
{
[Link] = [Link];
}
// Rotation
if ([Link](1))
{
var mouseMovement = new Vector2([Link]("Mouse X"),
[Link]("Mouse Y") * (invertY ? 1 : -1));
var mouseSensitivityFactor =
[Link]([Link]);
m_TargetCameraState.yaw += mouseMovement.x *
mouseSensitivityFactor;
m_TargetCameraState.pitch += mouseMovement.y *
mouseSensitivityFactor;
}
// Translation
translation = GetInputTranslationDirection() * [Link];
#elif USE_INPUT_SYSTEM
// TODO: make the new input system work
#endif
m_TargetCameraState.Translate(translation);
// Framerate-independent interpolation
// Calculate the lerp amount, such that we get 99% of the way to our
target in the specified time
var positionLerpPct = 1f - [Link](([Link](1f - 0.99f) /
positionLerpTime) * [Link]);
var rotationLerpPct = 1f - [Link](([Link](1f - 0.99f) /
rotationLerpTime) * [Link]);
m_InterpolatingCameraState.LerpTowards(m_TargetCameraState,
positionLerpPct, rotationLerpPct);
m_InterpolatingCameraState.UpdateTransform(transform);
}
}
using UnityEngine;
namespace UnityTemplateProjects
{
public class SimpleCameraController : MonoBehaviour
{
class CameraState
{
public float yaw;
public float pitch;
public float roll;
public float x;
public float y;
public float z;
x += rotatedTranslation.x;
y += rotatedTranslation.y;
z += rotatedTranslation.z;
}
[Header("Movement Settings")]
[Tooltip("Exponential boost factor on translation, controllable by mouse
wheel.")]
public float boost = 3.5f;
[Header("Rotation Settings")]
[Tooltip("X = Change in mouse position.\nY = Multiplicative factor for
camera rotation.")]
public AnimationCurve mouseSensitivityCurve = new AnimationCurve(new
Keyframe(0f, 0.5f, 0f, 5f), new Keyframe(1f, 2.5f, 0f, 0f));
void OnEnable()
{
m_TargetCameraState.SetFromTransform(transform);
m_InterpolatingCameraState.SetFromTransform(transform);
}
Vector3 GetInputTranslationDirection()
{
Vector3 direction = new Vector3();
if ([Link](KeyCode.W))
{
direction += [Link];
}
if ([Link](KeyCode.S))
{
direction += [Link];
}
if ([Link](KeyCode.A))
{
direction += [Link];
}
if ([Link](KeyCode.D))
{
direction += [Link];
}
if ([Link](KeyCode.Q))
{
direction += [Link];
}
if ([Link](KeyCode.E))
{
direction += [Link];
}
return direction;
}
void Update()
{
Vector3 translation = [Link];
#if ENABLE_LEGACY_INPUT_MANAGER
// Exit Sample
if ([Link]([Link]))
{
[Link]();
#if UNITY_EDITOR
[Link] = false;
#endif
}
// Hide and lock cursor when right mouse button pressed
if ([Link](1))
{
[Link] = [Link];
}
// Rotation
if ([Link](1))
{
var mouseMovement = new Vector2([Link]("Mouse X"),
[Link]("Mouse Y") * (invertY ? 1 : -1));
var mouseSensitivityFactor =
[Link]([Link]);
m_TargetCameraState.yaw += mouseMovement.x *
mouseSensitivityFactor;
m_TargetCameraState.pitch += mouseMovement.y *
mouseSensitivityFactor;
}
// Translation
translation = GetInputTranslationDirection() * [Link];
#elif USE_INPUT_SYSTEM
// TODO: make the new input system work
#endif
m_TargetCameraState.Translate(translation);
// Framerate-independent interpolation
// Calculate the lerp amount, such that we get 99% of the way to our
target in the specified time
var positionLerpPct = 1f - [Link](([Link](1f - 0.99f) /
positionLerpTime) * [Link]);
var rotationLerpPct = 1f - [Link](([Link](1f - 0.99f) /
rotationLerpTime) * [Link]);
m_InterpolatingCameraState.LerpTowards(m_TargetCameraState,
positionLerpPct, rotationLerpPct);
m_InterpolatingCameraState.UpdateTransform(transform);
}
}
using UnityEngine;
namespace UnityTemplateProjects
{
public class SimpleCameraController : MonoBehaviour
{
class CameraState
{
public float yaw;
public float pitch;
public float roll;
public float x;
public float y;
public float z;
x += rotatedTranslation.x;
y += rotatedTranslation.y;
z += rotatedTranslation.z;
}
[Header("Movement Settings")]
[Tooltip("Exponential boost factor on translation, controllable by mouse
wheel.")]
public float boost = 3.5f;
[Header("Rotation Settings")]
[Tooltip("X = Change in mouse position.\nY = Multiplicative factor for
camera rotation.")]
public AnimationCurve mouseSensitivityCurve = new AnimationCurve(new
Keyframe(0f, 0.5f, 0f, 5f), new Keyframe(1f, 2.5f, 0f, 0f));
void OnEnable()
{
m_TargetCameraState.SetFromTransform(transform);
m_InterpolatingCameraState.SetFromTransform(transform);
}
Vector3 GetInputTranslationDirection()
{
Vector3 direction = new Vector3();
if ([Link](KeyCode.W))
{
direction += [Link];
}
if ([Link](KeyCode.S))
{
direction += [Link];
}
if ([Link](KeyCode.A))
{
direction += [Link];
}
if ([Link](KeyCode.D))
{
direction += [Link];
}
if ([Link](KeyCode.Q))
{
direction += [Link];
}
if ([Link](KeyCode.E))
{
direction += [Link];
}
return direction;
}
void Update()
{
Vector3 translation = [Link];
#if ENABLE_LEGACY_INPUT_MANAGER
// Exit Sample
if ([Link]([Link]))
{
[Link]();
#if UNITY_EDITOR
[Link] = false;
#endif
}
// Hide and lock cursor when right mouse button pressed
if ([Link](1))
{
[Link] = [Link];
}
// Rotation
if ([Link](1))
{
var mouseMovement = new Vector2([Link]("Mouse X"),
[Link]("Mouse Y") * (invertY ? 1 : -1));
var mouseSensitivityFactor =
[Link]([Link]);
m_TargetCameraState.yaw += mouseMovement.x *
mouseSensitivityFactor;
m_TargetCameraState.pitch += mouseMovement.y *
mouseSensitivityFactor;
}
// Translation
translation = GetInputTranslationDirection() * [Link];
#elif USE_INPUT_SYSTEM
// TODO: make the new input system work
#endif
m_TargetCameraState.Translate(translation);
// Framerate-independent interpolation
// Calculate the lerp amount, such that we get 99% of the way to our
target in the specified time
var positionLerpPct = 1f - [Link](([Link](1f - 0.99f) /
positionLerpTime) * [Link]);
var rotationLerpPct = 1f - [Link](([Link](1f - 0.99f) /
rotationLerpTime) * [Link]);
m_InterpolatingCameraState.LerpTowards(m_TargetCameraState,
positionLerpPct, rotationLerpPct);
m_InterpolatingCameraState.UpdateTransform(transform);
}
}
using UnityEngine;
namespace UnityTemplateProjects
{
public class SimpleCameraController : MonoBehaviour
{
class CameraState
{
public float yaw;
public float pitch;
public float roll;
public float x;
public float y;
public float z;
x += rotatedTranslation.x;
y += rotatedTranslation.y;
z += rotatedTranslation.z;
}
[Header("Movement Settings")]
[Tooltip("Exponential boost factor on translation, controllable by mouse
wheel.")]
public float boost = 3.5f;
[Header("Rotation Settings")]
[Tooltip("X = Change in mouse position.\nY = Multiplicative factor for
camera rotation.")]
public AnimationCurve mouseSensitivityCurve = new AnimationCurve(new
Keyframe(0f, 0.5f, 0f, 5f), new Keyframe(1f, 2.5f, 0f, 0f));
void OnEnable()
{
m_TargetCameraState.SetFromTransform(transform);
m_InterpolatingCameraState.SetFromTransform(transform);
}
Vector3 GetInputTranslationDirection()
{
Vector3 direction = new Vector3();
if ([Link](KeyCode.W))
{
direction += [Link];
}
if ([Link](KeyCode.S))
{
direction += [Link];
}
if ([Link](KeyCode.A))
{
direction += [Link];
}
if ([Link](KeyCode.D))
{
direction += [Link];
}
if ([Link](KeyCode.Q))
{
direction += [Link];
}
if ([Link](KeyCode.E))
{
direction += [Link];
}
return direction;
}
void Update()
{
Vector3 translation = [Link];
#if ENABLE_LEGACY_INPUT_MANAGER
// Exit Sample
if ([Link]([Link]))
{
[Link]();
#if UNITY_EDITOR
[Link] = false;
#endif
}
// Hide and lock cursor when right mouse button pressed
if ([Link](1))
{
[Link] = [Link];
}
// Rotation
if ([Link](1))
{
var mouseMovement = new Vector2([Link]("Mouse X"),
[Link]("Mouse Y") * (invertY ? 1 : -1));
var mouseSensitivityFactor =
[Link]([Link]);
m_TargetCameraState.yaw += mouseMovement.x *
mouseSensitivityFactor;
m_TargetCameraState.pitch += mouseMovement.y *
mouseSensitivityFactor;
}
// Translation
translation = GetInputTranslationDirection() * [Link];
#elif USE_INPUT_SYSTEM
// TODO: make the new input system work
#endif
m_TargetCameraState.Translate(translation);
// Framerate-independent interpolation
// Calculate the lerp amount, such that we get 99% of the way to our
target in the specified time
var positionLerpPct = 1f - [Link](([Link](1f - 0.99f) /
positionLerpTime) * [Link]);
var rotationLerpPct = 1f - [Link](([Link](1f - 0.99f) /
rotationLerpTime) * [Link]);
m_InterpolatingCameraState.LerpTowards(m_TargetCameraState,
positionLerpPct, rotationLerpPct);
m_InterpolatingCameraState.UpdateTransform(transform);
}
}
using UnityEngine;
namespace UnityTemplateProjects
{
public class SimpleCameraController : MonoBehaviour
{
class CameraState
{
public float yaw;
public float pitch;
public float roll;
public float x;
public float y;
public float z;
x += rotatedTranslation.x;
y += rotatedTranslation.y;
z += rotatedTranslation.z;
}
[Header("Movement Settings")]
[Tooltip("Exponential boost factor on translation, controllable by mouse
wheel.")]
public float boost = 3.5f;
void OnEnable()
{
m_TargetCameraState.SetFromTransform(transform);
m_InterpolatingCameraState.SetFromTransform(transform);
}
Vector3 GetInputTranslationDirection()
{
Vector3 direction = new Vector3();
if ([Link](KeyCode.W))
{
direction += [Link];
}
if ([Link](KeyCode.S))
{
direction += [Link];
}
if ([Link](KeyCode.A))
{
direction += [Link];
}
if ([Link](KeyCode.D))
{
direction += [Link];
}
if ([Link](KeyCode.Q))
{
direction += [Link];
}
if ([Link](KeyCode.E))
{
direction += [Link];
}
return direction;
}
void Update()
{
Vector3 translation = [Link];
#if ENABLE_LEGACY_INPUT_MANAGER
// Exit Sample
if ([Link]([Link]))
{
[Link]();
#if UNITY_EDITOR
[Link] = false;
#endif
}
// Hide and lock cursor when right mouse button pressed
if ([Link](1))
{
[Link] = [Link];
}
// Rotation
if ([Link](1))
{
var mouseMovement = new Vector2([Link]("Mouse X"),
[Link]("Mouse Y") * (invertY ? 1 : -1));
var mouseSensitivityFactor =
[Link]([Link]);
m_TargetCameraState.yaw += mouseMovement.x *
mouseSensitivityFactor;
m_TargetCameraState.pitch += mouseMovement.y *
mouseSensitivityFactor;
}
// Translation
translation = GetInputTranslationDirection() * [Link];
#elif USE_INPUT_SYSTEM
// TODO: make the new input system work
#endif
m_TargetCameraState.Translate(translation);
// Framerate-independent interpolation
// Calculate the lerp amount, such that we get 99% of the way to our
target in the specified time
var positionLerpPct = 1f - [Link](([Link](1f - 0.99f) /
positionLerpTime) * [Link]);
var rotationLerpPct = 1f - [Link](([Link](1f - 0.99f) /
rotationLerpTime) * [Link]);
m_InterpolatingCameraState.LerpTowards(m_TargetCameraState,
positionLerpPct, rotationLerpPct);
m_InterpolatingCameraState.UpdateTransform(transform);
}
}
using UnityEngine;
namespace UnityTemplateProjects
{
public class SimpleCameraController : MonoBehaviour
{
class CameraState
{
public float yaw;
public float pitch;
public float roll;
public float x;
public float y;
public float z;
x += rotatedTranslation.x;
y += rotatedTranslation.y;
z += rotatedTranslation.z;
}
[Header("Movement Settings")]
[Tooltip("Exponential boost factor on translation, controllable by mouse
wheel.")]
public float boost = 3.5f;
[Header("Rotation Settings")]
[Tooltip("X = Change in mouse position.\nY = Multiplicative factor for
camera rotation.")]
public AnimationCurve mouseSensitivityCurve = new AnimationCurve(new
Keyframe(0f, 0.5f, 0f, 5f), new Keyframe(1f, 2.5f, 0f, 0f));
void OnEnable()
{
m_TargetCameraState.SetFromTransform(transform);
m_InterpolatingCameraState.SetFromTransform(transform);
}
Vector3 GetInputTranslationDirection()
{
Vector3 direction = new Vector3();
if ([Link](KeyCode.W))
{
direction += [Link];
}
if ([Link](KeyCode.S))
{
direction += [Link];
}
if ([Link](KeyCode.A))
{
direction += [Link];
}
if ([Link](KeyCode.D))
{
direction += [Link];
}
if ([Link](KeyCode.Q))
{
direction += [Link];
}
if ([Link](KeyCode.E))
{
direction += [Link];
}
return direction;
}
void Update()
{
Vector3 translation = [Link];
#if ENABLE_LEGACY_INPUT_MANAGER
// Exit Sample
if ([Link]([Link]))
{
[Link]();
#if UNITY_EDITOR
[Link] = false;
#endif
}
// Hide and lock cursor when right mouse button pressed
if ([Link](1))
{
[Link] = [Link];
}
// Rotation
if ([Link](1))
{
var mouseMovement = new Vector2([Link]("Mouse X"),
[Link]("Mouse Y") * (invertY ? 1 : -1));
var mouseSensitivityFactor =
[Link]([Link]);
m_TargetCameraState.yaw += mouseMovement.x *
mouseSensitivityFactor;
m_TargetCameraState.pitch += mouseMovement.y *
mouseSensitivityFactor;
}
// Translation
translation = GetInputTranslationDirection() * [Link];
#elif USE_INPUT_SYSTEM
// TODO: make the new input system work
#endif
m_TargetCameraState.Translate(translation);
// Framerate-independent interpolation
// Calculate the lerp amount, such that we get 99% of the way to our
target in the specified time
var positionLerpPct = 1f - [Link](([Link](1f - 0.99f) /
positionLerpTime) * [Link]);
var rotationLerpPct = 1f - [Link](([Link](1f - 0.99f) /
rotationLerpTime) * [Link]);
m_InterpolatingCameraState.LerpTowards(m_TargetCameraState,
positionLerpPct, rotationLerpPct);
m_InterpolatingCameraState.UpdateTransform(transform);
}
}
using UnityEngine;
namespace UnityTemplateProjects
{
public class SimpleCameraController : MonoBehaviour
{
class CameraState
{
public float yaw;
public float pitch;
public float roll;
public float x;
public float y;
public float z;
x += rotatedTranslation.x;
y += rotatedTranslation.y;
z += rotatedTranslation.z;
}
[Header("Movement Settings")]
[Tooltip("Exponential boost factor on translation, controllable by mouse
wheel.")]
public float boost = 3.5f;
[Header("Rotation Settings")]
[Tooltip("X = Change in mouse position.\nY = Multiplicative factor for
camera rotation.")]
public AnimationCurve mouseSensitivityCurve = new AnimationCurve(new
Keyframe(0f, 0.5f, 0f, 5f), new Keyframe(1f, 2.5f, 0f, 0f));
void OnEnable()
{
m_TargetCameraState.SetFromTransform(transform);
m_InterpolatingCameraState.SetFromTransform(transform);
}
Vector3 GetInputTranslationDirection()
{
Vector3 direction = new Vector3();
if ([Link](KeyCode.W))
{
direction += [Link];
}
if ([Link](KeyCode.S))
{
direction += [Link];
}
if ([Link](KeyCode.A))
{
direction += [Link];
}
if ([Link](KeyCode.D))
{
direction += [Link];
}
if ([Link](KeyCode.Q))
{
direction += [Link];
}
if ([Link](KeyCode.E))
{
direction += [Link];
}
return direction;
}
void Update()
{
Vector3 translation = [Link];
#if ENABLE_LEGACY_INPUT_MANAGER
// Exit Sample
if ([Link]([Link]))
{
[Link]();
#if UNITY_EDITOR
[Link] = false;
#endif
}
// Hide and lock cursor when right mouse button pressed
if ([Link](1))
{
[Link] = [Link];
}
var mouseSensitivityFactor =
[Link]([Link]);
m_TargetCameraState.yaw += mouseMovement.x *
mouseSensitivityFactor;
m_TargetCameraState.pitch += mouseMovement.y *
mouseSensitivityFactor;
}
// Translation
translation = GetInputTranslationDirection() * [Link];
#elif USE_INPUT_SYSTEM
// TODO: make the new input system work
#endif
m_TargetCameraState.Translate(translation);
// Framerate-independent interpolation
// Calculate the lerp amount, such that we get 99% of the way to our
target in the specified time
var positionLerpPct = 1f - [Link](([Link](1f - 0.99f) /
positionLerpTime) * [Link]);
var rotationLerpPct = 1f - [Link](([Link](1f - 0.99f) /
rotationLerpTime) * [Link]);
m_InterpolatingCameraState.LerpTowards(m_TargetCameraState,
positionLerpPct, rotationLerpPct);
m_InterpolatingCameraState.UpdateTransform(transform);
}
}
using UnityEngine;
namespace UnityTemplateProjects
{
public class SimpleCameraController : MonoBehaviour
{
class CameraState
{
public float yaw;
public float pitch;
public float roll;
public float x;
public float y;
public float z;
x += rotatedTranslation.x;
y += rotatedTranslation.y;
z += rotatedTranslation.z;
}
[Header("Movement Settings")]
[Tooltip("Exponential boost factor on translation, controllable by mouse
wheel.")]
public float boost = 3.5f;
[Tooltip("Time it takes to interpolate camera position 99% of the way to
the target."), Range(0.001f, 1f)]
public float positionLerpTime = 0.2f;
[Header("Rotation Settings")]
[Tooltip("X = Change in mouse position.\nY = Multiplicative factor for
camera rotation.")]
public AnimationCurve mouseSensitivityCurve = new AnimationCurve(new
Keyframe(0f, 0.5f, 0f, 5f), new Keyframe(1f, 2.5f, 0f, 0f));
void OnEnable()
{
m_TargetCameraState.SetFromTransform(transform);
m_InterpolatingCameraState.SetFromTransform(transform);
}
Vector3 GetInputTranslationDirection()
{
Vector3 direction = new Vector3();
if ([Link](KeyCode.W))
{
direction += [Link];
}
if ([Link](KeyCode.S))
{
direction += [Link];
}
if ([Link](KeyCode.A))
{
direction += [Link];
}
if ([Link](KeyCode.D))
{
direction += [Link];
}
if ([Link](KeyCode.Q))
{
direction += [Link];
}
if ([Link](KeyCode.E))
{
direction += [Link];
}
return direction;
}
void Update()
{
Vector3 translation = [Link];
#if ENABLE_LEGACY_INPUT_MANAGER
// Exit Sample
if ([Link]([Link]))
{
[Link]();
#if UNITY_EDITOR
[Link] = false;
#endif
}
// Hide and lock cursor when right mouse button pressed
if ([Link](1))
{
[Link] = [Link];
}
// Rotation
if ([Link](1))
{
var mouseMovement = new Vector2([Link]("Mouse X"),
[Link]("Mouse Y") * (invertY ? 1 : -1));
var mouseSensitivityFactor =
[Link]([Link]);
m_TargetCameraState.yaw += mouseMovement.x *
mouseSensitivityFactor;
m_TargetCameraState.pitch += mouseMovement.y *
mouseSensitivityFactor;
}
// Translation
translation = GetInputTranslationDirection() * [Link];
#elif USE_INPUT_SYSTEM
// TODO: make the new input system work
#endif
m_TargetCameraState.Translate(translation);
// Framerate-independent interpolation
// Calculate the lerp amount, such that we get 99% of the way to our
target in the specified time
var positionLerpPct = 1f - [Link](([Link](1f - 0.99f) /
positionLerpTime) * [Link]);
var rotationLerpPct = 1f - [Link](([Link](1f - 0.99f) /
rotationLerpTime) * [Link]);
m_InterpolatingCameraState.LerpTowards(m_TargetCameraState,
positionLerpPct, rotationLerpPct);
m_InterpolatingCameraState.UpdateTransform(transform);
}
}
using UnityEngine;
namespace UnityTemplateProjects
{
public class SimpleCameraController : MonoBehaviour
{
class CameraState
{
public float yaw;
public float pitch;
public float roll;
public float x;
public float y;
public float z;
x += rotatedTranslation.x;
y += rotatedTranslation.y;
z += rotatedTranslation.z;
}
[Header("Movement Settings")]
[Tooltip("Exponential boost factor on translation, controllable by mouse
wheel.")]
public float boost = 3.5f;
[Header("Rotation Settings")]
[Tooltip("X = Change in mouse position.\nY = Multiplicative factor for
camera rotation.")]
public AnimationCurve mouseSensitivityCurve = new AnimationCurve(new
Keyframe(0f, 0.5f, 0f, 5f), new Keyframe(1f, 2.5f, 0f, 0f));
void OnEnable()
{
m_TargetCameraState.SetFromTransform(transform);
m_InterpolatingCameraState.SetFromTransform(transform);
}
Vector3 GetInputTranslationDirection()
{
Vector3 direction = new Vector3();
if ([Link](KeyCode.W))
{
direction += [Link];
}
if ([Link](KeyCode.S))
{
direction += [Link];
}
if ([Link](KeyCode.A))
{
direction += [Link];
}
if ([Link](KeyCode.D))
{
direction += [Link];
}
if ([Link](KeyCode.Q))
{
direction += [Link];
}
if ([Link](KeyCode.E))
{
direction += [Link];
}
return direction;
}
void Update()
{
Vector3 translation = [Link];
#if ENABLE_LEGACY_INPUT_MANAGER
// Exit Sample
if ([Link]([Link]))
{
[Link]();
#if UNITY_EDITOR
[Link] = false;
#endif
}
// Hide and lock cursor when right mouse button pressed
if ([Link](1))
{
[Link] = [Link];
}
// Rotation
if ([Link](1))
{
var mouseMovement = new Vector2([Link]("Mouse X"),
[Link]("Mouse Y") * (invertY ? 1 : -1));
var mouseSensitivityFactor =
[Link]([Link]);
m_TargetCameraState.yaw += mouseMovement.x *
mouseSensitivityFactor;
m_TargetCameraState.pitch += mouseMovement.y *
mouseSensitivityFactor;
}
// Translation
translation = GetInputTranslationDirection() * [Link];
#elif USE_INPUT_SYSTEM
// TODO: make the new input system work
#endif
m_TargetCameraState.Translate(translation);
// Framerate-independent interpolation
// Calculate the lerp amount, such that we get 99% of the way to our
target in the specified time
var positionLerpPct = 1f - [Link](([Link](1f - 0.99f) /
positionLerpTime) * [Link]);
var rotationLerpPct = 1f - [Link](([Link](1f - 0.99f) /
rotationLerpTime) * [Link]);
m_InterpolatingCameraState.LerpTowards(m_TargetCameraState,
positionLerpPct, rotationLerpPct);
m_InterpolatingCameraState.UpdateTransform(transform);
}
}
using UnityEngine;
namespace UnityTemplateProjects
{
public class SimpleCameraController : MonoBehaviour
{
class CameraState
{
public float yaw;
public float pitch;
public float roll;
public float x;
public float y;
public float z;
x += rotatedTranslation.x;
y += rotatedTranslation.y;
z += rotatedTranslation.z;
}
[Header("Movement Settings")]
[Tooltip("Exponential boost factor on translation, controllable by mouse
wheel.")]
public float boost = 3.5f;
[Header("Rotation Settings")]
[Tooltip("X = Change in mouse position.\nY = Multiplicative factor for
camera rotation.")]
public AnimationCurve mouseSensitivityCurve = new AnimationCurve(new
Keyframe(0f, 0.5f, 0f, 5f), new Keyframe(1f, 2.5f, 0f, 0f));
Vector3 GetInputTranslationDirection()
{
Vector3 direction = new Vector3();
if ([Link](KeyCode.W))
{
direction += [Link];
}
if ([Link](KeyCode.S))
{
direction += [Link];
}
if ([Link](KeyCode.A))
{
direction += [Link];
}
if ([Link](KeyCode.D))
{
direction += [Link];
}
if ([Link](KeyCode.Q))
{
direction += [Link];
}
if ([Link](KeyCode.E))
{
direction += [Link];
}
return direction;
}
void Update()
{
Vector3 translation = [Link];
#if ENABLE_LEGACY_INPUT_MANAGER
// Exit Sample
if ([Link]([Link]))
{
[Link]();
#if UNITY_EDITOR
[Link] = false;
#endif
}
// Hide and lock cursor when right mouse button pressed
if ([Link](1))
{
[Link] = [Link];
}
// Rotation
if ([Link](1))
{
var mouseMovement = new Vector2([Link]("Mouse X"),
[Link]("Mouse Y") * (invertY ? 1 : -1));
var mouseSensitivityFactor =
[Link]([Link]);
m_TargetCameraState.yaw += mouseMovement.x *
mouseSensitivityFactor;
m_TargetCameraState.pitch += mouseMovement.y *
mouseSensitivityFactor;
}
// Translation
translation = GetInputTranslationDirection() * [Link];
#elif USE_INPUT_SYSTEM
// TODO: make the new input system work
#endif
m_TargetCameraState.Translate(translation);
// Framerate-independent interpolation
// Calculate the lerp amount, such that we get 99% of the way to our
target in the specified time
var positionLerpPct = 1f - [Link](([Link](1f - 0.99f) /
positionLerpTime) * [Link]);
var rotationLerpPct = 1f - [Link](([Link](1f - 0.99f) /
rotationLerpTime) * [Link]);
m_InterpolatingCameraState.LerpTowards(m_TargetCameraState,
positionLerpPct, rotationLerpPct);
m_InterpolatingCameraState.UpdateTransform(transform);
}
}
namespace UnityTemplateProjects
{
public class SimpleCameraController : MonoBehaviour
{
class CameraState
{
public float yaw;
public float pitch;
public float roll;
public float x;
public float y;
public float z;
x += rotatedTranslation.x;
y += rotatedTranslation.y;
z += rotatedTranslation.z;
}
[Header("Movement Settings")]
[Tooltip("Exponential boost factor on translation, controllable by mouse
wheel.")]
public float boost = 3.5f;
[Header("Rotation Settings")]
[Tooltip("X = Change in mouse position.\nY = Multiplicative factor for
camera rotation.")]
public AnimationCurve mouseSensitivityCurve = new AnimationCurve(new
Keyframe(0f, 0.5f, 0f, 5f), new Keyframe(1f, 2.5f, 0f, 0f));
void OnEnable()
{
m_TargetCameraState.SetFromTransform(transform);
m_InterpolatingCameraState.SetFromTransform(transform);
}
Vector3 GetInputTranslationDirection()
{
Vector3 direction = new Vector3();
if ([Link](KeyCode.W))
{
direction += [Link];
}
if ([Link](KeyCode.S))
{
direction += [Link];
}
if ([Link](KeyCode.A))
{
direction += [Link];
}
if ([Link](KeyCode.D))
{
direction += [Link];
}
if ([Link](KeyCode.Q))
{
direction += [Link];
}
if ([Link](KeyCode.E))
{
direction += [Link];
}
return direction;
}
void Update()
{
Vector3 translation = [Link];
#if ENABLE_LEGACY_INPUT_MANAGER
// Exit Sample
if ([Link]([Link]))
{
[Link]();
#if UNITY_EDITOR
[Link] = false;
#endif
}
// Hide and lock cursor when right mouse button pressed
if ([Link](1))
{
[Link] = [Link];
}
// Rotation
if ([Link](1))
{
var mouseMovement = new Vector2([Link]("Mouse X"),
[Link]("Mouse Y") * (invertY ? 1 : -1));
var mouseSensitivityFactor =
[Link]([Link]);
m_TargetCameraState.yaw += mouseMovement.x *
mouseSensitivityFactor;
m_TargetCameraState.pitch += mouseMovement.y *
mouseSensitivityFactor;
}
// Translation
translation = GetInputTranslationDirection() * [Link];
#elif USE_INPUT_SYSTEM
// TODO: make the new input system work
#endif
m_TargetCameraState.Translate(translation);
// Framerate-independent interpolation
// Calculate the lerp amount, such that we get 99% of the way to our
target in the specified time
var positionLerpPct = 1f - [Link](([Link](1f - 0.99f) /
positionLerpTime) * [Link]);
var rotationLerpPct = 1f - [Link](([Link](1f - 0.99f) /
rotationLerpTime) * [Link]);
m_InterpolatingCameraState.LerpTowards(m_TargetCameraState,
positionLerpPct, rotationLerpPct);
m_InterpolatingCameraState.UpdateTransform(transform);
}
}
[CustomEditor(typeof(WaveFunctionCollapse))]
public class WaveFunctionCollapseEditor : Editor
{
public override void OnInspectorGUI()
{
DrawDefaultInspector();
[CustomEditor(typeof(WaveFunctionCollapse))]
public class WaveFunctionCollapseEditor : Editor
{
public override void OnInspectorGUI()
{
DrawDefaultInspector();
[Link]();
}
}
}
not to invert our Y axis for mouse input to rotation.")]
public bool invertY = false;
void OnEnable()
{
m_TargetCameraState.SetFromTransform(transform);
m_InterpolatingCameraState.SetFromTransform(transform);
}
Vector3 GetInputTranslationDirection()
{
Vector3 direction = new Vector3();
if ([Link](KeyCode.W))
{
direction += [Link];
}
if ([Link](KeyCode.S))
{
direction += [Link];
}
if ([Link](KeyCode.A))
{
direction += [Link];
}
if ([Link](KeyCode.D))
{
direction += [Link];
}
if ([Link](KeyCode.Q))
{
direction += [Link];
}
if ([Link](KeyCode.E))
{
direction += [Link];
}
return direction;
}
void Update()
{
Vector3 translation = [Link];
#if ENABLE_LEGACY_INPUT_MANAGER
// Exit Sample
if ([Link]([Link]))
{
[Link]();
#if UNITY_EDITOR
[Link] = false;
#endif
}
// Hide and lock cursor when right mouse button pressed
if ([Link](1))
{
[Link] = [Link];
}
// Rotation
if ([Link](1))
{
var mouseMovement = new Vector2([Link]("Mouse X"),
[Link]("Mouse Y") * (invertY ? 1 : -1));
var mouseSensitivityFactor =
[Link]([Link]);
m_TargetCameraState.yaw += mouseMovement.x *
mouseSensitivityFactor;
m_TargetCameraState.pitch += mouseMovement.y *
mouseSensitivityFactor;
}
// Translation
translation = GetInputTranslationDirection() * [Link];
#elif USE_INPUT_SYSTEM
// TODO: make the new input system work
#endif
m_TargetCameraState.Translate(translation);
// Framerate-independent interpolation
// Calculate the lerp amount, such that we get 99% of the way to our
target in the specified time
var positionLerpPct = 1f - [Link](([Link](1f - 0.99f) /
positionLerpTime) * [Link]);
var rotationLerpPct = 1f - [Link](([Link](1f - 0.99f) /
rotationLerpTime) * [Link]);
m_InterpolatingCameraState.LerpTowards(m_TargetCameraState,
positionLerpPct, rotationLerpPct);
m_InterpolatingCameraState.UpdateTransform(transform);
}
}
using UnityEngine;
namespace UnityTemplateProjects
{
public class SimpleCameraController : MonoBehaviour
{
class CameraState
{
public float yaw;
public float pitch;
public float roll;
public float x;
public float y;
public float z;
x += rotatedTranslation.x;
y += rotatedTranslation.y;
z += rotatedTranslation.z;
}
[Header("Movement Settings")]
[Tooltip("Exponential boost factor on translation, controllable by mouse
wheel.")]
public float boost = 3.5f;
[Header("Rotation Settings")]
[Tooltip("X = Change in mouse position.\nY = Multiplicative factor for
camera rotation.")]
public AnimationCurve mouseSensitivityCurve = new AnimationCurve(new
Keyframe(0f, 0.5f, 0f, 5f), new Keyframe(1f, 2.5f, 0f, 0f));
void OnEnable()
{
m_TargetCameraState.SetFromTransform(transform);
m_InterpolatingCameraState.SetFromTransform(transform);
}
Vector3 GetInputTranslationDirection()
{
Vector3 direction = new Vector3();
if ([Link](KeyCode.W))
{
direction += [Link];
}
if ([Link](KeyCode.S))
{
direction += [Link];
}
if ([Link](KeyCode.A))
{
direction += [Link];
}
if ([Link](KeyCode.D))
{
direction += [Link];
}
if ([Link](KeyCode.Q))
{
direction += [Link];
}
if ([Link](KeyCode.E))
{
direction += [Link];
}
return direction;
}
void Update()
{
Vector3 translation = [Link];
#if ENABLE_LEGACY_INPUT_MANAGER
// Exit Sample
if ([Link]([Link]))
{
[Link]();
#if UNITY_EDITOR
[Link] = false;
#endif
}
// Hide and lock cursor when right mouse button pressed
if ([Link](1))
{
[Link] = [Link];
}
// Rotation
if ([Link](1))
{
var mouseMovement = new Vector2([Link]("Mouse X"),
[Link]("Mouse Y") * (invertY ? 1 : -1));
var mouseSensitivityFactor =
[Link]([Link]);
m_TargetCameraState.yaw += mouseMovement.x *
mouseSensitivityFactor;
m_TargetCameraState.pitch += mouseMovement.y *
mouseSensitivityFactor;
}
// Translation
translation = GetInputTranslationDirection() * [Link];
#elif USE_INPUT_SYSTEM
// TODO: make the new input system work
#endif
m_TargetCameraState.Translate(translation);
// Framerate-independent interpolation
// Calculate the lerp amount, such that we get 99% of the way to our
target in the specified time
var positionLerpPct = 1f - [Link](([Link](1f - 0.99f) /
positionLerpTime) * [Link]);
var rotationLerpPct = 1f - [Link](([Link](1f - 0.99f) /
rotationLerpTime) * [Link]);
m_InterpolatingCameraState.LerpTowards(m_TargetCameraState,
positionLerpPct, rotationLerpPct);
m_InterpolatingCameraState.UpdateTransform(transform);
}
}
using UnityEngine;
namespace UnityTemplateProjects
{
public class SimpleCameraController : MonoBehaviour
{
class CameraState
{
public float yaw;
public float pitch;
public float roll;
public float x;
public float y;
public float z;
x += rotatedTranslation.x;
y += rotatedTranslation.y;
z += rotatedTranslation.z;
}
[Header("Movement Settings")]
[Tooltip("Exponential boost factor on translation, controllable by mouse
wheel.")]
public float boost = 3.5f;
[Header("Rotation Settings")]
[Tooltip("X = Change in mouse position.\nY = Multiplicative factor for
camera rotation.")]
public AnimationCurve mouseSensitivityCurve = new AnimationCurve(new
Keyframe(0f, 0.5f, 0f, 5f), new Keyframe(1f, 2.5f, 0f, 0f));
void OnEnable()
{
m_TargetCameraState.SetFromTransform(transform);
m_InterpolatingCameraState.SetFromTransform(transform);
}
Vector3 GetInputTranslationDirection()
{
Vector3 direction = new Vector3();
if ([Link](KeyCode.W))
{
direction += [Link];
}
if ([Link](KeyCode.S))
{
direction += [Link];
}
if ([Link](KeyCode.A))
{
direction += [Link];
}
if ([Link](KeyCode.D))
{
direction += [Link];
}
if ([Link](KeyCode.Q))
{
direction += [Link];
}
if ([Link](KeyCode.E))
{
direction += [Link];
}
return direction;
}
void Update()
{
Vector3 translation = [Link];
#if ENABLE_LEGACY_INPUT_MANAGER
// Exit Sample
if ([Link]([Link]))
{
[Link]();
#if UNITY_EDITOR
[Link] = false;
#endif
}
// Hide and lock cursor when right mouse button pressed
if ([Link](1))
{
[Link] = [Link];
}
// Rotation
if ([Link](1))
{
var mouseMovement = new Vector2([Link]("Mouse X"),
[Link]("Mouse Y") * (invertY ? 1 : -1));
var mouseSensitivityFactor =
[Link]([Link]);
m_TargetCameraState.yaw += mouseMovement.x *
mouseSensitivityFactor;
m_TargetCameraState.pitch += mouseMovement.y *
mouseSensitivityFactor;
}
// Translation
translation = GetInputTranslationDirection() * [Link];
// Speed up movement when shift key held
if ([Link]([Link]))
{
translation *= 10.0f;
}
#elif USE_INPUT_SYSTEM
// TODO: make the new input system work
#endif
m_TargetCameraState.Translate(translation);
// Framerate-independent interpolation
// Calculate the lerp amount, such that we get 99% of the way to our
target in the specified time
var positionLerpPct = 1f - [Link](([Link](1f - 0.99f) /
positionLerpTime) * [Link]);
var rotationLerpPct = 1f - [Link](([Link](1f - 0.99f) /
rotationLerpTime) * [Link]);
m_InterpolatingCameraState.LerpTowards(m_TargetCameraState,
positionLerpPct, rotationLerpPct);
m_InterpolatingCameraState.UpdateTransform(transform);
}
}
using UnityEngine;
namespace UnityTemplateProjects
{
public class SimpleCameraController : MonoBehaviour
{
class CameraState
{
public float yaw;
public float pitch;
public float roll;
public float x;
public float y;
public float z;
x += rotatedTranslation.x;
y += rotatedTranslation.y;
z += rotatedTranslation.z;
}
[Header("Movement Settings")]
[Tooltip("Exponential boost factor on translation, controllable by mouse
wheel.")]
public float boost = 3.5f;
[Header("Rotation Settings")]
[Tooltip("X = Change in mouse position.\nY = Multiplicative factor for
camera rotation.")]
public AnimationCurve mouseSensitivityCurve = new AnimationCurve(new
Keyframe(0f, 0.5f, 0f, 5f), new Keyframe(1f, 2.5f, 0f, 0f));
void OnEnable()
{
m_TargetCameraState.SetFromTransform(transform);
m_InterpolatingCameraState.SetFromTransform(transform);
}
Vector3 GetInputTranslationDirection()
{
Vector3 direction = new Vector3();
if ([Link](KeyCode.W))
{
direction += [Link];
}
if ([Link](KeyCode.S))
{
direction += [Link];
}
if ([Link](KeyCode.A))
{
direction += [Link];
}
if ([Link](KeyCode.D))
{
direction += [Link];
}
if ([Link](KeyCode.Q))
{
direction += [Link];
}
if ([Link](KeyCode.E))
{
direction += [Link];
}
return direction;
}
void Update()
{
Vector3 translation = [Link];
#if ENABLE_LEGACY_INPUT_MANAGER
// Exit Sample
if ([Link]([Link]))
{
[Link]();
#if UNITY_EDITOR
[Link] = false;
#endif
}
// Hide and lock cursor when right mouse button pressed
if ([Link](1))
{
[Link] = [Link];
}
// Rotation
if ([Link](1))
{
var mouseMovement = new Vector2([Link]("Mouse X"),
[Link]("Mouse Y") * (invertY ? 1 : -1));
var mouseSensitivityFactor =
[Link]([Link]);
m_TargetCameraState.yaw += mouseMovement.x *
mouseSensitivityFactor;
m_TargetCameraState.pitch += mouseMovement.y *
mouseSensitivityFactor;
}
// Translation
translation = GetInputTranslationDirection() * [Link];
#elif USE_INPUT_SYSTEM
// TODO: make the new input system work
#endif
m_TargetCameraState.Translate(translation);
// Framerate-independent interpolation
// Calculate the lerp amount, such that we get 99% of the way to our
target in the specified time
var positionLerpPct = 1f - [Link](([Link](1f - 0.99f) /
positionLerpTime) * [Link]);
var rotationLerpPct = 1f - [Link](([Link](1f - 0.99f) /
rotationLerpTime) * [Link]);
m_InterpolatingCameraState.LerpTowards(m_TargetCameraState,
positionLerpPct, rotationLerpPct);
m_InterpolatingCameraState.UpdateTransform(transform);
}
}
using UnityEngine;
namespace UnityTemplateProjects
{
public class SimpleCameraController : MonoBehaviour
{
class CameraState
{
public float yaw;
public float pitch;
public float roll;
public float x;
public float y;
public float z;
x += rotatedTranslation.x;
y += rotatedTranslation.y;
z += rotatedTranslation.z;
}
[Header("Movement Settings")]
[Tooltip("Exponential boost factor on translation, controllable by mouse
wheel.")]
public float boost = 3.5f;
[Header("Rotation Settings")]
[Tooltip("X = Change in mouse position.\nY = Multiplicative factor for
camera rotation.")]
public AnimationCurve mouseSensitivityCurve = new AnimationCurve(new
Keyframe(0f, 0.5f, 0f, 5f), new Keyframe(1f, 2.5f, 0f, 0f));
void OnEnable()
{
m_TargetCameraState.SetFromTransform(transform);
m_InterpolatingCameraState.SetFromTransform(transform);
}
Vector3 GetInputTranslationDirection()
{
Vector3 direction = new Vector3();
if ([Link](KeyCode.W))
{
direction += [Link];
}
if ([Link](KeyCode.S))
{
direction += [Link];
}
if ([Link](KeyCode.A))
{
direction += [Link];
}
if ([Link](KeyCode.D))
{
direction += [Link];
}
if ([Link](KeyCode.Q))
{
direction += [Link];
}
if ([Link](KeyCode.E))
{
direction += [Link];
}
return direction;
}
void Update()
{
Vector3 translation = [Link];
#if ENABLE_LEGACY_INPUT_MANAGER
// Exit Sample
if ([Link]([Link]))
{
[Link]();
#if UNITY_EDITOR
[Link] = false;
#endif
}
// Hide and lock cursor when right mouse button pressed
if ([Link](1))
{
[Link] = [Link];
}
// Rotation
if ([Link](1))
{
var mouseMovement = new Vector2([Link]("Mouse X"),
[Link]("Mouse Y") * (invertY ? 1 : -1));
var mouseSensitivityFactor =
[Link]([Link]);
m_TargetCameraState.yaw += mouseMovement.x *
mouseSensitivityFactor;
m_TargetCameraState.pitch += mouseMovement.y *
mouseSensitivityFactor;
}
// Translation
translation = GetInputTranslationDirection() * [Link];
#elif USE_INPUT_SYSTEM
// TODO: make the new input system work
#endif
m_TargetCameraState.Translate(translation);
// Framerate-independent interpolation
// Calculate the lerp amount, such that we get 99% of the way to our
target in the specified time
var positionLerpPct = 1f - [Link](([Link](1f - 0.99f) /
positionLerpTime) * [Link]);
var rotationLerpPct = 1f - [Link](([Link](1f - 0.99f) /
rotationLerpTime) * [Link]);
m_InterpolatingCameraState.LerpTowards(m_TargetCameraState,
positionLerpPct, rotationLerpPct);
m_InterpolatingCameraState.UpdateTransform(transform);
}
}
using UnityEngine;
namespace UnityTemplateProjects
{
public class SimpleCameraController : MonoBehaviour
{
class CameraState
{
public float yaw;
public float pitch;
public float roll;
public float x;
public float y;
public float z;
x += rotatedTranslation.x;
y += rotatedTranslation.y;
z += rotatedTranslation.z;
}
[Header("Movement Settings")]
[Tooltip("Exponential boost factor on translation, controllable by mouse
wheel.")]
public float boost = 3.5f;
[Header("Rotation Settings")]
[Tooltip("X = Change in mouse position.\nY = Multiplicative factor for
camera rotation.")]
public AnimationCurve mouseSensitivityCurve = new AnimationCurve(new
Keyframe(0f, 0.5f, 0f, 5f), new Keyframe(1f, 2.5f, 0f, 0f));
void OnEnable()
{
m_TargetCameraState.SetFromTransform(transform);
m_InterpolatingCameraState.SetFromTransform(transform);
}
Vector3 GetInputTranslationDirection()
{
Vector3 direction = new Vector3();
if ([Link](KeyCode.W))
{
direction += [Link];
}
if ([Link](KeyCode.S))
{
direction += [Link];
}
if ([Link](KeyCode.A))
{
direction += [Link];
}
if ([Link](KeyCode.D))
{
direction += [Link];
}
if ([Link](KeyCode.Q))
{
direction += [Link];
}
if ([Link](KeyCode.E))
{
direction += [Link];
}
return direction;
}
void Update()
{
Vector3 translation = [Link];
#if ENABLE_LEGACY_INPUT_MANAGER
// Exit Sample
if ([Link]([Link]))
{
[Link]();
#if UNITY_EDITOR
[Link] = false;
#endif
}
// Hide and lock cursor when right mouse button pressed
if ([Link](1))
{
[Link] = [Link];
}
// Rotation
if ([Link](1))
{
var mouseMovement = new Vector2([Link]("Mouse X"),
[Link]("Mouse Y") * (invertY ? 1 : -1));
var mouseSensitivityFactor =
[Link]([Link]);
m_TargetCameraState.yaw += mouseMovement.x *
mouseSensitivityFactor;
m_TargetCameraState.pitch += mouseMovement.y *
mouseSensitivityFactor;
}
// Translation
translation = GetInputTranslationDirection() * [Link];
#elif USE_INPUT_SYSTEM
// TODO: make the new input system work
#endif
m_TargetCameraState.Translate(translation);
// Framerate-independent interpolation
// Calculate the lerp amount, such that we get 99% of the way to our
target in the specified time
var positionLerpPct = 1f - [Link](([Link](1f - 0.99f) /
positionLerpTime) * [Link]);
var rotationLerpPct = 1f - [Link](([Link](1f - 0.99f) /
rotationLerpTime) * [Link]);
m_InterpolatingCameraState.LerpTowards(m_TargetCameraState,
positionLerpPct, rotationLerpPct);
m_InterpolatingCameraState.UpdateTransform(transform);
}
}
using UnityEngine;
namespace UnityTemplateProjects
{
public class SimpleCameraController : MonoBehaviour
{
class CameraState
{
public float yaw;
public float pitch;
public float roll;
public float x;
public float y;
public float z;
x += rotatedTranslation.x;
y += rotatedTranslation.y;
z += rotatedTranslation.z;
}
[Header("Movement Settings")]
[Tooltip("Exponential boost factor on translation, controllable by mouse
wheel.")]
public float boost = 3.5f;
[Header("Rotation Settings")]
[Tooltip("X = Change in mouse position.\nY = Multiplicative factor for
camera rotation.")]
public AnimationCurve mouseSensitivityCurve = new AnimationCurve(new
Keyframe(0f, 0.5f, 0f, 5f), new Keyframe(1f, 2.5f, 0f, 0f));
void OnEnable()
{
m_TargetCameraState.SetFromTransform(transform);
m_InterpolatingCameraState.SetFromTransform(transform);
}
Vector3 GetInputTranslationDirection()
{
Vector3 direction = new Vector3();
if ([Link](KeyCode.W))
{
direction += [Link];
}
if ([Link](KeyCode.S))
{
direction += [Link];
}
if ([Link](KeyCode.A))
{
direction += [Link];
}
if ([Link](KeyCode.D))
{
direction += [Link];
}
if ([Link](KeyCode.Q))
{
direction += [Link];
}
if ([Link](KeyCode.E))
{
direction += [Link];
}
return direction;
}
void Update()
{
Vector3 translation = [Link];
#if ENABLE_LEGACY_INPUT_MANAGER
// Exit Sample
if ([Link]([Link]))
{
[Link]();
#if UNITY_EDITOR
[Link] = false;
#endif
}
// Hide and lock cursor when right mouse button pressed
if ([Link](1))
{
[Link] = [Link];
}
// Unlock and show cursor when right mouse button released
if ([Link](1))
{
[Link] = true;
[Link] = [Link];
}
// Rotation
if ([Link](1))
{
var mouseMovement = new Vector2([Link]("Mouse X"),
[Link]("Mouse Y") * (invertY ? 1 : -1));
var mouseSensitivityFactor =
[Link]([Link]);
m_TargetCameraState.yaw += mouseMovement.x *
mouseSensitivityFactor;
m_TargetCameraState.pitch += mouseMovement.y *
mouseSensitivityFactor;
}
// Translation
translation = GetInputTranslationDirection() * [Link];
#elif USE_INPUT_SYSTEM
// TODO: make the new input system work
#endif
m_TargetCameraState.Translate(translation);
// Framerate-independent interpolation
// Calculate the lerp amount, such that we get 99% of the way to our
target in the specified time
var positionLerpPct = 1f - [Link](([Link](1f - 0.99f) /
positionLerpTime) * [Link]);
var rotationLerpPct = 1f - [Link](([Link](1f - 0.99f) /
rotationLerpTime) * [Link]);
m_InterpolatingCameraState.LerpTowards(m_TargetCameraState,
positionLerpPct, rotationLerpPct);
m_InterpolatingCameraState.UpdateTransform(transform);
}
}