X-Git-Url: http://git.mutantstargoat.com?a=blobdiff_plain;f=src%2Fmain.cc;h=f49f68609ede7b1b34a611203701170b4fb55aeb;hb=32869d8ffb64be82541f48166c5e73a6c4336135;hp=1f4e0450f8cce17621f223c9db65c6904c7657d6;hpb=981f0eab2195d34f7c186a2e3e891810e14ce5b4;p=winnie diff --git a/src/main.cc b/src/main.cc index 1f4e045..f49f686 100644 --- a/src/main.cc +++ b/src/main.cc @@ -1,25 +1,50 @@ #include #include +#include #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() { - winnie_init(); + if(!winnie_init()) { + exit(1); + } + atexit(cleanup); Window *win1 = new Window; - win1->set_title("title1"); - win1->move(5, 10); + win1->set_title("Clipping the win title"); + win1->move(200, 100); 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); + + Window *win2 = new Window; + win2->set_title("window 2"); + win2->move(300, 100); + win2->resize(200, 300); + win2->set_display_callback(display); + win2->set_keyboard_callback(keyboard); + win2->set_mouse_button_callback(button); + win2->set_mouse_motion_callback(motion); wm->add_window(win1); + wm->add_window(win2); + + Pixmap bg; + if(!(bg.load("data/bg.ppm"))) { + fprintf(stderr, "failed to load pixmap\n"); + } + + wm->set_background(&bg); while(1) { process_events(); @@ -28,12 +53,7 @@ int main() 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); - } + fill_rect(win->get_absolute_rect(), 128, 128, 128); } static void keyboard(Window *win, int key, bool pressed) @@ -44,6 +64,16 @@ static void keyboard(Window *win, int key, bool pressed) } } +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"); +} + +static void motion(Window *win, int x, int y) +{ + printf("WINDOW(%p) motion %d %d\n", (void*)win, x, y); +} + static void cleanup() { winnie_shutdown();