--- /dev/null
+// Copyright (C) 2013 CEA/DEN, EDF R&D, OPEN CASCADE
+//
+// This library is free software; you can redistribute it and/or
+// modify it under the terms of the GNU Lesser General Public
+// License as published by the Free Software Foundation; either
+// version 2.1 of the License.
+//
+// This library is distributed in the hope that it will be useful,
+// but WITHOUT ANY WARRANTY; without even the implied warranty of
+// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
+// Lesser General Public License for more details.
+//
+// You should have received a copy of the GNU Lesser General Public
+// License along with this library; if not, write to the Free Software
+// Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
+//
+// See http://www.salome-platform.org/ or email : webmaster.salome@opencascade.com
+//
+
+#include "CurveCreator_UtilsICurve.hxx"
+
+#include "CurveCreator.hxx"
+
+const double LOCAL_SELECTION_TOLERANCE = 0.0001;
+
+int CurveCreator_UtilsICurve::findLocalPointIndex( CurveCreator_ICurve* theCurve,
+ int theSectionId, float theX, float theY )
+{
+ int aPntIndex = -1;
+ if ( !theCurve )
+ return aPntIndex;
+
+ CurveCreator::Coordinates aCoords;
+ for ( int i = 0, aNb = theCurve->getNbPoints( theSectionId ); i < aNb && aPntIndex < 0; i++ ) {
+ aCoords = theCurve->getPoint( theSectionId, i );
+ if ( aCoords.size() < 2 )
+ continue;
+ if ( fabs( aCoords[0] - theX ) < LOCAL_SELECTION_TOLERANCE &&
+ fabs( aCoords[1] - theY ) < LOCAL_SELECTION_TOLERANCE )
+ aPntIndex = i;
+ }
+
+ return aPntIndex;
+}
+
+void CurveCreator_UtilsICurve::findSectionsToPoints( CurveCreator_ICurve* theCurve,
+ const double theX, const double theY,
+ CurveCreator_ICurve::SectionToPointList& thePoints )
+{
+ thePoints.clear();
+
+ int aPointId = -1;
+ for ( int i = 0, aNb = theCurve->getNbSections(); i < aNb; i++ ) {
+ aPointId = CurveCreator_UtilsICurve::findLocalPointIndex( theCurve, i, theX, theY );
+ if ( aPointId < 0 )
+ continue;
+ CurveCreator_ICurve::SectionToPoint aPoint = std::make_pair( i, aPointId );
+ if ( !CurveCreator_UtilsICurve::contains( thePoints, aPoint ) )
+ thePoints.push_back( aPoint );
+ }
+}
+
+void CurveCreator_UtilsICurve::convert( const CurveCreator_ICurve::SectionToPointList& thePoints,
+ QMap<int, QList<int> >& theConvPoints )
+{
+ theConvPoints.clear();
+
+ CurveCreator_ICurve::SectionToPointList::const_iterator anIt = thePoints.begin(),
+ aLast = thePoints.end();
+ QList<int> aPoints;
+ int aSectionId, aPointId;
+ for ( ; anIt != aLast; anIt++ ) {
+ aSectionId = anIt->first;
+ aPointId = anIt->second;
+ aPoints.clear();
+ if ( theConvPoints.contains( aSectionId ) )
+ aPoints = theConvPoints[aSectionId];
+ if ( aPoints.contains( aPointId ) )
+ continue;
+ aPoints.append( aPointId );
+ theConvPoints[aSectionId] = aPoints;
+ }
+}
+
+/**
+ * Returns whethe the container has the value
+ * \param theList a container of values
+ * \param theValue a value
+ */
+bool CurveCreator_UtilsICurve::contains( const CurveCreator_ICurve::SectionToPointList& theList,
+ const CurveCreator_ICurve::SectionToPoint& theValue )
+{
+ bool isFound = false;
+
+ CurveCreator_ICurve::SectionToPointList::const_iterator anIt = theList.begin(),
+ aLast = theList.end();
+ for ( ; anIt != aLast && !isFound; anIt++ )
+ isFound = anIt->first == theValue.first && anIt->second == theValue.second;
+
+ return isFound;
+}
--- /dev/null
+// Copyright (C) 2013 CEA/DEN, EDF R&D, OPEN CASCADE
+//
+// This library is free software; you can redistribute it and/or
+// modify it under the terms of the GNU Lesser General Public
+// License as published by the Free Software Foundation; either
+// version 2.1 of the License.
+//
+// This library is distributed in the hope that it will be useful,
+// but WITHOUT ANY WARRANTY; without even the implied warranty of
+// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
+// Lesser General Public License for more details.
+//
+// You should have received a copy of the GNU Lesser General Public
+// License along with this library; if not, write to the Free Software
+// Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
+//
+// See http://www.salome-platform.org/ or email : webmaster.salome@opencascade.com
+//
+
+#ifndef CURVECREATOR_UTILS_ICURVE_H
+#define CURVECREATOR_UTILS_ICURVE_H
+
+#include "CurveCreator_Macro.hxx"
+
+#include "CurveCreator_ICurve.hxx"
+
+#include <QMap>
+#include <QList>
+
+class CurveCreator_UtilsICurve
+{
+public:
+
+ /*!
+ * Returns a point index in the model curve by the point coordinates in the viewer
+ * \param theX the X coordinate of the point
+ * \param theY the Y coordinate of the point
+ */
+ CURVECREATOR_EXPORT static int findLocalPointIndex( CurveCreator_ICurve* theCurve,
+ int theSectionId, float theX, float theY );
+
+ CURVECREATOR_EXPORT static void findSectionsToPoints( CurveCreator_ICurve* theCurve,
+ const double theX, const double theY,
+ CurveCreator_ICurve::SectionToPointList& thePoints );
+ CURVECREATOR_EXPORT static void convert( const CurveCreator_ICurve::SectionToPointList& thePoints,
+ QMap<int, QList<int> >& theConvPoints );
+
+ /**
+ * Returns whethe the container has the value
+ * \param theList a container of values
+ * \param theValue a value
+ */
+ CURVECREATOR_EXPORT static bool contains( const CurveCreator_ICurve::SectionToPointList& theList,
+ const CurveCreator_ICurve::SectionToPoint& theValue );
+};
+
+#endif // CURVECREATOR_UTILS_ICURVE_H
//#include "CurveCreator_NewPointDlg.h"
#include "CurveCreator_NewSectionDlg.h"
#include "CurveCreator_Utils.h"
+#include "CurveCreator_UtilsICurve.hxx"
#include "CurveCreator_TableView.h"
#include <SUIT_Session.h>
if( !myCurve )
return;
- CurveCreator_Widget::SectionToPointList aPoints;
+ CurveCreator_ICurve::SectionToPointList aPoints;
startCurveModification( aPoints, false );
myCurve->undo();
finishCurveModification();
{
if( !myCurve )
return;
- CurveCreator_Widget::SectionToPointList aPoints;
+ CurveCreator_ICurve::SectionToPointList aPoints;
startCurveModification( aPoints, false );
myCurve->redo();
finishCurveModification();
if ( myDragStarted ) {
bool isDragged = myDragged;
- CurveCreator_Widget::SectionToPointList aDraggedPoints;
+ CurveCreator_ICurve::SectionToPointList aDraggedPoints;
if ( myDragged )
aDraggedPoints = myDragPoints;
if ( aPntIndex < 0 )
return;
- SectionToPointList aSelPoints;
+ CurveCreator_ICurve::SectionToPointList aSelPoints;
startCurveModification( aSelPoints );
double aX = myLocalPointView->item( theRow, 2 )->data( Qt::UserRole ).toDouble();
*/
void CurveCreator_Widget::removePoint()
{
- SectionToPointList aPoints;
+ CurveCreator_ICurve::SectionToPointList aPoints;
getSelectedPonts( aPoints );
if ( aPoints.size() == 0 )
return;
- SectionToPointList aSelPoints;
+ CurveCreator_ICurve::SectionToPointList aSelPoints;
startCurveModification( aSelPoints, false );
myCurve->removeSeveralPoints( aPoints );
- finishCurveModification( SectionToPointList() );
+ finishCurveModification( CurveCreator_ICurve::SectionToPointList() );
}
void CurveCreator_Widget::insertPointToSelectedSegment( const int theX,
return;
// insert the point to the model curve
- SectionToPointList aSelPoints;
+ CurveCreator_ICurve::SectionToPointList aSelPoints;
startCurveModification( aSelPoints );
CurveCreator::Coordinates aCoords;
aCoords.push_back( aPoint.X() );
aCoords.push_back( aPoint.Y() );
- SectionToPointList aPoints1, aPoints2;
+ CurveCreator_ICurve::SectionToPointList aPoints1, aPoints2;
findSectionsToPoints( aPoint1.X(), aPoint1.Y(), aPoints1 );
findSectionsToPoints( aPoint2.X(), aPoint2.Y(), aPoints2 );
- SectionToPointList::const_iterator anIt = aPoints1.begin(), aLast = aPoints1.end();
+ CurveCreator_ICurve::SectionToPointList::const_iterator anIt = aPoints1.begin(),
+ aLast = aPoints1.end();
int aSectionId = -1;
// there can be a case when a new point is added into two sections
int aPoint1Id = -1, aPoint2Id = -1;
for ( ; anIt != aLast && aSectionId < 0; anIt++ ) {
int aSectionCur = anIt->first;
- SectionToPointList::const_iterator anIt2 = aPoints2.begin(), aLast2 = aPoints2.end();
+ CurveCreator_ICurve::SectionToPointList::const_iterator anIt2 = aPoints2.begin(),
+ aLast2 = aPoints2.end();
for ( ; anIt2 != aLast2 && aSectionId < 0; anIt2++ ) {
if ( anIt2->first == aSectionCur ) {
aSectionId = aSectionCur;
if ( !aViewPort )
return;
- SectionToPointList aPoints;
+ CurveCreator_ICurve::SectionToPointList aPoints;
startCurveModification( aPoints, false );
gp_Pnt aStartPnt = CurveCreator_Utils::ConvertClickToPoint( myDragStartPosition.x(),
CurveCreator_ICurve::SectionToPointCoordsList aCoordList;
std::deque<float> aChangedPos;
- SectionToPointList::const_iterator anIt = myDragPoints.begin(), aLast = myDragPoints.end();
+ CurveCreator_ICurve::SectionToPointList::const_iterator anIt = myDragPoints.begin(),
+ aLast = myDragPoints.end();
for ( ; anIt != aLast; anIt++ ) {
int aSectionId = anIt->first;
int aPointId = anIt->second;
void CurveCreator_Widget::addLocalPointToTable( const double theX, const double theY )
{
- SectionToPointList aPoints;
+ CurveCreator_ICurve::SectionToPointList aPoints;
findSectionsToPoints( theX, theY, aPoints );
- SectionToPointList aSkipList;
+ CurveCreator_ICurve::SectionToPointList aSkipList;
// table could not contain two equal value rows
int aRowId = myLocalPointView->rowCount();
double aCurrentX, aCurrentY;
int aSectionId, aPointId;
- SectionToPoint aPoint;
+ CurveCreator_ICurve::SectionToPoint aPoint;
for ( int i = 0; i < aRowId; i++ ) {
aCurrentX = myLocalPointView->item( i, 2 )->data( Qt::UserRole ).toDouble();
aCurrentY = myLocalPointView->item( i, 3 )->data( Qt::UserRole ).toDouble();
return;
QTableWidgetItem* anItem;
- SectionToPointList::const_iterator anIt = aPoints.begin(), aLast = aPoints.end();
+ CurveCreator_ICurve::SectionToPointList::const_iterator anIt = aPoints.begin(),
+ aLast = aPoints.end();
for ( ; anIt != aLast; anIt++ ) {
aPoint = *anIt;
if ( contains( aSkipList, aPoint ) )
myDragged = false;
}
-void CurveCreator_Widget::getSelectedPonts( CurveCreator_Widget::SectionToPointList& thePoints )
+void CurveCreator_Widget::getSelectedPonts( CurveCreator_ICurve::SectionToPointList& thePoints )
{
thePoints.clear();
for ( int i = 0, aNb = myLocalPointView->rowCount(); i < aNb; i++ )
thePoints.push_back( std::make_pair( getSectionId( i ), getPointId( i ) ) );
}
-void CurveCreator_Widget::setSelectedPonts( const CurveCreator_Widget::SectionToPointList& thePoints )
+void CurveCreator_Widget::setSelectedPonts( const CurveCreator_ICurve::SectionToPointList& thePoints )
{
if ( myDragStarted )
return;
return;
AIS_ListOfInteractive aListToSelect;
+
AIS_ListOfInteractive aDisplayedList;
ic->DisplayedObjects( aDisplayedList );
- SectionToPointList::const_iterator anIt = thePoints.begin(), aLast = thePoints.end();
- SectionToPoint aSToPoint;
+ CurveCreator_ICurve::SectionToPointList::const_iterator anIt = thePoints.begin(),
+ aLast = thePoints.end();
+ CurveCreator_ICurve::SectionToPoint aSToPoint;
for( ; anIt != aLast; anIt++ ) {
aSToPoint = *anIt;
gp_Pnt aPnt = BRep_Tool::Pnt( aVertex );
- SectionToPointList aPoints;
+ CurveCreator_ICurve::SectionToPointList aPoints;
findSectionsToPoints( aPnt.X(), aPnt.Y(), aPoints );
- SectionToPointList::const_iterator anIt = aPoints.begin(), aLast = aPoints.end();
- SectionToPoint aPoint;
+ CurveCreator_ICurve::SectionToPointList::const_iterator anIt = aPoints.begin(),
+ aLast = aPoints.end();
+ CurveCreator_ICurve::SectionToPoint aPoint;
for ( ; anIt != aLast; anIt++ ) {
aPoint = *anIt;
if ( aPoint.first == aSToPoint.first && aPoint.second == aSToPoint.second )
* \param theFillPoints a flag whether the selection list should be filled
*/
void CurveCreator_Widget::startCurveModification(
- CurveCreator_Widget::SectionToPointList& thePoints,
+ CurveCreator_ICurve::SectionToPointList& thePoints,
const bool theFillPoints )
{
if ( theFillPoints ) {
* \param thePoints a list of curve selected points
*/
void CurveCreator_Widget::finishCurveModification(
- const CurveCreator_Widget::SectionToPointList& thePoints )
+ const CurveCreator_ICurve::SectionToPointList& thePoints )
{
if ( getActionMode() == ModificationMode )
setLocalPointContext( true );
*/
int CurveCreator_Widget::findLocalPointIndex( int theSectionId, float theX, float theY )
{
- int aPntIndex = -1;
-
- CurveCreator::Coordinates aCoords;
- for ( int i = 0, aNb = myCurve->getNbPoints( theSectionId ); i < aNb && aPntIndex < 0; i++ ) {
- aCoords = myCurve->getPoint( theSectionId, i );
- if ( aCoords.size() < 2 )
- continue;
- if ( fabs( aCoords[0] - theX ) < LOCAL_SELECTION_TOLERANCE &&
- fabs( aCoords[1] - theY ) < LOCAL_SELECTION_TOLERANCE )
- aPntIndex = i;
- }
-
- return aPntIndex;
+ return CurveCreator_UtilsICurve::findLocalPointIndex( myCurve, theSectionId, theX, theY );
}
void CurveCreator_Widget::findSectionsToPoints( const double theX, const double theY,
- CurveCreator_Widget::SectionToPointList& thePoints )
+ CurveCreator_ICurve::SectionToPointList& thePoints )
{
- thePoints.clear();
-
- int aPointId = -1;
- for ( int i = 0, aNb = myCurve->getNbSections(); i < aNb; i++ ) {
- aPointId = findLocalPointIndex( i, theX, theY );
- if ( aPointId < 0 )
- continue;
- SectionToPoint aPoint = std::make_pair( i, aPointId );
- if ( !contains( thePoints, aPoint ) )
- thePoints.push_back( aPoint );
- }
+ return CurveCreator_UtilsICurve::findSectionsToPoints( myCurve, theX, theY, thePoints );
}
-void CurveCreator_Widget::convert( const SectionToPointList& thePoints,
+void CurveCreator_Widget::convert( const CurveCreator_ICurve::SectionToPointList& thePoints,
QMap<int, QList<int> >& theConvPoints )
{
- theConvPoints.clear();
-
- SectionToPointList::const_iterator anIt = thePoints.begin(), aLast = thePoints.end();
- QList<int> aPoints;
- int aSectionId, aPointId;
- for ( ; anIt != aLast; anIt++ ) {
- aSectionId = anIt->first;
- aPointId = anIt->second;
- aPoints.clear();
- if ( theConvPoints.contains( aSectionId ) )
- aPoints = theConvPoints[aSectionId];
- if ( aPoints.contains( aPointId ) )
- continue;
- aPoints.append( aPointId );
- theConvPoints[aSectionId] = aPoints;
- }
+ return CurveCreator_UtilsICurve::convert( thePoints, theConvPoints );
}
/**
* \param theList a container of values
* \param theValue a value
*/
-bool CurveCreator_Widget::contains( const CurveCreator_Widget::SectionToPointList& theList,
- const CurveCreator_Widget::SectionToPoint& theValue ) const
+bool CurveCreator_Widget::contains( const CurveCreator_ICurve::SectionToPointList& theList,
+ const CurveCreator_ICurve::SectionToPoint& theValue ) const
{
- bool isFound = false;
-
- SectionToPointList::const_iterator anIt = theList.begin(), aLast = theList.end();
- for ( ; anIt != aLast && !isFound; anIt++ )
- isFound = anIt->first == theValue.first && anIt->second == theValue.second;
-
- return isFound;
+ return CurveCreator_UtilsICurve::contains( theList, theValue );
}
#ifndef CURVECREATOR_WIDGET_H
#define CURVECREATOR_WIDGET_H
-//#include "CurveCreator_ICurve.hxx"
-#include "CurveCreator.hxx"
#include "CurveCreator_Macro.hxx"
+#include "CurveCreator.hxx"
+#include "CurveCreator_ICurve.hxx"
#include <QWidget>
#include <QMap>
class QAction;
class QPixmap;
class QTableWidget;
-class CurveCreator_ICurve;
class CurveCreator_TreeView;
class CurveCreator_NewPointDlg;
class CurveCreator_NewSectionDlg;
DetectionMode
};
- typedef std::pair< int, int > SectionToPoint;
- typedef std::deque< SectionToPoint > SectionToPointList;
-
private:
OCCViewer_Viewer* getOCCViewer();
void setDragStarted( const bool theState, const QPoint& thePoint = QPoint() );
- void getSelectedPonts( SectionToPointList& thePoints );
- void setSelectedPonts( const SectionToPointList& = SectionToPointList() );
+ void getSelectedPonts( CurveCreator_ICurve::SectionToPointList& thePoints );
+ void setSelectedPonts( const CurveCreator_ICurve::SectionToPointList& =
+ CurveCreator_ICurve::SectionToPointList() );
- void startCurveModification( SectionToPointList& thePoints,
+ void startCurveModification( CurveCreator_ICurve::SectionToPointList& thePoints,
const bool theFillPoints = true );
- void finishCurveModification( const SectionToPointList& thePoints = SectionToPointList() );
+ void finishCurveModification( const CurveCreator_ICurve::SectionToPointList& thePoints =
+ CurveCreator_ICurve::SectionToPointList() );
// curve algorithm
int findLocalPointIndex( int theSectionId, float theX, float theY );
void findSectionsToPoints( const double theX, const double theY,
- SectionToPointList& thePoints );
- void convert( const SectionToPointList& thePoints,
+ CurveCreator_ICurve::SectionToPointList& thePoints );
+ void convert( const CurveCreator_ICurve::SectionToPointList& thePoints,
QMap<int, QList<int> >& theConvPoints );
// local point view table methods
int getSectionId( const int theRowId ) const;
int getPointId( const int theRowId ) const;
- bool contains( const SectionToPointList& theList, const SectionToPoint& theValue ) const;
+ bool contains( const CurveCreator_ICurve::SectionToPointList& theList,
+ const CurveCreator_ICurve::SectionToPoint& theValue ) const;
private:
QMap<ActionId, QAction*> myActionMap;
bool myDragStarted;
QPoint myDragStartPosition;
int myDragInteractionStyle;
- SectionToPointList myDragPoints;
+ CurveCreator_ICurve::SectionToPointList myDragPoints;
bool myDragged;
QByteArray myGuiState;
};