X-Git-Url: http://git.salome-platform.org/gitweb/?a=blobdiff_plain;f=src%2FModuleBase%2FModuleBase_WidgetFactory.cpp;h=dec5f78ab6efc24d0e717b0b784ca7128f3e0052;hb=2413ba5e387ebc030eb89aaad917991844ae518d;hp=9437d5de6d5f1bf32588b65e32e4606539f0cc16;hpb=6df60c642d0427e2cb42bd29e2c64d4e5dbdaee4;p=modules%2Fshaper.git diff --git a/src/ModuleBase/ModuleBase_WidgetFactory.cpp b/src/ModuleBase/ModuleBase_WidgetFactory.cpp index 9437d5de6..dec5f78ab 100644 --- a/src/ModuleBase/ModuleBase_WidgetFactory.cpp +++ b/src/ModuleBase/ModuleBase_WidgetFactory.cpp @@ -1,3 +1,5 @@ +// Copyright (C) 2014-20xx CEA/DEN, EDF R&D + /* * ModuleBase_WidgetFactory.cpp * @@ -7,11 +9,33 @@ #include -#include +#include #include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include + +#include +#include -#include -#include #include #include @@ -32,184 +56,144 @@ #include #include -ModuleBase_WidgetFactory::ModuleBase_WidgetFactory(ModuleBase_Operation* theOperation) - : myOperation(theOperation) +ModuleBase_WidgetFactory::ModuleBase_WidgetFactory(const std::string& theXmlRepresentation, + ModuleBase_IWorkshop* theWorkshop) + : myWorkshop(theWorkshop) { - QString aXml = myOperation->getDescription()->xmlRepresentation(); - myWidgetApi = new Config_WidgetAPI(aXml.toStdString()); + myWidgetApi = new Config_WidgetAPI(theXmlRepresentation); } ModuleBase_WidgetFactory::~ModuleBase_WidgetFactory() { + delete myWidgetApi; } -void ModuleBase_WidgetFactory::createWidget(QWidget* theParent) +void ModuleBase_WidgetFactory::createWidget(ModuleBase_PageBase* thePage) { + myParentId = myWidgetApi->widgetId(); if (!myWidgetApi->toChildWidget()) return; - QVBoxLayout* aWidgetLay = new QVBoxLayout(theParent); - aWidgetLay->setContentsMargins(2, 2, 2, 2); - do { //Iterate over each node + do { //Iterate over each node std::string aWdgType = myWidgetApi->widgetType(); - //Create a widget (doublevalue, groupbox, toolbox, etc. - QWidget* aWidget = createWidgetByType(aWdgType, theParent); - if (aWidget) { - aWidgetLay->addWidget(aWidget); - } - if (myWidgetApi->isContainerWidget()) { + // Create PageGroup TODO: extract + if (myWidgetApi->isGroupBoxWidget() || + ModuleBase_WidgetCreatorFactory::get()->hasPageWidget(aWdgType)) { + //if current widget is groupbox (container) process it's children recursively - QString aGroupName = qs(myWidgetApi->getProperty(CONTAINER_PAGE_NAME)); - createWidget(aWidget); - QGroupBox* aGrBox = qobject_cast(aWidget); - aGrBox->setTitle(aGroupName); - } - if (myWidgetApi->isPagedWidget()) { - //If current widget is toolbox or switch-casebox then fetch all - //it's pages recursively and setup into the widget. - myWidgetApi->toChildWidget(); - do { - QString aPageName = qs(myWidgetApi->getProperty(CONTAINER_PAGE_NAME)); - QWidget* aPage = new QWidget(aWidget); - createWidget(aPage); - if (aWdgType == WDG_SWITCH) { - ModuleBase_WidgetSwitch* aSwitch = qobject_cast(aWidget); - aSwitch->addPage(aPage, aPageName); - } else if (aWdgType == WDG_TOOLBOX){ - QToolBox* aToolbox = qobject_cast(aWidget); - aToolbox->addItem(aPage, aPageName); + ModuleBase_PageBase* aPage = createPageByType(aWdgType, thePage->pageWidget()); + + createWidget(aPage); + thePage->addPageWidget(aPage); + } else { + // Create a ModelWidget + ModuleBase_ModelWidget* aWidget = createWidgetByType(aWdgType, thePage->pageWidget()); + if (aWidget) { + if (!myWidgetApi->getBooleanAttribute(ATTR_INTERNAL, false)) { + thePage->addModelWidget(aWidget); + } else { + aWidget->setVisible(false); } - } while(myWidgetApi->toNextWidget()); + } + // Create PagedContainer TODO: extract + if (myWidgetApi->isPagedWidget()) { + //If current widget is toolbox or switch-casebox then fetch all + //it's pages recursively and setup into the widget. + myWidgetApi->toChildWidget(); + do { + QString aPageName = qs(myWidgetApi->getProperty(CONTAINER_PAGE_NAME)); + QString aCaseId = qs(myWidgetApi->getProperty(_ID)); + ModuleBase_PageBase* aPage = new ModuleBase_PageWidget(aWidget); + createWidget(aPage); + if (aWdgType == WDG_SWITCH || aWdgType == WDG_TOOLBOX) { + ModuleBase_PagedContainer* aContainer = qobject_cast(aWidget); + + QString anIconPath = qs( myWidgetApi->getProperty( CONTAINER_PAGE_ICON ) ); + QPixmap anIcon( anIconPath ); + aContainer->addPage( aPage, aPageName, aCaseId, anIcon ); + } + } while (myWidgetApi->toNextWidget()); + } } - } while(myWidgetApi->toNextWidget()); - theParent->setLayout(aWidgetLay); -} + } while (myWidgetApi->toNextWidget()); -QWidget* ModuleBase_WidgetFactory::labelControl(QWidget* theParent) -{ - QWidget* result = new QWidget(theParent); - QVBoxLayout* aLabelLay = new QVBoxLayout(result); - QLabel* aLabel = new QLabel(result); - aLabel->setText(qs(myWidgetApi->getProperty(INFO_WDG_TEXT))); - aLabel->setToolTip(qs(myWidgetApi->getProperty(INFO_WDG_TOOLTIP))); - aLabelLay->addWidget(aLabel); - aLabelLay->addStretch(1); - result->setLayout(aLabelLay); - return result; + thePage->alignToTop(); } -QWidget* ModuleBase_WidgetFactory::createWidgetByType(const std::string& theType, QWidget* theParent) +ModuleBase_PageBase* ModuleBase_WidgetFactory::createPageByType(const std::string& theType, + QWidget* theParent) { - QWidget* result = NULL; - if (theType == WDG_DOUBLEVALUE) { - result = doubleSpinBoxControl(); - } else if (theType == WDG_INFO) { - result = labelControl(theParent); - } - else if (theType == WDG_POINT_SELECTOR) { - result = pointSelectorControl(theParent); - } - else if (myWidgetApi->isContainerWidget() || myWidgetApi->isPagedWidget()) { - result = createContainer(theType, theParent); + ModuleBase_PageBase* aResult = NULL; + + if (theType == WDG_GROUP) { + QString aGroupName = qs(myWidgetApi->getProperty(CONTAINER_PAGE_NAME)); + ModuleBase_PageGroupBox* aPage = new ModuleBase_PageGroupBox(theParent); + aPage->setTitle(aGroupName); + aResult = aPage; } -#ifdef _DEBUG - else { qDebug() << "ModuleBase_WidgetFactory::fillWidget: find bad widget type"; } -#endif - return result; + + if (!aResult) + aResult = ModuleBase_WidgetCreatorFactory::get()->createPageByType(theType, theParent); + + return aResult; } -QWidget* ModuleBase_WidgetFactory::createContainer(const std::string& theType, QWidget* theParent) +ModuleBase_ModelWidget* ModuleBase_WidgetFactory::createWidgetByType(const std::string& theType, + QWidget* theParent) { - QWidget* result = NULL; - if (theType == WDG_GROUP || theType == WDG_CHECK_GROUP) { - QGroupBox* aGroupBox = new QGroupBox(theParent); - aGroupBox->setCheckable(theType == WDG_CHECK_GROUP); - result = aGroupBox; + ModuleBase_ModelWidget* result = NULL; + + if (theType == WDG_INFO) { + result = new ModuleBase_WidgetLabel(theParent, myWidgetApi, myParentId); + } else if (theType == WDG_ERRORINFO) { + result = new ModuleBase_WidgetErrorLabel(theParent, myWidgetApi, myParentId); + } else if (theType == WDG_DOUBLEVALUE) { + result = new ModuleBase_WidgetDoubleValue(theParent, myWidgetApi, myParentId); + } else if (theType == WDG_INTEGERVALUE) { + result = new ModuleBase_WidgetIntValue(theParent, myWidgetApi, myParentId); + } else if (theType == WDG_SHAPE_SELECTOR) { + result = new ModuleBase_WidgetShapeSelector(theParent, myWorkshop, myWidgetApi, myParentId); + } else if (theType == WDG_BOOLVALUE) { + result = new ModuleBase_WidgetBoolValue(theParent, myWidgetApi, myParentId); + //} else if (theType == WDG_DOUBLEVALUE_EDITOR) { + // result = new ModuleBase_WidgetEditor(theParent, myWidgetApi, myParentId); + } else if (theType == WDG_FILE_SELECTOR) { + result = new ModuleBase_WidgetFileSelector(theParent, myWidgetApi, myParentId); + } else if (theType == WDG_CHOICE) { + result = new ModuleBase_WidgetChoice(theParent, myWidgetApi, myParentId); + } else if (theType == WDG_STRINGVALUE) { + std::string aPlaceHolder = myWidgetApi->getProperty( WDG_PLACE_HOLDER ); + result = new ModuleBase_WidgetLineEdit( theParent, myWidgetApi, myParentId, aPlaceHolder ); + } else if (theType == WDG_EXPR_EDITOR) { + std::string aPlaceHolder = myWidgetApi->getProperty( WDG_PLACE_HOLDER ); + result = new ModuleBase_WidgetExprEditor( theParent, myWidgetApi, myParentId, aPlaceHolder ); + } else if (theType == WDG_MULTISELECTOR) { + result = new ModuleBase_WidgetMultiSelector(theParent, myWorkshop, myWidgetApi, myParentId); } else if (theType == WDG_TOOLBOX) { - result = new QToolBox(theParent); + result = new ModuleBase_WidgetToolbox(theParent, myWidgetApi, myParentId); } else if (theType == WDG_SWITCH) { - result = new ModuleBase_WidgetSwitch(theParent); - } else if (theType == WDG_TOOLBOX_BOX || theType == WDG_SWITCH_CASE) { + result = new ModuleBase_WidgetSwitch(theParent, myWidgetApi, myParentId); + } else if (theType == WDG_TOOLBOX_BOX || theType == WDG_SWITCH_CASE || + theType == NODE_VALIDATOR) { + // Do nothing for "box" and "case" result = NULL; - } -#ifdef _DEBUG - else { qDebug() << "ModuleBase_WidgetFactory::fillWidget: find bad container type"; } -#endif - return result; -} - -QWidget* ModuleBase_WidgetFactory::doubleSpinBoxControl() -{ - QWidget* result = new QWidget(); - QHBoxLayout* aControlLay = new QHBoxLayout(result); - aControlLay->setContentsMargins(0, 0, 0, 0); - QString aLabelText = qs(myWidgetApi->widgetLabel()); - QString aLabelIcon = qs(myWidgetApi->widgetIcon()); - QLabel* aLabel = new QLabel(aLabelText); - aLabel->setPixmap(QPixmap(aLabelIcon)); - - aControlLay->addWidget(aLabel); - QDoubleSpinBox* aBox = new QDoubleSpinBox(result); - QString anObjName = QString::fromStdString(myWidgetApi->widgetId()); - aBox->setObjectName(anObjName); - bool isOk = false; - std::string aProp = myWidgetApi->getProperty(DOUBLE_WDG_MIN); - double aMinVal = qs(aProp).toDouble(&isOk); - if (isOk) { - aBox->setMinimum(aMinVal); } else { - aBox->setMinimum(-DBL_MAX); - } - aProp = myWidgetApi->getProperty(DOUBLE_WDG_MAX); - double aMaxVal = qs(aProp).toDouble(&isOk); - if (isOk) { - aBox->setMaximum(aMaxVal); - } else { - aBox->setMaximum(DBL_MAX); - } - aProp = myWidgetApi->getProperty(DOUBLE_WDG_STEP); - double aStepVal = qs(aProp).toDouble(&isOk); - if (isOk) { - aBox->setSingleStep(aStepVal); - } - aProp = myWidgetApi->getProperty(DOUBLE_WDG_DFLT); - double aDefVal = qs(aProp).toDouble(&isOk); - if (isOk) { - aBox->setValue(aDefVal); - } - QString aTTip = qs(myWidgetApi->widgetTooltip()); - aBox->setToolTip(aTTip); - aControlLay->addWidget(aBox); - aControlLay->setStretch(1, 1); - result->setLayout(aControlLay); - connectWidget(aBox, WDG_DOUBLEVALUE); - return result; -} - -QWidget* ModuleBase_WidgetFactory::pointSelectorControl(QWidget* theParent) -{ - ModuleBase_WidgetPoint2D* aWidget = new ModuleBase_WidgetPoint2D(theParent, - qs(myWidgetApi->getProperty(CONTAINER_PAGE_NAME)), myWidgetApi->widgetId()); - connectWidget(aWidget, WDG_POINT_SELECTOR); - return aWidget->getControl(); -} - -bool ModuleBase_WidgetFactory::connectWidget(QObject* theWidget, const QString& theType) -{ - bool result = false; - if (theType == WDG_DOUBLEVALUE) { - result = QObject::connect(theWidget, SIGNAL(valueChanged(double)), - myOperation, SLOT(storeReal(double))); - } - if (theType == WDG_POINT_SELECTOR) { - ModuleBase_WidgetCustom* aCustom = dynamic_cast(theWidget); - result = QObject::connect(aCustom, SIGNAL(valuesChanged()), - myOperation, SLOT(storeCustomValue())); + result = myWorkshop->module()->createWidgetByType(theType, theParent, myWidgetApi, myParentId); + if (!result) + result = ModuleBase_WidgetCreatorFactory::get()->createWidgetByType(theType, theParent); + #ifdef _DEBUG + if (!result) { + qDebug("ModuleBase_WidgetFactory::fillWidget: find bad widget type %s", theType.c_str()); + } + #endif } + if (result) + myModelWidgets.append(result); return result; } -QString ModuleBase_WidgetFactory::qs(const std::string& theStdString) const +QString ModuleBase_WidgetFactory::qs(const std::string& theStdString) { return QString::fromStdString(theStdString); } +