diff options
| author | Yuqian Yang <crupest@crupest.life> | 2025-09-10 01:01:47 +0800 |
|---|---|---|
| committer | Yuqian Yang <crupest@crupest.life> | 2025-09-10 01:01:47 +0800 |
| commit | 18e330f9f4a673da78e6503c697619ad99b4bdbf (patch) | |
| tree | ed4888d836a52a69e08b40557bb18c978da2a80a /include/cru/platform/gui/xcb/Window.h | |
| parent | e8e71847dccceee038338dab4e430957639f3d63 (diff) | |
| download | cru-18e330f9f4a673da78e6503c697619ad99b4bdbf.tar.gz cru-18e330f9f4a673da78e6503c697619ad99b4bdbf.tar.bz2 cru-18e330f9f4a673da78e6503c697619ad99b4bdbf.zip | |
xcb window painter.
Diffstat (limited to 'include/cru/platform/gui/xcb/Window.h')
| -rw-r--r-- | include/cru/platform/gui/xcb/Window.h | 5 |
1 files changed, 3 insertions, 2 deletions
diff --git a/include/cru/platform/gui/xcb/Window.h b/include/cru/platform/gui/xcb/Window.h index 62351645..e09fdbfb 100644 --- a/include/cru/platform/gui/xcb/Window.h +++ b/include/cru/platform/gui/xcb/Window.h @@ -3,6 +3,7 @@ #include "../Window.h" #include "Base.h" +#include <cairo.h> #include <xcb/xcb.h> #include <cstddef> #include <optional> @@ -59,8 +60,7 @@ class XcbWindow : public XcbResource, public virtual INativeWindow { virtual void RequestRepaint() = 0; - // Remember to call EndDraw on return value and destroy it. - virtual std::unique_ptr<graphics::IPainter> BeginPaint() = 0; + std::unique_ptr<graphics::IPainter> BeginPaint() override; IEvent<std::nullptr_t>* CreateEvent() override; IEvent<std::nullptr_t>* DestroyEvent() override; @@ -91,6 +91,7 @@ class XcbWindow : public XcbResource, public virtual INativeWindow { private: XcbUiApplication* application_; std::optional<xcb_window_t> xcb_window_; + cairo_surface_t *cairo_surface_; Size current_size_; Event<std::nullptr_t> create_event_; |
