From f897c3958efc65a7044ab674546353bc281572c2 Mon Sep 17 00:00:00 2001 From: Hajime Hoshi Date: Sat, 11 Jun 2016 01:20:55 +0900 Subject: [PATCH] graphics: Fix restoring logic --- graphicscontext.go | 2 +- image.go | 20 ++++++++++++-------- 2 files changed, 13 insertions(+), 9 deletions(-) diff --git a/graphicscontext.go b/graphicscontext.go index e370d9c66..ca694aa9c 100644 --- a/graphicscontext.go +++ b/graphicscontext.go @@ -97,7 +97,7 @@ func (c *graphicsContext) Resume() error { if err := graphics.Initialize(ui.GLContext()); err != nil { return err } - if err := theImages.restorePixels(); err != nil { + if err := theImages.restorePixels(ui.GLContext()); err != nil { return err } return nil diff --git a/image.go b/image.go index a03f7ec8d..d59ee2e1a 100644 --- a/image.go +++ b/image.go @@ -89,11 +89,11 @@ func (i *images) remove(img *Image) { delete(i.images, img.impl) } -func (i *images) restorePixels() error { +func (i *images) restorePixels(context *opengl.Context) error { i.m.Lock() defer i.m.Unlock() for img := range i.images { - if err := img.restorePixels(); err != nil { + if err := img.restorePixels(context); err != nil { return err } } @@ -293,7 +293,7 @@ func (i *imageImpl) At(x, y int) color.Color { return color.RGBA{r, g, b, a} } -func (i *imageImpl) restorePixels() error { +func (i *imageImpl) restorePixels(context *opengl.Context) error { imageM.Lock() defer imageM.Unlock() if i.defaultFramebuffer { @@ -302,15 +302,19 @@ func (i *imageImpl) restorePixels() error { if i.disposed { return nil } - if i.pixels == nil { - return errors.New("ebiten: pixels must not be nil") - } if i.texture != nil { - return errors.New("ebiten: texture must be nil") + // TODO: As the texture is already disposed, is it correct to delete it here? + if err := i.texture.Dispose(context); err != nil { + return err + } } if i.framebuffer != nil { - return errors.New("ebiten: framebuffer must be nil") + // TODO: Ditto + if err := i.framebuffer.Dispose(context); err != nil { + return err + } } + // TODO: Recalc i.pixels here img := image.NewRGBA(image.Rect(0, 0, i.width, i.height)) for j := 0; j < i.height; j++ { copy(img.Pix[j*img.Stride:], i.pixels[j*i.width*4:(j+1)*i.width*4])