QCustomPlot -paintevent(在图表上面进行QPainter绘制)

 

首先,声明QCustomPlot之后在构造函数里面实现

如果我直接重写MainWindow::paintevent(QPaintevent *event)

那么这个时候我绘制出来的图形会被mcustomplot覆盖

 效果如下:

 因为我们现在重写的paintevent事件是属于MainWindow这个类

所以QPainter绘制出来的图像是在ui界面上,而在界面上面添加的任何控件都会将其覆盖

这个时候我采用的做法是继承QCustomPlot类然后重写QCustomPlot类的paintevent

因为我想实现的效果是在图表上面点击释放鼠标会绘制一个矩形

所以我也需要重写鼠标事件

代码如下:

void customPlot::paintEvent(QPaintEvent *event)
{
   
  • 3
    点赞
  • 19
    收藏
    觉得还不错? 一键收藏
  • 7
    评论
在QT中使用QPainter绘制带有标题、轴线的图表可以采用以下步骤: 1. 创建一个QWidget或QFrame作为绘制图表的容器。 2. 重写QWidget或QFrame的paintEvent方法,在该方法中使用QPainter进行绘制。 3. 绘制图表的标题,可以使用QPainter的drawText方法。 4. 绘制图表的轴线,可以使用QPainter的drawLine方法。 5. 绘制图表的坐标轴刻度和标签,可以使用QPainter的drawText方法。 6. 绘制图表的数据点,可以使用QPainter的drawEllipse或drawRect方法。 7. 在数据点之间绘制曲线或直线,可以使用QPainter的drawPolyline方法。 8. 最后,调用QWidget或QFrame的update方法,触发paintEvent方法进行绘制。 具体实现方法可以参考以下代码: ```cpp void MyWidget::paintEvent(QPaintEvent *) { QPainter painter(this); // 绘制标题 painter.drawText(rect(), Qt::AlignTop | Qt::AlignHCenter, "My Chart"); // 绘制坐标轴 painter.drawLine(QPointF(50, height() - 50), QPointF(width() - 50, height() - 50)); // x轴 painter.drawLine(QPointF(50, height() - 50), QPointF(50, 50)); // y轴 // 绘制坐标轴刻度和标签 painter.drawText(QPointF(50, height() - 30), "0"); painter.drawText(QPointF(width() - 70, height() - 30), "100"); painter.drawText(QPointF(20, height() - 50), "0"); painter.drawText(QPointF(20, 70), "100"); // 绘制数据点和连接线 QVector<QPointF> points = {{75, height() - 75}, {100, height() - 50}, {125, height() - 75}, {150, height() - 100}, {175, height() - 125}, {200, height() - 150}}; painter.setPen(Qt::red); painter.setBrush(Qt::red); for (const auto &point : points) { painter.drawEllipse(point, 5, 5); } painter.drawPolyline(points); // 更新绘制 update(); } ``` 在该代码中,我们创建了一个QWidget作为绘制图表的容器,并重写了其paintEvent方法进行绘制。在绘制过程中,我们使用QPainter进行绘制绘制图表的标题、坐标轴、坐标轴刻度和标签、数据点和连接线。最后,我们调用QWidget的update方法,触发paintEvent方法进行绘制

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 7
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值