QWT--选取图元

本文介绍了如何在QWT库中自定义图元,并详细解释了如何通过rtti标识符来区分不同类型的自定义图元。同时,还展示了如何获取场景中的特定图元。

一、前言

在Qt的图形视图框架中,QGraphicsScent提供了items()来获取场景中的图元集合,提供了selectedItems()来获取场景中被选中的图元集合,获取集合之后,通过qgraphicsitem_cast<>()就可以将QGraphicsItem转换为相应的子类,例如:

if (isItemSelected(LineElementItem::Type)) {
	LineElementItem* item = qgraphicsitem_cast<LineElementItem*>(selectedItems().first());

	//操作item
}

但是实际在使用QWT时,并没有这么多的API来供开发者使用。


二、具体流程

1、定义图元标识

在QGraphicsItem中,采用Type来标识图元类别:

class TextItem : public QGraphicsTextItem {
    Q_OBJECT
public:
    enum { Type = UserType + TYPE_TEXT };
    
    TextItem(QGraphicsItem* parent = 0);

    int type() const
    {
        return Type;
    }
};

而在QWT中,则采用rtti来标识图元类别:
在这里插入图片描述

class QwtTextLabel : public QwtPlotItem
{
public:
    QwtTextLabel();

    virtual int rtti() const //指定当前图元项代表的意义
    {
    	return QwtPlotItem::Rtti_PlotUserItem + textLabel_item;
	}
}

通过QWT源码可知,QwtPlotItem将QwtPlotItem::Rtti_PlotUserItem(枚举值为100)之后的用于用户自定义图元标识,所以我们只需要在这个基础上定义自己的图元标识即可;


自定义QWT图元类

#ifndef QWTVALUELINE_H
#define QWTVALUELINE_H

#include <qwt_plot_item.h>
#include <qwt_painter.h>

#include "DataDefine.h"

class QPainter;
class QPen;
class QFont;
class QwtScaleMap;
class QwtScaleDiv;

class QwtValueLine : public QwtPlotItem
{
public:
    QwtValueLine();

    QPointF ValueLine_Pos1;
    QPointF ValueLine_Pos2;
    QColor ValueLine_Color;

    virtual int rtti() const; //指定当前图元项代表的意义
    virtual void draw( QPainter *p,
        const QwtScaleMap &xMap, const QwtScaleMap &yMap,
        const QRectF &rect ) const; //自定义图元项绘制函数

    void set_ValueLine_Pos1(QPointF);
    void set_ValueLine_Pos2(QPointF);
    void set_ValueLine_Color(QColor);
};

#endif // QWTVALUELINE_H

#include "qwtvalueline.h"

QwtValueLine::QwtValueLine()
{
    ValueLine_Pos1 = QPointF(-1,-1);
    ValueLine_Pos2 = QPointF(-1,-1);
    ValueLine_Color = QColor(255,0,0);
}

int QwtValueLine::rtti() const //虚函数,指定当前图元项代表的意义
{
    return QwtPlotItem::Rtti_PlotUserItem + valueLine_item;
}
void QwtValueLine::draw( QPainter *p,
                  const QwtScaleMap &xMap, const QwtScaleMap &yMap,
                  const QRectF &rect ) const //纯虚函数,自定义图元项绘制函数
{
    p->setRenderHints(QPainter::Antialiasing, true); //设置反锯齿
    p->setPen(QPen(ValueLine_Color,3));

    QwtPainter::drawLine(p,ValueLine_Pos1,ValueLine_Pos2);
}

void QwtValueLine::set_ValueLine_Pos1(QPointF pos1)
{
    this->ValueLine_Pos1 = pos1;
    this->itemChanged();
}
void QwtValueLine::set_ValueLine_Pos2(QPointF pos2)
{
    this->ValueLine_Pos2 = pos2;
    this->itemChanged();
}
void QwtValueLine::set_ValueLine_Color(QColor color)
{
    this->ValueLine_Color = color;
    this->itemChanged();
}


2、获取指定图元

QWT提供了itemList()来获取场景中的图元集合

void PlotView::mousePressEvent(QMouseEvent *event)
{
    mousePressed = event->pos();    //物理坐标

    isSelected_valueLine = false;

    for(int i=0; i<this->itemList().size(); ++i) {
        if(this->itemList().at(i)->rtti() == QwtPlotItem::Rtti_PlotUserItem + valueLine_item) {
            valueLine = (QwtValueLine*)this->itemList()[i];	//将QwtPlotItem类转换为自定义图元类QwtValueLine
            //valueLine = dynamic_cast<QwtValueLine*>(this->itemList()[i]);
        }
    }

    if(valueLine != nullptr) {
        if(qAbs(mousePressed.x() - valueLine->ValueLine_Pos1.x()) <= 10) {
            isSelected_valueLine = true;
        }
    }
}
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

贝勒里恩

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值