gg/cmd/test/player.go

164 lines
3 KiB
Go

package main
import "surdeus.su/core/gg"
import "surdeus.su/core/gg/ox"
import "surdeus.su/core/gg/mx"
import "time"
//import "log"
type Player struct {
ox.AnimatedSprite
MoveSpeed mx.Float
ScaleSpeed mx.Float
Spawned bool
}
func NewPlayer() *Player {
ret := &Player{}
//ret.Transform = ox.T()
ret.AnimatedSprite = ox.NewAnimatedSprite(
playerAnimations,
time.Second / 10,
)
ret.SetScale(mx.V2(1))
ret.SetAround(mx.V2(.5))
ret.MoveSpeed = 40.
ret.ScaleSpeed = .2
ret.Shader = gg.SolidWhiteColorShader
ret.Visible = true
ret.Layer = LayerPlayer
//ret.Collidable = true
//ret.Resolvable = true
return ret
}
func (p *Player) OnStart(c Context) {
p.Connect(rect)
}
func (p *Player) Draw(c Context) *gg.Drawing {
return p.AnimatedSprite.Draw(c)
prect := &ox.DrawableRectangle{
Rectangle: p.GetRectangle(),
}
prect.Color = gg.RGBA(1, 1, 1, 1)
return prect.Draw(c)
}
func (p *Player) OnUpdate(c Context) {
//log.Println("OnUpdate(...)")
if p.Spawned {
return
}
e := c.Engine()
dt := e.DT().Seconds()
//cam := c.Camera
keys := e.GetKeyboardKeys()
/*r := gg.Rectangle{
Transform: gg.T(),
}
r.Width = 150
r.Height = 150
col, _ := gg.Collide(p, r)
fmt.Println(col.Crosses)*/
//p.SetPosition(p.Position().Sub(gg.Y(2)))
//p.Move(gg.Y(1))
walking := false
shiftPressed := e.IsPressed(gg.KeyShift)
d := float64(1)
if shiftPressed {
d *= -1
}
//p.Uniforms["Random"] = any(rand.Float32())
for _, key := range keys {
switch key {
case gg.KeyQ:
p.AddScale(mx.VX(d*p.ScaleSpeed * dt))
case gg.KeyW:
p.Move(mx.VY(-p.MoveSpeed * dt))
walking = true
p.Animate(Walk)
case gg.KeyA:
p.Move(mx.VX(-p.MoveSpeed * dt))
p.SetScale(mx.V(-1, 1))
walking = true
p.Animate(Walk)
case gg.KeyS:
p.Move(mx.VY(p.MoveSpeed * dt))
//p.Position.Y -= p.MoveSpeed * dt
walking = true
p.Animate(Walk)
case gg.KeyD:
p.Move(mx.VX(p.MoveSpeed * dt))
p.SetScale(mx.V(1, 1))
walking = true
p.Animate(Walk)
case gg.KeyE :
p.Rotate(d*mx.Pi * 0.3 * dt)
case gg.KeyX:
c.Engine().Delete(p)
case gg.KeyC:
pp := *p
counter++
pp.Spawned = true
//pp.Collidable = false
//pp.Resolvable = false
c.Engine().Spawn(&pp)
}
}
if !walking {
p.Animate(Stand)
}
for _, down := range c.Events().Keyboard.Downs {
switch {
case down.Key == gg.KeyZ:
if p.Layer != LayerPlayer {
p.Layer = LayerPlayer
} else {
p.Layer = LayerHighest
}
}
}
}
/*func (p *Player) GetCollisionInterest() []gg.CollisionType {
return []gg.CollisionType{
gg.CollisionStaticPhysics,
}
}*/
/*func (p *Player) Resolve(c *Context) {
col := c.Collisions[0]
if !p.Spawned && false {
fmt.Printf(
"frame[%d]: the col[0] len(%d): %T, %T, %d %d\n",
c.Frame(), len(c.Collisions), col.What, col.With, len(col.Crosses), len(col.Points),
)
}
for _, col := range c.Collisions {
switch col.Type {
case gg.CollisionStaticPhysics:
LOOP:
for {
p.Move(gg.Y(-1))
_, collides := gg.Collide(p, col.With)
if !collides {
break LOOP
}
}
}
}
}*/