]> SALOME platform Git repositories - modules/shaper.git/blob - src/PartSet/PartSet_Filters.cpp
Salome HOME
Merge branch 'Dev_GroupsRevision'
[modules/shaper.git] / src / PartSet / PartSet_Filters.cpp
1 // Copyright (C) 2014-2017  CEA/DEN, EDF R&D
2 //
3 // This library is free software; you can redistribute it and/or
4 // modify it under the terms of the GNU Lesser General Public
5 // License as published by the Free Software Foundation; either
6 // version 2.1 of the License, or (at your option) any later version.
7 //
8 // This library is distributed in the hope that it will be useful,
9 // but WITHOUT ANY WARRANTY; without even the implied warranty of
10 // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
11 // Lesser General Public License for more details.
12 //
13 // You should have received a copy of the GNU Lesser General Public
14 // License along with this library; if not, write to the Free Software
15 // Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
16 //
17 // See http://www.salome-platform.org/ or
18 // email : webmaster.salome@opencascade.com<mailto:webmaster.salome@opencascade.com>
19 //
20
21 #include "PartSet_Filters.h"
22
23 #include <ModuleBase_IWorkshop.h>
24 #include "ModuleBase_IModule.h"
25 #include <ModuleBase_ResultPrs.h>
26
27 #include <ModelAPI_Feature.h>
28 #include <ModelAPI_ResultPart.h>
29 #include <ModelAPI_ResultGroup.h>
30 #include <ModelAPI_Session.h>
31
32 #include <AIS_InteractiveObject.hxx>
33 #include <AIS_Shape.hxx>
34 #include <StdSelect_BRepOwner.hxx>
35
36
37 IMPLEMENT_STANDARD_RTTIEXT(PartSet_GlobalFilter, ModuleBase_ShapeDocumentFilter);
38
39 Standard_Boolean PartSet_GlobalFilter::IsOk(const Handle(SelectMgr_EntityOwner)& theOwner) const
40 {
41   bool aValid = true;
42   ModuleBase_Operation* anOperation = myWorkshop->module()->currentOperation();
43   // the shapes from different documents should be provided if there is no started operation
44   // in order to show/hide results
45   if (anOperation) {
46     aValid = false;
47     if (ModuleBase_ShapeDocumentFilter::IsOk(theOwner)) {
48       std::shared_ptr<GeomAPI_AISObject> aAISObj = AISObjectPtr(new GeomAPI_AISObject());
49       if (theOwner->HasSelectable()) {
50         Handle(AIS_InteractiveObject) aAisObj =
51           Handle(AIS_InteractiveObject)::DownCast(theOwner->Selectable());
52         if (!aAisObj.IsNull()) {
53           aAISObj->setImpl(new Handle(AIS_InteractiveObject)(aAisObj));
54         }
55       }
56       ObjectPtr aObj = myWorkshop->findPresentedObject(aAISObj);
57       if (aObj) {
58         ResultPtr aResult = std::dynamic_pointer_cast<ModelAPI_Result>(aObj);
59         // result of parts belongs to PartSet document and can be selected only when PartSet
60         //  is active in order to do not select the result of the active part.
61         if (aResult.get()) {
62           if (aResult->groupName() == ModelAPI_ResultPart::group()) {
63             SessionPtr aMgr = ModelAPI_Session::get();
64             aValid = aMgr->activeDocument() == aMgr->moduleDocument();
65           } else if (aResult->groupName() == ModelAPI_ResultGroup::group()) {
66             aValid = Standard_False;
67           } else
68             aValid = Standard_True;
69         }
70         else { // possibly this code is obsolete, as a feature object can be selected in recovery
71           // only and there can not be Group feature
72           FeaturePtr aFeature = ModelAPI_Feature::feature(aObj);
73           if (aFeature) {
74             aValid = aFeature->getKind() != "Group";
75           } else
76             aValid = Standard_True;
77         }
78       } else
79         // This is not object controlled by the filter
80         aValid = Standard_True;
81     }
82   }
83 #ifdef DEBUG_FILTERS
84   qDebug(QString("PartSet_GlobalFilter::IsOk = %1").arg(aValid).toStdString().c_str());
85 #endif
86   return aValid;
87 }
88
89 IMPLEMENT_STANDARD_RTTIEXT(PartSet_ResultGroupNameFilter, SelectMgr_Filter);
90
91 void PartSet_ResultGroupNameFilter::setGroupNames(const std::set<std::string>& theGroupNames)
92 {
93   myGroupNames = theGroupNames;
94 }
95
96 Standard_Boolean PartSet_ResultGroupNameFilter::IsOk(
97   const Handle(SelectMgr_EntityOwner)& theOwner) const
98 {
99   std::shared_ptr<GeomAPI_AISObject> aAISObj = AISObjectPtr(new GeomAPI_AISObject());
100   if (theOwner->HasSelectable()) {
101     Handle(AIS_InteractiveObject) aAisObj =
102       Handle(AIS_InteractiveObject)::DownCast(theOwner->Selectable());
103     if (!aAisObj.IsNull()) {
104       aAISObj->setImpl(new Handle(AIS_InteractiveObject)(aAisObj));
105     }
106   }
107   ObjectPtr anObject = myWorkshop->findPresentedObject(aAISObj);
108   if (!anObject.get())
109     return true;
110
111   ResultPtr aResult = std::dynamic_pointer_cast<ModelAPI_Result>(anObject);
112   // result of parts belongs to PartSet document and can be selected only when PartSet
113   //  is active in order to do not select the result of the active part.
114   if (!aResult.get())
115     return true;
116
117   std::string aGroupName = aResult->groupName();// == ModelAPI_ResultPart::group()) {
118   if (myGroupNames.find(aGroupName) != myGroupNames.end())
119     return false; // the object of the filtered type is found
120
121   return true;
122 }
123
124
125 IMPLEMENT_STANDARD_RTTIEXT(PartSet_CirclePointFilter, SelectMgr_Filter);
126
127 Standard_Boolean
128   PartSet_CirclePointFilter::IsOk(const Handle(SelectMgr_EntityOwner)& theOwner) const
129 {
130   ModuleBase_Operation* anOperation = myWorkshop->module()->currentOperation();
131   if(!anOperation) {
132     return Standard_True;
133   }
134
135   if(theOwner->HasSelectable() == Standard_False) {
136     return Standard_True;
137   }
138
139   Handle(StdSelect_BRepOwner) aBrepOwner = Handle(StdSelect_BRepOwner)::DownCast(theOwner);
140   if(aBrepOwner.IsNull()) {
141     return Standard_True;
142   }
143
144   const TopoDS_Shape& aShape = aBrepOwner->Shape();
145   if(aShape.IsNull() || aShape.ShapeType() != TopAbs_VERTEX) {
146     return Standard_True;
147   }
148
149   Handle(ModuleBase_ResultPrs) aResultPrs =
150     Handle(ModuleBase_ResultPrs)::DownCast(theOwner->Selectable());
151   if(aResultPrs.IsNull()) {
152     return Standard_True;
153   }
154
155   std::shared_ptr<GeomAPI_AISObject> aGeomAISObj(new GeomAPI_AISObject());
156   aGeomAISObj->setImpl(new Handle(AIS_InteractiveObject)(aResultPrs));
157   ObjectPtr anObj = myWorkshop->findPresentedObject(aGeomAISObj);
158   if(!anObj.get()) {
159     return Standard_True;
160   }
161
162   ResultPtr aResult = std::dynamic_pointer_cast<ModelAPI_Result>(anObj);
163   if(!aResult.get()) {
164     return Standard_True;
165   }
166
167   DocumentPtr aDocument = aResult->document();
168   if(!aDocument.get()) {
169     return Standard_True;
170   }
171
172   FeaturePtr aFeature = aDocument->feature(aResult);
173   if(!aFeature.get() || aFeature->getKind() != "SketchCircle") {
174     return Standard_True;
175   }
176
177   const TopoDS_Shape anOwnerShape = aResultPrs->Shape();
178   if(anOwnerShape.ShapeType() == TopAbs_EDGE) {
179     return Standard_False;
180   }
181
182 #ifdef DEBUG_FILTERS
183   qDebug(QString("PartSet_ShapeDocumentFilter::IsOk = %1").arg(aValid).toStdString().c_str());
184 #endif
185
186   return Standard_True;
187 }