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已经成为了管理软件开发以及 ...
随机推荐
- ORBSlam with ROS
...相机标定 calibration 基本就是做CV 的常识 ORBSlam源码:
- n&&m and n||m 的区别
今天写一道题老是WA最后才发现问题出在了这个地方, 题目说的是当输入的n和m 都为0的时候,结束输入. 于是乎,条件我就写成了while(n&&m),其实这句话的意思是:只有m和n都不 ...
- Hibernate多对多双向关联需要注意的问题(实例说话)
以Student和Course为例,一个学生可以选多门课程,一门课程也可以被多个学生选取: 持久化类Student: package bean; import java.util.Set; publi ...
- Android-Java-了解编译
在多年以前,计算机早期的运行方式是 01010100 ....., 这种方式的时候,开发人员编写代码是把01010101/01100101/01010111 ..... /来汇编写代码,这种方式特别痛 ...
- Configure Pi as simulation hardware for Simulink
1. Only version not older than R2013 supports Raspberry Pi. First, download support package in Matla ...
- 运行spark官方的graphx 示例 ComprehensiveExample.scala报错解决
运行spark官方的graphx 示例 ComprehensiveExample.scala报错解决 在Idea中,直接运行ComprehensiveExample.scala,报需要指定master ...
- 用eFrameWork框架实现快捷搜索
软件系统最大的价值在于用心去帮客户解决各种痛点,需要做好方方面面的工作,数据的快捷搜索就是其中比较重要的一个环节.那么,什么样的搜索方式才是最高效快捷的呢?目前能想到最好的办法是用名称声母检索,用声母 ...
- Spring Batch学习笔记(一)
Spring Batch简介 Spring Batch提供了可重复使用的功能,用来处理大量数据.包括记录.跟踪,事务管理,作业处理统计,作业重启,跳过和资源管理. 此外还提供了更高级的技术服务和功能, ...
- SQL查询和替换含有回车,空格,TAB,等
---如下是查询语句 --查询名称有退格键 ),item_name) go --查询名称有制表符tab ),item_name) go --查询名称有换行 ),item_name) go --查询名称 ...
- Asp.net MVC4 记录在线用户数及登录时长
Global.asax.cs文件 public class MvcApplication : System.Web.HttpApplication { /// <summary> /// ...