GeoServer 裁剪WMS服务

裁剪WMS服务

正常的WMS服务加载的图层,要么是全要素渲染,要么是子集要素渲染(通过CQL_FILTER参数)。裁剪WMS服务就是只显示给定范围内的要素,范围外的要素不显示,比如只渲染一个矩形范围内,矩形外无渲染。

实现方式

1.采用SQL视图的方式发布一个图层:
定义SQL视图 原理就是根据pg表定义一个视图,视图的作用是重新计算数据源,通过%param%定义参数,接收外部传入的显示区域,然后通过pg的函数将区域范围转换成geometry,然后再通过pg的函数st_intersection对pg表中的几何字段进行裁剪,形成一个动态的数据源。
其中参数值可以是geojson,wkt,wkb等等,不同的参数值需要对应的函数转成geometry,比如:geojson -> st_geomgromgeojson,wkt -> st_geomfromtext,wkb -> st_geomfromwkb。
最后需要给参数设置默认值(可以采用中国四至范围),以支持默认情况下,与正常的WMS服务请求一致。

2.请求示例:
对于SQL视图,geoserver支持在WMS、WFS等OGC标准服务中,通过viewparams参数来定义SQL视图的参数,官方描述如下:
viewparams参数定义
所以完整裁剪WMS服务请求如下:
裁剪WMS服务请求示例
那么作为对比,默认情况下的结果如下:
默认WMS请求

注意事项:

1.传入的区域范围坐标系要与pg表中的几何字段坐标系一致,如果pg中的几何字段坐标系不是0,那么在使用st_geomfeomtext转换几何时,需要指定srid,否则会报错 mix srid。
2.如果区域范围的值很长,建议使用POST请求,GET的请求URL有大小限制。
3.如果请求的是一个面图层,那么区域范围的坐标精度要与面图层的坐标精度保持一致,否则在裁剪时会出现鲁棒性错误,无法裁剪而报错。
4.当前使用的版本时2.15.3,在geoserver的高版本中,WMS请求多了一个clip参数,支持使用WKT裁剪图层:
clip参数定义
5.当然,这种方式对性能肯定会有影响的,因为需要大量计算裁剪,所以如果数据量比较打,请谨慎使用。

结语:

geoserver的sql视图是一个很灵活的发布服务方式,满足一些特殊的需求,不止是pg,mysql同样可以,简直是屡试不爽。

  • 2
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 3
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值