QGraphicsRectItem 点击的时候变化填充颜色

在Qt中,要改变QGraphicsRectItem在被点击时的填充颜色,你可以重写mousePressEvent方法来处理鼠标点击事件,并在其中改变矩形的填充颜色。以下是一个示例代码,展示了如何实现这一功能:


#include <QGraphicsRectItem>  
#include <QGraphicsSceneMouseEvent>  
  
class ClickableRectItem : public QGraphicsRectItem {  
public:  
    ClickableRectItem(const QRectF &rect, QGraphicsItem *parent = nullptr)  
        : QGraphicsRectItem(rect, parent), fillColor(Qt::white) {  
        setAcceptHoverEvents(true); // 可选,如果你还想处理悬停事件  
    }  
  
protected:  
    void mousePressEvent(QGraphicsSceneMouseEvent *event) override {  
        if (event->button() == Qt::LeftButton) {  
            // 切换填充颜色  
            fillColor = fillColor == Qt::white ? Qt::green : Qt::white;  
            update(); // 更新项目以触发重绘  
        }  
        QGraphicsRectItem::mousePressEvent(event); // 调用基类的事件处理器  
    }  
  
    void paint(QPainter *painter, const QStyleOptionGraphicsItem *option, QWidget *widget = nullptr) override {  
        QPen pen(Qt::black); // 边框颜色  
        pen.setWidth(1); // 边框宽度  
        painter->setPen(pen);  
        painter->setBrush(fillColor); // 设置填充颜色  
        painter->drawRect(rect()); // 绘制矩形  
    }  
  
private:  
    QColor fillColor;  
};

在这个例子中,ClickableRectItem 类有一个私有成员 fillColor,它用于存储矩形的当前填充颜色。在构造函数中,填充颜色被初始化为白色。当鼠标左键点击该矩形时,mousePressEvent 方法会被调用,并切换 fillColor 的值。如果当前颜色是白色,则将其更改为绿色;如果是绿色,则将其更改回白色。然后,通过调用 update() 方法触发重绘事件。

在 paint 方法中,使用 QPainter 设置笔和刷子来绘制矩形。笔用于绘制边框,而刷子用于填充矩形内部。

要使用这个自定义矩形项,你可以像之前一样创建它并将其添加到场景中:


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

现在,每当你点击这个矩形项时,它的填充颜色就会在白色和绿色之间切换。

void ChartBaseView::checkAndUpdateRange(QPointF point) { double valuex = point.x(); double valuey = point.y(); QValueAxis *axisX = dynamic_cast<QValueAxis*>(m_chart->axisX()); QValueAxis *axisY = dynamic_cast<QValueAxis*>(m_chart->axisY()); double xmin = axisX->min(); double xmax = axisX->max(); double ymin = axisY->min(); double ymax = axisY->max(); // 当数据点为正数,且x轴最小值为默认0时,向上调整x轴最小值 if(valuex > 0 && xmin == 0) setRangeX(valuex, valuex+1); // 超出时更新坐标轴范围 if(valuex < xmin) this->setRangeX(valuex, xmax); else if(valuex > xmax) this->setRangeX(xmin, valuex); if(valuey < ymin) this->setRangeY(valuey, ymax); else if(valuey > ymax) this->setRangeY(ymin, valuey); } void ChartBaseView::mouseMoveEvent(QMouseEvent *pEvent) { // 检查并初始化状态变量,防止被图例点击干扰 if (!pEvent->buttons()) { m_bMiddleButtonPressed = false; m_bLeftButtonPressed = false; } // 鼠标中键按下时,拖动图表 if (m_bMiddleButtonPressed) { QPoint oDeltaPos = pEvent->pos() - m_oPrePos; this->chart()->scroll(-oDeltaPos.x(), oDeltaPos.y()); m_oPrePos = pEvent->pos(); } // 鼠标左键按下时,绘制矩形 if (m_bLeftButtonPressed) { m_oEndPoint = pEvent->pos(); QRectF rect(m_oStartPoint, m_oEndPoint); m_oRectItem->setRect(rect.normalized()); // 处理矩形可能的负宽高 } // 绘制线 x_line->setLine(pEvent->x(),0,pEvent->x(),this->height()); y_line->setLine(0,pEvent->y(),this->width(),pEvent->y()); QChartView::mouseMoveEvent(pEvent); // 调用基类的方法 } void ChartBaseView::mousePressEvent(QMouseEvent *pEvent) { // 鼠标中键按下 if (pEvent->button() == Qt::MiddleButton) { m_bMiddleButtonPressed = true; m_oPrePos = pEvent->pos(); this->setCursor(Qt::OpenHandCursor); } // 鼠标左键按下 if (pEvent->button() == Qt::LeftButton) { m_bLeftButtonPressed = true; m_oStartPoint = pEvent->pos(); m_oEndPoint = m_oStartPoint; // 初始化矩形绘制 if (!m_oRectItem) { m_oRectItem = new QGraphicsRectItem(); // 设置线条样式 QPen pen; pen.setColor(QColor(84, 224, 255)); // 设置线条颜色 pen.setStyle(Qt::DashLine); // 设置为虚线 m_oRectItem->setPen(pen); QColor color; color.setRgb(181, 229, 255, 25); m_oRectItem->setBrush(color); // 设置填充颜色 m_oRectItem->setZValue(10); // 设置层级 this->chart()->scene()->addItem(m_oRectItem); } m_oRectItem->setRect(QRectF(m_oStartPoint, QSize())); m_oRectItem->setVisible(true); } QChartView::mousePressEvent(pEvent); // 调用基类的方法 } void ChartBaseView::mouseReleaseEvent(QMouseEvent *pEvent) { // 鼠标中键释放 if (pEvent->button() == Qt::MiddleButton) { m_bMiddleButtonPressed = false; this->setCursor(Qt::ArrowCursor); } // 鼠标左键释放 if (pEvent->button() == Qt::LeftButton && m_bLeftButtonPressed) { m_bLeftButtonPressed = false; m_oEndPoint = pEvent->pos(); // 对最终的矩形区域进行处理,转换为数据坐标 QRectF dataRect = QRectF(this->chart()->mapToValue(m_oStartPoint), this->chart()->mapToValue(m_oEndPoint)).normalized(); emit rectangleDrawn(dataRect); // 发出信号传递绘制完成的矩形 // 获取矩形的 x 值范围 double xmin = dataRect.left(); double xmax = dataRect.right(); // 设置 x 轴范围 this->setRangeX(xmin, xmax); // 隐藏矩形 m_oRectItem->setVisible(false); } QChartView::mouseReleaseEvent(pEvent); // 调用基类的方法 }
03-20
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值