mirror of
https://github.com/hajimehoshi/ebiten.git
synced 2025-01-12 20:18:59 +01:00
graphics: Reland: Bug fix: a too old frame was rendered at least on Android
Fixes #525
This commit is contained in:
parent
1c0f5e09d5
commit
b8deabbd94
@ -16,6 +16,7 @@ package ebiten
|
|||||||
|
|
||||||
import (
|
import (
|
||||||
"github.com/hajimehoshi/ebiten/internal/clock"
|
"github.com/hajimehoshi/ebiten/internal/clock"
|
||||||
|
"github.com/hajimehoshi/ebiten/internal/graphics"
|
||||||
"github.com/hajimehoshi/ebiten/internal/hooks"
|
"github.com/hajimehoshi/ebiten/internal/hooks"
|
||||||
"github.com/hajimehoshi/ebiten/internal/restorable"
|
"github.com/hajimehoshi/ebiten/internal/restorable"
|
||||||
"github.com/hajimehoshi/ebiten/internal/ui"
|
"github.com/hajimehoshi/ebiten/internal/ui"
|
||||||
@ -97,27 +98,31 @@ func (c *graphicsContext) Update(afterFrameUpdate func()) error {
|
|||||||
}
|
}
|
||||||
afterFrameUpdate()
|
afterFrameUpdate()
|
||||||
}
|
}
|
||||||
if 0 < updateCount {
|
|
||||||
// Call ClearFramebuffer instead of c.screen.Clear()
|
|
||||||
// to clear the whole region including fullscreen's padding.
|
|
||||||
c.screen.restorable.ClearFramebuffer()
|
|
||||||
|
|
||||||
dw, dh := c.screen.Size()
|
// Clear the screen framebuffer by DrawImage instad of Fill
|
||||||
sw, _ := c.offscreen.Size()
|
// to clear the whole region including fullscreen's padding.
|
||||||
scale := float64(dw) / float64(sw)
|
op := &DrawImageOptions{}
|
||||||
|
w, h := emptyImage.Size()
|
||||||
|
// graphics.MaxImageSize should be the maximum size of framebuffer.
|
||||||
|
op.GeoM.Scale(graphics.MaxImageSize/float64(w), graphics.MaxImageSize/float64(h))
|
||||||
|
op.CompositeMode = CompositeModeCopy
|
||||||
|
op.Filter = filterScreen // any filter is fine: just use the same filter as below.
|
||||||
|
c.screen.DrawImage(emptyImage, op)
|
||||||
|
|
||||||
op := &DrawImageOptions{}
|
dw, dh := c.screen.Size()
|
||||||
|
sw, _ := c.offscreen.Size()
|
||||||
|
scale := float64(dw) / float64(sw)
|
||||||
|
|
||||||
// c.screen is special: its Y axis is down to up,
|
op = &DrawImageOptions{}
|
||||||
// and the origin point is lower left.
|
// c.screen is special: its Y axis is down to up,
|
||||||
op.GeoM.Scale(scale, -scale)
|
// and the origin point is lower left.
|
||||||
op.GeoM.Translate(0, float64(dh))
|
op.GeoM.Scale(scale, -scale)
|
||||||
op.GeoM.Translate(c.offsetX, c.offsetY)
|
op.GeoM.Translate(0, float64(dh))
|
||||||
|
op.GeoM.Translate(c.offsetX, c.offsetY)
|
||||||
|
|
||||||
op.CompositeMode = CompositeModeCopy
|
op.CompositeMode = CompositeModeCopy
|
||||||
op.Filter = filterScreen
|
op.Filter = filterScreen
|
||||||
_ = c.screen.DrawImage(c.offscreen, op)
|
_ = c.screen.DrawImage(c.offscreen, op)
|
||||||
}
|
|
||||||
|
|
||||||
if err := restorable.ResolveStaleImages(); err != nil {
|
if err := restorable.ResolveStaleImages(); err != nil {
|
||||||
return err
|
return err
|
||||||
|
@ -129,10 +129,6 @@ func (i *Image) clearIfVolatile() {
|
|||||||
if !i.volatile {
|
if !i.volatile {
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
i.ClearFramebuffer()
|
|
||||||
}
|
|
||||||
|
|
||||||
func (i *Image) ClearFramebuffer() {
|
|
||||||
i.basePixels = nil
|
i.basePixels = nil
|
||||||
i.drawImageHistory = nil
|
i.drawImageHistory = nil
|
||||||
i.stale = false
|
i.stale = false
|
||||||
|
Loading…
Reference in New Issue
Block a user