viewport-mercator-project
Advanced tools
Comparing version 4.1.0 to 4.1.1
@@ -5,2 +5,5 @@ # Change Log | ||
### 4.1.1 | ||
- Replace gl-matrix dependency with cherry-pick imports | ||
### 4.1.0 | ||
@@ -7,0 +10,0 @@ - NEW: `PerspectiveMercatorViewport.fitBounds` method |
@@ -13,9 +13,13 @@ export { _fitBounds as fitBounds }; | ||
// View and Projection Matrix calculations for mapbox-js style | ||
// map view properties | ||
// View and Projection Matrix calculations for mapbox-js style map view properties | ||
import Viewport, { createMat4 } from './viewport'; | ||
import { mat4, vec2 } from 'gl-matrix'; | ||
import autobind from './autobind'; | ||
import assert from 'assert'; | ||
/* eslint-disable camelcase */ | ||
import mat4 from 'gl-mat4'; | ||
import vec2_distance from 'gl-vec2/distance'; | ||
import vec2_add from 'gl-vec2/add'; | ||
import vec2_negate from 'gl-vec2/negate'; | ||
// CONSTANTS | ||
@@ -216,4 +220,4 @@ var PI = Math.PI; | ||
var translate = vec2.sub([], toLocation, fromLocation); | ||
var newCenter = vec2.add([], center, translate); | ||
var translate = vec2_add([], toLocation, vec2_negate([], fromLocation)); | ||
var newCenter = vec2_add([], center, translate); | ||
return this.unprojectFlat(newCenter); | ||
@@ -430,6 +434,6 @@ } | ||
// around current lat/lon | ||
var pixelsPerDegreeX = vec2.distance(projectFlat([longitude + 0.5, latitude], scale), projectFlat([longitude - 0.5, latitude], scale)); | ||
var pixelsPerDegreeX = vec2_distance(projectFlat([longitude + 0.5, latitude], scale), projectFlat([longitude - 0.5, latitude], scale)); | ||
// Calculate number of pixels occupied by one degree latitude | ||
// around current lat/lon | ||
var pixelsPerDegreeY = vec2.distance(projectFlat([longitude, latitude + 0.5], scale), projectFlat([longitude, latitude - 0.5], scale)); | ||
var pixelsPerDegreeY = vec2_distance(projectFlat([longitude, latitude + 0.5], scale), projectFlat([longitude, latitude - 0.5], scale)); | ||
@@ -597,2 +601,2 @@ var pixelsPerMeterX = pixelsPerDegreeX / metersPerDegree; | ||
} | ||
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../src/perspective-mercator-viewport.js"],"names":["Viewport","createMat4","mat4","vec2","autobind","assert","PI","Math","PI_4","DEGREES_TO_RADIANS","RADIANS_TO_DEGREES","TILE_SIZE","WORLD_SCALE","DEFAULT_MAP_STATE","latitude","longitude","zoom","pitch","bearing","altitude","ERR_ARGUMENT","WebMercatorViewport","width","height","farZMultiplier","undefined","scale","pow","max","center","projectFlat","distanceScales","calculateDistanceScales","projectionMatrix","makeProjectionMatrixFromMercatorParams","viewMatrix","makeViewMatrixFromMercatorParams","_distanceScales","Object","freeze","lngLat","xy","unprojectFlat","pos","fromLocation","unproject","toLocation","translate","sub","newCenter","add","xyz","x","y","z","Number","isFinite","pixelsPerMeter","degreesPerPixel","deltaLng","deltaLat","length","deltaLngLatZ","deltaZ","pixelsPerDegree","metersPerPixel","deltaX","deltaY","lngLatZ","lng","lat","Z","metersToLngLatDelta","bounds","options","fitBounds","assign","lambda2","phi2","log","tan","atan","exp","isNaN","METERS_PER_DEGREE","latCosine","cos","metersPerDegree","pixelsPerDegreeX","distance","pixelsPerDegreeY","pixelsPerMeterX","pixelsPerMeterY","pixelsPerMeterZ","worldSize","altPixelsPerMeter","getFov","getClippingPlanes","pitchRadians","halfFov","topHalfSurfaceDistance","sin","farZ","nearZ","fov","perspective","vm","rotateX","rotateZ","padding","offset","west","south","east","north","viewport","nw","project","se","size","abs","scaleX","scaleY","centerLngLat","log2","min"],"mappings":"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","file":"perspective-mercator-viewport.js","sourcesContent":["// View and Projection Matrix calculations for mapbox-js style\n// map view properties\nimport Viewport, {createMat4} from './viewport';\nimport {mat4, vec2} from 'gl-matrix';\nimport autobind from './autobind';\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\nconst DEFAULT_MAP_STATE = {\n  latitude: 37,\n  longitude: -122,\n  zoom: 11,\n  pitch: 0,\n  bearing: 0,\n  altitude: 1.5\n};\n\nconst ERR_ARGUMENT = 'Illegal argument to WebMercatorViewport';\n\nexport default class WebMercatorViewport extends Viewport {\n  /**\n   * @classdesc\n   * Creates view/projection matrices from mercator params\n   * Note: The Viewport is immutable in the sense that it only has accessors.\n   * A new viewport instance should be created if any parameters have changed.\n   *\n   * @class\n   * @param {Object} opt - options\n   * @param {Boolean} mercator=true - Whether to use mercator projection\n   *\n   * @param {Number} opt.width=1 - Width of \"viewport\" or window\n   * @param {Number} opt.height=1 - Height of \"viewport\" or window\n   * @param {Array} opt.center=[0, 0] - Center of viewport\n   *   [longitude, latitude] or [x, y]\n   * @param {Number} opt.scale=1 - Either use scale or zoom\n   * @param {Number} opt.pitch=0 - Camera angle in degrees (0 is straight down)\n   * @param {Number} opt.bearing=0 - Map rotation in degrees (0 means north is up)\n   * @param {Number} opt.altitude= - Altitude of camera in screen units\n   *\n   * Web mercator projection short-hand parameters\n   * @param {Number} opt.latitude - Center of viewport on map (alternative to opt.center)\n   * @param {Number} opt.longitude - Center of viewport on map (alternative to opt.center)\n   * @param {Number} opt.zoom - Scale = Math.pow(2,zoom) on map (alternative to opt.scale)\n\n   * Notes:\n   *  - Only one of center or [latitude, longitude] can be specified\n   *  - [latitude, longitude] can only be specified when \"mercator\" is true\n   *  - Altitude has a default value that matches assumptions in mapbox-gl\n   *  - width and height are forced to 1 if supplied as 0, to avoid\n   *    division by zero. This is intended to reduce the burden of apps to\n   *    to check values before instantiating a Viewport.\n   */\n  /* eslint-disable complexity */\n  constructor({\n    // Map state\n    width,\n    height,\n    latitude,\n    longitude,\n    zoom,\n    pitch,\n    bearing,\n    altitude,\n    farZMultiplier = 10\n  } = {}) {\n    // Viewport - support undefined arguments\n    width = width !== undefined ? width : DEFAULT_MAP_STATE.width;\n    height = height !== undefined ? height : DEFAULT_MAP_STATE.height;\n    zoom = zoom !== undefined ? zoom : DEFAULT_MAP_STATE.zoom;\n    latitude = latitude !== undefined ? latitude : DEFAULT_MAP_STATE.latitude;\n    longitude = longitude !== undefined ? longitude : DEFAULT_MAP_STATE.longitude;\n    bearing = bearing !== undefined ? bearing : DEFAULT_MAP_STATE.bearing;\n    pitch = pitch !== undefined ? pitch : DEFAULT_MAP_STATE.pitch;\n    altitude = altitude !== undefined ? altitude : DEFAULT_MAP_STATE.altitude;\n\n    // Silently allow apps to send in 0,0 to facilitate isomorphic render etc\n    width = width || 1;\n    height = height || 1;\n\n    const scale = Math.pow(2, zoom);\n    // Altitude - prevent division by 0\n    // TODO - just throw an Error instead?\n    altitude = Math.max(0.75, altitude);\n\n    const center = projectFlat([longitude, latitude], scale);\n\n    const distanceScales = calculateDistanceScales({latitude, longitude, scale});\n\n    const projectionMatrix = makeProjectionMatrixFromMercatorParams({\n      width,\n      height,\n      pitch,\n      bearing,\n      altitude,\n      farZMultiplier\n    });\n\n    const viewMatrix = makeViewMatrixFromMercatorParams({\n      width,\n      height,\n      longitude,\n      latitude,\n      zoom,\n      pitch,\n      bearing,\n      altitude,\n      distanceScales,\n      center\n    });\n\n    super({width, height, viewMatrix, projectionMatrix});\n\n    // Save parameters\n    this.latitude = latitude;\n    this.longitude = longitude;\n    this.zoom = zoom;\n    this.pitch = pitch;\n    this.bearing = bearing;\n    this.altitude = altitude;\n\n    this.scale = scale;\n    this.center = center;\n\n    this._distanceScales = distanceScales;\n\n    autobind(this);\n    Object.freeze(this);\n  }\n  /* eslint-enable complexity */\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   */\n  _projectFlat(lngLat, scale = this.scale) {\n    return projectFlat(lngLat, scale);\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   */\n  _unprojectFlat(xy, scale = this.scale) {\n    return unprojectFlat(xy, scale);\n  }\n\n  /**\n   * Get the map center that place a given [lng, lat] coordinate at screen\n   * point [x, y]\n   *\n   * @param {Array} lngLat - [lng,lat] coordinates\n   *   Specifies a point on the sphere.\n   * @param {Array} pos - [x,y] coordinates\n   *   Specifies a point on the screen.\n   * @return {Array} [lng,lat] new map center.\n   */\n  getLocationAtPoint({lngLat, pos}) {\n    const fromLocation = this.projectFlat(this.unproject(pos));\n    const toLocation = this.projectFlat(lngLat);\n\n    const center = this.projectFlat([this.longitude, this.latitude]);\n\n    const translate = vec2.sub([], toLocation, fromLocation);\n    const newCenter = vec2.add([], center, translate);\n    return this.unprojectFlat(newCenter);\n  }\n\n  /*\n  getLngLatAtViewportPosition(lnglat, xy) {\n    const c = this.locationCoordinate(lnglat);\n    const coordAtPoint = this.pointCoordinate(xy);\n    const coordCenter = this.pointCoordinate(this.centerPoint);\n    const translate = coordAtPoint._sub(c);\n    this.center = this.coordinateLocation(coordCenter._sub(translate));\n  }\n  */\n\n  getDistanceScales() {\n    return this._distanceScales;\n  }\n\n  /**\n   * Converts a meter offset to a lnglat offset\n   *\n   * Note: Uses simple linear approximation around the viewport center\n   * Error increases with size of offset (roughly 1% per 100km)\n   *\n   * @param {[Number,Number]|[Number,Number,Number]) xyz - array of meter deltas\n   * @return {[Number,Number]|[Number,Number,Number]) - array of [lng,lat,z] deltas\n   */\n  metersToLngLatDelta(xyz) {\n    const [x, y, z = 0] = xyz;\n    assert(Number.isFinite(x) && Number.isFinite(y) && Number.isFinite(z), ERR_ARGUMENT);\n    const {pixelsPerMeter, degreesPerPixel} = this._distanceScales;\n    const deltaLng = x * pixelsPerMeter[0] * degreesPerPixel[0];\n    const deltaLat = y * pixelsPerMeter[1] * degreesPerPixel[1];\n    return xyz.length === 2 ? [deltaLng, deltaLat] : [deltaLng, deltaLat, z];\n  }\n\n  /**\n   * Converts a lnglat offset to a meter offset\n   *\n   * Note: Uses simple linear approximation around the viewport center\n   * Error increases with size of offset (roughly 1% per 100km)\n   *\n   * @param {[Number,Number]|[Number,Number,Number]) deltaLngLatZ - array of [lng,lat,z] deltas\n   * @return {[Number,Number]|[Number,Number,Number]) - array of meter deltas\n   */\n  lngLatDeltaToMeters(deltaLngLatZ) {\n    const [deltaLng, deltaLat, deltaZ = 0] = deltaLngLatZ;\n    assert(Number.isFinite(deltaLng) && Number.isFinite(deltaLat) && Number.isFinite(deltaZ),\n      ERR_ARGUMENT);\n    const {pixelsPerDegree, metersPerPixel} = this._distanceScales;\n    const deltaX = deltaLng * pixelsPerDegree[0] * metersPerPixel[0];\n    const deltaY = deltaLat * pixelsPerDegree[1] * metersPerPixel[1];\n    return deltaLngLatZ.length === 2 ? [deltaX, deltaY] : [deltaX, deltaY, deltaZ];\n  }\n\n  /**\n   * Add a meter delta to a base lnglat coordinate, returning a new lnglat array\n   *\n   * Note: Uses simple linear approximation around the viewport center\n   * Error increases with size of offset (roughly 1% per 100km)\n   *\n   * @param {[Number,Number]|[Number,Number,Number]) lngLatZ - base coordinate\n   * @param {[Number,Number]|[Number,Number,Number]) xyz - array of meter deltas\n   * @return {[Number,Number]|[Number,Number,Number]) array of [lng,lat,z] deltas\n   */\n  addMetersToLngLat(lngLatZ, xyz) {\n    const [lng, lat, Z = 0] = lngLatZ;\n    const [deltaLng, deltaLat, deltaZ = 0] = this.metersToLngLatDelta(xyz);\n    return lngLatZ.length === 2 ?\n      [lng + deltaLng, lat + deltaLat] :\n      [lng + deltaLng, lat + deltaLat, Z + deltaZ];\n  }\n\n  /**\n   * Returns a new viewport that fit around the given rectangle.\n   * Only supports non-perspective mode.\n   * @param {Array} bounds - [[lon, lat], [lon, lat]]\n   * @param {Number} [options.padding] - The amount of padding in pixels to add to the given bounds.\n   * @param {Array} [options.offset] - The center of the given bounds relative to the map's center,\n   *    [x, y] measured in pixels.\n   * @returns {WebMercatorViewport}\n   */\n  fitBounds(bounds, options = {}) {\n    const {width, height} = this;\n    const {longitude, latitude, zoom} = fitBounds(Object.assign({width, height, bounds}, options));\n    return new WebMercatorViewport({width, height, longitude, latitude, zoom});\n  }\n\n  // INTERNAL METHODS\n\n  _getParams() {\n    return this._distanceScales;\n  }\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 */\nfunction 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 */\nfunction 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/**\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 */\nfunction calculateDistanceScales({latitude, longitude, scale}) {\n  assert(!isNaN(latitude) && !isNaN(longitude) && !isNaN(scale), ERR_ARGUMENT);\n  // Approximately 111km per degree at equator\n  const METERS_PER_DEGREE = 111000;\n\n  const latCosine = Math.cos(latitude * Math.PI / 180);\n\n  const metersPerDegree = METERS_PER_DEGREE * latCosine;\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 pixelsPerMeterX = pixelsPerDegreeX / metersPerDegree;\n  const pixelsPerMeterY = pixelsPerDegreeY / metersPerDegree;\n  const pixelsPerMeterZ = (pixelsPerMeterX + pixelsPerMeterY) / 2;\n  // const pixelsPerMeter = [pixelsPerMeterX, pixelsPerMeterY, pixelsPerMeterZ];\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 / pixelsPerMeterZ];\n\n  const pixelsPerDegree = [pixelsPerDegreeX, pixelsPerDegreeY, pixelsPerMeterZ];\n  const degreesPerPixel = [1 / pixelsPerDegreeX, 1 / pixelsPerDegreeY, 1 / pixelsPerMeterZ];\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// 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// PROJECTION MATRIX: PROJECTS FROM CAMERA (VIEW) SPACE TO CLIPSPACE\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\nfunction makeViewMatrixFromMercatorParams({\n  width,\n  height,\n  longitude,\n  latitude,\n  zoom,\n  pitch,\n  bearing,\n  altitude,\n  center\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 vm = createMat4();\n\n  // Move camera to altitude\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  // console.log(`VIEWPT Z ${pitch * DEGREES_TO_RADIANS} ${-bearing * DEGREES_TO_RADIANS} ${vm}`);\n  mat4.translate(vm, vm, [-center[0], -center[1], 0]);\n  // console.log(`VIEWPT T ${pitch * DEGREES_TO_RADIANS} ${-bearing * DEGREES_TO_RADIANS} ${vm}`);\n  return vm;\n}\n\n/**\n * Returns map settings {latitude, longitude, zoom}\n * that will contain the provided corners within the provided width.\n * Only supports non-perspective mode.\n * @param {Number} width - viewport width\n * @param {Number} height - viewport height\n * @param {Array} bounds - [[lon, lat], [lon, lat]]\n * @param {Number} [padding] - The amount of padding in pixels to add to the given bounds.\n * @param {Array} [offset] - The center of the given bounds relative to the map's center,\n *    [x, y] measured in pixels.\n * @returns {Object} - latitude, longitude and zoom\n */\nexport function fitBounds({\n  width,\n  height,\n  bounds,\n  // options\n  padding = 0,\n  offset = [0, 0]\n}) {\n  const [[west, south], [east, north]] = bounds;\n\n  const viewport = new WebMercatorViewport({\n    width,\n    height,\n    longitude: 0,\n    latitude: 0,\n    zoom: 0\n  });\n\n  const nw = viewport.project([west, north]);\n  const se = viewport.project([east, south]);\n  const size = [\n    Math.abs(se[0] - nw[0]),\n    Math.abs(se[1] - nw[1])\n  ];\n  const center = [\n    (se[0] + nw[0]) / 2,\n    (se[1] + nw[1]) / 2\n  ];\n\n  const scaleX = (width - padding * 2 - Math.abs(offset[0]) * 2) / size[0];\n  const scaleY = (height - padding * 2 - Math.abs(offset[1]) * 2) / size[1];\n\n  const centerLngLat = viewport.unproject(center);\n  const zoom = viewport.zoom + Math.log2(Math.abs(Math.min(scaleX, scaleY)));\n\n  return {\n    longitude: centerLngLat[0],\n    latitude: centerLngLat[1],\n    zoom\n  };\n}\n"]} | ||
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../src/perspective-mercator-viewport.js"],"names":["Viewport","createMat4","autobind","assert","mat4","vec2_distance","vec2_add","vec2_negate","PI","Math","PI_4","DEGREES_TO_RADIANS","RADIANS_TO_DEGREES","TILE_SIZE","WORLD_SCALE","DEFAULT_MAP_STATE","latitude","longitude","zoom","pitch","bearing","altitude","ERR_ARGUMENT","WebMercatorViewport","width","height","farZMultiplier","undefined","scale","pow","max","center","projectFlat","distanceScales","calculateDistanceScales","projectionMatrix","makeProjectionMatrixFromMercatorParams","viewMatrix","makeViewMatrixFromMercatorParams","_distanceScales","Object","freeze","lngLat","xy","unprojectFlat","pos","fromLocation","unproject","toLocation","translate","newCenter","xyz","x","y","z","Number","isFinite","pixelsPerMeter","degreesPerPixel","deltaLng","deltaLat","length","deltaLngLatZ","deltaZ","pixelsPerDegree","metersPerPixel","deltaX","deltaY","lngLatZ","lng","lat","Z","metersToLngLatDelta","bounds","options","fitBounds","assign","lambda2","phi2","log","tan","atan","exp","isNaN","METERS_PER_DEGREE","latCosine","cos","metersPerDegree","pixelsPerDegreeX","pixelsPerDegreeY","pixelsPerMeterX","pixelsPerMeterY","pixelsPerMeterZ","worldSize","altPixelsPerMeter","getFov","getClippingPlanes","pitchRadians","halfFov","topHalfSurfaceDistance","sin","farZ","nearZ","fov","perspective","vm","rotateX","rotateZ","padding","offset","west","south","east","north","viewport","nw","project","se","size","abs","scaleX","scaleY","centerLngLat","log2","min"],"mappings":"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","file":"perspective-mercator-viewport.js","sourcesContent":["// View and Projection Matrix calculations for mapbox-js style map view properties\nimport Viewport, {createMat4} from './viewport';\nimport autobind from './autobind';\nimport assert from 'assert';\n\n/* eslint-disable camelcase */\nimport mat4 from 'gl-mat4';\nimport vec2_distance from 'gl-vec2/distance';\nimport vec2_add from 'gl-vec2/add';\nimport vec2_negate from 'gl-vec2/negate';\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\nconst DEFAULT_MAP_STATE = {\n  latitude: 37,\n  longitude: -122,\n  zoom: 11,\n  pitch: 0,\n  bearing: 0,\n  altitude: 1.5\n};\n\nconst ERR_ARGUMENT = 'Illegal argument to WebMercatorViewport';\n\nexport default class WebMercatorViewport extends Viewport {\n  /**\n   * @classdesc\n   * Creates view/projection matrices from mercator params\n   * Note: The Viewport is immutable in the sense that it only has accessors.\n   * A new viewport instance should be created if any parameters have changed.\n   *\n   * @class\n   * @param {Object} opt - options\n   * @param {Boolean} mercator=true - Whether to use mercator projection\n   *\n   * @param {Number} opt.width=1 - Width of \"viewport\" or window\n   * @param {Number} opt.height=1 - Height of \"viewport\" or window\n   * @param {Array} opt.center=[0, 0] - Center of viewport\n   *   [longitude, latitude] or [x, y]\n   * @param {Number} opt.scale=1 - Either use scale or zoom\n   * @param {Number} opt.pitch=0 - Camera angle in degrees (0 is straight down)\n   * @param {Number} opt.bearing=0 - Map rotation in degrees (0 means north is up)\n   * @param {Number} opt.altitude= - Altitude of camera in screen units\n   *\n   * Web mercator projection short-hand parameters\n   * @param {Number} opt.latitude - Center of viewport on map (alternative to opt.center)\n   * @param {Number} opt.longitude - Center of viewport on map (alternative to opt.center)\n   * @param {Number} opt.zoom - Scale = Math.pow(2,zoom) on map (alternative to opt.scale)\n\n   * Notes:\n   *  - Only one of center or [latitude, longitude] can be specified\n   *  - [latitude, longitude] can only be specified when \"mercator\" is true\n   *  - Altitude has a default value that matches assumptions in mapbox-gl\n   *  - width and height are forced to 1 if supplied as 0, to avoid\n   *    division by zero. This is intended to reduce the burden of apps to\n   *    to check values before instantiating a Viewport.\n   */\n  /* eslint-disable complexity */\n  constructor({\n    // Map state\n    width,\n    height,\n    latitude,\n    longitude,\n    zoom,\n    pitch,\n    bearing,\n    altitude,\n    farZMultiplier = 10\n  } = {}) {\n    // Viewport - support undefined arguments\n    width = width !== undefined ? width : DEFAULT_MAP_STATE.width;\n    height = height !== undefined ? height : DEFAULT_MAP_STATE.height;\n    zoom = zoom !== undefined ? zoom : DEFAULT_MAP_STATE.zoom;\n    latitude = latitude !== undefined ? latitude : DEFAULT_MAP_STATE.latitude;\n    longitude = longitude !== undefined ? longitude : DEFAULT_MAP_STATE.longitude;\n    bearing = bearing !== undefined ? bearing : DEFAULT_MAP_STATE.bearing;\n    pitch = pitch !== undefined ? pitch : DEFAULT_MAP_STATE.pitch;\n    altitude = altitude !== undefined ? altitude : DEFAULT_MAP_STATE.altitude;\n\n    // Silently allow apps to send in 0,0 to facilitate isomorphic render etc\n    width = width || 1;\n    height = height || 1;\n\n    const scale = Math.pow(2, zoom);\n    // Altitude - prevent division by 0\n    // TODO - just throw an Error instead?\n    altitude = Math.max(0.75, altitude);\n\n    const center = projectFlat([longitude, latitude], scale);\n\n    const distanceScales = calculateDistanceScales({latitude, longitude, scale});\n\n    const projectionMatrix = makeProjectionMatrixFromMercatorParams({\n      width,\n      height,\n      pitch,\n      bearing,\n      altitude,\n      farZMultiplier\n    });\n\n    const viewMatrix = makeViewMatrixFromMercatorParams({\n      width,\n      height,\n      longitude,\n      latitude,\n      zoom,\n      pitch,\n      bearing,\n      altitude,\n      distanceScales,\n      center\n    });\n\n    super({width, height, viewMatrix, projectionMatrix});\n\n    // Save parameters\n    this.latitude = latitude;\n    this.longitude = longitude;\n    this.zoom = zoom;\n    this.pitch = pitch;\n    this.bearing = bearing;\n    this.altitude = altitude;\n\n    this.scale = scale;\n    this.center = center;\n\n    this._distanceScales = distanceScales;\n\n    autobind(this);\n    Object.freeze(this);\n  }\n  /* eslint-enable complexity */\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   */\n  _projectFlat(lngLat, scale = this.scale) {\n    return projectFlat(lngLat, scale);\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   */\n  _unprojectFlat(xy, scale = this.scale) {\n    return unprojectFlat(xy, scale);\n  }\n\n  /**\n   * Get the map center that place a given [lng, lat] coordinate at screen\n   * point [x, y]\n   *\n   * @param {Array} lngLat - [lng,lat] coordinates\n   *   Specifies a point on the sphere.\n   * @param {Array} pos - [x,y] coordinates\n   *   Specifies a point on the screen.\n   * @return {Array} [lng,lat] new map center.\n   */\n  getLocationAtPoint({lngLat, pos}) {\n    const fromLocation = this.projectFlat(this.unproject(pos));\n    const toLocation = this.projectFlat(lngLat);\n\n    const center = this.projectFlat([this.longitude, this.latitude]);\n\n    const translate = vec2_add([], toLocation, vec2_negate([], fromLocation));\n    const newCenter = vec2_add([], center, translate);\n    return this.unprojectFlat(newCenter);\n  }\n\n  /*\n  getLngLatAtViewportPosition(lnglat, xy) {\n    const c = this.locationCoordinate(lnglat);\n    const coordAtPoint = this.pointCoordinate(xy);\n    const coordCenter = this.pointCoordinate(this.centerPoint);\n    const translate = coordAtPoint._sub(c);\n    this.center = this.coordinateLocation(coordCenter._sub(translate));\n  }\n  */\n\n  getDistanceScales() {\n    return this._distanceScales;\n  }\n\n  /**\n   * Converts a meter offset to a lnglat offset\n   *\n   * Note: Uses simple linear approximation around the viewport center\n   * Error increases with size of offset (roughly 1% per 100km)\n   *\n   * @param {[Number,Number]|[Number,Number,Number]) xyz - array of meter deltas\n   * @return {[Number,Number]|[Number,Number,Number]) - array of [lng,lat,z] deltas\n   */\n  metersToLngLatDelta(xyz) {\n    const [x, y, z = 0] = xyz;\n    assert(Number.isFinite(x) && Number.isFinite(y) && Number.isFinite(z), ERR_ARGUMENT);\n    const {pixelsPerMeter, degreesPerPixel} = this._distanceScales;\n    const deltaLng = x * pixelsPerMeter[0] * degreesPerPixel[0];\n    const deltaLat = y * pixelsPerMeter[1] * degreesPerPixel[1];\n    return xyz.length === 2 ? [deltaLng, deltaLat] : [deltaLng, deltaLat, z];\n  }\n\n  /**\n   * Converts a lnglat offset to a meter offset\n   *\n   * Note: Uses simple linear approximation around the viewport center\n   * Error increases with size of offset (roughly 1% per 100km)\n   *\n   * @param {[Number,Number]|[Number,Number,Number]) deltaLngLatZ - array of [lng,lat,z] deltas\n   * @return {[Number,Number]|[Number,Number,Number]) - array of meter deltas\n   */\n  lngLatDeltaToMeters(deltaLngLatZ) {\n    const [deltaLng, deltaLat, deltaZ = 0] = deltaLngLatZ;\n    assert(Number.isFinite(deltaLng) && Number.isFinite(deltaLat) && Number.isFinite(deltaZ),\n      ERR_ARGUMENT);\n    const {pixelsPerDegree, metersPerPixel} = this._distanceScales;\n    const deltaX = deltaLng * pixelsPerDegree[0] * metersPerPixel[0];\n    const deltaY = deltaLat * pixelsPerDegree[1] * metersPerPixel[1];\n    return deltaLngLatZ.length === 2 ? [deltaX, deltaY] : [deltaX, deltaY, deltaZ];\n  }\n\n  /**\n   * Add a meter delta to a base lnglat coordinate, returning a new lnglat array\n   *\n   * Note: Uses simple linear approximation around the viewport center\n   * Error increases with size of offset (roughly 1% per 100km)\n   *\n   * @param {[Number,Number]|[Number,Number,Number]) lngLatZ - base coordinate\n   * @param {[Number,Number]|[Number,Number,Number]) xyz - array of meter deltas\n   * @return {[Number,Number]|[Number,Number,Number]) array of [lng,lat,z] deltas\n   */\n  addMetersToLngLat(lngLatZ, xyz) {\n    const [lng, lat, Z = 0] = lngLatZ;\n    const [deltaLng, deltaLat, deltaZ = 0] = this.metersToLngLatDelta(xyz);\n    return lngLatZ.length === 2 ?\n      [lng + deltaLng, lat + deltaLat] :\n      [lng + deltaLng, lat + deltaLat, Z + deltaZ];\n  }\n\n  /**\n   * Returns a new viewport that fit around the given rectangle.\n   * Only supports non-perspective mode.\n   * @param {Array} bounds - [[lon, lat], [lon, lat]]\n   * @param {Number} [options.padding] - The amount of padding in pixels to add to the given bounds.\n   * @param {Array} [options.offset] - The center of the given bounds relative to the map's center,\n   *    [x, y] measured in pixels.\n   * @returns {WebMercatorViewport}\n   */\n  fitBounds(bounds, options = {}) {\n    const {width, height} = this;\n    const {longitude, latitude, zoom} = fitBounds(Object.assign({width, height, bounds}, options));\n    return new WebMercatorViewport({width, height, longitude, latitude, zoom});\n  }\n\n  // INTERNAL METHODS\n\n  _getParams() {\n    return this._distanceScales;\n  }\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 */\nfunction 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 */\nfunction 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/**\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 */\nfunction calculateDistanceScales({latitude, longitude, scale}) {\n  assert(!isNaN(latitude) && !isNaN(longitude) && !isNaN(scale), ERR_ARGUMENT);\n  // Approximately 111km per degree at equator\n  const METERS_PER_DEGREE = 111000;\n\n  const latCosine = Math.cos(latitude * Math.PI / 180);\n\n  const metersPerDegree = METERS_PER_DEGREE * latCosine;\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 pixelsPerMeterX = pixelsPerDegreeX / metersPerDegree;\n  const pixelsPerMeterY = pixelsPerDegreeY / metersPerDegree;\n  const pixelsPerMeterZ = (pixelsPerMeterX + pixelsPerMeterY) / 2;\n  // const pixelsPerMeter = [pixelsPerMeterX, pixelsPerMeterY, pixelsPerMeterZ];\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 / pixelsPerMeterZ];\n\n  const pixelsPerDegree = [pixelsPerDegreeX, pixelsPerDegreeY, pixelsPerMeterZ];\n  const degreesPerPixel = [1 / pixelsPerDegreeX, 1 / pixelsPerDegreeY, 1 / pixelsPerMeterZ];\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// 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// PROJECTION MATRIX: PROJECTS FROM CAMERA (VIEW) SPACE TO CLIPSPACE\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\nfunction makeViewMatrixFromMercatorParams({\n  width,\n  height,\n  longitude,\n  latitude,\n  zoom,\n  pitch,\n  bearing,\n  altitude,\n  center\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 vm = createMat4();\n\n  // Move camera to altitude\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  // console.log(`VIEWPT Z ${pitch * DEGREES_TO_RADIANS} ${-bearing * DEGREES_TO_RADIANS} ${vm}`);\n  mat4.translate(vm, vm, [-center[0], -center[1], 0]);\n  // console.log(`VIEWPT T ${pitch * DEGREES_TO_RADIANS} ${-bearing * DEGREES_TO_RADIANS} ${vm}`);\n  return vm;\n}\n\n/**\n * Returns map settings {latitude, longitude, zoom}\n * that will contain the provided corners within the provided width.\n * Only supports non-perspective mode.\n * @param {Number} width - viewport width\n * @param {Number} height - viewport height\n * @param {Array} bounds - [[lon, lat], [lon, lat]]\n * @param {Number} [padding] - The amount of padding in pixels to add to the given bounds.\n * @param {Array} [offset] - The center of the given bounds relative to the map's center,\n *    [x, y] measured in pixels.\n * @returns {Object} - latitude, longitude and zoom\n */\nexport function fitBounds({\n  width,\n  height,\n  bounds,\n  // options\n  padding = 0,\n  offset = [0, 0]\n}) {\n  const [[west, south], [east, north]] = bounds;\n\n  const viewport = new WebMercatorViewport({\n    width,\n    height,\n    longitude: 0,\n    latitude: 0,\n    zoom: 0\n  });\n\n  const nw = viewport.project([west, north]);\n  const se = viewport.project([east, south]);\n  const size = [\n    Math.abs(se[0] - nw[0]),\n    Math.abs(se[1] - nw[1])\n  ];\n  const center = [\n    (se[0] + nw[0]) / 2,\n    (se[1] + nw[1]) / 2\n  ];\n\n  const scaleX = (width - padding * 2 - Math.abs(offset[0]) * 2) / size[0];\n  const scaleY = (height - padding * 2 - Math.abs(offset[1]) * 2) / size[1];\n\n  const centerLngLat = viewport.unproject(center);\n  const zoom = viewport.zoom + Math.log2(Math.abs(Math.min(scaleX, scaleY)));\n\n  return {\n    longitude: centerLngLat[0],\n    latitude: centerLngLat[1],\n    zoom\n  };\n}\n"]} |
@@ -9,6 +9,12 @@ 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"); } }; }(); | ||
// gl-matrix is a large dependency for a small module. | ||
// However since it is used by mapbox etc, it should already be present | ||
// in most target application bundles. | ||
import { mat4, vec4, vec2 } from 'gl-matrix'; | ||
/* eslint-disable camelcase */ | ||
import mat4_scale from 'gl-mat4/scale'; | ||
import mat4_translate from 'gl-mat4/translate'; | ||
import mat4_multiply from 'gl-mat4/multiply'; | ||
import mat4_invert from 'gl-mat4/invert'; | ||
import vec4_multiply from 'gl-vec4/multiply'; | ||
import vec4_transformMat4 from 'gl-vec4/transformMat4'; | ||
import vec2_lerp from 'gl-vec2/lerp'; | ||
import _equals from './equals'; | ||
import autobind from './autobind'; | ||
@@ -72,4 +78,4 @@ import assert from 'assert'; | ||
var vpm = createMat4(); | ||
mat4.multiply(vpm, vpm, this.projectionMatrix); | ||
mat4.multiply(vpm, vpm, this.viewMatrix); | ||
mat4_multiply(vpm, vpm, this.projectionMatrix); | ||
mat4_multiply(vpm, vpm, this.viewMatrix); | ||
this.viewProjectionMatrix = vpm; | ||
@@ -90,19 +96,8 @@ | ||
// matrix for conversion from location to screen coordinates | ||
mat4.scale(m, m, [this.width / 2, -this.height / 2, 1]); | ||
mat4.translate(m, m, [1, -1, 0]); | ||
mat4_scale(m, m, [this.width / 2, -this.height / 2, 1]); | ||
mat4_translate(m, m, [1, -1, 0]); | ||
// Scale with viewport window's width and height in pixels | ||
// mat4.scale(m, m, [this.width, this.height, 1]); | ||
// Convert to (0, 1) | ||
// mat4.translate(m, m, [0.5, 0.5, 0]); | ||
// mat4.scale(m, m, [0.5, 0.5, 1]); | ||
// Project to clip space (-1, 1) | ||
mat4.multiply(m, m, this.viewProjectionMatrix); | ||
mat4_multiply(m, m, this.viewProjectionMatrix); | ||
// console.log(`vec ${[this.width / 2, this.height / 2, 1]}`); | ||
// console.log(`View ${this.viewMatrix}`); | ||
// console.log(`VPM ${vpm}`); | ||
// console.log(`Pixel ${m}`); | ||
var mInverse = mat4.invert(createMat4(), m); | ||
var mInverse = mat4_invert(createMat4(), m); | ||
if (!mInverse) { | ||
@@ -130,3 +125,3 @@ throw new Error('Pixel project matrix not invertible'); | ||
return viewport.width === this.width && viewport.height === this.height && mat4.equals(viewport.projectionMatrix, this.projectionMatrix) && mat4.equals(viewport.viewMatrix, this.viewMatrix); | ||
return viewport.width === this.width && viewport.height === this.height && _equals(viewport.projectionMatrix, this.projectionMatrix) && _equals(viewport.viewMatrix, this.viewMatrix); | ||
} | ||
@@ -210,6 +205,4 @@ | ||
var t = z0 === z1 ? 0 : (targetZ - z0) / (z1 - z0); | ||
var v = vec2.lerp([], coord0, coord1, t); | ||
var v = vec2_lerp([], coord0, coord1, t); | ||
// console.error(`unprojecting to non-linear ${v}<=${[x, y2, targetZ]}`); | ||
var vUnprojected = this.unprojectFlat(v); | ||
@@ -224,5 +217,5 @@ return xyz.length === 2 ? vUnprojected : [vUnprojected[0], vUnprojected[1], 0]; | ||
value: function transformVector(matrix, vector) { | ||
var result = vec4.transformMat4([0, 0, 0, 0], vector, matrix); | ||
var result = vec4_transformMat4([0, 0, 0, 0], vector, matrix); | ||
var scale = 1 / result[3]; | ||
vec4.multiply(result, result, [scale, scale, scale, scale]); | ||
vec4_multiply(result, result, [scale, scale, scale, scale]); | ||
return result; | ||
@@ -284,5 +277,5 @@ } | ||
if (modelMatrix) { | ||
modelViewProjectionMatrix = mat4.multiply([], this.viewProjectionMatrix, modelMatrix); | ||
pixelProjectionMatrix = mat4.multiply([], this.pixelProjectionMatrix, modelMatrix); | ||
pixelUnprojectionMatrix = mat4.invert([], pixelProjectionMatrix); | ||
modelViewProjectionMatrix = mat4_multiply([], this.viewProjectionMatrix, modelMatrix); | ||
pixelProjectionMatrix = mat4_multiply([], this.pixelProjectionMatrix, modelMatrix); | ||
pixelUnprojectionMatrix = mat4_invert([], pixelProjectionMatrix); | ||
} | ||
@@ -326,3 +319,3 @@ | ||
// Helper, avoids low-precision 32 bit matrices from gl-matrix mat4.create() | ||
// Helper, avoids low-precision 32 bit matrices from mat4.create() | ||
@@ -334,2 +327,2 @@ | ||
} | ||
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../src/viewport.js"],"names":["mat4","vec4","vec2","autobind","assert","IDENTITY","createMat4","ERR_ARGUMENT","Viewport","width","height","viewMatrix","projectionMatrix","scale","vpm","multiply","viewProjectionMatrix","m","translate","mInverse","invert","Error","pixelProjectionMatrix","pixelUnprojectionMatrix","viewport","equals","xyz","topLeft","x0","y0","z0","Number","isFinite","projectFlat","X","Y","v","transformVector","x","y","y2","length","targetZ","coord0","coord1","z1","t","lerp","vUnprojected","unprojectFlat","matrix","vector","result","transformMat4","_projectFlat","arguments","_unprojectFlat","modelMatrix","modelViewProjectionMatrix","matrices","Object","assign","_getParams"],"mappings":"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","file":"viewport.js","sourcesContent":["// View and Projection Matrix management\n\n// gl-matrix is a large dependency for a small module.\n// However since it is used by mapbox etc, it should already be present\n// in most target application bundles.\nimport {mat4, vec4, vec2} from 'gl-matrix';\nimport autobind from './autobind';\nimport assert from 'assert';\n\nconst IDENTITY = createMat4();\n\nconst ERR_ARGUMENT = 'Illegal argument to Viewport';\n\nexport default class Viewport {\n  /**\n   * @classdesc\n   * Manages coordinate system transformations for deck.gl.\n   *\n   * Note: The Viewport is immutable in the sense that it only has accessors.\n   * A new viewport instance should be created if any parameters have changed.\n   *\n   * @class\n   * @param {Object} opt - options\n   * @param {Boolean} mercator=true - Whether to use mercator projection\n   *\n   * @param {Number} opt.width=1 - Width of \"viewport\" or window\n   * @param {Number} opt.height=1 - Height of \"viewport\" or window\n   * @param {Array} opt.center=[0, 0] - Center of viewport\n   *   [longitude, latitude] or [x, y]\n   * @param {Number} opt.scale=1 - Either use scale or zoom\n   * @param {Number} opt.pitch=0 - Camera angle in degrees (0 is straight down)\n   * @param {Number} opt.bearing=0 - Map rotation in degrees (0 means north is up)\n   * @param {Number} opt.altitude= - Altitude of camera in screen units\n   *\n   * Web mercator projection short-hand parameters\n   * @param {Number} opt.latitude - Center of viewport on map (alternative to opt.center)\n   * @param {Number} opt.longitude - Center of viewport on map (alternative to opt.center)\n   * @param {Number} opt.zoom - Scale = Math.pow(2,zoom) on map (alternative to opt.scale)\n   */\n  /* eslint-disable complexity */\n  constructor({\n    // Window width/height in pixels (for pixel projection)\n    width = 1,\n    height = 1,\n    // Desc\n    viewMatrix = IDENTITY,\n    projectionMatrix = IDENTITY\n  } = {}) {\n    // Silently allow apps to send in 0,0\n    this.width = width || 1;\n    this.height = height || 1;\n    this.scale = 1;\n\n    this.viewMatrix = viewMatrix;\n    this.projectionMatrix = projectionMatrix;\n\n    // Note: As usual, matrix operations should be applied in \"reverse\" order\n    // since vectors will be multiplied in from the right during transformation\n    const vpm = createMat4();\n    mat4.multiply(vpm, vpm, this.projectionMatrix);\n    mat4.multiply(vpm, vpm, this.viewMatrix);\n    this.viewProjectionMatrix = vpm;\n\n    // Calculate matrices and scales needed for projection\n    /**\n     * Builds matrices that converts preprojected lngLats to screen pixels\n     * and vice versa.\n     * Note: Currently returns bottom-left coordinates!\n     * Note: Starts with the GL projection matrix and adds steps to the\n     *       scale and translate that matrix onto the window.\n     * Note: WebGL controls clip space to screen projection with gl.viewport\n     *       and does not need this step.\n     */\n    const m = createMat4();\n\n   // matrix for conversion from location to screen coordinates\n    mat4.scale(m, m, [this.width / 2, -this.height / 2, 1]);\n    mat4.translate(m, m, [1, -1, 0]);\n\n    // Scale with viewport window's width and height in pixels\n    // mat4.scale(m, m, [this.width, this.height, 1]);\n    // Convert to (0, 1)\n    // mat4.translate(m, m, [0.5, 0.5, 0]);\n    // mat4.scale(m, m, [0.5, 0.5, 1]);\n    // Project to clip space (-1, 1)\n    mat4.multiply(m, m, this.viewProjectionMatrix);\n\n    // console.log(`vec ${[this.width / 2, this.height / 2, 1]}`);\n    // console.log(`View ${this.viewMatrix}`);\n    // console.log(`VPM ${vpm}`);\n    // console.log(`Pixel ${m}`);\n\n    const mInverse = mat4.invert(createMat4(), m);\n    if (!mInverse) {\n      throw new Error('Pixel project matrix not invertible');\n    }\n\n    this.pixelProjectionMatrix = m;\n    this.pixelUnprojectionMatrix = mInverse;\n\n    autobind(this);\n  }\n  /* eslint-enable complexity */\n\n  // Two viewports are equal if width and height are identical, and if\n  // their view and projection matrices are (approximately) equal.\n  equals(viewport) {\n    if (!(viewport instanceof Viewport)) {\n      return false;\n    }\n\n    return viewport.width === this.width &&\n      viewport.height === this.height &&\n      mat4.equals(viewport.projectionMatrix, this.projectionMatrix) &&\n      mat4.equals(viewport.viewMatrix, this.viewMatrix);\n  }\n\n  /**\n   * Projects xyz (possibly latitude and longitude) to pixel coordinates in window\n   * using viewport projection parameters\n   * - [longitude, latitude] to [x, y]\n   * - [longitude, latitude, Z] => [x, y, z]\n   * Note: By default, returns top-left coordinates for canvas/SVG type render\n   *\n   * @param {Array} lngLatZ - [lng, lat] or [lng, lat, Z]\n   * @param {Object} opts - options\n   * @param {Object} opts.topLeft=true - Whether projected coords are top left\n   * @return {Array} - [x, y] or [x, y, z] in top left coords\n   */\n  project(xyz, {topLeft = false} = {}) {\n    const [x0, y0, z0 = 0] = xyz;\n    assert(Number.isFinite(x0) && Number.isFinite(y0) && Number.isFinite(z0), ERR_ARGUMENT);\n\n    const [X, Y] = this.projectFlat([x0, y0]);\n    const v = this.transformVector(this.pixelProjectionMatrix, [X, Y, z0, 1]);\n\n    const [x, y] = v;\n    const y2 = topLeft ? this.height - y : y;\n    return xyz.length === 2 ? [x, y2] : [x, y2, 0];\n  }\n\n  /**\n   * Unproject pixel coordinates on screen onto world coordinates,\n   * (possibly [lon, lat]) on map.\n   * - [x, y] => [lng, lat]\n   * - [x, y, z] => [lng, lat, Z]\n   * @param {Array} xyz -\n   * @return {Array} - [lng, lat, Z] or [X, Y, Z]\n   */\n  unproject(xyz, {topLeft = false} = {}) {\n    const [x, y, targetZ = 0] = xyz;\n\n    const y2 = topLeft ? this.height - y : y;\n\n    // since we don't know the correct projected z value for the point,\n    // unproject two points to get a line and then find the point on that line with z=0\n    const coord0 = this.transformVector(this.pixelUnprojectionMatrix, [x, y2, 0, 1]);\n    const coord1 = this.transformVector(this.pixelUnprojectionMatrix, [x, y2, 1, 1]);\n\n    const z0 = coord0[2];\n    const z1 = coord1[2];\n\n    const t = z0 === z1 ? 0 : (targetZ - z0) / (z1 - z0);\n    const v = vec2.lerp([], coord0, coord1, t);\n\n    // console.error(`unprojecting to non-linear ${v}<=${[x, y2, targetZ]}`);\n\n    const vUnprojected = this.unprojectFlat(v);\n    return xyz.length === 2 ? vUnprojected : [vUnprojected[0], vUnprojected[1], 0];\n  }\n\n  // TODO - replace with math.gl\n  transformVector(matrix, vector) {\n    const result = vec4.transformMat4([0, 0, 0, 0], vector, matrix);\n    const scale = 1 / result[3];\n    vec4.multiply(result, result, [scale, scale, scale, scale]);\n    return result;\n  }\n\n  // NON_LINEAR PROJECTION HOOKS\n  // Used for web meractor projection\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   * @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   */\n  projectFlat([x, y], scale = this.scale) {\n    return this._projectFlat(...arguments);\n  }\n\n  /**\n   * Unproject world point [x,y] on map onto {lat, lon} on sphere\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   */\n  unprojectFlat(xyz, scale = this.scale) {\n    return this._unprojectFlat(...arguments);\n  }\n\n  getMatrices({modelMatrix = null} = {}) {\n    let modelViewProjectionMatrix = this.viewProjectionMatrix;\n    let pixelProjectionMatrix = this.pixelProjectionMatrix;\n    let pixelUnprojectionMatrix = this.pixelUnprojectionMatrix;\n\n    if (modelMatrix) {\n      modelViewProjectionMatrix = mat4.multiply([], this.viewProjectionMatrix, modelMatrix);\n      pixelProjectionMatrix = mat4.multiply([], this.pixelProjectionMatrix, modelMatrix);\n      pixelUnprojectionMatrix = mat4.invert([], pixelProjectionMatrix);\n    }\n\n    const matrices = Object.assign({\n      modelViewProjectionMatrix,\n      viewProjectionMatrix: this.viewProjectionMatrix,\n      viewMatrix: this.viewMatrix,\n      projectionMatrix: this.projectionMatrix,\n\n      // project/unproject between pixels and world\n      pixelProjectionMatrix,\n      pixelUnprojectionMatrix,\n\n      width: this.width,\n      height: this.height,\n      scale: this.scale\n    },\n\n      // Subclass can add additional params\n      // TODO - Fragile: better to make base Viewport class aware of all params\n      this._getParams()\n    );\n\n    return matrices;\n  }\n\n  // INTERNAL METHODS\n\n  // Can be subclassed to add additional fields to `getMatrices`\n  _getParams() {\n    return {};\n  }\n}\n\n// Helper, avoids low-precision 32 bit matrices from gl-matrix mat4.create()\nexport function createMat4() {\n  return [1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1];\n}\n"]} | ||
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../src/viewport.js"],"names":["mat4_scale","mat4_translate","mat4_multiply","mat4_invert","vec4_multiply","vec4_transformMat4","vec2_lerp","equals","autobind","assert","IDENTITY","createMat4","ERR_ARGUMENT","Viewport","width","height","viewMatrix","projectionMatrix","scale","vpm","viewProjectionMatrix","m","mInverse","Error","pixelProjectionMatrix","pixelUnprojectionMatrix","viewport","xyz","topLeft","x0","y0","z0","Number","isFinite","projectFlat","X","Y","v","transformVector","x","y","y2","length","targetZ","coord0","coord1","z1","t","vUnprojected","unprojectFlat","matrix","vector","result","_projectFlat","arguments","_unprojectFlat","modelMatrix","modelViewProjectionMatrix","matrices","Object","assign","_getParams"],"mappings":"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","file":"viewport.js","sourcesContent":["// View and Projection Matrix management\n\n/* eslint-disable camelcase */\nimport mat4_scale from 'gl-mat4/scale';\nimport mat4_translate from 'gl-mat4/translate';\nimport mat4_multiply from 'gl-mat4/multiply';\nimport mat4_invert from 'gl-mat4/invert';\nimport vec4_multiply from 'gl-vec4/multiply';\nimport vec4_transformMat4 from 'gl-vec4/transformMat4';\nimport vec2_lerp from 'gl-vec2/lerp';\nimport equals from './equals';\n\nimport autobind from './autobind';\nimport assert from 'assert';\n\nconst IDENTITY = createMat4();\n\nconst ERR_ARGUMENT = 'Illegal argument to Viewport';\n\nexport default class Viewport {\n  /**\n   * @classdesc\n   * Manages coordinate system transformations for deck.gl.\n   *\n   * Note: The Viewport is immutable in the sense that it only has accessors.\n   * A new viewport instance should be created if any parameters have changed.\n   *\n   * @class\n   * @param {Object} opt - options\n   * @param {Boolean} mercator=true - Whether to use mercator projection\n   *\n   * @param {Number} opt.width=1 - Width of \"viewport\" or window\n   * @param {Number} opt.height=1 - Height of \"viewport\" or window\n   * @param {Array} opt.center=[0, 0] - Center of viewport\n   *   [longitude, latitude] or [x, y]\n   * @param {Number} opt.scale=1 - Either use scale or zoom\n   * @param {Number} opt.pitch=0 - Camera angle in degrees (0 is straight down)\n   * @param {Number} opt.bearing=0 - Map rotation in degrees (0 means north is up)\n   * @param {Number} opt.altitude= - Altitude of camera in screen units\n   *\n   * Web mercator projection short-hand parameters\n   * @param {Number} opt.latitude - Center of viewport on map (alternative to opt.center)\n   * @param {Number} opt.longitude - Center of viewport on map (alternative to opt.center)\n   * @param {Number} opt.zoom - Scale = Math.pow(2,zoom) on map (alternative to opt.scale)\n   */\n  /* eslint-disable complexity */\n  constructor({\n    // Window width/height in pixels (for pixel projection)\n    width = 1,\n    height = 1,\n    // Desc\n    viewMatrix = IDENTITY,\n    projectionMatrix = IDENTITY\n  } = {}) {\n    // Silently allow apps to send in 0,0\n    this.width = width || 1;\n    this.height = height || 1;\n    this.scale = 1;\n\n    this.viewMatrix = viewMatrix;\n    this.projectionMatrix = projectionMatrix;\n\n    // Note: As usual, matrix operations should be applied in \"reverse\" order\n    // since vectors will be multiplied in from the right during transformation\n    const vpm = createMat4();\n    mat4_multiply(vpm, vpm, this.projectionMatrix);\n    mat4_multiply(vpm, vpm, this.viewMatrix);\n    this.viewProjectionMatrix = vpm;\n\n    // Calculate matrices and scales needed for projection\n    /**\n     * Builds matrices that converts preprojected lngLats to screen pixels\n     * and vice versa.\n     * Note: Currently returns bottom-left coordinates!\n     * Note: Starts with the GL projection matrix and adds steps to the\n     *       scale and translate that matrix onto the window.\n     * Note: WebGL controls clip space to screen projection with gl.viewport\n     *       and does not need this step.\n     */\n    const m = createMat4();\n\n    // matrix for conversion from location to screen coordinates\n    mat4_scale(m, m, [this.width / 2, -this.height / 2, 1]);\n    mat4_translate(m, m, [1, -1, 0]);\n\n    mat4_multiply(m, m, this.viewProjectionMatrix);\n\n    const mInverse = mat4_invert(createMat4(), m);\n    if (!mInverse) {\n      throw new Error('Pixel project matrix not invertible');\n    }\n\n    this.pixelProjectionMatrix = m;\n    this.pixelUnprojectionMatrix = mInverse;\n\n    autobind(this);\n  }\n  /* eslint-enable complexity */\n\n  // Two viewports are equal if width and height are identical, and if\n  // their view and projection matrices are (approximately) equal.\n  equals(viewport) {\n    if (!(viewport instanceof Viewport)) {\n      return false;\n    }\n\n    return viewport.width === this.width &&\n      viewport.height === this.height &&\n      equals(viewport.projectionMatrix, this.projectionMatrix) &&\n      equals(viewport.viewMatrix, this.viewMatrix);\n  }\n\n  /**\n   * Projects xyz (possibly latitude and longitude) to pixel coordinates in window\n   * using viewport projection parameters\n   * - [longitude, latitude] to [x, y]\n   * - [longitude, latitude, Z] => [x, y, z]\n   * Note: By default, returns top-left coordinates for canvas/SVG type render\n   *\n   * @param {Array} lngLatZ - [lng, lat] or [lng, lat, Z]\n   * @param {Object} opts - options\n   * @param {Object} opts.topLeft=true - Whether projected coords are top left\n   * @return {Array} - [x, y] or [x, y, z] in top left coords\n   */\n  project(xyz, {topLeft = false} = {}) {\n    const [x0, y0, z0 = 0] = xyz;\n    assert(Number.isFinite(x0) && Number.isFinite(y0) && Number.isFinite(z0), ERR_ARGUMENT);\n\n    const [X, Y] = this.projectFlat([x0, y0]);\n    const v = this.transformVector(this.pixelProjectionMatrix, [X, Y, z0, 1]);\n\n    const [x, y] = v;\n    const y2 = topLeft ? this.height - y : y;\n    return xyz.length === 2 ? [x, y2] : [x, y2, 0];\n  }\n\n  /**\n   * Unproject pixel coordinates on screen onto world coordinates,\n   * (possibly [lon, lat]) on map.\n   * - [x, y] => [lng, lat]\n   * - [x, y, z] => [lng, lat, Z]\n   * @param {Array} xyz -\n   * @return {Array} - [lng, lat, Z] or [X, Y, Z]\n   */\n  unproject(xyz, {topLeft = false} = {}) {\n    const [x, y, targetZ = 0] = xyz;\n\n    const y2 = topLeft ? this.height - y : y;\n\n    // since we don't know the correct projected z value for the point,\n    // unproject two points to get a line and then find the point on that line with z=0\n    const coord0 = this.transformVector(this.pixelUnprojectionMatrix, [x, y2, 0, 1]);\n    const coord1 = this.transformVector(this.pixelUnprojectionMatrix, [x, y2, 1, 1]);\n\n    const z0 = coord0[2];\n    const z1 = coord1[2];\n\n    const t = z0 === z1 ? 0 : (targetZ - z0) / (z1 - z0);\n    const v = vec2_lerp([], coord0, coord1, t);\n\n    const vUnprojected = this.unprojectFlat(v);\n    return xyz.length === 2 ? vUnprojected : [vUnprojected[0], vUnprojected[1], 0];\n  }\n\n  // TODO - replace with math.gl\n  transformVector(matrix, vector) {\n    const result = vec4_transformMat4([0, 0, 0, 0], vector, matrix);\n    const scale = 1 / result[3];\n    vec4_multiply(result, result, [scale, scale, scale, scale]);\n    return result;\n  }\n\n  // NON_LINEAR PROJECTION HOOKS\n  // Used for web meractor projection\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   * @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   */\n  projectFlat([x, y], scale = this.scale) {\n    return this._projectFlat(...arguments);\n  }\n\n  /**\n   * Unproject world point [x,y] on map onto {lat, lon} on sphere\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   */\n  unprojectFlat(xyz, scale = this.scale) {\n    return this._unprojectFlat(...arguments);\n  }\n\n  getMatrices({modelMatrix = null} = {}) {\n    let modelViewProjectionMatrix = this.viewProjectionMatrix;\n    let pixelProjectionMatrix = this.pixelProjectionMatrix;\n    let pixelUnprojectionMatrix = this.pixelUnprojectionMatrix;\n\n    if (modelMatrix) {\n      modelViewProjectionMatrix = mat4_multiply([], this.viewProjectionMatrix, modelMatrix);\n      pixelProjectionMatrix = mat4_multiply([], this.pixelProjectionMatrix, modelMatrix);\n      pixelUnprojectionMatrix = mat4_invert([], pixelProjectionMatrix);\n    }\n\n    const matrices = Object.assign({\n      modelViewProjectionMatrix,\n      viewProjectionMatrix: this.viewProjectionMatrix,\n      viewMatrix: this.viewMatrix,\n      projectionMatrix: this.projectionMatrix,\n\n      // project/unproject between pixels and world\n      pixelProjectionMatrix,\n      pixelUnprojectionMatrix,\n\n      width: this.width,\n      height: this.height,\n      scale: this.scale\n    },\n\n      // Subclass can add additional params\n      // TODO - Fragile: better to make base Viewport class aware of all params\n      this._getParams()\n    );\n\n    return matrices;\n  }\n\n  // INTERNAL METHODS\n\n  // Can be subclassed to add additional fields to `getMatrices`\n  _getParams() {\n    return {};\n  }\n}\n\n// Helper, avoids low-precision 32 bit matrices from mat4.create()\nexport function createMat4() {\n  return [1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1];\n}\n"]} |
@@ -11,5 +11,3 @@ 'use strict'; | ||
// gl-matrix is a large dependency for a small module. | ||
// However since it is used by mapbox etc, it should already be present | ||
// in most target application bundles. | ||
/* eslint-disable camelcase */ | ||
@@ -19,4 +17,34 @@ | ||
var _glMatrix = require('gl-matrix'); | ||
var _scale = require('gl-mat4/scale'); | ||
var _scale2 = _interopRequireDefault(_scale); | ||
var _translate = require('gl-mat4/translate'); | ||
var _translate2 = _interopRequireDefault(_translate); | ||
var _multiply = require('gl-mat4/multiply'); | ||
var _multiply2 = _interopRequireDefault(_multiply); | ||
var _invert = require('gl-mat4/invert'); | ||
var _invert2 = _interopRequireDefault(_invert); | ||
var _multiply3 = require('gl-vec4/multiply'); | ||
var _multiply4 = _interopRequireDefault(_multiply3); | ||
var _transformMat = require('gl-vec4/transformMat4'); | ||
var _transformMat2 = _interopRequireDefault(_transformMat); | ||
var _lerp = require('gl-vec2/lerp'); | ||
var _lerp2 = _interopRequireDefault(_lerp); | ||
var _equals2 = require('./equals'); | ||
var _equals3 = _interopRequireDefault(_equals2); | ||
var _autobind = require('./autobind'); | ||
@@ -89,4 +117,4 @@ | ||
var vpm = createMat4(); | ||
_glMatrix.mat4.multiply(vpm, vpm, this.projectionMatrix); | ||
_glMatrix.mat4.multiply(vpm, vpm, this.viewMatrix); | ||
(0, _multiply2.default)(vpm, vpm, this.projectionMatrix); | ||
(0, _multiply2.default)(vpm, vpm, this.viewMatrix); | ||
this.viewProjectionMatrix = vpm; | ||
@@ -107,19 +135,8 @@ | ||
// matrix for conversion from location to screen coordinates | ||
_glMatrix.mat4.scale(m, m, [this.width / 2, -this.height / 2, 1]); | ||
_glMatrix.mat4.translate(m, m, [1, -1, 0]); | ||
(0, _scale2.default)(m, m, [this.width / 2, -this.height / 2, 1]); | ||
(0, _translate2.default)(m, m, [1, -1, 0]); | ||
// Scale with viewport window's width and height in pixels | ||
// mat4.scale(m, m, [this.width, this.height, 1]); | ||
// Convert to (0, 1) | ||
// mat4.translate(m, m, [0.5, 0.5, 0]); | ||
// mat4.scale(m, m, [0.5, 0.5, 1]); | ||
// Project to clip space (-1, 1) | ||
_glMatrix.mat4.multiply(m, m, this.viewProjectionMatrix); | ||
(0, _multiply2.default)(m, m, this.viewProjectionMatrix); | ||
// console.log(`vec ${[this.width / 2, this.height / 2, 1]}`); | ||
// console.log(`View ${this.viewMatrix}`); | ||
// console.log(`VPM ${vpm}`); | ||
// console.log(`Pixel ${m}`); | ||
var mInverse = _glMatrix.mat4.invert(createMat4(), m); | ||
var mInverse = (0, _invert2.default)(createMat4(), m); | ||
if (!mInverse) { | ||
@@ -147,3 +164,3 @@ throw new Error('Pixel project matrix not invertible'); | ||
return viewport.width === this.width && viewport.height === this.height && _glMatrix.mat4.equals(viewport.projectionMatrix, this.projectionMatrix) && _glMatrix.mat4.equals(viewport.viewMatrix, this.viewMatrix); | ||
return viewport.width === this.width && viewport.height === this.height && (0, _equals3.default)(viewport.projectionMatrix, this.projectionMatrix) && (0, _equals3.default)(viewport.viewMatrix, this.viewMatrix); | ||
} | ||
@@ -227,6 +244,4 @@ | ||
var t = z0 === z1 ? 0 : (targetZ - z0) / (z1 - z0); | ||
var v = _glMatrix.vec2.lerp([], coord0, coord1, t); | ||
var v = (0, _lerp2.default)([], coord0, coord1, t); | ||
// console.error(`unprojecting to non-linear ${v}<=${[x, y2, targetZ]}`); | ||
var vUnprojected = this.unprojectFlat(v); | ||
@@ -241,5 +256,5 @@ return xyz.length === 2 ? vUnprojected : [vUnprojected[0], vUnprojected[1], 0]; | ||
value: function transformVector(matrix, vector) { | ||
var result = _glMatrix.vec4.transformMat4([0, 0, 0, 0], vector, matrix); | ||
var result = (0, _transformMat2.default)([0, 0, 0, 0], vector, matrix); | ||
var scale = 1 / result[3]; | ||
_glMatrix.vec4.multiply(result, result, [scale, scale, scale, scale]); | ||
(0, _multiply4.default)(result, result, [scale, scale, scale, scale]); | ||
return result; | ||
@@ -301,5 +316,5 @@ } | ||
if (modelMatrix) { | ||
modelViewProjectionMatrix = _glMatrix.mat4.multiply([], this.viewProjectionMatrix, modelMatrix); | ||
pixelProjectionMatrix = _glMatrix.mat4.multiply([], this.pixelProjectionMatrix, modelMatrix); | ||
pixelUnprojectionMatrix = _glMatrix.mat4.invert([], pixelProjectionMatrix); | ||
modelViewProjectionMatrix = (0, _multiply2.default)([], this.viewProjectionMatrix, modelMatrix); | ||
pixelProjectionMatrix = (0, _multiply2.default)([], this.pixelProjectionMatrix, modelMatrix); | ||
pixelUnprojectionMatrix = (0, _invert2.default)([], pixelProjectionMatrix); | ||
} | ||
@@ -343,3 +358,3 @@ | ||
// Helper, avoids low-precision 32 bit matrices from gl-matrix mat4.create() | ||
// Helper, avoids low-precision 32 bit matrices from mat4.create() | ||
@@ -351,2 +366,2 @@ | ||
} | ||
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../src/viewport.js"],"names":["createMat4","IDENTITY","ERR_ARGUMENT","Viewport","width","height","viewMatrix","projectionMatrix","scale","vpm","multiply","viewProjectionMatrix","m","translate","mInverse","invert","Error","pixelProjectionMatrix","pixelUnprojectionMatrix","viewport","equals","xyz","topLeft","x0","y0","z0","Number","isFinite","projectFlat","X","Y","v","transformVector","x","y","y2","length","targetZ","coord0","coord1","z1","t","lerp","vUnprojected","unprojectFlat","matrix","vector","result","transformMat4","_projectFlat","arguments","_unprojectFlat","modelMatrix","modelViewProjectionMatrix","matrices","Object","assign","_getParams"],"mappings":"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","file":"viewport.js","sourcesContent":["// View and Projection Matrix management\n\n// gl-matrix is a large dependency for a small module.\n// However since it is used by mapbox etc, it should already be present\n// in most target application bundles.\nimport {mat4, vec4, vec2} from 'gl-matrix';\nimport autobind from './autobind';\nimport assert from 'assert';\n\nconst IDENTITY = createMat4();\n\nconst ERR_ARGUMENT = 'Illegal argument to Viewport';\n\nexport default class Viewport {\n  /**\n   * @classdesc\n   * Manages coordinate system transformations for deck.gl.\n   *\n   * Note: The Viewport is immutable in the sense that it only has accessors.\n   * A new viewport instance should be created if any parameters have changed.\n   *\n   * @class\n   * @param {Object} opt - options\n   * @param {Boolean} mercator=true - Whether to use mercator projection\n   *\n   * @param {Number} opt.width=1 - Width of \"viewport\" or window\n   * @param {Number} opt.height=1 - Height of \"viewport\" or window\n   * @param {Array} opt.center=[0, 0] - Center of viewport\n   *   [longitude, latitude] or [x, y]\n   * @param {Number} opt.scale=1 - Either use scale or zoom\n   * @param {Number} opt.pitch=0 - Camera angle in degrees (0 is straight down)\n   * @param {Number} opt.bearing=0 - Map rotation in degrees (0 means north is up)\n   * @param {Number} opt.altitude= - Altitude of camera in screen units\n   *\n   * Web mercator projection short-hand parameters\n   * @param {Number} opt.latitude - Center of viewport on map (alternative to opt.center)\n   * @param {Number} opt.longitude - Center of viewport on map (alternative to opt.center)\n   * @param {Number} opt.zoom - Scale = Math.pow(2,zoom) on map (alternative to opt.scale)\n   */\n  /* eslint-disable complexity */\n  constructor({\n    // Window width/height in pixels (for pixel projection)\n    width = 1,\n    height = 1,\n    // Desc\n    viewMatrix = IDENTITY,\n    projectionMatrix = IDENTITY\n  } = {}) {\n    // Silently allow apps to send in 0,0\n    this.width = width || 1;\n    this.height = height || 1;\n    this.scale = 1;\n\n    this.viewMatrix = viewMatrix;\n    this.projectionMatrix = projectionMatrix;\n\n    // Note: As usual, matrix operations should be applied in \"reverse\" order\n    // since vectors will be multiplied in from the right during transformation\n    const vpm = createMat4();\n    mat4.multiply(vpm, vpm, this.projectionMatrix);\n    mat4.multiply(vpm, vpm, this.viewMatrix);\n    this.viewProjectionMatrix = vpm;\n\n    // Calculate matrices and scales needed for projection\n    /**\n     * Builds matrices that converts preprojected lngLats to screen pixels\n     * and vice versa.\n     * Note: Currently returns bottom-left coordinates!\n     * Note: Starts with the GL projection matrix and adds steps to the\n     *       scale and translate that matrix onto the window.\n     * Note: WebGL controls clip space to screen projection with gl.viewport\n     *       and does not need this step.\n     */\n    const m = createMat4();\n\n   // matrix for conversion from location to screen coordinates\n    mat4.scale(m, m, [this.width / 2, -this.height / 2, 1]);\n    mat4.translate(m, m, [1, -1, 0]);\n\n    // Scale with viewport window's width and height in pixels\n    // mat4.scale(m, m, [this.width, this.height, 1]);\n    // Convert to (0, 1)\n    // mat4.translate(m, m, [0.5, 0.5, 0]);\n    // mat4.scale(m, m, [0.5, 0.5, 1]);\n    // Project to clip space (-1, 1)\n    mat4.multiply(m, m, this.viewProjectionMatrix);\n\n    // console.log(`vec ${[this.width / 2, this.height / 2, 1]}`);\n    // console.log(`View ${this.viewMatrix}`);\n    // console.log(`VPM ${vpm}`);\n    // console.log(`Pixel ${m}`);\n\n    const mInverse = mat4.invert(createMat4(), m);\n    if (!mInverse) {\n      throw new Error('Pixel project matrix not invertible');\n    }\n\n    this.pixelProjectionMatrix = m;\n    this.pixelUnprojectionMatrix = mInverse;\n\n    autobind(this);\n  }\n  /* eslint-enable complexity */\n\n  // Two viewports are equal if width and height are identical, and if\n  // their view and projection matrices are (approximately) equal.\n  equals(viewport) {\n    if (!(viewport instanceof Viewport)) {\n      return false;\n    }\n\n    return viewport.width === this.width &&\n      viewport.height === this.height &&\n      mat4.equals(viewport.projectionMatrix, this.projectionMatrix) &&\n      mat4.equals(viewport.viewMatrix, this.viewMatrix);\n  }\n\n  /**\n   * Projects xyz (possibly latitude and longitude) to pixel coordinates in window\n   * using viewport projection parameters\n   * - [longitude, latitude] to [x, y]\n   * - [longitude, latitude, Z] => [x, y, z]\n   * Note: By default, returns top-left coordinates for canvas/SVG type render\n   *\n   * @param {Array} lngLatZ - [lng, lat] or [lng, lat, Z]\n   * @param {Object} opts - options\n   * @param {Object} opts.topLeft=true - Whether projected coords are top left\n   * @return {Array} - [x, y] or [x, y, z] in top left coords\n   */\n  project(xyz, {topLeft = false} = {}) {\n    const [x0, y0, z0 = 0] = xyz;\n    assert(Number.isFinite(x0) && Number.isFinite(y0) && Number.isFinite(z0), ERR_ARGUMENT);\n\n    const [X, Y] = this.projectFlat([x0, y0]);\n    const v = this.transformVector(this.pixelProjectionMatrix, [X, Y, z0, 1]);\n\n    const [x, y] = v;\n    const y2 = topLeft ? this.height - y : y;\n    return xyz.length === 2 ? [x, y2] : [x, y2, 0];\n  }\n\n  /**\n   * Unproject pixel coordinates on screen onto world coordinates,\n   * (possibly [lon, lat]) on map.\n   * - [x, y] => [lng, lat]\n   * - [x, y, z] => [lng, lat, Z]\n   * @param {Array} xyz -\n   * @return {Array} - [lng, lat, Z] or [X, Y, Z]\n   */\n  unproject(xyz, {topLeft = false} = {}) {\n    const [x, y, targetZ = 0] = xyz;\n\n    const y2 = topLeft ? this.height - y : y;\n\n    // since we don't know the correct projected z value for the point,\n    // unproject two points to get a line and then find the point on that line with z=0\n    const coord0 = this.transformVector(this.pixelUnprojectionMatrix, [x, y2, 0, 1]);\n    const coord1 = this.transformVector(this.pixelUnprojectionMatrix, [x, y2, 1, 1]);\n\n    const z0 = coord0[2];\n    const z1 = coord1[2];\n\n    const t = z0 === z1 ? 0 : (targetZ - z0) / (z1 - z0);\n    const v = vec2.lerp([], coord0, coord1, t);\n\n    // console.error(`unprojecting to non-linear ${v}<=${[x, y2, targetZ]}`);\n\n    const vUnprojected = this.unprojectFlat(v);\n    return xyz.length === 2 ? vUnprojected : [vUnprojected[0], vUnprojected[1], 0];\n  }\n\n  // TODO - replace with math.gl\n  transformVector(matrix, vector) {\n    const result = vec4.transformMat4([0, 0, 0, 0], vector, matrix);\n    const scale = 1 / result[3];\n    vec4.multiply(result, result, [scale, scale, scale, scale]);\n    return result;\n  }\n\n  // NON_LINEAR PROJECTION HOOKS\n  // Used for web meractor projection\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   * @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   */\n  projectFlat([x, y], scale = this.scale) {\n    return this._projectFlat(...arguments);\n  }\n\n  /**\n   * Unproject world point [x,y] on map onto {lat, lon} on sphere\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   */\n  unprojectFlat(xyz, scale = this.scale) {\n    return this._unprojectFlat(...arguments);\n  }\n\n  getMatrices({modelMatrix = null} = {}) {\n    let modelViewProjectionMatrix = this.viewProjectionMatrix;\n    let pixelProjectionMatrix = this.pixelProjectionMatrix;\n    let pixelUnprojectionMatrix = this.pixelUnprojectionMatrix;\n\n    if (modelMatrix) {\n      modelViewProjectionMatrix = mat4.multiply([], this.viewProjectionMatrix, modelMatrix);\n      pixelProjectionMatrix = mat4.multiply([], this.pixelProjectionMatrix, modelMatrix);\n      pixelUnprojectionMatrix = mat4.invert([], pixelProjectionMatrix);\n    }\n\n    const matrices = Object.assign({\n      modelViewProjectionMatrix,\n      viewProjectionMatrix: this.viewProjectionMatrix,\n      viewMatrix: this.viewMatrix,\n      projectionMatrix: this.projectionMatrix,\n\n      // project/unproject between pixels and world\n      pixelProjectionMatrix,\n      pixelUnprojectionMatrix,\n\n      width: this.width,\n      height: this.height,\n      scale: this.scale\n    },\n\n      // Subclass can add additional params\n      // TODO - Fragile: better to make base Viewport class aware of all params\n      this._getParams()\n    );\n\n    return matrices;\n  }\n\n  // INTERNAL METHODS\n\n  // Can be subclassed to add additional fields to `getMatrices`\n  _getParams() {\n    return {};\n  }\n}\n\n// Helper, avoids low-precision 32 bit matrices from gl-matrix mat4.create()\nexport function createMat4() {\n  return [1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1];\n}\n"]} | ||
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../src/viewport.js"],"names":["createMat4","IDENTITY","ERR_ARGUMENT","Viewport","width","height","viewMatrix","projectionMatrix","scale","vpm","viewProjectionMatrix","m","mInverse","Error","pixelProjectionMatrix","pixelUnprojectionMatrix","viewport","xyz","topLeft","x0","y0","z0","Number","isFinite","projectFlat","X","Y","v","transformVector","x","y","y2","length","targetZ","coord0","coord1","z1","t","vUnprojected","unprojectFlat","matrix","vector","result","_projectFlat","arguments","_unprojectFlat","modelMatrix","modelViewProjectionMatrix","matrices","Object","assign","_getParams"],"mappings":"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","file":"viewport.js","sourcesContent":["// View and Projection Matrix management\n\n/* eslint-disable camelcase */\nimport mat4_scale from 'gl-mat4/scale';\nimport mat4_translate from 'gl-mat4/translate';\nimport mat4_multiply from 'gl-mat4/multiply';\nimport mat4_invert from 'gl-mat4/invert';\nimport vec4_multiply from 'gl-vec4/multiply';\nimport vec4_transformMat4 from 'gl-vec4/transformMat4';\nimport vec2_lerp from 'gl-vec2/lerp';\nimport equals from './equals';\n\nimport autobind from './autobind';\nimport assert from 'assert';\n\nconst IDENTITY = createMat4();\n\nconst ERR_ARGUMENT = 'Illegal argument to Viewport';\n\nexport default class Viewport {\n  /**\n   * @classdesc\n   * Manages coordinate system transformations for deck.gl.\n   *\n   * Note: The Viewport is immutable in the sense that it only has accessors.\n   * A new viewport instance should be created if any parameters have changed.\n   *\n   * @class\n   * @param {Object} opt - options\n   * @param {Boolean} mercator=true - Whether to use mercator projection\n   *\n   * @param {Number} opt.width=1 - Width of \"viewport\" or window\n   * @param {Number} opt.height=1 - Height of \"viewport\" or window\n   * @param {Array} opt.center=[0, 0] - Center of viewport\n   *   [longitude, latitude] or [x, y]\n   * @param {Number} opt.scale=1 - Either use scale or zoom\n   * @param {Number} opt.pitch=0 - Camera angle in degrees (0 is straight down)\n   * @param {Number} opt.bearing=0 - Map rotation in degrees (0 means north is up)\n   * @param {Number} opt.altitude= - Altitude of camera in screen units\n   *\n   * Web mercator projection short-hand parameters\n   * @param {Number} opt.latitude - Center of viewport on map (alternative to opt.center)\n   * @param {Number} opt.longitude - Center of viewport on map (alternative to opt.center)\n   * @param {Number} opt.zoom - Scale = Math.pow(2,zoom) on map (alternative to opt.scale)\n   */\n  /* eslint-disable complexity */\n  constructor({\n    // Window width/height in pixels (for pixel projection)\n    width = 1,\n    height = 1,\n    // Desc\n    viewMatrix = IDENTITY,\n    projectionMatrix = IDENTITY\n  } = {}) {\n    // Silently allow apps to send in 0,0\n    this.width = width || 1;\n    this.height = height || 1;\n    this.scale = 1;\n\n    this.viewMatrix = viewMatrix;\n    this.projectionMatrix = projectionMatrix;\n\n    // Note: As usual, matrix operations should be applied in \"reverse\" order\n    // since vectors will be multiplied in from the right during transformation\n    const vpm = createMat4();\n    mat4_multiply(vpm, vpm, this.projectionMatrix);\n    mat4_multiply(vpm, vpm, this.viewMatrix);\n    this.viewProjectionMatrix = vpm;\n\n    // Calculate matrices and scales needed for projection\n    /**\n     * Builds matrices that converts preprojected lngLats to screen pixels\n     * and vice versa.\n     * Note: Currently returns bottom-left coordinates!\n     * Note: Starts with the GL projection matrix and adds steps to the\n     *       scale and translate that matrix onto the window.\n     * Note: WebGL controls clip space to screen projection with gl.viewport\n     *       and does not need this step.\n     */\n    const m = createMat4();\n\n    // matrix for conversion from location to screen coordinates\n    mat4_scale(m, m, [this.width / 2, -this.height / 2, 1]);\n    mat4_translate(m, m, [1, -1, 0]);\n\n    mat4_multiply(m, m, this.viewProjectionMatrix);\n\n    const mInverse = mat4_invert(createMat4(), m);\n    if (!mInverse) {\n      throw new Error('Pixel project matrix not invertible');\n    }\n\n    this.pixelProjectionMatrix = m;\n    this.pixelUnprojectionMatrix = mInverse;\n\n    autobind(this);\n  }\n  /* eslint-enable complexity */\n\n  // Two viewports are equal if width and height are identical, and if\n  // their view and projection matrices are (approximately) equal.\n  equals(viewport) {\n    if (!(viewport instanceof Viewport)) {\n      return false;\n    }\n\n    return viewport.width === this.width &&\n      viewport.height === this.height &&\n      equals(viewport.projectionMatrix, this.projectionMatrix) &&\n      equals(viewport.viewMatrix, this.viewMatrix);\n  }\n\n  /**\n   * Projects xyz (possibly latitude and longitude) to pixel coordinates in window\n   * using viewport projection parameters\n   * - [longitude, latitude] to [x, y]\n   * - [longitude, latitude, Z] => [x, y, z]\n   * Note: By default, returns top-left coordinates for canvas/SVG type render\n   *\n   * @param {Array} lngLatZ - [lng, lat] or [lng, lat, Z]\n   * @param {Object} opts - options\n   * @param {Object} opts.topLeft=true - Whether projected coords are top left\n   * @return {Array} - [x, y] or [x, y, z] in top left coords\n   */\n  project(xyz, {topLeft = false} = {}) {\n    const [x0, y0, z0 = 0] = xyz;\n    assert(Number.isFinite(x0) && Number.isFinite(y0) && Number.isFinite(z0), ERR_ARGUMENT);\n\n    const [X, Y] = this.projectFlat([x0, y0]);\n    const v = this.transformVector(this.pixelProjectionMatrix, [X, Y, z0, 1]);\n\n    const [x, y] = v;\n    const y2 = topLeft ? this.height - y : y;\n    return xyz.length === 2 ? [x, y2] : [x, y2, 0];\n  }\n\n  /**\n   * Unproject pixel coordinates on screen onto world coordinates,\n   * (possibly [lon, lat]) on map.\n   * - [x, y] => [lng, lat]\n   * - [x, y, z] => [lng, lat, Z]\n   * @param {Array} xyz -\n   * @return {Array} - [lng, lat, Z] or [X, Y, Z]\n   */\n  unproject(xyz, {topLeft = false} = {}) {\n    const [x, y, targetZ = 0] = xyz;\n\n    const y2 = topLeft ? this.height - y : y;\n\n    // since we don't know the correct projected z value for the point,\n    // unproject two points to get a line and then find the point on that line with z=0\n    const coord0 = this.transformVector(this.pixelUnprojectionMatrix, [x, y2, 0, 1]);\n    const coord1 = this.transformVector(this.pixelUnprojectionMatrix, [x, y2, 1, 1]);\n\n    const z0 = coord0[2];\n    const z1 = coord1[2];\n\n    const t = z0 === z1 ? 0 : (targetZ - z0) / (z1 - z0);\n    const v = vec2_lerp([], coord0, coord1, t);\n\n    const vUnprojected = this.unprojectFlat(v);\n    return xyz.length === 2 ? vUnprojected : [vUnprojected[0], vUnprojected[1], 0];\n  }\n\n  // TODO - replace with math.gl\n  transformVector(matrix, vector) {\n    const result = vec4_transformMat4([0, 0, 0, 0], vector, matrix);\n    const scale = 1 / result[3];\n    vec4_multiply(result, result, [scale, scale, scale, scale]);\n    return result;\n  }\n\n  // NON_LINEAR PROJECTION HOOKS\n  // Used for web meractor projection\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   * @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   */\n  projectFlat([x, y], scale = this.scale) {\n    return this._projectFlat(...arguments);\n  }\n\n  /**\n   * Unproject world point [x,y] on map onto {lat, lon} on sphere\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   */\n  unprojectFlat(xyz, scale = this.scale) {\n    return this._unprojectFlat(...arguments);\n  }\n\n  getMatrices({modelMatrix = null} = {}) {\n    let modelViewProjectionMatrix = this.viewProjectionMatrix;\n    let pixelProjectionMatrix = this.pixelProjectionMatrix;\n    let pixelUnprojectionMatrix = this.pixelUnprojectionMatrix;\n\n    if (modelMatrix) {\n      modelViewProjectionMatrix = mat4_multiply([], this.viewProjectionMatrix, modelMatrix);\n      pixelProjectionMatrix = mat4_multiply([], this.pixelProjectionMatrix, modelMatrix);\n      pixelUnprojectionMatrix = mat4_invert([], pixelProjectionMatrix);\n    }\n\n    const matrices = Object.assign({\n      modelViewProjectionMatrix,\n      viewProjectionMatrix: this.viewProjectionMatrix,\n      viewMatrix: this.viewMatrix,\n      projectionMatrix: this.projectionMatrix,\n\n      // project/unproject between pixels and world\n      pixelProjectionMatrix,\n      pixelUnprojectionMatrix,\n\n      width: this.width,\n      height: this.height,\n      scale: this.scale\n    },\n\n      // Subclass can add additional params\n      // TODO - Fragile: better to make base Viewport class aware of all params\n      this._getParams()\n    );\n\n    return matrices;\n  }\n\n  // INTERNAL METHODS\n\n  // Can be subclassed to add additional fields to `getMatrices`\n  _getParams() {\n    return {};\n  }\n}\n\n// Helper, avoids low-precision 32 bit matrices from mat4.create()\nexport function createMat4() {\n  return [1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1];\n}\n"]} |
{ | ||
"name": "viewport-mercator-project", | ||
"version": "4.1.0", | ||
"version": "4.1.1", | ||
"description": "Convert to and from lat/lng and pixels in web mercator at arbitrary floating point zoom levels.", | ||
@@ -25,3 +25,3 @@ "author": "Uber Technologies, Inc.", | ||
"clean": "rm -fr dist/* dist-es6/*", | ||
"lint": "eslint src", | ||
"lint": "eslint src test", | ||
"precommit": "npm test", | ||
@@ -35,3 +35,6 @@ "publish-prod": "npm run build && npm run test && npm publish", | ||
"dependencies": { | ||
"gl-matrix": "^2.3.2" | ||
"gl-mat4": "^1.1.4", | ||
"gl-vec2": "^1.0.0", | ||
"gl-vec3": "^1.0.3", | ||
"gl-vec4": "^1.0.1" | ||
}, | ||
@@ -38,0 +41,0 @@ "devDependencies": { |
@@ -1,8 +0,12 @@ | ||
// View and Projection Matrix calculations for mapbox-js style | ||
// map view properties | ||
// View and Projection Matrix calculations for mapbox-js style map view properties | ||
import Viewport, {createMat4} from './viewport'; | ||
import {mat4, vec2} from 'gl-matrix'; | ||
import autobind from './autobind'; | ||
import assert from 'assert'; | ||
/* eslint-disable camelcase */ | ||
import mat4 from 'gl-mat4'; | ||
import vec2_distance from 'gl-vec2/distance'; | ||
import vec2_add from 'gl-vec2/add'; | ||
import vec2_negate from 'gl-vec2/negate'; | ||
// CONSTANTS | ||
@@ -181,4 +185,4 @@ const PI = Math.PI; | ||
const translate = vec2.sub([], toLocation, fromLocation); | ||
const newCenter = vec2.add([], center, translate); | ||
const translate = vec2_add([], toLocation, vec2_negate([], fromLocation)); | ||
const newCenter = vec2_add([], center, translate); | ||
return this.unprojectFlat(newCenter); | ||
@@ -330,3 +334,3 @@ } | ||
// around current lat/lon | ||
const pixelsPerDegreeX = vec2.distance( | ||
const pixelsPerDegreeX = vec2_distance( | ||
projectFlat([longitude + 0.5, latitude], scale), | ||
@@ -337,3 +341,3 @@ projectFlat([longitude - 0.5, latitude], scale) | ||
// around current lat/lon | ||
const pixelsPerDegreeY = vec2.distance( | ||
const pixelsPerDegreeY = vec2_distance( | ||
projectFlat([longitude, latitude + 0.5], scale), | ||
@@ -340,0 +344,0 @@ projectFlat([longitude, latitude - 0.5], scale) |
// View and Projection Matrix management | ||
// gl-matrix is a large dependency for a small module. | ||
// However since it is used by mapbox etc, it should already be present | ||
// in most target application bundles. | ||
import {mat4, vec4, vec2} from 'gl-matrix'; | ||
/* eslint-disable camelcase */ | ||
import mat4_scale from 'gl-mat4/scale'; | ||
import mat4_translate from 'gl-mat4/translate'; | ||
import mat4_multiply from 'gl-mat4/multiply'; | ||
import mat4_invert from 'gl-mat4/invert'; | ||
import vec4_multiply from 'gl-vec4/multiply'; | ||
import vec4_transformMat4 from 'gl-vec4/transformMat4'; | ||
import vec2_lerp from 'gl-vec2/lerp'; | ||
import equals from './equals'; | ||
import autobind from './autobind'; | ||
@@ -60,4 +66,4 @@ import assert from 'assert'; | ||
const vpm = createMat4(); | ||
mat4.multiply(vpm, vpm, this.projectionMatrix); | ||
mat4.multiply(vpm, vpm, this.viewMatrix); | ||
mat4_multiply(vpm, vpm, this.projectionMatrix); | ||
mat4_multiply(vpm, vpm, this.viewMatrix); | ||
this.viewProjectionMatrix = vpm; | ||
@@ -77,20 +83,9 @@ | ||
// matrix for conversion from location to screen coordinates | ||
mat4.scale(m, m, [this.width / 2, -this.height / 2, 1]); | ||
mat4.translate(m, m, [1, -1, 0]); | ||
// matrix for conversion from location to screen coordinates | ||
mat4_scale(m, m, [this.width / 2, -this.height / 2, 1]); | ||
mat4_translate(m, m, [1, -1, 0]); | ||
// Scale with viewport window's width and height in pixels | ||
// mat4.scale(m, m, [this.width, this.height, 1]); | ||
// Convert to (0, 1) | ||
// mat4.translate(m, m, [0.5, 0.5, 0]); | ||
// mat4.scale(m, m, [0.5, 0.5, 1]); | ||
// Project to clip space (-1, 1) | ||
mat4.multiply(m, m, this.viewProjectionMatrix); | ||
mat4_multiply(m, m, this.viewProjectionMatrix); | ||
// console.log(`vec ${[this.width / 2, this.height / 2, 1]}`); | ||
// console.log(`View ${this.viewMatrix}`); | ||
// console.log(`VPM ${vpm}`); | ||
// console.log(`Pixel ${m}`); | ||
const mInverse = mat4.invert(createMat4(), m); | ||
const mInverse = mat4_invert(createMat4(), m); | ||
if (!mInverse) { | ||
@@ -116,4 +111,4 @@ throw new Error('Pixel project matrix not invertible'); | ||
viewport.height === this.height && | ||
mat4.equals(viewport.projectionMatrix, this.projectionMatrix) && | ||
mat4.equals(viewport.viewMatrix, this.viewMatrix); | ||
equals(viewport.projectionMatrix, this.projectionMatrix) && | ||
equals(viewport.viewMatrix, this.viewMatrix); | ||
} | ||
@@ -167,6 +162,4 @@ | ||
const t = z0 === z1 ? 0 : (targetZ - z0) / (z1 - z0); | ||
const v = vec2.lerp([], coord0, coord1, t); | ||
const v = vec2_lerp([], coord0, coord1, t); | ||
// console.error(`unprojecting to non-linear ${v}<=${[x, y2, targetZ]}`); | ||
const vUnprojected = this.unprojectFlat(v); | ||
@@ -178,5 +171,5 @@ return xyz.length === 2 ? vUnprojected : [vUnprojected[0], vUnprojected[1], 0]; | ||
transformVector(matrix, vector) { | ||
const result = vec4.transformMat4([0, 0, 0, 0], vector, matrix); | ||
const result = vec4_transformMat4([0, 0, 0, 0], vector, matrix); | ||
const scale = 1 / result[3]; | ||
vec4.multiply(result, result, [scale, scale, scale, scale]); | ||
vec4_multiply(result, result, [scale, scale, scale, scale]); | ||
return result; | ||
@@ -219,5 +212,5 @@ } | ||
if (modelMatrix) { | ||
modelViewProjectionMatrix = mat4.multiply([], this.viewProjectionMatrix, modelMatrix); | ||
pixelProjectionMatrix = mat4.multiply([], this.pixelProjectionMatrix, modelMatrix); | ||
pixelUnprojectionMatrix = mat4.invert([], pixelProjectionMatrix); | ||
modelViewProjectionMatrix = mat4_multiply([], this.viewProjectionMatrix, modelMatrix); | ||
pixelProjectionMatrix = mat4_multiply([], this.pixelProjectionMatrix, modelMatrix); | ||
pixelUnprojectionMatrix = mat4_invert([], pixelProjectionMatrix); | ||
} | ||
@@ -256,5 +249,5 @@ | ||
// Helper, avoids low-precision 32 bit matrices from gl-matrix mat4.create() | ||
// Helper, avoids low-precision 32 bit matrices from mat4.create() | ||
export function createMat4() { | ||
return [1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1]; | ||
} |
Sorry, the diff of this file is too big to display
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
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
271805
22
2593
4
+ Addedgl-mat4@^1.1.4
+ Addedgl-vec2@^1.0.0
+ Addedgl-vec3@^1.0.3
+ Addedgl-vec4@^1.0.1
+ Addedgl-mat4@1.2.0(transitive)
+ Addedgl-vec2@1.3.0(transitive)
+ Addedgl-vec3@1.1.3(transitive)
+ Addedgl-vec4@1.0.1(transitive)
- Removedgl-matrix@^2.3.2
- Removedgl-matrix@2.8.1(transitive)