8.12 矢量图层面要素单一符号使用十二(短划线渲染边界)

前言

  • 本章介绍矢量图层线要素单一符号中短划线渲染边界的使用
  • 说明:文章中的示例代码均来自开源项目qgis_cpp_api_apps

短划线渲染边界(Outline: Hashed Line)

  • Outline系列只画边界,不填充内容
  • 以protected_areas.shp为例,图层符号为Simple Fill时显示效果如下图
    在这里插入图片描述

QGis设置面符号为短划线渲染边界(Outline: Hashed Line)

  • Symbol layer type设置为Outline: Hashed Line,可设置的属性如下图
    在这里插入图片描述

  • 属性设置完成后显示效果如下图
    在这里插入图片描述

二次开发代码实现短划线渲染边界(Outline: Hashed Line)

  • 短划线渲染边界实现机制是将符号类型设置为Fill,但是Symbol layer type设置为对应的线类型
  • 构建对应的Symbol layer type,Hashed SymbolLayer,代码如下
  • 然后创建Fill类型的符号
  • 完整测试代码如下
void MainWindow::polygonOutlineHashedSlot()
{
    //添加测试图层
    QString filename = QStringLiteral("maps/shapefile/protected_areas.shp");
    QFileInfo ff(filename);
    QgsVectorLayer* layer = (QgsVectorLayer*)mApp->addVectorLayer(filename,ff.baseName());
    zoomToFirstLayer<QgsVectorLayer*>();
    //从图层获取渲染器
    QgsFeatureRenderer * layerRenderer= layer->renderer();
    QgsSingleSymbolRenderer *singleSymbolRenderer = QgsSingleSymbolRenderer::convertFromRenderer(layerRenderer);
#if 0
    auto hashedSymbolLayer = new QgsHashedLineSymbolLayer(true,3);
#else
    QVariantMap mp;
    mp["rotate"] = QStringLiteral("1");
    mp["interval"] = QStringLiteral("3");
    auto hashedSymbolLayer = QgsHashedLineSymbolLayer::create(mp);
#endif
    //多个Symbol Layer构成一个Symbol
    QgsSymbolLayerList layerList;
    layerList << hashedSymbolLayer;
    auto fillSymbol = new QgsFillSymbol(layerList);
    singleSymbolRenderer->setSymbol(fillSymbol);
    layer->setRenderer(singleSymbolRenderer);

}

  • 效果如下
    在这里插入图片描述
    在这里插入图片描述

总结

  • 介绍了矢量图层面要素单一符号中的短划线渲染边界(Outline: Hashed Line)
  • 8
    点赞
  • 9
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

雷动软件工作室

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

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

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

打赏作者

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

抵扣说明:

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

余额充值