diff --git a/modules/gui/qt/maininterface/videosurface.cpp b/modules/gui/qt/maininterface/videosurface.cpp index 0755238eee49eb9f53c4dfb667f0d1547fd04ac3..b07681df76d1e61462b8eebaa0149da61282523c 100644 --- a/modules/gui/qt/maininterface/videosurface.cpp +++ b/modules/gui/qt/maininterface/videosurface.cpp @@ -17,7 +17,6 @@ *****************************************************************************/ #include "videosurface.hpp" #include "maininterface/mainctx.hpp" -#include "util/vlchotkeyconverter.hpp" #include <QSGRectangleNode> #include <QThreadPool> #include <vlc_window.h> @@ -209,8 +208,6 @@ VideoSurface::VideoSurface(QQuickItem* parent) setAcceptedMouseButtons(Qt::AllButtons); setFlag(ItemAcceptsInputMethod, true); - m_wheelEventConverter = new WheelToVLCConverter(this); - { connect(this, &QQuickItem::widthChanged, this, &VideoSurface::updateSurfaceSize); connect(this, &QQuickItem::heightChanged, this, &VideoSurface::updateSurfaceSize); @@ -308,7 +305,7 @@ void VideoSurface::keyPressEvent(QKeyEvent* event) #if QT_CONFIG(wheelevent) void VideoSurface::wheelEvent(QWheelEvent *event) { - m_wheelEventConverter->wheelEvent(event); + m_wheelEventConverter.wheelEvent(event); event->accept(); } #endif @@ -392,6 +389,8 @@ void VideoSurface::setVideoSurfaceProvider(VideoSurfaceProvider *newVideoSurface if (m_provider) { + disconnect(this, nullptr, m_provider, nullptr); + disconnect(&m_wheelEventConverter, nullptr, m_provider, nullptr); disconnect(m_provider, nullptr, this, nullptr); } @@ -408,7 +407,7 @@ void VideoSurface::setVideoSurfaceProvider(VideoSurfaceProvider *newVideoSurface connect(this, &VideoSurface::surfacePositionChanged, m_provider, &VideoSurfaceProvider::surfacePositionChanged); connect(this, &VideoSurface::surfaceScaleChanged, m_provider, &VideoSurfaceProvider::surfaceScaleChanged); - connect(m_wheelEventConverter, &WheelToVLCConverter::vlcWheelKey, m_provider, &VideoSurfaceProvider::onMouseWheeled); + connect(&m_wheelEventConverter, &WheelToVLCConverter::vlcWheelKey, m_provider, &VideoSurfaceProvider::onMouseWheeled); connect(m_provider, &VideoSurfaceProvider::videoEnabledChanged, this, &VideoSurface::updateSurface); setFlag(ItemHasContents, true); diff --git a/modules/gui/qt/maininterface/videosurface.hpp b/modules/gui/qt/maininterface/videosurface.hpp index 7a0e5961169bbcf1c120d028e5e644f653f86fb1..4063e4d49cbfb1d0aed9637020d827ee6dcb0e2f 100644 --- a/modules/gui/qt/maininterface/videosurface.hpp +++ b/modules/gui/qt/maininterface/videosurface.hpp @@ -23,6 +23,7 @@ #include <QRunnable> #include <QPointer> #include "qt.hpp" +#include "util/vlchotkeyconverter.hpp" #include <vlc_threads.h> @@ -33,7 +34,6 @@ extern "C" { Q_MOC_INCLUDE( "maininterface/mainctx.hpp") class MainCtx; -class WheelToVLCConverter; class WindowResizer : public QRunnable @@ -153,7 +153,7 @@ protected slots: private: QPointF m_oldHoverPos; - WheelToVLCConverter* m_wheelEventConverter = nullptr; + WheelToVLCConverter m_wheelEventConverter; QPointer<VideoSurfaceProvider> m_provider;