mapbox - 添加图标光环作为上传为 Mapbox 图标的图像的边框
问题描述
我有一个带有自定义咖啡杯图标(不是 maki 图标)的 mapbox 地图。我想根据每个点的数据字段有条件地给图标一个光环。这可行,但由于图标是作为 png 上传的,因此它被视为一个矩形,即使图像是一个大部分是圆形的咖啡杯。因此,当您添加光环时,它会添加到图标边界矩形的周边。这是其中两个图标的图片,一个有光环,因为它符合“条件”,一个没有。
我怎样才能让这个光环环绕咖啡杯图标的边框,就像它对 maki 图标一样?这是我的样式定义的相关部分:
layout: {
'icon-image': 'cafe-icon'
},
paint: {
"icon-color": "#1a7a08",
"icon-halo-color": "#e4be8b",
"icon-halo-width": ['case', ['==', ['get', 'CONDITION'], true], 4, 0]
}
此外,这是我的 package.json 文件中的 mapbox 依赖项:
"@mapbox/mapbox-sdk": "^0.12.1",
"mapbox-gl": "^2.1.1",
"@mapbox/mapbox-gl-geocoder": "^4.7.0"
这是我现在使用的咖啡杯图标:
解决方案
根据 Mapbox-gl-js 文档,几个样式属性只能应用于启用 SDF 的图像,其中之一也是“icon-halo-width”。
其中说:
四个样式规范属性只能用于启用 SDF 的图像:icon-color、icon-halo-color、icon-halo-width 和 icon-halo-blur。
我从此链接下载了“shop-15.png”的演示 png,并将 icon-halo-width 应用到 10 并应用了样式。
代码:
//downloaded
var accessible = "http://localhost:3000/shop-15.png";
map.loadImage(accessible, function (error, image) {
if (error) throw error;
map.addImage('accessible', image, { sdf: true });
map.addLayer({
"id": "iconLayer",
"type": "symbol",
"source": 'maine',
"layout": {
'icon-allow-overlap': true,
"icon-image": "accessible",
"icon-size": 3,
},
"paint": {
"icon-color": "white",
"icon-halo-color": "red",
"icon-halo-width": 10
}
});
});
截屏:
如何创建 SDF 图像?
这是我结合了我的一些研究的链接。
谢谢!
推荐阅读
- drag-and-drop - 量角器将拖动的元素捕捉到鼠标指针,而不是将其放在目标容器中
- c - C语言如何将特定的JSON数据解析成字符串
- react-native - React Native - 将背景颜色/不透明度添加到整个屏幕但添加到子组件?
- knockout.js - 字段有效时启用提交按钮
- python-3.x - 如何删除所有html标签并连接文本
- go - 我如何消费来自rabbitmq的一批消息?
- jquery - 在社交媒体上分享帖子时如何根据带有 jquery 的 url 更改元标记图像?
- java - 在新窗口中查找 xpath 位置,单击后打开。使用 java 和 selenium
- r - 当级别没有名称时访问深度嵌套列表的多个级别
- java - 为什么 maven install 会在 npm 中出现此错误?