summaryrefslogtreecommitdiff
path: root/test/adjuster.cxx
blob: c745da32f4f7273c9c4c14c5ddbefe45f26a5160 (plain)
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
//
// Adjuster test program for the Fast Light Tool Kit (FLTK).
//
// Copyright 1998-2026 by Bill Spitzak and others.
//
// This library is free software. Distribution and use rights are outlined in
// the file "COPYING" which should have been included with this file.  If this
// file is missing or damaged, see the license at:
//
//     https://www.fltk.org/COPYING.php
//
// Please see the following page on how to report bugs and issues:
//
//     https://www.fltk.org/bugs.php
//

#include <stdlib.h>
#include <FL/Fl.H>
#include <FL/Fl_Double_Window.H>
#include <FL/Fl_Adjuster.H>
#include <FL/Fl_Box.H>

void adjcb(Fl_Widget *o, void *v) {
  Fl_Adjuster *a = (Fl_Adjuster*)o;
  Fl_Box *b = (Fl_Box *)v;
  char new_label[64];
  a->format(new_label);
  b->copy_label(new_label);
  b->redraw();
}

int main(int argc, char ** argv) {
  Fl_Double_Window window(320, 100, argv[0]);

  Fl_Box b1(20, 30, 80, 25);
  b1.box(FL_DOWN_BOX);
  b1.color(FL_WHITE);
  Fl_Adjuster a1(20+80, 30, 3*25, 25);
  a1.callback(adjcb, &b1);
  adjcb(&a1, &b1);

  Fl_Box b2(20+80+4*25, 30, 80, 25);
  b2.box(FL_DOWN_BOX);
  b2.color(FL_WHITE);
  Fl_Adjuster a2(b2.x()+b2.w(), 10, 25, 3*25);
  a2.callback(adjcb, &b2);
  adjcb(&a2, &b2);

  window.resizable(window);
  window.end();
  window.show(argc, argv);
  return Fl::run();
}