2015-05-12 09:18:09 +02:00
|
|
|
// license:BSD-3-Clause
|
2023-03-19 17:59:44 +01:00
|
|
|
// copyright-holders:Ryan Holtz, W. M. Martinez
|
2011-05-18 02:35:16 +02:00
|
|
|
//-----------------------------------------------------------------------------
|
|
|
|
// Color-Convolution Effect
|
|
|
|
//-----------------------------------------------------------------------------
|
|
|
|
|
2023-03-19 17:59:44 +01:00
|
|
|
//-----------------------------------------------------------------------------
|
|
|
|
// Macros
|
|
|
|
//-----------------------------------------------------------------------------
|
|
|
|
|
|
|
|
#define LUT_TEXTURE_WIDTH 4096.0f
|
|
|
|
#define LUT_SIZE 64.0f
|
|
|
|
#define LUT_SCALE float2(1.0f / LUT_TEXTURE_WIDTH, 1.0f / LUT_SIZE)
|
|
|
|
|
2015-12-31 16:32:35 +01:00
|
|
|
//-----------------------------------------------------------------------------
|
|
|
|
// Sampler Definitions
|
|
|
|
//-----------------------------------------------------------------------------
|
|
|
|
|
2011-05-18 02:35:16 +02:00
|
|
|
texture Diffuse;
|
2023-03-19 17:59:44 +01:00
|
|
|
texture LutTexture;
|
2011-05-18 02:35:16 +02:00
|
|
|
|
|
|
|
sampler DiffuseSampler = sampler_state
|
|
|
|
{
|
|
|
|
Texture = <Diffuse>;
|
2011-05-28 21:25:14 +02:00
|
|
|
MipFilter = LINEAR;
|
|
|
|
MinFilter = LINEAR;
|
|
|
|
MagFilter = LINEAR;
|
2011-05-18 02:35:16 +02:00
|
|
|
AddressU = CLAMP;
|
|
|
|
AddressV = CLAMP;
|
|
|
|
AddressW = CLAMP;
|
|
|
|
};
|
|
|
|
|
2023-03-19 17:59:44 +01:00
|
|
|
sampler2D LutSampler = sampler_state
|
|
|
|
{
|
|
|
|
Texture = <LutTexture>;
|
|
|
|
MinFilter = LINEAR;
|
|
|
|
MagFilter = LINEAR;
|
|
|
|
MipFilter = LINEAR;
|
|
|
|
AddressU = CLAMP;
|
|
|
|
AddressV = CLAMP;
|
|
|
|
AddressW = CLAMP;
|
|
|
|
};
|
|
|
|
|
|
|
|
//-----------------------------------------------------------------------------
|
|
|
|
// Utilities
|
|
|
|
//-----------------------------------------------------------------------------
|
|
|
|
|
|
|
|
float3 apply_lut(float3 color)
|
|
|
|
{
|
|
|
|
// NOTE: Do not change the order of parameters here.
|
|
|
|
float3 lutcoord = float3((color.rg * (LUT_SIZE - 1.0f) + 0.5f) *
|
|
|
|
LUT_SCALE, color.b * (LUT_SIZE - 1.0f));
|
|
|
|
float shift = floor(lutcoord.z);
|
|
|
|
|
|
|
|
lutcoord.x += shift * LUT_SCALE.y;
|
|
|
|
color.rgb = lerp(tex2D(LutSampler, lutcoord.xy).rgb, tex2D(LutSampler,
|
|
|
|
float2(lutcoord.x + LUT_SCALE.y, lutcoord.y)).rgb,
|
|
|
|
lutcoord.z - shift);
|
|
|
|
return color;
|
|
|
|
}
|
|
|
|
|
2011-05-18 02:35:16 +02:00
|
|
|
//-----------------------------------------------------------------------------
|
|
|
|
// Vertex Definitions
|
|
|
|
//-----------------------------------------------------------------------------
|
|
|
|
|
|
|
|
struct VS_OUTPUT
|
|
|
|
{
|
|
|
|
float4 Position : POSITION;
|
|
|
|
float4 Color : COLOR0;
|
|
|
|
float2 TexCoord : TEXCOORD0;
|
|
|
|
};
|
|
|
|
|
|
|
|
struct VS_INPUT
|
|
|
|
{
|
|
|
|
float4 Position : POSITION;
|
|
|
|
float4 Color : COLOR0;
|
|
|
|
float2 TexCoord : TEXCOORD0;
|
2013-05-22 03:58:38 +02:00
|
|
|
float2 Unused : TEXCOORD1;
|
2011-05-18 02:35:16 +02:00
|
|
|
};
|
|
|
|
|
|
|
|
struct PS_INPUT
|
|
|
|
{
|
|
|
|
float4 Color : COLOR0;
|
|
|
|
float2 TexCoord : TEXCOORD0;
|
|
|
|
};
|
|
|
|
|
|
|
|
//-----------------------------------------------------------------------------
|
2015-12-31 16:32:35 +01:00
|
|
|
// Color-Convolution Vertex Shader
|
2011-05-18 02:35:16 +02:00
|
|
|
//-----------------------------------------------------------------------------
|
|
|
|
|
2013-08-28 02:36:02 +02:00
|
|
|
uniform float2 ScreenDims;
|
2013-08-29 02:56:33 +02:00
|
|
|
uniform float2 SourceDims;
|
2023-01-28 17:59:25 +01:00
|
|
|
uniform float3 PrimTint = float3(1.0f, 1.0f, 1.0f);
|
2011-05-18 02:35:16 +02:00
|
|
|
|
|
|
|
VS_OUTPUT vs_main(VS_INPUT Input)
|
|
|
|
{
|
|
|
|
VS_OUTPUT Output = (VS_OUTPUT)0;
|
2015-12-25 20:02:47 +01:00
|
|
|
|
2011-05-18 02:35:16 +02:00
|
|
|
Output.Position = float4(Input.Position.xyz, 1.0f);
|
2013-08-28 02:36:02 +02:00
|
|
|
Output.Position.xy /= ScreenDims;
|
2015-12-25 20:02:47 +01:00
|
|
|
Output.Position.y = 1.0f - Output.Position.y; // flip y
|
|
|
|
Output.Position.xy -= 0.5f; // center
|
|
|
|
Output.Position.xy *= 2.0f; // zoom
|
|
|
|
|
|
|
|
Output.TexCoord = Input.TexCoord;
|
|
|
|
Output.TexCoord += 0.5f / SourceDims; // half texel offset correction (DX9)
|
|
|
|
|
2011-05-18 02:35:16 +02:00
|
|
|
Output.Color = Input.Color;
|
2023-01-28 17:59:25 +01:00
|
|
|
Output.Color.rgb *= PrimTint;
|
2011-05-18 02:35:16 +02:00
|
|
|
|
|
|
|
return Output;
|
|
|
|
}
|
|
|
|
|
|
|
|
//-----------------------------------------------------------------------------
|
2015-12-31 16:32:35 +01:00
|
|
|
// Color-Convolution Pixel Shader
|
2011-05-18 02:35:16 +02:00
|
|
|
//-----------------------------------------------------------------------------
|
|
|
|
|
2011-06-12 01:46:24 +02:00
|
|
|
uniform float3 RedRatios = float3(1.0f, 0.0f, 0.0f);
|
|
|
|
uniform float3 GrnRatios = float3(0.0f, 1.0f, 0.0f);
|
|
|
|
uniform float3 BluRatios = float3(0.0f, 0.0f, 1.0f);
|
|
|
|
uniform float3 Offset = float3(0.0f, 0.0f, 0.0f);
|
|
|
|
uniform float3 Scale = float3(1.0f, 1.0f, 1.0f);
|
2011-05-18 02:35:16 +02:00
|
|
|
uniform float Saturation = 1.0f;
|
2023-03-19 17:59:44 +01:00
|
|
|
uniform bool LutEnable;
|
2011-05-18 02:35:16 +02:00
|
|
|
|
|
|
|
float4 ps_main(PS_INPUT Input) : COLOR
|
|
|
|
{
|
2011-05-28 02:49:22 +02:00
|
|
|
float4 BaseTexel = tex2D(DiffuseSampler, Input.TexCoord);
|
2015-12-31 16:32:35 +01:00
|
|
|
|
2023-03-19 17:59:44 +01:00
|
|
|
if (LutEnable)
|
|
|
|
BaseTexel.rgb = apply_lut(BaseTexel.rgb);
|
|
|
|
|
2011-05-19 21:14:20 +02:00
|
|
|
float3 OutRGB = BaseTexel.rgb;
|
2011-05-18 02:35:16 +02:00
|
|
|
|
2015-12-25 20:02:47 +01:00
|
|
|
// RGB Tint & Shift
|
2011-06-12 01:46:24 +02:00
|
|
|
float ShiftedRed = dot(OutRGB, RedRatios);
|
|
|
|
float ShiftedGrn = dot(OutRGB, GrnRatios);
|
|
|
|
float ShiftedBlu = dot(OutRGB, BluRatios);
|
2015-12-31 16:32:35 +01:00
|
|
|
|
2015-12-25 20:02:47 +01:00
|
|
|
// RGB Scale & Offset
|
2011-06-12 01:46:24 +02:00
|
|
|
float3 OutTexel = float3(ShiftedRed, ShiftedGrn, ShiftedBlu) * Scale + Offset;
|
2015-12-31 16:32:35 +01:00
|
|
|
|
2015-12-25 20:02:47 +01:00
|
|
|
// Saturation
|
|
|
|
float3 Grayscale = float3(0.299f, 0.587f, 0.114f);
|
|
|
|
float OutLuma = dot(OutTexel, Grayscale);
|
2011-05-19 21:14:20 +02:00
|
|
|
float3 OutChroma = OutTexel - OutLuma;
|
|
|
|
float3 Saturated = OutLuma + OutChroma * Saturation;
|
2015-12-31 16:32:35 +01:00
|
|
|
|
2023-01-28 17:59:25 +01:00
|
|
|
return float4(Saturated * Input.Color.rgb, BaseTexel.a);
|
2011-05-18 02:35:16 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
//-----------------------------------------------------------------------------
|
|
|
|
// Color-Convolution Technique
|
|
|
|
//-----------------------------------------------------------------------------
|
|
|
|
|
2015-12-31 16:32:35 +01:00
|
|
|
technique DefaultTechnique
|
2011-05-18 02:35:16 +02:00
|
|
|
{
|
|
|
|
pass Pass0
|
|
|
|
{
|
|
|
|
Lighting = FALSE;
|
|
|
|
|
|
|
|
VertexShader = compile vs_3_0 vs_main();
|
|
|
|
PixelShader = compile ps_3_0 ps_main();
|
|
|
|
}
|
|
|
|
}
|