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> < ...
随机推荐
- 嘿嘿嘿,开始自学mysql
开始学习mysql了,作为非计算机专业学生,必须需要一个地方来给自己的知识进行一些记录和总结. 一SQL语句 数据库是不认识java语言的,但是我们同样要与数据库交互,这时需要使用到数据库认识的语言S ...
- ubuntu16.04如何安装搜狗输入法
1 . 首先我们需要先来下载支持linux版本的搜狗输入法安装包,这里我们先查看下自己的ubuntu系统是什么版本的,这里我们可以在右上角的那个齿轮图标点击查看"系统设置",在里面 ...
- consistent.go 源码阅读
) > len(c.circle) { hashes = nil } for k := range c.circle { hashes = app ...
- C++中常用到的容器
这里主要讲C++中经常用到的一些保存数据的容器,其中也会介绍string. 在C++11中提到了很多容器,这里主要介绍:vector.list.map.还有一些其他的容器就不做介绍了. 1.Strin ...
- 【强连通分量】Bzoj1051 HAOI2006 受欢迎的牛
Description 每一头牛的愿望就是变成一头最受欢迎的牛.现在有N头牛,给你M对整数(A,B),表示牛A认为牛B受欢迎. 这种关系是具有传递性的,如果A认为B受欢迎,B认为C受欢迎,那么牛A也认 ...
- BZOJ_2561_最小生成树_最小割
BZOJ_2561_最小生成树_最小割 题意: 给定一个边带正权的连通无向图G=(V,E),其中N=|V|,M=|E|,N个点从1到N依次编号,给定三个正整数u,v,和L (u≠v),假设现在加入一条 ...
- YAML基础教程
一.YAML介绍YAML参考了其他多种语言,包括:XML.C语言.Python.Perl以及电子邮件格式RFC2822.Clark Evans在2001年5月在首次发表了这种语言,另外Ingy döt ...
- 最新.net和Java调用SAP RFC中间件下载
还记得2012年初我发布的全网络第一个关于.net 连接SAP RFC的NCO3原创博文,用的就是SAP出的最新的.Net Connector 3.0的版本,在那个时候都是普遍用其他蹩脚的方式或Web ...
- 数据库分片(Database Sharding)详解
本文由云+社区发表 作者:腾讯云数据库 Introduction 导言 任何看到显著增长的应用程序或网站,最终都需要进行扩展,以适应流量的增加.以确保数据安全性和完整性的方式进行扩展,对于数据驱动的应 ...
- Linux 系统目录结构说明
在刚开始接触Linux系统时,对其目录结构迷茫的很,尤其是很少使用或者刚开始接触Linux系统的同学:我也是最近项目需要开始上手,所以查看了些资料,特整理出来供大家互相学习: 1.目录结构总揽 以下是 ...