openLayer加载WMS服务并定位
需求
通过 geoserver 服务发布的 WMS 服务,然后用户只传 url,只通过 wms 的服务 url 加载数据到地图上,并进行定位操作
最近项目有需要实现这个,花了一点时间研究了一下.
其实除了 ImageWMS 的加载,还有 TileWMS 的方法加载,TileWMS 的性能更好一些,但是此处只需要实现用户点击服务然后加载即可,不过多深究(完成需求即可).
代码
fetch(route.query.url)
.then((response) => response.text())
.then((text) => {
const result = parse.read(text);
const extentRange = result.Capability.Layer.EX_GeographicBoundingBox;
const extent = transformExtent(extentRange, "EPSG:4326", "EPSG:4326");
const wmsSource: any = new ImageWMS({
ratio: 1,
url: route.query.url,
serverType: "geoserver",
crossOrigin: "anonymous",
// 服务器类型
});
const imageLayer = new ImageLayer({
className: route.query.name,
source: wmsSource,
extent: extent,
});
//fit是定位作用
map.getView().fit(extent, { maxZoom: 20 });
map.addLayer(imageLayer);
});
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· winform 绘制太阳,地球,月球 运作规律
· 超详细:普通电脑也行Windows部署deepseek R1训练数据并当服务器共享给他人
· TypeScript + Deepseek 打造卜卦网站:技术与玄学的结合
· AI 智能体引爆开源社区「GitHub 热点速览」
· 写一个简单的SQL生成工具