Commits
Diff
diff --git a/window/main.go b/window/main.go
index 53fb6f0..01dd46b 100644
--- a/window/main.go
+++ b/window/main.go
@@ -96 +96 @@ func (wm *WindowManager) Draw(nodes []element.State) {
- rad = rad * 3
+
package window
import (
"gui/element"
"gui/fps"
"gui/utils"
"hash/fnv"
"image"
ic "image/color"
"slices"
"sort"
rl "github.com/gen2brain/raylib-go/raylib"
)
type Rect struct {
Node rl.Rectangle
Color rl.Color // Added a Color field
Text Text
}
type Text struct {
Color rl.Color
Size float32
Value string
Font string
}
// WindowManager manages the window and rectangles
type WindowManager struct {
Fonts map[string]rl.Font
FPS bool
FPSCounter fps.FPSCounter
Textures map[int]Texture
}
type Texture struct {
Hash uint64
Image rl.Texture2D
}
// NewWindowManager creates a new WindowManager instance
func NewWindowManager() *WindowManager {
fpsCounter := fps.NewFPSCounter()
return &WindowManager{
Fonts: make(map[string]rl.Font),
FPSCounter: *fpsCounter,
}
}
// OpenWindow opens the window
func (wm *WindowManager) OpenWindow(width, height int32) {
rl.InitWindow(width, height, "")
rl.SetTargetFPS(30)
// Enable window resizing
rl.SetWindowState(rl.FlagWindowResizable)
}
// CloseWindow closes the window
func (wm *WindowManager) CloseWindow() {
rl.CloseWindow()
}
func (wm *WindowManager) LoadTextures(nodes []element.State) {
if wm.Textures == nil {
wm.Textures = map[int]Texture{}
}
for i, node := range nodes {
if node.Texture != nil {
// !TODO: Make a faster hash algo that minimises the time to detect if a image is different
hash := computeImageHash(node.Texture)
if wm.Textures[i].Hash != hash {
rl.UnloadTexture(wm.Textures[i].Image)
texture := rl.LoadTextureFromImage(rl.NewImageFromImage(node.Texture))
wm.Textures[i] = Texture{
Hash: hash,
Image: texture,
}
}
}
}
}
// Draw draws all nodes on the window
func (wm *WindowManager) Draw(nodes []element.State) {
indexes := []float32{0}
// !TODO: Only Draw whats in fov
for a := 0; a < len(indexes); a++ {
for i, node := range nodes {
if node.Z == indexes[a] {
rad, _ := utils.ConvertToPixels(node.Border.Radius, node.EM, node.Width)
rad = rad * 3
p := node.Padding
rect := rl.NewRectangle(node.X+node.Border.Width,
node.Y+node.Border.Width,
node.Width,
(node.Height),
)
// node.Background.A = 100
// node.Background.R = uint8((255 / len(nodes)) * i)
// node.Background.G = uint8((255 / len(nodes)) * i)
// node.Background.B = uint8((255 / len(nodes)) * i)
rl.DrawRectangleRoundedLines(rect, rad/200, 1000, node.Border.Width, node.Border.Color)
rl.DrawRectangleRounded(rect, rad/200, 1000, node.Background)
// fmt.Println(node.Text.Image == nil, node.Text.Text)
// fmt.Printf("%v\n", node.Text)
if node.Texture != nil {
r, g, b, a := node.Color.RGBA()
rl.DrawTexture(wm.Textures[i].Image, int32(node.X+p.Left+node.Border.Width), int32(node.Y+p.Top+node.Border.Width), ic.RGBA{uint8(r), uint8(g), uint8(b), uint8(a)})
}
} else {
if !slices.Contains(indexes, node.Z) {
indexes = append(indexes, node.Z)
sort.Slice(indexes, func(i, j int) bool {
return indexes[i] < indexes[j]
})
}
}
}
}
if wm.FPS {
wm.FPSCounter.Update()
wm.FPSCounter.Draw(10, 10, 10, rl.DarkGray)
}
}
// WindowShouldClose returns true if the window should close
func (wm *WindowManager) WindowShouldClose() bool {
return rl.WindowShouldClose()
}
func computeImageHash(img *image.RGBA) uint64 {
var hash uint64
hasher := fnv.New64a()
// Combine the pixel values to generate the hash
for _, pixel := range img.Pix {
hasher.Write([]byte{pixel})
}
hash = hasher.Sum64()
return hash
}