Я использую 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, похоже, создает пустой образ.
UPDATE: Это мой новый код, в полном объеме:
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