[Qt][绘图][上]详细讲解

news2025/1/10 22:18:40

目录

  • 0.为什么?
  • 1.绘图API核心类
  • 2.设置画笔
  • 3.设置画刷
  • 4.设置画家
    • 1.移动画家位置
    • 2.保存/加载画家的状态


0.为什么?

  • 虽然Qt已经内置了很多的控件,但是不能保证现有控件就可以应对所有场景,很多时候,需要更强的"定制"能力
  • Qt提供了画图相关的API,可以允许用户在窗⼝上绘制任意的图形形状,来完成更复杂的界⾯设计
  • 所谓的"控件",本质上也是通过画图的⽅式画上去的
    • 画图API和控件之间的关系,可以类⽐成机器指令和⾼级语⾔之间的关系
    • 控件是对画图API的进⼀步封装,画图API是控件的底层实现

1.绘图API核心类

  • QPainter:⽤来绘图的对象,提供了⼀系列drawXXX⽅法,可以允许用户绘制各种图形
  • QPaintDevice:描述了QPainter把图形画到哪个对象上
    • QWidget也是⼀种QPaintDevice(QWidgetQPaintDevice的⼦类)
  • QPen:描述了QPainter出来的线是什么样的
  • QBrush:描述了QPainter填充⼀个区域是什么样的
  • 注意:绘图API的使⽤,⼀般不会在QWidget的构造函数中使⽤,⽽是要放到paintEvent事件中
    • paintEvent会在以下情况会被触发
      • 控件⾸次创建
      • 控件被遮挡,再解除遮挡
      • 窗⼝最⼩化,再恢复
      • 控件⼤⼩发⽣变化时
      • 主动调⽤repaint()或者update()⽅法(这两个⽅法都是QWidget的⽅法)
    • 因此,如果把绘图API放到构造函数中调⽤,那么⼀旦出现上述的情况,界⾯的绘制效果就⽆法确保符合预期
  • 示例
    void Widget::paintEvent(QPaintEvent *event)
    {
        // 此处的this并不是设置父对象,而是设置画板(往哪儿画)
    	QPainter painter(this);
    }
    

2.设置画笔

  • QPainter在绘制时,是有⼀个默认的画笔的,使⽤时也可以⾃定义画笔

  • QPen类中定义了QPainter应该如何绘制形状、线条和轮廓,同时通过QPen类可以设置画笔的线宽、颜⾊、样式、 画刷

  • 画笔的颜⾊可以在实例化画笔对象时进⾏设置,画笔的宽度是通过setWidth()进⾏设置,画笔的⻛格是通过setStyle()进⾏设置,设置画刷主要是通过setBrush()

    • 设置画笔颜⾊QPen::QPen(const QColor& color)
      • 画笔的颜⾊主要是通过QColor类设置
    • 设置画笔宽度void QPen::setWidth(int width)
    • 设置画笔⻛格void QPen::setStyle(Qt::PenStyle style),有如下风格
      请添加图片描述
  • 示例

    void Widget::paintEvent(QPaintEvent *event)
    {
        QPainter painter(this);
        
        QPen pen;
        pen.setColor(QColor(255, 0, 0));
        pen.setWidth(5);
        pen.setStyle(Qt::DashLine);
        
        painter.setPen(pen);
    }
    

3.设置画刷

  • 画刷是使⽤QBrush类来描述,画刷⼤多⽤于填充

    • QBrush定义了QPainter的填充模式, 具有样式、颜⾊、渐变以及纹理等属性
  • 设置画刷主要通过void QPen::setBrush(const QBrush& brush),其参数为画刷的格式

    • 画刷的格式中定义了填充的样式,使⽤Qt::BrushStyle枚举,默认值是Qt::NoBrush
      请添加图片描述
  • 示例

    void Widget::paintEvent(QPaintEvent *event)
    {
        QPainter painter(this);
        
        QBrush brush;
        brush.setColor(QColor(0, 255, 0));
        brush.setStyle(Qt::CrossPattern);
        
        painter.setBrush(brush);
    }
    

4.设置画家

1.移动画家位置

  • 有时候在绘制多个图形时,想使⽤同⼀坐标位置,那么绘制出来的图形肯定会重合,此时,可以通过 移动画家的位置来使图形不发⽣重合
  • 通过使⽤translate()即可移动画家所在位置
  • 示例
    void Widget::paintEvent(QPaintEvent *event)
    {
        QPainter painter(this);
        
        painter.drawEllipse(QPoint(100, 200), 100, 100);
        
        // 让画家移动
        painter.translate(200, 300);
        
        painter.drawEllipse(QPoint(100, 200), 100, 100);
    }
    

2.保存/加载画家的状态

  • 在绘制图形的过程中,可以通过save()来保存画家的状态,使⽤restore()还原画家状态
  • 示例
    void Widget::paintEvent(QPaintEvent *event)
    {
        QPainter painter(this);
        
        painter.drawEllipse(QPoint(100, 200), 100, 100);
        
        painter.translate(200, 0); // 让画家移动
        
        painter.save(); // 保存画家状态
        
        painter.drawEllipse(QPoint(100, 200), 100, 100);
        
        painter.translate(200, 0); // 让画家移动
        
        painter.restore(); // 还原画家状态
        
        painter.drawEllipse(QPoint(100, 200), 100, 100);
    }
    
  • 上述代码现象:在画第三个圆之前,由于还原了画家的状态,所以此时画家的位置坐标会移动到画家状态保存的地⽅,所以在绘制第三个圆的位置时实际是和第⼆个圆发⽣了重叠

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

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

相关文章

第N8周:使用Word2vec实现文本分类

本文为365天深度学习训练营 中的学习记录博客原作者:K同学啊 一、数据预处理 任务说明: 本次将加入Word2vec使用PyTorch实现中文文本分类,Word2Vec 则是其中的一种词嵌入方法,是一种用于生成词向量的浅层神经网络模型,由Tomas M…

spring boot学习第二十篇:使用minio上传下载文件获取文件路径

先安装好minio&#xff0c;参考&#xff1a;window10安装minio-CSDN博客 1、pom.xml文件添加依赖&#xff1a; <!-- 操作minio的java客户端--><dependency><groupId>io.minio</groupId><artifactId>minio</artifactId><version>8.…

C语言:ifswitch分支语句

目录 前言 一、if语句 1.1 if 1.2 else 1.3 嵌套if 1.4 悬空else问题 二、switch语句 2.1 if语句和switch语句的对比 2.2 switch语句中的default 前言 C语⾔是结构化的程序设计语言&#xff0c;这里的结构指的是顺序结构、选择结构、循环结构&#xff0c;C语言是能够实…

大模型之战-操作数据表-coze

工作流直接操作数据库啦【何时可以直接访问自己的数据库呢】 1&#xff0c;第一步创建一个bot智能体 1.1&#xff0c;bot中创建数据库表&#xff1a; 1.2&#xff0c;智能体可以通过对话&#xff0c;操作表&#xff1b;【增加&#xff0c;筛选查询等】 1.2.1&#xff0c;增加…

视频美颜SDK与直播美颜工具的开发详解与技术优化

本篇文章&#xff0c;小编将为开发者提供一份详细的美颜指南。 一、视频美颜SDK的核心功能 视频美颜SDK是一种嵌入式软件开发工具包&#xff0c;允许开发者在应用中轻松实现实时美颜效果。其核心功能主要包括&#xff1a; 1.实时磨皮 2.美白功能 3.瘦脸与大眼 4.智能滤镜…

链式结构二叉树的应用

一、求二叉树节点的个数 思路1&#xff1a;将一棵二叉树分成根节点和它的左右子树&#xff0c;其左右子树又可以分成根节点和左右子树&#xff0c;运用函数递归的方式统计根节点的数量&#xff0c;将根节点的数量相加。 比如这颗二叉树&#xff0c;1是根节点&#xff0c;size&…

自闭症表现的全方位解读

自闭症&#xff0c;一种神经发育障碍&#xff0c;影响着许多儿童和家庭的生活。了解自闭症的表现对于早期诊断、干预和支持这些孩子至关重要。 自闭症的表现形式多样&#xff0c;且在不同个体之间可能存在较大差异。社交互动障碍是自闭症的核心症状之一。自闭症儿童往往在与人建…

【软件测试面试题】WEB功能测试(持续更新)

Hi&#xff0c;大家好&#xff0c;我是小码哥。最近很多朋友都在说今年的互联网行情不好&#xff0c;面试很难&#xff0c;不知道怎么复习&#xff0c;我最近总结了一份在软件测试面试中比较常见的WEB功能测试面试面试题合集&#xff0c;希望对大家有帮助。 建议点赞收藏再阅读…

《机器学习数据标准化》—— 0~1归一化 和 Z标准化

文章目录 1、为什么要数据标准化2、常用的两种数据标准化1、0~1归一化2、Z标准化 3、注意事项 1、为什么要数据标准化 主要是基于以下几个方面的原因&#xff1a; 消除量纲影响&#xff1a;在机器学习中&#xff0c;不同的特征往往具有不同的量纲和单位。例如&#xff0c;身高…

DHT11温湿度传感器详解(STM32)

目录 一、介绍 二、传感器原理 1.原理图 2.工作时序 3.起始信号与响应信号 4.读数据时序 5.DHT11数据格式 三、程序设计 main.c文件 dht11.h文件 dht11.c文件 四、实验效果展示 五、资料获取 项目分享 一、介绍 DHT11是一款含有已校准数字信号输出的温湿度复合传感器&…

commvault学习(9):备份mysql(linux平台)

1.全备份 1.1创建实例 在centos7上安装完带有mysql组件的cv客户端后&#xff0c;就能在CS上看到客户端的mysql选项 右击图中mysql&#xff0c;点击所有任务-新MySql Server 在弹出的配置框中进行如下设置&#xff1a; *服务器名&#xff1a;类似任务名&#xff0c;自行设置即…

基于SpringBoot的论坛系统设计与实现(源码+lw+部署文档+讲解等)

文章目录 前言具体实现截图详细视频演示技术栈系统测试为什么选择我官方认证玩家&#xff0c;服务很多代码文档&#xff0c;百分百好评&#xff0c;战绩可查&#xff01;&#xff01;入职于互联网大厂&#xff0c;可以交流&#xff0c;共同进步。有保障的售后 代码参考数据库参…

伊朗通过 ChatGPT 试图影响美国大选, OpenAI 封禁多个账户|TodayAI

OpenAI 近日宣布&#xff0c;他们已经封禁了一系列与伊朗影响行动有关的 ChatGPT 账户&#xff0c;这些账户涉嫌利用该 AI 工具生成并传播与美国总统选举、以色列 – 哈马斯战争以及奥运会等相关的内容。 OpenAI 表示&#xff0c;这些账户与一个名为 “Storm-2035” 的秘密伊朗…

(Arxiv-2023)潜在一致性模型:通过少步推理合成高分辨率图像

潜在一致性模型&#xff1a;通过少步推理合成高分辨率图像 Paper Title: Latent Consistency Models: Synthesizing High-Resolution Images with Few-Step Inference Paper是清华发表在Arxiv 2023的工作 Paper地址 Code地址 ABSTRACT 潜在扩散模型 (LDM) 在合成高分辨率图像方…

寻找峰值(100%用例)C卷(JavaPythonC++Node.jsC语言)

给定一个长度为n的数组nums,请你找到峰值并返回其索引。数组可能包含多个峰值,在这种情况下,返回任何一个所在位置即可。 1. 峰值 元素是指其值严格大于左右相邻值的元素 。严格大于即不能有等于 2.假设 nums[-1] = nums[n] = 3.对于所有有效的 i 都有 nums[i] != nums[…

dockerfile搭建部署LNMP

目录 实验 架构&#xff1a; 实验步骤&#xff1a; nginx部分 mysql部分 php部分 实验 实验&#xff1a;用dockerfile搭建LNMP论坛 架构&#xff1a; 一台docker虚拟机 docker部署nginx 1.22 指定ip地址172.111.0.10 docker部署mysql 8.0.30 指定ip地址…

机器学习常用包numpy篇(三)随机数

目录 前言 随机数的生成 1.指定形状 生成【0&#xff0c;1&#xff09;的随机数组 2.从标准正态分布中返回一个或多个样本值&#xff08;组成数组&#xff09; 3.生成规定区间内的规定形状的随机数组 4. 生成[0, 1) 区间内指定 size 的随机浮点数 数组 5.从给定的数组里…

visionpro链接相机-生成应用程序

Cognex GigE Vision Configurator VisionPro (R) Application Wizard

无边界经济:Web3如何打造全球化数字市场

随着互联网技术的不断发展&#xff0c;Web3正在成为推动全球数字市场变革的关键力量。相较于传统的中心化互联网&#xff0c;Web3通过去中心化、区块链和智能合约等技术&#xff0c;正在重新定义全球经济的运作方式。本文将探讨Web3如何实现全球化数字市场的无边界化&#xff0…

【备战蓝桥杯青少组】第二天 奇特的砖墙

真题 第十四届省赛 编程题 第5题 工人砌了一面奇特的砖墙&#xff0c;该墙由N列砖组成&#xff08;1≤N≤1e6&#xff09;&#xff0c;且每列砖的数量为Ki&#xff08;1≤Ki≤1e4&#xff0c;相邻砖块之间无缝隙&#xff09;&#xff0c;每块砖的长宽高都为1。小蓝为了美化这面…