X-Git-Url: http://git.salome-platform.org/gitweb/?a=blobdiff_plain;f=src%2FModuleBase%2FModuleBase_WidgetChoice.cpp;h=5797e7cc8de201b0882d34a9a37610fe44bdf8cd;hb=d0e479afb535cd9d6542d53302428a5c8e99485f;hp=7156a0f453e1e1e32911853ff0f82bc1a1117aa5;hpb=3874b57fe5aba25ff5aee2a07654fc23c1ee8eb0;p=modules%2Fshaper.git diff --git a/src/ModuleBase/ModuleBase_WidgetChoice.cpp b/src/ModuleBase/ModuleBase_WidgetChoice.cpp index 7156a0f45..5797e7cc8 100644 --- a/src/ModuleBase/ModuleBase_WidgetChoice.cpp +++ b/src/ModuleBase/ModuleBase_WidgetChoice.cpp @@ -5,7 +5,8 @@ // Author: Vitaly Smetannikov #include "ModuleBase_WidgetChoice.h" -#include +#include "ModuleBase_Tools.h" +#include "ModuleBase_IconFactory.h" #include #include @@ -15,74 +16,163 @@ #include #include #include +#include +#include +#include +#include + ModuleBase_WidgetChoice::ModuleBase_WidgetChoice(QWidget* theParent, - const Config_WidgetAPI* theData, - const std::string& theParentId) - : ModuleBase_ModelWidget(theParent, theData, theParentId) + const Config_WidgetAPI* theData) +: ModuleBase_ModelWidget(theParent, theData), myCombo(0), myButtons(0) { - myContainer = new QWidget(theParent); - QHBoxLayout* aLayout = new QHBoxLayout(myContainer); + QHBoxLayout* aLayout = new QHBoxLayout(this); ModuleBase_Tools::adjustMargins(aLayout); QString aLabelText = QString::fromStdString(theData->widgetLabel()); QString aLabelIcon = QString::fromStdString(theData->widgetIcon()); - myLabel = new QLabel(aLabelText, myContainer); - if (!aLabelIcon.isEmpty()) - myLabel->setPixmap(QPixmap(aLabelIcon)); - aLayout->addWidget(myLabel); - - myCombo = new QComboBox(myContainer); - aLayout->addWidget(myCombo, 1); - std::string aTypes = theData->getProperty("string_list"); QStringList aList = QString(aTypes.c_str()).split(' '); - myCombo->addItems(aList); - connect(myCombo, SIGNAL(currentIndexChanged(int)), this, SLOT(onCurrentIndexChanged(int))); + if (theData->getBooleanAttribute("use_in_title", false)) + myButtonTitles = QString(aTypes.c_str()).split(" "); + + // Widget type can be combobox or radiobuttons + std::string aWgtType = theData->getProperty("widget_type"); + if ((aWgtType.length() > 0) && (aWgtType == "radiobuttons")) { + myButtons = new QButtonGroup(this); + QGroupBox* aGroupBox = new QGroupBox(aLabelText, this); + aLayout->addWidget(aGroupBox); + + + QLayout* aBtnLayout = 0; + std::string aWgtDir = theData->getProperty("buttons_dir"); + if (aWgtDir == "horizontal") + aBtnLayout = new QHBoxLayout(aGroupBox); + else + aBtnLayout = new QVBoxLayout(aGroupBox); + ModuleBase_Tools::adjustMargins(aBtnLayout); + + std::string aIcons = theData->getProperty("icons_list"); + QStringList aIconList = QString(aIcons.c_str()).split(' '); + if (aIconList.length() == aList.length()) { + int aId = 0; + foreach(QString aBtnTxt, aList) { + QToolButton* aBtn = new QToolButton(aGroupBox); + aBtn->setFocusPolicy(Qt::StrongFocus); + aBtn->setCheckable(true); + aBtn->setToolTip(aBtnTxt); + + QPixmap aIcon = ModuleBase_IconFactory::loadPixmap(aIconList.at(aId)); + aBtn->setIcon(aIcon); + aBtn->setIconSize(aIcon.size()); + + aBtnLayout->addWidget(aBtn); + myButtons->addButton(aBtn, aId++); + } + + } else { + int aId = 0; + foreach(QString aBtnTxt, aList) { + QRadioButton* aBtn = new QRadioButton(aBtnTxt, aGroupBox); + aBtnLayout->addWidget(aBtn); + myButtons->addButton(aBtn, aId++); + } + } + myButtons->button(0)->setChecked(true); + connect(myButtons, SIGNAL(buttonClicked(int)), this, SLOT(onCurrentIndexChanged(int))); + } else { + myLabel = new QLabel(aLabelText, this); + if (!aLabelIcon.isEmpty()) + myLabel->setPixmap(ModuleBase_IconFactory::loadPixmap(aLabelIcon)); + aLayout->addWidget(myLabel); + + std::string aToolstr = theData->widgetTooltip(); + if (!aToolstr.empty()) { + myLabel->setToolTip(QString::fromStdString(aToolstr)); + } + + myCombo = new QComboBox(this); + aLayout->addWidget(myCombo, 1); + + myCombo->addItems(aList); + + connect(myCombo, SIGNAL(currentIndexChanged(int)), this, SLOT(onCurrentIndexChanged(int))); + } } ModuleBase_WidgetChoice::~ModuleBase_WidgetChoice() { } -bool ModuleBase_WidgetChoice::storeValue() const +bool ModuleBase_WidgetChoice::storeValueCustom() { DataPtr aData = myFeature->data(); std::shared_ptr aIntAttr = aData->integer(attributeID()); - aIntAttr->setValue(myCombo->currentIndex()); + if (myCombo) + aIntAttr->setValue(myCombo->currentIndex()); + else + aIntAttr->setValue(myButtons->checkedId()); updateObject(myFeature); return true; } -bool ModuleBase_WidgetChoice::restoreValue() +bool ModuleBase_WidgetChoice::restoreValueCustom() { DataPtr aData = myFeature->data(); std::shared_ptr aIntAttr = aData->integer(attributeID()); - bool isBlocked = myCombo->blockSignals(true); - myCombo->setCurrentIndex(aIntAttr->value()); - myCombo->blockSignals(isBlocked); + if (aIntAttr->value() != -1) { + if (myCombo) { + bool isBlocked = myCombo->blockSignals(true); + myCombo->setCurrentIndex(aIntAttr->value()); + myCombo->blockSignals(isBlocked); + } else { + bool isBlocked = myButtons->blockSignals(true); + myButtons->button(aIntAttr->value())->setChecked(true); + myButtons->blockSignals(isBlocked); + emit itemSelected(this, aIntAttr->value()); + } + } return true; } bool ModuleBase_WidgetChoice::focusTo() { - myCombo->setFocus(); + if (myCombo) + ModuleBase_Tools::setFocus(myCombo, "ModuleBase_WidgetChoice::focusTo()"); + else + return false; return true; } QList ModuleBase_WidgetChoice::getControls() const { QList aControls; - aControls.append(myCombo); + if (myCombo) + aControls.append(myCombo); + //else { + // //foreach(QAbstractButton* aBtn, myButtons->buttons()) + // //if (myButtons->checkedId() != -1) + // // aControls.append(myButtons->button(myButtons->checkedId())); + //} return aControls; } +QString ModuleBase_WidgetChoice::getPropertyPanelTitle(int theIndex) +{ + QString aTitle; + if (myButtonTitles.length() > theIndex) + aTitle = tr(myButtonTitles[theIndex].toStdString().c_str()); + return aTitle; +} + void ModuleBase_WidgetChoice::onCurrentIndexChanged(int theIndex) { emit valuesChanged(); // Don't transfer focus // emit focusOutWidget(this); + + emit itemSelected(this, theIndex); }