X-Git-Url: http://git.salome-platform.org/gitweb/?a=blobdiff_plain;f=src%2FConstructionPlugin%2FConstructionPlugin_Point.h;h=439805742a9959d329c71ed480c24d822bbc1051;hb=d5c7ad3c50f89a2ddc2de1866ffb7f09397f3be2;hp=7537970a86564e671d0b94c9cabef0e26611d266;hpb=dc26a49174c150bb0fbb63a44ce562c17288d3ff;p=modules%2Fshaper.git diff --git a/src/ConstructionPlugin/ConstructionPlugin_Point.h b/src/ConstructionPlugin/ConstructionPlugin_Point.h index 7537970a8..439805742 100644 --- a/src/ConstructionPlugin/ConstructionPlugin_Point.h +++ b/src/ConstructionPlugin/ConstructionPlugin_Point.h @@ -1,4 +1,4 @@ -// Copyright (C) 2014-2017 CEA/DEN, EDF R&D +// Copyright (C) 2014-2019 CEA/DEN, EDF R&D // // This library is free software; you can redistribute it and/or // modify it under the terms of the GNU Lesser General Public @@ -12,10 +12,9 @@ // // 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 +// Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA // -// See http://www.salome-platform.org/ or -// email : webmaster.salome@opencascade.com +// See http://www.salome-platform.org/ or email : webmaster.salome@opencascade.com // #ifndef ConstructionPlugin_Point_H_ @@ -68,7 +67,6 @@ public: return MY_CREATION_METHOD_ID; } - /* /// Attribute name for creation method. inline static const std::string& CREATION_METHOD_BY_PROJECTION() { @@ -77,39 +75,23 @@ public: } /// Attribute name for creation method. - inline static const std::string& CREATION_METHOD_BY_LINES_INTERSECTION() + inline static const std::string& CREATION_METHOD_BY_INTERSECTION() { - static const std::string MY_CREATION_METHOD_ID("by_lines_intersection"); + static const std::string MY_CREATION_METHOD_ID("by_intersection"); return MY_CREATION_METHOD_ID; } - */ /// Attribute name for creation method. - inline static const std::string& CREATION_METHOD_BY_LINE_AND_PLANE_INTERSECTION() + inline static const std::string& CREATION_METHOD_BY_GEOMETRICAL_PROPERTY() { - static const std::string MY_CREATION_METHOD_ID("by_line_and_plane_intersection"); + static const std::string MY_CREATION_METHOD_ID("by_geometrical_property"); return MY_CREATION_METHOD_ID; } - /// Attribute name for X coordinate. - inline static const std::string& X() + inline static const std::string& POINT3D() { - static const std::string POINT_ATTR_X("x"); - return POINT_ATTR_X; - } - - /// Attribute name for Y coordinate. - inline static const std::string& Y() - { - static const std::string POINT_ATTR_Y("y"); - return POINT_ATTR_Y; - } - - /// Attribute name for Z coordinate. - inline static const std::string& Z() - { - static const std::string POINT_ATTR_Z("z"); - return POINT_ATTR_Z; + static const std::string POINT_ATTR("point3d"); + return POINT_ATTR; } /// Attribute name for selected edge. @@ -161,35 +143,89 @@ public: return ATTR_ID; } - /* - /// Attribute name for point. - inline static const std::string& POINT() + /// Attribute name for point to projection. + inline static const std::string& POINT_TO_PROJECT() + { + static const std::string ATTR_ID("point_to_project"); + return ATTR_ID; + } + + /// Attribute name for projection type. + inline static const std::string& PROJECTION_TYPE() { - static const std::string ATTR_ID("point"); + static const std::string ATTR_ID("projection_type"); return ATTR_ID; } - /// Attribute name for plane. - inline static const std::string& PLANE() + /// Attribute name for projection type on edge. + inline static const std::string& PROJECTION_TYPE_ON_EDGE() { - static const std::string ATTR_ID("plane"); + static const std::string ATTR_ID("projection_type_on_edge"); return ATTR_ID; } - /// Attribute name for selected first line. - inline static const std::string& FIRST_LINE() + /// Attribute name for projection type on face. + inline static const std::string& PROJECTION_TYPE_ON_FACE() { - static const std::string ATTR_ID("first_line"); + static const std::string ATTR_ID("projection_type_on_face"); return ATTR_ID; } - /// Attribute name for selected second line. - inline static const std::string& SECOND_LINE() + /// Attribute name for edge for point projection. + inline static const std::string& EDGE_FOR_POINT_PROJECTION() { - static const std::string ATTR_ID("second_line"); + static const std::string ATTR_ID("edge_for_point_projection"); + return ATTR_ID; + } + + /// Attribute name for face for point projection. + inline static const std::string& FACE_FOR_POINT_PROJECTION() + { + static const std::string ATTR_ID("face_for_point_projection"); + return ATTR_ID; + } + + /// Attribute name for intersection type. + inline static const std::string& INTERSECTION_TYPE() + { + static const std::string ATTR_ID("intersection_type"); + return ATTR_ID; + } + + /// Attribute name for intersection type by lines. + inline static const std::string& INTERSECTION_TYPE_BY_LINES() + { + static const std::string MY_CREATION_METHOD_ID("intersection_type_by_lines"); + return MY_CREATION_METHOD_ID; + } + + /// Attribute name for intersection type by line and plane. + inline static const std::string& INTERSECTION_TYPE_BY_LINE_AND_PLANE() + { + static const std::string MY_CREATION_METHOD_ID("intersection_type_by_line_and_plane"); + return MY_CREATION_METHOD_ID; + } + + /// Attribute name for intersection type by planes. + inline static const std::string& INTERSECTION_TYPE_BY_PLANES() + { + static const std::string MY_CREATION_METHOD_ID("intersection_type_by_planes"); + return MY_CREATION_METHOD_ID; + } + + /// Attribute name for selected first intersection line. + inline static const std::string& INTERSECTION_LINE_1() + { + static const std::string ATTR_ID("intersection_line_1"); + return ATTR_ID; + } + + /// Attribute name for selected second intersection line. + inline static const std::string& INTERSECTION_LINE_2() + { + static const std::string ATTR_ID("intersection_line_2"); return ATTR_ID; } - */ /// Attribute name for selected intersection line. inline static const std::string& INTERSECTION_LINE() @@ -226,15 +262,68 @@ public: return ATTR_ID; } + /// Attribute name for selected intersection plane. + inline static const std::string& INTERSECTION_PLANE_1() + { + static const std::string ATTR_ID("intersection_plane_1"); + return ATTR_ID; + } + + /// Attribute name for selected intersection plane. + inline static const std::string& INTERSECTION_PLANE_2() + { + static const std::string ATTR_ID("intersection_plane_2"); + return ATTR_ID; + } + + /// Attribute name for selected intersection plane. + inline static const std::string& INTERSECTION_PLANE_3() + { + static const std::string ATTR_ID("intersection_plane_3"); + return ATTR_ID; + } + + /// Attribute name for property type. + inline static const std::string& GEOMETRICAL_PROPERTY_TYPE() + { + static const std::string ATTR_ID("geometrical_property_type"); + return ATTR_ID; + } + + /// Attribute name for property type by center of gravity. + inline static const std::string& GEOMETRICAL_PROPERTY_TYPE_BY_CENTER_OF_GRAVITY() + { + static const std::string PROPERTY_TYPE("geometrical_property_type_by_center_of_gravity"); + return PROPERTY_TYPE; + } + + /// Attribute name for property type by center of circle. + inline static const std::string& GEOMETRICAL_PROPERTY_TYPE_BY_CENTER_OF_CIRCLE() + { + static const std::string PROPERTY_TYPE("geometrical_property_type_by_center_of_circle"); + return PROPERTY_TYPE; + } + + /// Attribute name for selected object for center of gravity. + inline static const std::string& OBJECT_FOR_CENTER_OF_GRAVITY() + { + static const std::string ATTR_ID("object_for_center_of_gravity"); + return ATTR_ID; + } + + /// Attribute name for selected object for center of cricle. + inline static const std::string& OBJECT_FOR_CENTER_OF_CIRCLE() + { + static const std::string ATTR_ID("object_for_center_of_circle"); + return ATTR_ID; + } + /// Creates a new part document if needed. CONSTRUCTIONPLUGIN_EXPORT virtual void execute(); /// Request for initialization of data model of the feature: adding all attributes. CONSTRUCTIONPLUGIN_EXPORT virtual void initAttributes(); - /// Construction result is allways recomuted on the fly. - CONSTRUCTIONPLUGIN_EXPORT virtual bool isPersistentResult() {return false;} - /// Use plugin manager for features creation ConstructionPlugin_Point(); @@ -245,10 +334,13 @@ public: private: std::shared_ptr createByXYZ(); std::shared_ptr createByDistanceOnEdge(); - /*std::shared_ptr createByProjection(); - std::shared_ptr createByLinesIntersection();*/ + std::shared_ptr createByProjectionOnEdge(); + std::shared_ptr createByProjectionOnFace(); + std::shared_ptr createByLinesIntersection(); std::list > createByLineAndPlaneIntersection(); - + std::shared_ptr createByPlanesIntersection(); + std::shared_ptr createByCenterOfGravity(); + std::shared_ptr createByCenterOfCircle(); }; #endif