graphicsdriver/monogame: Implement some functions

Updates #1078
This commit is contained in:
Hajime Hoshi 2020-04-05 16:34:34 +09:00
parent fa90e48eec
commit 3a5f0a7a95
2 changed files with 20 additions and 4 deletions

View File

@ -24,6 +24,10 @@ import (
) )
type Graphics struct { type Graphics struct {
dst *Image
src *Image
vertices []float32
indices []uint16
} }
var theGraphics Graphics var theGraphics Graphics
@ -33,25 +37,31 @@ func Get() *Graphics {
} }
func (g *Graphics) SetThread(thread *thread.Thread) { func (g *Graphics) SetThread(thread *thread.Thread) {
panic("monogame: SetThread is not implemented yet") panic("monogame: SetThread is not implemented")
} }
func (g *Graphics) Begin() { func (g *Graphics) Begin() {
// Do nothing
} }
func (g *Graphics) End() { func (g *Graphics) End() {
// Do nothing
} }
func (g *Graphics) SetTransparent(transparent bool) { func (g *Graphics) SetTransparent(transparent bool) {
panic("monogame: SetTransparent is not implemented yet")
} }
func (g *Graphics) SetVertices(vertices []float32, indices []uint16) { func (g *Graphics) SetVertices(vertices []float32, indices []uint16) {
g.vertices = vertices
g.indices = indices
} }
func (g *Graphics) NewImage(width, height int) (driver.Image, error) { func (g *Graphics) NewImage(width, height int) (driver.Image, error) {
v := monogame.CurrentGame().NewRenderTarget2D(width, height) v := monogame.CurrentGame().NewRenderTarget2D(width, height)
return &Image{ return &Image{
v: v, v: v,
g: g,
width: width, width: width,
height: height, height: height,
}, nil }, nil
@ -59,6 +69,7 @@ func (g *Graphics) NewImage(width, height int) (driver.Image, error) {
func (g *Graphics) NewScreenFramebufferImage(width, height int) (driver.Image, error) { func (g *Graphics) NewScreenFramebufferImage(width, height int) (driver.Image, error) {
return &Image{ return &Image{
g: g,
width: width, width: width,
height: height, height: height,
}, nil }, nil
@ -69,11 +80,12 @@ func (g *Graphics) Reset() error {
} }
func (g *Graphics) Draw(indexLen int, indexOffset int, mode driver.CompositeMode, colorM *affine.ColorM, filter driver.Filter, address driver.Address) error { func (g *Graphics) Draw(indexLen int, indexOffset int, mode driver.CompositeMode, colorM *affine.ColorM, filter driver.Filter, address driver.Address) error {
// TODO: Implement
return nil return nil
} }
func (g *Graphics) SetVsyncEnabled(enabled bool) { func (g *Graphics) SetVsyncEnabled(enabled bool) {
// TODO: Implement this panic("monogame: SetVsyncEnabled is not implemented yet")
} }
func (g *Graphics) VDirection() driver.VDirection { func (g *Graphics) VDirection() driver.VDirection {

View File

@ -23,6 +23,7 @@ import (
type Image struct { type Image struct {
v *monogame.RenderTarget2D v *monogame.RenderTarget2D
g *Graphics
width int width int
height int height int
} }
@ -36,13 +37,16 @@ func (*Image) IsInvalidated() bool {
} }
func (*Image) Pixels() ([]byte, error) { func (*Image) Pixels() ([]byte, error) {
panic("monogame: Pixels is not implemented yet")
return nil, nil return nil, nil
} }
func (*Image) SetAsDestination() { func (i *Image) SetAsDestination() {
i.g.dst = i
} }
func (*Image) SetAsSource() { func (i *Image) SetAsSource() {
i.g.src = i
} }
func (i *Image) ReplacePixels(args []*driver.ReplacePixelsArgs) { func (i *Image) ReplacePixels(args []*driver.ReplacePixelsArgs) {