@yandex/ymaps3-web-mercator-projection
v0.0.4
Published
Yandex Maps JS API 3.0 example @yandex/ymaps3-web-mercator-projection
Downloads
258
Readme
@yandex/ymaps3-web-mercator-projection package
Web Mercator projection package for Yandex JS API.
Install
You can install this package via npm:
npm install --save @yandex/ymaps3-web-mercator-projection
How use
To use Web Mercator projection, just import it:
import {WebMercator} from '@yandex/ymaps3-web-mercator-projection';
const projection = new WebMercator();
console.log(projection.toWorldCoordinates([-180, 90])) // {x: -1, y: 1}
console.log(projection.toWorldCoordinates([-180, 85.051])) // ~ {x: -1, y: 1}
console.log(projection.toWorldCoordinates([90, 0])) // ~ {x: 0.5, y: 0}
console.log(projection.toWorldCoordinates([0, -23.6])) // ~ {x: 0, y: -0.135}
console.log(projection.fromWorldCoordinates({x: -1, y: 1})) // ~ [-180, 85.051]
console.log(projection.fromWorldCoordinates({x: 0.5, y: 0})) // [90, 0]
console.log(projection.fromWorldCoordinates({x: 0, y: -0.135})) // ~ [0, -23.6]
Usage without npm
You can use some CDN with ymaps3.import
JS API module loading handler on your page:
const {WebMercator} = await ymaps3.import('@yandex/ymaps3-web-mercator-projection');
NOTE:
By default ymaps3.import
can load self modules, scripts or style.
To make the code above work, you should add a loader:
// Add loader at the beginning of the loader queue
ymaps3.import.loaders.unshift(async (pkg) => {
// Process only this package
if (!pkg.includes('@yandex/ymaps3-web-mercator-projection')) return;
// Load script directly. You can use another CDN
await ymaps3.import.script(`https://unpkg.com/${pkg}/dist/index.js`);
// Return result object
return window['@yandex/ymaps3-web-mercator-projection'];
});