前言
- 本章介绍矢量图层线要素单一符号中短划线渲染边界的使用
- 说明:文章中的示例代码均来自开源项目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)