diff options
author | Marvin Borner | 2020-08-16 00:44:53 +0200 |
---|---|---|
committer | Marvin Borner | 2020-08-16 00:44:53 +0200 |
commit | c4a0bc2571162ad83fc51eb823f1c535336041bf (patch) | |
tree | cba1169a027fea8884e882be601bf3cbaeaab654 /libgui/gui.c | |
parent | 9a827eb5f6ff58bf801bc98bcb653876428ebe69 (diff) |
Added psf/gui to libgui
...and some other things
Diffstat (limited to 'libgui/gui.c')
-rw-r--r-- | libgui/gui.c | 70 |
1 files changed, 70 insertions, 0 deletions
diff --git a/libgui/gui.c b/libgui/gui.c new file mode 100644 index 0000000..460cf07 --- /dev/null +++ b/libgui/gui.c @@ -0,0 +1,70 @@ +// MIT License, Copyright (c) 2020 Marvin Borner +// Some GUI functions + +#include <gui.h> +#include <psf.h> +#include <str.h> +#include <sys.h> +#include <vesa.h> + +struct font *font; + +void gui_write_char(struct vbe *vbe, int x, int y, const u32 c[3], char ch) +{ + int bpl = vbe->bpp >> 3; + + int pos = x * bpl + y * vbe->pitch; + char *draw = (char *)&vbe->fb[pos]; + + u32 stride = font->char_size / font->height; + for (int cy = 0; cy < font->height; cy++) { + for (int cx = 0; cx < font->width; cx++) { + u8 bits = font->chars[ch * font->char_size + cy * stride + cx / 8]; + u8 bit = bits >> (7 - cx % 8) & 1; + if (bit) { + draw[bpl * cx] = c[2]; + draw[bpl * cx + 1] = c[1]; + draw[bpl * cx + 2] = c[0]; + } + } + draw += vbe->pitch; + } +} + +void gui_write(struct vbe *vbe, 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]); + } +} + +// Abstraction +int x, y = 0; +const u32 c[3] = { 0xff, 0xff, 0xff }; +void gui_term_write_char(struct vbe *vbe, char ch) +{ + if (x + font->width > vbe->width) { + x = 0; + y += font->height; + } + + if (ch >= ' ' && ch <= '~') { + gui_write_char(vbe, x, y, c, ch); + x += font->width; + } else if (ch == '\n') { + x = 0; + y += font->height; + } +} + +void gui_term_write(struct vbe *vbe, char *text) +{ + for (u32 i = 0; i < strlen(text); i++) { + gui_term_write_char(vbe, text[i]); + } +} + +void gui_init(char *font_path) +{ + font = psf_parse(read(font_path)); +} |