X-Git-Url: http://git.salome-platform.org/gitweb/?a=blobdiff_plain;f=src%2FHYDROCurveCreator%2FCurveCreator_Curve.cxx;h=f056b03426ae1b2c486c6de592bacf4d73193df8;hb=1f844eb06506171b54541cc0caf1a0c237fe0dbf;hp=83b4c68fc98176050c5a92a258b2ceed92c66f12;hpb=66eed78107ad562c2846807c99978fe5a212cca4;p=modules%2Fhydro.git diff --git a/src/HYDROCurveCreator/CurveCreator_Curve.cxx b/src/HYDROCurveCreator/CurveCreator_Curve.cxx index 83b4c68f..f056b034 100644 --- a/src/HYDROCurveCreator/CurveCreator_Curve.cxx +++ b/src/HYDROCurveCreator/CurveCreator_Curve.cxx @@ -24,7 +24,21 @@ #include "CurveCreator.hxx" #include "CurveCreator_Section.hxx" -#include "CurveCreator_Listener.hxx" +#include "CurveCreator_Displayer.h" + +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include #include @@ -35,7 +49,7 @@ CurveCreator_Curve::CurveCreator_Curve( const CurveCreator::Dimension theDimension ) : myIsLocked (false), myDimension (theDimension), - myListener(NULL), + myDisplayer (NULL), myNbUndos (0), myNbRedos (0), myUndoDepth (-1), @@ -84,21 +98,21 @@ std::string CurveCreator_Curve::getUniqSectionName() const } //======================================================================= -// function: setListener -// purpose: set curve changes listener +// function: setDisplayer +// purpose: set curve changes Displayer //======================================================================= -void CurveCreator_Curve::setListener( CurveCreator_Listener* theListener ) +void CurveCreator_Curve::setDisplayer( CurveCreator_Displayer* theDisplayer ) { - myListener = theListener; + myDisplayer = theDisplayer; } //======================================================================= -// function: removeListener -// purpose: remove the attached listener +// function: removeDisplayer +// purpose: remove the attached Displayer //======================================================================= -void CurveCreator_Curve::removeListener() +void CurveCreator_Curve::removeDisplayer() { - myListener = NULL; + myDisplayer = NULL; } //======================================================================= @@ -152,6 +166,81 @@ int CurveCreator_Curve::toICoord(const int theIPnt) const return theIPnt * myDimension; } +std::vector CurveCreator_Curve::constructSection( int theISection ) const +{ + std::vector aSectionRepresentation; + + CurveCreator::SectionType aSectType = getSectionType( theISection ); + int aSectSize = getNbPoints( theISection ); + bool aSectIsClosed = isClosed( theISection ); + + if( aSectType == CurveCreator::Polyline ) + { + int iPoint = 0; + for( ; iPoint < ( aSectSize - 1 ) ; iPoint++ ){ + Handle_AIS_Point anAISPnt = getAISPoint(theISection, iPoint); + aSectionRepresentation.push_back( anAISPnt ); + Handle_AIS_Line aLine = getAISLine( theISection, iPoint, iPoint+1 ); + aSectionRepresentation.push_back( aLine ); + } + if( aSectSize != 0 ){ + Handle_AIS_Point anAISPnt = getAISPoint(theISection, iPoint); + aSectionRepresentation.push_back( anAISPnt ); + if( isClosed(theISection) && ( aSectSize > 1 ) ){ + Handle_AIS_Line aLine = getAISLine( theISection, iPoint, 0 ); + aSectionRepresentation.push_back( aLine ); + } + } + } + else if( aSectType == CurveCreator::Spline ) + { + std::vector aPoints; + for( int iPoint = 0; iPoint < aSectSize; iPoint++ ) + { + Handle_AIS_Point anAISPnt = getAISPoint( theISection, iPoint ); + aSectionRepresentation.push_back( anAISPnt ); + + CurveCreator::Coordinates aCoords = getPoint( theISection, iPoint ); + double aX = aCoords[0]; + double aY = aCoords[1]; + double aZ = aCoords[2]; + aPoints.push_back( aX ); + aPoints.push_back( aY ); + } + + if( aSectSize > 1 ) + { + Handle(Geom_BSplineCurve) aBSplineCurve; + // fill array for algorithm by the received coordinates + int aLen = aPoints.size() / 2; + Handle(TColgp_HArray1OfPnt) aHCurvePoints = new TColgp_HArray1OfPnt (1, aLen); + std::vector::const_iterator aListIter = aPoints.begin(); + for (int ind = 1; ind <= aLen; ind++) { + gp_Pnt aPnt(gp::Origin()); + aPnt.SetX(*aListIter); + aListIter++; + aPnt.SetY(*aListIter); + aListIter++; + aPnt.SetZ(0); + aHCurvePoints->SetValue(ind, aPnt); + } + // compute BSpline + GeomAPI_Interpolate aGBC(aHCurvePoints, aSectIsClosed, gp::Resolution()); + aGBC.Perform(); + if (aGBC.IsDone()) { + aBSplineCurve = aGBC.Curve(); + } + TopoDS_Edge anEdge = BRepBuilderAPI_MakeEdge( aBSplineCurve ).Edge(); + + TopoDS_Wire aWire = BRepBuilderAPI_MakeWire( anEdge ).Wire(); + + Handle(AIS_Shape) aShape = new AIS_Shape( aWire ); + aSectionRepresentation.push_back( aShape ); + } + } + return aSectionRepresentation; +} + //======================================================================= // function: setUndoDepth // purpose: @@ -210,6 +299,96 @@ int CurveCreator_Curve::getUndoDepth() const return myUndoDepth; } +Handle_AIS_Point CurveCreator_Curve::getAISPoint( int theISection, int theIPoint ) const +{ + double anX, anY, aZ; + getCoordinates( theISection, theIPoint, anX, anY, aZ ); + gp_Pnt aPoint( anX, anY, aZ); + + AIS_Point* aPnt = new AIS_Point( new Geom_CartesianPoint(aPoint)); + return aPnt; +} + +Handle_AIS_Line CurveCreator_Curve::getAISLine( int theISection, int theIPoint1, int theIPoint2 ) const +{ + double anX, anY, aZ; + getCoordinates( theISection, theIPoint1, anX, anY, aZ ); + gp_Pnt aPoint1( anX, anY, aZ); + + double anX2, anY2, aZ2; + getCoordinates( theISection, theIPoint2, anX2, anY2, aZ2 ); +//MTN to avoid crash during line construction + if( ( anX == anX2 ) && ( anY == anY2 ) && (aZ == aZ2 ) ){ + aZ2 += 1e-7; + } + + gp_Pnt aPoint2( anX2, anY2, aZ2 ); + + AIS_Line* aLine = new AIS_Line( new Geom_CartesianPoint(aPoint1), new Geom_CartesianPoint(aPoint2) ); + return aLine; +} + +void CurveCreator_Curve::getCoordinates( int theISection, int theIPoint, double& theX, double& theY, double& theZ ) const +{ + CurveCreator::Coordinates aCoords = getPoint( theISection, theIPoint ); + theX = aCoords[0]; + theY = aCoords[1]; + theZ = 0.; + if( getDimension() == CurveCreator::Dim3d ){ + theZ = aCoords[2]; + } +} + +void CurveCreator_Curve::redisplayCurve() +{ + if( myDisplayer ) { + myDisplayer->erase(); + myDisplayer->display( constructWire() ); + } +} + +//! For internal use only! Undo/Redo are not used here. +bool CurveCreator_Curve::moveSectionInternal(const int theISection, + const int theNewIndex) +{ + bool res = false; + if (theISection != theNewIndex) { + CurveCreator_Section *aSection = mySections.at(theISection); + + // Remove section + CurveCreator::Sections::iterator anIter = mySections.begin() + theISection; + + mySections.erase(anIter); + + // Insert section. + anIter = mySections.begin() + theNewIndex; + mySections.insert(anIter, aSection); + res = true; + } + return res; +} + +//======================================================================= +// function: moveSection +// purpose: +//======================================================================= +bool CurveCreator_Curve::moveSection(const int theISection, + const int theNewIndex) +{ + bool res = false; + // Set the difference. + startOperation(); + if (addEmptyDiff()) { + myListDiffs.back().init(this, CurveCreator_Operation::MoveSection, + theISection, theNewIndex); + } + + // Update the curve. + res = moveSectionInternal(theISection, theNewIndex); + finishOperation(); + return res; +} + /************ Implementation of INTERFACE methods ************/ /***********************************************/ @@ -259,12 +438,12 @@ bool CurveCreator_Curve::redo() /***********************************************/ /*** Section methods ***/ /***********************************************/ -//======================================================================= -// function: clear -// purpose: -//======================================================================= -bool CurveCreator_Curve::clear() +//! For internal use only! Undo/Redo are not used here. +bool CurveCreator_Curve::clearInternal() { + // erase curve from the viewer + if( myDisplayer ) + myDisplayer->erase(); // Delete all allocated data. int i = 0; const int aNbSections = getNbSections(); @@ -274,36 +453,59 @@ bool CurveCreator_Curve::clear() } mySections.clear(); - if( myListener ) - myListener->curveChanged(); return true; } +//======================================================================= +// function: clear +// purpose: +//======================================================================= +bool CurveCreator_Curve::clear() +{ + bool res = false; + startOperation(); + // Set the difference. + if (addEmptyDiff()) { + myListDiffs.back().init(this, CurveCreator_Operation::Clear); + } + res = clearInternal(); + finishOperation(); + return res; +} + +//! For internal use only! Undo/Redo are not used here. +bool CurveCreator_Curve::joinInternal( const int theISectionTo, + const int theISectionFrom ) +{ + bool res = false; + CurveCreator_Section *aSection1 = mySections.at(theISectionTo); + CurveCreator_Section *aSection2 = mySections.at(theISectionFrom); + + aSection1->myPoints.insert(aSection1->myPoints.end(), + aSection2->myPoints.begin(), + aSection2->myPoints.end()); + + res = removeSection(theISectionFrom); + redisplayCurve(); + return res; +} + //! Join range of sections to one section (join all sections if -1 is passed in one of arguments) bool CurveCreator_Curve::join( const int theISectionTo, - const int theISectionFrom ) + const int theISectionFrom ) { + bool res = false; if (theISectionTo != theISectionFrom) { startOperation(); if (addEmptyDiff()) myListDiffs.back().init(this, CurveCreator_Operation::Join, theISectionTo, theISectionFrom); - CurveCreator_Section *aSection1 = mySections.at(theISectionTo); - CurveCreator_Section *aSection2 = mySections.at(theISectionFrom); - - aSection1->myPoints.insert(aSection1->myPoints.end(), - aSection2->myPoints.begin(), - aSection2->myPoints.end()); - - removeSection(theISectionFrom); - if( myListener ) - myListener->curveChanged(); + res = joinInternal( theISectionTo, theISectionFrom ); finishOperation(); - return true; } - return false; + return res; } //! Get number of sections @@ -312,6 +514,26 @@ int CurveCreator_Curve::getNbSections() const return mySections.size(); } +//! For internal use only! Undo/Redo are not used here. +int CurveCreator_Curve::addSectionInternal + (const std::string& theName, const CurveCreator::SectionType theType, + const bool theIsClosed, const CurveCreator::Coordinates &thePoints) +{ + CurveCreator_Section *aSection = new CurveCreator_Section; + + std::string aName = theName; + if( aName.empty() ){ + aName = getUniqSectionName(); + } + aSection->myName = aName; + aSection->myType = theType; + aSection->myIsClosed = theIsClosed; + aSection->myPoints = thePoints; + mySections.push_back(aSection); + redisplayCurve(); + return mySections.size()-1; +} + //======================================================================= // function: addSection // purpose: adds an empty section @@ -323,26 +545,16 @@ int CurveCreator_Curve::addSection int resISection = -1; // Set the difference. startOperation(); + CurveCreator::Coordinates aCoords; //empty list if (addEmptyDiff()) { - CurveCreator::Coordinates aCoords; //empty list myListDiffs.back().init(this, CurveCreator_Operation::AddSection, theName, aCoords, theType, theIsClosed); } - CurveCreator_Section *aSection = new CurveCreator_Section; - std::string aName = theName; - if( aName.empty() ){ - aName = getUniqSectionName(); - } - aSection->myName = aName; - aSection->myType = theType; - aSection->myIsClosed = theIsClosed; - mySections.push_back(aSection); - if( myListener ) - myListener->sectionAdded( -1 ); + resISection = addSectionInternal(theName, theType, theIsClosed, aCoords); finishOperation(); - return mySections.size()-1; + return resISection; } //======================================================================= // function: addSection @@ -353,33 +565,22 @@ int CurveCreator_Curve::addSection const bool theIsClosed, const CurveCreator::Coordinates &thePoints) { int resISection = -1; - //// Set the difference. - //startOperation(); - //if (addEmptyDiff()) { - // myListDiffs.back().init(this, CurveCreator_Operation::AddSection, - // theName, thePoints, theType, theIsClosed); - //} - - // create an empty section - resISection = addSection(theName, theType, theIsClosed); - if( resISection != -1 ) { - // attach the given points to created section - CurveCreator_Section *aSection = mySections.at(resISection); - aSection->myPoints = thePoints; + // Set the difference. + startOperation(); + if (addEmptyDiff()) { + myListDiffs.back().init(this, CurveCreator_Operation::AddSection, + theName, thePoints, theType, theIsClosed); } - - //finishOperation(); + + resISection = addSectionInternal(theName, theType, theIsClosed, thePoints); + + finishOperation(); return resISection; } -//! Removes the given sections. -bool CurveCreator_Curve::removeSection( const int theISection ) +//! For internal use only! Undo/Redo are not used here. +bool CurveCreator_Curve::removeSectionInternal( const int theISection ) { - // Set the difference. - startOperation(); - if (addEmptyDiff()) - myListDiffs.back().init(this, CurveCreator_Operation::RemoveSection, theISection); - if (theISection == -1) { delete mySections.back(); mySections.pop_back(); @@ -389,11 +590,23 @@ bool CurveCreator_Curve::removeSection( const int theISection ) delete *anIterRm; mySections.erase(anIterRm); } - if( myListener ) - myListener->sectionRemoved(theISection); + redisplayCurve(); + return true; +} + +//! Removes the given sections. +bool CurveCreator_Curve::removeSection( const int theISection ) +{ + bool res = false; + // Set the difference. + startOperation(); + if (addEmptyDiff()) + myListDiffs.back().init(this, CurveCreator_Operation::RemoveSection, theISection); + + res = removeSectionInternal( theISection ); finishOperation(); - return true; + return res; } /** @@ -424,12 +637,9 @@ bool CurveCreator_Curve::isClosed( const int theISection ) const return mySections.at(theISection)->myIsClosed; } -/** - * Set "closed" flag of the specified section (all sections if - * \a theISection is -1). - */ -bool CurveCreator_Curve::setClosed( const int theISection, - const bool theIsClosed ) +//! For internal use only! Undo/Redo are not used here. +bool CurveCreator_Curve::setClosedInternal( const int theISection, + const bool theIsClosed ) { if (theISection == -1) { int aSize = mySections.size(); @@ -437,20 +647,35 @@ bool CurveCreator_Curve::setClosed( const int theISection, for (i = 0; i < aSize; i++) { mySections[i]->myIsClosed = theIsClosed; - if( myListener ){ - myListener->sectionClosed( theISection, theIsClosed ); - } + redisplayCurve(); } } else { mySections.at(theISection)->myIsClosed = theIsClosed; - if( myListener ){ - myListener->sectionClosed( theISection, theIsClosed ); - } + redisplayCurve(); } return true; } -//! Returns specifyed section name +/** + * Set "closed" flag of the specified section (all sections if + * \a theISection is -1). + */ +bool CurveCreator_Curve::setClosed( const int theISection, + const bool theIsClosed ) +{ + bool res = false; + // Set the difference. + startOperation(); + if (addEmptyDiff()) { + myListDiffs.back().init(this, CurveCreator_Operation::SetClosed, + theIsClosed, theISection); + } + res = setClosedInternal( theISection, theIsClosed ); + finishOperation(); + return res; +} + +//! Returns specified section name std::string CurveCreator_Curve::getSectionName( const int theISection ) const { if( ( theISection >= 0 ) && ( theISection < mySections.size() )) @@ -458,15 +683,32 @@ std::string CurveCreator_Curve::getSectionName( const int theISection ) const return ""; } -/** Set name of the specified section */ -bool CurveCreator_Curve::setSectionName - ( const int theISection, const std::string& theName ) +//! For internal use only! Undo/Redo are not used here. +bool CurveCreator_Curve::setSectionNameInternal( const int theISection, + const std::string& theName ) { + bool res = false; if( ( theISection >= 0 ) && ( theISection < mySections.size() )){ mySections.at(theISection)->myName = theName; - return true; + res = true; } - return false; + return res; +} + +/** Set name of the specified section */ +bool CurveCreator_Curve::setSectionName( const int theISection, + const std::string& theName ) +{ + bool res = false; + // Set the difference. + startOperation(); + if (addEmptyDiff()) { + myListDiffs.back().init(this, CurveCreator_Operation::RenameSection, + theName, theISection); + } + res = setSectionNameInternal( theISection, theName ); + finishOperation(); + return res; } //! Get type of the specified section @@ -476,12 +718,9 @@ CurveCreator::SectionType CurveCreator_Curve::getSectionType return mySections.at(theISection)->myType; } -/** - * Set type of the specified section (or all sections - * if \a theISection is -1). - */ -bool CurveCreator_Curve::setSectionType( const int theISection, - const CurveCreator::SectionType theType ) +//! For internal use only! Undo/Redo are not used here. +bool CurveCreator_Curve::setSectionTypeInternal( const int theISection, + const CurveCreator::SectionType theType ) { if (theISection == -1) { int i = 0; @@ -490,23 +729,75 @@ bool CurveCreator_Curve::setSectionType( const int theISection, for (; i < aNbSections; i++) { mySections[i]->myType = theType; } - if( myListener ) - myListener->curveChanged(); + redisplayCurve(); } else { if( mySections.at(theISection)->myType != theType ){ mySections.at(theISection)->myType = theType; - if( myListener ) - myListener->sectionTypeChanged(theISection); + redisplayCurve(); } } return true; } +/** + * Set type of the specified section (or all sections + * if \a theISection is -1). + */ +bool CurveCreator_Curve::setSectionType( const int theISection, + const CurveCreator::SectionType theType ) +{ + bool res = false; + startOperation(); + // Set the difference. + if (addEmptyDiff()) { + myListDiffs.back().init(this, CurveCreator_Operation::SetType, + theType, theISection); + } + + res = setSectionTypeInternal( theISection, theType ); + + finishOperation(); + return res; +} + /***********************************************/ /*** Point methods ***/ /***********************************************/ +//! For internal use only! Undo/Redo are not used here. +bool CurveCreator_Curve::addPointsInternal( const CurveCreator::Coordinates& theCoords, + const std::vector &theISections, + const std::vector &theIPnts ) +{ + bool res = false; + if( (theCoords.size()/getDimension()) == theISections.size() == theIPnts.size() ) { + for( int ind = 0; ind < theISections.size(); ind++ ) { + int anISection = theISections.at(ind); + CurveCreator_Section *aSection = + (anISection == -1 ? mySections.back() : mySections.at(anISection)); + + if( aSection ) { + int anIPnt = theIPnts.at(ind); + CurveCreator::Coordinates::iterator anIterPosition; + if(anIPnt == -1) + anIterPosition = aSection->myPoints.end(); + else + anIterPosition = aSection->myPoints.begin() + toICoord(anIPnt); + CurveCreator::Coordinates::const_iterator aFirstPosition = + theCoords.begin() + toICoord(ind); + aSection->myPoints.insert(anIterPosition, + aFirstPosition, + aFirstPosition + getDimension()); + res = true; + } + } + if(res) + redisplayCurve(); + } + return res; +} + /** * Add one point to the specified section starting from the given theIPnt index * (or at the end of points if \a theIPnt is -1). @@ -520,41 +811,23 @@ bool CurveCreator_Curve::addPoints( const CurveCreator::Coordinates& theCoords, // Set the difference. startOperation(); if (addEmptyDiff()) { - myListDiffs.back().init(this, CurveCreator_Operation::AddPoints, - theCoords, theISection); - } - CurveCreator_Section *aSection = - (theISection == -1 ? mySections.back() : mySections.at(theISection)); - - if( aSection ) { - int anICoord = ( theIPnt == -1 ? 0 : toICoord(theIPnt) ); - CurveCreator::Coordinates::iterator anIterPosition = aSection->myPoints.end(); - if( theIPnt != -1 ) - anIterPosition = aSection->myPoints.begin() + toICoord(theIPnt); - aSection->myPoints.insert(anIterPosition, - theCoords.begin(), theCoords.end()); - if( myListener ) - myListener->pointInserted( theISection, -1 ); - res = true; + myListDiffs.back().init(this, CurveCreator_Operation::InsertPoints, + theCoords, theISection, theIPnt); } + std::vector anISections, anIPnts; + anISections.push_back( theISection ); + anIPnts.push_back( theIPnt ); + res = addPointsInternal( theCoords, anISections, anIPnts ); finishOperation(); return res; } - //! Set coordinates of specified point -bool CurveCreator_Curve::setPoint( const int theISection, - const int theIPnt, - const CurveCreator::Coordinates& theNewCoords ) +//! For internal use only! Undo/Redo are not used here. +bool CurveCreator_Curve::setPointInternal( const int theISection, + const int theIPnt, + const CurveCreator::Coordinates& theNewCoords ) { - // Set the difference. - startOperation(); - if (addEmptyDiff()) { - myListDiffs.back().init(this, CurveCreator_Operation::SetCoordinates, - theNewCoords, theISection, theIPnt); - } - bool res = false; - // Update the curve. if (theNewCoords.size() == myDimension) { CurveCreator_Section *aSection = mySections.at(theISection); @@ -562,17 +835,63 @@ bool CurveCreator_Curve::setPoint( const int theISection, for (i = 0; i < myDimension; i++) { aSection->myPoints.at(toICoord(theIPnt) + i) = theNewCoords[i]; } - if( myListener ) - myListener->pointChanged( theISection, theIPnt ); + redisplayCurve(); res = true; } + return res; +} +//! Set coordinates of specified point +bool CurveCreator_Curve::setPoint( const int theISection, + const int theIPnt, + const CurveCreator::Coordinates& theNewCoords ) +{ + bool res = false; + // Set the difference. + startOperation(); + if (addEmptyDiff()) { + myListDiffs.back().init(this, CurveCreator_Operation::SetCoordinates, + theNewCoords, theISection, theIPnt); + } + res = setPointInternal( theISection, theIPnt, theNewCoords ); finishOperation(); return res; } +//! Set coordinates of specified points from different sections +bool CurveCreator_Curve::setSeveralPoints( const SectionToPointCoordsList &theSectionToPntCoords) +{ + return false; +} + +//! For internal use only! Undo/Redo are not used here. +bool CurveCreator_Curve::removePointsInternal( const std::vector &theISections, + const std::vector &theIPnts ) +{ + bool res = false; + if( theISections.size() == theIPnts.size() ) { + for( int ind = 0; ind < theISections.size(); ind++ ) { + int anISection = theISections.at(ind); + CurveCreator_Section *aSection = mySections.at(anISection); + if( aSection ) { + int anIPnt = theIPnts.at(ind); + CurveCreator::Coordinates::iterator aFirstPosition; + if(anIPnt == -1) + aFirstPosition = aSection->myPoints.end(); + else + aFirstPosition = aSection->myPoints.begin() + toICoord(anIPnt); + aSection->myPoints.erase( aFirstPosition, aFirstPosition + getDimension() ); + res = true; + } + } + if(res) + redisplayCurve(); + } + return res; +} + //! Remove point with given id bool CurveCreator_Curve::removePoint( const int theISection, const int theIPnt ) { @@ -581,22 +900,23 @@ bool CurveCreator_Curve::removePoint( const int theISection, const int theIPnt ) startOperation(); if (addEmptyDiff()) { myListDiffs.back().init(this, CurveCreator_Operation::RemovePoints, - theISection, theIPnt, 0); - } - CurveCreator_Section *aSection = mySections.at(theISection); - if( aSection ) { - CurveCreator::Coordinates::iterator anIterPosition = - aSection->myPoints.begin() + toICoord(theIPnt); - aSection->myPoints.erase( anIterPosition ); - if( myListener ) - myListener->pointRemoved( theISection, theIPnt ); - res = true; + theISection, theIPnt); } + std::vector anISections, anIPnts; + anISections.push_back( theISection ); + anIPnts.push_back( theIPnt ); + res = removePointsInternal( anISections, anIPnts ); finishOperation(); return res; } -//======================================================================= +//! Remove several points from different sections with given ids +bool CurveCreator_Curve::removeSeveralPoints( const SectionToPointList &theSectionToPntIDs) +{ + return false; +} + + //======================================================================= // function: getCoordinates // purpose: //======================================================================= @@ -624,6 +944,15 @@ CurveCreator::Coordinates CurveCreator_Curve::getPoints( const int theISection ) /***********************************************/ /*** Presentation methods ***/ /***********************************************/ -/* TopoDS_Wire CurveCreator_Curve::constructWire() const -{ -}*/ +std::vector CurveCreator_Curve::constructWire() const +{ + std::vector aCurveRepresentation; + std::vector aSectionObjects; + for( int iSection = 0 ; iSection < getNbSections() ; iSection++ ){ + aSectionObjects = constructSection( iSection ); + for( int iObject = 0 ; iObject < aSectionObjects.size() ; iObject++ ){ + aCurveRepresentation.push_back( aSectionObjects.at(iObject) ); + } + } + return aCurveRepresentation; +}