【Qt 实现一个画板,基于QWidget,可以绘制直线和矩形】

本文介绍如何使用Qt的QWidget和QPainter实现一个基础的画板应用,支持绘制直线和矩形。通过鼠标事件处理,实现图形绘制与更新。详细介绍了关键的PaintWidget类以及Shape、Line和Rect子类的设计与实现。
摘要由CSDN通过智能技术生成


🙉🙉更多内容 点击:Qt 专栏 🙉🙉



简介

这里我会只做出一个简单的画板程序,大体上就是能够画直线和矩形吧。这样,我计划分成两种实现,一是使用普通的 QWidget 作为画板,第二则是使用 Graphcis View Framework 来实现。因为前面有朋友说不大明白 Graphics View 的相关内容,所以计划如此。

好了,现在先来看看我们的主体框架。我们的框架还是使用 Qt Creator 创建一个 Gui Application工程。

简单的 main()函数就不再赘述。

效果展示

喜欢的伙伴可以自己扩展
图片由以下软件制作
在这里插入图片描述

Qt中创建一个自定义的QWidget子类来绘制图形,你可以通过重写QWidget的`paintEvent`函数来实现。`paintEvent`是处理绘图事件的函数,当需要重绘部件时,Qt框架会自动调用它。下面是一个简单的步骤说明: 1. 创建一个新的类,继承自QWidget。 2. 在该类的构造函数中调用`setAutoFillBackground(false)`,以禁用自动背景填充。 3. 重写`paintEvent`函数,在这个函数中使用`QPainter`对象来绘制图形。 4. 创建该自定义类的实例,并将其作为窗口部件使用。 下面是一个简单的示例代码: ```cpp // MyWidget.h #ifndef MYWIDGET_H #define MYWIDGET_H #include <QWidget> class MyWidget : public QWidget { Q_OBJECT public: MyWidget(QWidget *parent = nullptr); protected: void paintEvent(QPaintEvent *event) override; }; #endif // MYWIDGET_H // MyWidget.cpp #include "MyWidget.h" #include <QPainter> MyWidget::MyWidget(QWidget *parent) : QWidget(parent) { setAutoFillBackground(false); } void MyWidget::paintEvent(QPaintEvent *event) { QPainter painter(this); // 这里可以设置画笔颜色、样式等 painter.setPen(Qt::red); // 绘制简单的图形,例如矩形 painter.drawRect(10, 10, 100, 100); // 更复杂的图形绘制可以在这里实现 } // main.cpp #include <QApplication> #include "MyWidget.h" int main(int argc, char *argv[]) { QApplication app(argc, argv); MyWidget widget; widget.show(); return app.exec(); } ``` 在上述代码中,自定义的`MyWidget`类继承自`QWidget`。在构造函数中,调用了`setAutoFillBackground(false)`来避免自动填充背景。然后,重写了`paintEvent`函数,在其中使用`QPainter`对象绘制一个红色的矩形
评论 5
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Qt历险记

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值