## 一、前言

导航按钮控件,主要用于各种漂亮精美的导航条,我们经常在web中看到导航条都非常精美,都是html+css+js实现的,还自带动画过度效果,Qt提供的qss其实也是无敌的,支持基本上所有的CSS2属性,配合QPainter这个无敌大法工具,没有什么不能绘制的。这个控件总结了大部分的导航条样式,比如左侧+右侧+顶部+底部,线条指示器,倒三角指示器等。还可以在导航条前面加上图标等,就显得更加有特色。有了此控件,再也不用担心没有精美的导航了。总之这个控件在我的很多的项目中都在用,而且很多Qt界的朋友也在用,反响很热烈很好。

主要功能:

1. 可设置文字的左侧+右侧+顶部+底部间隔

2. 可设置文字对齐方式

3. 可设置显示倒三角/倒三角边长/倒三角位置/倒三角颜色

4. 可设置显示图标/图标间隔/图标尺寸/正常状态图标/悬停状态图标/选中状态图标

5. 可设置显示边框线条/线条宽度/线条间隔/线条位置/线条颜色

6. 可设置正常背景颜色/悬停背景颜色/选中背景颜色

7. 可设置正常文字颜色/悬停文字颜色/选中文字颜色

8. 可设置背景颜色为画刷颜色

## 二、代码思路

void NavButton::paintEvent(QPaintEvent *){    //绘制准备工作,启用反锯齿    QPainter painter(this);    painter.setRenderHints(QPainter::Antialiasing | QPainter::TextAntialiasing);    //绘制背景    drawBg(&painter);    //绘制文字    drawText(&painter);    //绘制图标    drawIcon(&painter);    //绘制边框线条    drawLine(&painter);    //绘制倒三角    drawTriangle(&painter);}void NavButton::drawBg(QPainter *painter){    painter->save();    painter->setPen(Qt::NoPen);    int width = this->width();    int height = this->height();    QRect bgRect;    if (linePosition == LinePosition_Left) {        bgRect = QRect(lineSpace, 0, width - lineSpace, height);    } else if (linePosition == LinePosition_Right) {        bgRect = QRect(0, 0, width - lineSpace, height);    } else if (linePosition == LinePosition_Top) {        bgRect = QRect(0, lineSpace, width, height - lineSpace);    } else if (linePosition == LinePosition_Bottom) {        bgRect = QRect(0, 0, width, height - lineSpace);    }    //如果画刷存在则取画刷    QBrush bgBrush;    if (isChecked()) {        bgBrush = checkBgBrush;    } else if (hover) {        bgBrush = hoverBgBrush;    } else {        bgBrush = normalBgBrush;    }    if (bgBrush != Qt::NoBrush) {        painter->setBrush(bgBrush);    } else {        //根据当前状态选择对应颜色        QColor bgColor;        if (isChecked()) {            bgColor = checkBgColor;        } else if (hover) {            bgColor = hoverBgColor;        } else {            bgColor = normalBgColor;        }        painter->setBrush(bgColor);    }    painter->drawRect(bgRect);    painter->restore();}void NavButton::drawText(QPainter *painter){    painter->save();    painter->setBrush(Qt::NoBrush);    //根据当前状态选择对应颜色    QColor textColor;    if (isChecked()) {        textColor = checkTextColor;    } else if (hover) {        textColor = hoverTextColor;    } else {        textColor = normalTextColor;    }    QRect textRect = QRect(paddingLeft, paddingTop, width() - paddingLeft - paddingRight, height() - paddingTop - paddingBottom);    painter->setPen(textColor);    painter->drawText(textRect, textAlign | Qt::AlignVCenter, text());    painter->restore();}void NavButton::drawIcon(QPainter *painter){    if (!showIcon) {        return;    }    painter->save();    QPixmap pix;    if (isChecked()) {        pix = iconCheck;    } else if (hover) {        pix = iconHover;    } else {        pix = iconNormal;    }    if (!pix.isNull()) {        //等比例平滑缩放图标        pix = pix.scaled(iconSize, Qt::KeepAspectRatio, Qt::SmoothTransformation);        painter->drawPixmap(iconSpace, (height() - iconSize.height()) / 2, pix);    }    painter->restore();}void NavButton::drawLine(QPainter *painter){    if (!showLine) {        return;    }    if (!isChecked()) {        return;    }    painter->save();    QPen pen;    pen.setWidth(lineWidth);    pen.setColor(lineColor);    painter->setPen(pen);    //根据线条位置设置线条坐标    QPoint pointStart, pointEnd;    if (linePosition == LinePosition_Left) {        pointStart = QPoint(0, 0);        pointEnd = QPoint(0, height());    } else if (linePosition == LinePosition_Right) {        pointStart = QPoint(width(), 0);        pointEnd = QPoint(width(), height());    } else if (linePosition == LinePosition_Top) {        pointStart = QPoint(0, 0);        pointEnd = QPoint(width(), 0);    } else if (linePosition == LinePosition_Bottom) {        pointStart = QPoint(0, height());        pointEnd = QPoint(width(), height());    }    painter->drawLine(pointStart, pointEnd);    painter->restore();}void NavButton::drawTriangle(QPainter *painter){    if (!showTriangle) {        return;    }    //选中或者悬停显示    if (!hover && !isChecked()) {        return;    }    painter->save();    painter->setPen(Qt::NoPen);    painter->setBrush(triangleColor);    //绘制在右侧中间,根据设定的倒三角的边长设定三个点位置    int width = this->width();    int height = this->height();    int midWidth = width / 2;    int midHeight = height / 2;    QPolygon pts;    if (trianglePosition == TrianglePosition_Left) {        pts.setPoints(3, triangleLen, midHeight, 0, midHeight - triangleLen, 0, midHeight + triangleLen);    } else if (trianglePosition == TrianglePosition_Right) {        pts.setPoints(3, width - triangleLen, midHeight, width, midHeight - triangleLen, width, midHeight + triangleLen);    } else if (trianglePosition == TrianglePosition_Top) {        pts.setPoints(3, midWidth, triangleLen, midWidth - triangleLen, 0, midWidth + triangleLen, 0);    } else if (trianglePosition == TrianglePosition_Bottom) {        pts.setPoints(3, midWidth, height - triangleLen, midWidth - triangleLen, height, midWidth + triangleLen, height);    }    painter->drawPolygon(pts);    painter->restore();}

## 三、效果图

## 四、开源主页

**以上作品完整源码下载都在开源主页,会持续不断更新作品数量和质量,欢迎各位关注。**

1. 国内站点:[https://gitee.com/feiyangqingyun/QWidgetDemo](https://gitee.com/feiyangqingyun/QWidgetDemo)

2. 国际站点:[https://github.com/feiyangqingyun/QWidgetDemo](https://github.com/feiyangqingyun/QWidgetDemo)

3. 个人主页:[https://blog.csdn.net/feiyangqingyun](https://blog.csdn.net/feiyangqingyun)

4. 知乎主页:[https://www.zhihu.com/people/feiyangqingyun/](https://www.zhihu.com/people/feiyangqingyun/)

qt设置边框颜色_Qt开源作品14-导航按钮控件相关推荐

  1. datetimepicker控件怎么改变hover颜色_Qt编写自定义控件9-导航按钮控件

    前言 导航按钮控件,主要用于各种漂亮精美的导航条,我们经常在web中看到导航条都非常精美,都是html+css+js实现的,还自带动画过度效果,Qt提供的qss其实也是无敌的,支持基本上所有的CSS2 ...

  2. qt设置圆形按钮_Qt开源作品25-电池电量控件

    一.前言 现在这个时代,智能手机不要太流行,满大街都是,甚至连爷爷奶奶级别的人都会用智能手机,本次要写的控件就是智能手机中的电池电量表示控件,采用纯painter绘制,其实也可以采用贴图,我估计大部分 ...

  3. qt 进度条_Qt开源作品12-硬盘容量控件

    一.前言 磁盘容量统计控件,说白了,就是用来统计本地盘符占用的容量,包括但不限于已用空间.剩余空间.总大小.已用百分比等,其中对应的百分比采用进度条显示,该进度条的前景色和背景色及文字颜色可以设置,在 ...

  4. qt显示rgba8888 如何改 frame_Qt开源作品17-IP地址输入控件

    一.前言 这个IP地址输入框控件,估计写烂了,网上随便一搜索,保证一大堆,估计也是因为这个控件太容易了,非常适合新手练手,一般的思路都是用4个qlineedit控件拼起来,然后每个输入框设置正则表达式 ...

  5. Qt开源作品33-图片开关控件

    一.前言 进入智能手机时代以来,各种各样的APP大行其道,手机上面的APP有很多流行的元素,开关按钮个人非常喜欢,手机QQ.360卫士.金山毒霸等,都有很多开关控制一些操作,在WINFORM项目上,如 ...

  6. qt建立一个按钮控件

    1.如果建立一个按钮控件 2.指定按钮控件的父对象 3.指定按钮控件的位置 4.设置按钮控件的大小 1.如果建立一个空间按钮 在头文件加上:#include<QPushButton>.(记 ...

  7. qt creator 设置按键颜色_Qt编写自定义控件30-颜色多态按钮

    一.前言 这个控件一开始打算用样式表来实现,经过初步的探索,后面发现还是不够智能以及不能完全满足需求,比如要在此控件设置多个角标,这个用QSS就很难实现,后面才慢慢研究用QPainter来绘制,我记得 ...

  8. html边框颜色线性渐变,css3设置边框颜色渐变的方法有哪些

    css3设置边框颜色渐变的方法有哪些 发布时间:2020-09-14 14:51:54 来源:亿速云 阅读:110 作者:小新 css3设置边框颜色渐变的方法有哪些?这个问题可能是我们日常学习或工作经 ...

  9. android wps表格如何设置边框颜色

    今天,简单讲讲如何使用WPS Excel设置表格边框. 这个可以说可android的关系不大,但是之前工作时,组长让我写一下工作计划要求用表格写.我完成后,组长说要是美观一些就好,于是自己查询了相关资 ...

最新文章

  1. iOS 获取当前设备型号iPhone7/iPhone7P
  2. restful api_将Spring MVC RESTful Web服务迁移到Spring 4
  3. scala一些奇怪的操作符的效果(持续更新中)
  4. 图卷积神经网络(part4)--GNN
  5. Java高级开发面试,java字符串拼接的方法
  6. Deskreen – 将电脑屏幕共享到浏览器中,做第二块屏幕[Win/macOS/Linux]
  7. 使用pytorch查看中间层特征矩阵以及卷积核参数
  8. java后端技术路线_Java后端精选技术:Java的反射机制
  9. 3.8 Anchor Boxes
  10. 从Nest到Nesk -- 模块化Node框架的实践
  11. Introduction to replication 翻译
  12. mysql gtid 错误_MySQL 5.6 GTID常见错误解决一例
  13. 【verbs】IBV_WR API(3) Libibverbs Programmer’s Manual
  14. 机器学习-推荐系统-利用用户标签数据
  15. 六级考试-考前最后一背
  16. 【Android】debug 状态下其签名文件 debug.keystore 相关(如何获得该文件,其密码,获取其sha1、MD5等)
  17. I219-V 14代 win7x64驱动程序
  18. 操作系统 --cpu与指令集
  19. CSGO DIY-文件修改位置
  20. 正式发售超两周 iPhone7部分机型仍然缺货

热门文章

  1. Leetcode 111.二叉树的最小深度
  2. C++多线程map读写加锁
  3. ubuntu16.04 装机4:安装防火墙ufw
  4. 编程笔记:python 中的 OrderedDict
  5. 判断形参S所指字符串是否是回文,若是,函数返回1,不是则返回0,并在main中实现输出...
  6. ScheduledExecutor定时器
  7. Spark之MLlib
  8. javaweb基础----使用ajax校验用户名是否重复
  9. lintcode-easy-Merge Intervals
  10. 1029 C语言文法定义与C程序的推导过程