2023-12-23 00:09:07 +03:00
|
|
|
package main
|
|
|
|
|
2024-01-05 04:22:53 +03:00
|
|
|
import "vultras.su/core/gg"
|
2024-01-08 07:12:35 +03:00
|
|
|
//import "fmt"
|
|
|
|
|
|
|
|
var (
|
|
|
|
counter int
|
|
|
|
)
|
2023-12-23 00:09:07 +03:00
|
|
|
|
|
|
|
type Tri struct {
|
2023-12-26 23:31:04 +03:00
|
|
|
gg.DrawablePolygon
|
2024-01-08 06:09:36 +03:00
|
|
|
Spawned bool
|
2023-12-23 00:09:07 +03:00
|
|
|
}
|
|
|
|
|
|
|
|
func NewTri() *Tri {
|
|
|
|
ret := &Tri{}
|
2023-12-24 15:05:34 +03:00
|
|
|
ret.Transform.Scale = gg.V2(1)
|
2023-12-23 00:09:07 +03:00
|
|
|
|
|
|
|
ret.Triangles = gg.Triangles{
|
|
|
|
gg.Triangle{
|
2023-12-27 01:35:50 +03:00
|
|
|
gg.V(0, 10),
|
|
|
|
gg.V(100, 0),
|
|
|
|
gg.V(0, -10),
|
2023-12-23 00:09:07 +03:00
|
|
|
},
|
|
|
|
}
|
2023-12-28 02:31:43 +03:00
|
|
|
ret.Color = gg.Rgba(1, 1, 0, 1)
|
2023-12-23 00:09:07 +03:00
|
|
|
ret.Visible = true
|
|
|
|
ret.Layer = TriangleL
|
2023-12-28 14:34:52 +03:00
|
|
|
ret.Connect(player)
|
2023-12-23 00:09:07 +03:00
|
|
|
|
|
|
|
return ret
|
|
|
|
}
|
|
|
|
|
|
|
|
func (t *Tri) Update(c *Context) {
|
2024-01-08 07:12:35 +03:00
|
|
|
if t.Spawned {
|
|
|
|
return
|
|
|
|
}
|
|
|
|
dt := c.DT()
|
2023-12-23 00:09:07 +03:00
|
|
|
if t.ContainsPoint(c.AbsCursorPosition()) {
|
|
|
|
t.Color = gg.Rgba(0, 1, 0, 1)
|
|
|
|
} else {
|
|
|
|
t.Color = gg.Rgba(1, 0, 1, 1)
|
|
|
|
}
|
2023-12-26 23:31:04 +03:00
|
|
|
|
2024-01-08 07:12:35 +03:00
|
|
|
keys := c.Keys()
|
2024-01-08 06:09:36 +03:00
|
|
|
|
2023-12-26 23:31:04 +03:00
|
|
|
d := +1.
|
|
|
|
if c.IsPressed(gg.KeyShift) {
|
2024-01-08 07:12:35 +03:00
|
|
|
d = -1
|
2023-12-26 23:31:04 +03:00
|
|
|
}
|
2024-01-08 07:12:35 +03:00
|
|
|
|
|
|
|
for _, key := range keys { switch key {
|
|
|
|
case gg.KeyM:
|
|
|
|
absPos := t.AbsPosition()
|
|
|
|
t.SetAbsPosition(
|
2024-01-04 17:05:51 +03:00
|
|
|
absPos.Add(gg.V(0, 100*c.DT()*d)),
|
2023-12-26 23:31:04 +03:00
|
|
|
)
|
2024-01-08 07:12:35 +03:00
|
|
|
case gg.KeyN:
|
|
|
|
absPos := t.AbsPosition()
|
|
|
|
t.SetAbsPosition(
|
2024-01-04 17:05:51 +03:00
|
|
|
absPos.Add(gg.V(100*c.DT()*d, 0)),
|
2023-12-26 23:31:04 +03:00
|
|
|
)
|
2024-01-08 07:12:35 +03:00
|
|
|
case gg.KeyV:
|
|
|
|
t.Rotation += d * gg.Pi * 0.3 * dt
|
|
|
|
case gg.Key2 :
|
2024-01-08 10:22:09 +03:00
|
|
|
if t.Spawned {
|
|
|
|
break
|
|
|
|
}
|
|
|
|
t.Triangles = append(t.Triangles, gg.Triangle{
|
|
|
|
gg.V(0, 10 + gg.Float(counter)),
|
|
|
|
gg.V(100 + gg.Float(counter), 0),
|
|
|
|
gg.V(0, -10 - gg.Float(counter)),
|
|
|
|
})
|
|
|
|
case gg.Key3 :
|
2024-01-08 07:12:35 +03:00
|
|
|
if t.Spawned {
|
|
|
|
break
|
|
|
|
}
|
|
|
|
tt := *t
|
|
|
|
tt.Spawned = true
|
2024-01-08 13:08:52 +03:00
|
|
|
tt.Visible = true
|
2024-01-08 07:12:35 +03:00
|
|
|
tt.Disconnect()
|
2024-01-08 12:25:18 +03:00
|
|
|
if c.Spawn(&tt) == nil {
|
|
|
|
counter++
|
|
|
|
}
|
2024-01-08 07:12:35 +03:00
|
|
|
}}
|
2023-12-28 02:31:43 +03:00
|
|
|
|
2024-01-08 07:12:35 +03:00
|
|
|
for _, event := range c.Events {
|
|
|
|
switch e := event.(type) { case *gg.KeyDown:
|
2024-01-08 06:09:36 +03:00
|
|
|
switch e.Key {
|
|
|
|
case gg.Key1 :
|
|
|
|
if t.Connected() {
|
|
|
|
t.Disconnect()
|
|
|
|
} else {
|
|
|
|
t.Connect(player)
|
|
|
|
}
|
2024-01-08 07:12:35 +03:00
|
|
|
}}}
|
2023-12-28 02:31:43 +03:00
|
|
|
}
|
2024-01-08 07:12:35 +03:00
|
|
|
|