QPainter主要功能说明与使用

news2025/1/13 13:52:51

图形填充QBrush主要功能:

QBrush类定义QPaint绘制的形状的填充图案。

函数原型功能
void setColor(QColor &color)设置画刷颜色,实体填充时即填充颜色
void setStyle(Qt::BrushStyle style)设置画刷填充样式,参数为枚举类型Qt::BrushStyle(下图)
void setTexture(QPixmap &pixmap)设置一个QPixmap类型图片作为画刷的图片
void setTextureImage(QImage &image)设置一个QImage类型图片作为画刷的图片


笔刷有样式、颜色、渐变和纹理。
brush style() 使用Qt::BrushStyle枚举定义填充图案。默认笔刷样式是Qt::NoBrush(取决于构造笔刷的方式)。这种风格告诉画家不要填充形状。填充的标准样式是Qt::SolidPattern。使用适当的构造函数创建画笔时可以设置样式,此外,setStyle()函数提供了在构造画笔后更改样式的方法。

不同枚举类型对应的填充效果图:

范例: 

void Widget::paintEvent(QPaintEvent *event)
{
    Q_UNUSED(event);
    QPainter painter(this);   //创建QPainter对象
    painter.setRenderHint(QPainter::Antialiasing);//将Antialiasing属性(也就是反走样)设置为true。经过这句设置,我们就打开了QPainter的反走样功能。
    painter.setRenderHint(QPainter::TextAntialiasing); //绘制的字体抗锯齿
    int W=this->width();                      //绘图区宽度
    int H=this->height();                     //绘图区高度
    QRect rect(W/4,H/4,W/2,H/2);              //中间区域举行
    //设置画笔
    QPen pen;
    pen.setWidth(3);
    pen.setColor(Qt::red);
    pen.setStyle(Qt::SolidLine);
    pen.setCapStyle(Qt::FlatCap);       //设置端点样式
    pen.setJoinStyle(Qt::BevelJoin);    //连接样式
    painter.setPen(pen);
    //1.设置画刷
    //    QBrush brush;
    //    brush.setColor(Qt::yellow);
    //    brush.setStyle(Qt::Dense6Pattern);
    //    painter.setBrush(brush);

    //2.设置线性渐变填充
    //    QLinearGradient linerGrad(rect.left(),rect.top(),rect.right(),rect.top());
    //    linerGrad.setColorAt(0,Qt::blue);
    //    linerGrad.setColorAt(0.5,Qt::white);
    //    linerGrad.setColorAt(1,Qt::blue);
    //    painter.setBrush(linerGrad);

    //3.设置辐射渐变填充
    //    QRadialGradient radialGrad(W/2,H/2,qMax(W/3,H/3),W/2,H/2);
    //    radialGrad.setColorAt(0,Qt::white);
    //    radialGrad.setColorAt(1,Qt::blue);
    //    painter.setBrush(radialGrad);

    //4.设置圆锥形渐变填充
    QConicalGradient conicalGrad(W/2,H/2,45);
    conicalGrad.setColorAt(0,Qt::blue);
    conicalGrad.setColorAt(1,Qt::white);
    painter.setBrush(conicalGrad);

    //5. 设置延展填充
    QRadialGradient radialGrad(W/2,H/2,qMax(W/8,H/8),W/2,H/2);
    radialGrad.setColorAt(0,Qt::white);
    radialGrad.setColorAt(1,Qt::blue);
    radialGrad.setSpread(QGradient::RepeatSpread);
    painter.setBrush(radialGrad);
    painter.drawRect(this->rect());//填充更大区域,会有延展效果

    //绘图
    painter.drawRect(rect);
}

填充效果如下所示: 

 

坐标变换

分组函数原型功能
坐标变换void translate(qreal dx,qreal dy)坐标系平移一定偏移量,坐标原点平移到新的位置
void rotate(qreal angle)坐标系旋转一定角度,角度单位为度
void scale(qreal sx,qreal sy)坐标系缩放
void shear(qreal sh,qreal sv)坐标系做扭转
状态保存与恢复void save()保存当前坐标状态,就是将当前状态压入栈
void restore()恢复上一次保存的坐标状态,就是从栈中弹出上次的坐标状态
void resetTransform()复位所有的坐标变换

范例:

void Widget::paintEvent(QPaintEvent *event)
{
    QPainter painter(this);
    painter.setRenderHint(QPainter::Antialiasing);
    painter.setRenderHint(QPainter::TextAntialiasing);
    //生成五角星的五个顶点,假设原点在五角星中心部分
    qreal R=100;   //半径
    const qreal pi=3.14159;
    qreal deg=pi*72/180;
    QPoint points[5]={QPoint(R,0),
                     QPoint(R*qCos(deg),-R*qSin(deg)),
                     QPoint(R*qCos(2*deg),-R*qSin(2*deg)),
                     QPoint(R*qCos(3*deg),-R*qSin(3*deg)),
                     QPoint(R*qCos(4*deg),-R*qSin(4*deg)),
                     };
    //设置字体
    QFont font;
    font.setPointSize(12);
    painter.setFont(font);
    //设置画笔
    QPen pen;
    pen.setWidth(3);
    pen.setColor(Qt::black);
    pen.setStyle(Qt::SolidLine);
    pen.setCapStyle(Qt::FlatCap);
    pen.setJoinStyle(Qt::BevelJoin);
    painter.setPen(pen);
    //设置画刷
    QBrush brush;
    brush.setColor(Qt::yellow);
    brush.setStyle(Qt::SolidPattern);
    painter.setBrush(brush);
    //设计绘制五角星的painterpath,以便重复使用
    QPainterPath starpath;
    starpath.moveTo(points[0]);
    starpath.lineTo(points[2]);
    starpath.lineTo(points[4]);
    starpath.lineTo(points[1]);
    starpath.lineTo(points[3]);
    starpath.closeSubpath();//闭合路径,最后一个点与第一个点相连
    starpath.addText(points[0],font,"1");
    starpath.addText(points[1],font,"2");
    starpath.addText(points[2],font,"3");
    starpath.addText(points[3],font,"4");
    starpath.addText(points[4],font,"5");

    //绘图,第一个五角星
    painter.save();//保存坐标状态
    painter.translate(100,120);
    painter.drawPath(starpath);
    painter.drawText(0,0,"S1");
    painter.restore();//恢复坐标状态

    //第二个五角星
    painter.translate(300,120);
    painter.scale(0.8,0.8);//缩放
    painter.rotate(90);//顺时针旋转
    painter.drawPath(starpath);
    painter.drawText(0,0,"S2");

    //第三个五角星
    painter.resetTransform();
    painter.translate(500,120);
    painter.rotate(-150);
    painter.drawPath(starpath);
    painter.drawText(0,0,"S3");
    event->accept();
}

运行效果:

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/935875.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

在vue项目中用vue-watermark快捷开发屏幕水印效果

我们先引入一个第三方依赖 npm install vue-watermark然后 因为这只是个测试工具 我就直接代码写 App.vue里啦 参考代码如下 <template><div><vue-watermark :text"watermarkText"></vue-watermark><!-- 正常的页面内容 --></div…

Git基本操作(Idea版)

第一次发布项目&#xff08;本地->远程&#xff09; 方式一 通过push的方式推送本地库到远程库&#xff08;远程已创建好仓库&#xff09; 这种方式需要提前创建好仓库。 右键点击项目&#xff0c;可以将当前分支的内容 push 到 GitHub 的远程仓库中。 注意&#xff1a…

2023/8/27周报

目录 摘要 论文阅读 1、标题和现存问题 2、过度平滑和度量方法 3、处理过坡 4、实验结果 深度学习 1、解决可视化问题 2、CART算法 总结 摘要 本周在论文阅读上&#xff0c;阅读了一篇Pairnorm:解决GNNS中的过平滑问题的论文。PairNorm 的核心思想是在图卷积层之间引…

LeetCode——回溯篇(一)

刷题顺序及思路来源于代码随想录&#xff0c;网站地址&#xff1a;https://programmercarl.com 目录 77. 组合 216. 组合总和 III 17. 电话号码的字母组合 39. 组合总和 40. 组合总和 II 77. 组合 给定两个整数 n 和 k&#xff0c;返回范围 [1, n] 中所有可能的 k 个数的…

UE4/5在蓝图细节面板中添加函数按钮(蓝图与c++的方法)

目录 在细节面板中添加按钮使用函数 蓝图的方法 事件 函数 效果 uec的方法 效果 在细节面板中添加按钮使用函数 很多时候&#xff0c;我们可以看到一些插件的actor类中&#xff0c;点击一下之后就可以实现如矩阵一样的效果。 实际上是因为其使用了函数来修改了蓝图中的数…

Compose - 容器组合项

一、延迟列表 LazyColumn、LazyRow 可滚动&#xff0c;类似RecyclerView&#xff08; Column、Row 用 Modifier 设置滚动是相当于ScrollView&#xff09;。 key设置为集合元素的唯一值例如id&#xff0c;使得列表能感知元素位置是否发生变化或新增移除&#xff0c;对于内容是否…

基于vue和element的脚手架【vue-element-admin 和vue-element-plus-admin 】

vue-element-admin vue-element-admin 是一个后台前端解决方案&#xff0c;它基于 vue 和 element-ui实现 介绍 | vue-element-adminA magical vue adminhttps://panjiachen.github.io/vue-element-admin-site/zh/guide/ vue-element-plus-admin vue-element-plus-admin 是一…

Python 通过traceback追溯异常信息

Python 通过traceback追溯异常信息 导入traceback包 import traceback自定义函数 def func_3():return 1 / 0def func_2():func_3()def func_1():func_2()捕捉异常 try:func_1() except Exception as e:traceback_info traceback.format_exc()print("traceback_info"…

Java IO流动(实战操作)

目录 1 IO流原理2 IO流的分类3 输入、输出流代码示例4 小结5 文件在前后台之间传递 在Java中&#xff0c;IO流是一种用于处理输入和输出操作的机制。它提供了一种统一的方式来读取和写入数据&#xff0c;平日开发中在文件读写&#xff0c;网络通信&#xff0c;特定场景的数据库…

哔哩哔哩 B站 bilibili 视频倍速设置 视频倍速可自定义

目录 一、复制如下代码 二、在B站视频播放页面进入控制台 三、将复制的代码粘贴到下方输入框&#xff0c;并 回车Enter 即可 四、然后就可以了 一、复制如下代码 &#xff08;该代码用于设置倍速为3&#xff0c;最后的数值是多少就是多少倍速&#xff0c;可以带小数点&#…

Docker容器:Harbor 私有仓库迁移

文章目录 一.私有仓库迁移的介绍1.为何要对Harbor 私有仓库的迁移2.Harbor 私有仓库的迁移特点3. Harbor 私有仓库的迁移注意要点 二.私有仓库迁移配置1.源Harbor配置&#xff08;192.168.198.11&#xff09;&#xff08;1&#xff09;接着以下操作查看容器状况及是否可以登录 …

【滑动窗口】leetcode1004:最大连续1的个数

一.题目描述 最大连续1的个数 这道题要我们找最大连续1的个数&#xff0c;看到“连续”二字&#xff0c;我们要想到滑动窗口的方法。滑动窗口的研究对象是一个连续的区间&#xff0c;这个区间需要满足某个条件。那么本题要找的是怎样的区间呢&#xff1f;是一个通过翻转0后得到…

容器导入与导出

docker的一大优势就是可移植性&#xff0c;容器因此docker容器可以随意的进行导入导出操作。 容器导出 使用export命令可以导出容器&#xff0c;具体操作如下&#xff1a; 创建一个容器&#xff0c;进行基本的配置操作 本案例中我首先创建一个nginx容器&#xff0c;然后启动…

开发过程中自己遇到的异常(六)

连接数据库失败&#xff1a; InternalError: (pymysql.err.InternalError) (1130, "Host xxx.xx.1.106 is not allowed to connect to this MySQL server") (Background on this error at: http://sqlalche.me/e/2j85) 解决方式&#xff1a; mysql> use mysql; …

基于静电放电算法优化的BP神经网络(预测应用) - 附代码

基于静电放电算法优化的BP神经网络&#xff08;预测应用&#xff09; - 附代码 文章目录 基于静电放电算法优化的BP神经网络&#xff08;预测应用&#xff09; - 附代码1.数据介绍2.静电放电优化BP神经网络2.1 BP神经网络参数设置2.2 静电放电算法应用 4.测试结果&#xff1a;5…

DebugInfo 模型功能系统介绍 文本上色 文本与表格对齐 分隔线 秒表计算器 语义日期

背景 今天系统性的为大家介绍一下 DebugInfo 模块。这个模块提供了一些丰富的基本功能的封装&#xff0c;希望能给有需要的人带来些许帮助。 文本上色 DebugInfo 模块引入了 colorama提供文本颜色支持。 # -*- coding:UTF-8 -*-# region 引入必要依赖 from DebugInfo.DebugI…

NGINX相关配置

NGINX相关配置 NGINX配置信息 nginx 官方帮助文档&#xff1a;http://nginx.org/en/docs/Nginx的配置文件的组成部分&#xff1a; 主配置文件&#xff1a;/conf/nginx.conf(/nginx/conf/nginx.conf) 子配置文件: include conf.d/*.conf#事件驱动相关的配置 同步 event { wo…

VMware安装启动windows虚拟机出错 efi vmware virtual ...... No media

本人是在最近一台新电脑想要装windows系统的虚拟机&#xff0c;下载了VMware workstation 17pro&#xff0c;也下载了官方的windows系统镜像iso文件。 但是在开启虚拟机的过程中&#xff0c;出现了类似以下的错误&#xff1a; efi vmware virtual … No media 看到有人说需要下…

OLED透明屏技术:引领品牌营销的视觉革命

在当今竞争激烈的市场中&#xff0c;品牌营销的成功与否关系到企业的生存和发展。 而随着科技的不断进步&#xff0c;新的广告展示技术不断涌现&#xff0c;其中OLED透明屏技术以其独特的视觉效果和创新性的应用在品牌营销领域引起了广泛关注。 那么&#xff0c;尼伽将详细介…

flutter和原生利用pigeon建立通道

首先导入依赖&#xff1a; dependencies: pigeon: ^10.0.0定义一个文件&#xff1a; /// 用于定于flutter和平台的桥接方法 /// HostApi() 标记的&#xff0c;是用于 Flutter 调用原生的方法&#xff1b; /// FlutterApi() 标记的&#xff0c;是用于原生调用 Flutter 的方法&…