OpenGL着色器无法工作
OpenGL Shader failed to work
我尝试在OpenGL项目中使用自己的顶点着色器和片段着色器。程序本身和着色器程序都已成功编译和链接,但顶点着色器和片段着色器都不起作用。我设法对着色器代码进行了一些更改,但什么也没发生,两个着色器仍然拒绝参与渲染过程。下面是我的代码:
#include<GLglew.h>
#include<GLfreeglut.h>
#include<iostream>
#include<fstream>
#include<string>
#include<assert.h>
using namespace std;
static GLuint VBO_handle = 0;
static GLfloat val = 1.5f;
static GLuint Unif_handle = 0;
static GLuint Program_handle = 0;
static GLuint Shader_handle = 0;
static GLuint Shader_handle2 = 0;
void init()
{
glGenBuffers(1, &VBO_handle);
glBindBuffer(GL_ARRAY_BUFFER, VBO_handle);
GLfloat vertices[] = { 0.0f, 0.8f, 0.0f, -0.8f, -0.8f, 0.0f, 0.8f, -0.8f, 0.0f };
glBufferData(GL_ARRAY_BUFFER, sizeof(vertices), vertices, GL_STATIC_DRAW);
}
void Rendering();
void callback_register()
{
glutDisplayFunc(Rendering);
glutIdleFunc(Rendering);
}
void Rendering()
{
glClear(GL_COLOR_BUFFER_BIT);
glUniform1f(Unif_handle, val);
glEnableVertexAttribArray(0);
glVertexAttribPointer(0, 3, GL_FLOAT, GL_FALSE, 0, 0);
glDrawArrays(GL_TRIANGLES, 0, 3);
glDisableVertexAttribArray(0);
glutSwapBuffers();
}
void ShaderReading()
{
Program_handle = glCreateProgram();
Shader_handle = glCreateShader(GL_VERTEX_SHADER);
std::fstream fin("vertex.vert", std::ios::in);
std::string temp;
while (fin.good())
{
string templine;
getline(fin, templine);
temp += templine;
temp.push_back('n');
}
fin.close();
const GLchar* p[1];
p[0] = temp.c_str();
GLint Lengths[1];
Lengths[0] = temp.size();
glShaderSource(Shader_handle, 1, p, Lengths);
glCompileShader(Shader_handle);
GLint success;
glGetShaderiv(Shader_handle, GL_COMPILE_STATUS, &success);
if (!success) {
GLchar InfoLog[1024];
glGetShaderInfoLog(Shader_handle, 1024, NULL, InfoLog);
fprintf(stderr, "Error compiling shader type %d: '%s'n", GL_VERTEX_SHADER, InfoLog);
exit(1);
}
glAttachShader(Program_handle, Shader_handle);
GLint Success = 0;
GLchar ErrorLog[1024] = { 0 };
Shader_handle2 = glCreateShader(GL_FRAGMENT_SHADER);
fin.open("fragment.frag", std::ios::in);
temp.clear();
while (fin.good())
{
string templine;
getline(fin, templine);
temp += templine;
temp.push_back('n');
}
fin.close();
p[0] = temp.c_str();
Lengths[0] = temp.size();
glShaderSource(Shader_handle2, 1, p, Lengths);
glCompileShader(Shader_handle2);
glGetShaderiv(Shader_handle2, GL_COMPILE_STATUS, &success);
if (!success) {
GLchar InfoLog[1024];
glGetShaderInfoLog(Shader_handle2, 1024, NULL, InfoLog);
fprintf(stderr, "Error compiling shader type %d: '%s'n", GL_VERTEX_SHADER, InfoLog);
exit(1);
}
glAttachShader(Program_handle, Shader_handle2);
Success = 0;
glLinkProgram(Program_handle);
glGetProgramiv(Program_handle, GL_LINK_STATUS, &Success);
if (Success == 0) {
glGetProgramInfoLog(Program_handle, sizeof(ErrorLog), NULL, ErrorLog);
fprintf(stderr, "Error linking shader program: '%s'n", ErrorLog);
exit(1);
}
glValidateProgram(Program_handle);
glGetProgramiv(Program_handle, GL_VALIDATE_STATUS, &Success);
if (!Success) {
glGetProgramInfoLog(Program_handle, sizeof(ErrorLog), NULL, ErrorLog);
fprintf(stderr, "Invalid shader program: '%s'n", ErrorLog);
exit(1);
}
glUseProgram(Shader_handle);
}
int main(int argc, char** argv)
{
glutInit(&argc, argv);
glutInitDisplayMode(GLUT_RGBA | GLUT_DOUBLE);
glutInitWindowSize(600, 600);
glutInitWindowPosition(100, 100);
glutCreateWindow("6666");
callback_register();
GLenum res = glewInit();
if (res != GLEW_OK) {
fprintf(stderr, "Error: '%s'n", glewGetErrorString(res));
return 1;
}
glClearColor(0.0f, 0.0f, 0.0f, 0.0f);
init();
ShaderReading();
glutMainLoop();
return 0;
}
下面是着色器程序,非常简单:(顶点着色器:
#version 330
layout (location = 0) in vec3 Position;
uniform float gScale;
void main()
{
gl_Position = vec4(gScale*Position.x, Position.y, Position.z, 1.0);
}
片段着色器:#版本330
out vec4 FragColor;
void main()
{
FragColor = vec4(1.0, 0.0, 0.0, 1.0);
}
这里有一些小错误:
glUseProgram(Shader_handle);
这实际上应该是Program_handle
。上面的代码应该只是产生一些GL错误,没有任何影响。由于您处于兼容性/传统配置文件中,因此将使用固定函数管道进行绘制,属性0将对顶点位置进行别名。默认颜色将是白色,所以这就是您看到白色三角形的原因。
正如我在评论中已经指出的,你也从来没有查询过你制服的位置,并假设它是零。由于您只使用一种制服,这在一定程度上是可能的——然而,GL规范根本不能保证这一点。你也应该加上这一点。
相关文章:
- 如何使实例化在我的 OpenGL 程序中工作?
- 无法使 opengl 纹理正常工作
- OpenGL 正交相机变焦无法正常工作
- OpenGL应用程序在不同的计算机上的工作方式不同
- GlM(OpenGl Mathematics)库阻止M_PI和其他定义的常量工作
- 现代 OpenGL 多维数据集旋转未按预期工作
- opengl32.lib如何在Windows(仅1.1版本)上工作?它是否真正实现了OpenGL函数
- SFML OpenGL:如何同时与他们一起工作
- OpenGL VAO无法按预期工作
- OpenGL Ping Pong可与一张通行证一起工作,而不是两个通行证
- OpenGL代码在GLFW上工作,但在QT OpenGL上不起作用
- 旧版OpenGL纹理无法正常工作
- 运行Mac OS X C 程序与OpenGL 3.3一起工作
- 具有两个OpenGL图形视图的MFC MDI拆分器无法工作
- glUniform3fv 无法正常工作 OpenGL
- OpenGL着色器无法工作
- OpenGL glTranslatef无法正常工作
- OpenGL顶点属性指针或着色器不工作
- OpenGL的缓冲区是如何工作的?
- 使纹理在OpenGL 3.2中工作