1. 程式人生 > >Qt淺談之四十一QLineEdit的新樣式和補全歷史記錄

Qt淺談之四十一QLineEdit的新樣式和補全歷史記錄

一、簡介

       利用背景圖片設計出QLineEdit新的樣式,起到美化介面的效果,並增加自動補全歷史記錄的功能,就可以作為一個完整的庫。
 

二、詳解

1、知識點

(1)切換QLineEdit的背景

void InnerLineEdit::setNormal()
{
    setText("");
    setTextMargins(-5,0,this->height(),0);    //solve the cursor problem
    setStyleSheet("background-image:url(:/searchInput.png);border:1px solid #536874;");
}

void InnerLineEdit::setSearching()
{
    setTextMargins(0,0,this->height(),0);
    setStyleSheet("background-image:url(:/searchInput_click.png);border:1px solid #536874;");
}
(2)QLineEdit模糊匹配
    QCompleter *completer = new QCompleter(this);
    listModel = new QStringListModel(valueList, this);
    completer->setCaseSensitivity(Qt::CaseInsensitive);
    completer->setModel(listModel);
    this->setCompleter(completer);
(3)記錄歷史輸入
connect(this, SIGNAL(editingFinished()), this, SLOT(editComplete()));
void InnerLineEdit::editComplete()
{
    QString text = this->text();
    if(QString::compare(text, QString("")) != 0) {
        bool flag = valueList.contains(text, Qt::CaseInsensitive);
        if(!flag) {
            addValue(text);
        }
    }
}

2、完整程式碼

(1)searchlineedit.h
#ifndef SEARCHLINEEDIT_H
#define SEARCHLINEEDIT_H

#include <QtGui>
class InnerLineEdit;
class SearchLineEdit : public QWidget
{
    Q_OBJECT

public:
    SearchLineEdit(QWidget *parent = 0);
    ~SearchLineEdit();

protected:
    void resizeEvent(QResizeEvent *event);

signals:
    void searchTextChanged(QString);

private slots:
    void textChange(QString text);
    void editClicked();
    void btnClicked();

private:
    InnerLineEdit *lineEdit;
    QPushButton *btn;
};

class InnerLineEdit : public QLineEdit
{
    Q_OBJECT

 public:
    explicit InnerLineEdit(QWidget *parent = 0);
    void setNormal();
    void setSearching();
    void addValue(const QString &value);

protected:
   void focusInEvent(QFocusEvent *event);
   void focusOutEvent(QFocusEvent *event);

 signals:
    void pressed();

private slots:
    void editComplete();

private:
    QStringList valueList;
    QStringListModel *listModel;
};

#endif // SEARCHLINEEDIT_H
(2)searchlineedit.cpp
#include "searchlineedit.h"

SearchLineEdit::SearchLineEdit(QWidget *parent)
    : QWidget(parent)
{
    lineEdit = new InnerLineEdit(this);
    lineEdit->move(8,38);
    lineEdit->resize(168,23);
    connect(lineEdit,SIGNAL(textChanged(QString)),this,SLOT(textChange(QString)));
    connect(lineEdit,SIGNAL(pressed()),this,SLOT(editClicked()));

    btn = new QPushButton(this);
    btn->setFocusPolicy(Qt::NoFocus);
    btn->setCursor(Qt::PointingHandCursor);
    btn->resize(14,14);
    btn->move(157,42);
    btn->setStyleSheet("QPushButton{background-color:transparent;border:0px;}");
    btn->setFocusPolicy(Qt::NoFocus);
    btn->setVisible(false);
    connect(btn,SIGNAL(clicked()),this,SLOT(btnClicked()));

    this->setFocus();
    lineEdit->addValue("C");
    lineEdit->addValue("C++");
    lineEdit->addValue("Python");
    lineEdit->addValue("Php");
    lineEdit->addValue("Perl");
    lineEdit->addValue("Qt");
}

SearchLineEdit::~SearchLineEdit()
{

}

void SearchLineEdit::resizeEvent(QResizeEvent *event)
{
    move((QApplication::desktop()->width() - width())/2,  (QApplication::desktop()->height() - height())/2);
    QWidget::resizeEvent(event);
}

void SearchLineEdit::textChange(QString text)
{
    emit searchTextChanged(text);
}

void SearchLineEdit::editClicked()
{
    lineEdit->setSearching();
    btn->setVisible(true);
}

void SearchLineEdit::btnClicked()
{
    lineEdit->setNormal();
    btn->setVisible(false);
    this->setFocus();
}


/*******************************/
InnerLineEdit::InnerLineEdit(QWidget *parent)
   : QLineEdit(parent)
{
    setTextMargins(0,0,this->height(),0);
    setStyleSheet("background-image:url(:/searchInput.png);border:1px solid #536874;");

    QCompleter *completer = new QCompleter(this);
    listModel = new QStringListModel(valueList, this);
    completer->setCaseSensitivity(Qt::CaseInsensitive);
    completer->setModel(listModel);
    this->setCompleter(completer);
    connect(this, SIGNAL(editingFinished()), this, SLOT(editComplete()));

}

void InnerLineEdit::setNormal()
{
    setText("");
    setTextMargins(-5,0,this->height(),0);    //solve the cursor problem
    setStyleSheet("background-image:url(:/searchInput.png);border:1px solid #536874;");
}

void InnerLineEdit::setSearching()
{
    setTextMargins(0,0,this->height(),0);
    setStyleSheet("background-image:url(:/searchInput_click.png);border:1px solid #536874;");
}

void InnerLineEdit::addValue(const QString &value)
{
    valueList.append(value);
    listModel->setStringList(valueList);
}

void InnerLineEdit::focusInEvent(QFocusEvent *event)
{
    emit pressed();
    QLineEdit::focusInEvent(event);
}

void InnerLineEdit::focusOutEvent(QFocusEvent *event)
{
    QLineEdit::focusInEvent(event);
}

void InnerLineEdit::editComplete()
{
    QString text = this->text();
    if(QString::compare(text, QString("")) != 0) {
        bool flag = valueList.contains(text, Qt::CaseInsensitive);
        if(!flag) {
            addValue(text);
        }
    }
}
(3)main.cpp
#include "searchlineedit.h"
#include <QApplication>

int main(int argc, char *argv[])
{
    QApplication a(argc, argv);
    SearchLineEdit w;
    w.show();

    return a.exec();
}

(4)編譯執行


       其中的預設值有C、C++、Python、Php、Perl、Qt,輸入第一個字元會自動不區分大小寫的匹配判斷,並顯示在下拉列表中。若輸入一個不存在的字串,按回車後會儲存下來,下次便會提示該字串。

三、總結