2015-05-22 10:01:59 -05: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 "RivGeoMechVizLogic.h"
|
|
|
|
|
|
|
|
#include "RimGeoMechView.h"
|
|
|
|
#include "cvfModelBasicList.h"
|
2015-06-25 06:32:00 -05:00
|
|
|
#include "RimGeoMechCellColors.h"
|
2015-05-22 10:01:59 -05:00
|
|
|
#include "RivGeoMechPartMgrCache.h"
|
|
|
|
#include "RivGeoMechPartMgr.h"
|
|
|
|
#include "RivReservoirViewPartMgr.h"
|
|
|
|
#include "RimGeoMechCase.h"
|
|
|
|
#include "RigFemPartCollection.h"
|
2015-05-27 07:50:12 -05:00
|
|
|
#include "RigGeoMechCaseData.h"
|
2015-05-22 10:01:59 -05:00
|
|
|
#include "RimCellRangeFilterCollection.h"
|
|
|
|
|
2015-06-18 06:09:09 -05:00
|
|
|
#include "RivCellSetEnum.h"
|
2015-06-18 12:42:38 -05:00
|
|
|
#include "RivFemElmVisibilityCalculator.h"
|
2015-06-22 01:16:46 -05:00
|
|
|
#include "RigFemPartResultsCollection.h"
|
2015-06-22 14:57:52 -05:00
|
|
|
#include "RimGeoMechPropertyFilterCollection.h"
|
2015-06-18 06:09:09 -05:00
|
|
|
|
2015-05-22 10:01:59 -05:00
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
|
|
///
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
|
|
RivGeoMechVizLogic::RivGeoMechVizLogic(RimGeoMechView * geomView)
|
|
|
|
{
|
|
|
|
CVF_ASSERT(geomView);
|
|
|
|
m_geomechView = geomView;
|
|
|
|
m_partMgrCache = new RivGeoMechPartMgrCache;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
|
|
///
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
|
|
RivGeoMechVizLogic::~RivGeoMechVizLogic()
|
|
|
|
{
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
|
|
///
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
|
|
void RivGeoMechVizLogic::appendNoAnimPartsToModel(cvf::ModelBasicList* model)
|
|
|
|
{
|
2015-06-22 01:16:46 -05:00
|
|
|
this->appendPartsToModel(-1, model);
|
|
|
|
}
|
2015-05-22 10:01:59 -05:00
|
|
|
|
2015-06-22 01:16:46 -05:00
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
|
|
///
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
|
|
void RivGeoMechVizLogic::appendPartsToModel(int timeStepIndex, cvf::ModelBasicList* model)
|
|
|
|
{
|
|
|
|
std::vector<RivGeoMechPartMgrCache::Key> visiblePartMgrs = keysToVisiblePartMgrs(timeStepIndex);
|
|
|
|
for (size_t pmIdx = 0; pmIdx < visiblePartMgrs.size(); ++pmIdx)
|
2015-05-22 10:01:59 -05:00
|
|
|
{
|
2015-06-22 01:16:46 -05:00
|
|
|
RivGeoMechPartMgr* partMgr = getUpdatedPartMgr(visiblePartMgrs[pmIdx]);
|
2015-05-22 10:01:59 -05:00
|
|
|
|
2015-06-22 01:16:46 -05:00
|
|
|
partMgr->appendGridPartsToModel(model);
|
2015-05-22 10:01:59 -05:00
|
|
|
}
|
2015-06-22 01:16:46 -05:00
|
|
|
|
2015-05-22 10:01:59 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
|
|
///
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
2015-06-25 05:03:02 -05:00
|
|
|
void RivGeoMechVizLogic::updateCellResultColor(int timeStepIndex, RimGeoMechCellColors* cellResultSlot)
|
2015-05-22 10:01:59 -05:00
|
|
|
{
|
2015-06-22 01:16:46 -05:00
|
|
|
std::vector<RivGeoMechPartMgrCache::Key> visiblePartMgrs = keysToVisiblePartMgrs(timeStepIndex);
|
|
|
|
for (size_t pmIdx = 0; pmIdx < visiblePartMgrs.size(); ++pmIdx)
|
|
|
|
{
|
|
|
|
RivGeoMechPartMgr* partMgr = m_partMgrCache->partMgr(visiblePartMgrs[pmIdx]);
|
|
|
|
partMgr->updateCellResultColor(timeStepIndex, cellResultSlot);
|
|
|
|
}
|
|
|
|
|
2015-05-22 10:01:59 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
|
|
///
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
2015-06-22 01:16:46 -05:00
|
|
|
void RivGeoMechVizLogic::updateStaticCellColors(int timeStepIndex)
|
2015-05-22 10:01:59 -05:00
|
|
|
{
|
2015-06-22 01:16:46 -05:00
|
|
|
std::vector<RivGeoMechPartMgrCache::Key> visiblePartMgrs = keysToVisiblePartMgrs(timeStepIndex);
|
|
|
|
for (size_t pmIdx = 0; pmIdx < visiblePartMgrs.size(); ++pmIdx)
|
|
|
|
{
|
|
|
|
RivGeoMechPartMgr* partMgr = m_partMgrCache->partMgr(visiblePartMgrs[pmIdx]);
|
|
|
|
partMgr->updateCellColor(cvf::Color4f(cvf::Color3f::ORANGE));
|
|
|
|
}
|
2015-05-22 10:01:59 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
|
|
///
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
2015-06-22 01:16:46 -05:00
|
|
|
void RivGeoMechVizLogic::scheduleGeometryRegen(RivCellSetEnum geometryType)
|
2015-05-22 10:01:59 -05:00
|
|
|
{
|
2015-06-24 04:59:39 -05:00
|
|
|
this->scheduleRegenOfDirectlyDependentGeometry(geometryType);
|
|
|
|
|
2015-06-22 01:16:46 -05:00
|
|
|
int frameCount = m_geomechView->geoMechCase()->geoMechData()->femPartResults()->frameCount();
|
|
|
|
|
|
|
|
for (int fIdx = -1; fIdx < frameCount; ++fIdx)
|
|
|
|
{
|
|
|
|
RivGeoMechPartMgrCache::Key geomToRegen(geometryType, fIdx);
|
|
|
|
m_partMgrCache->scheduleRegeneration(geomToRegen);
|
|
|
|
}
|
2015-05-22 10:01:59 -05:00
|
|
|
}
|
|
|
|
|
2015-06-24 04:59:39 -05:00
|
|
|
void RivGeoMechVizLogic::scheduleRegenOfDirectlyDependentGeometry(RivCellSetEnum geometryType)
|
|
|
|
{
|
|
|
|
if (geometryType == RANGE_FILTERED)
|
|
|
|
{
|
|
|
|
this->scheduleGeometryRegen(PROPERTY_FILTERED);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2015-05-22 10:01:59 -05:00
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
|
|
///
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
2015-06-22 01:16:46 -05:00
|
|
|
std::vector<RivGeoMechPartMgrCache::Key> RivGeoMechVizLogic::keysToVisiblePartMgrs(int timeStepIndex)
|
2015-05-22 10:01:59 -05:00
|
|
|
{
|
2015-06-22 01:16:46 -05:00
|
|
|
std::vector<RivGeoMechPartMgrCache::Key> visiblePartMgrs;
|
|
|
|
|
2015-06-22 14:57:52 -05:00
|
|
|
if (timeStepIndex >= 0 && m_geomechView->propertyFilterCollection()->hasActiveFilters())
|
2015-06-22 01:16:46 -05:00
|
|
|
{
|
|
|
|
visiblePartMgrs.push_back(RivGeoMechPartMgrCache::Key(PROPERTY_FILTERED, timeStepIndex));
|
|
|
|
}
|
|
|
|
else if (m_geomechView->rangeFilterCollection()->hasActiveFilters())
|
|
|
|
{
|
|
|
|
visiblePartMgrs.push_back(RivGeoMechPartMgrCache::Key(RANGE_FILTERED, -1));
|
|
|
|
}
|
|
|
|
else
|
2015-05-22 10:01:59 -05:00
|
|
|
{
|
2015-06-22 01:16:46 -05:00
|
|
|
visiblePartMgrs.push_back(RivGeoMechPartMgrCache::Key(ALL_CELLS, -1));
|
2015-05-22 10:01:59 -05:00
|
|
|
}
|
2015-06-22 01:16:46 -05:00
|
|
|
|
|
|
|
return visiblePartMgrs;
|
2015-05-22 10:01:59 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
|
|
///
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
2015-06-22 01:16:46 -05:00
|
|
|
RivGeoMechPartMgr* RivGeoMechVizLogic::getUpdatedPartMgr(RivGeoMechPartMgrCache::Key pMgrKey)
|
2015-05-22 10:01:59 -05:00
|
|
|
{
|
2015-06-22 01:16:46 -05:00
|
|
|
if (!m_partMgrCache->isNeedingRegeneration(pMgrKey))
|
2015-05-22 10:01:59 -05:00
|
|
|
{
|
2015-06-22 01:16:46 -05:00
|
|
|
return m_partMgrCache->partMgr(pMgrKey);
|
2015-05-22 10:01:59 -05:00
|
|
|
}
|
2015-06-22 01:16:46 -05:00
|
|
|
|
|
|
|
RivGeoMechPartMgr* partMgrToUpdate = m_partMgrCache->partMgr(pMgrKey);
|
|
|
|
RigGeoMechCaseData* caseData = m_geomechView->geoMechCase()->geoMechData();
|
|
|
|
int partCount = caseData->femParts()->partCount();
|
|
|
|
|
|
|
|
if (partMgrToUpdate->initializedFemPartCount() != partCount)
|
2015-05-22 10:01:59 -05:00
|
|
|
{
|
2015-06-22 01:16:46 -05:00
|
|
|
partMgrToUpdate->clearAndSetReservoir(caseData);
|
2015-05-22 10:01:59 -05:00
|
|
|
}
|
|
|
|
|
2015-06-22 01:16:46 -05:00
|
|
|
for (int femPartIdx = 0; femPartIdx < partCount; ++femPartIdx)
|
|
|
|
{
|
|
|
|
cvf::ref<cvf::UByteArray> elmVisibility = partMgrToUpdate->cellVisibility(femPartIdx);
|
|
|
|
partMgrToUpdate->setTransform(m_geomechView->scaleTransform());
|
|
|
|
|
|
|
|
if (pMgrKey.geometryType() == RANGE_FILTERED)
|
|
|
|
{
|
|
|
|
cvf::CellRangeFilter cellRangeFilter;
|
|
|
|
m_geomechView->rangeFilterCollection()->compoundCellRangeFilter(&cellRangeFilter, femPartIdx);
|
|
|
|
RivFemElmVisibilityCalculator::computeRangeVisibility( elmVisibility.p(),
|
|
|
|
caseData->femParts()->part(femPartIdx),
|
|
|
|
cellRangeFilter);
|
|
|
|
}
|
|
|
|
else if (pMgrKey.geometryType() == PROPERTY_FILTERED)
|
|
|
|
{
|
2015-06-24 04:59:39 -05:00
|
|
|
RivGeoMechPartMgr* rangefiltered = NULL;
|
|
|
|
if (m_geomechView->rangeFilterCollection()->hasActiveFilters())
|
|
|
|
{
|
|
|
|
rangefiltered = getUpdatedPartMgr(RivGeoMechPartMgrCache::Key(RANGE_FILTERED, -1));
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
rangefiltered = getUpdatedPartMgr(RivGeoMechPartMgrCache::Key(ALL_CELLS, -1));
|
|
|
|
}
|
|
|
|
cvf::ref<cvf::UByteArray> rangeFiltVisibility = rangefiltered->cellVisibility(femPartIdx);
|
|
|
|
|
|
|
|
RivFemElmVisibilityCalculator::computePropertyVisibility(elmVisibility.p(),
|
|
|
|
caseData->femParts()->part(femPartIdx),
|
|
|
|
pMgrKey.frameIndex(),
|
|
|
|
rangeFiltVisibility.p(),
|
|
|
|
m_geomechView->propertyFilterCollection()
|
|
|
|
);
|
2015-06-22 01:16:46 -05:00
|
|
|
}
|
2015-06-24 04:59:39 -05:00
|
|
|
else if (pMgrKey.geometryType() == ALL_CELLS)
|
2015-06-22 01:16:46 -05:00
|
|
|
{
|
|
|
|
RivFemElmVisibilityCalculator::computeAllVisible(elmVisibility.p(), caseData->femParts()->part(femPartIdx));
|
|
|
|
}
|
2015-06-24 04:59:39 -05:00
|
|
|
else
|
|
|
|
{
|
|
|
|
CVF_ASSERT(false); // Unsupported CellSet Enum
|
|
|
|
}
|
2015-06-22 01:16:46 -05:00
|
|
|
|
|
|
|
partMgrToUpdate->setCellVisibility(femPartIdx, elmVisibility.p());
|
|
|
|
}
|
|
|
|
|
|
|
|
m_partMgrCache->setGenerationFinished(pMgrKey);
|
|
|
|
|
|
|
|
return partMgrToUpdate;
|
2015-05-22 10:01:59 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
|