http://blog.csdn.net/a3070173/archive/2008/11/27/3390477.aspx

  1. 图像过滤无论是在作图工具还是特效的实现上都时有运用,这里发一些通常会使用到的图像
  2. 过滤着色器供有需要的朋友参考.
  3. 备注:这里列出的都是片元着色器,顶点着色器都是一样地简单变换顶点和传递纹理坐标.
  4. 高斯过滤 - 常用于进行图像模糊
  5. 横向过滤:
  6. const int g_iWeightNumber = 17;
  7. uniform sampler2D g_FilterTexture;  // 被过滤纹理
  8. uniform float g_aryWeight[g_iWeightNumber]; // Blur权重数组
  9. uniform vec2 g_aryVerticalOffset[g_iWeightNumber];  // 横向Blur偏移数组
  10. void main()
  11. {
  12. vec4 vec4Sum = vec4(0.0);
  13. for(int i = 0; i < g_iWeightNumber; ++i)
  14. {
  15. vec4Sum += texture2D(g_FilterTexture, gl_TexCoord[0].st + g_aryVerticalOffset[i])*g_aryWeight[i];
  16. }
  17. gl_FragColor = vec4Sum;
  18. }
  19. 纵向过滤:
  20. const int g_iWeightNumber = 17;
  21. uniform sampler2D g_FilterTexture;  // 被过滤纹理
  22. uniform float g_aryWeight[g_iWeightNumber]; // Blur权重数组
  23. uniform vec2 g_aryHorizontalOffset[g_iWeightNumber];    // 横向Blur偏移数组
  24. void main()
  25. {
  26. vec4 vec4Sum = vec4(0.0);
  27. for(int i = 0; i < g_iWeightNumber; ++i)
  28. {
  29. vec4Sum += texture2D(g_FilterTexture, gl_TexCoord[0].st + g_aryHorizontalOffset[i])*g_aryWeight[i];
  30. }
  31. gl_FragColor = vec4Sum;
  32. }
  33. Mean过滤 - 用于纹理抗锯齿
  34. // Mean kernel
  35. // 1 1 1
  36. // 1 1 1
  37. // 1 1 1
  38. const int g_iWeightNumber = 9;
  39. uniform sampler2D g_FilterTexture;  // 被过滤纹理
  40. uniform float g_aryWeight[g_iWeightNumber]; // Blur权重数组
  41. uniform vec2 g_aryOffset[g_iWeightNumber];  // 横向Blur偏移数组
  42. void main()
  43. {
  44. vec4 vec4Sum = vec4(0.0);
  45. if (gl_TexCoord[0].s < 0.495)
  46. {
  47. for(int i = 0; i < g_iWeightNumber; ++i)
  48. {
  49. vec4Sum += texture2D(g_FilterTexture, gl_TexCoord[0].st + g_aryOffset[i])*g_aryWeight[i];
  50. }
  51. }
  52. else if (gl_TexCoord[0].s > 0.505)
  53. {
  54. vec4Sum = texture2D(g_FilterTexture, gl_TexCoord[0].st);
  55. }
  56. else
  57. {
  58. vec4Sum = vec4(1.0, 0.0, 0.0, 1.0);
  59. }
  60. gl_FragColor = vec4Sum;
  61. }
  62. Laplacian过滤 - 用于突显图像轮廓
  63. // Edge detection kernel (Laplacian filter).
  64. // 0  -1 0
  65. // -1  4 -1
  66. // 0  -1 0
  67. const int g_iWeightNumber = 9;
  68. uniform sampler2D g_FilterTexture;  // 被过滤纹理
  69. uniform float g_aryWeight[g_iWeightNumber]; // Blur权重数组
  70. uniform vec2 g_aryOffset[g_iWeightNumber];  // 横向Blur偏移数组
  71. void main()
  72. {
  73. vec4 vec4Sum = vec4(0.0);
  74. if (gl_TexCoord[0].s < 0.495)
  75. {
  76. for(int i = 0; i < g_iWeightNumber; ++i)
  77. {
  78. vec4Sum += texture2D(g_FilterTexture, gl_TexCoord[0].st + g_aryOffset[i])*g_aryWeight[i];
  79. }
  80. vec4 vec4BaseColor = texture2D(g_FilterTexture, gl_TexCoord[0].st);
  81. vec4Sum += vec4BaseColor*0.1;
  82. }
  83. else if (gl_TexCoord[0].s > 0.505)
  84. {
  85. vec4Sum = texture2D(g_FilterTexture, gl_TexCoord[0].st);
  86. }
  87. else
  88. {
  89. vec4Sum = vec4(1.0, 0.0, 0.0, 1.0);
  90. }
  91. gl_FragColor = vec4Sum;
  92. }
  93. Emboss过滤 - used to simulate the relief of an image
  94. // Emboss filter
  95. // 2   0  0
  96. // 0  -1  0
  97. // 0   0  -1
  98. const int g_iWeightNumber = 9;
  99. uniform sampler2D g_FilterTexture;  // 被过滤纹理
  100. uniform float g_aryWeight[g_iWeightNumber]; // Blur权重数组
  101. uniform vec2 g_aryOffset[g_iWeightNumber];  // 横向Blur偏移数组
  102. void main()
  103. {
  104. vec4 vec4Sum = vec4(0.0);
  105. if (gl_TexCoord[0].s < 0.495)
  106. {
  107. for(int i = 0; i < g_iWeightNumber; ++i)
  108. {
  109. vec4Sum += texture2D(g_FilterTexture, gl_TexCoord[0].st + g_aryOffset[i])*g_aryWeight[i];
  110. }
  111. vec4Sum += 0.5;
  112. }
  113. else if (gl_TexCoord[0].s > 0.505)
  114. {
  115. vec4Sum = texture2D(g_FilterTexture, gl_TexCoord[0].st);
  116. }
  117. else
  118. {
  119. vec4Sum = vec4(1.0, 0.0, 0.0, 1.0);
  120. }
  121. gl_FragColor = vec4Sum;
  122. }
  123. Sharpness过滤 - 突显图像的细节
  124. // Sharpness filter
  125. // -1  -1  -1
  126. // -1   9  -1
  127. // -1  -1  -1
  128. const int g_iWeightNumber = 9;
  129. uniform sampler2D g_FilterTexture;  // 被过滤纹理
  130. uniform float g_aryWeight[g_iWeightNumber]; // Blur权重数组
  131. uniform vec2 g_aryOffset[g_iWeightNumber];  // 横向Blur偏移数组
  132. void main()
  133. {
  134. vec4 vec4Sum = vec4(0.0);
  135. if (gl_TexCoord[0].s < 0.495)
  136. {
  137. for(int i = 0; i < g_iWeightNumber; ++i)
  138. {
  139. vec4Sum += texture2D(g_FilterTexture, gl_TexCoord[0].st + g_aryOffset[i])*g_aryWeight[i];
  140. }
  141. }
  142. else if (gl_TexCoord[0].s > 0.505)
  143. {
  144. vec4Sum = texture2D(g_FilterTexture, gl_TexCoord[0].st);
  145. }
  146. else
  147. {
  148. vec4Sum = vec4(1.0, 0.0, 0.0, 1.0);
  149. }
  150. gl_FragColor = vec4Sum;
  151. }
  152. Demo效果截图:
  153. exe文件:http://www.fileupyours.com/view/219112/GLSL/Image%20Filter%20Demo.rar

GLSL实现Image Filter 【转】的更多相关文章

  1. mipmap一

    讲一下mipmap 生成的时候 指定texture 的mipmaplevel 8 然后memory自动就会那么大的 画的时候要在lineraspace(因为我是gpucopy所以不涉及这个问题 可能) ...

  2. django 操作数据库--orm(object relation mapping)---models

    思想 django为使用一种新的方式,即:关系对象映射(Object Relational Mapping,简称ORM). PHP:activerecord Java:Hibernate C#:Ent ...

  3. GLSL实现Glow效果 [转]

    http://blog.csdn.net/a3070173/archive/2008/11/04/3220940.aspx Glow即辉光效果现在已成为3D图形中一个引人注目的特效.本文主要介绍如何使 ...

  4. GLSL/C++ 实现滤镜效果

    入门效果之浮雕 "浮雕"图象效果是指图像的前景前向凸出背景.常见于一些纪念碑的雕刻上.要实现浮雕事实上很easy.我们把图象的一个象素和左上方的象素进行求差运算.并加上一个灰度.这 ...

  5. GLSL实现Glow效果 【转】

    http://blog.csdn.net/a3070173/article/details/3220940 Glow即辉光效果现在已成为3D图形中一个引人注目的特效.本文主要介绍如何使用GLSL实现一 ...

  6. JavaWeb——Filter

    一.基本概念 之前我们用一篇博文介绍了Servlet相关的知识,有了那篇博文的知识积淀,今天我们学习Filter将会非常轻松,因为Filter有很多地方和Servlet类似,下面在讲Filter的时候 ...

  7. 使用Visual Studio SDK制作GLSL词法着色插件

    使用Visual Studio SDK制作GLSL词法着色插件 我们在Visual Studio上开发OpenGL ES项目时,避免不了写Shader.这时在vs里直接编辑shader就会显得很方便. ...

  8. 以bank account 数据为例,认识elasticsearch query 和 filter

    Elasticsearch 查询语言(Query DSL)认识(一) 一.基本认识 查询子句的行为取决于 query context filter context 也就是执行的是查询(query)还是 ...

  9. AngularJS过滤器filter-保留小数,小数点-$filter

    AngularJS      保留小数 默认是保留3位 固定的套路是 {{deom | number:4}} 意思就是保留小数点 的后四位 在渲染页面的时候 加入这儿个代码 用来精确浮点数,指定小数点 ...

随机推荐

  1. SQL查询数据库信息, 数据库表名, 数据库表信息

    SQL查询数据库信息, 数据库表名, 数据库表信息 ---------------------------------------------- -- 以下例子, 在sql_server 中可以直接运 ...

  2. C#判断程序是由Windows服务启动还是用户启动

    在Windows系统做网络开发,很多时候都是使用Windows服务的模式,但在调度阶段,我们更多的是使用控制台的模式.在开发程序的时候,我们在Program的Main入口进行判断.最初开始使用Envi ...

  3. 11个实用经典的SQL小贴士

    学习工作之余,在没有要解决问题的压力之下,还是建议系统的看看书,对于一些认为没啥用的知识点,也建议去仔细的看看,练练手,说不定什么时候就用到了,到时也好有针对性的去查,不至于盲目的按照自己的思路,重复 ...

  4. Android中设置全屏的方法

    在实际的应用程序开发中,我们有时需要把 Activity 设置成全屏显示,一般情况下,可以通过两种方式来设置全屏显示效果.其一,通过在代码中可以设置,其二,通过manifest配置文件来设置全屏. 其 ...

  5. hip-hop初探

    啥都不说了,上两张图片先 1.使用hiphop的 2.不使用这玩意的 都是前端部署nginx,转发的后面php的 hhvm的配置文件 /etc/hhvm.hdf 目前结论:facebook的这玩意可能 ...

  6. 第三百三十一天 how can I 坚持

    今天加了一天班,好累,还没吃晚饭,回来只吃了个泡面. 晚上回来的路上,在群里聊的倒是很happy,快笑死我了,仲宫二少,哈哈. 弟弟过两天要去见面,多聊聊,该结婚来. 还有,中午吃的肯德基,不好吃,可 ...

  7. 第一百九十四天 how can I坚持

    该挺妈妈话的,不该买可乐,该熬点粥喝,肚子疼,救我. 好像每天都一样,每天都在重复.. 哎.. 对了,买了点花种子,铜钱草,牡丹.玫瑰.还买了棵小多肉. 还有,老妈把咸菜给邮过来了,有点期待啊. 连续 ...

  8. 每天学一点-Jquery判断checkbox是否为选中状态

    if ($("#ctl00_ContentPlaceHolder1_IsLimitedService").attr("checked") ==true)

  9. unigui MessageDlg方法调用例子

    procedure TfrmEmployee.btnDeleteClick(Sender: TObject);var aBool: Boolean;begin inherited; MessageDl ...

  10. Python输入输出(IO)

    程序会有输入和输出,输入可以从标准输入或是从一个文件读入数据,程序的输出可以以一种友好可读的方式(human-readable)打印出来,或是写进一个文件,而标准输入和标准输出(键盘和显示器)在程序的 ...