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

本文探讨了在QCustomPlot中重写paintevent事件和鼠标事件以在图表上绘制矩形的问题。由于MainWindow的paintevent会导致图像被控件覆盖,因此选择继承QCustomPlot并重写其paintevent。目前遇到的问题包括:矩形绘制延迟、坐标定位不准确、缩放时不自动调整以及可能使用过滤器的解决方案。
摘要由CSDN通过智能技术生成

 

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

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

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

 效果如下:

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

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

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

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

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

代码如下:

void customPlot::paintEvent(QPaintEvent *event)
{
    //调用父类的paintEvent使QCustomPlot可以被重绘
    QCustomPlot::paintEvent(event);
    //在父类重绘完的基础上进行绘制
    //新建painter
    QPainter painter(this);
    //painter设置Pen
    painter.setPen(QPen(QColor(200,255,222)));
    QColor color(1
评论 7
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值