mirror of
https://github.com/bloeys/nmage.git
synced 2025-12-29 13:28:20 +00:00
Uniforms and better logging
This commit is contained in:
@ -2,9 +2,9 @@ package shaders
|
||||
|
||||
import (
|
||||
"fmt"
|
||||
"log"
|
||||
"strings"
|
||||
|
||||
"github.com/bloeys/go-sdl-engine/logging"
|
||||
"github.com/go-gl/gl/v4.6-core/gl"
|
||||
)
|
||||
|
||||
@ -20,7 +20,7 @@ func NewProgram(name string) Program {
|
||||
p.Shaders = make([]Shader, 0)
|
||||
|
||||
if p.ID = gl.CreateProgram(); p.ID == 0 {
|
||||
log.Fatalln("Creating OpenGL program failed")
|
||||
logging.ErrLog.Fatalln("Creating OpenGL program failed")
|
||||
}
|
||||
|
||||
return p
|
||||
@ -79,6 +79,72 @@ func (p *Program) Use() {
|
||||
gl.UseProgram(p.ID)
|
||||
}
|
||||
|
||||
func (p *Program) GetUniformLocation(name string) int32 {
|
||||
return gl.GetUniformLocation(p.ID, gl.Str(name+"\x00"))
|
||||
}
|
||||
|
||||
//SetUniformF32 handles setting uniform values of 1-4 floats.
|
||||
//Returns false if len(floats) is <1 or >4, or if the uniform was not found.
|
||||
//Uniforms aren't found if it doesn't exist or was not used in the shader
|
||||
func (p *Program) SetUniformF32(name string, floats ...float32) bool {
|
||||
|
||||
loc := p.GetUniformLocation(name)
|
||||
if loc == 0 {
|
||||
logging.WarnLog.Printf(
|
||||
"Uniform with name '%s' was not found. "+
|
||||
"This is either because it doesn't exist or isn't used in the shader",
|
||||
name)
|
||||
return false
|
||||
}
|
||||
|
||||
switch len(floats) {
|
||||
case 1:
|
||||
gl.Uniform1f(loc, floats[0])
|
||||
case 2:
|
||||
gl.Uniform2f(loc, floats[0], floats[1])
|
||||
case 3:
|
||||
gl.Uniform3f(loc, floats[0], floats[1], floats[2])
|
||||
case 4:
|
||||
gl.Uniform4f(loc, floats[0], floats[1], floats[2], floats[3])
|
||||
default:
|
||||
logging.ErrLog.Println("Invalid input size in SetUniformF32. Size must be 1-4 but got", len(floats))
|
||||
return false
|
||||
}
|
||||
|
||||
return true
|
||||
}
|
||||
|
||||
//SetUniformI32 handles setting uniform values of 1-4 ints.
|
||||
//Returns false if len(ints) is <1 or >4, or if the uniform was not found.
|
||||
//Uniforms aren't found if it doesn't exist or was not used in the shader
|
||||
func (p *Program) SetUniformI32(name string, ints ...int32) bool {
|
||||
|
||||
loc := p.GetUniformLocation(name)
|
||||
if loc == 0 {
|
||||
logging.WarnLog.Printf(
|
||||
"Uniform with name '%s' was not found. "+
|
||||
"This is either because it doesn't exist or isn't used in the shader",
|
||||
name)
|
||||
return false
|
||||
}
|
||||
|
||||
switch len(ints) {
|
||||
case 1:
|
||||
gl.Uniform1i(loc, ints[0])
|
||||
case 2:
|
||||
gl.Uniform2i(loc, ints[0], ints[1])
|
||||
case 3:
|
||||
gl.Uniform3i(loc, ints[0], ints[1], ints[2])
|
||||
case 4:
|
||||
gl.Uniform4i(loc, ints[0], ints[1], ints[2], ints[3])
|
||||
default:
|
||||
logging.ErrLog.Println("Invalid input size in SetUniformI32. Size must be 1-4 but got", len(ints))
|
||||
return false
|
||||
}
|
||||
|
||||
return true
|
||||
}
|
||||
|
||||
//Delete deletes all shaders and then deletes the program
|
||||
func (p *Program) Delete() {
|
||||
for _, v := range p.Shaders {
|
||||
|
||||
@ -2,10 +2,10 @@ package shaders
|
||||
|
||||
import (
|
||||
"fmt"
|
||||
"log"
|
||||
"os"
|
||||
"strings"
|
||||
|
||||
"github.com/bloeys/go-sdl-engine/logging"
|
||||
"github.com/go-gl/gl/v4.6-core/gl"
|
||||
)
|
||||
|
||||
@ -33,7 +33,7 @@ func NewShaderFromString(sourceString string, st ShaderType) (Shader, error) {
|
||||
|
||||
newShader := Shader{Type: st}
|
||||
if newShader.ID = gl.CreateShader(st.GLType()); newShader.ID == 0 {
|
||||
log.Fatalln("Creating shader failed. ShaderType:", st)
|
||||
logging.ErrLog.Panicln("Creating shader failed. ShaderType:", st)
|
||||
}
|
||||
|
||||
gl.ShaderSource(newShader.ID, 1, glString, nil)
|
||||
|
||||
@ -1,8 +1,7 @@
|
||||
package shaders
|
||||
|
||||
import (
|
||||
"log"
|
||||
|
||||
"github.com/bloeys/go-sdl-engine/logging"
|
||||
"github.com/go-gl/gl/v4.6-core/gl"
|
||||
)
|
||||
|
||||
@ -25,7 +24,7 @@ func (t ShaderType) GLType() uint32 {
|
||||
return gl.FRAGMENT_SHADER
|
||||
}
|
||||
|
||||
log.Panicf("Converting ShaderType->GL Shader Type failed. Unknown ShaderType of value: %v\n", t)
|
||||
logging.ErrLog.Panicf("Converting ShaderType->GL Shader Type failed. Unknown ShaderType of value: %v\n", t)
|
||||
return 0
|
||||
}
|
||||
|
||||
@ -39,7 +38,7 @@ func (t ShaderType) FromGLShaderType(glShaderType int) ShaderType {
|
||||
case gl.FRAGMENT_SHADER:
|
||||
return Fragment
|
||||
default:
|
||||
log.Printf("Converting GL shader type->ShaderType failed. Unknown GL shader type of value: %v\n", glShaderType)
|
||||
logging.ErrLog.Panicf("Converting GL shader type->ShaderType failed. Unknown GL shader type of value: %v\n", glShaderType)
|
||||
return Unknown
|
||||
}
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user