opengles图像处理之平滑过滤

本文利用卷积实现图像的平滑过滤,卷积是一种很常见的数字图像处理操作,可以用来过滤一副图像,实现过滤的方法是计算原图像与卷积内核之间的积,所谓卷积内核是指一个nxn的矩阵,n一般为奇数,进行卷积计算时将卷积内核对待处理图像中的每个像素都应用一次。

实现平滑过滤的卷积内核

111
111
111

效果图


核心实现在片元shader中

[cpp]  view plain  copy
  1. precision mediump float;//给出默认浮点精度  
  2. varying vec2 vTextureCoord;//从顶点着色器传递过来的纹理坐标  
  3. uniform sampler2D sTexture;//纹理内容数据  
  4. void main()  
  5. {  
  6.     //给出卷积内核中各个元素对应像素相对于待处理像素的纹理坐标偏移量 3*3内核  
  7.     vec2 offset0=vec2(-1.0,-1.0); vec2 offset1=vec2(0.0,-1.0); vec2 offset2=vec2(1.0,-1.0);  
  8.     vec2 offset3=vec2(-1.0,0.0); vec2 offset4=vec2(0.0,0.0); vec2 offset5=vec2(1.0,0.0);  
  9.     vec2 offset6=vec2(-1.0,1.0); vec2 offset7=vec2(0.0,1.0); vec2 offset8=vec2(1.0,1.0);  
  10.     const float scaleFactor=1.0/9.0;//给出最终求和时的加权因子(调整亮度)  
  11.   
  12.     //卷积内核中各个位置的值  
  13.     float kernelValue0 = 1.0; float kernelValue1 = 1.0; float kernelValue2 = 1.0;  
  14.     float kernelValue3 = 1.0; float kernelValue4 = 1.0; float kernelValue5 = 1.0;  
  15.     float kernelValue6 = 1.0; float kernelValue7 = 1.0; float kernelValue8 = 1.0;  
  16.   
  17.     vec4 sum;//最终的颜色和  
  18.     //获取卷积内核中各个元素对应像素的颜色值  
  19.     vec4 cTemp0,cTemp1,cTemp2,cTemp3,cTemp4,cTemp5,cTemp6,cTemp7,cTemp8;  
  20.     cTemp0=texture2D(sTexture, vTextureCoord.st + offset0.xy/512.0);  
  21.     cTemp1=texture2D(sTexture, vTextureCoord.st + offset1.xy/512.0);  
  22.     cTemp2=texture2D(sTexture, vTextureCoord.st + offset2.xy/512.0);  
  23.     cTemp3=texture2D(sTexture, vTextureCoord.st + offset3.xy/512.0);  
  24.     cTemp4=texture2D(sTexture, vTextureCoord.st + offset4.xy/512.0);  
  25.     cTemp5=texture2D(sTexture, vTextureCoord.st + offset5.xy/512.0);  
  26.     cTemp6=texture2D(sTexture, vTextureCoord.st + offset6.xy/512.0);  
  27.     cTemp7=texture2D(sTexture, vTextureCoord.st + offset7.xy/512.0);  
  28.     cTemp8=texture2D(sTexture, vTextureCoord.st + offset8.xy/512.0);  
  29.     //颜色求和  
  30.     sum =kernelValue0*cTemp0+kernelValue1*cTemp1+kernelValue2*cTemp2+  
  31.              kernelValue3*cTemp3+kernelValue4*cTemp4+kernelValue5*cTemp5+  
  32.              kernelValue6*cTemp6+kernelValue7*cTemp7+kernelValue8*cTemp8;  
  33.     gl_FragColor=sum*scaleFactor;//进行亮度加权后将最终颜色传递给管线  
  34. }  
完整代码下载

http://download.csdn.net/detail/hb707934728/9677655

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值