| 
									
										
										
										
											2020-05-18 10:56:22 +02:00
										 |  |  | #[vertex] | 
					
						
							| 
									
										
										
										
											2019-10-03 17:39:08 -03:00
										 |  |  | 
 | 
					
						
							|  |  |  | #version 450 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-04-13 17:01:43 -03:00
										 |  |  | #VERSION_DEFINES | 
					
						
							| 
									
										
										
										
											2019-10-03 17:39:08 -03:00
										 |  |  | 
 | 
					
						
							|  |  |  | struct CellData { | 
					
						
							|  |  |  | 	uint position; // xyz 10 bits | 
					
						
							|  |  |  | 	uint albedo; //rgb albedo | 
					
						
							|  |  |  | 	uint emission; //rgb normalized with e as multiplier | 
					
						
							|  |  |  | 	uint normal; //RGB normal encoded | 
					
						
							|  |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-11-05 12:01:00 +01:00
										 |  |  | layout(set = 0, binding = 1, std140) buffer CellDataBuffer { | 
					
						
							|  |  |  | 	CellData data[]; | 
					
						
							| 
									
										
										
										
											2020-02-11 14:01:43 +01:00
										 |  |  | } | 
					
						
							|  |  |  | cell_data; | 
					
						
							| 
									
										
										
										
											2019-10-03 17:39:08 -03:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-11-05 12:01:00 +01:00
										 |  |  | layout(set = 0, binding = 2) uniform texture3D color_tex; | 
					
						
							| 
									
										
										
										
											2019-10-03 17:39:08 -03:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-11-05 12:01:00 +01:00
										 |  |  | layout(set = 0, binding = 3) uniform sampler tex_sampler; | 
					
						
							| 
									
										
										
										
											2019-10-03 17:39:08 -03:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-02-11 18:40:24 +01:00
										 |  |  | layout(push_constant, std430) uniform Params { | 
					
						
							| 
									
										
										
										
											2019-10-03 17:39:08 -03:00
										 |  |  | 	mat4 projection; | 
					
						
							|  |  |  | 	uint cell_offset; | 
					
						
							|  |  |  | 	float dynamic_range; | 
					
						
							|  |  |  | 	float alpha; | 
					
						
							|  |  |  | 	uint level; | 
					
						
							| 
									
										
										
										
											2019-10-10 23:14:56 -03:00
										 |  |  | 	ivec3 bounds; | 
					
						
							|  |  |  | 	uint pad; | 
					
						
							| 
									
										
										
										
											2020-02-11 14:01:43 +01:00
										 |  |  | } | 
					
						
							|  |  |  | params; | 
					
						
							| 
									
										
										
										
											2019-10-03 17:39:08 -03:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-11-05 12:01:00 +01:00
										 |  |  | layout(location = 0) out vec4 color_interp; | 
					
						
							| 
									
										
										
										
											2019-10-03 17:39:08 -03:00
										 |  |  | 
 | 
					
						
							|  |  |  | void main() { | 
					
						
							|  |  |  | 	const vec3 cube_triangles[36] = vec3[]( | 
					
						
							| 
									
										
										
										
											2019-11-05 12:01:00 +01:00
										 |  |  | 			vec3(-1.0f, -1.0f, -1.0f), | 
					
						
							|  |  |  | 			vec3(-1.0f, -1.0f, 1.0f), | 
					
						
							|  |  |  | 			vec3(-1.0f, 1.0f, 1.0f), | 
					
						
							|  |  |  | 			vec3(1.0f, 1.0f, -1.0f), | 
					
						
							|  |  |  | 			vec3(-1.0f, -1.0f, -1.0f), | 
					
						
							|  |  |  | 			vec3(-1.0f, 1.0f, -1.0f), | 
					
						
							|  |  |  | 			vec3(1.0f, -1.0f, 1.0f), | 
					
						
							|  |  |  | 			vec3(-1.0f, -1.0f, -1.0f), | 
					
						
							|  |  |  | 			vec3(1.0f, -1.0f, -1.0f), | 
					
						
							|  |  |  | 			vec3(1.0f, 1.0f, -1.0f), | 
					
						
							|  |  |  | 			vec3(1.0f, -1.0f, -1.0f), | 
					
						
							|  |  |  | 			vec3(-1.0f, -1.0f, -1.0f), | 
					
						
							|  |  |  | 			vec3(-1.0f, -1.0f, -1.0f), | 
					
						
							|  |  |  | 			vec3(-1.0f, 1.0f, 1.0f), | 
					
						
							|  |  |  | 			vec3(-1.0f, 1.0f, -1.0f), | 
					
						
							|  |  |  | 			vec3(1.0f, -1.0f, 1.0f), | 
					
						
							|  |  |  | 			vec3(-1.0f, -1.0f, 1.0f), | 
					
						
							|  |  |  | 			vec3(-1.0f, -1.0f, -1.0f), | 
					
						
							|  |  |  | 			vec3(-1.0f, 1.0f, 1.0f), | 
					
						
							|  |  |  | 			vec3(-1.0f, -1.0f, 1.0f), | 
					
						
							|  |  |  | 			vec3(1.0f, -1.0f, 1.0f), | 
					
						
							|  |  |  | 			vec3(1.0f, 1.0f, 1.0f), | 
					
						
							|  |  |  | 			vec3(1.0f, -1.0f, -1.0f), | 
					
						
							|  |  |  | 			vec3(1.0f, 1.0f, -1.0f), | 
					
						
							|  |  |  | 			vec3(1.0f, -1.0f, -1.0f), | 
					
						
							|  |  |  | 			vec3(1.0f, 1.0f, 1.0f), | 
					
						
							|  |  |  | 			vec3(1.0f, -1.0f, 1.0f), | 
					
						
							|  |  |  | 			vec3(1.0f, 1.0f, 1.0f), | 
					
						
							|  |  |  | 			vec3(1.0f, 1.0f, -1.0f), | 
					
						
							|  |  |  | 			vec3(-1.0f, 1.0f, -1.0f), | 
					
						
							|  |  |  | 			vec3(1.0f, 1.0f, 1.0f), | 
					
						
							|  |  |  | 			vec3(-1.0f, 1.0f, -1.0f), | 
					
						
							|  |  |  | 			vec3(-1.0f, 1.0f, 1.0f), | 
					
						
							|  |  |  | 			vec3(1.0f, 1.0f, 1.0f), | 
					
						
							|  |  |  | 			vec3(-1.0f, 1.0f, 1.0f), | 
					
						
							|  |  |  | 			vec3(1.0f, -1.0f, 1.0f)); | 
					
						
							| 
									
										
										
										
											2019-10-03 17:39:08 -03:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	vec3 vertex = cube_triangles[gl_VertexIndex] * 0.5 + 0.5; | 
					
						
							| 
									
										
										
										
											2019-10-10 23:14:56 -03:00
										 |  |  | #ifdef MODE_DEBUG_LIGHT_FULL | 
					
						
							| 
									
										
										
										
											2019-11-05 12:01:00 +01:00
										 |  |  | 	uvec3 posu = uvec3(gl_InstanceIndex % params.bounds.x, (gl_InstanceIndex / params.bounds.x) % params.bounds.y, gl_InstanceIndex / (params.bounds.y * params.bounds.x)); | 
					
						
							| 
									
										
										
										
											2019-10-10 23:14:56 -03:00
										 |  |  | #else | 
					
						
							| 
									
										
										
										
											2019-10-03 17:39:08 -03:00
										 |  |  | 	uint cell_index = gl_InstanceIndex + params.cell_offset; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-11-05 12:01:00 +01:00
										 |  |  | 	uvec3 posu = uvec3(cell_data.data[cell_index].position & 0x7FF, (cell_data.data[cell_index].position >> 11) & 0x3FF, cell_data.data[cell_index].position >> 21); | 
					
						
							| 
									
										
										
										
											2019-10-10 23:14:56 -03:00
										 |  |  | #endif | 
					
						
							| 
									
										
										
										
											2019-10-03 17:39:08 -03:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-10-05 10:27:43 -03:00
										 |  |  | #ifdef MODE_DEBUG_EMISSION | 
					
						
							| 
									
										
										
										
											2019-11-05 12:01:00 +01:00
										 |  |  | 	color_interp.xyz = vec3(uvec3(cell_data.data[cell_index].emission & 0x1ff, (cell_data.data[cell_index].emission >> 9) & 0x1ff, (cell_data.data[cell_index].emission >> 18) & 0x1ff)) * pow(2.0, float(cell_data.data[cell_index].emission >> 27) - 15.0 - 9.0); | 
					
						
							| 
									
										
										
										
											2019-10-05 10:27:43 -03:00
										 |  |  | #endif | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-10-03 17:39:08 -03:00
										 |  |  | #ifdef MODE_DEBUG_COLOR | 
					
						
							|  |  |  | 	color_interp.xyz = unpackUnorm4x8(cell_data.data[cell_index].albedo).xyz; | 
					
						
							|  |  |  | #endif | 
					
						
							| 
									
										
										
										
											2019-10-05 10:27:43 -03:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-10-03 17:39:08 -03:00
										 |  |  | #ifdef MODE_DEBUG_LIGHT | 
					
						
							| 
									
										
										
										
											2019-11-05 12:01:00 +01:00
										 |  |  | 	color_interp = texelFetch(sampler3D(color_tex, tex_sampler), ivec3(posu), int(params.level)); | 
					
						
							|  |  |  | 	color_interp.xyz *params.dynamic_range; | 
					
						
							| 
									
										
										
										
											2019-10-03 17:39:08 -03:00
										 |  |  | #endif | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-11-05 12:01:00 +01:00
										 |  |  | 	float scale = (1 << params.level); | 
					
						
							| 
									
										
										
										
											2019-10-03 17:39:08 -03:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-11-05 12:01:00 +01:00
										 |  |  | 	gl_Position = params.projection * vec4((vec3(posu) + vertex) * scale, 1.0); | 
					
						
							| 
									
										
										
										
											2019-10-03 17:39:08 -03:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-10-10 23:14:56 -03:00
										 |  |  | #ifdef MODE_DEBUG_LIGHT_FULL | 
					
						
							|  |  |  | 	if (color_interp.a == 0.0) { | 
					
						
							|  |  |  | 		gl_Position = vec4(0.0); //force clip and not draw | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | #else | 
					
						
							|  |  |  | 	color_interp.a = params.alpha; | 
					
						
							|  |  |  | #endif | 
					
						
							| 
									
										
										
										
											2019-10-03 17:39:08 -03:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-05-18 10:56:22 +02:00
										 |  |  | #[fragment] | 
					
						
							| 
									
										
										
										
											2019-10-03 17:39:08 -03:00
										 |  |  | 
 | 
					
						
							|  |  |  | #version 450 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-04-13 17:01:43 -03:00
										 |  |  | #VERSION_DEFINES | 
					
						
							| 
									
										
										
										
											2019-10-03 17:39:08 -03:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-11-05 12:01:00 +01:00
										 |  |  | layout(location = 0) in vec4 color_interp; | 
					
						
							|  |  |  | layout(location = 0) out vec4 frag_color; | 
					
						
							| 
									
										
										
										
											2019-10-03 17:39:08 -03:00
										 |  |  | 
 | 
					
						
							|  |  |  | void main() { | 
					
						
							|  |  |  | 	frag_color = color_interp; | 
					
						
							| 
									
										
										
										
											2019-10-10 23:14:56 -03:00
										 |  |  | 
 | 
					
						
							|  |  |  | #ifdef MODE_DEBUG_LIGHT_FULL | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	//there really is no alpha, so use dither | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	int x = int(gl_FragCoord.x) % 4; | 
					
						
							|  |  |  | 	int y = int(gl_FragCoord.y) % 4; | 
					
						
							|  |  |  | 	int index = x + y * 4; | 
					
						
							|  |  |  | 	float limit = 0.0; | 
					
						
							|  |  |  | 	if (x < 8) { | 
					
						
							|  |  |  | 		if (index == 0) | 
					
						
							|  |  |  | 			limit = 0.0625; | 
					
						
							|  |  |  | 		if (index == 1) | 
					
						
							|  |  |  | 			limit = 0.5625; | 
					
						
							|  |  |  | 		if (index == 2) | 
					
						
							|  |  |  | 			limit = 0.1875; | 
					
						
							|  |  |  | 		if (index == 3) | 
					
						
							|  |  |  | 			limit = 0.6875; | 
					
						
							|  |  |  | 		if (index == 4) | 
					
						
							|  |  |  | 			limit = 0.8125; | 
					
						
							|  |  |  | 		if (index == 5) | 
					
						
							|  |  |  | 			limit = 0.3125; | 
					
						
							|  |  |  | 		if (index == 6) | 
					
						
							|  |  |  | 			limit = 0.9375; | 
					
						
							|  |  |  | 		if (index == 7) | 
					
						
							|  |  |  | 			limit = 0.4375; | 
					
						
							|  |  |  | 		if (index == 8) | 
					
						
							|  |  |  | 			limit = 0.25; | 
					
						
							|  |  |  | 		if (index == 9) | 
					
						
							|  |  |  | 			limit = 0.75; | 
					
						
							|  |  |  | 		if (index == 10) | 
					
						
							|  |  |  | 			limit = 0.125; | 
					
						
							|  |  |  | 		if (index == 11) | 
					
						
							|  |  |  | 			limit = 0.625; | 
					
						
							|  |  |  | 		if (index == 12) | 
					
						
							|  |  |  | 			limit = 1.0; | 
					
						
							|  |  |  | 		if (index == 13) | 
					
						
							|  |  |  | 			limit = 0.5; | 
					
						
							|  |  |  | 		if (index == 14) | 
					
						
							|  |  |  | 			limit = 0.875; | 
					
						
							|  |  |  | 		if (index == 15) | 
					
						
							|  |  |  | 			limit = 0.375; | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 	if (frag_color.a < limit) { | 
					
						
							|  |  |  | 		discard; | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | #endif | 
					
						
							| 
									
										
										
										
											2019-10-03 17:39:08 -03:00
										 |  |  | } |