mirror of
https://github.com/OPM/ResInsight.git
synced 2025-01-08 07:03:25 -06:00
f8c5cf389f
* Set column width to 140 * Use c++20 * Remove redundant virtual
315 lines
13 KiB
C++
315 lines
13 KiB
C++
/////////////////////////////////////////////////////////////////////////////////
|
|
//
|
|
// 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 "Riu3dSelectionManager.h"
|
|
|
|
#include "Rim2dIntersectionView.h"
|
|
#include "RimEclipseResultDefinition.h"
|
|
#include "RimEclipseView.h"
|
|
#include "RimGeoMechResultDefinition.h"
|
|
#include "RimGeoMechView.h"
|
|
#include "RimGridView.h"
|
|
#include "RimSimWellInView.h"
|
|
#include "RimWellPath.h"
|
|
|
|
#include "RivSimWellPipeSourceInfo.h"
|
|
#include "RivWellPathSourceInfo.h"
|
|
|
|
#include "RiuSelectionChangedHandler.h"
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
///
|
|
//--------------------------------------------------------------------------------------------------
|
|
Riu3dSelectionManager::Riu3dSelectionManager()
|
|
: m_notificationCenter( new RiuSelectionChangedHandler )
|
|
{
|
|
m_selection.resize( 2 );
|
|
}
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
///
|
|
//--------------------------------------------------------------------------------------------------
|
|
Riu3dSelectionManager::~Riu3dSelectionManager()
|
|
{
|
|
deleteAllItemsFromSelection( RUI_APPLICATION_GLOBAL );
|
|
deleteAllItemsFromSelection( RUI_TEMPORARY );
|
|
|
|
delete m_notificationCenter;
|
|
}
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
///
|
|
//--------------------------------------------------------------------------------------------------
|
|
Riu3dSelectionManager* Riu3dSelectionManager::instance()
|
|
{
|
|
static Riu3dSelectionManager* singleton = new Riu3dSelectionManager;
|
|
return singleton;
|
|
}
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
///
|
|
//--------------------------------------------------------------------------------------------------
|
|
void Riu3dSelectionManager::selectedItems( std::vector<RiuSelectionItem*>& items, int role ) const
|
|
{
|
|
const std::vector<RiuSelectionItem*>& s = m_selection[role];
|
|
|
|
items = s;
|
|
}
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
///
|
|
//--------------------------------------------------------------------------------------------------
|
|
RiuSelectionItem* Riu3dSelectionManager::selectedItem( int role /*= RUI_APPLICATION_GLOBAL*/ ) const
|
|
{
|
|
const std::vector<RiuSelectionItem*>& s = m_selection[role];
|
|
|
|
if ( s.size() == 1 )
|
|
{
|
|
if ( s[0] )
|
|
{
|
|
return s[0];
|
|
}
|
|
}
|
|
|
|
return nullptr;
|
|
}
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
///
|
|
//--------------------------------------------------------------------------------------------------
|
|
void Riu3dSelectionManager::appendItemToSelection( RiuSelectionItem* item, int role )
|
|
{
|
|
std::vector<RiuSelectionItem*>& s = m_selection[role];
|
|
|
|
s.push_back( item );
|
|
|
|
if ( role == RUI_APPLICATION_GLOBAL ) m_notificationCenter->handleItemAppended( item );
|
|
}
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
///
|
|
//--------------------------------------------------------------------------------------------------
|
|
void Riu3dSelectionManager::setSelectedItem( RiuSelectionItem* item, int role )
|
|
{
|
|
deleteAllItemsFromSelection( role );
|
|
|
|
std::vector<RiuSelectionItem*>& s = m_selection[role];
|
|
|
|
s.push_back( item );
|
|
|
|
if ( role == RUI_APPLICATION_GLOBAL ) m_notificationCenter->handleSetSelectedItem( item );
|
|
}
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
///
|
|
//--------------------------------------------------------------------------------------------------
|
|
void Riu3dSelectionManager::deleteAllItems( int role )
|
|
{
|
|
if ( !isEmpty( role ) )
|
|
{
|
|
deleteAllItemsFromSelection( role );
|
|
|
|
if ( role == RUI_APPLICATION_GLOBAL ) m_notificationCenter->handleSelectionDeleted();
|
|
}
|
|
}
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
///
|
|
//--------------------------------------------------------------------------------------------------
|
|
bool Riu3dSelectionManager::isEmpty( int role ) const
|
|
{
|
|
const std::vector<RiuSelectionItem*>& s = m_selection[role];
|
|
|
|
return s.size() == 0;
|
|
}
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
///
|
|
//--------------------------------------------------------------------------------------------------
|
|
void Riu3dSelectionManager::deleteAllItemsFromSelection( int role )
|
|
{
|
|
std::vector<RiuSelectionItem*>& s = m_selection[role];
|
|
|
|
for ( RiuSelectionItem* item : s )
|
|
{
|
|
delete item;
|
|
}
|
|
|
|
s.clear();
|
|
}
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
///
|
|
//--------------------------------------------------------------------------------------------------
|
|
RiuEclipseSelectionItem::RiuEclipseSelectionItem( RimGridView* view,
|
|
RimEclipseResultDefinition* resultDefinition,
|
|
size_t timestepIdx,
|
|
size_t gridIndex,
|
|
size_t gridLocalCellIndex,
|
|
size_t nncIndex,
|
|
cvf::Color3f color,
|
|
cvf::StructGridInterface::FaceType face,
|
|
const cvf::Vec3d& localIntersectionPointInDisplay )
|
|
: m_view( view )
|
|
, m_resultDefinition( resultDefinition )
|
|
, m_timestepIdx( timestepIdx )
|
|
, m_gridIndex( gridIndex )
|
|
, m_gridLocalCellIndex( gridLocalCellIndex )
|
|
, m_nncIndex( nncIndex )
|
|
, m_color( color )
|
|
, m_face( face )
|
|
, m_localIntersectionPointInDisplay( localIntersectionPointInDisplay )
|
|
{
|
|
}
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
///
|
|
//--------------------------------------------------------------------------------------------------
|
|
RiuGeoMechSelectionItem::RiuGeoMechSelectionItem( RimGridView* view,
|
|
RimGeoMechResultDefinition* resultDefinition,
|
|
int timestepIdx,
|
|
int frameIdx,
|
|
size_t gridIndex,
|
|
size_t cellIndex,
|
|
cvf::Color3f color,
|
|
int elementFace,
|
|
const cvf::Vec3d& localIntersectionPointInDisplay )
|
|
: m_view( view )
|
|
, m_resultDefinition( resultDefinition )
|
|
, m_timestepIdx( timestepIdx )
|
|
, m_frameIdx( frameIdx )
|
|
, m_gridIndex( gridIndex )
|
|
, m_cellIndex( cellIndex )
|
|
, m_color( color )
|
|
, m_elementFace( elementFace )
|
|
, m_hasIntersectionTriangle( false )
|
|
, m_localIntersectionPointInDisplay( localIntersectionPointInDisplay )
|
|
{
|
|
}
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
///
|
|
//--------------------------------------------------------------------------------------------------
|
|
RiuGeoMechSelectionItem::RiuGeoMechSelectionItem( RimGridView* view,
|
|
RimGeoMechResultDefinition* resultDefinition,
|
|
int timestepIdx,
|
|
int frameIdx,
|
|
size_t gridIndex,
|
|
size_t cellIndex,
|
|
cvf::Color3f color,
|
|
int elementFace,
|
|
const cvf::Vec3d& localIntersectionPointInDisplay,
|
|
const std::array<cvf::Vec3f, 3>& intersectionTriangle )
|
|
: m_view( view )
|
|
, m_resultDefinition( resultDefinition )
|
|
, m_timestepIdx( timestepIdx )
|
|
, m_frameIdx( frameIdx )
|
|
, m_gridIndex( gridIndex )
|
|
, m_cellIndex( cellIndex )
|
|
, m_color( color )
|
|
, m_elementFace( elementFace )
|
|
, m_hasIntersectionTriangle( true )
|
|
, m_intersectionTriangle( intersectionTriangle )
|
|
, m_localIntersectionPointInDisplay( localIntersectionPointInDisplay )
|
|
{
|
|
}
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
///
|
|
//--------------------------------------------------------------------------------------------------
|
|
Riu2dIntersectionSelectionItem::Riu2dIntersectionSelectionItem( Rim2dIntersectionView* view, RiuSelectionItem* selItem )
|
|
{
|
|
m_view = view;
|
|
m_eclipseSelItem = dynamic_cast<RiuEclipseSelectionItem*>( selItem );
|
|
m_geoMechSelItem = dynamic_cast<RiuGeoMechSelectionItem*>( selItem );
|
|
}
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
///
|
|
//--------------------------------------------------------------------------------------------------
|
|
Riu2dIntersectionSelectionItem::~Riu2dIntersectionSelectionItem()
|
|
{
|
|
if ( m_eclipseSelItem ) delete m_eclipseSelItem;
|
|
if ( m_geoMechSelItem ) delete m_geoMechSelItem;
|
|
}
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
///
|
|
//--------------------------------------------------------------------------------------------------
|
|
caf::PdmPointer<Rim2dIntersectionView> Riu2dIntersectionSelectionItem::view() const
|
|
{
|
|
return m_view;
|
|
}
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
///
|
|
//--------------------------------------------------------------------------------------------------
|
|
RiuEclipseSelectionItem* Riu2dIntersectionSelectionItem::eclipseSelectionItem() const
|
|
{
|
|
return m_eclipseSelItem;
|
|
}
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
///
|
|
//--------------------------------------------------------------------------------------------------
|
|
RiuGeoMechSelectionItem* Riu2dIntersectionSelectionItem::geoMechSelectionItem() const
|
|
{
|
|
return m_geoMechSelItem;
|
|
}
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
///
|
|
//--------------------------------------------------------------------------------------------------
|
|
RiuWellPathSelectionItem::RiuWellPathSelectionItem( const RivWellPathSourceInfo* wellPathSourceInfo,
|
|
const cvf::Vec3d& pipeCenterLineIntersectionInDomainCoords,
|
|
double measuredDepth,
|
|
RimWellPathComponentInterface* component /*=nullptr*/ )
|
|
: m_pipeCenterlineIntersectionInDomainCoords( pipeCenterLineIntersectionInDomainCoords )
|
|
, m_measuredDepth( measuredDepth )
|
|
, m_wellPathComponent( component )
|
|
{
|
|
m_wellpath = wellPathSourceInfo->wellPath();
|
|
}
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
///
|
|
//--------------------------------------------------------------------------------------------------
|
|
RiuWellPathSelectionItem* RiuWellPathSelectionItem::wellPathSelectionItem()
|
|
{
|
|
return Riu3dSelectionManager::instance()->objectByType<RiuWellPathSelectionItem>( Riu3dSelectionManager::RUI_TEMPORARY );
|
|
}
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
///
|
|
//--------------------------------------------------------------------------------------------------
|
|
RiuSimWellSelectionItem::RiuSimWellSelectionItem( RimSimWellInView* simwell, cvf::Vec3d m_domainCoord, size_t m_branchIndex )
|
|
: m_simWell( simwell )
|
|
, m_domainCoord( m_domainCoord )
|
|
, m_branchIndex( m_branchIndex )
|
|
{
|
|
}
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
///
|
|
//--------------------------------------------------------------------------------------------------
|
|
RiuGeneralSelectionItem::RiuGeneralSelectionItem( caf::PdmObject* object )
|
|
: m_object( object )
|
|
{
|
|
}
|