* Author: sbh
*/
-#include <XGUI_Constants.h>
#include <XGUI_PropertyPanel.h>
+#include <XGUI_Constants.h>
+#include <ModuleBase_WidgetPoint2D.h>
#include <QWidget>
#include <QVBoxLayout>
#include <iostream>
#endif
-XGUI_PropertyPanel::XGUI_PropertyPanel(QWidget* theParent)
+XGUI_PropertyPanel::XGUI_PropertyPanel(QWidget* theParent) :
+QDockWidget(theParent)
{
this->setWindowTitle(tr("Property Panel"));
QAction* aViewAct = this->toggleViewAction();
void XGUI_PropertyPanel::cleanContent()
{
- myWidgets.clear();
-
- QLayoutItem* aItem = myMainLayout->takeAt(myMainLayout->count() - 1);
- delete aItem;
-
- myMainLayout->removeWidget(myCustomWidget);
- delete myCustomWidget;
-
- myCustomWidget = new QWidget(widget());
- myMainLayout->addWidget(myCustomWidget);
- myMainLayout->addStretch(1);
+ myWidgets.clear();
+ qDeleteAll(myCustomWidget->children());
}
void XGUI_PropertyPanel::setModelWidgets(const QList<ModuleBase_ModelWidget*>& theWidgets)
connect(*anIt, SIGNAL(focusOutWidget(ModuleBase_ModelWidget*)),
this, SLOT(onActivateNextWidget(ModuleBase_ModelWidget*)));
+
+ //connect(*anIt, SIGNAL(activated(ModuleBase_ModelWidget*)),
+ // this, SIGNAL(widgetActivated(ModuleBase_ModelWidget*)));
+
+ ModuleBase_WidgetPoint2D* aPointWidget = dynamic_cast<ModuleBase_WidgetPoint2D*>(*anIt);
+ if (aPointWidget)
+ connect(aPointWidget, SIGNAL(storedPoint2D(ObjectPtr, const std::string&)),
+ this, SIGNAL(storedPoint2D(ObjectPtr, const std::string&)));
}
ModuleBase_ModelWidget* aLastWidget = theWidgets.last();
if (aLastWidget) {
setTabOrder(anOkBtn, aCancelBtn);
}
}
- ModuleBase_ModelWidget* aWidget = theWidgets.first();
- if (aWidget) {
- activateWidget(aWidget);
- }
+ onActivateNextWidget(0);
}
}
+const QList<ModuleBase_ModelWidget*>& XGUI_PropertyPanel::modelWidgets() const
+{
+ return myWidgets;
+}
+
bool XGUI_PropertyPanel::eventFilter(QObject *theObject, QEvent *theEvent)
{
QPushButton* anOkBtn = findChild<QPushButton*>(XGUI::PROP_PANEL_OK);
void XGUI_PropertyPanel::updateContentWidget(FeaturePtr theFeature)
{
foreach(ModuleBase_ModelWidget* eachWidget, myWidgets) {
- eachWidget->restoreValue(theFeature);
+ eachWidget->setFeature(theFeature);
+ eachWidget->restoreValue();
}
// the repaint is used here to immediatelly react in GUI to the values change.
repaint();
}
-void XGUI_PropertyPanel::onFocusActivated(const std::string& theAttributeName)
-{
- if (theAttributeName == XGUI::PROP_PANEL_OK) {
- QPushButton* aBtn = findChild<QPushButton*>(XGUI::PROP_PANEL_OK);
- aBtn->setFocus();
- }
- if (theAttributeName == XGUI::PROP_PANEL_CANCEL) {
- QPushButton* aBtn = findChild<QPushButton*>(XGUI::PROP_PANEL_CANCEL);
- aBtn->setFocus();
- }
- else {
- foreach(ModuleBase_ModelWidget* eachWidget, myWidgets) {
- if (eachWidget->canFocusTo(theAttributeName)) {
- eachWidget->focusTo();
- break;
- }
- }
- }
-}
-
void XGUI_PropertyPanel::onActivateNextWidget(ModuleBase_ModelWidget* theWidget)
{
ModuleBase_ModelWidget* aNextWidget = 0;
-
QList<ModuleBase_ModelWidget*>::const_iterator anIt = myWidgets.begin(),
aLast = myWidgets.end();
- for (;anIt != aLast; anIt++)
- {
- if ((*anIt) == theWidget) {
- anIt++;
- if (anIt != aLast)
+ bool isFoundWidget = false;
+ for (;anIt != aLast && !aNextWidget; anIt++) {
+ if (isFoundWidget || !theWidget) {
+ if ((*anIt)->focusTo()) {
aNextWidget = *anIt;
- break;
+ }
}
+ isFoundWidget = (*anIt) == theWidget;
}
- activateWidget(aNextWidget);
+ emit widgetActivated(aNextWidget);
}
-void XGUI_PropertyPanel::activateWidget(ModuleBase_ModelWidget* theWidget)
+void XGUI_PropertyPanel::setAcceptEnabled(bool isEnabled)
{
- if (theWidget)
- theWidget->focusTo();
- emit widgetActivated(theWidget);
+ QPushButton* anOkBtn = findChild<QPushButton*>(XGUI::PROP_PANEL_OK);
+ anOkBtn->setEnabled(isEnabled);
}