123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128 |
- Shader "Hidden/Post FX/Lut Generator"
- {
- CGINCLUDE
- #pragma target 3.0
- #pragma multi_compile __ TONEMAPPING_NEUTRAL TONEMAPPING_FILMIC
- #include "UnityCG.cginc"
- #include "ACES.cginc"
- #include "Common.cginc"
- #include "ColorGrading.cginc"
- #include "Tonemapping.cginc"
- half3 _Balance;
- half3 _Lift;
- half3 _InvGamma;
- half3 _Gain;
- half3 _Offset;
- half3 _Power;
- half3 _Slope;
- half _HueShift;
- half _Saturation;
- half _Contrast;
- half3 _ChannelMixerRed;
- half3 _ChannelMixerGreen;
- half3 _ChannelMixerBlue;
- half4 _NeutralTonemapperParams1;
- half4 _NeutralTonemapperParams2;
- sampler2D _Curves;
- half4 _LutParams;
- half3 ColorGrade(half3 color)
- {
- half3 aces = unity_to_ACES(color);
- // ACEScc (log) space
- half3 acescc = ACES_to_ACEScc(aces);
- acescc = OffsetPowerSlope(acescc, _Offset, _Power, _Slope);
- half2 hs = RgbToHsv(acescc).xy;
- half satMultiplier = SecondaryHueSat(hs.x, _Curves);
- satMultiplier *= SecondarySatSat(hs.y, _Curves);
- satMultiplier *= SecondaryLumSat(AcesLuminance(acescc), _Curves);
- acescc = Saturation(acescc, _Saturation * satMultiplier);
- acescc = ContrastLog(acescc, _Contrast);
- aces = ACEScc_to_ACES(acescc);
- // ACEScg (linear) space
- half3 acescg = ACES_to_ACEScg(aces);
- acescg = WhiteBalance(acescg, _Balance);
- acescg = LiftGammaGain(acescg, _Lift, _InvGamma, _Gain);
- half3 hsv = RgbToHsv(max(acescg, 0.0));
- hsv.x = SecondaryHueHue(hsv.x + _HueShift, _Curves);
- acescg = HsvToRgb(hsv);
- acescg = ChannelMixer(acescg, _ChannelMixerRed, _ChannelMixerGreen, _ChannelMixerBlue);
- #if TONEMAPPING_FILMIC
- aces = ACEScg_to_ACES(acescg);
- color = FilmicTonemap(aces);
- #elif TONEMAPPING_NEUTRAL
- color = ACEScg_to_unity(acescg);
- color = NeutralTonemap(color, _NeutralTonemapperParams1, _NeutralTonemapperParams2);
- #else
- color = ACEScg_to_unity(acescg);
- #endif
- // YRGB curves (done in linear/LDR for now)
- color = YrgbCurve(color, _Curves);
- return color;
- }
- half4 FragCreateLut(VaryingsDefault i) : SV_Target
- {
- // 2D strip lut
- half2 uv = i.uv - _LutParams.yz;
- half3 color;
- color.r = frac(uv.x * _LutParams.x);
- color.b = uv.x - color.r / _LutParams.x;
- color.g = uv.y;
- // Lut is in LogC
- half3 colorLogC = color * _LutParams.w;
- // Switch back to unity linear and color grade
- half3 colorLinear = LogCToLinear(colorLogC);
- half3 graded = ColorGrade(colorLinear);
- return half4(graded, 1.0);
- }
- ENDCG
- SubShader
- {
- Cull Off ZWrite Off ZTest Always
- // (0)
- Pass
- {
- CGPROGRAM
- #pragma vertex VertDefault
- #pragma fragment FragCreateLut
- ENDCG
- }
- }
- }
|