factor/library/ui/world.factor

88 lines
2.1 KiB
Factor
Raw Normal View History

2005-01-31 22:32:06 -05:00
! Copyright (C) 2005 Slava Pestov.
! See http://factor.sf.net/license.txt for BSD license.
IN: gadgets
2005-05-03 20:09:04 -04:00
USING: alien errors generic kernel lists math
memory namespaces prettyprint sdl sequences io strings
threads sequences ;
2005-02-01 19:00:16 -05:00
2005-01-31 22:32:06 -05:00
! The world gadget is the top level gadget that all (visible)
! gadgets are contained in. The current world is stored in the
2005-07-08 01:32:29 -04:00
! world variable. The invalid slot is a list of gadgets that
! need to be layout.
TUPLE: world running? hand glass invalid ;
2005-02-01 19:00:16 -05:00
2005-01-31 22:32:06 -05:00
C: world ( -- world )
f <stack> over set-delegate
2005-01-31 22:32:06 -05:00
t over set-world-running?
2005-07-08 01:32:29 -04:00
t over set-gadget-root?
2005-03-06 19:46:29 -05:00
dup <hand> over set-world-hand ;
2005-01-31 22:32:06 -05:00
2005-07-08 01:32:29 -04:00
: add-invalid ( gadget world -- )
[ world-invalid cons ] keep set-world-invalid ;
: pop-invalid ( world -- list )
[ world-invalid f ] keep set-world-invalid ;
: layout-world ( world -- )
dup world-invalid [
dup pop-invalid [ layout ] each layout-world
] [
drop
] ifte ;
: add-layer ( gadget -- )
world get add-gadget ;
2005-07-08 01:32:29 -04:00
: show-glass ( gadget -- )
<empty-gadget> dup
world get 2dup add-gadget set-world-glass
add-gadget ;
2005-07-08 01:32:29 -04:00
: hide-glass ( -- )
world get world-glass unparent f
world get set-world-glass ;
M: world inside? ( point world -- ? ) 2drop t ;
2005-03-03 20:43:55 -05:00
: hand world get world-hand ;
2005-01-31 22:32:06 -05:00
2005-02-19 17:54:04 -05:00
: draw-world ( world -- )
dup gadget-redraw? [
2005-07-08 01:32:29 -04:00
[
dup 0 0 width get height get <rectangle> clip set-paint-prop
draw-gadget
] with-surface
2005-02-01 19:00:16 -05:00
] [
drop
] ifte ;
2005-02-01 21:47:10 -05:00
DEFER: handle-event
2005-03-03 20:43:55 -05:00
2005-02-19 17:54:04 -05:00
: world-step ( world -- ? )
world get dup world-running? [
2005-02-19 17:54:04 -05:00
dup layout-world draw-world t
] [
drop f
] ifte ;
: next-event ( -- event ? )
<event> dup SDL_PollEvent ;
2005-05-03 20:09:04 -04:00
2005-03-01 18:55:25 -05:00
: run-world ( -- )
#! Keep polling for events until there are no more events in
#! the queue; then block for the next event.
2005-05-03 20:09:04 -04:00
next-event [
handle-event run-world
] [
drop world-step [ yield run-world ] when
2005-02-19 21:49:37 -05:00
] ifte ;
2005-01-31 22:32:06 -05:00
2005-03-02 21:26:11 -05:00
: ensure-ui ( -- )
#! Raise an error if the UI is not running.
world get dup [ world-running? ] when [
2005-03-06 19:46:29 -05:00
"UI not running." throw
2005-03-02 21:26:11 -05:00
] unless ;
: start-world ( -- )
world get t over set-world-running? relayout ;