From 18e330f9f4a673da78e6503c697619ad99b4bdbf Mon Sep 17 00:00:00 2001 From: Yuqian Yang Date: Wed, 10 Sep 2025 01:01:47 +0800 Subject: xcb window painter. --- include/cru/platform/gui/xcb/UiApplication.h | 9 ++++++++- include/cru/platform/gui/xcb/Window.h | 5 +++-- 2 files changed, 11 insertions(+), 3 deletions(-) (limited to 'include/cru/platform/gui') diff --git a/include/cru/platform/gui/xcb/UiApplication.h b/include/cru/platform/gui/xcb/UiApplication.h index 3fce8efa..2a9ea517 100644 --- a/include/cru/platform/gui/xcb/UiApplication.h +++ b/include/cru/platform/gui/xcb/UiApplication.h @@ -3,6 +3,7 @@ #include "Base.h" #include +#include #include #include @@ -14,10 +15,13 @@ class XcbUiApplication : public XcbResource, public virtual IUiApplication { friend XcbWindow; public: - XcbUiApplication(); + explicit XcbUiApplication( + graphics::cairo::CairoGraphicsFactory* cairo_factory = nullptr); ~XcbUiApplication(); public: + graphics::cairo::CairoGraphicsFactory* GetCairoFactory(); + void CheckXcbConnectionError(); xcb_connection_t* GetXcbConnection(); @@ -72,6 +76,9 @@ class XcbUiApplication : public XcbResource, public virtual IUiApplication { void UnregisterWindow(XcbWindow* window); private: + graphics::cairo::CairoGraphicsFactory* cairo_factory_; + bool release_cairo_factory_; + xcb_connection_t* xcb_connection_; xcb_screen_t* screen_; 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 #include #include #include @@ -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 BeginPaint() = 0; + std::unique_ptr BeginPaint() override; IEvent* CreateEvent() override; IEvent* DestroyEvent() override; @@ -91,6 +91,7 @@ class XcbWindow : public XcbResource, public virtual INativeWindow { private: XcbUiApplication* application_; std::optional xcb_window_; + cairo_surface_t *cairo_surface_; Size current_size_; Event create_event_; -- cgit v1.2.3