X-Git-Url: http://git.tdb.fi/?a=blobdiff_plain;f=source%2Fgraphics%2Fwindow.h;h=a6fb92b4e8e1eb4db2f0cf46004a3a93cf92d1f6;hb=a6eecc5117d91534aaf13e93baf64855f4b963c0;hp=b2c7833c1db844957b09d39df9b1cbe6876dbdb5;hpb=05db7bfc90b3a3806080f34e463c57b9b3d87d31;p=libs%2Fgui.git diff --git a/source/graphics/window.h b/source/graphics/window.h index b2c7833..a6fb92b 100644 --- a/source/graphics/window.h +++ b/source/graphics/window.h @@ -3,23 +3,28 @@ #include #include +#include "mspgui_api.h" namespace Msp { namespace Graphics { class Display; +struct Monitor; struct WindowOptions { - unsigned width; - unsigned height; - bool fullscreen; - bool resizable; - - WindowOptions(); + int x = 0; + int y = 0; + bool user_position = false; + unsigned width = 640; + unsigned height = 480; + bool fullscreen = false; + const Monitor *fullscreen_monitor = nullptr; + bool fullscreen_exclusive = true; + bool resizable = false; }; -class Window +class MSPGUI_API Window { public: struct Private; @@ -30,6 +35,10 @@ public: objects instead. */ sigc::signal signal_input_event; + sigc::signal signal_got_focus; + sigc::signal signal_lost_focus; + + sigc::signal signal_move; sigc::signal signal_resize; sigc::signal signal_expose; sigc::signal signal_close; @@ -37,11 +46,12 @@ public: protected: Display &display; WindowOptions options; - bool visible; - bool kbd_autorepeat; - bool touch_input; - bool resizing; - Private *priv; + bool visible = false; + bool kbd_autorepeat = true; + bool touch_input = false; + bool resizing = false; + bool moving = false; + Private *priv = nullptr; public: Window(Display &, unsigned w, unsigned h, bool fs = false); @@ -51,11 +61,12 @@ private: void platform_init(); void platform_cleanup(); public: - virtual ~Window(); + ~Window(); void set_title(const std::string &); void reconfigure(const WindowOptions &); private: + void set_fullscreen_mode(); void platform_reconfigure(bool); public: void set_keyboard_autorepeat(bool); @@ -70,8 +81,8 @@ public: Display &get_display() const { return display; } const WindowOptions &get_options() const { return options; } - virtual unsigned get_width() const { return options.width; } - virtual unsigned get_height() const { return options.height; } + unsigned get_width() const { return options.width; } + unsigned get_height() const { return options.height; } const Private &get_private() const { return *priv; } void show();