using System;
namespace UnityEngine.Rendering.Universal
{
///
/// Focusing modes for the depth of field effect.
///
public enum DepthOfFieldMode
{
///
/// Disables depth of field.
///
Off,
///
/// Use this for faster but non physical depth of field.
///
Gaussian, // Non physical, fast, small radius, far blur only
///
/// Use this for a more realistic but slower depth of field.
///
Bokeh
}
///
/// A volume component that holds settings for the Depth Of Field effect.
///
[Serializable, VolumeComponentMenuForRenderPipeline("Post-processing/Depth Of Field", typeof(UniversalRenderPipeline))]
[URPHelpURL("post-processing-depth-of-field")]
public sealed class DepthOfField : VolumeComponent, IPostProcessComponent
{
///
/// Use this to select Focusing modes for the depth of field effect.
///
[Tooltip("Use \"Gaussian\" for a faster but non physical depth of field; \"Bokeh\" for a more realistic but slower depth of field.")]
public DepthOfFieldModeParameter mode = new DepthOfFieldModeParameter(DepthOfFieldMode.Off);
///
/// The distance at which the blurring will start.
///
[Tooltip("The distance at which the blurring will start.")]
public MinFloatParameter gaussianStart = new MinFloatParameter(10f, 0f);
///
/// The distance at which the blurring will reach its maximum radius.
///
[Tooltip("The distance at which the blurring will reach its maximum radius.")]
public MinFloatParameter gaussianEnd = new MinFloatParameter(30f, 0f);
///
/// The maximum radius of the gaussian blur. Values above 1 may show under-sampling artifacts.
///
[Tooltip("The maximum radius of the gaussian blur. Values above 1 may show under-sampling artifacts.")]
public ClampedFloatParameter gaussianMaxRadius = new ClampedFloatParameter(1f, 0.5f, 1.5f);
///
/// Use higher quality sampling to reduce flickering and improve the overall blur smoothness.
///
[Tooltip("Use higher quality sampling to reduce flickering and improve the overall blur smoothness.")]
public BoolParameter highQualitySampling = new BoolParameter(false);
///
/// The distance to the point of focus.
///
[Tooltip("The distance to the point of focus.")]
public MinFloatParameter focusDistance = new MinFloatParameter(10f, 0.1f);
///
/// The ratio of aperture (known as f-stop or f-number). The smaller the value is, the shallower the depth of field is.
///
[Tooltip("The ratio of aperture (known as f-stop or f-number). The smaller the value is, the shallower the depth of field is.")]
public ClampedFloatParameter aperture = new ClampedFloatParameter(5.6f, 1f, 32f);
///
/// The distance between the lens and the film. The larger the value is, the shallower the depth of field is.
///
[Tooltip("The distance between the lens and the film. The larger the value is, the shallower the depth of field is.")]
public ClampedFloatParameter focalLength = new ClampedFloatParameter(50f, 1f, 300f);
///
/// The number of aperture blades.
///
[Tooltip("The number of aperture blades.")]
public ClampedIntParameter bladeCount = new ClampedIntParameter(5, 3, 9);
///
/// The curvature of aperture blades. The smaller the value is, the more visible aperture blades are. A value of 1 will make the bokeh perfectly circular.
///
[Tooltip("The curvature of aperture blades. The smaller the value is, the more visible aperture blades are. A value of 1 will make the bokeh perfectly circular.")]
public ClampedFloatParameter bladeCurvature = new ClampedFloatParameter(1f, 0f, 1f);
///
/// The rotation of aperture blades in degrees.
///
[Tooltip("The rotation of aperture blades in degrees.")]
public ClampedFloatParameter bladeRotation = new ClampedFloatParameter(0f, -180f, 180f);
///
public bool IsActive()
{
if (mode.value == DepthOfFieldMode.Off || SystemInfo.graphicsShaderLevel < 35)
return false;
return mode.value != DepthOfFieldMode.Gaussian || SystemInfo.supportedRenderTargetCount > 1;
}
///
public bool IsTileCompatible() => false;
}
///
/// A that holds a value.
///
[Serializable]
public sealed class DepthOfFieldModeParameter : VolumeParameter
{
///
/// Creates a new instance.
///
/// The initial value to store in the parameter.
/// The initial override state for the parameter.
public DepthOfFieldModeParameter(DepthOfFieldMode value, bool overrideState = false) : base(value, overrideState) { }
}
}