在QMap地图上的线段橡皮筋特效,并在线段右端随时跟随移动文本

何为橡皮筋特效,即为按下鼠标拖动时,以刚开始按下的点为中心点,拉出一条直线,随鼠标拖动来随时改变(可随时拉长拉短改变方向)。当松开鼠标时线段消失。

//包含相关头文件
//.h头文件
class XXX:public QgsMapCanvas
{
public:
void mouseMoveEvent(QMousEvent *e) override;
void mousePressEvent(QMousEvent *e) override;
void mouseReleaseEvent(QMousEvent *e) override;

const QgsMapToPixel *coordinatesTransform_; //坐标转换

private:
QgsPointXY m_startPoint;    //鼠标按下点
QgsRubberBand *m_rubberBand;

};
//.cpp文件
void XXX::mouseMoveEvent(QMouseEvent *e){
    if(e->buttons()&Qt::LeftButton)  //注意是buttons
    {
       m_rubberBand->setVisible(true);
       //记录鼠标移动的当前坐标,并转换为qgs的对应位置
       QgsPointXY currentMapPoint=coordinatesTransform_->toMapCoordinates(e->pos());
       m_rubberBand->reset(Qgis::GeometryType::Line);
       m_rubberBand->addPoint(m_startPoint,true);
       m_rubberBand->addPoint(currentMapPoint,true);
       refresh();
    }else{
       QgsMapCanvas::mouseMoveEvent(e);
    }
}
void XXX::mousePressEvent(QMouseEvent *e){
       if(e->button()==Qt::LeftButton){
       m_startPoint=coordinateTransform->toMapCoordinates(e->pos());
       m_rubberBand->setVisible(true);
       m_rubberBand->reset(Qgis::GeometryType::Line);
       m_rubberBand->addPoint(m_startPoint);
 }else{
       QgsMapCanvas::mouseMoveEvent(e);
 }
}
void XXX::mouseReleaseEvent(QMouseEvent *e){
       if(e->button()==Qt::LeftButton)
 {
       m_rubberBand->setVisiable(false);
 }else{
       QgsMapCanvas::mouseMoveEvent(e);
 }
}

该特效的重点在于重写鼠标事件。至此橡皮条特效已实现。

若要在线段右端显示文本,将该函数加入cpp,并在mouseMoveEvent函数中引用

该函数displayString(m_startPoint,currentMapPoint);

//在private中加入QGraphicsTextItem *m_textItem
void XXX::dispalyString(const QgsPointXY &startPoint,const QgsPointXY &endPoint){
    QString text=QString("aaa");
    m_textItem->setPlainText(text);
 
    //文字跟随鼠标
    QPointF screenPos=this->mapToScene(this->viewport()->mapFromGlobal(QCursor::pos()));
    m_textItem->setPos(QPointF(screenPos.x(),screenPos.y()));
    m_textItem->setVisiable(true);
    m_textItem->show();
}

鼠标释放时文本跟随线段一起消失可以在mousereleaseevent函数中加入m_textItem->hide();

至此功能全部完成。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值