forked from eden-emu/eden
		
	SwRasterizer/Lighting: unify float suffix
This commit is contained in:
		
							parent
							
								
									35bbf67e6e
								
							
						
					
					
						commit
						4fe16d80bd
					
				
					 1 changed files with 13 additions and 11 deletions
				
			
		|  | @ -143,8 +143,8 @@ std::tuple<Math::Vec4<u8>, Math::Vec4<u8>> ComputeFragmentsColors( | ||||||
|     // Use the normalized the quaternion when performing the rotation
 |     // Use the normalized the quaternion when performing the rotation
 | ||||||
|     auto normal = Math::QuaternionRotate(normquat.Normalized(), surface_normal); |     auto normal = Math::QuaternionRotate(normquat.Normalized(), surface_normal); | ||||||
| 
 | 
 | ||||||
|     Math::Vec4<float> diffuse_sum = {0.f, 0.f, 0.f, 1.f}; |     Math::Vec4<float> diffuse_sum = {0.0f, 0.0f, 0.0f, 1.0f}; | ||||||
|     Math::Vec4<float> specular_sum = {0.f, 0.f, 0.f, 1.f}; |     Math::Vec4<float> specular_sum = {0.0f, 0.0f, 0.0f, 1.0f}; | ||||||
| 
 | 
 | ||||||
|     for (unsigned light_index = 0; light_index <= lighting.max_light_index; ++light_index) { |     for (unsigned light_index = 0; light_index <= lighting.max_light_index; ++light_index) { | ||||||
|         unsigned num = lighting.light_enable.GetNum(light_index); |         unsigned num = lighting.light_enable.GetNum(light_index); | ||||||
|  | @ -174,7 +174,7 @@ std::tuple<Math::Vec4<u8>, Math::Vec4<u8>> ComputeFragmentsColors( | ||||||
|             float sample_loc = scale * distance + bias; |             float sample_loc = scale * distance + bias; | ||||||
| 
 | 
 | ||||||
|             u8 lutindex = |             u8 lutindex = | ||||||
|                 static_cast<u8>(MathUtil::Clamp(std::floor(sample_loc * 256.f), 0.0f, 255.0f)); |                 static_cast<u8>(MathUtil::Clamp(std::floor(sample_loc * 256.0f), 0.0f, 255.0f)); | ||||||
|             float delta = sample_loc * 256 - lutindex; |             float delta = sample_loc * 256 - lutindex; | ||||||
|             dist_atten = LookupLightingLut(lighting_state, lut, lutindex, delta); |             dist_atten = LookupLightingLut(lighting_state, lut, lutindex, delta); | ||||||
|         } |         } | ||||||
|  | @ -206,7 +206,7 @@ std::tuple<Math::Vec4<u8>, Math::Vec4<u8>> ComputeFragmentsColors( | ||||||
|             default: |             default: | ||||||
|                 LOG_CRITICAL(HW_GPU, "Unknown lighting LUT input %u\n", static_cast<u32>(input)); |                 LOG_CRITICAL(HW_GPU, "Unknown lighting LUT input %u\n", static_cast<u32>(input)); | ||||||
|                 UNIMPLEMENTED(); |                 UNIMPLEMENTED(); | ||||||
|                 result = 0.f; |                 result = 0.0f; | ||||||
|             } |             } | ||||||
| 
 | 
 | ||||||
|             u8 index; |             u8 index; | ||||||
|  | @ -218,13 +218,13 @@ std::tuple<Math::Vec4<u8>, Math::Vec4<u8>> ComputeFragmentsColors( | ||||||
|                 else |                 else | ||||||
|                     result = std::max(result, 0.0f); |                     result = std::max(result, 0.0f); | ||||||
| 
 | 
 | ||||||
|                 float flr = std::floor(result * 256.f); |                 float flr = std::floor(result * 256.0f); | ||||||
|                 index = static_cast<u8>(MathUtil::Clamp(flr, 0.0f, 255.0f)); |                 index = static_cast<u8>(MathUtil::Clamp(flr, 0.0f, 255.0f)); | ||||||
|                 delta = result * 256 - index; |                 delta = result * 256 - index; | ||||||
|             } else { |             } else { | ||||||
|                 float flr = std::floor(result * 128.f); |                 float flr = std::floor(result * 128.0f); | ||||||
|                 s8 signed_index = static_cast<s8>(MathUtil::Clamp(flr, -128.0f, 127.0f)); |                 s8 signed_index = static_cast<s8>(MathUtil::Clamp(flr, -128.0f, 127.0f)); | ||||||
|                 delta = result * 128.f - signed_index; |                 delta = result * 128.0f - signed_index; | ||||||
|                 index = static_cast<u8>(signed_index); |                 index = static_cast<u8>(signed_index); | ||||||
|             } |             } | ||||||
| 
 | 
 | ||||||
|  | @ -278,6 +278,7 @@ std::tuple<Math::Vec4<u8>, Math::Vec4<u8>> ComputeFragmentsColors( | ||||||
|             refl_value.z = refl_value.x; |             refl_value.z = refl_value.x; | ||||||
|         } |         } | ||||||
| 
 | 
 | ||||||
|  |         // Specular 1 component
 | ||||||
|         float d1_lut_value = 1.0f; |         float d1_lut_value = 1.0f; | ||||||
|         if (lighting.config1.disable_lut_d1 == 0 && |         if (lighting.config1.disable_lut_d1 == 0 && | ||||||
|             LightingRegs::IsLightingSamplerSupported( |             LightingRegs::IsLightingSamplerSupported( | ||||||
|  | @ -290,6 +291,7 @@ std::tuple<Math::Vec4<u8>, Math::Vec4<u8>> ComputeFragmentsColors( | ||||||
|         Math::Vec3<float> specular_1 = |         Math::Vec3<float> specular_1 = | ||||||
|             d1_lut_value * refl_value * light_config.specular_1.ToVec3f(); |             d1_lut_value * refl_value * light_config.specular_1.ToVec3f(); | ||||||
| 
 | 
 | ||||||
|  |         // Fresnel
 | ||||||
|         if (lighting.config1.disable_lut_fr == 0 && |         if (lighting.config1.disable_lut_fr == 0 && | ||||||
|             LightingRegs::IsLightingSamplerSupported(lighting.config0.config, |             LightingRegs::IsLightingSamplerSupported(lighting.config0.config, | ||||||
|                                                      LightingRegs::LightingSampler::Fresnel)) { |                                                      LightingRegs::LightingSampler::Fresnel)) { | ||||||
|  | @ -319,10 +321,10 @@ std::tuple<Math::Vec4<u8>, Math::Vec4<u8>> ComputeFragmentsColors( | ||||||
|         // product.
 |         // product.
 | ||||||
|         float clamp_highlights = 1.0f; |         float clamp_highlights = 1.0f; | ||||||
|         if (lighting.config0.clamp_highlights) { |         if (lighting.config0.clamp_highlights) { | ||||||
|             if (dot_product <= 0.f) |             if (dot_product <= 0.0f) | ||||||
|                 clamp_highlights = 0.f; |                 clamp_highlights = 0.0f; | ||||||
|             else |             else | ||||||
|                 clamp_highlights = 1.f; |                 clamp_highlights = 1.0f; | ||||||
|         } |         } | ||||||
| 
 | 
 | ||||||
|         if (light_config.config.two_sided_diffuse) |         if (light_config.config.two_sided_diffuse) | ||||||
|  | @ -335,7 +337,7 @@ std::tuple<Math::Vec4<u8>, Math::Vec4<u8>> ComputeFragmentsColors( | ||||||
|         diffuse_sum += Math::MakeVec(diffuse * dist_atten, 0.0f); |         diffuse_sum += Math::MakeVec(diffuse * dist_atten, 0.0f); | ||||||
| 
 | 
 | ||||||
|         specular_sum += |         specular_sum += | ||||||
|             Math::MakeVec((specular_0 + specular_1) * clamp_highlights * dist_atten, 0.f); |             Math::MakeVec((specular_0 + specular_1) * clamp_highlights * dist_atten, 0.0f); | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     diffuse_sum += Math::MakeVec(lighting.global_ambient.ToVec3f(), 0.0f); |     diffuse_sum += Math::MakeVec(lighting.global_ambient.ToVec3f(), 0.0f); | ||||||
|  |  | ||||||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue
	
	 wwylele
						wwylele