diff --git a/src/OpenGl/OpenGl_GraphicDriver.cxx b/src/OpenGl/OpenGl_GraphicDriver.cxx index 833c4c5e10..b60b7cd16e 100644 --- a/src/OpenGl/OpenGl_GraphicDriver.cxx +++ b/src/OpenGl/OpenGl_GraphicDriver.cxx @@ -447,23 +447,26 @@ void OpenGl_GraphicDriver::EnableVBO (const Standard_Boolean theToTurnOn) // function : GetSharedContext // purpose : // ======================================================================= -const Handle(OpenGl_Context)& OpenGl_GraphicDriver::GetSharedContext() const +const Handle(OpenGl_Context)& OpenGl_GraphicDriver::GetSharedContext (bool theBound) const { if (myMapOfView.IsEmpty()) { return TheNullGlCtx; } - NCollection_Map::Iterator anIter (myMapOfView); - for (; anIter.More(); anIter.Next()) + for (NCollection_Map::Iterator aViewIter (myMapOfView); aViewIter.More(); aViewIter.Next()) { - Handle(OpenGl_Window) aWindow = anIter.Value()->GlWindow(); - if (aWindow.IsNull()) + if (const Handle(OpenGl_Window)& aWindow = aViewIter.Value()->GlWindow()) { - continue; + if (!theBound) + { + return aWindow->GetGlContext(); + } + else if (aWindow->GetGlContext()->IsCurrent()) + { + return aWindow->GetGlContext(); + } } - - return aWindow->GetGlContext(); } return TheNullGlCtx; diff --git a/src/OpenGl/OpenGl_GraphicDriver.hxx b/src/OpenGl/OpenGl_GraphicDriver.hxx index 4cdba035dd..a07ec644be 100644 --- a/src/OpenGl/OpenGl_GraphicDriver.hxx +++ b/src/OpenGl/OpenGl_GraphicDriver.hxx @@ -153,7 +153,9 @@ public: //! Method to retrieve valid GL context. //! Could return NULL-handle if no window created by this driver. - Standard_EXPORT const Handle(OpenGl_Context)& GetSharedContext() const; + //! @param theBound if TRUE then currently bound context will be returned, + //! any context will be returned otherwise + Standard_EXPORT const Handle(OpenGl_Context)& GetSharedContext (bool theBound = false) const; #if defined(HAVE_EGL) || defined(HAVE_GLES2) || defined(OCCT_UWP) || defined(__ANDROID__) || defined(__QNX__) Aspect_Display getRawGlDisplay() const { return myEglDisplay; } diff --git a/src/SelectBasics/SelectBasics_SelectingVolumeManager.hxx b/src/SelectBasics/SelectBasics_SelectingVolumeManager.hxx index 1c68de1cbd..eb93e1c899 100644 --- a/src/SelectBasics/SelectBasics_SelectingVolumeManager.hxx +++ b/src/SelectBasics/SelectBasics_SelectingVolumeManager.hxx @@ -109,6 +109,9 @@ public: //! correspondingly) onto far view frustum plane virtual gp_Pnt GetFarPickedPnt() const = 0; + //! Return mouse coordinates for Point selection mode. + virtual gp_Pnt2d GetMousePosition() const = 0; + //! Stores plane equation coefficients (in the following form: //! Ax + By + Cz + D = 0) to the given vector virtual void GetPlanes (NCollection_Vector >& thePlaneEquations) const = 0; diff --git a/src/SelectMgr/SelectMgr_RectangularFrustum.hxx b/src/SelectMgr/SelectMgr_RectangularFrustum.hxx index 1fae9f4f0a..10ad731d1d 100644 --- a/src/SelectMgr/SelectMgr_RectangularFrustum.hxx +++ b/src/SelectMgr/SelectMgr_RectangularFrustum.hxx @@ -133,6 +133,9 @@ public: //! correspondingly) onto far view frustum plane inline const gp_Pnt& GetFarPnt() const { return myFarPickedPnt; } + //! Return mouse coordinates. + const gp_Pnt2d& GetMousePosition() const { return myMousePos; } + //! Stores plane equation coefficients (in the following form: //! Ax + By + Cz + D = 0) to the given vector Standard_EXPORT virtual void GetPlanes (NCollection_Vector& thePlaneEquations) const Standard_OVERRIDE; diff --git a/src/SelectMgr/SelectMgr_SelectingVolumeManager.hxx b/src/SelectMgr/SelectMgr_SelectingVolumeManager.hxx index 92715faabe..d54cf1f87c 100644 --- a/src/SelectMgr/SelectMgr_SelectingVolumeManager.hxx +++ b/src/SelectMgr/SelectMgr_SelectingVolumeManager.hxx @@ -196,6 +196,17 @@ public: //! correspondingly) onto far view frustum plane Standard_EXPORT virtual gp_Pnt GetFarPickedPnt() const Standard_OVERRIDE; + //! Return mouse coordinates for Point selection mode. + virtual gp_Pnt2d GetMousePosition() const Standard_OVERRIDE + { + if (myActiveSelectionType != Point) + { + return gp_Pnt2d (RealLast(), RealLast()); + } + const SelectMgr_RectangularFrustum* aFr = reinterpret_cast (mySelectingVolumes[myActiveSelectionType / 2].get()); + return aFr->GetMousePosition(); + } + //! Returns active selecting volume that was built during last //! run of OCCT selection mechanism Handle(SelectMgr_BaseFrustum) ActiveVolume() const