mirror of
https://github.com/hajimehoshi/ebiten.git
synced 2025-01-26 10:42:42 +01:00
Revert "graphics: Refactoring: clearing framebuffer"
This reverts commit 58f5c9c1d0
.
Fixes #515
This commit is contained in:
parent
94c4cc35ab
commit
9adc1ac6a0
@ -17,7 +17,6 @@ package ebiten
|
|||||||
import (
|
import (
|
||||||
"github.com/hajimehoshi/ebiten/internal/clock"
|
"github.com/hajimehoshi/ebiten/internal/clock"
|
||||||
"github.com/hajimehoshi/ebiten/internal/hooks"
|
"github.com/hajimehoshi/ebiten/internal/hooks"
|
||||||
"github.com/hajimehoshi/ebiten/internal/math"
|
|
||||||
"github.com/hajimehoshi/ebiten/internal/restorable"
|
"github.com/hajimehoshi/ebiten/internal/restorable"
|
||||||
"github.com/hajimehoshi/ebiten/internal/ui"
|
"github.com/hajimehoshi/ebiten/internal/ui"
|
||||||
"github.com/hajimehoshi/ebiten/internal/web"
|
"github.com/hajimehoshi/ebiten/internal/web"
|
||||||
@ -59,9 +58,7 @@ func (c *graphicsContext) SetSize(screenWidth, screenHeight int, screenScale flo
|
|||||||
w := int(float64(screenWidth) * screenScale)
|
w := int(float64(screenWidth) * screenScale)
|
||||||
h := int(float64(screenHeight) * screenScale)
|
h := int(float64(screenHeight) * screenScale)
|
||||||
px0, py0, px1, py1 := ui.ScreenPadding()
|
px0, py0, px1, py1 := ui.ScreenPadding()
|
||||||
fw := math.NextPowerOf2Int(w + int(px0+px1))
|
c.screen = newImageWithScreenFramebuffer(w, h, px0, py0, px1, py1)
|
||||||
fh := math.NextPowerOf2Int(h + int(py0+py1))
|
|
||||||
c.screen = newImageWithScreenFramebuffer(w, h, fw, fh)
|
|
||||||
_ = c.screen.Clear()
|
_ = c.screen.Clear()
|
||||||
|
|
||||||
c.offscreen = offscreen
|
c.offscreen = offscreen
|
||||||
|
4
image.go
4
image.go
@ -407,9 +407,9 @@ func NewImageFromImage(source image.Image, filter Filter) (*Image, error) {
|
|||||||
return i, nil
|
return i, nil
|
||||||
}
|
}
|
||||||
|
|
||||||
func newImageWithScreenFramebuffer(width, height, framebufferWidth, framebufferHeight int) *Image {
|
func newImageWithScreenFramebuffer(width, height int, paddingX0, paddingY0, paddingX1, paddingY1 float64) *Image {
|
||||||
checkSize(width, height)
|
checkSize(width, height)
|
||||||
r := restorable.NewScreenFramebufferImage(width, height, framebufferWidth, framebufferHeight)
|
r := restorable.NewScreenFramebufferImage(width, height, paddingX0, paddingY0, paddingX1, paddingY1)
|
||||||
i := &Image{
|
i := &Image{
|
||||||
restorable: r,
|
restorable: r,
|
||||||
filter: FilterDefault,
|
filter: FilterDefault,
|
||||||
|
@ -80,8 +80,10 @@ type Image struct {
|
|||||||
// screen indicates whether the image is used as an actual screen.
|
// screen indicates whether the image is used as an actual screen.
|
||||||
screen bool
|
screen bool
|
||||||
|
|
||||||
framebufferWidth int
|
paddingX0 float64
|
||||||
framebufferHeight int
|
paddingY0 float64
|
||||||
|
paddingX1 float64
|
||||||
|
paddingY1 float64
|
||||||
}
|
}
|
||||||
|
|
||||||
// NewImage creates an empty image with the given size.
|
// NewImage creates an empty image with the given size.
|
||||||
@ -115,13 +117,15 @@ func NewImageFromImage(source image.Image) *Image {
|
|||||||
}
|
}
|
||||||
|
|
||||||
// NewScreenFramebufferImage creates a special image that framebuffer is one for the screen.
|
// NewScreenFramebufferImage creates a special image that framebuffer is one for the screen.
|
||||||
func NewScreenFramebufferImage(width, height, framebufferWidth, framebufferHeight int) *Image {
|
func NewScreenFramebufferImage(width, height int, paddingX0, paddingY0, paddingX1, paddingY1 float64) *Image {
|
||||||
i := &Image{
|
i := &Image{
|
||||||
image: graphics.NewScreenFramebufferImage(width, height),
|
image: graphics.NewScreenFramebufferImage(width, height),
|
||||||
volatile: true,
|
volatile: true,
|
||||||
screen: true,
|
screen: true,
|
||||||
framebufferWidth: framebufferWidth,
|
paddingX0: paddingX0,
|
||||||
framebufferHeight: framebufferHeight,
|
paddingY0: paddingY0,
|
||||||
|
paddingX1: paddingX1,
|
||||||
|
paddingY1: paddingY1,
|
||||||
}
|
}
|
||||||
theImages.add(i)
|
theImages.add(i)
|
||||||
runtime.SetFinalizer(i, (*Image).Dispose)
|
runtime.SetFinalizer(i, (*Image).Dispose)
|
||||||
@ -166,10 +170,11 @@ func (i *Image) clearIfVolatile() {
|
|||||||
panic("not reached")
|
panic("not reached")
|
||||||
}
|
}
|
||||||
|
|
||||||
|
w, h := i.image.Size()
|
||||||
x0 := float32(0)
|
x0 := float32(0)
|
||||||
y0 := float32(0)
|
y0 := float32(0)
|
||||||
x1 := float32(i.framebufferWidth)
|
x1 := float32(w) + float32(i.paddingX0+i.paddingX1)
|
||||||
y1 := float32(i.framebufferHeight)
|
y1 := float32(h) + float32(i.paddingY0+i.paddingY1)
|
||||||
// For the rule of values, see vertices.go.
|
// For the rule of values, see vertices.go.
|
||||||
clearVertices := []float32{
|
clearVertices := []float32{
|
||||||
x0, y0, 0, 0, 1, 1,
|
x0, y0, 0, 0, 1, 1,
|
||||||
|
Loading…
Reference in New Issue
Block a user