internal/atlas: refactoring: remove unnecessary logics

Updates #2601
This commit is contained in:
Hajime Hoshi 2023-08-19 03:59:03 +09:00
parent e1041ea20e
commit 1e2a4cb4b1

View File

@ -337,29 +337,6 @@ func (i *Image) regionWithPadding() image.Rectangle {
return i.node.Region() return i.node.Region()
} }
func (i *Image) processSrc(src *Image) {
if src == nil {
return
}
if src.disposed {
panic("atlas: the drawing source image must not be disposed (DrawTriangles)")
}
if src.backend == nil {
backends := make([]*backend, 0, 1)
if i.backend != nil {
backends = append(backends, i.backend)
}
src.allocate(backends, true)
}
// Compare i and source images after ensuring i is not on an atlas, or
// i and a source image might share the same atlas even though i != src.
if i.backend.restorable == src.backend.restorable {
panic("atlas: Image.DrawTriangles: source must be different from the receiver")
}
}
// DrawTriangles draws triangles with the given image. // DrawTriangles draws triangles with the given image.
// //
// The vertex floats are: // The vertex floats are:
@ -388,6 +365,9 @@ func (i *Image) drawTriangles(srcs [graphics.ShaderImageCount]*Image, vertices [
if src == nil { if src == nil {
continue continue
} }
if src.disposed {
panic("atlas: the drawing source image must not be disposed (DrawTriangles)")
}
if src.backend == nil { if src.backend == nil {
// It is possible to spcify i.backend as a forbidden backend, but this might prevent a good allocation for a source image. // It is possible to spcify i.backend as a forbidden backend, but this might prevent a good allocation for a source image.
// If the backend becomes the same as i's, this will be changed later. // If the backend becomes the same as i's, this will be changed later.
@ -396,10 +376,15 @@ func (i *Image) drawTriangles(srcs [graphics.ShaderImageCount]*Image, vertices [
backends = append(backends, src.backend) backends = append(backends, src.backend)
theSourceBackendsForOneFrame[src.backend] = struct{}{} theSourceBackendsForOneFrame[src.backend] = struct{}{}
} }
i.ensureIsolatedFromSource(backends) i.ensureIsolatedFromSource(backends)
for _, src := range srcs { for _, src := range srcs {
i.processSrc(src) // Compare i and source images after ensuring i is not on an atlas, or
// i and a source image might share the same atlas even though i != src.
if src != nil && i.backend.restorable == src.backend.restorable {
panic("atlas: Image.DrawTriangles: source must be different from the receiver")
}
} }
r := i.regionWithPadding() r := i.regionWithPadding()