X-Git-Url: http://git.mutantstargoat.com?a=blobdiff_plain;f=src%2Fmain.cc;h=f87b011559856e035e5d1af181e7be5bc0c57eeb;hb=8f628fa4e4af94adca4db9c6cc41cf016e0c3677;hp=6697506ab77e96040cf86e0c18d01bf295b53973;hpb=b73087b9c4e30e034bb1690c492f4c9798e0d09b;p=winnie diff --git a/src/main.cc b/src/main.cc index 6697506..f87b011 100644 --- a/src/main.cc +++ b/src/main.cc @@ -5,6 +5,8 @@ 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() @@ -18,6 +20,8 @@ int main() 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); @@ -29,10 +33,10 @@ int main() static void display(Window *win) { if(wm->get_focused_window() != win) { - fill_rect(win->get_rect(), 106, 106, 250); + fill_rect(win->get_absolute_rect(), 106, 106, 250); } else { - fill_rect(win->get_rect(), 0, 0, 255); + fill_rect(win->get_absolute_rect(), 0, 0, 255); } } @@ -44,6 +48,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();