mirror of
https://github.com/hajimehoshi/ebiten.git
synced 2025-01-13 04:22:05 +01:00
graphicscommand: 0th image must be adopted to calculate the size
This commit is contained in:
parent
8bfe406470
commit
985ff2d43f
@ -106,7 +106,7 @@ func (q *commandQueue) appendVertices(vertices []float32, src *Image) {
|
|||||||
|
|
||||||
width := float32(1)
|
width := float32(1)
|
||||||
height := float32(1)
|
height := float32(1)
|
||||||
// src is nil when a shader is used and there are no images in the uniform variables.
|
// src is nil when a shader is used and there are no specified images.
|
||||||
if src != nil {
|
if src != nil {
|
||||||
w, h := src.InternalSize()
|
w, h := src.InternalSize()
|
||||||
width = float32(w)
|
width = float32(w)
|
||||||
@ -145,14 +145,8 @@ func (q *commandQueue) EnqueueDrawTrianglesCommand(dst *Image, srcs [graphics.Sh
|
|||||||
}
|
}
|
||||||
|
|
||||||
// Assume that all the image sizes are same.
|
// Assume that all the image sizes are same.
|
||||||
var firstSrc *Image
|
// Assume that the images are packed from the front in the slice srcs.
|
||||||
for _, src := range srcs {
|
q.appendVertices(vertices, srcs[0])
|
||||||
if src != nil {
|
|
||||||
firstSrc = src
|
|
||||||
break
|
|
||||||
}
|
|
||||||
}
|
|
||||||
q.appendVertices(vertices, firstSrc)
|
|
||||||
q.appendIndices(indices, uint16(q.nextIndex))
|
q.appendIndices(indices, uint16(q.nextIndex))
|
||||||
q.nextIndex += len(vertices) / graphics.VertexFloatNum
|
q.nextIndex += len(vertices) / graphics.VertexFloatNum
|
||||||
q.tmpNumIndices += len(indices)
|
q.tmpNumIndices += len(indices)
|
||||||
@ -167,8 +161,8 @@ func (q *commandQueue) EnqueueDrawTrianglesCommand(dst *Image, srcs [graphics.Sh
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if firstSrc != nil {
|
if srcs[0] != nil {
|
||||||
w, h := firstSrc.InternalSize()
|
w, h := srcs[0].InternalSize()
|
||||||
if address != driver.AddressUnsafe {
|
if address != driver.AddressUnsafe {
|
||||||
sourceRegion.X /= float32(w)
|
sourceRegion.X /= float32(w)
|
||||||
sourceRegion.Y /= float32(h)
|
sourceRegion.Y /= float32(h)
|
||||||
|
Loading…
Reference in New Issue
Block a user