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
Update Split feature and corresponding unit test
[modules/shaper.git]
/
src
/
SketchPlugin
/
SketchPlugin_Line.h
diff --git
a/src/SketchPlugin/SketchPlugin_Line.h
b/src/SketchPlugin/SketchPlugin_Line.h
index d2656e5d83ec89dfaa0360aa6a2b618947a3b8c7..e24e90e5444c0f52762a57e99e576f89258db299 100644
(file)
--- a/
src/SketchPlugin/SketchPlugin_Line.h
+++ b/
src/SketchPlugin/SketchPlugin_Line.h
@@
-1,3
+1,5
@@
+// Copyright (C) 2014-20xx CEA/DEN, EDF R&D -->
+
// File: SketchPlugin_Line.h
// Created: 24 Apr 2014
// Author: Mikhail PONIKAROV
// File: SketchPlugin_Line.h
// Created: 24 Apr 2014
// Author: Mikhail PONIKAROV
@@
-6,15
+8,17
@@
#define SketchPlugin_Line_H_
#include "SketchPlugin.h"
#define SketchPlugin_Line_H_
#include "SketchPlugin.h"
-#include <SketchPlugin_
Feature
.h>
+#include <SketchPlugin_
SketchEntity
.h>
#include <SketchPlugin_Sketch.h>
#include <list>
#include <SketchPlugin_Sketch.h>
#include <list>
+class GeomAPI_Pnt2d;
+
/**\class SketchPlugin_Line
/**\class SketchPlugin_Line
- * \ingroup
DataModel
+ * \ingroup
Plugins
* \brief Feature for creation of the new part in PartSet.
*/
* \brief Feature for creation of the new part in PartSet.
*/
-class SketchPlugin_Line : public SketchPlugin_
Feature
+class SketchPlugin_Line : public SketchPlugin_
SketchEntity
{
public:
/// Arc feature kind
{
public:
/// Arc feature kind
@@
-36,24
+40,24
@@
class SketchPlugin_Line : public SketchPlugin_Feature
return MY_END_ID;
}
return MY_END_ID;
}
- ///
Returns the kind of a feature
-
SKETCHPLUGIN_EXPORT virtual const std::string& getKind
()
+ ///
Line length.
+
static const std::string& LENGTH_ID
()
{
{
- static
std::string MY_KIND = SketchPlugin_Line::ID(
);
- return MY_
KIND
;
+ static
const std::string MY_LENGTH("LineLength"
);
+ return MY_
LENGTH
;
}
}
- /// Creates a new part document if needed
- SKETCHPLUGIN_EXPORT virtual void execute();
+ /// Returns the kind of a feature
+ SKETCHPLUGIN_EXPORT virtual const std::string& getKind();
+
+ /// Returns true is sketch element is under the rigid constraint
+ SKETCHPLUGIN_EXPORT virtual bool isFixed();
/// Request for initialization of data model of the feature: adding all attributes
/// Request for initialization of data model of the feature: adding all attributes
-
SKETCHPLUGIN_EXPORT
virtual void initAttributes();
+ virtual void initAttributes();
- /// Returns the AIS preview
- SKETCHPLUGIN_EXPORT virtual AISObjectPtr getAISObject(AISObjectPtr thePrevious)
- {
- return simpleAISObject(firstResult(), thePrevious);
- }
+ /// Creates a new part document if needed
+ SKETCHPLUGIN_EXPORT virtual void execute();
/// Moves the feature
/// \param theDeltaX the delta for X coordinate is moved
/// Moves the feature
/// \param theDeltaX the delta for X coordinate is moved
@@
-62,10
+66,21
@@
class SketchPlugin_Line : public SketchPlugin_Feature
/// Return the distance between the feature and the point
/// \param thePoint the point
/// Return the distance between the feature and the point
/// \param thePoint the point
- virtual double distanceToPoint(const boost::shared_ptr<GeomAPI_Pnt2d>& thePoint);
+ double distanceToPoint(const std::shared_ptr<GeomAPI_Pnt2d>& thePoint);
+
+ /// Called on change of any argument-attribute of this object
+ SKETCHPLUGIN_EXPORT virtual void attributeChanged(const std::string& theID);
/// Use plugin manager for features creation
SketchPlugin_Line();
/// Use plugin manager for features creation
SketchPlugin_Line();
+
+private:
+ /// Calculates the lenght of the line and fill the lenght attribute with the value
+ void updateLenghtValue();
+
+protected:
+ /// \brief Initializes attributes of derived class.
+ virtual void initDerivedClassAttributes();
};
#endif
};
#endif