mirror of
https://github.com/hajimehoshi/ebiten.git
synced 2025-01-27 03:02:49 +01:00
Refactoring
This commit is contained in:
parent
508e5150de
commit
30cdcfd574
@ -66,11 +66,9 @@ func newContext(screenWidth, screenHeight, screenScale int) *Context {
|
|||||||
|
|
||||||
initializeShaders()
|
initializeShaders()
|
||||||
|
|
||||||
return context
|
context.screen = context.NewTexture(screenWidth, screenHeight)
|
||||||
}
|
|
||||||
|
|
||||||
func (context *Context) setScreen(screen graphics.Texture) {
|
return context
|
||||||
context.screen = screen
|
|
||||||
}
|
}
|
||||||
|
|
||||||
func (context *Context) Screen() graphics.Texture {
|
func (context *Context) Screen() graphics.Texture {
|
||||||
|
@ -31,29 +31,21 @@ import (
|
|||||||
)
|
)
|
||||||
|
|
||||||
type Device struct {
|
type Device struct {
|
||||||
screenWidth int
|
screenScale int
|
||||||
screenHeight int
|
context *Context
|
||||||
screenScale int
|
drawing chan chan func(graphics.Context)
|
||||||
context *Context
|
updating chan chan func()
|
||||||
offscreenTexture graphics.Texture
|
|
||||||
drawing chan chan func(graphics.Context)
|
|
||||||
updating chan chan func()
|
|
||||||
}
|
}
|
||||||
|
|
||||||
func NewDevice(screenWidth, screenHeight, screenScale int, updating chan chan func()) *Device {
|
func NewDevice(screenWidth, screenHeight, screenScale int, updating chan chan func()) *Device {
|
||||||
context := newContext(screenWidth, screenHeight, screenScale)
|
context := newContext(screenWidth, screenHeight, screenScale)
|
||||||
|
|
||||||
device := &Device{
|
device := &Device{
|
||||||
screenWidth: screenWidth,
|
screenScale: screenScale,
|
||||||
screenHeight: screenHeight,
|
drawing: make(chan chan func(graphics.Context)),
|
||||||
screenScale: screenScale,
|
context: context,
|
||||||
drawing: make(chan chan func(graphics.Context)),
|
updating: updating,
|
||||||
context: context,
|
|
||||||
updating: updating,
|
|
||||||
}
|
}
|
||||||
device.offscreenTexture =
|
|
||||||
device.context.NewTexture(screenWidth, screenHeight)
|
|
||||||
device.context.setScreen(device.offscreenTexture)
|
|
||||||
|
|
||||||
go func() {
|
go func() {
|
||||||
for {
|
for {
|
||||||
@ -70,35 +62,35 @@ func (device *Device) Drawing() <-chan chan func(graphics.Context) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
func (device *Device) Update() {
|
func (device *Device) Update() {
|
||||||
g := device.context
|
context := device.context
|
||||||
C.glEnable(C.GL_TEXTURE_2D)
|
C.glEnable(C.GL_TEXTURE_2D)
|
||||||
C.glTexParameteri(C.GL_TEXTURE_2D, C.GL_TEXTURE_MIN_FILTER, C.GL_NEAREST)
|
C.glTexParameteri(C.GL_TEXTURE_2D, C.GL_TEXTURE_MIN_FILTER, C.GL_NEAREST)
|
||||||
C.glTexParameteri(C.GL_TEXTURE_2D, C.GL_TEXTURE_MAG_FILTER, C.GL_NEAREST)
|
C.glTexParameteri(C.GL_TEXTURE_2D, C.GL_TEXTURE_MAG_FILTER, C.GL_NEAREST)
|
||||||
g.SetOffscreen(device.offscreenTexture.ID)
|
context.SetOffscreen(context.Screen().ID)
|
||||||
g.Clear()
|
context.Clear()
|
||||||
|
|
||||||
ch := make(chan func(graphics.Context))
|
ch := make(chan func(graphics.Context))
|
||||||
device.drawing <- ch
|
device.drawing <- ch
|
||||||
drawable := <-ch
|
drawable := <-ch
|
||||||
drawable(g)
|
drawable(context)
|
||||||
|
|
||||||
g.flush()
|
context.flush()
|
||||||
|
|
||||||
C.glTexParameteri(C.GL_TEXTURE_2D, C.GL_TEXTURE_MIN_FILTER, C.GL_LINEAR)
|
C.glTexParameteri(C.GL_TEXTURE_2D, C.GL_TEXTURE_MIN_FILTER, C.GL_LINEAR)
|
||||||
C.glTexParameteri(C.GL_TEXTURE_2D, C.GL_TEXTURE_MAG_FILTER, C.GL_LINEAR)
|
C.glTexParameteri(C.GL_TEXTURE_2D, C.GL_TEXTURE_MAG_FILTER, C.GL_LINEAR)
|
||||||
g.resetOffscreen()
|
context.resetOffscreen()
|
||||||
g.Clear()
|
context.Clear()
|
||||||
|
|
||||||
scale := float64(g.screenScale)
|
scale := float64(context.screenScale)
|
||||||
geometryMatrix := matrix.Geometry{
|
geometryMatrix := matrix.Geometry{
|
||||||
[2][3]float64{
|
[2][3]float64{
|
||||||
{scale, 0, 0},
|
{scale, 0, 0},
|
||||||
{0, scale, 0},
|
{0, scale, 0},
|
||||||
},
|
},
|
||||||
}
|
}
|
||||||
g.DrawTexture(device.offscreenTexture.ID,
|
context.DrawTexture(context.Screen().ID,
|
||||||
geometryMatrix, matrix.IdentityColor())
|
geometryMatrix, matrix.IdentityColor())
|
||||||
g.flush()
|
context.flush()
|
||||||
}
|
}
|
||||||
|
|
||||||
func (device *Device) TextureFactory() graphics.TextureFactory {
|
func (device *Device) TextureFactory() graphics.TextureFactory {
|
||||||
|
Loading…
Reference in New Issue
Block a user