最近版本的OpenGL更新以后,所有的固定流水线的功能全部加入到shader里面计算。
兼容模式:最早版本的opengl绘制模式,支持glBegin/glEnd/glVertexPointer/glColorPointer等函数,也支持可编程管线,无显卡要求。
核心模式:现代3D编程模式,较新,不支持glBegin/glEnd/glVertexPointer/glColorPointer等函数,仅支持可编程管线。
兼容模式Shader 和核心模式的Shader不兼容
1.Shader:
//VertexShader:
1
#version 330 core
2data:image/s3,"s3://crabby-images/13de6/13de6130588e8a001331bf125b484ea2f97d951e" alt=""
3
// Input vertex data, different for all executions of this shader.
4
layout(location = 0) in vec3 vertexPosition_modelspace;
5data:image/s3,"s3://crabby-images/13de6/13de6130588e8a001331bf125b484ea2f97d951e" alt=""
6data:image/s3,"s3://crabby-images/f86b7/f86b7e502a0580d5e24db72fe38f81dda2bc052d" alt=""
void main()
{
7
gl_Position.xyz = vertexPosition_modelspace;
8
}
9data:image/s3,"s3://crabby-images/13de6/13de6130588e8a001331bf125b484ea2f97d951e" alt=""
10data:image/s3,"s3://crabby-images/13de6/13de6130588e8a001331bf125b484ea2f97d951e" alt=""
//FragmentShader:
1
#version 330 core
2data:image/s3,"s3://crabby-images/13de6/13de6130588e8a001331bf125b484ea2f97d951e" alt=""
3
// Ouput data
4
out vec3 color;
5data:image/s3,"s3://crabby-images/13de6/13de6130588e8a001331bf125b484ea2f97d951e" alt=""
6data:image/s3,"s3://crabby-images/f86b7/f86b7e502a0580d5e24db72fe38f81dda2bc052d" alt=""
void main()
{
7
// Output color = red
8
color = vec3(1,0,0);
9
} 2.Shader:
Data can be passed from a vertex shader to a fragment shader, using output variables in the vertex shader and corresponding input variables in the fragment shader//VertexShader:
1
#version 330
2data:image/s3,"s3://crabby-images/13de6/13de6130588e8a001331bf125b484ea2f97d951e" alt=""
3
layout (location = 0) in vec4 position;
4
layout (location = 1) in vec4 color;
5data:image/s3,"s3://crabby-images/13de6/13de6130588e8a001331bf125b484ea2f97d951e" alt=""
6
smooth out vec4 theColor;
7data:image/s3,"s3://crabby-images/13de6/13de6130588e8a001331bf125b484ea2f97d951e" alt=""
8data:image/s3,"s3://crabby-images/f86b7/f86b7e502a0580d5e24db72fe38f81dda2bc052d" alt=""
void main()
{
9
gl_Position=position;
10
theColor=color;
11
} //FragmentShader:
1
#version 330
2data:image/s3,"s3://crabby-images/54783/547830fede928f19a3ce63b212a632c66666c748" alt=""
3
smooth in vec4 theColor;
4
out vec4 outputColor;
5data:image/s3,"s3://crabby-images/54783/547830fede928f19a3ce63b212a632c66666c748" alt=""
6data:image/s3,"s3://crabby-images/d8aef/d8aef1ca72194cc1f263ac1b681faa2e7d2ee4af" alt=""
void main()
{
7
outputColor=theColor;
8
}
9data:image/s3,"s3://crabby-images/54783/547830fede928f19a3ce63b212a632c66666c748" alt=""
10data:image/s3,"s3://crabby-images/54783/547830fede928f19a3ce63b212a632c66666c748" alt=""
渲染:
1data:image/s3,"s3://crabby-images/f86b7/f86b7e502a0580d5e24db72fe38f81dda2bc052d" alt=""
void myDispaly()
{
2
glClearColor(0.0f, 0.0f, 0.0f, 0.0f);
3
glClear(GL_COLOR_BUFFER_BIT);
4data:image/s3,"s3://crabby-images/6c6b8/6c6b84e662455f8092d9c42e3a86036cd3a28be1" alt=""
5
GLuint programID = LoadShaders( "vertpositionColor.vert", "fragmentpc.frag" );
6
7
GLuint vertexbuffer;
8
glGenBuffers(1, &vertexbuffer);
9
glBindBuffer(GL_ARRAY_BUFFER, vertexbuffer);
10
glBufferData(GL_ARRAY_BUFFER, sizeof(g_vertex_buffer_data), g_vertex_buffer_data, GL_STATIC_DRAW);
11data:image/s3,"s3://crabby-images/6c6b8/6c6b84e662455f8092d9c42e3a86036cd3a28be1" alt=""
12
glUseProgram(programID);
13
glBindBuffer(GL_ARRAY_BUFFER, vertexbuffer);
14data:image/s3,"s3://crabby-images/6c6b8/6c6b84e662455f8092d9c42e3a86036cd3a28be1" alt=""
15
glEnableVertexAttribArray(0);
16
glEnableVertexAttribArray(1);
17
18
glVertexAttribPointer(0, 4, GL_FLOAT, GL_FALSE, 0, (void*)0 );
19
glVertexAttribPointer(1, 4, GL_FLOAT, GL_FALSE, 0, (void*)48 );
20
21
glDrawArrays(GL_TRIANGLES, 0, 3); // Starting from vertex 0; 3 vertices total -> 1 triangle
22data:image/s3,"s3://crabby-images/6c6b8/6c6b84e662455f8092d9c42e3a86036cd3a28be1" alt=""
23
glDisableVertexAttribArray(0);
24
glDisableVertexAttribArray(1);
25
26
glutSwapBuffers();
27
glUseProgram(0);
28
glDeleteBuffers(1, &vertexbuffer);
29
}
30data:image/s3,"s3://crabby-images/13de6/13de6130588e8a001331bf125b484ea2f97d951e" alt=""
3.Shader:移动
如果不用内置函数来操作,那么可以用shader来实现,首先要计算出物体移动的x y z坐标,然后通过vertex shader来传递:
//vertex shader
1
#version 330 core
2data:image/s3,"s3://crabby-images/13de6/13de6130588e8a001331bf125b484ea2f97d951e" alt=""
3
layout (location = 0) in vec4 position;
4data:image/s3,"s3://crabby-images/13de6/13de6130588e8a001331bf125b484ea2f97d951e" alt=""
5
uniform vec2 offset;
6data:image/s3,"s3://crabby-images/13de6/13de6130588e8a001331bf125b484ea2f97d951e" alt=""
7data:image/s3,"s3://crabby-images/f86b7/f86b7e502a0580d5e24db72fe38f81dda2bc052d" alt=""
void main()
{
8
vec4 totaloffset=vec4(offset.x,offset.y,0,0);
9
gl_Position=position+totaloffset;
10
} uniform变量操作:
1
offsetLocation=glGetUniformLocation(programID,"offset"); 1
glUniform2f(offsetLocation,fXOffset,fYOffset); 4.Shader:透视投影
//vertex shader
1
#version 330 core
2data:image/s3,"s3://crabby-images/54783/547830fede928f19a3ce63b212a632c66666c748" alt=""
3
layout (location = 0) in vec4 position;
4
layout (location = 1) in vec4 Color;
5data:image/s3,"s3://crabby-images/54783/547830fede928f19a3ce63b212a632c66666c748" alt=""
6
smooth out vec4 theColor;
7data:image/s3,"s3://crabby-images/54783/547830fede928f19a3ce63b212a632c66666c748" alt=""
8
uniform vec2 offset;
9
uniform float zNear;
10
uniform float zFar;
11
uniform float frustumScale;
12data:image/s3,"s3://crabby-images/54783/547830fede928f19a3ce63b212a632c66666c748" alt=""
13data:image/s3,"s3://crabby-images/d8aef/d8aef1ca72194cc1f263ac1b681faa2e7d2ee4af" alt=""
void main()
{
14
vec4 cameraPos=position+vec4(offset.x, offset.y, 0, 0);
15
vec4 clipPos;
16data:image/s3,"s3://crabby-images/f74aa/f74aa0daa97912d7a2dcb8fc685747aa4f541b5c" alt=""
17
clipPos.xy=cameraPos.xy*frustumScale;
18data:image/s3,"s3://crabby-images/f74aa/f74aa0daa97912d7a2dcb8fc685747aa4f541b5c" alt=""
19
clipPos.z=cameraPos.z*(zNear + zFar)/(zNear - zFar);
20
clipPos.z+=2*zNear*zFar/(zNear - zFar);
21
22
clipPos.w = -cameraPos.z;
23
24
gl_Position=clipPos;
25
theColor=Color;
26data:image/s3,"s3://crabby-images/f74aa/f74aa0daa97912d7a2dcb8fc685747aa4f541b5c" alt=""
27
} 5.Shader 透视投影版本1
//vertex shader
1
#version 330
2data:image/s3,"s3://crabby-images/54783/547830fede928f19a3ce63b212a632c66666c748" alt=""
3
layout(location = 0) in vec4 position;
4
layout(location = 1) in vec4 color;
5data:image/s3,"s3://crabby-images/54783/547830fede928f19a3ce63b212a632c66666c748" alt=""
6
smooth out vec4 theColor;
7data:image/s3,"s3://crabby-images/54783/547830fede928f19a3ce63b212a632c66666c748" alt=""
8
uniform vec2 offset;
9
uniform mat4 perspectiveMatrix;
10data:image/s3,"s3://crabby-images/54783/547830fede928f19a3ce63b212a632c66666c748" alt=""
11
void main()
12data:image/s3,"s3://crabby-images/d8aef/d8aef1ca72194cc1f263ac1b681faa2e7d2ee4af" alt=""
data:image/s3,"s3://crabby-images/c9e2b/c9e2bc817d66f0a3894ba04ea7703b8e0b7b6162" alt=""
{
13
vec4 cameraPos = position + vec4(offset.x, offset.y, 0.0, 0.0);
14
15
gl_Position = perspectiveMatrix * cameraPos;
16
theColor = color;
17
} 变量传值:
1
offsetUniform = glGetUniformLocation(theProgram, "offset");
2data:image/s3,"s3://crabby-images/54783/547830fede928f19a3ce63b212a632c66666c748" alt=""
3
perspectiveMatrixUnif = glGetUniformLocation(theProgram, "perspectiveMatrix");
4data:image/s3,"s3://crabby-images/54783/547830fede928f19a3ce63b212a632c66666c748" alt=""
5
float fFrustumScale = 1.0f; float fzNear = 0.5f; float fzFar = 3.0f;
6data:image/s3,"s3://crabby-images/54783/547830fede928f19a3ce63b212a632c66666c748" alt=""
7
float theMatrix[16];
8
memset(theMatrix, 0, sizeof(float) * 16);
9data:image/s3,"s3://crabby-images/54783/547830fede928f19a3ce63b212a632c66666c748" alt=""
10
theMatrix[0] = fFrustumScale;
11
theMatrix[5] = fFrustumScale;
12
theMatrix[10] = (fzFar + fzNear) / (fzNear - fzFar);
13
theMatrix[14] = (2 * fzFar * fzNear) / (fzNear - fzFar);
14
theMatrix[11] = -1.0f;
15data:image/s3,"s3://crabby-images/54783/547830fede928f19a3ce63b212a632c66666c748" alt=""
16
glUseProgram(theProgram);
17
glUniformMatrix4fv(perspectiveMatrixUnif, 1, GL_FALSE, theMatrix);
18
glUseProgram(0);