graphics: Bug Fix: The screen image should be recreated

This commit is contained in:
Hajime Hoshi 2016-07-05 02:57:41 +09:00
parent 6cb1c929b5
commit 7e296b1aae
3 changed files with 35 additions and 6 deletions

View File

@ -231,13 +231,13 @@ func NewImageFromImage(source image.Image, filter Filter) (*Image, error) {
} }
func newImageWithScreenFramebuffer(width, height int) (*Image, error) { func newImageWithScreenFramebuffer(width, height int) (*Image, error) {
i, err := graphics.NewScreenFramebufferImage(width, height) img, err := newScreenImageImpl(width, height)
if err != nil { if err != nil {
return nil, err return nil, err
} }
img, err := newImageImpl(i, FilterNearest) eimg, err := theImagesForRestoring.add(img)
if err != nil { if err != nil {
return nil, err return nil, err
} }
return &Image{img}, nil return eimg, nil
} }

View File

@ -37,6 +37,7 @@ type imageImpl struct {
filter Filter filter Filter
pixels []uint8 pixels []uint8
noSave bool noSave bool
screen bool
m sync.Mutex m sync.Mutex
} }
@ -84,6 +85,19 @@ func newImageImplFromImage(source image.Image, filter Filter) (*imageImpl, error
return i, nil return i, nil
} }
func newScreenImageImpl(width, height int) (*imageImpl, error) {
i, err := graphics.NewScreenFramebufferImage(width, height)
if err != nil {
return nil, err
}
img, err := newImageImpl(i, FilterNearest)
if err != nil {
return nil, err
}
img.screen = true
return img, nil
}
func (i *imageImpl) Fill(clr color.Color) error { func (i *imageImpl) Fill(clr color.Color) error {
i.m.Lock() i.m.Lock()
defer i.m.Unlock() defer i.m.Unlock()
@ -159,6 +173,9 @@ func (i *imageImpl) At(x, y int) color.Color {
func (i *imageImpl) savePixels(context *opengl.Context) error { func (i *imageImpl) savePixels(context *opengl.Context) error {
i.m.Lock() i.m.Lock()
defer i.m.Unlock() defer i.m.Unlock()
if i.screen {
return nil
}
if i.noSave { if i.noSave {
return nil return nil
} }
@ -182,6 +199,16 @@ func (i *imageImpl) restorePixels() error {
if i.disposed { if i.disposed {
return nil return nil
} }
if i.screen {
// The screen image should also be recreated because framebuffer might
// be changed.
var err error
i.image, err = graphics.NewScreenFramebufferImage(i.width, i.height)
if err != nil {
return err
}
return nil
}
if i.pixels != nil { if i.pixels != nil {
img := image.NewRGBA(image.Rect(0, 0, i.width, i.height)) img := image.NewRGBA(image.Rect(0, 0, i.width, i.height))
for j := 0; j < i.height; j++ { for j := 0; j < i.height; j++ {
@ -208,9 +235,11 @@ func (i *imageImpl) Dispose() error {
if i.disposed { if i.disposed {
return errors.New("ebiten: image is already disposed") return errors.New("ebiten: image is already disposed")
} }
if !i.screen {
if err := i.image.Dispose(); err != nil { if err := i.image.Dispose(); err != nil {
return err return err
} }
}
i.image = nil i.image = nil
i.disposed = true i.disposed = true
i.pixels = nil i.pixels = nil

View File

@ -167,7 +167,7 @@ type disposeCommand struct {
} }
func (c *disposeCommand) Exec(context *opengl.Context) error { func (c *disposeCommand) Exec(context *opengl.Context) error {
if c.target.framebuffer != nil && c.target.framebuffer.native != context.ScreenFramebuffer() { if c.target.framebuffer != nil {
context.DeleteFramebuffer(c.target.framebuffer.native) context.DeleteFramebuffer(c.target.framebuffer.native)
} }
if c.target.texture != nil { if c.target.texture != nil {