-
Notifications
You must be signed in to change notification settings - Fork 43
/
Copy pathcheckbuttons.ml
64 lines (53 loc) · 1.53 KB
/
checkbuttons.ml
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
(*
* checkbuttons.ml
* ----------
* Copyright : (c) 2011, Jeremie Dimino <[email protected]>
* Licence : BSD3
*
* This file is a part of Lambda-Term.
*)
open Lwt
open LTerm_widget
let main () =
let waiter, wakener = wait () in
let vbox = new vbox in
let checked_label = new label "" in
let create_button n = new checkbutton ("button按钮" ^ (string_of_int n)) false in
let checkbuttons = Array.init 9 create_button in
let callback () =
let new_label = ref "" in
for i = 0 to 8 do
if checkbuttons.(i)#state
then new_label := !new_label ^ " " ^ string_of_int i
else ()
done;
checked_label#set_text !new_label
in
let button = new button "exit退出" in
button#on_click (wakeup wakener);
vbox#add ~expand:false button;
vbox#add ~expand:false (new hline);
let use_checkbutton n =
let cb = checkbuttons.(n) in
cb#on_click callback;
cb in
for i = 0 to 2 do
let hbox = new hbox in
hbox#add (use_checkbutton i);
hbox#add ~expand:false (new vline);
hbox#add (use_checkbutton (i + 3));
hbox#add ~expand:false (new vline);
hbox#add (use_checkbutton (i + 6));
vbox#add ~expand:false hbox
done;
vbox#add ~expand:false (new hline);
vbox#add ~expand:false checked_label;
vbox#add (new t "glue") ;
let frame = new frame in
frame#set vbox;
Lazy.force LTerm.stdout >>= fun term ->
LTerm.enable_mouse term >>= fun () ->
Lwt.finalize
(fun () -> run term frame waiter)
(fun () -> LTerm.disable_mouse term)
let () = Lwt_main.run (main ())