summaryrefslogtreecommitdiff
path: root/src/gui/gui.cpp
diff options
context:
space:
mode:
Diffstat (limited to 'src/gui/gui.cpp')
-rw-r--r--src/gui/gui.cpp150
1 files changed, 72 insertions, 78 deletions
diff --git a/src/gui/gui.cpp b/src/gui/gui.cpp
index 273d4c7d..270cbb5e 100644
--- a/src/gui/gui.cpp
+++ b/src/gui/gui.cpp
@@ -46,7 +46,6 @@ static BITMAP *gui__repository[GUI_BMP_COUNT];
/* The currently active skin */
LexSkin gui_skin;
BITMAP *gui_bitmap;
-ALFONT_FONT *gui_font;
bool drag;
DATAFILE *gui_gfx;
@@ -96,9 +95,6 @@ void init_gui(BITMAP *bitmap, const char *skin) {
gui_bitmap = bitmap;
gui_load_skin(skin);
- //alfont_init();
- gui_font = alfont_load_font("./data/Skin/arial.ttf");
- alfont_set_font_size(gui_font, 14);
drag = false;
show_mouse(NULL);
}
@@ -470,9 +466,7 @@ void gui_exit() {
delete guiGraphics;
delete imageLoader;
- //alfont_destroy_font(gui_font);
gui_shutdown();
- //alfont_exit();
}
void gui_shutdown(void) {
@@ -537,19 +531,19 @@ int gui_text(BITMAP *bmp, AL_CONST char *s, int x, int y, int color, int centre)
}
}
usetc(tmp+out_pos, 0);
- pix_len = alfont_text_length(gui_font, tmp);
+ pix_len = text_length(font, tmp);
if (centre)x -= pix_len / 2;
if (bmp) {
- alfont_textout_aa(bmp, gui_font, tmp, x, y, color);
+ textout(bmp, font, tmp, x, y, color);
if (hline_pos >= 0) {
c = ugetat(tmp, hline_pos);
usetat(tmp, hline_pos, 0);
- hline_pos = alfont_text_length(gui_font, tmp);
+ hline_pos = text_length(font, tmp);
c = usetc(tmp, c);
usetc(tmp+c, 0);
- c = alfont_text_length(gui_font, tmp);
- hline(bmp, x+hline_pos, y+alfont_text_height(gui_font)-gui_font_baseline, x+hline_pos+c-1, color);
+ c = text_length(font, tmp);
+ hline(bmp, x+hline_pos, y+text_height(font)-gui_font_baseline, x+hline_pos+c-1, color);
}
}
return pix_len;
@@ -558,9 +552,9 @@ int gui_text(BITMAP *bmp, AL_CONST char *s, int x, int y, int color, int centre)
int tmw_text_proc(int msg, DIALOG *d, int c) {
if (msg==MSG_DRAW) {
int rtm;
- rtm = alfont_text_mode(-1);
+ rtm = text_mode(-1);
gui_text(gui_bitmap, (char *)d->dp, d->x, d->y, d->fg, FALSE);
- alfont_text_mode(rtm);
+ text_mode(rtm);
}
return D_O_K;
}
@@ -590,16 +584,16 @@ int tmw_button_proc(int msg, DIALOG *d, int c) {
draw_skinned_rect(gui_bitmap, &gui_skin.button.background[0], d->x, d->y, d->w, d->h);
col = gui_skin.button.textcolor[0];
}
- rtm = alfont_text_mode(-1);
- gui_text(gui_bitmap, (const char *)d->dp, d->x+d->w/2+ofs, d->y+d->h/2-alfont_text_height(gui_font)/2+ofs, col, TRUE);
- alfont_text_mode(rtm);
+ rtm = text_mode(-1);
+ gui_text(gui_bitmap, (const char *)d->dp, d->x+d->w/2+ofs, d->y+d->h/2-text_height(font)/2+ofs, col, TRUE);
+ text_mode(rtm);
ret = D_O_K;
} else {
/*if(msg==MSG_CLICK) {
if(d->d1==1)((int)d->dp2) + 1;
else if(d->d1==2)((int)d->dp2) - 1;
}*/
-
+
ret = d_button_proc(msg,d,c);
}
return ret;
@@ -669,11 +663,11 @@ int tmw_slider_proc(int msg, DIALOG *d, int c) {
}
masked_blit(gui_skin.slider.vGrip, gui_bitmap, 0, 0, x, y, gui_skin.slider.vGrip->w, gui_skin.slider.vGrip->h);
}
- //textprintf(gui_bitmap, gui_font,10, 10, makecol(255,255,255), "%i", d->d2);
+ //textprintf(gui_bitmap, font,10, 10, makecol(255,255,255), "%i", d->d2);
} else {
if(d->d1==0)d->d1 = 1;
ret = d_slider_proc(msg,d,c);
- }
+ }
if (watchdog == 1) {
d->dp2 = (void*)gui__external_slider_callback;
@@ -725,13 +719,13 @@ int tmw_radio_proc(int msg, DIALOG *d, int c) {
tx = x - box->w/2 - l;
}
y = d->y + (d->h - box->h)/ 2;
- ty = d->y + (d->h - alfont_text_height(gui_font)) / 2;
+ ty = d->y + (d->h - text_height(font)) / 2;
masked_blit(box, gui_bitmap, 0, 0, x, y, box->w, box->h);
if (d->dp != NULL) {
- rtm = alfont_text_mode(-1);
+ rtm = text_mode(-1);
gui_text(gui_bitmap, (const char *)d->dp, tx, ty, col, 0);
- alfont_text_mode(rtm);
+ text_mode(rtm);
}
@@ -767,13 +761,13 @@ int tmw_edit_proc(int msg, DIALOG *d, int c) {
lb = gui_skin.textbox.bg.grid[0]->w;
rb = gui_skin.textbox.bg.grid[2]->w;
tx = d->x + lb;
- ty = d->y + (d->h - alfont_text_height(gui_font))/2;
+ ty = d->y + (d->h - text_height(font))/2;
text = (char *)d->dp;
start = text;
- rtm = alfont_text_mode(-1);
+ rtm = text_mode(-1);
if (gui_bitmap->clip) {
cl = gui_bitmap->cl;
@@ -785,10 +779,10 @@ int tmw_edit_proc(int msg, DIALOG *d, int c) {
cr=gui_bitmap->w;
cb=gui_bitmap->h;
}
- set_clip_rect(gui_bitmap, tx, ty, d->x+d->w-rb, ty + alfont_text_height(gui_font)); // set_clip() is deprecated use set_clip_rect() instead
+ set_clip_rect(gui_bitmap, tx, ty, d->x+d->w-rb, ty + text_height(font)); // set_clip() is deprecated use set_clip_rect() instead
hack = text[d->d2];
text[d->d2] = '\0';
- l = alfont_text_length(gui_font, text);
+ l = text_length(font, text);
text[d->d2] = hack;
if (l > d->w-lb-rb) {
@@ -800,11 +794,11 @@ int tmw_edit_proc(int msg, DIALOG *d, int c) {
if (d->flags & D_GOTFOCUS) {
hack = text[d->d2];
text[d->d2] = '\0';
- x = tx + alfont_text_length(gui_font, text);
- vline(gui_bitmap, x, ty, ty + alfont_text_height(gui_font), col);
+ x = tx + text_length(font, text);
+ vline(gui_bitmap, x, ty, ty + text_height(font), col);
text[d->d2] = hack;
}
- alfont_text_mode(rtm);
+ text_mode(rtm);
set_clip_rect(gui_bitmap, cl, ct, cr, cb);
} else {
return d_edit_proc(msg, d, c);
@@ -838,7 +832,7 @@ int tmw_password_proc(int msg, DIALOG *d, int c) {
lb = gui_skin.textbox.bg.grid[0]->w;
rb = gui_skin.textbox.bg.grid[2]->w;
tx = d->x + lb;
- ty = d->y + (d->h - alfont_text_height(gui_font))/2;
+ ty = d->y + (d->h - text_height(font))/2;
text = (char *)malloc(strlen((char *)d->dp)+1);
@@ -848,7 +842,7 @@ int tmw_password_proc(int msg, DIALOG *d, int c) {
text[i] = '\0';
start = text;
- rtm = alfont_text_mode(-1);
+ rtm = text_mode(-1);
if (gui_bitmap->clip) {
cl = gui_bitmap->cl;
@@ -860,11 +854,11 @@ int tmw_password_proc(int msg, DIALOG *d, int c) {
cr=gui_bitmap->w;
cb=gui_bitmap->h;
}
- set_clip_rect(gui_bitmap, tx, ty, d->x+d->w-rb, ty + alfont_text_height(gui_font));
+ set_clip_rect(gui_bitmap, tx, ty, d->x+d->w-rb, ty + text_height(font));
hack = text[d->d2];
text[d->d2] = '\0';
- l = alfont_text_length(gui_font, text);
+ l = text_length(font, text);
text[d->d2] = hack;
if (l > d->w-lb-rb) {
@@ -876,11 +870,11 @@ int tmw_password_proc(int msg, DIALOG *d, int c) {
if (d->flags & D_GOTFOCUS) {
hack = text[d->d2];
text[d->d2] = '\0';
- x = tx + alfont_text_length(gui_font, text);
- vline(gui_bitmap, x, ty, ty + alfont_text_height(gui_font), col);
+ x = tx + text_length(font, text);
+ vline(gui_bitmap, x, ty, ty + text_height(font), col);
text[d->d2] = hack;
}
- alfont_text_mode(rtm);
+ text_mode(rtm);
set_clip_rect(gui_bitmap, cl, ct, cr, cb);
} else {
return d_edit_proc(msg, d, c);
@@ -899,7 +893,7 @@ int tmw_list_proc(int msg, DIALOG *d, int c) {
int w, h = 0;
int rtm = 0;
int cl, cr, cb, ct;
- int th = alfont_text_height(gui_font);
+ int th = text_height(font);
int vscroll = 0;
int sliderh = 10;
@@ -908,8 +902,8 @@ int tmw_list_proc(int msg, DIALOG *d, int c) {
(*(getfuncptr)d->dp)(-1, &itemCount);
w = d->w - gui_skin.listbox.bg.grid[0]->w - gui_skin.listbox.bg.grid[2]->w;
h = d->h - gui_skin.listbox.bg.grid[1]->h - gui_skin.listbox.bg.grid[7]->h;
- lastItem = MIN(itemCount-1, firstItem + h / alfont_text_height(gui_font));
-
+ lastItem = MIN(itemCount-1, firstItem + h / text_height(font));
+
if (msg == MSG_DRAW) {
if (ignoreRedraw) {
return D_O_K;
@@ -927,7 +921,7 @@ int tmw_list_proc(int msg, DIALOG *d, int c) {
draw_skinned_rect(gui_bitmap, &gui_skin.listbox.vscroll, d->x+d->w-13, slidery, 11, sliderh);
}
- rtm = alfont_text_mode(-1);
+ rtm = text_mode(-1);
if (gui_bitmap->clip) {
cl = gui_bitmap->cl;
ct = gui_bitmap->ct;
@@ -944,22 +938,22 @@ int tmw_list_proc(int msg, DIALOG *d, int c) {
if (d->flags & D_DISABLED) {
col = gui_skin.listbox.textcolor[3];
for (a=firstItem; a < lastItem; a++) {
- alfont_textout_aa(gui_bitmap, gui_font, (*(getfuncptr)d->dp)(a, 0), x, y, col);
- y += alfont_text_height(gui_font);
+ textout(gui_bitmap, font, (*(getfuncptr)d->dp)(a, 0), x, y, col);
+ y += text_height(font);
}
} else {
for (a=firstItem; a <= lastItem; a++) {
if (a==d->d1) {
col = gui_skin.listbox.textcolor[1];
- rectfill(gui_bitmap, x, y, x+w, y+alfont_text_height(gui_font)-1, gui_skin.listbox.textcolor[2]);
+ rectfill(gui_bitmap, x, y, x+w, y+text_height(font)-1, gui_skin.listbox.textcolor[2]);
} else {
col = gui_skin.listbox.textcolor[0];
}
- alfont_textout_aa(gui_bitmap, gui_font, (*(getfuncptr)d->dp)(a, 0), x, y, col);
- y += alfont_text_height(gui_font);
+ textout(gui_bitmap, font, (*(getfuncptr)d->dp)(a, 0), x, y, col);
+ y += text_height(font);
}
}
- alfont_text_mode(rtm);
+ text_mode(rtm);
set_clip_rect(gui_bitmap, cl, ct, cr, cb);
} else if (msg == MSG_CLICK) {
x = d->x + gui_skin.listbox.bg.grid[0]->w;
@@ -1008,7 +1002,7 @@ int tmw_list_proc(int msg, DIALOG *d, int c) {
}
} else if (mouse_x >= x && mouse_x < x+w && mouse_y >= y && mouse_y < y+h) {
while (mouse_b) {
- a = firstItem + (mouse_y-y) / alfont_text_height(gui_font);
+ a = firstItem + (mouse_y-y) / text_height(font);
if (a <= lastItem && a != selectedItem) {
d->d1 = selectedItem = a;
scare_mouse();
@@ -1060,7 +1054,7 @@ if(mouse_b & 1)
}
if(!draw)
masked_blit(gui_skin.plus.bg.grid[0], gui_bitmap, 0, 0, d->x, d->y, gui_bitmap->w, gui_bitmap->h);
-
+
return D_O_K;
}
@@ -1072,7 +1066,7 @@ if(share2!=0)
masked_blit(gui_skin.bar.bg.grid[3], gui_bitmap, 0, 0, d->x, d->y, gui_bitmap->w, gui_bitmap->h);
else
masked_blit(gui_skin.bar.bg.grid[0], gui_bitmap, 0, 0, d->x, d->y, gui_bitmap->w, gui_bitmap->h);
-
+
for(int i = 3; i < (d->w-3); i++)
if(i<share2*d->w-3)
masked_blit(gui_skin.bar.bg.grid[4], gui_bitmap, 0, 0, d->x+1*i, d->y, gui_bitmap->w, gui_bitmap->h);
@@ -1125,11 +1119,11 @@ int tmw_dialog_proc(int msg, DIALOG *d, int c) {
d->d2 = -1;
}
draw_skinned_rect(gui_bitmap, &gui_skin.dialog.bg, d->x, d->y, d->w, d->h);
- rtm = alfont_text_mode(-1);
- alfont_textprintf_centre_aa(gui_bitmap, gui_font,
+ rtm = text_mode(-1);
+ textprintf_centre(gui_bitmap, font,
d->x + d->w/2,
- d->y + (gui_skin.dialog.bg.grid[1]->h - alfont_text_height(gui_font))/2, d->fg, "%s", d->dp);
- alfont_text_mode(rtm);
+ d->y + (gui_skin.dialog.bg.grid[1]->h - text_height(font))/2, d->fg, "%s", d->dp);
+ text_mode(rtm);
break;
}
return D_O_K;
@@ -1176,9 +1170,9 @@ int tmw_ldialog_proc(int msg, DIALOG *d, int c) {
d->d2 = -1;
}
draw_skinned_rect(gui_bitmap, &gui_skin.dialog.bg, d->x, d->y, d->w, d->h);
- rtm = alfont_text_mode(-1);
- alfont_textprintf_aa(gui_bitmap, gui_font, d->x + 4, d->y + (gui_skin.dialog.bg.grid[1]->h - alfont_text_height(gui_font))/2, d->fg, "%s", d->dp);
- alfont_text_mode(rtm);
+ rtm = text_mode(-1);
+ textprintf(gui_bitmap, font, d->x + 4, d->y + (gui_skin.dialog.bg.grid[1]->h - text_height(font))/2, d->fg, "%s", d->dp);
+ text_mode(rtm);
}
return D_O_K;
}
@@ -1252,7 +1246,7 @@ void _gui_draw_textbox(char *thetext, int *listsize, int draw, int offset,
if (disabled)
fg = disable;
- rtm = alfont_text_mode(-1);
+ rtm = text_mode(-1);
/* loop over the entire string */
while (1) {
@@ -1270,11 +1264,11 @@ void _gui_draw_textbox(char *thetext, int *listsize, int draw, int offset,
/* the next character length */
usetc(s+usetc(s, ugetc(scanned)), 0);
- len = alfont_text_length(gui_font, s);
+ len = text_length(font, s);
/* modify length if its a tab */
if (ugetc(s) == '\t')
- len = tabsize * alfont_text_length(gui_font, space);
+ len = tabsize * text_length(font, space);
/* check for the end of a line by excess width of next char */
if (width+len >= ww) {
@@ -1348,8 +1342,8 @@ void _gui_draw_textbox(char *thetext, int *listsize, int draw, int offset,
case '\t':
for (i=0; i<tabsize; i++) {
usetc(s+usetc(s, ' '), 0);
- alfont_textout_aa(gui_bitmap, gui_font, s, x1, y1, fg);
- x1 += alfont_text_length(gui_font, s);
+ textout(gui_bitmap, font, s, x1, y1, fg);
+ x1 += text_length(font, s);
}
break;
@@ -1357,8 +1351,8 @@ void _gui_draw_textbox(char *thetext, int *listsize, int draw, int offset,
default:
if (printed != ignore) {
usetc(s+usetc(s, ugetc(printed)), 0);
- alfont_textout_aa(gui_bitmap, gui_font, s, x1, y1, fg);
- x1 += alfont_text_length(gui_font, s);
+ textout(gui_bitmap, font, s, x1, y1, fg);
+ x1 += text_length(font, s);
}
}
@@ -1367,10 +1361,10 @@ void _gui_draw_textbox(char *thetext, int *listsize, int draw, int offset,
}
/* the last blank bit */
/*if (x1 <= x+w-3)
- rectfill(gui_bitmap, x1, y1, x+w-3, y1+alfont_text_height(gui_font)-1, deselect);*/
+ rectfill(gui_bitmap, x1, y1, x+w-3, y1+alfont_text_height(font)-1, deselect);*/
/* print the line end */
- y1 += alfont_text_height(gui_font);
+ y1 += text_height(font);
}
printed = scanned;
@@ -1385,12 +1379,12 @@ void _gui_draw_textbox(char *thetext, int *listsize, int draw, int offset,
/* tell how many lines we found */
*listsize = line;
- alfont_text_mode(rtm);
+ text_mode(rtm);
return;
}
}
- alfont_text_mode(rtm);
+ text_mode(rtm);
}
int tmw_textbox_proc(int msg, DIALOG *d, int c) {
@@ -1400,7 +1394,7 @@ int tmw_textbox_proc(int msg, DIALOG *d, int c) {
int fg_color = (d->flags & D_DISABLED) ? gui_mg_color : d->fg;
/* calculate the actual height */
- height = (d->h-8) / alfont_text_height(gui_font);
+ height = (d->h-8) / text_height(font);
switch (msg) {
@@ -1447,7 +1441,7 @@ int tmw_textbox_proc(int msg, DIALOG *d, int c) {
/* figure out if it's on the text or the scrollbar */
bar = (d->d1 > height);
- if ((!bar) || (gui_mouse_x() < d->x+d->w-13)) /* clicked on the text area */
+ if ((!bar) || (gui_mouse_x() < d->x+d->w-13)) /* clicked on the text area */
ret = D_O_K;
else /* clicked on the scroll area */
//_handle_scrollable_scroll_click(d, d->d1, &d->d2, height);
@@ -1463,7 +1457,7 @@ int tmw_textbox_proc(int msg, DIALOG *d, int c) {
else
top = 0;
- l = (d->h-8)/alfont_text_height(gui_font);
+ l = (d->h-8)/text_height(font);
bottom = d->d2 + l - 1;
if (bottom >= d->d1-1)
@@ -1503,7 +1497,7 @@ int tmw_textbox_proc(int msg, DIALOG *d, int c) {
break;
case MSG_WHEEL:
- l = (d->h-8)/alfont_text_height(gui_font);
+ l = (d->h-8)/text_height(font);
delta = (l > 3) ? 3 : 1;
/* scroll, making sure that the list stays in bounds */
@@ -1550,10 +1544,10 @@ DIALOG alert_dialog[] = {
BITMAP *temp = gui_bitmap;
gui_bitmap = screen;
show_mouse(screen);
- alert_dialog[0].w = alfont_text_length(gui_font, message)+4;
- alert_dialog[1].w = alfont_text_length(gui_font, message);
- alert_dialog[1].h = alfont_text_height(gui_font);
- alert_dialog[2].x = alfont_text_length(gui_font, message)/2-22;
+ alert_dialog[0].w = text_length(font, message)+4;
+ alert_dialog[1].w = text_length(font, message);
+ alert_dialog[1].h = text_height(font);
+ alert_dialog[2].x = text_length(font, message)/2-22;
position_dialog(alert_dialog, 400-alert_dialog[0].w/2, 270);
do_dialog(alert_dialog, 2);
show_mouse(NULL);
@@ -1573,11 +1567,11 @@ unsigned int yes_no(const char *title, const char *message) {
BITMAP *temp = gui_bitmap;
gui_bitmap = screen;
show_mouse(screen);
- int width = alfont_text_length(gui_font, message)+4;
+ int width = text_length(font, message)+4;
if(width<100)width=100;
alert_dialog[0].w = width;
- alert_dialog[1].w = alfont_text_length(gui_font, message);
- alert_dialog[1].h = alfont_text_height(gui_font);
+ alert_dialog[1].w = text_length(font, message);
+ alert_dialog[1].h = text_height(font);
alert_dialog[2].x = width/2-46;
alert_dialog[2].x = width/2+2;
position_dialog(alert_dialog, 400-width/2, 270);