1 // Copyright (C) 2013 CEA/DEN, EDF R&D, OPEN CASCADE
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.
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.
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
17 // See http://www.salome-platform.org/ or email : webmaster.salome@opencascade.com
20 #include "CurveCreator_Profile.hxx"
22 #include "CurveCreator.hxx"
23 #include "CurveCreator_PosPoint.hxx"
24 #include "CurveCreator_Section.hxx"
25 #include "CurveCreator_Displayer.h"
27 #include <BRepBuilderAPI_MakeEdge.hxx>
28 #include <BRepBuilderAPI_MakeWire.hxx>
29 #include <Geom_CartesianPoint.hxx>
32 #include <TopoDS_Edge.hxx>
33 #include <TopoDS_Face.hxx>
34 #include <TopoDS_Wire.hxx>
35 #include <TColgp_HArray1OfPnt.hxx>
36 #include <GeomAPI_Interpolate.hxx>
40 CurveCreator_Profile::CurveCreator_Profile()
41 : CurveCreator_Curve( CurveCreator::Dim2d )
43 CurveCreator_Section *aSection = new CurveCreator_Section;
44 aSection->myName = getUniqSectionName();
45 aSection->myType = CurveCreator::Polyline;
46 aSection->myIsClosed = false;
48 mySections.push_back( aSection );
51 CurveCreator_Profile::~CurveCreator_Profile()
55 bool CurveCreator_Profile::moveSectionInternal( const int theISection,
56 const int theNewIndex )
61 bool CurveCreator_Profile::moveSection( const int theISection,
62 const int theNewIndex )
67 bool CurveCreator_Profile::clearInternal()
69 // erase curve from the viewer
71 myDisplayer->eraseAll( true );
73 // Delete all allocated data.
74 CurveCreator_Section* aSection = getSection( 0 );
76 aSection->myPoints.clear();
81 bool CurveCreator_Profile::joinInternal( const std::list<int>& theSections )
86 bool CurveCreator_Profile::join( const std::list<int>& theSections )
91 int CurveCreator_Profile::addSectionInternal( const std::string& theName,
92 const CurveCreator::SectionType theType,
93 const bool theIsClosed,
94 const CurveCreator::Coordinates& thePoints )
99 int CurveCreator_Profile::addSection( const std::string& theName,
100 const CurveCreator::SectionType theType,
101 const bool theIsClosed )
106 int CurveCreator_Profile::addSection( const std::string& theName,
107 const CurveCreator::SectionType theType,
108 const bool theIsClosed,
109 const CurveCreator::Coordinates& thePoints )
114 bool CurveCreator_Profile::removeSectionInternal( const int theISection )
119 bool CurveCreator_Profile::removeSection( const int theISection )
124 bool CurveCreator_Profile::setClosedInternal( const int theISection,
125 const bool theIsClosed )
130 bool CurveCreator_Profile::setClosed( const int theISection,
131 const bool theIsClosed )
136 bool CurveCreator_Profile::addPointsInternal( const CurveCreator::SectionsMap &theSectionsMap )
140 CurveCreator_Section* aSection = getSection( 0 );
144 CurveCreator::SectionsMap::const_iterator anIt = theSectionsMap.begin();
145 for ( ; anIt != theSectionsMap.end(); anIt++ )
147 int anISection = anIt->first;
148 if( anISection != 0 )
151 const CurveCreator::PosPointsList& aSectionPoints = anIt->second;
153 CurveCreator::PosPointsList::const_iterator aPntIt = aSectionPoints.begin();
154 for( ; aPntIt != aSectionPoints.end(); aPntIt++ )
156 const CurveCreator::Coordinates& aNewCoords = (*aPntIt)->myCoords;
157 CurveCreator::Coordinates::const_iterator aNewPntIt = aNewCoords.begin();
158 for( ; aNewPntIt != aNewCoords.end(); aNewPntIt++ )
160 const CurveCreator::TypeCoord& aCoordU = *aNewPntIt++;
161 if ( aNewPntIt == aNewCoords.end() )
164 const CurveCreator::TypeCoord& aCoordZ = *aNewPntIt;
166 CurveCreator::TypeCoord aC = aCoordU - 1;
167 if ( !aSection->myPoints.empty() )
168 aC = *(aSection->myPoints.end() - 2);
170 if ( aSection->myPoints.empty() || aCoordU >= aC )
172 aSection->myPoints.push_back( aCoordU );
173 aSection->myPoints.push_back( aCoordZ );
175 else if ( aCoordU < aSection->myPoints.front() )
177 aSection->myPoints.push_front( aCoordZ );
178 aSection->myPoints.push_front( aCoordU );
182 CurveCreator::Coordinates::iterator aRefPntIt = aSection->myPoints.begin();
183 for( ; aRefPntIt != aSection->myPoints.end(); aRefPntIt++ )
185 const CurveCreator::TypeCoord& aRefCoordU = *aRefPntIt++;
186 if ( aCoordU < aRefCoordU )
190 aSection->myPoints.insert( aRefPntIt - 1, aNewPntIt - 1, aNewPntIt + 1 );
204 //! For internal use only! Undo/Redo are not used here.
205 bool CurveCreator_Profile::setPointInternal( const CurveCreator::SectionsMap &theSectionsMap )
209 if ( mySkipSorting ) {
210 return CurveCreator_Curve::setPointInternal( theSectionsMap );
214 CurveCreator_Section* aSection = getSection( anISection );
218 CurveCreator::SectionsMap::const_iterator anIt = theSectionsMap.begin();
219 if ( anIt == theSectionsMap.end() )
222 const CurveCreator::PosPointsList& aSectionPoints = anIt->second;
224 std::list<int> aConvPoints;
225 convert( aSectionPoints, aConvPoints );
226 removeSectionPoints( anISection, aConvPoints );
228 aRes = addPointsInternal( theSectionsMap );
235 void CurveCreator_Profile::convert( const CurveCreator::PosPointsList& thePoints,
236 std::list<int>& theConvPoints )
238 theConvPoints.clear();
240 CurveCreator::PosPointsList::const_iterator aPntIt = thePoints.begin(),
241 aPntLast = thePoints.end();
242 for( ; aPntIt != aPntLast; aPntIt++ )
244 int anIPnt = (*aPntIt)->myID;
245 theConvPoints.push_back( anIPnt );
249 bool CurveCreator_Profile::canPointsBeSorted()
255 * Add one point to the specified section starting from the given theIPnt index
256 * (or at the end of points if \a theIPnt is -1).
258 bool CurveCreator_Profile::addPoints( const CurveCreator::Coordinates& theCoords,
259 const int theISection,
262 int anIPnt = theIPnt;
264 if ( anIPnt == - 1 && theCoords.size() > 1 ) {
265 CurveCreator::Coordinates aCoords;
266 for ( int i = 0, aNb = getNbPoints( theISection ); i < aNb; i++ ) {
267 aCoords = getPoint( theISection, i );
268 if ( aCoords.size() < 2 ) {
272 if ( theCoords[0] < aCoords[0] ) {
279 return CurveCreator_Curve::addPoints( theCoords, theISection, anIPnt );