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
Merge branch 'Dev_1.1.0' of newgeom:newgeom into Dev_1.1.0
[modules/shaper.git]
/
src
/
SketchPlugin
/
SketchPlugin_Arc.h
diff --git
a/src/SketchPlugin/SketchPlugin_Arc.h
b/src/SketchPlugin/SketchPlugin_Arc.h
index 66da16cfeef25f08ffdab09611acd1ec430b8eb3..47a9f9dd45d2d089d1f2c469478ba1631d2b1b17 100644
(file)
--- a/
src/SketchPlugin/SketchPlugin_Arc.h
+++ b/
src/SketchPlugin/SketchPlugin_Arc.h
@@
-1,22
+1,31
@@
+// Copyright (C) 2014-20xx CEA/DEN, EDF R&D -->
+
// File: SketchPlugin_Arc.h
// Created: 26 May 2014
// Author: Artem ZHIDKOV
// File: SketchPlugin_Arc.h
// Created: 26 May 2014
// Author: Artem ZHIDKOV
-#ifndef SketchPlugin_Arc_H
eaderFile
-#define SketchPlugin_Arc_H
eaderFile
+#ifndef SketchPlugin_Arc_H
_
+#define SketchPlugin_Arc_H
_
#include "SketchPlugin.h"
#include "SketchPlugin.h"
-#include <SketchPlugin_
Feature
.h>
+#include <SketchPlugin_
SketchEntity
.h>
#include <SketchPlugin_Sketch.h>
#include <GeomAPI_IPresentable.h>
/**\class SketchPlugin_Arc
#include <SketchPlugin_Sketch.h>
#include <GeomAPI_IPresentable.h>
/**\class SketchPlugin_Arc
- * \ingroup
DataModel
+ * \ingroup
Plugins
* \brief Feature for creation of the new arc of circle in PartSet.
* \brief Feature for creation of the new arc of circle in PartSet.
+ * The visualization of this object is separated in two parts. The first one is an AIS object
+ * calculated when there is non-initialized attributes of the arc. The second is a result and
+ * it is calculated if all attributes are initialized.
*/
*/
-class SketchPlugin_Arc
: public SketchPlugin_Feature//
, public GeomAPI_IPresentable
+class SketchPlugin_Arc
: public SketchPlugin_SketchEntity
, public GeomAPI_IPresentable
{
{
-public:
+ /// to avoid cyclic dependencies in automatic updates: they mean that
+ /// update is performed right now and automatic updates are not needed
+ bool myStartUpdate, myEndUpdate;
+
+ public:
/// Arc feature kind
inline static const std::string& ID()
{
/// Arc feature kind
inline static const std::string& ID()
{
@@
-45,7
+54,13
@@
public:
/// Returns the kind of a feature
SKETCHPLUGIN_EXPORT virtual const std::string& getKind()
/// Returns the kind of a feature
SKETCHPLUGIN_EXPORT virtual const std::string& getKind()
- {static std::string MY_KIND = SketchPlugin_Arc::ID(); return MY_KIND;}
+ {
+ static std::string MY_KIND = SketchPlugin_Arc::ID();
+ return MY_KIND;
+ }
+
+ /// Returns true is sketch element is under the rigid constraint
+ SKETCHPLUGIN_EXPORT virtual bool isFixed();
/// Creates an arc-shape
SKETCHPLUGIN_EXPORT virtual void execute();
/// Creates an arc-shape
SKETCHPLUGIN_EXPORT virtual void execute();
@@
-53,10
+68,12
@@
public:
/// Request for initialization of data model of the feature: adding all attributes
SKETCHPLUGIN_EXPORT virtual void initAttributes();
/// Request for initialization of data model of the feature: adding all attributes
SKETCHPLUGIN_EXPORT virtual void initAttributes();
+ /// Called on change of any argument-attribute of this object
+ /// \param theID identifier of changed attribute
+ SKETCHPLUGIN_EXPORT virtual void attributeChanged(const std::string& theID);
+
/// Returns the AIS preview
/// Returns the AIS preview
- virtual boost::shared_ptr<GeomAPI_AISObject> getAISObject(
- boost::shared_ptr<GeomAPI_AISObject> thePrevious)
- {return simpleAISObject(firstResult(), thePrevious);}
+ virtual AISObjectPtr getAISObject(AISObjectPtr thePrevious);
/// Moves the feature
/// \param theDeltaX the delta for X coordinate is moved
/// Moves the feature
/// \param theDeltaX the delta for X coordinate is moved
@@
-65,10
+82,14
@@
public:
/// 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);
+ virtual double distanceToPoint(const
std
::shared_ptr<GeomAPI_Pnt2d>& thePoint);
/// Use plugin manager for features creation
SketchPlugin_Arc();
/// Use plugin manager for features creation
SketchPlugin_Arc();
+
+private:
+ /// Returns true if all obligatory attributes are initialized
+ bool isFeatureValid();
};
#endif
};
#endif