桶形畸变

今天,查找了下桶形畸变,特分享如下:

顶点缓冲区


void main(void)
{
    gl_TexCoord[0] = gl_MultiTexCoord0;
    gl_Position = ftransform();
}


片元着色器


uniform sampler2D colorMap;
const float PI = 3.1415926535;
const float BarrelPower = 0.5;  //可调

vec2 Distort(vec2 p )
{
    float theta = atan(p.y, p.x );
    float radius = length(p);
    radius = pow(radius, BarrelPower);
    p.x = radius * cos(theta);
    p.y = radius * sin(theta);
    return 0.5 * ( p+1.0);
}
void main(void)
{
   vec2 xy = 2.0 * gl_TexCoord[0].xy - 1.0;
   vec2 uv;
   float d = length(xy);
   if( d < 1.0 )
   {
 uv = Distort(xy);
   }
   else
   {
 uv = gl_TexCoord[0].xy;
   }
 
   gl_FragColor = texture2D(colorMap, uv );
}




  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 3
    评论
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值