viewport-mercator-project
Advanced tools
Comparing version 4.2.0-alpha.2 to 5.0.0-alpha.1
// Classic web-mercator-project | ||
export { default } from './flat-mercator-viewport'; | ||
export { default as FlatMercatorViewport } from './flat-mercator-viewport'; | ||
export { default as PerspectiveMercatorViewport } from './perspective-mercator-viewport'; | ||
export { default } from './web-mercator-viewport'; | ||
export { default as WebMercatorViewport } from './web-mercator-viewport'; | ||
// Legacy class name | ||
export { default as PerspectiveMercatorViewport } from './web-mercator-viewport'; | ||
export { projectFlat } from './web-mercator-utils'; | ||
export { unprojectFlat } from './web-mercator-utils'; | ||
export { getMercatorMeterZoom } from './web-mercator-utils'; | ||
export { getMercatorDistanceScales } from './web-mercator-utils'; | ||
export { getMercatorWorldPosition } from './web-mercator-utils'; | ||
export { makeViewMatricesFromMercatorParams } from './web-mercator-utils'; | ||
export { makeUncenteredViewMatrixFromMercatorParams } from './web-mercator-utils'; | ||
export { makeProjectionMatrixFromMercatorParams } from './web-mercator-utils'; | ||
export { getFov } from './web-mercator-utils'; | ||
export { getClippingPlanes } from './web-mercator-utils'; | ||
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uL3NyYy9pbmRleC5qcyJdLCJuYW1lcyI6WyJkZWZhdWx0IiwiRmxhdE1lcmNhdG9yVmlld3BvcnQiLCJQZXJzcGVjdGl2ZU1lcmNhdG9yVmlld3BvcnQiLCJwcm9qZWN0RmxhdCIsInVucHJvamVjdEZsYXQiLCJnZXRNZXJjYXRvck1ldGVyWm9vbSIsImdldE1lcmNhdG9yRGlzdGFuY2VTY2FsZXMiLCJnZXRNZXJjYXRvcldvcmxkUG9zaXRpb24iLCJtYWtlVmlld01hdHJpY2VzRnJvbU1lcmNhdG9yUGFyYW1zIiwibWFrZVVuY2VudGVyZWRWaWV3TWF0cml4RnJvbU1lcmNhdG9yUGFyYW1zIiwibWFrZVByb2plY3Rpb25NYXRyaXhGcm9tTWVyY2F0b3JQYXJhbXMiLCJnZXRGb3YiLCJnZXRDbGlwcGluZ1BsYW5lcyJdLCJtYXBwaW5ncyI6IkFBQUE7QUFDQSxTQUFRQSxPQUFSLFFBQWlDLDBCQUFqQztBQUNBLFNBQVFBLFdBQVdDLG9CQUFuQixRQUE4QywwQkFBOUM7QUFDQSxTQUFRRCxXQUFXRSwyQkFBbkIsUUFBcUQsaUNBQXJEOztBQUVBLFNBQVFDLFdBQVIsUUFBMEIsc0JBQTFCO0FBQ0EsU0FBUUMsYUFBUixRQUE0QixzQkFBNUI7QUFDQSxTQUFRQyxvQkFBUixRQUFtQyxzQkFBbkM7QUFDQSxTQUFRQyx5QkFBUixRQUF3QyxzQkFBeEM7QUFDQSxTQUFRQyx3QkFBUixRQUF1QyxzQkFBdkM7QUFDQSxTQUFRQyxrQ0FBUixRQUFpRCxzQkFBakQ7QUFDQSxTQUFRQywwQ0FBUixRQUF5RCxzQkFBekQ7QUFDQSxTQUFRQyxzQ0FBUixRQUFxRCxzQkFBckQ7QUFDQSxTQUFRQyxNQUFSLFFBQXFCLHNCQUFyQjtBQUNBLFNBQVFDLGlCQUFSLFFBQWdDLHNCQUFoQyIsImZpbGUiOiJpbmRleC5qcyIsInNvdXJjZXNDb250ZW50IjpbIi8vIENsYXNzaWMgd2ViLW1lcmNhdG9yLXByb2plY3RcbmV4cG9ydCB7ZGVmYXVsdCBhcyBkZWZhdWx0fSBmcm9tICcuL2ZsYXQtbWVyY2F0b3Itdmlld3BvcnQnO1xuZXhwb3J0IHtkZWZhdWx0IGFzIEZsYXRNZXJjYXRvclZpZXdwb3J0fSBmcm9tICcuL2ZsYXQtbWVyY2F0b3Itdmlld3BvcnQnO1xuZXhwb3J0IHtkZWZhdWx0IGFzIFBlcnNwZWN0aXZlTWVyY2F0b3JWaWV3cG9ydH0gZnJvbSAnLi9wZXJzcGVjdGl2ZS1tZXJjYXRvci12aWV3cG9ydCc7XG5cbmV4cG9ydCB7cHJvamVjdEZsYXR9IGZyb20gJy4vd2ViLW1lcmNhdG9yLXV0aWxzJztcbmV4cG9ydCB7dW5wcm9qZWN0RmxhdH0gZnJvbSAnLi93ZWItbWVyY2F0b3ItdXRpbHMnO1xuZXhwb3J0IHtnZXRNZXJjYXRvck1ldGVyWm9vbX0gZnJvbSAnLi93ZWItbWVyY2F0b3ItdXRpbHMnO1xuZXhwb3J0IHtnZXRNZXJjYXRvckRpc3RhbmNlU2NhbGVzfSBmcm9tICcuL3dlYi1tZXJjYXRvci11dGlscyc7XG5leHBvcnQge2dldE1lcmNhdG9yV29ybGRQb3NpdGlvbn0gZnJvbSAnLi93ZWItbWVyY2F0b3ItdXRpbHMnO1xuZXhwb3J0IHttYWtlVmlld01hdHJpY2VzRnJvbU1lcmNhdG9yUGFyYW1zfSBmcm9tICcuL3dlYi1tZXJjYXRvci11dGlscyc7XG5leHBvcnQge21ha2VVbmNlbnRlcmVkVmlld01hdHJpeEZyb21NZXJjYXRvclBhcmFtc30gZnJvbSAnLi93ZWItbWVyY2F0b3ItdXRpbHMnO1xuZXhwb3J0IHttYWtlUHJvamVjdGlvbk1hdHJpeEZyb21NZXJjYXRvclBhcmFtc30gZnJvbSAnLi93ZWItbWVyY2F0b3ItdXRpbHMnO1xuZXhwb3J0IHtnZXRGb3Z9IGZyb20gJy4vd2ViLW1lcmNhdG9yLXV0aWxzJztcbmV4cG9ydCB7Z2V0Q2xpcHBpbmdQbGFuZXN9IGZyb20gJy4vd2ViLW1lcmNhdG9yLXV0aWxzJztcbiJdfQ== | ||
export { fitBounds } from './web-mercator-viewport'; | ||
export { projectFlat, unprojectFlat, getMeterZoom, getDistanceScales, getWorldPosition, getViewMatrix, getUncenteredViewMatrix, getProjectionMatrix } from './web-mercator-utils'; | ||
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uL3NyYy9pbmRleC5qcyJdLCJuYW1lcyI6WyJkZWZhdWx0IiwiV2ViTWVyY2F0b3JWaWV3cG9ydCIsIlBlcnNwZWN0aXZlTWVyY2F0b3JWaWV3cG9ydCIsImZpdEJvdW5kcyIsInByb2plY3RGbGF0IiwidW5wcm9qZWN0RmxhdCIsImdldE1ldGVyWm9vbSIsImdldERpc3RhbmNlU2NhbGVzIiwiZ2V0V29ybGRQb3NpdGlvbiIsImdldFZpZXdNYXRyaXgiLCJnZXRVbmNlbnRlcmVkVmlld01hdHJpeCIsImdldFByb2plY3Rpb25NYXRyaXgiXSwibWFwcGluZ3MiOiJBQUFBO0FBQ0EsU0FBUUEsT0FBUixRQUFpQyx5QkFBakM7QUFDQSxTQUFRQSxXQUFXQyxtQkFBbkIsUUFBNkMseUJBQTdDO0FBQ0E7QUFDQSxTQUFRRCxXQUFXRSwyQkFBbkIsUUFBcUQseUJBQXJEOztBQUVBLFNBQVFDLFNBQVIsUUFBd0IseUJBQXhCOztBQUVBLFNBQ0VDLFdBREYsRUFFRUMsYUFGRixFQUdFQyxZQUhGLEVBSUVDLGlCQUpGLEVBS0VDLGdCQUxGLEVBTUVDLGFBTkYsRUFPRUMsdUJBUEYsRUFRRUMsbUJBUkYsUUFTTyxzQkFUUCIsImZpbGUiOiJpbmRleC5qcyIsInNvdXJjZXNDb250ZW50IjpbIi8vIENsYXNzaWMgd2ViLW1lcmNhdG9yLXByb2plY3RcbmV4cG9ydCB7ZGVmYXVsdCBhcyBkZWZhdWx0fSBmcm9tICcuL3dlYi1tZXJjYXRvci12aWV3cG9ydCc7XG5leHBvcnQge2RlZmF1bHQgYXMgV2ViTWVyY2F0b3JWaWV3cG9ydH0gZnJvbSAnLi93ZWItbWVyY2F0b3Itdmlld3BvcnQnO1xuLy8gTGVnYWN5IGNsYXNzIG5hbWVcbmV4cG9ydCB7ZGVmYXVsdCBhcyBQZXJzcGVjdGl2ZU1lcmNhdG9yVmlld3BvcnR9IGZyb20gJy4vd2ViLW1lcmNhdG9yLXZpZXdwb3J0JztcblxuZXhwb3J0IHtmaXRCb3VuZHN9IGZyb20gJy4vd2ViLW1lcmNhdG9yLXZpZXdwb3J0JztcblxuZXhwb3J0IHtcbiAgcHJvamVjdEZsYXQsXG4gIHVucHJvamVjdEZsYXQsXG4gIGdldE1ldGVyWm9vbSxcbiAgZ2V0RGlzdGFuY2VTY2FsZXMsXG4gIGdldFdvcmxkUG9zaXRpb24sXG4gIGdldFZpZXdNYXRyaXgsXG4gIGdldFVuY2VudGVyZWRWaWV3TWF0cml4LFxuICBnZXRQcm9qZWN0aW9uTWF0cml4XG59IGZyb20gJy4vd2ViLW1lcmNhdG9yLXV0aWxzJztcbiJdfQ== |
@@ -6,2 +6,4 @@ var _slicedToArray = function () { function sliceIterator(arr, i) { var _arr = []; var _n = true; var _d = false; var _e = undefined; try { for (var _i = arr[Symbol.iterator](), _s; !(_n = (_s = _i.next()).done); _n = true) { _arr.push(_s.value); if (i && _arr.length === i) break; } } catch (err) { _d = true; _e = err; } finally { try { if (!_n && _i["return"]) _i["return"](); } finally { if (_d) throw _e; } } return _arr; } return function (arr, i) { if (Array.isArray(arr)) { return arr; } else if (Symbol.iterator in Object(arr)) { return sliceIterator(arr, i); } else { throw new TypeError("Invalid attempt to destructure non-iterable instance"); } }; }(); | ||
import { Vector3 } from 'math.gl'; | ||
import { createMat4 } from './math-utils'; | ||
import mat4_perspective from 'gl-mat4/perspective'; | ||
@@ -22,10 +24,5 @@ import mat4_scale from 'gl-mat4/scale'; | ||
var WORLD_SCALE = TILE_SIZE; | ||
var EARTH_CIRCUMFERENCE = 40.075e6; | ||
// const METERS_PER_DEGREE_AT_EQUATOR = 111000; // Approximately 111km per degree at equator | ||
// Helper, avoids low-precision 32 bit matrices from gl-matrix mat4.create() | ||
function createMat4() { | ||
return [1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1]; | ||
} | ||
/** | ||
@@ -76,7 +73,6 @@ * Project [lng,lat] on sphere onto [x,y] on 512*512 Mercator Zoom 0 tile. | ||
// S=C*cos(y)/2^(z+8) | ||
export function getMercatorMeterZoom(_ref5) { | ||
export function getMeterZoom(_ref5) { | ||
var latitude = _ref5.latitude; | ||
assert(latitude); | ||
var EARTH_CIRCUMFERENCE = 40.075e6; | ||
var radians = function radians(degrees) { | ||
@@ -94,3 +90,3 @@ return degrees / 180 * Math.PI; | ||
*/ | ||
export function getMercatorDistanceScales(_ref6) { | ||
export function getDistanceScales(_ref6) { | ||
var latitude = _ref6.latitude, | ||
@@ -139,3 +135,3 @@ longitude = _ref6.longitude, | ||
*/ | ||
export function getMercatorWorldPosition(_ref7) { | ||
export function getWorldPosition(_ref7) { | ||
var longitude = _ref7.longitude, | ||
@@ -150,5 +146,2 @@ latitude = _ref7.latitude, | ||
// Calculate distance scales if lng/lat/zoom are provided | ||
distanceScales = distanceScales || getMercatorDistanceScales({ latitude: latitude, longitude: longitude, scale: scale }); | ||
// Make a centered version of the matrix for projection modes without an offset | ||
@@ -159,2 +152,5 @@ var center2d = projectFlat([longitude, latitude], scale); | ||
if (meterOffset) { | ||
// Calculate distance scales if lng/lat/zoom are provided | ||
distanceScales = distanceScales || getDistanceScales({ latitude: latitude, longitude: longitude, scale: scale }); | ||
var pixelPosition = new Vector3(meterOffset) | ||
@@ -178,3 +174,3 @@ // Convert to pixels in current zoom | ||
// Variable fov (in radians) | ||
export function getFov(_ref8) { | ||
function getFov(_ref8) { | ||
var height = _ref8.height, | ||
@@ -186,3 +182,3 @@ altitude = _ref8.altitude; | ||
export function getClippingPlanes(_ref9) { | ||
function getClippingPlanes(_ref9) { | ||
var altitude = _ref9.altitude, | ||
@@ -204,12 +200,7 @@ pitch = _ref9.pitch; | ||
// TODO - rename this matrix | ||
export function makeUncenteredViewMatrixFromMercatorParams(_ref10) { | ||
var width = _ref10.width, | ||
height = _ref10.height, | ||
longitude = _ref10.longitude, | ||
latitude = _ref10.latitude, | ||
zoom = _ref10.zoom, | ||
export function getUncenteredViewMatrix(_ref10) { | ||
var height = _ref10.height, | ||
pitch = _ref10.pitch, | ||
bearing = _ref10.bearing, | ||
altitude = _ref10.altitude, | ||
center = _ref10.center; | ||
altitude = _ref10.altitude; | ||
@@ -237,3 +228,3 @@ // VIEW MATRIX: PROJECTS MERCATOR WORLD COORDINATES | ||
export function makeViewMatricesFromMercatorParams(_ref11) { | ||
export function getViewMatrix(_ref11) { | ||
var width = _ref11.width, | ||
@@ -247,7 +238,16 @@ height = _ref11.height, | ||
altitude = _ref11.altitude, | ||
centerLngLat = _ref11.centerLngLat, | ||
_ref11$distanceScales = _ref11.distanceScales, | ||
distanceScales = _ref11$distanceScales === undefined ? null : _ref11$distanceScales, | ||
_ref11$center = _ref11.center, | ||
center = _ref11$center === undefined ? null : _ref11$center, | ||
_ref11$viewMatrixUnce = _ref11.viewMatrixUncentered, | ||
viewMatrixUncentered = _ref11$viewMatrixUnce === undefined ? null : _ref11$viewMatrixUnce, | ||
_ref11$meterOffset = _ref11.meterOffset, | ||
meterOffset = _ref11$meterOffset === undefined ? null : _ref11$meterOffset; | ||
meterOffset = _ref11$meterOffset === undefined ? null : _ref11$meterOffset, | ||
_ref11$flipY = _ref11.flipY, | ||
flipY = _ref11$flipY === undefined ? true : _ref11$flipY; | ||
var center = getMercatorWorldPosition({ longitude: longitude, latitude: latitude, zoom: zoom, meterOffset: meterOffset }); | ||
if (!center) { | ||
center = getWorldPosition({ longitude: longitude, latitude: latitude, zoom: zoom, distanceScales: distanceScales, meterOffset: meterOffset }); | ||
} | ||
@@ -257,22 +257,15 @@ // VIEW MATRIX: PROJECTS FROM VIRTUAL PIXELS TO CAMERA SPACE | ||
// since vectors will be multiplied from the right during transformation | ||
var viewMatrixUncentered = makeUncenteredViewMatrixFromMercatorParams({ | ||
width: width, | ||
height: height, | ||
longitude: longitude, | ||
latitude: latitude, | ||
zoom: zoom, | ||
pitch: pitch, | ||
bearing: bearing, | ||
altitude: altitude | ||
}); | ||
if (!viewMatrixUncentered) { | ||
viewMatrixUncentered = getUncenteredViewMatrix({ height: height, pitch: pitch, bearing: bearing, altitude: altitude }); | ||
} | ||
var vm = createMat4(); | ||
mat4_scale(vm, viewMatrixUncentered, [1, -1, 1]); | ||
if (flipY) { | ||
mat4_scale(vm, viewMatrixUncentered, [1, -1, 1]); | ||
} | ||
var viewMatrixCentered = mat4_translate(vm, vm, new Vector3(center).negate()); | ||
return { | ||
viewMatrixCentered: viewMatrixCentered, | ||
viewMatrixUncentered: viewMatrixUncentered, | ||
center: center | ||
}; | ||
return viewMatrixCentered; | ||
} | ||
@@ -282,3 +275,3 @@ | ||
// This is a "Mapbox" projection matrix - matches mapbox exactly if farZMultiplier === 1 | ||
export function makeProjectionMatrixFromMercatorParams(_ref12) { | ||
export function getProjectionMatrix(_ref12) { | ||
var width = _ref12.width, | ||
@@ -297,3 +290,3 @@ height = _ref12.height, | ||
var projectionMatrix = mat4_perspective(createMat4(), fov, // fov in radians | ||
var projectionMatrix = mat4_perspective([], fov, // fov in radians | ||
width / height, // aspect ratio | ||
@@ -306,2 +299,2 @@ nearZ, // near plane | ||
} | ||
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../src/web-mercator-utils.js"],"names":["Vector3","mat4_perspective","mat4_scale","mat4_translate","mat4_rotateX","mat4_rotateZ","vec2_distance","assert","PI","Math","PI_4","DEGREES_TO_RADIANS","RADIANS_TO_DEGREES","TILE_SIZE","WORLD_SCALE","createMat4","projectFlat","scale","lng","lat","lambda2","phi2","x","y","log","tan","unprojectFlat","atan","exp","getMercatorMeterZoom","latitude","EARTH_CIRCUMFERENCE","radians","degrees","log2","cos","getMercatorDistanceScales","longitude","zoom","undefined","pow","isNaN","latCosine","pixelsPerDegreeX","pixelsPerDegreeY","worldSize","altPixelsPerMeter","pixelsPerMeter","metersPerPixel","pixelsPerDegree","degreesPerPixel","getMercatorWorldPosition","meterOffset","distanceScales","center2d","center","pixelPosition","add","getFov","height","altitude","getClippingPlanes","pitch","pitchRadians","halfFov","topHalfSurfaceDistance","sin","farZ","nearZ","makeUncenteredViewMatrixFromMercatorParams","width","bearing","vm","makeViewMatricesFromMercatorParams","centerLngLat","viewMatrixUncentered","viewMatrixCentered","negate","makeProjectionMatrixFromMercatorParams","farZMultiplier","fov","projectionMatrix"],"mappings":"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","file":"web-mercator-utils.js","sourcesContent":["// TODO - THE UTILITIES IN THIS FILE SHOULD BE IMPORTED FROM WEB-MERCATOR-VIEWPORT MODULE\n\nimport {Vector3} from 'math.gl';\nimport mat4_perspective from 'gl-mat4/perspective';\nimport mat4_scale from 'gl-mat4/scale';\nimport mat4_translate from 'gl-mat4/translate';\nimport mat4_rotateX from 'gl-mat4/rotateX';\nimport mat4_rotateZ from 'gl-mat4/rotateZ';\nimport vec2_distance from 'gl-vec2/distance';\nimport assert from 'assert';\n\n// CONSTANTS\nconst PI = Math.PI;\nconst PI_4 = PI / 4;\nconst DEGREES_TO_RADIANS = PI / 180;\nconst RADIANS_TO_DEGREES = 180 / PI;\nconst TILE_SIZE = 512;\nconst WORLD_SCALE = TILE_SIZE;\n\n// const METERS_PER_DEGREE_AT_EQUATOR = 111000; // Approximately 111km per degree at equator\n\n// Helper, avoids low-precision 32 bit matrices from gl-matrix mat4.create()\nfunction createMat4() {\n  return [1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1];\n}\n\n/**\n * Project [lng,lat] on sphere onto [x,y] on 512*512 Mercator Zoom 0 tile.\n * Performs the nonlinear part of the web mercator projection.\n * Remaining projection is done with 4x4 matrices which also handles\n * perspective.\n *\n * @param {Array} lngLat - [lng, lat] coordinates\n *   Specifies a point on the sphere to project onto the map.\n * @return {Array} [x,y] coordinates.\n */\nexport function projectFlat([lng, lat], scale) {\n  scale = scale * WORLD_SCALE;\n  const lambda2 = lng * DEGREES_TO_RADIANS;\n  const phi2 = lat * DEGREES_TO_RADIANS;\n  const x = scale * (lambda2 + PI) / (2 * PI);\n  const y = scale * (PI - Math.log(Math.tan(PI_4 + phi2 * 0.5))) / (2 * PI);\n  return [x, y];\n}\n\n/**\n * Unproject world point [x,y] on map onto {lat, lon} on sphere\n *\n * @param {object|Vector} xy - object with {x,y} members\n *  representing point on projected map plane\n * @return {GeoCoordinates} - object with {lat,lon} of point on sphere.\n *   Has toArray method if you need a GeoJSON Array.\n *   Per cartographic tradition, lat and lon are specified as degrees.\n */\nexport function unprojectFlat([x, y], scale) {\n  scale = scale * WORLD_SCALE;\n  const lambda2 = (x / scale) * (2 * PI) - PI;\n  const phi2 = 2 * (Math.atan(Math.exp(PI - (y / scale) * (2 * PI))) - PI_4);\n  return [lambda2 * RADIANS_TO_DEGREES, phi2 * RADIANS_TO_DEGREES];\n}\n\n// Returns the zoom level that gives a 1 meter pixel at a certain latitude\n// S=C*cos(y)/2^(z+8)\nexport function getMercatorMeterZoom({latitude}) {\n  assert(latitude);\n  const EARTH_CIRCUMFERENCE = 40.075e6;\n  const radians = degrees => degrees / 180 * Math.PI;\n  return Math.log2(EARTH_CIRCUMFERENCE * Math.cos(radians(latitude))) - 8;\n}\n\n/**\n * Calculate distance scales in meters around current lat/lon, both for\n * degrees and pixels.\n * In mercator projection mode, the distance scales vary significantly\n * with latitude.\n */\nexport function getMercatorDistanceScales({latitude, longitude, zoom, scale}) {\n  // Calculate scale from zoom if not provided\n  scale = scale !== undefined ? scale : Math.pow(2, zoom);\n\n  assert(!isNaN(latitude) && !isNaN(longitude) && !isNaN(scale));\n\n  const latCosine = Math.cos(latitude * Math.PI / 180);\n\n  // const metersPerDegreeX = METERS_PER_DEGREE_AT_EQUATOR * latCosine;\n  // const metersPerDegreeY = METERS_PER_DEGREE_AT_EQUATOR;\n\n  // Calculate number of pixels occupied by one degree longitude\n  // around current lat/lon\n  const pixelsPerDegreeX = vec2_distance(\n    projectFlat([longitude + 0.5, latitude], scale),\n    projectFlat([longitude - 0.5, latitude], scale)\n  );\n  // Calculate number of pixels occupied by one degree latitude\n  // around current lat/lon\n  const pixelsPerDegreeY = vec2_distance(\n    projectFlat([longitude, latitude + 0.5], scale),\n    projectFlat([longitude, latitude - 0.5], scale)\n  );\n\n  const worldSize = TILE_SIZE * scale;\n  const altPixelsPerMeter = worldSize / (4e7 * latCosine);\n  const pixelsPerMeter = [altPixelsPerMeter, altPixelsPerMeter, altPixelsPerMeter];\n  const metersPerPixel = [1 / altPixelsPerMeter, 1 / altPixelsPerMeter, 1 / altPixelsPerMeter];\n\n  const pixelsPerDegree = [pixelsPerDegreeX, pixelsPerDegreeY, altPixelsPerMeter];\n  const degreesPerPixel = [1 / pixelsPerDegreeX, 1 / pixelsPerDegreeY, 1 / altPixelsPerMeter];\n\n  // Main results, used for converting meters to latlng deltas and scaling offsets\n  return {\n    pixelsPerMeter,\n    metersPerPixel,\n    pixelsPerDegree,\n    degreesPerPixel\n  };\n}\n\n/**\n * Calculates a mercator world position (\"pixels\" in given zoom level)\n * from a lng/lat and meterOffset\n */\nexport function getMercatorWorldPosition({\n  longitude,\n  latitude,\n  zoom,\n  meterOffset,\n  distanceScales = null\n}) {\n  const scale = Math.pow(2, zoom);\n\n  // Calculate distance scales if lng/lat/zoom are provided\n  distanceScales = distanceScales || getMercatorDistanceScales({latitude, longitude, scale});\n\n  // Make a centered version of the matrix for projection modes without an offset\n  const center2d = projectFlat([longitude, latitude], scale);\n  const center = new Vector3(center2d[0], center2d[1], 0);\n\n  if (meterOffset) {\n    const pixelPosition = new Vector3(meterOffset)\n      // Convert to pixels in current zoom\n      .scale(distanceScales.pixelsPerMeter)\n      // We want positive Y to represent an offset towards north,\n      // but web mercator world coordinates is top-left\n      .scale([1, -1, 1]);\n    center.add(pixelPosition);\n  }\n\n  return center;\n}\n\n// ATTRIBUTION:\n// view and projection matrix creation is intentionally kept compatible with\n// mapbox-gl's implementation to ensure that seamless interoperation\n// with mapbox and react-map-gl. See: https://github.com/mapbox/mapbox-gl-js\n\n// Variable fov (in radians)\nexport function getFov({height, altitude}) {\n  return 2 * Math.atan((height / 2) / altitude);\n}\n\nexport function getClippingPlanes({altitude, pitch}) {\n  // Find the distance from the center point to the center top\n  // in altitude units using law of sines.\n  const pitchRadians = pitch * DEGREES_TO_RADIANS;\n  const halfFov = Math.atan(0.5 / altitude);\n  const topHalfSurfaceDistance =\n    Math.sin(halfFov) * altitude / Math.sin(Math.PI / 2 - pitchRadians - halfFov);\n\n  // Calculate z value of the farthest fragment that should be rendered.\n  const farZ = Math.cos(Math.PI / 2 - pitchRadians) * topHalfSurfaceDistance + altitude;\n\n  return {farZ, nearZ: 0.1};\n}\n\n// TODO - rename this matrix\nexport function makeUncenteredViewMatrixFromMercatorParams({\n  width,\n  height,\n  longitude,\n  latitude,\n  zoom,\n  pitch,\n  bearing,\n  altitude,\n  center\n}) {\n  // VIEW MATRIX: PROJECTS MERCATOR WORLD COORDINATES\n  // Note that mercator world coordinates typically need to be flipped\n  //\n  // Note: As usual, matrix operation orders should be read in reverse\n  // since vectors will be multiplied from the right during transformation\n  const vm = createMat4();\n\n  // Move camera to altitude (along the pitch & bearing direction)\n  mat4_translate(vm, vm, [0, 0, -altitude]);\n\n  // After the rotateX, z values are in pixel units. Convert them to\n  // altitude units. 1 altitude unit = the screen height.\n  mat4_scale(vm, vm, [1, 1, 1 / height]);\n\n  // Rotate by bearing, and then by pitch (which tilts the view)\n  mat4_rotateX(vm, vm, -pitch * DEGREES_TO_RADIANS);\n  mat4_rotateZ(vm, vm, bearing * DEGREES_TO_RADIANS);\n\n  return vm;\n}\n\nexport function makeViewMatricesFromMercatorParams({\n  width,\n  height,\n  longitude,\n  latitude,\n  zoom,\n  pitch,\n  bearing,\n  altitude,\n  centerLngLat,\n  meterOffset = null\n}) {\n  const center = getMercatorWorldPosition({longitude, latitude, zoom, meterOffset});\n\n  // VIEW MATRIX: PROJECTS FROM VIRTUAL PIXELS TO CAMERA SPACE\n  // Note: As usual, matrix operation orders should be read in reverse\n  // since vectors will be multiplied from the right during transformation\n  const viewMatrixUncentered = makeUncenteredViewMatrixFromMercatorParams({\n    width,\n    height,\n    longitude,\n    latitude,\n    zoom,\n    pitch,\n    bearing,\n    altitude\n  });\n\n  const vm = createMat4();\n  mat4_scale(vm, viewMatrixUncentered, [1, -1, 1]);\n  const viewMatrixCentered = mat4_translate(vm, vm, new Vector3(center).negate());\n\n  return {\n    viewMatrixCentered,\n    viewMatrixUncentered,\n    center\n  };\n}\n\n// PROJECTION MATRIX: PROJECTS FROM CAMERA (VIEW) SPACE TO CLIPSPACE\n// This is a \"Mapbox\" projection matrix - matches mapbox exactly if farZMultiplier === 1\nexport function makeProjectionMatrixFromMercatorParams({\n  width,\n  height,\n  pitch,\n  altitude,\n  farZMultiplier = 10\n}) {\n  const {nearZ, farZ} = getClippingPlanes({altitude, pitch});\n  const fov = getFov({height, altitude});\n\n  const projectionMatrix = mat4_perspective(\n    createMat4(),\n    fov,              // fov in radians\n    width / height,   // aspect ratio\n    nearZ,            // near plane\n    farZ * farZMultiplier // far plane\n  );\n\n  return projectionMatrix;\n}\n"]} | ||
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../src/web-mercator-utils.js"],"names":["Vector3","createMat4","mat4_perspective","mat4_scale","mat4_translate","mat4_rotateX","mat4_rotateZ","vec2_distance","assert","PI","Math","PI_4","DEGREES_TO_RADIANS","RADIANS_TO_DEGREES","TILE_SIZE","WORLD_SCALE","EARTH_CIRCUMFERENCE","projectFlat","scale","lng","lat","lambda2","phi2","x","y","log","tan","unprojectFlat","atan","exp","getMeterZoom","latitude","radians","degrees","log2","cos","getDistanceScales","longitude","zoom","undefined","pow","isNaN","latCosine","pixelsPerDegreeX","pixelsPerDegreeY","worldSize","altPixelsPerMeter","pixelsPerMeter","metersPerPixel","pixelsPerDegree","degreesPerPixel","getWorldPosition","meterOffset","distanceScales","center2d","center","pixelPosition","add","getFov","height","altitude","getClippingPlanes","pitch","pitchRadians","halfFov","topHalfSurfaceDistance","sin","farZ","nearZ","getUncenteredViewMatrix","bearing","vm","getViewMatrix","width","viewMatrixUncentered","flipY","viewMatrixCentered","negate","getProjectionMatrix","farZMultiplier","fov","projectionMatrix"],"mappings":"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","file":"web-mercator-utils.js","sourcesContent":["// TODO - THE UTILITIES IN THIS FILE SHOULD BE IMPORTED FROM WEB-MERCATOR-VIEWPORT MODULE\n\nimport {Vector3} from 'math.gl';\nimport {createMat4} from './math-utils';\n\nimport mat4_perspective from 'gl-mat4/perspective';\nimport mat4_scale from 'gl-mat4/scale';\nimport mat4_translate from 'gl-mat4/translate';\nimport mat4_rotateX from 'gl-mat4/rotateX';\nimport mat4_rotateZ from 'gl-mat4/rotateZ';\nimport vec2_distance from 'gl-vec2/distance';\nimport assert from 'assert';\n\n// CONSTANTS\nconst PI = Math.PI;\nconst PI_4 = PI / 4;\nconst DEGREES_TO_RADIANS = PI / 180;\nconst RADIANS_TO_DEGREES = 180 / PI;\nconst TILE_SIZE = 512;\nconst WORLD_SCALE = TILE_SIZE;\nconst EARTH_CIRCUMFERENCE = 40.075e6;\n// const METERS_PER_DEGREE_AT_EQUATOR = 111000; // Approximately 111km per degree at equator\n\n/**\n * Project [lng,lat] on sphere onto [x,y] on 512*512 Mercator Zoom 0 tile.\n * Performs the nonlinear part of the web mercator projection.\n * Remaining projection is done with 4x4 matrices which also handles\n * perspective.\n *\n * @param {Array} lngLat - [lng, lat] coordinates\n *   Specifies a point on the sphere to project onto the map.\n * @return {Array} [x,y] coordinates.\n */\nexport function projectFlat([lng, lat], scale) {\n  scale = scale * WORLD_SCALE;\n  const lambda2 = lng * DEGREES_TO_RADIANS;\n  const phi2 = lat * DEGREES_TO_RADIANS;\n  const x = scale * (lambda2 + PI) / (2 * PI);\n  const y = scale * (PI - Math.log(Math.tan(PI_4 + phi2 * 0.5))) / (2 * PI);\n  return [x, y];\n}\n\n/**\n * Unproject world point [x,y] on map onto {lat, lon} on sphere\n *\n * @param {object|Vector} xy - object with {x,y} members\n *  representing point on projected map plane\n * @return {GeoCoordinates} - object with {lat,lon} of point on sphere.\n *   Has toArray method if you need a GeoJSON Array.\n *   Per cartographic tradition, lat and lon are specified as degrees.\n */\nexport function unprojectFlat([x, y], scale) {\n  scale = scale * WORLD_SCALE;\n  const lambda2 = (x / scale) * (2 * PI) - PI;\n  const phi2 = 2 * (Math.atan(Math.exp(PI - (y / scale) * (2 * PI))) - PI_4);\n  return [lambda2 * RADIANS_TO_DEGREES, phi2 * RADIANS_TO_DEGREES];\n}\n\n// Returns the zoom level that gives a 1 meter pixel at a certain latitude\n// S=C*cos(y)/2^(z+8)\nexport function getMeterZoom({latitude}) {\n  assert(latitude);\n  const radians = degrees => degrees / 180 * Math.PI;\n  return Math.log2(EARTH_CIRCUMFERENCE * Math.cos(radians(latitude))) - 8;\n}\n\n/**\n * Calculate distance scales in meters around current lat/lon, both for\n * degrees and pixels.\n * In mercator projection mode, the distance scales vary significantly\n * with latitude.\n */\nexport function getDistanceScales({latitude, longitude, zoom, scale}) {\n  // Calculate scale from zoom if not provided\n  scale = scale !== undefined ? scale : Math.pow(2, zoom);\n\n  assert(!isNaN(latitude) && !isNaN(longitude) && !isNaN(scale));\n\n  const latCosine = Math.cos(latitude * Math.PI / 180);\n\n  // const metersPerDegreeX = METERS_PER_DEGREE_AT_EQUATOR * latCosine;\n  // const metersPerDegreeY = METERS_PER_DEGREE_AT_EQUATOR;\n\n  // Calculate number of pixels occupied by one degree longitude\n  // around current lat/lon\n  const pixelsPerDegreeX = vec2_distance(\n    projectFlat([longitude + 0.5, latitude], scale),\n    projectFlat([longitude - 0.5, latitude], scale)\n  );\n  // Calculate number of pixels occupied by one degree latitude\n  // around current lat/lon\n  const pixelsPerDegreeY = vec2_distance(\n    projectFlat([longitude, latitude + 0.5], scale),\n    projectFlat([longitude, latitude - 0.5], scale)\n  );\n\n  const worldSize = TILE_SIZE * scale;\n  const altPixelsPerMeter = worldSize / (4e7 * latCosine);\n  const pixelsPerMeter = [altPixelsPerMeter, altPixelsPerMeter, altPixelsPerMeter];\n  const metersPerPixel = [1 / altPixelsPerMeter, 1 / altPixelsPerMeter, 1 / altPixelsPerMeter];\n\n  const pixelsPerDegree = [pixelsPerDegreeX, pixelsPerDegreeY, altPixelsPerMeter];\n  const degreesPerPixel = [1 / pixelsPerDegreeX, 1 / pixelsPerDegreeY, 1 / altPixelsPerMeter];\n\n  // Main results, used for converting meters to latlng deltas and scaling offsets\n  return {\n    pixelsPerMeter,\n    metersPerPixel,\n    pixelsPerDegree,\n    degreesPerPixel\n  };\n}\n\n/**\n * Calculates a mercator world position (\"pixels\" in given zoom level)\n * from a lng/lat and meterOffset\n */\nexport function getWorldPosition({\n  longitude,\n  latitude,\n  zoom,\n  meterOffset,\n  distanceScales = null\n}) {\n  const scale = Math.pow(2, zoom);\n\n  // Make a centered version of the matrix for projection modes without an offset\n  const center2d = projectFlat([longitude, latitude], scale);\n  const center = new Vector3(center2d[0], center2d[1], 0);\n\n  if (meterOffset) {\n    // Calculate distance scales if lng/lat/zoom are provided\n    distanceScales = distanceScales || getDistanceScales({latitude, longitude, scale});\n\n    const pixelPosition = new Vector3(meterOffset)\n      // Convert to pixels in current zoom\n      .scale(distanceScales.pixelsPerMeter)\n      // We want positive Y to represent an offset towards north,\n      // but web mercator world coordinates is top-left\n      .scale([1, -1, 1]);\n    center.add(pixelPosition);\n  }\n\n  return center;\n}\n\n// ATTRIBUTION:\n// view and projection matrix creation is intentionally kept compatible with\n// mapbox-gl's implementation to ensure that seamless interoperation\n// with mapbox and react-map-gl. See: https://github.com/mapbox/mapbox-gl-js\n\n// Variable fov (in radians)\nfunction getFov({height, altitude}) {\n  return 2 * Math.atan((height / 2) / altitude);\n}\n\nfunction getClippingPlanes({altitude, pitch}) {\n  // Find the distance from the center point to the center top\n  // in altitude units using law of sines.\n  const pitchRadians = pitch * DEGREES_TO_RADIANS;\n  const halfFov = Math.atan(0.5 / altitude);\n  const topHalfSurfaceDistance =\n    Math.sin(halfFov) * altitude / Math.sin(Math.PI / 2 - pitchRadians - halfFov);\n\n  // Calculate z value of the farthest fragment that should be rendered.\n  const farZ = Math.cos(Math.PI / 2 - pitchRadians) * topHalfSurfaceDistance + altitude;\n\n  return {farZ, nearZ: 0.1};\n}\n\n// TODO - rename this matrix\nexport function getUncenteredViewMatrix({\n  height,\n  pitch,\n  bearing,\n  altitude\n}) {\n  // VIEW MATRIX: PROJECTS MERCATOR WORLD COORDINATES\n  // Note that mercator world coordinates typically need to be flipped\n  //\n  // Note: As usual, matrix operation orders should be read in reverse\n  // since vectors will be multiplied from the right during transformation\n  const vm = createMat4();\n\n  // Move camera to altitude (along the pitch & bearing direction)\n  mat4_translate(vm, vm, [0, 0, -altitude]);\n\n  // After the rotateX, z values are in pixel units. Convert them to\n  // altitude units. 1 altitude unit = the screen height.\n  mat4_scale(vm, vm, [1, 1, 1 / height]);\n\n  // Rotate by bearing, and then by pitch (which tilts the view)\n  mat4_rotateX(vm, vm, -pitch * DEGREES_TO_RADIANS);\n  mat4_rotateZ(vm, vm, bearing * DEGREES_TO_RADIANS);\n\n  return vm;\n}\n\nexport function getViewMatrix({\n  // Viewport props\n  width,\n  height,\n  longitude,\n  latitude,\n  zoom,\n  pitch,\n  bearing,\n  altitude,\n  // Pre-calculated parameters\n  distanceScales = null,\n  center = null,\n  viewMatrixUncentered = null,\n  // Options\n  meterOffset = null,\n  flipY = true\n}) {\n  if (!center) {\n    center = getWorldPosition({longitude, latitude, zoom, distanceScales, meterOffset});\n  }\n\n  // VIEW MATRIX: PROJECTS FROM VIRTUAL PIXELS TO CAMERA SPACE\n  // Note: As usual, matrix operation orders should be read in reverse\n  // since vectors will be multiplied from the right during transformation\n  if (!viewMatrixUncentered) {\n    viewMatrixUncentered = getUncenteredViewMatrix({height, pitch, bearing, altitude});\n  }\n\n  const vm = createMat4();\n\n  if (flipY) {\n    mat4_scale(vm, viewMatrixUncentered, [1, -1, 1]);\n  }\n\n  const viewMatrixCentered = mat4_translate(vm, vm, new Vector3(center).negate());\n\n  return viewMatrixCentered;\n}\n\n// PROJECTION MATRIX: PROJECTS FROM CAMERA (VIEW) SPACE TO CLIPSPACE\n// This is a \"Mapbox\" projection matrix - matches mapbox exactly if farZMultiplier === 1\nexport function getProjectionMatrix({\n  width,\n  height,\n  pitch,\n  altitude,\n  farZMultiplier = 10\n}) {\n  const {nearZ, farZ} = getClippingPlanes({altitude, pitch});\n  const fov = getFov({height, altitude});\n\n  const projectionMatrix = mat4_perspective(\n    [],\n    fov,              // fov in radians\n    width / height,   // aspect ratio\n    nearZ,            // near plane\n    farZ * farZMultiplier // far plane\n  );\n\n  return projectionMatrix;\n}\n"]} |
@@ -7,3 +7,3 @@ 'use strict'; | ||
var _flatMercatorViewport = require('./flat-mercator-viewport'); | ||
var _webMercatorViewport = require('./web-mercator-viewport'); | ||
@@ -13,20 +13,23 @@ Object.defineProperty(exports, 'default', { | ||
get: function get() { | ||
return _interopRequireDefault(_flatMercatorViewport).default; | ||
return _interopRequireDefault(_webMercatorViewport).default; | ||
} | ||
}); | ||
Object.defineProperty(exports, 'FlatMercatorViewport', { | ||
Object.defineProperty(exports, 'WebMercatorViewport', { | ||
enumerable: true, | ||
get: function get() { | ||
return _interopRequireDefault(_flatMercatorViewport).default; | ||
return _interopRequireDefault(_webMercatorViewport).default; | ||
} | ||
}); | ||
var _perspectiveMercatorViewport = require('./perspective-mercator-viewport'); | ||
Object.defineProperty(exports, 'PerspectiveMercatorViewport', { | ||
enumerable: true, | ||
get: function get() { | ||
return _interopRequireDefault(_perspectiveMercatorViewport).default; | ||
return _interopRequireDefault(_webMercatorViewport).default; | ||
} | ||
}); | ||
Object.defineProperty(exports, 'fitBounds', { | ||
enumerable: true, | ||
get: function get() { | ||
return _webMercatorViewport.fitBounds; | ||
} | ||
}); | ||
@@ -47,52 +50,40 @@ var _webMercatorUtils = require('./web-mercator-utils'); | ||
}); | ||
Object.defineProperty(exports, 'getMercatorMeterZoom', { | ||
Object.defineProperty(exports, 'getMeterZoom', { | ||
enumerable: true, | ||
get: function get() { | ||
return _webMercatorUtils.getMercatorMeterZoom; | ||
return _webMercatorUtils.getMeterZoom; | ||
} | ||
}); | ||
Object.defineProperty(exports, 'getMercatorDistanceScales', { | ||
Object.defineProperty(exports, 'getDistanceScales', { | ||
enumerable: true, | ||
get: function get() { | ||
return _webMercatorUtils.getMercatorDistanceScales; | ||
return _webMercatorUtils.getDistanceScales; | ||
} | ||
}); | ||
Object.defineProperty(exports, 'getMercatorWorldPosition', { | ||
Object.defineProperty(exports, 'getWorldPosition', { | ||
enumerable: true, | ||
get: function get() { | ||
return _webMercatorUtils.getMercatorWorldPosition; | ||
return _webMercatorUtils.getWorldPosition; | ||
} | ||
}); | ||
Object.defineProperty(exports, 'makeViewMatricesFromMercatorParams', { | ||
Object.defineProperty(exports, 'getViewMatrix', { | ||
enumerable: true, | ||
get: function get() { | ||
return _webMercatorUtils.makeViewMatricesFromMercatorParams; | ||
return _webMercatorUtils.getViewMatrix; | ||
} | ||
}); | ||
Object.defineProperty(exports, 'makeUncenteredViewMatrixFromMercatorParams', { | ||
Object.defineProperty(exports, 'getUncenteredViewMatrix', { | ||
enumerable: true, | ||
get: function get() { | ||
return _webMercatorUtils.makeUncenteredViewMatrixFromMercatorParams; | ||
return _webMercatorUtils.getUncenteredViewMatrix; | ||
} | ||
}); | ||
Object.defineProperty(exports, 'makeProjectionMatrixFromMercatorParams', { | ||
Object.defineProperty(exports, 'getProjectionMatrix', { | ||
enumerable: true, | ||
get: function get() { | ||
return _webMercatorUtils.makeProjectionMatrixFromMercatorParams; | ||
return _webMercatorUtils.getProjectionMatrix; | ||
} | ||
}); | ||
Object.defineProperty(exports, 'getFov', { | ||
enumerable: true, | ||
get: function get() { | ||
return _webMercatorUtils.getFov; | ||
} | ||
}); | ||
Object.defineProperty(exports, 'getClippingPlanes', { | ||
enumerable: true, | ||
get: function get() { | ||
return _webMercatorUtils.getClippingPlanes; | ||
} | ||
}); | ||
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } | ||
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uL3NyYy9pbmRleC5qcyJdLCJuYW1lcyI6WyJkZWZhdWx0IiwicHJvamVjdEZsYXQiLCJ1bnByb2plY3RGbGF0IiwiZ2V0TWVyY2F0b3JNZXRlclpvb20iLCJnZXRNZXJjYXRvckRpc3RhbmNlU2NhbGVzIiwiZ2V0TWVyY2F0b3JXb3JsZFBvc2l0aW9uIiwibWFrZVZpZXdNYXRyaWNlc0Zyb21NZXJjYXRvclBhcmFtcyIsIm1ha2VVbmNlbnRlcmVkVmlld01hdHJpeEZyb21NZXJjYXRvclBhcmFtcyIsIm1ha2VQcm9qZWN0aW9uTWF0cml4RnJvbU1lcmNhdG9yUGFyYW1zIiwiZ2V0Rm92IiwiZ2V0Q2xpcHBpbmdQbGFuZXMiXSwibWFwcGluZ3MiOiI7Ozs7Ozs7Ozs7O3lEQUNRQSxPOzs7Ozs7eURBQ0FBLE87Ozs7Ozs7OztnRUFDQUEsTzs7Ozs7Ozs7OzZCQUVBQyxXOzs7Ozs7NkJBQ0FDLGE7Ozs7Ozs2QkFDQUMsb0I7Ozs7Ozs2QkFDQUMseUI7Ozs7Ozs2QkFDQUMsd0I7Ozs7Ozs2QkFDQUMsa0M7Ozs7Ozs2QkFDQUMsMEM7Ozs7Ozs2QkFDQUMsc0M7Ozs7Ozs2QkFDQUMsTTs7Ozs7OzZCQUNBQyxpQiIsImZpbGUiOiJpbmRleC5qcyIsInNvdXJjZXNDb250ZW50IjpbIi8vIENsYXNzaWMgd2ViLW1lcmNhdG9yLXByb2plY3RcbmV4cG9ydCB7ZGVmYXVsdCBhcyBkZWZhdWx0fSBmcm9tICcuL2ZsYXQtbWVyY2F0b3Itdmlld3BvcnQnO1xuZXhwb3J0IHtkZWZhdWx0IGFzIEZsYXRNZXJjYXRvclZpZXdwb3J0fSBmcm9tICcuL2ZsYXQtbWVyY2F0b3Itdmlld3BvcnQnO1xuZXhwb3J0IHtkZWZhdWx0IGFzIFBlcnNwZWN0aXZlTWVyY2F0b3JWaWV3cG9ydH0gZnJvbSAnLi9wZXJzcGVjdGl2ZS1tZXJjYXRvci12aWV3cG9ydCc7XG5cbmV4cG9ydCB7cHJvamVjdEZsYXR9IGZyb20gJy4vd2ViLW1lcmNhdG9yLXV0aWxzJztcbmV4cG9ydCB7dW5wcm9qZWN0RmxhdH0gZnJvbSAnLi93ZWItbWVyY2F0b3ItdXRpbHMnO1xuZXhwb3J0IHtnZXRNZXJjYXRvck1ldGVyWm9vbX0gZnJvbSAnLi93ZWItbWVyY2F0b3ItdXRpbHMnO1xuZXhwb3J0IHtnZXRNZXJjYXRvckRpc3RhbmNlU2NhbGVzfSBmcm9tICcuL3dlYi1tZXJjYXRvci11dGlscyc7XG5leHBvcnQge2dldE1lcmNhdG9yV29ybGRQb3NpdGlvbn0gZnJvbSAnLi93ZWItbWVyY2F0b3ItdXRpbHMnO1xuZXhwb3J0IHttYWtlVmlld01hdHJpY2VzRnJvbU1lcmNhdG9yUGFyYW1zfSBmcm9tICcuL3dlYi1tZXJjYXRvci11dGlscyc7XG5leHBvcnQge21ha2VVbmNlbnRlcmVkVmlld01hdHJpeEZyb21NZXJjYXRvclBhcmFtc30gZnJvbSAnLi93ZWItbWVyY2F0b3ItdXRpbHMnO1xuZXhwb3J0IHttYWtlUHJvamVjdGlvbk1hdHJpeEZyb21NZXJjYXRvclBhcmFtc30gZnJvbSAnLi93ZWItbWVyY2F0b3ItdXRpbHMnO1xuZXhwb3J0IHtnZXRGb3Z9IGZyb20gJy4vd2ViLW1lcmNhdG9yLXV0aWxzJztcbmV4cG9ydCB7Z2V0Q2xpcHBpbmdQbGFuZXN9IGZyb20gJy4vd2ViLW1lcmNhdG9yLXV0aWxzJztcbiJdfQ== | ||
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uL3NyYy9pbmRleC5qcyJdLCJuYW1lcyI6WyJkZWZhdWx0IiwiZml0Qm91bmRzIiwicHJvamVjdEZsYXQiLCJ1bnByb2plY3RGbGF0IiwiZ2V0TWV0ZXJab29tIiwiZ2V0RGlzdGFuY2VTY2FsZXMiLCJnZXRXb3JsZFBvc2l0aW9uIiwiZ2V0Vmlld01hdHJpeCIsImdldFVuY2VudGVyZWRWaWV3TWF0cml4IiwiZ2V0UHJvamVjdGlvbk1hdHJpeCJdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7Ozs7d0RBQ1FBLE87Ozs7Ozt3REFDQUEsTzs7Ozs7O3dEQUVBQSxPOzs7Ozs7Z0NBRUFDLFM7Ozs7Ozs7Ozs2QkFHTkMsVzs7Ozs7OzZCQUNBQyxhOzs7Ozs7NkJBQ0FDLFk7Ozs7Ozs2QkFDQUMsaUI7Ozs7Ozs2QkFDQUMsZ0I7Ozs7Ozs2QkFDQUMsYTs7Ozs7OzZCQUNBQyx1Qjs7Ozs7OzZCQUNBQyxtQiIsImZpbGUiOiJpbmRleC5qcyIsInNvdXJjZXNDb250ZW50IjpbIi8vIENsYXNzaWMgd2ViLW1lcmNhdG9yLXByb2plY3RcbmV4cG9ydCB7ZGVmYXVsdCBhcyBkZWZhdWx0fSBmcm9tICcuL3dlYi1tZXJjYXRvci12aWV3cG9ydCc7XG5leHBvcnQge2RlZmF1bHQgYXMgV2ViTWVyY2F0b3JWaWV3cG9ydH0gZnJvbSAnLi93ZWItbWVyY2F0b3Itdmlld3BvcnQnO1xuLy8gTGVnYWN5IGNsYXNzIG5hbWVcbmV4cG9ydCB7ZGVmYXVsdCBhcyBQZXJzcGVjdGl2ZU1lcmNhdG9yVmlld3BvcnR9IGZyb20gJy4vd2ViLW1lcmNhdG9yLXZpZXdwb3J0JztcblxuZXhwb3J0IHtmaXRCb3VuZHN9IGZyb20gJy4vd2ViLW1lcmNhdG9yLXZpZXdwb3J0JztcblxuZXhwb3J0IHtcbiAgcHJvamVjdEZsYXQsXG4gIHVucHJvamVjdEZsYXQsXG4gIGdldE1ldGVyWm9vbSxcbiAgZ2V0RGlzdGFuY2VTY2FsZXMsXG4gIGdldFdvcmxkUG9zaXRpb24sXG4gIGdldFZpZXdNYXRyaXgsXG4gIGdldFVuY2VudGVyZWRWaWV3TWF0cml4LFxuICBnZXRQcm9qZWN0aW9uTWF0cml4XG59IGZyb20gJy4vd2ViLW1lcmNhdG9yLXV0aWxzJztcbiJdfQ== |
@@ -11,13 +11,13 @@ 'use strict'; | ||
exports.unprojectFlat = unprojectFlat; | ||
exports.getMercatorMeterZoom = getMercatorMeterZoom; | ||
exports.getMercatorDistanceScales = getMercatorDistanceScales; | ||
exports.getMercatorWorldPosition = getMercatorWorldPosition; | ||
exports.getFov = getFov; | ||
exports.getClippingPlanes = getClippingPlanes; | ||
exports.makeUncenteredViewMatrixFromMercatorParams = makeUncenteredViewMatrixFromMercatorParams; | ||
exports.makeViewMatricesFromMercatorParams = makeViewMatricesFromMercatorParams; | ||
exports.makeProjectionMatrixFromMercatorParams = makeProjectionMatrixFromMercatorParams; | ||
exports.getMeterZoom = getMeterZoom; | ||
exports.getDistanceScales = getDistanceScales; | ||
exports.getWorldPosition = getWorldPosition; | ||
exports.getUncenteredViewMatrix = getUncenteredViewMatrix; | ||
exports.getViewMatrix = getViewMatrix; | ||
exports.getProjectionMatrix = getProjectionMatrix; | ||
var _math = require('math.gl'); | ||
var _mathUtils = require('./math-utils'); | ||
var _perspective = require('gl-mat4/perspective'); | ||
@@ -60,10 +60,5 @@ | ||
var WORLD_SCALE = TILE_SIZE; | ||
var EARTH_CIRCUMFERENCE = 40.075e6; | ||
// const METERS_PER_DEGREE_AT_EQUATOR = 111000; // Approximately 111km per degree at equator | ||
// Helper, avoids low-precision 32 bit matrices from gl-matrix mat4.create() | ||
function createMat4() { | ||
return [1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1]; | ||
} | ||
/** | ||
@@ -114,7 +109,6 @@ * Project [lng,lat] on sphere onto [x,y] on 512*512 Mercator Zoom 0 tile. | ||
// S=C*cos(y)/2^(z+8) | ||
function getMercatorMeterZoom(_ref5) { | ||
function getMeterZoom(_ref5) { | ||
var latitude = _ref5.latitude; | ||
(0, _assert2.default)(latitude); | ||
var EARTH_CIRCUMFERENCE = 40.075e6; | ||
var radians = function radians(degrees) { | ||
@@ -132,3 +126,3 @@ return degrees / 180 * Math.PI; | ||
*/ | ||
function getMercatorDistanceScales(_ref6) { | ||
function getDistanceScales(_ref6) { | ||
var latitude = _ref6.latitude, | ||
@@ -177,3 +171,3 @@ longitude = _ref6.longitude, | ||
*/ | ||
function getMercatorWorldPosition(_ref7) { | ||
function getWorldPosition(_ref7) { | ||
var longitude = _ref7.longitude, | ||
@@ -188,5 +182,2 @@ latitude = _ref7.latitude, | ||
// Calculate distance scales if lng/lat/zoom are provided | ||
distanceScales = distanceScales || getMercatorDistanceScales({ latitude: latitude, longitude: longitude, scale: scale }); | ||
// Make a centered version of the matrix for projection modes without an offset | ||
@@ -197,2 +188,5 @@ var center2d = projectFlat([longitude, latitude], scale); | ||
if (meterOffset) { | ||
// Calculate distance scales if lng/lat/zoom are provided | ||
distanceScales = distanceScales || getDistanceScales({ latitude: latitude, longitude: longitude, scale: scale }); | ||
var pixelPosition = new _math.Vector3(meterOffset) | ||
@@ -240,12 +234,7 @@ // Convert to pixels in current zoom | ||
// TODO - rename this matrix | ||
function makeUncenteredViewMatrixFromMercatorParams(_ref10) { | ||
var width = _ref10.width, | ||
height = _ref10.height, | ||
longitude = _ref10.longitude, | ||
latitude = _ref10.latitude, | ||
zoom = _ref10.zoom, | ||
function getUncenteredViewMatrix(_ref10) { | ||
var height = _ref10.height, | ||
pitch = _ref10.pitch, | ||
bearing = _ref10.bearing, | ||
altitude = _ref10.altitude, | ||
center = _ref10.center; | ||
altitude = _ref10.altitude; | ||
@@ -257,3 +246,3 @@ // VIEW MATRIX: PROJECTS MERCATOR WORLD COORDINATES | ||
// since vectors will be multiplied from the right during transformation | ||
var vm = createMat4(); | ||
var vm = (0, _mathUtils.createMat4)(); | ||
@@ -274,3 +263,3 @@ // Move camera to altitude (along the pitch & bearing direction) | ||
function makeViewMatricesFromMercatorParams(_ref11) { | ||
function getViewMatrix(_ref11) { | ||
var width = _ref11.width, | ||
@@ -284,7 +273,16 @@ height = _ref11.height, | ||
altitude = _ref11.altitude, | ||
centerLngLat = _ref11.centerLngLat, | ||
_ref11$distanceScales = _ref11.distanceScales, | ||
distanceScales = _ref11$distanceScales === undefined ? null : _ref11$distanceScales, | ||
_ref11$center = _ref11.center, | ||
center = _ref11$center === undefined ? null : _ref11$center, | ||
_ref11$viewMatrixUnce = _ref11.viewMatrixUncentered, | ||
viewMatrixUncentered = _ref11$viewMatrixUnce === undefined ? null : _ref11$viewMatrixUnce, | ||
_ref11$meterOffset = _ref11.meterOffset, | ||
meterOffset = _ref11$meterOffset === undefined ? null : _ref11$meterOffset; | ||
meterOffset = _ref11$meterOffset === undefined ? null : _ref11$meterOffset, | ||
_ref11$flipY = _ref11.flipY, | ||
flipY = _ref11$flipY === undefined ? true : _ref11$flipY; | ||
var center = getMercatorWorldPosition({ longitude: longitude, latitude: latitude, zoom: zoom, meterOffset: meterOffset }); | ||
if (!center) { | ||
center = getWorldPosition({ longitude: longitude, latitude: latitude, zoom: zoom, distanceScales: distanceScales, meterOffset: meterOffset }); | ||
} | ||
@@ -294,22 +292,15 @@ // VIEW MATRIX: PROJECTS FROM VIRTUAL PIXELS TO CAMERA SPACE | ||
// since vectors will be multiplied from the right during transformation | ||
var viewMatrixUncentered = makeUncenteredViewMatrixFromMercatorParams({ | ||
width: width, | ||
height: height, | ||
longitude: longitude, | ||
latitude: latitude, | ||
zoom: zoom, | ||
pitch: pitch, | ||
bearing: bearing, | ||
altitude: altitude | ||
}); | ||
if (!viewMatrixUncentered) { | ||
viewMatrixUncentered = getUncenteredViewMatrix({ height: height, pitch: pitch, bearing: bearing, altitude: altitude }); | ||
} | ||
var vm = createMat4(); | ||
(0, _scale2.default)(vm, viewMatrixUncentered, [1, -1, 1]); | ||
var vm = (0, _mathUtils.createMat4)(); | ||
if (flipY) { | ||
(0, _scale2.default)(vm, viewMatrixUncentered, [1, -1, 1]); | ||
} | ||
var viewMatrixCentered = (0, _translate2.default)(vm, vm, new _math.Vector3(center).negate()); | ||
return { | ||
viewMatrixCentered: viewMatrixCentered, | ||
viewMatrixUncentered: viewMatrixUncentered, | ||
center: center | ||
}; | ||
return viewMatrixCentered; | ||
} | ||
@@ -319,3 +310,3 @@ | ||
// This is a "Mapbox" projection matrix - matches mapbox exactly if farZMultiplier === 1 | ||
function makeProjectionMatrixFromMercatorParams(_ref12) { | ||
function getProjectionMatrix(_ref12) { | ||
var width = _ref12.width, | ||
@@ -334,3 +325,3 @@ height = _ref12.height, | ||
var projectionMatrix = (0, _perspective2.default)(createMat4(), fov, // fov in radians | ||
var projectionMatrix = (0, _perspective2.default)([], fov, // fov in radians | ||
width / height, // aspect ratio | ||
@@ -343,2 +334,2 @@ nearZ, // near plane | ||
} | ||
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../src/web-mercator-utils.js"],"names":["projectFlat","unprojectFlat","getMercatorMeterZoom","getMercatorDistanceScales","getMercatorWorldPosition","getFov","getClippingPlanes","makeUncenteredViewMatrixFromMercatorParams","makeViewMatricesFromMercatorParams","makeProjectionMatrixFromMercatorParams","PI","Math","PI_4","DEGREES_TO_RADIANS","RADIANS_TO_DEGREES","TILE_SIZE","WORLD_SCALE","createMat4","scale","lng","lat","lambda2","phi2","x","y","log","tan","atan","exp","latitude","EARTH_CIRCUMFERENCE","radians","degrees","log2","cos","longitude","zoom","undefined","pow","isNaN","latCosine","pixelsPerDegreeX","pixelsPerDegreeY","worldSize","altPixelsPerMeter","pixelsPerMeter","metersPerPixel","pixelsPerDegree","degreesPerPixel","meterOffset","distanceScales","center2d","center","pixelPosition","add","height","altitude","pitch","pitchRadians","halfFov","topHalfSurfaceDistance","sin","farZ","nearZ","width","bearing","vm","centerLngLat","viewMatrixUncentered","viewMatrixCentered","negate","farZMultiplier","fov","projectionMatrix"],"mappings":"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","file":"web-mercator-utils.js","sourcesContent":["// TODO - THE UTILITIES IN THIS FILE SHOULD BE IMPORTED FROM WEB-MERCATOR-VIEWPORT MODULE\n\nimport {Vector3} from 'math.gl';\nimport mat4_perspective from 'gl-mat4/perspective';\nimport mat4_scale from 'gl-mat4/scale';\nimport mat4_translate from 'gl-mat4/translate';\nimport mat4_rotateX from 'gl-mat4/rotateX';\nimport mat4_rotateZ from 'gl-mat4/rotateZ';\nimport vec2_distance from 'gl-vec2/distance';\nimport assert from 'assert';\n\n// CONSTANTS\nconst PI = Math.PI;\nconst PI_4 = PI / 4;\nconst DEGREES_TO_RADIANS = PI / 180;\nconst RADIANS_TO_DEGREES = 180 / PI;\nconst TILE_SIZE = 512;\nconst WORLD_SCALE = TILE_SIZE;\n\n// const METERS_PER_DEGREE_AT_EQUATOR = 111000; // Approximately 111km per degree at equator\n\n// Helper, avoids low-precision 32 bit matrices from gl-matrix mat4.create()\nfunction createMat4() {\n  return [1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1];\n}\n\n/**\n * Project [lng,lat] on sphere onto [x,y] on 512*512 Mercator Zoom 0 tile.\n * Performs the nonlinear part of the web mercator projection.\n * Remaining projection is done with 4x4 matrices which also handles\n * perspective.\n *\n * @param {Array} lngLat - [lng, lat] coordinates\n *   Specifies a point on the sphere to project onto the map.\n * @return {Array} [x,y] coordinates.\n */\nexport function projectFlat([lng, lat], scale) {\n  scale = scale * WORLD_SCALE;\n  const lambda2 = lng * DEGREES_TO_RADIANS;\n  const phi2 = lat * DEGREES_TO_RADIANS;\n  const x = scale * (lambda2 + PI) / (2 * PI);\n  const y = scale * (PI - Math.log(Math.tan(PI_4 + phi2 * 0.5))) / (2 * PI);\n  return [x, y];\n}\n\n/**\n * Unproject world point [x,y] on map onto {lat, lon} on sphere\n *\n * @param {object|Vector} xy - object with {x,y} members\n *  representing point on projected map plane\n * @return {GeoCoordinates} - object with {lat,lon} of point on sphere.\n *   Has toArray method if you need a GeoJSON Array.\n *   Per cartographic tradition, lat and lon are specified as degrees.\n */\nexport function unprojectFlat([x, y], scale) {\n  scale = scale * WORLD_SCALE;\n  const lambda2 = (x / scale) * (2 * PI) - PI;\n  const phi2 = 2 * (Math.atan(Math.exp(PI - (y / scale) * (2 * PI))) - PI_4);\n  return [lambda2 * RADIANS_TO_DEGREES, phi2 * RADIANS_TO_DEGREES];\n}\n\n// Returns the zoom level that gives a 1 meter pixel at a certain latitude\n// S=C*cos(y)/2^(z+8)\nexport function getMercatorMeterZoom({latitude}) {\n  assert(latitude);\n  const EARTH_CIRCUMFERENCE = 40.075e6;\n  const radians = degrees => degrees / 180 * Math.PI;\n  return Math.log2(EARTH_CIRCUMFERENCE * Math.cos(radians(latitude))) - 8;\n}\n\n/**\n * Calculate distance scales in meters around current lat/lon, both for\n * degrees and pixels.\n * In mercator projection mode, the distance scales vary significantly\n * with latitude.\n */\nexport function getMercatorDistanceScales({latitude, longitude, zoom, scale}) {\n  // Calculate scale from zoom if not provided\n  scale = scale !== undefined ? scale : Math.pow(2, zoom);\n\n  assert(!isNaN(latitude) && !isNaN(longitude) && !isNaN(scale));\n\n  const latCosine = Math.cos(latitude * Math.PI / 180);\n\n  // const metersPerDegreeX = METERS_PER_DEGREE_AT_EQUATOR * latCosine;\n  // const metersPerDegreeY = METERS_PER_DEGREE_AT_EQUATOR;\n\n  // Calculate number of pixels occupied by one degree longitude\n  // around current lat/lon\n  const pixelsPerDegreeX = vec2_distance(\n    projectFlat([longitude + 0.5, latitude], scale),\n    projectFlat([longitude - 0.5, latitude], scale)\n  );\n  // Calculate number of pixels occupied by one degree latitude\n  // around current lat/lon\n  const pixelsPerDegreeY = vec2_distance(\n    projectFlat([longitude, latitude + 0.5], scale),\n    projectFlat([longitude, latitude - 0.5], scale)\n  );\n\n  const worldSize = TILE_SIZE * scale;\n  const altPixelsPerMeter = worldSize / (4e7 * latCosine);\n  const pixelsPerMeter = [altPixelsPerMeter, altPixelsPerMeter, altPixelsPerMeter];\n  const metersPerPixel = [1 / altPixelsPerMeter, 1 / altPixelsPerMeter, 1 / altPixelsPerMeter];\n\n  const pixelsPerDegree = [pixelsPerDegreeX, pixelsPerDegreeY, altPixelsPerMeter];\n  const degreesPerPixel = [1 / pixelsPerDegreeX, 1 / pixelsPerDegreeY, 1 / altPixelsPerMeter];\n\n  // Main results, used for converting meters to latlng deltas and scaling offsets\n  return {\n    pixelsPerMeter,\n    metersPerPixel,\n    pixelsPerDegree,\n    degreesPerPixel\n  };\n}\n\n/**\n * Calculates a mercator world position (\"pixels\" in given zoom level)\n * from a lng/lat and meterOffset\n */\nexport function getMercatorWorldPosition({\n  longitude,\n  latitude,\n  zoom,\n  meterOffset,\n  distanceScales = null\n}) {\n  const scale = Math.pow(2, zoom);\n\n  // Calculate distance scales if lng/lat/zoom are provided\n  distanceScales = distanceScales || getMercatorDistanceScales({latitude, longitude, scale});\n\n  // Make a centered version of the matrix for projection modes without an offset\n  const center2d = projectFlat([longitude, latitude], scale);\n  const center = new Vector3(center2d[0], center2d[1], 0);\n\n  if (meterOffset) {\n    const pixelPosition = new Vector3(meterOffset)\n      // Convert to pixels in current zoom\n      .scale(distanceScales.pixelsPerMeter)\n      // We want positive Y to represent an offset towards north,\n      // but web mercator world coordinates is top-left\n      .scale([1, -1, 1]);\n    center.add(pixelPosition);\n  }\n\n  return center;\n}\n\n// ATTRIBUTION:\n// view and projection matrix creation is intentionally kept compatible with\n// mapbox-gl's implementation to ensure that seamless interoperation\n// with mapbox and react-map-gl. See: https://github.com/mapbox/mapbox-gl-js\n\n// Variable fov (in radians)\nexport function getFov({height, altitude}) {\n  return 2 * Math.atan((height / 2) / altitude);\n}\n\nexport function getClippingPlanes({altitude, pitch}) {\n  // Find the distance from the center point to the center top\n  // in altitude units using law of sines.\n  const pitchRadians = pitch * DEGREES_TO_RADIANS;\n  const halfFov = Math.atan(0.5 / altitude);\n  const topHalfSurfaceDistance =\n    Math.sin(halfFov) * altitude / Math.sin(Math.PI / 2 - pitchRadians - halfFov);\n\n  // Calculate z value of the farthest fragment that should be rendered.\n  const farZ = Math.cos(Math.PI / 2 - pitchRadians) * topHalfSurfaceDistance + altitude;\n\n  return {farZ, nearZ: 0.1};\n}\n\n// TODO - rename this matrix\nexport function makeUncenteredViewMatrixFromMercatorParams({\n  width,\n  height,\n  longitude,\n  latitude,\n  zoom,\n  pitch,\n  bearing,\n  altitude,\n  center\n}) {\n  // VIEW MATRIX: PROJECTS MERCATOR WORLD COORDINATES\n  // Note that mercator world coordinates typically need to be flipped\n  //\n  // Note: As usual, matrix operation orders should be read in reverse\n  // since vectors will be multiplied from the right during transformation\n  const vm = createMat4();\n\n  // Move camera to altitude (along the pitch & bearing direction)\n  mat4_translate(vm, vm, [0, 0, -altitude]);\n\n  // After the rotateX, z values are in pixel units. Convert them to\n  // altitude units. 1 altitude unit = the screen height.\n  mat4_scale(vm, vm, [1, 1, 1 / height]);\n\n  // Rotate by bearing, and then by pitch (which tilts the view)\n  mat4_rotateX(vm, vm, -pitch * DEGREES_TO_RADIANS);\n  mat4_rotateZ(vm, vm, bearing * DEGREES_TO_RADIANS);\n\n  return vm;\n}\n\nexport function makeViewMatricesFromMercatorParams({\n  width,\n  height,\n  longitude,\n  latitude,\n  zoom,\n  pitch,\n  bearing,\n  altitude,\n  centerLngLat,\n  meterOffset = null\n}) {\n  const center = getMercatorWorldPosition({longitude, latitude, zoom, meterOffset});\n\n  // VIEW MATRIX: PROJECTS FROM VIRTUAL PIXELS TO CAMERA SPACE\n  // Note: As usual, matrix operation orders should be read in reverse\n  // since vectors will be multiplied from the right during transformation\n  const viewMatrixUncentered = makeUncenteredViewMatrixFromMercatorParams({\n    width,\n    height,\n    longitude,\n    latitude,\n    zoom,\n    pitch,\n    bearing,\n    altitude\n  });\n\n  const vm = createMat4();\n  mat4_scale(vm, viewMatrixUncentered, [1, -1, 1]);\n  const viewMatrixCentered = mat4_translate(vm, vm, new Vector3(center).negate());\n\n  return {\n    viewMatrixCentered,\n    viewMatrixUncentered,\n    center\n  };\n}\n\n// PROJECTION MATRIX: PROJECTS FROM CAMERA (VIEW) SPACE TO CLIPSPACE\n// This is a \"Mapbox\" projection matrix - matches mapbox exactly if farZMultiplier === 1\nexport function makeProjectionMatrixFromMercatorParams({\n  width,\n  height,\n  pitch,\n  altitude,\n  farZMultiplier = 10\n}) {\n  const {nearZ, farZ} = getClippingPlanes({altitude, pitch});\n  const fov = getFov({height, altitude});\n\n  const projectionMatrix = mat4_perspective(\n    createMat4(),\n    fov,              // fov in radians\n    width / height,   // aspect ratio\n    nearZ,            // near plane\n    farZ * farZMultiplier // far plane\n  );\n\n  return projectionMatrix;\n}\n"]} | ||
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../src/web-mercator-utils.js"],"names":["projectFlat","unprojectFlat","getMeterZoom","getDistanceScales","getWorldPosition","getUncenteredViewMatrix","getViewMatrix","getProjectionMatrix","PI","Math","PI_4","DEGREES_TO_RADIANS","RADIANS_TO_DEGREES","TILE_SIZE","WORLD_SCALE","EARTH_CIRCUMFERENCE","scale","lng","lat","lambda2","phi2","x","y","log","tan","atan","exp","latitude","radians","degrees","log2","cos","longitude","zoom","undefined","pow","isNaN","latCosine","pixelsPerDegreeX","pixelsPerDegreeY","worldSize","altPixelsPerMeter","pixelsPerMeter","metersPerPixel","pixelsPerDegree","degreesPerPixel","meterOffset","distanceScales","center2d","center","pixelPosition","add","getFov","height","altitude","getClippingPlanes","pitch","pitchRadians","halfFov","topHalfSurfaceDistance","sin","farZ","nearZ","bearing","vm","width","viewMatrixUncentered","flipY","viewMatrixCentered","negate","farZMultiplier","fov","projectionMatrix"],"mappings":"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","file":"web-mercator-utils.js","sourcesContent":["// TODO - THE UTILITIES IN THIS FILE SHOULD BE IMPORTED FROM WEB-MERCATOR-VIEWPORT MODULE\n\nimport {Vector3} from 'math.gl';\nimport {createMat4} from './math-utils';\n\nimport mat4_perspective from 'gl-mat4/perspective';\nimport mat4_scale from 'gl-mat4/scale';\nimport mat4_translate from 'gl-mat4/translate';\nimport mat4_rotateX from 'gl-mat4/rotateX';\nimport mat4_rotateZ from 'gl-mat4/rotateZ';\nimport vec2_distance from 'gl-vec2/distance';\nimport assert from 'assert';\n\n// CONSTANTS\nconst PI = Math.PI;\nconst PI_4 = PI / 4;\nconst DEGREES_TO_RADIANS = PI / 180;\nconst RADIANS_TO_DEGREES = 180 / PI;\nconst TILE_SIZE = 512;\nconst WORLD_SCALE = TILE_SIZE;\nconst EARTH_CIRCUMFERENCE = 40.075e6;\n// const METERS_PER_DEGREE_AT_EQUATOR = 111000; // Approximately 111km per degree at equator\n\n/**\n * Project [lng,lat] on sphere onto [x,y] on 512*512 Mercator Zoom 0 tile.\n * Performs the nonlinear part of the web mercator projection.\n * Remaining projection is done with 4x4 matrices which also handles\n * perspective.\n *\n * @param {Array} lngLat - [lng, lat] coordinates\n *   Specifies a point on the sphere to project onto the map.\n * @return {Array} [x,y] coordinates.\n */\nexport function projectFlat([lng, lat], scale) {\n  scale = scale * WORLD_SCALE;\n  const lambda2 = lng * DEGREES_TO_RADIANS;\n  const phi2 = lat * DEGREES_TO_RADIANS;\n  const x = scale * (lambda2 + PI) / (2 * PI);\n  const y = scale * (PI - Math.log(Math.tan(PI_4 + phi2 * 0.5))) / (2 * PI);\n  return [x, y];\n}\n\n/**\n * Unproject world point [x,y] on map onto {lat, lon} on sphere\n *\n * @param {object|Vector} xy - object with {x,y} members\n *  representing point on projected map plane\n * @return {GeoCoordinates} - object with {lat,lon} of point on sphere.\n *   Has toArray method if you need a GeoJSON Array.\n *   Per cartographic tradition, lat and lon are specified as degrees.\n */\nexport function unprojectFlat([x, y], scale) {\n  scale = scale * WORLD_SCALE;\n  const lambda2 = (x / scale) * (2 * PI) - PI;\n  const phi2 = 2 * (Math.atan(Math.exp(PI - (y / scale) * (2 * PI))) - PI_4);\n  return [lambda2 * RADIANS_TO_DEGREES, phi2 * RADIANS_TO_DEGREES];\n}\n\n// Returns the zoom level that gives a 1 meter pixel at a certain latitude\n// S=C*cos(y)/2^(z+8)\nexport function getMeterZoom({latitude}) {\n  assert(latitude);\n  const radians = degrees => degrees / 180 * Math.PI;\n  return Math.log2(EARTH_CIRCUMFERENCE * Math.cos(radians(latitude))) - 8;\n}\n\n/**\n * Calculate distance scales in meters around current lat/lon, both for\n * degrees and pixels.\n * In mercator projection mode, the distance scales vary significantly\n * with latitude.\n */\nexport function getDistanceScales({latitude, longitude, zoom, scale}) {\n  // Calculate scale from zoom if not provided\n  scale = scale !== undefined ? scale : Math.pow(2, zoom);\n\n  assert(!isNaN(latitude) && !isNaN(longitude) && !isNaN(scale));\n\n  const latCosine = Math.cos(latitude * Math.PI / 180);\n\n  // const metersPerDegreeX = METERS_PER_DEGREE_AT_EQUATOR * latCosine;\n  // const metersPerDegreeY = METERS_PER_DEGREE_AT_EQUATOR;\n\n  // Calculate number of pixels occupied by one degree longitude\n  // around current lat/lon\n  const pixelsPerDegreeX = vec2_distance(\n    projectFlat([longitude + 0.5, latitude], scale),\n    projectFlat([longitude - 0.5, latitude], scale)\n  );\n  // Calculate number of pixels occupied by one degree latitude\n  // around current lat/lon\n  const pixelsPerDegreeY = vec2_distance(\n    projectFlat([longitude, latitude + 0.5], scale),\n    projectFlat([longitude, latitude - 0.5], scale)\n  );\n\n  const worldSize = TILE_SIZE * scale;\n  const altPixelsPerMeter = worldSize / (4e7 * latCosine);\n  const pixelsPerMeter = [altPixelsPerMeter, altPixelsPerMeter, altPixelsPerMeter];\n  const metersPerPixel = [1 / altPixelsPerMeter, 1 / altPixelsPerMeter, 1 / altPixelsPerMeter];\n\n  const pixelsPerDegree = [pixelsPerDegreeX, pixelsPerDegreeY, altPixelsPerMeter];\n  const degreesPerPixel = [1 / pixelsPerDegreeX, 1 / pixelsPerDegreeY, 1 / altPixelsPerMeter];\n\n  // Main results, used for converting meters to latlng deltas and scaling offsets\n  return {\n    pixelsPerMeter,\n    metersPerPixel,\n    pixelsPerDegree,\n    degreesPerPixel\n  };\n}\n\n/**\n * Calculates a mercator world position (\"pixels\" in given zoom level)\n * from a lng/lat and meterOffset\n */\nexport function getWorldPosition({\n  longitude,\n  latitude,\n  zoom,\n  meterOffset,\n  distanceScales = null\n}) {\n  const scale = Math.pow(2, zoom);\n\n  // Make a centered version of the matrix for projection modes without an offset\n  const center2d = projectFlat([longitude, latitude], scale);\n  const center = new Vector3(center2d[0], center2d[1], 0);\n\n  if (meterOffset) {\n    // Calculate distance scales if lng/lat/zoom are provided\n    distanceScales = distanceScales || getDistanceScales({latitude, longitude, scale});\n\n    const pixelPosition = new Vector3(meterOffset)\n      // Convert to pixels in current zoom\n      .scale(distanceScales.pixelsPerMeter)\n      // We want positive Y to represent an offset towards north,\n      // but web mercator world coordinates is top-left\n      .scale([1, -1, 1]);\n    center.add(pixelPosition);\n  }\n\n  return center;\n}\n\n// ATTRIBUTION:\n// view and projection matrix creation is intentionally kept compatible with\n// mapbox-gl's implementation to ensure that seamless interoperation\n// with mapbox and react-map-gl. See: https://github.com/mapbox/mapbox-gl-js\n\n// Variable fov (in radians)\nfunction getFov({height, altitude}) {\n  return 2 * Math.atan((height / 2) / altitude);\n}\n\nfunction getClippingPlanes({altitude, pitch}) {\n  // Find the distance from the center point to the center top\n  // in altitude units using law of sines.\n  const pitchRadians = pitch * DEGREES_TO_RADIANS;\n  const halfFov = Math.atan(0.5 / altitude);\n  const topHalfSurfaceDistance =\n    Math.sin(halfFov) * altitude / Math.sin(Math.PI / 2 - pitchRadians - halfFov);\n\n  // Calculate z value of the farthest fragment that should be rendered.\n  const farZ = Math.cos(Math.PI / 2 - pitchRadians) * topHalfSurfaceDistance + altitude;\n\n  return {farZ, nearZ: 0.1};\n}\n\n// TODO - rename this matrix\nexport function getUncenteredViewMatrix({\n  height,\n  pitch,\n  bearing,\n  altitude\n}) {\n  // VIEW MATRIX: PROJECTS MERCATOR WORLD COORDINATES\n  // Note that mercator world coordinates typically need to be flipped\n  //\n  // Note: As usual, matrix operation orders should be read in reverse\n  // since vectors will be multiplied from the right during transformation\n  const vm = createMat4();\n\n  // Move camera to altitude (along the pitch & bearing direction)\n  mat4_translate(vm, vm, [0, 0, -altitude]);\n\n  // After the rotateX, z values are in pixel units. Convert them to\n  // altitude units. 1 altitude unit = the screen height.\n  mat4_scale(vm, vm, [1, 1, 1 / height]);\n\n  // Rotate by bearing, and then by pitch (which tilts the view)\n  mat4_rotateX(vm, vm, -pitch * DEGREES_TO_RADIANS);\n  mat4_rotateZ(vm, vm, bearing * DEGREES_TO_RADIANS);\n\n  return vm;\n}\n\nexport function getViewMatrix({\n  // Viewport props\n  width,\n  height,\n  longitude,\n  latitude,\n  zoom,\n  pitch,\n  bearing,\n  altitude,\n  // Pre-calculated parameters\n  distanceScales = null,\n  center = null,\n  viewMatrixUncentered = null,\n  // Options\n  meterOffset = null,\n  flipY = true\n}) {\n  if (!center) {\n    center = getWorldPosition({longitude, latitude, zoom, distanceScales, meterOffset});\n  }\n\n  // VIEW MATRIX: PROJECTS FROM VIRTUAL PIXELS TO CAMERA SPACE\n  // Note: As usual, matrix operation orders should be read in reverse\n  // since vectors will be multiplied from the right during transformation\n  if (!viewMatrixUncentered) {\n    viewMatrixUncentered = getUncenteredViewMatrix({height, pitch, bearing, altitude});\n  }\n\n  const vm = createMat4();\n\n  if (flipY) {\n    mat4_scale(vm, viewMatrixUncentered, [1, -1, 1]);\n  }\n\n  const viewMatrixCentered = mat4_translate(vm, vm, new Vector3(center).negate());\n\n  return viewMatrixCentered;\n}\n\n// PROJECTION MATRIX: PROJECTS FROM CAMERA (VIEW) SPACE TO CLIPSPACE\n// This is a \"Mapbox\" projection matrix - matches mapbox exactly if farZMultiplier === 1\nexport function getProjectionMatrix({\n  width,\n  height,\n  pitch,\n  altitude,\n  farZMultiplier = 10\n}) {\n  const {nearZ, farZ} = getClippingPlanes({altitude, pitch});\n  const fov = getFov({height, altitude});\n\n  const projectionMatrix = mat4_perspective(\n    [],\n    fov,              // fov in radians\n    width / height,   // aspect ratio\n    nearZ,            // near plane\n    farZ * farZMultiplier // far plane\n  );\n\n  return projectionMatrix;\n}\n"]} |
{ | ||
"name": "viewport-mercator-project", | ||
"version": "4.2.0-alpha.2", | ||
"version": "5.0.0-alpha.1", | ||
"description": "Utilities for perspective-enabled Web Mercator projections", | ||
@@ -38,2 +38,3 @@ "author": "Uber Technologies, Inc.", | ||
"devDependencies": { | ||
"@turf/distance": "^5.0.4", | ||
"babel-cli": "^6.22.2", | ||
@@ -49,3 +50,4 @@ "babel-core": "^6.22.1", | ||
"jsdom": "~9.9.1", | ||
"mapbox-gl": "0.26.0", | ||
"mapbox-gl": "0.41.0", | ||
"mock-browser": "^0.92.14", | ||
"module-alias": "^2.0.0", | ||
@@ -52,0 +54,0 @@ "pre-commit": "^1.2.2", |
@@ -16,24 +16,38 @@ <p align="right"> | ||
<h1 align="center">viewport-mercator-project</h1> | ||
# viewport-mercator-project | [Docs](https://uber-common.github.io/viewport-mercator-project/#/) | ||
Documentation is available in the [**website**](https://uber-common.github.io/viewport-mercator-project/#/) or in the [docs](./docs) folder). | ||
Projection and camera utilities supporting the Web Mercator Projection. At its core this is a utility for converting to and from map coordinates (i.e. latitude, longitude) to screen coordinates and back. | ||
## Installation | ||
<h5 align="center">Utility to convert map or world coordinates to screen coordinates back and forth</h5> | ||
```bash | ||
npm install viewport-mercator-project --save | ||
``` | ||
npm install viewport-mercator-project --save | ||
## Overview | ||
Projection and camera utilities supporting the Web Mercator Projection. At its core this is a utility for converting to and from map coordinates (i.e. latitude, longitude) to screen coordinates and back. | ||
The `WebMercatorViewport` class offers the equivalent of a 3D matrix "camera" class of the type you would find in any 3D/WebGL/OpenGL library. | ||
* `FlatMercatorViewport` - For 2D applications, a simple, fast utility is provided that supports the basic flat Web Mercator projection and unprojection between geo coordinates and pixels. | ||
```js | ||
import WebMercatorViewport from 'viewport-mercator-project'; | ||
* `PerspectiveMercatorViewport` - For 3D applications, a subclass of a generic `Viewport` class (which is essentially a 3D matrix "camera" class of the type you would find in any 3D/WebGL/OpenGL library). | ||
// A viewport looking at San Francisco city area | ||
const viewport = WebMercatorViewport({ | ||
width: 800, | ||
height: 600, | ||
longitude: -122.45, | ||
latitude: 37.78, | ||
zoom: 12, | ||
pitch: 60, | ||
bearing: 30 | ||
}); | ||
The constructor of this "advanced" perspective-enabled viewport also takes the same typical map view parameters as the `FlatMercatorViewport`, however it offers perspective enabled/project unproject functions, and generates general 4x4 view matrices that correspond to the parameters. | ||
viewport.project([-122.45, 37.78]); | ||
// returns pixel coordinates [400, 300] | ||
viewport.unproject([400, 300]); | ||
// returns map coordinates [-122.45, 37.78] | ||
``` | ||
## Who is this for? | ||
### Who is this for? | ||
Specifically built for use with [deck.gl](https://github.com/uber/deck-gl) and [react-map-gl](https://github.com/uber/react-map-gl), but could be useful for any web mapping application that wants to support perspective enabled Web Mercator Projections with floating point zoom levels. |
// Classic web-mercator-project | ||
export {default as default} from './flat-mercator-viewport'; | ||
export {default as FlatMercatorViewport} from './flat-mercator-viewport'; | ||
export {default as PerspectiveMercatorViewport} from './perspective-mercator-viewport'; | ||
export {default as default} from './web-mercator-viewport'; | ||
export {default as WebMercatorViewport} from './web-mercator-viewport'; | ||
// Legacy class name | ||
export {default as PerspectiveMercatorViewport} from './web-mercator-viewport'; | ||
export {projectFlat} from './web-mercator-utils'; | ||
export {unprojectFlat} from './web-mercator-utils'; | ||
export {getMercatorMeterZoom} from './web-mercator-utils'; | ||
export {getMercatorDistanceScales} from './web-mercator-utils'; | ||
export {getMercatorWorldPosition} from './web-mercator-utils'; | ||
export {makeViewMatricesFromMercatorParams} from './web-mercator-utils'; | ||
export {makeUncenteredViewMatrixFromMercatorParams} from './web-mercator-utils'; | ||
export {makeProjectionMatrixFromMercatorParams} from './web-mercator-utils'; | ||
export {getFov} from './web-mercator-utils'; | ||
export {getClippingPlanes} from './web-mercator-utils'; | ||
export {fitBounds} from './web-mercator-viewport'; | ||
export { | ||
projectFlat, | ||
unprojectFlat, | ||
getMeterZoom, | ||
getDistanceScales, | ||
getWorldPosition, | ||
getViewMatrix, | ||
getUncenteredViewMatrix, | ||
getProjectionMatrix | ||
} from './web-mercator-utils'; |
// TODO - THE UTILITIES IN THIS FILE SHOULD BE IMPORTED FROM WEB-MERCATOR-VIEWPORT MODULE | ||
import {Vector3} from 'math.gl'; | ||
import {createMat4} from './math-utils'; | ||
import mat4_perspective from 'gl-mat4/perspective'; | ||
@@ -19,10 +21,5 @@ import mat4_scale from 'gl-mat4/scale'; | ||
const WORLD_SCALE = TILE_SIZE; | ||
const EARTH_CIRCUMFERENCE = 40.075e6; | ||
// const METERS_PER_DEGREE_AT_EQUATOR = 111000; // Approximately 111km per degree at equator | ||
// Helper, avoids low-precision 32 bit matrices from gl-matrix mat4.create() | ||
function createMat4() { | ||
return [1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1]; | ||
} | ||
/** | ||
@@ -65,5 +62,4 @@ * Project [lng,lat] on sphere onto [x,y] on 512*512 Mercator Zoom 0 tile. | ||
// S=C*cos(y)/2^(z+8) | ||
export function getMercatorMeterZoom({latitude}) { | ||
export function getMeterZoom({latitude}) { | ||
assert(latitude); | ||
const EARTH_CIRCUMFERENCE = 40.075e6; | ||
const radians = degrees => degrees / 180 * Math.PI; | ||
@@ -79,3 +75,3 @@ return Math.log2(EARTH_CIRCUMFERENCE * Math.cos(radians(latitude))) - 8; | ||
*/ | ||
export function getMercatorDistanceScales({latitude, longitude, zoom, scale}) { | ||
export function getDistanceScales({latitude, longitude, zoom, scale}) { | ||
// Calculate scale from zoom if not provided | ||
@@ -125,3 +121,3 @@ scale = scale !== undefined ? scale : Math.pow(2, zoom); | ||
*/ | ||
export function getMercatorWorldPosition({ | ||
export function getWorldPosition({ | ||
longitude, | ||
@@ -135,5 +131,2 @@ latitude, | ||
// Calculate distance scales if lng/lat/zoom are provided | ||
distanceScales = distanceScales || getMercatorDistanceScales({latitude, longitude, scale}); | ||
// Make a centered version of the matrix for projection modes without an offset | ||
@@ -144,2 +137,5 @@ const center2d = projectFlat([longitude, latitude], scale); | ||
if (meterOffset) { | ||
// Calculate distance scales if lng/lat/zoom are provided | ||
distanceScales = distanceScales || getDistanceScales({latitude, longitude, scale}); | ||
const pixelPosition = new Vector3(meterOffset) | ||
@@ -163,7 +159,7 @@ // Convert to pixels in current zoom | ||
// Variable fov (in radians) | ||
export function getFov({height, altitude}) { | ||
function getFov({height, altitude}) { | ||
return 2 * Math.atan((height / 2) / altitude); | ||
} | ||
export function getClippingPlanes({altitude, pitch}) { | ||
function getClippingPlanes({altitude, pitch}) { | ||
// Find the distance from the center point to the center top | ||
@@ -183,12 +179,7 @@ // in altitude units using law of sines. | ||
// TODO - rename this matrix | ||
export function makeUncenteredViewMatrixFromMercatorParams({ | ||
width, | ||
export function getUncenteredViewMatrix({ | ||
height, | ||
longitude, | ||
latitude, | ||
zoom, | ||
pitch, | ||
bearing, | ||
altitude, | ||
center | ||
altitude | ||
}) { | ||
@@ -216,3 +207,4 @@ // VIEW MATRIX: PROJECTS MERCATOR WORLD COORDINATES | ||
export function makeViewMatricesFromMercatorParams({ | ||
export function getViewMatrix({ | ||
// Viewport props | ||
width, | ||
@@ -226,6 +218,13 @@ height, | ||
altitude, | ||
centerLngLat, | ||
meterOffset = null | ||
// Pre-calculated parameters | ||
distanceScales = null, | ||
center = null, | ||
viewMatrixUncentered = null, | ||
// Options | ||
meterOffset = null, | ||
flipY = true | ||
}) { | ||
const center = getMercatorWorldPosition({longitude, latitude, zoom, meterOffset}); | ||
if (!center) { | ||
center = getWorldPosition({longitude, latitude, zoom, distanceScales, meterOffset}); | ||
} | ||
@@ -235,22 +234,15 @@ // VIEW MATRIX: PROJECTS FROM VIRTUAL PIXELS TO CAMERA SPACE | ||
// since vectors will be multiplied from the right during transformation | ||
const viewMatrixUncentered = makeUncenteredViewMatrixFromMercatorParams({ | ||
width, | ||
height, | ||
longitude, | ||
latitude, | ||
zoom, | ||
pitch, | ||
bearing, | ||
altitude | ||
}); | ||
if (!viewMatrixUncentered) { | ||
viewMatrixUncentered = getUncenteredViewMatrix({height, pitch, bearing, altitude}); | ||
} | ||
const vm = createMat4(); | ||
mat4_scale(vm, viewMatrixUncentered, [1, -1, 1]); | ||
if (flipY) { | ||
mat4_scale(vm, viewMatrixUncentered, [1, -1, 1]); | ||
} | ||
const viewMatrixCentered = mat4_translate(vm, vm, new Vector3(center).negate()); | ||
return { | ||
viewMatrixCentered, | ||
viewMatrixUncentered, | ||
center | ||
}; | ||
return viewMatrixCentered; | ||
} | ||
@@ -260,3 +252,3 @@ | ||
// This is a "Mapbox" projection matrix - matches mapbox exactly if farZMultiplier === 1 | ||
export function makeProjectionMatrixFromMercatorParams({ | ||
export function getProjectionMatrix({ | ||
width, | ||
@@ -272,3 +264,3 @@ height, | ||
const projectionMatrix = mat4_perspective( | ||
createMat4(), | ||
[], | ||
fov, // fov in radians | ||
@@ -275,0 +267,0 @@ width / height, // aspect ratio |
License Policy Violation
LicenseThis package is not allowed per your license policy. Review the package's license to ensure compliance.
Found 1 instance in 1 package
Major refactor
Supply chain riskPackage has recently undergone a major refactor. It may be unstable or indicate significant internal changes. Use caution when updating to versions that include significant changes.
Found 1 instance in 1 package
License Policy Violation
LicenseThis package is not allowed per your license policy. Review the package's license to ensure compliance.
Found 1 instance in 1 package
53
217146
23
19
2143
1