diff options
Diffstat (limited to 'src/platform')
| -rw-r--r-- | src/platform/graphics/cairo/CairoPainter.cpp | 8 | ||||
| -rw-r--r-- | src/platform/gui/sdl/OpenGLRenderer.cpp | 20 |
2 files changed, 17 insertions, 11 deletions
diff --git a/src/platform/graphics/cairo/CairoPainter.cpp b/src/platform/graphics/cairo/CairoPainter.cpp index 30162506..c71d9359 100644 --- a/src/platform/graphics/cairo/CairoPainter.cpp +++ b/src/platform/graphics/cairo/CairoPainter.cpp @@ -1,5 +1,4 @@ #include "cru/platform/graphics/cairo/CairoPainter.h" -#include "cru/base/log/Logger.h" #include "cru/platform/graphics/cairo/Base.h" #include "cru/platform/graphics/cairo/CairoBrush.h" #include "cru/platform/graphics/cairo/CairoGeometry.h" @@ -236,22 +235,15 @@ void CairoPainter::PopState() { void CairoPainter::EndDraw() { if (cairo_surface_ != nullptr) { - CruLogDebug(kLogTag, "Flush cairo painter."); cairo_surface_flush(cairo_surface_); cairo_device_t* device = cairo_surface_get_device(cairo_surface_); if (device) { cairo_device_flush(device); } - - if (end_draw_callback_) end_draw_callback_(); } valid_ = false; } -void CairoPainter::SetEndDrawCallback(std::function<void()> action) { - end_draw_callback_ = std::move(action); -} - void CairoPainter::CheckValidation() { if (!valid_) { throw ReuseException("Painter already ended drawing."); diff --git a/src/platform/gui/sdl/OpenGLRenderer.cpp b/src/platform/gui/sdl/OpenGLRenderer.cpp index 78eb578e..dbd59db2 100644 --- a/src/platform/gui/sdl/OpenGLRenderer.cpp +++ b/src/platform/gui/sdl/OpenGLRenderer.cpp @@ -38,6 +38,21 @@ void main() { FragColor = texture(ourTexture, TexCoord); })"; + +class SdlOpenGLCairoRendererPainter : public graphics::cairo::CairoPainter { + public: + SdlOpenGLCairoRendererPainter(cairo_t* cairo, cairo_surface_t* surface, + SdlOpenGLRenderer* renderer) + : CairoPainter(nullptr, cairo, false, surface), renderer_(renderer) {} + + void EndDraw() override { + CairoPainter::EndDraw(); + renderer_->Present(); + } + + private: + SdlOpenGLRenderer* renderer_; +}; } // namespace SdlOpenGLRenderer::SdlOpenGLRenderer(SdlWindow* window, int width, int height) { @@ -166,9 +181,8 @@ std::unique_ptr<graphics::IPainter> SdlOpenGLRenderer::BeginPaint() { assert(cairo_surface_); assert(gl_texture_); - auto painter = std::make_unique<graphics::cairo::CairoPainter>( - nullptr, cairo_, false, cairo_surface_); - painter->SetEndDrawCallback([this] { Present(); }); + auto painter = std::make_unique<SdlOpenGLCairoRendererPainter>( + cairo_, cairo_surface_, this); return painter; } |
