mirror of
https://github.com/OPM/ResInsight.git
synced 2025-02-25 18:55:39 -06:00
Simplify pick event system
This commit is contained in:
@@ -47,7 +47,6 @@ RicMeasurementPickEventHandler* RicMeasurementPickEventHandler::instance()
|
|||||||
///
|
///
|
||||||
//--------------------------------------------------------------------------------------------------
|
//--------------------------------------------------------------------------------------------------
|
||||||
RicMeasurementPickEventHandler::RicMeasurementPickEventHandler()
|
RicMeasurementPickEventHandler::RicMeasurementPickEventHandler()
|
||||||
: Ric3dViewPickEventHandler(nullptr)
|
|
||||||
{}
|
{}
|
||||||
|
|
||||||
//--------------------------------------------------------------------------------------------------
|
//--------------------------------------------------------------------------------------------------
|
||||||
|
|||||||
@@ -20,13 +20,6 @@
|
|||||||
|
|
||||||
#include <typeinfo>
|
#include <typeinfo>
|
||||||
|
|
||||||
//--------------------------------------------------------------------------------------------------
|
|
||||||
///
|
|
||||||
//--------------------------------------------------------------------------------------------------
|
|
||||||
Ric3dViewPickEventHandler::Ric3dViewPickEventHandler(const caf::PdmObjectHandle* handlingObject)
|
|
||||||
: caf::PickEventHandler(handlingObject)
|
|
||||||
{}
|
|
||||||
|
|
||||||
//--------------------------------------------------------------------------------------------------
|
//--------------------------------------------------------------------------------------------------
|
||||||
///
|
///
|
||||||
//--------------------------------------------------------------------------------------------------
|
//--------------------------------------------------------------------------------------------------
|
||||||
|
|||||||
@@ -28,8 +28,6 @@
|
|||||||
class Ric3dViewPickEventHandler : public caf::PickEventHandler
|
class Ric3dViewPickEventHandler : public caf::PickEventHandler
|
||||||
{
|
{
|
||||||
public:
|
public:
|
||||||
Ric3dViewPickEventHandler(const caf::PdmObjectHandle* handlingObject);
|
|
||||||
|
|
||||||
// Override from caf
|
// Override from caf
|
||||||
void registerAsPickEventHandler() override;
|
void registerAsPickEventHandler() override;
|
||||||
void unregisterAsPickEventHandler() override;
|
void unregisterAsPickEventHandler() override;
|
||||||
|
|||||||
@@ -26,10 +26,8 @@
|
|||||||
//--------------------------------------------------------------------------------------------------
|
//--------------------------------------------------------------------------------------------------
|
||||||
///
|
///
|
||||||
//--------------------------------------------------------------------------------------------------
|
//--------------------------------------------------------------------------------------------------
|
||||||
RicVec3dPickEventHandler::RicVec3dPickEventHandler(const caf::PdmObjectHandle* handlingObject,
|
RicVec3dPickEventHandler::RicVec3dPickEventHandler(caf::PdmField<cvf::Vec3d>* vectorField)
|
||||||
caf::PdmField<cvf::Vec3d>* vectorField)
|
: m_vectorField(vectorField)
|
||||||
: Ric3dViewPickEventHandler(handlingObject)
|
|
||||||
, m_vectorField(vectorField)
|
|
||||||
{
|
{
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -38,19 +36,14 @@ RicVec3dPickEventHandler::RicVec3dPickEventHandler(const caf::PdmObjectHandle* h
|
|||||||
//--------------------------------------------------------------------------------------------------
|
//--------------------------------------------------------------------------------------------------
|
||||||
bool RicVec3dPickEventHandler::handle3dPickEvent(const Ric3dPickEvent& eventObject)
|
bool RicVec3dPickEventHandler::handle3dPickEvent(const Ric3dPickEvent& eventObject)
|
||||||
{
|
{
|
||||||
caf::PdmObjectHandle* selectedObject = caf::SelectionManager::instance()->selectedItemOfType<caf::PdmObjectHandle>();
|
const Rim3dView* rimView = eventObject.m_view;
|
||||||
if (isObjectBeingModified(selectedObject))
|
|
||||||
{
|
|
||||||
const Rim3dView* rimView = eventObject.m_view;
|
|
||||||
|
|
||||||
cvf::ref<caf::DisplayCoordTransform> transForm = rimView->displayCoordTransform();
|
cvf::ref<caf::DisplayCoordTransform> transForm = rimView->displayCoordTransform();
|
||||||
cvf::Vec3d pickedPositionInUTM = transForm->transformToDomainCoord(eventObject.m_pickItemInfos.front().globalPickedPoint());
|
cvf::Vec3d pickedPositionInUTM = transForm->transformToDomainCoord(eventObject.m_pickItemInfos.front().globalPickedPoint());
|
||||||
|
|
||||||
pickedPositionInUTM.z() *= -1.0;
|
pickedPositionInUTM.z() *= -1.0;
|
||||||
m_vectorField->setValueWithFieldChanged(pickedPositionInUTM);
|
m_vectorField->setValueWithFieldChanged(pickedPositionInUTM);
|
||||||
return true;
|
return true;
|
||||||
}
|
|
||||||
return false;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
//--------------------------------------------------------------------------------------------------
|
//--------------------------------------------------------------------------------------------------
|
||||||
|
|||||||
@@ -29,7 +29,7 @@ class Rim3dView;
|
|||||||
class RicVec3dPickEventHandler : public Ric3dViewPickEventHandler
|
class RicVec3dPickEventHandler : public Ric3dViewPickEventHandler
|
||||||
{
|
{
|
||||||
public:
|
public:
|
||||||
RicVec3dPickEventHandler(const caf::PdmObjectHandle* handlingObject, caf::PdmField<cvf::Vec3d>* vectorField);
|
RicVec3dPickEventHandler(caf::PdmField<cvf::Vec3d>* vectorField);
|
||||||
bool handle3dPickEvent(const Ric3dPickEvent& eventObject) override;
|
bool handle3dPickEvent(const Ric3dPickEvent& eventObject) override;
|
||||||
|
|
||||||
|
|
||||||
|
|||||||
@@ -23,6 +23,7 @@
|
|||||||
#include "RimPolylineTarget.h"
|
#include "RimPolylineTarget.h"
|
||||||
#include "RimUserDefinedPolylinesAnnotation.h"
|
#include "RimUserDefinedPolylinesAnnotation.h"
|
||||||
|
|
||||||
|
#include "cafPickEventHandler.h"
|
||||||
|
|
||||||
CAF_PDM_UI_3D_OBJECT_EDITOR_SOURCE_INIT(RicPolyline3dEditor);
|
CAF_PDM_UI_3D_OBJECT_EDITOR_SOURCE_INIT(RicPolyline3dEditor);
|
||||||
|
|
||||||
@@ -43,6 +44,10 @@ RicPolyline3dEditor::~RicPolyline3dEditor()
|
|||||||
{
|
{
|
||||||
delete targetEditor;
|
delete targetEditor;
|
||||||
}
|
}
|
||||||
|
if (m_attribute.pickEventHandler != nullptr)
|
||||||
|
{
|
||||||
|
m_attribute.pickEventHandler->unregisterAsPickEventHandler();
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
//--------------------------------------------------------------------------------------------------
|
//--------------------------------------------------------------------------------------------------
|
||||||
@@ -60,6 +65,18 @@ void RicPolyline3dEditor::configureAndUpdateUi(const QString& uiConfigName)
|
|||||||
|
|
||||||
if (!geomDef) return;
|
if (!geomDef) return;
|
||||||
|
|
||||||
|
geomDef->objectEditorAttribute("", &m_attribute);
|
||||||
|
if (m_attribute.pickEventHandler != nullptr)
|
||||||
|
{
|
||||||
|
if (m_attribute.enablePicking)
|
||||||
|
{
|
||||||
|
m_attribute.pickEventHandler->registerAsPickEventHandler();
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
m_attribute.pickEventHandler->unregisterAsPickEventHandler();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
std::vector<RimPolylineTarget*> targets = geomDef->activeTargets();
|
std::vector<RimPolylineTarget*> targets = geomDef->activeTargets();
|
||||||
|
|
||||||
|
|||||||
@@ -17,10 +17,39 @@
|
|||||||
/////////////////////////////////////////////////////////////////////////////////
|
/////////////////////////////////////////////////////////////////////////////////
|
||||||
|
|
||||||
#pragma once
|
#pragma once
|
||||||
|
|
||||||
#include "cafPdmUi3dObjectEditorHandle.h"
|
#include "cafPdmUi3dObjectEditorHandle.h"
|
||||||
|
#include "cafPdmUiFieldEditorHandle.h"
|
||||||
|
|
||||||
|
#include <memory>
|
||||||
|
|
||||||
|
namespace caf
|
||||||
|
{
|
||||||
|
class PickEventHandler;
|
||||||
|
};
|
||||||
|
|
||||||
class RicPolylineTarget3dEditor;
|
class RicPolylineTarget3dEditor;
|
||||||
|
|
||||||
|
|
||||||
|
//==================================================================================================
|
||||||
|
///
|
||||||
|
//==================================================================================================
|
||||||
|
class RicPolyline3dEditorAttribute : public caf::PdmUiEditorAttribute
|
||||||
|
{
|
||||||
|
public:
|
||||||
|
RicPolyline3dEditorAttribute()
|
||||||
|
: enablePicking(false)
|
||||||
|
{
|
||||||
|
}
|
||||||
|
|
||||||
|
public:
|
||||||
|
bool enablePicking;
|
||||||
|
std::shared_ptr<caf::PickEventHandler> pickEventHandler;
|
||||||
|
};
|
||||||
|
|
||||||
|
//==================================================================================================
|
||||||
|
///
|
||||||
|
//==================================================================================================
|
||||||
class RicPolyline3dEditor : public caf::PdmUi3dObjectEditorHandle
|
class RicPolyline3dEditor : public caf::PdmUi3dObjectEditorHandle
|
||||||
{
|
{
|
||||||
CAF_PDM_UI_3D_OBJECT_EDITOR_HEADER_INIT;
|
CAF_PDM_UI_3D_OBJECT_EDITOR_HEADER_INIT;
|
||||||
@@ -32,9 +61,9 @@ public:
|
|||||||
protected:
|
protected:
|
||||||
void configureAndUpdateUi(const QString& uiConfigName) override;
|
void configureAndUpdateUi(const QString& uiConfigName) override;
|
||||||
|
|
||||||
private:
|
private:
|
||||||
|
|
||||||
std::vector<RicPolylineTarget3dEditor*> m_targetEditors;
|
std::vector<RicPolylineTarget3dEditor*> m_targetEditors;
|
||||||
|
RicPolyline3dEditorAttribute m_attribute;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
||||||
|
|||||||
@@ -24,6 +24,7 @@
|
|||||||
#include "RimWellPathTarget.h"
|
#include "RimWellPathTarget.h"
|
||||||
#include "RimWellPathGeometryDef.h"
|
#include "RimWellPathGeometryDef.h"
|
||||||
|
|
||||||
|
#include "cafPickEventHandler.h"
|
||||||
|
|
||||||
CAF_PDM_UI_3D_OBJECT_EDITOR_SOURCE_INIT(RicWellPathGeometry3dEditor);
|
CAF_PDM_UI_3D_OBJECT_EDITOR_SOURCE_INIT(RicWellPathGeometry3dEditor);
|
||||||
|
|
||||||
@@ -44,6 +45,10 @@ RicWellPathGeometry3dEditor::~RicWellPathGeometry3dEditor()
|
|||||||
{
|
{
|
||||||
delete targetEditor;
|
delete targetEditor;
|
||||||
}
|
}
|
||||||
|
if (m_attribute.pickEventHandler)
|
||||||
|
{
|
||||||
|
m_attribute.pickEventHandler->unregisterAsPickEventHandler();
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
//--------------------------------------------------------------------------------------------------
|
//--------------------------------------------------------------------------------------------------
|
||||||
@@ -61,6 +66,7 @@ void RicWellPathGeometry3dEditor::configureAndUpdateUi(const QString& uiConfigNa
|
|||||||
|
|
||||||
if (!geomDef) return;
|
if (!geomDef) return;
|
||||||
|
|
||||||
|
geomDef->objectEditorAttribute("", &m_attribute);
|
||||||
|
|
||||||
std::vector<RimWellPathTarget*> targets = geomDef->activeWellTargets();
|
std::vector<RimWellPathTarget*> targets = geomDef->activeWellTargets();
|
||||||
|
|
||||||
@@ -72,6 +78,18 @@ void RicWellPathGeometry3dEditor::configureAndUpdateUi(const QString& uiConfigNa
|
|||||||
m_targetEditors.push_back(targetEditor);
|
m_targetEditors.push_back(targetEditor);
|
||||||
targetEditor->updateUi();
|
targetEditor->updateUi();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (m_attribute.pickEventHandler)
|
||||||
|
{
|
||||||
|
if (m_attribute.enablePicking)
|
||||||
|
{
|
||||||
|
m_attribute.pickEventHandler->registerAsPickEventHandler();
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
m_attribute.pickEventHandler->unregisterAsPickEventHandler();
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|||||||
@@ -18,9 +18,25 @@
|
|||||||
|
|
||||||
#pragma once
|
#pragma once
|
||||||
#include "cafPdmUi3dObjectEditorHandle.h"
|
#include "cafPdmUi3dObjectEditorHandle.h"
|
||||||
|
#include "cafPdmUiFieldEditorHandle.h"
|
||||||
|
#include <memory>
|
||||||
|
|
||||||
|
namespace caf
|
||||||
|
{
|
||||||
|
class PickEventHandler;
|
||||||
|
}
|
||||||
|
|
||||||
class RicWellTarget3dEditor;
|
class RicWellTarget3dEditor;
|
||||||
|
|
||||||
|
|
||||||
|
class RicWellPathGeometry3dEditorAttribute : public caf::PdmUiEditorAttribute
|
||||||
|
{
|
||||||
|
public:
|
||||||
|
RicWellPathGeometry3dEditorAttribute() : enablePicking(false) {}
|
||||||
|
bool enablePicking;
|
||||||
|
std::shared_ptr<caf::PickEventHandler> pickEventHandler;
|
||||||
|
};
|
||||||
|
|
||||||
class RicWellPathGeometry3dEditor : public caf::PdmUi3dObjectEditorHandle
|
class RicWellPathGeometry3dEditor : public caf::PdmUi3dObjectEditorHandle
|
||||||
{
|
{
|
||||||
CAF_PDM_UI_3D_OBJECT_EDITOR_HEADER_INIT;
|
CAF_PDM_UI_3D_OBJECT_EDITOR_HEADER_INIT;
|
||||||
@@ -33,8 +49,8 @@ protected:
|
|||||||
void configureAndUpdateUi(const QString& uiConfigName) override;
|
void configureAndUpdateUi(const QString& uiConfigName) override;
|
||||||
|
|
||||||
private:
|
private:
|
||||||
|
std::vector<RicWellTarget3dEditor*> m_targetEditors;
|
||||||
std::vector<RicWellTarget3dEditor*> m_targetEditors;
|
RicWellPathGeometry3dEditorAttribute m_attribute;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
||||||
|
|||||||
@@ -18,6 +18,7 @@
|
|||||||
|
|
||||||
#include "RicCreateWellTargetsPickEventHandler.h"
|
#include "RicCreateWellTargetsPickEventHandler.h"
|
||||||
|
|
||||||
|
#include "RiaApplication.h"
|
||||||
#include "RiaOffshoreSphericalCoords.h"
|
#include "RiaOffshoreSphericalCoords.h"
|
||||||
|
|
||||||
#include "RigFemPart.h"
|
#include "RigFemPart.h"
|
||||||
@@ -55,7 +56,7 @@
|
|||||||
///
|
///
|
||||||
//--------------------------------------------------------------------------------------------------
|
//--------------------------------------------------------------------------------------------------
|
||||||
RicCreateWellTargetsPickEventHandler::RicCreateWellTargetsPickEventHandler(RimWellPathGeometryDef* wellGeometryDef)
|
RicCreateWellTargetsPickEventHandler::RicCreateWellTargetsPickEventHandler(RimWellPathGeometryDef* wellGeometryDef)
|
||||||
: Ric3dViewPickEventHandler(wellGeometryDef), m_geometryToAddTargetsTo(wellGeometryDef)
|
: m_geometryToAddTargetsTo(wellGeometryDef)
|
||||||
{
|
{
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -64,12 +65,21 @@ RicCreateWellTargetsPickEventHandler::RicCreateWellTargetsPickEventHandler(RimWe
|
|||||||
//--------------------------------------------------------------------------------------------------
|
//--------------------------------------------------------------------------------------------------
|
||||||
RicCreateWellTargetsPickEventHandler::~RicCreateWellTargetsPickEventHandler() {}
|
RicCreateWellTargetsPickEventHandler::~RicCreateWellTargetsPickEventHandler() {}
|
||||||
|
|
||||||
|
//--------------------------------------------------------------------------------------------------
|
||||||
|
///
|
||||||
|
//--------------------------------------------------------------------------------------------------
|
||||||
|
void RicCreateWellTargetsPickEventHandler::registerAsPickEventHandler()
|
||||||
|
{
|
||||||
|
RiaApplication::instance()->setOverrideCursor(Qt::CrossCursor);
|
||||||
|
Ric3dViewPickEventHandler::registerAsPickEventHandler();
|
||||||
|
}
|
||||||
|
|
||||||
//--------------------------------------------------------------------------------------------------
|
//--------------------------------------------------------------------------------------------------
|
||||||
///
|
///
|
||||||
//--------------------------------------------------------------------------------------------------
|
//--------------------------------------------------------------------------------------------------
|
||||||
void RicCreateWellTargetsPickEventHandler::notifyUnregistered()
|
void RicCreateWellTargetsPickEventHandler::notifyUnregistered()
|
||||||
{
|
{
|
||||||
m_geometryToAddTargetsTo->enableTargetPointPicking(false);
|
RiaApplication::instance()->restoreOverrideCursor();
|
||||||
}
|
}
|
||||||
|
|
||||||
//--------------------------------------------------------------------------------------------------
|
//--------------------------------------------------------------------------------------------------
|
||||||
@@ -77,13 +87,6 @@ void RicCreateWellTargetsPickEventHandler::notifyUnregistered()
|
|||||||
//--------------------------------------------------------------------------------------------------
|
//--------------------------------------------------------------------------------------------------
|
||||||
bool RicCreateWellTargetsPickEventHandler::handle3dPickEvent(const Ric3dPickEvent& eventObject)
|
bool RicCreateWellTargetsPickEventHandler::handle3dPickEvent(const Ric3dPickEvent& eventObject)
|
||||||
{
|
{
|
||||||
if (!isObjectBeingModified(caf::SelectionManager::instance()->selectedItemOfType<caf::PdmObjectHandle>()))
|
|
||||||
{
|
|
||||||
m_geometryToAddTargetsTo->enableTargetPointPicking(false);
|
|
||||||
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (m_geometryToAddTargetsTo)
|
if (m_geometryToAddTargetsTo)
|
||||||
{
|
{
|
||||||
Rim3dView* rimView = eventObject.m_view;
|
Rim3dView* rimView = eventObject.m_view;
|
||||||
|
|||||||
@@ -34,6 +34,8 @@ public:
|
|||||||
RicCreateWellTargetsPickEventHandler(RimWellPathGeometryDef* wellGeometryDef);
|
RicCreateWellTargetsPickEventHandler(RimWellPathGeometryDef* wellGeometryDef);
|
||||||
~RicCreateWellTargetsPickEventHandler();
|
~RicCreateWellTargetsPickEventHandler();
|
||||||
|
|
||||||
|
void registerAsPickEventHandler() override;
|
||||||
|
|
||||||
protected:
|
protected:
|
||||||
bool handle3dPickEvent(const Ric3dPickEvent& eventObject) override;
|
bool handle3dPickEvent(const Ric3dPickEvent& eventObject) override;
|
||||||
void notifyUnregistered() override;
|
void notifyUnregistered() override;
|
||||||
|
|||||||
@@ -18,6 +18,7 @@
|
|||||||
|
|
||||||
#include "RicPolylineTargetsPickEventHandler.h"
|
#include "RicPolylineTargetsPickEventHandler.h"
|
||||||
|
|
||||||
|
#include "RiaApplication.h"
|
||||||
#include "RiaOffshoreSphericalCoords.h"
|
#include "RiaOffshoreSphericalCoords.h"
|
||||||
|
|
||||||
#include "RigWellPath.h"
|
#include "RigWellPath.h"
|
||||||
@@ -40,7 +41,7 @@
|
|||||||
///
|
///
|
||||||
//--------------------------------------------------------------------------------------------------
|
//--------------------------------------------------------------------------------------------------
|
||||||
RicPolylineTargetsPickEventHandler::RicPolylineTargetsPickEventHandler(RimUserDefinedPolylinesAnnotation* polylineDef)
|
RicPolylineTargetsPickEventHandler::RicPolylineTargetsPickEventHandler(RimUserDefinedPolylinesAnnotation* polylineDef)
|
||||||
: Ric3dViewPickEventHandler(polylineDef), m_polylineDef(polylineDef)
|
: m_polylineDef(polylineDef)
|
||||||
{
|
{
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -49,12 +50,21 @@ RicPolylineTargetsPickEventHandler::RicPolylineTargetsPickEventHandler(RimUserDe
|
|||||||
//--------------------------------------------------------------------------------------------------
|
//--------------------------------------------------------------------------------------------------
|
||||||
RicPolylineTargetsPickEventHandler::~RicPolylineTargetsPickEventHandler() {}
|
RicPolylineTargetsPickEventHandler::~RicPolylineTargetsPickEventHandler() {}
|
||||||
|
|
||||||
|
//--------------------------------------------------------------------------------------------------
|
||||||
|
///
|
||||||
|
//--------------------------------------------------------------------------------------------------
|
||||||
|
void RicPolylineTargetsPickEventHandler::registerAsPickEventHandler()
|
||||||
|
{
|
||||||
|
RiaApplication::instance()->setOverrideCursor(Qt::CrossCursor);
|
||||||
|
Ric3dViewPickEventHandler::registerAsPickEventHandler();
|
||||||
|
}
|
||||||
|
|
||||||
//--------------------------------------------------------------------------------------------------
|
//--------------------------------------------------------------------------------------------------
|
||||||
///
|
///
|
||||||
//--------------------------------------------------------------------------------------------------
|
//--------------------------------------------------------------------------------------------------
|
||||||
void RicPolylineTargetsPickEventHandler::notifyUnregistered()
|
void RicPolylineTargetsPickEventHandler::notifyUnregistered()
|
||||||
{
|
{
|
||||||
//m_polylineDef->enableTargetPointPicking(false);
|
RiaApplication::instance()->restoreOverrideCursor();
|
||||||
}
|
}
|
||||||
|
|
||||||
//--------------------------------------------------------------------------------------------------
|
//--------------------------------------------------------------------------------------------------
|
||||||
@@ -62,11 +72,6 @@ void RicPolylineTargetsPickEventHandler::notifyUnregistered()
|
|||||||
//--------------------------------------------------------------------------------------------------
|
//--------------------------------------------------------------------------------------------------
|
||||||
bool RicPolylineTargetsPickEventHandler::handle3dPickEvent(const Ric3dPickEvent& eventObject)
|
bool RicPolylineTargetsPickEventHandler::handle3dPickEvent(const Ric3dPickEvent& eventObject)
|
||||||
{
|
{
|
||||||
if (!isObjectBeingModified(caf::SelectionManager::instance()->selectedItemOfType<caf::PdmObjectHandle>()))
|
|
||||||
{
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (m_polylineDef)
|
if (m_polylineDef)
|
||||||
{
|
{
|
||||||
Rim3dView* rimView = eventObject.m_view;
|
Rim3dView* rimView = eventObject.m_view;
|
||||||
|
|||||||
@@ -33,6 +33,8 @@ public:
|
|||||||
RicPolylineTargetsPickEventHandler(RimUserDefinedPolylinesAnnotation* polylineDef);
|
RicPolylineTargetsPickEventHandler(RimUserDefinedPolylinesAnnotation* polylineDef);
|
||||||
~RicPolylineTargetsPickEventHandler();
|
~RicPolylineTargetsPickEventHandler();
|
||||||
|
|
||||||
|
void registerAsPickEventHandler() override;
|
||||||
|
|
||||||
protected:
|
protected:
|
||||||
bool handle3dPickEvent(const Ric3dPickEvent& eventObject) override;
|
bool handle3dPickEvent(const Ric3dPickEvent& eventObject) override;
|
||||||
void notifyUnregistered() override;
|
void notifyUnregistered() override;
|
||||||
|
|||||||
@@ -26,7 +26,8 @@
|
|||||||
|
|
||||||
#include "RicVec3dPickEventHandler.h"
|
#include "RicVec3dPickEventHandler.h"
|
||||||
|
|
||||||
#include "cafPdmUiVec3dEditor.h"
|
#include "cafPdmUiPushButtonEditor.h"
|
||||||
|
#include "cafPdmUiPickableLineEditor.h"
|
||||||
|
|
||||||
CAF_PDM_SOURCE_INIT(RimReachCircleAnnotation, "RimReachCircleAnnotation");
|
CAF_PDM_SOURCE_INIT(RimReachCircleAnnotation, "RimReachCircleAnnotation");
|
||||||
|
|
||||||
@@ -42,7 +43,11 @@ RimReachCircleAnnotation::RimReachCircleAnnotation()
|
|||||||
m_isActive.uiCapability()->setUiHidden(true);
|
m_isActive.uiCapability()->setUiHidden(true);
|
||||||
|
|
||||||
CAF_PDM_InitField(&m_centerPointXyd, "CenterPointXyd", Vec3d::ZERO, "Center Point", "", "", "");
|
CAF_PDM_InitField(&m_centerPointXyd, "CenterPointXyd", Vec3d::ZERO, "Center Point", "", "", "");
|
||||||
m_centerPointXyd.uiCapability()->setUiEditorTypeName(caf::PdmUiVec3dEditor::uiEditorTypeName());
|
m_centerPointXyd.uiCapability()->setUiEditorTypeName(caf::PdmUiPickableLineEditor::uiEditorTypeName());
|
||||||
|
CAF_PDM_InitField(&m_centerPointPickEnabled, "AnchorPointPick", true, "", "", "", "");
|
||||||
|
caf::PdmUiPushButtonEditor::configureEditorForField(&m_centerPointPickEnabled);
|
||||||
|
m_centerPointPickEnabled.uiCapability()->setUiLabelPosition(caf::PdmUiItemInfo::LabelPosType::HIDDEN);
|
||||||
|
|
||||||
CAF_PDM_InitField(&m_radius, "Radius", 100.0, "Radius", "", "", "");
|
CAF_PDM_InitField(&m_radius, "Radius", 100.0, "Radius", "", "", "");
|
||||||
CAF_PDM_InitField(&m_name, "Name", QString("Circle Annotation"), "Name", "", "", "");
|
CAF_PDM_InitField(&m_name, "Name", QString("Circle Annotation"), "Name", "", "", "");
|
||||||
|
|
||||||
@@ -52,7 +57,7 @@ RimReachCircleAnnotation::RimReachCircleAnnotation()
|
|||||||
m_appearance.uiCapability()->setUiTreeHidden(true);
|
m_appearance.uiCapability()->setUiTreeHidden(true);
|
||||||
m_appearance.uiCapability()->setUiTreeChildrenHidden(true);
|
m_appearance.uiCapability()->setUiTreeChildrenHidden(true);
|
||||||
|
|
||||||
m_centerPointEventHandler.reset(new RicVec3dPickEventHandler(this, &m_centerPointXyd));
|
m_centerPointEventHandler.reset(new RicVec3dPickEventHandler(&m_centerPointXyd));
|
||||||
}
|
}
|
||||||
|
|
||||||
//--------------------------------------------------------------------------------------------------
|
//--------------------------------------------------------------------------------------------------
|
||||||
@@ -115,6 +120,7 @@ void RimReachCircleAnnotation::defineUiOrdering(QString uiConfigName, caf::PdmUi
|
|||||||
{
|
{
|
||||||
uiOrdering.add(&m_name);
|
uiOrdering.add(&m_name);
|
||||||
uiOrdering.add(&m_centerPointXyd);
|
uiOrdering.add(&m_centerPointXyd);
|
||||||
|
uiOrdering.add(&m_centerPointPickEnabled);
|
||||||
uiOrdering.add(&m_radius);
|
uiOrdering.add(&m_radius);
|
||||||
|
|
||||||
auto appearanceGroup = uiOrdering.addNewGroup("Appearance");
|
auto appearanceGroup = uiOrdering.addNewGroup("Appearance");
|
||||||
@@ -130,6 +136,15 @@ void RimReachCircleAnnotation::fieldChangedByUi(const caf::PdmFieldHandle* chang
|
|||||||
const QVariant& oldValue,
|
const QVariant& oldValue,
|
||||||
const QVariant& newValue)
|
const QVariant& newValue)
|
||||||
{
|
{
|
||||||
|
if (changedField == &m_centerPointXyd)
|
||||||
|
{
|
||||||
|
m_centerPointPickEnabled = false;
|
||||||
|
this->updateConnectedEditors();
|
||||||
|
}
|
||||||
|
if (changedField == &m_centerPointPickEnabled)
|
||||||
|
{
|
||||||
|
this->updateConnectedEditors();
|
||||||
|
}
|
||||||
RimAnnotationCollection* annColl = nullptr;
|
RimAnnotationCollection* annColl = nullptr;
|
||||||
this->firstAncestorOrThisOfTypeAsserted(annColl);
|
this->firstAncestorOrThisOfTypeAsserted(annColl);
|
||||||
|
|
||||||
@@ -161,13 +176,30 @@ void RimReachCircleAnnotation::defineEditorAttribute(const caf::PdmFieldHandle*
|
|||||||
{
|
{
|
||||||
if (field == &m_centerPointXyd)
|
if (field == &m_centerPointXyd)
|
||||||
{
|
{
|
||||||
caf::PdmUiVec3dEditorAttribute* attr = dynamic_cast<caf::PdmUiVec3dEditorAttribute*>(attribute);
|
auto* attr = dynamic_cast<caf::PdmUiPickableLineEditorAttribute*>(attribute);
|
||||||
if (attr)
|
if (attr)
|
||||||
{
|
{
|
||||||
attr->pickEventHandler = m_centerPointEventHandler;
|
attr->pickEventHandler = m_centerPointEventHandler;
|
||||||
|
attr->enablePicking = m_centerPointPickEnabled;
|
||||||
if (m_centerPointXyd().isZero())
|
if (m_centerPointXyd().isZero())
|
||||||
{
|
{
|
||||||
attr->startInPickingMode = true;
|
attr->enablePicking = true;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if (field == &m_centerPointPickEnabled)
|
||||||
|
{
|
||||||
|
auto* attr = dynamic_cast<caf::PdmUiPushButtonEditorAttribute*>(attribute);
|
||||||
|
if (attr)
|
||||||
|
{
|
||||||
|
if (m_centerPointPickEnabled)
|
||||||
|
{
|
||||||
|
attr->m_buttonText = "Stop";
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
attr->m_buttonText = "Pick";
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -76,6 +76,7 @@ private:
|
|||||||
caf::PdmField<bool> m_isActive;
|
caf::PdmField<bool> m_isActive;
|
||||||
|
|
||||||
caf::PdmField<Vec3d> m_centerPointXyd;
|
caf::PdmField<Vec3d> m_centerPointXyd;
|
||||||
|
caf::PdmField<bool> m_centerPointPickEnabled;
|
||||||
caf::PdmField<double> m_radius;
|
caf::PdmField<double> m_radius;
|
||||||
caf::PdmField<QString> m_name;
|
caf::PdmField<QString> m_name;
|
||||||
caf::PdmChildField<RimReachCircleLineAppearance*> m_appearance;
|
caf::PdmChildField<RimReachCircleLineAppearance*> m_appearance;
|
||||||
|
|||||||
@@ -29,9 +29,10 @@
|
|||||||
#include "AnnotationCommands/RicTextAnnotation3dEditor.h"
|
#include "AnnotationCommands/RicTextAnnotation3dEditor.h"
|
||||||
|
|
||||||
#include "cafCmdFeatureManager.h"
|
#include "cafCmdFeatureManager.h"
|
||||||
|
#include "cafPdmUiPushButtonEditor.h"
|
||||||
#include "cafPdmUiTextEditor.h"
|
#include "cafPdmUiTextEditor.h"
|
||||||
#include "cafPdmUiTreeOrdering.h"
|
#include "cafPdmUiTreeOrdering.h"
|
||||||
#include "cafPdmUiVec3dEditor.h"
|
#include "cafPdmUiPickableLineEditor.h"
|
||||||
|
|
||||||
#include <QAction>
|
#include <QAction>
|
||||||
#include <QPointer>
|
#include <QPointer>
|
||||||
@@ -48,9 +49,17 @@ RimTextAnnotation::RimTextAnnotation()
|
|||||||
this->setUi3dEditorTypeName(RicTextAnnotation3dEditor::uiEditorTypeName());
|
this->setUi3dEditorTypeName(RicTextAnnotation3dEditor::uiEditorTypeName());
|
||||||
|
|
||||||
CAF_PDM_InitField(&m_anchorPointXyd, "AnchorPointXyd", Vec3d::ZERO, "Anchor Point", "", "", "");
|
CAF_PDM_InitField(&m_anchorPointXyd, "AnchorPointXyd", Vec3d::ZERO, "Anchor Point", "", "", "");
|
||||||
m_anchorPointXyd.uiCapability()->setUiEditorTypeName(caf::PdmUiVec3dEditor::uiEditorTypeName());
|
m_anchorPointXyd.uiCapability()->setUiEditorTypeName(caf::PdmUiPickableLineEditor::uiEditorTypeName());
|
||||||
|
CAF_PDM_InitField(&m_anchorPointPickEnabledButtonField, "AnchorPointPick", true, "", "", "", "");
|
||||||
|
caf::PdmUiPushButtonEditor::configureEditorForField(&m_anchorPointPickEnabledButtonField);
|
||||||
|
m_anchorPointPickEnabledButtonField.uiCapability()->setUiLabelPosition(caf::PdmUiItemInfo::LabelPosType::HIDDEN);
|
||||||
|
|
||||||
CAF_PDM_InitField(&m_labelPointXyd, "LabelPointXyd", Vec3d::ZERO, "Label Point", "", "", "");
|
CAF_PDM_InitField(&m_labelPointXyd, "LabelPointXyd", Vec3d::ZERO, "Label Point", "", "", "");
|
||||||
m_labelPointXyd.uiCapability()->setUiEditorTypeName(caf::PdmUiVec3dEditor::uiEditorTypeName());
|
m_labelPointXyd.uiCapability()->setUiEditorTypeName(caf::PdmUiPickableLineEditor::uiEditorTypeName());
|
||||||
|
CAF_PDM_InitField(&m_labelPointPickEnabledButtonField, "LabelPointPick", false, "", "", "", "");
|
||||||
|
caf::PdmUiPushButtonEditor::configureEditorForField(&m_labelPointPickEnabledButtonField);
|
||||||
|
m_labelPointPickEnabledButtonField.uiCapability()->setUiLabelPosition(caf::PdmUiItemInfo::LabelPosType::HIDDEN);
|
||||||
|
|
||||||
CAF_PDM_InitField(&m_text, "Text", QString("(New text)"), "Text", "", "", "");
|
CAF_PDM_InitField(&m_text, "Text", QString("(New text)"), "Text", "", "", "");
|
||||||
m_text.uiCapability()->setUiEditorTypeName(caf::PdmUiTextEditor::uiEditorTypeName());
|
m_text.uiCapability()->setUiEditorTypeName(caf::PdmUiTextEditor::uiEditorTypeName());
|
||||||
|
|
||||||
@@ -67,8 +76,8 @@ RimTextAnnotation::RimTextAnnotation()
|
|||||||
m_nameProxy.uiCapability()->setUiReadOnly(true);
|
m_nameProxy.uiCapability()->setUiReadOnly(true);
|
||||||
m_nameProxy.xmlCapability()->disableIO();
|
m_nameProxy.xmlCapability()->disableIO();
|
||||||
|
|
||||||
m_anchorPointPickEventHandler.reset(new RicVec3dPickEventHandler(this, &m_anchorPointXyd));
|
m_anchorPointPickEventHandler.reset(new RicVec3dPickEventHandler(&m_anchorPointXyd));
|
||||||
m_labelPointPickEventHandler.reset(new RicVec3dPickEventHandler(this, &m_labelPointXyd));
|
m_labelPointPickEventHandler.reset(new RicVec3dPickEventHandler(&m_labelPointXyd));
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -140,7 +149,10 @@ const QString& RimTextAnnotation::text() const
|
|||||||
void RimTextAnnotation::defineUiOrdering(QString uiConfigName, caf::PdmUiOrdering& uiOrdering)
|
void RimTextAnnotation::defineUiOrdering(QString uiConfigName, caf::PdmUiOrdering& uiOrdering)
|
||||||
{
|
{
|
||||||
uiOrdering.add(&m_anchorPointXyd);
|
uiOrdering.add(&m_anchorPointXyd);
|
||||||
|
uiOrdering.add(&m_anchorPointPickEnabledButtonField, false);
|
||||||
uiOrdering.add(&m_labelPointXyd);
|
uiOrdering.add(&m_labelPointXyd);
|
||||||
|
uiOrdering.add(&m_labelPointPickEnabledButtonField, false);
|
||||||
|
|
||||||
uiOrdering.add(&m_text);
|
uiOrdering.add(&m_text);
|
||||||
|
|
||||||
auto appearanceGroup = uiOrdering.addNewGroup("Text Appearance");
|
auto appearanceGroup = uiOrdering.addNewGroup("Text Appearance");
|
||||||
@@ -156,15 +168,24 @@ void RimTextAnnotation::fieldChangedByUi(const caf::PdmFieldHandle* changedField
|
|||||||
const QVariant& oldValue,
|
const QVariant& oldValue,
|
||||||
const QVariant& newValue)
|
const QVariant& newValue)
|
||||||
{
|
{
|
||||||
if (changedField == &m_anchorPointXyd && m_labelPointXyd().isZero())
|
if (changedField == &m_anchorPointXyd)
|
||||||
{
|
{
|
||||||
m_labelPointXyd = m_anchorPointXyd();
|
m_anchorPointPickEnabledButtonField = false;
|
||||||
|
if (m_labelPointXyd().isZero())
|
||||||
|
{
|
||||||
|
m_labelPointXyd = m_anchorPointXyd;
|
||||||
|
}
|
||||||
|
this->updateConnectedEditors();
|
||||||
}
|
}
|
||||||
if (changedField == &m_labelPointXyd && m_anchorPointXyd().isZero())
|
if (changedField == &m_labelPointXyd)
|
||||||
{
|
{
|
||||||
m_anchorPointXyd = m_labelPointXyd();
|
m_labelPointPickEnabledButtonField = false;
|
||||||
|
this->updateConnectedEditors();
|
||||||
|
}
|
||||||
|
if (changedField == &m_anchorPointPickEnabledButtonField || changedField == &m_labelPointPickEnabledButtonField)
|
||||||
|
{
|
||||||
|
this->updateConnectedEditors();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
RimAnnotationCollectionBase* annColl = nullptr;
|
RimAnnotationCollectionBase* annColl = nullptr;
|
||||||
this->firstAncestorOrThisOfTypeAsserted(annColl);
|
this->firstAncestorOrThisOfTypeAsserted(annColl);
|
||||||
@@ -226,20 +247,36 @@ void RimTextAnnotation::defineEditorAttribute(const caf::PdmFieldHandle* field,
|
|||||||
QString uiConfigName,
|
QString uiConfigName,
|
||||||
caf::PdmUiEditorAttribute* attribute)
|
caf::PdmUiEditorAttribute* attribute)
|
||||||
{
|
{
|
||||||
caf::PdmUiVec3dEditorAttribute* attr = dynamic_cast<caf::PdmUiVec3dEditorAttribute*>(attribute);
|
caf::PdmUiPickableLineEditorAttribute* attr = dynamic_cast<caf::PdmUiPickableLineEditorAttribute*>(attribute);
|
||||||
|
|
||||||
if (attr && field == &m_anchorPointXyd)
|
if (attr && field == &m_anchorPointXyd)
|
||||||
{
|
{
|
||||||
attr->pickEventHandler = m_anchorPointPickEventHandler;
|
attr->pickEventHandler = m_anchorPointPickEventHandler;
|
||||||
if (m_anchorPointXyd().isZero())
|
attr->enablePicking = m_anchorPointPickEnabledButtonField;
|
||||||
{
|
|
||||||
attr->startInPickingMode = true;
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
else if (attr && field == &m_labelPointXyd)
|
else if (attr && field == &m_labelPointXyd)
|
||||||
{
|
{
|
||||||
attr->pickEventHandler = m_labelPointPickEventHandler;
|
attr->pickEventHandler = m_labelPointPickEventHandler;
|
||||||
|
attr->enablePicking = m_labelPointPickEnabledButtonField;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (field == &m_anchorPointPickEnabledButtonField || field == &m_labelPointPickEnabledButtonField)
|
||||||
|
{
|
||||||
|
auto* pbAttribute = dynamic_cast<caf::PdmUiPushButtonEditorAttribute*>(attribute);
|
||||||
|
if (pbAttribute)
|
||||||
|
{
|
||||||
|
auto boolField = static_cast<const caf::PdmField<bool>*>(field);
|
||||||
|
if (boolField->v())
|
||||||
|
{
|
||||||
|
pbAttribute->m_buttonText = "Stop";
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
pbAttribute->m_buttonText = "Pick";
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
//--------------------------------------------------------------------------------------------------
|
//--------------------------------------------------------------------------------------------------
|
||||||
|
|||||||
@@ -84,7 +84,9 @@ private:
|
|||||||
QString extractNameFromText() const;
|
QString extractNameFromText() const;
|
||||||
|
|
||||||
caf::PdmField<Vec3d> m_anchorPointXyd;
|
caf::PdmField<Vec3d> m_anchorPointXyd;
|
||||||
|
caf::PdmField<bool> m_anchorPointPickEnabledButtonField;
|
||||||
caf::PdmField<Vec3d> m_labelPointXyd;
|
caf::PdmField<Vec3d> m_labelPointXyd;
|
||||||
|
caf::PdmField<bool> m_labelPointPickEnabledButtonField;
|
||||||
caf::PdmField<QString> m_text;
|
caf::PdmField<QString> m_text;
|
||||||
caf::PdmField<bool> m_isActive;
|
caf::PdmField<bool> m_isActive;
|
||||||
|
|
||||||
|
|||||||
@@ -209,14 +209,6 @@ void RimUserDefinedPolylinesAnnotation::updateVisualization()
|
|||||||
void RimUserDefinedPolylinesAnnotation::enablePicking(bool enable)
|
void RimUserDefinedPolylinesAnnotation::enablePicking(bool enable)
|
||||||
{
|
{
|
||||||
m_enablePicking = enable;
|
m_enablePicking = enable;
|
||||||
if (enable)
|
|
||||||
{
|
|
||||||
RiuViewerCommands::setPickEventHandler(m_pickTargetsEventHandler);
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
RiuViewerCommands::removePickEventHandlerIfActive(m_pickTargetsEventHandler);
|
|
||||||
}
|
|
||||||
updateConnectedEditors();
|
updateConnectedEditors();
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -259,7 +251,7 @@ void RimUserDefinedPolylinesAnnotation::fieldChangedByUi(const caf::PdmFieldHand
|
|||||||
{
|
{
|
||||||
if (changedField == &m_enablePicking)
|
if (changedField == &m_enablePicking)
|
||||||
{
|
{
|
||||||
enablePicking(m_enablePicking);
|
this->updateConnectedEditors();
|
||||||
}
|
}
|
||||||
else if (changedField == &m_showLines)
|
else if (changedField == &m_showLines)
|
||||||
{
|
{
|
||||||
@@ -273,6 +265,19 @@ void RimUserDefinedPolylinesAnnotation::fieldChangedByUi(const caf::PdmFieldHand
|
|||||||
updateVisualization();
|
updateVisualization();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
//--------------------------------------------------------------------------------------------------
|
||||||
|
///
|
||||||
|
//--------------------------------------------------------------------------------------------------
|
||||||
|
void RimUserDefinedPolylinesAnnotation::defineObjectEditorAttribute(QString uiConfigName, caf::PdmUiEditorAttribute* attribute)
|
||||||
|
{
|
||||||
|
RicPolyline3dEditorAttribute* attrib = dynamic_cast<RicPolyline3dEditorAttribute*>(attribute);
|
||||||
|
if (attrib)
|
||||||
|
{
|
||||||
|
attrib->pickEventHandler = m_pickTargetsEventHandler;
|
||||||
|
attrib->enablePicking = m_enablePicking;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
//--------------------------------------------------------------------------------------------------
|
//--------------------------------------------------------------------------------------------------
|
||||||
///
|
///
|
||||||
//--------------------------------------------------------------------------------------------------
|
//--------------------------------------------------------------------------------------------------
|
||||||
|
|||||||
@@ -22,6 +22,8 @@
|
|||||||
#include "cafPdmFieldCvfVec3d.h"
|
#include "cafPdmFieldCvfVec3d.h"
|
||||||
#include "cafPdmChildArrayField.h"
|
#include "cafPdmChildArrayField.h"
|
||||||
|
|
||||||
|
#include <memory>
|
||||||
|
|
||||||
class RicPolylineTargetsPickEventHandler;
|
class RicPolylineTargetsPickEventHandler;
|
||||||
class RimPolylineTarget;
|
class RimPolylineTarget;
|
||||||
|
|
||||||
@@ -59,6 +61,7 @@ protected:
|
|||||||
void defineUiOrdering(QString uiConfigName, caf::PdmUiOrdering& uiOrdering) override;
|
void defineUiOrdering(QString uiConfigName, caf::PdmUiOrdering& uiOrdering) override;
|
||||||
void defineUiTreeOrdering(caf::PdmUiTreeOrdering& uiTreeOrdering, QString uiConfigName) override;
|
void defineUiTreeOrdering(caf::PdmUiTreeOrdering& uiTreeOrdering, QString uiConfigName) override;
|
||||||
void fieldChangedByUi(const caf::PdmFieldHandle* changedField, const QVariant& oldValue, const QVariant& newValue) override;
|
void fieldChangedByUi(const caf::PdmFieldHandle* changedField, const QVariant& oldValue, const QVariant& newValue) override;
|
||||||
|
void defineObjectEditorAttribute(QString uiConfigName, caf::PdmUiEditorAttribute* attribute) override;
|
||||||
|
|
||||||
private:
|
private:
|
||||||
void defineCustomContextMenu(const caf::PdmFieldHandle* fieldNeedingMenu, QMenu* menu, QWidget* fieldEditorWidget) override;
|
void defineCustomContextMenu(const caf::PdmFieldHandle* fieldNeedingMenu, QMenu* menu, QWidget* fieldEditorWidget) override;
|
||||||
@@ -71,7 +74,8 @@ private:
|
|||||||
caf::PdmField<QString> m_name;
|
caf::PdmField<QString> m_name;
|
||||||
caf::PdmField<bool> m_enablePicking;
|
caf::PdmField<bool> m_enablePicking;
|
||||||
caf::PdmChildArrayField<RimPolylineTarget*> m_targets;
|
caf::PdmChildArrayField<RimPolylineTarget*> m_targets;
|
||||||
RicPolylineTargetsPickEventHandler* m_pickTargetsEventHandler;
|
|
||||||
|
std::shared_ptr<RicPolylineTargetsPickEventHandler> m_pickTargetsEventHandler;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
||||||
|
|||||||
@@ -100,11 +100,6 @@ RimWellPathGeometryDef::RimWellPathGeometryDef()
|
|||||||
//--------------------------------------------------------------------------------------------------
|
//--------------------------------------------------------------------------------------------------
|
||||||
RimWellPathGeometryDef::~RimWellPathGeometryDef()
|
RimWellPathGeometryDef::~RimWellPathGeometryDef()
|
||||||
{
|
{
|
||||||
RiuViewerCommands::removePickEventHandlerIfActive(m_pickTargetsEventHandler);
|
|
||||||
|
|
||||||
delete m_pickTargetsEventHandler;
|
|
||||||
|
|
||||||
m_pickTargetsEventHandler = nullptr;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
//--------------------------------------------------------------------------------------------------
|
//--------------------------------------------------------------------------------------------------
|
||||||
@@ -290,18 +285,8 @@ const RimWellPathTarget* RimWellPathGeometryDef::lastActiveTarget() const
|
|||||||
//--------------------------------------------------------------------------------------------------
|
//--------------------------------------------------------------------------------------------------
|
||||||
void RimWellPathGeometryDef::enableTargetPointPicking(bool isEnabling)
|
void RimWellPathGeometryDef::enableTargetPointPicking(bool isEnabling)
|
||||||
{
|
{
|
||||||
if (isEnabling)
|
m_pickPointsEnabled = isEnabling;
|
||||||
{
|
this->updateConnectedEditors();
|
||||||
m_pickPointsEnabled = true;
|
|
||||||
RiuViewerCommands::setPickEventHandler(m_pickTargetsEventHandler);
|
|
||||||
updateConnectedEditors();
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
RiuViewerCommands::removePickEventHandlerIfActive(m_pickTargetsEventHandler);
|
|
||||||
m_pickPointsEnabled = false;
|
|
||||||
updateConnectedEditors();
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
//--------------------------------------------------------------------------------------------------
|
//--------------------------------------------------------------------------------------------------
|
||||||
@@ -333,7 +318,7 @@ void RimWellPathGeometryDef::fieldChangedByUi(const caf::PdmFieldHandle* changed
|
|||||||
}
|
}
|
||||||
else if (changedField == &m_pickPointsEnabled)
|
else if (changedField == &m_pickPointsEnabled)
|
||||||
{
|
{
|
||||||
enableTargetPointPicking(m_pickPointsEnabled);
|
this->updateConnectedEditors();
|
||||||
}
|
}
|
||||||
|
|
||||||
updateWellPathVisualization();
|
updateWellPathVisualization();
|
||||||
@@ -640,6 +625,19 @@ void RimWellPathGeometryDef::defineEditorAttribute(const caf::PdmFieldHandle* fi
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
//--------------------------------------------------------------------------------------------------
|
||||||
|
///
|
||||||
|
//--------------------------------------------------------------------------------------------------
|
||||||
|
void RimWellPathGeometryDef::defineObjectEditorAttribute(QString uiConfigName, caf::PdmUiEditorAttribute* attribute)
|
||||||
|
{
|
||||||
|
RicWellPathGeometry3dEditorAttribute* attrib = dynamic_cast<RicWellPathGeometry3dEditorAttribute*>(attribute);
|
||||||
|
if (attrib)
|
||||||
|
{
|
||||||
|
attrib->pickEventHandler = m_pickTargetsEventHandler;
|
||||||
|
attrib->enablePicking = m_pickPointsEnabled;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
//--------------------------------------------------------------------------------------------------
|
//--------------------------------------------------------------------------------------------------
|
||||||
///
|
///
|
||||||
//--------------------------------------------------------------------------------------------------
|
//--------------------------------------------------------------------------------------------------
|
||||||
|
|||||||
@@ -80,6 +80,9 @@ protected:
|
|||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
virtual void defineObjectEditorAttribute(QString uiConfigName, caf::PdmUiEditorAttribute* attribute) override;
|
||||||
|
|
||||||
private:
|
private:
|
||||||
void fieldChangedByUi(const caf::PdmFieldHandle* changedField,
|
void fieldChangedByUi(const caf::PdmFieldHandle* changedField,
|
||||||
const QVariant& oldValue,
|
const QVariant& oldValue,
|
||||||
@@ -101,11 +104,12 @@ private:
|
|||||||
caf::PdmChildArrayField<RimWellPathTarget*> m_wellTargets;
|
caf::PdmChildArrayField<RimWellPathTarget*> m_wellTargets;
|
||||||
|
|
||||||
caf::PdmField< bool > m_pickPointsEnabled;
|
caf::PdmField< bool > m_pickPointsEnabled;
|
||||||
RicCreateWellTargetsPickEventHandler* m_pickTargetsEventHandler;
|
|
||||||
|
|
||||||
// Unused for now. Remove when dust settles
|
// TODO: Unused for now. Remove when dust settles
|
||||||
|
|
||||||
caf::PdmField<caf::AppEnum<WellStartType> > m_wellStartType;
|
caf::PdmField<caf::AppEnum<WellStartType> > m_wellStartType;
|
||||||
caf::PdmField<double> m_kickoffDepthOrMD;
|
caf::PdmField<double> m_kickoffDepthOrMD;
|
||||||
caf::PdmPtrField<RimWellPath*> m_parentWell;
|
caf::PdmPtrField<RimWellPath*> m_parentWell;
|
||||||
|
|
||||||
|
std::shared_ptr<RicCreateWellTargetsPickEventHandler> m_pickTargetsEventHandler;
|
||||||
};
|
};
|
||||||
|
|||||||
@@ -10,19 +10,7 @@ else()
|
|||||||
include(${QT_USE_FILE})
|
include(${QT_USE_FILE})
|
||||||
endif(CAF_USE_QT5)
|
endif(CAF_USE_QT5)
|
||||||
|
|
||||||
|
|
||||||
# These headers need to go through Qt's MOC compiler
|
|
||||||
set (MOC_HEADER_FILES
|
|
||||||
cafPdmUiVec3dEditor.h
|
|
||||||
)
|
|
||||||
|
|
||||||
# Run MOC on the headers
|
|
||||||
add_definitions(-DCVF_USING_CMAKE)
|
add_definitions(-DCVF_USING_CMAKE)
|
||||||
if (CAF_USE_QT5)
|
|
||||||
qt5_wrap_cpp(MOC_SOURCE_FILES ${MOC_HEADER_FILES} )
|
|
||||||
else()
|
|
||||||
qt4_wrap_cpp(MOC_SOURCE_FILES ${MOC_HEADER_FILES} )
|
|
||||||
endif(CAF_USE_QT5)
|
|
||||||
|
|
||||||
add_library( ${PROJECT_NAME}
|
add_library( ${PROJECT_NAME}
|
||||||
cafPdmCoreColor3f.h
|
cafPdmCoreColor3f.h
|
||||||
@@ -45,10 +33,6 @@ add_library( ${PROJECT_NAME}
|
|||||||
cafPdmXmlMat4d.cpp
|
cafPdmXmlMat4d.cpp
|
||||||
cafPdmXmlMat4d.h
|
cafPdmXmlMat4d.h
|
||||||
cafPdmFieldCvfMat4d.h
|
cafPdmFieldCvfMat4d.h
|
||||||
cafPdmUiVec3dEditor.cpp
|
|
||||||
|
|
||||||
${MOC_HEADER_FILES}
|
|
||||||
${MOC_SOURCE_FILES}
|
|
||||||
)
|
)
|
||||||
|
|
||||||
target_include_directories(${PROJECT_NAME}
|
target_include_directories(${PROJECT_NAME}
|
||||||
|
|||||||
@@ -1,239 +0,0 @@
|
|||||||
//##################################################################################################
|
|
||||||
//
|
|
||||||
// Custom Visualization Core library
|
|
||||||
// Copyright (C) 2019- Ceetron Solutions AS
|
|
||||||
//
|
|
||||||
// This library may be used under the terms of either the GNU General Public License or
|
|
||||||
// the GNU Lesser General Public License as follows:
|
|
||||||
//
|
|
||||||
// GNU General Public License Usage
|
|
||||||
// This library is free software: you can redistribute it and/or modify
|
|
||||||
// it under the terms of the GNU General Public License as published by
|
|
||||||
// the Free Software Foundation, either version 3 of the License, or
|
|
||||||
// (at your option) any later version.
|
|
||||||
//
|
|
||||||
// This library is distributed in the hope that it will be useful, but WITHOUT ANY
|
|
||||||
// WARRANTY; without even the implied warranty of MERCHANTABILITY or
|
|
||||||
// FITNESS FOR A PARTICULAR PURPOSE.
|
|
||||||
//
|
|
||||||
// See the GNU General Public License at <<http://www.gnu.org/licenses/gpl.html>>
|
|
||||||
// for more details.
|
|
||||||
//
|
|
||||||
// GNU Lesser General Public License Usage
|
|
||||||
// This library is free software; you can redistribute it and/or modify
|
|
||||||
// it under the terms of the GNU Lesser General Public License as published by
|
|
||||||
// the Free Software Foundation; either version 2.1 of the License, or
|
|
||||||
// (at your option) any later version.
|
|
||||||
//
|
|
||||||
// This library is distributed in the hope that it will be useful, but WITHOUT ANY
|
|
||||||
// WARRANTY; without even the implied warranty of MERCHANTABILITY or
|
|
||||||
// FITNESS FOR A PARTICULAR PURPOSE.
|
|
||||||
//
|
|
||||||
// See the GNU Lesser General Public License at <<http://www.gnu.org/licenses/lgpl-2.1.html>>
|
|
||||||
// for more details.
|
|
||||||
//
|
|
||||||
//##################################################################################################
|
|
||||||
#include "cafPdmUiVec3dEditor.h"
|
|
||||||
|
|
||||||
#include "cafFactory.h"
|
|
||||||
#include "cafPdmField.h"
|
|
||||||
#include "cafPdmObject.h"
|
|
||||||
#include "cafPdmUiDefaultObjectEditor.h"
|
|
||||||
#include "cafPdmUiFieldEditorHandle.h"
|
|
||||||
#include "cafPdmUiOrdering.h"
|
|
||||||
#include "cafPdmUniqueIdValidator.h"
|
|
||||||
#include "cafPickEventHandler.h"
|
|
||||||
#include "cafSelectionManager.h"
|
|
||||||
|
|
||||||
#include <QAction>
|
|
||||||
#include <QDoubleValidator>
|
|
||||||
#include <QHBoxLayout>
|
|
||||||
#include <QPushButton>
|
|
||||||
|
|
||||||
using namespace caf;
|
|
||||||
|
|
||||||
//--------------------------------------------------------------------------------------------------
|
|
||||||
///
|
|
||||||
//--------------------------------------------------------------------------------------------------
|
|
||||||
QWidget* PdmUiVec3dEditor::createEditorWidget(QWidget* parent)
|
|
||||||
{
|
|
||||||
QWidget* containerWidget = new QWidget(parent);
|
|
||||||
|
|
||||||
QHBoxLayout* layout = new QHBoxLayout();
|
|
||||||
layout->setMargin(0);
|
|
||||||
containerWidget->setLayout(layout);
|
|
||||||
|
|
||||||
m_lineEdit = new QLineEdit(containerWidget);
|
|
||||||
|
|
||||||
connect(m_lineEdit, SIGNAL(editingFinished()), this, SLOT(slotEditingFinished()));
|
|
||||||
|
|
||||||
m_pickButton = new QPushButton(containerWidget);
|
|
||||||
m_pickButton->setText("Pick");
|
|
||||||
m_pickButton->setCheckable(true);
|
|
||||||
|
|
||||||
layout->addWidget(m_lineEdit);
|
|
||||||
layout->addWidget(m_pickButton);
|
|
||||||
|
|
||||||
connect(m_pickButton, SIGNAL(toggled(bool)), this, SLOT(pickButtonToggled(bool)));
|
|
||||||
return containerWidget;
|
|
||||||
}
|
|
||||||
|
|
||||||
//--------------------------------------------------------------------------------------------------
|
|
||||||
///
|
|
||||||
//--------------------------------------------------------------------------------------------------
|
|
||||||
QWidget* PdmUiVec3dEditor::createLabelWidget(QWidget* parent)
|
|
||||||
{
|
|
||||||
m_label = new QLabel(parent);
|
|
||||||
return m_label;
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
//--------------------------------------------------------------------------------------------------
|
|
||||||
///
|
|
||||||
//--------------------------------------------------------------------------------------------------
|
|
||||||
caf::PdmUiVec3dEditor::~PdmUiVec3dEditor()
|
|
||||||
{
|
|
||||||
if (pickEventHandler())
|
|
||||||
{
|
|
||||||
pickEventHandler()->unregisterAsPickEventHandler();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
//--------------------------------------------------------------------------------------------------
|
|
||||||
///
|
|
||||||
//--------------------------------------------------------------------------------------------------
|
|
||||||
void caf::PdmUiVec3dEditor::configureAndUpdateUi(const QString& uiConfigName)
|
|
||||||
{
|
|
||||||
if (!m_label.isNull())
|
|
||||||
{
|
|
||||||
PdmUiFieldEditorHandle::updateLabelFromField(m_label, uiConfigName);
|
|
||||||
}
|
|
||||||
|
|
||||||
PdmUiVec3dEditorAttribute attributes;
|
|
||||||
caf::PdmUiObjectHandle* uiObject = uiObj(uiField()->fieldHandle()->ownerObject());
|
|
||||||
if (uiObject)
|
|
||||||
{
|
|
||||||
uiObject->editorAttribute(uiField()->fieldHandle(), uiConfigName, &attributes);
|
|
||||||
}
|
|
||||||
m_attribute = attributes;
|
|
||||||
|
|
||||||
bool isReadOnly = uiField()->isUiReadOnly(uiConfigName);
|
|
||||||
|
|
||||||
m_pickButton->setVisible(attributes.pickEventHandler != nullptr);
|
|
||||||
m_pickButton->setEnabled(!isReadOnly);
|
|
||||||
|
|
||||||
m_lineEdit->setText(uiField()->uiValue().toString());
|
|
||||||
m_lineEdit->setReadOnly(isReadOnly);
|
|
||||||
if (isReadOnly)
|
|
||||||
{
|
|
||||||
m_lineEdit->setStyleSheet("QLineEdit {"
|
|
||||||
"color: #808080;"
|
|
||||||
"background-color: #F0F0F0;}");
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
m_lineEdit->setStyleSheet("");
|
|
||||||
}
|
|
||||||
pickButtonToggled(m_attribute.startInPickingMode);
|
|
||||||
|
|
||||||
m_lineEdit->setToolTip(uiField()->uiToolTip(uiConfigName));
|
|
||||||
}
|
|
||||||
|
|
||||||
//--------------------------------------------------------------------------------------------------
|
|
||||||
///
|
|
||||||
//--------------------------------------------------------------------------------------------------
|
|
||||||
QMargins caf::PdmUiVec3dEditor::calculateLabelContentMargins() const
|
|
||||||
{
|
|
||||||
QSize editorSize = m_lineEdit->sizeHint();
|
|
||||||
QSize labelSize = m_label->sizeHint();
|
|
||||||
int heightDiff = editorSize.height() - labelSize.height();
|
|
||||||
|
|
||||||
QMargins contentMargins = m_label->contentsMargins();
|
|
||||||
if (heightDiff > 0)
|
|
||||||
{
|
|
||||||
contentMargins.setTop(contentMargins.top() + heightDiff / 2);
|
|
||||||
contentMargins.setBottom(contentMargins.bottom() + heightDiff / 2);
|
|
||||||
}
|
|
||||||
return contentMargins;
|
|
||||||
}
|
|
||||||
|
|
||||||
//--------------------------------------------------------------------------------------------------
|
|
||||||
///
|
|
||||||
//--------------------------------------------------------------------------------------------------
|
|
||||||
void caf::PdmUiVec3dEditor::slotEditingFinished()
|
|
||||||
{
|
|
||||||
QString textValue = m_lineEdit->text();
|
|
||||||
QVariant v = textValue;
|
|
||||||
this->setValueToField(v);
|
|
||||||
}
|
|
||||||
|
|
||||||
//--------------------------------------------------------------------------------------------------
|
|
||||||
///
|
|
||||||
//--------------------------------------------------------------------------------------------------
|
|
||||||
void caf::PdmUiVec3dEditor::pickButtonToggled(bool checked)
|
|
||||||
{
|
|
||||||
if (!pickEventHandler())
|
|
||||||
{
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
if (checked)
|
|
||||||
{
|
|
||||||
m_lineEdit->setStyleSheet("QLineEdit {"
|
|
||||||
"color: #000000;"
|
|
||||||
"background-color: #FFDCFF;}");
|
|
||||||
m_pickButton->setText("Stop Picking");
|
|
||||||
pickEventHandler()->registerAsPickEventHandler();
|
|
||||||
m_pickButton->setChecked(true);
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
m_lineEdit->setStyleSheet("");
|
|
||||||
m_pickButton->setText("Pick");
|
|
||||||
pickEventHandler()->unregisterAsPickEventHandler();
|
|
||||||
m_pickButton->setChecked(false);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
//--------------------------------------------------------------------------------------------------
|
|
||||||
///
|
|
||||||
//--------------------------------------------------------------------------------------------------
|
|
||||||
bool caf::PdmUiVec3dEditor::isMultipleFieldsWithSameKeywordSelected(PdmFieldHandle* editorField) const
|
|
||||||
{
|
|
||||||
std::vector<PdmFieldHandle*> fieldsToUpdate;
|
|
||||||
fieldsToUpdate.push_back(editorField);
|
|
||||||
|
|
||||||
// For current selection, find all fields with same keyword
|
|
||||||
std::vector<PdmUiItem*> items;
|
|
||||||
SelectionManager::instance()->selectedItems(items, SelectionManager::FIRST_LEVEL);
|
|
||||||
|
|
||||||
for (size_t i = 0; i < items.size(); i++)
|
|
||||||
{
|
|
||||||
PdmUiFieldHandle* uiField = dynamic_cast<PdmUiFieldHandle*>(items[i]);
|
|
||||||
if (!uiField) continue;
|
|
||||||
|
|
||||||
PdmFieldHandle* field = uiField->fieldHandle();
|
|
||||||
if (field && field != editorField && field->keyword() == editorField->keyword())
|
|
||||||
{
|
|
||||||
fieldsToUpdate.push_back(field);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
if (fieldsToUpdate.size() > 1)
|
|
||||||
{
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
|
|
||||||
//--------------------------------------------------------------------------------------------------
|
|
||||||
///
|
|
||||||
//--------------------------------------------------------------------------------------------------
|
|
||||||
caf::PickEventHandler* caf::PdmUiVec3dEditor::pickEventHandler()
|
|
||||||
{
|
|
||||||
return m_attribute.pickEventHandler.get();
|
|
||||||
}
|
|
||||||
|
|
||||||
// Define at this location to avoid duplicate symbol definitions in 'cafPdmUiDefaultObjectEditor.cpp' in a cotire build. The
|
|
||||||
// variables defined by the macro are prefixed by line numbers causing a crash if the macro is defined at the same line number.
|
|
||||||
CAF_PDM_UI_FIELD_EDITOR_SOURCE_INIT(PdmUiVec3dEditor);
|
|
||||||
@@ -50,6 +50,7 @@ set (MOC_HEADER_FILES
|
|||||||
cafPdmUiDoubleValueEditor.h
|
cafPdmUiDoubleValueEditor.h
|
||||||
cafPdmUniqueIdValidator.h
|
cafPdmUniqueIdValidator.h
|
||||||
cafPdmDoubleStringValidator.h
|
cafPdmDoubleStringValidator.h
|
||||||
|
cafPdmUiPickableLineEditor.h
|
||||||
)
|
)
|
||||||
|
|
||||||
if ( NOT CMAKE_AUTOMOC )
|
if ( NOT CMAKE_AUTOMOC )
|
||||||
@@ -155,7 +156,7 @@ set( PROJECT_FILES
|
|||||||
cafPdmUniqueIdValidator.cpp
|
cafPdmUniqueIdValidator.cpp
|
||||||
cafPdmDoubleStringValidator.cpp
|
cafPdmDoubleStringValidator.cpp
|
||||||
cafPickEventHandler.h
|
cafPickEventHandler.h
|
||||||
cafPickEventHandler.cpp
|
cafPdmUiPickableLineEditor.cpp
|
||||||
)
|
)
|
||||||
|
|
||||||
add_library( ${PROJECT_NAME}
|
add_library( ${PROJECT_NAME}
|
||||||
|
|||||||
@@ -116,7 +116,7 @@ protected slots:
|
|||||||
private:
|
private:
|
||||||
bool isMultipleFieldsWithSameKeywordSelected(PdmFieldHandle* editorField) const;
|
bool isMultipleFieldsWithSameKeywordSelected(PdmFieldHandle* editorField) const;
|
||||||
|
|
||||||
private:
|
protected:
|
||||||
QPointer<PdmUiLineEdit> m_lineEdit;
|
QPointer<PdmUiLineEdit> m_lineEdit;
|
||||||
QPointer<QLabel> m_label;
|
QPointer<QLabel> m_label;
|
||||||
|
|
||||||
|
|||||||
@@ -1,7 +1,7 @@
|
|||||||
//##################################################################################################
|
//##################################################################################################
|
||||||
//
|
//
|
||||||
// Custom Visualization Core library
|
// Custom Visualization Core library
|
||||||
// Copyright (C) 2019- Ceetron Solution AS
|
// Copyright (C) 2019- Ceetron Solutions AS
|
||||||
//
|
//
|
||||||
// This library may be used under the terms of either the GNU General Public License or
|
// This library may be used under the terms of either the GNU General Public License or
|
||||||
// the GNU Lesser General Public License as follows:
|
// the GNU Lesser General Public License as follows:
|
||||||
@@ -33,12 +33,59 @@
|
|||||||
// for more details.
|
// for more details.
|
||||||
//
|
//
|
||||||
//##################################################################################################
|
//##################################################################################################
|
||||||
|
#include "cafPdmUiPickableLineEditor.h"
|
||||||
|
|
||||||
|
#include "cafPdmField.h"
|
||||||
|
#include "cafPdmObject.h"
|
||||||
|
#include "cafPdmUiDefaultObjectEditor.h"
|
||||||
|
#include "cafPdmUiFieldEditorHandle.h"
|
||||||
#include "cafPickEventHandler.h"
|
#include "cafPickEventHandler.h"
|
||||||
|
|
||||||
|
using namespace caf;
|
||||||
|
|
||||||
//--------------------------------------------------------------------------------------------------
|
//--------------------------------------------------------------------------------------------------
|
||||||
///
|
///
|
||||||
//--------------------------------------------------------------------------------------------------
|
//--------------------------------------------------------------------------------------------------
|
||||||
bool caf::PickEventHandler::isObjectBeingModified(const PdmObjectHandle* object) const
|
caf::PdmUiPickableLineEditor::~PdmUiPickableLineEditor()
|
||||||
{
|
{
|
||||||
return m_objectBeingModified == object;
|
if (m_attribute.pickEventHandler)
|
||||||
|
{
|
||||||
|
m_attribute.pickEventHandler->unregisterAsPickEventHandler();
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
//--------------------------------------------------------------------------------------------------
|
||||||
|
///
|
||||||
|
//--------------------------------------------------------------------------------------------------
|
||||||
|
void caf::PdmUiPickableLineEditor::configureAndUpdateUi(const QString& uiConfigName)
|
||||||
|
{
|
||||||
|
PdmUiLineEditor::configureAndUpdateUi(uiConfigName);
|
||||||
|
|
||||||
|
caf::PdmUiObjectHandle* uiObject = uiObj(uiField()->fieldHandle()->ownerObject());
|
||||||
|
if (uiObject)
|
||||||
|
{
|
||||||
|
uiObject->editorAttribute(uiField()->fieldHandle(), uiConfigName, &m_attribute);
|
||||||
|
}
|
||||||
|
|
||||||
|
if (m_attribute.pickEventHandler)
|
||||||
|
{
|
||||||
|
if (m_attribute.enablePicking)
|
||||||
|
{
|
||||||
|
m_attribute.pickEventHandler->registerAsPickEventHandler();
|
||||||
|
m_lineEdit->setStyleSheet("QLineEdit {"
|
||||||
|
"color: #000000;"
|
||||||
|
"background-color: #FFDCFF;}");
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
m_attribute.pickEventHandler->unregisterAsPickEventHandler();
|
||||||
|
m_lineEdit->setStyleSheet("");
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
m_lineEdit->setToolTip(uiField()->uiToolTip(uiConfigName));
|
||||||
|
}
|
||||||
|
|
||||||
|
// Define at this location to avoid duplicate symbol definitions in 'cafPdmUiDefaultObjectEditor.cpp' in a cotire build. The
|
||||||
|
// variables defined by the macro are prefixed by line numbers causing a crash if the macro is defined at the same line number.
|
||||||
|
CAF_PDM_UI_FIELD_EDITOR_SOURCE_INIT(PdmUiPickableLineEditor);
|
||||||
@@ -36,15 +36,8 @@
|
|||||||
#pragma once
|
#pragma once
|
||||||
|
|
||||||
#include "cafPdmUiLineEditor.h"
|
#include "cafPdmUiLineEditor.h"
|
||||||
#include "cafPdmCoreVec3d.h"
|
|
||||||
|
|
||||||
#include "cvfAssert.h"
|
|
||||||
#include "cvfVector3.h"
|
|
||||||
|
|
||||||
#include <memory>
|
#include <memory>
|
||||||
#include <vector>
|
|
||||||
|
|
||||||
class QPushButton;
|
|
||||||
|
|
||||||
namespace caf
|
namespace caf
|
||||||
{
|
{
|
||||||
@@ -53,46 +46,33 @@ class PickEventHandler;
|
|||||||
//==================================================================================================
|
//==================================================================================================
|
||||||
///
|
///
|
||||||
//==================================================================================================
|
//==================================================================================================
|
||||||
class PdmUiVec3dEditorAttribute : public PdmUiEditorAttribute
|
class PdmUiPickableLineEditorAttribute : public PdmUiEditorAttribute
|
||||||
{
|
{
|
||||||
public:
|
public:
|
||||||
PdmUiVec3dEditorAttribute() : startInPickingMode(false) {}
|
PdmUiPickableLineEditorAttribute() : enablePicking(false) {}
|
||||||
|
|
||||||
public:
|
public:
|
||||||
bool startInPickingMode;
|
bool enablePicking;
|
||||||
std::shared_ptr<PickEventHandler> pickEventHandler;
|
std::shared_ptr<PickEventHandler> pickEventHandler;
|
||||||
};
|
};
|
||||||
|
|
||||||
//--------------------------------------------------------------------------------------------------
|
//--------------------------------------------------------------------------------------------------
|
||||||
///
|
///
|
||||||
//--------------------------------------------------------------------------------------------------
|
//--------------------------------------------------------------------------------------------------
|
||||||
class PdmUiVec3dEditor : public PdmUiFieldEditorHandle
|
class PdmUiPickableLineEditor : public PdmUiLineEditor
|
||||||
{
|
{
|
||||||
Q_OBJECT
|
Q_OBJECT
|
||||||
CAF_PDM_UI_FIELD_EDITOR_HEADER_INIT;
|
CAF_PDM_UI_FIELD_EDITOR_HEADER_INIT;
|
||||||
|
|
||||||
public:
|
public:
|
||||||
PdmUiVec3dEditor() {}
|
PdmUiPickableLineEditor() {}
|
||||||
~PdmUiVec3dEditor() override;
|
~PdmUiPickableLineEditor() override;
|
||||||
|
|
||||||
protected:
|
protected:
|
||||||
QWidget* createEditorWidget(QWidget* parent) override;
|
void configureAndUpdateUi(const QString& uiConfigName) override;
|
||||||
QWidget* createLabelWidget(QWidget* parent) override;
|
|
||||||
void configureAndUpdateUi(const QString& uiConfigName) override;
|
|
||||||
QMargins calculateLabelContentMargins() const override;
|
|
||||||
|
|
||||||
protected slots:
|
|
||||||
void slotEditingFinished();
|
|
||||||
void pickButtonToggled(bool checked);
|
|
||||||
private:
|
private:
|
||||||
bool isMultipleFieldsWithSameKeywordSelected(PdmFieldHandle* editorField) const;
|
PdmUiPickableLineEditorAttribute m_attribute;
|
||||||
PickEventHandler* pickEventHandler();
|
|
||||||
private:
|
|
||||||
QPointer<QLineEdit> m_lineEdit;
|
|
||||||
QPointer<QPushButton> m_pickButton;
|
|
||||||
QPointer<QLabel> m_label;
|
|
||||||
|
|
||||||
PdmUiVec3dEditorAttribute m_attribute;
|
|
||||||
};
|
};
|
||||||
|
|
||||||
} // end namespace caf
|
} // end namespace caf
|
||||||
@@ -56,18 +56,12 @@ public:
|
|||||||
class PickEventHandler
|
class PickEventHandler
|
||||||
{
|
{
|
||||||
public:
|
public:
|
||||||
PickEventHandler(const PdmObjectHandle* objectBeingModified) : m_objectBeingModified(objectBeingModified) {}
|
|
||||||
|
|
||||||
bool isObjectBeingModified(const PdmObjectHandle* testObject) const;
|
|
||||||
|
|
||||||
virtual void registerAsPickEventHandler() = 0;
|
virtual void registerAsPickEventHandler() = 0;
|
||||||
virtual void unregisterAsPickEventHandler() = 0;
|
virtual void unregisterAsPickEventHandler() = 0;
|
||||||
// TODO: Rename to just handlePickEvent when the RicPickEventHandler::handlePickEvent has been renamed
|
// TODO: Rename to just handlePickEvent when the RicPickEventHandler::handlePickEvent has been renamed
|
||||||
virtual bool handlePickEvent(const PickEvent& eventObject) = 0;
|
virtual bool handlePickEvent(const PickEvent& eventObject) = 0;
|
||||||
virtual void notifyUnregistered() = 0;
|
virtual void notifyUnregistered() = 0;
|
||||||
|
|
||||||
private:
|
|
||||||
const PdmObjectHandle* m_objectBeingModified;
|
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
Reference in New Issue
Block a user