Qt中QPainter基本绘图

2024-06-11 21:08
文章标签 qt 绘图 基本 qpainter

本文主要是介绍Qt中QPainter基本绘图,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

QWidget 派系的只能在paintEvent中进行重绘;如果你想要很好的交互功能的话推荐QGraphicsView框架,自定义Item的绘制在paint函数;如果你想利用线程绘制的话,你可以创建个QPixmap或者QImage,然后在把图片当画布在线程中绘制。

Qt的绘图系统基于 QPainter  QPaintDevice 和 QPaintEngine类

1). QPainter : 用于绘图操作的类

2).QPaintDevice   : 可以使用QPainter进行绘图的抽象的二维界面

3).QPaintEngine  : 为QPainter提供在不同设备上绘图的接口,由QPainter和QPainterDevice内部使用,应用程序无需调用QPaintEngine,除非要创建自己的设备类型

 一般绘图设备包括:QWidget 、QPixmap、QImage等,这些绘图设备为QPainter提供一个“画布”

 

1.  QWidget类及其子类是最常用的绘图设备,从QWidget继承的类都有QPaintEvent事件 ,要在设备上绘图,只需要重定义此事件,并编写响应代码

 ::paintEvent(QPaintEvent *e)

{

  QPainter painter(this)//绘制与绘图设备关联的QPainter对象

  //painter在设备的窗口上绘图

    

}

 

2 . QPainter绘图的主要属性

QPainter绘图,主要绘制一些基本图形元素(点、直线、圆形、矩形、曲线、文字),控制这些绘图元素特性的主要是QPainter的3个属性:

  1)   pen属性    :  是一个QPen对象,用于控制线条的颜色、宽度、线型

  2)brush属性 :  是一个QBrush对象,用于一个区域的填充特性,可以设置填充颜色、填充方式、渐变特性等

  3)font属性:      是一个QFont对象,用于绘制颜色的时候,设置文字的字体样式、大小属性

使用3个属性基本控制绘图的基本特点,还有其他功能可结合使用:叠加 旋转和缩放

 

3. QPen  用于绘图时对线条的设置,主要包括线宽,颜色,线型等,QPen类的主要接口函数,通常一个设置函数都有一个对应的读取函数

setColor(QColor &color)                              //  设置画笔颜色 线条颜色

setWidth(int width)                                      //   设置线条宽度

setStyle(Qt::PenStyle style)                   //   设置线条样式,参数为Qt::PenStyle枚举类型

setCapStyle(Qt::PenCapStyle style)      //   设置线条端点样式

setJoinStyle(Qt::PenJoinStyle style)      //    设置连接样式

 

4. QBrush 用于绘图时填充特性:填充颜色 填充样式、材质填充时的材质图片

setColor(QColor &color)                          //设置画刷颜色,实体填充即为填充色

setStyle(Qt::BrushStyle style)            //设置画刷样式

setTexture(QPixmap &pixmap)               //设置一个QPixmap类型的图片作为画刷的图片,画刷样式自动设置为Qt::TexturePattern

setTextureImage(QImage &image)         //设置一个QImage类型的图片作为画刷图片,画刷样式自动设置为Qt::TexturePattern

 

setStyle(Qt::BrushStyle style)            //设置画刷样式

Qt::SolidPatton                                      // 单一颜色填充

Qt::HorPatton                                        // 水平线填充

Qt::VerPatton                                        // 垂直线填充

Qt::TexturePattern                                // 材质填充 需要指定texture 或者 textureImage图片

Qt::QLinearGradient                            // 线性渐变

Qt::QRadialGradient                             // 辐射渐变

Qt::QConicalGradient                          // 圆锥渐变

1 QPixmap texturePixmap(":images/images/texture.jpg");
2 QBrush brush
3 brush.setStyle(Qt::TexturePattern)          // 画刷填充材质
4 brush.setTexture(texturePixmap)             // 设置材质图片
5 painter.setBrush(brush)

5 .QBrush 中的渐变填充

3个实现渐变填充的类:

1) QLinearGradient                                 //线性渐变    制定一个起点和颜色,一个终点及其颜色,还可以指定中间某点颜色,起点和终点之间的颜色会线性插值计算

2) QRadialGradient                                //简单辐射和扩展辐射

3) QConicalGradient                              //圆锥形渐变

还需要用到方法  setSpread(QGradient::Spread method)函数设置延展方式,圆锥形填充没有延展效果

PadSpread      用结束点的颜色填充外部区域(缺省)

RepeatSpread     重复使用简便方式填充外部区域

ReflectSpread      反射式重复使用简便方式填充外部区域

复制代码

 1 #include "paintt.h"2 #include "ui_paintt.h"3 #include <QPaintEvent>4 #include <QPainter>5 6 7 PaintT::PaintT(QWidget *parent) :8     QWidget(parent),9     ui(new Ui::PaintT)
10 {
11     ui->setupUi(this);
12     setPalette(QPalette(Qt::white));//控件调色板 设置窗口为白色背景
13     setAutoFillBackground(true);
14 }
15 
16 PaintT::~PaintT()
17 {
18     delete ui;
19 }
20 
21 void PaintT::paintEvent(QPaintEvent *event)
22 {
23     QPainter painter(this);
24     painter.setRenderHint(QPainter::Antialiasing);   //线条抗锯齿
25     painter.setRenderHint(QPainter::TextAntialiasing);
26 
27     int w = this->width();             //绘图区宽度
28     int h = this->height();            //绘图区高度
29 #if 0
30     QRect rect(w/4 ,h/4,w/2,h/2);      //中间区域矩形框 这个矩形随着widget大小变化而变化
31     QPen pen ;
32     pen.setWidth(3);
33     pen.setColor(Qt::red);
34     pen.setStyle(Qt::DashDotLine);
35     pen.setCapStyle(Qt::FlatCap);
36     pen.setJoinStyle(Qt::BevelJoin);
37     painter.setPen(pen);
38 
39     QBrush brush;
40     brush.setColor(Qt::yellow);
41     brush.setStyle(Qt::SolidPattern);
42     painter.setBrush(brush);
43 #endif
44 //QRadialGradient::QRadialGradient(qreal cx, qreal cy, qreal radius, qreal fx, qreal fy)
45     QRadialGradient radialGrad(w/2,h/2,qMax(w/8,h/8),w/2,h/2);//辐射填充中心点,辐射填充去半径,焦点坐标
46     radialGrad.setColorAt(0,Qt::green);   // 这里使用逻辑坐标
47     radialGrad.setColorAt(1,Qt::blue);    // 0 起点:辐射中心点  1 终点:填充区圆周
48     radialGrad.setSpread(QGradient::ReflectSpread);
49     painter.setBrush(radialGrad);
50 
51     painter.drawRect(this->rect());   //即widget窗口的整个矩形,大于定义的辐射填充区域有延展效果
52 }

复制代码

自带催眠眩晕效果,不停绘制刷新,不知道会不会出现动态效果

 

6.QPainter 中的 drawPath 函数 绘制 一个复合的图形对象

这篇关于Qt中QPainter基本绘图的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1052285

相关文章

Qt实现发送HTTP请求的示例详解

《Qt实现发送HTTP请求的示例详解》这篇文章主要为大家详细介绍了如何通过Qt实现发送HTTP请求,文中的示例代码讲解详细,具有一定的借鉴价值,感兴趣的小伙伴可以跟随小编一起学习一下... 目录1、添加network模块2、包含改头文件3、创建网络访问管理器4、创建接口5、创建网络请求对象6、创建一个回复对

Python中多线程和多进程的基本用法详解

《Python中多线程和多进程的基本用法详解》这篇文章介绍了Python中多线程和多进程的相关知识,包括并发编程的优势,多线程和多进程的概念、适用场景、示例代码,线程池和进程池的使用,以及如何选择合适... 目录引言一、并发编程的主要优势二、python的多线程(Threading)1. 什么是多线程?2.

Qt 中集成mqtt协议的使用方法

《Qt中集成mqtt协议的使用方法》文章介绍了如何在工程中引入qmqtt库,并通过声明一个单例类来暴露订阅到的主题数据,本文通过实例代码给大家介绍的非常详细,感兴趣的朋友一起看看吧... 目录一,引入qmqtt 库二,使用一,引入qmqtt 库我是将整个头文件/源文件都添加到了工程中进行编译,这样 跨平台

MyBatis-Flex BaseMapper的接口基本用法小结

《MyBatis-FlexBaseMapper的接口基本用法小结》本文主要介绍了MyBatis-FlexBaseMapper的接口基本用法小结,文中通过示例代码介绍的非常详细,对大家的学习或者工作具... 目录MyBATis-Flex简单介绍特性基础方法INSERT① insert② insertSelec

JAVA调用Deepseek的api完成基本对话简单代码示例

《JAVA调用Deepseek的api完成基本对话简单代码示例》:本文主要介绍JAVA调用Deepseek的api完成基本对话的相关资料,文中详细讲解了如何获取DeepSeekAPI密钥、添加H... 获取API密钥首先,从DeepSeek平台获取API密钥,用于身份验证。添加HTTP客户端依赖使用Jav

C++中使用vector存储并遍历数据的基本步骤

《C++中使用vector存储并遍历数据的基本步骤》C++标准模板库(STL)提供了多种容器类型,包括顺序容器、关联容器、无序关联容器和容器适配器,每种容器都有其特定的用途和特性,:本文主要介绍C... 目录(1)容器及简要描述‌php顺序容器‌‌关联容器‌‌无序关联容器‌(基于哈希表):‌容器适配器‌:(

使用Python进行文件读写操作的基本方法

《使用Python进行文件读写操作的基本方法》今天的内容来介绍Python中进行文件读写操作的方法,这在学习Python时是必不可少的技术点,希望可以帮助到正在学习python的小伙伴,以下是Pyth... 目录一、文件读取:二、文件写入:三、文件追加:四、文件读写的二进制模式:五、使用 json 模块读写

基于Qt Qml实现时间轴组件

《基于QtQml实现时间轴组件》时间轴组件是现代用户界面中常见的元素,用于按时间顺序展示事件,本文主要为大家详细介绍了如何使用Qml实现一个简单的时间轴组件,需要的可以参考下... 目录写在前面效果图组件概述实现细节1. 组件结构2. 属性定义3. 数据模型4. 事件项的添加和排序5. 事件项的渲染如何使用

基于Qt开发一个简单的OFD阅读器

《基于Qt开发一个简单的OFD阅读器》这篇文章主要为大家详细介绍了如何使用Qt框架开发一个功能强大且性能优异的OFD阅读器,文中的示例代码讲解详细,有需要的小伙伴可以参考一下... 目录摘要引言一、OFD文件格式解析二、文档结构解析三、页面渲染四、用户交互五、性能优化六、示例代码七、未来发展方向八、结论摘要

python与QT联合的详细步骤记录

《python与QT联合的详细步骤记录》:本文主要介绍python与QT联合的详细步骤,文章还展示了如何在Python中调用QT的.ui文件来实现GUI界面,并介绍了多窗口的应用,文中通过代码介绍... 目录一、文章简介二、安装pyqt5三、GUI页面设计四、python的使用python文件创建pytho