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-22 10:23:47 +03:00
|
|
|
import "fmt"
|
2024-01-08 07:12:35 +03:00
|
|
|
|
|
|
|
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{}
|
2024-01-21 13:35:40 +03:00
|
|
|
ret.Transform = gg.T()
|
2024-01-22 10:23:47 +03:00
|
|
|
ret.SetPosition(gg.V(-100, -100))
|
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
|
2024-01-22 20:08:50 +03:00
|
|
|
//ret.Collidable = true
|
2024-01-22 10:23:47 +03:00
|
|
|
ret.Type = gg.CollisionStaticPhysics
|
2023-12-23 00:09:07 +03:00
|
|
|
ret.Layer = TriangleL
|
2024-01-22 10:23:47 +03:00
|
|
|
//ret.Connect(player)
|
2023-12-23 00:09:07 +03:00
|
|
|
|
|
|
|
return ret
|
|
|
|
}
|
|
|
|
|
|
|
|
func (t *Tri) Update(c *Context) {
|
2024-01-22 10:23:47 +03:00
|
|
|
//redges := rect.Edges()
|
|
|
|
//tedges := t.Edges()
|
|
|
|
//crosses, ok := tedges.CrossWithEdges(redges)
|
|
|
|
//fmt.Println("shit:", crosses, ok)
|
|
|
|
|
|
|
|
if false {
|
|
|
|
//fmt.Println("edges:", tedges)
|
|
|
|
}
|
|
|
|
col, hasCol := gg.Collide(t, rect)
|
2024-01-22 20:08:50 +03:00
|
|
|
if hasCol && len(col.Crosses) > 0 {
|
2024-01-22 10:23:47 +03:00
|
|
|
fmt.Println("col:", col)
|
|
|
|
}
|
2024-01-13 23:46:12 +03:00
|
|
|
dt := c.Dt().Seconds()
|
2024-01-16 01:08:21 +03:00
|
|
|
if !t.ContainedPoints(gg.Points{c.AbsCursorPosition()}).Empty() {
|
2023-12-23 00:09:07 +03:00
|
|
|
t.Color = gg.Rgba(0, 1, 0, 1)
|
|
|
|
} else {
|
|
|
|
t.Color = gg.Rgba(1, 0, 1, 1)
|
|
|
|
}
|
2024-01-11 04:45:28 +03:00
|
|
|
if t.Spawned {
|
|
|
|
return
|
|
|
|
}
|
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 {
|
2024-01-21 16:34:23 +03:00
|
|
|
|
2024-01-08 07:12:35 +03:00
|
|
|
case gg.KeyM:
|
2024-01-21 16:34:23 +03:00
|
|
|
t.Move(gg.Y(100*dt*d))
|
2024-01-08 07:12:35 +03:00
|
|
|
case gg.KeyN:
|
2024-01-21 16:34:23 +03:00
|
|
|
t.Move(gg.X(100*dt*d))
|
|
|
|
|
2024-01-08 07:12:35 +03:00
|
|
|
case gg.KeyV:
|
2024-01-21 16:34:23 +03:00
|
|
|
t.Rotate(d * gg.Pi * 0.3 * dt)
|
2024-01-08 07:12:35 +03:00
|
|
|
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
|
|
|
|
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
|
|
|
|