Window.h 9.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276
  1. /*
  2. * Copyright (c) 2018-2021, Andreas Kling <kling@serenityos.org>
  3. *
  4. * SPDX-License-Identifier: BSD-2-Clause
  5. */
  6. #pragma once
  7. #include <AK/Function.h>
  8. #include <AK/String.h>
  9. #include <AK/WeakPtr.h>
  10. #include <LibCore/Object.h>
  11. #include <LibGUI/FocusSource.h>
  12. #include <LibGUI/Forward.h>
  13. #include <LibGUI/WindowType.h>
  14. #include <LibGfx/Color.h>
  15. #include <LibGfx/Forward.h>
  16. #include <LibGfx/Rect.h>
  17. #include <LibGfx/StandardCursor.h>
  18. namespace GUI {
  19. class WindowBackingStore;
  20. class Window : public Core::Object {
  21. C_OBJECT(Window)
  22. public:
  23. virtual ~Window() override;
  24. static Window* from_window_id(int);
  25. bool is_modified() const;
  26. void set_modified(bool);
  27. bool is_modal() const { return m_modal; }
  28. void set_modal(bool);
  29. bool is_fullscreen() const { return m_fullscreen; }
  30. void set_fullscreen(bool);
  31. bool is_maximized() const;
  32. bool is_frameless() const { return m_frameless; }
  33. void set_frameless(bool);
  34. bool is_resizable() const { return m_resizable; }
  35. void set_resizable(bool resizable) { m_resizable = resizable; }
  36. bool is_minimizable() const { return m_minimizable; }
  37. void set_minimizable(bool minimizable) { m_minimizable = minimizable; }
  38. void set_double_buffering_enabled(bool);
  39. void set_has_alpha_channel(bool);
  40. bool has_alpha_channel() const { return m_has_alpha_channel; }
  41. void set_opacity(float);
  42. float opacity() const { return m_opacity_when_windowless; }
  43. void set_alpha_hit_threshold(float);
  44. float alpha_hit_threshold() const { return m_alpha_hit_threshold; }
  45. WindowType window_type() const { return m_window_type; }
  46. void set_window_type(WindowType);
  47. int window_id() const { return m_window_id; }
  48. void make_window_manager(unsigned event_mask);
  49. String title() const;
  50. void set_title(String);
  51. Color background_color() const { return m_background_color; }
  52. void set_background_color(Color color) { m_background_color = color; }
  53. enum class CloseRequestDecision {
  54. StayOpen,
  55. Close,
  56. };
  57. Function<void()> on_close;
  58. Function<CloseRequestDecision()> on_close_request;
  59. Function<void(bool is_active_input)> on_active_input_change;
  60. int x() const { return rect().x(); }
  61. int y() const { return rect().y(); }
  62. int width() const { return rect().width(); }
  63. int height() const { return rect().height(); }
  64. Gfx::IntRect rect() const;
  65. Gfx::IntRect applet_rect_on_screen() const;
  66. Gfx::IntSize size() const { return rect().size(); }
  67. void set_rect(const Gfx::IntRect&);
  68. void set_rect(int x, int y, int width, int height) { set_rect({ x, y, width, height }); }
  69. Gfx::IntPoint position() const { return rect().location(); }
  70. Gfx::IntSize minimum_size() const;
  71. void set_minimum_size(const Gfx::IntSize&);
  72. void set_minimum_size(int width, int height) { set_minimum_size({ width, height }); }
  73. void move_to(int x, int y) { move_to({ x, y }); }
  74. void move_to(const Gfx::IntPoint& point) { set_rect({ point, size() }); }
  75. void resize(int width, int height) { resize({ width, height }); }
  76. void resize(const Gfx::IntSize& size) { set_rect({ position(), size }); }
  77. void center_on_screen();
  78. void center_within(const Window&);
  79. virtual void event(Core::Event&) override;
  80. bool is_visible() const;
  81. bool is_active() const;
  82. bool is_active_input() const { return m_is_active_input; }
  83. bool is_accessory() const { return m_accessory; }
  84. void set_accessory(bool accessory) { m_accessory = accessory; }
  85. void show();
  86. void hide();
  87. virtual void close();
  88. void move_to_front();
  89. void start_interactive_resize();
  90. Widget* main_widget() { return m_main_widget; }
  91. const Widget* main_widget() const { return m_main_widget; }
  92. void set_main_widget(Widget*);
  93. template<class T, class... Args>
  94. inline T& set_main_widget(Args&&... args)
  95. {
  96. auto widget = T::construct(forward<Args>(args)...);
  97. set_main_widget(widget.ptr());
  98. return *widget;
  99. }
  100. Widget* focused_widget() { return m_focused_widget; }
  101. const Widget* focused_widget() const { return m_focused_widget; }
  102. void set_focused_widget(Widget*, FocusSource = FocusSource::Programmatic);
  103. void update();
  104. void update(const Gfx::IntRect&);
  105. void set_global_cursor_tracking_widget(Widget*);
  106. Widget* global_cursor_tracking_widget() { return m_global_cursor_tracking_widget.ptr(); }
  107. const Widget* global_cursor_tracking_widget() const { return m_global_cursor_tracking_widget.ptr(); }
  108. void set_automatic_cursor_tracking_widget(Widget*);
  109. Widget* automatic_cursor_tracking_widget() { return m_automatic_cursor_tracking_widget.ptr(); }
  110. const Widget* automatic_cursor_tracking_widget() const { return m_automatic_cursor_tracking_widget.ptr(); }
  111. Widget* hovered_widget() { return m_hovered_widget.ptr(); }
  112. const Widget* hovered_widget() const { return m_hovered_widget.ptr(); }
  113. void set_hovered_widget(Widget*);
  114. Gfx::Bitmap* back_bitmap();
  115. Gfx::IntSize size_increment() const { return m_size_increment; }
  116. void set_size_increment(const Gfx::IntSize&);
  117. Gfx::IntSize base_size() const { return m_base_size; }
  118. void set_base_size(const Gfx::IntSize&);
  119. const Optional<Gfx::IntSize>& resize_aspect_ratio() const { return m_resize_aspect_ratio; }
  120. void set_resize_aspect_ratio(int width, int height) { set_resize_aspect_ratio(Gfx::IntSize(width, height)); }
  121. void set_no_resize_aspect_ratio() { set_resize_aspect_ratio({}); }
  122. void set_resize_aspect_ratio(const Optional<Gfx::IntSize>& ratio);
  123. void set_cursor(Gfx::StandardCursor);
  124. void set_cursor(const Gfx::Bitmap&);
  125. void set_icon(const Gfx::Bitmap*);
  126. void apply_icon();
  127. const Gfx::Bitmap* icon() const { return m_icon.ptr(); }
  128. Vector<Widget*> focusable_widgets(FocusSource) const;
  129. void schedule_relayout();
  130. void refresh_system_theme();
  131. static void for_each_window(Badge<WindowServerConnection>, Function<void(Window&)>);
  132. static void update_all_windows(Badge<WindowServerConnection>);
  133. void notify_state_changed(Badge<WindowServerConnection>, bool minimized, bool occluded);
  134. virtual bool is_visible_for_timer_purposes() const override { return m_visible_for_timer_purposes; }
  135. Action* action_for_key_event(const KeyEvent&);
  136. void did_add_widget(Badge<Widget>, Widget&);
  137. void did_remove_widget(Badge<Widget>, Widget&);
  138. Window* find_parent_window();
  139. void set_progress(int);
  140. void update_cursor(Badge<Widget>) { update_cursor(); }
  141. void did_disable_focused_widget(Badge<Widget>);
  142. void set_menubar(RefPtr<Menubar>);
  143. protected:
  144. Window(Core::Object* parent = nullptr);
  145. virtual void wm_event(WMEvent&);
  146. virtual void screen_rect_change_event(ScreenRectChangeEvent&);
  147. private:
  148. void update_cursor();
  149. void focus_a_widget_if_possible(FocusSource);
  150. void handle_drop_event(DropEvent&);
  151. void handle_mouse_event(MouseEvent&);
  152. void handle_multi_paint_event(MultiPaintEvent&);
  153. void handle_key_event(KeyEvent&);
  154. void handle_resize_event(ResizeEvent&);
  155. void handle_input_entered_or_left_event(Core::Event&);
  156. void handle_became_active_or_inactive_event(Core::Event&);
  157. void handle_close_request();
  158. void handle_theme_change_event(ThemeChangeEvent&);
  159. void handle_screen_rect_change_event(ScreenRectChangeEvent&);
  160. void handle_drag_move_event(DragEvent&);
  161. void handle_left_event();
  162. void server_did_destroy();
  163. OwnPtr<WindowBackingStore> create_backing_store(const Gfx::IntSize&);
  164. void set_current_backing_store(WindowBackingStore&, bool flush_immediately = false);
  165. void flip(const Vector<Gfx::IntRect, 32>& dirty_rects);
  166. void force_update();
  167. OwnPtr<WindowBackingStore> m_front_store;
  168. OwnPtr<WindowBackingStore> m_back_store;
  169. RefPtr<Menubar> m_menubar;
  170. RefPtr<Gfx::Bitmap> m_icon;
  171. RefPtr<Gfx::Bitmap> m_custom_cursor;
  172. int m_window_id { 0 };
  173. float m_opacity_when_windowless { 1.0f };
  174. float m_alpha_hit_threshold { 0.0f };
  175. RefPtr<Widget> m_main_widget;
  176. WeakPtr<Widget> m_focused_widget;
  177. WeakPtr<Widget> m_global_cursor_tracking_widget;
  178. WeakPtr<Widget> m_automatic_cursor_tracking_widget;
  179. WeakPtr<Widget> m_hovered_widget;
  180. Gfx::IntRect m_rect_when_windowless;
  181. Gfx::IntSize m_minimum_size_when_windowless { 50, 50 };
  182. bool m_minimum_size_modified { false };
  183. String m_title_when_windowless;
  184. Vector<Gfx::IntRect, 32> m_pending_paint_event_rects;
  185. Gfx::IntSize m_size_increment;
  186. Gfx::IntSize m_base_size;
  187. Color m_background_color { Color::WarmGray };
  188. WindowType m_window_type { WindowType::Normal };
  189. Gfx::StandardCursor m_cursor { Gfx::StandardCursor::None };
  190. Gfx::StandardCursor m_effective_cursor { Gfx::StandardCursor::None };
  191. bool m_is_active_input { false };
  192. bool m_has_alpha_channel { false };
  193. bool m_double_buffering_enabled { true };
  194. bool m_modal { false };
  195. bool m_resizable { true };
  196. Optional<Gfx::IntSize> m_resize_aspect_ratio {};
  197. bool m_minimizable { true };
  198. bool m_fullscreen { false };
  199. bool m_frameless { false };
  200. bool m_layout_pending { false };
  201. bool m_visible_for_timer_purposes { true };
  202. bool m_visible { false };
  203. bool m_accessory { false };
  204. bool m_moved_by_client { false };
  205. };
  206. }
  207. template<>
  208. struct AK::Formatter<GUI::Window> : Formatter<Core::Object> {
  209. };