From 6a5d5b204569fc6abe6cb5a8ac338350eb5e923d Mon Sep 17 00:00:00 2001 From: Claudius 'keldu' Holeksa Date: Tue, 6 Aug 2024 16:13:50 +0200 Subject: Fixed xcb windows --- modules/window/SConstruct | 5 ++- modules/window/c++/xcb.cpp | 56 +++++++++++++++++++++++++++---- modules/window/c++/xcb.hpp | 6 ++-- modules/window/examples/window_create.cpp | 50 +++++++++++++++++++++++++++ 4 files changed, 107 insertions(+), 10 deletions(-) (limited to 'modules') diff --git a/modules/window/SConstruct b/modules/window/SConstruct index 3017baf..23a5195 100644 --- a/modules/window/SConstruct +++ b/modules/window/SConstruct @@ -46,7 +46,7 @@ env_vars.Add('prefix', env_vars.Add( BoolVariable('build_examples', help='Build examples', - default=False + default=True ) ); @@ -59,6 +59,9 @@ env=Environment(ENV=os.environ, variables=env_vars, CPPPATH=[], ,'forstio-io' ,'forstio-async' ,'forstio-codec' + ,'libX11' + ,'libxcb' + ,'libX11-xcb' ] ); diff --git a/modules/window/c++/xcb.cpp b/modules/window/c++/xcb.cpp index e90fa5a..9d4ae58 100644 --- a/modules/window/c++/xcb.cpp +++ b/modules/window/c++/xcb.cpp @@ -261,25 +261,69 @@ void window::resize(uint64_t w, uint64_t h){ conveyor> window::on_event() { auto caf = new_conveyor_and_feeder>(); - event_feeder = std::move(caf.feeder); + event_feeder_ = std::move(caf.feeder); return std::move(caf.conveyor); } void window::resize_event(uint64_t x, uint64_t y, uint64_t width, uint64_t height){ - /// @todo implement - assert(false); + video_mode_.width = width; + video_mode_.height = height; + + if(event_feeder_) { + /// @TODO implement + assert(false); + } } void window::mouse_event(int16_t x, int16_t y, uint16_t state, bool pressed){ - /// @todo implement + if(x < 0 || y < 0){ + return; + } + + uint32_t ux = static_cast(x); + uint32_t uy = static_cast(y); + + if( ux >= video_mode_.width || uy >= video_mode_.height){ + return; + } + + if(event_feeder_){ + /// @TODO implement assert(false); + } } + void window::mouse_move_event(int16_t x, int16_t y){ - /// @todo implement + if(x < 0 || y < 0){ + return; + } + uint32_t ux = static_cast(x); + uint32_t uy = static_cast(y); + + if( ux >= video_mode_.width || uy >= video_mode_.height){ + return; + } + + if(event_feeder_){ + /// @TODO implement assert(false); + } } + void window::keyboard_event(int16_t x, int16_t y, uint32_t keycode, bool pressed, bool repeat){ - /// @todo implement + if(x < 0 || y < 0){ + return; + } + uint32_t ux = static_cast(x); + uint32_t uy = static_cast(y); + + if( ux >= video_mode_.width || uy >= video_mode_.height){ + return; + } + + if(event_feeder_){ + /// @TODO implement assert(false); + } } xcb_window_t window::get_xcb_window_handle() const{ diff --git a/modules/window/c++/xcb.hpp b/modules/window/c++/xcb.hpp index 1694923..2f84133 100644 --- a/modules/window/c++/xcb.hpp +++ b/modules/window/c++/xcb.hpp @@ -10,8 +10,8 @@ #include -#include -#include +#include +#include namespace saw { namespace gfx { @@ -76,7 +76,7 @@ private: video_mode video_mode_; std::string window_title_; - own>> event_feeder = nullptr; + own>> event_feeder_ = nullptr; public: window(device& dev_, xcb_window_t xcb_win, xcb_colormap_t xcb_colormap_, const video_mode& vid_mode_, const std::string_view& title_view_); diff --git a/modules/window/examples/window_create.cpp b/modules/window/examples/window_create.cpp index dde8295..3517dae 100644 --- a/modules/window/examples/window_create.cpp +++ b/modules/window/examples/window_create.cpp @@ -1,4 +1,54 @@ +#include "../c++/window.hpp" + +#include + int main(){ + auto eo_aio = saw::setup_async_io(); + if(eo_aio.is_error()){ + auto& err = eo_aio.get_error(); + std::cerr<<"Error: "< 0u){ + std::cerr<<" - "< 0u){ + std::cerr<<" - "<create_window({}, "foo"); + if(!window){ + return 42; + } + window->show(); + + bool running = true; + + aio.event_port.on_signal(saw::Signal::Terminate).then([&running](){ + running = false; + }).detach(); + while(running){ + device->flush(); + wait.wait(std::chrono::seconds{1u}); + } return 0; } -- cgit v1.2.3