2015-11-10 01:16:50 +00:00
|
|
|
#lang racket ;; -*- racket -*-
|
|
|
|
|
2016-06-14 07:49:47 +00:00
|
|
|
(require (only-in syndicate seal))
|
|
|
|
(require syndicate/actor)
|
|
|
|
(require syndicate/big-bang)
|
2015-11-10 01:16:50 +00:00
|
|
|
|
|
|
|
(define (button #:background [background "grey"]
|
|
|
|
#:foreground [foreground "white"]
|
|
|
|
#:font-size [font-size 22]
|
|
|
|
name x y label callback)
|
|
|
|
(define label-image (text label font-size foreground))
|
|
|
|
(actor (forever
|
2016-06-14 07:49:47 +00:00
|
|
|
(on (message (mouse-event _ _ name "button-down") #:meta-level 1) (callback))
|
2015-11-10 01:16:50 +00:00
|
|
|
(assert (window name x y 0
|
|
|
|
(seal
|
|
|
|
(overlay label-image
|
|
|
|
(rectangle (+ (image-width label-image) 20)
|
|
|
|
(+ (image-height label-image) 20)
|
|
|
|
"solid"
|
2016-06-14 07:49:47 +00:00
|
|
|
background))))
|
|
|
|
#:meta-level 1))))
|
2015-11-10 01:16:50 +00:00
|
|
|
|
|
|
|
(define (draggable-shape name orig-x orig-y image)
|
2016-06-14 07:49:47 +00:00
|
|
|
(define (window-at x y) (window name x y 10 (seal image)))
|
|
|
|
(define (mouse-left-event-type? t) (member t '("leave" "button-up")))
|
2015-11-10 01:16:50 +00:00
|
|
|
(define (idle ticks x y)
|
2016-06-14 07:49:47 +00:00
|
|
|
;; TODO: Once "tail-calls" between `state`s are fixed, remove the
|
|
|
|
;; ugly returning-of-an-immediately-called-thunk-from-the-
|
|
|
|
;; termination-handlers here and in `dragging`.
|
|
|
|
((state [#:collect [(ticks ticks) (x x) (y y)]
|
|
|
|
(assert (window-at x y) #:meta-level 1)
|
|
|
|
(on (message (tick-event) #:meta-level 1)
|
|
|
|
(define new-ticks (+ ticks 1))
|
|
|
|
(define displacement (* (cos (* new-ticks 10 1/180 pi)) 4))
|
|
|
|
(values new-ticks x (+ y displacement)))]
|
|
|
|
[(message (mouse-event $mx $my name "button-down") #:meta-level 1)
|
|
|
|
(lambda () (dragging mx my (- mx x) (- my y)))])))
|
2015-11-10 01:16:50 +00:00
|
|
|
(define (dragging mx my dx dy)
|
2016-06-14 07:49:47 +00:00
|
|
|
((state [#:collect [(mx mx) (my my)]
|
|
|
|
(assert (window-at (- mx dx) (- my dy)) #:meta-level 1)
|
|
|
|
(on (message (mouse-event $mx $my _ "drag") #:meta-level 1) (values mx my))]
|
|
|
|
[(message (mouse-event $mx $my _ (? mouse-left-event-type? $t)) #:meta-level 1)
|
|
|
|
(lambda () (idle 0 (- mx dx) (- my dy)))])))
|
2015-11-10 01:16:50 +00:00
|
|
|
(actor (idle 0 orig-x orig-y)))
|
|
|
|
|
2016-04-07 07:42:54 +00:00
|
|
|
(big-bang-dataspace #:width 640
|
|
|
|
#:height 480
|
|
|
|
(actor (forever
|
2016-06-14 07:49:47 +00:00
|
|
|
(during (active-window $id) #:meta-level 1
|
|
|
|
(assert (window 'active-window-label 300 0 0
|
|
|
|
(seal (text (format "~v" id) 22 "black")))
|
|
|
|
#:meta-level 1))))
|
2016-04-07 07:42:54 +00:00
|
|
|
(button #:background "red" 'stop-button 0 0 "Exit"
|
|
|
|
(lambda () (assert! 'stop #:meta-level 1)))
|
|
|
|
(draggable-shape 'c1 50 50 (circle 30 "solid" "orange"))
|
|
|
|
(draggable-shape 's1 100 100 (star 40 "solid" "firebrick")))
|
2015-11-10 01:16:50 +00:00
|
|
|
|
|
|
|
(exit 0)
|