Firstborn/Library/PackageCache/com.unity.cinemachine@2.8.9/Runtime/Behaviours/CinemachinePixelPerfect.cs

74 lines
3.2 KiB
C#
Raw Normal View History

2023-03-28 13:24:16 -04:00
using UnityEngine;
#if CINEMACHINE_LWRP_7_3_1 || CINEMACHINE_PIXEL_PERFECT_2_0_3
namespace Cinemachine
{
/// <summary>
/// An add-on module for Cinemachine Virtual Camera that tweaks the orthographic size
/// of the virtual camera. It detects the presence of the Pixel Perfect Camera component and use the
/// settings from that Pixel Perfect Camera to correct the orthographic size so that pixel art
/// sprites would appear pixel perfect when the virtual camera becomes live.
/// </summary>
[AddComponentMenu("")] // Hide in menu
[ExecuteAlways]
[DisallowMultipleComponent]
[HelpURL(Documentation.BaseURL + "manual/CinemachinePixelPerfect.html")]
public class CinemachinePixelPerfect : CinemachineExtension
{
/// <summary>Callback to tweak the orthographic size</summary>
/// <param name="vcam">The virtual camera being processed</param>
/// <param name="stage">The current pipeline stage</param>
/// <param name="state">The current virtual camera state</param>
/// <param name="deltaTime">The current applicable deltaTime</param>
protected override void PostPipelineStageCallback(
CinemachineVirtualCameraBase vcam,
CinemachineCore.Stage stage, ref CameraState state, float deltaTime)
{
// This must run during the Body stage because CinemachineConfiner also runs during Body stage,
// and CinemachinePixelPerfect needs to run before CinemachineConfiner as the confiner reads the
// orthographic size. We also altered the script execution order to ensure this.
if (stage != CinemachineCore.Stage.Body)
return;
var brain = CinemachineCore.Instance.FindPotentialTargetBrain(vcam);
if (brain == null || !brain.IsLive(vcam))
return;
#if CINEMACHINE_LWRP_7_3_1
UnityEngine.Experimental.Rendering.Universal.PixelPerfectCamera pixelPerfectCamera;
#elif CINEMACHINE_PIXEL_PERFECT_2_0_3
UnityEngine.U2D.PixelPerfectCamera pixelPerfectCamera;
#endif
brain.TryGetComponent(out pixelPerfectCamera);
if (pixelPerfectCamera == null || !pixelPerfectCamera.isActiveAndEnabled)
return;
#if UNITY_EDITOR
if (!UnityEditor.EditorApplication.isPlaying && !pixelPerfectCamera.runInEditMode)
return;
#endif
var lens = state.Lens;
lens.OrthographicSize = pixelPerfectCamera.CorrectCinemachineOrthoSize(lens.OrthographicSize);
state.Lens = lens;
}
}
}
#else
// We need this dummy MonoBehaviour for Unity to properly recognize this script asset.
namespace Cinemachine
{
/// <summary>
/// An add-on module for Cinemachine Virtual Camera that tweaks the orthographic size
/// of the virtual camera. It detects the presence of the Pixel Perfect Camera component and use the
/// settings from that Pixel Perfect Camera to correct the orthographic size so that pixel art
/// sprites would appear pixel perfect when the virtual camera becomes live.
/// </summary>
[AddComponentMenu("")] // Hide in menu
[DisallowMultipleComponent]
public class CinemachinePixelPerfect : MonoBehaviour {}
}
#endif