QPainterPath 不规则提示框(二)
前一篇讲过不规则提示框,但是提示框的方向是固定的,不能达到随意变换方向的效果,本接讲述可以动态变换方向的提示框
先看效果图
如上图1所示,上一篇文章的代码可以达到类似效果
本片文章我只介绍变动部分,尽可能的做到详细吧
我先说原理,整个窗口包含两个布局器,水平布局和垂直布局,还有2个空间填充器,最后一个当然是显示消息的窗口,显示消息的窗口可以定制
整个窗口可以使用ui来做,也可以使用纯代码来控制,我使用了ui做布局部分,如图5,空间填充器是动态加入到布局中的,代码如下
case TOPLEFT://箭头朝左上
{
ui->horizontalLayout->addSpacerItem(new QSpacerItem(size().width() / ,
, QSizePolicy::Maximum, QSizePolicy::Minimum));
ui->horizontalLayout->addWidget(_p->messageWidget);//消息显示窗口
ui->horizontalLayout->setStretch(, );//设置空格和窗口长度比例
ui->horizontalLayout->setStretch(, );
ui->verticalLayout->insertSpacerItem(, new QSpacerItem(, size().height() /
, QSizePolicy::Minimum, QSizePolicy::Maximum));
ui->verticalLayout->setStretch(, );
ui->verticalLayout->setStretch(, );
}
break;
case BOTTOMLEFT://箭头朝左下
{
ui->horizontalLayout->addSpacerItem(new QSpacerItem(size().width() / ,
, QSizePolicy::Maximum, QSizePolicy::Minimum));
ui->horizontalLayout->addWidget(_p->messageWidget);
ui->horizontalLayout->setStretch(, );
ui->horizontalLayout->setStretch(, );
ui->verticalLayout->addSpacerItem(new QSpacerItem(, size().height() /
, QSizePolicy::Minimum, QSizePolicy::Maximum));
ui->verticalLayout->setStretch(, );
ui->verticalLayout->setStretch(, );
}
break;
case BOTTOMRIGHT://箭头朝 右下
{
ui->horizontalLayout->addWidget(_p->messageWidget);
ui->horizontalLayout->addSpacerItem(new QSpacerItem(,
, QSizePolicy::Expanding, QSizePolicy::Minimum));
ui->horizontalLayout->setStretch(, );
ui->horizontalLayout->setStretch(, );
ui->verticalLayout->addSpacerItem(new QSpacerItem(,
, QSizePolicy::Minimum, QSizePolicy::Expanding));
ui->verticalLayout->setStretch(, );
ui->verticalLayout->setStretch(, );
}
break;
case TOPRIGHT://箭头朝右上
{
ui->horizontalLayout->addWidget(_p->messageWidget);
ui->horizontalLayout->addSpacerItem(new QSpacerItem(,
, QSizePolicy::Expanding, QSizePolicy::Minimum));
ui->horizontalLayout->setStretch(, );
ui->horizontalLayout->setStretch(, );
ui->verticalLayout->insertSpacerItem(, new QSpacerItem(,
, QSizePolicy::Minimum, QSizePolicy::Expanding));
ui->verticalLayout->setStretch(, );
ui->verticalLayout->setStretch(, );
}
break;
整个窗口背景色透明后需要自己绘制窗口颜色,长款北京形状创建代码如下
QPainterPath rectPath, triPath;
switch (posStyle)
{
case :
{
rectPath.addRoundRect(QRect(size.width() /
, size.height() /
, size.width() / *
, size.height() / )
, );
triPath.moveTo(, );
triPath.lineTo(size.width() / , size.height() / );
triPath.lineTo(size.width() / * , size.height() / );
triPath.lineTo(, );
}
break;
case :
{
rectPath.addRoundRect(QRect(
, size.height() /
, size.width() / *
, size.height() / )
, );
triPath.moveTo(size.width(), );
triPath.lineTo(size.width() / * , size.height() / );
triPath.lineTo(size.width() / * , size.height() / );
triPath.lineTo(size.width(), );
}
break;
case :
{
rectPath.addRoundRect(QRect(
,
, size.width() / *
, size.height() / )
, );
triPath.moveTo(size.width(), size.height());
triPath.lineTo(size.width() / * , size.height() / );
triPath.lineTo(size.width() / * , size.height() / );
triPath.lineTo(size.width(), size.height());
}
break;
case :
{
rectPath.addRoundRect(QRect(size.width() /
,
, size.width() / *
, size.height() / )
, );
triPath.moveTo(, size.height());
triPath.lineTo(size.width() / , size.height() / );
triPath.lineTo(size.width() / * , size.height() / );
triPath.lineTo(, size.height());
}
break;
}
rectPath.addPath(triPath); //添加子闭合路径
return rectPath;
如此创建的提示窗口,在使用过程中需要用户根据箭头的指向 自己去移动窗口,paintEvent函数没有变化
================================================
前边介绍的这两种不规则图形的绘制都是直接绘制在窗口上的,接下来我再介绍一种绘制不规则图形的方式,只做大概讲述,具体实现代码我就不做过多的讲解 了,这种方式的原理就是贴图,我们把想要绘制的不规则图形先绘制到图片上,然后对图片做各种处理,比如旋转、镜像、平移等操作,然后在把图片绘制到窗口 上,这样做的好处是,这个不规则的形状可以随意变化,而不需要更改很多的代码。下面我写一下这种方式的伪代码
void 窗口重回函数()
{
根据QImage构造QPainter对象或者指针
构造如图1所示的不规则QPainterPath路径
使用绘图对象把该路径绘制到QImage上
使用绘图对象把QImage绘制到窗口上
}
QPainterPath 不规则提示框(二)的更多相关文章
- QPainterPath 不规则提示框
currentPosition()是最后一次绘制后的“结束点”(或初始点),使用moveTo()移动currentPosition()而不会添加任何元素. QPainterPath 合并: 1.方法 ...
- android标题栏上面弹出提示框(二) PopupWindow实现,带动画效果
需求:上次用TextView写了一个从标题栏下面弹出的提示框.android标题栏下面弹出提示框(一) TextView实现,带动画效果, 总在找事情做的产品经理又提出了奇葩的需求.之前在通知栏显示 ...
- UWP中的消息提示框(二)
在UWP中的消息提示框(一)中介绍了一些常见的需要用户主动去干涉的一些消息提示框,接下来打算聊聊不需要用户主动去干涉的一些消息提示框.效果就是像双击退出的那种提示框. 先说说比较简单的吧,通过系统To ...
- android标题栏下面弹出提示框(一) TextView实现,带动画效果
产品经理用的是ios手机,于是android就走上了模仿的道路.做这个东西也走了一些弯路,写一篇博客放在这里,以后自己也可用参考,也方便别人学习. 弯路: 1.刚开始本来用PopupWindow去实现 ...
- UWP中的消息提示框(一)
不管什么平台,应用内难免会出现一些消息提示框,下面就来聊聊我在UWP里用到的消息提示框. 弹窗也可按是否需要用户操作促发一些逻辑进行分为两大类. 不需要用户干涉的一类: MessageDialog:操 ...
- 第三方框架MBProgressHUD-----实现各种提示框
程序运行显示如下 : 点击按钮实现对应的提示框: 这里只截取了其中一张图,有兴趣的可以自己运行程序,查看其他的几种提示框哟!!! 第三方框架MBProgressHUD的下载地址:https://git ...
- HTML5 微信二维码提示框
这是一个js的小案例,主要效果是显示一个微信二维码的提示框,非常简单实用. 源码如下: JS部分 <script src="js/jquery-1.8.3.min.js"&g ...
- (二)easyUI之消息提示框
<%@ page language="java" contentType="text/html; charset=UTF-8" pageEncoding= ...
- 使用纯CSS实现带箭头的提示框
爱编程爱分享,原创文章,转载请注明出处,谢谢!http://www.cnblogs.com/fozero/p/6187323.html 1.全部代码 <!DOCTYPE html> < ...
随机推荐
- ubuntu16.04开机循环输入密码无法进入桌面的解决办法
前些天碰到一个头疼的问题,启动我的ubuntu之后,输入密码闪屏一下,又需要输入密码!!!于是再输还要再输!!!!! 经过百度一翻后终于找到原因和解决办法. 原来是我之前在profile文件里配置了一 ...
- nginx 开启 停止 重启
Nginx的启动.停止与重启 启动 启动代码格式:nginx安装目录地址 -c nginx配置文件地址 例如: [root@LinuxServer sbin]# /usr/local/nginx/sb ...
- MySQL 慢查询日志总结
慢查询日志概念 MySQL的慢查询日志是MySQL提供的一种日志记录,它用来记录在MySQL中响应时间超过阀值的语句,具体指运行时间超过long_query_time值的SQL,则会被记录到慢查询日志 ...
- 如果裸写一个goroutine pool
引言 在上文中,我说到golang的原生http server处理client的connection的时候,每个connection起一个goroutine,这是一个相当粗暴的方法.为了感受更深一点, ...
- CAD中用户选择实体
在CAD的很多操作中都会有需要用户选择实体的时候,这里将我最近项目中用到的方法分享一下,程序原意是希望用户选择一个单行文本或者多行文本,并返回所选文本的内容,直接上代码: CString CPaint ...
- 「SDOI 2018」战略游戏
题目大意: 给一个$G=(V,E)$,满足$|V|=n$,$|E|=m$,且保证图联通,有Q个询问,每组询问有s个点,求图中有多少点满足:将其删去后,这s个点中存在一对点集$(a,b)$不联通且删去点 ...
- BZOJ_1098_[POI2007]办公楼biu_链表优化BFS
BZOJ_1098_[POI2007]办公楼biu_链表优化BFS Description FGD开办了一家电话公司.他雇用了N个职员,给了每个职员一部手机.每个职员的手机里都存储有一些同事的 电话号 ...
- 基于Orangpi Zero和Linux ALSA实现WIFI无线音箱(二)
作品已经完成,先上源码: https://files.cnblogs.com/files/qzrzq1/WIFISpeaker.zip 全文包含三篇,这是第二篇,主要讲述发送端程序的原理和过程. 第一 ...
- HTML5网页录音和上传到服务器,支持PC、Android,支持IOS微信
准备做一个网页版聊天界面,表情啊.图片啊.上传文件啊都应该要有,视频就算了,语音还是要的. 本文记录的是在网页上用GitHub上的Recorder进行在线录音和上传到服务器,前几天升了一下级,以后有时 ...
- SSRS报表服务随笔(rdl报表服务)-报表参数
上一篇我们说了创建一个简单的显示报表,但在实际工作中,我们有很多要带条件的报表 现在先认识一下报表数据,首次打开SSDT,报表数据在窗口的左侧,要是找不到了,没关系,在工具栏-视图-最下面的报表数据 ...