X-Git-Url: http://git.salome-platform.org/gitweb/?a=blobdiff_plain;f=src%2FModuleBase%2FModuleBase_WidgetLineEdit.cpp;h=54223e6d26c0082e5ffaa975afad732a02b34de1;hb=3b676e8f67d0b110ecee42985223b99fc181532b;hp=bf311c59f51979de549a89f7b5754f28ea104a3a;hpb=758a57d77b6fa3a0485fa3378a1280c7e87a74aa;p=modules%2Fshaper.git diff --git a/src/ModuleBase/ModuleBase_WidgetLineEdit.cpp b/src/ModuleBase/ModuleBase_WidgetLineEdit.cpp index bf311c59f..54223e6d2 100644 --- a/src/ModuleBase/ModuleBase_WidgetLineEdit.cpp +++ b/src/ModuleBase/ModuleBase_WidgetLineEdit.cpp @@ -1,3 +1,5 @@ +// Copyright (C) 2014-20xx CEA/DEN, EDF R&D + /* * ModuleBase_WidgetLineEdit.cpp * @@ -15,39 +17,95 @@ #include -#include +#include #include #include #include #include +#include +#include -#include +#include #include +/** +* Customization of Line edit control +*/ +class CustomLineEdit : public QLineEdit +{ +public: + /// Constructor + /// \param theParent a parent widget + /// \param thePlaceHolder a string which is shown when text is empty + CustomLineEdit( QWidget* theParent, const QString& thePlaceHolder ) + : QLineEdit( theParent ), myPlaceHolder( thePlaceHolder ) + { + } + + virtual ~CustomLineEdit() + { + } + + /// Redefiniotion of virtual method + /// \param theEvent a paint event + virtual void paintEvent( QPaintEvent* theEvent ) + { + QLineEdit::paintEvent( theEvent ); + if( text().isEmpty() && !myPlaceHolder.isEmpty() ) + { + QPainter aPainter( this ); + QRect aRect = rect(); + int aHorMargin = 5; + aRect.adjust( aHorMargin, 0, 0, 0 ); + + QColor aColor = palette().text().color(); + aColor.setAlpha( 128 ); + QPen anOldpen = aPainter.pen(); + aPainter.setPen( aColor ); + QFontMetrics aFontMetrics = fontMetrics(); + QString elidedText = aFontMetrics.elidedText( myPlaceHolder, Qt::ElideRight, aRect.width() ); + aPainter.drawText( aRect, Qt::AlignLeft | Qt::AlignVCenter, elidedText ); + aPainter.setPen( anOldpen ); + } + } + +private: + QString myPlaceHolder; +}; + ModuleBase_WidgetLineEdit::ModuleBase_WidgetLineEdit(QWidget* theParent, const Config_WidgetAPI* theData, - const std::string& theParentId) - : ModuleBase_ModelWidget(theParent, theData, theParentId) + const std::string& thePlaceHolder ) +: ModuleBase_ModelWidget(theParent, theData) { - myMainWidget = new QWidget(theParent); - QHBoxLayout* aMainLay = new QHBoxLayout(myMainWidget); + QFormLayout* aMainLay = new QFormLayout(this); ModuleBase_Tools::adjustMargins(aMainLay); - QString aTitle = QString::fromStdString(theData->widgetLabel()); - QLabel* aTitleLabel = new QLabel(aTitle, myMainWidget); - aMainLay->addWidget(aTitleLabel); - myLineEdit = new QLineEdit(myMainWidget); - aMainLay->addWidget(myLineEdit); + QString aLabelText = QString::fromStdString(theData->widgetLabel()); + QString aLabelIcon = QString::fromStdString(theData->widgetIcon()); + QLabel* aLabel = new QLabel(aLabelText, this); + if (!aLabelIcon.isEmpty()) + aLabel->setPixmap(QPixmap(aLabelIcon)); + + myLineEdit = new CustomLineEdit( this, QString::fromStdString( thePlaceHolder ) ); + // Here we do not use the Qt's standard method setPlaceHolderText() since it + // draws the place holder only if there is no focus on widget; + // we would like to see the place holder in the case of empty text + // even if the widget is focused. + // The corresponding patch appears in Qt only since version 5.x + myLineEdit->setMinimumHeight(20); - myMainWidget->setLayout(aMainLay); - connect(myLineEdit, SIGNAL(textChanged(const QString&)), this, SLOT(onTextChanged())); + aMainLay->addRow(aLabel, myLineEdit); + this->setLayout(aMainLay); + + connect(myLineEdit, SIGNAL(textChanged(const QString&)), this, SIGNAL(valuesModified())); } ModuleBase_WidgetLineEdit::~ModuleBase_WidgetLineEdit() { } -bool ModuleBase_WidgetLineEdit::storeValue() const +bool ModuleBase_WidgetLineEdit::storeValueCustom() { // A rare case when plugin was not loaded. if(!myFeature) @@ -60,7 +118,7 @@ bool ModuleBase_WidgetLineEdit::storeValue() const return true; } -bool ModuleBase_WidgetLineEdit::restoreValue() +bool ModuleBase_WidgetLineEdit::restoreValueCustom() { // A rare case when plugin was not loaded. if(!myFeature) @@ -75,11 +133,6 @@ bool ModuleBase_WidgetLineEdit::restoreValue() return true; } -QWidget* ModuleBase_WidgetLineEdit::getControl() const -{ - return myMainWidget; -} - QList ModuleBase_WidgetLineEdit::getControls() const { QList result; @@ -87,7 +140,12 @@ QList ModuleBase_WidgetLineEdit::getControls() const return result; } -void ModuleBase_WidgetLineEdit::onTextChanged() +bool ModuleBase_WidgetLineEdit::processEnter() { - storeValue(); + bool isModified = getValueState() == ModifiedInPP; + if (isModified) { + emit valuesChanged(); + myLineEdit->selectAll(); + } + return isModified; }