#include "XGUI_ViewerProxy.h"
#include "XGUI_Displayer.h"
#include "XGUI_Selection.h"
+#include "XGUI_OperationMgr.h"
#ifndef HAVE_SALOME
#include <AppElements_MainWindow.h>
#include <SelectMgr_ListIteratorOfListOfFilter.hxx>
-#ifdef VINSPECTOR
-#include <VInspectorAPI_CallBack.h>
+#ifdef TINSPECTOR
+#include <VInspectorAPI_CallBack.hxx>
#endif
XGUI_SelectionMgr::XGUI_SelectionMgr(XGUI_Workshop* theParent)
void XGUI_SelectionMgr::setSelectedOwners(const SelectMgr_IndexedMapOfOwner& theSelectedOwners,
bool isUpdateViewer)
{
- SelectMgr_IndexedMapOfOwner aSelectedOwners;
- selection()->selectedOwners(aSelectedOwners);
-
Handle(AIS_InteractiveContext) aContext = myWorkshop->viewer()->AISContext();
if (!aContext.IsNull()) {
+ /// previous selection should be cleared, else there will be decomposition of selections:
+ /// as AddOrRemoveSelected inverts current selection
+ aContext->ClearSelected(false);
+
for (Standard_Integer i = 1, n = theSelectedOwners.Extent(); i <= n; i++) {
Handle(SelectMgr_EntityOwner) anOwner = theSelectedOwners(i);
- if (aSelectedOwners.FindIndex(anOwner) > 0)
- continue;
aContext->AddOrRemoveSelected(anOwner, isUpdateViewer);
- #ifdef VINSPECTOR
+ #ifdef TINSPECTOR
if (myWorkshop->displayer()->getCallBack())
myWorkshop->displayer()->getCallBack()->AddOrRemoveSelected(anOwner);
#endif
}
}
- ModuleBase_Tools::selectionInfo(aContext,
- "XGUI_SelectionMgr::setSelectedOwners -- AddOrRemoveSelected");
-}
-
-//**************************************************************
-void XGUI_SelectionMgr::updateSelectedOwners(bool isUpdateViewer)
-{
- Handle(AIS_InteractiveContext) aContext = myWorkshop->viewer()->AISContext();
- if (aContext.IsNull())
- return;
-
- const SelectMgr_ListOfFilter& aFilters = aContext->Filters();
-
- SelectMgr_IndexedMapOfOwner anOwnersToDeselect;
-
- SelectMgr_ListIteratorOfListOfFilter anIt(aFilters);
- for (; anIt.More(); anIt.Next()) {
- Handle(SelectMgr_Filter) aFilter = anIt.Value();
- for (aContext->InitSelected(); aContext->MoreSelected(); aContext->NextSelected()) {
- Handle(SelectMgr_EntityOwner) anOwner = aContext->SelectedOwner();
- if (!aFilter->IsOk(anOwner))
- anOwnersToDeselect.Add(aContext->SelectedOwner());
- }
- }
-
- setSelectedOwners(anOwnersToDeselect, false);
-
- if (isUpdateViewer)
- aContext->UpdateCurrentViewer();
}
//**************************************************************
QObjectPtrList aFeatures;
ResultPtr aResult;
FeaturePtr aFeature;
+ bool aHasOperation = (myWorkshop->operationMgr()->currentOperation() != 0);
Handle(AIS_InteractiveContext) aContext = myWorkshop->viewer()->AISContext();
if (!aContext.IsNull()) {
QList<ModuleBase_ViewerPrsPtr> aPresentations =
if (aPrs->object().get()) {
if (!aFeatures.contains(aPrs->object()))
aFeatures.append(aPrs->object());
- if (aPrs->shape().get()) {
+ if (aPrs->shape().get() && (!aHasOperation)) {
aResult = std::dynamic_pointer_cast<ModelAPI_Result>(aPrs->object());
if (aResult.get()) {
aFeature = anActiveDocument->producedByFeature(aResult, aPrs->shape());