mirror of
				https://github.com/OpenMW/openmw.git
				synced 2025-10-25 19:26:39 +00:00 
			
		
		
		
	
		
			
				
	
	
		
			23 lines
		
	
	
	
		
			477 B
		
	
	
	
		
			GLSL
		
	
	
	
	
	
			
		
		
	
	
			23 lines
		
	
	
	
		
			477 B
		
	
	
	
		
			GLSL
		
	
	
	
	
	
| #ifndef LIB_WATER_FRESNEL
 | |
| #define LIB_WATER_FRESNEL
 | |
| 
 | |
| float fresnel_dielectric(vec3 Incoming, vec3 Normal, float eta)
 | |
| {
 | |
|   float c = abs(dot(Incoming, Normal));
 | |
|   float g = eta * eta - 1.0 + c * c;
 | |
|   float result;
 | |
| 
 | |
|   if (g > 0.0) {
 | |
|       g = sqrt(g);
 | |
|       float A =(g - c)/(g + c);
 | |
|       float B =(c *(g + c)- 1.0)/(c *(g - c)+ 1.0);
 | |
|       result = 0.5 * A * A *(1.0 + B * B);
 | |
|   }
 | |
|   else {
 | |
|       result = 1.0;  /* TIR (no refracted component) */
 | |
|   }
 | |
| 
 | |
|   return result;
 | |
| }
 | |
| 
 | |
| #endif
 |