Merge pull request #5748 from nitrousox1de/hide-mouse-delay-fullscreen

Hide mouse delay fullscreen
This commit is contained in:
Leo Lam
2017-08-11 17:34:46 +08:00
committed by GitHub
6 changed files with 50 additions and 2 deletions

View File

@ -3,6 +3,7 @@
// Refer to the license.txt file included.
#include <QKeyEvent>
#include <QTimer>
#include "DolphinQt2/Host.h"
#include "DolphinQt2/RenderWidget.h"
@ -18,9 +19,15 @@ RenderWidget::RenderWidget(QWidget* parent) : QWidget(parent)
connect(this, &RenderWidget::HandleChanged, Host::GetInstance(), &Host::SetRenderHandle);
emit HandleChanged((void*)winId());
m_mouse_timer = new QTimer(this);
connect(m_mouse_timer, &QTimer::timeout, this, &RenderWidget::HandleCursorTimer);
m_mouse_timer->setSingleShot(true);
setMouseTracking(true);
connect(&Settings::Instance(), &Settings::HideCursorChanged, this,
&RenderWidget::OnHideCursorChanged);
OnHideCursorChanged();
m_mouse_timer->start(MOUSE_HIDE_DELAY);
}
void RenderWidget::OnHideCursorChanged()
@ -28,6 +35,12 @@ void RenderWidget::OnHideCursorChanged()
setCursor(Settings::Instance().GetHideCursor() ? Qt::BlankCursor : Qt::ArrowCursor);
}
void RenderWidget::HandleCursorTimer()
{
if (isActiveWindow())
setCursor(Qt::BlankCursor);
}
bool RenderWidget::event(QEvent* event)
{
switch (event->type())
@ -39,6 +52,14 @@ bool RenderWidget::event(QEvent* event)
emit EscapePressed();
break;
}
case QEvent::MouseMove:
case QEvent::MouseButtonPress:
if (!Settings::Instance().GetHideCursor() && isActiveWindow())
{
setCursor(Qt::ArrowCursor);
m_mouse_timer->start(MOUSE_HIDE_DELAY);
}
break;
case QEvent::WinIdChange:
emit HandleChanged((void*)winId());
break;