博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
Qt之自定义搜索框
阅读量:6983 次
发布时间:2019-06-27

本文共 1575 字,大约阅读时间需要 5 分钟。

简述

关于搜索框,大家都经常接触。例如:浏览器搜索、Windows资源管理器搜索等。

这里写图片描述

这里写图片描述

当然,这些对于Qt实现来说毫无压力,只要思路清晰,分分钟搞定。

效果

这里写图片描述

细节分析

实现细节需要如下步骤:

  1. 组合实现,输入框+按钮
  2. 事件关联
  3. 获取输入文本,进行文本搜索

为了更人性、易用,这里有一些细节需要注意:

  1. 输入框的文本不能处于按钮之下
  2. 输入框无文本时必须给与友好性提示
  3. 按钮无文本描述,一般需要给予ToolTip提示
  4. 按钮样式-正常、滑过、按下,以及鼠标滑过鼠标样式手型,

这些都想清楚了,我们就能快速实现一个搜索框了。

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));    }}

源码下载

你可能感兴趣的文章
缓存涉及的http头,虽然很多不懂但是我也粘出来,希望大家帮我一想分析
查看>>
调试 Dockerfile - 每天5分钟玩转 Docker 容器技术(15)
查看>>
我的友情链接
查看>>
Oracle计算时间跨度的函数
查看>>
python进程之间消息监控程序
查看>>
Abset Line Number Information
查看>>
设置grub密码
查看>>
去除文件中<feff>
查看>>
我的学习计划 2015
查看>>
MySQL中 TIMESTAMP类型 和 DATETIME类型 的区别
查看>>
spring管理用hibernate连接informix 数据库
查看>>
jquery通过多个属性选择器过滤
查看>>
Fedora 11 安装指南-12
查看>>
2011年10款最佳Linux桌面
查看>>
机器学习【一】:绪论
查看>>
Android权限摘要
查看>>
自写字符串操作函数
查看>>
oracle 带斜杠的date格式转横杠
查看>>
NPM---前端包管理工具
查看>>
mysql 同步redis
查看>>