Salome HOME
projects
/
modules
/
shaper.git
/ blobdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
tree
raw
|
inline
| side by side
#1330 Multiply selection when Create fillet using Shift button
[modules/shaper.git]
/
src
/
SketcherPrs
/
SketcherPrs_PositionMgr.cpp
diff --git
a/src/SketcherPrs/SketcherPrs_PositionMgr.cpp
b/src/SketcherPrs/SketcherPrs_PositionMgr.cpp
index 842eceba4c3ec96b3fb45f9128ed3fd5610cf454..1eb15216c24f051af4d2e9eed72d8857f84f9f5d 100644
(file)
--- a/
src/SketcherPrs/SketcherPrs_PositionMgr.cpp
+++ b/
src/SketcherPrs/SketcherPrs_PositionMgr.cpp
@@
-14,7
+14,7
@@
static SketcherPrs_PositionMgr* MyPosMgr = NULL;
static SketcherPrs_PositionMgr* MyPosMgr = NULL;
-
+// The class is implemented as a singlton
SketcherPrs_PositionMgr* SketcherPrs_PositionMgr::get()
{
if (MyPosMgr == NULL)
SketcherPrs_PositionMgr* SketcherPrs_PositionMgr::get()
{
if (MyPosMgr == NULL)
@@
-31,15
+31,19
@@
int SketcherPrs_PositionMgr::getPositionIndex(ObjectPtr theLine,
const SketcherPrs_SymbolPrs* thePrs)
{
if (myShapes.count(theLine) == 1) {
const SketcherPrs_SymbolPrs* thePrs)
{
if (myShapes.count(theLine) == 1) {
+ // Find the map and add new [Presentation - Index] pair
PositionsMap& aPosMap = myShapes[theLine];
if (aPosMap.count(thePrs) == 1) {
PositionsMap& aPosMap = myShapes[theLine];
if (aPosMap.count(thePrs) == 1) {
+ // return existing index
return aPosMap[thePrs];
} else {
return aPosMap[thePrs];
} else {
+ // Add a new [Presentation - Index] pair
int aInd = aPosMap.size();
aPosMap[thePrs] = aInd;
return aInd;
}
} else {
int aInd = aPosMap.size();
aPosMap[thePrs] = aInd;
return aInd;
}
} else {
+ // Create a new map with initial index
PositionsMap aPosMap;
aPosMap[thePrs] = 0;
myShapes[theLine] = aPosMap;
PositionsMap aPosMap;
aPosMap[thePrs] = 0;
myShapes[theLine] = aPosMap;
@@
-71,6
+75,7
@@
gp_Pnt SketcherPrs_PositionMgr::getPosition(ObjectPtr theShape,
(aPnt1->z() + aPnt2->z())/2.);
} else {
(aPnt1->z() + aPnt2->z())/2.);
} else {
+ // this is a circle or arc
double aMidParam = (aCurve->startParam() + aCurve->endParam()) / 2.;
std::shared_ptr<GeomAPI_Pnt> aPnt = aCurve->getPoint(aMidParam);
aP = aPnt->impl<gp_Pnt>();
double aMidParam = (aCurve->startParam() + aCurve->endParam()) / 2.;
std::shared_ptr<GeomAPI_Pnt> aPnt = aCurve->getPoint(aMidParam);
aP = aPnt->impl<gp_Pnt>();
@@
-88,10
+93,12
@@
gp_Pnt SketcherPrs_PositionMgr::getPosition(ObjectPtr theShape,
std::shared_ptr<GeomAPI_Dir> aDir = thePrs->plane()->dirX();
aVec1 = gp_Vec(aDir->impl<gp_Dir>());
}
std::shared_ptr<GeomAPI_Dir> aDir = thePrs->plane()->dirX();
aVec1 = gp_Vec(aDir->impl<gp_Dir>());
}
+ // Compute shifting vector for a one symbol
gp_Vec aShift = aVec1.Crossed(thePrs->plane()->normal()->impl<gp_Dir>());
aShift.Normalize();
aShift.Multiply(theStep * 0.8);
gp_Vec aShift = aVec1.Crossed(thePrs->plane()->normal()->impl<gp_Dir>());
aShift.Normalize();
aShift.Multiply(theStep * 0.8);
+ // Shift the position coordinate according to position index
int aPos = getPositionIndex(theShape, thePrs);
int aM = 1;
if ((aPos % 2) == 0) {
int aPos = getPositionIndex(theShape, thePrs);
int aM = 1;
if ((aPos % 2) == 0) {
@@
-126,12
+133,22
@@
void SketcherPrs_PositionMgr::deleteConstraint(const SketcherPrs_SymbolPrs* theP
{
std::map<ObjectPtr, PositionsMap>::iterator aIt;
std::list<ObjectPtr> aToDel;
{
std::map<ObjectPtr, PositionsMap>::iterator aIt;
std::list<ObjectPtr> aToDel;
+ // Clear map for deleted presentation
for (aIt = myShapes.begin(); aIt != myShapes.end(); ++aIt) {
PositionsMap& aPosMap = aIt->second;
if (aPosMap.count(thePrs) > 0) {
for (aIt = myShapes.begin(); aIt != myShapes.end(); ++aIt) {
PositionsMap& aPosMap = aIt->second;
if (aPosMap.count(thePrs) > 0) {
+ // Erase index
aPosMap.erase(aPosMap.find(thePrs));
if (aPosMap.size() == 0)
aPosMap.erase(aPosMap.find(thePrs));
if (aPosMap.size() == 0)
+ // Delete the map
aToDel.push_back(aIt->first);
aToDel.push_back(aIt->first);
+ else {
+ // Reindex objects positions in order to avoid spaces
+ PositionsMap::iterator aIt;
+ int i = 0;
+ for (aIt = aPosMap.begin(); aIt != aPosMap.end(); aIt++, i++)
+ aIt->second = i;
+ }
}
}
std::list<ObjectPtr>::const_iterator aListIt;
}
}
std::list<ObjectPtr>::const_iterator aListIt;