]> SALOME platform Git repositories - modules/shaper.git/blob - src/PartSet/PartSet_Module.cpp
Salome HOME
b28152c011924f6074ae5086818dfbda93dd8c6c
[modules/shaper.git] / src / PartSet / PartSet_Module.cpp
1 #include <PartSet_Module.h>
2 #include <PartSet_OperationSketch.h>
3 #include <PartSet_OperationFeatureCreate.h>
4 #include <PartSet_OperationFeatureEditMulti.h>
5 #include <PartSet_OperationFeatureEdit.h>
6 #include <PartSet_Listener.h>
7 #include <PartSet_TestOCC.h>
8 #include <PartSet_WidgetSketchLabel.h>
9 #include <PartSet_Validators.h>
10 #include <PartSet_Tools.h>
11
12 #include <ModuleBase_Operation.h>
13 #include <ModuleBase_OperationDescription.h>
14 #include <ModuleBase_WidgetFactory.h>
15 #include <ModuleBase_Operation.h>
16 #include <ModuleBase_Tools.h>
17
18 #include <ModelAPI_Object.h>
19 #include <ModelAPI_Events.h>
20 #include <ModelAPI_Validator.h>
21 #include <ModelAPI_Data.h>
22
23 #include <GeomDataAPI_Point2D.h>
24
25 #include <XGUI_MainWindow.h>
26 #include <XGUI_Displayer.h>
27 #include <XGUI_Viewer.h>
28 #include <XGUI_Workshop.h>
29 #include <XGUI_OperationMgr.h>
30 #include <XGUI_SelectionMgr.h>
31 #include <XGUI_Selection.h>
32 #include <XGUI_ViewPort.h>
33 #include <XGUI_ActionsMgr.h>
34 #include <XGUI_ViewerProxy.h>
35 #include <XGUI_ContextMenuMgr.h>
36 #include <XGUI_PropertyPanel.h>
37 #include <XGUI_ModuleConnector.h>
38 #include <XGUI_Tools.h>
39
40 #include <SketchPlugin_Line.h>
41
42 #include <Config_PointerMessage.h>
43 #include <Config_ModuleReader.h>
44 #include <Config_WidgetReader.h>
45 #include <Events_Loop.h>
46 #include <Events_Message.h>
47 #include <Events_Error.h>
48
49 #include <GeomAPI_Shape.h>
50 #include <GeomAPI_AISObject.h>
51 #include <AIS_Shape.hxx>
52
53 #include <QObject>
54 #include <QMouseEvent>
55 #include <QString>
56
57 #include <GeomAlgoAPI_FaceBuilder.h>
58 #include <GeomDataAPI_Dir.h>
59
60 #ifdef _DEBUG
61 #include <QDebug>
62 #endif
63
64
65 /*!Create and return new instance of XGUI_Module*/
66 extern "C" PARTSET_EXPORT ModuleBase_IModule* createModule(XGUI_Workshop* theWshop)
67 {
68   return new PartSet_Module(theWshop);
69 }
70
71 PartSet_Module::PartSet_Module(XGUI_Workshop* theWshop)
72 {
73   myWorkshop = theWshop;
74   myListener = new PartSet_Listener(this);
75
76   XGUI_OperationMgr* anOperationMgr = myWorkshop->operationMgr();
77
78   connect(anOperationMgr, SIGNAL(operationStarted()),
79           this, SLOT(onOperationStarted()));
80
81   connect(anOperationMgr, SIGNAL(operationStopped(ModuleBase_Operation*)),
82           this, SLOT(onOperationStopped(ModuleBase_Operation*)));
83
84   XGUI_ContextMenuMgr* aContextMenuMgr = myWorkshop->contextMenuMgr();
85   connect(aContextMenuMgr, SIGNAL(actionTriggered(const QString&, bool)), 
86           this, SLOT(onContextMenuCommand(const QString&, bool)));
87
88   connect(myWorkshop->viewer(), SIGNAL(mousePress(QMouseEvent*)),
89           this, SLOT(onMousePressed(QMouseEvent*)));
90   connect(myWorkshop->viewer(), SIGNAL(mouseRelease(QMouseEvent*)),
91           this, SLOT(onMouseReleased(QMouseEvent*)));
92   connect(myWorkshop->viewer(), SIGNAL(mouseMove(QMouseEvent*)),
93           this, SLOT(onMouseMoved(QMouseEvent*)));
94   connect(myWorkshop->viewer(), SIGNAL(keyRelease(QKeyEvent*)),
95           this, SLOT(onKeyRelease(QKeyEvent*)));
96   connect(myWorkshop->viewer(), SIGNAL(mouseDoubleClick(QMouseEvent*)),
97           this, SLOT(onMouseDoubleClick(QMouseEvent*)));
98 }
99
100 PartSet_Module::~PartSet_Module()
101 {
102 }
103
104 XGUI_Workshop* PartSet_Module::workshop() const
105 {
106   return myWorkshop;
107 }
108
109 void PartSet_Module::createFeatures()
110 {
111   //!! Test registering of validators
112   PluginManagerPtr aMgr = ModelAPI_PluginManager::get();
113   ModelAPI_ValidatorsFactory* aFactory = aMgr->validators();
114   aFactory->registerValidator("PartSet_DistanceValidator", new PartSet_DistanceValidator);
115   aFactory->registerValidator("PartSet_LengthValidator", new PartSet_LengthValidator);
116   aFactory->registerValidator("PartSet_PerpendicularValidator", new PartSet_PerpendicularValidator);
117   aFactory->registerValidator("PartSet_ParallelValidator", new PartSet_ParallelValidator);
118   aFactory->registerValidator("PartSet_RadiusValidator", new PartSet_RadiusValidator);
119
120   Config_ModuleReader aXMLReader = Config_ModuleReader();
121   aXMLReader.readAll();
122   myFeaturesInFiles = aXMLReader.featuresInFiles();
123 }
124
125 void PartSet_Module::featureCreated(QAction* theFeature)
126 {
127   connect(theFeature, SIGNAL(triggered(bool)), this, SLOT(onFeatureTriggered()));
128 }
129
130 QStringList PartSet_Module::nestedFeatures(QString)
131 {
132   return QStringList();
133 }
134
135 std::string PartSet_Module::featureFile(const std::string& theFeatureId)
136 {
137   return myFeaturesInFiles[theFeatureId];
138 }
139
140 /*
141  *
142  */
143 void PartSet_Module::onFeatureTriggered()
144 {
145   //PartSet_TestOCC::local_selection_change_shape(myWorkshop->viewer()->AISContext(),
146   //                                   myWorkshop->viewer()->activeView());
147
148   //PartSet_TestOCC::local_selection_erase(myWorkshop->viewer()->AISContext(),
149   //                                       myWorkshop->viewer()->activeView());
150   QAction* aCmd = dynamic_cast<QAction*>(sender());
151   //Do nothing on uncheck
152   if(aCmd->isCheckable() && !aCmd->isChecked())
153     return;
154   launchOperation(aCmd->data().toString());
155 }
156   
157 void PartSet_Module::launchOperation(const QString& theCmdId)
158 {
159   ModuleBase_Operation* anOperation = createOperation(theCmdId.toStdString());
160   PartSet_OperationSketchBase* aPreviewOp = dynamic_cast<PartSet_OperationSketchBase*>(anOperation);
161   if (aPreviewOp) {
162     XGUI_Selection* aSelection = myWorkshop->selector()->selection();
163     // Initialise operation with preliminary selection
164     std::list<ModuleBase_ViewerPrs> aSelected = aSelection->getSelected();
165     std::list<ModuleBase_ViewerPrs> aHighlighted = aSelection->getHighlighted();
166     aPreviewOp->initSelection(aSelected, aHighlighted);
167   } 
168   sendOperation(anOperation);
169 }
170
171 void PartSet_Module::onOperationStarted()
172 {
173   PartSet_OperationSketchBase* aPreviewOp = dynamic_cast<PartSet_OperationSketchBase*>(
174                                        myWorkshop->operationMgr()->currentOperation());
175   if (aPreviewOp) {
176     XGUI_PropertyPanel* aPropPanel = myWorkshop->propertyPanel();
177     connect(aPropPanel, SIGNAL(storedPoint2D(ObjectPtr, const std::string&)),
178       this, SLOT(onStorePoint2D(ObjectPtr, const std::string&)), Qt::UniqueConnection);
179   }
180 }
181
182 void PartSet_Module::onOperationStopped(ModuleBase_Operation* theOperation)
183 {
184   if (!theOperation)
185     return;
186   PartSet_OperationSketchBase* aPreviewOp = dynamic_cast<PartSet_OperationSketchBase*>(theOperation);
187   if (aPreviewOp) {
188     XGUI_PropertyPanel* aPropPanel = myWorkshop->propertyPanel();
189     //disconnect(aPropPanel, SIGNAL(storedPoint2D(ObjectPtr, const std::string&)),
190     //           this, SLOT(onStorePoint2D(ObjectPtr, const std::string&)));
191   } else {
192     // Activate results of current feature for selection
193     FeaturePtr aFeature = theOperation->feature();
194     XGUI_Displayer* aDisplayer = myWorkshop->displayer();
195     std::list<ResultPtr> aResults = aFeature->results();
196     std::list<ResultPtr>::const_iterator aIt;
197     for (aIt = aResults.cbegin(); aIt != aResults.cend(); ++aIt) {
198       aDisplayer->activate(*aIt);
199     }
200   }
201 }
202
203 void PartSet_Module::onContextMenuCommand(const QString& theId, bool isChecked)
204 {
205   QList<ObjectPtr> aFeatures = myWorkshop->selector()->selection()->selectedObjects();
206   if (theId == "EDIT_CMD" && (aFeatures.size() > 0)) {
207     FeaturePtr aFeature = boost::dynamic_pointer_cast<ModelAPI_Feature>(aFeatures.first());
208     if (aFeature)
209       editFeature(aFeature);
210   }
211 }
212
213 void PartSet_Module::onMousePressed(QMouseEvent* theEvent)
214 {
215   PartSet_OperationSketchBase* aPreviewOp = dynamic_cast<PartSet_OperationSketchBase*>(
216                                        myWorkshop->operationMgr()->currentOperation());
217   if (aPreviewOp) {
218     XGUI_Selection* aSelection = myWorkshop->selector()->selection();
219     // Initialise operation with preliminary selection
220     std::list<ModuleBase_ViewerPrs> aSelected = aSelection->getSelected();
221     std::list<ModuleBase_ViewerPrs> aHighlighted = aSelection->getHighlighted();
222
223     aPreviewOp->mousePressed(theEvent, myWorkshop->viewer()->activeView(), aSelected, aHighlighted);
224   }
225 }
226
227 void PartSet_Module::onMouseReleased(QMouseEvent* theEvent)
228 {
229   PartSet_OperationSketchBase* aPreviewOp = dynamic_cast<PartSet_OperationSketchBase*>(
230                                        myWorkshop->operationMgr()->currentOperation());
231   if (aPreviewOp) {
232     XGUI_Selection* aSelection = myWorkshop->selector()->selection();
233     // Initialise operation with preliminary selection
234     std::list<ModuleBase_ViewerPrs> aSelected = aSelection->getSelected();
235     std::list<ModuleBase_ViewerPrs> aHighlighted = aSelection->getHighlighted();
236
237     aPreviewOp->mouseReleased(theEvent, myWorkshop->viewer()->activeView(), aSelected, aHighlighted);
238   }
239 }
240
241 void PartSet_Module::onMouseMoved(QMouseEvent* theEvent)
242 {
243   PartSet_OperationSketchBase* aPreviewOp = dynamic_cast<PartSet_OperationSketchBase*>(
244                                        myWorkshop->operationMgr()->currentOperation());
245   if (aPreviewOp)
246     aPreviewOp->mouseMoved(theEvent, myWorkshop->viewer()->activeView());
247 }
248
249 void PartSet_Module::onKeyRelease(QKeyEvent* theEvent)
250 {
251   ModuleBase_Operation* anOperation = myWorkshop->operationMgr()->currentOperation();
252   PartSet_OperationSketchBase* aPreviewOp = dynamic_cast<PartSet_OperationSketchBase*>(anOperation);
253   if (aPreviewOp) {
254     aPreviewOp->keyReleased(theEvent->key());
255   }
256 }
257
258 void PartSet_Module::onMouseDoubleClick(QMouseEvent* theEvent)
259 {
260   PartSet_OperationSketchBase* aPreviewOp = dynamic_cast<PartSet_OperationSketchBase*>(
261                                        myWorkshop->operationMgr()->currentOperation());
262   if (aPreviewOp)
263   {
264     XGUI_Selection* aSelection = myWorkshop->selector()->selection();
265     // Initialise operation with preliminary selection
266     std::list<ModuleBase_ViewerPrs> aSelected = aSelection->getSelected();
267     std::list<ModuleBase_ViewerPrs> aHighlighted = aSelection->getHighlighted();
268     aPreviewOp->mouseDoubleClick(theEvent, myWorkshop->viewer()->activeView(), aSelected,
269                                  aHighlighted);
270   }
271 }
272
273 void PartSet_Module::onPlaneSelected(double theX, double theY, double theZ)
274 {
275   //erasePlanes();
276   myWorkshop->viewer()->setViewProjection(theX, theY, theZ);
277   myWorkshop->actionsMgr()->update();
278
279   //PartSet_TestOCC::testSelection(myWorkshop);
280 }
281
282 void PartSet_Module::onFitAllView()
283 {
284   myWorkshop->viewer()->fitAll();
285 }
286
287 void PartSet_Module::onLaunchOperation(std::string theName, ObjectPtr theObject)
288 {
289   FeaturePtr aFeature = ModuleBase_Tools::feature(theObject);
290   if (!aFeature) {
291     qDebug("Warning! Restart operation without feature!");
292     return;
293   }
294   ModuleBase_Operation* anOperation = createOperation(theName.c_str(),
295                                                       aFeature ? aFeature->getKind() : "");
296   PartSet_OperationSketchBase* aPreviewOp = dynamic_cast<PartSet_OperationSketchBase*>(anOperation);
297   if (aPreviewOp) {
298     XGUI_Selection* aSelection = myWorkshop->selector()->selection();
299     // Initialise operation with preliminary selection
300     std::list<ModuleBase_ViewerPrs> aSelected = aSelection->getSelected();
301     std::list<ModuleBase_ViewerPrs> aHighlighted = aSelection->getHighlighted();
302     aPreviewOp->initFeature(aFeature);
303     aPreviewOp->initSelection(aSelected, aHighlighted);
304   } else {
305     anOperation->setEditingFeature(aFeature);
306     //Deactivate result of current feature in order to avoid its selection
307     XGUI_Displayer* aDisplayer = myWorkshop->displayer();
308     std::list<ResultPtr> aResults = aFeature->results();
309     std::list<ResultPtr>::const_iterator aIt;
310     for (aIt = aResults.cbegin(); aIt != aResults.cend(); ++aIt) {
311       aDisplayer->deactivate(*aIt);
312     }
313   }
314   sendOperation(anOperation);
315   myWorkshop->actionsMgr()->updateCheckState();
316 }
317
318 void PartSet_Module::onMultiSelectionEnabled(bool theEnabled)
319 {
320   XGUI_ViewerProxy* aViewer = myWorkshop->viewer();
321   aViewer->enableMultiselection(theEnabled);
322 }
323
324 void PartSet_Module::onStopSelection(const QList<ObjectPtr>& theFeatures, const bool isStop)
325 {
326   XGUI_Displayer* aDisplayer = myWorkshop->displayer();
327   if (!isStop) {
328     foreach(ObjectPtr aObject, theFeatures) {
329       activateFeature(aObject, false);
330     }
331   }
332   aDisplayer->stopSelection(theFeatures, isStop, false);
333
334   XGUI_ViewerProxy* aViewer = myWorkshop->viewer();
335   aViewer->enableSelection(!isStop);
336
337   aDisplayer->updateViewer();
338 }
339
340 void PartSet_Module::onSetSelection(const QList<ObjectPtr>& theFeatures)
341 {
342   XGUI_Displayer* aDisplayer = myWorkshop->displayer();
343   aDisplayer->setSelected(theFeatures, false);
344   aDisplayer->updateViewer();
345 }
346
347 void PartSet_Module::onCloseLocalContext()
348 {
349   XGUI_Displayer* aDisplayer = myWorkshop->displayer();
350   aDisplayer->closeLocalContexts();
351 }
352
353 void PartSet_Module::onFeatureConstructed(ObjectPtr theFeature, int theMode)
354 {
355   bool isDisplay = theMode != PartSet_OperationSketchBase::FM_Hide;
356   ModuleBase_Operation* aCurOperation = myWorkshop->operationMgr()->currentOperation();
357   PartSet_OperationSketchBase* aPrevOp = dynamic_cast<PartSet_OperationSketchBase*>(aCurOperation);
358   if (aPrevOp) {
359     std::list<FeaturePtr> aList = aPrevOp->subFeatures();
360     XGUI_Displayer* aDisplayer = myWorkshop->displayer();
361     std::list<int> aModes = aPrevOp->getSelectionModes(aPrevOp->feature());
362     std::list<FeaturePtr>::iterator aSFIt; 
363     for (aSFIt = aList.begin(); aSFIt != aList.end(); ++aSFIt) {
364       std::list<ResultPtr> aResults = (*aSFIt)->results();
365       std::list<ResultPtr>::iterator aIt;
366       for (aIt = aResults.begin(); aIt != aResults.end(); ++aIt) {
367         if (isDisplay)
368           aDisplayer->activateInLocalContext((*aIt), aModes, false);
369         else
370           aDisplayer->erase((*aIt), false);
371       }
372       if (!isDisplay)
373         aDisplayer->erase((*aSFIt), false);
374     }
375   }
376   if (isDisplay)
377     ModelAPI_EventCreator::get()->sendUpdated(theFeature, 
378         Events_Loop::loop()->eventByName(EVENT_OBJECT_TO_REDISPLAY));
379 /*  bool isDisplay = theMode != PartSet_OperationSketchBase::FM_Hide;
380   // TODO visualizePreview(theFeature, isDisplay, false);
381   if (!isDisplay) {
382     ModuleBase_Operation* aCurOperation = myWorkshop->operationMgr()->currentOperation();
383     FeaturePtr aSketch;
384     PartSet_OperationSketchBase* aPrevOp = dynamic_cast<PartSet_OperationSketchBase*>(aCurOperation);
385     if (aPrevOp) {
386       std::list<FeaturePtr> aList = aPrevOp->subFeatures();
387       XGUI_Displayer* aDisplayer = myWorkshop->displayer();
388       std::list<int> aModes = aPrevOp->getSelectionModes(aPrevOp->feature());
389
390       std::list<FeaturePtr>::const_iterator anIt = aList.begin(),
391                                             aLast = aList.end();
392       //TODO for (; anIt != aLast; anIt++)
393       //  visualizePreview((*anIt), false, false);
394       //aDisplayer->updateViewer();
395     }
396   }
397
398   if (theMode == PartSet_OperationSketchBase::FM_Activation ||
399       theMode == PartSet_OperationSketchBase::FM_Deactivation)
400     activateFeature(theFeature, true);*/
401 }
402
403 ModuleBase_Operation* PartSet_Module::createOperation(const std::string& theCmdId,
404                                                       const std::string& theFeatureKind)
405 {
406   // create the operation
407   ModuleBase_Operation* anOperation = 0;
408   if (theCmdId == PartSet_OperationSketch::Type()) {
409     anOperation = new PartSet_OperationSketch(theCmdId.c_str(), this);
410   }
411   else {
412     ModuleBase_Operation* aCurOperation = myWorkshop->operationMgr()->currentOperation();
413     FeaturePtr aSketch;
414     PartSet_OperationSketchBase* aPrevOp = dynamic_cast<PartSet_OperationSketchBase*>(aCurOperation);
415     if (aPrevOp)
416       aSketch = aPrevOp->sketch();
417     if (PartSet_OperationFeatureCreate::canProcessKind(theCmdId))
418       anOperation = new PartSet_OperationFeatureCreate(theCmdId.c_str(), this, aSketch);
419     else if (theCmdId == PartSet_OperationFeatureEditMulti::Type())
420                 anOperation = new PartSet_OperationFeatureEditMulti(theCmdId.c_str(), this, aSketch);
421     else if (theCmdId == PartSet_OperationFeatureEdit::Type())
422       anOperation = new PartSet_OperationFeatureEdit(theCmdId.c_str(), this, aSketch);
423   }
424
425   if (!anOperation) {
426     anOperation = new ModuleBase_Operation(theCmdId.c_str(), this);
427   }
428
429   // set operation description and list of widgets corresponding to the feature xml definition
430   std::string aFeatureKind = theFeatureKind.empty() ? theCmdId : theFeatureKind;
431
432   std::string aPluginFileName = featureFile(aFeatureKind);
433   Config_WidgetReader aWdgReader = Config_WidgetReader(aPluginFileName);
434   aWdgReader.readAll();
435   std::string aXmlCfg = aWdgReader.featureWidgetCfg(aFeatureKind);
436   std::string aDescription = aWdgReader.featureDescription(aFeatureKind);
437
438   //QString aXmlRepr = QString::fromStdString(aXmlCfg);
439   //ModuleBase_WidgetFactory aFactory = ModuleBase_WidgetFactory(aXmlRepr.toStdString(),
440   //                                                             myWorkshop->moduleConnector());
441   //QWidget* aContent = myWorkshop->propertyPanel()->contentWidget();
442   //qDeleteAll(aContent->children());
443   //aFactory.createWidget(aContent);
444
445   anOperation->getDescription()->setDescription(QString::fromStdString(aDescription));
446   anOperation->getDescription()->setXmlRepresentation(QString::fromStdString(aXmlCfg));
447
448   //anOperation->setModelWidgets(aXmlRepr.toStdString(), aFactory.getModelWidgets());
449
450   // connect the operation
451   PartSet_OperationSketchBase* aPreviewOp = dynamic_cast<PartSet_OperationSketchBase*>(anOperation);
452   if (aPreviewOp) {
453     connect(aPreviewOp, SIGNAL(featureConstructed(ObjectPtr, int)),
454             this, SLOT(onFeatureConstructed(ObjectPtr, int)));
455     connect(aPreviewOp, SIGNAL(launchOperation(std::string, ObjectPtr)),
456             this, SLOT(onLaunchOperation(std::string, ObjectPtr)));
457     connect(aPreviewOp, SIGNAL(multiSelectionEnabled(bool)),
458             this, SLOT(onMultiSelectionEnabled(bool)));
459
460     connect(aPreviewOp, SIGNAL(stopSelection(const QList<ObjectPtr>&, const bool)),
461             this, SLOT(onStopSelection(const QList<ObjectPtr>&, const bool)));
462     connect(aPreviewOp, SIGNAL(setSelection(const QList<ObjectPtr>&)),
463             this, SLOT(onSetSelection(const QList<ObjectPtr>&)));
464
465      connect(aPreviewOp, SIGNAL(closeLocalContext()),
466              this, SLOT(onCloseLocalContext()));
467
468     PartSet_OperationSketch* aSketchOp = dynamic_cast<PartSet_OperationSketch*>(aPreviewOp);
469     if (aSketchOp) {
470       connect(aSketchOp, SIGNAL(planeSelected(double, double, double)),
471               this, SLOT(onPlaneSelected(double, double, double)));
472       connect(aSketchOp, SIGNAL(fitAllView()),
473               this, SLOT(onFitAllView()));
474     }
475   }
476
477   return anOperation;
478 }
479
480 void PartSet_Module::sendOperation(ModuleBase_Operation* theOperation)
481 {
482   static Events_ID aModuleEvent = Events_Loop::eventByName(EVENT_OPERATION_LAUNCHED);
483   Config_PointerMessage aMessage(aModuleEvent, this);
484   aMessage.setPointer(theOperation);
485   Events_Loop::loop()->send(aMessage);
486 }
487
488
489 /*void PartSet_Module::visualizePreview(FeaturePtr theFeature, bool isDisplay,
490                                       const bool isUpdateViewer)
491 {
492   ModuleBase_Operation* anOperation = myWorkshop->operationMgr()->currentOperation();
493   if (!anOperation)
494     return;
495
496   PartSet_OperationSketchBase* aPreviewOp = dynamic_cast<PartSet_OperationSketchBase*>(anOperation);
497   if (!aPreviewOp)
498     return;
499
500   ResultPtr aResult = theFeature->firstResult();
501   XGUI_Displayer* aDisplayer = myWorkshop->displayer();
502   if (isDisplay) {
503     boost::shared_ptr<SketchPlugin_Feature> aSPFeature = 
504       boost::dynamic_pointer_cast<SketchPlugin_Feature>(theFeature);
505     if (aSPFeature) {
506       PartSet_OperationSketch* aSketchOp = dynamic_cast<PartSet_OperationSketch*>(aPreviewOp);
507       if (aSketchOp && !aSketchOp->hasSketchPlane())
508         showPlanes();
509     }
510   }
511   else
512     aDisplayer->erase(aResult, false);
513
514   if (isUpdateViewer)
515     aDisplayer->updateViewer();
516 }*/
517
518 void PartSet_Module::activateFeature(ObjectPtr theFeature, const bool isUpdateViewer)
519 {
520   ModuleBase_Operation* anOperation = myWorkshop->operationMgr()->currentOperation();
521   PartSet_OperationSketchBase* aPreviewOp = dynamic_cast<PartSet_OperationSketchBase*>(anOperation);
522   if (aPreviewOp) {
523     XGUI_Displayer* aDisplayer = myWorkshop->displayer();
524     std::list<int> aModes = aPreviewOp->getSelectionModes(theFeature);
525     aDisplayer->activateInLocalContext(theFeature, aModes, isUpdateViewer);
526   }
527 }
528
529 void PartSet_Module::updateCurrentPreview(const std::string& theCmdId)
530 {
531   ModuleBase_Operation* anOperation = myWorkshop->operationMgr()->currentOperation();
532   if (!anOperation)
533     return;
534
535   PartSet_OperationSketchBase* aPreviewOp = dynamic_cast<PartSet_OperationSketchBase*>(anOperation);
536   if (!aPreviewOp)
537     return;
538
539   FeaturePtr aFeature = aPreviewOp->feature();
540   if (!aFeature || aFeature->getKind() != theCmdId)
541     return;
542
543   XGUI_Displayer* aDisplayer = myWorkshop->displayer();
544   // Hide result of sketch
545   std::list<ResultPtr> aResults = aFeature->results();
546   std::list<ResultPtr>::const_iterator aIt;
547   for (aIt = aResults.cbegin(); aIt != aResults.cend(); ++aIt)
548     aDisplayer->erase(*aIt, false);
549
550   std::list<FeaturePtr> aList = aPreviewOp->subFeatures();
551   std::list<int> aModes = aPreviewOp->getSelectionModes(aPreviewOp->feature());
552
553   std::list<FeaturePtr>::const_iterator anIt = aList.begin(), 
554                                         aLast = aList.end();
555   for (; anIt != aLast; anIt++) {
556     boost::shared_ptr<SketchPlugin_Feature> aSPFeature = 
557       boost::dynamic_pointer_cast<SketchPlugin_Feature>(*anIt);
558     if (!aSPFeature)
559       continue;
560     std::list<ResultPtr> aResults = aSPFeature->results();
561     std::list<ResultPtr>::const_iterator aRIt;
562     for (aRIt = aResults.cbegin(); aRIt != aResults.cend(); ++aRIt) {
563       aDisplayer->display((*aRIt), false);
564       aDisplayer->activateInLocalContext((*aRIt), aModes, false);
565     }
566     aDisplayer->display(aSPFeature, false);
567     aDisplayer->activateInLocalContext(aSPFeature, aModes, false);
568   }
569   aDisplayer->updateViewer();
570 }
571
572 void PartSet_Module::editFeature(FeaturePtr theFeature)
573 {
574   if (!theFeature)
575     return;
576
577 //  if (theFeature->getKind() == SKETCH_KIND) {
578     //FeaturePtr aFeature = theFeature;
579     //if (XGUI_Tools::isModelObject(aFeature)) {
580     //  ObjectPtr aObject = boost::dynamic_pointer_cast<ModelAPI_Object>(aFeature);
581     //  aFeature = aObject->featureRef();
582     //}
583
584     //if (aFeature) {
585       onLaunchOperation(theFeature->getKind(), theFeature);
586       updateCurrentPreview(theFeature->getKind());
587     //}
588 //  }
589 }
590
591 void PartSet_Module::onStorePoint2D(ObjectPtr theFeature, const std::string& theAttribute)
592 {
593   FeaturePtr aFeature = boost::dynamic_pointer_cast<ModelAPI_Feature>(theFeature);
594
595   PartSet_OperationSketchBase* aPreviewOp = dynamic_cast<PartSet_OperationSketchBase*>(
596                                        myWorkshop->operationMgr()->currentOperation());
597   if (!aPreviewOp)
598     return;
599
600   boost::shared_ptr<GeomDataAPI_Point2D> aPoint =
601         boost::dynamic_pointer_cast<GeomDataAPI_Point2D>(aFeature->data()->attribute(theAttribute));
602
603   PartSet_Tools::setConstraints(aPreviewOp->sketch(), aFeature, theAttribute,
604                                 aPoint->x(), aPoint->y());
605 }
606
607 /*bool PartSet_Module::isFeatureEnabled(const QString& theCmdId) const
608 {
609   XGUI_OperationMgr* aOpMgr = myWorkshop->operationMgr();
610   XGUI_ActionsMgr* aActMgr = myWorkshop->actionsMgr();
611
612   ModuleBase_Operation* aOperation = aOpMgr->currentOperation();
613   if (!aOperation)
614     return !aActMgr->isNested(theCmdId);
615
616   PartSet_OperationFeatureEdit* aSketchEdtOp = dynamic_cast<PartSet_OperationFeatureEdit*>(aOperation);
617   if (aSketchEdtOp) {
618     QStringList aConstraintList;
619     aConstraintList<<"SketchConstraintDistance"<<"SketchConstraintLength"
620       <<"SketchConstraintRadius"<<"SketchConstraintParallel"<<"SketchConstraintPerpendicular";
621     return aConstraintList.contains(theCmdId);
622   }
623   QStringList aList = aActMgr->nestedCommands(aOperation->id());
624   return aList.contains(theCmdId);
625 }*/
626
627 QWidget* PartSet_Module::createWidgetByType(const std::string& theType, QWidget* theParent, 
628                          Config_WidgetAPI* theWidgetApi, QList<ModuleBase_ModelWidget*>& theModelWidgets)
629 {
630   if (theType == "sketch-start-label") {
631     PartSet_WidgetSketchLabel* aWgt = new PartSet_WidgetSketchLabel(theParent, theWidgetApi, "");
632     aWgt->setOperationsMgr(myWorkshop->operationMgr());
633     theModelWidgets.append(aWgt);
634     return aWgt->getControl();
635   } else
636     return 0;
637 }