OpenGL(四)Shader错误 检测
来源:互联网 发布:眼睛很亮女孩子知乎 编辑:程序博客网 时间:2024/06/10 02:34
由于shader不需要预编译,因此在OpenGL动态加载时会碰到 shader错误 。因此需要区分错误属于C++代码还是shader代码。本文主要探讨如何封装检测 shader错误 的接口。
原理
在OpenGL中有方法能够获取到 shader错误 信息。使用:
GLint compileResult = GL_TRUE;glGetShaderiv(shader,GL_COMPILE_STATUS,&compileResult);glGetShaderInfoLog(shader,1024,&logLen,szLog);
可以将产生的错误储存到字符数组szLog
中。 另一方面,使用
GLint linkResult = GL_TRUE;glGetProgramiv(program,GL_LINK_STATUS,&linkResult);glGetProgramInfoLog(program,1024,&logLen,szLog);
可以获得链接程序时候的错误信息。
实现
可以编写加载函数如下:
GLuint CompileShader(GLenum shaderType,const char* shaderPath){ GLuint shader = glCreateShader(shaderType); if(shader == 0) { printf("create shader fail: %s\n",shaderPath); glDeleteShader(shader); return 0; } const char* shaderCode = LoadFileContent(shaderPath); if(shaderCode == nullptr) { printf("load shader code from %s fail\n",shaderPath); glDeleteShader(shader); return 0; } glShaderSource(shader,1,&shaderCode,nullptr); glCompileShader(shader); GLint compileResult = GL_TRUE; glGetShaderiv(shader,GL_COMPILE_STATUS,&compileResult); if(compileResult == GL_FALSE){ char szLog[1024] = {0}; GLsizei logLen = 0; glGetShaderInfoLog(shader,1024,&logLen,szLog); printf("Compile Shader fail error log: %s \nshader code:\n%s\n",szLog,shaderCode); glDeleteShader(shader); shader = 0; } delete shaderCode; return shader;}
最终加载使用下面函数即可:
GLuint CreateGPUProgram(const char* vsShaderPath,const char* fsShaderPath){ GLuint vsShader = CompileShader(GL_VERTEX_SHADER,vsShaderPath); GLuint fsShader = CompileShader(GL_FRAGMENT_SHADER,fsShaderPath); //Attach GLuint program = glCreateProgram(); glAttachShader(program,vsShader); glAttachShader(program,fsShader); //Link glLinkProgram(program); //Clear glDetachShader(program,vsShader); glDetachShader(program,fsShader); glDeleteShader(vsShader); glDeleteShader(fsShader); //check error GLint linkResult = GL_TRUE; glGetProgramiv(program,GL_LINK_STATUS,&linkResult); if(linkResult == GL_FALSE){ char szLog[1024] = {0}; GLsizei logLen = 0; glGetProgramInfoLog(program,1024,&logLen,szLog); printf("Link program fail error log: %s \nvs shader code:\n%s\nfs shader code:\n%s\n",szLog,vsShaderPath,fsShaderPath); glDeleteShader(program); program = 0; } return program;}
总结
通过glGetShaderInfoLog
和glGetProgramInfoLog
两个函数,我们可以获取到程序运行过程中产生的 shader错误 。另一方面,也可以通过这两个接口为其他功能编写函数。
关注我的微信公众号,获取更多优质内容
0 0
- OpenGL(四)Shader错误 检测
- [Modern OpenGL系列(四)]在OpenGL中使用Shader
- 【OpenGL】Shader实例分析(五)- 边缘检测
- 【OpenGL】Shader实例分析(五)- 边缘检测
- 【OpenGL】Shader实例分析(五)- 边缘检测
- opengl shader 学习 随笔四
- OpenGL-shader排除错误方法
- (二)OpenGL中的Shader
- 【OpenGL】Shader实例分析(四)- 照片闪光,圆角和遮罩
- cocos2dx :【OpenGL】Shader实例分析(四)- 照片闪光,圆角和遮罩
- 【OpenGL】Shader实例分析(四)- 照片闪光,圆角和遮罩
- OpenGL Shader
- opengl shader
- opengl shader
- 【OpenGL/ES】 第03讲 OpenGL/ES错误检测
- Shader学习笔记(四)
- OPENGL 纹理贴图 过滤 mipmaps (shader)
- unity 边缘检测shader简介(二)
- git 排错 fatal: 'git status --porcelain' failed in submodule abi/cpp
- java之HttpClient 使用[get/post]
- bootstra查阅参考文档
- Maven集成的Spring框架运行提示Failed to load ApplicationContext.xml
- SQL server安装跨语言失败咋整 求大神帮帮忙
- OpenGL(四)Shader错误 检测
- PS如何快速切图
- 带动画的点击可展开TextView
- xshell操作linux常用命令
- SVN解决不能查看最近提交日志的问题
- OSG3.4 + VS 2015环境配置
- 跳台阶问题(二)
- hdu 5755
- 历届试题 网络寻路 (树上dfs)