ebiten: Bug fix: Source regions should not be passed when not needed

The source region information affects the condition of merging
graphics commands. To avoid performance issues by the big number of
graphcis commands, do not pass the source region whenever possible.

Fixes #1293
This commit is contained in:
Hajime Hoshi 2020-08-12 02:12:32 +09:00
parent 95022ff1a5
commit d4042a5cfa
2 changed files with 24 additions and 12 deletions

View File

@ -271,12 +271,16 @@ func (i *Image) DrawImage(img *Image, options *DrawImageOptions) error {
is := graphics.QuadIndices() is := graphics.QuadIndices()
var sr driver.Region var sr driver.Region
// Pass the source region only when the shader is used, since this affects the condition of merging graphics
// commands (#1293).
if options.Shader != nil {
sr = driver.Region{ sr = driver.Region{
X: float32(bounds.Min.X), X: float32(bounds.Min.X),
Y: float32(bounds.Min.Y), Y: float32(bounds.Min.Y),
Width: float32(bounds.Dx()), Width: float32(bounds.Dx()),
Height: float32(bounds.Dy()), Height: float32(bounds.Dy()),
} }
}
srcs := [graphics.ShaderImageNum]*mipmap.Mipmap{img.mipmap} srcs := [graphics.ShaderImageNum]*mipmap.Mipmap{img.mipmap}
if options.Shader == nil { if options.Shader == nil {
@ -430,12 +434,16 @@ func (i *Image) DrawTriangles(vertices []Vertex, indices []uint16, img *Image, o
var sr driver.Region var sr driver.Region
b := img.Bounds() b := img.Bounds()
// Pass the source region only when the shader is used, since this affects the condition of merging graphics
// commands (#1293).
if options.Shader != nil || options.Address != AddressUnsafe {
sr = driver.Region{ sr = driver.Region{
X: float32(b.Min.X), X: float32(b.Min.X),
Y: float32(b.Min.Y), Y: float32(b.Min.Y),
Width: float32(b.Dx()), Width: float32(b.Dx()),
Height: float32(b.Dy()), Height: float32(b.Dy()),
} }
}
var srcs [graphics.ShaderImageNum]*mipmap.Mipmap var srcs [graphics.ShaderImageNum]*mipmap.Mipmap
if img != nil { if img != nil {

View File

@ -337,9 +337,13 @@ func (i *Image) DrawTriangles(srcs [graphics.ShaderImageNum]*Image, vertices []f
vertices[i*graphics.VertexFloatNum+2] += oxf vertices[i*graphics.VertexFloatNum+2] += oxf
vertices[i*graphics.VertexFloatNum+3] += oyf vertices[i*graphics.VertexFloatNum+3] += oyf
} }
// sourceRegion can be delibarately empty when this is not needed in order to avoid unexpected
// performance issue (#1293).
if sourceRegion.Width != 0 && sourceRegion.Height != 0 {
sourceRegion.X += oxf sourceRegion.X += oxf
sourceRegion.Y += oyf sourceRegion.Y += oyf
} }
}
var offsets [graphics.ShaderImageNum - 1][2]float32 var offsets [graphics.ShaderImageNum - 1][2]float32
for i := range offsets { for i := range offsets {