mirror of
https://github.com/hajimehoshi/ebiten.git
synced 2025-01-27 19:22:49 +01:00
Refactoring
This commit is contained in:
parent
c921f4fc3b
commit
991d0a975b
@ -8,11 +8,11 @@ import "C"
|
|||||||
import (
|
import (
|
||||||
"github.com/hajimehoshi/go-ebiten/graphics"
|
"github.com/hajimehoshi/go-ebiten/graphics"
|
||||||
"github.com/hajimehoshi/go-ebiten/graphics/matrix"
|
"github.com/hajimehoshi/go-ebiten/graphics/matrix"
|
||||||
"github.com/hajimehoshi/go-ebiten/graphics/opengl/rendertarget"
|
"github.com/hajimehoshi/go-ebiten/graphics/opengl/offscreen"
|
||||||
"github.com/hajimehoshi/go-ebiten/graphics/opengl/shader"
|
// "github.com/hajimehoshi/go-ebiten/graphics/opengl/shader"
|
||||||
"github.com/hajimehoshi/go-ebiten/graphics/opengl/texture"
|
"github.com/hajimehoshi/go-ebiten/graphics/opengl/texture"
|
||||||
grendertarget "github.com/hajimehoshi/go-ebiten/graphics/rendertarget"
|
grendertarget "github.com/hajimehoshi/go-ebiten/graphics/rendertarget"
|
||||||
gtexture "github.com/hajimehoshi/go-ebiten/graphics/texture"
|
// gtexture "github.com/hajimehoshi/go-ebiten/graphics/texture"
|
||||||
"image"
|
"image"
|
||||||
"math"
|
"math"
|
||||||
)
|
)
|
||||||
@ -23,8 +23,9 @@ type Context struct {
|
|||||||
screenHeight int
|
screenHeight int
|
||||||
screenScale int
|
screenScale int
|
||||||
ids *ids
|
ids *ids
|
||||||
mainFramebufferTexture *grendertarget.RenderTarget
|
//mainFramebufferTexture *grendertarget.RenderTarget
|
||||||
projectionMatrix [16]float32
|
//projectionMatrix [16]float32
|
||||||
|
offscreen *offscreen.Offscreen
|
||||||
}
|
}
|
||||||
|
|
||||||
func newContext(screenWidth, screenHeight, screenScale int) *Context {
|
func newContext(screenWidth, screenHeight, screenScale int) *Context {
|
||||||
@ -33,22 +34,10 @@ func newContext(screenWidth, screenHeight, screenScale int) *Context {
|
|||||||
screenHeight: screenHeight,
|
screenHeight: screenHeight,
|
||||||
screenScale: screenScale,
|
screenScale: screenScale,
|
||||||
ids: newIds(),
|
ids: newIds(),
|
||||||
|
offscreen: offscreen.New(screenWidth, screenHeight, screenScale),
|
||||||
}
|
}
|
||||||
|
|
||||||
// The main framebuffer should be created sooner than any other
|
|
||||||
// framebuffers!
|
|
||||||
mainFramebuffer := C.GLint(0)
|
|
||||||
C.glGetIntegerv(C.GL_FRAMEBUFFER_BINDING, &mainFramebuffer)
|
|
||||||
|
|
||||||
var err error
|
var err error
|
||||||
context.mainFramebufferTexture, err = rendertarget.NewWithFramebuffer(
|
|
||||||
context.screenWidth*context.screenScale,
|
|
||||||
context.screenHeight*context.screenScale,
|
|
||||||
rendertarget.Framebuffer(mainFramebuffer))
|
|
||||||
if err != nil {
|
|
||||||
panic("creating main framebuffer failed: " + err.Error())
|
|
||||||
}
|
|
||||||
|
|
||||||
context.screenId, err = context.createRenderTarget(
|
context.screenId, err = context.createRenderTarget(
|
||||||
context.screenWidth, context.screenHeight, texture.FilterNearest)
|
context.screenWidth, context.screenHeight, texture.FilterNearest)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
@ -82,22 +71,14 @@ func (context *Context) DrawTexture(
|
|||||||
textureId graphics.TextureId,
|
textureId graphics.TextureId,
|
||||||
geometryMatrix matrix.Geometry, colorMatrix matrix.Color) {
|
geometryMatrix matrix.Geometry, colorMatrix matrix.Color) {
|
||||||
tex := context.ids.TextureAt(textureId)
|
tex := context.ids.TextureAt(textureId)
|
||||||
tex.Draw(func(native interface{}, quads []gtexture.Quad) {
|
context.offscreen.DrawTexture(tex, geometryMatrix, colorMatrix)
|
||||||
shader.DrawTexture(native.(texture.Native),
|
|
||||||
context.projectionMatrix, quads,
|
|
||||||
geometryMatrix, colorMatrix)
|
|
||||||
})
|
|
||||||
}
|
}
|
||||||
|
|
||||||
func (context *Context) DrawTextureParts(
|
func (context *Context) DrawTextureParts(
|
||||||
textureId graphics.TextureId, parts []graphics.TexturePart,
|
textureId graphics.TextureId, parts []graphics.TexturePart,
|
||||||
geometryMatrix matrix.Geometry, colorMatrix matrix.Color) {
|
geometryMatrix matrix.Geometry, colorMatrix matrix.Color) {
|
||||||
tex := context.ids.TextureAt(textureId)
|
tex := context.ids.TextureAt(textureId)
|
||||||
tex.DrawParts(parts, func(native interface{}, quads []gtexture.Quad) {
|
context.offscreen.DrawTextureParts(tex, parts, geometryMatrix, colorMatrix)
|
||||||
shader.DrawTexture(native.(texture.Native),
|
|
||||||
context.projectionMatrix, quads,
|
|
||||||
geometryMatrix, colorMatrix)
|
|
||||||
})
|
|
||||||
}
|
}
|
||||||
|
|
||||||
func (context *Context) Init() {
|
func (context *Context) Init() {
|
||||||
@ -115,19 +96,16 @@ func (context *Context) SetOffscreen(renderTargetId graphics.RenderTargetId) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
func (context *Context) setOffscreen(rt *grendertarget.RenderTarget) {
|
func (context *Context) setOffscreen(rt *grendertarget.RenderTarget) {
|
||||||
C.glFlush()
|
/*C.glFlush()
|
||||||
|
|
||||||
setter := &OffscreenSetter{
|
rt.SetAsOffscreen(context.offscreen)
|
||||||
context.screenHeight,
|
context.projectionMatrix = setter.projectionMatrix*/
|
||||||
context.screenScale,
|
context.offscreen.Set(rt)
|
||||||
rt == context.mainFramebufferTexture,
|
|
||||||
&context.projectionMatrix,
|
|
||||||
}
|
|
||||||
rt.SetAsOffscreen(setter)
|
|
||||||
}
|
}
|
||||||
|
|
||||||
func (context *Context) setMainFramebufferOffscreen() {
|
func (context *Context) setMainFramebufferOffscreen() {
|
||||||
context.setOffscreen(context.mainFramebufferTexture)
|
//context.setOffscreen(context.mainFramebufferTexture)
|
||||||
|
context.offscreen.SetMainFramebuffer()
|
||||||
}
|
}
|
||||||
|
|
||||||
func (context *Context) flush() {
|
func (context *Context) flush() {
|
||||||
|
@ -1,48 +0,0 @@
|
|||||||
package opengl
|
|
||||||
|
|
||||||
// #cgo LDFLAGS: -framework OpenGL
|
|
||||||
//
|
|
||||||
// #include <stdlib.h>
|
|
||||||
// #include <OpenGL/gl.h>
|
|
||||||
import "C"
|
|
||||||
import (
|
|
||||||
"fmt"
|
|
||||||
"github.com/hajimehoshi/go-ebiten/graphics"
|
|
||||||
"github.com/hajimehoshi/go-ebiten/graphics/opengl/rendertarget"
|
|
||||||
)
|
|
||||||
|
|
||||||
type OffscreenSetter struct {
|
|
||||||
screenHeight int
|
|
||||||
screenScale int
|
|
||||||
usingMainFramebuffer bool
|
|
||||||
projectionMatrix *[16]float32
|
|
||||||
}
|
|
||||||
|
|
||||||
func (s *OffscreenSetter) Set(framebuffer interface{}, x, y, width, height int) {
|
|
||||||
f := framebuffer.(rendertarget.Framebuffer)
|
|
||||||
C.glBindFramebuffer(C.GL_FRAMEBUFFER, C.GLuint(f))
|
|
||||||
err := C.glCheckFramebufferStatus(C.GL_FRAMEBUFFER)
|
|
||||||
if err != C.GL_FRAMEBUFFER_COMPLETE {
|
|
||||||
panic(fmt.Sprintf("glBindFramebuffer failed: %d", err))
|
|
||||||
}
|
|
||||||
|
|
||||||
C.glBlendFuncSeparate(C.GL_SRC_ALPHA, C.GL_ONE_MINUS_SRC_ALPHA,
|
|
||||||
C.GL_ZERO, C.GL_ONE)
|
|
||||||
|
|
||||||
C.glViewport(C.GLint(x), C.GLint(y),
|
|
||||||
C.GLsizei(width), C.GLsizei(height))
|
|
||||||
|
|
||||||
matrix := graphics.OrthoProjectionMatrix(x, width, y, height)
|
|
||||||
if s.usingMainFramebuffer {
|
|
||||||
actualScreenHeight := s.screenHeight * s.screenScale
|
|
||||||
// Flip Y and move to fit with the top of the window.
|
|
||||||
matrix[1][1] *= -1
|
|
||||||
matrix[1][3] += float64(actualScreenHeight) / float64(height) * 2
|
|
||||||
}
|
|
||||||
|
|
||||||
for j := 0; j < 4; j++ {
|
|
||||||
for i := 0; i < 4; i++ {
|
|
||||||
s.projectionMatrix[i+j*4] = float32(matrix[i][j])
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
115
graphics/opengl/offscreen/offscreen.go
Normal file
115
graphics/opengl/offscreen/offscreen.go
Normal file
@ -0,0 +1,115 @@
|
|||||||
|
package offscreen
|
||||||
|
|
||||||
|
// #cgo LDFLAGS: -framework OpenGL
|
||||||
|
//
|
||||||
|
// #include <stdlib.h>
|
||||||
|
// #include <OpenGL/gl.h>
|
||||||
|
import "C"
|
||||||
|
import (
|
||||||
|
"fmt"
|
||||||
|
"github.com/hajimehoshi/go-ebiten/graphics"
|
||||||
|
"github.com/hajimehoshi/go-ebiten/graphics/matrix"
|
||||||
|
"github.com/hajimehoshi/go-ebiten/graphics/opengl/rendertarget"
|
||||||
|
"github.com/hajimehoshi/go-ebiten/graphics/opengl/shader"
|
||||||
|
"github.com/hajimehoshi/go-ebiten/graphics/opengl/texture"
|
||||||
|
grendertarget "github.com/hajimehoshi/go-ebiten/graphics/rendertarget"
|
||||||
|
gtexture "github.com/hajimehoshi/go-ebiten/graphics/texture"
|
||||||
|
)
|
||||||
|
|
||||||
|
type Offscreen struct {
|
||||||
|
screenHeight int
|
||||||
|
screenScale int
|
||||||
|
mainFramebufferTexture *grendertarget.RenderTarget
|
||||||
|
projectionMatrix [16]float32
|
||||||
|
}
|
||||||
|
|
||||||
|
func New(screenWidth, screenHeight, screenScale int) *Offscreen {
|
||||||
|
offscreen := &Offscreen{
|
||||||
|
screenHeight: screenHeight,
|
||||||
|
screenScale: screenScale,
|
||||||
|
}
|
||||||
|
|
||||||
|
// The main framebuffer should be created sooner than any other
|
||||||
|
// framebuffers!
|
||||||
|
mainFramebuffer := C.GLint(0)
|
||||||
|
C.glGetIntegerv(C.GL_FRAMEBUFFER_BINDING, &mainFramebuffer)
|
||||||
|
|
||||||
|
var err error
|
||||||
|
offscreen.mainFramebufferTexture, err = rendertarget.NewWithFramebuffer(
|
||||||
|
screenWidth*screenScale,
|
||||||
|
screenHeight*screenScale,
|
||||||
|
rendertarget.Framebuffer(mainFramebuffer))
|
||||||
|
if err != nil {
|
||||||
|
panic("creating main framebuffer failed: " + err.Error())
|
||||||
|
}
|
||||||
|
|
||||||
|
return offscreen
|
||||||
|
}
|
||||||
|
|
||||||
|
func (o *Offscreen) Set(rt *grendertarget.RenderTarget) {
|
||||||
|
C.glFlush()
|
||||||
|
rt.SetAsOffscreen(&setter{o, rt == o.mainFramebufferTexture})
|
||||||
|
}
|
||||||
|
|
||||||
|
func (o *Offscreen) SetMainFramebuffer() {
|
||||||
|
o.Set(o.mainFramebufferTexture)
|
||||||
|
}
|
||||||
|
|
||||||
|
func (o *Offscreen) DrawTexture(texture *gtexture.Texture,
|
||||||
|
geometryMatrix matrix.Geometry, colorMatrix matrix.Color) {
|
||||||
|
d := &drawable{o, geometryMatrix, colorMatrix}
|
||||||
|
texture.Draw(d.Draw)
|
||||||
|
}
|
||||||
|
|
||||||
|
func (o *Offscreen) DrawTextureParts(texture *gtexture.Texture,
|
||||||
|
parts []graphics.TexturePart,
|
||||||
|
geometryMatrix matrix.Geometry, colorMatrix matrix.Color) {
|
||||||
|
d := &drawable{o, geometryMatrix, colorMatrix}
|
||||||
|
texture.DrawParts(parts, d.Draw)
|
||||||
|
}
|
||||||
|
|
||||||
|
type setter struct {
|
||||||
|
offscreen *Offscreen
|
||||||
|
usingMainFramebuffer bool
|
||||||
|
}
|
||||||
|
|
||||||
|
func (s *setter) Set(framebuffer interface{}, x, y, width, height int) {
|
||||||
|
f := framebuffer.(rendertarget.Framebuffer)
|
||||||
|
C.glBindFramebuffer(C.GL_FRAMEBUFFER, C.GLuint(f))
|
||||||
|
err := C.glCheckFramebufferStatus(C.GL_FRAMEBUFFER)
|
||||||
|
if err != C.GL_FRAMEBUFFER_COMPLETE {
|
||||||
|
panic(fmt.Sprintf("glBindFramebuffer failed: %d", err))
|
||||||
|
}
|
||||||
|
|
||||||
|
C.glBlendFuncSeparate(C.GL_SRC_ALPHA, C.GL_ONE_MINUS_SRC_ALPHA,
|
||||||
|
C.GL_ZERO, C.GL_ONE)
|
||||||
|
|
||||||
|
C.glViewport(C.GLint(x), C.GLint(y),
|
||||||
|
C.GLsizei(width), C.GLsizei(height))
|
||||||
|
|
||||||
|
matrix := graphics.OrthoProjectionMatrix(x, width, y, height)
|
||||||
|
if s.usingMainFramebuffer {
|
||||||
|
actualScreenHeight := s.offscreen.screenHeight * s.offscreen.screenScale
|
||||||
|
// Flip Y and move to fit with the top of the window.
|
||||||
|
matrix[1][1] *= -1
|
||||||
|
matrix[1][3] += float64(actualScreenHeight) / float64(height) * 2
|
||||||
|
}
|
||||||
|
|
||||||
|
for j := 0; j < 4; j++ {
|
||||||
|
for i := 0; i < 4; i++ {
|
||||||
|
s.offscreen.projectionMatrix[i+j*4] = float32(matrix[i][j])
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
type drawable struct {
|
||||||
|
offscreen *Offscreen
|
||||||
|
geometryMatrix matrix.Geometry
|
||||||
|
colorMatrix matrix.Color
|
||||||
|
}
|
||||||
|
|
||||||
|
func (d *drawable) Draw(native interface{}, quads []gtexture.Quad) {
|
||||||
|
shader.DrawTexture(native.(texture.Native),
|
||||||
|
d.offscreen.projectionMatrix, quads,
|
||||||
|
d.geometryMatrix, d.colorMatrix)
|
||||||
|
}
|
@ -80,7 +80,7 @@ func New(screenWidth, screenHeight, screenScale int, title string) *UI {
|
|||||||
C.StartApplication()
|
C.StartApplication()
|
||||||
|
|
||||||
context := C.CreateGLContext(unsafe.Pointer(nil))
|
context := C.CreateGLContext(unsafe.Pointer(nil))
|
||||||
C.SetCurrentGLContext(context);
|
C.SetCurrentGLContext(context)
|
||||||
ui.graphicsDevice = opengl.NewDevice(
|
ui.graphicsDevice = opengl.NewDevice(
|
||||||
ui.screenWidth,
|
ui.screenWidth,
|
||||||
ui.screenHeight,
|
ui.screenHeight,
|
||||||
|
Loading…
Reference in New Issue
Block a user