mirror of
https://github.com/OPM/ResInsight.git
synced 2025-01-01 03:37:15 -06:00
#4220 Apply picking cursor only when over a 3d View
This commit is contained in:
parent
ef182da8a9
commit
44f3882ecb
@ -20,6 +20,7 @@
|
||||
|
||||
#include "RiaApplication.h"
|
||||
#include "RiuViewerCommands.h"
|
||||
#include "RiuViewer.h"
|
||||
|
||||
#include "Rim3dView.h"
|
||||
#include "RimIntersection.h"
|
||||
@ -49,7 +50,7 @@ RicMeasurementPickEventHandler* RicMeasurementPickEventHandler::instance()
|
||||
//--------------------------------------------------------------------------------------------------
|
||||
void RicMeasurementPickEventHandler::registerAsPickEventHandler()
|
||||
{
|
||||
RiaApplication::instance()->setOverrideCursor(Qt::CrossCursor);
|
||||
RiuViewer::setHoverCursor(Qt::CrossCursor);
|
||||
RiuViewerCommands::setPickEventHandler(RicMeasurementPickEventHandler::instance());
|
||||
}
|
||||
|
||||
@ -58,7 +59,7 @@ void RicMeasurementPickEventHandler::registerAsPickEventHandler()
|
||||
//--------------------------------------------------------------------------------------------------
|
||||
void RicMeasurementPickEventHandler::unregisterAsPickEventHandler()
|
||||
{
|
||||
RiaApplication::instance()->restoreOverrideCursor();
|
||||
RiuViewer::clearHoverCursor();
|
||||
RiuViewerCommands::removePickEventHandlerIfActive(RicMeasurementPickEventHandler::instance());
|
||||
}
|
||||
|
||||
|
@ -19,6 +19,7 @@
|
||||
|
||||
#include "RiaApplication.h"
|
||||
#include "Rim3dView.h"
|
||||
#include "RiuViewer.h"
|
||||
|
||||
#include "cafDisplayCoordTransform.h"
|
||||
#include "cafSelectionManager.h"
|
||||
@ -52,7 +53,7 @@ bool RicVec3dPickEventHandler::handle3dPickEvent(const Ric3dPickEvent& eventObje
|
||||
void RicVec3dPickEventHandler::registerAsPickEventHandler()
|
||||
{
|
||||
Ric3dViewPickEventHandler::registerAsPickEventHandler();
|
||||
RiaApplication::instance()->setOverrideCursor(Qt::CrossCursor);
|
||||
RiuViewer::setHoverCursor(Qt::CrossCursor);
|
||||
}
|
||||
|
||||
//--------------------------------------------------------------------------------------------------
|
||||
@ -60,5 +61,5 @@ void RicVec3dPickEventHandler::registerAsPickEventHandler()
|
||||
//--------------------------------------------------------------------------------------------------
|
||||
void RicVec3dPickEventHandler::notifyUnregistered()
|
||||
{
|
||||
RiaApplication::instance()->restoreOverrideCursor();
|
||||
RiuViewer::clearHoverCursor();
|
||||
}
|
||||
|
@ -29,6 +29,7 @@
|
||||
#include "RimUserDefinedPolylinesAnnotation.h"
|
||||
|
||||
#include "RiuViewerCommands.h"
|
||||
#include "RiuViewer.h"
|
||||
|
||||
#include "RivPolylinesAnnotationSourceInfo.h"
|
||||
|
||||
@ -55,7 +56,7 @@ RicPolylineTargetsPickEventHandler::~RicPolylineTargetsPickEventHandler() {}
|
||||
//--------------------------------------------------------------------------------------------------
|
||||
void RicPolylineTargetsPickEventHandler::registerAsPickEventHandler()
|
||||
{
|
||||
RiaApplication::instance()->setOverrideCursor(Qt::CrossCursor);
|
||||
RiuViewer::setHoverCursor(Qt::CrossCursor);
|
||||
Ric3dViewPickEventHandler::registerAsPickEventHandler();
|
||||
}
|
||||
|
||||
@ -64,7 +65,7 @@ void RicPolylineTargetsPickEventHandler::registerAsPickEventHandler()
|
||||
//--------------------------------------------------------------------------------------------------
|
||||
void RicPolylineTargetsPickEventHandler::notifyUnregistered()
|
||||
{
|
||||
RiaApplication::instance()->restoreOverrideCursor();
|
||||
RiuViewer::clearHoverCursor();
|
||||
}
|
||||
|
||||
//--------------------------------------------------------------------------------------------------
|
||||
|
@ -77,6 +77,8 @@ using cvf::ManipulatorTrackball;
|
||||
|
||||
const double RI_MIN_NEARPLANE_DISTANCE = 0.1;
|
||||
|
||||
std::unique_ptr<QCursor> RiuViewer::s_hoverCursor;
|
||||
|
||||
//==================================================================================================
|
||||
///
|
||||
/// \class RiuViewer
|
||||
@ -841,11 +843,24 @@ void RiuViewer::mouseMoveEvent(QMouseEvent* mouseEvent)
|
||||
caf::Viewer::mouseMoveEvent(mouseEvent);
|
||||
}
|
||||
|
||||
//--------------------------------------------------------------------------------------------------
|
||||
///
|
||||
//--------------------------------------------------------------------------------------------------
|
||||
void RiuViewer::enterEvent(QEvent*)
|
||||
{
|
||||
if (s_hoverCursor)
|
||||
{
|
||||
QApplication::setOverrideCursor(*s_hoverCursor);
|
||||
}
|
||||
}
|
||||
|
||||
//--------------------------------------------------------------------------------------------------
|
||||
///
|
||||
//--------------------------------------------------------------------------------------------------
|
||||
void RiuViewer::leaveEvent(QEvent*)
|
||||
{
|
||||
QApplication::restoreOverrideCursor();
|
||||
|
||||
if (m_rimView && m_rimView->assosiatedViewLinker())
|
||||
{
|
||||
RimViewLinker* viewLinker = m_rimView->assosiatedViewLinker();
|
||||
@ -1026,6 +1041,22 @@ void RiuViewer::showScaleLegend(bool show)
|
||||
updateLegendLayout();
|
||||
}
|
||||
|
||||
//--------------------------------------------------------------------------------------------------
|
||||
///
|
||||
//--------------------------------------------------------------------------------------------------
|
||||
void RiuViewer::setHoverCursor(const QCursor& cursor)
|
||||
{
|
||||
s_hoverCursor.reset(new QCursor(cursor));
|
||||
}
|
||||
|
||||
//--------------------------------------------------------------------------------------------------
|
||||
///
|
||||
//--------------------------------------------------------------------------------------------------
|
||||
void RiuViewer::clearHoverCursor()
|
||||
{
|
||||
s_hoverCursor.reset();
|
||||
}
|
||||
|
||||
//--------------------------------------------------------------------------------------------------
|
||||
///
|
||||
//--------------------------------------------------------------------------------------------------
|
||||
|
@ -21,15 +21,17 @@
|
||||
#pragma once
|
||||
|
||||
#include "RiuViewerToViewInterface.h"
|
||||
#include "cafViewer.h"
|
||||
#include "RiuInterfaceToViewWindow.h"
|
||||
|
||||
#include "cafMouseState.h"
|
||||
#include "cafPdmObject.h"
|
||||
#include "cafPdmPointer.h"
|
||||
#include "cafPdmInterfacePointer.h"
|
||||
#include "cafViewer.h"
|
||||
|
||||
#include "cafMouseState.h"
|
||||
#include "cvfStructGrid.h"
|
||||
#include "RiuInterfaceToViewWindow.h"
|
||||
|
||||
#include <memory>
|
||||
|
||||
class RicCommandFeature;
|
||||
class Rim3dView;
|
||||
@ -127,6 +129,9 @@ public:
|
||||
|
||||
void showScaleLegend(bool show);
|
||||
|
||||
static void setHoverCursor(const QCursor& cursor);
|
||||
static void clearHoverCursor();
|
||||
|
||||
public slots:
|
||||
void slotSetCurrentFrame(int frameIndex) override;
|
||||
void slotEndAnimation() override;
|
||||
@ -135,7 +140,8 @@ protected:
|
||||
void optimizeClippingPlanes() override;
|
||||
void resizeGL(int width, int height) override;
|
||||
void mouseMoveEvent(QMouseEvent* e) override;
|
||||
void leaveEvent(QEvent *) override;
|
||||
void enterEvent(QEvent*) override;
|
||||
void leaveEvent(QEvent*) override;
|
||||
|
||||
private:
|
||||
void updateLegendLayout();
|
||||
@ -191,5 +197,7 @@ private:
|
||||
bool m_isNavigationRotationEnabled;
|
||||
|
||||
cvf::ref<caf::OverlayScaleLegend> m_scaleLegend;
|
||||
|
||||
static std::unique_ptr<QCursor> s_hoverCursor;
|
||||
};
|
||||
|
||||
|
Loading…
Reference in New Issue
Block a user