#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; } } }