mirror of
				https://github.com/OPM/ResInsight.git
				synced 2025-02-25 18:55:39 -06:00 
			
		
		
		
	(#612) Improved user interaction for adding/deleting curves
When time hist plot is visible, CTRL + mouse click on a cell adds curve to plot Mouse click outside clears curve plot
This commit is contained in:
		| @@ -225,7 +225,7 @@ void RiuViewer::mouseReleaseEvent(QMouseEvent* event) | ||||
|  | ||||
|     if (event->button() == Qt::LeftButton) | ||||
|     { | ||||
|         m_viewerCommands->handlePickAction(event->x(), event->y()); | ||||
|         m_viewerCommands->handlePickAction(event->x(), event->y(), event->modifiers()); | ||||
|         return; | ||||
|     } | ||||
|     else if (event->button() == Qt::RightButton) | ||||
|   | ||||
| @@ -404,9 +404,8 @@ void RiuViewerCommands::slotAddGeoMechPropertyFilter() | ||||
| //-------------------------------------------------------------------------------------------------- | ||||
| ///  | ||||
| //-------------------------------------------------------------------------------------------------- | ||||
| void RiuViewerCommands::handlePickAction(int winPosX, int winPosY) | ||||
| void RiuViewerCommands::handlePickAction(int winPosX, int winPosY, Qt::KeyboardModifiers keyboardModifiers) | ||||
| { | ||||
|  | ||||
|     size_t gridIndex = cvf::UNDEFINED_SIZE_T; | ||||
|     size_t cellIndex = cvf::UNDEFINED_SIZE_T; | ||||
|     size_t nncIndex = cvf::UNDEFINED_SIZE_T; | ||||
| @@ -474,13 +473,18 @@ void RiuViewerCommands::handlePickAction(int winPosX, int winPosY) | ||||
|     } | ||||
|  | ||||
|  | ||||
|     RiuMainWindow* mainWnd = RiuMainWindow::instance(); | ||||
|  | ||||
|     // Compose a info text regarding the hit | ||||
|  | ||||
|     QString pickInfo = "No hits"; | ||||
|     QString resultInfo = ""; | ||||
|  | ||||
|     bool addCurveToTimeHistoryPlot = false; | ||||
|     if (keyboardModifiers & Qt::ControlModifier) | ||||
|     { | ||||
|         addCurveToTimeHistoryPlot = true; | ||||
|     } | ||||
|  | ||||
|     if (cellIndex != cvf::UNDEFINED_SIZE_T || nncIndex != cvf::UNDEFINED_SIZE_T) | ||||
|     { | ||||
|         RimEclipseView* eclipseView = dynamic_cast<RimEclipseView*>(m_reservoirView.p()); | ||||
| @@ -497,12 +501,7 @@ void RiuViewerCommands::handlePickAction(int winPosX, int winPosY) | ||||
|  | ||||
|             pickInfo = textBuilder.topologyText(", "); | ||||
|  | ||||
|             if (eclipseView->cellResult()->hasDynamicResult() && | ||||
|                 eclipseView->eclipseCase() && | ||||
|                 eclipseView->eclipseCase()->reservoirData()) | ||||
|             { | ||||
|                 addTimeHistoryCurve(eclipseView, gridIndex, cellIndex); | ||||
|             } | ||||
|             if (addCurveToTimeHistoryPlot) addTimeHistoryCurve(eclipseView, gridIndex, cellIndex); | ||||
|         } | ||||
|         else if (geomView) | ||||
|         { | ||||
| @@ -515,24 +514,26 @@ void RiuViewerCommands::handlePickAction(int winPosX, int winPosY) | ||||
|  | ||||
|             pickInfo = textBuilder.topologyText(", "); | ||||
|  | ||||
|             if (geomView->cellResult() && | ||||
|                 geomView->cellResult()->hasResult()) | ||||
|             { | ||||
|                 addTimeHistoryCurve(geomView, gridIndex, cellIndex, localIntersectionPoint); | ||||
|             if (addCurveToTimeHistoryPlot) addTimeHistoryCurve(geomView, gridIndex, cellIndex, localIntersectionPoint); | ||||
|         } | ||||
|     } | ||||
|     } | ||||
|     else | ||||
|     { | ||||
|         // Delete all curves if no cell is hit | ||||
|         mainWnd->timeHistoryPlot()->deleteAllCurves(); | ||||
|     } | ||||
|      | ||||
|     if (wellPath) | ||||
|     { | ||||
|         pickInfo = QString("Well path hit: %1").arg(wellPath->name()); | ||||
|     } | ||||
|  | ||||
|     RiuMainWindow* mainWnd = RiuMainWindow::instance(); | ||||
|     if (cellIndex == cvf::UNDEFINED_SIZE_T && | ||||
|         !(keyboardModifiers & Qt::ControlModifier)) | ||||
|     { | ||||
|         if (mainWnd->timeHistoryPlot()->isVisible()) | ||||
|         { | ||||
|             // Delete all curves if no cell is hit | ||||
|             mainWnd->timeHistoryPlot()->deleteAllCurves(); | ||||
|         } | ||||
|     } | ||||
|  | ||||
|     mainWnd->statusBar()->showMessage(pickInfo); | ||||
|     mainWnd->setResultInfo(resultInfo); | ||||
| } | ||||
| @@ -542,6 +543,13 @@ void RiuViewerCommands::handlePickAction(int winPosX, int winPosY) | ||||
| //-------------------------------------------------------------------------------------------------- | ||||
| void RiuViewerCommands::addTimeHistoryCurve(RimEclipseView* eclipseView, size_t gridIndex, size_t cellIndex) | ||||
| { | ||||
|     RiuMainWindow* mainWnd = RiuMainWindow::instance(); | ||||
|     if (!mainWnd->timeHistoryPlot()->isVisible()) return; | ||||
|  | ||||
|     if (eclipseView->cellResult()->hasDynamicResult() && | ||||
|         eclipseView->eclipseCase() && | ||||
|         eclipseView->eclipseCase()->reservoirData()) | ||||
|     { | ||||
|         RifReaderInterface::PorosityModelResultType porosityModel = RigCaseCellResultsData::convertFromProjectModelPorosityModel(eclipseView->cellResult()->porosityModel()); | ||||
|  | ||||
|         std::vector<QDateTime> timeStepDates = eclipseView->eclipseCase()->reservoirData()->results(porosityModel)->timeStepDates(eclipseView->cellResult()->scalarResultIndex()); | ||||
| @@ -549,18 +557,19 @@ void RiuViewerCommands::addTimeHistoryCurve(RimEclipseView* eclipseView, size_t | ||||
|         RigTimeHistoryResultAccessor timeHistResultAccessor(eclipseView->eclipseCase()->reservoirData(), gridIndex, cellIndex, eclipseView->cellResult()->scalarResultIndex(), porosityModel); | ||||
|  | ||||
|         QString curveName = eclipseView->eclipseCase()->caseUserDescription(); | ||||
|     curveName += " - Result : "; | ||||
|         curveName += ", "; | ||||
|         curveName += eclipseView->cellResult()->resultVariable(); | ||||
|     curveName += " - "; | ||||
|         curveName += ", "; | ||||
|         curveName += QString("Grid index %1").arg(gridIndex); | ||||
|         curveName += ", "; | ||||
|         curveName += timeHistResultAccessor.topologyText(); | ||||
|  | ||||
|         std::vector<double> timeHistoryValues = timeHistResultAccessor.timeHistoryValues(); | ||||
|  | ||||
|         CVF_ASSERT(timeStepDates.size() == timeHistoryValues.size()); | ||||
|      | ||||
|     RiuMainWindow* mainWnd = RiuMainWindow::instance(); | ||||
|      | ||||
|         mainWnd->timeHistoryPlot()->addCurve(curveName, timeStepDates, timeHistoryValues); | ||||
|     } | ||||
| } | ||||
|  | ||||
| //-------------------------------------------------------------------------------------------------- | ||||
| @@ -568,8 +577,12 @@ void RiuViewerCommands::addTimeHistoryCurve(RimEclipseView* eclipseView, size_t | ||||
| //-------------------------------------------------------------------------------------------------- | ||||
| void RiuViewerCommands::addTimeHistoryCurve(RimGeoMechView* geoMechView, size_t gridIndex, size_t cellIndex, const cvf::Vec3d& localIntersectionPoint) | ||||
| { | ||||
|     RiuMainWindow* mainWnd = RiuMainWindow::instance(); | ||||
|     if (!mainWnd->timeHistoryPlot()->isVisible()) return; | ||||
|  | ||||
|     if (geoMechView && | ||||
|         geoMechView->cellResult() && | ||||
|         geoMechView->cellResult()->hasResult() && | ||||
|         geoMechView->geoMechCase() && | ||||
|         geoMechView->geoMechCase()->geoMechData()) | ||||
|     { | ||||
|   | ||||
| @@ -47,7 +47,7 @@ public: | ||||
|     void setOwnerView(RimView * owner); | ||||
|  | ||||
|     void            displayContextMenu(QMouseEvent* event); | ||||
|     void            handlePickAction(int winPosX, int winPosY); | ||||
|     void            handlePickAction(int winPosX, int winPosY, Qt::KeyboardModifiers keyboardModifiers); | ||||
|  | ||||
|  | ||||
| private slots: | ||||
|   | ||||
		Reference in New Issue
	
	Block a user