diff --git a/src/Compositor.cpp b/src/Compositor.cpp index 7ccc6ce82..e4ea9fc11 100644 --- a/src/Compositor.cpp +++ b/src/Compositor.cpp @@ -177,6 +177,17 @@ SMonitor* CCompositor::getMonitorFromCursor() { return &m_lMonitors.front(); } +SMonitor* CCompositor::getMonitorFromVector(const Vector2D& point) { + const auto OUTPUT = wlr_output_layout_output_at(m_sWLROutputLayout, point.x, point.y); + + if (!OUTPUT) { + Debug::log(WARN, "getMonitorFromVector: vector outside monitors??"); + return nullptr; + } + + return getMonitorFromOutput(OUTPUT); +} + void CCompositor::removeWindowFromVectorSafe(CWindow* pWindow) { if (windowExists(pWindow)) m_lWindows.remove(*pWindow); @@ -195,7 +206,7 @@ CWindow* CCompositor::vectorToWindow(const Vector2D& pos) { const auto PMONITOR = getMonitorFromCursor(); for (auto& w : m_lWindows) { wlr_box box = {w.m_vRealPosition.x, w.m_vRealPosition.y, w.m_vRealSize.x, w.m_vRealSize.y}; - if (w.m_iMonitorID == PMONITOR->ID && wlr_box_contains_point(&box, pos.x, pos.y)) + if (wlr_box_contains_point(&box, pos.x, pos.y)) // TODO: workspaces return &w; } @@ -208,13 +219,13 @@ CWindow* CCompositor::vectorToWindowIdeal(const Vector2D& pos) { // TODO: make an actual Z-system for (auto& w : m_lWindows) { wlr_box box = {w.m_vRealPosition.x, w.m_vRealPosition.y, w.m_vRealSize.x, w.m_vRealSize.y}; - if (w.m_iMonitorID == PMONITOR->ID && wlr_box_contains_point(&box, m_sWLRCursor->x, m_sWLRCursor->y) && w.m_bIsFloating) + if (wlr_box_contains_point(&box, m_sWLRCursor->x, m_sWLRCursor->y) && w.m_bIsFloating) // TODO: workspaces return &w; } for (auto& w : m_lWindows) { wlr_box box = {w.m_vPosition.x, w.m_vPosition.y, w.m_vSize.x, w.m_vSize.y}; - if (w.m_iMonitorID == PMONITOR->ID && wlr_box_contains_point(&box, pos.x, pos.y)) + if (wlr_box_contains_point(&box, pos.x, pos.y)) // TODO: workspaces return &w; } @@ -228,13 +239,13 @@ CWindow* CCompositor::windowFromCursor() { // TODO: make an actual Z-system for (auto& w : m_lWindows) { wlr_box box = {w.m_vRealPosition.x, w.m_vRealPosition.y, w.m_vRealSize.x, w.m_vRealSize.y}; - if (w.m_iMonitorID == PMONITOR->ID && wlr_box_contains_point(&box, m_sWLRCursor->x, m_sWLRCursor->y) && w.m_bIsFloating) + if (wlr_box_contains_point(&box, m_sWLRCursor->x, m_sWLRCursor->y) && w.m_bIsFloating) // TODO: workspaces return &w; } for (auto& w : m_lWindows) { wlr_box box = {w.m_vPosition.x, w.m_vPosition.y, w.m_vSize.x, w.m_vSize.y}; - if (w.m_iMonitorID == PMONITOR->ID && wlr_box_contains_point(&box, m_sWLRCursor->x, m_sWLRCursor->y)) + if (wlr_box_contains_point(&box, m_sWLRCursor->x, m_sWLRCursor->y)) // TODO: workspaces return &w; } @@ -245,7 +256,7 @@ CWindow* CCompositor::windowFloatingFromCursor() { const auto PMONITOR = getMonitorFromCursor(); for (auto& w : m_lWindows) { wlr_box box = {w.m_vRealPosition.x, w.m_vRealPosition.y, w.m_vRealSize.x, w.m_vRealSize.y}; - if (w.m_iMonitorID == PMONITOR->ID && wlr_box_contains_point(&box, m_sWLRCursor->x, m_sWLRCursor->y) && w.m_bIsFloating) + if (wlr_box_contains_point(&box, m_sWLRCursor->x, m_sWLRCursor->y) && w.m_bIsFloating) // TODO: workspaces return &w; } diff --git a/src/Compositor.hpp b/src/Compositor.hpp index 42046990a..92280ea67 100644 --- a/src/Compositor.hpp +++ b/src/Compositor.hpp @@ -59,6 +59,7 @@ public: SMonitor* getMonitorFromID(const int&); SMonitor* getMonitorFromCursor(); + SMonitor* getMonitorFromVector(const Vector2D&); void removeWindowFromVectorSafe(CWindow*); void focusWindow(CWindow*); bool windowExists(CWindow*); diff --git a/src/layout/DwindleLayout.cpp b/src/layout/DwindleLayout.cpp index 2b69e2d9a..129c21423 100644 --- a/src/layout/DwindleLayout.cpp +++ b/src/layout/DwindleLayout.cpp @@ -294,4 +294,13 @@ void CHyprDwindleLayout::onMouseMove(const Vector2D& mousePos) { g_pXWaylandManager->setWindowSize(DRAGGINGWINDOW, DRAGGINGWINDOW->m_vRealSize); } + + // get middle point + Vector2D middle = DRAGGINGWINDOW->m_vRealPosition + DRAGGINGWINDOW->m_vRealSize / 2.f; + + // and check its monitor + const auto PMONITOR = g_pCompositor->getMonitorFromVector(middle); + + if (PMONITOR) + DRAGGINGWINDOW->m_iMonitorID = PMONITOR->ID; } \ No newline at end of file