欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Qt實(shí)現(xiàn)模糊匹配功能的實(shí)例詳解

 更新時間:2022年10月17日 11:09:45   作者:中國好公民st  
對于瀏覽器的使用,我想大家一定不會陌生吧,輸入要搜索的內(nèi)容時,會出現(xiàn)相應(yīng)的匹配信息。本文就來用Qt實(shí)現(xiàn)模糊匹配功能,感興趣的可以了解一下

對于瀏覽器的使用,我想大家一定不會陌生吧,輸入要搜索的內(nèi)容時,會出現(xiàn)相應(yīng)的匹配信息。

那么,今天我要講述的也是這樣一個功能。

首先看一下展示效果

輸入任意文本后,彈出具有該文本的符合項,也就是模糊查詢。

實(shí)現(xiàn)功能的核心是:QCompleter

該類可以在任何Qt小部件中提供自動完成搜索功能,例如:QLineEdit、QComboBox。當(dāng)輸入指定字符后,QCompleter會根據(jù)單詞列表提供的內(nèi)容進(jìn)行篩查。

在這里,我是采用QLineEdit + QCompleter組合使用的。

下面我來介紹下如何使用的吧~

1.準(zhǔn)備基礎(chǔ)數(shù)據(jù)

想要讓QCompleter完成模糊匹配功能,前提必須要有一個可供查詢的庫文件,否則是無法搜索的。

這里就簡單插入一些字符串吧~

QStringList listData;
listData << QStringLiteral("基礎(chǔ)數(shù)據(jù)1");
listData << QStringLiteral("基礎(chǔ)數(shù)據(jù)n");

2.創(chuàng)建并實(shí)例化匹配類

QCompleter *m_pCompleter = new QCompleter(listData);

設(shè)置匹配方式,在Completer中存在以下幾種匹配模式,分別列舉,如下:

模式描述
Qt::MatchExactly只匹配第一個字/詞
Qt::MatchFixedString只匹配第一個詞,并且區(qū)分大小寫
Qt::MatchContains只要字符串中包含字/詞就能匹配
Qt::MatchStartsWith與第一個字/詞進(jìn)行匹配
Qt::MatchEndsWith 
Qt::MatchCaseSensitive搜索區(qū)分大小寫
Qt::MatchRegExp使用正則表達(dá)式作為搜索項執(zhí)行基于字符串的匹配(Qt5.15)
Qt::MatchRegularExpression使用正則表達(dá)式作為搜索項執(zhí)行基于字符串的匹配(Qt5.15)
Qt::MatchWildcard使用帶有通配符的字符串作為搜索條件,執(zhí)行基于字符串的匹配
Qt::MatchWrap執(zhí)行一個環(huán)繞的搜索,這樣當(dāng)搜索到達(dá)模型中的最后一項時,就會從第一個項開始,直到檢查完所有項為止
Qt::MatchRecursive搜索整個層次結(jié)構(gòu)

在使用過程中,一般采用:Qt::MatchContains的定義比較多。

代碼設(shè)置,如下:

m_pCompleter->setFilterMode(Qt::MatchContains);

3.控件綁定

ui.edit->setCompleter(m_pCompleter);

到此,一個簡單的模糊搜索就實(shí)現(xiàn)了,其實(shí)在使用過程中為了美觀起見,還可以對QCompleter中展示的文本進(jìn)行美化~

例如:

滾動條風(fēng)格

QString g_scrollVerticalWidth8Gray = 
"QScrollBar:vertical{ width:8px; background-color:#e9f1f7;}"
"QScrollBar::handle:vertical{ width:8px; background-color:#6eade0; border-radius:4px;}"
"QScrollBar::handle:vertical:hover{background-color:#2b76af;}"
"QScrollBar::handle:vertical:pressed{background-color:#1e659b;}";

Completer風(fēng)格

QString qsCompleterStyle =
//設(shè)置:背景色、字體顏色、大小、字體風(fēng)格
"QAbstractItemView{background-color:#FFFFFF;color: #FFB6C1;font-size:16px;font-family:Microsoft YaHei UI;outline:0px;}"
"QAbstractItemView::item:hover{background-color:#7FFF00;color: #0000FF;}"
"QAbstractItemView::item:selected{background-color:#FF8C00;color: #0000FF;}";

風(fēng)格設(shè)置,如下:

m_pCompleter->popup()->setStyleSheet(qsCompleterStyle + g_scrollVerticalWidth8Gray);

單純的設(shè)置風(fēng)格肯定是不行的,想要讓風(fēng)格有效,必須設(shè)置:QStyledItemDelegate

QStyledItemDelegate *d = new QStyledItemDelegate;
m_completerName->popup()->setItemDelegate(d);

最終展示效果,如下:

到此這篇關(guān)于Qt實(shí)現(xiàn)模糊匹配功能的實(shí)例詳解的文章就介紹到這了,更多相關(guān)Qt模糊匹配功能內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

最新評論