Add Fl_Terminal to "Scrollbar Size" unittest (#931)

This involved enlarging the unittest main window to make room
for the additional test.

Adding this test revealed a problem in Fl_Terminal's global
scrollbar size handling, which is fixed here as well.

Also fixed a small issue in the demo's debugging terminal
with the horiz scrollbar.
This commit is contained in:
Greg Ercolano 2024-03-11 13:20:17 -07:00
parent b1910ccfff
commit 38af0c823b
4 changed files with 66 additions and 27 deletions

View File

@ -3657,6 +3657,12 @@ void Fl_Terminal::draw(void) {
current_style_->update(); // do deferred update here current_style_->update(); // do deferred update here
update_screen(true); // update fonts update_screen(true); // update fonts
} }
// Detect if Fl::scrollbar_size() was changed in size, recalc if so
if (scrollbar_size_ == 0 &&
( scrollbar->visible() && scrollbar->w() != Fl::scrollbar_size() ||
hscrollbar->visible() && hscrollbar->h() != Fl::scrollbar_size())) {
update_scrollbar();
}
// Draw group first, terminal last // Draw group first, terminal last
Fl_Group::draw(); Fl_Group::draw();
// Draw that little square between the scrollbars: // Draw that little square between the scrollbars:

View File

@ -91,7 +91,7 @@
#define FORM_W 350 #define FORM_W 350
#define FORM_H 440 #define FORM_H 440
#define TTY_W 700 #define TTY_W 780
#define TTY_H 200 #define TTY_H 200
/* The form description */ /* The form description */

View File

@ -23,6 +23,7 @@
#include <FL/Fl_Table.H> #include <FL/Fl_Table.H>
#include <FL/Fl_Text_Display.H> #include <FL/Fl_Text_Display.H>
#include <FL/Fl_Value_Slider.H> #include <FL/Fl_Value_Slider.H>
#include <FL/Fl_Terminal.H>
// //
// Test new 1.3.x global vs. local scrollbar sizing // Test new 1.3.x global vs. local scrollbar sizing
@ -80,12 +81,15 @@ static const char *phonetics[] = {
class Ut_Scrollbar_Size_Test : public Fl_Group { class Ut_Scrollbar_Size_Test : public Fl_Group {
Fl_Browser *brow_a, *brow_b, *brow_c; Fl_Browser *brow_a, *brow_b, *brow_c;
Fl_Tree *tree_a, *tree_b, *tree_c; Fl_Tree *tree_a, *tree_b, *tree_c;
Ut_Table *table_a,*table_b,*table_c; Ut_Table *table_a,*table_b,*table_c;
Fl_Text_Display *text_a, *text_b, *text_c; Fl_Text_Display *text_a, *text_b, *text_c;
Fl_Terminal *term_a, *term_b, *term_c;
Fl_Browser *makebrowser(int X,int Y,int W,int H,const char*L=0) { Fl_Browser *makebrowser(int X,int Y,int W,int H,const char*L=0) {
Fl_Browser *b = new Fl_Browser(X,Y,W,H,L); Fl_Browser *b = new Fl_Browser(X,Y,W,H,L);
b->type(FL_MULTI_BROWSER); b->type(FL_MULTI_BROWSER);
b->labelsize(10);
b->textsize(10);
b->align(FL_ALIGN_TOP); b->align(FL_ALIGN_TOP);
for (int t=0; phonetics[t]; t++ ) { for (int t=0; phonetics[t]; t++ ) {
b->add(phonetics[t]); b->add(phonetics[t]);
@ -95,6 +99,8 @@ class Ut_Scrollbar_Size_Test : public Fl_Group {
} }
Fl_Tree *maketree(int X,int Y,int W,int H,const char*L=0) { Fl_Tree *maketree(int X,int Y,int W,int H,const char*L=0) {
Fl_Tree *b = new Fl_Tree(X,Y,W,H,L); Fl_Tree *b = new Fl_Tree(X,Y,W,H,L);
b->labelsize(10);
b->item_labelsize(10);
b->type(FL_TREE_SELECT_MULTI); b->type(FL_TREE_SELECT_MULTI);
b->align(FL_ALIGN_TOP); b->align(FL_ALIGN_TOP);
for (int t=0; phonetics[t]; t++ ) { for (int t=0; phonetics[t]; t++ ) {
@ -105,6 +111,7 @@ class Ut_Scrollbar_Size_Test : public Fl_Group {
} }
Ut_Table *maketable(int X,int Y,int W,int H,const char*L=0) { Ut_Table *maketable(int X,int Y,int W,int H,const char*L=0) {
Ut_Table *mta = new Ut_Table(X,Y,W,H,L); Ut_Table *mta = new Ut_Table(X,Y,W,H,L);
mta->labelsize(10);
mta->align(FL_ALIGN_TOP); mta->align(FL_ALIGN_TOP);
mta->end(); mta->end();
return(mta); return(mta);
@ -112,6 +119,8 @@ class Ut_Scrollbar_Size_Test : public Fl_Group {
Fl_Text_Display *maketextdisplay(int X,int Y,int W,int H,const char*L=0) { Fl_Text_Display *maketextdisplay(int X,int Y,int W,int H,const char*L=0) {
Fl_Text_Display *dpy = new Fl_Text_Display(X,Y,W,H,L); Fl_Text_Display *dpy = new Fl_Text_Display(X,Y,W,H,L);
Fl_Text_Buffer *buf = new Fl_Text_Buffer(); Fl_Text_Buffer *buf = new Fl_Text_Buffer();
dpy->labelsize(10);
dpy->textsize(10);
dpy->buffer(buf); dpy->buffer(buf);
for (int t=0; phonetics[t]; t++ ) { for (int t=0; phonetics[t]; t++ ) {
buf->printf("%s\n", phonetics[t]); buf->printf("%s\n", phonetics[t]);
@ -119,6 +128,15 @@ class Ut_Scrollbar_Size_Test : public Fl_Group {
} }
return(dpy); return(dpy);
} }
Fl_Terminal *maketerm(int X,int Y,int W,int H,const char*L=0) {
Fl_Terminal *term = new Fl_Terminal(X,Y,W,H,L);
term->labelsize(8);
term->textsize(8);
term->end();
term->display_columns(40); // force wider than normal to show hscroll
term->printf("Long entry will show h-bar\n");
return(term);
}
void slide_cb2(Fl_Value_Slider *in) { void slide_cb2(Fl_Value_Slider *in) {
const char *label = in->label(); const char *label = in->label();
int val = int(in->value()); int val = int(in->value());
@ -128,6 +146,7 @@ class Ut_Scrollbar_Size_Test : public Fl_Group {
tree_a->scrollbar_size(val); tree_a->scrollbar_size(val);
table_a->scrollbar_size(val); table_a->scrollbar_size(val);
text_a->scrollbar_size(val); text_a->scrollbar_size(val);
term_a->scrollbar_size(val);
} else { } else {
Fl::scrollbar_size(val); Fl::scrollbar_size(val);
} }
@ -148,35 +167,44 @@ public:
begin(); begin();
// _____________ _______________ // _____________ _______________
// |_____________| |_______________| // |_____________| |_______________|
// --- ----- <-- tgrpy // --- ----- <-- tgrpy
// brow_a brow_b brow_c | 14 | // brow_a brow_b brow_c ↕ 14 ↑
// ---------- ---------- ---------- --- | <-- browy // ---------- ---------- ---------- --- | <-- browy
// | | | | | | |browh | // | | | | | | ↑ browh |
// | | | | | | | | // | | | | | | ↓ |
// ---------- ---------- ---------- --- tgrph // ---------- ---------- ---------- --- tgrph
// | | // ↑ |
// tree_a tree_b tree_c | 20 | // tree_a tree_b tree_c ↓ 20 |
// ---------- ---------- ---------- --- | <-- treey // ---------- ---------- ---------- --- | <-- treey
// | | | | | | |treeh | // | | | | | | ↑ treeh |
// | | | | | | | | // | | | | | | ↓ |
// ---------- ---------- ---------- --- | // ---------- ---------- ---------- --- |
// | | // ↑ |
// table_a table_b table_c | 20 | // table_a table_b table_c ↓ 20 |
// ---------- ---------- ---------- --- | <-- tabley // ---------- ---------- ---------- --- | <-- tabley
// | | | | | | |tableh| // | | | | | | ↑ tableh |
// | | | | | | | | // | | | | | | ↓ |
// ---------- ---------- ---------- --- ------ // ---------- ---------- ---------- --- |
// ↑ |
// term_a term_b term_c ↓ 20 |
// ---------- ---------- ---------- --- | <-- termy
// | | | | | | ↑ termh |
// | | | | | | ↓ ↓
// ---------- ---------- ---------- --- ------
// etc.. // etc..
int tgrpy = Y+30; int tgrpy = Y+30;
int tgrph = H-130; int tgrph = H-30;
int ysep = 20; // y separation between widgets
int browy = tgrpy+14; int browy = tgrpy+14;
int browh = tgrph/3 - 20; int browh = tgrph/5 - 20; // 5: number of widgets vertically
int treey = browy + browh + 20; int treey = browy + browh + ysep;
int treeh = browh; int treeh = browh;
int tabley = treey + treeh + 20; int tabley = treey + treeh + ysep;
int tableh = browh; int tableh = browh;
int texty = tabley + tableh + 20; int texty = tabley + tableh + ysep;
int texth = browh; int texth = browh;
int termy = texty + texth + ysep;
int termh = texth;
brow_a = makebrowser(X+ 10,browy,100,browh,"Browser A"); brow_a = makebrowser(X+ 10,browy,100,browh,"Browser A");
brow_b = makebrowser(X+120,browy,100,browh,"Browser B"); brow_b = makebrowser(X+120,browy,100,browh,"Browser B");
brow_c = makebrowser(X+230,browy,100,browh,"Browser C"); brow_c = makebrowser(X+230,browy,100,browh,"Browser C");
@ -189,6 +217,9 @@ public:
text_a = maketextdisplay(X+ 10,texty,100,texth,"Text Display A"); text_a = maketextdisplay(X+ 10,texty,100,texth,"Text Display A");
text_b = maketextdisplay(X+120,texty,100,texth,"Text Display B"); text_b = maketextdisplay(X+120,texty,100,texth,"Text Display B");
text_c = maketextdisplay(X+230,texty,100,texth,"Text Display C"); text_c = maketextdisplay(X+230,texty,100,texth,"Text Display C");
term_a = maketerm(X+ 10,termy,100,texth,"Term A");
term_b = maketerm(X+120,termy,100,texth,"Term B");
term_c = maketerm(X+230,termy,100,texth,"Term C");
Fl_Value_Slider *slide_glob = new Fl_Value_Slider(X+100,Y,100,18,"Global Scroll Size"); Fl_Value_Slider *slide_glob = new Fl_Value_Slider(X+100,Y,100,18,"Global Scroll Size");
slide_glob->value(16); slide_glob->value(16);
slide_glob->type(FL_HORIZONTAL); slide_glob->type(FL_HORIZONTAL);
@ -206,8 +237,10 @@ public:
slide_browa->callback(slide_cb, (void*)this); slide_browa->callback(slide_cb, (void*)this);
slide_browa->labelsize(12); slide_browa->labelsize(12);
int msgbox_x = brow_c->x() + brow_c->w() + 20; int msgbox_x = brow_c->x() + brow_c->w() + 20;
int msgbox_y = tgrpy;
int msgbox_w = W-(msgbox_x-X); int msgbox_w = W-(msgbox_x-X);
Fl_Box *msgbox = new Fl_Box(msgbox_x,browy,msgbox_w,H-Y-48); int msgbox_h = tgrph;
Fl_Box *msgbox = new Fl_Box(msgbox_x,msgbox_y,msgbox_w,msgbox_h);
msgbox->label("\nVerify global scrollbar sizing and per-widget scrollbar sizing. " msgbox->label("\nVerify global scrollbar sizing and per-widget scrollbar sizing. "
"Scrollbar's size should change interactively as size sliders are changed. " "Scrollbar's size should change interactively as size sliders are changed. "
"Changing 'Global Scroll Size' should affect all scrollbars AS LONG AS the " "Changing 'Global Scroll Size' should affect all scrollbars AS LONG AS the "

View File

@ -26,7 +26,7 @@ class Fl_Terminal;
// WINDOW/WIDGET SIZES // WINDOW/WIDGET SIZES
const int UT_MAINWIN_W = 700; // main window w() const int UT_MAINWIN_W = 700; // main window w()
const int UT_MAINWIN_H = 400; // main window h() const int UT_MAINWIN_H = 600; // main window h()
const int UT_BROWSER_X = 10; // browser x() const int UT_BROWSER_X = 10; // browser x()
const int UT_BROWSER_Y = 25; // browser y() const int UT_BROWSER_Y = 25; // browser y()
const int UT_BROWSER_W = 150; // browser w() const int UT_BROWSER_W = 150; // browser w()