程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 編程語言 >> C語言 >> 關於C語言 >> Qt之自定義搜索框

Qt之自定義搜索框

編輯:關於C語言

Qt之自定義搜索框


簡述

關於搜索框,大家都經常接觸。例如:浏覽器搜索、Windows資源管理器搜索等。

這裡寫圖片描述

這裡寫圖片描述

當然,這些對於Qt實現來說毫無壓力,只要思路清晰,分分鐘搞定。

簡述 效果 細節分析 Coding 源碼下載

效果

這裡寫圖片描述

細節分析

實現細節需要如下步驟:

組合實現,輸入框+按鈕 事件關聯 獲取輸入文本,進行文本搜索

為了更人性、易用,這裡有一些細節需要注意:

輸入框的文本不能處於按鈕之下 輸入框無文本時必須給與友好性提示 按鈕無文本描述,一般需要給予ToolTip提示 按鈕樣式-正常、滑過、按下,以及鼠標滑過鼠標樣式手型,

這些都想清楚了,我們就能快速實現一個搜索框了。

Coding

搜索框實現

m_pSearchLineEdit = new QLineEdit();
QPushButton *pSearchButton = new QPushButton(this);

pSearchButton->setCursor(Qt::PointingHandCursor);
pSearchButton->setFixedSize(22, 22);
pSearchButton->setToolTip(QStringLiteral("搜索"));
pSearchButton->setStyleSheet("QPushButton{border-image:url(:/images/icon_search_normal); background:transparent;} \
                                     QPushButton:hover{border-image:url(:/images/icon_search_hover)} \
                                     QPushButton:pressed{border-image:url(:/images/icon_search_press)}");

//防止文本框輸入內容位於按鈕之下
QMargins margins = m_pSearchLineEdit->textMargins();
m_pSearchLineEdit->setTextMargins(margins.left(), margins.top(), pSearchButton->width(), margins.bottom());
m_pSearchLineEdit->setPlaceholderText(QStringLiteral("請輸入搜索內容"));

QHBoxLayout *pSearchLayout = new QHBoxLayout();
pSearchLayout->addStretch();
pSearchLayout->addWidget(pSearchButton);
pSearchLayout->setSpacing(0);
pSearchLayout->setContentsMargins(0, 0, 0, 0);
m_pSearchLineEdit->setLayout(pSearchLayout);

connect(pSearchButton, SIGNAL(clicked(bool)), this, SLOT(search()));

槽函數實現

void Widget::search()
{
    QString strText = m_pSearchLineEdit->text();
    if (!strText.isEmpty())
    {
        QMessageBox::information(this, QStringLiteral("搜索"), QStringLiteral("搜索內容為%1").arg(strText));
    }
}

  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved