mirror of
				https://github.com/OPM/ResInsight.git
				synced 2025-02-25 18:55:39 -06:00 
			
		
		
		
	
		
			
				
	
	
		
			256 lines
		
	
	
		
			8.9 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
			
		
		
	
	
			256 lines
		
	
	
		
			8.9 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
| /////////////////////////////////////////////////////////////////////////////////
 | |
| //
 | |
| //  Copyright (C) 2011-2012 Statoil ASA, 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 "RimWellPathImport.h"
 | |
| 
 | |
| #include "RimOilFieldEntry.h"
 | |
| #include "RimOilRegionEntry.h"
 | |
| #include "RimTools.h"
 | |
| #include "RimWellPath.h"
 | |
| #include "RimWellPathCollection.h"
 | |
| 
 | |
| #include "cafPdmUiTreeViewEditor.h"
 | |
| 
 | |
| #include <QFileInfo>
 | |
| 
 | |
| namespace caf {
 | |
| 
 | |
|     template<>
 | |
|     void caf::AppEnum< RimWellPathImport::UtmFilterEnum >::setUp()
 | |
|     {
 | |
|         addItem(RimWellPathImport::UTM_FILTER_OFF,      "UTM_FILTER_OFF",       "Off");
 | |
|         addItem(RimWellPathImport::UTM_FILTER_PROJECT,  "UTM_FILTER_PROJECT",   "Project");
 | |
|         addItem(RimWellPathImport::UTM_FILTER_CUSTOM,   "UTM_FILTER_CUSTOM",    "Custom");
 | |
|         setDefault(RimWellPathImport::UTM_FILTER_PROJECT);
 | |
|     }
 | |
| 
 | |
| } // End namespace caf
 | |
| 
 | |
| 
 | |
| CAF_PDM_SOURCE_INIT(RimWellPathImport, "RimWellPathImport");
 | |
| 
 | |
| 
 | |
| 
 | |
| //--------------------------------------------------------------------------------------------------
 | |
| /// 
 | |
| //--------------------------------------------------------------------------------------------------
 | |
| RimWellPathImport::RimWellPathImport()
 | |
| {
 | |
|     CAF_PDM_InitObject("RimWellPathImport", "", "", "");
 | |
| 
 | |
|     CAF_PDM_InitField(&wellTypeSurvey,       "WellTypeSurvey",         true,   "Survey", "", "", "");
 | |
|     CAF_PDM_InitField(&wellTypePlans,        "WellTypePlans",          true,   "Plans", "", "", "");
 | |
|  
 | |
|     caf::AppEnum<RimWellPathImport::UtmFilterEnum> defaultUtmMode = UTM_FILTER_OFF;
 | |
|     CAF_PDM_InitField(&utmFilterMode, "UtmMode", defaultUtmMode, "Utm filter",   "", "", "");
 | |
| 
 | |
|     CAF_PDM_InitField(&north, "UtmNorth", 0.0,    "North", "", "", "");
 | |
|     CAF_PDM_InitField(&south, "UtmSouth", 0.0,    "South", "", "", "");
 | |
|     CAF_PDM_InitField(&east,  "UtmEast",  0.0,    "East", "", "", "");
 | |
|     CAF_PDM_InitField(&west,  "UtmWest",  0.0,    "West", "", "", "");
 | |
| 
 | |
|     CAF_PDM_InitFieldNoDefault(®ions, "Regions", "",  "", "", "");
 | |
|     regions.uiCapability()->setUiHidden(true);
 | |
| }
 | |
| 
 | |
| //--------------------------------------------------------------------------------------------------
 | |
| /// 
 | |
| //--------------------------------------------------------------------------------------------------
 | |
| void RimWellPathImport::updateRegions(const QStringList& regionStrings, const QStringList& fieldStrings, const QStringList& edmIds)
 | |
| {
 | |
|     assert(regionStrings.size() == fieldStrings.size() && regionStrings.size() == edmIds.size());
 | |
| 
 | |
|     std::vector<RimOilRegionEntry*> regionsToRemove;
 | |
|     
 | |
|     // Remove regions and fields not present in last request
 | |
|     for (size_t regionIdx = 0; regionIdx < this->regions.size(); regionIdx++)
 | |
|     {
 | |
|         if (!regionStrings.contains(this->regions[regionIdx]->name))
 | |
|         {
 | |
|             regionsToRemove.push_back(this->regions[regionIdx]);
 | |
|         }
 | |
|         else
 | |
|         {
 | |
|             std::vector<RimOilFieldEntry*> fieldsToRemove;
 | |
| 
 | |
|             for (size_t fIdx = 0; fIdx < this->regions[regionIdx]->fields.size(); fIdx++)
 | |
|             {
 | |
|                 if (!fieldStrings.contains(this->regions[regionIdx]->fields[fIdx]->name))
 | |
|                 {
 | |
|                     fieldsToRemove.push_back(this->regions[regionIdx]->fields[fIdx]);
 | |
|                 }
 | |
|             }
 | |
| 
 | |
|             for (size_t i = 0; i < fieldsToRemove.size(); i++)
 | |
|             {
 | |
|                 this->regions[regionIdx]->fields.removeChildObject(fieldsToRemove[i]);
 | |
| 
 | |
|                 delete fieldsToRemove[i];
 | |
|             }
 | |
|         }
 | |
|     }
 | |
| 
 | |
|     for (size_t i = 0; i < regionsToRemove.size(); i++)
 | |
|     {
 | |
|         this->regions.removeChildObject(regionsToRemove[i]);
 | |
| 
 | |
|         delete regionsToRemove[i];
 | |
|     }
 | |
| 
 | |
| 
 | |
|     for (int i = 0; i < regionStrings.size(); i++)
 | |
|     {
 | |
|         RimOilRegionEntry* oilRegionEntry = NULL;
 | |
|         RimOilFieldEntry*  oilFieldEntry = NULL;
 | |
| 
 | |
|         for (size_t regionIdx = 0; regionIdx < this->regions.size(); regionIdx++)
 | |
|         {
 | |
|             if (this->regions[regionIdx]->name == regionStrings[i])
 | |
|             {
 | |
|                 oilRegionEntry = this->regions[regionIdx];
 | |
| 
 | |
|                 for (size_t fIdx = 0; fIdx < this->regions[regionIdx]->fields.size(); fIdx++)
 | |
|                 {
 | |
|                     if (this->regions[regionIdx]->fields[fIdx]->edmId == edmIds[i])
 | |
|                     {
 | |
|                         oilFieldEntry = this->regions[regionIdx]->fields[fIdx];
 | |
|                     }
 | |
|                 }
 | |
|             }
 | |
|         }
 | |
| 
 | |
|         if (!oilRegionEntry)
 | |
|         {
 | |
|             oilRegionEntry = new RimOilRegionEntry;
 | |
|             oilRegionEntry->name = regionStrings[i];
 | |
| 
 | |
|             this->regions.push_back(oilRegionEntry);
 | |
|         }
 | |
| 
 | |
|         assert(oilRegionEntry);
 | |
| 
 | |
|         if (!oilFieldEntry)
 | |
|         {
 | |
|             RimOilFieldEntry* oilFieldEntry = new RimOilFieldEntry;
 | |
|             oilFieldEntry->name = fieldStrings[i];
 | |
|             oilFieldEntry->edmId = edmIds[i];
 | |
| 
 | |
|             oilRegionEntry->fields.push_back(oilFieldEntry);
 | |
|         }
 | |
|     }
 | |
| 
 | |
|     updateFieldVisibility();
 | |
| }
 | |
| 
 | |
| //--------------------------------------------------------------------------------------------------
 | |
| /// 
 | |
| //--------------------------------------------------------------------------------------------------
 | |
| void RimWellPathImport::initAfterRead()
 | |
| {
 | |
|     updateFieldVisibility();
 | |
| }
 | |
| 
 | |
| //--------------------------------------------------------------------------------------------------
 | |
| /// 
 | |
| //--------------------------------------------------------------------------------------------------
 | |
| void RimWellPathImport::updateFieldVisibility()
 | |
| {
 | |
|     if (utmFilterMode == UTM_FILTER_CUSTOM)
 | |
|     {
 | |
|         north.uiCapability()->setUiReadOnly(false);
 | |
|         south.uiCapability()->setUiReadOnly(false);
 | |
|         east.uiCapability()->setUiReadOnly(false);
 | |
|         west.uiCapability()->setUiReadOnly(false);
 | |
|     }
 | |
|     else
 | |
|     {
 | |
|         north.uiCapability()->setUiReadOnly(true);
 | |
|         south.uiCapability()->setUiReadOnly(true);
 | |
|         east.uiCapability()->setUiReadOnly(true);
 | |
|         west.uiCapability()->setUiReadOnly(true);
 | |
|     }
 | |
| }
 | |
| 
 | |
| //--------------------------------------------------------------------------------------------------
 | |
| /// 
 | |
| //--------------------------------------------------------------------------------------------------
 | |
| void RimWellPathImport::fieldChangedByUi(const caf::PdmFieldHandle* changedField, const QVariant& oldValue, const QVariant& newValue)
 | |
| {
 | |
|     if (changedField == &utmFilterMode)
 | |
|     {
 | |
|         updateFieldVisibility();
 | |
|     }
 | |
| }
 | |
| 
 | |
| //--------------------------------------------------------------------------------------------------
 | |
| /// 
 | |
| //--------------------------------------------------------------------------------------------------
 | |
| void RimWellPathImport::defineObjectEditorAttribute(QString uiConfigName, caf::PdmUiEditorAttribute * attribute)
 | |
| {
 | |
|     caf::PdmUiTreeViewEditorAttribute* myAttr = dynamic_cast<caf::PdmUiTreeViewEditorAttribute*>(attribute);
 | |
|     if (myAttr)
 | |
|     {
 | |
|         QStringList colHeaders;
 | |
|         colHeaders << "Region";
 | |
|         myAttr->columnHeaders = colHeaders;
 | |
|     }
 | |
| }
 | |
| 
 | |
| //--------------------------------------------------------------------------------------------------
 | |
| /// 
 | |
| //--------------------------------------------------------------------------------------------------
 | |
| RimWellPathImport::~RimWellPathImport()
 | |
| {
 | |
|     regions.deleteAllChildObjects();
 | |
| }
 | |
| 
 | |
| //--------------------------------------------------------------------------------------------------
 | |
| /// 
 | |
| //--------------------------------------------------------------------------------------------------
 | |
| void RimWellPathImport::updateFilePaths()
 | |
| {
 | |
|     QString wellPathsFolderPath = RimTools::getCacheRootDirectoryPathFromProject();
 | |
|     wellPathsFolderPath += "_wellpaths";
 | |
| 
 | |
|     for (size_t regionIdx = 0; regionIdx < this->regions.size(); regionIdx++)
 | |
|     {
 | |
|         for (size_t fIdx = 0; fIdx < this->regions[regionIdx]->fields.size(); fIdx++)
 | |
|         {
 | |
|             RimOilFieldEntry* oilField = this->regions[regionIdx]->fields[fIdx];
 | |
| 
 | |
|             QFileInfo fi(oilField->wellsFilePath);
 | |
| 
 | |
|             QString newWellsFilePath = wellPathsFolderPath + "/" + fi.fileName();
 | |
|             oilField->wellsFilePath = newWellsFilePath;
 | |
| 
 | |
|             for (size_t wIdx = 0; wIdx < oilField->wells.size(); wIdx++)
 | |
|             {
 | |
|                 RimWellPathEntry* rimWellPathEntry = oilField->wells[wIdx];
 | |
| 
 | |
|                 QFileInfo fiWell(rimWellPathEntry->wellPathFilePath);
 | |
| 
 | |
|                 QString newFilePath = wellPathsFolderPath + "/" + fiWell.fileName();
 | |
|                 rimWellPathEntry->wellPathFilePath = newFilePath;
 | |
|             }
 | |
|         }
 | |
|     }
 | |
| }
 | |
| 
 | |
| 
 | |
| 
 |