1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
|
Shader "Hidden/Bloom"
{
Properties
{
_MainTex("Texture", 2D) = "white" {}
_BlurOffset("BlurOffset",Float) = 1
}
CGINCLUDE
#include "UnityCG.cginc"
sampler2D _MainTex;
sampler2D _BloomTex;
float4 _MainTex_TexelSize;
float _Threshold;
float _Intensity;
float _BlurRadius;
//阈值
half4 frag_PreFilter(v2f_img i) : SV_Target
{
//提取阈值
half4 d = _MainTex_TexelSize.xyxy * half4(-1,-1,1,1)* _BlurRadius;
half4 color = 0;
color += tex2D(_MainTex, i.uv);
float br = max(max(color.r, color.g), color.b);
br = max(0.0f, (br - _Threshold)) / max(br,0.00001f);
//降采样
color = 0;
color += tex2D(_MainTex, i.uv + d.xy);
color += tex2D(_MainTex, i.uv + d.zy);
color += tex2D(_MainTex, i.uv + d.xw);
color += tex2D(_MainTex, i.uv + d.zw);
color *= 0.25;
color.rgb *= br;
return color;
}
//降采样模糊,BoxBlur
half4 frag_DownsampleBox(v2f_img i) : SV_Target
{
half4 d = _MainTex_TexelSize.xyxy * half4(-1,-1,1,1)* _BlurRadius;
half4 s = 0;
s += tex2D(_MainTex, i.uv + d.xy);
s += tex2D(_MainTex, i.uv + d.zy);
s += tex2D(_MainTex, i.uv + d.xw);
s += tex2D(_MainTex, i.uv + d.zw);
s *= 0.25;
return s;
}
//升采样模糊,BoxBlur
half4 frag_UpsampleBox(v2f_img i) : SV_Target
{
half4 d = _MainTex_TexelSize.xyxy * half4(-1,-1,1,1)* _BlurRadius;
half4 color = 0;
color += tex2D(_MainTex, i.uv + d.xy);
color += tex2D(_MainTex, i.uv + d.zy);
color += tex2D(_MainTex, i.uv + d.xw);
color += tex2D(_MainTex, i.uv + d.zw);
color *= 0.25;
half4 color2 = tex2D(_BloomTex, i.uv);
return color + color2;
}
//合并
half4 frag_Combine(v2f_img i) : SV_Target
{
half4 base_color = tex2D(_MainTex, i.uv);
half4 bloom_color = tex2D(_BloomTex, i.uv);
half3 final_color = base_color.rgb + bloom_color.rgb * _Intensity;
return half4(final_color,1.0);
}
ENDCG
SubShader
{
Cull Off ZWrite Off ZTest Always
//0 阈值
Pass
{
CGPROGRAM
#pragma vertex vert_img
#pragma fragment frag_PreFilter
ENDCG
}
//1 降采样模糊
Pass
{
CGPROGRAM
#pragma vertex vert_img
#pragma fragment frag_DownsampleBox
ENDCG
}
//2 升采样模糊
Pass
{
CGPROGRAM
#pragma vertex vert_img
#pragma fragment frag_UpsampleBox
ENDCG
}
//3 合并
Pass
{
CGPROGRAM
#pragma vertex vert_img
#pragma fragment frag_Combine
ENDCG
}
}
}
|