[问题记录]Qt QGraphicsItem 移动时出现残影

目录

1.问题现象

2.问题原因

3.修改方案


1.问题现象

自定义 QGraphicsItem 时,绘制rect,对象移动时出现残影。

2.问题原因

直接原因是view未刷新的问题,所以网上有人使用方案 setViewportUpdateMode(QGraphicsView::FullViewportUpdate); 的方案,但当图片过多时,此方案会造成画面闪烁,耗费资源等问题。

而根本原因是,boundingRect返回大小的问题,存在两种情况:

(1)boundingRect 返回的大小,不能完全包含实际图形大小,导致刷新不全

(2)boundingRect的左上角顶点位置、长宽,未补全画笔宽度,导致原因同(1)

boundingRect函数功能,是将图形项的外部边界定义为一个矩形。所有的绘图操作都必须限制在图形的边界矩形中,QGraphicsView需要使用这个边界来确定重绘的区域。

而边界的宽度,精确为画笔宽度的的一半。

3.修改方案

boundingRect的左上角顶点,需要补充画笔宽度/2,实际矩形的长宽,补全画笔宽度

cpp 复制代码
QRectF CGraphicsDragItem::boundingRect() const
{
    return QRectF(
        -m_penWidth/2,
        -m_penWidth/2,
        m_rectWidth+m_penWidth,
        m_rectHeight+m_penWidth);
}

void CGraphicsDragItem::paint(
    QPainter *painter,
    const QStyleOptionGraphicsItem *option,
    QWidget *widget)
{
    Q_UNUSED(option);
    Q_UNUSED(widget);

    if (hasFocus() || !collidingItems().isEmpty())
    {
        m_penWidth = 10;
        painter->setPen(QPen(QColor(255, 255, 255, 200), m_penWidth));
        if (hasFocus())
        {
            for (auto it : collidingItems())
            {
                it->update();
            }
        }
    }
    else
    {
        m_penWidth = 1;
        painter->setPen(QPen(QColor(100, 100, 100, 100), m_penWidth));
    }

    painter->setBrush(m_clrBrush);
    painter->drawEllipse(0, 0, m_rectWidth, m_rectHeight);
}
相关推荐
Halo_tjn3 分钟前
Java IO流实现文件操作知识点
java·开发语言·windows·算法
FL16238631299 分钟前
VTK源码编译时候选qt5路径
开发语言·qt
Felven9 分钟前
C. Maximum Median
c语言·开发语言·算法
Wang's Blog31 分钟前
Lua: 基于协程的生产者-消费者模型实现
开发语言·lua
jamesge201042 分钟前
限流之漏桶算法
java·开发语言·算法
Dargon2881 小时前
Simulink的SIL软件在环测试
开发语言·matlab·simulink·mbd软件开发
csbysj20201 小时前
SVG 椭圆详解
开发语言
oioihoii1 小时前
C++数据竞争与无锁编程
java·开发语言·c++
资生算法程序员_畅想家_剑魔1 小时前
Java常见技术分享-16-多线程安全-并发编程的核心问题
java·开发语言
We....1 小时前
Java SPI 机制
java·开发语言