mirror of
https://github.com/hajimehoshi/ebiten.git
synced 2025-01-11 19:48:54 +01:00
internal/graphicsdriver/opengl: Optimization: Cache texture variable names
This commit is contained in:
parent
9d51356eef
commit
15f62bfeb5
@ -47,6 +47,7 @@ type Graphics struct {
|
||||
drawCalled bool
|
||||
|
||||
uniformVariableNameCache map[int]string
|
||||
textureVariableNameCache map[int]string
|
||||
|
||||
uniformVars []uniformVariable
|
||||
|
||||
|
@ -251,6 +251,18 @@ type textureVariable struct {
|
||||
native textureNative
|
||||
}
|
||||
|
||||
func (g *Graphics) textureVariableName(idx int) string {
|
||||
if v, ok := g.textureVariableNameCache[idx]; ok {
|
||||
return v
|
||||
}
|
||||
if g.textureVariableNameCache == nil {
|
||||
g.textureVariableNameCache = map[int]string{}
|
||||
}
|
||||
name := fmt.Sprintf("T%d", idx)
|
||||
g.textureVariableNameCache[idx] = name
|
||||
return name
|
||||
}
|
||||
|
||||
// useProgram uses the program (programTexture).
|
||||
func (g *Graphics) useProgram(program program, uniforms []uniformVariable, textures [graphics.ShaderImageNum]textureVariable) error {
|
||||
if !g.state.lastProgram.equal(program) {
|
||||
@ -318,7 +330,7 @@ loop:
|
||||
// Rebinding the same texture seems problematic (#1193).
|
||||
for _, at := range g.activatedTextures {
|
||||
if t.native.equal(at.textureNative) {
|
||||
g.context.uniformInt(program, fmt.Sprintf("T%d", i), at.index)
|
||||
g.context.uniformInt(program, g.textureVariableName(i), at.index)
|
||||
continue loop
|
||||
}
|
||||
}
|
||||
@ -327,7 +339,7 @@ loop:
|
||||
textureNative: t.native,
|
||||
index: idx,
|
||||
})
|
||||
g.context.uniformInt(program, fmt.Sprintf("T%d", i), idx)
|
||||
g.context.uniformInt(program, g.textureVariableName(i), idx)
|
||||
if g.state.lastActiveTexture != idx {
|
||||
g.context.activeTexture(idx)
|
||||
g.state.lastActiveTexture = idx
|
||||
|
Loading…
Reference in New Issue
Block a user