#include <ModuleBase_WidgetValidated.h>
#include <ModuleBase_ViewerFilters.h>
-#include <GeomAPI_Pnt.h>
#include <GeomAPI_Dir.h>
-#include <GeomAPI_AISObject.h>
#include <TopoDS_Shape.hxx>
#include <QMap>
+class PartSet_PreviewPlanes;
+
class QLabel;
class XGUI_OperationMgr;
class XGUI_Workshop;
class QCheckBox;
class QStackedWidget;
-
-/// the plane edge width
-#define SKETCH_WIDTH "4"
-
-/// face of the square-face displayed for selection of general plane
-#define PLANE_SIZE "200"
+class QLineEdit;
/**
* \ingroup Modules
/// It is redefined to do nothing if the plane of the sketch has been already set.
/// \param theValues the wrapped selection values
/// \param theToValidate a validation flag
- virtual bool setSelection(QList<ModuleBase_ViewerPrs>& theValues,
+ virtual bool setSelection(QList<std::shared_ptr<ModuleBase_ViewerPrs>>& theValues,
const bool theToValidate);
/// Returns list of widget controls
virtual void setHighlighted(bool) { /*do nothing*/ };
virtual void enableFocusProcessing();
+ /// Returns True if the selected presentation can be used for plane definition
+ /// \param thePrs a presentation
+ static bool canFillSketch(const std::shared_ptr<ModuleBase_ViewerPrs>& thePrs);
+
+ /// Set sketch plane from selected object
+ /// \param theFeature a feature of sketch
+ /// \param thePrs a presentation
static bool fillSketchPlaneBySelection(const FeaturePtr& theFeature,
- const ModuleBase_ViewerPrs& thePrs);
+ const std::shared_ptr<ModuleBase_ViewerPrs>& thePrs);
signals:
/// Signal on plane selection
/// 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
- virtual void storeAttributeValue();
+ /// \param theAttribute an attribute to be stored
+ virtual void storeAttributeValue(const AttributePtr& theAttribute);
/// 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 to be restored
/// \param theValid a boolean flag, if restore happens for valid parameters
- virtual void restoreAttributeValue(const bool theValid);
+ virtual void restoreAttributeValue(const AttributePtr& theAttribute,
+ const bool theValid);
/// Fills the attribute with the value of the selected owner
/// \param thePrs a selected owner
- virtual bool setSelectionCustom(const ModuleBase_ViewerPrs& thePrs);
+ virtual bool setSelectionCustom(const std::shared_ptr<ModuleBase_ViewerPrs>& thePrs);
/// Saves the internal parameters to the given feature
/// \return True in success
- virtual bool storeValueCustom() const
+ virtual bool storeValueCustom()
{
return true;
}
/// Block the model flush of update and intialization of attribute
/// In additional to curstom realization it blocks initialization for all feature attributes
/// as the current attribute is selection but its modification leads to other attributes change
+ /// \param theAttribute an attribute
/// \param theToBlock flag whether the model is blocked or unblocked
- /// \param isActive out value if model is blocked, in value if model is unblocked
+ /// \param isFlushesActived out value if model is blocked, in value if model is unblocked
/// to be used to restore flush state when unblocked
/// \param isAttributeSetInitializedBlocked out value if model is blocked
/// in value if model is unblocked to be used to restore previous state when unblocked
- virtual void blockAttribute(const bool& theToBlock, bool& isFlushesActived,
+ virtual void blockAttribute(const AttributePtr& theAttribute, const bool& theToBlock,
+ bool& isFlushesActived,
bool& isAttributeSetInitializedBlocked);
+ /// Set the given wrapped value to the current widget
+ /// This value should be processed in the widget according to the needs
+ /// The method is called by the current operation to process the operation preselection.
+ /// It is redefined to do nothing if the plane of the sketch has been already set.
+ /// \param theValues the wrapped selection values
+ /// \param theToValidate a validation flag
+ bool setSelectionInternal(const QList<std::shared_ptr<ModuleBase_ViewerPrs>>& theValues,
+ const bool theToValidate);
+
/// Erase preview planes, disconnect widget, change the view projection
/// \param thePrs a selected presentation
- void updateByPlaneSelected(const ModuleBase_ViewerPrs& thePrs);
+ void updateByPlaneSelected(const std::shared_ptr<ModuleBase_ViewerPrs>& thePrs);
protected:
/// Activate or deactivate selection
void onShowConstraint(bool theOn);
private:
- /// Create preview of planes for sketch plane selection
- /// \param theOrigin an origin of the plane
- /// \param theNorm a normal vector of the plane
- /// \param theRGB a color of plane presentation [r, g, b] array
- AISObjectPtr createPreviewPlane(std::shared_ptr<GeomAPI_Pnt> theOrigin,
- std::shared_ptr<GeomAPI_Dir> theNorm,
- const int theRGB[3]);
-
- //! Returns workshop
- XGUI_Workshop* workshop() const;
-
/// Set sketch plane by shape
/// \param theShape a planar face
static std::shared_ptr<GeomAPI_Dir> setSketchPlane(const FeaturePtr& theFeature,
const TopoDS_Shape& theShape);
- /// Erase preview planes
- void erasePreviewPlanes();
-
- /// Show preview planes
- void showPreviewPlanes();
-
- AISObjectPtr myYZPlane;
- AISObjectPtr myXZPlane;
- AISObjectPtr myXYPlane;
- bool myPreviewDisplayed;
+private:
+ /// class to show/hide preview planes
+ PartSet_PreviewPlanes* myPreviewPlanes;
QCheckBox* myViewInverted;
QMap<PartSet_Tools::ConstraintVisibleState, QCheckBox*> myShowConstraints;
+ QWidget* mySizeOfViewWidget;
QStackedWidget* myStackWidget;
+ QLineEdit* mySizeOfView;
};
#endif