| 
									
										
										
										
											2016-09-17 13:33:02 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-05-17 10:46:42 +10:00
										 |  |  | flat in vec4 color_flat; | 
					
						
							|  |  |  | noperspective in vec2 texCoord_interp; | 
					
						
							| 
									
										
										
											
												BLF: Optimize text rendering and caching
The current code allocates and transfers a lot of memory to the GPU,
but only a small portion of this memory is actually used.
In addition, the code calls many costly gl operations during the
caching process.
This commit significantly reduce the amount of memory by allocating
and transferring a flat array without pads to the GPU.
It also calls as little as possible the gl operations during the cache.
This code also simulate a billinear filter `GL_LINEAR` using a 1D texture.
**Average drawing time:**
|before:|0.00003184 sec
|now:|0.00001943 sec
|fac:|1.6385156675048407
**5 worst times:**
|before:|[0.001075, 0.001433, 0.002143, 0.002915, 0.003242]
|now:|[0.00094, 0.000993, 0.001502, 0.002284, 0.002328]
Differential Revision: https://developer.blender.org/D6886
											
										 
											2020-02-23 17:30:27 -03:00
										 |  |  | flat in int glyph_offset; | 
					
						
							|  |  |  | flat in ivec2 glyph_dim; | 
					
						
							|  |  |  | flat in int interp_size; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-05-17 10:46:42 +10:00
										 |  |  | out vec4 fragColor; | 
					
						
							| 
									
										
										
										
											2016-09-17 13:33:02 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
											
												BLF: Optimize text rendering and caching
The current code allocates and transfers a lot of memory to the GPU,
but only a small portion of this memory is actually used.
In addition, the code calls many costly gl operations during the
caching process.
This commit significantly reduce the amount of memory by allocating
and transferring a flat array without pads to the GPU.
It also calls as little as possible the gl operations during the cache.
This code also simulate a billinear filter `GL_LINEAR` using a 1D texture.
**Average drawing time:**
|before:|0.00003184 sec
|now:|0.00001943 sec
|fac:|1.6385156675048407
**5 worst times:**
|before:|[0.001075, 0.001433, 0.002143, 0.002915, 0.003242]
|now:|[0.00094, 0.000993, 0.001502, 0.002284, 0.002328]
Differential Revision: https://developer.blender.org/D6886
											
										 
											2020-02-23 17:30:27 -03:00
										 |  |  | uniform sampler1DArray glyph; | 
					
						
							| 
									
										
										
										
											2016-09-17 13:33:02 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-04-08 01:00:55 +02:00
										 |  |  | const vec2 offsets4[4] = vec2[4]( | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |     vec2(-0.5, 0.5), vec2(0.5, 0.5), vec2(-0.5, -0.5), vec2(-0.5, -0.5)); | 
					
						
							| 
									
										
										
										
											2018-04-08 00:44:35 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  | const vec2 offsets16[16] = vec2[16](vec2(-1.5, 1.5), | 
					
						
							|  |  |  |                                     vec2(-0.5, 1.5), | 
					
						
							|  |  |  |                                     vec2(0.5, 1.5), | 
					
						
							|  |  |  |                                     vec2(1.5, 1.5), | 
					
						
							|  |  |  |                                     vec2(-1.5, 0.5), | 
					
						
							|  |  |  |                                     vec2(-0.5, 0.5), | 
					
						
							|  |  |  |                                     vec2(0.5, 0.5), | 
					
						
							|  |  |  |                                     vec2(1.5, 0.5), | 
					
						
							|  |  |  |                                     vec2(-1.5, -0.5), | 
					
						
							|  |  |  |                                     vec2(-0.5, -0.5), | 
					
						
							|  |  |  |                                     vec2(0.5, -0.5), | 
					
						
							|  |  |  |                                     vec2(1.5, -0.5), | 
					
						
							|  |  |  |                                     vec2(-1.5, -1.5), | 
					
						
							|  |  |  |                                     vec2(-0.5, -1.5), | 
					
						
							|  |  |  |                                     vec2(0.5, -1.5), | 
					
						
							|  |  |  |                                     vec2(1.5, -1.5)); | 
					
						
							| 
									
										
										
										
											2018-04-08 00:44:35 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
											
												BLF: Optimize text rendering and caching
The current code allocates and transfers a lot of memory to the GPU,
but only a small portion of this memory is actually used.
In addition, the code calls many costly gl operations during the
caching process.
This commit significantly reduce the amount of memory by allocating
and transferring a flat array without pads to the GPU.
It also calls as little as possible the gl operations during the cache.
This code also simulate a billinear filter `GL_LINEAR` using a 1D texture.
**Average drawing time:**
|before:|0.00003184 sec
|now:|0.00001943 sec
|fac:|1.6385156675048407
**5 worst times:**
|before:|[0.001075, 0.001433, 0.002143, 0.002915, 0.003242]
|now:|[0.00094, 0.000993, 0.001502, 0.002284, 0.002328]
Differential Revision: https://developer.blender.org/D6886
											
										 
											2020-02-23 17:30:27 -03:00
										 |  |  | //#define GPU_NEAREST | 
					
						
							| 
									
										
										
										
											2020-02-25 15:11:33 +01:00
										 |  |  | #define sample_glyph_offset(texel, ofs) \ | 
					
						
							|  |  |  |   texture_1D_custom_bilinear_filter(texCoord_interp + ofs * texel) | 
					
						
							| 
									
										
										
											
												BLF: Optimize text rendering and caching
The current code allocates and transfers a lot of memory to the GPU,
but only a small portion of this memory is actually used.
In addition, the code calls many costly gl operations during the
caching process.
This commit significantly reduce the amount of memory by allocating
and transferring a flat array without pads to the GPU.
It also calls as little as possible the gl operations during the cache.
This code also simulate a billinear filter `GL_LINEAR` using a 1D texture.
**Average drawing time:**
|before:|0.00003184 sec
|now:|0.00001943 sec
|fac:|1.6385156675048407
**5 worst times:**
|before:|[0.001075, 0.001433, 0.002143, 0.002915, 0.003242]
|now:|[0.00094, 0.000993, 0.001502, 0.002284, 0.002328]
Differential Revision: https://developer.blender.org/D6886
											
										 
											2020-02-23 17:30:27 -03:00
										 |  |  | 
 | 
					
						
							|  |  |  | float texel_fetch(int index) | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2020-02-25 15:11:33 +01:00
										 |  |  |   int size_x = textureSize(glyph, 0).r; | 
					
						
							|  |  |  |   if (index >= size_x) { | 
					
						
							|  |  |  |     return texelFetch(glyph, ivec2(index % size_x, index / size_x), 0).r; | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  |   return texelFetch(glyph, ivec2(index, 0), 0).r; | 
					
						
							| 
									
										
										
											
												BLF: Optimize text rendering and caching
The current code allocates and transfers a lot of memory to the GPU,
but only a small portion of this memory is actually used.
In addition, the code calls many costly gl operations during the
caching process.
This commit significantly reduce the amount of memory by allocating
and transferring a flat array without pads to the GPU.
It also calls as little as possible the gl operations during the cache.
This code also simulate a billinear filter `GL_LINEAR` using a 1D texture.
**Average drawing time:**
|before:|0.00003184 sec
|now:|0.00001943 sec
|fac:|1.6385156675048407
**5 worst times:**
|before:|[0.001075, 0.001433, 0.002143, 0.002915, 0.003242]
|now:|[0.00094, 0.000993, 0.001502, 0.002284, 0.002328]
Differential Revision: https://developer.blender.org/D6886
											
										 
											2020-02-23 17:30:27 -03:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | bool is_inside_box(ivec2 v) | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2020-02-25 15:11:33 +01:00
										 |  |  |   return all(greaterThanEqual(v, ivec2(0))) && all(lessThan(v, glyph_dim)); | 
					
						
							| 
									
										
										
											
												BLF: Optimize text rendering and caching
The current code allocates and transfers a lot of memory to the GPU,
but only a small portion of this memory is actually used.
In addition, the code calls many costly gl operations during the
caching process.
This commit significantly reduce the amount of memory by allocating
and transferring a flat array without pads to the GPU.
It also calls as little as possible the gl operations during the cache.
This code also simulate a billinear filter `GL_LINEAR` using a 1D texture.
**Average drawing time:**
|before:|0.00003184 sec
|now:|0.00001943 sec
|fac:|1.6385156675048407
**5 worst times:**
|before:|[0.001075, 0.001433, 0.002143, 0.002915, 0.003242]
|now:|[0.00094, 0.000993, 0.001502, 0.002284, 0.002328]
Differential Revision: https://developer.blender.org/D6886
											
										 
											2020-02-23 17:30:27 -03:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | float texture_1D_custom_bilinear_filter(vec2 uv) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |   vec2 texel_2d = uv * glyph_dim + 0.5; | 
					
						
							|  |  |  |   ivec2 texel_2d_near = ivec2(texel_2d) - 1; | 
					
						
							|  |  |  |   int frag_offset = glyph_offset + texel_2d_near.y * glyph_dim.x + texel_2d_near.x; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   float tl = 0.0; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   if (is_inside_box(texel_2d_near)) { | 
					
						
							|  |  |  |     tl = texel_fetch(frag_offset); | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #ifdef GPU_NEAREST | 
					
						
							|  |  |  |   return tl; | 
					
						
							| 
									
										
										
										
											2020-02-25 15:11:33 +01:00
										 |  |  | #else  // GPU_LINEAR | 
					
						
							| 
									
										
										
											
												BLF: Optimize text rendering and caching
The current code allocates and transfers a lot of memory to the GPU,
but only a small portion of this memory is actually used.
In addition, the code calls many costly gl operations during the
caching process.
This commit significantly reduce the amount of memory by allocating
and transferring a flat array without pads to the GPU.
It also calls as little as possible the gl operations during the cache.
This code also simulate a billinear filter `GL_LINEAR` using a 1D texture.
**Average drawing time:**
|before:|0.00003184 sec
|now:|0.00001943 sec
|fac:|1.6385156675048407
**5 worst times:**
|before:|[0.001075, 0.001433, 0.002143, 0.002915, 0.003242]
|now:|[0.00094, 0.000993, 0.001502, 0.002284, 0.002328]
Differential Revision: https://developer.blender.org/D6886
											
										 
											2020-02-23 17:30:27 -03:00
										 |  |  |   int offset_x = 1; | 
					
						
							|  |  |  |   int offset_y = glyph_dim.x; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   float tr = 0.0; | 
					
						
							|  |  |  |   float bl = 0.0; | 
					
						
							|  |  |  |   float br = 0.0; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   if (is_inside_box(texel_2d_near + ivec2(1, 0))) { | 
					
						
							|  |  |  |     tr = texel_fetch(frag_offset + offset_x); | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  |   if (is_inside_box(texel_2d_near + ivec2(0, 1))) { | 
					
						
							|  |  |  |     bl = texel_fetch(frag_offset + offset_y); | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  |   if (is_inside_box(texel_2d_near + ivec2(1, 1))) { | 
					
						
							|  |  |  |     br = texel_fetch(frag_offset + offset_x + offset_y); | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   vec2 f = fract(texel_2d); | 
					
						
							|  |  |  |   float tA = mix(tl, tr, f.x); | 
					
						
							|  |  |  |   float tB = mix(bl, br, f.x); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   return mix(tA, tB, f.y); | 
					
						
							|  |  |  | #endif | 
					
						
							|  |  |  | } | 
					
						
							| 
									
										
										
										
											2018-04-08 00:44:35 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-09-17 13:33:02 +02:00
										 |  |  | void main() | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |   // input color replaces texture color | 
					
						
							|  |  |  |   fragColor.rgb = color_flat.rgb; | 
					
						
							| 
									
										
										
										
											2016-09-17 13:33:02 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |   // modulate input alpha & texture alpha | 
					
						
							| 
									
										
										
											
												BLF: Optimize text rendering and caching
The current code allocates and transfers a lot of memory to the GPU,
but only a small portion of this memory is actually used.
In addition, the code calls many costly gl operations during the
caching process.
This commit significantly reduce the amount of memory by allocating
and transferring a flat array without pads to the GPU.
It also calls as little as possible the gl operations during the cache.
This code also simulate a billinear filter `GL_LINEAR` using a 1D texture.
**Average drawing time:**
|before:|0.00003184 sec
|now:|0.00001943 sec
|fac:|1.6385156675048407
**5 worst times:**
|before:|[0.001075, 0.001433, 0.002143, 0.002915, 0.003242]
|now:|[0.00094, 0.000993, 0.001502, 0.002284, 0.002328]
Differential Revision: https://developer.blender.org/D6886
											
										 
											2020-02-23 17:30:27 -03:00
										 |  |  |   if (interp_size == 0) { | 
					
						
							|  |  |  |     fragColor.a = texture_1D_custom_bilinear_filter(texCoord_interp); | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |   } | 
					
						
							|  |  |  |   else { | 
					
						
							| 
									
										
										
											
												BLF: Optimize text rendering and caching
The current code allocates and transfers a lot of memory to the GPU,
but only a small portion of this memory is actually used.
In addition, the code calls many costly gl operations during the
caching process.
This commit significantly reduce the amount of memory by allocating
and transferring a flat array without pads to the GPU.
It also calls as little as possible the gl operations during the cache.
This code also simulate a billinear filter `GL_LINEAR` using a 1D texture.
**Average drawing time:**
|before:|0.00003184 sec
|now:|0.00001943 sec
|fac:|1.6385156675048407
**5 worst times:**
|before:|[0.001075, 0.001433, 0.002143, 0.002915, 0.003242]
|now:|[0.00094, 0.000993, 0.001502, 0.002284, 0.002328]
Differential Revision: https://developer.blender.org/D6886
											
										 
											2020-02-23 17:30:27 -03:00
										 |  |  |     vec2 texel = 1.0 / glyph_dim; | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |     fragColor.a = 0.0; | 
					
						
							| 
									
										
										
										
											2018-04-08 00:44:35 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
											
												BLF: Optimize text rendering and caching
The current code allocates and transfers a lot of memory to the GPU,
but only a small portion of this memory is actually used.
In addition, the code calls many costly gl operations during the
caching process.
This commit significantly reduce the amount of memory by allocating
and transferring a flat array without pads to the GPU.
It also calls as little as possible the gl operations during the cache.
This code also simulate a billinear filter `GL_LINEAR` using a 1D texture.
**Average drawing time:**
|before:|0.00003184 sec
|now:|0.00001943 sec
|fac:|1.6385156675048407
**5 worst times:**
|before:|[0.001075, 0.001433, 0.002143, 0.002915, 0.003242]
|now:|[0.00094, 0.000993, 0.001502, 0.002284, 0.002328]
Differential Revision: https://developer.blender.org/D6886
											
										 
											2020-02-23 17:30:27 -03:00
										 |  |  |     if (interp_size == 1) { | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |       /* 3x3 blur */ | 
					
						
							|  |  |  |       /* Manual unroll for perf. (stupid glsl compiler) */ | 
					
						
							| 
									
										
										
											
												BLF: Optimize text rendering and caching
The current code allocates and transfers a lot of memory to the GPU,
but only a small portion of this memory is actually used.
In addition, the code calls many costly gl operations during the
caching process.
This commit significantly reduce the amount of memory by allocating
and transferring a flat array without pads to the GPU.
It also calls as little as possible the gl operations during the cache.
This code also simulate a billinear filter `GL_LINEAR` using a 1D texture.
**Average drawing time:**
|before:|0.00003184 sec
|now:|0.00001943 sec
|fac:|1.6385156675048407
**5 worst times:**
|before:|[0.001075, 0.001433, 0.002143, 0.002915, 0.003242]
|now:|[0.00094, 0.000993, 0.001502, 0.002284, 0.002328]
Differential Revision: https://developer.blender.org/D6886
											
										 
											2020-02-23 17:30:27 -03:00
										 |  |  |       fragColor.a += sample_glyph_offset(texel, offsets4[0]); | 
					
						
							|  |  |  |       fragColor.a += sample_glyph_offset(texel, offsets4[1]); | 
					
						
							|  |  |  |       fragColor.a += sample_glyph_offset(texel, offsets4[2]); | 
					
						
							|  |  |  |       fragColor.a += sample_glyph_offset(texel, offsets4[3]); | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |       fragColor.a *= (1.0 / 4.0); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     else { | 
					
						
							|  |  |  |       /* 5x5 blur */ | 
					
						
							|  |  |  |       /* Manual unroll for perf. (stupid glsl compiler) */ | 
					
						
							| 
									
										
										
											
												BLF: Optimize text rendering and caching
The current code allocates and transfers a lot of memory to the GPU,
but only a small portion of this memory is actually used.
In addition, the code calls many costly gl operations during the
caching process.
This commit significantly reduce the amount of memory by allocating
and transferring a flat array without pads to the GPU.
It also calls as little as possible the gl operations during the cache.
This code also simulate a billinear filter `GL_LINEAR` using a 1D texture.
**Average drawing time:**
|before:|0.00003184 sec
|now:|0.00001943 sec
|fac:|1.6385156675048407
**5 worst times:**
|before:|[0.001075, 0.001433, 0.002143, 0.002915, 0.003242]
|now:|[0.00094, 0.000993, 0.001502, 0.002284, 0.002328]
Differential Revision: https://developer.blender.org/D6886
											
										 
											2020-02-23 17:30:27 -03:00
										 |  |  |       fragColor.a += sample_glyph_offset(texel, offsets16[0]); | 
					
						
							|  |  |  |       fragColor.a += sample_glyph_offset(texel, offsets16[1]); | 
					
						
							|  |  |  |       fragColor.a += sample_glyph_offset(texel, offsets16[2]); | 
					
						
							|  |  |  |       fragColor.a += sample_glyph_offset(texel, offsets16[3]); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       fragColor.a += sample_glyph_offset(texel, offsets16[4]); | 
					
						
							|  |  |  |       fragColor.a += sample_glyph_offset(texel, offsets16[5]) * 2.0; | 
					
						
							|  |  |  |       fragColor.a += sample_glyph_offset(texel, offsets16[6]) * 2.0; | 
					
						
							|  |  |  |       fragColor.a += sample_glyph_offset(texel, offsets16[7]); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       fragColor.a += sample_glyph_offset(texel, offsets16[8]); | 
					
						
							|  |  |  |       fragColor.a += sample_glyph_offset(texel, offsets16[9]) * 2.0; | 
					
						
							|  |  |  |       fragColor.a += sample_glyph_offset(texel, offsets16[10]) * 2.0; | 
					
						
							|  |  |  |       fragColor.a += sample_glyph_offset(texel, offsets16[11]); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       fragColor.a += sample_glyph_offset(texel, offsets16[12]); | 
					
						
							|  |  |  |       fragColor.a += sample_glyph_offset(texel, offsets16[13]); | 
					
						
							|  |  |  |       fragColor.a += sample_glyph_offset(texel, offsets16[14]); | 
					
						
							|  |  |  |       fragColor.a += sample_glyph_offset(texel, offsets16[15]); | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |       fragColor.a *= (1.0 / 20.0); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |   } | 
					
						
							| 
									
										
										
										
											2018-04-08 00:44:35 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |   fragColor.a *= color_flat.a; | 
					
						
							| 
									
										
										
										
											2020-07-18 04:25:56 +02:00
										 |  |  |   fragColor = blender_srgb_to_framebuffer_space(fragColor); | 
					
						
							| 
									
										
										
										
											2016-09-17 13:33:02 +02:00
										 |  |  | } |