/// \param theParent the parent object
/// \param theWorkshop instance of workshop interface
/// \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);
+ const Config_WidgetAPI* theData);
virtual ~PartSet_WidgetShapeSelector();
/// Retrurns installed sketcher
CompositeFeaturePtr sketch() const { return mySketch; }
+ /// Activate or deactivate selection and selection filters
+ /// \param toActivate boolean state whether it should be activated/deactivated
+ virtual bool activateSelectionAndFilters(bool toActivate);
+
protected:
/// Checks the widget validity. By default, it returns true.
/// \param thePrs a selected presentation in the view
/// \return a boolean value
- virtual bool isValidSelectionCustom(const ModuleBase_ViewerPrs& thePrs);
-
- /// 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
- /// \return true if it is succeed
- virtual void setObject(ObjectPtr theSelectedObject, GeomShapePtr theShape);
+ virtual bool isValidSelectionCustom(const std::shared_ptr<ModuleBase_ViewerPrs>& thePrs);
/// Return an object and geom shape by the viewer presentation
/// \param thePrs a selection
/// \param theObject an output object
/// \param theShape a shape of the selection
- virtual void getGeomSelection(const ModuleBase_ViewerPrs& thePrs,
+ virtual void getGeomSelection(const std::shared_ptr<ModuleBase_ViewerPrs>& thePrs,
ObjectPtr& theObject,
GeomShapePtr& 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;
-
/// 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 theAttribute an 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);
+ void restoreAttributeValue(const AttributePtr& theAttribute, const bool theValid);
protected:
/// A reference to external objects manager
/// Pointer to a sketch
CompositeFeaturePtr mySketch;
+
+ bool myUseSketchPlane; ///< state whether the sketch plane filter should be switched on
};
#endif
\ No newline at end of file