前言
- 本章介绍矢量图层线要素单一符号中使用栅格数据填充(Raster image fill)的使用
- 说明:文章中的示例代码均来自[开源项目qgis_cpp_api_apps]
栅格数据填充(Raster image fill)
A class for filling symbols with a repeated raster image.
- 以protected_areas.shp为例,图层符号为Simple Fill时显示效果如下图
 
QGis设置面符号为栅格数据填充(Raster image fill)
- Symbol layer type设置为Raster image fill,可设置的属性如下图
 
- 设置完成后,图层显示效果如下图
 
二次开发代码实现栅格数据填充(Raster image fill)
- 类QgsRasterFillSymbolLayer是Raster image fill,详细见文档,类图如下 
- 创建符号层有两种方法:构造函数和create
- 方法一
- 从图层获取渲染器
    //从图层获取渲染器
    QgsFeatureRenderer * layerRenderer= layer->renderer();
    QgsSingleSymbolRenderer *singleSymbolRenderer = QgsSingleSymbolRenderer::convertFromRenderer(layerRenderer);
- 构造函数:修改属性可以调用setxxx函数,如下代码
    QString path = QStringLiteral("resources/eye.png");
    auto rasterFillSymbolLayer = new QgsRasterFillSymbolLayer(path);
    rasterFillSymbolLayer->setAngle(0.0);
- 创建符号并设置到渲染器
    //多个Symbol Layer构成一个Symbol
    QgsSymbolLayerList layerList;
    layerList << rasterFillSymbolLayer;
    //构造QgsFillSymbol并设置renderer
    auto fillSymbol = new QgsFillSymbol(layerList);
    singleSymbolRenderer->setSymbol(fillSymbol);
    layer->setRenderer(singleSymbolRenderer);
- 方法二
方法一中步骤1,3不变,步骤2中使用create()成员函数,颜色方案同样有两种选择
    QVariantMap mp;
    mp["imageFile"] = QStringLiteral("resources/eye.png");
    mp["angle"] = QStringLiteral("0.0");
    auto rasterFillSymbolLayer = QgsRasterFillSymbolLayer::create(mp);
- 完整测试代码如下
void MainWindow::polygonRasterImageSlot()
{
    //添加一个线图层
    QgsVectorLayer* layer = addTestShape(QStringLiteral("maps/shapefile/protected_areas.shp"));
    //从图层获取渲染器
    QgsFeatureRenderer * layerRenderer= layer->renderer();
    QgsSingleSymbolRenderer *singleSymbolRenderer = QgsSingleSymbolRenderer::convertFromRenderer(layerRenderer);
#if 0
    QString path = QStringLiteral("resources/eye.png");
    auto rasterFillSymbolLayer = new QgsRasterFillSymbolLayer(path);
    rasterFillSymbolLayer->setAngle(0.0);
#else
    QVariantMap mp;
    mp["imageFile"] = QStringLiteral("resources/eye.png");
    mp["angle"] = QStringLiteral("0.0");
    auto rasterFillSymbolLayer = QgsRasterFillSymbolLayer::create(mp);
#endif
    //多个Symbol Layer构成一个Symbol
    QgsSymbolLayerList layerList;
    layerList << rasterFillSymbolLayer;
    //构造QgsFillSymbol并设置renderer
    auto fillSymbol = new QgsFillSymbol(layerList);
    singleSymbolRenderer->setSymbol(fillSymbol);
    layer->setRenderer(singleSymbolRenderer);
}
- 效果如下图
   
总结
- 介绍了矢量图层面要素单一符号中的栅格数据填充(Raster image fill)使用








