mirror of
https://github.com/OPM/ResInsight.git
synced 2025-01-24 15:26:48 -06:00
673 lines
24 KiB
C++
673 lines
24 KiB
C++
/////////////////////////////////////////////////////////////////////////////////
|
|
//
|
|
// Copyright (C) 2016- Statoil ASA
|
|
//
|
|
// ResInsight 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.
|
|
//
|
|
// ResInsight 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.
|
|
//
|
|
/////////////////////////////////////////////////////////////////////////////////
|
|
|
|
#include "RimIntersectionBox.h"
|
|
|
|
#include "RimCase.h"
|
|
#include "RimEclipseView.h"
|
|
#include "Rim3dView.h"
|
|
|
|
#include "IntersectionBoxCommands/RicBoxManipulatorEventHandler.h"
|
|
|
|
#include "RiuViewer.h"
|
|
|
|
#include "RivIntersectionBoxPartMgr.h"
|
|
|
|
#include "cafPdmUiDoubleSliderEditor.h"
|
|
#include "cafPdmUiPushButtonEditor.h"
|
|
#include "cafPdmUiSliderEditor.h"
|
|
#include "cafDisplayCoordTransform.h"
|
|
|
|
|
|
namespace caf
|
|
{
|
|
template<>
|
|
void AppEnum< RimIntersectionBox::SinglePlaneState >::setUp()
|
|
{
|
|
addItem(RimIntersectionBox::PLANE_STATE_NONE, "PLANE_STATE_NONE", "Box");
|
|
addItem(RimIntersectionBox::PLANE_STATE_X, "PLANE_STATE_X", "X Plane");
|
|
addItem(RimIntersectionBox::PLANE_STATE_Y, "PLANE_STATE_Y", "Y Plane");
|
|
addItem(RimIntersectionBox::PLANE_STATE_Z, "PLANE_STATE_Z", "Z Plane");
|
|
setDefault(RimIntersectionBox::PLANE_STATE_NONE);
|
|
}
|
|
}
|
|
|
|
|
|
CAF_PDM_SOURCE_INIT(RimIntersectionBox, "IntersectionBox");
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
///
|
|
//--------------------------------------------------------------------------------------------------
|
|
RimIntersectionBox::RimIntersectionBox()
|
|
{
|
|
CAF_PDM_InitObject("Intersection Box", ":/IntersectionBox16x16.png", "", "");
|
|
|
|
CAF_PDM_InitField(&name, "UserDescription", QString("Intersection Name"), "Name", "", "", "");
|
|
CAF_PDM_InitField(&isActive, "Active", true, "Active", "", "", "");
|
|
isActive.uiCapability()->setUiHidden(true);
|
|
|
|
CAF_PDM_InitField(&m_singlePlaneState, "singlePlaneState", caf::AppEnum<SinglePlaneState>(SinglePlaneState::PLANE_STATE_NONE), "Box Type", "", "", "");
|
|
|
|
CAF_PDM_InitField(&m_minXCoord, "MinXCoord", 0.0, "Min", "", "", "");
|
|
m_minXCoord.uiCapability()->setUiEditorTypeName(caf::PdmUiDoubleSliderEditor::uiEditorTypeName());
|
|
|
|
CAF_PDM_InitField(&m_maxXCoord, "MaxXCoord", 0.0, "Max", "", "", "");
|
|
m_maxXCoord.uiCapability()->setUiEditorTypeName(caf::PdmUiDoubleSliderEditor::uiEditorTypeName());
|
|
|
|
CAF_PDM_InitField(&m_minYCoord, "MinYCoord", 0.0, "Min", "", "", "");
|
|
m_minYCoord.uiCapability()->setUiEditorTypeName(caf::PdmUiDoubleSliderEditor::uiEditorTypeName());
|
|
|
|
CAF_PDM_InitField(&m_maxYCoord, "MaxYCoord", 0.0, "Max", "", "", "");
|
|
m_maxYCoord.uiCapability()->setUiEditorTypeName(caf::PdmUiDoubleSliderEditor::uiEditorTypeName());
|
|
|
|
CAF_PDM_InitField(&m_minDepth, "MinDepth", 0.0, "Min", "", "", "");
|
|
m_minDepth.uiCapability()->setUiEditorTypeName(caf::PdmUiDoubleSliderEditor::uiEditorTypeName());
|
|
|
|
CAF_PDM_InitField(&m_maxDepth, "MaxDepth", 0.0, "Max", "", "", "");
|
|
m_maxDepth.uiCapability()->setUiEditorTypeName(caf::PdmUiDoubleSliderEditor::uiEditorTypeName());
|
|
|
|
CAF_PDM_InitField (&showInactiveCells, "ShowInactiveCells", false, "Show Inactive Cells", "", "", "");
|
|
CAF_PDM_InitField (&m_xySliderStepSize, "xySliderStepSize", 1.0, "XY Slider Step Size", "", "", "");
|
|
CAF_PDM_InitField (&m_depthSliderStepSize, "DepthSliderStepSize", 0.5, "Depth Slider Step Size", "", "", "");
|
|
|
|
CAF_PDM_InitFieldNoDefault(&m_show3DManipulator, "show3DManipulator", "", "", "", "");
|
|
caf::PdmUiPushButtonEditor::configureEditorForField(&m_show3DManipulator);
|
|
m_show3DManipulator = false;
|
|
}
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
///
|
|
//--------------------------------------------------------------------------------------------------
|
|
RimIntersectionBox::~RimIntersectionBox()
|
|
{
|
|
if (m_boxManipulator)
|
|
{
|
|
m_boxManipulator->deleteLater();
|
|
}
|
|
}
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
///
|
|
//--------------------------------------------------------------------------------------------------
|
|
cvf::Mat4d RimIntersectionBox::boxOrigin() const
|
|
{
|
|
cvf::Mat4d mx(cvf::Mat4d::IDENTITY);
|
|
mx.setTranslation(cvf::Vec3d(m_minXCoord, m_minYCoord, -m_maxDepth));
|
|
return mx;
|
|
}
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
///
|
|
//--------------------------------------------------------------------------------------------------
|
|
cvf::Vec3d RimIntersectionBox::boxSize() const
|
|
{
|
|
return cvf::Vec3d(m_maxXCoord, m_maxYCoord, m_maxDepth) - cvf::Vec3d(m_minXCoord, m_minYCoord, m_minDepth);
|
|
}
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
///
|
|
//--------------------------------------------------------------------------------------------------
|
|
void RimIntersectionBox::setFromOriginAndSize(const cvf::Vec3d& origin, const cvf::Vec3d& size)
|
|
{
|
|
m_minXCoord = origin.x();
|
|
m_minYCoord = origin.y();
|
|
m_minDepth = -(origin.z() + size.z());
|
|
|
|
m_maxXCoord = origin.x() + size.x();
|
|
m_maxYCoord = origin.y() + size.y();
|
|
m_maxDepth = -origin.z();
|
|
|
|
clampSinglePlaneValues();
|
|
|
|
updateBoxManipulatorGeometry();
|
|
|
|
updateConnectedEditors();
|
|
|
|
rebuildGeometryAndScheduleCreateDisplayModel();
|
|
}
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
///
|
|
//--------------------------------------------------------------------------------------------------
|
|
bool RimIntersectionBox::show3dManipulator() const
|
|
{
|
|
return m_show3DManipulator;
|
|
}
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
///
|
|
//--------------------------------------------------------------------------------------------------
|
|
RimIntersectionBox::SinglePlaneState RimIntersectionBox::singlePlaneState() const
|
|
{
|
|
return m_singlePlaneState();
|
|
}
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
///
|
|
//--------------------------------------------------------------------------------------------------
|
|
void RimIntersectionBox::setToDefaultSizeBox()
|
|
{
|
|
cvf::BoundingBox boundingBox = currentCellBoundingBox();
|
|
cvf::Vec3d center = boundingBox.center();
|
|
|
|
double defaultWidthFactor = 0.5;
|
|
|
|
m_minXCoord = center.x() - 0.5 * boundingBox.extent().x() * defaultWidthFactor;
|
|
m_minYCoord = center.y() - 0.5 * boundingBox.extent().y() * defaultWidthFactor;
|
|
m_minDepth = -(center.z() + 0.5 * boundingBox.extent().z() * defaultWidthFactor);
|
|
m_maxXCoord = center.x() + 0.5 * boundingBox.extent().x() * defaultWidthFactor;
|
|
m_maxYCoord = center.y() + 0.5 * boundingBox.extent().y() * defaultWidthFactor;
|
|
m_maxDepth = -(center.z() - 0.5 * boundingBox.extent().z() * defaultWidthFactor);
|
|
|
|
}
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
///
|
|
//--------------------------------------------------------------------------------------------------
|
|
void RimIntersectionBox::setToDefaultSizeSlice(SinglePlaneState plane, const cvf::Vec3d& position)
|
|
{
|
|
m_singlePlaneState = plane;
|
|
|
|
cvf::BoundingBox boundingBox = currentCellBoundingBox();
|
|
cvf::Vec3d center = position;
|
|
|
|
if (center.isUndefined()) center = boundingBox.center();
|
|
|
|
double defaultWidthFactor = 0.5;
|
|
|
|
m_minXCoord = center[0] - 0.5 * boundingBox.extent().x() * defaultWidthFactor;
|
|
m_minYCoord = center[1] - 0.5 * boundingBox.extent().y() * defaultWidthFactor;
|
|
m_minDepth = -(center[2] + 0.5 * boundingBox.extent().z() * defaultWidthFactor);
|
|
m_maxXCoord = center[0] + 0.5 * boundingBox.extent().x() * defaultWidthFactor;
|
|
m_maxYCoord = center[1] + 0.5 * boundingBox.extent().y() * defaultWidthFactor;
|
|
m_maxDepth = -(center[2] - 0.5 * boundingBox.extent().z() * defaultWidthFactor);
|
|
|
|
switch (plane)
|
|
{
|
|
case PLANE_STATE_X: m_minXCoord = m_maxXCoord = center[0]; break;
|
|
case PLANE_STATE_Y: m_minYCoord = m_maxYCoord = center[1]; break;
|
|
case PLANE_STATE_Z: m_minDepth = m_maxDepth = -center[2]; break;
|
|
}
|
|
|
|
updateVisibility();
|
|
}
|
|
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
///
|
|
//--------------------------------------------------------------------------------------------------
|
|
RivIntersectionBoxPartMgr* RimIntersectionBox::intersectionBoxPartMgr()
|
|
{
|
|
if (m_intersectionBoxPartMgr.isNull()) m_intersectionBoxPartMgr = new RivIntersectionBoxPartMgr(this);
|
|
|
|
return m_intersectionBoxPartMgr.p();
|
|
}
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
///
|
|
//--------------------------------------------------------------------------------------------------
|
|
void RimIntersectionBox::appendManipulatorPartsToModel(cvf::ModelBasicList* model)
|
|
{
|
|
if (show3dManipulator() && m_boxManipulator)
|
|
{
|
|
m_boxManipulator->appendPartsToModel(model);
|
|
}
|
|
}
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
///
|
|
//--------------------------------------------------------------------------------------------------
|
|
void RimIntersectionBox::rebuildGeometry()
|
|
{
|
|
m_intersectionBoxPartMgr = nullptr;
|
|
}
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
///
|
|
//--------------------------------------------------------------------------------------------------
|
|
void RimIntersectionBox::fieldChangedByUi(const caf::PdmFieldHandle* changedField, const QVariant& oldValue, const QVariant& newValue)
|
|
{
|
|
if (changedField == &m_singlePlaneState)
|
|
{
|
|
switchSingelPlaneState();
|
|
updateVisibility();
|
|
updateBoxManipulatorGeometry();
|
|
}
|
|
else if (changedField == &m_minXCoord)
|
|
{
|
|
if (m_singlePlaneState == PLANE_STATE_X)
|
|
{
|
|
m_maxXCoord = m_minXCoord;
|
|
}
|
|
else
|
|
{
|
|
m_minXCoord = CVF_MIN(m_maxXCoord, m_minXCoord);
|
|
}
|
|
}
|
|
else if (changedField == &m_minYCoord)
|
|
{
|
|
if (m_singlePlaneState == PLANE_STATE_Y)
|
|
{
|
|
m_maxYCoord = m_minYCoord;
|
|
}
|
|
else
|
|
{
|
|
m_minYCoord = CVF_MIN(m_maxYCoord, m_minYCoord);
|
|
}
|
|
}
|
|
else if (changedField == &m_minDepth)
|
|
{
|
|
if (m_singlePlaneState == PLANE_STATE_Z)
|
|
{
|
|
m_maxDepth = m_minDepth;
|
|
}
|
|
else
|
|
{
|
|
m_minDepth = CVF_MIN(m_maxDepth, m_minDepth);
|
|
}
|
|
}
|
|
else if (changedField == &m_maxXCoord)
|
|
{
|
|
m_maxXCoord = CVF_MAX(m_maxXCoord, m_minXCoord);
|
|
}
|
|
else if (changedField == &m_maxYCoord)
|
|
{
|
|
m_maxYCoord = CVF_MAX(m_maxYCoord, m_minYCoord);
|
|
}
|
|
else if (changedField == &m_maxDepth)
|
|
{
|
|
m_maxDepth = CVF_MAX(m_maxDepth, m_minDepth);
|
|
}
|
|
else if (changedField == &m_show3DManipulator)
|
|
{
|
|
if (m_show3DManipulator)
|
|
{
|
|
if (viewer())
|
|
{
|
|
m_boxManipulator = new RicBoxManipulatorEventHandler(viewer());
|
|
|
|
connect(m_boxManipulator, SIGNAL(notifyRedraw()), this, SLOT(slotScheduleRedraw()));
|
|
connect(m_boxManipulator, SIGNAL(notifyUpdate(const cvf::Vec3d&, const cvf::Vec3d&)), this, SLOT(slotUpdateGeometry(const cvf::Vec3d&, const cvf::Vec3d&)));
|
|
|
|
updateBoxManipulatorGeometry();
|
|
}
|
|
}
|
|
else
|
|
{
|
|
if (m_boxManipulator)
|
|
{
|
|
m_boxManipulator->deleteLater();
|
|
m_boxManipulator = nullptr;
|
|
}
|
|
}
|
|
}
|
|
|
|
if (changedField == &m_minXCoord ||
|
|
changedField == &m_minYCoord ||
|
|
changedField == &m_minDepth ||
|
|
changedField == &m_maxXCoord ||
|
|
changedField == &m_maxYCoord ||
|
|
changedField == &m_maxDepth)
|
|
{
|
|
if (m_boxManipulator)
|
|
{
|
|
Rim3dView* rimView = nullptr;
|
|
this->firstAncestorOrThisOfType(rimView);
|
|
|
|
if (rimView)
|
|
{
|
|
cvf::ref<caf::DisplayCoordTransform> transForm = rimView->displayCoordTransform();
|
|
|
|
m_boxManipulator->setOrigin(transForm->transformToDisplayCoord(boxOrigin().translation()));
|
|
m_boxManipulator->setSize(transForm->scaleToDisplaySize(boxSize()));
|
|
}
|
|
}
|
|
}
|
|
|
|
|
|
if (changedField != &name)
|
|
{
|
|
rebuildGeometryAndScheduleCreateDisplayModel();
|
|
}
|
|
}
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
///
|
|
//--------------------------------------------------------------------------------------------------
|
|
void RimIntersectionBox::updateBoxManipulatorGeometry()
|
|
{
|
|
if (m_boxManipulator.isNull()) return;
|
|
|
|
Rim3dView* rimView = nullptr;
|
|
this->firstAncestorOrThisOfType(rimView);
|
|
if (!rimView) return;
|
|
|
|
cvf::ref<caf::DisplayCoordTransform> transForm = rimView->displayCoordTransform();
|
|
|
|
m_boxManipulator->setOrigin(transForm->transformToDisplayCoord(boxOrigin().translation()));
|
|
m_boxManipulator->setSize(transForm->scaleToDisplaySize(boxSize()));
|
|
}
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
///
|
|
//--------------------------------------------------------------------------------------------------
|
|
void RimIntersectionBox::defineEditorAttribute(const caf::PdmFieldHandle* field, QString uiConfigName, caf::PdmUiEditorAttribute* attribute)
|
|
{
|
|
caf::PdmUiDoubleSliderEditorAttribute* myAttr = dynamic_cast<caf::PdmUiDoubleSliderEditorAttribute*>(attribute);
|
|
if (myAttr)
|
|
{
|
|
cvf::BoundingBox cellsBoundingBox = currentCellBoundingBox();
|
|
if (field == &m_minXCoord || field == &m_maxXCoord)
|
|
{
|
|
myAttr->m_minimum = cellsBoundingBox.min().x();
|
|
myAttr->m_maximum = cellsBoundingBox.max().x();
|
|
|
|
int range = cellsBoundingBox.extent().x();
|
|
int tickCount = range / m_xySliderStepSize;
|
|
|
|
myAttr->m_sliderTickCount = cvf::Math::abs(tickCount);
|
|
}
|
|
else if (field == &m_minYCoord || field == &m_maxYCoord)
|
|
{
|
|
myAttr->m_minimum = cellsBoundingBox.min().y();
|
|
myAttr->m_maximum = cellsBoundingBox.max().y();
|
|
|
|
int range = cellsBoundingBox.extent().y();
|
|
int tickCount = range / m_xySliderStepSize;
|
|
|
|
myAttr->m_sliderTickCount = cvf::Math::abs(tickCount);
|
|
}
|
|
else if (field == &m_minDepth || field == &m_maxDepth)
|
|
{
|
|
myAttr->m_minimum = -cellsBoundingBox.max().z();
|
|
myAttr->m_maximum = -cellsBoundingBox.min().z();
|
|
|
|
int range = cellsBoundingBox.extent().z();
|
|
int tickCount = range / m_depthSliderStepSize;
|
|
|
|
myAttr->m_sliderTickCount = cvf::Math::abs(tickCount);
|
|
}
|
|
}
|
|
|
|
if (field == &m_show3DManipulator)
|
|
{
|
|
caf::PdmUiPushButtonEditorAttribute* attrib = dynamic_cast<caf::PdmUiPushButtonEditorAttribute*> (attribute);
|
|
|
|
if (attrib)
|
|
{
|
|
if (m_show3DManipulator)
|
|
{
|
|
attrib->m_buttonText = "Hide 3D manipulator";
|
|
}
|
|
else
|
|
{
|
|
attrib->m_buttonText = "Show 3D manipulator";
|
|
}
|
|
}
|
|
|
|
}
|
|
}
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
///
|
|
//--------------------------------------------------------------------------------------------------
|
|
void RimIntersectionBox::defineUiOrdering(QString uiConfigName, caf::PdmUiOrdering& uiOrdering)
|
|
{
|
|
uiOrdering.add(&name);
|
|
|
|
{
|
|
caf::PdmUiGroup* group = uiOrdering.addNewGroup("Options");
|
|
group->add(&m_singlePlaneState);
|
|
group->add(&showInactiveCells);
|
|
}
|
|
|
|
cvf::BoundingBox cellsBoundingBox = currentCellBoundingBox();
|
|
{
|
|
caf::PdmUiGroup* group = uiOrdering.addNewGroup("X Coordinates " + QString(" [%1 %2]").arg(cellsBoundingBox.min().x()).arg(cellsBoundingBox.max().x()));
|
|
group->add(&m_minXCoord);
|
|
group->add(&m_maxXCoord);
|
|
}
|
|
|
|
{
|
|
caf::PdmUiGroup* group = uiOrdering.addNewGroup("Y Coordinates" + QString(" [%1 %2]").arg(cellsBoundingBox.min().y()).arg(cellsBoundingBox.max().y()));
|
|
group->add(&m_minYCoord);
|
|
group->add(&m_maxYCoord);
|
|
}
|
|
|
|
{
|
|
caf::PdmUiGroup* group = uiOrdering.addNewGroup("Depth" + QString(" [%1 %2]").arg(-cellsBoundingBox.max().z()).arg(-cellsBoundingBox.min().z()));
|
|
group->add(&m_minDepth);
|
|
group->add(&m_maxDepth);
|
|
}
|
|
|
|
{
|
|
caf::PdmUiGroup* group = uiOrdering.addNewGroup("Slider Options");
|
|
group->add(&m_xySliderStepSize);
|
|
group->add(&m_depthSliderStepSize);
|
|
}
|
|
|
|
uiOrdering.add(&m_show3DManipulator);
|
|
}
|
|
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
///
|
|
//--------------------------------------------------------------------------------------------------
|
|
void RimIntersectionBox::initAfterRead()
|
|
{
|
|
updateVisibility();
|
|
}
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
///
|
|
//--------------------------------------------------------------------------------------------------
|
|
void RimIntersectionBox::slotScheduleRedraw()
|
|
{
|
|
Rim3dView* rimView = nullptr;
|
|
this->firstAncestorOrThisOfType(rimView);
|
|
if (rimView)
|
|
{
|
|
rimView->scheduleCreateDisplayModelAndRedraw();
|
|
}
|
|
}
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
///
|
|
//--------------------------------------------------------------------------------------------------
|
|
void RimIntersectionBox::slotUpdateGeometry(const cvf::Vec3d& origin, const cvf::Vec3d& size)
|
|
{
|
|
Rim3dView* rimView = nullptr;
|
|
this->firstAncestorOrThisOfType(rimView);
|
|
|
|
if (rimView)
|
|
{
|
|
cvf::ref<caf::DisplayCoordTransform> transForm = rimView->displayCoordTransform();
|
|
|
|
cvf::Vec3d domainOrigin = transForm->transformToDomainCoord(origin);
|
|
cvf::Vec3d domainSize = transForm->scaleToDomainSize(size);
|
|
|
|
setFromOriginAndSize(domainOrigin, domainSize);
|
|
}
|
|
}
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
///
|
|
//--------------------------------------------------------------------------------------------------
|
|
caf::PdmFieldHandle* RimIntersectionBox::userDescriptionField()
|
|
{
|
|
return &name;
|
|
}
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
///
|
|
//--------------------------------------------------------------------------------------------------
|
|
caf::PdmFieldHandle* RimIntersectionBox::objectToggleField()
|
|
{
|
|
return &isActive;
|
|
}
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
///
|
|
//--------------------------------------------------------------------------------------------------
|
|
void RimIntersectionBox::rebuildGeometryAndScheduleCreateDisplayModel()
|
|
{
|
|
m_intersectionBoxPartMgr = nullptr;
|
|
|
|
slotScheduleRedraw();
|
|
}
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
///
|
|
//--------------------------------------------------------------------------------------------------
|
|
void RimIntersectionBox::updateVisibility()
|
|
{
|
|
m_maxXCoord.uiCapability()->setUiReadOnly(false);
|
|
m_maxYCoord.uiCapability()->setUiReadOnly(false);
|
|
m_maxDepth.uiCapability()->setUiReadOnly(false);
|
|
|
|
if (m_singlePlaneState == PLANE_STATE_X)
|
|
{
|
|
m_maxXCoord.uiCapability()->setUiReadOnly(true);
|
|
this->setUiIcon(QIcon(QString(":/IntersectionXPlane16x16.png")));
|
|
}
|
|
else if (m_singlePlaneState == PLANE_STATE_Y)
|
|
{
|
|
m_maxYCoord.uiCapability()->setUiReadOnly(true);
|
|
this->setUiIcon(QIcon(QString(":/IntersectionYPlane16x16.png")));
|
|
}
|
|
else if (m_singlePlaneState == PLANE_STATE_Z)
|
|
{
|
|
m_maxDepth.uiCapability()->setUiReadOnly(true);
|
|
this->setUiIcon(QIcon(QString(":/IntersectionZPlane16x16.png")));
|
|
}
|
|
else
|
|
{
|
|
this->setUiIcon(QIcon(QString(":/IntersectionBox16x16.png")));
|
|
}
|
|
}
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
///
|
|
//--------------------------------------------------------------------------------------------------
|
|
void RimIntersectionBox::clampSinglePlaneValues()
|
|
{
|
|
if (m_singlePlaneState == PLANE_STATE_X)
|
|
{
|
|
m_maxXCoord = m_minXCoord = 0.5*(m_minXCoord + m_maxXCoord);
|
|
}
|
|
else if (m_singlePlaneState == PLANE_STATE_Y)
|
|
{
|
|
m_maxYCoord = m_minYCoord = 0.5*(m_minYCoord + m_maxYCoord);
|
|
}
|
|
else if (m_singlePlaneState == PLANE_STATE_Z)
|
|
{
|
|
m_maxDepth = m_minDepth = 0.5*(m_minDepth + m_maxDepth);
|
|
}
|
|
}
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
///
|
|
//--------------------------------------------------------------------------------------------------
|
|
void RimIntersectionBox::switchSingelPlaneState()
|
|
{
|
|
cvf::Vec3d orgSize = boxSize();
|
|
double orgWidth = orgSize.length();
|
|
|
|
switch( m_singlePlaneState()) // New collapsed direction
|
|
{
|
|
case PLANE_STATE_X:
|
|
orgWidth = orgSize[0];
|
|
break;
|
|
case PLANE_STATE_Y:
|
|
orgWidth = orgSize[1];
|
|
break;
|
|
case PLANE_STATE_Z:
|
|
orgWidth = orgSize[2];
|
|
break;
|
|
case PLANE_STATE_NONE:
|
|
orgWidth = orgSize.length() *0.3;
|
|
break;
|
|
}
|
|
|
|
// For the originally collapsed direction, set a new width
|
|
|
|
if(m_minXCoord() == m_maxXCoord())
|
|
{
|
|
double center = m_minXCoord;
|
|
m_minXCoord = center - 0.5*orgWidth;
|
|
m_maxXCoord = center + 0.5*orgWidth;
|
|
}
|
|
|
|
if(m_minYCoord() == m_maxYCoord())
|
|
{
|
|
double center = m_minYCoord;
|
|
m_minYCoord = center - 0.5*orgWidth;
|
|
m_maxYCoord = center + 0.5*orgWidth;
|
|
}
|
|
|
|
if(m_minDepth() == m_maxDepth())
|
|
{
|
|
double center = m_minDepth;
|
|
m_minDepth = center - 0.5*orgWidth;
|
|
m_maxDepth = center + 0.5*orgWidth;
|
|
}
|
|
|
|
clampSinglePlaneValues();
|
|
}
|
|
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
///
|
|
//--------------------------------------------------------------------------------------------------
|
|
cvf::BoundingBox RimIntersectionBox::currentCellBoundingBox()
|
|
{
|
|
RimCase* rimCase = nullptr;
|
|
this->firstAncestorOrThisOfType(rimCase);
|
|
|
|
CVF_ASSERT(rimCase);
|
|
/*
|
|
RimEclipseView* eclView = nullptr;
|
|
this->firstAncestorOrThisOfType(eclView);
|
|
|
|
bool useAllCells = true;
|
|
if (eclView)
|
|
{
|
|
useAllCells = eclView->showInactiveCells();
|
|
}
|
|
|
|
if(false)//useAllCells) // For now, only use the active CellsBBox.
|
|
return rimCase->allCellsBoundingBox();
|
|
else */
|
|
return rimCase->activeCellsBoundingBox();
|
|
|
|
}
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
///
|
|
//--------------------------------------------------------------------------------------------------
|
|
RiuViewer* RimIntersectionBox::viewer()
|
|
{
|
|
Rim3dView* rimView = nullptr;
|
|
this->firstAncestorOrThisOfType(rimView);
|
|
|
|
RiuViewer* riuViewer = nullptr;
|
|
if (rimView) riuViewer = rimView->viewer();
|
|
|
|
return riuViewer;
|
|
}
|