mirror of
https://github.com/hajimehoshi/ebiten.git
synced 2025-01-13 12:32:05 +01:00
graphics: Now images from NewImage also shares a texture
This commit is contained in:
parent
2903f32d9b
commit
d944d51c14
69
image.go
69
image.go
@ -106,21 +106,20 @@ func (i *Image) Fill(clr color.Color) error {
|
|||||||
return nil
|
return nil
|
||||||
}
|
}
|
||||||
|
|
||||||
func (img *Image) ensureNotShared() {
|
func (i *Image) ensureNotShared() {
|
||||||
if img.sharedImagePart == nil {
|
if i.sharedImagePart == nil {
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
if img.restorable == nil {
|
if i.restorable != nil {
|
||||||
// The image is already disposed.
|
panic("not reached")
|
||||||
return
|
|
||||||
}
|
}
|
||||||
|
|
||||||
s := img.sharedImagePart
|
s := i.sharedImagePart
|
||||||
x, y, w, h := s.region()
|
x, y, w, h := s.region()
|
||||||
|
|
||||||
img.restorable = restorable.NewImage(w, h, false)
|
i.restorable = restorable.NewImage(w, h, false)
|
||||||
img.sharedImagePart = nil
|
i.sharedImagePart = nil
|
||||||
img.restorable.DrawImage(s.image(), x, y, w, h, nil, nil, opengl.CompositeModeCopy, graphics.FilterNearest)
|
i.restorable.DrawImage(s.image(), x, y, w, h, nil, nil, opengl.CompositeModeCopy, graphics.FilterNearest)
|
||||||
s.Dispose()
|
s.Dispose()
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -180,6 +179,10 @@ func (i *Image) DrawImage(img *Image, options *DrawImageOptions) error {
|
|||||||
panic("ebiten: the given image to DrawImage must not be disposed")
|
panic("ebiten: the given image to DrawImage must not be disposed")
|
||||||
}
|
}
|
||||||
i.ensureNotShared()
|
i.ensureNotShared()
|
||||||
|
if i.restorable == nil {
|
||||||
|
panic("not reached")
|
||||||
|
}
|
||||||
|
|
||||||
// Compare i and img after ensuring i is not shared, or
|
// Compare i and img after ensuring i is not shared, or
|
||||||
// i and img might share the same texture even though i != img.
|
// i and img might share the same texture even though i != img.
|
||||||
if i == img {
|
if i == img {
|
||||||
@ -439,11 +442,19 @@ type DrawImageOptions struct {
|
|||||||
// Error returned by NewImage is always nil as of 1.5.0-alpha.
|
// Error returned by NewImage is always nil as of 1.5.0-alpha.
|
||||||
func NewImage(width, height int, filter Filter) (*Image, error) {
|
func NewImage(width, height int, filter Filter) (*Image, error) {
|
||||||
checkSize(width, height)
|
checkSize(width, height)
|
||||||
// TODO: Is it possible to use the shared texture here? (#514)
|
var i *Image
|
||||||
r := restorable.NewImage(width, height, false)
|
s := newSharedImagePart(width, height)
|
||||||
i := &Image{
|
if s != nil {
|
||||||
restorable: r,
|
i = &Image{
|
||||||
filter: filter,
|
sharedImagePart: s,
|
||||||
|
filter: filter,
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
r := restorable.NewImage(width, height, false)
|
||||||
|
i = &Image{
|
||||||
|
restorable: r,
|
||||||
|
filter: filter,
|
||||||
|
}
|
||||||
}
|
}
|
||||||
i.fill(0, 0, 0, 0)
|
i.fill(0, 0, 0, 0)
|
||||||
runtime.SetFinalizer(i, (*Image).Dispose)
|
runtime.SetFinalizer(i, (*Image).Dispose)
|
||||||
@ -453,11 +464,19 @@ func NewImage(width, height int, filter Filter) (*Image, error) {
|
|||||||
// newImageWithoutInit creates an empty image without initialization.
|
// newImageWithoutInit creates an empty image without initialization.
|
||||||
func newImageWithoutInit(width, height int) *Image {
|
func newImageWithoutInit(width, height int) *Image {
|
||||||
checkSize(width, height)
|
checkSize(width, height)
|
||||||
// TODO: Is it possible to use the shared texture here? (#514)
|
var i *Image
|
||||||
r := restorable.NewImage(width, height, false)
|
s := newSharedImagePart(width, height)
|
||||||
i := &Image{
|
if s != nil {
|
||||||
restorable: r,
|
i = &Image{
|
||||||
filter: FilterDefault,
|
sharedImagePart: s,
|
||||||
|
filter: FilterDefault,
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
r := restorable.NewImage(width, height, false)
|
||||||
|
i = &Image{
|
||||||
|
restorable: r,
|
||||||
|
filter: FilterDefault,
|
||||||
|
}
|
||||||
}
|
}
|
||||||
runtime.SetFinalizer(i, (*Image).Dispose)
|
runtime.SetFinalizer(i, (*Image).Dispose)
|
||||||
return i
|
return i
|
||||||
@ -506,17 +525,17 @@ func NewImageFromImage(source image.Image, filter Filter) (*Image, error) {
|
|||||||
|
|
||||||
var i *Image
|
var i *Image
|
||||||
s := newSharedImagePart(width, height)
|
s := newSharedImagePart(width, height)
|
||||||
if s == nil {
|
if s != nil {
|
||||||
|
i = &Image{
|
||||||
|
sharedImagePart: s,
|
||||||
|
filter: filter,
|
||||||
|
}
|
||||||
|
} else {
|
||||||
r := restorable.NewImage(width, height, false)
|
r := restorable.NewImage(width, height, false)
|
||||||
i = &Image{
|
i = &Image{
|
||||||
restorable: r,
|
restorable: r,
|
||||||
filter: filter,
|
filter: filter,
|
||||||
}
|
}
|
||||||
} else {
|
|
||||||
i = &Image{
|
|
||||||
sharedImagePart: s,
|
|
||||||
filter: filter,
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
runtime.SetFinalizer(i, (*Image).Dispose)
|
runtime.SetFinalizer(i, (*Image).Dispose)
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user