diff options
Diffstat (limited to 'apps')
-rw-r--r-- | apps/window.c | 4 | ||||
-rw-r--r-- | apps/wm.c | 31 |
2 files changed, 26 insertions, 9 deletions
diff --git a/apps/window.c b/apps/window.c index da84eff..96691fa 100644 --- a/apps/window.c +++ b/apps/window.c @@ -11,8 +11,8 @@ int main() gfx_fill(win.ctx, COLOR_GREEN); // Professional testing for (int i = 0; i < 12; i++) { - gfx_write(win.ctx, vec2(0, i * gfx_font_height(FONT_32)), FONT_32, COLOR_BLACK, - "Hallo, wie geht es Ihnen denn heute?"); + gfx_write(win.ctx, vec2(0, i * gfx_font_height(FONT_32)), FONT_32, + 0xff000000 + (i * 0xaf << i), "Hallo, wie geht es Ihnen denn heute?!"); } assert(gui_redraw_window(win.id) > 0); log("%d\n", win.ctx->size.x); @@ -11,7 +11,6 @@ #include <vesa.h> //#define FLUSH_TIMEOUT 6 -#define bypp (screen.bpp >> 3) struct client { u32 pid; @@ -33,6 +32,7 @@ struct rectangle { void *data; }; +static u8 bypp = 4; static struct vbe screen = { 0 }; static struct list *windows = NULL; // THIS LIST SHALL BE SORTED BY Z-INDEX! static struct window *direct = NULL; @@ -164,7 +164,7 @@ static struct rectangle rectangle_at(vec2 pos1, vec2 pos2, struct window *exclud u32 width = pos2.x - pos1.x; u32 height = pos2.y - pos1.y; u32 pitch = width * bypp; - void *data = zalloc(width * height * bypp); + u8 *data = zalloc(width * height * bypp); struct list *windows_at = list_new(); windows_at_rec(pos1, pos2, windows_at); @@ -177,11 +177,27 @@ static struct rectangle rectangle_at(vec2 pos1, vec2 pos2, struct window *exclud continue; vec2 pos = vec2_sub(pos1, win->pos); - u8 *srcfb = &win->ctx.fb[pos.x * bypp + pos.y * win->ctx.pitch]; - u8 *destfb = data; - for (u32 cy = 0; cy < height; cy++) { + + s32 start_x = win->pos.x - pos1.x; + u32 end_x = width; + if (start_x <= 0) { // Either right side or background + u32 right = start_x + win->ctx.size.x; + if (right <= width) { // Right side + end_x = 0; + start_x = 0; + } else { // Background + start_x = 0; + } + } + u32 start_y = 0; + + u8 *srcfb = &win->ctx.fb[(pos.x + start_x) * bypp + pos.y * win->ctx.pitch]; + u8 *destfb = &data[start_x * bypp]; + + // Copy window data to rectangle buffer + for (u32 cy = start_y; cy < height; cy++) { int diff = 0; - for (u32 cx = 0; cx < width; cx++) { + for (u32 cx = start_x; cx < end_x; cx++) { if (srcfb[bypp - 1]) memcpy(destfb, srcfb, bypp); @@ -281,7 +297,7 @@ static void handle_message_new_window(struct message *msg) return; } struct gui_window *buf = msg->data; - struct window *win = window_new((struct client){ .pid = msg->src }, "idk", vec2(100, 100), + struct window *win = window_new((struct client){ .pid = msg->src }, "idk", vec2(500, 600), vec2(600, 400), 0); buf->id = win->id; buf->ctx = &win->ctx; @@ -331,6 +347,7 @@ int main(int argc, char **argv) (void)argc; screen = *(struct vbe *)argv[1]; wm_client = (struct client){ .pid = getpid() }; + bypp = (screen.bpp >> 3); log("WM loaded: %dx%d\n", screen.width, screen.height); windows = list_new(); |