1
0
mirror of https://github.com/TomHarte/CLK.git synced 2025-01-12 00:30:31 +00:00

Filled in shader class.

This commit is contained in:
Thomas Harte 2016-02-07 19:21:22 -05:00
parent 4d0a218a57
commit 3a9ea66f8b
4 changed files with 91 additions and 50 deletions

View File

@ -212,6 +212,7 @@ class CRT {
ColourSpace _colour_space; ColourSpace _colour_space;
unsigned int _colour_cycle_numerator; unsigned int _colour_cycle_numerator;
unsigned int _colour_cycle_denominator; unsigned int _colour_cycle_denominator;
OutputDevice _output_device;
// properties directly derived from there // properties directly derived from there
unsigned int _hsync_error_window; // the permitted window around the expected sync position in which a sync pulse will be recognised; calculated once at init unsigned int _hsync_error_window; // the permitted window around the expected sync position in which a sync pulse will be recognised; calculated once at init

View File

@ -11,12 +11,12 @@
#include "OpenGL.hpp" #include "OpenGL.hpp"
#include "TextureTarget.hpp" #include "TextureTarget.hpp"
#include "Shader.hpp"
using namespace Outputs; using namespace Outputs;
struct CRT::OpenGLState { struct CRT::OpenGLState {
GLuint vertexShader, fragmentShader; OpenGL::Shader *shaderProgram;
GLuint shaderProgram;
GLuint arrayBuffer, vertexArray; GLuint arrayBuffer, vertexArray;
GLint positionAttribute; GLint positionAttribute;
@ -35,31 +35,11 @@ struct CRT::OpenGLState {
OpenGL::TextureTarget *colourTexture; OpenGL::TextureTarget *colourTexture;
OpenGL::TextureTarget *filteredTexture; OpenGL::TextureTarget *filteredTexture;
GLuint compile_shader(const char *source, GLenum type) OpenGLState() : shaderProgram(nullptr) {}
~OpenGLState()
{ {
GLuint shader = glCreateShader(type); delete shaderProgram;
glShaderSource(shader, 1, &source, NULL);
glCompileShader(shader);
#if defined(DEBUG)
GLint isCompiled = 0;
glGetShaderiv(shader, GL_COMPILE_STATUS, &isCompiled);
if(isCompiled == GL_FALSE)
{
GLint logLength;
glGetShaderiv(shader, GL_INFO_LOG_LENGTH, &logLength);
if (logLength > 0) {
GLchar *log = (GLchar *)malloc((size_t)logLength);
glGetShaderInfoLog(shader, logLength, &logLength, log);
printf("Compile log:\n%s\n", log);
free(log);
} }
}
#endif
return shader;
}
}; };
static GLenum formatForDepth(unsigned int depth) static GLenum formatForDepth(unsigned int depth)
@ -74,7 +54,6 @@ static GLenum formatForDepth(unsigned int depth)
} }
} }
void CRT::construct_openGL() void CRT::construct_openGL()
{ {
_openGL_state = nullptr; _openGL_state = nullptr;
@ -303,32 +282,20 @@ void CRT::prepare_shader()
char *vertex_shader = get_vertex_shader(); char *vertex_shader = get_vertex_shader();
char *fragment_shader = get_fragment_shader(); char *fragment_shader = get_fragment_shader();
_openGL_state->shaderProgram = glCreateProgram(); _openGL_state->shaderProgram = new OpenGL::Shader(vertex_shader, fragment_shader);
_openGL_state->vertexShader = _openGL_state->compile_shader(vertex_shader, GL_VERTEX_SHADER); _openGL_state->shaderProgram->bind();
_openGL_state->fragmentShader = _openGL_state->compile_shader(fragment_shader, GL_FRAGMENT_SHADER);
delete vertex_shader; _openGL_state->positionAttribute = _openGL_state->shaderProgram->get_attrib_location("position");
delete fragment_shader; _openGL_state->textureCoordinatesAttribute = _openGL_state->shaderProgram->get_attrib_location("srcCoordinates");
_openGL_state->lateralAttribute = _openGL_state->shaderProgram->get_attrib_location("lateral");
_openGL_state->alphaUniform = _openGL_state->shaderProgram->get_uniform_location("alpha");
_openGL_state->textureSizeUniform = _openGL_state->shaderProgram->get_uniform_location("textureSize");
_openGL_state->windowSizeUniform = _openGL_state->shaderProgram->get_uniform_location("windowSize");
_openGL_state->boundsSizeUniform = _openGL_state->shaderProgram->get_uniform_location("boundsSize");
_openGL_state->boundsOriginUniform = _openGL_state->shaderProgram->get_uniform_location("boundsOrigin");
glAttachShader(_openGL_state->shaderProgram, _openGL_state->vertexShader); GLint texIDUniform = _openGL_state->shaderProgram->get_uniform_location("texID");
glAttachShader(_openGL_state->shaderProgram, _openGL_state->fragmentShader); GLint shadowMaskTexIDUniform = _openGL_state->shaderProgram->get_uniform_location("shadowMaskTexID");
glLinkProgram(_openGL_state->shaderProgram);
glUseProgram(_openGL_state->shaderProgram);
_openGL_state->positionAttribute = glGetAttribLocation(_openGL_state->shaderProgram, "position");
_openGL_state->textureCoordinatesAttribute = glGetAttribLocation(_openGL_state->shaderProgram, "srcCoordinates");
_openGL_state->lateralAttribute = glGetAttribLocation(_openGL_state->shaderProgram, "lateral");
_openGL_state->alphaUniform = glGetUniformLocation(_openGL_state->shaderProgram, "alpha");
_openGL_state->textureSizeUniform = glGetUniformLocation(_openGL_state->shaderProgram, "textureSize");
_openGL_state->windowSizeUniform = glGetUniformLocation(_openGL_state->shaderProgram, "windowSize");
_openGL_state->boundsSizeUniform = glGetUniformLocation(_openGL_state->shaderProgram, "boundsSize");
_openGL_state->boundsOriginUniform = glGetUniformLocation(_openGL_state->shaderProgram, "boundsOrigin");
GLint texIDUniform = glGetUniformLocation(_openGL_state->shaderProgram, "texID");
GLint shadowMaskTexIDUniform = glGetUniformLocation(_openGL_state->shaderProgram, "shadowMaskTexID");
// [self pushSizeUniforms];
glUniform1i(texIDUniform, 0); glUniform1i(texIDUniform, 0);
glUniform1i(shadowMaskTexIDUniform, 1); glUniform1i(shadowMaskTexIDUniform, 1);
@ -342,3 +309,7 @@ void CRT::prepare_shader()
glVertexAttribPointer((GLuint)_openGL_state->textureCoordinatesAttribute, 2, GL_UNSIGNED_SHORT, GL_FALSE, vertexStride, (void *)kCRTVertexOffsetOfTexCoord); glVertexAttribPointer((GLuint)_openGL_state->textureCoordinatesAttribute, 2, GL_UNSIGNED_SHORT, GL_FALSE, vertexStride, (void *)kCRTVertexOffsetOfTexCoord);
glVertexAttribPointer((GLuint)_openGL_state->lateralAttribute, 1, GL_UNSIGNED_BYTE, GL_FALSE, vertexStride, (void *)kCRTVertexOffsetOfLateral); glVertexAttribPointer((GLuint)_openGL_state->lateralAttribute, 1, GL_UNSIGNED_BYTE, GL_FALSE, vertexStride, (void *)kCRTVertexOffsetOfLateral);
} }
void CRT::set_output_device(OutputDevice output_device)
{
}

View File

@ -7,3 +7,64 @@
// //
#include "Shader.hpp" #include "Shader.hpp"
#include <stdlib.h>
#include <stdio.h>
using namespace OpenGL;
GLuint Shader::compile_shader(const char *source, GLenum type)
{
GLuint shader = glCreateShader(type);
glShaderSource(shader, 1, &source, NULL);
glCompileShader(shader);
#if defined(DEBUG)
GLint isCompiled = 0;
glGetShaderiv(shader, GL_COMPILE_STATUS, &isCompiled);
if(isCompiled == GL_FALSE)
{
GLint logLength;
glGetShaderiv(shader, GL_INFO_LOG_LENGTH, &logLength);
if (logLength > 0) {
GLchar *log = (GLchar *)malloc((size_t)logLength);
glGetShaderInfoLog(shader, logLength, &logLength, log);
printf("Compile log:\n%s\n", log);
free(log);
}
}
#endif
return shader;
}
Shader::Shader(const char *vertex_shader, const char *fragment_shader)
{
_shader_program = glCreateProgram();
GLuint vertex = compile_shader(vertex_shader, GL_VERTEX_SHADER);
GLuint fragment = compile_shader(fragment_shader, GL_FRAGMENT_SHADER);
glAttachShader(_shader_program, vertex);
glAttachShader(_shader_program, fragment);
glLinkProgram(_shader_program);
}
Shader::~Shader()
{
glDeleteProgram(_shader_program);
}
void Shader::bind()
{
glUseProgram(_shader_program);
}
GLint Shader::get_attrib_location(const char *name)
{
return glGetAttribLocation(_shader_program, name);
}
GLint Shader::get_uniform_location(const char *name)
{
return glGetUniformLocation(_shader_program, name);
}

View File

@ -9,6 +9,8 @@
#ifndef Shader_hpp #ifndef Shader_hpp
#define Shader_hpp #define Shader_hpp
#include "OpenGL.hpp"
namespace OpenGL { namespace OpenGL {
class Shader { class Shader {
public: public:
@ -16,6 +18,12 @@ namespace OpenGL {
~Shader(); ~Shader();
void bind(); void bind();
GLint get_attrib_location(const char *name);
GLint get_uniform_location(const char *name);
private:
GLuint compile_shader(const char *source, GLenum type);
GLuint _shader_program;
}; };
} }