mirror of
https://github.com/hajimehoshi/ebiten.git
synced 2025-01-26 10:42:42 +01:00
Avoid copying for performance; Use location caches
This commit is contained in:
parent
1117862d19
commit
71d463c102
@ -18,8 +18,8 @@ import (
|
||||
"github.com/hajimehoshi/ebiten/internal/opengl"
|
||||
)
|
||||
|
||||
func glMatrix(m *[4][4]float64) [16]float32 {
|
||||
result := [16]float32{}
|
||||
func glMatrix(m *[4][4]float64) []float32 {
|
||||
result := make([]float32, 16)
|
||||
for j := 0; j < 4; j++ {
|
||||
for i := 0; i < 4; i++ {
|
||||
result[i+j*4] = float32(m[i][j])
|
||||
|
@ -65,7 +65,7 @@ func initialize(c *opengl.Context) error {
|
||||
|
||||
var lastProgram opengl.Program
|
||||
|
||||
func useProgramColorMatrix(c *opengl.Context, projectionMatrix [16]float32, geo Matrix, color Matrix) opengl.Program {
|
||||
func useProgramColorMatrix(c *opengl.Context, projectionMatrix []float32, geo Matrix, color Matrix) opengl.Program {
|
||||
if lastProgram != programColorMatrix {
|
||||
c.UseProgram(programColorMatrix)
|
||||
lastProgram = programColorMatrix
|
||||
@ -81,7 +81,7 @@ func useProgramColorMatrix(c *opengl.Context, projectionMatrix [16]float32, geo
|
||||
md := float32(geo.Element(1, 1))
|
||||
tx := float32(geo.Element(0, 2))
|
||||
ty := float32(geo.Element(1, 2))
|
||||
glModelviewMatrix := [...]float32{
|
||||
glModelviewMatrix := []float32{
|
||||
ma, mc, 0, 0,
|
||||
mb, md, 0, 0,
|
||||
0, 0, 1, 0,
|
||||
@ -97,14 +97,14 @@ func useProgramColorMatrix(c *opengl.Context, projectionMatrix [16]float32, geo
|
||||
}
|
||||
}
|
||||
|
||||
glColorMatrix := [...]float32{
|
||||
glColorMatrix := []float32{
|
||||
e[0][0], e[1][0], e[2][0], e[3][0],
|
||||
e[0][1], e[1][1], e[2][1], e[3][1],
|
||||
e[0][2], e[1][2], e[2][2], e[3][2],
|
||||
e[0][3], e[1][3], e[2][3], e[3][3],
|
||||
}
|
||||
c.Uniform(program, "color_matrix", glColorMatrix)
|
||||
glColorMatrixTranslation := [...]float32{
|
||||
glColorMatrixTranslation := []float32{
|
||||
e[0][4], e[1][4], e[2][4], e[3][4],
|
||||
}
|
||||
c.Uniform(program, "color_matrix_translation", glColorMatrixTranslation)
|
||||
|
@ -26,6 +26,8 @@ type Texture int
|
||||
type Framebuffer int
|
||||
type Shader int
|
||||
type Program int
|
||||
type UniformLocation int
|
||||
type AttribLocation int
|
||||
|
||||
type context struct{}
|
||||
|
||||
@ -177,10 +179,19 @@ func (c *Context) Uniform(p Program, location string, v interface{}) {
|
||||
switch v := v.(type) {
|
||||
case int:
|
||||
l.Uniform1i(v)
|
||||
case [4]float32:
|
||||
l.Uniform4fv(1, v[:])
|
||||
case [16]float32:
|
||||
l.UniformMatrix4fv(false, v)
|
||||
case []float32:
|
||||
switch len(v) {
|
||||
case 4:
|
||||
l.Uniform4fv(1, v)
|
||||
case 16:
|
||||
v2 := [16]float32{}
|
||||
copy(v2[:], v)
|
||||
l.UniformMatrix4fv(false, v2)
|
||||
default:
|
||||
panic("not reach")
|
||||
}
|
||||
default:
|
||||
panic("not reach")
|
||||
}
|
||||
}
|
||||
|
||||
|
@ -27,6 +27,8 @@ type Texture js.Object
|
||||
type Framebuffer js.Object
|
||||
type Shader js.Object
|
||||
type Program js.Object
|
||||
type UniformLocation js.Object
|
||||
type AttribLocation js.Object
|
||||
|
||||
type context struct {
|
||||
gl *webgl.Context
|
||||
@ -196,14 +198,26 @@ func (c *Context) UseProgram(p Program) {
|
||||
|
||||
func (c *Context) Uniform(p Program, location string, v interface{}) {
|
||||
gl := c.gl
|
||||
l := gl.GetUniformLocation(p, location)
|
||||
key := locationCacheKey{p, location}
|
||||
l, ok := uniformLocationCache[key]
|
||||
if !ok {
|
||||
l = gl.GetUniformLocation(p, location)
|
||||
uniformLocationCache[key] = l
|
||||
}
|
||||
switch v := v.(type) {
|
||||
case int:
|
||||
gl.Uniform1i(l, v)
|
||||
case [4]float32:
|
||||
gl.Call("uniform4fv", l, v[:])
|
||||
case [16]float32:
|
||||
gl.UniformMatrix4fv(l, false, v[:])
|
||||
case []float32:
|
||||
switch len(v) {
|
||||
case 4:
|
||||
gl.Call("uniform4fv", l, v)
|
||||
case 16:
|
||||
gl.UniformMatrix4fv(l, false, v)
|
||||
default:
|
||||
panic("not reach")
|
||||
}
|
||||
default:
|
||||
panic("not reach")
|
||||
}
|
||||
}
|
||||
|
||||
|
22
internal/opengl/locationcache.go
Normal file
22
internal/opengl/locationcache.go
Normal file
@ -0,0 +1,22 @@
|
||||
// Copyright 2014 Hajime Hoshi
|
||||
//
|
||||
// Licensed under the Apache License, Version 2.0 (the "License");
|
||||
// you may not use this file except in compliance with the License.
|
||||
// You may obtain a copy of the License at
|
||||
//
|
||||
// http://www.apache.org/licenses/LICENSE-2.0
|
||||
//
|
||||
// Unless required by applicable law or agreed to in writing, software
|
||||
// distributed under the License is distributed on an "AS IS" BASIS,
|
||||
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||
// See the License for the specific language governing permissions and
|
||||
// limitations under the License.
|
||||
|
||||
package opengl
|
||||
|
||||
type locationCacheKey struct {
|
||||
program Program
|
||||
name string
|
||||
}
|
||||
|
||||
var uniformLocationCache = map[locationCacheKey]UniformLocation{}
|
Loading…
Reference in New Issue
Block a user