Artifact
ed1ac7e149327202a2533bbced8ecfd6163a1a63:
0000: 23 6c 61 6e 67 20 72 61 63 6b 65 74 0a 28 72 65 #lang racket.(re
0010: 71 75 69 72 65 0a 20 73 72 66 69 2f 31 37 0a 20 quire. srfi/17.
0020: 73 72 66 69 2f 32 36 0a 20 66 66 69 2f 75 6e 73 srfi/26. ffi/uns
0030: 61 66 65 0a 20 66 66 69 2f 75 6e 73 61 66 65 2f afe. ffi/unsafe/
0040: 63 76 65 63 74 6f 72 0a 20 22 62 61 73 65 2e 72 cvector. "base.r
0050: 6b 74 22 29 0a 0a 28 64 65 66 69 6e 65 20 6c 69 kt")..(define li
0060: 62 63 64 0a 20 20 28 63 61 73 65 20 28 73 79 73 bcd. (case (sys
0070: 74 65 6d 2d 74 79 70 65 20 27 6f 73 29 0a 20 20 tem-type 'os).
0080: 20 20 5b 28 77 69 6e 64 6f 77 73 29 0a 20 20 20 [(windows).
0090: 20 20 28 66 66 69 2d 6c 69 62 20 22 63 64 22 29 (ffi-lib "cd")
00a0: 5d 0a 20 20 20 20 5b 65 6c 73 65 0a 20 20 20 20 ]. [else.
00b0: 20 28 66 66 69 2d 6c 69 62 20 22 6c 69 62 63 64 (ffi-lib "libcd
00c0: 22 29 5d 29 29 0a 0a 3b 3b 20 7b 7b 7b 20 50 6f ")]))..;; {{{ Po
00d0: 69 6e 74 20 64 72 61 77 69 6e 67 20 66 75 6e 63 int drawing func
00e0: 74 69 6f 6e 73 0a 0a 28 64 65 66 69 6e 65 20 63 tions..(define c
00f0: 61 6e 76 61 73 2d 70 69 78 65 6c 21 0a 20 20 28 anvas-pixel!. (
0100: 67 65 74 2d 66 66 69 2d 6f 62 6a 0a 20 20 20 22 get-ffi-obj. "
0110: 63 64 43 61 6e 76 61 73 50 69 78 65 6c 22 20 6c cdCanvasPixel" l
0120: 69 62 63 64 0a 20 20 20 28 5f 66 75 6e 20 28 63 ibcd. (_fun (c
0130: 61 6e 76 61 73 20 78 20 79 20 5b 63 6f 6c 6f 72 anvas x y [color
0140: 20 28 63 61 6e 76 61 73 2d 66 6f 72 65 67 72 6f (canvas-foregro
0150: 75 6e 64 20 63 61 6e 76 61 73 29 5d 29 0a 20 20 und canvas)]).
0160: 20 20 20 20 20 20 20 3a 3a 20 5b 63 61 6e 76 61 :: [canva
0170: 73 20 3a 20 5f 63 61 6e 76 61 73 5d 20 5b 78 20 s : _canvas] [x
0180: 3a 20 5f 69 6e 74 5d 20 5b 79 20 3a 20 5f 69 6e : _int] [y : _in
0190: 74 5d 20 5b 63 6f 6c 6f 72 20 3a 20 5f 75 6c 6f t] [color : _ulo
01a0: 6e 67 5d 20 2d 3e 20 5f 76 6f 69 64 29 29 29 0a ng] -> _void))).
01b0: 0a 28 64 65 66 69 6e 65 20 63 61 6e 76 61 73 2d .(define canvas-
01c0: 6d 61 72 6b 21 0a 20 20 28 67 65 74 2d 66 66 69 mark!. (get-ffi
01d0: 2d 6f 62 6a 0a 20 20 20 22 63 64 43 61 6e 76 61 -obj. "cdCanva
01e0: 73 4d 61 72 6b 22 20 6c 69 62 63 64 0a 20 20 20 sMark" libcd.
01f0: 28 5f 66 75 6e 20 5b 63 61 6e 76 61 73 20 3a 20 (_fun [canvas :
0200: 5f 63 61 6e 76 61 73 5d 20 5b 78 20 3a 20 5f 69 _canvas] [x : _i
0210: 6e 74 5d 20 5b 79 20 3a 20 5f 69 6e 74 5d 20 2d nt] [y : _int] -
0220: 3e 20 5f 76 6f 69 64 29 29 29 0a 0a 28 64 65 66 > _void)))..(def
0230: 69 6e 65 20 5f 6d 61 72 6b 2d 74 79 70 65 0a 20 ine _mark-type.
0240: 20 28 5f 65 6e 75 6d 0a 20 20 20 27 28 2b 20 3d (_enum. '(+ =
0250: 20 30 20 70 6c 75 73 20 3d 20 30 0a 20 20 20 20 0 plus = 0.
0260: 20 2a 20 3d 20 31 20 73 74 61 72 20 3d 20 31 0a * = 1 star = 1.
0270: 20 20 20 20 20 30 20 3d 20 32 20 63 69 72 63 6c 0 = 2 circl
0280: 65 20 3d 20 32 0a 20 20 20 20 20 58 20 3d 20 33 e = 2. X = 3
0290: 20 78 20 3d 20 33 0a 20 20 20 20 20 62 6f 78 0a x = 3. box.
02a0: 20 20 20 20 20 64 69 61 6d 6f 6e 64 0a 20 20 20 diamond.
02b0: 20 20 4f 20 3d 20 36 20 68 6f 6c 6c 6f 77 2d 63 O = 6 hollow-c
02c0: 69 72 63 6c 65 20 3d 20 36 0a 20 20 20 20 20 68 ircle = 6. h
02d0: 6f 6c 6c 6f 77 2d 62 6f 78 0a 20 20 20 20 20 68 ollow-box. h
02e0: 6f 6c 6c 6f 77 2d 64 69 61 6d 6f 6e 64 29 0a 20 ollow-diamond).
02f0: 20 20 5f 66 69 78 69 6e 74 29 29 0a 0a 28 64 65 _fixint))..(de
0300: 66 69 6e 65 20 63 61 6e 76 61 73 2d 6d 61 72 6b fine canvas-mark
0310: 2d 74 79 70 65 2d 73 65 74 21 0a 20 20 28 67 65 -type-set!. (ge
0320: 74 2d 66 66 69 2d 6f 62 6a 0a 20 20 20 22 63 64 t-ffi-obj. "cd
0330: 43 61 6e 76 61 73 4d 61 72 6b 54 79 70 65 22 20 CanvasMarkType"
0340: 6c 69 62 63 64 0a 20 20 20 28 5f 66 75 6e 20 5b libcd. (_fun [
0350: 63 61 6e 76 61 73 20 3a 20 5f 63 61 6e 76 61 73 canvas : _canvas
0360: 5d 20 5b 6d 61 72 6b 2d 74 79 70 65 20 3a 20 5f ] [mark-type : _
0370: 6d 61 72 6b 2d 74 79 70 65 5d 20 2d 3e 20 5f 76 mark-type] -> _v
0380: 6f 69 64 29 29 29 0a 0a 28 64 65 66 69 6e 65 20 oid)))..(define
0390: 63 61 6e 76 61 73 2d 6d 61 72 6b 2d 74 79 70 65 canvas-mark-type
03a0: 0a 20 20 28 67 65 74 74 65 72 2d 77 69 74 68 2d . (getter-with-
03b0: 73 65 74 74 65 72 0a 20 20 20 28 67 65 74 2d 66 setter. (get-f
03c0: 66 69 2d 6f 62 6a 0a 20 20 20 20 22 63 64 43 61 fi-obj. "cdCa
03d0: 6e 76 61 73 4d 61 72 6b 54 79 70 65 22 20 6c 69 nvasMarkType" li
03e0: 62 63 64 0a 20 20 20 20 28 5f 66 75 6e 20 5b 63 bcd. (_fun [c
03f0: 61 6e 76 61 73 20 3a 20 5f 63 61 6e 76 61 73 5d anvas : _canvas]
0400: 20 5b 71 75 65 72 79 20 3a 20 5f 66 69 78 69 6e [query : _fixin
0410: 74 20 3d 20 2d 31 5d 20 2d 3e 20 5b 6d 61 72 6b t = -1] -> [mark
0420: 2d 74 79 70 65 20 3a 20 5f 6d 61 72 6b 2d 74 79 -type : _mark-ty
0430: 70 65 5d 29 29 0a 20 20 20 63 61 6e 76 61 73 2d pe])). canvas-
0440: 6d 61 72 6b 2d 74 79 70 65 2d 73 65 74 21 29 29 mark-type-set!))
0450: 0a 0a 28 64 65 66 69 6e 65 20 63 61 6e 76 61 73 ..(define canvas
0460: 2d 6d 61 72 6b 2d 73 69 7a 65 2d 73 65 74 21 0a -mark-size-set!.
0470: 20 20 28 67 65 74 2d 66 66 69 2d 6f 62 6a 0a 20 (get-ffi-obj.
0480: 20 20 22 63 64 43 61 6e 76 61 73 4d 61 72 6b 53 "cdCanvasMarkS
0490: 69 7a 65 22 20 6c 69 62 63 64 0a 20 20 20 28 5f ize" libcd. (_
04a0: 66 75 6e 20 5b 63 61 6e 76 61 73 20 3a 20 5f 63 fun [canvas : _c
04b0: 61 6e 76 61 73 5d 20 5b 73 69 7a 65 20 3a 20 5f anvas] [size : _
04c0: 69 6e 74 5d 20 2d 3e 20 5f 76 6f 69 64 29 29 29 int] -> _void)))
04d0: 0a 0a 28 64 65 66 69 6e 65 20 63 61 6e 76 61 73 ..(define canvas
04e0: 2d 6d 61 72 6b 2d 73 69 7a 65 0a 20 20 28 67 65 -mark-size. (ge
04f0: 74 74 65 72 2d 77 69 74 68 2d 73 65 74 74 65 72 tter-with-setter
0500: 0a 20 20 20 28 67 65 74 2d 66 66 69 2d 6f 62 6a . (get-ffi-obj
0510: 0a 20 20 20 20 22 63 64 43 61 6e 76 61 73 4d 61 . "cdCanvasMa
0520: 72 6b 53 69 7a 65 22 20 6c 69 62 63 64 0a 20 20 rkSize" libcd.
0530: 20 20 28 5f 66 75 6e 20 5b 63 61 6e 76 61 73 20 (_fun [canvas
0540: 3a 20 5f 63 61 6e 76 61 73 5d 20 5b 71 75 65 72 : _canvas] [quer
0550: 79 20 3a 20 5f 69 6e 74 20 3d 20 2d 31 5d 20 2d y : _int = -1] -
0560: 3e 20 5b 73 69 7a 65 20 3a 20 5f 69 6e 74 5d 29 > [size : _int])
0570: 29 0a 20 20 20 63 61 6e 76 61 73 2d 6d 61 72 6b ). canvas-mark
0580: 2d 73 69 7a 65 2d 73 65 74 21 29 29 0a 0a 28 70 -size-set!))..(p
0590: 72 6f 76 69 64 65 0a 20 63 61 6e 76 61 73 2d 70 rovide. canvas-p
05a0: 69 78 65 6c 21 0a 20 63 61 6e 76 61 73 2d 6d 61 ixel!. canvas-ma
05b0: 72 6b 21 0a 20 63 61 6e 76 61 73 2d 6d 61 72 6b rk!. canvas-mark
05c0: 2d 74 79 70 65 20 63 61 6e 76 61 73 2d 6d 61 72 -type canvas-mar
05d0: 6b 2d 74 79 70 65 2d 73 65 74 21 0a 20 63 61 6e k-type-set!. can
05e0: 76 61 73 2d 6d 61 72 6b 2d 73 69 7a 65 20 63 61 vas-mark-size ca
05f0: 6e 76 61 73 2d 6d 61 72 6b 2d 73 69 7a 65 2d 73 nvas-mark-size-s
0600: 65 74 21 29 0a 0a 3b 3b 20 7d 7d 7d 0a 0a 3b 3b et!)..;; }}}..;;
0610: 20 7b 7b 7b 20 4c 69 6e 65 20 66 75 6e 63 74 69 {{{ Line functi
0620: 6f 6e 73 0a 0a 28 64 65 66 69 6e 65 20 63 61 6e ons..(define can
0630: 76 61 73 2d 6c 69 6e 65 21 0a 20 20 28 67 65 74 vas-line!. (get
0640: 2d 66 66 69 2d 6f 62 6a 0a 20 20 20 22 63 64 66 -ffi-obj. "cdf
0650: 43 61 6e 76 61 73 4c 69 6e 65 22 20 6c 69 62 63 CanvasLine" libc
0660: 64 0a 20 20 20 28 5f 66 75 6e 20 5b 63 61 6e 76 d. (_fun [canv
0670: 61 73 20 3a 20 5f 63 61 6e 76 61 73 5d 20 5b 78 as : _canvas] [x
0680: 30 20 3a 20 5f 64 6f 75 62 6c 65 2a 5d 20 5b 79 0 : _double*] [y
0690: 30 20 3a 20 5f 64 6f 75 62 6c 65 2a 5d 20 5b 78 0 : _double*] [x
06a0: 31 20 3a 20 5f 64 6f 75 62 6c 65 2a 5d 20 5b 79 1 : _double*] [y
06b0: 31 20 3a 20 5f 64 6f 75 62 6c 65 2a 5d 20 2d 3e 1 : _double*] ->
06c0: 20 5f 76 6f 69 64 29 29 29 0a 0a 28 64 65 66 69 _void)))..(defi
06d0: 6e 65 20 63 61 6e 76 61 73 2d 72 65 63 74 61 6e ne canvas-rectan
06e0: 67 6c 65 21 0a 20 20 28 67 65 74 2d 66 66 69 2d gle!. (get-ffi-
06f0: 6f 62 6a 0a 20 20 20 22 63 64 66 43 61 6e 76 61 obj. "cdfCanva
0700: 73 52 65 63 74 22 20 6c 69 62 63 64 0a 20 20 20 sRect" libcd.
0710: 28 5f 66 75 6e 20 5b 63 61 6e 76 61 73 20 3a 20 (_fun [canvas :
0720: 5f 63 61 6e 76 61 73 5d 20 5b 78 30 20 3a 20 5f _canvas] [x0 : _
0730: 64 6f 75 62 6c 65 2a 5d 20 5b 78 31 20 3a 20 5f double*] [x1 : _
0740: 64 6f 75 62 6c 65 2a 5d 20 5b 79 30 20 3a 20 5f double*] [y0 : _
0750: 64 6f 75 62 6c 65 2a 5d 20 5b 79 31 20 3a 20 5f double*] [y1 : _
0760: 64 6f 75 62 6c 65 2a 5d 20 2d 3e 20 5f 76 6f 69 double*] -> _voi
0770: 64 29 29 29 0a 0a 28 64 65 66 69 6e 65 20 63 61 d)))..(define ca
0780: 6e 76 61 73 2d 61 72 63 21 0a 20 20 28 67 65 74 nvas-arc!. (get
0790: 2d 66 66 69 2d 6f 62 6a 0a 20 20 20 22 63 64 66 -ffi-obj. "cdf
07a0: 43 61 6e 76 61 73 41 72 63 22 20 6c 69 62 63 64 CanvasArc" libcd
07b0: 0a 20 20 20 28 5f 66 75 6e 20 5b 63 61 6e 76 61 . (_fun [canva
07c0: 73 20 3a 20 5f 63 61 6e 76 61 73 5d 0a 20 20 20 s : _canvas].
07d0: 20 20 20 20 20 20 5b 78 20 3a 20 5f 64 6f 75 62 [x : _doub
07e0: 6c 65 2a 5d 20 5b 79 20 3a 20 5f 64 6f 75 62 6c le*] [y : _doubl
07f0: 65 2a 5d 20 5b 77 69 64 74 68 20 3a 20 5f 64 6f e*] [width : _do
0800: 75 62 6c 65 2a 5d 20 5b 68 65 69 67 68 74 20 3a uble*] [height :
0810: 20 5f 64 6f 75 62 6c 65 2a 5d 0a 20 20 20 20 20 _double*].
0820: 20 20 20 20 5b 61 6c 70 68 61 30 20 3a 20 5f 64 [alpha0 : _d
0830: 6f 75 62 6c 65 2a 5d 20 5b 61 6c 70 68 61 31 20 ouble*] [alpha1
0840: 3a 20 5f 64 6f 75 62 6c 65 2a 5d 0a 20 20 20 20 : _double*].
0850: 20 20 20 20 20 2d 3e 20 5f 76 6f 69 64 29 29 29 -> _void)))
0860: 0a 0a 28 64 65 66 69 6e 65 20 5f 6c 69 6e 65 2d ..(define _line-
0870: 73 74 79 6c 65 0a 20 20 28 5f 65 6e 75 6d 0a 20 style. (_enum.
0880: 20 20 27 28 63 6f 6e 74 69 6e 75 6f 75 73 20 64 '(continuous d
0890: 61 73 68 65 64 20 64 6f 74 74 65 64 20 64 61 73 ashed dotted das
08a0: 68 2d 64 6f 74 74 65 64 20 64 61 73 68 2d 64 6f h-dotted dash-do
08b0: 74 2d 64 6f 74 74 65 64 20 63 75 73 74 6f 6d 29 t-dotted custom)
08c0: 0a 20 20 20 5f 66 69 78 69 6e 74 29 29 0a 0a 28 . _fixint))..(
08d0: 64 65 66 69 6e 65 20 63 61 6e 76 61 73 2d 6c 69 define canvas-li
08e0: 6e 65 2d 73 74 79 6c 65 2d 73 65 74 21 0a 20 20 ne-style-set!.
08f0: 28 6c 65 74 72 65 63 20 28 5b 63 61 6e 76 61 73 (letrec ([canvas
0900: 2d 6c 69 6e 65 2d 73 74 79 6c 65 2d 73 65 74 2f -line-style-set/
0910: 72 61 77 21 0a 20 20 20 20 20 20 20 20 20 20 20 raw!.
0920: 20 28 67 65 74 2d 66 66 69 2d 6f 62 6a 0a 20 20 (get-ffi-obj.
0930: 20 20 20 20 20 20 20 20 20 20 20 22 63 64 43 61 "cdCa
0940: 6e 76 61 73 4c 69 6e 65 53 74 79 6c 65 22 20 6c nvasLineStyle" l
0950: 69 62 63 64 0a 20 20 20 20 20 20 20 20 20 20 20 ibcd.
0960: 20 20 28 5f 66 75 6e 20 5b 63 61 6e 76 61 73 20 (_fun [canvas
0970: 3a 20 5f 63 61 6e 76 61 73 5d 20 5b 6c 69 6e 65 : _canvas] [line
0980: 2d 73 74 79 6c 65 20 3a 20 5f 6c 69 6e 65 2d 73 -style : _line-s
0990: 74 79 6c 65 5d 20 2d 3e 20 5f 76 6f 69 64 29 29 tyle] -> _void))
09a0: 5d 0a 20 20 20 20 20 20 20 20 20 20 20 5b 63 61 ]. [ca
09b0: 6e 76 61 73 2d 6c 69 6e 65 2d 73 74 79 6c 65 2d nvas-line-style-
09c0: 64 61 73 68 65 73 2d 73 65 74 2f 72 61 77 21 0a dashes-set/raw!.
09d0: 20 20 20 20 20 20 20 20 20 20 20 20 28 67 65 74 (get
09e0: 2d 66 66 69 2d 6f 62 6a 0a 20 20 20 20 20 20 20 -ffi-obj.
09f0: 20 20 20 20 20 20 22 63 64 43 61 6e 76 61 73 4c "cdCanvasL
0a00: 69 6e 65 53 74 79 6c 65 44 61 73 68 65 73 22 20 ineStyleDashes"
0a10: 6c 69 62 63 64 0a 20 20 20 20 20 20 20 20 20 20 libcd.
0a20: 20 20 20 28 5f 66 75 6e 20 5b 63 61 6e 76 61 73 (_fun [canvas
0a30: 20 3a 20 5f 63 61 6e 76 61 73 5d 20 5b 64 61 73 : _canvas] [das
0a40: 68 65 73 20 3a 20 5f 63 76 65 63 74 6f 72 5d 20 hes : _cvector]
0a50: 5b 6c 65 6e 20 3a 20 5f 69 6e 74 20 3d 20 28 63 [len : _int = (c
0a60: 76 65 63 74 6f 72 2d 6c 65 6e 67 74 68 20 64 61 vector-length da
0a70: 73 68 65 73 29 5d 20 2d 3e 20 5f 76 6f 69 64 29 shes)] -> _void)
0a80: 29 5d 29 0a 20 20 20 20 28 ce bb 20 28 63 61 6e )]). (λ (can
0a90: 76 61 73 20 6c 69 6e 65 2d 73 74 79 6c 65 29 0a vas line-style).
0aa0: 20 20 20 20 20 20 28 6d 61 74 63 68 20 6c 69 6e (match lin
0ab0: 65 2d 73 74 79 6c 65 0a 20 20 20 20 20 20 20 20 e-style.
0ac0: 5b 28 6c 69 73 74 2d 72 65 73 74 20 27 63 75 73 [(list-rest 'cus
0ad0: 74 6f 6d 20 64 61 73 68 65 73 29 0a 20 20 20 20 tom dashes).
0ae0: 20 20 20 20 20 28 63 61 6e 76 61 73 2d 6c 69 6e (canvas-lin
0af0: 65 2d 73 74 79 6c 65 2d 64 61 73 68 65 73 2d 73 e-style-dashes-s
0b00: 65 74 2f 72 61 77 21 20 63 61 6e 76 61 73 20 28 et/raw! canvas (
0b10: 6c 69 73 74 2d 3e 63 76 65 63 74 6f 72 20 64 61 list->cvector da
0b20: 73 68 65 73 20 5f 69 6e 74 29 29 0a 20 20 20 20 shes _int)).
0b30: 20 20 20 20 20 28 63 61 6e 76 61 73 2d 6c 69 6e (canvas-lin
0b40: 65 2d 73 74 79 6c 65 2d 73 65 74 2f 72 61 77 21 e-style-set/raw!
0b50: 20 63 61 6e 76 61 73 20 27 64 61 73 68 65 73 29 canvas 'dashes)
0b60: 5d 0a 20 20 20 20 20 20 20 20 5b 5f 0a 20 20 20 ]. [_.
0b70: 20 20 20 20 20 20 28 63 61 6e 76 61 73 2d 6c 69 (canvas-li
0b80: 6e 65 2d 73 74 79 6c 65 2d 73 65 74 2f 72 61 77 ne-style-set/raw
0b90: 21 20 63 61 6e 76 61 73 20 6c 69 6e 65 2d 73 74 ! canvas line-st
0ba0: 79 6c 65 29 5d 29 29 29 29 0a 0a 28 64 65 66 69 yle)]))))..(defi
0bb0: 6e 65 20 63 61 6e 76 61 73 2d 6c 69 6e 65 2d 73 ne canvas-line-s
0bc0: 74 79 6c 65 0a 20 20 28 67 65 74 74 65 72 2d 77 tyle. (getter-w
0bd0: 69 74 68 2d 73 65 74 74 65 72 0a 20 20 20 28 67 ith-setter. (g
0be0: 65 74 2d 66 66 69 2d 6f 62 6a 0a 20 20 20 20 22 et-ffi-obj. "
0bf0: 63 64 43 61 6e 76 61 73 4c 69 6e 65 53 74 79 6c cdCanvasLineStyl
0c00: 65 22 20 6c 69 62 63 64 0a 20 20 20 20 28 5f 66 e" libcd. (_f
0c10: 75 6e 20 5b 63 61 6e 76 61 73 20 3a 20 5f 63 61 un [canvas : _ca
0c20: 6e 76 61 73 5d 20 5b 71 75 65 72 79 20 3a 20 5f nvas] [query : _
0c30: 66 69 78 69 6e 74 20 3d 20 2d 31 5d 20 2d 3e 20 fixint = -1] ->
0c40: 5b 6c 69 6e 65 2d 73 74 79 6c 65 20 3a 20 5f 6c [line-style : _l
0c50: 69 6e 65 2d 73 74 79 6c 65 5d 29 29 0a 20 20 20 ine-style])).
0c60: 63 61 6e 76 61 73 2d 6c 69 6e 65 2d 73 74 79 6c canvas-line-styl
0c70: 65 2d 73 65 74 21 29 29 0a 0a 28 64 65 66 69 6e e-set!))..(defin
0c80: 65 20 63 61 6e 76 61 73 2d 6c 69 6e 65 2d 77 69 e canvas-line-wi
0c90: 64 74 68 2d 73 65 74 21 0a 20 20 28 67 65 74 2d dth-set!. (get-
0ca0: 66 66 69 2d 6f 62 6a 0a 20 20 20 22 63 64 43 61 ffi-obj. "cdCa
0cb0: 6e 76 61 73 4c 69 6e 65 57 69 64 74 68 22 20 6c nvasLineWidth" l
0cc0: 69 62 63 64 0a 20 20 20 28 5f 66 75 6e 20 5b 63 ibcd. (_fun [c
0cd0: 61 6e 76 61 73 20 3a 20 5f 63 61 6e 76 61 73 5d anvas : _canvas]
0ce0: 20 5b 77 69 64 74 68 20 3a 20 5f 69 6e 74 5d 20 [width : _int]
0cf0: 2d 3e 20 5f 76 6f 69 64 29 29 29 0a 0a 28 64 65 -> _void)))..(de
0d00: 66 69 6e 65 20 63 61 6e 76 61 73 2d 6c 69 6e 65 fine canvas-line
0d10: 2d 77 69 64 74 68 0a 20 20 28 67 65 74 74 65 72 -width. (getter
0d20: 2d 77 69 74 68 2d 73 65 74 74 65 72 0a 20 20 20 -with-setter.
0d30: 28 67 65 74 2d 66 66 69 2d 6f 62 6a 0a 20 20 20 (get-ffi-obj.
0d40: 20 22 63 64 43 61 6e 76 61 73 4c 69 6e 65 57 69 "cdCanvasLineWi
0d50: 64 74 68 22 20 6c 69 62 63 64 0a 20 20 20 20 28 dth" libcd. (
0d60: 5f 66 75 6e 20 5b 63 61 6e 76 61 73 20 3a 20 5f _fun [canvas : _
0d70: 63 61 6e 76 61 73 5d 20 5b 71 75 65 72 79 20 3a canvas] [query :
0d80: 20 5f 69 6e 74 20 3d 20 2d 31 5d 20 2d 3e 20 5b _int = -1] -> [
0d90: 77 69 64 74 68 20 3a 20 5f 69 6e 74 5d 29 29 0a width : _int])).
0da0: 20 20 20 63 61 6e 76 61 73 2d 6c 69 6e 65 2d 77 canvas-line-w
0db0: 69 64 74 68 2d 73 65 74 21 29 29 0a 0a 28 64 65 idth-set!))..(de
0dc0: 66 69 6e 65 20 5f 6c 69 6e 65 2d 6a 6f 69 6e 0a fine _line-join.
0dd0: 20 20 28 5f 65 6e 75 6d 0a 20 20 20 27 28 6d 69 (_enum. '(mi
0de0: 74 65 72 20 62 65 76 65 6c 20 72 6f 75 6e 64 29 ter bevel round)
0df0: 0a 20 20 20 5f 66 69 78 69 6e 74 29 29 0a 0a 28 . _fixint))..(
0e00: 64 65 66 69 6e 65 20 63 61 6e 76 61 73 2d 6c 69 define canvas-li
0e10: 6e 65 2d 6a 6f 69 6e 2d 73 65 74 21 0a 20 20 28 ne-join-set!. (
0e20: 67 65 74 2d 66 66 69 2d 6f 62 6a 0a 20 20 20 22 get-ffi-obj. "
0e30: 63 64 43 61 6e 76 61 73 4c 69 6e 65 4a 6f 69 6e cdCanvasLineJoin
0e40: 22 20 6c 69 62 63 64 0a 20 20 20 28 5f 66 75 6e " libcd. (_fun
0e50: 20 5b 63 61 6e 76 61 73 20 3a 20 5f 63 61 6e 76 [canvas : _canv
0e60: 61 73 5d 20 5b 6c 69 6e 65 2d 6a 6f 69 6e 20 3a as] [line-join :
0e70: 20 5f 6c 69 6e 65 2d 6a 6f 69 6e 5d 20 2d 3e 20 _line-join] ->
0e80: 5f 76 6f 69 64 29 29 29 0a 0a 28 64 65 66 69 6e _void)))..(defin
0e90: 65 20 63 61 6e 76 61 73 2d 6c 69 6e 65 2d 6a 6f e canvas-line-jo
0ea0: 69 6e 0a 20 20 28 67 65 74 74 65 72 2d 77 69 74 in. (getter-wit
0eb0: 68 2d 73 65 74 74 65 72 0a 20 20 20 28 67 65 74 h-setter. (get
0ec0: 2d 66 66 69 2d 6f 62 6a 0a 20 20 20 20 22 63 64 -ffi-obj. "cd
0ed0: 43 61 6e 76 61 73 4c 69 6e 65 4a 6f 69 6e 22 20 CanvasLineJoin"
0ee0: 6c 69 62 63 64 0a 20 20 20 20 28 5f 66 75 6e 20 libcd. (_fun
0ef0: 5b 63 61 6e 76 61 73 20 3a 20 5f 63 61 6e 76 61 [canvas : _canva
0f00: 73 5d 20 5b 71 75 65 72 79 20 3a 20 5f 66 69 78 s] [query : _fix
0f10: 69 6e 74 20 3d 20 2d 31 5d 20 2d 3e 20 5f 76 6f int = -1] -> _vo
0f20: 69 64 29 29 0a 20 20 20 63 61 6e 76 61 73 2d 6c id)). canvas-l
0f30: 69 6e 65 2d 6a 6f 69 6e 2d 73 65 74 21 29 29 0a ine-join-set!)).
0f40: 0a 28 64 65 66 69 6e 65 20 5f 6c 69 6e 65 2d 63 .(define _line-c
0f50: 61 70 0a 20 20 28 5f 65 6e 75 6d 0a 20 20 20 27 ap. (_enum. '
0f60: 28 66 6c 61 74 20 73 71 75 61 72 65 20 72 6f 75 (flat square rou
0f70: 6e 64 29 0a 20 20 20 5f 66 69 78 69 6e 74 29 29 nd). _fixint))
0f80: 0a 0a 28 64 65 66 69 6e 65 20 63 61 6e 76 61 73 ..(define canvas
0f90: 2d 6c 69 6e 65 2d 63 61 70 2d 73 65 74 21 0a 20 -line-cap-set!.
0fa0: 20 28 67 65 74 2d 66 66 69 2d 6f 62 6a 0a 20 20 (get-ffi-obj.
0fb0: 20 22 63 64 43 61 6e 76 61 73 4c 69 6e 65 43 61 "cdCanvasLineCa
0fc0: 70 22 20 6c 69 62 63 64 0a 20 20 20 28 5f 66 75 p" libcd. (_fu
0fd0: 6e 20 5b 63 61 6e 76 61 73 20 3a 20 5f 63 61 6e n [canvas : _can
0fe0: 76 61 73 5d 20 5b 6c 69 6e 65 2d 63 61 70 20 3a vas] [line-cap :
0ff0: 20 5f 6c 69 6e 65 2d 63 61 70 5d 20 2d 3e 20 5f _line-cap] -> _
1000: 76 6f 69 64 29 29 29 0a 0a 28 64 65 66 69 6e 65 void)))..(define
1010: 20 63 61 6e 76 61 73 2d 6c 69 6e 65 2d 63 61 70 canvas-line-cap
1020: 0a 20 20 28 67 65 74 74 65 72 2d 77 69 74 68 2d . (getter-with-
1030: 73 65 74 74 65 72 0a 20 20 20 28 67 65 74 2d 66 setter. (get-f
1040: 66 69 2d 6f 62 6a 0a 20 20 20 20 22 63 64 43 61 fi-obj. "cdCa
1050: 6e 76 61 73 4c 69 6e 65 43 61 70 22 20 6c 69 62 nvasLineCap" lib
1060: 63 64 0a 20 20 20 20 28 5f 66 75 6e 20 5b 63 61 cd. (_fun [ca
1070: 6e 76 61 73 20 3a 20 5f 63 61 6e 76 61 73 5d 20 nvas : _canvas]
1080: 5b 71 75 65 72 79 20 3a 20 5f 66 69 78 69 6e 74 [query : _fixint
1090: 20 3d 20 2d 31 5d 20 2d 3e 20 5b 6c 69 6e 65 2d = -1] -> [line-
10a0: 63 61 70 20 3a 20 5f 6c 69 6e 65 2d 63 61 70 5d cap : _line-cap]
10b0: 29 29 0a 20 20 20 63 61 6e 76 61 73 2d 6c 69 6e )). canvas-lin
10c0: 65 2d 63 61 70 2d 73 65 74 21 29 29 0a 0a 28 70 e-cap-set!))..(p
10d0: 72 6f 76 69 64 65 0a 20 63 61 6e 76 61 73 2d 6c rovide. canvas-l
10e0: 69 6e 65 21 20 63 61 6e 76 61 73 2d 72 65 63 74 ine! canvas-rect
10f0: 61 6e 67 6c 65 21 20 63 61 6e 76 61 73 2d 61 72 angle! canvas-ar
1100: 63 21 0a 20 63 61 6e 76 61 73 2d 6c 69 6e 65 2d c!. canvas-line-
1110: 73 74 79 6c 65 20 63 61 6e 76 61 73 2d 6c 69 6e style canvas-lin
1120: 65 2d 73 74 79 6c 65 2d 73 65 74 21 0a 20 63 61 e-style-set!. ca
1130: 6e 76 61 73 2d 6c 69 6e 65 2d 77 69 64 74 68 20 nvas-line-width
1140: 63 61 6e 76 61 73 2d 6c 69 6e 65 2d 77 69 64 74 canvas-line-widt
1150: 68 2d 73 65 74 21 0a 20 63 61 6e 76 61 73 2d 6c h-set!. canvas-l
1160: 69 6e 65 2d 6a 6f 69 6e 20 63 61 6e 76 61 73 2d ine-join canvas-
1170: 6c 69 6e 65 2d 6a 6f 69 6e 2d 73 65 74 21 0a 20 line-join-set!.
1180: 63 61 6e 76 61 73 2d 6c 69 6e 65 2d 63 61 70 20 canvas-line-cap
1190: 63 61 6e 76 61 73 2d 6c 69 6e 65 2d 63 61 70 2d canvas-line-cap-
11a0: 73 65 74 21 29 0a 0a 3b 3b 20 7d 7d 7d 0a 0a 3b set!)..;; }}}..;
11b0: 3b 20 7b 7b 7b 20 46 69 6c 6c 65 64 20 61 72 65 ; {{{ Filled are
11c0: 61 20 66 75 6e 63 74 69 6f 6e 73 0a 0a 28 64 65 a functions..(de
11d0: 66 69 6e 65 20 63 61 6e 76 61 73 2d 62 6f 78 21 fine canvas-box!
11e0: 0a 20 20 28 67 65 74 2d 66 66 69 2d 6f 62 6a 0a . (get-ffi-obj.
11f0: 20 20 20 22 63 64 66 43 61 6e 76 61 73 42 6f 78 "cdfCanvasBox
1200: 22 20 6c 69 62 63 64 0a 20 20 20 28 5f 66 75 6e " libcd. (_fun
1210: 20 5b 63 61 6e 76 61 73 20 3a 20 5f 63 61 6e 76 [canvas : _canv
1220: 61 73 5d 20 5b 78 30 20 3a 20 5f 64 6f 75 62 6c as] [x0 : _doubl
1230: 65 2a 5d 20 5b 78 31 20 3a 20 5f 64 6f 75 62 6c e*] [x1 : _doubl
1240: 65 2a 5d 20 5b 79 30 20 3a 20 5f 64 6f 75 62 6c e*] [y0 : _doubl
1250: 65 2a 5d 20 5b 79 31 20 3a 20 5f 64 6f 75 62 6c e*] [y1 : _doubl
1260: 65 2a 5d 20 2d 3e 20 5f 76 6f 69 64 29 29 29 0a e*] -> _void))).
1270: 0a 28 64 65 66 69 6e 65 20 63 61 6e 76 61 73 2d .(define canvas-
1280: 73 65 63 74 6f 72 21 0a 20 20 28 67 65 74 2d 66 sector!. (get-f
1290: 66 69 2d 6f 62 6a 0a 20 20 20 22 63 64 66 43 61 fi-obj. "cdfCa
12a0: 6e 76 61 73 53 65 63 74 6f 72 22 20 6c 69 62 63 nvasSector" libc
12b0: 64 0a 20 20 20 28 5f 66 75 6e 20 5b 63 61 6e 76 d. (_fun [canv
12c0: 61 73 20 3a 20 5f 63 61 6e 76 61 73 5d 0a 20 20 as : _canvas].
12d0: 20 20 20 20 20 20 20 5b 78 20 3a 20 5f 64 6f 75 [x : _dou
12e0: 62 6c 65 2a 5d 20 5b 79 20 3a 20 5f 64 6f 75 62 ble*] [y : _doub
12f0: 6c 65 2a 5d 20 5b 77 69 64 74 68 20 3a 20 5f 64 le*] [width : _d
1300: 6f 75 62 6c 65 2a 5d 20 5b 68 65 69 67 68 74 20 ouble*] [height
1310: 3a 20 5f 64 6f 75 62 6c 65 2a 5d 0a 20 20 20 20 : _double*].
1320: 20 20 20 20 20 5b 61 6c 70 68 61 30 20 3a 20 5f [alpha0 : _
1330: 64 6f 75 62 6c 65 2a 5d 20 5b 61 6c 70 68 61 31 double*] [alpha1
1340: 20 3a 20 5f 64 6f 75 62 6c 65 2a 5d 0a 20 20 20 : _double*].
1350: 20 20 20 20 20 20 2d 3e 20 5f 76 6f 69 64 29 29 -> _void))
1360: 29 0a 0a 28 64 65 66 69 6e 65 20 63 61 6e 76 61 )..(define canva
1370: 73 2d 63 68 6f 72 64 21 0a 20 20 28 67 65 74 2d s-chord!. (get-
1380: 66 66 69 2d 6f 62 6a 0a 20 20 20 22 63 64 66 43 ffi-obj. "cdfC
1390: 61 6e 76 61 73 43 68 6f 72 64 22 20 6c 69 62 63 anvasChord" libc
13a0: 64 0a 20 20 20 28 5f 66 75 6e 20 5b 63 61 6e 76 d. (_fun [canv
13b0: 61 73 20 3a 20 5f 63 61 6e 76 61 73 5d 0a 20 20 as : _canvas].
13c0: 20 20 20 20 20 20 20 5b 78 20 3a 20 5f 64 6f 75 [x : _dou
13d0: 62 6c 65 2a 5d 20 5b 79 20 3a 20 5f 64 6f 75 62 ble*] [y : _doub
13e0: 6c 65 2a 5d 20 5b 77 69 64 74 68 20 3a 20 5f 64 le*] [width : _d
13f0: 6f 75 62 6c 65 2a 5d 20 5b 68 65 69 67 68 74 20 ouble*] [height
1400: 3a 20 5f 64 6f 75 62 6c 65 2a 5d 0a 20 20 20 20 : _double*].
1410: 20 20 20 20 20 5b 61 6c 70 68 61 30 20 3a 20 5f [alpha0 : _
1420: 64 6f 75 62 6c 65 2a 5d 20 5b 61 6c 70 68 61 31 double*] [alpha1
1430: 20 3a 20 5f 64 6f 75 62 6c 65 2a 5d 0a 20 20 20 : _double*].
1440: 20 20 20 20 20 20 2d 3e 20 5f 76 6f 69 64 29 29 -> _void))
1450: 29 0a 0a 28 64 65 66 69 6e 65 20 5f 6f 70 61 63 )..(define _opac
1460: 69 74 79 0a 20 20 28 5f 65 6e 75 6d 0a 20 20 20 ity. (_enum.
1470: 27 28 6f 70 61 71 75 65 20 74 72 61 6e 73 70 61 '(opaque transpa
1480: 72 65 6e 74 29 0a 20 20 20 5f 66 69 78 69 6e 74 rent). _fixint
1490: 29 29 0a 0a 28 64 65 66 69 6e 65 20 63 61 6e 76 ))..(define canv
14a0: 61 73 2d 62 61 63 6b 67 72 6f 75 6e 64 2d 6f 70 as-background-op
14b0: 61 63 69 74 79 2d 73 65 74 21 0a 20 20 28 67 65 acity-set!. (ge
14c0: 74 2d 66 66 69 2d 6f 62 6a 0a 20 20 20 22 63 64 t-ffi-obj. "cd
14d0: 43 61 6e 76 61 73 42 61 63 6b 4f 70 61 63 69 74 CanvasBackOpacit
14e0: 79 22 20 6c 69 62 63 64 0a 20 20 20 28 5f 66 75 y" libcd. (_fu
14f0: 6e 20 5b 63 61 6e 76 61 73 20 3a 20 5f 63 61 6e n [canvas : _can
1500: 76 61 73 5d 20 5b 6f 70 61 63 69 74 79 20 3a 20 vas] [opacity :
1510: 5f 6f 70 61 63 69 74 79 5d 20 2d 3e 20 5f 76 6f _opacity] -> _vo
1520: 69 64 29 29 29 0a 0a 28 64 65 66 69 6e 65 20 63 id)))..(define c
1530: 61 6e 76 61 73 2d 62 61 63 6b 67 72 6f 75 6e 64 anvas-background
1540: 2d 6f 70 61 63 69 74 79 0a 20 20 28 67 65 74 74 -opacity. (gett
1550: 65 72 2d 77 69 74 68 2d 73 65 74 74 65 72 0a 20 er-with-setter.
1560: 20 20 28 67 65 74 2d 66 66 69 2d 6f 62 6a 0a 20 (get-ffi-obj.
1570: 20 20 20 22 63 64 43 61 6e 76 61 73 42 61 63 6b "cdCanvasBack
1580: 4f 70 61 63 69 74 79 22 20 6c 69 62 63 64 0a 20 Opacity" libcd.
1590: 20 20 20 28 5f 66 75 6e 20 5b 63 61 6e 76 61 73 (_fun [canvas
15a0: 20 3a 20 5f 63 61 6e 76 61 73 5d 20 5b 71 75 65 : _canvas] [que
15b0: 72 79 20 3a 20 5f 66 69 78 69 6e 74 20 3d 20 2d ry : _fixint = -
15c0: 31 5d 20 2d 3e 20 5b 6f 70 61 63 69 74 79 20 3a 1] -> [opacity :
15d0: 20 5f 6f 70 61 63 69 74 79 5d 29 29 0a 20 20 20 _opacity])).
15e0: 63 61 6e 76 61 73 2d 62 61 63 6b 67 72 6f 75 6e canvas-backgroun
15f0: 64 2d 6f 70 61 63 69 74 79 2d 73 65 74 21 29 29 d-opacity-set!))
1600: 0a 0a 28 64 65 66 69 6e 65 20 5f 66 69 6c 6c 2d ..(define _fill-
1610: 6d 6f 64 65 0a 20 20 28 5f 65 6e 75 6d 0a 20 20 mode. (_enum.
1620: 20 27 28 65 76 65 6e 2d 6f 64 64 20 77 69 6e 64 '(even-odd wind
1630: 69 6e 67 29 0a 20 20 20 5f 66 69 78 69 6e 74 29 ing). _fixint)
1640: 29 0a 0a 28 64 65 66 69 6e 65 20 63 61 6e 76 61 )..(define canva
1650: 73 2d 66 69 6c 6c 2d 6d 6f 64 65 2d 73 65 74 21 s-fill-mode-set!
1660: 0a 20 20 28 67 65 74 2d 66 66 69 2d 6f 62 6a 0a . (get-ffi-obj.
1670: 20 20 20 22 63 64 43 61 6e 76 61 73 46 69 6c 6c "cdCanvasFill
1680: 4d 6f 64 65 22 20 6c 69 62 63 64 0a 20 20 20 28 Mode" libcd. (
1690: 5f 66 75 6e 20 5b 63 61 6e 76 61 73 20 3a 20 5f _fun [canvas : _
16a0: 63 61 6e 76 61 73 5d 20 5b 66 69 6c 6c 2d 6d 6f canvas] [fill-mo
16b0: 64 65 20 3a 20 5f 66 69 6c 6c 2d 6d 6f 64 65 5d de : _fill-mode]
16c0: 20 2d 3e 20 5f 76 6f 69 64 29 29 29 0a 0a 28 64 -> _void)))..(d
16d0: 65 66 69 6e 65 20 63 61 6e 76 61 73 2d 66 69 6c efine canvas-fil
16e0: 6c 2d 6d 6f 64 65 0a 20 20 28 67 65 74 74 65 72 l-mode. (getter
16f0: 2d 77 69 74 68 2d 73 65 74 74 65 72 0a 20 20 20 -with-setter.
1700: 28 67 65 74 2d 66 66 69 2d 6f 62 6a 0a 20 20 20 (get-ffi-obj.
1710: 20 22 63 64 43 61 6e 76 61 73 46 69 6c 6c 4d 6f "cdCanvasFillMo
1720: 64 65 22 20 6c 69 62 63 64 0a 20 20 20 20 28 5f de" libcd. (_
1730: 66 75 6e 20 5b 63 61 6e 76 61 73 20 3a 20 5f 63 fun [canvas : _c
1740: 61 6e 76 61 73 5d 20 5b 71 75 65 72 79 20 3a 20 anvas] [query :
1750: 5f 66 69 78 69 6e 74 20 3d 20 2d 31 5d 20 2d 3e _fixint = -1] ->
1760: 20 5b 66 69 6c 6c 2d 6d 6f 64 65 20 3a 20 5f 66 [fill-mode : _f
1770: 69 6c 6c 2d 6d 6f 64 65 5d 29 29 0a 20 20 20 63 ill-mode])). c
1780: 61 6e 76 61 73 2d 66 69 6c 6c 2d 6d 6f 64 65 2d anvas-fill-mode-
1790: 73 65 74 21 29 29 0a 0a 28 64 65 66 69 6e 65 20 set!))..(define
17a0: 5f 69 6e 74 65 72 69 6f 72 2d 73 74 79 6c 65 0a _interior-style.
17b0: 20 20 28 5f 65 6e 75 6d 0a 20 20 20 27 28 73 6f (_enum. '(so
17c0: 6c 69 64 20 68 61 74 63 68 20 73 74 69 70 70 6c lid hatch stippl
17d0: 65 20 70 61 74 74 65 72 6e 20 23 66 29 0a 20 20 e pattern #f).
17e0: 20 5f 66 69 78 69 6e 74 29 29 0a 0a 28 64 65 66 _fixint))..(def
17f0: 69 6e 65 20 5f 68 61 74 63 68 2d 73 74 79 6c 65 ine _hatch-style
1800: 0a 20 20 28 5f 65 6e 75 6d 0a 20 20 20 27 28 68 . (_enum. '(h
1810: 6f 72 69 7a 6f 6e 74 61 6c 20 76 65 72 74 69 63 orizontal vertic
1820: 61 6c 20 66 6f 72 77 61 72 64 2d 64 69 61 67 6f al forward-diago
1830: 6e 61 6c 20 62 61 63 6b 77 61 72 64 2d 64 69 61 nal backward-dia
1840: 67 6f 6e 61 6c 20 63 72 6f 73 73 20 64 69 61 67 gonal cross diag
1850: 6f 6e 61 6c 2d 63 72 6f 73 73 29 0a 20 20 20 5f onal-cross). _
1860: 66 69 78 69 6e 74 29 29 0a 0a 28 64 65 66 69 6e fixint))..(defin
1870: 65 20 63 61 6e 76 61 73 2d 69 6e 74 65 72 69 6f e canvas-interio
1880: 72 2d 73 74 79 6c 65 2d 73 65 74 21 0a 20 20 28 r-style-set!. (
1890: 6c 65 74 72 65 63 20 28 5b 63 61 6e 76 61 73 2d letrec ([canvas-
18a0: 69 6e 74 65 72 69 6f 72 2d 73 74 79 6c 65 2d 73 interior-style-s
18b0: 65 74 2f 72 61 77 21 0a 20 20 20 20 20 20 20 20 et/raw!.
18c0: 20 20 20 20 28 67 65 74 2d 66 66 69 2d 6f 62 6a (get-ffi-obj
18d0: 0a 20 20 20 20 20 20 20 20 20 20 20 20 20 22 63 . "c
18e0: 64 43 61 6e 76 61 73 49 6e 74 65 72 69 6f 72 53 dCanvasInteriorS
18f0: 74 79 6c 65 22 20 6c 69 62 63 64 0a 20 20 20 20 tyle" libcd.
1900: 20 20 20 20 20 20 20 20 20 28 5f 66 75 6e 20 5b (_fun [
1910: 63 61 6e 76 61 73 20 3a 20 5f 63 61 6e 76 61 73 canvas : _canvas
1920: 5d 20 5b 69 6e 74 65 72 69 6f 72 2d 73 74 79 6c ] [interior-styl
1930: 65 20 3a 20 5f 69 6e 74 65 72 69 6f 72 2d 73 74 e : _interior-st
1940: 79 6c 65 5d 20 2d 3e 20 5f 76 6f 69 64 29 29 5d yle] -> _void))]
1950: 0a 20 20 20 20 20 20 20 20 20 20 20 5b 63 61 6e . [can
1960: 76 61 73 2d 68 61 74 63 68 2d 73 74 79 6c 65 2d vas-hatch-style-
1970: 73 65 74 2f 72 61 77 21 0a 20 20 20 20 20 20 20 set/raw!.
1980: 20 20 20 20 20 28 67 65 74 2d 66 66 69 2d 6f 62 (get-ffi-ob
1990: 6a 0a 20 20 20 20 20 20 20 20 20 20 20 20 20 22 j. "
19a0: 63 64 43 61 6e 76 61 73 48 61 74 63 68 22 20 6c cdCanvasHatch" l
19b0: 69 62 63 64 0a 20 20 20 20 20 20 20 20 20 20 20 ibcd.
19c0: 20 20 28 5f 66 75 6e 20 5b 63 61 6e 76 61 73 20 (_fun [canvas
19d0: 3a 20 5f 63 61 6e 76 61 73 5d 20 5b 68 61 74 63 : _canvas] [hatc
19e0: 68 2d 73 74 79 6c 65 20 3a 20 5f 68 61 74 63 68 h-style : _hatch
19f0: 2d 73 74 79 6c 65 5d 20 2d 3e 20 5f 76 6f 69 64 -style] -> _void
1a00: 29 29 5d 0a 20 20 20 20 20 20 20 20 20 20 20 5b ))]. [
1a10: 63 61 6e 76 61 73 2d 73 74 69 70 70 6c 65 2d 73 canvas-stipple-s
1a20: 65 74 2f 72 61 77 21 0a 20 20 20 20 20 20 20 20 et/raw!.
1a30: 20 20 20 20 28 67 65 74 2d 66 66 69 2d 6f 62 6a (get-ffi-obj
1a40: 0a 20 20 20 20 20 20 20 20 20 20 20 20 20 22 63 . "c
1a50: 64 43 61 6e 76 61 73 53 74 69 70 70 6c 65 22 20 dCanvasStipple"
1a60: 6c 69 62 63 64 0a 20 20 20 20 20 20 20 20 20 20 libcd.
1a70: 20 20 20 28 5f 66 75 6e 20 5b 63 61 6e 76 61 73 (_fun [canvas
1a80: 20 3a 20 5f 63 61 6e 76 61 73 5d 20 5b 77 69 64 : _canvas] [wid
1a90: 74 68 20 3a 20 5f 69 6e 74 5d 20 5b 68 65 69 67 th : _int] [heig
1aa0: 68 74 20 3a 20 5f 69 6e 74 5d 20 5b 64 61 74 61 ht : _int] [data
1ab0: 2a 20 3a 20 5f 63 76 65 63 74 6f 72 5d 20 2d 3e * : _cvector] ->
1ac0: 20 5f 76 6f 69 64 29 29 5d 0a 20 20 20 20 20 20 _void))].
1ad0: 20 20 20 20 20 5b 63 61 6e 76 61 73 2d 70 61 74 [canvas-pat
1ae0: 74 65 72 6e 2d 73 65 74 2f 72 61 77 21 0a 20 20 tern-set/raw!.
1af0: 20 20 20 20 20 20 20 20 20 20 28 67 65 74 2d 66 (get-f
1b00: 66 69 2d 6f 62 6a 0a 20 20 20 20 20 20 20 20 20 fi-obj.
1b10: 20 20 20 20 22 63 64 43 61 6e 76 61 73 50 61 74 "cdCanvasPat
1b20: 74 65 72 6e 22 20 6c 69 62 63 64 0a 20 20 20 20 tern" libcd.
1b30: 20 20 20 20 20 20 20 20 20 28 5f 66 75 6e 20 5b (_fun [
1b40: 63 61 6e 76 61 73 20 3a 20 5f 63 61 6e 76 61 73 canvas : _canvas
1b50: 5d 20 5b 77 69 64 74 68 20 3a 20 5f 69 6e 74 5d ] [width : _int]
1b60: 20 5b 68 65 69 67 68 74 20 3a 20 5f 69 6e 74 5d [height : _int]
1b70: 20 5b 64 61 74 61 2a 20 3a 20 5f 63 76 65 63 74 [data* : _cvect
1b80: 6f 72 5d 20 2d 3e 20 5f 76 6f 69 64 29 29 5d 29 or] -> _void))])
1b90: 0a 20 20 20 20 28 ce bb 20 28 63 61 6e 76 61 73 . (λ (canvas
1ba0: 20 69 6e 74 65 72 69 6f 72 2d 73 74 79 6c 65 29 interior-style)
1bb0: 0a 20 20 20 20 20 20 28 6d 61 74 63 68 20 69 6e . (match in
1bc0: 74 65 72 69 6f 72 2d 73 74 79 6c 65 0a 20 20 20 terior-style.
1bd0: 20 20 20 20 20 5b 28 6c 69 73 74 20 27 68 61 74 [(list 'hat
1be0: 63 68 20 68 61 74 63 68 2d 73 74 79 6c 65 29 0a ch hatch-style).
1bf0: 20 20 20 20 20 20 20 20 20 28 63 61 6e 76 61 73 (canvas
1c00: 2d 68 61 74 63 68 2d 73 74 79 6c 65 2d 73 65 74 -hatch-style-set
1c10: 2f 72 61 77 21 20 63 61 6e 76 61 73 20 68 61 74 /raw! canvas hat
1c20: 63 68 2d 73 74 79 6c 65 29 0a 20 20 20 20 20 20 ch-style).
1c30: 20 20 20 28 63 61 6e 76 61 73 2d 69 6e 74 65 72 (canvas-inter
1c40: 69 6f 72 2d 73 74 79 6c 65 2d 73 65 74 2f 72 61 ior-style-set/ra
1c50: 77 21 20 63 61 6e 76 61 73 20 27 68 61 74 63 68 w! canvas 'hatch
1c60: 29 5d 0a 20 20 20 20 20 20 20 20 5b 28 6c 69 73 )]. [(lis
1c70: 74 20 27 73 74 69 70 70 6c 65 20 77 69 64 74 68 t 'stipple width
1c80: 20 68 65 69 67 68 74 20 64 61 74 61 29 0a 20 20 height data).
1c90: 20 20 20 20 20 20 20 28 6c 65 74 20 28 5b 64 61 (let ([da
1ca0: 74 61 2a 20 28 6d 61 6b 65 2d 63 76 65 63 74 6f ta* (make-cvecto
1cb0: 72 20 5f 75 62 79 74 65 20 28 2a 20 77 69 64 74 r _ubyte (* widt
1cc0: 68 20 68 65 69 67 68 74 29 29 5d 29 0a 20 20 20 h height))]).
1cd0: 20 20 20 20 20 20 20 20 28 66 6f 72 2a 20 28 5b (for* ([
1ce0: 6a 20 28 69 6e 2d 72 61 6e 67 65 20 68 65 69 67 j (in-range heig
1cf0: 68 74 29 5d 20 5b 69 20 28 69 6e 2d 72 61 6e 67 ht)] [i (in-rang
1d00: 65 20 77 69 64 74 68 29 5d 0a 20 20 20 20 20 20 e width)].
1d10: 20 20 20 20 20 20 20 20 20 20 20 20 5b 6f 66 73 [ofs
1d20: 2a 20 28 69 6e 2d 76 61 6c 75 65 20 28 2b 20 28 * (in-value (+ (
1d30: 2a 20 6a 20 77 69 64 74 68 29 20 69 29 29 5d 0a * j width) i))].
1d40: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20
1d50: 20 20 5b 76 6f 66 73 20 28 69 6e 2d 76 61 6c 75 [vofs (in-valu
1d60: 65 20 28 71 75 6f 74 69 65 6e 74 20 6f 66 73 2a e (quotient ofs*
1d70: 20 38 29 29 5d 0a 20 20 20 20 20 20 20 20 20 20 8))].
1d80: 20 20 20 20 20 20 20 20 5b 62 6f 66 73 20 28 69 [bofs (i
1d90: 6e 2d 76 61 6c 75 65 20 28 72 65 6d 61 69 6e 64 n-value (remaind
1da0: 65 72 20 6f 66 73 2a 20 38 29 29 5d 29 0a 20 20 er ofs* 8))]).
1db0: 20 20 20 20 20 20 20 20 20 20 20 28 63 76 65 63 (cvec
1dc0: 74 6f 72 2d 73 65 74 21 20 64 61 74 61 2a 20 6f tor-set! data* o
1dd0: 66 73 2a 20 28 62 69 74 77 69 73 65 2d 62 69 74 fs* (bitwise-bit
1de0: 2d 66 69 65 6c 64 20 28 62 79 74 65 73 2d 72 65 -field (bytes-re
1df0: 66 20 64 61 74 61 20 76 6f 66 73 29 20 62 6f 66 f data vofs) bof
1e00: 73 20 28 61 64 64 31 20 62 6f 66 73 29 29 29 29 s (add1 bofs))))
1e10: 0a 20 20 20 20 20 20 20 20 20 20 20 28 63 61 6e . (can
1e20: 76 61 73 2d 73 74 69 70 70 6c 65 2d 73 65 74 2f vas-stipple-set/
1e30: 72 61 77 21 20 63 61 6e 76 61 73 20 77 69 64 74 raw! canvas widt
1e40: 68 20 68 65 69 67 68 74 20 64 61 74 61 2a 29 29 h height data*))
1e50: 0a 20 20 20 20 20 20 20 20 20 28 63 61 6e 76 61 . (canva
1e60: 73 2d 69 6e 74 65 72 69 6f 72 2d 73 74 79 6c 65 s-interior-style
1e70: 2d 73 65 74 2f 72 61 77 21 20 63 61 6e 76 61 73 -set/raw! canvas
1e80: 20 27 73 74 69 70 70 6c 65 29 5d 0a 20 20 20 20 'stipple)].
1e90: 20 20 20 20 5b 28 6c 69 73 74 20 27 70 61 74 74 [(list 'patt
1ea0: 65 72 6e 2f 72 67 62 20 77 69 64 74 68 20 68 65 ern/rgb width he
1eb0: 69 67 68 74 20 64 61 74 61 29 0a 20 20 20 20 20 ight data).
1ec0: 20 20 20 20 28 6c 65 74 20 28 5b 64 61 74 61 2a (let ([data*
1ed0: 20 28 6d 61 6b 65 2d 63 76 65 63 74 6f 72 20 5f (make-cvector _
1ee0: 75 6c 6f 6e 67 20 28 2a 20 77 69 64 74 68 20 68 ulong (* width h
1ef0: 65 69 67 68 74 29 29 5d 29 0a 20 20 20 20 20 20 eight))]).
1f00: 20 20 20 20 20 28 66 6f 72 2a 20 28 5b 6a 20 28 (for* ([j (
1f10: 69 6e 2d 72 61 6e 67 65 20 68 65 69 67 68 74 29 in-range height)
1f20: 5d 20 5b 69 20 28 69 6e 2d 72 61 6e 67 65 20 77 ] [i (in-range w
1f30: 69 64 74 68 29 5d 0a 20 20 20 20 20 20 20 20 20 idth)].
1f40: 20 20 20 20 20 20 20 20 20 5b 6f 66 73 2a 20 28 [ofs* (
1f50: 69 6e 2d 76 61 6c 75 65 20 28 2b 20 28 2a 20 6a in-value (+ (* j
1f60: 20 77 69 64 74 68 29 20 69 29 29 5d 0a 20 20 20 width) i))].
1f70: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 5b [
1f80: 6f 66 73 20 28 69 6e 2d 76 61 6c 75 65 20 28 2a ofs (in-value (*
1f90: 20 33 20 6f 66 73 2a 29 29 5d 29 0a 20 20 20 20 3 ofs*))]).
1fa0: 20 20 20 20 20 20 20 20 20 28 63 76 65 63 74 6f (cvecto
1fb0: 72 2d 73 65 74 21 20 64 61 74 61 2a 20 6f 66 73 r-set! data* ofs
1fc0: 2a 0a 20 20 20 20 20 20 20 20 20 20 20 20 20 20 *.
1fd0: 20 28 62 69 74 77 69 73 65 2d 69 6f 72 0a 20 20 (bitwise-ior.
1fe0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 28 61 (a
1ff0: 72 69 74 68 6d 65 74 69 63 2d 73 68 69 66 74 20 rithmetic-shift
2000: 28 62 79 74 65 73 2d 72 65 66 20 64 61 74 61 20 (bytes-ref data
2010: 6f 66 73 29 20 31 36 29 0a 20 20 20 20 20 20 20 ofs) 16).
2020: 20 20 20 20 20 20 20 20 20 28 61 72 69 74 68 6d (arithm
2030: 65 74 69 63 2d 73 68 69 66 74 20 28 62 79 74 65 etic-shift (byte
2040: 73 2d 72 65 66 20 64 61 74 61 20 28 2b 20 6f 66 s-ref data (+ of
2050: 73 20 31 29 29 20 38 29 0a 20 20 20 20 20 20 20 s 1)) 8).
2060: 20 20 20 20 20 20 20 20 20 28 62 79 74 65 73 2d (bytes-
2070: 72 65 66 20 64 61 74 61 20 28 2b 20 6f 66 73 20 ref data (+ ofs
2080: 32 29 29 29 29 29 0a 20 20 20 20 20 20 20 20 20 2))))).
2090: 20 20 28 63 61 6e 76 61 73 2d 70 61 74 74 65 72 (canvas-patter
20a0: 6e 2d 73 65 74 2f 72 61 77 21 20 63 61 6e 76 61 n-set/raw! canva
20b0: 73 20 77 69 64 74 68 20 68 65 69 67 68 74 20 64 s width height d
20c0: 61 74 61 2a 29 29 0a 20 20 20 20 20 20 20 20 20 ata*)).
20d0: 28 63 61 6e 76 61 73 2d 69 6e 74 65 72 69 6f 72 (canvas-interior
20e0: 2d 73 74 79 6c 65 2d 73 65 74 2f 72 61 77 21 20 -style-set/raw!
20f0: 63 61 6e 76 61 73 20 27 70 61 74 74 65 72 6e 29 canvas 'pattern)
2100: 5d 0a 20 20 20 20 20 20 20 20 5b 28 6c 69 73 74 ]. [(list
2110: 20 27 70 61 74 74 65 72 6e 2f 72 67 62 61 20 77 'pattern/rgba w
2120: 69 64 74 68 20 68 65 69 67 68 74 20 64 61 74 61 idth height data
2130: 29 0a 20 20 20 20 20 20 20 20 20 28 6c 65 74 2a ). (let*
2140: 20 28 5b 64 61 74 61 2a 20 28 6d 61 6b 65 2d 63 ([data* (make-c
2150: 76 65 63 74 6f 72 20 5f 75 6c 6f 6e 67 20 28 2a vector _ulong (*
2160: 20 77 69 64 74 68 20 68 65 69 67 68 74 29 29 5d width height))]
2170: 0a 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 .
2180: 20 5b 65 6c 74 2d 73 65 74 21 20 28 63 75 74 20 [elt-set! (cut
2190: 70 74 72 2d 73 65 74 21 20 64 61 74 61 2a 20 5f ptr-set! data* _
21a0: 6c 6f 6e 67 20 3c 3e 20 3c 3e 29 5d 29 0a 20 20 long <> <>)]).
21b0: 20 20 20 20 20 20 20 20 20 28 66 6f 72 2a 20 28 (for* (
21c0: 5b 6a 20 28 69 6e 2d 72 61 6e 67 65 20 68 65 69 [j (in-range hei
21d0: 67 68 74 29 5d 20 5b 69 20 28 69 6e 2d 72 61 6e ght)] [i (in-ran
21e0: 67 65 20 77 69 64 74 68 29 5d 0a 20 20 20 20 20 ge width)].
21f0: 20 20 20 20 20 20 20 20 20 20 20 20 20 5b 6f 66 [of
2200: 73 2a 20 28 69 6e 2d 76 61 6c 75 65 20 28 2b 20 s* (in-value (+
2210: 28 2a 20 6a 20 77 69 64 74 68 29 20 69 29 29 5d (* j width) i))]
2220: 0a 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 .
2230: 20 20 20 5b 6f 66 73 20 28 69 6e 2d 76 61 6c 75 [ofs (in-valu
2240: 65 20 28 2a 20 34 20 6f 66 73 2a 29 29 5d 29 0a e (* 4 ofs*))]).
2250: 20 20 20 20 20 20 20 20 20 20 20 20 20 28 63 76 (cv
2260: 65 63 74 6f 72 2d 73 65 74 21 20 64 61 74 61 2a ector-set! data*
2270: 20 6f 66 73 2a 0a 20 20 20 20 20 20 20 20 20 20 ofs*.
2280: 20 20 20 20 20 28 62 69 74 77 69 73 65 2d 69 6f (bitwise-io
2290: 72 0a 20 20 20 20 20 20 20 20 20 20 20 20 20 20 r.
22a0: 20 20 28 61 72 69 74 68 6d 65 74 69 63 2d 73 68 (arithmetic-sh
22b0: 69 66 74 20 28 2d 20 23 78 66 66 20 28 62 79 74 ift (- #xff (byt
22c0: 65 73 2d 72 65 66 20 64 61 74 61 20 28 2b 20 6f es-ref data (+ o
22d0: 66 73 20 33 29 29 29 20 32 34 29 0a 20 20 20 20 fs 3))) 24).
22e0: 20 20 20 20 20 20 20 20 20 20 20 20 28 61 72 69 (ari
22f0: 74 68 6d 65 74 69 63 2d 73 68 69 66 74 20 28 62 thmetic-shift (b
2300: 79 74 65 73 2d 72 65 66 20 64 61 74 61 20 6f 66 ytes-ref data of
2310: 73 29 20 31 36 29 0a 20 20 20 20 20 20 20 20 20 s) 16).
2320: 20 20 20 20 20 20 20 28 61 72 69 74 68 6d 65 74 (arithmet
2330: 69 63 2d 73 68 69 66 74 20 28 62 79 74 65 73 2d ic-shift (bytes-
2340: 72 65 66 20 64 61 74 61 20 28 2b 20 6f 66 73 20 ref data (+ ofs
2350: 31 29 29 20 38 29 0a 20 20 20 20 20 20 20 20 20 1)) 8).
2360: 20 20 20 20 20 20 20 28 62 79 74 65 73 2d 72 65 (bytes-re
2370: 66 20 64 61 74 61 20 28 2b 20 6f 66 73 20 32 29 f data (+ ofs 2)
2380: 29 29 29 29 0a 20 20 20 20 20 20 20 20 20 20 20 )))).
2390: 28 63 61 6e 76 61 73 2d 70 61 74 74 65 72 6e 2d (canvas-pattern-
23a0: 73 65 74 2f 72 61 77 21 20 63 61 6e 76 61 73 20 set/raw! canvas
23b0: 77 69 64 74 68 20 68 65 69 67 68 74 20 64 61 74 width height dat
23c0: 61 2a 29 29 0a 20 20 20 20 20 20 20 20 20 28 63 a*)). (c
23d0: 61 6e 76 61 73 2d 69 6e 74 65 72 69 6f 72 2d 73 anvas-interior-s
23e0: 74 79 6c 65 2d 73 65 74 2f 72 61 77 21 20 63 61 tyle-set/raw! ca
23f0: 6e 76 61 73 20 27 70 61 74 74 65 72 6e 29 5d 0a nvas 'pattern)].
2400: 20 20 20 20 20 20 20 20 5b 5f 0a 20 20 20 20 20 [_.
2410: 20 20 20 20 28 63 61 6e 76 61 73 2d 69 6e 74 65 (canvas-inte
2420: 72 69 6f 72 2d 73 74 79 6c 65 2d 73 65 74 2f 72 rior-style-set/r
2430: 61 77 21 20 63 61 6e 76 61 73 20 69 6e 74 65 72 aw! canvas inter
2440: 69 6f 72 2d 73 74 79 6c 65 29 5d 29 29 29 29 0a ior-style)])))).
2450: 0a 28 64 65 66 69 6e 65 20 63 61 6e 76 61 73 2d .(define canvas-
2460: 69 6e 74 65 72 69 6f 72 2d 73 74 79 6c 65 0a 20 interior-style.
2470: 20 28 67 65 74 74 65 72 2d 77 69 74 68 2d 73 65 (getter-with-se
2480: 74 74 65 72 0a 20 20 20 28 6c 65 74 72 65 63 20 tter. (letrec
2490: 28 5b 63 61 6e 76 61 73 2d 69 6e 74 65 72 69 6f ([canvas-interio
24a0: 72 2d 73 74 79 6c 65 2f 72 61 77 0a 20 20 20 20 r-style/raw.
24b0: 20 20 20 20 20 20 20 20 20 28 67 65 74 2d 66 66 (get-ff
24c0: 69 2d 6f 62 6a 0a 20 20 20 20 20 20 20 20 20 20 i-obj.
24d0: 20 20 20 20 22 63 64 43 61 6e 76 61 73 49 6e 74 "cdCanvasInt
24e0: 65 72 69 6f 72 53 74 79 6c 65 22 20 6c 69 62 63 eriorStyle" libc
24f0: 64 0a 20 20 20 20 20 20 20 20 20 20 20 20 20 20 d.
2500: 28 5f 66 75 6e 20 5b 63 61 6e 76 61 73 20 3a 20 (_fun [canvas :
2510: 5f 63 61 6e 76 61 73 5d 20 5b 71 75 65 72 79 20 _canvas] [query
2520: 3a 20 5f 66 69 78 69 6e 74 20 3d 20 2d 31 5d 20 : _fixint = -1]
2530: 2d 3e 20 5b 69 6e 74 65 72 69 6f 72 2d 73 74 79 -> [interior-sty
2540: 6c 65 20 3a 20 5f 69 6e 74 65 72 69 6f 72 2d 73 le : _interior-s
2550: 74 79 6c 65 5d 29 29 5d 0a 20 20 20 20 20 20 20 tyle]))].
2560: 20 20 20 20 20 5b 63 61 6e 76 61 73 2d 68 61 74 [canvas-hat
2570: 63 68 2d 73 74 79 6c 65 2f 72 61 77 0a 20 20 20 ch-style/raw.
2580: 20 20 20 20 20 20 20 20 20 20 28 67 65 74 2d 66 (get-f
2590: 66 69 2d 6f 62 6a 0a 20 20 20 20 20 20 20 20 20 fi-obj.
25a0: 20 20 20 20 20 22 63 64 43 61 6e 76 61 73 48 61 "cdCanvasHa
25b0: 74 63 68 22 20 6c 69 62 63 64 0a 20 20 20 20 20 tch" libcd.
25c0: 20 20 20 20 20 20 20 20 20 28 5f 66 75 6e 20 5b (_fun [
25d0: 63 61 6e 76 61 73 20 3a 20 5f 63 61 6e 76 61 73 canvas : _canvas
25e0: 5d 20 5b 71 75 65 72 79 20 3a 20 5f 66 69 78 69 ] [query : _fixi
25f0: 6e 74 20 3d 20 2d 31 5d 20 2d 3e 20 5b 68 61 74 nt = -1] -> [hat
2600: 63 68 2d 73 74 79 6c 65 20 3a 20 5f 68 61 74 63 ch-style : _hatc
2610: 68 2d 73 74 79 6c 65 5d 29 29 5d 0a 20 20 20 20 h-style]))].
2620: 20 20 20 20 20 20 20 20 5b 63 61 6e 76 61 73 2d [canvas-
2630: 73 74 69 70 70 6c 65 2f 72 61 77 0a 20 20 20 20 stipple/raw.
2640: 20 20 20 20 20 20 20 20 20 28 67 65 74 2d 66 66 (get-ff
2650: 69 2d 6f 62 6a 0a 20 20 20 20 20 20 20 20 20 20 i-obj.
2660: 20 20 20 20 22 63 64 43 61 6e 76 61 73 47 65 74 "cdCanvasGet
2670: 53 74 69 70 70 6c 65 22 20 6c 69 62 63 64 0a 20 Stipple" libcd.
2680: 20 20 20 20 20 20 20 20 20 20 20 20 20 28 5f 66 (_f
2690: 75 6e 20 5b 63 61 6e 76 61 73 20 3a 20 5f 63 61 un [canvas : _ca
26a0: 6e 76 61 73 5d 20 5b 77 69 64 74 68 20 3a 20 28 nvas] [width : (
26b0: 5f 70 74 72 20 6f 20 5f 69 6e 74 29 5d 20 5b 68 _ptr o _int)] [h
26c0: 65 69 67 68 74 20 3a 20 28 5f 70 74 72 20 6f 20 eight : (_ptr o
26d0: 5f 69 6e 74 29 5d 0a 20 20 20 20 20 20 20 20 20 _int)].
26e0: 20 20 20 20 20 20 20 20 20 20 20 2d 3e 20 5b 64 -> [d
26f0: 61 74 61 20 3a 20 5f 67 63 70 6f 69 6e 74 65 72 ata : _gcpointer
2700: 5d 0a 20 20 20 20 20 20 20 20 20 20 20 20 20 20 ].
2710: 20 20 20 20 20 20 2d 3e 20 28 76 61 6c 75 65 73 -> (values
2720: 20 77 69 64 74 68 20 68 65 69 67 68 74 20 64 61 width height da
2730: 74 61 29 29 29 5d 0a 20 20 20 20 20 20 20 20 20 ta)))].
2740: 20 20 20 5b 63 61 6e 76 61 73 2d 70 61 74 74 65 [canvas-patte
2750: 72 6e 2f 72 61 77 0a 20 20 20 20 20 20 20 20 20 rn/raw.
2760: 20 20 20 20 28 67 65 74 2d 66 66 69 2d 6f 62 6a (get-ffi-obj
2770: 0a 20 20 20 20 20 20 20 20 20 20 20 20 20 20 22 . "
2780: 63 64 43 61 6e 76 61 73 47 65 74 50 61 74 74 65 cdCanvasGetPatte
2790: 72 6e 22 20 6c 69 62 63 64 0a 20 20 20 20 20 20 rn" libcd.
27a0: 20 20 20 20 20 20 20 20 28 5f 66 75 6e 20 5b 63 (_fun [c
27b0: 61 6e 76 61 73 20 3a 20 5f 63 61 6e 76 61 73 5d anvas : _canvas]
27c0: 20 5b 77 69 64 74 68 20 3a 20 28 5f 70 74 72 20 [width : (_ptr
27d0: 6f 20 5f 69 6e 74 29 5d 20 5b 68 65 69 67 68 74 o _int)] [height
27e0: 20 3a 20 28 5f 70 74 72 20 6f 20 5f 69 6e 74 29 : (_ptr o _int)
27f0: 5d 0a 20 20 20 20 20 20 20 20 20 20 20 20 20 20 ].
2800: 20 20 20 20 20 20 2d 3e 20 5b 64 61 74 61 20 3a -> [data :
2810: 20 5f 67 63 70 6f 69 6e 74 65 72 5d 0a 20 20 20 _gcpointer].
2820: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20
2830: 20 2d 3e 20 28 76 61 6c 75 65 73 20 77 69 64 74 -> (values widt
2840: 68 20 68 65 69 67 68 74 20 64 61 74 61 29 29 29 h height data)))
2850: 5d 29 0a 20 20 20 20 20 28 ce bb 20 28 63 61 6e ]). (λ (can
2860: 76 61 73 29 0a 20 20 20 20 20 20 20 28 6c 65 74 vas). (let
2870: 20 28 5b 69 6e 74 65 72 69 6f 72 2d 73 74 79 6c ([interior-styl
2880: 65 20 28 63 61 6e 76 61 73 2d 69 6e 74 65 72 69 e (canvas-interi
2890: 6f 72 2d 73 74 79 6c 65 2f 72 61 77 20 63 61 6e or-style/raw can
28a0: 76 61 73 29 5d 29 0a 20 20 20 20 20 20 20 20 20 vas)]).
28b0: 28 63 61 73 65 20 69 6e 74 65 72 69 6f 72 2d 73 (case interior-s
28c0: 74 79 6c 65 0a 20 20 20 20 20 20 20 20 20 20 20 tyle.
28d0: 5b 28 68 61 74 63 68 29 0a 20 20 20 20 20 20 20 [(hatch).
28e0: 20 20 20 20 20 28 6c 69 73 74 20 27 68 61 74 63 (list 'hatc
28f0: 68 20 28 63 61 6e 76 61 73 2d 68 61 74 63 68 2d h (canvas-hatch-
2900: 73 74 79 6c 65 2f 72 61 77 20 63 61 6e 76 61 73 style/raw canvas
2910: 29 29 5d 0a 20 20 20 20 20 20 20 20 20 20 20 5b ))]. [
2920: 28 73 74 69 70 70 6c 65 29 0a 20 20 20 20 20 20 (stipple).
2930: 20 20 20 20 20 20 28 6c 65 74 2a 2d 76 61 6c 75 (let*-valu
2940: 65 73 20 28 5b 28 77 69 64 74 68 20 68 65 69 67 es ([(width heig
2950: 68 74 20 64 61 74 61 2a 29 20 28 63 61 6e 76 61 ht data*) (canva
2960: 73 2d 73 74 69 70 70 6c 65 2f 72 61 77 20 63 61 s-stipple/raw ca
2970: 6e 76 61 73 29 5d 0a 20 20 20 20 20 20 20 20 20 nvas)].
2980: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20
2990: 20 5b 28 64 61 74 61 2a 29 20 28 6d 61 6b 65 2d [(data*) (make-
29a0: 63 76 65 63 74 6f 72 2a 20 64 61 74 61 2a 20 5f cvector* data* _
29b0: 75 62 79 74 65 20 28 2a 20 77 69 64 74 68 20 68 ubyte (* width h
29c0: 65 69 67 68 74 29 29 5d 0a 20 20 20 20 20 20 20 eight))].
29d0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20
29e0: 20 20 20 5b 28 64 61 74 61 29 20 28 6d 61 6b 65 [(data) (make
29f0: 2d 62 79 74 65 73 20 28 63 65 69 6c 69 6e 67 20 -bytes (ceiling
2a00: 28 2f 20 28 2a 20 77 69 64 74 68 20 68 65 69 67 (/ (* width heig
2a10: 68 74 29 20 38 29 29 20 30 29 5d 29 0a 20 20 20 ht) 8)) 0)]).
2a20: 20 20 20 20 20 20 20 20 20 20 20 28 66 6f 72 2a (for*
2a30: 20 28 5b 6a 20 28 69 6e 2d 72 61 6e 67 65 20 68 ([j (in-range h
2a40: 65 69 67 68 74 29 5d 20 5b 69 20 28 69 6e 2d 72 eight)] [i (in-r
2a50: 61 6e 67 65 20 77 69 64 74 68 29 5d 0a 20 20 20 ange width)].
2a60: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20
2a70: 20 20 5b 6f 66 73 2a 20 28 69 6e 2d 76 61 6c 75 [ofs* (in-valu
2a80: 65 20 28 2b 20 28 2a 20 6a 20 77 69 64 74 68 29 e (+ (* j width)
2a90: 20 69 29 29 5d 0a 20 20 20 20 20 20 20 20 20 20 i))].
2aa0: 20 20 20 20 20 20 20 20 20 20 20 5b 76 6f 66 73 [vofs
2ab0: 20 28 69 6e 2d 76 61 6c 75 65 20 28 71 75 6f 74 (in-value (quot
2ac0: 69 65 6e 74 20 6f 66 73 2a 20 38 29 29 5d 0a 20 ient ofs* 8))].
2ad0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20
2ae0: 20 20 20 20 5b 62 6f 66 73 20 28 69 6e 2d 76 61 [bofs (in-va
2af0: 6c 75 65 20 28 72 65 6d 61 69 6e 64 65 72 20 6f lue (remainder o
2b00: 66 73 2a 20 38 29 29 5d 29 0a 20 20 20 20 20 20 fs* 8))]).
2b10: 20 20 20 20 20 20 20 20 20 20 28 62 79 74 65 73 (bytes
2b20: 2d 73 65 74 21 20 64 61 74 61 20 76 6f 66 73 0a -set! data vofs.
2b30: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20
2b40: 20 20 28 62 69 74 77 69 73 65 2d 69 6f 72 0a 20 (bitwise-ior.
2b50: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20
2b60: 20 20 28 62 79 74 65 73 2d 72 65 66 20 64 61 74 (bytes-ref dat
2b70: 61 20 76 6f 66 73 29 0a 20 20 20 20 20 20 20 20 a vofs).
2b80: 20 20 20 20 20 20 20 20 20 20 20 28 61 72 69 74 (arit
2b90: 68 6d 65 74 69 63 2d 73 68 69 66 74 20 28 62 69 hmetic-shift (bi
2ba0: 74 77 69 73 65 2d 61 6e 64 20 28 63 76 65 63 74 twise-and (cvect
2bb0: 6f 72 2d 72 65 66 20 64 61 74 61 2a 20 6f 66 73 or-ref data* ofs
2bc0: 2a 29 20 31 29 20 62 6f 66 73 29 29 29 29 0a 20 *) 1) bofs)))).
2bd0: 20 20 20 20 20 20 20 20 20 20 20 20 20 28 6c 69 (li
2be0: 73 74 20 27 73 74 69 70 70 6c 65 20 77 69 64 74 st 'stipple widt
2bf0: 68 20 68 65 69 67 68 74 20 64 61 74 61 29 29 5d h height data))]
2c00: 0a 20 20 20 20 20 20 20 20 20 20 20 5b 28 70 61 . [(pa
2c10: 74 74 65 72 6e 29 0a 20 20 20 20 20 20 20 20 20 ttern).
2c20: 20 20 20 28 6c 65 74 2a 2d 76 61 6c 75 65 73 20 (let*-values
2c30: 28 5b 28 77 69 64 74 68 20 68 65 69 67 68 74 20 ([(width height
2c40: 64 61 74 61 2a 29 20 28 63 61 6e 76 61 73 2d 70 data*) (canvas-p
2c50: 61 74 74 65 72 6e 2f 72 61 77 20 63 61 6e 76 61 attern/raw canva
2c60: 73 29 5d 0a 20 20 20 20 20 20 20 20 20 20 20 20 s)].
2c70: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 5b 28 [(
2c80: 64 61 74 61 2a 29 20 28 6d 61 6b 65 2d 63 76 65 data*) (make-cve
2c90: 63 74 6f 72 2a 20 64 61 74 61 2a 20 5f 75 6c 6f ctor* data* _ulo
2ca0: 6e 67 20 28 2a 20 77 69 64 74 68 20 68 65 69 67 ng (* width heig
2cb0: 68 74 29 29 5d 0a 20 20 20 20 20 20 20 20 20 20 ht))].
2cc0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20
2cd0: 5b 28 64 61 74 61 29 20 28 6d 61 6b 65 2d 62 79 [(data) (make-by
2ce0: 74 65 73 20 28 2a 20 34 20 77 69 64 74 68 20 68 tes (* 4 width h
2cf0: 65 69 67 68 74 29 29 5d 29 0a 20 20 20 20 20 20 eight))]).
2d00: 20 20 20 20 20 20 20 20 28 66 6f 72 2a 20 28 5b (for* ([
2d10: 6a 20 28 69 6e 2d 72 61 6e 67 65 20 68 65 69 67 j (in-range heig
2d20: 68 74 29 5d 20 5b 69 20 28 69 6e 2d 72 61 6e 67 ht)] [i (in-rang
2d30: 65 20 77 69 64 74 68 29 5d 0a 20 20 20 20 20 20 e width)].
2d40: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 5b [
2d50: 6f 66 73 2a 20 28 69 6e 2d 76 61 6c 75 65 20 28 ofs* (in-value (
2d60: 2b 20 28 2a 20 6a 20 77 69 64 74 68 29 20 69 29 + (* j width) i)
2d70: 29 5d 0a 20 20 20 20 20 20 20 20 20 20 20 20 20 )].
2d80: 20 20 20 20 20 20 20 20 5b 6f 66 73 20 28 69 6e [ofs (in
2d90: 2d 76 61 6c 75 65 20 28 2a 20 34 20 6f 66 73 2a -value (* 4 ofs*
2da0: 29 29 5d 0a 20 20 20 20 20 20 20 20 20 20 20 20 ))].
2db0: 20 20 20 20 20 20 20 20 20 5b 63 6f 6c 20 28 69 [col (i
2dc0: 6e 2d 76 61 6c 75 65 20 28 63 76 65 63 74 6f 72 n-value (cvector
2dd0: 2d 72 65 66 20 64 61 74 61 2a 20 6f 66 73 2a 29 -ref data* ofs*)
2de0: 29 5d 29 0a 20 20 20 20 20 20 20 20 20 20 20 20 )]).
2df0: 20 20 20 20 28 62 79 74 65 73 2d 73 65 74 21 20 (bytes-set!
2e00: 64 61 74 61 20 6f 66 73 20 28 62 69 74 77 69 73 data ofs (bitwis
2e10: 65 2d 62 69 74 2d 66 69 65 6c 64 20 63 6f 6c 20 e-bit-field col
2e20: 31 36 20 32 34 29 29 0a 20 20 20 20 20 20 20 20 16 24)).
2e30: 20 20 20 20 20 20 20 20 28 62 79 74 65 73 2d 73 (bytes-s
2e40: 65 74 21 20 64 61 74 61 20 28 2b 20 6f 66 73 20 et! data (+ ofs
2e50: 31 29 20 28 62 69 74 77 69 73 65 2d 62 69 74 2d 1) (bitwise-bit-
2e60: 66 69 65 6c 64 20 63 6f 6c 20 38 20 31 36 29 29 field col 8 16))
2e70: 0a 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 .
2e80: 20 28 62 79 74 65 73 2d 73 65 74 21 20 64 61 74 (bytes-set! dat
2e90: 61 20 28 2b 20 6f 66 73 20 32 29 20 28 62 69 74 a (+ ofs 2) (bit
2ea0: 77 69 73 65 2d 62 69 74 2d 66 69 65 6c 64 20 63 wise-bit-field c
2eb0: 6f 6c 20 30 20 38 29 29 0a 20 20 20 20 20 20 20 ol 0 8)).
2ec0: 20 20 20 20 20 20 20 20 20 28 62 79 74 65 73 2d (bytes-
2ed0: 73 65 74 21 20 64 61 74 61 20 28 2b 20 6f 66 73 set! data (+ ofs
2ee0: 20 33 29 20 28 2d 20 23 78 66 66 20 28 62 69 74 3) (- #xff (bit
2ef0: 77 69 73 65 2d 62 69 74 2d 66 69 65 6c 64 20 63 wise-bit-field c
2f00: 6f 6c 20 32 34 20 33 32 29 29 29 29 0a 20 20 20 ol 24 32)))).
2f10: 20 20 20 20 20 20 20 20 20 20 20 28 6c 69 73 74 (list
2f20: 20 27 70 61 74 74 65 72 6e 2f 72 67 62 61 20 77 'pattern/rgba w
2f30: 69 64 74 68 20 68 65 69 67 68 74 20 64 61 74 61 idth height data
2f40: 29 29 5d 0a 20 20 20 20 20 20 20 20 20 20 20 5b ))]. [
2f50: 65 6c 73 65 0a 20 20 20 20 20 20 20 20 20 20 20 else.
2f60: 20 69 6e 74 65 72 69 6f 72 2d 73 74 79 6c 65 5d interior-style]
2f70: 29 29 29 29 0a 20 20 20 63 61 6e 76 61 73 2d 69 )))). canvas-i
2f80: 6e 74 65 72 69 6f 72 2d 73 74 79 6c 65 2d 73 65 nterior-style-se
2f90: 74 21 29 29 0a 0a 28 70 72 6f 76 69 64 65 0a 20 t!))..(provide.
2fa0: 63 61 6e 76 61 73 2d 62 6f 78 21 20 63 61 6e 76 canvas-box! canv
2fb0: 61 73 2d 73 65 63 74 6f 72 21 20 63 61 6e 76 61 as-sector! canva
2fc0: 73 2d 63 68 6f 72 64 21 0a 20 63 61 6e 76 61 73 s-chord!. canvas
2fd0: 2d 62 61 63 6b 67 72 6f 75 6e 64 2d 6f 70 61 63 -background-opac
2fe0: 69 74 79 20 63 61 6e 76 61 73 2d 62 61 63 6b 67 ity canvas-backg
2ff0: 72 6f 75 6e 64 2d 6f 70 61 63 69 74 79 2d 73 65 round-opacity-se
3000: 74 21 0a 20 63 61 6e 76 61 73 2d 66 69 6c 6c 2d t!. canvas-fill-
3010: 6d 6f 64 65 20 63 61 6e 76 61 73 2d 66 69 6c 6c mode canvas-fill
3020: 2d 6d 6f 64 65 2d 73 65 74 21 0a 20 63 61 6e 76 -mode-set!. canv
3030: 61 73 2d 69 6e 74 65 72 69 6f 72 2d 73 74 79 6c as-interior-styl
3040: 65 20 63 61 6e 76 61 73 2d 69 6e 74 65 72 69 6f e canvas-interio
3050: 72 2d 73 74 79 6c 65 2d 73 65 74 21 29 0a 0a 3b r-style-set!)..;
3060: 3b 20 7d 7d 7d 0a 0a 3b 3b 20 7b 7b 7b 20 54 65 ; }}}..;; {{{ Te
3070: 78 74 20 66 75 6e 63 74 69 6f 6e 73 0a 0a 28 64 xt functions..(d
3080: 65 66 69 6e 65 20 63 61 6e 76 61 73 2d 74 65 78 efine canvas-tex
3090: 74 21 0a 20 20 28 67 65 74 2d 66 66 69 2d 6f 62 t!. (get-ffi-ob
30a0: 6a 0a 20 20 20 22 63 64 66 43 61 6e 76 61 73 54 j. "cdfCanvasT
30b0: 65 78 74 22 20 6c 69 62 63 64 0a 20 20 20 28 5f ext" libcd. (_
30c0: 66 75 6e 20 5b 63 61 6e 76 61 73 20 3a 20 5f 63 fun [canvas : _c
30d0: 61 6e 76 61 73 5d 20 5b 78 20 3a 20 5f 64 6f 75 anvas] [x : _dou
30e0: 62 6c 65 2a 5d 20 5b 79 20 3a 20 5f 64 6f 75 62 ble*] [y : _doub
30f0: 6c 65 2a 5d 20 5b 74 65 78 74 20 3a 20 5f 73 74 le*] [text : _st
3100: 72 69 6e 67 2f 75 74 66 2d 38 5d 20 2d 3e 20 5f ring/utf-8] -> _
3110: 76 6f 69 64 29 29 29 0a 0a 28 64 65 66 69 6e 65 void)))..(define
3120: 20 63 61 6e 76 61 73 2d 66 6f 6e 74 2d 73 65 74 canvas-font-set
3130: 21 0a 20 20 28 67 65 74 2d 66 66 69 2d 6f 62 6a !. (get-ffi-obj
3140: 0a 20 20 20 22 63 64 43 61 6e 76 61 73 4e 61 74 . "cdCanvasNat
3150: 69 76 65 46 6f 6e 74 22 20 6c 69 62 63 64 0a 20 iveFont" libcd.
3160: 20 20 28 5f 66 75 6e 20 5b 63 61 6e 76 61 73 20 (_fun [canvas
3170: 3a 20 5f 63 61 6e 76 61 73 5d 20 5b 66 6f 6e 74 : _canvas] [font
3180: 20 3a 20 5f 73 74 72 69 6e 67 2f 75 74 66 2d 38 : _string/utf-8
3190: 5d 20 2d 3e 20 5f 76 6f 69 64 29 29 29 0a 0a 28 ] -> _void)))..(
31a0: 64 65 66 69 6e 65 20 63 61 6e 76 61 73 2d 66 6f define canvas-fo
31b0: 6e 74 0a 20 20 28 67 65 74 74 65 72 2d 77 69 74 nt. (getter-wit
31c0: 68 2d 73 65 74 74 65 72 0a 20 20 20 28 67 65 74 h-setter. (get
31d0: 2d 66 66 69 2d 6f 62 6a 0a 20 20 20 20 22 63 64 -ffi-obj. "cd
31e0: 43 61 6e 76 61 73 4e 61 74 69 76 65 46 6f 6e 74 CanvasNativeFont
31f0: 22 20 6c 69 62 63 64 0a 20 20 20 20 28 5f 66 75 " libcd. (_fu
3200: 6e 20 5b 63 61 6e 76 61 73 20 3a 20 5f 63 61 6e n [canvas : _can
3210: 76 61 73 5d 20 5b 71 75 65 72 79 20 3a 20 5f 70 vas] [query : _p
3220: 6f 69 6e 74 65 72 20 3d 20 23 66 5d 20 2d 3e 20 ointer = #f] ->
3230: 5b 66 6f 6e 74 20 3a 20 5f 73 74 72 69 6e 67 2f [font : _string/
3240: 75 74 66 2d 38 5d 29 29 0a 20 20 20 63 61 6e 76 utf-8])). canv
3250: 61 73 2d 66 6f 6e 74 2d 73 65 74 21 29 29 0a 0a as-font-set!))..
3260: 28 64 65 66 69 6e 65 20 5f 61 6c 69 67 6e 6d 65 (define _alignme
3270: 6e 74 0a 20 20 28 5f 65 6e 75 6d 0a 20 20 20 27 nt. (_enum. '
3280: 28 6e 6f 72 74 68 20 73 6f 75 74 68 20 65 61 73 (north south eas
3290: 74 20 77 65 73 74 20 6e 6f 72 74 68 2d 65 61 73 t west north-eas
32a0: 74 20 6e 6f 72 74 68 2d 77 65 73 74 20 73 6f 75 t north-west sou
32b0: 74 68 2d 65 61 73 74 20 73 6f 75 74 68 2d 77 65 th-east south-we
32c0: 73 74 20 63 65 6e 74 65 72 20 62 61 73 65 2d 6c st center base-l
32d0: 65 66 74 20 62 61 73 65 2d 63 65 6e 74 65 72 20 eft base-center
32e0: 62 61 73 65 2d 72 69 67 68 74 29 0a 20 20 20 5f base-right). _
32f0: 66 69 78 69 6e 74 29 29 0a 0a 28 64 65 66 69 6e fixint))..(defin
3300: 65 20 63 61 6e 76 61 73 2d 74 65 78 74 2d 61 6c e canvas-text-al
3310: 69 67 6e 6d 65 6e 74 2d 73 65 74 21 0a 20 20 28 ignment-set!. (
3320: 67 65 74 2d 66 66 69 2d 6f 62 6a 0a 20 20 20 22 get-ffi-obj. "
3330: 63 64 43 61 6e 76 61 73 54 65 78 74 41 6c 69 67 cdCanvasTextAlig
3340: 6e 6d 65 6e 74 22 20 6c 69 62 63 64 0a 20 20 20 nment" libcd.
3350: 28 5f 66 75 6e 20 5b 63 61 6e 76 61 73 20 3a 20 (_fun [canvas :
3360: 5f 63 61 6e 76 61 73 5d 20 5b 61 6c 69 67 6e 6d _canvas] [alignm
3370: 65 6e 74 20 3a 20 5f 61 6c 69 67 6e 6d 65 6e 74 ent : _alignment
3380: 5d 20 2d 3e 20 5f 76 6f 69 64 29 29 29 0a 0a 28 ] -> _void)))..(
3390: 64 65 66 69 6e 65 20 63 61 6e 76 61 73 2d 74 65 define canvas-te
33a0: 78 74 2d 61 6c 69 67 6e 6d 65 6e 74 0a 20 20 28 xt-alignment. (
33b0: 67 65 74 74 65 72 2d 77 69 74 68 2d 73 65 74 74 getter-with-sett
33c0: 65 72 0a 20 20 20 28 67 65 74 2d 66 66 69 2d 6f er. (get-ffi-o
33d0: 62 6a 0a 20 20 20 20 22 63 64 43 61 6e 76 61 73 bj. "cdCanvas
33e0: 54 65 78 74 41 6c 69 67 6e 6d 65 6e 74 22 20 6c TextAlignment" l
33f0: 69 62 63 64 0a 20 20 20 20 28 5f 66 75 6e 20 5b ibcd. (_fun [
3400: 63 61 6e 76 61 73 20 3a 20 5f 63 61 6e 76 61 73 canvas : _canvas
3410: 5d 20 5b 71 75 65 72 79 20 3a 20 5f 66 69 78 69 ] [query : _fixi
3420: 6e 74 20 3d 20 2d 31 5d 20 2d 3e 20 5b 61 6c 69 nt = -1] -> [ali
3430: 67 6e 6d 65 6e 74 20 3a 20 5f 61 6c 69 67 6e 6d gnment : _alignm
3440: 65 6e 74 5d 29 29 0a 20 20 20 63 61 6e 76 61 73 ent])). canvas
3450: 2d 74 65 78 74 2d 61 6c 69 67 6e 6d 65 6e 74 2d -text-alignment-
3460: 73 65 74 21 29 29 0a 0a 28 64 65 66 69 6e 65 20 set!))..(define
3470: 63 61 6e 76 61 73 2d 74 65 78 74 2d 6f 72 69 65 canvas-text-orie
3480: 6e 74 61 74 69 6f 6e 2d 73 65 74 21 0a 20 20 28 ntation-set!. (
3490: 67 65 74 2d 66 66 69 2d 6f 62 6a 0a 20 20 20 22 get-ffi-obj. "
34a0: 63 64 43 61 6e 76 61 73 54 65 78 74 4f 72 69 65 cdCanvasTextOrie
34b0: 6e 74 61 74 69 6f 6e 22 20 6c 69 62 63 64 0a 20 ntation" libcd.
34c0: 20 20 28 5f 66 75 6e 20 5b 63 61 6e 76 61 73 20 (_fun [canvas
34d0: 3a 20 5f 63 61 6e 76 61 73 5d 20 5b 6f 72 69 65 : _canvas] [orie
34e0: 6e 74 61 74 69 6f 6e 20 3a 20 5f 64 6f 75 62 6c ntation : _doubl
34f0: 65 2a 5d 20 2d 3e 20 5f 76 6f 69 64 29 29 29 0a e*] -> _void))).
3500: 0a 28 64 65 66 69 6e 65 20 63 61 6e 76 61 73 2d .(define canvas-
3510: 74 65 78 74 2d 6f 72 69 65 6e 74 61 74 69 6f 6e text-orientation
3520: 0a 20 20 28 67 65 74 74 65 72 2d 77 69 74 68 2d . (getter-with-
3530: 73 65 74 74 65 72 0a 20 20 20 28 67 65 74 2d 66 setter. (get-f
3540: 66 69 2d 6f 62 6a 0a 20 20 20 20 22 63 64 43 61 fi-obj. "cdCa
3550: 6e 76 61 73 54 65 78 74 4f 72 69 65 6e 74 61 74 nvasTextOrientat
3560: 69 6f 6e 22 20 6c 69 62 63 64 0a 20 20 20 20 28 ion" libcd. (
3570: 5f 66 75 6e 20 5b 63 61 6e 76 61 73 20 3a 20 5f _fun [canvas : _
3580: 63 61 6e 76 61 73 5d 20 5b 71 75 65 72 79 20 3a canvas] [query :
3590: 20 5f 64 6f 75 62 6c 65 20 3d 20 2d 31 2e 30 5d _double = -1.0]
35a0: 20 2d 3e 20 5b 6f 72 69 65 6e 74 61 74 69 6f 6e -> [orientation
35b0: 20 3a 20 5f 64 6f 75 62 6c 65 5d 29 29 0a 20 20 : _double])).
35c0: 20 63 61 6e 76 61 73 2d 74 65 78 74 2d 6f 72 69 canvas-text-ori
35d0: 65 6e 74 61 74 69 6f 6e 2d 73 65 74 21 29 29 0a entation-set!)).
35e0: 0a 28 64 65 66 69 6e 65 20 63 61 6e 76 61 73 2d .(define canvas-
35f0: 66 6f 6e 74 2d 64 69 6d 65 6e 73 69 6f 6e 73 0a font-dimensions.
3600: 20 20 28 67 65 74 2d 66 66 69 2d 6f 62 6a 0a 20 (get-ffi-obj.
3610: 20 20 22 63 64 43 61 6e 76 61 73 47 65 74 46 6f "cdCanvasGetFo
3620: 6e 74 44 69 6d 22 20 6c 69 62 63 64 0a 20 20 20 ntDim" libcd.
3630: 28 5f 66 75 6e 20 5b 63 61 6e 76 61 73 20 3a 20 (_fun [canvas :
3640: 5f 63 61 6e 76 61 73 5d 0a 20 20 20 20 20 20 20 _canvas].
3650: 20 20 5b 6d 61 78 2d 77 69 64 74 68 20 3a 20 28 [max-width : (
3660: 5f 70 74 72 20 6f 20 5f 69 6e 74 29 5d 20 5b 68 _ptr o _int)] [h
3670: 65 69 67 68 74 20 3a 20 28 5f 70 74 72 20 6f 20 eight : (_ptr o
3680: 5f 69 6e 74 29 5d 0a 20 20 20 20 20 20 20 20 20 _int)].
3690: 5b 61 73 63 65 6e 74 20 3a 20 28 5f 70 74 72 20 [ascent : (_ptr
36a0: 6f 20 5f 69 6e 74 29 5d 20 5b 64 65 73 63 65 6e o _int)] [descen
36b0: 74 20 3a 20 28 5f 70 74 72 20 6f 20 5f 69 6e 74 t : (_ptr o _int
36c0: 29 5d 0a 20 20 20 20 20 20 20 20 20 2d 3e 20 5f )]. -> _
36d0: 76 6f 69 64 0a 20 20 20 20 20 20 20 20 20 2d 3e void. ->
36e0: 20 28 76 61 6c 75 65 73 0a 20 20 20 20 20 20 20 (values.
36f0: 20 20 20 20 20 20 6d 61 78 2d 77 69 64 74 68 20 max-width
3700: 68 65 69 67 68 74 0a 20 20 20 20 20 20 20 20 20 height.
3710: 20 20 20 20 61 73 63 65 6e 74 20 64 65 73 63 65 ascent desce
3720: 6e 74 29 29 29 29 0a 0a 28 64 65 66 69 6e 65 20 nt))))..(define
3730: 63 61 6e 76 61 73 2d 74 65 78 74 2d 73 69 7a 65 canvas-text-size
3740: 0a 20 20 28 67 65 74 2d 66 66 69 2d 6f 62 6a 0a . (get-ffi-obj.
3750: 20 20 20 22 63 64 43 61 6e 76 61 73 47 65 74 54 "cdCanvasGetT
3760: 65 78 74 53 69 7a 65 22 20 6c 69 62 63 64 0a 20 extSize" libcd.
3770: 20 20 28 5f 66 75 6e 20 5b 63 61 6e 76 61 73 20 (_fun [canvas
3780: 3a 20 5f 63 61 6e 76 61 73 5d 20 5b 74 65 78 74 : _canvas] [text
3790: 20 3a 20 5f 73 74 72 69 6e 67 2f 75 74 66 2d 38 : _string/utf-8
37a0: 5d 0a 20 20 20 20 20 20 20 20 20 5b 77 69 64 74 ]. [widt
37b0: 68 20 3a 20 28 5f 70 74 72 20 6f 20 5f 69 6e 74 h : (_ptr o _int
37c0: 29 5d 20 5b 68 65 69 67 68 74 20 3a 20 28 5f 70 )] [height : (_p
37d0: 74 72 20 6f 20 5f 69 6e 74 29 5d 0a 20 20 20 20 tr o _int)].
37e0: 20 20 20 20 20 2d 3e 20 5f 76 6f 69 64 0a 20 20 -> _void.
37f0: 20 20 20 20 20 20 20 2d 3e 20 28 76 61 6c 75 65 -> (value
3800: 73 20 77 69 64 74 68 20 68 65 69 67 68 74 29 29 s width height))
3810: 29 29 0a 0a 28 64 65 66 69 6e 65 20 63 61 6e 76 ))..(define canv
3820: 61 73 2d 74 65 78 74 2d 62 6f 78 0a 20 20 28 67 as-text-box. (g
3830: 65 74 2d 66 66 69 2d 6f 62 6a 0a 20 20 20 22 63 et-ffi-obj. "c
3840: 64 43 61 6e 76 61 73 47 65 74 54 65 78 74 42 6f dCanvasGetTextBo
3850: 78 22 20 6c 69 62 63 64 0a 20 20 20 28 5f 66 75 x" libcd. (_fu
3860: 6e 20 5b 63 61 6e 76 61 73 20 3a 20 5f 63 61 6e n [canvas : _can
3870: 76 61 73 5d 20 5b 78 20 3a 20 5f 69 6e 74 5d 20 vas] [x : _int]
3880: 5b 79 20 3a 20 5f 69 6e 74 5d 20 5b 74 65 78 74 [y : _int] [text
3890: 20 3a 20 5f 73 74 72 69 6e 67 2f 75 74 66 2d 38 : _string/utf-8
38a0: 5d 0a 20 20 20 20 20 20 20 20 20 5b 78 30 20 3a ]. [x0 :
38b0: 20 28 5f 70 74 72 20 6f 20 5f 69 6e 74 29 5d 20 (_ptr o _int)]
38c0: 5b 78 31 20 3a 20 28 5f 70 74 72 20 6f 20 5f 69 [x1 : (_ptr o _i
38d0: 6e 74 29 5d 0a 20 20 20 20 20 20 20 20 20 5b 79 nt)]. [y
38e0: 30 20 3a 20 28 5f 70 74 72 20 6f 20 5f 69 6e 74 0 : (_ptr o _int
38f0: 29 5d 20 5b 79 31 20 3a 20 28 5f 70 74 72 20 6f )] [y1 : (_ptr o
3900: 20 5f 69 6e 74 29 5d 0a 20 20 20 20 20 20 20 20 _int)].
3910: 20 2d 3e 20 5f 76 6f 69 64 0a 20 20 20 20 20 20 -> _void.
3920: 20 20 20 2d 3e 20 28 76 61 6c 75 65 73 20 78 30 -> (values x0
3930: 20 78 31 20 79 30 20 79 31 29 29 29 29 0a 0a 28 x1 y0 y1))))..(
3940: 70 72 6f 76 69 64 65 0a 20 63 61 6e 76 61 73 2d provide. canvas-
3950: 74 65 78 74 21 0a 20 63 61 6e 76 61 73 2d 66 6f text!. canvas-fo
3960: 6e 74 20 63 61 6e 76 61 73 2d 66 6f 6e 74 2d 73 nt canvas-font-s
3970: 65 74 21 0a 20 63 61 6e 76 61 73 2d 74 65 78 74 et!. canvas-text
3980: 2d 61 6c 69 67 6e 6d 65 6e 74 20 63 61 6e 76 61 -alignment canva
3990: 73 2d 74 65 78 74 2d 61 6c 69 67 6e 6d 65 6e 74 s-text-alignment
39a0: 2d 73 65 74 21 0a 20 63 61 6e 76 61 73 2d 74 65 -set!. canvas-te
39b0: 78 74 2d 6f 72 69 65 6e 74 61 74 69 6f 6e 20 63 xt-orientation c
39c0: 61 6e 76 61 73 2d 74 65 78 74 2d 6f 72 69 65 6e anvas-text-orien
39d0: 74 61 74 69 6f 6e 2d 73 65 74 21 0a 20 63 61 6e tation-set!. can
39e0: 76 61 73 2d 66 6f 6e 74 2d 64 69 6d 65 6e 73 69 vas-font-dimensi
39f0: 6f 6e 73 20 63 61 6e 76 61 73 2d 74 65 78 74 2d ons canvas-text-
3a00: 73 69 7a 65 20 63 61 6e 76 61 73 2d 74 65 78 74 size canvas-text
3a10: 2d 62 6f 78 29 0a 0a 3b 3b 20 7d 7d 7d 0a 0a 3b -box)..;; }}}..;
3a20: 3b 20 7b 7b 7b 20 56 65 72 74 65 78 20 66 75 6e ; {{{ Vertex fun
3a30: 63 74 69 6f 6e 73 0a 0a 28 64 65 66 69 6e 65 20 ctions..(define
3a40: 5f 63 61 6e 76 61 73 2d 6d 6f 64 65 0a 20 20 28 _canvas-mode. (
3a50: 5f 65 6e 75 6d 0a 20 20 20 27 28 66 69 6c 6c 20 _enum. '(fill
3a60: 6f 70 65 6e 2d 6c 69 6e 65 73 20 63 6c 6f 73 65 open-lines close
3a70: 64 2d 6c 69 6e 65 73 20 63 6c 69 70 20 62 65 7a d-lines clip bez
3a80: 69 65 72 20 72 65 67 69 6f 6e 20 70 61 74 68 29 ier region path)
3a90: 0a 20 20 20 5f 66 69 78 69 6e 74 29 29 0a 0a 28 . _fixint))..(
3aa0: 64 65 66 69 6e 65 20 63 61 6c 6c 2d 77 69 74 68 define call-with
3ab0: 2d 63 61 6e 76 61 73 2d 69 6e 2d 6d 6f 64 65 0a -canvas-in-mode.
3ac0: 20 20 28 6c 65 74 72 65 63 20 28 5b 63 61 6e 76 (letrec ([canv
3ad0: 61 73 2d 62 65 67 69 6e 2f 72 61 77 0a 20 20 20 as-begin/raw.
3ae0: 20 20 20 20 20 20 20 20 20 28 67 65 74 2d 66 66 (get-ff
3af0: 69 2d 6f 62 6a 0a 20 20 20 20 20 20 20 20 20 20 i-obj.
3b00: 20 20 20 22 63 64 43 61 6e 76 61 73 42 65 67 69 "cdCanvasBegi
3b10: 6e 22 20 6c 69 62 63 64 0a 20 20 20 20 20 20 20 n" libcd.
3b20: 20 20 20 20 20 20 28 5f 66 75 6e 20 5b 63 61 6e (_fun [can
3b30: 76 61 73 20 3a 20 5f 63 61 6e 76 61 73 5d 20 5b vas : _canvas] [
3b40: 63 61 6e 76 61 73 2d 6d 6f 64 65 20 3a 20 5f 63 canvas-mode : _c
3b50: 61 6e 76 61 73 2d 6d 6f 64 65 5d 20 2d 3e 20 5f anvas-mode] -> _
3b60: 76 6f 69 64 29 29 5d 0a 20 20 20 20 20 20 20 20 void))].
3b70: 20 20 20 5b 63 61 6e 76 61 73 2d 65 6e 64 2f 72 [canvas-end/r
3b80: 61 77 0a 20 20 20 20 20 20 20 20 20 20 20 20 28 aw. (
3b90: 67 65 74 2d 66 66 69 2d 6f 62 6a 0a 20 20 20 20 get-ffi-obj.
3ba0: 20 20 20 20 20 20 20 20 20 22 63 64 43 61 6e 76 "cdCanv
3bb0: 61 73 45 6e 64 22 20 6c 69 62 63 64 0a 20 20 20 asEnd" libcd.
3bc0: 20 20 20 20 20 20 20 20 20 20 28 5f 66 75 6e 20 (_fun
3bd0: 5b 63 61 6e 76 61 73 20 3a 20 5f 63 61 6e 76 61 [canvas : _canva
3be0: 73 5d 20 2d 3e 20 5f 76 6f 69 64 29 29 5d 29 0a s] -> _void))]).
3bf0: 20 20 20 20 28 ce bb 20 28 63 61 6e 76 61 73 20 (λ (canvas
3c00: 63 61 6e 76 61 73 2d 6d 6f 64 65 20 70 72 6f 63 canvas-mode proc
3c10: 29 0a 20 20 20 20 20 20 28 64 79 6e 61 6d 69 63 ). (dynamic
3c20: 2d 77 69 6e 64 0a 20 20 20 20 20 20 20 28 63 75 -wind. (cu
3c30: 74 20 63 61 6e 76 61 73 2d 62 65 67 69 6e 2f 72 t canvas-begin/r
3c40: 61 77 20 63 61 6e 76 61 73 20 63 61 6e 76 61 73 aw canvas canvas
3c50: 2d 6d 6f 64 65 29 0a 20 20 20 20 20 20 20 28 63 -mode). (c
3c60: 75 74 20 70 72 6f 63 20 63 61 6e 76 61 73 29 0a ut proc canvas).
3c70: 20 20 20 20 20 20 20 28 63 75 74 20 63 61 6e 76 (cut canv
3c80: 61 73 2d 65 6e 64 2f 72 61 77 20 63 61 6e 76 61 as-end/raw canva
3c90: 73 29 29 29 29 29 0a 0a 28 64 65 66 69 6e 65 20 s)))))..(define
3ca0: 5f 70 61 74 68 2d 61 63 74 69 6f 6e 0a 20 20 28 _path-action. (
3cb0: 5f 65 6e 75 6d 0a 20 20 20 27 28 6e 65 77 20 6d _enum. '(new m
3cc0: 6f 76 65 2d 74 6f 20 6c 69 6e 65 2d 74 6f 20 61 ove-to line-to a
3cd0: 72 63 20 63 75 72 76 65 2d 74 6f 20 63 6c 6f 73 rc curve-to clos
3ce0: 65 20 66 69 6c 6c 20 73 74 72 6f 6b 65 20 66 69 e fill stroke fi
3cf0: 6c 6c 2b 73 74 72 6f 6b 65 20 63 6c 69 70 29 0a ll+stroke clip).
3d00: 20 20 20 5f 66 69 78 69 6e 74 29 29 0a 0a 28 64 _fixint))..(d
3d10: 65 66 69 6e 65 20 63 61 6e 76 61 73 2d 70 61 74 efine canvas-pat
3d20: 68 2d 73 65 74 21 0a 20 20 28 67 65 74 2d 66 66 h-set!. (get-ff
3d30: 69 2d 6f 62 6a 0a 20 20 20 22 63 64 43 61 6e 76 i-obj. "cdCanv
3d40: 61 73 50 61 74 68 53 65 74 22 20 6c 69 62 63 64 asPathSet" libcd
3d50: 0a 20 20 20 28 5f 66 75 6e 20 5b 63 61 6e 76 61 . (_fun [canva
3d60: 73 20 3a 20 5f 63 61 6e 76 61 73 5d 20 5b 70 61 s : _canvas] [pa
3d70: 74 68 2d 61 63 74 69 6f 6e 20 3a 20 5f 70 61 74 th-action : _pat
3d80: 68 2d 61 63 74 69 6f 6e 5d 20 2d 3e 20 5f 76 6f h-action] -> _vo
3d90: 69 64 29 29 29 0a 0a 28 64 65 66 69 6e 65 20 63 id)))..(define c
3da0: 61 6e 76 61 73 2d 76 65 72 74 65 78 21 0a 20 20 anvas-vertex!.
3db0: 28 67 65 74 2d 66 66 69 2d 6f 62 6a 0a 20 20 20 (get-ffi-obj.
3dc0: 22 63 64 66 43 61 6e 76 61 73 56 65 72 74 65 78 "cdfCanvasVertex
3dd0: 22 20 6c 69 62 63 64 0a 20 20 20 28 5f 66 75 6e " libcd. (_fun
3de0: 20 5b 63 61 6e 76 61 73 20 3a 20 5f 63 61 6e 76 [canvas : _canv
3df0: 61 73 5d 20 5b 78 20 3a 20 5f 64 6f 75 62 6c 65 as] [x : _double
3e00: 2a 5d 20 5b 79 20 3a 20 5f 64 6f 75 62 6c 65 2a *] [y : _double*
3e10: 5d 20 2d 3e 20 5f 76 6f 69 64 29 29 29 0a 0a 28 ] -> _void)))..(
3e20: 70 72 6f 76 69 64 65 0a 20 63 61 6c 6c 2d 77 69 provide. call-wi
3e30: 74 68 2d 63 61 6e 76 61 73 2d 69 6e 2d 6d 6f 64 th-canvas-in-mod
3e40: 65 20 63 61 6e 76 61 73 2d 70 61 74 68 2d 73 65 e canvas-path-se
3e50: 74 21 0a 20 63 61 6e 76 61 73 2d 76 65 72 74 65 t!. canvas-verte
3e60: 78 21 29 0a 0a 3b 3b 20 7d 7d 7d 0a x!)..;; }}}.