1 // Copyright (C) 2014-20xx CEA/DEN, EDF R&D
4 #include "ModuleBase_ValidatorFace.h"
5 #include "ModuleBase_WidgetShapeSelector.h"
7 #include "ModelAPI_AttributeSelection.h"
9 #include <GeomAPI_Face.h>
11 #include <Events_Error.h>
16 typedef QMap<QString, GeomAbs_SurfaceType> FaceTypes;
17 static FaceTypes MyFaceTypes;
19 GeomAbs_SurfaceType ModuleBase_ValidatorFace::faceType(const std::string& theType)
21 if (MyFaceTypes.count() == 0) {
22 MyFaceTypes["plane"] = GeomAbs_Plane;
23 MyFaceTypes["cylinder"] = GeomAbs_Cylinder;
25 QString aType = QString(theType.c_str()).toLower();
26 if (MyFaceTypes.contains(aType))
27 return MyFaceTypes[aType];
29 Events_Error::send("Face type defined in XML is not implemented!");
33 bool ModuleBase_ValidatorFace::isValid(const AttributePtr& theAttribute,
34 const std::list<std::string>& theArguments) const
38 GeomAbs_SurfaceType aFaceType = GeomAbs_Plane;
39 if (theArguments.size() == 1) {
40 std::string anArgument = theArguments.front();
41 aFaceType = faceType(anArgument);
44 ObjectPtr anObject = ModuleBase_WidgetShapeSelector::getObject(theAttribute);
45 if (anObject.get() != NULL) {
46 AttributeSelectionPtr aSelectionAttr = std::dynamic_pointer_cast<ModelAPI_AttributeSelection>
48 std::shared_ptr<GeomAPI_Shape> aGeomShape = aSelectionAttr->value();
49 std::shared_ptr<GeomAPI_Face> aGeomFace(new GeomAPI_Face(aGeomShape));
50 if (aGeomFace.get() != NULL) {
53 aValid = aGeomFace->isPlanar();
55 case GeomAbs_Cylinder: