1 // Copyright (C) 2014-20xx CEA/DEN, EDF R&D
3 // File: PartSet_CustomPrs.cpp
4 // Created: 30 Jun 2015
5 // Author: Natalia ERMOLAEVA
7 #include <PartSet_CustomPrs.h>
8 #include <PartSet_Module.h>
9 #include "PartSet_OperationPrs.h"
10 #include "PartSet_OverconstraintListener.h"
12 #include <XGUI_ModuleConnector.h>
13 #include <XGUI_Workshop.h>
14 #include <XGUI_Displayer.h>
16 #include <ModuleBase_IWorkshop.h>
17 #include <ModuleBase_IViewer.h>
18 #include <ModuleBase_Tools.h>
20 #include <Config_PropManager.h>
21 #include <Events_Loop.h>
22 #include <ModelAPI_Events.h>
24 #include <AIS_InteractiveContext.hxx>
25 #include <AIS_InteractiveObject.hxx>
26 #include <Prs3d_PointAspect.hxx>
28 //#define DO_NOT_VISUALIZE_CUSTOM_PRESENTATION
30 PartSet_CustomPrs::PartSet_CustomPrs(ModuleBase_IWorkshop* theWorkshop)
31 : myWorkshop(theWorkshop), myFeature(FeaturePtr()), myPresentationIsEmpty(false)
33 Events_Loop* aLoop = Events_Loop::loop();
34 aLoop->registerListener(this, Events_Loop::eventByName(EVENT_EMPTY_OPERATION_PRESENTATION));
36 initPresentation(ModuleBase_IModule::CustomizeArguments);
37 initPresentation(ModuleBase_IModule::CustomizeResults);
38 initPresentation(ModuleBase_IModule::CustomizeHighlightedObjects);
40 myIsActive[ModuleBase_IModule::CustomizeArguments] = false;
41 myIsActive[ModuleBase_IModule::CustomizeResults] = false;
42 myIsActive[ModuleBase_IModule::CustomizeHighlightedObjects] = false;
45 bool PartSet_CustomPrs::isActive(const ModuleBase_IModule::ModuleBase_CustomizeFlag& theFlag)
47 return myIsActive[theFlag];
50 bool PartSet_CustomPrs::activate(const FeaturePtr& theFeature,
51 const ModuleBase_IModule::ModuleBase_CustomizeFlag& theFlag,
52 const bool theUpdateViewer)
54 #ifdef DO_NOT_VISUALIZE_CUSTOM_PRESENTATION
58 myIsActive[theFlag] = true;
59 myFeature = theFeature;
61 bool isModified = false;
62 if (theFeature.get()) {
63 displayPresentation(ModuleBase_IModule::CustomizeArguments, theUpdateViewer);
64 displayPresentation(ModuleBase_IModule::CustomizeResults, theUpdateViewer);
65 displayPresentation(ModuleBase_IModule::CustomizeHighlightedObjects, theUpdateViewer);
71 bool PartSet_CustomPrs::deactivate(const ModuleBase_IModule::ModuleBase_CustomizeFlag& theFlag,
72 const bool theUpdateViewer)
74 myIsActive[theFlag] = false;
75 bool isModified = false;
77 erasePresentation(ModuleBase_IModule::CustomizeArguments, theUpdateViewer);
78 erasePresentation(ModuleBase_IModule::CustomizeResults, theUpdateViewer);
79 erasePresentation(ModuleBase_IModule::CustomizeHighlightedObjects, theUpdateViewer);
85 bool PartSet_CustomPrs::displayPresentation(
86 const ModuleBase_IModule::ModuleBase_CustomizeFlag& theFlag,
87 const bool theUpdateViewer)
89 bool isModified = false;
91 // update the AIS objects content
92 AISObjectPtr aPresentation = getPresentation(theFlag, true);
93 Handle(AIS_InteractiveObject) anAISIO = aPresentation->impl<Handle(AIS_InteractiveObject)>();
94 Handle(PartSet_OperationPrs) anOperationPrs = Handle(PartSet_OperationPrs)::DownCast(anAISIO);
96 // do nothing if the feature can not be displayed [is moved from presentation, to be checked]
100 QMap<ObjectPtr, QList<GeomShapePtr> > aFeatureShapes;
102 case ModuleBase_IModule::CustomizeArguments:
103 PartSet_OperationPrs::getFeatureShapes(myFeature, myWorkshop, aFeatureShapes);
105 case ModuleBase_IModule::CustomizeResults:
106 PartSet_OperationPrs::getResultShapes(myFeature, myWorkshop, aFeatureShapes);
108 case ModuleBase_IModule::CustomizeHighlightedObjects:
109 PartSet_OperationPrs::getHighlightedShapes(myWorkshop, aFeatureShapes);
114 NCollection_DataMap<TopoDS_Shape, Handle_AIS_InteractiveObject>& aShapeMap =
115 anOperationPrs->shapesMap();
116 PartSet_OperationPrs::fillShapeList(aFeatureShapes, myWorkshop, aShapeMap);
118 myPresentationIsEmpty = false;
119 // redisplay AIS objects
120 bool aRedisplayed = false;
121 Handle(AIS_InteractiveContext) aContext = myWorkshop->viewer()->AISContext();
122 if (!aContext.IsNull() && !aContext->IsDisplayed(anOperationPrs)) {
123 // when the feature can not be visualized in the module, the operation preview should not
124 // be visualized also
125 if (anOperationPrs->hasShapes() && myWorkshop->module()->canDisplayObject(myFeature)) {
126 // set color here because it can be changed in preferences
127 Quantity_Color aShapeColor = getShapeColor(theFlag);
128 anOperationPrs->setShapeColor(aShapeColor);
130 PartSet_Module* aModule = dynamic_cast<PartSet_Module*>(myWorkshop->module());
131 XGUI_Workshop* aWorkshop = workshop();
132 aRedisplayed = aWorkshop->displayer()->displayAIS(myPresentations[theFlag],
133 false/*load object in selection*/, false);
134 aContext->SetZLayer(anOperationPrs, aModule->getVisualLayerId());
139 // when the feature can not be visualized in the module, the operation preview should not
140 // be visualized also
141 if (!anOperationPrs->hasShapes() || !myWorkshop->module()->canDisplayObject(myFeature)) {
142 aRedisplayed = erasePresentation(theFlag, false);
146 anOperationPrs->Redisplay();
151 if (myPresentationIsEmpty) {
152 aRedisplayed = erasePresentation(theFlag, false);
154 if (aRedisplayed && theUpdateViewer)
155 workshop()->displayer()->updateViewer();
160 bool PartSet_CustomPrs::erasePresentation(const ModuleBase_IModule::ModuleBase_CustomizeFlag& theFlag,
161 const bool theUpdateViewer)
163 bool isErased = false;
164 XGUI_Workshop* aWorkshop = workshop();
165 if (myPresentations.contains(theFlag))
166 isErased = aWorkshop->displayer()->eraseAIS(myPresentations[theFlag], theUpdateViewer);
170 void PartSet_CustomPrs::clearPresentation(const ModuleBase_IModule::ModuleBase_CustomizeFlag& theFlag)
172 AISObjectPtr aPresentation = getPresentation(theFlag, false);
173 if (aPresentation.get()) {
174 Handle(AIS_InteractiveObject) anAISIO = aPresentation->impl<Handle(AIS_InteractiveObject)>();
175 Handle(PartSet_OperationPrs) anOperationPrs = Handle(PartSet_OperationPrs)::DownCast(anAISIO);
177 anOperationPrs->shapesMap().Clear();
178 if (!anOperationPrs.IsNull())
179 anOperationPrs.Nullify();
180 myPresentations.remove(theFlag);
184 AISObjectPtr PartSet_CustomPrs::getPresentation(
185 const ModuleBase_IModule::ModuleBase_CustomizeFlag& theFlag,
186 const bool theToCreate)
188 Handle(PartSet_OperationPrs) aPresentation;
190 AISObjectPtr anOperationPrs;
191 if (myPresentations.contains(theFlag))
192 anOperationPrs = myPresentations[theFlag];
194 if (!anOperationPrs.get() && theToCreate) {
195 initPresentation(theFlag);
196 anOperationPrs = myPresentations[theFlag];
199 return anOperationPrs;
202 bool PartSet_CustomPrs::redisplay(const ObjectPtr& theObject,
203 const ModuleBase_IModule::ModuleBase_CustomizeFlag& theFlag,
204 const bool theUpdateViewer)
206 #ifdef DO_NOT_VISUALIZE_CUSTOM_PRESENTATION
209 bool aRedisplayed = false;
210 if (myIsActive[theFlag])
211 aRedisplayed = displayPresentation(theFlag, theUpdateViewer);
216 void PartSet_CustomPrs::clearPrs()
218 clearPresentation(ModuleBase_IModule::CustomizeArguments);
219 clearPresentation(ModuleBase_IModule::CustomizeResults);
220 clearPresentation(ModuleBase_IModule::CustomizeHighlightedObjects);
223 void PartSet_CustomPrs::processEvent(const std::shared_ptr<Events_Message>& theMessage)
225 if (theMessage->eventID() == Events_Loop::eventByName(EVENT_EMPTY_OPERATION_PRESENTATION))
226 myPresentationIsEmpty = true; /// store state to analize it after display/erase is finished
229 void PartSet_CustomPrs::initPresentation(const ModuleBase_IModule::ModuleBase_CustomizeFlag& theFlag)
231 AISObjectPtr anOperationPrs = AISObjectPtr(new GeomAPI_AISObject());
232 Handle(PartSet_OperationPrs) anAISPrs = new PartSet_OperationPrs(myWorkshop);
233 anOperationPrs->setImpl(new Handle(AIS_InteractiveObject)(anAISPrs));
234 if (theFlag == ModuleBase_IModule::CustomizeArguments ||
235 theFlag == ModuleBase_IModule::CustomizeResults) {
236 anOperationPrs->setPointMarker(5, 2.);
237 anOperationPrs->setWidth(1);
239 else if (theFlag == ModuleBase_IModule::CustomizeHighlightedObjects)
240 anAISPrs->useAISWidth();
242 if (anOperationPrs.get())
243 myPresentations[theFlag] = anOperationPrs;
246 Quantity_Color PartSet_CustomPrs::getShapeColor(
247 const ModuleBase_IModule::ModuleBase_CustomizeFlag& theFlag)
249 Quantity_Color aColor;
251 case ModuleBase_IModule::CustomizeArguments:
252 aColor = ModuleBase_Tools::color("Visualization", "operation_parameter_color",
253 OPERATION_PARAMETER_COLOR());
255 case ModuleBase_IModule::CustomizeResults:
256 aColor = ModuleBase_Tools::color("Visualization", "operation_result_color",
257 OPERATION_RESULT_COLOR());
259 case ModuleBase_IModule::CustomizeHighlightedObjects:
260 aColor = ModuleBase_Tools::color("Visualization", "operation_highlight_color",
261 OPERATION_HIGHLIGHT_COLOR());
269 XGUI_Workshop* PartSet_CustomPrs::workshop() const
271 XGUI_ModuleConnector* aConnector = dynamic_cast<XGUI_ModuleConnector*>(myWorkshop);
272 return aConnector->workshop();