diff options
author | Thorsten Behrens <Thorsten.Behrens@CIB.de> | 2018-09-04 09:17:11 +0200 |
---|---|---|
committer | Thorsten Behrens <Thorsten.Behrens@CIB.de> | 2018-09-05 08:06:11 +0200 |
commit | 58069fef2d81a81f35a0a5f40441d841a5636cd0 (patch) | |
tree | a1d5dd9568cdf8043d8f8b3fb2d221ef6d7d9ae0 | |
parent | 1bbbe57dfc0b43d6b5444798d77dcdf5e4e76e49 (diff) |
kde5: add more missing pieces to Qt5Frame
- some cleanup
- ShowFullScreen
- ToTop/SetAlwaysOnTop
- CaptureMouse/SetPointerPos
- Beep/Flush
- ClipRegion functions
Change-Id: Ieafdbdae3f808879b9ad0ebed0fa99a2e4f7ee2e
Reviewed-on: https://gerrit.libreoffice.org/60008
Reviewed-by: Thorsten Behrens <Thorsten.Behrens@CIB.de>
Tested-by: Thorsten Behrens <Thorsten.Behrens@CIB.de>
-rw-r--r-- | vcl/inc/qt5/Qt5Frame.hxx | 4 | ||||
-rw-r--r-- | vcl/qt5/Qt5Frame.cxx | 154 | ||||
-rw-r--r-- | vcl/qt5/Qt5Widget.cxx | 3 | ||||
-rw-r--r-- | vcl/unx/kde5/KDE5SalFrame.hxx | 5 |
4 files changed, 127 insertions, 39 deletions
diff --git a/vcl/inc/qt5/Qt5Frame.hxx b/vcl/inc/qt5/Qt5Frame.hxx index e81add10ad1e..0eb796330e38 100644 --- a/vcl/inc/qt5/Qt5Frame.hxx +++ b/vcl/inc/qt5/Qt5Frame.hxx @@ -54,6 +54,8 @@ class VCLPLUG_QT5_PUBLIC Qt5Frame : public SalFrame // of SvpSalGraphics (which the derived class then owns) SvpSalGraphics* m_pSvpGraphics; DamageHandler m_aDamageHandler; + QRegion m_aRegion; + bool m_bNullRegion; bool m_bGraphicsInUse; SalFrameStyleFlags m_nStyle; @@ -128,8 +130,8 @@ public: virtual void SetPointer(PointerStyle ePointerStyle) override; virtual void CaptureMouse(bool bMouse) override; virtual void SetPointerPos(long nX, long nY) override; + using SalFrame::Flush; virtual void Flush() override; - virtual void Flush(const tools::Rectangle& rRect) override; virtual void SetInputContext(SalInputContext* pContext) override; virtual void EndExtTextInput(EndExtTextInputFlags nFlags) override; virtual OUString GetKeyName(sal_uInt16 nKeyCode) override; diff --git a/vcl/qt5/Qt5Frame.cxx b/vcl/qt5/Qt5Frame.cxx index b6ce6dc5736a..198c75b04b82 100644 --- a/vcl/qt5/Qt5Frame.cxx +++ b/vcl/qt5/Qt5Frame.cxx @@ -58,6 +58,7 @@ Qt5Frame::Qt5Frame(Qt5Frame* pParent, SalFrameStyleFlags nStyle, bool bUseCairo) : m_pTopLevel(nullptr) , m_bUseCairo(bUseCairo) , m_pSvpGraphics(nullptr) + , m_bNullRegion(true) , m_bGraphicsInUse(false) , m_ePointerStyle(PointerStyle::Arrow) , m_bDefaultSize(true) @@ -236,17 +237,11 @@ QWindow* Qt5Frame::windowHandle() QScreen* Qt5Frame::screen() { - QWindow* winHandle = nullptr; - - if (m_pTopLevel) - winHandle = m_pTopLevel->windowHandle(); + QWindow* const pWindow = windowHandle(); + if (pWindow) + return pWindow->screen(); else - winHandle = m_pQWidget->windowHandle(); - - if (winHandle) - return winHandle->screen(); - - return nullptr; + return nullptr; } bool Qt5Frame::isMinimized() @@ -302,9 +297,9 @@ void Qt5Frame::SetIcon(sal_uInt16 nIcon) void Qt5Frame::SetMenu(SalMenu* pMenu) { m_pSalMenu = static_cast<Qt5Menu*>(pMenu); } -void Qt5Frame::DrawMenuBar() {} +void Qt5Frame::DrawMenuBar() { /* not needed */} -void Qt5Frame::SetExtendedFrameStyle(SalExtStyle /*nExtStyle*/) {} +void Qt5Frame::SetExtendedFrameStyle(SalExtStyle /*nExtStyle*/) { /* not needed */} void Qt5Frame::Show(bool bVisible, bool /*bNoActivate*/) { @@ -521,13 +516,47 @@ bool Qt5Frame::GetWindowState(SalFrameState* pState) return true; } -void Qt5Frame::ShowFullScreen(bool /*bFullScreen*/, sal_Int32 /*nDisplay*/) {} +void Qt5Frame::ShowFullScreen(bool bFullScreen, sal_Int32 nScreen) +{ + assert(m_pTopLevel); + + if (isWindow()) + { + QWidget* const pWidget = m_pTopLevel ? m_pTopLevel : m_pQWidget; + pWidget->show(); + + // do that before going fullscreen + SetScreenNumber(nScreen); + bFullScreen ? windowHandle()->showFullScreen() : windowHandle()->showNormal(); + } +} + +void Qt5Frame::StartPresentation(bool) +{ + // meh - so there's no Qt platform independent solution - defer to + // KDE5 impl. For everyone else: + // https://forum.qt.io/topic/38504/solved-qdialog-in-fullscreen-disable-os-screensaver +} -void Qt5Frame::StartPresentation(bool /*bStart*/) {} +void Qt5Frame::SetAlwaysOnTop(bool bOnTop) +{ + QWidget* const pWidget = m_pTopLevel ? m_pTopLevel : m_pQWidget; + const Qt::WindowFlags flags = pWidget->windowFlags(); + if (bOnTop) + pWidget->setWindowFlags(flags | Qt::CustomizeWindowHint | Qt::WindowStaysOnTopHint); + else + pWidget->setWindowFlags(flags & ~(Qt::CustomizeWindowHint | Qt::WindowStaysOnTopHint)); + pWidget->show(); +} -void Qt5Frame::SetAlwaysOnTop(bool /*bOnTop*/) {} +void Qt5Frame::ToTop(SalFrameToTop nFlags) +{ + QWidget* const pWidget = m_pTopLevel ? m_pTopLevel : m_pQWidget; -void Qt5Frame::ToTop(SalFrameToTop /*nFlags*/) {} + if (isWindow() && !(nFlags & SalFrameToTop::GrabFocusOnly)) + pWidget->raise(); + pWidget->activateWindow(); +} void Qt5Frame::SetPointer(PointerStyle ePointerStyle) { @@ -541,27 +570,62 @@ void Qt5Frame::SetPointer(PointerStyle ePointerStyle) pWindow->setCursor(static_cast<Qt5Data*>(GetSalData())->getCursor(ePointerStyle)); } -void Qt5Frame::CaptureMouse(bool /*bMouse*/) {} +void Qt5Frame::CaptureMouse(bool bMouse) +{ + QWidget* const pWidget = m_pTopLevel ? m_pTopLevel : m_pQWidget; + if (bMouse) + pWidget->grabMouse(); + else + pWidget->releaseMouse(); +} + +void Qt5Frame::SetPointerPos(long nX, long nY) +{ + QWidget* const pWidget = m_pTopLevel ? m_pTopLevel : m_pQWidget; + QCursor aCursor = pWidget->cursor(); + aCursor.setPos(pWidget->mapToGlobal(QPoint(nX, nY))); + pWidget->setCursor(aCursor); +} -void Qt5Frame::SetPointerPos(long /*nX*/, long /*nY*/) {} +void Qt5Frame::Flush() +{ + QGuiApplication::sync(); -void Qt5Frame::Flush() {} + // unclear if we need to also flush cairo surface - gtk3 backend + // does not do it. QPainter in Qt5Widget::paintEvent() is + // destroyed, so that state should be safely flushed. +} -void Qt5Frame::Flush(const tools::Rectangle& /*rRect*/) {} +// do we even need it? void Qt5Frame::Flush(const tools::Rectangle& /*rRect*/) {} -void Qt5Frame::SetInputContext(SalInputContext* /*pContext*/) {} +void Qt5Frame::SetInputContext(SalInputContext* /*pContext*/) +{ + // TODO some IM handler setup +} -void Qt5Frame::EndExtTextInput(EndExtTextInputFlags /*nFlags*/) {} +void Qt5Frame::EndExtTextInput(EndExtTextInputFlags /*nFlags*/) +{ + // TODO fwd to IM handler +} -OUString Qt5Frame::GetKeyName(sal_uInt16 /*nKeyCode*/) { return OUString(); } +OUString Qt5Frame::GetKeyName(sal_uInt16 /*nKeyCode*/) +{ + // TODO retrieve key cap / modifier names + return OUString(); +} bool Qt5Frame::MapUnicodeToKeyCode(sal_Unicode /*aUnicode*/, LanguageType /*aLangType*/, vcl::KeyCode& /*rKeyCode*/) { + // not supported yet return false; } -LanguageType Qt5Frame::GetInputLanguage() { return LANGUAGE_DONTKNOW; } +LanguageType Qt5Frame::GetInputLanguage() +{ + // fallback + return LANGUAGE_DONTKNOW; +} static Color toColor(const QColor& rColor) { @@ -692,7 +756,7 @@ void Qt5Frame::UpdateSettings(AllSettings& rSettings) rSettings.SetStyleSettings(style); } -void Qt5Frame::Beep() {} +void Qt5Frame::Beep() { QApplication::beep(); } const SystemEnvData* Qt5Frame::GetSystemData() const { return nullptr; } @@ -708,22 +772,46 @@ SalFrame::SalPointerState Qt5Frame::GetPointerState() KeyIndicatorState Qt5Frame::GetIndicatorState() { return KeyIndicatorState(); } -void Qt5Frame::SimulateKeyPress(sal_uInt16 /*nKeyCode*/) {} +void Qt5Frame::SimulateKeyPress(sal_uInt16 nKeyCode) +{ + SAL_WARN("vcl.kde5", "missing simulate keypress " << nKeyCode); +} void Qt5Frame::SetParent(SalFrame* pNewParent) { m_pParent = static_cast<Qt5Frame*>(pNewParent); } -bool Qt5Frame::SetPluginParent(SystemParentData* /*pNewParent*/) { return false; } +bool Qt5Frame::SetPluginParent(SystemParentData* /*pNewParent*/) +{ + //FIXME: no SetPluginParent impl. for kde5 + return false; +} -void Qt5Frame::ResetClipRegion() {} +void Qt5Frame::ResetClipRegion() { m_bNullRegion = true; } -void Qt5Frame::BeginSetClipRegion(sal_uLong /*nRects*/) {} +void Qt5Frame::BeginSetClipRegion(sal_uLong) +{ + m_aRegion = QRegion(QRect(QPoint(0, 0), m_pQWidget->size())); +} -void Qt5Frame::UnionClipRegion(long /*nX*/, long /*nY*/, long /*nWidth*/, long /*nHeight*/) {} +void Qt5Frame::UnionClipRegion(long nX, long nY, long nWidth, long nHeight) +{ + m_aRegion.united(QRegion(nX, nY, nWidth, nHeight)); +} -void Qt5Frame::EndSetClipRegion() {} +void Qt5Frame::EndSetClipRegion() { m_bNullRegion = false; } -void Qt5Frame::SetScreenNumber(unsigned int) {} +void Qt5Frame::SetScreenNumber(unsigned int nScreen) +{ + if (isWindow()) + { + QWindow* const pWindow = windowHandle(); + if (pWindow) + pWindow->setScreen(QApplication::screens()[nScreen]); + } +} -void Qt5Frame::SetApplicationID(const OUString&) {} +void Qt5Frame::SetApplicationID(const OUString&) +{ + // So the hope is that QGuiApplication deals with this properly.. +} /* vim:set shiftwidth=4 softtabstop=4 expandtab: */ diff --git a/vcl/qt5/Qt5Widget.cxx b/vcl/qt5/Qt5Widget.cxx index bb79b7cd6130..3e90a94d4501 100644 --- a/vcl/qt5/Qt5Widget.cxx +++ b/vcl/qt5/Qt5Widget.cxx @@ -41,6 +41,9 @@ void Qt5Widget::paintEvent(QPaintEvent* pEvent) { QPainter p(this); + if (!m_pFrame->m_bNullRegion) + p.setClipRegion(m_pFrame->m_aRegion); + if (m_pFrame->m_bUseCairo) { cairo_surface_t* pSurface = m_pFrame->m_pSurface.get(); diff --git a/vcl/unx/kde5/KDE5SalFrame.hxx b/vcl/unx/kde5/KDE5SalFrame.hxx index 58bdcd82f4c0..6135d630adb3 100644 --- a/vcl/unx/kde5/KDE5SalFrame.hxx +++ b/vcl/unx/kde5/KDE5SalFrame.hxx @@ -43,15 +43,10 @@ public: virtual void ReleaseGraphics(SalGraphics* pGraphics) override; virtual void UpdateSettings(AllSettings& rSettings) override; - virtual void DrawMenuBar() override { return; } - virtual LanguageType GetInputLanguage() override { return LANGUAGE_SYSTEM; } - virtual void Beep() override { return; } virtual const SystemEnvData* GetSystemData() const override { return nullptr; } virtual SalPointerState GetPointerState() override { return SalPointerState(); } virtual KeyIndicatorState GetIndicatorState() override { return KeyIndicatorState(); } - - virtual void SetScreenNumber(unsigned int) override { return; } }; /* vim:set shiftwidth=4 softtabstop=4 expandtab: */ |