我想在tilemill中制作一张与此示例中标签显示方式相匹配的地图,包括在每个缩放级别获取标签的国家/地区,哪个国家/地区获得缩写与完整标题,使用线条将标签连接到较小的国家/地区等。
这似乎是默认的 Mapbox 标签样式(我注意到这个 Mozilla 地图的行为方式完全相同),因为那里没有自定义。但是,在创建新的 Tilemill 地图时,根本没有标注。我需要做什么才能以与该 Mapbox 示例完全相同的方式添加标签(即 Mapbox 默认标签样式)?
TileMill2提供了来自OpenStreetMap的基本地图数据,包括标签。TM2也被用来创建Mozilla的地图。您可以创建纯标注图层的地图,也可以更改字体和样式。如果您使用的是 OS X,建议您从二进制文件构建 TM2。
注意:TM2 作为存储库提供,目前是公开测试版。TM2 上传到 mapbox.com 将在未来几个月内公开发布。
使用的样式,应该让你入门。对我来说,我不希望覆盖在地图框图块顶部的图层与默认标签重叠。
你可以在这里看到它的外观
然而,标签在很多情况下都是一两个像素。出于沮丧,我放弃了让它100%完美。另请记住,默认地图框样式似乎正在演变。
一个技巧是让光环比你需要的大一点。这可以隐藏/混合您正在叠加的标签。
字体:
@sans_lt: "Open Sans Regular","DejaVu Sans Book","unifont Medium";
@sans: "Open Sans Semibold","DejaVu Sans Book","unifont Medium";
@sans_bold: "Open Sans Bold","DejaVu Sans Bold","unifont Medium";
@sans_italic: "Open Sans Semibold Italic","DejaVu Sans Italic","unifont Medium";
@sans_bold_italic: "Open Sans Bold Italic","DejaVu Sans Bold Italic","unifont Medium";
@place_halo: fadeout(@bluish_white,5%);
@town_text: #444;
@town_halo: @place_halo;
OSM放置样式,使用OSM明亮的imposm脚本导入OSM数据
#place::small[type='village'][zoom<13][zoom>9],
#place::small[type='suburb'][zoom<13][zoom>9],
#place::small[type='hamlet'][zoom<13][zoom>9]{
text-name:'[name]';
text-face-name:@sans;
text-placement:point;
text-fill:@town_text;
text-size:9;
text-halo-fill:fadeout(@town_halo, 25%);
text-halo-radius:3;
text-wrap-width: 50;
text-allow-overlap: true;
[zoom>=10] {
text-size: 11;
}
[zoom>=11]{ text-size:11; }
[zoom>=12]{
text-size:12;
text-line-spacing: 1;
}
}
希望这有所帮助,我认为这可能是我们在矢量图块登陆之前能得到的最好的。如果您弄清楚他们使用的确切风格,那就太好了。