OpenGL12-shader(GLSL)着色语言1(代码已上传)

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(代码已上传)的更多相关文章
- OpenGL12-shader(GLSL)着色语言3-(属性参数)(代码已上传)
上一个例程中,使用了uniform 类型的变量,uniform可以理解为全局变量,这一节中使用 的是attribute类型的变量,翻译过来就是属性,他是与顶点绑定的,就意味着一个顶点可以 有很多个属性 ...
- OpenGL12-shader(GLSL)着色语言4-广告版的实现
之前介绍了vertex shader的基本原理,现在我们来做一个简单的实践,在游戏中广告版(布告版) 随处可见,而且效率很高,现在我们就使用shader来实现这一过程,首先我们要知道布告版的原理 实际 ...
- C++向main函数传递参数的方法(实例已上传至github)
通常情况下,我们定义的main函数都只有空形参列表: int main(){...} 然而,有时我们确实需要给mian传递实参,一种常见的情况是用户设置一组选项来确定函数所要执行的操作.例如,假定ma ...
- SWFUpload 已上传成功数量控制 插件(用于解决队列满问题)
当我们在使用 SWFUpload 做文件上传时,我们需要把已经上传的文件列表做一个删除, 但在我们把已上传列表删除后,再重新上传时,会发现提示 上传队列满 的问题,原因就是有一个状态对象中的一个 成功 ...
- python代码git上传
python代码git上传 1.每次上传代码之前需要先拉取线上的代码 操作如下:
- OpenGL12-shader(GLSL)着色语言2-(参数传递)(代码以上传)
上一篇中介绍了如何使用shader,用来一个最简单的shader,计算顶点的位置,调用了 OpenGL 顶点着色语言中的内置变量对顶点进行操作,这一例程中,将展示如何将应用层 的数据传递到shader ...
- GLSL着色语言学习。橙皮书第一个例子GLSL+OpenTK+F#的实现。
Opengl红皮书有选择的看了一些,最后的讲着色语言GLSL的部分看的甚为不理解,然后找到Opengl橙皮书,然后就容易理解多了. 在前面,我们或多或少接触到Opengl的处理过程,只说前面一些处理, ...
- OpenGL10-骨骼动画原理篇(3)-Shader版本代码已经上传
视频教程请关注 http://edu.csdn.net/lecturer/lecturer_detail?lecturer_id=440 接上一个例程OpenGL10-骨骼动画原理篇(2),对骨骼动画 ...
- 利用git工具将自己的代码文件上传到Github
GitHub 是一个面向开源及私有软件项目的托管平台,作为开源代码库以及版本控制系统,Github拥有超过900万开发者用户.随着越来越多的应用程序转移到了云上,Github已经成为了管理软件开发以及 ...
随机推荐
- C语言中union关键字
union 关键字的用法与struct 的用法非常类似. union 维护足够的空间来置放多个数据成员中的“一种”,而不是为每一个数据成员配置空间,在union 中所有的数据成员共用一个空间,同一时间 ...
- Gridview的RowDataBound事件可以做很多事情
protected void gvTest_RowDataBound(object sender, GridViewRowEventArgs e) { //如果是绑 ...
- 【最大流之Dinic算法】POJ1273 【 & 当前弧优化 & 】
总评一句:Dinic算法的基本思想比较好理解,就是它的当前弧优化的思想,网上的资料也不多,所以对于当前弧的优化,我还是费了很大的功夫的,现在也一知半解,索性就写一篇博客,来发现自己哪里的算法思想还没理 ...
- TFS Java SDK使用指南
[2018.3.6 更新] 最新版本的TFS Java SDK(14.123.1)支持Java SDK 1.6版本,可以从Oracle的官方网站(http://www.oracle.com/techn ...
- Javascript设计模式理论与实战:状态模式
在软件开发中,很大部分时候就是操作数据,而不同数据下展示的结果我们将其抽象出来称为状态,我们平时开发时本质上就是对应用程序的各种状态进行切换并作出相应处理.状态模式就是一种适合多种状态场景下的设计模式 ...
- 排序算法之堆排序(Heapsort)解析
一.堆排序的优缺点(pros and cons) (还是简单的说说这个,毕竟没有必要浪费时间去理解一个糟糕的的算法) 优点: 堆排序的效率与快排.归并相同,都达到了基于比较的排序算法效率的峰值(时间复 ...
- json--pyton中obj与json的互转,js中obj与json的互转
json 解释:json是一种跨平台的通用的数据格式 python中对象(obj)与json之间的相互转换 1.对象(obj)转json格式的字符串 json.dumps(res) res = () ...
- asp .net api 日志
方法1:继承IExceptionLogger ExceptionLogger是框架提供的表示未处理的异常记录器的抽象类 public class RecordExceptionLogger : Exc ...
- Tomcat 7.x/8.x 优化
一.优化Connector http://www.aikaiyuan.com/8466.html tomcat的运行模式有3种 1)bio 默认的模式,性能非常低下,没有经过任何优化处理和支持. 2) ...
- Day 1. 占位符的使用方法(%d,%s)(格式化输出)
方法1 name = input("请输入名字1") age = input ("请输入年龄") hobby = input("请输入兴趣爱好&qu ...