mirror of
				https://github.com/luanti-org/luanti.git
				synced 2025-10-26 21:35:28 +01:00 
			
		
		
		
	
		
			
				
	
	
		
			50 lines
		
	
	
		
			1.1 KiB
		
	
	
	
		
			GLSL
		
	
	
	
	
	
			
		
		
	
	
			50 lines
		
	
	
		
			1.1 KiB
		
	
	
	
		
			GLSL
		
	
	
	
	
	
| uniform mat4 LightMVP; // world matrix
 | |
| uniform vec4 CameraPos; // camera position
 | |
| varying vec4 tPos;
 | |
| 
 | |
| uniform float xyPerspectiveBias0;
 | |
| uniform float xyPerspectiveBias1;
 | |
| uniform float zPerspectiveBias;
 | |
| 
 | |
| #ifdef GL_ES
 | |
| varying mediump vec2 varTexCoord;
 | |
| #else
 | |
| centroid varying vec2 varTexCoord;
 | |
| #endif
 | |
| 
 | |
| vec4 getRelativePosition(in vec4 position)
 | |
| {
 | |
| 	vec2 l = position.xy - CameraPos.xy;
 | |
| 	vec2 s = l / abs(l);
 | |
| 	s = (1.0 - s * CameraPos.xy);
 | |
| 	l /= s;
 | |
| 	return vec4(l, s);
 | |
| }
 | |
| 
 | |
| float getPerspectiveFactor(in vec4 relativePosition)
 | |
| {
 | |
| 	float pDistance = length(relativePosition.xy);
 | |
| 	float pFactor = pDistance * xyPerspectiveBias0 + xyPerspectiveBias1;
 | |
| 	return pFactor;
 | |
| }
 | |
| 
 | |
| vec4 applyPerspectiveDistortion(in vec4 position)
 | |
| {
 | |
| 	vec4 l = getRelativePosition(position);
 | |
| 	float pFactor = getPerspectiveFactor(l);
 | |
| 	l.xy /= pFactor;
 | |
| 	position.xy = l.xy * l.zw + CameraPos.xy;
 | |
| 	position.z *= zPerspectiveBias;
 | |
| 	return position;
 | |
| }
 | |
| 
 | |
| void main()
 | |
| {
 | |
| 	vec4 pos = LightMVP * inVertexPosition;
 | |
| 
 | |
| 	tPos = applyPerspectiveDistortion(pos);
 | |
| 
 | |
| 	gl_Position = vec4(tPos.xyz, 1.0);
 | |
| 	varTexCoord = (mTexture * vec4(inTexCoord0.xy, 0.0, 1.0)).xy;
 | |
| }
 |