mirror of
				https://github.com/OPM/ResInsight.git
				synced 2025-02-25 18:55:39 -06:00 
			
		
		
		
	(#592) Fixed autoscale for track move delete toggle
Also avoid to always do updateConnectedEditors on project when deleting a curve
This commit is contained in:
		| @@ -110,32 +110,40 @@ void RicDeleteItemExec::redo() | ||||
|             wellPathColl->scheduleGeometryRegenAndRedrawViews(); | ||||
|         } | ||||
|  | ||||
|         // Update due to deletion of curves (not tracks, handled separatly) | ||||
|  | ||||
|         RimWellLogPlot* wellLogPlot; | ||||
|         parentObj->firstAnchestorOrThisOfType(wellLogPlot); | ||||
|         if (wellLogPlot) | ||||
|         { | ||||
|             wellLogPlot->calculateAvailableDepthRange(); | ||||
|             wellLogPlot->zoomAllDepth(); | ||||
|         } | ||||
|  | ||||
|         RimWellLogPlotTrack* wellLogPlotTrack; | ||||
|         parentObj->firstAnchestorOrThisOfType(wellLogPlotTrack); | ||||
|         if (wellLogPlotTrack) | ||||
|         { | ||||
|             wellLogPlotTrack->zoomAllXAndZoomAllDepthOnOwnerPlot(); | ||||
|             wellLogPlotTrack->zoomAllXAxis(); | ||||
|         } | ||||
|          | ||||
|         // Update due to delete plots | ||||
|         // Make sure the plot collection disappears with the last plot | ||||
|  | ||||
|         RimWellLogPlotCollection* wellLogPlotCollection = NULL; | ||||
|         parentObj->firstAnchestorOrThisOfType(wellLogPlotCollection); | ||||
|         RimWellLogPlotCollection* wellLogPlotCollection = dynamic_cast<RimWellLogPlotCollection*>(parentObj); | ||||
|         if (wellLogPlotCollection) | ||||
|         { | ||||
|             RimProject* project = NULL; | ||||
|             parentObj->firstAnchestorOrThisOfType(project); | ||||
|             if (project) | ||||
|             if (wellLogPlotCollection->wellLogPlots.empty()) | ||||
|             { | ||||
|                 project->updateConnectedEditors(); | ||||
|                 RimProject* project = NULL; | ||||
|                 parentObj->firstAnchestorOrThisOfType(project); | ||||
|                 if (project) | ||||
|                 { | ||||
|                     project->updateConnectedEditors(); | ||||
|                 } | ||||
|             } | ||||
|         } | ||||
|  | ||||
|          | ||||
|         RimViewLinkerCollection* viewLinkerCollection = NULL; | ||||
|         parentObj->firstAnchestorOrThisOfType(viewLinkerCollection); | ||||
|         if (viewLinkerCollection) | ||||
|   | ||||
| @@ -67,12 +67,12 @@ void RicDeleteWellLogPlotTrackFeature::onActionTriggered(bool isChecked) | ||||
|         if (wellLogPlot && wellLogPlot->trackCount() > 1) | ||||
|         { | ||||
|             wellLogPlot->removeTrack(track); | ||||
|             wellLogPlot->calculateAvailableDepthRange(); | ||||
|             wellLogPlot->uiCapability()->updateConnectedEditors(); | ||||
|          | ||||
|             caf::SelectionManager::instance()->removeObjectFromAllSelections(track); | ||||
|  | ||||
|             delete track; | ||||
|  | ||||
|             wellLogPlot->calculateAvailableDepthRange(); | ||||
|             wellLogPlot->zoomAllDepth(); | ||||
|             wellLogPlot->uiCapability()->updateConnectedEditors(); | ||||
|         } | ||||
|     } | ||||
| } | ||||
|   | ||||
| @@ -32,7 +32,7 @@ | ||||
| //-------------------------------------------------------------------------------------------------- | ||||
| void RicWellLogPlotTrackFeatureImpl::moveCurvesToWellLogPlotTrack(RimWellLogPlotTrack* destTrack,  | ||||
|                                                                   const std::vector<RimWellLogPlotCurve*>& curves,  | ||||
|                                                                   RimWellLogPlotCurve* insertAfterCurve) | ||||
|                                                                   RimWellLogPlotCurve* curveToInsertAfter) | ||||
| { | ||||
|     CVF_ASSERT(destTrack ); | ||||
|  | ||||
| @@ -57,7 +57,7 @@ void RicWellLogPlotTrackFeatureImpl::moveCurvesToWellLogPlotTrack(RimWellLogPlot | ||||
|     } | ||||
|  | ||||
|     size_t insertionStartIndex = 0; | ||||
|     if (insertAfterCurve) insertionStartIndex = destTrack->curveIndex(insertAfterCurve) + 1; | ||||
|     if (curveToInsertAfter) insertionStartIndex = destTrack->curveIndex(curveToInsertAfter) + 1; | ||||
|  | ||||
|     for (size_t cIdx = 0; cIdx < curves.size(); cIdx++) | ||||
|     { | ||||
| @@ -88,21 +88,30 @@ void RicWellLogPlotTrackFeatureImpl::moveTracksToWellLogPlot(RimWellLogPlot* dst | ||||
| { | ||||
|     CVF_ASSERT(dstWellLogPlot); | ||||
|  | ||||
|     RimWellLogPlotTrack* track = NULL; | ||||
|     std::set<RimWellLogPlot*> srcPlots; | ||||
|  | ||||
|     for (size_t tIdx = 0; tIdx < tracksToMove.size(); tIdx++) | ||||
|     { | ||||
|         track = tracksToMove[tIdx]; | ||||
|         RimWellLogPlotTrack* track = tracksToMove[tIdx]; | ||||
|  | ||||
|         RimWellLogPlot* oldPlot; | ||||
|         track->firstAnchestorOrThisOfType(oldPlot); | ||||
|         if (oldPlot) | ||||
|         RimWellLogPlot* srcPlot; | ||||
|         track->firstAnchestorOrThisOfType(srcPlot); | ||||
|         if (srcPlot) | ||||
|         { | ||||
|             oldPlot->removeTrack(track); | ||||
|             oldPlot->updateTrackNames(); | ||||
|             oldPlot->updateConnectedEditors(); | ||||
|             srcPlot->removeTrack(track); | ||||
|            | ||||
|             srcPlots.insert(srcPlot); | ||||
|         } | ||||
|      } | ||||
|     } | ||||
|  | ||||
|     for (std::set<RimWellLogPlot*>::iterator pIt = srcPlots.begin(); pIt != srcPlots.end(); ++pIt) | ||||
|     { | ||||
|         (*pIt)->calculateAvailableDepthRange(); | ||||
|         (*pIt)->updateTrackNames(); | ||||
|         (*pIt)->zoomAllDepth(); | ||||
|         (*pIt)->updateConnectedEditors(); | ||||
|     } | ||||
|  | ||||
|  | ||||
|     size_t insertionStartIndex = 0; | ||||
|     if (trackToInsertAfter) insertionStartIndex = dstWellLogPlot->trackIndex(trackToInsertAfter) + 1; | ||||
| @@ -116,21 +125,3 @@ void RicWellLogPlotTrackFeatureImpl::moveTracksToWellLogPlot(RimWellLogPlot* dst | ||||
|     dstWellLogPlot->updateTracks(); | ||||
|     dstWellLogPlot->updateConnectedEditors(); | ||||
| } | ||||
|  | ||||
| /* | ||||
| //-------------------------------------------------------------------------------------------------- | ||||
| ///  | ||||
| //-------------------------------------------------------------------------------------------------- | ||||
| void RicWellLogPlotTrackFeatureImpl::moveTracks(RimWellLogPlotTrack* insertAfterTrack, const std::vector<RimWellLogPlotTrack*>& tracks) | ||||
| { | ||||
|     CVF_ASSERT(insertAfterTrack); | ||||
|  | ||||
|     RimWellLogPlot* wellLogPlot; | ||||
|     insertAfterTrack->firstAnchestorOrThisOfType(wellLogPlot); | ||||
|     if (wellLogPlot) | ||||
|     { | ||||
|         wellLogPlot->moveTracks(insertAfterTrack, tracks); | ||||
|         wellLogPlot->updateConnectedEditors(); | ||||
|     } | ||||
| } | ||||
| */ | ||||
| @@ -38,5 +38,4 @@ public: | ||||
|     static void moveTracksToWellLogPlot(RimWellLogPlot* wellLogPlot,  | ||||
|                                         const std::vector<RimWellLogPlotTrack*>& tracks, | ||||
|                                         RimWellLogPlotTrack* trackToInsertAfter); | ||||
|     //static void moveTracks(RimWellLogPlotTrack* insertAfterTrack, const std::vector<RimWellLogPlotTrack*>& tracks); | ||||
| }; | ||||
|   | ||||
| @@ -291,18 +291,20 @@ void RimWellLogPlot::calculateAvailableDepthRange() | ||||
|         double minTrackDepth = HUGE_VAL; | ||||
|         double maxTrackDepth = -HUGE_VAL; | ||||
|  | ||||
|         m_tracks[tIdx]->availableDepthRange(&minTrackDepth, &maxTrackDepth); | ||||
|  | ||||
|         if (minTrackDepth < minDepth) | ||||
|         if (m_tracks[tIdx]->isVisible()) | ||||
|         { | ||||
|             minDepth = minTrackDepth; | ||||
|         } | ||||
|             m_tracks[tIdx]->availableDepthRange(&minTrackDepth, &maxTrackDepth); | ||||
|  | ||||
|         if (maxTrackDepth > maxDepth) | ||||
|         { | ||||
|             maxDepth = maxTrackDepth; | ||||
|             if (minTrackDepth < minDepth) | ||||
|             { | ||||
|                 minDepth = minTrackDepth; | ||||
|             } | ||||
|  | ||||
|             if (maxTrackDepth > maxDepth) | ||||
|             { | ||||
|                 maxDepth = maxTrackDepth; | ||||
|             } | ||||
|         } | ||||
|          | ||||
|     } | ||||
|  | ||||
|     m_minAvailableDepth = minDepth; | ||||
|   | ||||
| @@ -80,7 +80,18 @@ void RimWellLogPlotTrack::fieldChangedByUi(const caf::PdmFieldHandle* changedFie | ||||
| { | ||||
|     if (changedField == &m_show) | ||||
|     { | ||||
|         if (m_wellLogTrackPlotWidget) m_wellLogTrackPlotWidget->setVisible(m_show()); | ||||
|         if (m_wellLogTrackPlotWidget) | ||||
|         { | ||||
|             m_wellLogTrackPlotWidget->setVisible(m_show()); | ||||
|         } | ||||
|  | ||||
|         RimWellLogPlot* wellLogPlot; | ||||
|         this->firstAnchestorOrThisOfType(wellLogPlot); | ||||
|         if (wellLogPlot) | ||||
|         { | ||||
|             wellLogPlot->calculateAvailableDepthRange(); | ||||
|             wellLogPlot->zoomAllDepth(); | ||||
|         } | ||||
|     } | ||||
|     else if (changedField == &m_visibleXRangeMin || changedField == &m_visibleXRangeMax) | ||||
|     { | ||||
| @@ -353,3 +364,11 @@ size_t RimWellLogPlotTrack::curveIndex(RimWellLogPlotCurve* curve) | ||||
| { | ||||
|     return curves.index(curve); | ||||
| } | ||||
|  | ||||
| //-------------------------------------------------------------------------------------------------- | ||||
| ///  | ||||
| //-------------------------------------------------------------------------------------------------- | ||||
| bool RimWellLogPlotTrack::isVisible() | ||||
| { | ||||
|     return m_show; | ||||
| } | ||||
|   | ||||
| @@ -44,7 +44,7 @@ public: | ||||
|     virtual ~RimWellLogPlotTrack(); | ||||
|  | ||||
|     void setDescription(const QString& description); | ||||
|  | ||||
|     bool isVisible(); | ||||
|     void addCurve(RimWellLogPlotCurve* curve); | ||||
|     void insertCurve(RimWellLogPlotCurve* curve, size_t index); | ||||
|     void removeCurve(RimWellLogPlotCurve* curve); | ||||
| @@ -59,6 +59,7 @@ public: | ||||
|     void availableDepthRange(double* minimumDepth, double* maximumDepth); | ||||
|     void zoomAllXAndZoomAllDepthOnOwnerPlot(); | ||||
|     void alignDepthZoomToPlotAndZoomAllX(); | ||||
|     void zoomAllXAxis(); | ||||
|  | ||||
|     RiuWellLogTrackPlot* viewer(); | ||||
|      | ||||
| @@ -73,7 +74,6 @@ protected: | ||||
|     virtual void defineUiOrdering(QString uiConfigName, caf::PdmUiOrdering& uiOrdering); | ||||
|  | ||||
| private: | ||||
|     void zoomAllXAxis(); | ||||
| private: | ||||
|     caf::PdmField<bool> m_show; | ||||
|     caf::PdmField<QString> m_userName; | ||||
|   | ||||
		Reference in New Issue
	
	Block a user