Cesium加载GeoServer发布WMTS系列问题

这两天为了摆脱对ArcGIS的依赖,准备走开源这一套(现在发布只能用这两个吗,知道的探讨一下),想走GeoServer的路线,在发布了shp之类的之后发现还挺好用的,但是到了发布影像的时候,就很垃圾了,各种问题,可能人家有更好的解决方案,经过两三天的研究,终于研究明白了,接下来给大家分享一波我的处理过程以及遇到的问题。


一共是三步,数据准备,数据发布,以及数据加载

一、数据准备

我的解决方案是把数据转成4326坐标系,后缀为tif的影像,在原影像导出过程中需要注意第二步,增加几个选项。我们最终到手的应该是一个坐标系为4326,后缀为tif的影像。
影像名字最好起英文名,含有中文的地址会在浏览器中进行转译,变成数字符号,可能会出现400的错

1. 坐标系问题

诸如我们国内一般都使用的是CGCS2000的地理坐标系以及各分带的投影坐标系,但在以WGS84为主的GeoServer中,想找对应坐标系的切片方案还是挺难的,因此你需要建立你自己的切片方案。方法如下:切片方案建立

2. 数据格式问题

在我转完坐标系之后,直接用转完的数据进行发布,出来之后发现数据只有灰度值,原先的那些色彩都消失了,经过百度之后解决方法就是需要用arcgis导出的时候选择这个选项:原博客在这:地址
在这里插入图片描述
这样就能在发布的过程中有这三个,不然的话只有一条
在这里插入图片描述

2. 数据发布

接下来就是比较重要的一步,因为Geoserver对我来说不是很友好的界面,刚开始不使用它就是因为没有一个流程化的界面,让我知道发布WMTS需要哪些步骤。经过研究我把它分成两步,第一步是上传数据,在Geoserver中进行注册;第二步就是发布服务,利用切片功能对数据进行切片

2.1 数据注册

打开GeoServer的数据存储,将数据在其中注册,注意名字使用英文名,图片中报错的原因可能是没有选对正确的切片方案,具体方法可以参考这里
在这里插入图片描述

2.2切片服务的发布

选择切片功能,进入切片预览:
在这里插入图片描述
选择需要的线程数,切片策略,发布级别等:
在这里插入图片描述
点击发布后,可以在线看到发布的情况
https://i0.hdslb.com/bfs/article/55f384dd9980e63047793140f98cd98f333138913.png@1256w_436h_!web-article-pic.avif
当发布完成后,会在list of currently executing tasks中显示none字样。
并且可以在浏览器中进行预览:
在这里插入图片描述
在缓存目录中看见切完的切片有大片的黑色图片,这是属于正常现象,在加载过程中会变的透明,只要关注有数据区域的数据颜色是正常彩色并且背景是白色就行。
在这里插入图片描述

3. 数据的加载

在数据发布之后,就可以进行和Cesium之间的加载了,在加载过程中,会有几个必要字段需要注意。如果没有必要字段会使得数据服务加载不出来。

let layerWMTS = new Cesium.WebMapTileServiceImageryProvider({
    url: 'http://localhost:8080/geoserver/gwc/service/wmts', //地址写到这一步就行了
    layer: 'cite:xi18',//必填字段,其中cite为项目名,xi18为图层名,这里只是示例,找对应的名字
    style: 'raster',//必填字段,栅格类型
    format: 'image/png',//切片的格式类型,和你切片的相同
    tileMatrixSetID: 'EPSG:4326'//切片策略,和你选择的切片策略相同
});

通过这样子,就能加载出来正常的服务。

4. 使用感受

我觉得最好的体验就是可以选择切片发布时可以自行选择调用的CPU核数,可以选择上限,另外,如果想进行服务迁移的话只需要将新的GeoServer缓存地址定位在相同地方就行了,这点还是很好的。下面说说缺点,使用繁琐,在使用一些功能时,界面的引导不够明晰,造成上手困难,二一个是对国内坐标系统的支持度不够好,自己创建的切片策略会出现各种各样的问题。不过总的来说还是值得被选择的,不知道还有什么好的服务发布方式能有,希望大家能给点知识哈哈。

### 回答1: 要在Cesium加载IGE栅格数据,可以按照以下步骤进行: 1. 将IGE栅格数据转换为Cesium支持的格式,例如GeoTIFF或BIL。 2. 使用Cesium的ImageryLayer类来加载栅格数据。例如,以下代码将加载GeoTIFF格式的栅格数据: ``` var viewer = new Cesium.Viewer('cesiumContainer'); var imageryProvider = new Cesium.GeoTiffImageryProvider({ url: 'path/to/imagery.tif' }); viewer.imageryLayers.addImageryProvider(imageryProvider); ``` 3. 如果需要对栅格数据进行处理或者渲染,可以使用Cesium的渲染管线和着色器技术来实现。例如,以下代码将对栅格数据进行灰度化处理: ``` var viewer = new Cesium.Viewer('cesiumContainer'); var imageryProvider = new Cesium.GeoTiffImageryProvider({ url: 'path/to/imagery.tif' }); var shader = 'void main() { \ vec4 color = texture2D(image, v_textureCoordinates); \ float gray = dot(color.rgb, vec3(0.299, 0.587, 0.114)); \ gl_FragColor = vec4(vec3(gray), color.a); \ }'; var material = new Cesium.Material({ fabric: { type: 'Color', uniforms: { color: new Cesium.Color(1.0, 1.0, 1.0), image: imageryProvider }, source: shader } }); var primitive = new Cesium.Primitive({ geometryInstances: new Cesium.GeometryInstance({ geometry: new Cesium.PlaneGeometry({ plane: new Cesium.Plane(new Cesium.Cartesian3(0, 0, 1), 0), vertexFormat: Cesium.VertexFormat.POSITION_AND_NORMAL }), attributes: { color: new Cesium.ColorGeometryInstanceAttribute(1.0, 1.0, 1.0, 1.0) }, id: 'grid' }), appearance: new Cesium.MaterialAppearance({ material: material, flat: true }) }); viewer.scene.primitives.add(primitive); ``` 以上代码将创建一个灰度化的平面图层,并将其添加到场景中。 希望这些代码可以帮助你加载IGE栅格数据。 ### 回答2: Cesium是一个用于在网页上渲染三维地球和地理信息的开源JavaScript库。Cesium的功能强大且易于使用,可以加载各种类型的地理数据,包括栅格数据。加载IGE栅格数据到Cesium可以通过以下几个步骤完成。 首先,将IGE栅格数据转换为Cesium支持的格式。Cesium支持的栅格数据格式包括GeoTIFF、WMS、WCS等。可以使用专门的软件工具或在线转换工具将IGE数据转换为这些格式中的一种。 接下来,在Cesium应用程序中添加一个ImageryLayer,用于加载并显示栅格数据。可以使用Cesium的ImageryLayer类来创建一个新的图层,并指定加载的数据源和其他配置信息。例如,可以指定加载的栅格数据的URL、坐标系、渲染方法等。 然后,将创建的ImageryLayer添加到Cesium的Viewer实例中。Viewer是Cesium的主要组件,用于创建和管理地球场景。可以使用Viewer的imageryLayers属性将新创建的ImageryLayer添加到场景中。 最后,通过调整Cesium的摄像机位置和视图设置,可以查看加载的IGE栅格数据。可以使用Cesium的Camera类和相关方法来控制摄像机的位置、方向和视角。 需要注意的是,在加载大型IGE栅格数据时,需要考虑性能和网络问题。可以使用Cesium加载优化技术和压缩算法来提高加载和渲染速度。另外,如果需要处理和分析栅格数据,可以使用Cesium的其他功能和插件,如高程分析、数据裁剪等。 总之,通过上述步骤,可以在Cesium中成功加载和显示IGE栅格数据,使用户能够在三维地球上观察和分析这些数据。 ### 回答3: Cesium是一款用于创建Web上可视化和交互式3D地图的开源引擎。它支持加载多种不同类型的数据,包括栅格数据。而IGE(Image Georeference Editor)是一种用于编辑和管理栅格数据的工具。 要在Cesium加载IGE栅格数据,需要进行以下步骤: 1. 准备IGE栅格数据文件:首先,确保你已经拥有IGE格式的栅格数据文件。这个文件通常包含了图像的地理位置信息,可以用于实现栅格数据的地理坐标映射。 2. 将栅格数据转换为Cesium可识别的格式:使用IGE或其他相关软件,将IGE格式的栅格数据转换为Cesium可识别的格式,比如GeoTIFF或PNG格式。这些格式在Cesium中可以更容易地进行加载和显示。 3. 在Cesium加载栅格数据:使用Cesium提供的相关API,将转换后的栅格数据加载到Web应用中。一般来说,可以创建一个Cesium的ImageryLayer或ImageryProvider来加载栅格数据。你可以设置数据的位置、坐标和显示样式等属性,以便在地图中正确显示和渲染栅格数据。 4. 将栅格数据与其他要素进行叠加:在加载栅格数据之后,你还可以通过Cesium的其他功能,比如添加矢量图层或标记点等,将栅格数据与其他要素进行叠加。这样可以实现更丰富和多样化的地图可视化效果。 总之,要在Cesium加载IGE栅格数据,你需要准备好IGE栅格数据文件并将其转换为Cesium可识别的格式,然后使用Cesium的API加载和显示栅格数据。这样,你就可以在Cesium地图上展示和操作栅格数据了。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值