diff options
author | Marvin Borner | 2020-08-25 23:37:09 +0200 |
---|---|---|
committer | Marvin Borner | 2020-08-25 23:37:09 +0200 |
commit | 2b26af8325b9492948cb7fe516638537e4e58337 (patch) | |
tree | 6640f28efa106fa682dd5578ac70633039a682a0 /libgui | |
parent | ec5c4a7398fcfcfb5a809292cbe029b1bb69a320 (diff) |
Some GUI things
Diffstat (limited to 'libgui')
-rw-r--r-- | libgui/gui.c | 86 | ||||
-rw-r--r-- | libgui/inc/gui.h | 10 | ||||
-rw-r--r-- | libgui/psf.c | 2 |
3 files changed, 58 insertions, 40 deletions
diff --git a/libgui/gui.c b/libgui/gui.c index 0759df6..331c940 100644 --- a/libgui/gui.c +++ b/libgui/gui.c @@ -12,12 +12,12 @@ struct font *font; -void gui_write_char(struct vbe *vbe, int x, int y, const u32 c[3], char ch) +static void write_char(struct window *win, int x, int y, const u32 c[3], char ch) { - int bypp = vbe->bpp >> 3; + int bypp = win->bpp >> 3; - int pos = x * bypp + y * vbe->pitch; - char *draw = (char *)&vbe->fb[pos]; + int pos = x * bypp + y * win->pitch; + char *draw = (char *)&win->fb[pos]; u32 stride = font->char_size / font->height; for (int cy = 0; cy < font->height; cy++) { @@ -30,15 +30,38 @@ void gui_write_char(struct vbe *vbe, int x, int y, const u32 c[3], char ch) draw[bypp * cx + 2] = c[0]; } } - draw += vbe->pitch; + draw += win->pitch; + } +} + +static void draw_rectangle(struct window *win, int x1, int y1, int x2, int y2, const u32 c[3]) +{ + int bypp = win->bpp >> 3; + + int pos1 = x1 * bypp + y1 * win->pitch; + u8 *draw = &win->fb[pos1]; + for (int i = 0; i < y2 - y1; i++) { + for (int j = 0; j < x2 - x1; j++) { + draw[bypp * j] = c[2]; + draw[bypp * j + 1] = c[1]; + draw[bypp * j + 2] = c[0]; + } + draw += win->pitch; } } -void gui_write(struct vbe *vbe, int x, int y, const u32 c[3], char *text) +void gui_write_char(struct window *win, int x, int y, const u32 c[3], char ch) +{ + write_char(win, x, y, c, ch); + gui_redraw(); +} + +void gui_write(struct window *win, int x, int y, const u32 c[3], char *text) { for (u32 i = 0; i < strlen(text); i++) { - gui_write_char(vbe, x + i * font->width, y, c, text[i]); + write_char(win, x + i * font->width, y, c, text[i]); } + gui_redraw(); } void gui_load_image(struct window *win, char *path, int x, int y) @@ -60,6 +83,7 @@ void gui_load_image(struct window *win, char *path, int x, int y) srcfb += bmp->pitch; destfb += win->pitch; } + gui_redraw(); } void gui_load_wallpaper(struct window *win, char *path) @@ -70,18 +94,17 @@ void gui_load_wallpaper(struct window *win, char *path) // TODO: Optimize! void gui_win_on_win(struct window *dest, struct window *src, int x, int y) { - // Optimization? - /* if (src->width == dest->width && src->height == dest->height && src->x == 0 && */ - /* dest->y == 0) { */ - /* memcpy(dest->fb, src->fb, dest->pitch * dest->height); */ - /* return; */ - /* } */ + if (src->width == dest->width && src->height == dest->height && src->x == 0 && + dest->y == 0) { + memcpy(dest->fb, src->fb, dest->pitch * dest->height); + return; + } int bypp = dest->bpp >> 3; u8 *srcfb = src->fb; u8 *destfb = &dest->fb[x * bypp + y * dest->pitch]; - for (u32 cy = 0; cy < src->height - 1; cy++) { - for (u32 cx = 0; cx < src->width - 1; cx++) { + for (u32 cy = 0; cy < src->height; cy++) { + for (u32 cx = 0; cx < src->width; cx++) { destfb[bypp * cx + 0] = srcfb[bypp * cx + 0]; destfb[bypp * cx + 1] = srcfb[bypp * cx + 1]; destfb[bypp * cx + 2] = srcfb[bypp * cx + 2]; @@ -91,28 +114,19 @@ void gui_win_on_win(struct window *dest, struct window *src, int x, int y) } } -void gui_draw_rectangle(struct window *win, int x1, int y1, int x2, int y2, const u32 color[3]) +void gui_draw_rectangle(struct window *win, int x1, int y1, int x2, int y2, const u32 c[3]) { - int bypp = win->bpp >> 3; - - int pos1 = x1 * bypp + y1 * win->pitch; - u8 *draw = &win->fb[pos1]; - for (int i = 0; i < y2 - y1; i++) { - for (int j = 0; j < x2 - x1; j++) { - draw[bypp * j] = color[2]; - draw[bypp * j + 1] = color[1]; - draw[bypp * j + 2] = color[0]; - } - draw += win->pitch; - } + draw_rectangle(win, x1, y1, x2, y2, c); + gui_redraw(); } -void gui_fill(struct window *win, const u32 color[3]) +void gui_fill(struct window *win, const u32 c[3]) { - gui_draw_rectangle(win, 0, 0, win->width - 1, win->height - 1, color); + draw_rectangle(win, 0, 0, win->width, win->height, c); + gui_redraw(); } -void gui_border(struct window *win, const u32 color[3], u32 width) +void gui_border(struct window *win, const u32 c[3], u32 width) { if (width <= 0) return; @@ -123,17 +137,19 @@ void gui_border(struct window *win, const u32 color[3], u32 width) for (u32 j = 0; j < win->width; j++) { if (j <= width - 1 || i <= width - 1 || j - win->width + width + 1 <= width || - i - win->height + width + 1 <= width) { - draw[bypp * j + 0] = color[2]; - draw[bypp * j + 1] = color[1]; - draw[bypp * j + 2] = color[0]; + i - win->height + width <= width) { + draw[bypp * j + 0] = c[2]; + draw[bypp * j + 1] = c[1]; + draw[bypp * j + 2] = c[0]; } } draw += win->pitch; } + gui_redraw(); } void gui_init(char *font_path) { font = psf_parse(read(font_path)); + assert(font); } diff --git a/libgui/inc/gui.h b/libgui/inc/gui.h index e0cffdf..e228772 100644 --- a/libgui/inc/gui.h +++ b/libgui/inc/gui.h @@ -26,11 +26,13 @@ struct window { u32 pitch; }; +void gui_write_char(struct window *win, int x, int y, const u32 c[3], char ch); +void gui_write(struct window *win, int x, int y, const u32 c[3], char *text); void gui_load_wallpaper(struct window *win, char *path); void gui_win_on_win(struct window *dest, struct window *src, int x, int y); -void gui_draw_rectangle(struct window *win, int x1, int y1, int x2, int y2, const u32 color[3]); -void gui_fill(struct window *win, const u32 color[3]); -void gui_border(struct window *win, const u32 color[3], u32 width); +void gui_draw_rectangle(struct window *win, int x1, int y1, int x2, int y2, const u32 c[3]); +void gui_fill(struct window *win, const u32 c[3]); +void gui_border(struct window *win, const u32 c[3], u32 width); void gui_init(char *font_path); /** @@ -39,5 +41,5 @@ void gui_init(char *font_path); #define gui_new_window() \ (msg_send(2, MSG_NEW_WINDOW, NULL), (struct window *)msg_receive_loop()->data) - +#define gui_redraw() (msg_send(2, MSG_REDRAW, NULL)) // TODO: Partial redraw (optimisation) #endif diff --git a/libgui/psf.c b/libgui/psf.c index 56c673b..dbbf032 100644 --- a/libgui/psf.c +++ b/libgui/psf.c @@ -44,7 +44,7 @@ struct font *psf_parse(char *data) char_size = ((struct psf2_header *)data)->char_size; } else { print("Unknown font!\n"); - return 0; + return NULL; } struct font *font = malloc(sizeof(*font)); |