X-Git-Url: http://git.mutantstargoat.com?a=blobdiff_plain;f=src%2Fmain.cc;h=ab82aa2ee60a5e35950ee2480bf92301376fcc24;hb=c4ab1fa2768863098306862047bdb1116bd62a24;hp=b4f5f3a1fb8fc4a5cf4fbfda5ed988eed198a336;hpb=0860ce537422597075fbc63ddcc9a73303362a93;p=winnie diff --git a/src/main.cc b/src/main.cc index b4f5f3a..ab82aa2 100644 --- a/src/main.cc +++ b/src/main.cc @@ -1,41 +1,67 @@ #include +#include -#include "gfx.h" +#include "winnie.h" + +static void display(Window *win); +static void keyboard(Window *win, int key, bool pressed); +static void button(Window *win, int bn, bool pressed, int x, int y); +static void motion(Window *win, int x, int y); +static void cleanup(); int main() { - if(!init_gfx()) { - return 1; + if(!winnie_init()) { + exit(1); + } + + atexit(cleanup); + + Window *win1 = new Window; + win1->set_title("title1"); + win1->move(5, 10); + win1->resize(200, 300); + win1->set_display_callback(display); + win1->set_keyboard_callback(keyboard); + win1->set_mouse_button_callback(button); + win1->set_mouse_motion_callback(motion); + + wm->add_window(win1); + + while(1) { + process_events(); + } +} + +static void display(Window *win) +{ + if(wm->get_focused_window() != win) { + fill_rect(win->get_absolute_rect(), 106, 106, 250); } + else { + fill_rect(win->get_absolute_rect(), 0, 0, 255); + } +} - set_cursor_visibility(false); - - unsigned char* fb = get_framebuffer(); - Rect scrn_sz = get_screen_size(); - - for(int i=0; i> 4) & 1) == ((i >> 4) & 1)) { - color = color0; - } - else { - color = color1; - } - - *fb++ = color[0]; - *fb++ = color[1]; - *fb++ = color[2]; - fb++; - } +static void keyboard(Window *win, int key, bool pressed) +{ + switch(key) { + case 'q': + exit(0); } +} + +static void button(Window *win, int bn, bool pressed, int x, int y) +{ + printf("WINDOW(%p) button %d %s\n", (void*)win, bn, pressed ? "press" : "release"); +} - getchar(); - clear_screen(0, 0, 0); +static void motion(Window *win, int x, int y) +{ + printf("WINDOW(%p) motion %d %d\n", (void*)win, x, y); +} - destroy_gfx(); +static void cleanup() +{ + winnie_shutdown(); }