mirror of
				https://github.com/OPM/ResInsight.git
				synced 2025-02-25 18:55:39 -06:00 
			
		
		
		
	
		
			
				
	
	
		
			1669 lines
		
	
	
		
			64 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
			
		
		
	
	
			1669 lines
		
	
	
		
			64 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
| /////////////////////////////////////////////////////////////////////////////////
 | |
| //
 | |
| //  Copyright (C) 2011-     Statoil ASA
 | |
| //  Copyright (C) 2013-     Ceetron Solutions AS
 | |
| //  Copyright (C) 2011-2012 Ceetron 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 "RimEclipseView.h"
 | |
| 
 | |
| #include "RiaApplication.h"
 | |
| #include "RiaPreferences.h"
 | |
| 
 | |
| #include "RigActiveCellInfo.h"
 | |
| #include "RigCaseCellResultsData.h"
 | |
| #include "RigEclipseCaseData.h"
 | |
| #include "RigFlowDiagResults.h"
 | |
| #include "RigFormationNames.h"
 | |
| #include "RigMainGrid.h"
 | |
| #include "RigResultAccessor.h"
 | |
| #include "RigResultAccessorFactory.h"
 | |
| #include "RigSingleWellResultsData.h"
 | |
| 
 | |
| #include "Rim3dOverlayInfoConfig.h"
 | |
| #include "RimCellEdgeColors.h"
 | |
| #include "RimCellRangeFilterCollection.h"
 | |
| #include "RimEclipseCase.h"
 | |
| #include "RimEclipseCellColors.h"
 | |
| #include "RimEclipseFaultColors.h"
 | |
| #include "RimEclipsePropertyFilterCollection.h"
 | |
| #include "RimEclipseResultDefinition.h"
 | |
| #include "RimEclipseWell.h"
 | |
| #include "RimEclipseWellCollection.h"
 | |
| #include "RimFaultCollection.h"
 | |
| #include "RimFlowDiagSolution.h"
 | |
| #include "RimFracture.h"
 | |
| #include "RimGridCollection.h"
 | |
| #include "RimIntersection.h"
 | |
| #include "RimIntersectionCollection.h"
 | |
| #include "RimLegendConfig.h"
 | |
| #include "RimOilField.h"
 | |
| #include "RimProject.h"
 | |
| #include "RimReservoirCellResultsStorage.h"
 | |
| #include "RimStimPlanColors.h"
 | |
| #include "RimTernaryLegendConfig.h"
 | |
| #include "RimViewController.h"
 | |
| #include "RimViewLinker.h"
 | |
| #include "RimWellPathCollection.h"
 | |
| 
 | |
| #include "RiuMainWindow.h"
 | |
| #include "RiuSelectionManager.h"
 | |
| #include "RiuViewer.h"
 | |
| 
 | |
| #include "RivReservoirSimWellsPartMgr.h"
 | |
| #include "RivReservoirViewPartMgr.h"
 | |
| #include "RivSingleCellPartGenerator.h"
 | |
| #include "RivTernarySaturationOverlayItem.h"
 | |
| #include "RivWellPathCollectionPartMgr.h"
 | |
| #include "RivWellFracturePartMgr.h"
 | |
| 
 | |
| #include "cafCadNavigation.h"
 | |
| #include "cafCeetronPlusNavigation.h"
 | |
| #include "cafDisplayCoordTransform.h"
 | |
| #include "cafFrameAnimationControl.h"
 | |
| #include "cafPdmUiTreeOrdering.h"
 | |
| 
 | |
| #include "cvfDrawable.h"
 | |
| #include "cvfModelBasicList.h"
 | |
| #include "cvfOverlayScalarMapperLegend.h"
 | |
| #include "cvfPart.h"
 | |
| #include "cvfScene.h"
 | |
| #include "cvfViewport.h" 
 | |
| #include "cvfqtUtils.h"
 | |
| 
 | |
| #include <QMessageBox>
 | |
| 
 | |
| #include <limits.h>
 | |
| 
 | |
| 
 | |
| 
 | |
| 
 | |
| CAF_PDM_SOURCE_INIT(RimEclipseView, "ReservoirView");
 | |
| //--------------------------------------------------------------------------------------------------
 | |
| /// 
 | |
| //--------------------------------------------------------------------------------------------------
 | |
| RimEclipseView::RimEclipseView()
 | |
| {
 | |
|     RiaApplication* app = RiaApplication::instance();
 | |
|     RiaPreferences* preferences = app->preferences();
 | |
|     CVF_ASSERT(preferences);
 | |
| 
 | |
|     CAF_PDM_InitObject("Reservoir View", ":/3DView16x16.png", "", "");
 | |
|  
 | |
|     CAF_PDM_InitFieldNoDefault(&cellResult,  "GridCellResult", "Cell Result", ":/CellResult.png", "", "");
 | |
|     cellResult = new RimEclipseCellColors();
 | |
|     cellResult.uiCapability()->setUiHidden(true);
 | |
| 
 | |
|     CAF_PDM_InitFieldNoDefault(&cellEdgeResult,  "GridCellEdgeResult", "Cell Edge Result", ":/EdgeResult_1.png", "", "");
 | |
|     cellEdgeResult = new RimCellEdgeColors();
 | |
|     cellEdgeResult.uiCapability()->setUiHidden(true);
 | |
| 
 | |
|     CAF_PDM_InitFieldNoDefault(&faultResultSettings,  "FaultResultSettings", "Separate Fault Result", "", "", "");
 | |
|     faultResultSettings = new RimEclipseFaultColors();
 | |
|     faultResultSettings.uiCapability()->setUiHidden(true);
 | |
|   
 | |
|     CAF_PDM_InitFieldNoDefault(&stimPlanColors, "StimPlanColors", "Fracture Colors", "", "", "");
 | |
|     stimPlanColors = new RimStimPlanColors();
 | |
|     stimPlanColors.uiCapability()->setUiHidden(true);
 | |
| 
 | |
|     CAF_PDM_InitFieldNoDefault(&wellCollection, "WellCollection", "Simulation Wells", "", "", "");
 | |
|     wellCollection = new RimEclipseWellCollection;
 | |
|     wellCollection.uiCapability()->setUiHidden(true);
 | |
| 
 | |
|     CAF_PDM_InitFieldNoDefault(&faultCollection, "FaultCollection", "Faults", "", "", "");
 | |
|     faultCollection = new RimFaultCollection;
 | |
|     faultCollection.uiCapability()->setUiHidden(true);
 | |
| 
 | |
|     CAF_PDM_InitFieldNoDefault(&m_propertyFilterCollection, "PropertyFilters", "Property Filters", "", "", "");
 | |
|     m_propertyFilterCollection = new RimEclipsePropertyFilterCollection();
 | |
|     m_propertyFilterCollection.uiCapability()->setUiHidden(true);
 | |
| 
 | |
|     // Visualization fields
 | |
|     CAF_PDM_InitField(&showMainGrid,        "ShowMainGrid",         true,   "Show Main Grid",   "", "", "");
 | |
|     CAF_PDM_InitField(&showInactiveCells,   "ShowInactiveCells",    false,  "Show Inactive Cells",   "", "", "");
 | |
|     CAF_PDM_InitField(&showInvalidCells,    "ShowInvalidCells",     false,  "Show Invalid Cells",   "", "", "");
 | |
|    
 | |
|     this->cellResult()->setReservoirView(this);
 | |
| 
 | |
|     this->cellEdgeResult()->setReservoirView(this);
 | |
|     this->cellEdgeResult()->legendConfig()->setColorRangeMode(RimLegendConfig::PINK_WHITE);
 | |
| 
 | |
|     this->faultResultSettings()->setReservoirView(this);
 | |
| 
 | |
|     m_reservoirGridPartManager = new RivReservoirViewPartMgr(this);
 | |
|     m_simWellsPartManager = new RivReservoirSimWellsPartMgr(this);
 | |
| 	
 | |
| 	m_eclipseCase = NULL;
 | |
| }
 | |
| 
 | |
| //--------------------------------------------------------------------------------------------------
 | |
| /// 
 | |
| //--------------------------------------------------------------------------------------------------
 | |
| RimEclipseView::~RimEclipseView()
 | |
| {
 | |
|     delete this->faultResultSettings();
 | |
|     delete this->cellResult();
 | |
|     delete this->cellEdgeResult();
 | |
| 
 | |
|     delete m_propertyFilterCollection;
 | |
|     delete wellCollection();
 | |
|     delete faultCollection();
 | |
| 
 | |
|     m_reservoirGridPartManager->clearGeometryCache();
 | |
| 
 | |
|     m_eclipseCase = NULL;
 | |
| }
 | |
| 
 | |
| 
 | |
| //--------------------------------------------------------------------------------------------------
 | |
| /// Clamp the current timestep to actual possibilities
 | |
| //--------------------------------------------------------------------------------------------------
 | |
| void RimEclipseView::clampCurrentTimestep()
 | |
| {
 | |
|     if (this->currentGridCellResults() && this->currentGridCellResults()->cellResults()) 
 | |
|     {
 | |
|         if (m_currentTimeStep() >= static_cast<int>(this->currentGridCellResults()->cellResults()->maxTimeStepCount()))
 | |
|         {
 | |
|             m_currentTimeStep = static_cast<int>(this->currentGridCellResults()->cellResults()->maxTimeStepCount()) -1;
 | |
|         }
 | |
|     }
 | |
| 
 | |
|     if (m_currentTimeStep < 0 ) m_currentTimeStep = 0;
 | |
| }
 | |
| 
 | |
| //--------------------------------------------------------------------------------------------------
 | |
| /// 
 | |
| //--------------------------------------------------------------------------------------------------
 | |
| void RimEclipseView::fieldChangedByUi(const caf::PdmFieldHandle* changedField, const QVariant& oldValue, const QVariant& newValue)
 | |
| {
 | |
|     RimView::fieldChangedByUi(changedField, oldValue, newValue);
 | |
| 
 | |
|     if (changedField == &showInvalidCells)
 | |
|     {
 | |
|         this->scheduleGeometryRegen(INACTIVE);
 | |
|         this->scheduleGeometryRegen(RANGE_FILTERED_INACTIVE);
 | |
| 
 | |
|         scheduleCreateDisplayModelAndRedraw();
 | |
|     }
 | |
|     else if (changedField == &showInactiveCells)
 | |
|     {
 | |
|         this->updateGridBoxData();
 | |
|         
 | |
|         this->scheduleGeometryRegen(INACTIVE);
 | |
|         this->scheduleGeometryRegen(RANGE_FILTERED_INACTIVE);
 | |
| 
 | |
|         scheduleCreateDisplayModelAndRedraw();
 | |
|     }
 | |
|     else if (changedField == &showMainGrid)
 | |
|     {
 | |
|         scheduleCreateDisplayModelAndRedraw();
 | |
|     }
 | |
|     else if (changedField == &m_rangeFilterCollection)
 | |
|     {
 | |
|         this->scheduleGeometryRegen(RANGE_FILTERED);
 | |
|         this->scheduleGeometryRegen(RANGE_FILTERED_INACTIVE);
 | |
| 
 | |
|         scheduleCreateDisplayModelAndRedraw();
 | |
|     }
 | |
|     else if (changedField == &m_propertyFilterCollection)
 | |
|     {
 | |
|         this->scheduleGeometryRegen(PROPERTY_FILTERED);
 | |
| 
 | |
|         scheduleCreateDisplayModelAndRedraw();
 | |
|     }
 | |
| 
 | |
| 
 | |
| }
 | |
| 
 | |
| //--------------------------------------------------------------------------------------------------
 | |
| /// 
 | |
| //--------------------------------------------------------------------------------------------------
 | |
| void RimEclipseView::updateScaleTransform()
 | |
| {
 | |
|     cvf::Mat4d scale = cvf::Mat4d::IDENTITY;
 | |
|     scale(2, 2) = scaleZ();
 | |
| 
 | |
|     this->scaleTransform()->setLocalTransform(scale);
 | |
|     m_simWellsPartManager->setScaleTransform(this->scaleTransform());
 | |
| 
 | |
|     // Regenerate fracture geometry
 | |
|     std::vector<RimFracture*> fractures;
 | |
|     this->descendantsIncludingThisOfType(fractures);
 | |
|     for (RimFracture* fracture : fractures)
 | |
|     {
 | |
|         fracture->setRecomputeGeometryFlag();
 | |
|     }
 | |
| 
 | |
|     if (m_viewer) m_viewer->updateCachedValuesInScene();
 | |
| }
 | |
| 
 | |
| //--------------------------------------------------------------------------------------------------
 | |
| /// Create display model,
 | |
| /// or at least empty scenes as frames that is delivered to the viewer
 | |
| /// The real geometry generation is done inside RivReservoirViewGeometry and friends
 | |
| //--------------------------------------------------------------------------------------------------
 | |
| void RimEclipseView::createDisplayModel()
 | |
| {
 | |
|     if (m_viewer.isNull()) return;
 | |
| 
 | |
| #if 0 // Debug info
 | |
|     static int callCount = 0;
 | |
|     std::cout << "RimReservoirView::createDisplayModel() " << callCount++ << std::endl;
 | |
|     RiuMainWindow::instance()->setResultInfo(QString("RimReservoirView::createDisplayModel() ") + QString::number(callCount++));
 | |
| #endif
 | |
| 
 | |
|     if (!(m_eclipseCase && m_eclipseCase->eclipseCaseData())) return;
 | |
| 
 | |
|     // Define a vector containing time step indices to produce geometry for.
 | |
|     // First entry in this vector is used to define the geometry only result mode with no results.
 | |
|     std::vector<size_t> timeStepIndices;
 | |
| 
 | |
|     // The one and only geometry entry
 | |
|     timeStepIndices.push_back(0);
 | |
| 
 | |
|     // Find the number of time frames the animation needs to show the requested data.
 | |
| 
 | |
|     if (isTimeStepDependentDataVisible())
 | |
|     {
 | |
|         CVF_ASSERT(currentGridCellResults());
 | |
| 
 | |
|         size_t i;
 | |
|         for (i = 0; i < currentGridCellResults()->cellResults()->maxTimeStepCount(); i++)
 | |
|         {
 | |
|             timeStepIndices.push_back(i);
 | |
|         }
 | |
|     } 
 | |
|     else if (this->cellResult()->hasStaticResult() 
 | |
|         || this->cellEdgeResult()->hasResult() 
 | |
|         || this->eclipsePropertyFilterCollection()->hasActiveFilters())
 | |
|     {
 | |
|         // The one and only result entry
 | |
|         timeStepIndices.push_back(0);
 | |
|     }
 | |
| 
 | |
| 
 | |
| 
 | |
|     cvf::Collection<cvf::ModelBasicList> frameModels;
 | |
|     size_t timeIdx;
 | |
|     for (timeIdx = 0; timeIdx < timeStepIndices.size(); timeIdx++)
 | |
|     {
 | |
|         frameModels.push_back(new cvf::ModelBasicList);
 | |
|     }
 | |
| 
 | |
|     // Remove all existing animation frames from the viewer. 
 | |
|     // The parts are still cached in the RivReservoir geometry and friends
 | |
|     m_viewer->removeAllFrames();
 | |
| 
 | |
|     wellCollection->scheduleIsWellPipesVisibleRecalculation();
 | |
| 
 | |
|     // Create vector of grid indices to render
 | |
|     std::vector<size_t> gridIndices;
 | |
|     this->indicesToVisibleGrids(&gridIndices);
 | |
| 
 | |
|     ///
 | |
|     // Get or create the parts for "static" type geometry. The same geometry is used 
 | |
|     // for the different frames. updateCurrentTimeStep updates the colors etc.
 | |
|     // For property filtered geometry : just set all the models as empty scenes 
 | |
|     // updateCurrentTimeStep requests the actual parts
 | |
|     
 | |
| 
 | |
|     if (!this->eclipsePropertyFilterCollection()->hasActiveFilters()
 | |
|         || this->viewController() && this->viewController()->isVisibleCellsOveridden())
 | |
|     {
 | |
|         std::vector<RivCellSetEnum> geometryTypesToAdd;
 | |
| 
 | |
|         if (this->viewController() && this->viewController()->isVisibleCellsOveridden())
 | |
|         {
 | |
|             geometryTypesToAdd.push_back(OVERRIDDEN_CELL_VISIBILITY);
 | |
|         }
 | |
|         else if (this->rangeFilterCollection()->hasActiveFilters() && this->wellCollection()->hasVisibleWellCells())
 | |
|         {
 | |
|             geometryTypesToAdd.push_back(RANGE_FILTERED);
 | |
|             geometryTypesToAdd.push_back(RANGE_FILTERED_WELL_CELLS);
 | |
|             geometryTypesToAdd.push_back(VISIBLE_WELL_CELLS_OUTSIDE_RANGE_FILTER);
 | |
|             geometryTypesToAdd.push_back(VISIBLE_WELL_FENCE_CELLS_OUTSIDE_RANGE_FILTER);
 | |
|             if (this->showInactiveCells())
 | |
|             {
 | |
|                 geometryTypesToAdd.push_back(RANGE_FILTERED_INACTIVE);
 | |
|             }
 | |
|         }
 | |
|         else if (!this->rangeFilterCollection()->hasActiveFilters() && this->wellCollection()->hasVisibleWellCells())
 | |
|         {
 | |
|             geometryTypesToAdd.push_back(VISIBLE_WELL_CELLS);
 | |
|             geometryTypesToAdd.push_back(VISIBLE_WELL_FENCE_CELLS);
 | |
|         }
 | |
|         else if (this->rangeFilterCollection()->hasActiveFilters() && !this->wellCollection()->hasVisibleWellCells())
 | |
|         {
 | |
|             geometryTypesToAdd.push_back(RANGE_FILTERED);
 | |
|             geometryTypesToAdd.push_back(RANGE_FILTERED_WELL_CELLS);
 | |
|             if (this->showInactiveCells())
 | |
|             {
 | |
|                 geometryTypesToAdd.push_back(RANGE_FILTERED_INACTIVE);
 | |
|             }
 | |
|         }
 | |
|         else
 | |
|         {
 | |
|             geometryTypesToAdd.push_back(ALL_WELL_CELLS); // Should be all well cells
 | |
|             geometryTypesToAdd.push_back(ACTIVE);
 | |
| 
 | |
|             if (this->showInactiveCells())
 | |
|             {
 | |
|                 geometryTypesToAdd.push_back(INACTIVE);
 | |
|             }
 | |
|         }
 | |
| 
 | |
|         // NOTE: This assignment must be done here, as m_visibleGridParts is used in code triggered by 
 | |
|         // m_reservoirGridPartManager->appendStaticGeometryPartsToModel()
 | |
|         m_visibleGridParts = geometryTypesToAdd;
 | |
| 
 | |
|         size_t frameIdx;
 | |
|         for (frameIdx = 0; frameIdx < frameModels.size(); ++frameIdx)
 | |
|         {
 | |
|             for (size_t gtIdx = 0; gtIdx < geometryTypesToAdd.size(); ++gtIdx)
 | |
|             {
 | |
|                 m_reservoirGridPartManager->appendStaticGeometryPartsToModel(frameModels[frameIdx].p(), geometryTypesToAdd[gtIdx], gridIndices); 
 | |
|             }
 | |
|         }
 | |
| 
 | |
|         // Set static colors 
 | |
|         this->updateStaticCellColors();
 | |
|     }
 | |
| 
 | |
|     m_reservoirGridPartManager->clearWatertightGeometryFlags();
 | |
| 
 | |
|     if (faultCollection()->showFaultsOutsideFilters() || !this->eclipsePropertyFilterCollection()->hasActiveFilters() )
 | |
|     {
 | |
|         for (RivCellSetEnum cellSetType : m_visibleGridParts)
 | |
|         {
 | |
|             m_reservoirGridPartManager->forceWatertightGeometryOnForType(cellSetType);
 | |
|         }
 | |
| 
 | |
|         std::set<RivCellSetEnum> faultGeometryTypesToAppend = allVisibleFaultGeometryTypes();
 | |
|         RivCellSetEnum faultLabelType = m_reservoirGridPartManager->geometryTypeForFaultLabels(faultGeometryTypesToAppend, faultCollection()->showFaultsOutsideFilters());
 | |
| 
 | |
|         for (size_t frameIdx = 0; frameIdx < frameModels.size(); ++frameIdx)
 | |
|         {
 | |
|             for (RivCellSetEnum geometryType : faultGeometryTypesToAppend)
 | |
|             {
 | |
|                 if (geometryType == PROPERTY_FILTERED || geometryType == PROPERTY_FILTERED_WELL_CELLS) continue;
 | |
|                 m_reservoirGridPartManager->appendFaultsStaticGeometryPartsToModel(frameModels[frameIdx].p(), geometryType);
 | |
|             }
 | |
| 
 | |
|             m_reservoirGridPartManager->appendFaultLabelsStaticGeometryPartsToModel(frameModels[frameIdx].p(), faultLabelType);
 | |
|         }
 | |
|     }
 | |
| 
 | |
| 
 | |
|     // Cross sections
 | |
| 
 | |
|     m_crossSectionVizModel->removeAllParts();
 | |
|     crossSectionCollection->appendPartsToModel(m_crossSectionVizModel.p(), m_reservoirGridPartManager->scaleTransform());
 | |
|     m_viewer->addStaticModelOnce(m_crossSectionVizModel.p());
 | |
| 
 | |
| 
 | |
|     // Compute triangle count, Debug only
 | |
| /*
 | |
|     if (false)
 | |
|     {
 | |
|         size_t totalTriangleCount = 0;
 | |
|         {
 | |
|             size_t mIdx;
 | |
|             for (mIdx = 0; mIdx < frameModels.size(); mIdx++)
 | |
|             {
 | |
|                 cvf::Collection<cvf::Part> partCollection;
 | |
|                 frameModels.at(mIdx)->allParts(&partCollection);
 | |
| 
 | |
|                 size_t modelTriangleCount = 0;
 | |
|                 size_t pIdx;
 | |
|                 for (pIdx = 0; pIdx < partCollection.size(); pIdx++)
 | |
|                 {
 | |
|                     modelTriangleCount += partCollection.at(pIdx)->drawable()->triangleCount();
 | |
|                 }
 | |
| 
 | |
|                 totalTriangleCount += modelTriangleCount;
 | |
|             }
 | |
|         }
 | |
|     }
 | |
| */
 | |
|     // Well path model
 | |
| 
 | |
| 
 | |
|     m_wellPathPipeVizModel->removeAllParts();
 | |
| 
 | |
|     RigMainGrid* mainGrid = this->mainGrid();
 | |
|     if (mainGrid)
 | |
|     {
 | |
|         addWellPathsToModel(m_wellPathPipeVizModel.p(),
 | |
|             mainGrid->displayModelOffset(),
 | |
|             mainGrid->characteristicIJCellSize(),
 | |
|             currentActiveCellInfo()->geometryBoundingBox(),
 | |
|             m_reservoirGridPartManager->scaleTransform());
 | |
|     }
 | |
| 
 | |
|     m_viewer->addStaticModelOnce(m_wellPathPipeVizModel.p());
 | |
| 
 | |
|     // Create Scenes from the frameModels
 | |
|     // Animation frames for results display, starts from frame 1
 | |
| 
 | |
| 
 | |
|     size_t frameIndex;
 | |
|     for (frameIndex = 0; frameIndex < frameModels.size(); frameIndex++)
 | |
|     {
 | |
|         cvf::ModelBasicList* model = frameModels.at(frameIndex);
 | |
|         model->updateBoundingBoxesRecursive();
 | |
| 
 | |
|         cvf::ref<cvf::Scene> scene = new cvf::Scene;
 | |
|         scene->addModel(model);
 | |
| 
 | |
|         if (frameIndex == 0)
 | |
|             m_viewer->setMainScene(scene.p());
 | |
|         else
 | |
|             m_viewer->addFrame(scene.p());
 | |
|     }
 | |
| 
 | |
|     // If the animation was active before recreating everything, make viewer view current frame
 | |
| 
 | |
|     if (frameModels.size() > 1 && this->hasUserRequestedAnimation())
 | |
|     {
 | |
|         m_viewer->setCurrentFrame(m_currentTimeStep);
 | |
|     }
 | |
|     else
 | |
|     {
 | |
|         m_overlayInfoConfig()->update3DInfo();
 | |
|         updateLegends();
 | |
|     }
 | |
| }
 | |
| 
 | |
| //--------------------------------------------------------------------------------------------------
 | |
| /// 
 | |
| //--------------------------------------------------------------------------------------------------
 | |
| void RimEclipseView::updateCurrentTimeStep()
 | |
| {
 | |
|     m_propertyFilterCollection()->updateFromCurrentTimeStep();
 | |
| 
 | |
|     updateLegends(); // To make sure the scalar mappers are set up correctly
 | |
| 
 | |
|     std::vector<RivCellSetEnum> geometriesToRecolor;
 | |
| 
 | |
|     if (this->viewController() && this->viewController()->isVisibleCellsOveridden())
 | |
|     {
 | |
|         geometriesToRecolor.push_back(OVERRIDDEN_CELL_VISIBILITY);
 | |
|     }
 | |
|     else if (this->eclipsePropertyFilterCollection()->hasActiveFilters())
 | |
|     {
 | |
|         cvf::ref<cvf::ModelBasicList> frameParts = new cvf::ModelBasicList;
 | |
|         frameParts->setName("GridModel");
 | |
| 
 | |
|         std::vector<size_t> gridIndices;
 | |
|         this->indicesToVisibleGrids(&gridIndices);
 | |
| 
 | |
|         geometriesToRecolor.push_back( PROPERTY_FILTERED);
 | |
|         m_reservoirGridPartManager->appendDynamicGeometryPartsToModel(frameParts.p(), PROPERTY_FILTERED, m_currentTimeStep, gridIndices);
 | |
| 
 | |
|         geometriesToRecolor.push_back( PROPERTY_FILTERED_WELL_CELLS);
 | |
|         m_reservoirGridPartManager->appendDynamicGeometryPartsToModel(frameParts.p(), PROPERTY_FILTERED_WELL_CELLS, m_currentTimeStep, gridIndices);
 | |
| 
 | |
|         m_visibleGridParts = geometriesToRecolor;
 | |
| 
 | |
|         std::set<RivCellSetEnum> faultGeometryTypesToAppend = allVisibleFaultGeometryTypes();
 | |
|         for (RivCellSetEnum geometryType : faultGeometryTypesToAppend)
 | |
|         {
 | |
|             if (geometryType == PROPERTY_FILTERED || geometryType == PROPERTY_FILTERED_WELL_CELLS)
 | |
|             {
 | |
|                 m_reservoirGridPartManager->appendFaultsDynamicGeometryPartsToModel(frameParts.p(), geometryType, m_currentTimeStep);
 | |
|             }
 | |
|             else
 | |
|             {
 | |
|                 m_reservoirGridPartManager->appendFaultsStaticGeometryPartsToModel(frameParts.p(), geometryType);
 | |
|             }
 | |
|         }
 | |
| 
 | |
|         RivCellSetEnum faultLabelType = m_reservoirGridPartManager->geometryTypeForFaultLabels(faultGeometryTypesToAppend, faultCollection()->showFaultsOutsideFilters());
 | |
|         if (faultLabelType == PROPERTY_FILTERED)
 | |
|         {
 | |
|             m_reservoirGridPartManager->appendFaultLabelsDynamicGeometryPartsToModel(frameParts.p(), faultLabelType, m_currentTimeStep);
 | |
|         }
 | |
|         else
 | |
|         {
 | |
|             m_reservoirGridPartManager->appendFaultLabelsStaticGeometryPartsToModel(frameParts.p(), faultLabelType);
 | |
|         }
 | |
| 
 | |
| 
 | |
|         // Set the transparency on all the Wellcell parts before setting the result color
 | |
|         float opacity = static_cast< float> (1 - cvf::Math::clamp(this->wellCollection()->wellCellTransparencyLevel(), 0.0, 1.0));
 | |
|         m_reservoirGridPartManager->updateCellColor(PROPERTY_FILTERED_WELL_CELLS, m_currentTimeStep, cvf::Color4f(cvf::Color3f(cvf::Color3::WHITE), opacity));
 | |
| 
 | |
| 
 | |
|         if (this->showInactiveCells())
 | |
|         {
 | |
|             std::vector<size_t> gridIndices;
 | |
|             this->indicesToVisibleGrids(&gridIndices);
 | |
|  
 | |
|             if (this->rangeFilterCollection()->hasActiveFilters() ) // Wells not considered, because we do not have a INACTIVE_WELL_CELLS group yet.
 | |
|             {
 | |
|                 m_reservoirGridPartManager->appendStaticGeometryPartsToModel(frameParts.p(), RANGE_FILTERED_INACTIVE, gridIndices); 
 | |
| 
 | |
|                 if (!faultCollection()->showFaultsOutsideFilters())
 | |
|                 {
 | |
|                     m_reservoirGridPartManager->appendFaultsStaticGeometryPartsToModel(frameParts.p(), RANGE_FILTERED_INACTIVE); 
 | |
|                 }
 | |
|             }
 | |
|             else
 | |
|             {
 | |
|                 m_reservoirGridPartManager->appendStaticGeometryPartsToModel(frameParts.p(), INACTIVE, gridIndices);
 | |
| 
 | |
|                 if (!faultCollection()->showFaultsOutsideFilters())
 | |
|                 {
 | |
|                     m_reservoirGridPartManager->appendFaultsStaticGeometryPartsToModel(frameParts.p(), INACTIVE);
 | |
|                 }
 | |
|             }
 | |
|         }
 | |
| 
 | |
|         if (m_viewer)
 | |
|         {
 | |
|             cvf::Scene* frameScene = m_viewer->frame(m_currentTimeStep);
 | |
|             if (frameScene)
 | |
|             {
 | |
|                 this->removeModelByName(frameScene, frameParts->name());
 | |
|                 frameScene->addModel(frameParts.p());
 | |
|                 frameParts->updateBoundingBoxesRecursive();
 | |
|             }
 | |
|         }
 | |
|     }
 | |
|     else if (this->rangeFilterCollection()->hasActiveFilters() && this->wellCollection()->hasVisibleWellCells())
 | |
|     {
 | |
|         geometriesToRecolor.push_back(RANGE_FILTERED);
 | |
|         geometriesToRecolor.push_back(RANGE_FILTERED_WELL_CELLS);
 | |
|         geometriesToRecolor.push_back(VISIBLE_WELL_CELLS_OUTSIDE_RANGE_FILTER);
 | |
|         geometriesToRecolor.push_back(VISIBLE_WELL_FENCE_CELLS_OUTSIDE_RANGE_FILTER);
 | |
|     }
 | |
|     else if (!this->rangeFilterCollection()->hasActiveFilters() && this->wellCollection()->hasVisibleWellCells())
 | |
|     {
 | |
|         geometriesToRecolor.push_back(VISIBLE_WELL_CELLS);
 | |
|         geometriesToRecolor.push_back(VISIBLE_WELL_FENCE_CELLS);
 | |
|     }
 | |
|     else if (this->rangeFilterCollection()->hasActiveFilters() && !this->wellCollection()->hasVisibleWellCells())
 | |
|     {
 | |
|         geometriesToRecolor.push_back(RANGE_FILTERED);
 | |
|         geometriesToRecolor.push_back(RANGE_FILTERED_WELL_CELLS);
 | |
|     }
 | |
|     else 
 | |
|     {
 | |
|         geometriesToRecolor.push_back(ACTIVE);
 | |
|         geometriesToRecolor.push_back(ALL_WELL_CELLS);
 | |
|     }
 | |
| 
 | |
|     for (size_t i = 0; i < geometriesToRecolor.size(); ++i)
 | |
|     {
 | |
|         if (this->hasUserRequestedAnimation() && this->cellEdgeResult()->hasResult())
 | |
|         {
 | |
|             m_reservoirGridPartManager->updateCellEdgeResultColor(geometriesToRecolor[i], m_currentTimeStep, this->cellResult(), this->cellEdgeResult());
 | |
|         } 
 | |
|         else if ((this->hasUserRequestedAnimation() && this->cellResult()->hasResult()) || this->cellResult()->isTernarySaturationSelected())
 | |
|         {
 | |
|             m_reservoirGridPartManager->updateCellResultColor(geometriesToRecolor[i], m_currentTimeStep, this->cellResult());
 | |
|         }
 | |
|         else
 | |
|         {
 | |
|             this->updateStaticCellColors(geometriesToRecolor[i]);
 | |
|         }
 | |
|     }
 | |
| 
 | |
|     this->updateFaultColors();
 | |
| 
 | |
| 
 | |
|     if ((this->hasUserRequestedAnimation() && this->cellResult()->hasResult()) || this->cellResult()->isTernarySaturationSelected())
 | |
|     {
 | |
|         crossSectionCollection->updateCellResultColor(m_currentTimeStep);
 | |
|     }
 | |
|     else
 | |
|     {
 | |
|         crossSectionCollection->applySingleColorEffect();
 | |
|     }
 | |
| 
 | |
|     // Simulation Wells
 | |
|     if (m_viewer)
 | |
|     {
 | |
|         cvf::Scene* frameScene = m_viewer->frame(m_currentTimeStep);
 | |
|         if (frameScene)
 | |
|         {
 | |
|             cvf::ref<cvf::ModelBasicList> simWellModelBasicList = new cvf::ModelBasicList;
 | |
|             simWellModelBasicList->setName("SimWellPipeMod");
 | |
| 
 | |
|             m_simWellsPartManager->appendDynamicGeometryPartsToModel(simWellModelBasicList.p(), m_currentTimeStep);
 | |
| 
 | |
|             simWellModelBasicList->updateBoundingBoxesRecursive();
 | |
| 
 | |
|             this->removeModelByName(frameScene, simWellModelBasicList->name());
 | |
|             frameScene->addModel(simWellModelBasicList.p());
 | |
|             cvf::ref<caf::DisplayCoordTransform> transForm = this->displayCoordTransform();
 | |
| 
 | |
|             std::vector<RimFracture*> fractures;
 | |
|             this->descendantsIncludingThisOfType(fractures);
 | |
|             for (RimFracture* f : fractures)
 | |
|             {
 | |
|                 RimEclipseWell* eclWell = nullptr;
 | |
|                 f->firstAncestorOrThisOfType(eclWell);
 | |
|                 if (eclWell)
 | |
|                 {
 | |
|                     bool isAnyGeometryPresent = eclWell->isWellPipeVisible(m_currentTimeStep) || eclWell->isWellSpheresVisible(m_currentTimeStep);
 | |
|                     if (!isAnyGeometryPresent)
 | |
|                     {
 | |
|                         continue;
 | |
|                     }
 | |
|                 }
 | |
| 
 | |
|                 f->fracturePartManager()->appendGeometryPartsToModel(simWellModelBasicList.p(), transForm.p());
 | |
|             }
 | |
| 
 | |
|             simWellModelBasicList->updateBoundingBoxesRecursive();
 | |
| 
 | |
|             m_simWellsPartManager->updatePipeResultColor(m_currentTimeStep);
 | |
|         }
 | |
|     }
 | |
| 
 | |
|     m_overlayInfoConfig()->update3DInfo();
 | |
| 
 | |
|     // Invisible Wells are marked as read only when "show wells intersecting visible cells" is enabled
 | |
|     // Visibility of wells differ betweeen time steps, so trigger a rebuild of tree state items
 | |
|     wellCollection->updateConnectedEditors();
 | |
| }
 | |
| 
 | |
| //--------------------------------------------------------------------------------------------------
 | |
| /// 
 | |
| //--------------------------------------------------------------------------------------------------
 | |
| void RimEclipseView::loadDataAndUpdate()
 | |
| {
 | |
|     updateScaleTransform();
 | |
| 
 | |
|     if (m_eclipseCase)
 | |
|     {
 | |
|         if (!m_eclipseCase->openReserviorCase())
 | |
|         {
 | |
|             QMessageBox::warning(RiuMainWindow::instance(), 
 | |
|                                 "Error when opening project file", 
 | |
|                                 "Could not open the Eclipse Grid file: \n"+ m_eclipseCase->gridFileName());
 | |
|             this->setEclipseCase( NULL);
 | |
|             return;
 | |
|         }
 | |
|     }
 | |
| 
 | |
|     CVF_ASSERT(this->cellResult() != NULL);
 | |
|     this->cellResult()->loadResult();
 | |
| 
 | |
|     CVF_ASSERT(this->cellEdgeResult() != NULL);
 | |
|     this->cellEdgeResult()->loadResult();
 | |
| 
 | |
|     this->faultResultSettings()->customFaultResult()->loadResult();
 | |
|     this->stimPlanColors->loadDataAndUpdate();
 | |
| 
 | |
|     updateMdiWindowVisibility();
 | |
| 
 | |
|     this->m_propertyFilterCollection()->loadAndInitializePropertyFilters();
 | |
| 
 | |
|     this->faultCollection()->setReservoirView(this);
 | |
|     this->faultCollection()->syncronizeFaults();
 | |
| 
 | |
|     m_reservoirGridPartManager->clearGeometryCache();
 | |
|     m_simWellsPartManager->clearGeometryCache();
 | |
| 
 | |
|     syncronizeWellsWithResults();
 | |
| 
 | |
|     this->scheduleCreateDisplayModelAndRedraw();
 | |
| 
 | |
| }
 | |
| 
 | |
| 
 | |
| 
 | |
| //--------------------------------------------------------------------------------------------------
 | |
| /// 
 | |
| //--------------------------------------------------------------------------------------------------
 | |
| void RimEclipseView::initAfterRead()
 | |
| {
 | |
|     RimViewWindow::initAfterRead();
 | |
| 
 | |
|     this->faultResultSettings()->setReservoirView(this);
 | |
|     this->cellResult()->setReservoirView(this);
 | |
|     this->cellEdgeResult()->setReservoirView(this);
 | |
| 
 | |
|     this->updateUiIconFromToggleField();
 | |
| }
 | |
| 
 | |
| 
 | |
| //--------------------------------------------------------------------------------------------------
 | |
| /// 
 | |
| //--------------------------------------------------------------------------------------------------
 | |
| void RimEclipseView::updateStaticCellColors()
 | |
| {
 | |
|     updateStaticCellColors( OVERRIDDEN_CELL_VISIBILITY);
 | |
|     updateStaticCellColors( ACTIVE);
 | |
|     updateStaticCellColors( ALL_WELL_CELLS);
 | |
|     updateStaticCellColors( VISIBLE_WELL_CELLS);
 | |
|     updateStaticCellColors( VISIBLE_WELL_FENCE_CELLS);
 | |
|     updateStaticCellColors( VISIBLE_WELL_CELLS_OUTSIDE_RANGE_FILTER);
 | |
|     updateStaticCellColors( VISIBLE_WELL_FENCE_CELLS_OUTSIDE_RANGE_FILTER);
 | |
|     updateStaticCellColors( INACTIVE);
 | |
|     updateStaticCellColors( RANGE_FILTERED);
 | |
|     updateStaticCellColors( RANGE_FILTERED_WELL_CELLS);
 | |
|     updateStaticCellColors( RANGE_FILTERED_INACTIVE);
 | |
| }
 | |
| 
 | |
| //--------------------------------------------------------------------------------------------------
 | |
| /// 
 | |
| //--------------------------------------------------------------------------------------------------
 | |
| void RimEclipseView::updateStaticCellColors(RivCellSetEnum geometryType)
 | |
| {
 | |
|     float opacity = static_cast< float> (1 - cvf::Math::clamp(this->wellCollection()->wellCellTransparencyLevel(), 0.0, 1.0));
 | |
|     cvf::Color4f color(cvf::Color3::ORANGE);
 | |
| 
 | |
|     switch (geometryType)
 | |
|     {
 | |
|         case ACTIVE:                      color = cvf::Color4f(cvf::Color3::ORANGE);      break;
 | |
|         case ALL_WELL_CELLS:              color = cvf::Color4f(cvf::Color3f(cvf::Color3::BROWN), opacity ); break;
 | |
|         case VISIBLE_WELL_CELLS:          color = cvf::Color4f(cvf::Color3f(cvf::Color3::BROWN), opacity ); break;
 | |
|         case VISIBLE_WELL_FENCE_CELLS:    color = cvf::Color4f(cvf::Color3::ORANGE);      break;
 | |
|         case VISIBLE_WELL_CELLS_OUTSIDE_RANGE_FILTER:         
 | |
|                                                                     color = cvf::Color4f(cvf::Color3f(cvf::Color3::BROWN), opacity ); break;
 | |
|         case VISIBLE_WELL_FENCE_CELLS_OUTSIDE_RANGE_FILTER:   
 | |
|                                                                     color = cvf::Color4f(cvf::Color3::ORANGE);      break;
 | |
|         case INACTIVE:                    color = cvf::Color4f(cvf::Color3::LIGHT_GRAY);  break;
 | |
|         case RANGE_FILTERED:              color = cvf::Color4f(cvf::Color3::ORANGE);      break;
 | |
|         case RANGE_FILTERED_WELL_CELLS:   color = cvf::Color4f(cvf::Color3f(cvf::Color3::BROWN), opacity ); break;
 | |
|         case RANGE_FILTERED_INACTIVE:     color = cvf::Color4f(cvf::Color3::LIGHT_GRAY);  break;   
 | |
|     }
 | |
| 
 | |
|     if (geometryType == PROPERTY_FILTERED || geometryType == PROPERTY_FILTERED_WELL_CELLS)
 | |
|     {
 | |
|         // Always use current time step when updating color of property geometry
 | |
|         m_reservoirGridPartManager->updateCellColor(geometryType, m_currentTimeStep, color);
 | |
|     }
 | |
|     else
 | |
|     {
 | |
|         // Use static timestep (timestep 0) for geometry with no change between time steps
 | |
|         m_reservoirGridPartManager->updateCellColor(geometryType, 0, color);
 | |
|     }
 | |
| }
 | |
| 
 | |
| //--------------------------------------------------------------------------------------------------
 | |
| /// 
 | |
| //--------------------------------------------------------------------------------------------------
 | |
| void RimEclipseView::updateDisplayModelVisibility()
 | |
| {
 | |
|     if (m_viewer.isNull()) return;
 | |
| 
 | |
|     const cvf::uint uintSurfaceBit      = surfaceBit;
 | |
|     const cvf::uint uintMeshSurfaceBit  = meshSurfaceBit;
 | |
|     const cvf::uint uintFaultBit        = faultBit;
 | |
|     const cvf::uint uintMeshFaultBit    = meshFaultBit;
 | |
|  
 | |
|     // Initialize the mask to show everything except the the bits controlled here
 | |
|     unsigned int mask = 0xffffffff & ~uintSurfaceBit & ~uintFaultBit & ~uintMeshSurfaceBit & ~uintMeshFaultBit ;
 | |
| 
 | |
|     // Then turn the appropriate bits on according to the user settings
 | |
| 
 | |
|     if (surfaceMode == SURFACE)
 | |
|     {
 | |
|          mask |= uintSurfaceBit;
 | |
|          mask |= uintFaultBit;
 | |
|     }
 | |
|     else if (surfaceMode == FAULTS)
 | |
|     {
 | |
|         mask |= uintFaultBit;
 | |
|     }
 | |
| 
 | |
|     if (meshMode == FULL_MESH)
 | |
|     {
 | |
|         mask |= uintMeshSurfaceBit;
 | |
|         mask |= uintMeshFaultBit;
 | |
|     }
 | |
|     else if (meshMode == FAULTS_MESH)
 | |
|     {
 | |
|         mask |= uintMeshFaultBit;
 | |
|     }
 | |
| 
 | |
|     m_viewer->setEnableMask(mask);
 | |
|     m_viewer->update();
 | |
| 
 | |
|     faultCollection->updateConnectedEditors();
 | |
| 
 | |
|     // This is required to update the read-only state of simulation wells
 | |
|     // when a range filter is manipulated and visible simulation wells might change
 | |
|     //
 | |
|     // The visibility is controlled by RimEclipseWell::defineUiTreeOrdering
 | |
|     // updateConnectedEditors will call recursively on child objects
 | |
|     wellCollection->updateConnectedEditors();
 | |
| }
 | |
| 
 | |
| //--------------------------------------------------------------------------------------------------
 | |
| /// Convenience for quick access to results
 | |
| //--------------------------------------------------------------------------------------------------
 | |
| RimReservoirCellResultsStorage* RimEclipseView::currentGridCellResults()
 | |
| {
 | |
|     if (m_eclipseCase)
 | |
|     {
 | |
|         RifReaderInterface::PorosityModelResultType porosityModel = RigCaseCellResultsData::convertFromProjectModelPorosityModel(cellResult->porosityModel());
 | |
| 
 | |
|         return m_eclipseCase->results(porosityModel);
 | |
|     }
 | |
| 
 | |
|     return NULL;
 | |
| }
 | |
| 
 | |
| //--------------------------------------------------------------------------------------------------
 | |
| /// 
 | |
| //--------------------------------------------------------------------------------------------------
 | |
| RigActiveCellInfo* RimEclipseView::currentActiveCellInfo()
 | |
| {
 | |
|     if (m_eclipseCase &&
 | |
|         m_eclipseCase->eclipseCaseData()
 | |
|         )
 | |
|     {
 | |
|         RifReaderInterface::PorosityModelResultType porosityModel = RigCaseCellResultsData::convertFromProjectModelPorosityModel(cellResult->porosityModel());
 | |
| 
 | |
|         return m_eclipseCase->eclipseCaseData()->activeCellInfo(porosityModel);
 | |
|     }
 | |
| 
 | |
|     return NULL;
 | |
| }
 | |
| 
 | |
| 
 | |
| //--------------------------------------------------------------------------------------------------
 | |
| /// 
 | |
| //--------------------------------------------------------------------------------------------------
 | |
| void RimEclipseView::scheduleGeometryRegen(RivCellSetEnum geometryType)
 | |
| {
 | |
|     m_reservoirGridPartManager->scheduleGeometryRegen(geometryType);
 | |
| 
 | |
|     if (this->isMasterView())
 | |
|     {
 | |
|         RimViewLinker* viewLinker = this->assosiatedViewLinker();
 | |
|         if (viewLinker)
 | |
|         {
 | |
|             viewLinker->scheduleGeometryRegenForDepViews(geometryType);
 | |
|         }
 | |
|     }
 | |
| 
 | |
|     m_currentReservoirCellVisibility = NULL;
 | |
| }
 | |
| 
 | |
| //--------------------------------------------------------------------------------------------------
 | |
| /// 
 | |
| //--------------------------------------------------------------------------------------------------
 | |
| void RimEclipseView::scheduleReservoirGridGeometryRegen()
 | |
| {
 | |
|     m_reservoirGridPartManager->clearGeometryCache();
 | |
| }
 | |
| 
 | |
| //--------------------------------------------------------------------------------------------------
 | |
| ///
 | |
| //--------------------------------------------------------------------------------------------------
 | |
| void RimEclipseView::scheduleSimWellGeometryRegen()
 | |
| {
 | |
|     m_simWellsPartManager->scheduleGeometryRegen();
 | |
| }
 | |
| 
 | |
| 
 | |
| //--------------------------------------------------------------------------------------------------
 | |
| /// 
 | |
| //--------------------------------------------------------------------------------------------------
 | |
| void RimEclipseView::indicesToVisibleGrids(std::vector<size_t>* gridIndices)
 | |
| {
 | |
|     CVF_ASSERT(gridIndices != NULL);
 | |
| 
 | |
|     // Create vector of grid indices to render
 | |
|     std::vector<RigGridBase*> grids;
 | |
|     if (this->m_eclipseCase && this->m_eclipseCase->eclipseCaseData() )
 | |
|     {
 | |
|         this->m_eclipseCase->eclipseCaseData()->allGrids(&grids);
 | |
|     }
 | |
| 
 | |
|     size_t i;
 | |
|     for (i = 0; i < grids.size(); i++)
 | |
|     {
 | |
|         if (!grids[i]->isMainGrid() || this->showMainGrid() )
 | |
|         {
 | |
|             gridIndices->push_back(i);
 | |
|         }
 | |
|     }
 | |
| }
 | |
| 
 | |
| //--------------------------------------------------------------------------------------------------
 | |
| /// 
 | |
| //--------------------------------------------------------------------------------------------------
 | |
| void RimEclipseView::updateLegends()
 | |
| {
 | |
|     if (m_viewer)
 | |
|     {
 | |
|         m_viewer->removeAllColorLegends();
 | |
|     }
 | |
| 
 | |
|     if (!m_eclipseCase || !m_viewer || !m_eclipseCase->eclipseCaseData() )
 | |
|     {
 | |
|         return;
 | |
|     }
 | |
| 
 | |
|     RigEclipseCaseData* eclipseCase = m_eclipseCase->eclipseCaseData();
 | |
|     CVF_ASSERT(eclipseCase);
 | |
| 
 | |
|     RifReaderInterface::PorosityModelResultType porosityModel = RigCaseCellResultsData::convertFromProjectModelPorosityModel(cellResult()->porosityModel());
 | |
|     RigCaseCellResultsData* results = eclipseCase->results(porosityModel);
 | |
|     CVF_ASSERT(results);
 | |
| 
 | |
|     updateMinMaxValuesAndAddLegendToView(QString("Cell Results: \n"), this->cellResult(), results);
 | |
| 
 | |
|     if (this->faultResultSettings()->showCustomFaultResult() && this->faultResultSettings()->hasValidCustomResult())
 | |
|     {
 | |
|         updateMinMaxValuesAndAddLegendToView(QString("Fault Results: \n"), this->currentFaultResultColors(), results);
 | |
|     }
 | |
| 
 | |
|     if (this->cellEdgeResult()->hasResult())
 | |
|     {
 | |
|         if (this->cellEdgeResult()->isUsingSingleVariable())
 | |
|         {
 | |
|             this->cellEdgeResult()->singleVarEdgeResultColors()->updateLegendData(m_currentTimeStep);
 | |
|         }
 | |
|         else
 | |
|         {
 | |
|             double globalMin, globalMax;
 | |
|             double globalPosClosestToZero, globalNegClosestToZero;
 | |
|             this->cellEdgeResult()->minMaxCellEdgeValues(globalMin, globalMax);
 | |
|             this->cellEdgeResult()->posNegClosestToZero(globalPosClosestToZero, globalNegClosestToZero);
 | |
| 
 | |
|             this->cellEdgeResult()->legendConfig()->setClosestToZeroValues(globalPosClosestToZero, globalNegClosestToZero, globalPosClosestToZero, globalNegClosestToZero);
 | |
|             this->cellEdgeResult()->legendConfig()->setAutomaticRanges(globalMin, globalMax, globalMin, globalMax);
 | |
| 
 | |
|             if (this->cellEdgeResult()->hasCategoryResult())
 | |
|             {
 | |
|                 if(cellEdgeResult()->singleVarEdgeResultColors()->resultType() != RimDefines::FORMATION_NAMES)
 | |
|                 {
 | |
|                     cellEdgeResult()->legendConfig()->setIntegerCategories(results->uniqueCellScalarValues(cellEdgeResult()->singleVarEdgeResultColors()->scalarResultIndex()));
 | |
|                 }
 | |
|                 else
 | |
|                 {
 | |
|                     const std::vector<QString>& fnVector = eclipseCase->activeFormationNames()->formationNames();
 | |
|                     cellEdgeResult()->legendConfig()->setNamedCategoriesInverse(fnVector);
 | |
|                 }
 | |
|             }
 | |
|         }
 | |
| 
 | |
|         m_viewer->addColorLegendToBottomLeftCorner(this->cellEdgeResult()->legendConfig()->legend());
 | |
|         this->cellEdgeResult()->legendConfig()->setTitle(cvfqt::Utils::toString(QString("Edge Results: \n") + this->cellEdgeResult()->resultVariableUiShortName()));
 | |
|     }
 | |
|     else
 | |
|     {
 | |
|         this->cellEdgeResult()->legendConfig()->setClosestToZeroValues(0, 0, 0, 0);
 | |
|         this->cellEdgeResult()->legendConfig()->setAutomaticRanges(cvf::UNDEFINED_DOUBLE, cvf::UNDEFINED_DOUBLE, cvf::UNDEFINED_DOUBLE, cvf::UNDEFINED_DOUBLE);
 | |
|     }
 | |
| 
 | |
|     RimLegendConfig* stimPlanLegend = stimPlanColors()->activeLegend();
 | |
|     if (stimPlanLegend)
 | |
|     {
 | |
|         stimPlanColors->updateLegendData();
 | |
|         
 | |
|         if (stimPlanColors()->isChecked() && stimPlanLegend->legend())
 | |
|         {
 | |
|             m_viewer->addColorLegendToBottomLeftCorner(stimPlanLegend->legend());
 | |
|         }
 | |
|     }
 | |
| }
 | |
| 
 | |
| //--------------------------------------------------------------------------------------------------
 | |
| /// 
 | |
| //--------------------------------------------------------------------------------------------------
 | |
| void RimEclipseView::updateMinMaxValuesAndAddLegendToView(QString legendLabel, RimEclipseCellColors* resultColors, RigCaseCellResultsData* cellResultsData)
 | |
| {
 | |
|     if (resultColors->hasResult())
 | |
|     {
 | |
|         resultColors->updateLegendData(m_currentTimeStep);
 | |
| 
 | |
|         m_viewer->addColorLegendToBottomLeftCorner(resultColors->legendConfig()->legend());
 | |
|         resultColors->legendConfig()->setTitle(cvfqt::Utils::toString(legendLabel + resultColors->resultVariableUiShortName()));
 | |
|     }
 | |
| 
 | |
|     size_t maxTimeStepCount = cellResultsData->maxTimeStepCount();
 | |
|     if (resultColors->isTernarySaturationSelected() && maxTimeStepCount > 1)
 | |
|     {
 | |
|         RimReservoirCellResultsStorage* gridCellResults = resultColors->currentGridCellResults();
 | |
|         {
 | |
|             size_t scalarSetIndex = gridCellResults->findOrLoadScalarResult(RimDefines::DYNAMIC_NATIVE, "SOIL");
 | |
|             if (scalarSetIndex != cvf::UNDEFINED_SIZE_T)
 | |
|             {
 | |
|                 double globalMin = 0.0;
 | |
|                 double globalMax = 1.0;
 | |
|                 double localMin = 0.0;
 | |
|                 double localMax = 1.0;
 | |
| 
 | |
|                 cellResultsData->minMaxCellScalarValues(scalarSetIndex, globalMin, globalMax);
 | |
|                 cellResultsData->minMaxCellScalarValues(scalarSetIndex, m_currentTimeStep, localMin, localMax);
 | |
| 
 | |
|                 resultColors->ternaryLegendConfig()->setAutomaticRanges(RimTernaryLegendConfig::TERNARY_SOIL_IDX, globalMin, globalMax, localMin, localMax);
 | |
|             }
 | |
|         }
 | |
| 
 | |
|         {
 | |
|             size_t scalarSetIndex = gridCellResults->findOrLoadScalarResult(RimDefines::DYNAMIC_NATIVE, "SGAS");
 | |
|             if (scalarSetIndex != cvf::UNDEFINED_SIZE_T)
 | |
|             {
 | |
|                 double globalMin = 0.0;
 | |
|                 double globalMax = 1.0;
 | |
|                 double localMin = 0.0;
 | |
|                 double localMax = 1.0;
 | |
| 
 | |
|                 cellResultsData->minMaxCellScalarValues(scalarSetIndex, globalMin, globalMax);
 | |
|                 cellResultsData->minMaxCellScalarValues(scalarSetIndex, m_currentTimeStep, localMin, localMax);
 | |
| 
 | |
|                 resultColors->ternaryLegendConfig()->setAutomaticRanges(RimTernaryLegendConfig::TERNARY_SGAS_IDX, globalMin, globalMax, localMin, localMax);
 | |
|             }
 | |
|         }
 | |
| 
 | |
|         {
 | |
|             size_t scalarSetIndex = gridCellResults->findOrLoadScalarResult(RimDefines::DYNAMIC_NATIVE, "SWAT");
 | |
|             if (scalarSetIndex != cvf::UNDEFINED_SIZE_T)
 | |
|             {
 | |
|                 double globalMin = 0.0;
 | |
|                 double globalMax = 1.0;
 | |
|                 double localMin = 0.0;
 | |
|                 double localMax = 1.0;
 | |
| 
 | |
|                 cellResultsData->minMaxCellScalarValues(scalarSetIndex, globalMin, globalMax);
 | |
|                 cellResultsData->minMaxCellScalarValues(scalarSetIndex, m_currentTimeStep, localMin, localMax);
 | |
| 
 | |
|                 resultColors->ternaryLegendConfig()->setAutomaticRanges(RimTernaryLegendConfig::TERNARY_SWAT_IDX, globalMin, globalMax, localMin, localMax);
 | |
|             }
 | |
|         }
 | |
| 
 | |
|         if (resultColors->ternaryLegendConfig->legend())
 | |
|         {
 | |
|             resultColors->ternaryLegendConfig->legend()->setTitle(cvfqt::Utils::toString(legendLabel));
 | |
|             m_viewer->addColorLegendToBottomLeftCorner(resultColors->ternaryLegendConfig->legend());
 | |
|         }
 | |
|     }
 | |
| }
 | |
| 
 | |
| //--------------------------------------------------------------------------------------------------
 | |
| /// 
 | |
| //--------------------------------------------------------------------------------------------------
 | |
| void RimEclipseView::setEclipseCase(RimEclipseCase* reservoir)
 | |
| {
 | |
|     m_eclipseCase = reservoir;
 | |
|     cellResult()->setEclipseCase(reservoir);
 | |
|     faultResultSettings()->customFaultResult()->setEclipseCase(reservoir);
 | |
|     
 | |
|     cellEdgeResult()->setEclipseCase(reservoir);
 | |
| }
 | |
| 
 | |
| //--------------------------------------------------------------------------------------------------
 | |
| /// 
 | |
| //--------------------------------------------------------------------------------------------------
 | |
| RimEclipseCase* RimEclipseView::eclipseCase() const
 | |
| {
 | |
|     return m_eclipseCase;
 | |
| }
 | |
| 
 | |
| //--------------------------------------------------------------------------------------------------
 | |
| //
 | |
| /*
 | |
|     wells vs wellres
 | |
|     For all wellres 
 | |
|         find well
 | |
|             if no well, create new 
 | |
|         connect well and wellres
 | |
|     for all wells not connected
 | |
|         Delete ?
 | |
| 
 | |
| */
 | |
| //--------------------------------------------------------------------------------------------------
 | |
| void RimEclipseView::syncronizeWellsWithResults()
 | |
| {
 | |
|     if (!(m_eclipseCase && m_eclipseCase->eclipseCaseData()) ) return;
 | |
| 
 | |
|     cvf::Collection<RigSingleWellResultsData> wellResults = m_eclipseCase->eclipseCaseData()->wellResults();
 | |
| 
 | |
|  
 | |
|     std::vector<caf::PdmPointer<RimEclipseWell> > newWells;
 | |
| 
 | |
|     // Clear the possible well results data present
 | |
|     for (size_t wIdx = 0; wIdx < this->wellCollection()->wells().size(); ++wIdx)
 | |
|     {
 | |
|         RimEclipseWell* well = this->wellCollection()->wells()[wIdx];
 | |
|         well->setWellResults(NULL, -1);
 | |
|     }
 | |
| 
 | |
|     bool isAnyWellCreated = false;
 | |
| 
 | |
|     // Find corresponding well from well result, or create a new
 | |
| 
 | |
|     for (size_t wIdx = 0; wIdx < wellResults.size(); ++wIdx)
 | |
|     {
 | |
|         RimEclipseWell* well = this->wellCollection()->findWell(wellResults[wIdx]->m_wellName);
 | |
| 
 | |
|         if (!well)
 | |
|         {
 | |
|             well = new RimEclipseWell;
 | |
|             well->name = wellResults[wIdx]->m_wellName;
 | |
| 
 | |
|             isAnyWellCreated = true;
 | |
|         }
 | |
|         newWells.push_back(well);
 | |
| 
 | |
|         well->setWellResults(wellResults[wIdx].p(), wIdx);
 | |
|     }
 | |
| 
 | |
|     // Delete all wells that does not have a result
 | |
| 
 | |
|     for (size_t wIdx = 0; wIdx < this->wellCollection()->wells().size(); ++wIdx)
 | |
|     {
 | |
|         RimEclipseWell* well = this->wellCollection()->wells()[wIdx];
 | |
|         RigSingleWellResultsData* wellRes = well->wellResults();
 | |
|         if (wellRes == NULL)
 | |
|         {
 | |
|             delete well;
 | |
|         }
 | |
|     }
 | |
|     this->wellCollection()->wells().clear();
 | |
| 
 | |
|     // Set the new wells into the field.
 | |
|     this->wellCollection()->wells().insert(0, newWells);
 | |
| 
 | |
|     // Make sure all the wells have their reservoirView ptr setup correctly
 | |
|     this->wellCollection()->setReservoirView(this);
 | |
| 
 | |
|     // Sort wells before assigning colors, as the colors are distributed based on sorting
 | |
|     this->wellCollection()->sortWellsByName();
 | |
| 
 | |
|     if (isAnyWellCreated)
 | |
|     {
 | |
|         this->wellCollection()->assignDefaultWellColors();
 | |
|     }
 | |
| }
 | |
| 
 | |
| //--------------------------------------------------------------------------------------------------
 | |
| /// 
 | |
| //--------------------------------------------------------------------------------------------------
 | |
| const RivReservoirViewPartMgr* RimEclipseView::reservoirGridPartManager() const
 | |
| {
 | |
|     return m_reservoirGridPartManager.p();
 | |
| }
 | |
| 
 | |
| //--------------------------------------------------------------------------------------------------
 | |
| /// 
 | |
| //--------------------------------------------------------------------------------------------------
 | |
| void RimEclipseView::calculateVisibleWellCellsIncFence(cvf::UByteArray* visibleCells, RigGridBase * grid)
 | |
| {
 | |
|     CVF_ASSERT(visibleCells != NULL);
 | |
| 
 | |
|     // Initialize the return array
 | |
|     if (visibleCells->size() != grid->cellCount())
 | |
|     {
 | |
|         visibleCells->resize(grid->cellCount());
 | |
|     }
 | |
|     visibleCells->setAll(false);
 | |
| 
 | |
|     RigActiveCellInfo* activeCellInfo = this->currentActiveCellInfo();
 | |
| 
 | |
|     CVF_ASSERT(activeCellInfo);
 | |
| 
 | |
|     // Loop over the wells and find their contribution
 | |
|     for (size_t wIdx = 0; wIdx < this->wellCollection()->wells().size(); ++wIdx)
 | |
|     {
 | |
|         RimEclipseWell* well =  this->wellCollection()->wells()[wIdx];
 | |
|         if (well->isWellCellsVisible())
 | |
|         {
 | |
|             RigSingleWellResultsData* wres = well->wellResults();
 | |
|             if (!wres) continue;
 | |
| 
 | |
|             const std::vector< RigWellResultFrame >& wellResFrames = wres->m_wellCellsTimeSteps;
 | |
|             for (size_t wfIdx = 0; wfIdx < wellResFrames.size(); ++wfIdx)
 | |
|             {
 | |
|                 // Add the wellhead cell if it is active
 | |
|                 if (wellResFrames[wfIdx].m_wellHead.m_gridIndex == grid->gridIndex())
 | |
|                 {
 | |
|                     size_t gridCellIndex = wellResFrames[wfIdx].m_wellHead.m_gridCellIndex;
 | |
|                     size_t reservoirCellIndex = grid->reservoirCellIndex(gridCellIndex);
 | |
| 
 | |
|                     if (activeCellInfo->isActive(reservoirCellIndex))
 | |
|                     {
 | |
|                         (*visibleCells)[gridCellIndex] = true;
 | |
|                     }
 | |
|                 }
 | |
| 
 | |
|                 // Add all the cells from the branches
 | |
| 
 | |
|                 const std::vector<RigWellResultBranch>& wellResSegments = wellResFrames[wfIdx].m_wellResultBranches;
 | |
|                 for (size_t wsIdx = 0; wsIdx < wellResSegments.size(); ++wsIdx)
 | |
|                 {
 | |
|                     const std::vector<RigWellResultPoint>& wsResCells = wellResSegments[wsIdx].m_branchResultPoints;
 | |
|                     for (size_t cIdx = 0; cIdx < wsResCells.size(); ++ cIdx)
 | |
|                     {
 | |
|                         if (wsResCells[cIdx].m_gridIndex == grid->gridIndex())
 | |
|                         {
 | |
|                             if (!wsResCells[cIdx].isCell())
 | |
|                             {
 | |
|                                 continue;
 | |
|                             }
 | |
| 
 | |
|                             size_t gridCellIndex = wsResCells[cIdx].m_gridCellIndex;
 | |
|                             (*visibleCells)[gridCellIndex] = true;
 | |
| 
 | |
|                             // Calculate well fence cells
 | |
|                             if (well->showWellCellFence())
 | |
|                             {
 | |
|                                 size_t i, j, k;
 | |
|                                 grid->ijkFromCellIndex(gridCellIndex, &i, &j, &k);
 | |
| 
 | |
|                                 size_t* pI = &i;
 | |
|                                 size_t *pJ = &j;
 | |
|                                 size_t *pK = &k;
 | |
|                                 size_t cellCountFenceDirection = 0;
 | |
|                                 size_t fIdx = 0;
 | |
| 
 | |
|                                 if (this->wellCollection()->wellCellFenceType == RimEclipseWellCollection::K_DIRECTION)
 | |
|                                 {
 | |
|                                     cellCountFenceDirection = grid->cellCountK();
 | |
|                                     pK = &fIdx;
 | |
|                                 }
 | |
|                                 else if (this->wellCollection()->wellCellFenceType == RimEclipseWellCollection::J_DIRECTION)
 | |
|                                 {
 | |
|                                     cellCountFenceDirection = grid->cellCountJ();
 | |
|                                     pJ = &fIdx;
 | |
|                                 }
 | |
|                                 else if (this->wellCollection()->wellCellFenceType == RimEclipseWellCollection::I_DIRECTION)
 | |
|                                 {
 | |
|                                     cellCountFenceDirection = grid->cellCountI();
 | |
|                                     pI = &fIdx;
 | |
|                                 }
 | |
| 
 | |
|                                 for ( fIdx = 0; fIdx < cellCountFenceDirection; ++fIdx)
 | |
|                                 {
 | |
|                                     size_t fenceCellIndex = grid->cellIndexFromIJK(*pI,*pJ,*pK);
 | |
|                                     size_t reservoirCellIndex = grid->reservoirCellIndex(fenceCellIndex);
 | |
| 
 | |
|                                     if (activeCellInfo && activeCellInfo->isActive(reservoirCellIndex))
 | |
|                                     {
 | |
|                                         (*visibleCells)[fenceCellIndex] = true;
 | |
|                                     }
 | |
|                                 }
 | |
|                             }
 | |
|                         }
 | |
|                     }
 | |
|                 }
 | |
|             }
 | |
|         }
 | |
|     }
 | |
| }
 | |
| 
 | |
| //--------------------------------------------------------------------------------------------------
 | |
| /// 
 | |
| //--------------------------------------------------------------------------------------------------
 | |
| void RimEclipseView::updateDisplayModelForWellResults()
 | |
| {
 | |
|     m_reservoirGridPartManager->clearGeometryCache();
 | |
|     m_simWellsPartManager->clearGeometryCache();
 | |
| 
 | |
|     syncronizeWellsWithResults();
 | |
| 
 | |
|     createDisplayModel();
 | |
|     updateDisplayModelVisibility();
 | |
| 
 | |
|     if (hasUserRequestedAnimation() && m_viewer)
 | |
|     {
 | |
|         m_viewer->animationControl()->setCurrentFrame(m_currentTimeStep);
 | |
|     }
 | |
| 
 | |
|     RiuMainWindow::instance()->refreshAnimationActions(); 
 | |
|    
 | |
| }
 | |
| 
 | |
| 
 | |
| //--------------------------------------------------------------------------------------------------
 | |
| /// 
 | |
| //--------------------------------------------------------------------------------------------------
 | |
| const std::vector<RivCellSetEnum>& RimEclipseView::visibleGridParts() const
 | |
| {
 | |
|     return m_visibleGridParts;
 | |
| }
 | |
| 
 | |
| //--------------------------------------------------------------------------------------------------
 | |
| /// 
 | |
| //--------------------------------------------------------------------------------------------------
 | |
| void RimEclipseView::defineUiOrdering(QString uiConfigName, caf::PdmUiOrdering& uiOrdering)
 | |
| {
 | |
|     RimView::defineUiOrdering(uiConfigName, uiOrdering);
 | |
| 
 | |
|     caf::PdmUiGroup* cellGroup = uiOrdering.addNewGroup("Cell Visibility");
 | |
|     cellGroup->add(&showMainGrid);
 | |
|     cellGroup->add(&showInactiveCells);
 | |
|     cellGroup->add(&showInvalidCells);
 | |
| }
 | |
| 
 | |
| //--------------------------------------------------------------------------------------------------
 | |
| /// 
 | |
| //--------------------------------------------------------------------------------------------------
 | |
| void RimEclipseView::defineUiTreeOrdering(caf::PdmUiTreeOrdering& uiTreeOrdering, QString uiConfigName /*= ""*/)
 | |
| {
 | |
|     uiTreeOrdering.add(m_overlayInfoConfig());
 | |
|     uiTreeOrdering.add(m_gridCollection());
 | |
| 
 | |
|     uiTreeOrdering.add(cellResult());
 | |
|     uiTreeOrdering.add(cellEdgeResult());
 | |
|     uiTreeOrdering.add(faultResultSettings());
 | |
|     uiTreeOrdering.add(stimPlanColors());
 | |
| 
 | |
|     uiTreeOrdering.add(wellCollection());
 | |
|     uiTreeOrdering.add(faultCollection());
 | |
|     uiTreeOrdering.add(crossSectionCollection());
 | |
|     
 | |
|     uiTreeOrdering.add(m_rangeFilterCollection());
 | |
|     uiTreeOrdering.add(m_propertyFilterCollection());
 | |
| 
 | |
|     uiTreeOrdering.skipRemainingChildren(true);
 | |
| }
 | |
| 
 | |
| //--------------------------------------------------------------------------------------------------
 | |
| /// 
 | |
| //--------------------------------------------------------------------------------------------------
 | |
| std::set<RivCellSetEnum> RimEclipseView::allVisibleFaultGeometryTypes() const
 | |
| {
 | |
|     std::set<RivCellSetEnum> faultGeoTypes;
 | |
|     faultGeoTypes.insert(m_visibleGridParts.begin(), m_visibleGridParts.end());
 | |
| 
 | |
|     if (faultCollection()->showFaultsOutsideFilters())
 | |
|     {
 | |
|         faultGeoTypes.insert(ACTIVE);
 | |
|         faultGeoTypes.insert(ALL_WELL_CELLS);
 | |
| 
 | |
|         if (showInactiveCells())
 | |
|         {
 | |
|             faultGeoTypes.insert(INACTIVE);
 | |
|         }
 | |
|     }
 | |
| 
 | |
|     return faultGeoTypes;
 | |
| }
 | |
| 
 | |
| //--------------------------------------------------------------------------------------------------
 | |
| /// 
 | |
| //--------------------------------------------------------------------------------------------------
 | |
| void RimEclipseView::updateFaultColors()
 | |
| {
 | |
|     std::set<RivCellSetEnum> faultGeometriesToRecolor = allVisibleFaultGeometryTypes();
 | |
| 
 | |
|     RimEclipseCellColors* faultResultColors = currentFaultResultColors();
 | |
| 
 | |
|     for (RivCellSetEnum cellSetType : faultGeometriesToRecolor)
 | |
|     {
 | |
|         if (this->hasUserRequestedAnimation() && this->cellEdgeResult()->hasResult())
 | |
|         {
 | |
|             m_reservoirGridPartManager->updateFaultCellEdgeResultColor(cellSetType, m_currentTimeStep, faultResultColors, this->cellEdgeResult());
 | |
|         }
 | |
|         else
 | |
|         {
 | |
|             m_reservoirGridPartManager->updateFaultColors(cellSetType, m_currentTimeStep, faultResultColors);
 | |
|         }
 | |
|     }
 | |
| }
 | |
| 
 | |
| 
 | |
| //--------------------------------------------------------------------------------------------------
 | |
| /// 
 | |
| //--------------------------------------------------------------------------------------------------
 | |
| bool RimEclipseView::isTimeStepDependentDataVisible() const
 | |
| {
 | |
|     if (this->cellResult()->hasDynamicResult()) return true;
 | |
| 
 | |
|     if (this->eclipsePropertyFilterCollection()->hasActiveDynamicFilters()) return true;
 | |
|         
 | |
|     if (this->wellCollection->hasVisibleWellPipes()) return true;
 | |
| 
 | |
|     if (this->cellResult()->isTernarySaturationSelected()) return true;
 | |
|     
 | |
|     if (this->faultResultSettings->showCustomFaultResult())
 | |
|     {
 | |
|         if (this->faultResultSettings->customFaultResult()->hasDynamicResult()) return true;
 | |
| 
 | |
|         if (this->faultResultSettings->customFaultResult()->isTernarySaturationSelected()) return true;
 | |
|     }
 | |
| 
 | |
|     return false;
 | |
| }
 | |
| 
 | |
| 
 | |
| //--------------------------------------------------------------------------------------------------
 | |
| /// 
 | |
| //--------------------------------------------------------------------------------------------------
 | |
| RimEclipseCellColors* RimEclipseView::currentFaultResultColors()
 | |
| {
 | |
|     RimEclipseCellColors* faultResultColors = this->cellResult();
 | |
| 
 | |
|     if (this->faultResultSettings()->showCustomFaultResult())
 | |
|     {
 | |
|         faultResultColors = this->faultResultSettings()->customFaultResult();
 | |
|     }
 | |
| 
 | |
|     return faultResultColors;
 | |
| }
 | |
| 
 | |
| //--------------------------------------------------------------------------------------------------
 | |
| /// 
 | |
| //--------------------------------------------------------------------------------------------------
 | |
| void RimEclipseView::resetLegendsInViewer()
 | |
| {
 | |
|     RimLegendConfig* cellResultNormalLegendConfig = this->cellResult()->legendConfig();
 | |
|     if (cellResultNormalLegendConfig) cellResultNormalLegendConfig->recreateLegend();
 | |
| 
 | |
|     this->cellResult()->ternaryLegendConfig->recreateLegend();
 | |
|     this->cellEdgeResult()->legendConfig()->recreateLegend();
 | |
| 
 | |
|     m_viewer->removeAllColorLegends();
 | |
|     
 | |
|     if (cellResultNormalLegendConfig) m_viewer->addColorLegendToBottomLeftCorner(cellResultNormalLegendConfig->legend());
 | |
| 
 | |
|     m_viewer->addColorLegendToBottomLeftCorner(this->cellEdgeResult()->legendConfig()->legend());
 | |
| }
 | |
| 
 | |
| //--------------------------------------------------------------------------------------------------
 | |
| /// 
 | |
| //--------------------------------------------------------------------------------------------------
 | |
| cvf::Transform* RimEclipseView::scaleTransform()
 | |
| {
 | |
|     return m_reservoirGridPartManager->scaleTransform();
 | |
| }
 | |
| 
 | |
| //--------------------------------------------------------------------------------------------------
 | |
| /// 
 | |
| //--------------------------------------------------------------------------------------------------
 | |
| RimCase* RimEclipseView::ownerCase()
 | |
| {
 | |
|     return eclipseCase();
 | |
| }
 | |
| 
 | |
| //--------------------------------------------------------------------------------------------------
 | |
| /// 
 | |
| //--------------------------------------------------------------------------------------------------
 | |
| RigMainGrid* RimEclipseView::mainGrid() const
 | |
| {
 | |
|     if (eclipseCase() && eclipseCase()->eclipseCaseData())
 | |
|     {
 | |
|         return eclipseCase()->eclipseCaseData()->mainGrid();
 | |
|     }
 | |
| 
 | |
|     return nullptr;
 | |
| }
 | |
| 
 | |
| //--------------------------------------------------------------------------------------------------
 | |
| /// 
 | |
| //--------------------------------------------------------------------------------------------------
 | |
| void RimEclipseView::findGridIndexAndCellIndex(RimEclipseWell* eclipseWell, size_t branchIndex, size_t triangleIndex, size_t* gridIndex, size_t* cellIndex)
 | |
| {
 | |
|     CVF_ASSERT(eclipseWell);
 | |
| 
 | |
|     size_t wellIndex = wellCollection->wells().index(eclipseWell);
 | |
|     if (wellIndex != cvf::UNDEFINED_SIZE_T)
 | |
|     {
 | |
|         m_simWellsPartManager->findGridIndexAndCellIndex(wellIndex, branchIndex, triangleIndex, gridIndex, cellIndex);
 | |
|     }
 | |
| }
 | |
| 
 | |
| //--------------------------------------------------------------------------------------------------
 | |
| /// 
 | |
| //--------------------------------------------------------------------------------------------------
 | |
| RimEclipsePropertyFilterCollection* RimEclipseView::eclipsePropertyFilterCollection()
 | |
| {
 | |
|     if (m_overridePropertyFilterCollection)
 | |
|     {
 | |
|         return m_overridePropertyFilterCollection;
 | |
|     }
 | |
|     else
 | |
|     {
 | |
|         return m_propertyFilterCollection;
 | |
|     }
 | |
| }
 | |
| 
 | |
| //--------------------------------------------------------------------------------------------------
 | |
| /// 
 | |
| //--------------------------------------------------------------------------------------------------
 | |
| const RimEclipsePropertyFilterCollection* RimEclipseView::eclipsePropertyFilterCollection() const
 | |
| {
 | |
|     if (m_overridePropertyFilterCollection)
 | |
|     {
 | |
|         return m_overridePropertyFilterCollection;
 | |
|     }
 | |
|     else
 | |
|     {
 | |
|         return m_propertyFilterCollection;
 | |
|     }
 | |
| }
 | |
| 
 | |
| //--------------------------------------------------------------------------------------------------
 | |
| /// 
 | |
| //--------------------------------------------------------------------------------------------------
 | |
| void RimEclipseView::setOverridePropertyFilterCollection(RimEclipsePropertyFilterCollection* pfc)
 | |
| {
 | |
|     m_overridePropertyFilterCollection = pfc;
 | |
| 
 | |
|     this->scheduleGeometryRegen(PROPERTY_FILTERED);
 | |
|     this->scheduleCreateDisplayModelAndRedraw();
 | |
| }
 | |
| 
 | |
| //--------------------------------------------------------------------------------------------------
 | |
| /// 
 | |
| //--------------------------------------------------------------------------------------------------
 | |
| void RimEclipseView::calculateCurrentTotalCellVisibility(cvf::UByteArray* totalVisibility)
 | |
| {
 | |
|     size_t gridCount = this->eclipseCase()->eclipseCaseData()->gridCount();
 | |
|     size_t cellCount = this->mainGrid()->globalCellArray().size();
 | |
| 
 | |
|     totalVisibility->resize(cellCount);
 | |
|     totalVisibility->setAll(false);
 | |
| 
 | |
|     for (size_t gridIdx = 0; gridIdx < gridCount; ++gridIdx)
 | |
|     {
 | |
|         RigGridBase * grid = this->eclipseCase()->eclipseCaseData()->grid(gridIdx);
 | |
|         int gridCellCount = static_cast<int>(grid->cellCount());
 | |
| 
 | |
|         for (size_t gpIdx = 0; gpIdx < m_visibleGridParts.size(); ++gpIdx)
 | |
|         {
 | |
|             const cvf::UByteArray* visibility =  m_reservoirGridPartManager->cellVisibility(m_visibleGridParts[gpIdx], gridIdx, m_currentTimeStep);
 | |
| 
 | |
|             for (int lcIdx = 0; lcIdx < gridCellCount; ++ lcIdx)
 | |
|             {
 | |
|                 (*totalVisibility)[grid->reservoirCellIndex(lcIdx)] |= (*visibility)[lcIdx];
 | |
|             }
 | |
|         }
 | |
|     }
 | |
| }
 | |
| 
 | |
| //--------------------------------------------------------------------------------------------------
 | |
| /// 
 | |
| //--------------------------------------------------------------------------------------------------
 | |
| bool RimEclipseView::showActiveCellsOnly()
 | |
| {
 | |
|     return !showInactiveCells;
 | |
| }
 | |
| 
 | |
| //--------------------------------------------------------------------------------------------------
 | |
| /// 
 | |
| //--------------------------------------------------------------------------------------------------
 | |
| void RimEclipseView::createPartCollectionFromSelection(cvf::Collection<cvf::Part>* parts)
 | |
| {
 | |
|     RiuSelectionManager* riuSelManager = RiuSelectionManager::instance();
 | |
|     std::vector<RiuSelectionItem*> items;
 | |
|     riuSelManager->selectedItems(items);
 | |
| 
 | |
|     for (size_t i = 0; i < items.size(); i++)
 | |
|     {
 | |
|         if (items[i]->type() == RiuSelectionItem::ECLIPSE_SELECTION_OBJECT)
 | |
|         {
 | |
|             RiuEclipseSelectionItem* eclipseSelItem = static_cast<RiuEclipseSelectionItem*>(items[i]);
 | |
|             if (eclipseSelItem && eclipseSelItem->m_view == this)
 | |
|             {
 | |
|                 CVF_ASSERT(eclipseSelItem->m_view->eclipseCase());
 | |
|                 CVF_ASSERT(eclipseSelItem->m_view->eclipseCase()->eclipseCaseData());
 | |
| 
 | |
|                 RivSingleCellPartGenerator partGen(eclipseSelItem->m_view->eclipseCase()->eclipseCaseData(), eclipseSelItem->m_gridIndex, eclipseSelItem->m_cellIndex);
 | |
| 
 | |
|                 cvf::ref<cvf::Part> part = partGen.createPart(eclipseSelItem->m_color);
 | |
|                 part->setTransform(this->scaleTransform());
 | |
| 
 | |
|                 parts->push_back(part.p());
 | |
|             }
 | |
|         }
 | |
|     }
 | |
| }
 | |
| 
 | |
| //--------------------------------------------------------------------------------------------------
 | |
| /// 
 | |
| //--------------------------------------------------------------------------------------------------
 | |
| void RimEclipseView::updateIconStateForFilterCollections()
 | |
| {
 | |
|     m_rangeFilterCollection()->updateIconState();
 | |
|     m_rangeFilterCollection()->uiCapability()->updateConnectedEditors();
 | |
| 
 | |
|     // NB - notice that it is the filter collection managed by this view that the icon update applies to
 | |
|     m_propertyFilterCollection()->updateIconState();
 | |
|     m_propertyFilterCollection()->uiCapability()->updateConnectedEditors();
 | |
| }
 | |
| 
 | |
| //--------------------------------------------------------------------------------------------------
 | |
| /// 
 | |
| //--------------------------------------------------------------------------------------------------
 | |
| void RimEclipseView::axisLabels(cvf::String* xLabel, cvf::String* yLabel, cvf::String* zLabel)
 | |
| {
 | |
|     CVF_ASSERT(xLabel && yLabel && zLabel);
 | |
| 
 | |
|     *xLabel = "E(x)";
 | |
|     *yLabel = "N(y)";
 | |
|     *zLabel = "Z";
 | |
| }
 | |
| 
 | |
| //--------------------------------------------------------------------------------------------------
 | |
| /// 
 | |
| //--------------------------------------------------------------------------------------------------
 | |
| bool RimEclipseView::isUsingFormationNames() const
 | |
| {
 | |
|     if ((cellResult()->resultType() == RimDefines::FORMATION_NAMES)) return true;
 | |
|     
 | |
|     return eclipsePropertyFilterCollection()->isUsingFormationNames();
 | |
| }
 | |
| 
 | |
| //--------------------------------------------------------------------------------------------------
 | |
| /// 
 | |
| //--------------------------------------------------------------------------------------------------
 | |
| const RimPropertyFilterCollection* RimEclipseView::propertyFilterCollection() const
 | |
| {
 | |
|     return eclipsePropertyFilterCollection();
 | |
| }
 |