首页 > 其他分享 >【QT】绘图

【QT】绘图

时间:2024-11-24 12:04:57浏览次数:6  
标签:picture QT 画笔 300 QPoint 绘图 100 painter

在这里插入图片描述

个人主页~


绘图

一、绘图

1、基础内容

绘图可以帮助我们实现应对多种场景的功能,因为虽然Qt内部内置了很多控件,但是它们不能满足所有要求,我们就可以通过绘图来实现自定义图形

API核心类说明
QPainter用来绘画的对象,可以允许我们绘制各种图形
QPaintDevice描述QPainter把图形画到哪个对象上
QPen描述QPainter画出来的线
QBrush描述QPainter填充一个区域

一般绘图API的使用会放到paintEvent事件中,当控件首次创建控件被遮挡再解除遮挡窗口最小化再回复控件大小发生变化主动调用repaint或update方法时,paintEvent会被触发

2、绘制形状

下面只有线段是写在paintEvent里面的,其实它们都是要重写paintEvent函数的,为了简短表达,所以除了第一个其他的都没写出函数以及大括号和定义painter的部分

(1)线段

void Widget::paintEvent(QPaintEvent *event)
{
    QPainter painter(this);
    //参数为坐标(QPoint)
    painter.drawLine(QPoint(30,20),QPoint(300,200));
	//参数两个一组,为坐标(int)
    painter.drawLine(40,50,400,500);
}

在这里插入图片描述

(2)矩形

//参数从左到右依次是窗口横坐标、窗口纵坐标、所绘制矩形的宽、所绘制矩形的高
painter.drawRect(20,20,200,50);

在这里插入图片描述

(3)圆形

//从左到右参数依次是圆心坐标,离圆心的x距离,离圆心的y距离
painter.drawEllipse(QPoint(100,100),100,100);

在这里插入图片描述

(4)文本

//设置字体
QFont font("楷体",30);
painter.setFont(font);
//设置画笔颜色
painter.setPen(Qt::blue);
//画文本
painter.drawText(QRect(50,100,800,200),"超级小小怪-s_little_monster");

在这里插入图片描述

(5)画笔

QPen类控制画笔,它定义了QPainter绘制什么样的形状、线条和轮廓,以及设置画笔的线宽、颜色、样式、画刷

画笔颜色可以在实例化画笔对象时进行设置,画笔的宽度是通过setWidth()方法进行设置,画笔的风格是通过setSytle()方法进行设置,设置画刷主要是通过setBrush()方法

//画笔颜色
QPen::QPen(const QColor& color);
//画笔宽度
void QPen::setWidth(int width);
//画笔风格
void QPen::setSytle(Qt::PenSytle style);

以下是画笔的风格:
在这里插入图片描述

(6)画刷

用QBrush类描述,大多用于填充,具有样式、颜色、渐变、纹理等属性
以下是画刷的风格:
在这里插入图片描述

//设置画笔
QPen pen(QColor(155,155,255));
//画笔宽度
pen.setWidth(5);
//画笔风格
pen.setStyle(Qt::DashLine);
//将画笔设置到画家手中
painter.setPen(pen);
//设置画刷,设置为青色(cyan)
QBrush brush(Qt::cyan);
//画刷风格
brush.setStyle(Qt::Dense1Pattern);
//画家拿画刷
painter.setBrush(brush);
//画圆
painter.drawEllipse(QPoint(200,200),100,100);

在这里插入图片描述

3、绘制图片

(1)简单图片

//移动图片基点(基点默认为左上角)
painter.translate(100,100);
//绘制图片
painter.drawPixmap(0,0,QPixmap(":/picture/slm.jpg"));
//移动图片基点+改变图片尺寸+绘制图片
painter.drawPixmap(300,400,60,40,QPixmap(":/picture/slm.jpg"));

在这里插入图片描述

(2)旋转图片

painter.translate(300,300);
//对坐标系进行180°旋转(顺时针)
painter.rotate(180);
//使原点从(300,300)移动回到(0,0)
painter.translate(-300,-300);
//画图片
painter.drawPixmap(0,0,QPixmap(":/picture/slm.jpg"));

在这里插入图片描述

这里详细解释一下,第一行代码将图片移动到(300,300)此时旋转的基点就是(300,300),旋转180°之后的图片是下面这样的
在这里插入图片描述
原来我们的坐标系是向上y减小,向左x减小,此时坐标系180°旋转,变成了向上y增大,向左x增大,所以现在将基点移动到(-300,-300)就是向下移动300个像素,向右移动300个像素

4、其他

(1)移动画家位置

painter.drawEllipse(QPoint(100,100),100,100);
//移动画家位置,此时(200,0)就是下个圆的(0,0)基点
painter.translate(200,0);
painter.drawEllipse(QPoint(100,100),100,100);

在这里插入图片描述

(2)保存、加载画家的状态

save函数保存画家状态
restore函数还原画家状态

比如上面的程序可以稍加改造

painter.drawEllipse(QPoint(100,100),100,100);
painter.translate(200,0);
//保存状态
painter.save();
painter.drawEllipse(QPoint(100,100),100,100);
painter.translate(200,0);
//恢复状态
painter.restore();
painter.drawEllipse(QPoint(100,100),100,100);

在这里插入图片描述

我们发现第三个圆没有出现,其实是跟第二个圆重叠了,就是因为画家恢复了状态,导致画家的移动失效了

5、其他

(1)QPixmap

//画布大小
QPixmap map(600,600);
//实例化画家
QPainter painter(&map);
//画笔颜色
painter.setPen(Qt::green);
//画圆
painter.drawEllipse(QPoint(100,100),100,100);
//保存绘制的图片
map.save("C:\\Users\\14725\\Desktop\\map.png");

在这里插入图片描述

(2)QImage

//设置画布大小以及绘图格式,绘图格式可在Qt助手中查看
QImage img(600,600,QImage::Format_RGB32);
//填充色为白色,默认为黑色
img.fill(Qt::white);
QPainter painter(&img);
//画笔颜色
painter.setPen(Qt::green);
//画圆
painter.drawEllipse(QPoint(100,100),100,100);
img.save("C:\\Users\\14725\\Desktop\\img.png");

在这里插入图片描述

修改像素点
void Widget::paintEvent(QPaintEvent *event)
{
    QPainter painter(this);
    QImage img;
    img.load(":/picture/slm.jpg");
    //将长方形内的像素都改为红色
    for(int i = 100;i<300;i++)
    {
        for(int j = 100;j <200;j++)
        {
            QRgb rgb = qRgb(255,0,0);
            img.setPixel(i,j,rgb);
        }
    }
    //将这个图画出来
    painter.drawImage(0,0,img);
}

在这里插入图片描述

(3)QPicture

QPicture类似于游戏中的replay功能,replay可以通过记录地图中发生的所有事件,当回放replay的时候其实就是把上述记录的事件再一条一条的执行一遍就可以还原游戏场景了,这就大大节约了我们存储该内容的空间,当然它只能加载自己生成的文件,不能加载其他的文件

要使用begin和end配套,首先使用begin将QPicture实例作为参数传递进去,告诉系统开始记录,记录完毕后用end结束

Widget::Widget(QWidget *parent)
    : QWidget(parent)
    , ui(new Ui::Widget)
{
    ui->setupUi(this);

    QPicture picture;
    QPainter painter;
    //开始在画布上画画
    painter.begin(&picture);
    //设置画笔颜色
    painter.setPen(Qt::red);
    painter.drawEllipse(QPoint(100,100),100,100);
    //结束画画
    painter.end();
    picture.save("C:\\Users\\14725\\Desktop\\picture.pic");
}

void Widget::paintEvent(QPaintEvent *event)
{
    QPainter painter(this);
    //重现画图指令
    QPicture picture;
    picture.load("C:\\Users\\14725\\Desktop\\picture.pic");//加载图片
    painter.drawPicture(0,0,picture);
}

在这里插入图片描述
在这里插入图片描述
后缀为pic无法直接打开,只能通过重现绘图指令来打开


今日分享就到这了~

在这里插入图片描述

标签:picture,QT,画笔,300,QPoint,绘图,100,painter
From: https://blog.csdn.net/s_little_monster/article/details/143755043

相关文章

  • 用python写一段k-means聚类算法,要求使其能够显示聚类前后的差异,绘图使其可视化
    当您使用K-means算法时,可以使用scikit-learn库中的KMeans类来实现。以下是一个示例代码,可以帮助您理解如何使用K-means算法进行聚类,并使用matplotlib库绘制可视化结果。importnumpyasnpfromsklearn.clusterimportKMeansimportmatplotlib.pyplotasplt#创建一个......
  • 作为前端工程师,不了解MQTT,只知道HTTP,那就是不合格啦。
    作为前端开发工程师,了解MQTT(MessageQueuingTelemetryTransport)协议是很有必要的。MQTT是一种轻量级的消息传输协议,主要用于物联网(IoT)设备之间的通信。一、MQTT协议特点轻量级MQTT协议设计简洁,占用带宽小,对硬件资源要求低,非常适合在资源受限的设备上使用,如传感器、嵌......
  • 我开发了许多智能家居设备,支持通过MQTT接入home Assitant ,我想用php开发一个网站,通过
    您好,您想开发一个PHP网站,通过OpenAI的API和FunctionCalling功能,实现智能家居的控制。这是一个非常有趣的项目,下面我将为您提供实现思路和步骤。1.整体架构思路用户界面(PHP网站):用户可以在网站上与AI进行聊天。OpenAIAPI交互:将用户的输入发送给OpenAI的API,使用Functio......
  • 【Python项目】基于Python的数学函数绘图软件
    【Python项目】基于Python的数学函数绘图软件技术简介:采用C/S架构、Python语言、MYSQL数据库等实现。系统简介:系统的主要使用角色为普通用户和管理员用户,两者功能几乎是一致的,但管理员用户比普通用户多了用户管理的功能,普通用户比管理员用户多了注册的功能。两种角色共同有的......
  • 3. 使用Docker部署MQTT平台mosquitto到云服务器
    3.使用Docker部署MQTT平台mosquitto到云服务器1.拉取MosquittoDocker镜像(这里选择拉取1.6.14版本,因为最新版本报错Addressnotavailable)dockerpulleclipse-mosquitto#或者拉取1.6.14版本dockerpulleclipse-mosquitto:1.6.142.创建mosquitto配置文件在运......
  • Qt开发技巧(十九):定时器的调用问题,控件的透明问题,慎用事件过滤器,依赖库的路径链接,对话框
    继续讲一些Qt开发中的技巧操作:1.定时器的调用问题有一个场景经常遇到,那就是在符合某个条件下,延时一段时间去执行一段代码,如果短时间内触发多次又不需要频繁执行,只需要执行一次就行。如果选择用QTimer::singleShot无法终止已经触发的,这个时候就要主动实例化一个单次定时器,......
  • QtCreator通过CMake多文件编译.cpp、.qss、.h、.ui文件,达到MVC三层架构的效果
        博主在构建C++项目的时候,一般都喜欢将头文件和源文件分开为不同的文件夹,比如include目录下只存放.h文件和.ui文件,src目录下只存放.cpp和.qss文件,res目录下只存放图片、音频等文件,这时候使用CMake对项目进行分文件管理就特别方便和清晰了。  很多人写qt项目的......
  • [QT基础系列]标签QLabel
    标签QLabelQLabel是Qt中的标签类,通常用于显示提示性的文本,也可以显示图像文本可以获取和设置按钮上显示的文本//获取和设置显示的文本QStringtext()const;voidsetText(constQString&text);对齐方式用于设置标签中的内容在水平和垂直两个方向上的对齐方式......
  • 【动态绘图】python 动态柱形图 动态折线图 bar_chart_race sjvisualizer
    本文主要介绍如何使用Python的bar_chart_race和sjvisualizer模块绘制动态柱形图和动态折线图。关于sjvisualizer包使用详细可见【动态绘图】上。一、实验环境1.1操作系统及Python环境本实验的所使用的操作系统为Windows1064位,Python版本为Python3.12.4,Python编译器......
  • 实现Qtextedit控件大小改变时候希望不重新绘制
    实现Qtextedit控件大小改变时候希望不重新绘制4.备选方案5.完整示例6.总结要在QTextEdit控件大小改变时防止其重新绘制,可以通过创建一个自定义的QTextEdit子类,并重载相关事件来控制绘制行为。以下是实现这一目标的详细步骤和示例代码:创建自定义的QTextEdit......