QLineEdit с пользовательской кнопкой

Мне нужно реализовать виджет LineEdit с возможностью добавления кнопок инструментов в правом конце текстовой области. Я знаю два способа сделать это, но оба решения кажутся безобразными.

1) добавить кнопки инструментов в качестве дочерних виджетов QLineEdit и обработать resizeEvent, чтобы правильно расположить их. Основным недостатком является то, что если текст достаточно длинный, он может появляться под кнопками инструментов.

2) Другое решение состоит в том, чтобы поместить редактирование строк и кнопки внутри фрейма и стиля перезаписи, чтобы скрыть фреймы строк и сделать QFrame похожим на QLineEdit.

Мне нужен лучший способ реализовать такой виджет. Также мой виджет должен знать стиль.

5

Решение

Оригинальный пост в блоге исчез, но Trolltech однажды опубликовал пример кнопки очистки для Qt 4.

Редактирование строки без текста:

Редактирование строки с некоторым текстом (появляется кнопка):

Редактирование строки с полным текстом (не идет под кнопкой):

lineedit.h

/****************************************************************************
**
** Copyright (c) 2007 Trolltech ASA <[email protected]>
**
** Use, modification and distribution is allowed without limitation,
** warranty, liability or support of any kind.
**
****************************************************************************/

#ifndef LINEEDIT_H
#define LINEEDIT_H

#include <QLineEdit>

class QToolButton;

class LineEdit : public QLineEdit
{
Q_OBJECT

public:
LineEdit(QWidget *parent = 0);

protected:
void resizeEvent(QResizeEvent *);

private slots:
void updateCloseButton(const QString &text);

private:
QToolButton *clearButton;
};

#endif // LIENEDIT_H

lineedit.cpp

/****************************************************************************
**
** Copyright (c) 2007 Trolltech ASA <[email protected]>
**
** Use, modification and distribution is allowed without limitation,
** warranty, liability or support of any kind.
**
****************************************************************************/

#include "lineedit.h"#include <QToolButton>
#include <QStyle>

LineEdit::LineEdit(QWidget *parent)
: QLineEdit(parent)
{
clearButton = new QToolButton(this);
QPixmap pixmap("fileclose.png");
clearButton->setIcon(QIcon(pixmap));
clearButton->setIconSize(pixmap.size());
clearButton->setCursor(Qt::ArrowCursor);
clearButton->setStyleSheet("QToolButton { border: none; padding: 0px; }");
clearButton->hide();
connect(clearButton, SIGNAL(clicked()), this, SLOT(clear()));
connect(this, SIGNAL(textChanged(const QString&)), this, SLOT(updateCloseButton(const QString&)));
int frameWidth = style()->pixelMetric(QStyle::PM_DefaultFrameWidth);
setStyleSheet(QString("QLineEdit { padding-right: %1px; } ").arg(clearButton->sizeHint().width() + frameWidth + 1));
QSize msz = minimumSizeHint();
setMinimumSize(qMax(msz.width(), clearButton->sizeHint().height() + frameWidth * 2 + 2),
qMax(msz.height(), clearButton->sizeHint().height() + frameWidth * 2 + 2));
}

void LineEdit::resizeEvent(QResizeEvent *)
{
QSize sz = clearButton->sizeHint();
int frameWidth = style()->pixelMetric(QStyle::PM_DefaultFrameWidth);
clearButton->move(rect().right() - frameWidth - sz.width(),
(rect().bottom() + 1 - sz.height())/2);
}

void LineEdit::updateCloseButton(const QString& text)
{
clearButton->setVisible(!text.isEmpty());
}
4

Другие решения

Начиная с Qt 5.2 можно использовать QLineEdit::addAction(...) вставить пользовательские кнопки. (Qt Docs)

Пример (предположим, что мы находимся внутри определения MyClass):

QLineEdit *myLineEdit = new QLineEdit(this);
QAction *myAction = myLineEdit->addAction(QIcon("test.png"), QLineEdit::TrailingPosition);
connect(myAction, &QAction::triggered, this, &MyClass::onActionTriggered);

введите описание изображения здесь

26

Однажды я реализовал такое решение для этого:

// LineEdit.h

#ifndef LINEEDIT_H
#define LINEEDIT_H

#include <QLineEdit>

class QToolButton;

class LineEdit : public QLineEdit
{
Q_OBJECT

public:
LineEdit(QWidget *parent = 0);

protected:
void resizeEvent(QResizeEvent *);

private:
QToolButton *furfurIcon;
};

#endif // LINEEDIT_H

// LineEdit.cpp

#include "lineedit.h"#include <QToolButton>
#include <QStyle>

LineEdit::LineEdit(QWidget *parent)
: QLineEdit(parent)
{
furfurIcon = new QToolButton(this);

QPixmap pixmap(":/root/your_icon");
furfurIcon->setIcon(QIcon(pixmap));
furfurIcon->setIconSize(pixmap.size());
furfurIcon->setCursor(Qt::ArrowCursor);
furfurIcon->setStyleSheet("QToolButton
"{""border: none; padding: 0px;""}");

setStyleSheet(QString("QLineEdit""{""border: 1px solid;""border-color: rgb(148, 168, 199);""border-radius: 10px;""background: white;""padding-left: %1px;""}").arg(furfurIcon->sizeHint().width() - 4));

setMinimumSize(0, 25);
}

void LineEdit::resizeEvent(QResizeEvent *)
{
QSize sz = furfurIcon->sizeHint();
furfurIcon->move(rect().left(), (rect().bottom() + 1 - sz.height()) / 2);
}

Позиция QToolButton обрабатывается в resizeEvent. Если их больше одного, вам придется корректировать их координаты. Также вы можете изменить его, чтобы использовать макет. Здесь нет совпадения текста.

1
По вопросам рекламы [email protected]