aboutsummaryrefslogtreecommitdiffstats
path: root/examples/layout/blinker.go
diff options
context:
space:
mode:
authorSam Anthony <sam@samanthony.xyz>2024-08-17 14:05:07 -0400
committerSam Anthony <sam@samanthony.xyz>2024-08-17 14:05:07 -0400
commit32f1b20c3e93457dec949e7e426fd3ab17dc3d5c (patch)
tree201321e995e9f74cab877dac64e74eb654946f1b /examples/layout/blinker.go
parentee1ecb5c17ebe98d18dc62390ecb6c09f648a52e (diff)
parent8d183ef96a57e3a2f42c0cb4ec0ab4c256e0d47e (diff)
downloadgui-32f1b20c3e93457dec949e7e426fd3ab17dc3d5c.zip
Merge remote-tracking branch 'keitio/master'
layout
Diffstat (limited to 'examples/layout/blinker.go')
-rw-r--r--examples/layout/blinker.go71
1 files changed, 71 insertions, 0 deletions
diff --git a/examples/layout/blinker.go b/examples/layout/blinker.go
new file mode 100644
index 0000000..65dce43
--- /dev/null
+++ b/examples/layout/blinker.go
@@ -0,0 +1,71 @@
+package main
+
+import (
+ "image"
+ "image/color"
+ "image/draw"
+ "log"
+ "math/rand"
+ "sync"
+ "time"
+
+ "github.com/faiface/gui"
+ "github.com/faiface/gui/win"
+)
+
+func Blinker(env gui.Env) {
+ defer func() {
+ if recover() != nil {
+ log.Print("recovered blinker")
+ }
+ }()
+ buf := make([]byte, 3)
+ rand.Read(buf)
+ defaultColor := image.NewUniform(color.RGBA{buf[0], buf[1], buf[2], 255})
+ rand.Read(buf)
+ blinkColor := image.NewUniform(color.RGBA{buf[0], buf[1], buf[2], 255})
+ redraw := func(r image.Rectangle, visible bool) func(draw.Image) image.Rectangle {
+ return func(drw draw.Image) image.Rectangle {
+ if r == image.ZR {
+ return r
+ }
+ if visible {
+ draw.Draw(drw, r, defaultColor, image.ZP, draw.Src)
+ } else {
+ draw.Draw(drw, r, blinkColor, image.ZP, draw.Src)
+ }
+ return r
+ }
+ }
+
+ var mu sync.Mutex
+ var (
+ r image.Rectangle
+ visible bool = true
+ )
+
+ // first we draw a white rectangle
+ // env.Draw() <- redraw(b)
+ func() {
+ for event := range env.Events() {
+ switch event := event.(type) {
+ case win.MoDown:
+ if event.Point.In(r) {
+ go func() {
+ for i := 0; i < 6; i++ {
+ mu.Lock()
+ visible = !visible
+ env.Draw() <- redraw(r, visible)
+ mu.Unlock()
+
+ time.Sleep(time.Second / 3)
+ }
+ }()
+ }
+ case gui.Resize:
+ r = event.Rectangle
+ env.Draw() <- redraw(r, visible)
+ }
+ }
+ }()
+}