#include "Workspace.hpp" #include "../Compositor.hpp" CWorkspace::CWorkspace(int monitorID, bool special) { const auto PMONITOR = g_pCompositor->getMonitorFromID(monitorID); if (!PMONITOR) { Debug::log(ERR, "Attempted a creation of CWorkspace with an invalid monitor?"); return; } m_iMonitorID = monitorID; m_bIsSpecialWorkspace = special; if (!special) { m_pWlrHandle = wlr_ext_workspace_handle_v1_create(PMONITOR->pWLRWorkspaceGroupHandle); // set geometry here cuz we can wl_array_init(&m_wlrCoordinateArr); *reinterpret_cast(wl_array_add(&m_wlrCoordinateArr, sizeof(int))) = (int)PMONITOR->vecPosition.x; *reinterpret_cast(wl_array_add(&m_wlrCoordinateArr, sizeof(int))) = (int)PMONITOR->vecPosition.y; wlr_ext_workspace_handle_v1_set_coordinates(m_pWlrHandle, &m_wlrCoordinateArr); wlr_ext_workspace_handle_v1_set_hidden(m_pWlrHandle, false); wlr_ext_workspace_handle_v1_set_urgent(m_pWlrHandle, false); } m_vRenderOffset.m_pWorkspace = this; m_vRenderOffset.create(AVARTYPE_VECTOR, &g_pConfigManager->getConfigValuePtr("animations:workspaces_speed")->floatValue, &g_pConfigManager->getConfigValuePtr("animations:workspaces")->intValue, &g_pConfigManager->getConfigValuePtr("animations:workspaces_curve")->strValue, nullptr, AVARDAMAGE_ENTIRE); m_fAlpha.m_pWorkspace = this; m_fAlpha.create(AVARTYPE_FLOAT, &g_pConfigManager->getConfigValuePtr("animations:workspaces_speed")->floatValue, &g_pConfigManager->getConfigValuePtr("animations:workspaces")->intValue, &g_pConfigManager->getConfigValuePtr("animations:workspaces_curve")->strValue, nullptr, AVARDAMAGE_ENTIRE); m_fAlpha.setValueAndWarp(255.f); } CWorkspace::~CWorkspace() { m_vRenderOffset.unregister(); Debug::log(LOG, "Destroying workspace ID %d", m_iID); if (m_pWlrHandle) { wlr_ext_workspace_handle_v1_set_active(m_pWlrHandle, false); wlr_ext_workspace_handle_v1_destroy(m_pWlrHandle); m_pWlrHandle = nullptr; } } void CWorkspace::startAnim(bool in, bool left, bool instant) { const auto ANIMSTYLE = g_pConfigManager->getString("animations:workspaces_style"); if (ANIMSTYLE == "fade") { m_vRenderOffset.setValueAndWarp(Vector2D(0, 0)); // fix a bug, if switching from slide -> fade. if (in) { m_fAlpha.setValueAndWarp(0.f); m_fAlpha = 255.f; } else { m_fAlpha.setValueAndWarp(255.f); m_fAlpha = 0.f; } } else { // fallback is slide const auto PMONITOR = g_pCompositor->getMonitorFromID(m_iMonitorID); m_fAlpha.setValueAndWarp(255.f); // fix a bug, if switching from fade -> slide. if (in) { m_vRenderOffset.setValueAndWarp(Vector2D(left ? PMONITOR->vecSize.x : -PMONITOR->vecSize.x, 0)); m_vRenderOffset = Vector2D(0, 0); } else { m_vRenderOffset = Vector2D(left ? -PMONITOR->vecSize.x : PMONITOR->vecSize.x, 0); } } if (instant) { m_vRenderOffset.warp(); m_fAlpha.warp(); } } void CWorkspace::setActive(bool on) { if (m_pWlrHandle) { wlr_ext_workspace_handle_v1_set_active(m_pWlrHandle, on); } } void CWorkspace::moveToMonitor(const int& id) { const auto PMONITOR = g_pCompositor->getMonitorFromID(id); if (!PMONITOR || m_bIsSpecialWorkspace) return; wlr_ext_workspace_handle_v1_set_active(m_pWlrHandle, false); wlr_ext_workspace_handle_v1_destroy(m_pWlrHandle); m_pWlrHandle = wlr_ext_workspace_handle_v1_create(PMONITOR->pWLRWorkspaceGroupHandle); // set geometry here cuz we can wl_array_init(&m_wlrCoordinateArr); *reinterpret_cast(wl_array_add(&m_wlrCoordinateArr, sizeof(int))) = (int)PMONITOR->vecPosition.x; *reinterpret_cast(wl_array_add(&m_wlrCoordinateArr, sizeof(int))) = (int)PMONITOR->vecPosition.y; wlr_ext_workspace_handle_v1_set_coordinates(m_pWlrHandle, &m_wlrCoordinateArr); wlr_ext_workspace_handle_v1_set_hidden(m_pWlrHandle, false); wlr_ext_workspace_handle_v1_set_urgent(m_pWlrHandle, false); wlr_ext_workspace_handle_v1_set_name(m_pWlrHandle, m_szName.c_str()); }