]> SALOME platform Git repositories - modules/shaper.git/blob - src/PartSet/PartSet_OperationFeatureEditMulti.cpp
Salome HOME
Merge branch 'master' of newgeom:newgeom.git
[modules/shaper.git] / src / PartSet / PartSet_OperationFeatureEditMulti.cpp
1 // File:        PartSet_OperationFeatureEditMulti.h
2 // Created:     05 May 2014
3 // Author:      Natalia ERMOLAEVA
4
5 #include <PartSet_OperationFeatureEditMulti.h>
6 #include <PartSet_Tools.h>
7 #include <PartSet_OperationSketch.h>
8
9 #include <ModuleBase_OperationDescription.h>
10 #include <ModuleBase_ViewerPrs.h>
11
12 #include <ModelAPI_Events.h>
13
14 #include <SketchPlugin_Feature.h>
15 #include <GeomDataAPI_Point2D.h>
16 #include <ModelAPI_Data.h>
17 #include <ModelAPI_Document.h>
18
19 #include <ModelAPI_Events.h>
20
21 #include <Events_Loop.h>
22
23 #include <SketchPlugin_Line.h>
24
25 #include <V3d_View.hxx>
26
27 #ifdef _DEBUG
28 #include <QDebug>
29 #endif
30
31 #include <QMouseEvent>
32
33 using namespace std;
34
35 PartSet_OperationFeatureEditMulti::PartSet_OperationFeatureEditMulti(const QString& theId,
36                                                   QObject* theParent,
37                                               FeaturePtr theFeature)
38 : PartSet_OperationSketchBase(theId, theParent), mySketch(theFeature), myIsBlockedSelection(false)
39 {
40 }
41
42 PartSet_OperationFeatureEditMulti::~PartSet_OperationFeatureEditMulti()
43 {
44 }
45
46 bool PartSet_OperationFeatureEditMulti::isGranted(ModuleBase_IOperation* theOperation) const
47 {
48   return theOperation->getDescription()->operationId().toStdString() == PartSet_OperationSketch::Type();
49 }
50
51 void PartSet_OperationFeatureEditMulti::initSelection(const std::list<ModuleBase_ViewerPrs>& theSelected,
52                                                       const std::list<ModuleBase_ViewerPrs>& theHighlighted)
53 {
54   if (!theHighlighted.empty()) {
55     // if there is highlighted object, we check whether it is in the list of selected objects
56     // in that case this object is a handle of the moved lines. If there no such object in the selection,
57     // the hightlighted object should moved and the selection is skipped. The skipped selection will be
58     // deselected in the viewer by blockSelection signal in the startOperation method.
59     bool isSelected = false;
60     std::list<ModuleBase_ViewerPrs>::const_iterator anIt = theSelected.begin(), aLast = theSelected.end();
61     for (; anIt != aLast && !isSelected; anIt++) {
62       isSelected = ModelAPI_Feature::feature((*anIt).object()) == feature();
63     }
64     if (!isSelected)
65       myFeatures = theHighlighted;
66     else
67       myFeatures = theSelected;
68   }
69   else
70     myFeatures = theSelected;
71 }
72
73 void PartSet_OperationFeatureEditMulti::initFeature(FeaturePtr theFeature)
74 {
75   setEditingFeature(theFeature);
76 }
77
78 FeaturePtr PartSet_OperationFeatureEditMulti::sketch() const
79 {
80   return mySketch;
81 }
82
83 void PartSet_OperationFeatureEditMulti::mousePressed(QMouseEvent* theEvent, Handle(V3d_View) theView,
84                                              const std::list<ModuleBase_ViewerPrs>& /*theSelected*/,
85                                              const std::list<ModuleBase_ViewerPrs>& theHighlighted)
86 {
87 }
88
89 void PartSet_OperationFeatureEditMulti::mouseMoved(QMouseEvent* theEvent, Handle(V3d_View) theView)
90 {
91   if (!(theEvent->buttons() &  Qt::LeftButton))
92     return;
93
94   gp_Pnt aPoint = PartSet_Tools::convertClickToPoint(theEvent->pos(), theView);
95
96   blockSelection(true);
97   if (myCurPoint.myIsInitialized) {
98     double aCurX, aCurY;
99     PartSet_Tools::convertTo2D(myCurPoint.myPoint, sketch(), theView, aCurX, aCurY);
100
101     double aX, anY;
102     PartSet_Tools::convertTo2D(aPoint, sketch(), theView, aX, anY);
103
104     double aDeltaX = aX - aCurX;
105     double aDeltaY = anY - aCurY;
106
107     boost::shared_ptr<SketchPlugin_Feature> aSketchFeature = 
108                            boost::dynamic_pointer_cast<SketchPlugin_Feature>(feature());
109     aSketchFeature->move(aDeltaX, aDeltaY);
110
111     std::list<ModuleBase_ViewerPrs>::const_iterator anIt = myFeatures.begin(), aLast = myFeatures.end();
112     for (; anIt != aLast; anIt++) {
113       ObjectPtr aObject = (*anIt).object();
114       if (!aObject || aObject == feature())
115         continue;
116       FeaturePtr aFeature = ModelAPI_Feature::feature(aObject);
117       if (aFeature) {
118         aSketchFeature = boost::dynamic_pointer_cast<SketchPlugin_Feature>(aFeature);
119         if (aSketchFeature)
120           aSketchFeature->move(aDeltaX, aDeltaY);
121       }
122     }
123   }
124   sendFeatures();
125
126   myCurPoint.setPoint(aPoint);
127 }
128
129 void PartSet_OperationFeatureEditMulti::mouseReleased(QMouseEvent* theEvent, Handle(V3d_View) theView,
130                                               const std::list<ModuleBase_ViewerPrs>& /*theSelected*/,
131                                               const std::list<ModuleBase_ViewerPrs>& /*theHighlighted*/)
132 {
133   if (commit()) {
134     std::list<ModuleBase_ViewerPrs> aFeatures = myFeatures;
135     std::list<ModuleBase_ViewerPrs>::const_iterator anIt = aFeatures.begin(), aLast = aFeatures.end();
136     for (; anIt != aLast; anIt++) {
137       ObjectPtr aFeature = (*anIt).object();
138       if (aFeature) {
139         emit featureConstructed(aFeature, FM_Deactivation);
140             }
141     }
142   }
143 }
144
145 void PartSet_OperationFeatureEditMulti::startOperation()
146 {
147   PartSet_OperationSketchBase::startOperation();
148   emit multiSelectionEnabled(false);
149
150   blockSelection(true);
151
152   myCurPoint.clear();
153 }
154
155 void PartSet_OperationFeatureEditMulti::stopOperation()
156 {
157   emit multiSelectionEnabled(true);
158
159   blockSelection(false, true);
160
161   myFeatures.clear();
162 }
163
164 void PartSet_OperationFeatureEditMulti::blockSelection(bool isBlocked, const bool isRestoreSelection)
165 {
166   if (myIsBlockedSelection == isBlocked)
167     return;
168
169   myIsBlockedSelection = isBlocked;
170   QList<ObjectPtr> aFeatureList;
171   std::list<ModuleBase_ViewerPrs>::const_iterator anIt = myFeatures.begin(),
172                                             aLast = myFeatures.end();
173   /*for(; anIt != aLast; anIt++)
174     aFeatureList.append((*anIt).feature());*/
175   if (isBlocked) {
176     emit setSelection(QList<ObjectPtr>());
177     emit stopSelection(aFeatureList, true);
178   }
179   else {
180     emit stopSelection(aFeatureList, false);
181     if (isRestoreSelection) {
182       emit setSelection(aFeatureList);
183     }
184   }
185 }
186
187 void PartSet_OperationFeatureEditMulti::sendFeatures()
188 {
189   static Events_ID anEvent = Events_Loop::eventByName(EVENT_OBJECT_MOVED);
190
191   std::list<FeaturePtr > aFeatures;
192   std::list<ModuleBase_ViewerPrs>::const_iterator anIt = myFeatures.begin(), aLast = myFeatures.end();
193   for (; anIt != aLast; anIt++) {
194     ObjectPtr aFeature = (*anIt).object();
195     if (!aFeature)
196       continue;
197
198     ModelAPI_EventCreator::get()->sendUpdated(aFeature, anEvent);
199   }
200   Events_Loop::loop()->flush(anEvent);
201   flushUpdated();
202 }
203