using System;
using UnityEngine.Experimental.Rendering;
using UnityEngine.Rendering.Universal.Internal;
namespace UnityEngine.Rendering.Universal
{
///
/// Run-time creation parameters for post process passes.
///
internal struct PostProcessParams
{
///
/// The blit Material to use.
///
///
public Material blitMaterial;
///
/// Requested GraphicsFormat for HDR postprocess rendering.
///
///
public GraphicsFormat requestHDRFormat;
///
/// A static factory function for default initialization of PostProcessParams.
///
///
public static PostProcessParams Create()
{
PostProcessParams ppParams;
ppParams.blitMaterial = null;
ppParams.requestHDRFormat = GraphicsFormat.None;
return ppParams;
}
}
///
/// Type acts as wrapper for post process passes. Can we be recreated and destroyed at any point during runtime with post process data.
///
internal struct PostProcessPasses : IDisposable
{
ColorGradingLutPass m_ColorGradingLutPass;
PostProcessPass m_PostProcessPass;
PostProcessPass m_FinalPostProcessPass;
internal RTHandle m_AfterPostProcessColor;
internal RTHandle m_ColorGradingLut;
PostProcessData m_RendererPostProcessData;
PostProcessData m_CurrentPostProcessData;
Material m_BlitMaterial;
public ColorGradingLutPass colorGradingLutPass { get => m_ColorGradingLutPass; }
public PostProcessPass postProcessPass { get => m_PostProcessPass; }
public PostProcessPass finalPostProcessPass { get => m_FinalPostProcessPass; }
public RTHandle afterPostProcessColor { get => m_AfterPostProcessColor; }
public RTHandle colorGradingLut { get => m_ColorGradingLut; }
public bool isCreated { get => m_CurrentPostProcessData != null; }
///
/// Creates post process passes with supplied data anda params.
///
/// Post process resources.
/// Post process run-time creation parameters.
public PostProcessPasses(PostProcessData rendererPostProcessData, ref PostProcessParams postProcessParams)
{
m_ColorGradingLutPass = null;
m_PostProcessPass = null;
m_FinalPostProcessPass = null;
m_CurrentPostProcessData = null;
m_AfterPostProcessColor = null;
m_ColorGradingLut = null;
m_RendererPostProcessData = rendererPostProcessData;
m_BlitMaterial = postProcessParams.blitMaterial;
Recreate(rendererPostProcessData, ref postProcessParams);
}
///
/// Recreates post process passes with supplied data. If already contains valid post process passes, they will be replaced by new ones.
///
/// Resources used for creating passes. In case of the null, no passes will be created.
/// Run-time parameters used for creating passes.
public void Recreate(PostProcessData data, ref PostProcessParams ppParams)
{
if (m_RendererPostProcessData)
data = m_RendererPostProcessData;
if (data == m_CurrentPostProcessData)
return;
if (m_CurrentPostProcessData != null)
{
m_ColorGradingLutPass?.Cleanup();
m_PostProcessPass?.Cleanup();
m_FinalPostProcessPass?.Cleanup();
// We need to null post process passes to avoid using them
m_ColorGradingLutPass = null;
m_PostProcessPass = null;
m_FinalPostProcessPass = null;
m_CurrentPostProcessData = null;
}
if (data != null)
{
m_ColorGradingLutPass = new ColorGradingLutPass(RenderPassEvent.BeforeRenderingPrePasses, data);
m_PostProcessPass = new PostProcessPass(RenderPassEvent.BeforeRenderingPostProcessing, data, ref ppParams);
m_FinalPostProcessPass = new PostProcessPass(RenderPassEvent.AfterRenderingPostProcessing, data, ref ppParams);
m_CurrentPostProcessData = data;
}
}
public void Dispose()
{
// always dispose unmanaged resources
m_ColorGradingLutPass?.Cleanup();
m_PostProcessPass?.Cleanup();
m_FinalPostProcessPass?.Cleanup();
m_AfterPostProcessColor?.Release();
m_ColorGradingLut?.Release();
}
internal void ReleaseRenderTargets()
{
m_AfterPostProcessColor?.Release();
m_PostProcessPass?.Dispose();
m_FinalPostProcessPass?.Dispose();
m_ColorGradingLut?.Release();
}
}
}