热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

iClientforLeaflet解决地图放大问题

作者:yx文章目录前言一、修改参数二、自定义resolution前言客户在iServer发布rest地图服务之后,预览能够正常放大,但当

作者:yx


文章目录

  • 前言
  • 一、修改参数
  • 二、自定义resolution




前言

客户在iServer发布rest地图服务之后,预览能够正常放大,但当leaflet前端对接的时候,发现最大只能放大到某一层级(如下图),达不到预期效果。
在leaflet中,默认的maxZoom为18。当你设置的值大于18后,然后缩放地图,虽然地图做出了缩放效果,但是你会发现地图变成空白,且http请求并未触发19的请求。接下来就介绍两种方法解决该问题。
在这里插入图片描述



一、修改参数

在初始化tileLayer是,追加一个参数layer.options.maxZoom。这个参数允许你设置超过18的zoom值,参考博客https://blog.csdn.net/qq_45149720/article/details/117199585,具体实现代码如下:

<!DOCTYPE html>
<html>
<head><meta charset&#61;"UTF-8"><title data-i18n&#61;"resources.title_tiledMapLayer4326"></title><script type&#61;"text/Javascript" src&#61;"../js/include-web.js"></script>
</head>
<body style&#61;" margin: 0;overflow: hidden;background: #fff;width: 100%;height:100%;position: absolute;top: 0;">
<div id&#61;"map" style&#61;"margin:0 auto;width: 100%;height: 100%"></div>
<script type&#61;"text/Javascript" src&#61;"../../dist/leaflet/include-leaflet.js"></script>
<script type&#61;"text/Javascript">
var host &#61; window.isLocal ? window.server : "https://iserver.supermap.io";var map, url &#61; "http://localhost:8090/iserver/services/map-LL/rest/maps/zoom";var layer&#61;L.supermap.tiledMapLayer(url);map &#61; L.map(&#39;map&#39;, {crs: L.CRS.EPSG4326,center: [ 39.86283085415676,116.37512261782454 ],zoom: 20});layer.options.maxZoom &#61; 22;layer.addTo(map);
</script>
</body>
</html>

注&#xff1a;layer.options.maxZoom设置一定要在 layer.addTo(map)之前
效果展示在这里插入图片描述

二、自定义resolution

该种方法是一个绕行方法&#xff0c;可以将服务发为wmts&#xff0c;自定义resolution&#xff0c;实现预期效果

<!DOCTYPE html>
<html><head><meta charset&#61;"UTF-8"><title data-i18n&#61;"resources.title_tiledMapLayer4326"></title><script type&#61;"text/Javascript" src&#61;"../js/include-web.js"></script>
</head><body style&#61;" margin: 0;overflow: hidden;background: #fff;width: 100%;height:100%;position: absolute;top: 0;"><div id&#61;"map" style&#61;"margin:0 auto;width: 100%;height: 100%"></div><script type&#61;"text/Javascript" src&#61;"../../dist/leaflet/include-leaflet.js"></script><script type&#61;"text/Javascript">var host &#61; window.isLocal ? window.server : "https://iserver.supermap.io";var map, url &#61; "http://localhost:8090/iserver/services/map-LL/rest/maps/zoom";map &#61; L.map(&#39;map&#39;, {crs: new L.Proj.CRS("EPSG:4326",{resolutions: [1.38236552221875E-5, 6.91182761109375E-6, 3.455913805546875E-6, 1.7279569027734376E-6, 8.639784513867188E-7, 4.319892256933594E-7, 2.159946128466797E-7, 1.0799730642333985E-7, 5.3998653211669925E-8, 2.6999326605834962E-8, 1.3499663302917481E-8, 6.749831651458741E-9, 3.3749158257293703E-9, 1.6874579128646852E-9, 8.437289564323426E-10, 4.218644782161713E-10, 2.1093223910808564E-10],bounds: L.bounds([-180, -90], [180, 90]),origin: [-180, 90],}),center: [39.86283085415676, 116.37512261782454],zoom: 5})L.supermap.tiledMapLayer(url).addTo(map);</script>
</body></html>

在这里插入图片描述


推荐阅读
  • 导航栏样式练习:项目实例解析
    本文详细介绍了如何创建一个具有动态效果的导航栏,包括HTML、CSS和JavaScript代码的实现,并附有详细的说明和效果图。 ... [详细]
  • 深入理解Cookie与Session会话管理
    本文详细介绍了如何通过HTTP响应和请求处理浏览器的Cookie信息,以及如何创建、设置和管理Cookie。同时探讨了会话跟踪技术中的Session机制,解释其原理及应用场景。 ... [详细]
  • 前言--页数多了以后需要指定到某一页(只做了功能,样式没有细调)html ... [详细]
  • 本文介绍如何使用Objective-C结合dispatch库进行并发编程,以提高素数计数任务的效率。通过对比纯C代码与引入并发机制后的代码,展示dispatch库的强大功能。 ... [详细]
  • 技术分享:从动态网站提取站点密钥的解决方案
    本文探讨了如何从动态网站中提取站点密钥,特别是针对验证码(reCAPTCHA)的处理方法。通过结合Selenium和requests库,提供了详细的代码示例和优化建议。 ... [详细]
  • CentOS7源码编译安装MySQL5.6
    2019独角兽企业重金招聘Python工程师标准一、先在cmake官网下个最新的cmake源码包cmake官网:https:www.cmake.org如此时最新 ... [详细]
  • UNP 第9章:主机名与地址转换
    本章探讨了用于在主机名和数值地址之间进行转换的函数,如gethostbyname和gethostbyaddr。此外,还介绍了getservbyname和getservbyport函数,用于在服务器名和端口号之间进行转换。 ... [详细]
  • 扫描线三巨头 hdu1928hdu 1255  hdu 1542 [POJ 1151]
    学习链接:http:blog.csdn.netlwt36articledetails48908031学习扫描线主要学习的是一种扫描的思想,后期可以求解很 ... [详细]
  • This document outlines the recommended naming conventions for HTML attributes in Fast Components, focusing on readability and consistency with existing standards. ... [详细]
  • Splay Tree 区间操作优化
    本文详细介绍了使用Splay Tree进行区间操作的实现方法,包括插入、删除、修改、翻转和求和等操作。通过这些操作,可以高效地处理动态序列问题,并且代码实现具有一定的挑战性,有助于编程能力的提升。 ... [详细]
  • 使用Vultr云服务器和Namesilo域名搭建个人网站
    本文详细介绍了如何通过Vultr云服务器和Namesilo域名搭建一个功能齐全的个人网站,包括购买、配置服务器以及绑定域名的具体步骤。文章还提供了详细的命令行操作指南,帮助读者顺利完成建站过程。 ... [详细]
  • 深入理解Tornado模板系统
    本文详细介绍了Tornado框架中模板系统的使用方法。Tornado自带的轻量级、高效且灵活的模板语言位于tornado.template模块,支持嵌入Python代码片段,帮助开发者快速构建动态网页。 ... [详细]
  • JavaScript中属性节点的类型及应用
    本文深入探讨了JavaScript中属性节点的不同类型及其在实际开发中的应用,帮助开发者更好地理解和处理HTML元素的属性。通过具体的案例和代码示例,我们将详细解析如何操作这些属性节点。 ... [详细]
  • 本实验主要探讨了二叉排序树(BST)的基本操作,包括创建、查找和删除节点。通过具体实例和代码实现,详细介绍了如何使用递归和非递归方法进行关键字查找,并展示了删除特定节点后的树结构变化。 ... [详细]
  • SQLite 动态创建多个表的需求在网络上有不少讨论,但很少有详细的解决方案。本文将介绍如何在 Qt 环境中使用 QString 类轻松实现 SQLite 表的动态创建,并提供详细的步骤和示例代码。 ... [详细]
author-avatar
齐老大2502895835
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有