QGraphicsRectItem 点击的时候变化边框颜色

在Qt中,如果你想要在点击QGraphicsRectItem时改变其边框颜色,你可以通过重写mousePressEvent函数来实现这一功能。下面是一个简单的例子,展示了如何在点击时改变边框颜色:

 
#include <QGraphicsRectItem>  
#include <QGraphicsSceneMouseEvent>  
  
class ClickableRectItem : public QGraphicsRectItem {  
public:  
    ClickableRectItem(const QRectF &rect, QGraphicsItem *parent = nullptr)  
        : QGraphicsRectItem(rect, parent) {  
        // 初始化边框颜色  
        borderColor = Qt::black;  
        setAcceptHoverEvents(true); // 启用悬停事件,如果需要的话  
    }  
  
protected:  
    void mousePressEvent(QGraphicsSceneMouseEvent *event) override {  
        if (event->button() == Qt::LeftButton) {  
            // 点击时改变边框颜色  
            borderColor = Qt::red; // 或者任何你想要的颜色  
            update(); // 更新以触发重绘  
        }  
        QGraphicsRectItem::mousePressEvent(event); // 调用基类的mousePressEvent  
    }  
  
    void paint(QPainter *painter, const QStyleOptionGraphicsItem *option, QWidget *widget = nullptr) override {  
        QPen pen(borderColor);  
        pen.setWidth(2); // 设置边框宽度  
        painter->setPen(pen);  
        painter->setBrush(Qt::white); // 设置矩形内部填充颜色,可以根据需要修改  
        painter->drawRect(rect()); // 绘制矩形  
    }  
  
private:  
    QColor borderColor;  
};

在这个例子中,ClickableRectItem类继承自QGraphicsRectItem。当鼠标左键点击该矩形项时,mousePressEvent函数会被触发,并将边框颜色改为红色。然后调用update()函数来触发一个重绘事件,这会导致paint函数被调用,并使用新的边框颜色重新绘制矩形。

要使用这个自定义的矩形项,你可以这样创建并添加到场景中:

 
QGraphicsScene *scene = new QGraphicsScene();  
ClickableRectItem *rectItem = new ClickableRectItem(QRectF(0, 0, 100, 100));  
scene->addItem(rectItem);

现在,每当你用鼠标左键点击这个矩形项时,它的边框颜色就会变为红色。如果你想要在点击后再次点击恢复原来的颜色,你可以在mousePressEvent中添加逻辑来切换颜色。

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值