10.qgis二次开发qt中拉框选择要素一些问题汇总


在我的另一篇文章《qgis二次开发qt中实现拉框选择要素》(链接:http://t.csdn.cn/AlaNn)中虽然实现了拉框选择,但是出现了一些问题,需要解决。主要问题出现在上文中的identifyFromGeometry()方法中。

拉框选择之后选择了框外的元素(多选)

造成这个bug的原因是:每个图层的每个要素系统中都有一个ID号,这图层有一个425号,另一个图层也有一个425号,以至于想选这个图层的425号,结果都选中了,就形成了选择了框外的元素(多选)的问题。
解决方法:在每个图层选择完成之后,清理ids列表。

        //选择的Features集合
        QList<QgsFeature> selectFeatures;
        QgsVectorLayer *layer= nullptr;
                QgsFeatureIds ids;
                QgsFeature Feature1;
                //显示出来
                for (int i = 0; i < results.count(); ++i)
                {
                    layer= qobject_cast<QgsVectorLayer*>(results.at(i).mLayer);
                    Feature1= results.at(i).mFeature;
                    ids.insert(Feature1.id());
                    if(ids.count()>0)
                    {
                        layer->select(ids);
                    }
                    ids.clear();
                }
                results.clear();

如果添加了栅格图层,之后选择会崩溃

造成这个bug的原因是:要清除所选要素的时候,之前遍历的是所有图层的列表,需要改为矢量图层列表。而且identify函数也需要只识别矢量图层列表来获取geometry中的要素。
解决代码:

 if (mCanvas)
        {
            mCanvas->setSelectionColor(Qt::red);//设置颜色
            QList< QgsMapLayer * > 	alllayers = mCanvas->layers();
            QList< QgsMapLayer * >  vectorlayers=mCanvas->layers();
            vectorlayers.clear();
            foreach (QgsMapLayer *l , alllayers)
            {
                if(l->type()==QgsMapLayerType::VectorLayer)
                    vectorlayers.append(l);
            }
            QgsVectorLayer *l1= nullptr;
            foreach (QgsMapLayer *l , vectorlayers)
            {
                l1= qobject_cast<QgsVectorLayer*>(l);
                l1->removeSelection();
            }
        }
        //返回选中的结果
        QList<IdentifyResult> results = QgsMapToolIdentify::identify(mSelectGeometry, IdentifyMode::TopDownAll, AllLayers);

identifyFromGeometry()方法的完整改后代码

void QgsMapToolSelectFeatures::identifyFromGeometry()
{
    if (mCanvas)
        {
            mCanvas->setSelectionColor(Qt::red);//设置颜色
            QList< QgsMapLayer * > 	alllayers = mCanvas->layers();
            QList< QgsMapLayer * >  vectorlayers=mCanvas->layers();
            vectorlayers.clear();
            foreach (QgsMapLayer *l , alllayers)
            {
                if(l->type()==QgsMapLayerType::VectorLayer)
                    vectorlayers.append(l);
            }
            QgsVectorLayer *l1= nullptr;
            foreach (QgsMapLayer *l , vectorlayers)
            {
                l1= qobject_cast<QgsVectorLayer*>(l);
                l1->removeSelection();
            }
        }
        //返回选中的结果
        QList<IdentifyResult> results = QgsMapToolIdentify::identify(mSelectGeometry, IdentifyMode::TopDownAll, AllLayers);
        //选择的Features集合
        QList<QgsFeature> selectFeatures;
        QgsVectorLayer *layer= nullptr;
                QgsFeatureIds ids;
                QgsFeature Feature1;
                //显示出来
                for (int i = 0; i < results.count(); ++i)
                {
                    layer= qobject_cast<QgsVectorLayer*>(results.at(i).mLayer);
                    Feature1= results.at(i).mFeature;
                    ids.insert(Feature1.id());
                    if(ids.count()>0)
                    {
                        layer->select(ids);
                    }
                    ids.clear();
                }
                results.clear();
}

总结

出现崩溃很正常,但是需要深入思考,多调试才可以解决bug。
可以用qDebug来打印变量或字符串来调试。

qDebug()<<"111";
qDebug()<<bianliang;

除此之后,其实矩形拉框选择要素,除了用本文中的select()或者selectbyids()方法,还可以用selectbyrect()方法。

评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值