QT-QPainter介绍

QT-QPainter介绍介绍可以在 QPaintDevice 类上绘制各种图形 QPaintDevice 类表示 QPainter 的绘图设备 画布 QpaintDevice 子类有 QImage QOpenGLPaint QWidget 等 所以 QPainter 可以在 QImage QOpenGLPaint QWidget 上进行绘制图形 QPainter 只能在类对象的 paintEvent 函

介绍

  • 可以在QPaintDevice类上绘制各种图形
  • QPaintDevice类表示QPainter的绘图设备(画布)
  • QpaintDevice子类有QImage、QOpenGLPaintDevice、QWidget 等
  • 所以, QPainter可以在QImageQOpenGLPaintDeviceQWidget上进行绘制图形
  • QPainter只能在类对象的paintEvent()函数中绘制图形

QPainter类的成员角色有:

  • QPen         : 用于绘制几何图形的边缘,由颜色,宽度,线风格等参数组成
  • QBrush     : 用于填充几何图形的调色板,由颜色和填充风格组成
  • QFont       : 用于文本绘制
  • QPixmap  : 绘制图片,可以加速显示,带有屏幕截图,窗口截图等支持,适合小图片
  • QImage    : 绘制图片,可以直接读取图像文件进行像素访问,适合大图片
  • QBitmap  : QPixmap的一个子类,主要用于显示单色位图
  • QPicture  : 绘图装置,用于记录和重播Qpainter的绘图指令 

具体参考: https://blog.csdn.net/cloud_castle/article/details/

QPainter基础图形绘制相关函数:

 QT-QPainter介绍

 

绘画圆弧drawArc

 QT-QPainter介绍

QPainter painter(this); painter.setPen( QPen(QColor(11,67,127),3)); QRectF rect(40.0, 40.0, 100.0, 100.0); painter.setRenderHint(QPainter:: Antialiasing, true); //设置渲染,启动反锯齿  painter.drawArc(rect,30*16,150*16); //绘画角度为30°~(30+150°)  painter.drawPoint(40+50,40+50); //绘制中心点

绘画椭圆drawElipse

 QT-QPainter介绍

QPainter painter(this); painter.setRenderHint(QPainter:: Antialiasing, true); //设置渲染,启动反锯齿  painter.setPen( QPen(QColor(11,67,127),3)); painter.drawEllipse(40.0, 40.0, 100.0, 100.0); //半径为50的圆

绘画扇形drawPie

 QT-QPainter介绍

QPainter painter(this); painter.setPen(QPen(QColor(11,67,127),3)); QRectF rect(40.0, 40.0, 100.0, 100.0); painter.setRenderHint(QPainter:: Antialiasing, true); //设置渲染,启动反锯齿  painter.drawPie(rect,30*16,150*16); //绘画角度为30°~(30+150°)

绘画弦drawChord

 QT-QPainter介绍

QPainter painter(this); painter.setPen(QPen(QColor(11,67,127),3)); QRectF rect(40.0, 40.0, 100.0, 100.0); painter.setRenderHint(QPainter:: Antialiasing, true); //设置渲染,启动反锯齿  painter.drawChord(rect,30*16,150*16); //绘画角度为30°~(30+150°)

QPainter-视口/窗口

在Qt中, QPainter可以通过视口和窗口来设置自身组件大小位置.

视口:  基于QPaintDevice类组件的坐标实现的,属于物理坐标,通过setViewport成员函数设置

窗口:  基于自身的逻辑坐标实现的,并不是真实坐标,可以通过setWindow成员函数设置

 

需要注意的是:

  • Qpainter的坐标是使用的窗口坐标(逻辑坐标)
  • 当QPainter初始化时,视口和窗口坐标默认是相同的,也就是说原点(0,0)在于窗口左上角
  • 所以视口和窗口的最小坐标和最大坐标是从左上到右下的.

 

示例1-设置原点(0,0)为窗口的(100,100),设置绘画区域为窗口大小为100*100

如下图所示,其中蓝色为视口坐标,红色为窗口坐标:

 QT-QPainter介绍

由于数学Y坐标方向与屏幕Y坐标方向是相反的,所以w保持不变,h = -height

所以对应代码为:

 QPainter painter(this); QSize ViewWH(100,100); //定义视口宽高  painter.setViewport(50,50,ViewWH.width(),ViewWH.height()); painter.setWindow(-50,50,ViewWH.width(),-ViewWH.height()); painter.setBrush(QColor(187,229,253)); painter.setPen(QPen(QColor(11,67,127),2)); painter.drawRect(-50,50,ViewWH.width(),-ViewWH.height()); //窗口背景  painter.drawLine(-50,0,50,0); //画X坐标  painter.drawLine(0,-50,0,50); //画Y坐标 

效果如下:

 QT-QPainter介绍

 

示例2-在窗口的中心处绘制正弦波

QPainter painter(this); painter.setViewport(50,50,width()-100,height()-100); //设置视口为中心处  painter.setWindow(-10,4,20,-8); //定义窗口 左上角为(-10,4) 右下角为(10,-4)  painter.fillRect(-10,4,20,-8,Qt::black); painter.setPen(QPen(QBrush(Qt::green),1/(width()-100)/20)); //由于当前窗口和视口的比例为 width()-100 : 20 //所以1px的横纵Line线宽 = 1/(width()-100)/20  painter.drawLine(-10,0,10,0); painter.setPen(QPen(QBrush(Qt::green),1/(height()-100)/8)); painter.drawLine(0,-4,0,4); for(float x=-10;x<10;x+=0.01) { float y= qSin(x); painter.drawPoint(QPointF(x,y)); qDebug()< 
 
   " 
  , 
  "<< 
  y; } 
 

效果如下:

 QT-QPainter介绍

 

Qpainter通过drawText来绘制文本

void MainWindow::paintEvent(QPaintEvent *) { QPainter painter(this); QFont font; font.setPixelSize(24); //设置字体像素大小为12 QString text=""; //设置显示的文本 QFontMetrics metrics(font); int w=metrics.width(text); //获取显示文本的宽度 int h=metrics.height(); //获取显示文本的高度 painter.setFont(font); painter.setPen(Qt::blue); painter.drawText(QRect(width()/2-w,height()/2-h,w,h),text); painter.drawRect(QRect(width()/2-w,height()/2-h,w,h)); qDebug()<<"w:"< 
 
   // 
  一个字符大小为12*24,所以宽度为12*7 qDebug()<< 
  " 
  h: 
  "< 
  
    // 
   高度为24 } 
   
 

效果:

QT-QPainter介绍

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/215396.html原文链接:https://javaforall.net

(0)
上一篇 2026年3月18日 下午2:01
下一篇 2026年3月18日 下午2:01


相关推荐

  • 常用配件

    常用配件常用配件常用配件常用配件一滤光片滤光片是塑料或玻璃片再加入特种染料做成的 红色滤光片只能让红光通过 如此类推 比如一束白光通过蓝色滤光片 射出的是一束蓝光 而绿光 红光极少 大多数被滤光片吸收了 滤光片的一个共性 就是没有任何滤光片能让目标的成像变的更明亮 因为所有的滤光片都会吸收某些波长 从而使物体变得更暗 理想的滤光片 应该使系统不需要的图像信息与目标点分离 并提高目标信息在图像中的对比度 且保持长期的光源稳定性

    2026年3月19日
    3
  • paraphrase和translation的区别_translating和interpreting的区别

    paraphrase和translation的区别_translating和interpreting的区别PreTranslateMessage是消息在送给TranslateMessage函数之前被调用的,绝大多数本窗口的消息都要通过这里,比较常用,当需要在MFC之前处理某些消息时,常常要在这里添加代码.                MFC消息控制流最具特色的地方是CWnd类的虚拟函数PreTranslateMessage(),通过重载这个函数,可以改变MFC的消息控制流程,甚至可以

    2025年11月6日
    4
  • mysql uniqueidentifier_Uniqueidentifier数据类型[通俗易懂]

    mysql uniqueidentifier_Uniqueidentifier数据类型[通俗易懂]一.Uniqueidentifier数据类型可存储16字节的二进制值Uniqueidentifier用来存储一个全局唯一标识符,即GUID。GUID是唯一的二进制数:世界上的任何两台计算机都不会生成重复的GUID值uniqueidentifier值通常不定义为常量。您可以按下列方式指定uniqueidentifier常量:字符串格式:’6F9619FF-8B86-D011-B42D-00C0…

    2025年10月8日
    6
  • 图像小波分解与重构

    图像小波分解与重构小波变换原理 nbsp nbsp 所谓的小波的小是针对傅里叶波而言 傅里叶波指的是在时域空间无穷震荡的正弦 或余弦波 nbsp 相对而言 小波指的是一种能量在时域非常集中的波 它的能量有限 都集中在某一点附近 而且积分的值为零 这说明它与傅里叶波一样是正交波 nbsp 举一些小波的例子 可以看到 能量集中在 x 轴 0 值附近 以 y 轴的 0 值为基线 上下两个区域的波形面积相等

    2026年3月26日
    3
  • Instruments详解

    Instruments详解使用 Instruments 可以监测分析 app 内存相关的 OverallMemor LeakedMemory AbandonedMem Zombies 等内容 1 Blank 空模板 创建一个空的模板 可以从 Library 库中添加其他模板 2 ActivityMoni 活动监视器 监控进程的 CPU 内存 磁盘 网络使用情况是程序在手机运行真正占

    2026年3月26日
    2
  • 精进Quartz源码—Quartz中JobStore保存JonDetail和Trigger源码分析(一)

    我都是分析的jobStore 方式为jdbc的SimpleTrigger!RAM的方式类似分析方式!要使用定时器,并讲任务持久到数据库,我们一定明白JobDetail和Trigger是如何操作进入数据库,如何注册到Scheduler中!前面我分析了Scheduler的start()和QuartzSchedulerThread的run()!这些都是要在下面讲的这个流程的基础上!那么下面就开始分析源码,

    2022年2月25日
    212

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号