+// Copyright (C) 2014-20xx CEA/DEN, EDF R&D
+
// File: ModuleBase_WidgetShapeSelector.h
// Created: 2 June 2014
// Author: Vitaly Smetannikov
#include "ModuleBase.h"
#include "ModuleBase_ModelWidget.h"
+#include "ModuleBase_ViewerFilters.h"
#include <ModelAPI_Object.h>
+#include <GeomAPI_Shape.h>
#include <TopAbs_ShapeEnum.hxx>
#include <QStringList>
-#include <QPalette>
class Config_WidgetAPI;
class QWidget;
virtual ~ModuleBase_WidgetShapeSelector();
/// Saves the internal parameters to the given feature
- /// \param theObject a model feature to be changed
virtual bool storeValue() const;
virtual bool restoreValue();
- virtual bool focusTo();
-
/// Returns the internal parent wiget control, that can be shown anywhere
/// \returns the widget
QWidget* getControl() const
/// Set the given wrapped value to the current widget
/// This value should be processed in the widget according to the needs
/// \param theValue the wrapped widget value
- virtual bool setValue(ModuleBase_WidgetValue* theValue);
+ virtual bool setSelection(ModuleBase_ViewerPrs theValue);
+
+
+ /// The methiod called when widget is activated
+ virtual void activate();
-public slots:
+ /// The methiod called when widget is deactivated
+ virtual void deactivate();
+
+
+ public slots:
/// Activate or deactivate selection
void activateSelection(bool toActivate);
-private slots:
+ private slots:
void onSelectionChanged();
-protected:
- bool eventFilter(QObject* theObj, QEvent* theEvent);
-
-private:
+ protected:
void updateSelectionName();
void raisePanel() const;
- bool isAccepted(const ObjectPtr theObject) const;
+
+ /// Returns true if shape of given object corresponds to requested shape type
+ /// This method is called only in non sub-shapes selection mode
+ virtual bool acceptObjectShape(const ObjectPtr theObject) const;
+
+ /// Returns true if selected shape corresponds to requested shape types
+ /// This method is called only in sub-shapes selection mode
+ virtual bool acceptSubShape(std::shared_ptr<GeomAPI_Shape> theShape) const;
+
+ /// Returns true if selected object corresponds to requested Object type
+ /// Thid method is used in any selection mode
+ virtual bool acceptObjectType(const ObjectPtr theObject) const;
+
// Set the given object as a value of the widget
- void setObject(ObjectPtr theObj);
+ void setObject(ObjectPtr theObj, std::shared_ptr<GeomAPI_Shape> theShape = std::shared_ptr<GeomAPI_Shape>());
+
+ /// Check the selected with validators if installed
+ virtual bool isValid(ObjectPtr theObj, std::shared_ptr<GeomAPI_Shape> theShape);
+ /// Clear attribute
+ void clearAttribute();
+
+ //----------- Class members -------------
+ protected:
QWidget* myContainer;
QLabel* myLabel;
QLineEdit* myTextLine;
- //QToolButton* myActivateBtn;
ModuleBase_IWorkshop* myWorkshop;
ObjectPtr mySelectedObject;
+ std::shared_ptr<GeomAPI_Shape> myShape;
+
QStringList myShapeTypes;
+ QStringList myObjectTypes;
- QPalette myBasePalet;
- QPalette myInactivePalet;
+ /// If true then local selector has to be activated in context
+ bool myUseSubShapes;
bool myIsActive;
+
+ Handle(ModuleBase_ObjectTypesFilter) myObjTypeFilter;
};
#endif