2015-11-27 10:18:30 -06:00
|
|
|
/////////////////////////////////////////////////////////////////////////////////
|
|
|
|
//
|
|
|
|
// Copyright (C) 2015- Statoil ASA
|
|
|
|
// Copyright (C) 2015- Ceetron Solutions AS
|
|
|
|
//
|
|
|
|
// 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 "RicNewPolylineCrossSectionFeature.h"
|
|
|
|
|
|
|
|
#include "RiaApplication.h"
|
|
|
|
|
|
|
|
#include "RimCase.h"
|
|
|
|
#include "RimCrossSection.h"
|
|
|
|
#include "RimCrossSectionCollection.h"
|
|
|
|
#include "RimView.h"
|
|
|
|
|
|
|
|
#include "RiuMainWindow.h"
|
|
|
|
#include "RiuSelectionManager.h"
|
|
|
|
|
|
|
|
#include "cafCmdExecCommandManager.h"
|
|
|
|
#include "cafSelectionManager.h"
|
|
|
|
|
|
|
|
#include "cvfAssert.h"
|
|
|
|
|
|
|
|
#include <QAction>
|
|
|
|
|
|
|
|
CAF_CMD_SOURCE_INIT(RicNewPolylineCrossSectionFeature, "RicNewPolylineCrossSectionFeature");
|
|
|
|
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
|
|
///
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
|
|
RicNewPolylineCrossSectionFeature::RicNewPolylineCrossSectionFeature()
|
|
|
|
{
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
|
|
///
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
|
|
bool RicNewPolylineCrossSectionFeature::isCommandEnabled()
|
|
|
|
{
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
|
|
///
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
|
|
void RicNewPolylineCrossSectionFeature::onActionTriggered(bool isChecked)
|
|
|
|
{
|
|
|
|
RimView* activeView = RiaApplication::instance()->activeReservoirView();
|
|
|
|
if (!activeView) return;
|
|
|
|
|
|
|
|
RicNewPolylineCrossSectionFeatureCmd* cmd = new RicNewPolylineCrossSectionFeatureCmd(activeView->crossSectionCollection);
|
|
|
|
caf::CmdExecCommandManager::instance()->processExecuteCommand(cmd);
|
|
|
|
}
|
|
|
|
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
|
|
///
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
|
|
void RicNewPolylineCrossSectionFeature::setupActionLook(QAction* actionToSetup)
|
|
|
|
{
|
|
|
|
actionToSetup->setIcon(QIcon(":/CrossSection16x16.png"));
|
|
|
|
actionToSetup->setText("New Polyline Intersection");
|
|
|
|
}
|
|
|
|
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
|
|
///
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
2015-12-04 08:15:13 -06:00
|
|
|
bool RicNewPolylineCrossSectionFeature::handleEvent(cvf::Object* eventObject)
|
2015-11-27 10:18:30 -06:00
|
|
|
{
|
|
|
|
std::vector<RimCrossSection*> selection;
|
|
|
|
caf::SelectionManager::instance()->objectsByType(&selection);
|
|
|
|
|
|
|
|
if (selection.size() == 1)
|
|
|
|
{
|
2015-12-04 08:15:13 -06:00
|
|
|
RicViewerEventObject* polylineUiEvent = dynamic_cast<RicViewerEventObject*>(eventObject);
|
2015-11-27 10:18:30 -06:00
|
|
|
if (polylineUiEvent)
|
|
|
|
{
|
|
|
|
RimCrossSection* crossSection = selection[0];
|
2015-11-30 06:23:11 -06:00
|
|
|
if (crossSection->inputFromViewerEnabled())
|
|
|
|
{
|
|
|
|
RimCase* rimCase = NULL;
|
|
|
|
crossSection->firstAnchestorOrThisOfType(rimCase);
|
|
|
|
CVF_ASSERT(rimCase);
|
2015-11-27 10:18:30 -06:00
|
|
|
|
2015-11-30 06:23:11 -06:00
|
|
|
crossSection->appendPointToPolyLine(rimCase->displayModelOffset() + polylineUiEvent->localIntersectionPoint);
|
2015-11-27 10:18:30 -06:00
|
|
|
|
2015-11-30 06:23:11 -06:00
|
|
|
// Further Ui processing is stopped when true is returned
|
|
|
|
return true;
|
|
|
|
}
|
2015-11-27 10:18:30 -06:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
|
|
///
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
|
|
RicNewPolylineCrossSectionFeatureCmd::RicNewPolylineCrossSectionFeatureCmd(RimCrossSectionCollection* crossSectionCollection)
|
|
|
|
: CmdExecuteCommand(NULL),
|
|
|
|
m_crossSectionCollection(crossSectionCollection)
|
|
|
|
{
|
|
|
|
}
|
|
|
|
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
|
|
///
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
|
|
RicNewPolylineCrossSectionFeatureCmd::~RicNewPolylineCrossSectionFeatureCmd()
|
|
|
|
{
|
|
|
|
}
|
|
|
|
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
|
|
///
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
|
|
QString RicNewPolylineCrossSectionFeatureCmd::name()
|
|
|
|
{
|
|
|
|
return "Start Polyline Intersection";
|
|
|
|
}
|
|
|
|
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
|
|
///
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
|
|
void RicNewPolylineCrossSectionFeatureCmd::redo()
|
|
|
|
{
|
|
|
|
CVF_ASSERT(m_crossSectionCollection);
|
|
|
|
|
|
|
|
RimCrossSection* crossSection = new RimCrossSection();
|
|
|
|
crossSection->name = "Polyline";
|
|
|
|
crossSection->type = RimCrossSection::CS_POLYLINE;
|
2015-11-30 06:23:11 -06:00
|
|
|
crossSection->inputFromViewerEnabled = true;
|
2015-11-27 10:18:30 -06:00
|
|
|
|
2015-11-30 06:23:11 -06:00
|
|
|
m_crossSectionCollection->appendCrossSection(crossSection);
|
2015-11-27 10:18:30 -06:00
|
|
|
|
|
|
|
RiuSelectionManager::instance()->deleteAllItems();
|
|
|
|
|
2015-12-07 03:07:51 -06:00
|
|
|
RiuMainWindow::instance()->selectAsCurrentItem(crossSection);
|
2015-11-27 10:18:30 -06:00
|
|
|
}
|
|
|
|
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
|
|
///
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
|
|
void RicNewPolylineCrossSectionFeatureCmd::undo()
|
|
|
|
{
|
|
|
|
}
|