File: cairo_test.ml

package info (click to toggle)
mlpost 0.9-5
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid, trixie
  • size: 3,844 kB
  • sloc: ml: 21,094; javascript: 4,047; makefile: 430; ansic: 34; lisp: 19; sh: 15
file content (118 lines) | stat: -rw-r--r-- 2,592 bytes parent folder | download | duplicates (2)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
open Mlpost
open Command
open Picture
open Point
open Path
module H = Helpers

(*parse <<togglescript>> *)

(*parse <<other27 *)

let a = Point.pt (Num.bp 0., Num.bp 0.)

let pen = Pen.scale (Num.bp 7.) Pen.circle

let label ~pos pic p =
  let pic = Picture.make (seq [ draw_pic pic; draw (corner_bbox pic) ]) in
  label ~pos pic p

let other27 =
  seq
    [
      draw (Path.pathp [ a ]) ~pen;
      label ~pos:`Top (Picture.tex "Au dessus") a;
      label ~pos:`Bot (Picture.tex "En dessous") a;
      label ~pos:`Right (Picture.tex "\\`A droite") a;
      label ~pos:`Left (Picture.tex "\\`A gauche") a;
    ]

(*parse >> <<handbook3 *)
let z0 = (-1.3, -1.)

let z1 = (50., 30.)

let z2 = (80., 80.)

let z3 = (10., 70.)

let z4 = (30., 50.)

let l1 = [ z0; z1; z2; z3; z4 ]

let labels1 =
  seq
    [
      H.dotlabels ~pos:`Top [ "0"; "2"; "4" ] (map_bp [ z0; z2; z4 ]);
      dotlabel ~pos:`Left (tex "3") (bpp z3);
      dotlabel ~pos:`Right (tex "1") (bpp z1);
    ]

let handbook3 = seq [ draw (path ~style:jCurve l1); labels1 ]

(*parse >> *)

let bp = Num.bp

let ribbon =
  MetaPath.concat
    ~style:(MetaPath.jControls (pt (bp 310., bp 300.)) (pt (bp 10., bp 310.)))
    (MetaPath.start (knotp (pt (bp 110., bp 20.))))
    (MetaPath.knotp (pt (bp 210., bp 20.)))

let ribbon = draw (of_metapath ribbon)

let path_test = path ~style:jCurve [ z0; z1; z2 ]

let tg p t =
  draw (pathp ~style:jLine [ point t p; add (point t p) (direction t p) ])

let test =
  seq
    ( draw path_test
    :: List.map (tg path_test)
         [ 0.; 0.264543; 0.5; 0.785651; 1.; 1.3528; 1.5; 1.8653; 2. ] )

let some_cut =
  let p = Point.p (10., 10.) in
  let p1 = path [ (0., 0.); (50., 50.) ] in
  let p2 = path [ (0., 50.); (50., 0.) ] in
  let p3 = cut_after p1 p2 in
  seq [ draw p1; draw p3; draw (Path.shift p p2) ]

let w0 = (0., 0.)

let w1 = (-50., 50.)

let w2 = (0., 100.)

let w3 = (50., 50.)

let labels2 =
  seq
    [
      H.dotlabels ~pos:`Top [ "0"; "2" ] (map_bp [ w0; w2 ]);
      dotlabel ~pos:`Left (tex "3") (bpp w3);
      dotlabel ~pos:`Right (tex "1") (bpp w1);
    ]

(*let circle = seq [ draw (MetaPath.cycle ~style:jCurve (MetaPath.path ~style:jCurve (w0::w1::w2::w3::[])));labels2]*)

let circle =
  seq
    [
      draw (Path.scale (bp 100.) Path.halfcircle);
      draw (Path.scale (bp 50.) Path.quartercircle);
    ]

let to_export =
  [
    ("other27", other27);
    ("handbook3", handbook3);
    ("ribbon", ribbon);
    ("test", test);
    ("circle", circle);
    ("somecut", some_cut);
  ]

let _ = List.iter (fun (name, fig) -> Metapost.emit name fig) to_export