OpenGL着色语言(GLSL――OpenGL Shading Language)是用来在OpenGL中着色编程的语言,

也即开发人员写的短小的自定义程序,他们是在图形卡的GPU (Graphic Processor Unit图形处理单元)

上执行的,代替了固定的渲染管线的一部分。比如:视图转换、投影转换等。GLSL(GL Shading Language)

的着色器代码分成2个部分:Vertex Shader(顶点着色器)和Fragment(片断着色器)

,有时还会有Geometry Shader(几何着色器)。负责运行顶点着色的是顶点着色器。

它可以得到当前OpenGL 中的状态,GLSL内置变量进行传递。

先看下vertex shader,起设计目的是对应用层输入的顶点数据做处理,我们可以以一个简单的

代码来看下定点处理的过程,可以把下面的过程看成是显卡处理定点数据的过程:

void process( const Vertex& position,Vertex&  gl_Position)
{
gl_Position = gl_ModelViewProjectionMatrix * position;
} for (int i = ;i < vertexCnt ; ++ i )
{
Vertex gl_Position;
process( position[i],Vertex& gl_Position);
//! 对定点数据做其他的处理
}
 

上面的代码中process函数,就是我们要写的shader函数,里面对顶点数据进行处理,处理完成

后交给下一个渲染流程。下面的for循环函数,是又显卡内部控制,当然也是在显卡内完成,即当

我们在应用层调用OpenGL的函数 glVertex**或者glNormal等函数的时候,就是把顶点数据从

cpu传递给GPU,就会调用Process函数进行处理(实际远比我说的复杂)。假设应用层有10万

个顶点做计算,那么Process函数就会被调用10万次。试想这该是多么大的计算量,当然这个相比

纹理来说还是小意思,当我们绘制一个图片处理的时候,每一个像素的绘制都要调用一个类似的处理

过程函数进行处理,假设有一个1024 × 1024 的图片绘制出来,需要的计算量大家可想而知,说

这个的道理在于我们要认识到显卡的强大计算能力。

废话不说,看下面的一个代码片段,我们进行分析:

void main( void )
{
gl_Position = gl_ModelViewProjectionMatrix * gl_Vertex;
}

上述的代码是一个最简单的顶点shader:

gl_Position:是GLSL的一个内置变量,即输出的丁点位置

gl_Vertex:是GLSL的一个内置变量,输入的顶点位置。

gl_ModelViewProjectionMatrix:GLSL的内置变量:

保存了 Project Matrix * View Matrix * Model Matrix的结果

Model Matrix:保存了当前对顶点数据的缩放,旋转,平移等操作

View Matrix :观察矩阵 ,

Project Matrix:就是正交投影,或者透视投影的矩阵(调用 :glOrtho,或者 gluPerspective)

通过上面的介绍,想必大家已经多shader的工作原理已经有所了解了,下面介绍shader的使用步骤:

1.首先编写一个shader,当然是文本方式(其实也可以是汇编方式,或者bin方式,后面介绍)

2.调用glCreateShaderObjectARB创建一个shader对象

3.将源文件(就是shader 的程序)给shader对象

4.进行编译

单独的一个shader对象还不能使用,要想使用它,还需要创建一个shader program 对象,然后进行关联

可以这样来理解,shader object 类似我们编译c++生成的obj文件,将obj文件连接生成一个exe.这个exe

就是shader program了。

5.建立一个shader program

6.关联shader object 到 shader program

7.进行链接

8.使用这个程序。

        const char *source[];
source[] = vertexShaderSource;
//1 创建一个定点shader,理解成对源码进行编译
g_vertexShader = glCreateShaderObjectARB( GL_VERTEX_SHADER_ARB );
//2 指定数据(就是代码)
glShaderSourceARB( g_vertexShader, , source, NULL );
//3 编译
glCompileShaderARB( g_vertexShader);
//4 看编译成功了没有
glGetObjectParameterivARB( g_vertexShader, GL_OBJECT_COMPILE_STATUS_ARB, &bVertCompiled );
//5 编译失败,打印错误的原因
if( bVertCompiled == false )
{
glGetInfoLogARB(g_vertexShader, sizeof(temp), NULL, temp);
MessageBoxA( NULL, temp, "Vertex Shader Compile Error", MB_OK|MB_ICONEXCLAMATION );
}
//6 创建一个程序对象,可以理解成exe
_programObj = glCreateProgramObjectARB();
//7 将顶点shader与程序绑定
glAttachObjectARB( _programObj, g_vertexShader );
//8 链接过程
glLinkProgramARB( _programObj );
glGetObjectParameterivARB( _programObj, GL_OBJECT_LINK_STATUS_ARB, &bLinked );

代码下载

OpenGL12-shader(GLSL)着色语言1(代码已上传)的更多相关文章

  1. OpenGL12-shader(GLSL)着色语言3-(属性参数)(代码已上传)

    上一个例程中,使用了uniform 类型的变量,uniform可以理解为全局变量,这一节中使用 的是attribute类型的变量,翻译过来就是属性,他是与顶点绑定的,就意味着一个顶点可以 有很多个属性 ...

  2. OpenGL12-shader(GLSL)着色语言4-广告版的实现

    之前介绍了vertex shader的基本原理,现在我们来做一个简单的实践,在游戏中广告版(布告版) 随处可见,而且效率很高,现在我们就使用shader来实现这一过程,首先我们要知道布告版的原理 实际 ...

  3. C++向main函数传递参数的方法(实例已上传至github)

    通常情况下,我们定义的main函数都只有空形参列表: int main(){...} 然而,有时我们确实需要给mian传递实参,一种常见的情况是用户设置一组选项来确定函数所要执行的操作.例如,假定ma ...

  4. SWFUpload 已上传成功数量控制 插件(用于解决队列满问题)

    当我们在使用 SWFUpload 做文件上传时,我们需要把已经上传的文件列表做一个删除, 但在我们把已上传列表删除后,再重新上传时,会发现提示 上传队列满 的问题,原因就是有一个状态对象中的一个 成功 ...

  5. python代码git上传

    python代码git上传 1.每次上传代码之前需要先拉取线上的代码 操作如下:

  6. OpenGL12-shader(GLSL)着色语言2-(参数传递)(代码以上传)

    上一篇中介绍了如何使用shader,用来一个最简单的shader,计算顶点的位置,调用了 OpenGL 顶点着色语言中的内置变量对顶点进行操作,这一例程中,将展示如何将应用层 的数据传递到shader ...

  7. GLSL着色语言学习。橙皮书第一个例子GLSL+OpenTK+F#的实现。

    Opengl红皮书有选择的看了一些,最后的讲着色语言GLSL的部分看的甚为不理解,然后找到Opengl橙皮书,然后就容易理解多了. 在前面,我们或多或少接触到Opengl的处理过程,只说前面一些处理, ...

  8. OpenGL10-骨骼动画原理篇(3)-Shader版本代码已经上传

    视频教程请关注 http://edu.csdn.net/lecturer/lecturer_detail?lecturer_id=440 接上一个例程OpenGL10-骨骼动画原理篇(2),对骨骼动画 ...

  9. 利用git工具将自己的代码文件上传到Github

    GitHub 是一个面向开源及私有软件项目的托管平台,作为开源代码库以及版本控制系统,Github拥有超过900万开发者用户.随着越来越多的应用程序转移到了云上,Github已经成为了管理软件开发以及 ...

随机推荐

  1. Codeforces758A Holiday Of Equality 2017-01-20 10:08 48人阅读 评论(0) 收藏

    A. Holiday Of Equality time limit per test 1 second memory limit per test 256 megabytes input standa ...

  2. Linux监控本机当前状态命令

    vmstat 1.简介 vmstat命令是最常见的Linux监控工具,可以查看系统的状态值,其中包括:CPU.内存.虚拟内存.I/O情况. 2.参数说明 命令格式:  vmstat [-a] [-n ...

  3. UniGUI的TUniLoginForm窗口自定义背景色

    uniGUI的TUniLoginForm类创建的登录窗口默认是不带颜色,可以自定义css风格来改变背景颜色. 一般是通过在UniServerModule中,在CustcomSS属性中,修改extjs的 ...

  4. 序列化Json时遇到的大小写问题及解决方法

    最近在一个webapi2项目中遇到了一个问题:C#编码规范中规定属性的首字母是大写的(大多数公司采用这种编码风格),但是从其它系统中接收到的json对象的属性却是小写的(大多数公司采用这种编码风格), ...

  5. Linux SNAT/DNAT简单理解与案例分析。

      在计算机网络中,网络地址转换(Network Address Translation,缩写为NAT),也叫做网络掩蔽或者IP掩蔽(IP masquerading),是一种在IP数据包通过路由器或防 ...

  6. netty--NioEventLoop滴干活

    netty是最近项目要用到的nio框架,找了各种资料,发现称赞它的有点多,所以决定用它:其实也就二选一嘛,mina或netty或自己写.对于mina,也不熟,不过看各种介绍,貌似netty干活还是很不 ...

  7. Git提取两次提交的差异文件

    1. 创建清单文件 获取两次提交之间的文件差异,并将文件清单保存到diff.txt文件中 Git diff --name-only 173d3010 18586360 > diff.txt 2. ...

  8. hbuilder APP服务器端(C#)推送

     实现推送有多种方法和技术手段,我这边是使用三方“个推”去实现对特定用户的推送.我自己是关联业务,对下一步任务代办人进行消息通知.   1 .个推账号申请和配置 1.1.IOS需要推送证书 参考网址: ...

  9. echarts呈现数据表图形

    讲一下echarts的用法,列举了两个图表,一个是单柱图,一个是多柱图,至于饼状图,只许更改echarts的类型就好了 一.首先是要两个div,用来存放两个图表 <div class=" ...

  10. 知识记录:ASP.NET 应用程序生命周期概述及Global.asax文件中的事件

    IIS7 ASP.NET 应用程序生命周期概述 https://msdn.microsoft.com/zh-cn/library/bb470252(v=vs.100).aspx HttpApplica ...