GLSL实现Image Filter 【转】
http://blog.csdn.net/a3070173/archive/2008/11/27/3390477.aspx
- 图像过滤无论是在作图工具还是特效的实现上都时有运用,这里发一些通常会使用到的图像
- 过滤着色器供有需要的朋友参考.
- 备注:这里列出的都是片元着色器,顶点着色器都是一样地简单变换顶点和传递纹理坐标.
- 高斯过滤 - 常用于进行图像模糊
- 横向过滤:
- const int g_iWeightNumber = 17;
- uniform sampler2D g_FilterTexture; // 被过滤纹理
- uniform float g_aryWeight[g_iWeightNumber]; // Blur权重数组
- uniform vec2 g_aryVerticalOffset[g_iWeightNumber]; // 横向Blur偏移数组
- void main()
- {
- vec4 vec4Sum = vec4(0.0);
- for(int i = 0; i < g_iWeightNumber; ++i)
- {
- vec4Sum += texture2D(g_FilterTexture, gl_TexCoord[0].st + g_aryVerticalOffset[i])*g_aryWeight[i];
- }
- gl_FragColor = vec4Sum;
- }
- 纵向过滤:
- const int g_iWeightNumber = 17;
- uniform sampler2D g_FilterTexture; // 被过滤纹理
- uniform float g_aryWeight[g_iWeightNumber]; // Blur权重数组
- uniform vec2 g_aryHorizontalOffset[g_iWeightNumber]; // 横向Blur偏移数组
- void main()
- {
- vec4 vec4Sum = vec4(0.0);
- for(int i = 0; i < g_iWeightNumber; ++i)
- {
- vec4Sum += texture2D(g_FilterTexture, gl_TexCoord[0].st + g_aryHorizontalOffset[i])*g_aryWeight[i];
- }
- gl_FragColor = vec4Sum;
- }
- Mean过滤 - 用于纹理抗锯齿
- // Mean kernel
- // 1 1 1
- // 1 1 1
- // 1 1 1
- const int g_iWeightNumber = 9;
- uniform sampler2D g_FilterTexture; // 被过滤纹理
- uniform float g_aryWeight[g_iWeightNumber]; // Blur权重数组
- uniform vec2 g_aryOffset[g_iWeightNumber]; // 横向Blur偏移数组
- void main()
- {
- vec4 vec4Sum = vec4(0.0);
- if (gl_TexCoord[0].s < 0.495)
- {
- for(int i = 0; i < g_iWeightNumber; ++i)
- {
- vec4Sum += texture2D(g_FilterTexture, gl_TexCoord[0].st + g_aryOffset[i])*g_aryWeight[i];
- }
- }
- else if (gl_TexCoord[0].s > 0.505)
- {
- vec4Sum = texture2D(g_FilterTexture, gl_TexCoord[0].st);
- }
- else
- {
- vec4Sum = vec4(1.0, 0.0, 0.0, 1.0);
- }
- gl_FragColor = vec4Sum;
- }
- Laplacian过滤 - 用于突显图像轮廓
- // Edge detection kernel (Laplacian filter).
- // 0 -1 0
- // -1 4 -1
- // 0 -1 0
- const int g_iWeightNumber = 9;
- uniform sampler2D g_FilterTexture; // 被过滤纹理
- uniform float g_aryWeight[g_iWeightNumber]; // Blur权重数组
- uniform vec2 g_aryOffset[g_iWeightNumber]; // 横向Blur偏移数组
- void main()
- {
- vec4 vec4Sum = vec4(0.0);
- if (gl_TexCoord[0].s < 0.495)
- {
- for(int i = 0; i < g_iWeightNumber; ++i)
- {
- vec4Sum += texture2D(g_FilterTexture, gl_TexCoord[0].st + g_aryOffset[i])*g_aryWeight[i];
- }
- vec4 vec4BaseColor = texture2D(g_FilterTexture, gl_TexCoord[0].st);
- vec4Sum += vec4BaseColor*0.1;
- }
- else if (gl_TexCoord[0].s > 0.505)
- {
- vec4Sum = texture2D(g_FilterTexture, gl_TexCoord[0].st);
- }
- else
- {
- vec4Sum = vec4(1.0, 0.0, 0.0, 1.0);
- }
- gl_FragColor = vec4Sum;
- }
- Emboss过滤 - used to simulate the relief of an image
- // Emboss filter
- // 2 0 0
- // 0 -1 0
- // 0 0 -1
- const int g_iWeightNumber = 9;
- uniform sampler2D g_FilterTexture; // 被过滤纹理
- uniform float g_aryWeight[g_iWeightNumber]; // Blur权重数组
- uniform vec2 g_aryOffset[g_iWeightNumber]; // 横向Blur偏移数组
- void main()
- {
- vec4 vec4Sum = vec4(0.0);
- if (gl_TexCoord[0].s < 0.495)
- {
- for(int i = 0; i < g_iWeightNumber; ++i)
- {
- vec4Sum += texture2D(g_FilterTexture, gl_TexCoord[0].st + g_aryOffset[i])*g_aryWeight[i];
- }
- vec4Sum += 0.5;
- }
- else if (gl_TexCoord[0].s > 0.505)
- {
- vec4Sum = texture2D(g_FilterTexture, gl_TexCoord[0].st);
- }
- else
- {
- vec4Sum = vec4(1.0, 0.0, 0.0, 1.0);
- }
- gl_FragColor = vec4Sum;
- }
- Sharpness过滤 - 突显图像的细节
- // Sharpness filter
- // -1 -1 -1
- // -1 9 -1
- // -1 -1 -1
- const int g_iWeightNumber = 9;
- uniform sampler2D g_FilterTexture; // 被过滤纹理
- uniform float g_aryWeight[g_iWeightNumber]; // Blur权重数组
- uniform vec2 g_aryOffset[g_iWeightNumber]; // 横向Blur偏移数组
- void main()
- {
- vec4 vec4Sum = vec4(0.0);
- if (gl_TexCoord[0].s < 0.495)
- {
- for(int i = 0; i < g_iWeightNumber; ++i)
- {
- vec4Sum += texture2D(g_FilterTexture, gl_TexCoord[0].st + g_aryOffset[i])*g_aryWeight[i];
- }
- }
- else if (gl_TexCoord[0].s > 0.505)
- {
- vec4Sum = texture2D(g_FilterTexture, gl_TexCoord[0].st);
- }
- else
- {
- vec4Sum = vec4(1.0, 0.0, 0.0, 1.0);
- }
- gl_FragColor = vec4Sum;
- }
- Demo效果截图:
- exe文件:http://www.fileupyours.com/view/219112/GLSL/Image%20Filter%20Demo.rar
GLSL实现Image Filter 【转】的更多相关文章
- mipmap一
讲一下mipmap 生成的时候 指定texture 的mipmaplevel 8 然后memory自动就会那么大的 画的时候要在lineraspace(因为我是gpucopy所以不涉及这个问题 可能) ...
- django 操作数据库--orm(object relation mapping)---models
思想 django为使用一种新的方式,即:关系对象映射(Object Relational Mapping,简称ORM). PHP:activerecord Java:Hibernate C#:Ent ...
- GLSL实现Glow效果 [转]
http://blog.csdn.net/a3070173/archive/2008/11/04/3220940.aspx Glow即辉光效果现在已成为3D图形中一个引人注目的特效.本文主要介绍如何使 ...
- GLSL/C++ 实现滤镜效果
入门效果之浮雕 "浮雕"图象效果是指图像的前景前向凸出背景.常见于一些纪念碑的雕刻上.要实现浮雕事实上很easy.我们把图象的一个象素和左上方的象素进行求差运算.并加上一个灰度.这 ...
- GLSL实现Glow效果 【转】
http://blog.csdn.net/a3070173/article/details/3220940 Glow即辉光效果现在已成为3D图形中一个引人注目的特效.本文主要介绍如何使用GLSL实现一 ...
- JavaWeb——Filter
一.基本概念 之前我们用一篇博文介绍了Servlet相关的知识,有了那篇博文的知识积淀,今天我们学习Filter将会非常轻松,因为Filter有很多地方和Servlet类似,下面在讲Filter的时候 ...
- 使用Visual Studio SDK制作GLSL词法着色插件
使用Visual Studio SDK制作GLSL词法着色插件 我们在Visual Studio上开发OpenGL ES项目时,避免不了写Shader.这时在vs里直接编辑shader就会显得很方便. ...
- 以bank account 数据为例,认识elasticsearch query 和 filter
Elasticsearch 查询语言(Query DSL)认识(一) 一.基本认识 查询子句的行为取决于 query context filter context 也就是执行的是查询(query)还是 ...
- AngularJS过滤器filter-保留小数,小数点-$filter
AngularJS 保留小数 默认是保留3位 固定的套路是 {{deom | number:4}} 意思就是保留小数点 的后四位 在渲染页面的时候 加入这儿个代码 用来精确浮点数,指定小数点 ...
随机推荐
- Enter回车切换输入焦点方法兼容各大浏览器
做项目时,客户要求能够用enter回车直接切换输入(焦点),当最后一个时候,直接提交信息. 第一想法就是,网上去copy一段代码直接用.但了百度.谷歌找了个遍,找到的代码80%以上都是一样的.有的代码 ...
- pssh 不能执行指定用户命令
问题: 一个脚本a.sh(必须root用户执行),在本地可以运行,通过pssh -h ip_file "cd /home/byte/a.sh"不能执行. 原因: 分析应该是ssh ...
- linux笔记_20150417_ubuntu 常见问题_文件_音乐播放器
最近在学习ubuntu的过程中,遇到了一些问题,就记下来了它的解决办法.以希望对你也有用. ),至少保证周围局域网内用户可以访问.至于配置文件,内容比较少,反正对我来讲能用就ok了~不知道会不会很弱 ...
- 大数据处理-bitmap是个神马东西
1. Bit Map算法简介 所谓的Bit-map就是用一个bit位来标记某个元素对应的Value, 而Key即是该元素.由于采用了Bit为单位来存储数据,因此在存储空间方面,可以大大节省. 2. B ...
- Python 多线程学习(转)
转自:http://www.cnblogs.com/slider/archive/2012/06/20/2556256.html 引言 对于 Python 来说,并不缺少并发选项,其标准库中包括了对线 ...
- ps 图片提取线稿方法2种 转
- 精选PSD素材下载周刊【Goodfav PSD 20130720】
我们每周精选来自Goodfav PSD的免费PSD素材,有兴趣的朋友尤其是做设计工作的,不妨收藏或者下载. 这些现成的PSD素材能给我们一些相关的灵感,从而提高工作的效率. 1.File Upload ...
- APT攻击将向云计算平台聚焦
APT攻击作为一种高效.精确的网络攻击方式,在近几年被频繁用于各种网络攻击事件之中,并迅速成为企业信息安全最大的威胁之一. 近日,飞塔中国首席技术顾问X在谈及APT攻击时表示,随着云计算的不断发展普及 ...
- [翻译]Behavior-Driven Development (BDD)行为驱动开发(一)
简单而言,BDD是一系列基于TDD的工具和方法集发展而来的开发模式,一般不认为是一种新的开发模式,而是作为TDD的补充.因此,首先对TDD的概念进行进行. 测试驱动开发(TDD) TDD模式采取的是迭 ...
- 数据结构(C语言版)---第三章栈和队列 3.4.2 队列的链式表示和实现(循环队列)
这个是循环队列的实现,至于串及数组这两章,等有空再看,下面将学习树. 源码如下: #include <stdio.h> #include <stdlib.h> #define ...