X-Git-Url: http://git.mutantstargoat.com?a=blobdiff_plain;f=src%2Fwindow.h;h=ecbee9e2edcf0077656219ff0a83125460bc456f;hb=15e07ead145a859762b48ac9062a07cddf826151;hp=7bccd2cba295130d337651946f23480b538077f9;hpb=8a92836b3af157fd47c657cfe546887e5f5683a8;p=winnie diff --git a/src/window.h b/src/window.h index 7bccd2c..ecbee9e 100644 --- a/src/window.h +++ b/src/window.h @@ -1,22 +1,38 @@ #ifndef WINDOW_H_ #define WINDOW_H_ +#include + #include "geom.h" #include "event.h" class Window { +public: + enum State {STATE_NORMAL, STATE_MINIMIZED, STATE_MAXIMIZED, STATE_SHADED}; + private: char *title; + State state; + Rect rect; + Rect normal_rect; // normal state rectangle managed by the wm + Callbacks callbacks; + std::vector children; + Window* parent; + bool dirty; + bool managed; // whether the wm manages (+decorates) this win + bool focusable; public: Window(); ~Window(); const Rect &get_rect() const; + Rect get_absolute_rect() const; + bool contains_point(int ptr_x, int ptr_y); void move(int x, int y); void resize(int x, int y); @@ -29,16 +45,43 @@ public: */ void invalidate(); - void draw(); + void draw(Rect *dirty_region); + void draw_children(const Rect &dirty_region); unsigned char *get_win_start_on_fb(); int get_scanline_width(); + void set_managed(bool managed); + bool get_managed() const; + + void set_focusable(bool focusable); + bool get_focusable() const; + + bool get_dirty() const; + void set_display_callback(DisplayFuncType func); void set_keyboard_callback(KeyboardFuncType func); void set_mouse_button_callback(MouseButtonFuncType func); void set_mouse_motion_callback(MouseMotionFuncType func); + const DisplayFuncType get_display_callback() const; + const KeyboardFuncType get_keyboard_callback() const; + const MouseButtonFuncType get_mouse_button_callback() const; + const MouseMotionFuncType get_mouse_motion_callback() const; + + // win hierarchy + void add_child(Window *win); + void remove_child(Window *win); + + Window **get_children(); + int get_children_count() const; + + const Window *get_parent() const; + Window *get_parent(); + + void set_state(State state); + State get_state() const; + // XXX remove if not needed friend class WindowManager; };