Skip to content

Commit

Permalink
buffered: Add Shader
Browse files Browse the repository at this point in the history
  • Loading branch information
hajimehoshi committed May 29, 2020
1 parent 218b6fc commit f922534
Show file tree
Hide file tree
Showing 4 changed files with 39 additions and 4 deletions.
2 changes: 1 addition & 1 deletion image.go
Original file line number Diff line number Diff line change
Expand Up @@ -331,7 +331,7 @@ func (i *Image) DrawTriangles(vertices []Vertex, indices []uint16, img *Image, o
is := make([]uint16, len(indices))
copy(is, indices)

i.buffered.DrawTriangles(img.buffered, vs, is, options.ColorM.impl, mode, filter, driver.Address(options.Address))
i.buffered.DrawTriangles(img.buffered, vs, is, options.ColorM.impl, mode, filter, driver.Address(options.Address), nil, nil)
}

// SubImage returns an image representing the portion of the image p visible through r. The returned value shares pixels with the original image.
Expand Down
38 changes: 35 additions & 3 deletions internal/buffered/image.go
Original file line number Diff line number Diff line change
Expand Up @@ -22,6 +22,7 @@ import (
"github.com/hajimehoshi/ebiten/internal/affine"
"github.com/hajimehoshi/ebiten/internal/driver"
"github.com/hajimehoshi/ebiten/internal/mipmap"
"github.com/hajimehoshi/ebiten/internal/shaderir"
)

type Image struct {
Expand Down Expand Up @@ -286,7 +287,7 @@ func (i *Image) drawImage(src *Image, bounds image.Rectangle, g mipmap.GeoM, col
// DrawTriangles draws the src image with the given vertices.
//
// Copying vertices and indices is the caller's responsibility.
func (i *Image) DrawTriangles(src *Image, vertices []float32, indices []uint16, colorm *affine.ColorM, mode driver.CompositeMode, filter driver.Filter, address driver.Address) {
func (i *Image) DrawTriangles(src *Image, vertices []float32, indices []uint16, colorm *affine.ColorM, mode driver.CompositeMode, filter driver.Filter, address driver.Address, shader *Shader, uniforms []interface{}) {
if i == src {
panic("buffered: Image.DrawTriangles: src must be different from the receiver")
}
Expand All @@ -297,13 +298,44 @@ func (i *Image) DrawTriangles(src *Image, vertices []float32, indices []uint16,
if needsToDelayCommands {
delayedCommands = append(delayedCommands, func() error {
// Arguments are not copied. Copying is the caller's responsibility.
i.DrawTriangles(src, vertices, indices, colorm, mode, filter, address)
i.DrawTriangles(src, vertices, indices, colorm, mode, filter, address, shader, uniforms)
return nil
})
return
}

src.resolvePendingPixels(true)
i.resolvePendingPixels(false)
i.img.DrawTriangles(src.img, vertices, indices, colorm, mode, filter, address, nil, nil)

var s *mipmap.Shader
if shader != nil {
s = shader.shader
}
us := make([]interface{}, len(uniforms))
for k, v := range uniforms {
switch v := v.(type) {
case *Image:
i.resolvePendingPixels(true)
us[k] = v.img
default:
us[k] = v
}
}

i.img.DrawTriangles(src.img, vertices, indices, colorm, mode, filter, address, s, us)
}

type Shader struct {
shader *mipmap.Shader
}

func NewShader(program *shaderir.Program) *Shader {
return &Shader{
shader: mipmap.NewShader(program),
}
}

func (s *Shader) MarkDisposed() {
s.shader.MarkDisposed()
s.shader = nil
}
2 changes: 2 additions & 0 deletions internal/buffered/image_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -306,3 +306,5 @@ func TestReplacePixelsAndModifyBeforeMain(t *testing.T) {
t.Errorf("got: %v, want: %v", got, want)
}
}

// TODO: Add tests for shaders and ReplacePixels to check resolvePendingPiexles works correctly.
1 change: 1 addition & 0 deletions internal/mipmap/mipmap.go
Original file line number Diff line number Diff line change
Expand Up @@ -184,6 +184,7 @@ func (m *Mipmap) DrawTriangles(src *Mipmap, vertices []float32, indices []uint16
vertices[i*n+11] *= ca
}
}

var s *shareable.Shader
if shader != nil {
s = shader.shader
Expand Down

0 comments on commit f922534

Please sign in to comment.