2009-01-11 20:40:17 -05:00
|
|
|
! Copyright (C) 2005, 2009 Slava Pestov.
|
2007-09-20 18:09:08 -04:00
|
|
|
! See http://factorcode.org/license.txt for BSD license.
|
2009-02-02 01:02:55 -05:00
|
|
|
USING: accessors arrays hashtables io kernel math math.functions
|
|
|
|
namespaces make opengl sequences strings splitting ui.gadgets
|
2009-02-12 04:58:42 -05:00
|
|
|
ui.gadgets.tracks ui.gadgets.packs fonts ui.render ui.pens.solid
|
2009-02-17 07:10:02 -05:00
|
|
|
ui.baseline-alignment ui.text colors colors.constants models
|
2009-09-08 12:43:47 -04:00
|
|
|
combinators opengl.gl ;
|
2007-09-20 18:09:08 -04:00
|
|
|
IN: ui.gadgets.labels
|
|
|
|
|
|
|
|
! A label gadget draws a string.
|
2012-09-18 18:48:49 -04:00
|
|
|
TUPLE: label < aligned-gadget text font ;
|
2007-09-20 18:09:08 -04:00
|
|
|
|
2009-02-01 21:31:42 -05:00
|
|
|
SLOT: string
|
|
|
|
|
|
|
|
M: label string>> ( label -- string )
|
2008-06-18 23:30:54 -04:00
|
|
|
text>> dup string? [ "\n" join ] unless ; inline
|
2007-09-20 18:09:08 -04:00
|
|
|
|
2009-02-09 01:22:41 -05:00
|
|
|
<PRIVATE
|
|
|
|
|
|
|
|
PREDICATE: string-array < array [ string? ] all? ;
|
|
|
|
|
|
|
|
PRIVATE>
|
|
|
|
|
|
|
|
: ?string-lines ( string -- string/array )
|
2009-10-28 16:02:00 -04:00
|
|
|
CHAR: \n over member-eq? [ string-lines ] when ;
|
2009-02-09 01:22:41 -05:00
|
|
|
|
|
|
|
ERROR: not-a-string object ;
|
|
|
|
|
2010-05-05 16:52:54 -04:00
|
|
|
M: label string<< ( string label -- )
|
2009-02-09 01:22:41 -05:00
|
|
|
[
|
|
|
|
{
|
|
|
|
{ [ dup string-array? ] [ ] }
|
|
|
|
{ [ dup string? ] [ ?string-lines ] }
|
|
|
|
[ not-a-string ]
|
|
|
|
} cond
|
2010-05-05 16:52:54 -04:00
|
|
|
] dip text<< ; inline
|
2007-09-20 18:09:08 -04:00
|
|
|
|
2008-06-18 23:30:54 -04:00
|
|
|
: label-theme ( gadget -- gadget )
|
2009-01-30 04:36:39 -05:00
|
|
|
sans-serif-font >>font ; inline
|
2007-09-20 18:09:08 -04:00
|
|
|
|
2008-07-10 21:32:17 -04:00
|
|
|
: new-label ( string class -- label )
|
2009-02-16 05:04:32 -05:00
|
|
|
new
|
2009-02-01 21:31:42 -05:00
|
|
|
swap >>string
|
2008-07-10 21:32:17 -04:00
|
|
|
label-theme ; inline
|
|
|
|
|
|
|
|
: <label> ( string -- label )
|
|
|
|
label new-label ;
|
2007-09-20 18:09:08 -04:00
|
|
|
|
2009-02-01 21:31:42 -05:00
|
|
|
: >label< ( label -- font text )
|
2012-09-17 20:21:31 -04:00
|
|
|
[ font>> ] [ text>> ] bi ; inline
|
2009-02-01 21:31:42 -05:00
|
|
|
|
2007-09-20 18:09:08 -04:00
|
|
|
M: label pref-dim*
|
2009-02-01 21:31:42 -05:00
|
|
|
>label< text-dim ;
|
|
|
|
|
2012-09-18 12:19:29 -04:00
|
|
|
<PRIVATE
|
|
|
|
|
|
|
|
: label-metrics ( label -- metrics )
|
|
|
|
>label< dup string? [ first ] unless line-metrics ;
|
|
|
|
|
|
|
|
PRIVATE>
|
|
|
|
|
2012-09-18 18:48:49 -04:00
|
|
|
M: label baseline*
|
2012-09-18 12:19:29 -04:00
|
|
|
label-metrics ascent>> round ;
|
2009-02-17 07:10:02 -05:00
|
|
|
|
2012-09-18 18:48:49 -04:00
|
|
|
M: label cap-height*
|
2012-09-18 12:19:29 -04:00
|
|
|
label-metrics cap-height>> round ;
|
2007-09-20 18:09:08 -04:00
|
|
|
|
2009-09-08 12:43:47 -04:00
|
|
|
M: label draw-gadget*
|
2009-09-08 14:22:27 -04:00
|
|
|
>label<
|
|
|
|
[
|
|
|
|
background get [ font-with-background ] when*
|
|
|
|
foreground get [ font-with-foreground ] when*
|
|
|
|
] dip
|
|
|
|
draw-text ;
|
2009-09-08 12:43:47 -04:00
|
|
|
|
2009-02-01 21:31:42 -05:00
|
|
|
M: label gadget-text* string>> % ;
|
2007-09-20 18:09:08 -04:00
|
|
|
|
2008-07-10 21:32:17 -04:00
|
|
|
TUPLE: label-control < label ;
|
2007-11-13 18:51:10 -05:00
|
|
|
|
|
|
|
M: label-control model-changed
|
2009-02-01 21:31:42 -05:00
|
|
|
swap value>> >>string relayout ;
|
2007-11-13 18:51:10 -05:00
|
|
|
|
2007-09-20 18:09:08 -04:00
|
|
|
: <label-control> ( model -- gadget )
|
2008-07-10 21:32:17 -04:00
|
|
|
"" label-control new-label
|
|
|
|
swap >>model ;
|
2007-09-20 18:09:08 -04:00
|
|
|
|
2008-06-18 23:30:54 -04:00
|
|
|
: text-theme ( gadget -- gadget )
|
|
|
|
monospace-font >>font ;
|
2007-09-20 18:09:08 -04:00
|
|
|
|
2008-06-18 23:30:54 -04:00
|
|
|
: reverse-video-theme ( label -- label )
|
2009-02-01 21:31:42 -05:00
|
|
|
sans-serif-font reverse-video-font >>font
|
2009-02-05 23:17:15 -05:00
|
|
|
COLOR: black <solid> >>interior ;
|
2007-10-31 01:04:54 -04:00
|
|
|
|
|
|
|
GENERIC: >label ( obj -- gadget )
|
|
|
|
M: string >label <label> ;
|
|
|
|
M: array >label <label> ;
|
|
|
|
M: object >label ;
|
|
|
|
M: f >label drop <gadget> ;
|
|
|
|
|
2009-02-02 01:02:55 -05:00
|
|
|
<PRIVATE
|
|
|
|
|
|
|
|
: label-on-left/right ( -- track )
|
|
|
|
horizontal <track>
|
2009-02-14 21:46:35 -05:00
|
|
|
0 >>fill
|
2009-02-02 01:02:55 -05:00
|
|
|
+baseline+ >>align
|
|
|
|
{ 5 5 } >>gap ; inline
|
|
|
|
PRIVATE>
|
|
|
|
|
2010-07-18 17:30:49 -04:00
|
|
|
: label-on-left ( gadget label -- track )
|
2009-02-02 01:02:55 -05:00
|
|
|
label-on-left/right
|
2008-09-27 15:36:04 -04:00
|
|
|
swap >label f track-add
|
|
|
|
swap 1 track-add ;
|
|
|
|
|
2010-07-18 17:30:49 -04:00
|
|
|
: label-on-right ( label gadget -- track )
|
2009-02-02 01:02:55 -05:00
|
|
|
label-on-left/right
|
2008-09-27 15:36:04 -04:00
|
|
|
swap f track-add
|
|
|
|
swap >label 1 track-add ;
|