gg/src/cmd/test/main.go

181 lines
3.2 KiB
Go
Raw Normal View History

2023-02-17 07:04:29 +03:00
package main
import (
"github.com/surdeus/gox/src/gx"
2023-02-17 23:51:40 +03:00
"github.com/hajimehoshi/ebiten/v2/examples/resources/images"
"github.com/hajimehoshi/ebiten/v2"
2023-02-17 23:51:40 +03:00
"bytes"
"log"
"strings"
2023-05-26 18:31:04 +03:00
"fmt"
2023-05-27 18:00:27 +03:00
"math/rand"
2023-02-17 07:04:29 +03:00
)
type Player struct {
2023-02-17 23:51:40 +03:00
*gx.Sprite
MoveSpeed gx.Float
ScaleSpeed gx.Float
}
type Debug struct{}
2023-05-26 18:31:04 +03:00
type Rect struct {
*gx.DrawableRectangle
}
func NewRect() *Rect {
return &Rect{&gx.DrawableRectangle{
Rectangle: gx.Rectangle{
Transform: gx.T(),
2023-05-26 18:31:04 +03:00
W: 200,
H: 400,
},
Color: gx.Color{
gx.MaxColorV,
0,
0,
gx.MaxColorV,
},
Visible: true,
/*Shader: gx.SolidWhiteColorShader,
Options: gx.ShaderOptions{
Images: [4]*gx.Image{
playerImg,
nil,
nil,
nil,
},
},*/
}}
}
func (r *Rect) Update(e *gx.Engine) error {
return nil
}
2023-02-17 23:51:40 +03:00
var (
playerImg *gx.Image
)
func NewPlayer() *Player {
2023-05-26 18:31:04 +03:00
ret := &Player{
2023-02-17 23:51:40 +03:00
Sprite: &gx.Sprite{
Transform: gx.Transform {
S: gx.Vector{5, 5},
RA: gx.Vector{320, 240},
2023-02-17 23:51:40 +03:00
},
Visible: true,
ShaderOptions: gx.ShaderOptions {
Shader: gx.SolidWhiteColorShader,
Uniforms: make(map[string] any),
},
2023-02-17 23:51:40 +03:00
},
MoveSpeed: 90.,
ScaleSpeed: .2,
}
2023-05-26 18:31:04 +03:00
ret.Images[0] = playerImg
return ret
}
2023-05-26 18:31:04 +03:00
func (p *Player) Start(e *gx.Engine, v ...any) {
fmt.Println("starting")
c := e.Camera()
c.RA = gx.V(360, -240)
}
func (p *Player) Update(e *gx.Engine) error {
2023-02-18 03:51:43 +03:00
dt := e.DT()
c := e.Camera()
keys := e.Keys()
2023-05-27 18:00:27 +03:00
p.Uniforms["Random"] = any(rand.Float32())
for _, v := range keys {switch v {
case ebiten.KeyArrowUp :
c.P.Y += p.MoveSpeed * dt
case ebiten.KeyArrowLeft :
c.P.X -= p.MoveSpeed * dt
case ebiten.KeyArrowDown :
c.P.Y -= p.MoveSpeed * dt
case ebiten.KeyArrowRight :
c.P.X += p.MoveSpeed * dt
case ebiten.KeyW :
p.P.Y += p.MoveSpeed * dt
case ebiten.KeyA :
p.P.X -= p.MoveSpeed * dt
case ebiten.KeyS :
p.P.Y -= p.MoveSpeed * dt
case ebiten.KeyD :
p.P.X += p.MoveSpeed * dt
case ebiten.KeyR :
c.R += gx.Pi * p.ScaleSpeed * dt
case ebiten.KeyT :
c.R -= gx.Pi * p.ScaleSpeed * dt
case ebiten.KeyF :
if e.KeyIsPressed(ebiten.KeyShift) {
c.S.X -= gx.Pi * p.ScaleSpeed * dt
} else {
c.S.X += gx.Pi * p.ScaleSpeed * dt
}
case ebiten.KeyG :
if e.KeyIsPressed(ebiten.KeyShift) {
c.S.Y -= gx.Pi * p.ScaleSpeed * dt
} else {
c.S.Y += gx.Pi * p.ScaleSpeed * dt
}
case ebiten.KeyZ :
if e.KeyIsPressed(ebiten.KeyShift) {
c.RA.X -= gx.Pi * p.MoveSpeed * dt
} else {
c.RA.X += gx.Pi * p.MoveSpeed * dt
}
log.Println(c.RA.X)
case ebiten.KeyX :
if e.KeyIsPressed(ebiten.KeyShift) {
c.RA.Y -= gx.Pi * p.MoveSpeed * dt
} else {
c.RA.Y += gx.Pi * p.MoveSpeed * dt
}
log.Println(c.RA.Y)
2023-04-28 18:21:34 +03:00
case ebiten.Key0 :
e.Del(p)
}}
return nil
}
func (d *Debug) Draw(
e *gx.Engine,
i *gx.Image,
) {
keyStrs := []string{}
for _, k := range e.Keys() {
keyStrs = append(keyStrs, k.String())
}
e.DebugPrint(i, strings.Join(keyStrs, ", "))
2023-02-17 23:51:40 +03:00
}
func (d *Debug) IsVisible() bool {return true}
2023-02-17 07:04:29 +03:00
func main() {
e := gx.New(&gx.WindowConfig{
Title: "Test title",
Width: 720,
Height: 480,
VSync: true,
2023-02-17 07:04:29 +03:00
})
2023-02-17 23:51:40 +03:00
var err error
playerImg, err = gx.LoadImage(bytes.NewReader(images.Runner_png))
if err != nil {
log.Fatal(err)
}
e.Add(0, NewPlayer())
e.Add(1, &Debug{})
2023-05-26 18:31:04 +03:00
e.Add(-1, NewRect())
2023-02-17 07:04:29 +03:00
e.Run()
}