Я использую Mapbox GL JS версии 0.32. Есть ли способ экспортировать карту в PNG или PDF с высоким разрешением?
Очевидно, я могу просто сделать снимок экрана, но было бы неплохо, если бы был более формальный способ.
Я нашел это репо, но оно выглядит старым и непонятно, как оно работает. .
Я пробовал использовать параметр preserveDrawingBuffer
:
var map = new mapboxgl.Map({
container: 'map',
style: 'mapbox://styles/mapbox/light-v9',
minZoom: 4,
maxZoom: 14,
center: [-2.0, 53.3],
preserveDrawingBuffer: true
});
console.log(map.getCanvas().toDataURL());
Это выводит длинный URL-адрес данных в консоли, но копирует и вставляет его в base64 Converter просто создает пустое изображение.
ОБНОВЛЕНИЕ. Это мой новый код полностью:
mapboxgl.accessToken = 'pk.eyXXX';
var map = new mapboxgl.Map({
container: 'map',
style: 'mapbox://styles/mapbox/light-v9',
minZoom: 4,
maxZoom: 14,
center: [-2.0, 53.3],
preserveDrawingBuffer: true
});
var dpi = 300;
Object.defineProperty(window, 'devicePixelRatio', {
get: function() {return dpi / 96}
});
map.on('load', function () {
var content = map.getCanvas().toDataURL();
console.log(content)
});
Вывод на консоль следующий: http://pastebin.com/raw/KhyJkJWJ
content
мне кажется Ирландией, Великобританией и Западной Европой. Большинство браузеров могут просмотреть его, просто вставив его в адресную строку. Чтобы сохранить png, используйтеtoBlob()
вместоtoDataURL()
. . И последнее, что не менее важно: чтобы отобразить эту карту в высоком разрешении, загляните в github.com/mpetroff/ распечатайте карты, чтобы узнать подробности. - person sgelb   schedule 03.03.2017