- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在使用 Leaflet 构建故事 map ,使用的是切片成图 block 的大图像而不是“真实世界” map 数据。我正在使用这个插件:https://commenthol.github.io/leaflet-rastercoords/这个 repo 协议(protocol):https://github.com/jackdougherty/leaflet-storymap
加载我的 GeoJSON 数据并取消投影坐标,将它们正确地绘制在我的图像 map 上:
$.getJSON('map.geojson', function(data) {
var geojson = L.geoJson(data, {
// correctly map the geojson coordinates on the image
coordsToLatLng: function (coords) {
return rc.unproject(coords)
},
但是当我到达 onEachFeature 时,我用 map.flyTo() 撞墙了,它从我的 JSON 文件调用 geometry.coordinates,但没有取消投影它们,所以 flyTo() 将它们解释为远离 map 的地理空间坐标:
map.flyTo([feature.geometry.coordinates[1], feature.geometry.coordinates[0] ], feature.properties['zoom']);
我尝试将未投影的坐标传递给变量,然后传递给 map.flyTo() 和嵌套函数的变体,例如 map.flyTo.unproject(...,但没有成功。
如何将光栅坐标传递给 flyTo()?
我不仅是 Leaflet 的新手,也是 JavaScript 的新手。到目前为止,我一直在砍我的路,但我很难过。我相信解决方案是显而易见的。任何帮助是极大的赞赏。
最佳答案
在您的情况下,您可能只需要使用 rc.unproject
将您的坐标转换为可以传递给 flyTo
的 LatLng:
map.flyTo(
rc.unproject(feature.geometry.coordinates),
feature.properties['zoom']
);
话虽如此,我必须承认我并不完全明白使用 leaflet-rastercoords 插件的意义,因为您可以按照 Leaflet 教程 "Non-geographical maps" 轻松地做到这一点。 .
var yx = L.latLng;
var xy = function(x, y) {
if (L.Util.isArray(x)) { // When doing xy([x, y]);
return yx(x[1], x[0]);
}
return yx(y, x); // When doing xy(x, y);
};
有了这个,每当你想把你的“光栅”坐标转换成 Leaflet 可用的东西时,你只需使用 xy(x, y)
和 x
是你的水平值,y
垂直值。
额外的好处是许多其他东西将变得容易兼容。
由于您使用的是图 block 而不是单个图像(在教程中使用 ImageOverlay
拉伸(stretch)以适合坐标),您应该修改 CRS 转换,以便在缩放 0 时,您的tile 0/0/0
适合您的整个坐标。另见 Leaflet custom coordinates on image
即在 leaflet-rastercoords 示例的情况下:
0/0/0
实际上覆盖了比原始图像更多,就好像后者是 4096 x 4096 像素(其余部分用白色填充)<新CRS的确定:
a
和 c
应该是 1/16
b
和 d
是 0
y
垂直坐标没有反转 => c
为正因此,要使用的新 CRS 将是:
L.CRS.MySimple = L.extend({}, L.CRS.Simple, {
// coefficients: a b c d
transformation: new L.Transformation(1 / 16, 0, 1 / 16, 0)
});
现在你的 flyTo
非常相似,但许多其他东西也兼容:
map.flyTo(
xy(feature.geometry.coordinates),
feature.properties['zoom']
);
Demo 改编自 leaflet-rastercoords 示例,并使用额外的插件来演示兼容性:https://plnkr.co/edit/Gvei5I0S9yEo6fCYXPuy?p=preview
关于javascript - 如何在大型光栅图像上将 Leaflet flyTo() 与 unproject() 和 GeoJSON 数据一起使用?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/44054833/
我知道这在 Linux 上是可能的。我尝试使用 open("E:", 0); 和 open("E:\\", 0); 但它返回为 -1。我想将 DVD 作为一个大文件来读取,而不是将其用作文件系统。 最
我正在尝试编译一个包含 CUDA 代码的小型库。 我已成功将其编译为共享库,但我真正需要的是静态库。 我有两个源文件: main.c:包含一个用C编写的测试函数。我用gcc编译这个文件 mai
关闭。这个问题不符合Stack Overflow guidelines .它目前不接受答案。 这个问题似乎与 help center 中定义的范围内的编程无关。 . 关闭 9 年前。 Improve
我正在使用 MingW 在 Windows 上编写 C 程序,并希望使用 EXPAT XML 库。我想静态编译我的程序,所以我需要静态 .a 库。 有什么方法可以将 EXPAT 编译成 Windows
我想将结果限制为 KEY_HOMEID 等于 journalId 的结果。我已经研究了几天,如有任何帮助,我们将不胜感激。 public Cursor fetchAllNotes(String jou
我一直在寻找这个信息,但是由于可以通过 homebrew 和 pip 安装额外的包和 python 版本,我感觉我的环境很乱向上。此外,很久以前,我用 sudo pip install 和 sudo
关闭。这个问题不符合Stack Overflow guidelines .它目前不接受答案。 这个问题似乎不是关于 a specific programming problem, a softwar
我正在尝试合并目录中的所有 *.pdf : gswin64c -q -dNOPAUSE -sDEVICE=pdfwrite -sOutputFile=Total_Files.pdf -dBATCH *
所以我有一个简单的图像缩略图着陆页,例如: 在我的网站上,4 个并排显示在桌面上。如何强制它们在移动设备 View 中成对出现在一行中? 所以:桌面: #### 手机: ## ## 最佳答案
我正在使用 Ubuntu 21.04。我已删除 /usr/bin/python3和 /usr/lib/python3/因为某些软件包在二进制文件中出现错误。我的意思是重新安装python3到一个新的状
是否可以在 Windows 上使用 gyp 将 googles v8 构建为共享库(msvc 2012)?我试过的一切都不起作用。我试过的: python build\gyp_v8 -Dcompone
我需要将 rubygems 从 1.3.5 更新到 1.4.2 但显然 rubygems update 只是将您更新到最新版本 如何更新到 1.4.2? 最佳答案 您可以使用 RVM 安装特定
我还没有找到太多关于它的信息,但我看到了一些提示,表明可以在 iPhone 应用程序中使用 NSTask。如果可能的话,我将如何去做? 我不想越狱我的 iPhone,但我正在开发的应用程序仅供内部使用
我在 UIWebView 中有一个 map 图像。它默认加载在左上角。我希望它在 UIWebView 的中心初始化。 有人知道怎么做吗? 谢谢! 最佳答案 如果 map 图像是页面中唯一的内容,它是否
如何公开 NodePort 类型的服务上网没有 使用类型 LoadBalancer ?我发现的每个资源都是通过使用负载均衡器来完成的。但我不希望负载平衡对我的用例来说既昂贵又不必要,因为我正在运行 p
是否可以将 View 变成可编辑的,例如 this image ? 我知道我可以使用 GridView 来做到这一点。但是,我正在尝试使用 TableRows 来做到这一点,这可能吗? 编辑:我真正想
假设我已将 Heroku 应用程序扩展为 1 个工作进程,但如何指定具有特定名称的 rake 任务应作为工作进程运行? 最佳答案 在你的项目中创建一个 Procfile,然后像这样将 rake 任务放
目前,我在 GitHub 上一个项目的 README.md 文件中使用此 Markdown 文本: See the docs of [testthat][3] on how to write unit
我正在尝试使用一些到 uint8_t 的转换将 IPv4 转换为 IPv6。我知道 IPv4 有 4 个字节,IPv6 有 2 个字节的 16 个无符号整数,但我找不到它们转换的方法。 #includ
我是编程新手,目前正在学习 C。您能帮我解决以下案例吗? 一个例子是,如果用户输入“cbamike”,我想将其分成两个字符串:cba 和 mike。 我尝试了下面的代码,但它不起作用: #includ
我是一名优秀的程序员,十分优秀!