#if UNITY_EDITOR
using UnityEditor;
using UnityEditor.ProjectWindowCallback;
using ShaderKeywordFilter = UnityEditor.ShaderKeywordFilter;
#endif
using System;
using UnityEngine.Scripting.APIUpdating;
using UnityEngine.Assertions;
namespace UnityEngine.Rendering.Universal
{
///
/// Defines if Unity will copy the depth that can be bound in shaders as _CameraDepthTexture after the opaques pass or after the transparents pass.
///
public enum CopyDepthMode
{
/// Depth will be copied after the opaques pass
AfterOpaques,
/// Depth will be copied after the transparents pass
AfterTransparents,
/// Depth will be written by a depth prepass
ForcePrepass
}
///
/// Class containing resources needed for the UniversalRenderer.
///
[Serializable, ReloadGroup, ExcludeFromPreset]
[URPHelpURL("urp-universal-renderer")]
public class UniversalRendererData : ScriptableRendererData, ISerializationCallbackReceiver
{
#if UNITY_EDITOR
[System.Diagnostics.CodeAnalysis.SuppressMessage("Microsoft.Performance", "CA1812")]
internal class CreateUniversalRendererAsset : EndNameEditAction
{
public override void Action(int instanceId, string pathName, string resourceFile)
{
var instance = UniversalRenderPipelineAsset.CreateRendererAsset(pathName, RendererType.UniversalRenderer, false) as UniversalRendererData;
Selection.activeObject = instance;
}
}
[MenuItem("Assets/Create/Rendering/URP Universal Renderer", priority = CoreUtils.Sections.section3 + CoreUtils.Priorities.assetsCreateRenderingMenuPriority + 2)]
static void CreateUniversalRendererData()
{
ProjectWindowUtil.StartNameEditingIfProjectWindowExists(0, CreateInstance(), "New Custom Universal Renderer Data.asset", null, null);
}
#endif
///
/// Class containing shader resources used in URP.
///
[Serializable, ReloadGroup]
public sealed class ShaderResources
{
///
/// Blit shader.
///
[Reload("Shaders/Utils/Blit.shader")]
public Shader blitPS;
///
/// Copy Depth shader.
///
[Reload("Shaders/Utils/CopyDepth.shader")]
public Shader copyDepthPS;
///
/// Screen Space Shadows shader.
///
[Obsolete("Obsolete, this feature will be supported by new 'ScreenSpaceShadows' renderer feature")]
public Shader screenSpaceShadowPS;
///
/// Sampling shader.
///
[Reload("Shaders/Utils/Sampling.shader")]
public Shader samplingPS;
///
/// Stencil Deferred shader.
///
[Reload("Shaders/Utils/StencilDeferred.shader")]
public Shader stencilDeferredPS;
///
/// Fallback error shader.
///
[Reload("Shaders/Utils/FallbackError.shader")]
public Shader fallbackErrorPS;
///
/// Fallback loading shader.
///
[Reload("Shaders/Utils/FallbackLoading.shader")]
public Shader fallbackLoadingPS;
///
/// Material Error shader.
///
[Obsolete("Use fallbackErrorPS instead")]
[Reload("Shaders/Utils/MaterialError.shader")]
public Shader materialErrorPS;
// Core blitter shaders, adapted from HDRP
// TODO: move to core and share with HDRP
[Reload("Shaders/Utils/CoreBlit.shader"), SerializeField]
internal Shader coreBlitPS;
[Reload("Shaders/Utils/CoreBlitColorAndDepth.shader"), SerializeField]
internal Shader coreBlitColorAndDepthPS;
///
/// Blit shader that blits UI Overlay and performs HDR encoding.
///
[Reload("Shaders/Utils/BlitHDROverlay.shader"), SerializeField]
internal Shader blitHDROverlay;
///
/// Camera Motion Vectors shader.
///
[Reload("Shaders/CameraMotionVectors.shader")]
public Shader cameraMotionVector;
///
/// Object Motion Vectors shader.
///
[Reload("Shaders/ObjectMotionVectors.shader")]
public Shader objectMotionVector;
///
/// Data Driven Lens Flare shader.
///
[Reload("Shaders/PostProcessing/LensFlareDataDriven.shader")]
public Shader dataDrivenLensFlare;
}
///
/// Resources needed for Post Processing.
///
public PostProcessData postProcessData = null;
#if ENABLE_VR && ENABLE_XR_MODULE
///
/// Shader resources needed in URP for XR.
///
[Reload("Runtime/Data/XRSystemData.asset")]
public XRSystemData xrSystemData = null;
#endif
///
/// Shader resources used in URP.
///
public ShaderResources shaders = null;
const int k_LatestAssetVersion = 2;
[SerializeField] int m_AssetVersion = 0;
[SerializeField] LayerMask m_OpaqueLayerMask = -1;
[SerializeField] LayerMask m_TransparentLayerMask = -1;
[SerializeField] StencilStateData m_DefaultStencilState = new StencilStateData() { passOperation = StencilOp.Replace }; // This default state is compatible with deferred renderer.
[SerializeField] bool m_ShadowTransparentReceive = true;
[SerializeField] RenderingMode m_RenderingMode = RenderingMode.Forward;
[SerializeField] DepthPrimingMode m_DepthPrimingMode = DepthPrimingMode.Disabled; // Default disabled because there are some outstanding issues with Text Mesh rendering.
[SerializeField] CopyDepthMode m_CopyDepthMode = CopyDepthMode.AfterTransparents;
#if UNITY_EDITOR
// Do not strip accurateGbufferNormals on Mobile Vulkan as some GPUs do not support R8G8B8A8_SNorm, which then force us to use accurateGbufferNormals
[ShaderKeywordFilter.ApplyRulesIfNotGraphicsAPI(GraphicsDeviceType.Vulkan)]
[ShaderKeywordFilter.RemoveIf(false, keywordNames: ShaderKeywordStrings._GBUFFER_NORMALS_OCT)]
#endif
[SerializeField] bool m_AccurateGbufferNormals = false;
[SerializeField] IntermediateTextureMode m_IntermediateTextureMode = IntermediateTextureMode.Always;
///
protected override ScriptableRenderer Create()
{
if (!Application.isPlaying)
{
ReloadAllNullProperties();
}
return new UniversalRenderer(this);
}
///
/// Use this to configure how to filter opaque objects.
///
public LayerMask opaqueLayerMask
{
get => m_OpaqueLayerMask;
set
{
SetDirty();
m_OpaqueLayerMask = value;
}
}
///
/// Use this to configure how to filter transparent objects.
///
public LayerMask transparentLayerMask
{
get => m_TransparentLayerMask;
set
{
SetDirty();
m_TransparentLayerMask = value;
}
}
///
/// The default stencil state settings.
///
public StencilStateData defaultStencilState
{
get => m_DefaultStencilState;
set
{
SetDirty();
m_DefaultStencilState = value;
}
}
///
/// True if transparent objects receive shadows.
///
public bool shadowTransparentReceive
{
get => m_ShadowTransparentReceive;
set
{
SetDirty();
m_ShadowTransparentReceive = value;
}
}
///
/// Rendering mode.
///
public RenderingMode renderingMode
{
get => m_RenderingMode;
set
{
SetDirty();
m_RenderingMode = value;
}
}
///
/// Depth priming mode.
///
public DepthPrimingMode depthPrimingMode
{
get => m_DepthPrimingMode;
set
{
SetDirty();
m_DepthPrimingMode = value;
}
}
///
/// Copy depth mode.
///
public CopyDepthMode copyDepthMode
{
get => m_CopyDepthMode;
set
{
SetDirty();
m_CopyDepthMode = value;
}
}
///
/// Use Octaedron Octahedron normal vector encoding for gbuffer normals.
/// The overhead is negligible from desktop GPUs, while it should be avoided for mobile GPUs.
///
public bool accurateGbufferNormals
{
get => m_AccurateGbufferNormals;
set
{
SetDirty();
m_AccurateGbufferNormals = value;
}
}
///
/// Controls when URP renders via an intermediate texture.
///
public IntermediateTextureMode intermediateTextureMode
{
get => m_IntermediateTextureMode;
set
{
SetDirty();
m_IntermediateTextureMode = value;
}
}
///
protected override void OnEnable()
{
base.OnEnable();
// Upon asset creation, OnEnable is called and `shaders` reference is not yet initialized
// We need to call the OnEnable for data migration when updating from old versions of UniversalRP that
// serialized resources in a different format. Early returning here when OnEnable is called
// upon asset creation is fine because we guarantee new assets get created with all resources initialized.
if (shaders == null)
return;
ReloadAllNullProperties();
}
private void ReloadAllNullProperties()
{
#if UNITY_EDITOR
ResourceReloader.TryReloadAllNullIn(this, UniversalRenderPipelineAsset.packagePath);
if (postProcessData != null)
ResourceReloader.TryReloadAllNullIn(postProcessData, UniversalRenderPipelineAsset.packagePath);
#if ENABLE_VR && ENABLE_XR_MODULE
ResourceReloader.TryReloadAllNullIn(xrSystemData, UniversalRenderPipelineAsset.packagePath);
#endif
#endif
}
///
void ISerializationCallbackReceiver.OnBeforeSerialize()
{
m_AssetVersion = k_LatestAssetVersion;
}
///
void ISerializationCallbackReceiver.OnAfterDeserialize()
{
if (m_AssetVersion <= 1)
{
// To avoid breaking existing projects, keep the old AfterOpaques behaviour. The new AfterTransparents default will only apply to new projects.
m_CopyDepthMode = CopyDepthMode.AfterOpaques;
}
m_AssetVersion = k_LatestAssetVersion;
}
}
}