#include <ModelAPI_CompositeFeature.h>
+class PartSet_ExternalObjectsMgr;
/**
* \ingroup Modules
* Customosation of ModuleBase_WidgetShapeSelector in order to provide
-* working with sketch specific objects.
+* working with sketch specific objects and external objects.
*/
class PARTSET_EXPORT PartSet_WidgetShapeSelector: public ModuleBase_WidgetShapeSelector
{
/// \param theData the widget configuation. The attribute of the model widget is obtained from
/// \param theParentId is Id of a parent of the current attribute
PartSet_WidgetShapeSelector(QWidget* theParent, ModuleBase_IWorkshop* theWorkshop,
- const Config_WidgetAPI* theData, const std::string& theParentId)
- : ModuleBase_WidgetShapeSelector(theParent, theWorkshop, theData, theParentId) {}
+ const Config_WidgetAPI* theData, const std::string& theParentId);
- virtual ~PartSet_WidgetShapeSelector() {}
+ virtual ~PartSet_WidgetShapeSelector();
/// Set sketcher
/// \param theSketch a sketcher object
CompositeFeaturePtr sketch() const { return mySketch; }
protected:
- /// Saves the internal parameters to the given feature
- /// \return True in success
- virtual bool storeValueCustom() const;
+ /// Store the values to the model attribute of the widget. It casts this attribute to
+ /// the specific type and set the given values
+ /// \param theSelectedObject an object
+ /// \param theShape a selected shape, which is used in the selection attribute
+ virtual bool setObject(ObjectPtr theSelectedObject, GeomShapePtr theShape);
- /// Check the selected with validators if installed
- virtual bool isValid(ObjectPtr theObj, std::shared_ptr<GeomAPI_Shape> theShape);
+ /// Get the shape from the attribute if the attribute contain a shape
+ /// It processes the ref attr type of attributes. It obtains the referenced attribute,
+ /// results of the attribute feature. And it founds a vertes in the owners of the results
+ /// If the vertex is found, it creates a geom shape on it.
+ /// \return a shape
+ virtual GeomShapePtr getShape() const;
-private:
+ /// Creates a backup of the current values of the attribute
+ /// It should be realized in the specific widget because of different
+ /// parameters of the current attribute
+ /// \param theValid a boolean flag, if restore happens for valid parameters
+ void restoreAttributeValue(const bool theValid);
+
+ /// Found the sketch point attribute by the shape and set it in the feature attribute
+ /// otherwise set the selected object
+ /// \param theSelectedObject an object
+ /// \param theShape a selected shape, which is used in the selection attribute
+ void setPointAttribute(ObjectPtr theSelectedObject, GeomShapePtr theShape);
+
+protected:
+ PartSet_ExternalObjectsMgr* myExternalObjectMgr;
/// Pointer to a sketch
CompositeFeaturePtr mySketch;
};