Skip to content

Commit

Permalink
pointermgr: Hide hardware cursor on leave (#7806)
Browse files Browse the repository at this point in the history
  • Loading branch information
vaxerski authored Sep 18, 2024
1 parent 94140e8 commit e6cf643
Showing 1 changed file with 29 additions and 2 deletions.
31 changes: 29 additions & 2 deletions src/managers/PointerManager.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -208,9 +208,8 @@ void CPointerManager::recheckEnteredOutputs() {

// if we are using hw cursors, prevent
// the cursor from being stuck at the last point.
// if we are leaving it, move it to narnia.
if (!s->hardwareFailed && (s->monitor->output->getBackend()->capabilities() & Aquamarine::IBackendImplementation::eBackendCapabilities::AQ_BACKEND_CAPABILITY_POINTER))
s->monitor->output->moveCursor({-1337, -420});
setHWCursorBuffer(s, nullptr);

if (!currentCursorImage.surface)
continue;
Expand Down Expand Up @@ -269,6 +268,8 @@ void CPointerManager::resetCursorImage(bool apply) {
void CPointerManager::updateCursorBackend() {
static auto PNOHW = CConfigValue<Hyprlang::INT>("cursor:no_hardware_cursors");

const auto CURSORBOX = getCursorBoxGlobal();

for (auto const& m : g_pCompositor->m_vMonitors) {
auto state = stateFor(m);

Expand All @@ -277,6 +278,15 @@ void CPointerManager::updateCursorBackend() {
continue;
}

auto CROSSES = !m->logicalBox().intersection(CURSORBOX).empty();

if (!CROSSES) {
if (state->cursorFrontBuffer)
setHWCursorBuffer(state, nullptr);

continue;
}

if (state->softwareLocks > 0 || *PNOHW || !attemptHardwareCursor(state)) {
Debug::log(TRACE, "Output {} rejected hardware cursors, falling back to sw", m->szName);
state->box = getCursorBoxLogicalForMonitor(state->monitor.lock());
Expand All @@ -297,17 +307,34 @@ void CPointerManager::onCursorMoved() {
if (!hasCursor())
return;

const auto CURSORBOX = getCursorBoxGlobal();
bool recalc = false;

for (auto const& m : g_pCompositor->m_vMonitors) {
auto state = stateFor(m);

state->box = getCursorBoxLogicalForMonitor(state->monitor.lock());

auto CROSSES = !m->logicalBox().intersection(CURSORBOX).empty();

if (!CROSSES && state->cursorFrontBuffer) {
Debug::log(TRACE, "onCursorMoved for output {}: cursor left the viewport, removing it from the backend", m->szName);
setHWCursorBuffer(state, nullptr);
continue;
} else if (CROSSES && !state->cursorFrontBuffer) {
Debug::log(TRACE, "onCursorMoved for output {}: cursor entered the output, but no front buffer, forcing recalc", m->szName);
recalc = true;
}

if (state->hardwareFailed || !state->entered)
continue;

const auto CURSORPOS = getCursorPosForMonitor(m);
m->output->moveCursor(CURSORPOS);
}

if (recalc)
updateCursorBackend();
}

bool CPointerManager::attemptHardwareCursor(SP<CPointerManager::SMonitorPointerState> state) {
Expand Down

0 comments on commit e6cf643

Please sign in to comment.