@antv/l7-map 2.5.37-mini → 2.5.37-mini10

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/lib/camera.js.map CHANGED
@@ -1 +1 @@
1
- {"version":3,"sources":["../src/camera.ts"],"names":["Camera","options","t","Math","min","easeStart","easeOptions","duration","onEaseFrame","easing","easeFrameId","requestRenderFrame","renderFrameCallback","stop","minZoom","maxZoom","minPitch","maxPitch","renderWorldCopies","moving","zooming","bearingSnap","transform","Transform","cb","_","center","lng","lat","LngLat","zoom","pitch","eventData","jumpTo","bearing","lnglat","easeTo","zoomTo","getZoom","padding","rotateTo","bounds","fitInternal","cameraForBounds","LngLatBounds","convert","cameraForBoxAndBearing","getNorthWest","getSouthEast","abs","getBearing","resetNorth","tr","zoomChanged","bearingChanged","pitchChanged","undefined","isPaddingEqual","emit","Event","offset","defaultEasing","animate","essential","startZoom","startBearing","startPitch","getPitch","startPadding","getPadding","normalizeBearing","offsetAsPoint","Point","pointAtOffset","centerPoint","add","locationAtOffset","pointLocation","normalizeCenter","from","project","delta","sub","finalScale","zoomScale","around","aroundPoint","locationPoint","currently","rotating","pitching","easeId","prepareEase","noMoveStart","clearTimeout","easeEndTimeoutID","ease","k","interpolatePadding","setLocationAtPoint","scale","base","max","speedup","pow","newCenter","unproject","mult","wrap","fireMoveEvents","interruptingEaseId","afterEase","coercedOptions","speed","curve","rho","w0","width","height","w1","u1","mag","wMax","sqrt","rho2","r","i","b","log","sinh","n","exp","cosh","tanh","r0","w","s","u","S","isFinite","V","screenSpeed","maxDuration","easeScale","scaleZoom","p0","p1","allowGestures","cancelRenderFrame","onEaseEnd","call","currentBearing","diff","lngRange","wasZooming","wasRotating","wasPitching","frame","finish","defaultPadding","top","bottom","right","left","p","edgePadding","p0world","p1world","p0rotated","rotate","PI","p1rotated","upperRight","x","y","lowerLeft","size","scaleX","scaleY","paddingOffsetX","paddingOffsetY","offsetAtInitialZoom","offsetAtFinalZoom","div","calculatedOptions","linear","flyTo","EventEmitter"],"mappings":"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","sourcesContent":["// @ts-ignore\nimport { EventEmitter } from 'eventemitter3';\nimport { merge } from 'lodash';\nimport { IPaddingOptions } from './geo/edge_insets';\nimport LngLat, { LngLatLike } from './geo/lng_lat';\nimport LngLatBounds, { LngLatBoundsLike } from './geo/lng_lat_bounds';\nimport Point, { PointLike } from './geo/point';\nimport Transform from './geo/transform';\nimport { Event } from './handler/events/event';\nimport { IMapOptions } from './interface';\ntype CallBack = (_: number) => void;\nimport {\n cancel,\n clamp,\n ease as defaultEasing,\n interpolate,\n now,\n pick,\n prefersReducedMotion,\n raf,\n wrap,\n} from './util';\n\nexport interface ICameraOptions {\n center?: LngLatLike;\n zoom?: number;\n bearing?: number;\n pitch?: number;\n around?: LngLatLike;\n padding?: IPaddingOptions;\n}\n\nexport interface IAnimationOptions {\n duration?: number;\n easing?: (_: number) => number;\n offset?: PointLike;\n animate?: boolean;\n essential?: boolean;\n linear?: boolean;\n}\n\nexport default class Camera extends EventEmitter {\n public transform: Transform;\n // public requestRenderFrame: (_: any) => number;\n // public cancelRenderFrame: (_: number) => void;\n protected options: IMapOptions;\n protected moving: boolean;\n protected zooming: boolean;\n protected rotating: boolean;\n protected pitching: boolean;\n protected padding: boolean;\n\n private bearingSnap: number;\n private easeEndTimeoutID: number;\n private easeStart: number;\n private easeOptions: {\n duration: number;\n easing: (_: number) => number;\n };\n private easeId: string | void;\n private onEaseFrame: (_: number) => void;\n private onEaseEnd: (easeId?: string) => void;\n private easeFrameId: number;\n\n constructor(options: IMapOptions) {\n super();\n this.options = options;\n const { minZoom, maxZoom, minPitch, maxPitch, renderWorldCopies } = options;\n this.moving = false;\n this.zooming = false;\n this.bearingSnap = options.bearingSnap;\n this.transform = new Transform(\n minZoom,\n maxZoom,\n minPitch,\n maxPitch,\n renderWorldCopies,\n );\n }\n public requestRenderFrame(cb: CallBack): number {\n return 0;\n }\n public cancelRenderFrame(_: number): void {\n return;\n }\n\n public getCenter() {\n const { lng, lat } = this.transform.center;\n return new LngLat(lng, lat);\n }\n\n public getZoom(): number {\n return this.transform.zoom;\n }\n\n public getPitch(): number {\n return this.transform.pitch;\n }\n\n public setCenter(center: LngLatLike, eventData?: any) {\n return this.jumpTo({ center }, eventData);\n }\n\n public setPitch(pitch: number, eventData?: any) {\n this.jumpTo({ pitch }, eventData);\n return this;\n }\n\n public getBearing(): number {\n return this.transform.bearing;\n }\n\n public panTo(\n lnglat: LngLatLike,\n options?: IAnimationOptions,\n eventData?: any,\n ) {\n return this.easeTo(\n merge(\n {\n center: lnglat,\n },\n options,\n ),\n eventData,\n );\n }\n\n public zoomOut(options?: IAnimationOptions, eventData?: any) {\n this.zoomTo(this.getZoom() - 1, options, eventData);\n return this;\n }\n\n public setBearing(bearing: number, eventData?: any) {\n this.jumpTo({ bearing }, eventData);\n return this;\n }\n public setZoom(zoom: number, eventData?: any) {\n this.jumpTo({ zoom }, eventData);\n return this;\n }\n\n public zoomIn(options?: IAnimationOptions, eventData?: any) {\n this.zoomTo(this.getZoom() + 1, options, eventData);\n return this;\n }\n\n public zoomTo(zoom: number, options?: IAnimationOptions, eventData?: any) {\n return this.easeTo(\n merge(\n {\n zoom,\n },\n options,\n ),\n eventData,\n );\n }\n\n public getPadding(): IPaddingOptions {\n return this.transform.padding;\n }\n\n public setPadding(padding: IPaddingOptions, eventData?: any) {\n this.jumpTo({ padding }, eventData);\n return this;\n }\n\n public rotateTo(\n bearing: number,\n options?: IAnimationOptions,\n eventData?: any,\n ) {\n return this.easeTo(\n merge(\n {\n bearing,\n },\n options,\n ),\n eventData,\n );\n }\n\n public resetNorth(options?: IAnimationOptions, eventData?: any) {\n this.rotateTo(0, merge({ duration: 1000 }, options), eventData);\n return this;\n }\n\n public resetNorthPitch(options?: IAnimationOptions, eventData?: any) {\n this.easeTo(\n merge(\n {\n bearing: 0,\n pitch: 0,\n duration: 1000,\n },\n options,\n ),\n eventData,\n );\n return this;\n }\n public fitBounds(\n bounds: LngLatBoundsLike,\n options?: IAnimationOptions & ICameraOptions,\n eventData?: any,\n ) {\n return this.fitInternal(\n // @ts-ignore\n this.cameraForBounds(bounds, options),\n options,\n eventData,\n );\n }\n public cameraForBounds(\n bounds: LngLatBoundsLike,\n options?: ICameraOptions,\n ): void | (ICameraOptions & IAnimationOptions) {\n bounds = LngLatBounds.convert(bounds);\n return this.cameraForBoxAndBearing(\n bounds.getNorthWest(),\n bounds.getSouthEast(),\n 0,\n // @ts-ignore\n options,\n );\n }\n\n public snapToNorth(options?: IAnimationOptions, eventData?: any) {\n if (Math.abs(this.getBearing()) < this.bearingSnap) {\n return this.resetNorth(options, eventData);\n }\n return this;\n }\n\n public jumpTo(options: ICameraOptions = {}, eventData?: any) {\n this.stop();\n\n const tr = this.transform;\n let zoomChanged = false;\n let bearingChanged = false;\n let pitchChanged = false;\n\n if (options.zoom && tr.zoom !== +options.zoom) {\n zoomChanged = true;\n tr.zoom = +options.zoom;\n }\n\n if (options.center !== undefined) {\n tr.center = LngLat.convert(options.center);\n }\n\n if (options.bearing && tr.bearing !== +options.bearing) {\n bearingChanged = true;\n tr.bearing = +options.bearing;\n }\n\n if (options.pitch && tr.pitch !== +options.pitch) {\n pitchChanged = true;\n tr.pitch = +options.pitch;\n }\n\n if (options.padding != null && !tr.isPaddingEqual(options.padding)) {\n tr.padding = options.padding;\n }\n\n this.emit('movestart', new Event('movestart', eventData));\n this.emit('move', new Event('move', eventData));\n\n if (zoomChanged) {\n this.emit('zoomstart', new Event('zoomstart', eventData));\n this.emit('zoom', new Event('zoom', eventData));\n this.emit('zoomend', new Event('zoomend', eventData));\n }\n\n if (bearingChanged) {\n this.emit('rotatestart', new Event('rotatestart', eventData));\n this.emit('rotate', new Event('rotate', eventData));\n this.emit('rotateend', new Event('rotateend', eventData));\n }\n\n if (pitchChanged) {\n this.emit('pitchstart', new Event('pitchstart', eventData));\n this.emit('pitch', new Event('pitch', eventData));\n this.emit('pitchend', new Event('pitchend', eventData));\n }\n\n return this.emit('moveend', new Event('moveend', eventData));\n }\n\n public easeTo(\n options: ICameraOptions &\n IAnimationOptions & { easeId?: string; noMoveStart?: boolean } = {},\n eventData?: any,\n ) {\n options = merge(\n {\n offset: [0, 0],\n duration: 500,\n easing: defaultEasing,\n },\n options,\n );\n\n if (\n options.animate === false ||\n (!options.essential && prefersReducedMotion())\n ) {\n options.duration = 0;\n }\n\n const tr = this.transform;\n const startZoom = this.getZoom();\n const startBearing = this.getBearing();\n const startPitch = this.getPitch();\n const startPadding = this.getPadding();\n\n const zoom = options.zoom ? +options.zoom : startZoom;\n const bearing = options.bearing\n ? this.normalizeBearing(options.bearing, startBearing)\n : startBearing;\n const pitch = options.pitch ? +options.pitch : startPitch;\n const padding = options.padding ? options.padding : tr.padding;\n\n const offsetAsPoint = Point.convert(options.offset);\n let pointAtOffset = tr.centerPoint.add(offsetAsPoint);\n const locationAtOffset = tr.pointLocation(pointAtOffset);\n const center = LngLat.convert(options.center || locationAtOffset);\n this.normalizeCenter(center);\n\n const from = tr.project(locationAtOffset);\n const delta = tr.project(center).sub(from);\n const finalScale = tr.zoomScale(zoom - startZoom);\n\n let around: LngLat;\n let aroundPoint: Point;\n\n if (options.around) {\n around = LngLat.convert(options.around);\n aroundPoint = tr.locationPoint(around);\n }\n\n const currently = {\n moving: this.moving,\n zooming: this.zooming,\n rotating: this.rotating,\n pitching: this.pitching,\n };\n\n this.zooming = this.zooming || zoom !== startZoom;\n this.rotating = this.rotating || startBearing !== bearing;\n this.pitching = this.pitching || pitch !== startPitch;\n this.padding = !tr.isPaddingEqual(padding);\n\n this.easeId = options.easeId;\n this.prepareEase(eventData, options.noMoveStart, currently);\n\n clearTimeout(this.easeEndTimeoutID);\n\n this.ease(\n (k) => {\n if (this.zooming) {\n tr.zoom = interpolate(startZoom, zoom, k);\n }\n if (this.rotating) {\n tr.bearing = interpolate(startBearing, bearing, k);\n }\n if (this.pitching) {\n tr.pitch = interpolate(startPitch, pitch, k);\n }\n if (this.padding) {\n tr.interpolatePadding(startPadding, padding, k);\n // When padding is being applied, Transform#centerPoint is changing continously,\n // thus we need to recalculate offsetPoint every fra,e\n pointAtOffset = tr.centerPoint.add(offsetAsPoint);\n }\n\n if (around) {\n tr.setLocationAtPoint(around, aroundPoint);\n } else {\n const scale = tr.zoomScale(tr.zoom - startZoom);\n const base =\n zoom > startZoom\n ? Math.min(2, finalScale)\n : Math.max(0.5, finalScale);\n const speedup = Math.pow(base, 1 - k);\n const newCenter = tr.unproject(\n from.add(delta.mult(k * speedup)).mult(scale),\n );\n tr.setLocationAtPoint(\n tr.renderWorldCopies ? newCenter.wrap() : newCenter,\n pointAtOffset,\n );\n }\n\n this.fireMoveEvents(eventData);\n },\n (interruptingEaseId?: string) => {\n this.afterEase(eventData, interruptingEaseId);\n },\n // @ts-ignore\n options,\n );\n\n return this;\n }\n public flyTo(options: any = {}, eventData?: any) {\n // Fall through to jumpTo if user has set prefers-reduced-motion\n if (!options.essential && prefersReducedMotion()) {\n const coercedOptions = pick(options, [\n 'center',\n 'zoom',\n 'bearing',\n 'pitch',\n 'around',\n ]) as ICameraOptions;\n return this.jumpTo(coercedOptions, eventData);\n }\n\n this.stop();\n\n options = merge(\n {\n offset: [0, 0],\n speed: 1.2,\n curve: 1.42,\n easing: defaultEasing,\n },\n options,\n );\n const tr = this.transform;\n const startZoom = this.getZoom();\n const startBearing = this.getBearing();\n const startPitch = this.getPitch();\n const startPadding = this.getPadding();\n\n const zoom = options.zoom\n ? clamp(+options.zoom, tr.minZoom, tr.maxZoom)\n : startZoom;\n const bearing = options.bearing\n ? this.normalizeBearing(options.bearing, startBearing)\n : startBearing;\n const pitch = options.pitch ? +options.pitch : startPitch;\n const padding = 'padding' in options ? options.padding : tr.padding;\n\n const scale = tr.zoomScale(zoom - startZoom);\n const offsetAsPoint = Point.convert(options.offset);\n let pointAtOffset = tr.centerPoint.add(offsetAsPoint);\n const locationAtOffset = tr.pointLocation(pointAtOffset);\n const center = LngLat.convert(options.center || locationAtOffset);\n this.normalizeCenter(center);\n\n const from = tr.project(locationAtOffset);\n const delta = tr.project(center).sub(from);\n\n let rho = options.curve;\n\n // w₀: Initial visible span, measured in pixels at the initial scale.\n const w0 = Math.max(tr.width, tr.height);\n // w₁: Final visible span, measured in pixels with respect to the initial scale.\n const w1 = w0 / scale;\n // Length of the flight path as projected onto the ground plane, measured in pixels from\n // the world image origin at the initial scale.\n const u1 = delta.mag();\n\n if ('minZoom' in options) {\n const minZoom = clamp(\n Math.min(options.minZoom, startZoom, zoom),\n tr.minZoom,\n tr.maxZoom,\n );\n // w<sub>m</sub>: Maximum visible span, measured in pixels with respect to the initial\n // scale.\n const wMax = w0 / tr.zoomScale(minZoom - startZoom);\n rho = Math.sqrt((wMax / u1) * 2);\n }\n\n // ρ²\n const rho2 = rho * rho;\n\n /**\n * rᵢ: Returns the zoom-out factor at one end of the animation.\n *\n * @param i 0 for the ascent or 1 for the descent.\n * @private\n */\n function r(i: number) {\n const b =\n (w1 * w1 - w0 * w0 + (i ? -1 : 1) * rho2 * rho2 * u1 * u1) /\n (2 * (i ? w1 : w0) * rho2 * u1);\n return Math.log(Math.sqrt(b * b + 1) - b);\n }\n\n function sinh(n: number) {\n return (Math.exp(n) - Math.exp(-n)) / 2;\n }\n function cosh(n: number) {\n return (Math.exp(n) + Math.exp(-n)) / 2;\n }\n function tanh(n: number) {\n return sinh(n) / cosh(n);\n }\n\n // r₀: Zoom-out factor during ascent.\n const r0 = r(0);\n\n // w(s): Returns the visible span on the ground, measured in pixels with respect to the\n // initial scale. Assumes an angular field of view of 2 arctan ½ ≈ 53°.\n let w: (_: number) => number = (s) => {\n return cosh(r0) / cosh(r0 + rho * s);\n };\n\n // u(s): Returns the distance along the flight path as projected onto the ground plane,\n // measured in pixels from the world image origin at the initial scale.\n let u: (_: number) => number = (s) => {\n return (w0 * ((cosh(r0) * tanh(r0 + rho * s) - sinh(r0)) / rho2)) / u1;\n };\n\n // S: Total length of the flight path, measured in ρ-screenfuls.\n let S = (r(1) - r0) / rho;\n\n // When u₀ = u₁, the optimal path doesn’t require both ascent and descent.\n if (Math.abs(u1) < 0.000001 || !isFinite(S)) {\n // Perform a more or less instantaneous transition if the path is too short.\n if (Math.abs(w0 - w1) < 0.000001) {\n return this.easeTo(options, eventData);\n }\n\n const k = w1 < w0 ? -1 : 1;\n S = Math.abs(Math.log(w1 / w0)) / rho;\n\n u = () => {\n return 0;\n };\n w = (s) => {\n return Math.exp(k * rho * s);\n };\n }\n\n if ('duration' in options) {\n options.duration = +options.duration;\n } else {\n const V =\n 'screenSpeed' in options ? +options.screenSpeed / rho : +options.speed;\n options.duration = (1000 * S) / V;\n }\n\n if (options.maxDuration && options.duration > options.maxDuration) {\n options.duration = 0;\n }\n\n this.zooming = true;\n this.rotating = startBearing !== bearing;\n this.pitching = pitch !== startPitch;\n this.padding = !tr.isPaddingEqual(padding);\n\n this.prepareEase(eventData, false);\n\n this.ease(\n (k) => {\n // s: The distance traveled along the flight path, measured in ρ-screenfuls.\n const s = k * S;\n // @ts-ignore\n const easeScale = 1 / w(s);\n tr.zoom = k === 1 ? zoom : startZoom + tr.scaleZoom(easeScale);\n\n if (this.rotating) {\n tr.bearing = interpolate(startBearing, bearing, k);\n }\n if (this.pitching) {\n tr.pitch = interpolate(startPitch, pitch, k);\n }\n if (this.padding) {\n tr.interpolatePadding(startPadding, padding, k);\n // When padding is being applied, Transform#centerPoint is changing continously,\n // thus we need to recalculate offsetPoint every frame\n pointAtOffset = tr.centerPoint.add(offsetAsPoint);\n }\n\n const newCenter =\n k === 1\n ? center\n : tr.unproject(from.add(delta.mult(u(s))).mult(easeScale));\n tr.setLocationAtPoint(\n tr.renderWorldCopies ? newCenter.wrap() : newCenter,\n pointAtOffset,\n );\n\n this.fireMoveEvents(eventData);\n },\n () => this.afterEase(eventData),\n options,\n );\n\n return this;\n }\n public fitScreenCoordinates(\n p0: PointLike,\n p1: PointLike,\n bearing: number,\n options?: IAnimationOptions & ICameraOptions,\n eventData?: any,\n ) {\n return this.fitInternal(\n // @ts-ignore\n this.cameraForBoxAndBearing(\n this.transform.pointLocation(Point.convert(p0)),\n this.transform.pointLocation(Point.convert(p1)),\n bearing,\n // @ts-ignore\n options,\n ),\n options,\n eventData,\n );\n }\n public stop(allowGestures?: boolean, easeId?: string) {\n if (this.easeFrameId) {\n this.cancelRenderFrame(this.easeFrameId);\n // @ts-ignore\n delete this.easeFrameId;\n // @ts-ignore\n delete this.onEaseFrame;\n }\n\n if (this.onEaseEnd) {\n // The _onEaseEnd function might emit events which trigger new\n // animation, which sets a new _onEaseEnd. Ensure we don't delete\n // it unintentionally.\n const onEaseEnd = this.onEaseEnd;\n // @ts-ignore\n delete this.onEaseEnd;\n onEaseEnd.call(this, easeId);\n }\n // if (!allowGestures) {\n // const handlers = (this: any).handlers;\n // if (handlers) handlers.stop();\n // }\n return this;\n }\n public renderFrameCallback = () => {\n const t = Math.min((now() - this.easeStart) / this.easeOptions.duration, 1);\n this.onEaseFrame(this.easeOptions.easing(t));\n if (t < 1) {\n // this.easeFrameId = window.requestAnimationFrame(this.renderFrameCallback);\n this.easeFrameId = this.requestRenderFrame(this.renderFrameCallback);\n } else {\n this.stop();\n }\n };\n private normalizeBearing(bearing: number, currentBearing: number) {\n bearing = wrap(bearing, -180, 180);\n const diff = Math.abs(bearing - currentBearing);\n if (Math.abs(bearing - 360 - currentBearing) < diff) {\n bearing -= 360;\n }\n if (Math.abs(bearing + 360 - currentBearing) < diff) {\n bearing += 360;\n }\n return bearing;\n }\n\n private normalizeCenter(center: LngLat) {\n const tr = this.transform;\n if (!tr.renderWorldCopies || tr.lngRange) {\n return;\n }\n\n const delta = center.lng - tr.center.lng;\n center.lng += delta > 180 ? -360 : delta < -180 ? 360 : 0;\n }\n\n private fireMoveEvents(eventData?: any) {\n this.emit('move', new Event('move', eventData));\n if (this.zooming) {\n this.emit('zoom', new Event('zoom', eventData));\n }\n if (this.rotating) {\n this.emit('rotate', new Event('rotate', eventData));\n }\n if (this.pitching) {\n this.emit('rotate', new Event('pitch', eventData));\n }\n }\n private prepareEase(\n eventData: object | undefined,\n noMoveStart: boolean = false,\n currently: { [key: string]: boolean } = {},\n ) {\n this.moving = true;\n\n if (!noMoveStart && !currently.moving) {\n this.emit('movestart', new Event('movestart', eventData));\n }\n if (this.zooming && !currently.zooming) {\n this.emit('zoomstart', new Event('zoomstart', eventData));\n }\n if (this.rotating && !currently.rotating) {\n this.emit('rotatestart', new Event('rotatestart', eventData));\n }\n if (this.pitching && !currently.pitching) {\n this.emit('pitchstart', new Event('pitchstart', eventData));\n }\n }\n\n private afterEase(eventData: object | undefined, easeId?: string) {\n // if this easing is being stopped to start another easing with\n // the same id then don't fire any events to avoid extra start/stop events\n if (this.easeId && easeId && this.easeId === easeId) {\n return;\n }\n delete this.easeId;\n\n const wasZooming = this.zooming;\n const wasRotating = this.rotating;\n const wasPitching = this.pitching;\n this.moving = false;\n this.zooming = false;\n this.rotating = false;\n this.pitching = false;\n this.padding = false;\n\n if (wasZooming) {\n this.emit('zoomend', new Event('zoomend', eventData));\n }\n if (wasRotating) {\n this.emit('rotateend', new Event('rotateend', eventData));\n }\n if (wasPitching) {\n this.emit('pitchend', new Event('pitchend', eventData));\n }\n this.emit('moveend', new Event('moveend', eventData));\n }\n\n private ease(\n frame: (_: number) => void,\n finish: () => void,\n options: {\n animate: boolean;\n duration: number;\n easing: (_: number) => number;\n },\n ) {\n if (options.animate === false || options.duration === 0) {\n frame(1);\n finish();\n } else {\n this.easeStart = now();\n this.easeOptions = options;\n this.onEaseFrame = frame;\n this.onEaseEnd = finish;\n this.easeFrameId = this.requestRenderFrame(this.renderFrameCallback);\n }\n }\n\n private cameraForBoxAndBearing(\n p0: LngLatLike,\n p1: LngLatLike,\n bearing: number,\n options?: ICameraOptions & {\n offset: [number, number];\n maxZoom: number;\n padding: IPaddingOptions;\n },\n ): void | (ICameraOptions & IAnimationOptions) {\n const defaultPadding = {\n top: 0,\n bottom: 0,\n right: 0,\n left: 0,\n };\n options = merge(\n {\n padding: defaultPadding,\n offset: [0, 0],\n maxZoom: this.transform.maxZoom,\n },\n options,\n );\n\n if (typeof options.padding === 'number') {\n const p = options.padding;\n options.padding = {\n top: p,\n bottom: p,\n right: p,\n left: p,\n };\n }\n\n options.padding = merge(defaultPadding, options.padding);\n const tr = this.transform;\n const edgePadding = tr.padding as IPaddingOptions;\n\n // We want to calculate the upper right and lower left of the box defined by p0 and p1\n // in a coordinate system rotate to match the destination bearing.\n const p0world = tr.project(LngLat.convert(p0));\n const p1world = tr.project(LngLat.convert(p1));\n const p0rotated = p0world.rotate((-bearing * Math.PI) / 180);\n const p1rotated = p1world.rotate((-bearing * Math.PI) / 180);\n\n const upperRight = new Point(\n Math.max(p0rotated.x, p1rotated.x),\n Math.max(p0rotated.y, p1rotated.y),\n );\n const lowerLeft = new Point(\n Math.min(p0rotated.x, p1rotated.x),\n Math.min(p0rotated.y, p1rotated.y),\n );\n\n // Calculate zoom: consider the original bbox and padding.\n const size = upperRight.sub(lowerLeft);\n const scaleX =\n (tr.width -\n // @ts-ignore\n (edgePadding.left +\n // @ts-ignore\n edgePadding.right +\n // @ts-ignore\n options.padding.left +\n // @ts-ignore\n options.padding.right)) /\n size.x;\n const scaleY =\n (tr.height -\n // @ts-ignore\n (edgePadding.top +\n // @ts-ignore\n edgePadding.bottom +\n // @ts-ignore\n options.padding.top +\n // @ts-ignore\n options.padding.bottom)) /\n size.y;\n\n if (scaleY < 0 || scaleX < 0) {\n return;\n }\n\n const zoom = Math.min(\n tr.scaleZoom(tr.scale * Math.min(scaleX, scaleY)),\n options.maxZoom,\n );\n\n // Calculate center: apply the zoom, the configured offset, as well as offset that exists as a result of padding.\n const offset = Point.convert(options.offset);\n // @ts-ignore\n const paddingOffsetX = (options.padding.left - options.padding.right) / 2;\n // @ts-ignore\n const paddingOffsetY = (options.padding.top - options.padding.bottom) / 2;\n const offsetAtInitialZoom = new Point(\n offset.x + paddingOffsetX,\n offset.y + paddingOffsetY,\n );\n const offsetAtFinalZoom = offsetAtInitialZoom.mult(\n tr.scale / tr.zoomScale(zoom),\n );\n\n const center = tr.unproject(\n p0world\n .add(p1world)\n .div(2)\n .sub(offsetAtFinalZoom),\n );\n\n return {\n center,\n zoom,\n bearing,\n };\n }\n\n private fitInternal(\n calculatedOptions?: ICameraOptions & IAnimationOptions,\n options?: IAnimationOptions & ICameraOptions,\n eventData?: any,\n ) {\n // cameraForBounds warns + returns undefined if unable to fit:\n if (!calculatedOptions) {\n return this;\n }\n\n options = merge(calculatedOptions, options);\n // Explictly remove the padding field because, calculatedOptions already accounts for padding by setting zoom and center accordingly.\n delete options.padding;\n // @ts-ignore\n return options.linear\n ? this.easeTo(options, eventData)\n : this.flyTo(options, eventData);\n }\n}\n"],"file":"camera.js"}
1
+ {"version":3,"sources":["../src/camera.ts"],"names":["Camera","options","t","Math","min","easeStart","easeOptions","duration","onEaseFrame","easing","easeFrameId","requestRenderFrame","renderFrameCallback","stop","minZoom","maxZoom","minPitch","maxPitch","renderWorldCopies","moving","zooming","bearingSnap","transform","Transform","cb","_","center","lng","lat","LngLat","zoom","pitch","eventData","jumpTo","bearing","lnglat","easeTo","zoomTo","getZoom","padding","rotateTo","bounds","fitInternal","cameraForBounds","LngLatBounds","convert","cameraForBoxAndBearing","getNorthWest","getSouthEast","abs","getBearing","resetNorth","tr","zoomChanged","bearingChanged","pitchChanged","undefined","isPaddingEqual","emit","Event","offset","defaultEasing","animate","essential","startZoom","startBearing","startPitch","getPitch","startPadding","getPadding","normalizeBearing","offsetAsPoint","Point","pointAtOffset","centerPoint","add","locationAtOffset","pointLocation","normalizeCenter","from","project","delta","sub","finalScale","zoomScale","around","aroundPoint","locationPoint","currently","rotating","pitching","easeId","prepareEase","noMoveStart","clearTimeout","easeEndTimeoutID","ease","k","interpolatePadding","setLocationAtPoint","scale","base","max","speedup","pow","newCenter","unproject","mult","wrap","fireMoveEvents","interruptingEaseId","afterEase","coercedOptions","speed","curve","rho","w0","width","height","w1","u1","mag","wMax","sqrt","rho2","r","i","b","log","sinh","n","exp","cosh","tanh","r0","w","s","u","S","isFinite","V","screenSpeed","maxDuration","easeScale","scaleZoom","p0","p1","allowGestures","cancelRenderFrame","onEaseEnd","call","currentBearing","diff","lngRange","wasZooming","wasRotating","wasPitching","frame","finish","defaultPadding","top","bottom","right","left","p","edgePadding","p0world","p1world","p0rotated","rotate","PI","p1rotated","upperRight","x","y","lowerLeft","size","scaleX","scaleY","paddingOffsetX","paddingOffsetY","offsetAtInitialZoom","offsetAtFinalZoom","div","calculatedOptions","linear","flyTo","EventEmitter"],"mappings":"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","sourcesContent":["// @ts-ignore\nimport { EventEmitter } from 'eventemitter3';\nimport { merge } from 'lodash';\nimport { IPaddingOptions } from './geo/edge_insets';\nimport LngLat, { LngLatLike } from './geo/lng_lat';\nimport LngLatBounds, { LngLatBoundsLike } from './geo/lng_lat_bounds';\nimport Point, { PointLike } from './geo/point';\nimport Transform from './geo/transform';\nimport { Event } from './handler/events/event';\nimport { IMapOptions } from './interface';\ntype CallBack = (_: number) => void;\nimport {\n cancel,\n clamp,\n ease as defaultEasing,\n interpolate,\n now,\n pick,\n prefersReducedMotion,\n raf,\n wrap,\n} from './util';\n\nexport interface ICameraOptions {\n center?: LngLatLike;\n zoom?: number;\n bearing?: number;\n pitch?: number;\n around?: LngLatLike;\n padding?: IPaddingOptions;\n}\n\nexport interface IAnimationOptions {\n duration?: number;\n easing?: (_: number) => number;\n offset?: PointLike;\n animate?: boolean;\n essential?: boolean;\n linear?: boolean;\n}\n\nexport default class Camera extends EventEmitter {\n public transform: Transform;\n // public requestRenderFrame: (_: any) => number;\n // public cancelRenderFrame: (_: number) => void;\n protected options: IMapOptions;\n protected moving: boolean;\n protected zooming: boolean;\n protected rotating: boolean;\n protected pitching: boolean;\n protected padding: boolean;\n\n private bearingSnap: number;\n private easeEndTimeoutID: number;\n private easeStart: number;\n private easeOptions: {\n duration: number;\n easing: (_: number) => number;\n };\n private easeId: string | void;\n private onEaseFrame: (_: number) => void;\n private onEaseEnd: (easeId?: string) => void;\n private easeFrameId: number;\n\n constructor(options: IMapOptions) {\n super();\n this.options = options;\n const { minZoom, maxZoom, minPitch, maxPitch, renderWorldCopies } = options;\n this.moving = false;\n this.zooming = false;\n this.bearingSnap = options.bearingSnap;\n this.transform = new Transform(\n minZoom,\n maxZoom,\n minPitch,\n maxPitch,\n renderWorldCopies,\n );\n }\n public requestRenderFrame(cb: CallBack): number {\n return 0;\n }\n public cancelRenderFrame(_: number): void {\n return;\n }\n\n public getCenter() {\n const { lng, lat } = this.transform.center;\n return new LngLat(lng, lat);\n }\n\n public getZoom(): number {\n return this.transform.zoom;\n }\n\n public getPitch(): number {\n return this.transform.pitch;\n }\n\n public setCenter(center: LngLatLike, eventData?: any) {\n return this.jumpTo({ center }, eventData);\n }\n\n public setPitch(pitch: number, eventData?: any) {\n this.jumpTo({ pitch }, eventData);\n return this;\n }\n\n public getBearing(): number {\n return this.transform.bearing;\n }\n\n public panTo(\n lnglat: LngLatLike,\n options?: IAnimationOptions,\n eventData?: any,\n ) {\n return this.easeTo(\n merge(\n {\n center: lnglat,\n },\n options,\n ),\n eventData,\n );\n }\n\n public zoomOut(options?: IAnimationOptions, eventData?: any) {\n this.zoomTo(this.getZoom() - 1, options, eventData);\n return this;\n }\n\n public setBearing(bearing: number, eventData?: any) {\n this.jumpTo({ bearing }, eventData);\n return this;\n }\n public setZoom(zoom: number, eventData?: any) {\n this.jumpTo({ zoom }, eventData);\n return this;\n }\n\n public zoomIn(options?: IAnimationOptions, eventData?: any) {\n this.zoomTo(this.getZoom() + 1, options, eventData);\n return this;\n }\n\n public zoomTo(zoom: number, options?: IAnimationOptions, eventData?: any) {\n return this.easeTo(\n merge(\n {\n zoom,\n },\n options,\n ),\n eventData,\n );\n }\n\n public getPadding(): IPaddingOptions {\n return this.transform.padding;\n }\n\n public setPadding(padding: IPaddingOptions, eventData?: any) {\n this.jumpTo({ padding }, eventData);\n return this;\n }\n\n public rotateTo(\n bearing: number,\n options?: IAnimationOptions,\n eventData?: any,\n ) {\n return this.easeTo(\n merge(\n {\n bearing,\n },\n options,\n ),\n eventData,\n );\n }\n\n public resetNorth(options?: IAnimationOptions, eventData?: any) {\n this.rotateTo(0, merge({ duration: 1000 }, options), eventData);\n return this;\n }\n\n public resetNorthPitch(options?: IAnimationOptions, eventData?: any) {\n this.easeTo(\n merge(\n {\n bearing: 0,\n pitch: 0,\n duration: 1000,\n },\n options,\n ),\n eventData,\n );\n return this;\n }\n public fitBounds(\n bounds: LngLatBoundsLike,\n options?: IAnimationOptions & ICameraOptions,\n eventData?: any,\n ) {\n return this.fitInternal(\n // @ts-ignore\n this.cameraForBounds(bounds, options),\n options,\n eventData,\n );\n }\n public cameraForBounds(\n bounds: LngLatBoundsLike,\n options?: ICameraOptions,\n ): void | (ICameraOptions & IAnimationOptions) {\n bounds = LngLatBounds.convert(bounds);\n return this.cameraForBoxAndBearing(\n bounds.getNorthWest(),\n bounds.getSouthEast(),\n 0,\n // @ts-ignore\n options,\n );\n }\n\n public snapToNorth(options?: IAnimationOptions, eventData?: any) {\n if (Math.abs(this.getBearing()) < this.bearingSnap) {\n return this.resetNorth(options, eventData);\n }\n return this;\n }\n\n public jumpTo(options: ICameraOptions = {}, eventData?: any) {\n this.stop();\n\n const tr = this.transform;\n let zoomChanged = false;\n let bearingChanged = false;\n let pitchChanged = false;\n\n if (options.zoom && tr.zoom !== +options.zoom) {\n zoomChanged = true;\n tr.zoom = +options.zoom;\n }\n\n if (options.center !== undefined) {\n tr.center = LngLat.convert(options.center);\n }\n\n if (options.bearing && tr.bearing !== +options.bearing) {\n bearingChanged = true;\n tr.bearing = +options.bearing;\n }\n\n if (options.pitch && tr.pitch !== +options.pitch) {\n pitchChanged = true;\n tr.pitch = +options.pitch;\n }\n\n if (options.padding != null && !tr.isPaddingEqual(options.padding)) {\n tr.padding = options.padding;\n }\n\n this.emit('movestart', new Event('movestart', eventData));\n this.emit('move', new Event('move', eventData));\n\n if (zoomChanged) {\n this.emit('zoomstart', new Event('zoomstart', eventData));\n this.emit('zoom', new Event('zoom', eventData));\n this.emit('zoomend', new Event('zoomend', eventData));\n }\n\n if (bearingChanged) {\n this.emit('rotatestart', new Event('rotatestart', eventData));\n this.emit('rotate', new Event('rotate', eventData));\n this.emit('rotateend', new Event('rotateend', eventData));\n }\n\n if (pitchChanged) {\n this.emit('pitchstart', new Event('pitchstart', eventData));\n this.emit('pitch', new Event('pitch', eventData));\n this.emit('pitchend', new Event('pitchend', eventData));\n }\n\n return this.emit('moveend', new Event('moveend', eventData));\n }\n\n public easeTo(\n options: ICameraOptions &\n IAnimationOptions & { easeId?: string; noMoveStart?: boolean } = {},\n eventData?: any,\n ) {\n options = merge(\n {\n offset: [0, 0],\n duration: 500,\n easing: defaultEasing,\n },\n options,\n );\n\n if (\n options.animate === false ||\n (!options.essential && prefersReducedMotion())\n ) {\n options.duration = 0;\n }\n\n const tr = this.transform;\n const startZoom = this.getZoom();\n const startBearing = this.getBearing();\n const startPitch = this.getPitch();\n const startPadding = this.getPadding();\n\n const zoom = options.zoom ? +options.zoom : startZoom;\n const bearing = options.bearing\n ? this.normalizeBearing(options.bearing, startBearing)\n : startBearing;\n const pitch = options.pitch ? +options.pitch : startPitch;\n const padding = options.padding ? options.padding : tr.padding;\n\n const offsetAsPoint = Point.convert(options.offset);\n let pointAtOffset = tr.centerPoint.add(offsetAsPoint);\n const locationAtOffset = tr.pointLocation(pointAtOffset);\n const center = LngLat.convert(options.center || locationAtOffset);\n this.normalizeCenter(center);\n\n const from = tr.project(locationAtOffset);\n const delta = tr.project(center).sub(from);\n const finalScale = tr.zoomScale(zoom - startZoom);\n\n let around: LngLat;\n let aroundPoint: Point;\n\n if (options.around) {\n around = LngLat.convert(options.around);\n aroundPoint = tr.locationPoint(around);\n }\n\n const currently = {\n moving: this.moving,\n zooming: this.zooming,\n rotating: this.rotating,\n pitching: this.pitching,\n };\n\n this.zooming = this.zooming || zoom !== startZoom;\n this.rotating = this.rotating || startBearing !== bearing;\n this.pitching = this.pitching || pitch !== startPitch;\n this.padding = !tr.isPaddingEqual(padding);\n\n this.easeId = options.easeId;\n this.prepareEase(eventData, options.noMoveStart, currently);\n\n clearTimeout(this.easeEndTimeoutID);\n\n this.ease(\n (k) => {\n if (this.zooming) {\n tr.zoom = interpolate(startZoom, zoom, k);\n }\n if (this.rotating) {\n tr.bearing = interpolate(startBearing, bearing, k);\n }\n if (this.pitching) {\n tr.pitch = interpolate(startPitch, pitch, k);\n }\n if (this.padding) {\n tr.interpolatePadding(startPadding, padding, k);\n // When padding is being applied, Transform#centerPoint is changing continously,\n // thus we need to recalculate offsetPoint every fra,e\n pointAtOffset = tr.centerPoint.add(offsetAsPoint);\n }\n\n if (around) {\n tr.setLocationAtPoint(around, aroundPoint);\n } else {\n const scale = tr.zoomScale(tr.zoom - startZoom);\n const base =\n zoom > startZoom\n ? Math.min(2, finalScale)\n : Math.max(0.5, finalScale);\n const speedup = Math.pow(base, 1 - k);\n const newCenter = tr.unproject(\n from.add(delta.mult(k * speedup)).mult(scale),\n );\n tr.setLocationAtPoint(\n tr.renderWorldCopies ? newCenter.wrap() : newCenter,\n pointAtOffset,\n );\n }\n\n this.fireMoveEvents(eventData);\n },\n (interruptingEaseId?: string) => {\n this.afterEase(eventData, interruptingEaseId);\n },\n // @ts-ignore\n options,\n );\n\n return this;\n }\n public flyTo(options: any = {}, eventData?: any) {\n // Fall through to jumpTo if user has set prefers-reduced-motion\n if (!options.essential && prefersReducedMotion()) {\n const coercedOptions = pick(options, [\n 'center',\n 'zoom',\n 'bearing',\n 'pitch',\n 'around',\n ]) as ICameraOptions;\n return this.jumpTo(coercedOptions, eventData);\n }\n\n this.stop();\n\n options = merge(\n {\n offset: [0, 0],\n speed: 1.2,\n curve: 1.42,\n easing: defaultEasing,\n },\n options,\n );\n const tr = this.transform;\n const startZoom = this.getZoom();\n const startBearing = this.getBearing();\n const startPitch = this.getPitch();\n const startPadding = this.getPadding();\n\n const zoom = options.zoom\n ? clamp(+options.zoom, tr.minZoom, tr.maxZoom)\n : startZoom;\n const bearing = options.bearing\n ? this.normalizeBearing(options.bearing, startBearing)\n : startBearing;\n const pitch = options.pitch ? +options.pitch : startPitch;\n const padding = 'padding' in options ? options.padding : tr.padding;\n\n const scale = tr.zoomScale(zoom - startZoom);\n const offsetAsPoint = Point.convert(options.offset);\n let pointAtOffset = tr.centerPoint.add(offsetAsPoint);\n const locationAtOffset = tr.pointLocation(pointAtOffset);\n const center = LngLat.convert(options.center || locationAtOffset);\n this.normalizeCenter(center);\n\n const from = tr.project(locationAtOffset);\n const delta = tr.project(center).sub(from);\n\n let rho = options.curve;\n\n // w₀: Initial visible span, measured in pixels at the initial scale.\n const w0 = Math.max(tr.width, tr.height);\n // w₁: Final visible span, measured in pixels with respect to the initial scale.\n const w1 = w0 / scale;\n // Length of the flight path as projected onto the ground plane, measured in pixels from\n // the world image origin at the initial scale.\n const u1 = delta.mag();\n\n if ('minZoom' in options) {\n const minZoom = clamp(\n Math.min(options.minZoom, startZoom, zoom),\n tr.minZoom,\n tr.maxZoom,\n );\n // w<sub>m</sub>: Maximum visible span, measured in pixels with respect to the initial\n // scale.\n const wMax = w0 / tr.zoomScale(minZoom - startZoom);\n rho = Math.sqrt((wMax / u1) * 2);\n }\n\n // ρ²\n const rho2 = rho * rho;\n\n /**\n * rᵢ: Returns the zoom-out factor at one end of the animation.\n *\n * @param i 0 for the ascent or 1 for the descent.\n * @private\n */\n function r(i: number) {\n const b =\n (w1 * w1 - w0 * w0 + (i ? -1 : 1) * rho2 * rho2 * u1 * u1) /\n (2 * (i ? w1 : w0) * rho2 * u1);\n return Math.log(Math.sqrt(b * b + 1) - b);\n }\n\n function sinh(n: number) {\n return (Math.exp(n) - Math.exp(-n)) / 2;\n }\n function cosh(n: number) {\n return (Math.exp(n) + Math.exp(-n)) / 2;\n }\n function tanh(n: number) {\n return sinh(n) / cosh(n);\n }\n\n // r₀: Zoom-out factor during ascent.\n const r0 = r(0);\n\n // w(s): Returns the visible span on the ground, measured in pixels with respect to the\n // initial scale. Assumes an angular field of view of 2 arctan ½ ≈ 53°.\n let w: (_: number) => number = (s) => {\n return cosh(r0) / cosh(r0 + rho * s);\n };\n\n // u(s): Returns the distance along the flight path as projected onto the ground plane,\n // measured in pixels from the world image origin at the initial scale.\n let u: (_: number) => number = (s) => {\n return (w0 * ((cosh(r0) * tanh(r0 + rho * s) - sinh(r0)) / rho2)) / u1;\n };\n\n // S: Total length of the flight path, measured in ρ-screenfuls.\n let S = (r(1) - r0) / rho;\n\n // When u₀ = u₁, the optimal path doesn’t require both ascent and descent.\n if (Math.abs(u1) < 0.000001 || !isFinite(S)) {\n // Perform a more or less instantaneous transition if the path is too short.\n if (Math.abs(w0 - w1) < 0.000001) {\n return this.easeTo(options, eventData);\n }\n\n const k = w1 < w0 ? -1 : 1;\n S = Math.abs(Math.log(w1 / w0)) / rho;\n\n u = () => {\n return 0;\n };\n w = (s) => {\n return Math.exp(k * rho * s);\n };\n }\n\n if ('duration' in options) {\n options.duration = +options.duration;\n } else {\n const V =\n 'screenSpeed' in options ? +options.screenSpeed / rho : +options.speed;\n options.duration = (1000 * S) / V;\n }\n\n if (options.maxDuration && options.duration > options.maxDuration) {\n options.duration = 0;\n }\n\n this.zooming = true;\n this.rotating = startBearing !== bearing;\n this.pitching = pitch !== startPitch;\n this.padding = !tr.isPaddingEqual(padding);\n\n this.prepareEase(eventData, false);\n\n this.ease(\n (k) => {\n // s: The distance traveled along the flight path, measured in ρ-screenfuls.\n const s = k * S;\n // @ts-ignore\n const easeScale = 1 / w(s);\n tr.zoom = k === 1 ? zoom : startZoom + tr.scaleZoom(easeScale);\n\n if (this.rotating) {\n tr.bearing = interpolate(startBearing, bearing, k);\n }\n if (this.pitching) {\n tr.pitch = interpolate(startPitch, pitch, k);\n }\n if (this.padding) {\n tr.interpolatePadding(startPadding, padding, k);\n // When padding is being applied, Transform#centerPoint is changing continously,\n // thus we need to recalculate offsetPoint every frame\n pointAtOffset = tr.centerPoint.add(offsetAsPoint);\n }\n\n const newCenter =\n k === 1\n ? center\n : tr.unproject(from.add(delta.mult(u(s))).mult(easeScale));\n tr.setLocationAtPoint(\n tr.renderWorldCopies ? newCenter.wrap() : newCenter,\n pointAtOffset,\n );\n\n this.fireMoveEvents(eventData);\n },\n () => this.afterEase(eventData),\n options,\n );\n\n return this;\n }\n public fitScreenCoordinates(\n p0: PointLike,\n p1: PointLike,\n bearing: number,\n options?: IAnimationOptions & ICameraOptions,\n eventData?: any,\n ) {\n return this.fitInternal(\n // @ts-ignore\n this.cameraForBoxAndBearing(\n this.transform.pointLocation(Point.convert(p0)),\n this.transform.pointLocation(Point.convert(p1)),\n bearing,\n // @ts-ignore\n options,\n ),\n options,\n eventData,\n );\n }\n public stop(allowGestures?: boolean, easeId?: string) {\n if (this.easeFrameId) {\n this.cancelRenderFrame(this.easeFrameId);\n delete this.easeFrameId;\n delete this.onEaseFrame;\n }\n\n if (this.onEaseEnd) {\n // The _onEaseEnd function might emit events which trigger new\n // animation, which sets a new _onEaseEnd. Ensure we don't delete\n // it unintentionally.\n const onEaseEnd = this.onEaseEnd;\n delete this.onEaseEnd;\n onEaseEnd.call(this, easeId);\n }\n // if (!allowGestures) {\n // const handlers = (this: any).handlers;\n // if (handlers) handlers.stop();\n // }\n return this;\n }\n public renderFrameCallback = () => {\n const t = Math.min((now() - this.easeStart) / this.easeOptions.duration, 1);\n this.onEaseFrame(this.easeOptions.easing(t));\n if (t < 1) {\n // this.easeFrameId = window.requestAnimationFrame(this.renderFrameCallback);\n this.easeFrameId = this.requestRenderFrame(this.renderFrameCallback);\n } else {\n this.stop();\n }\n };\n private normalizeBearing(bearing: number, currentBearing: number) {\n bearing = wrap(bearing, -180, 180);\n const diff = Math.abs(bearing - currentBearing);\n if (Math.abs(bearing - 360 - currentBearing) < diff) {\n bearing -= 360;\n }\n if (Math.abs(bearing + 360 - currentBearing) < diff) {\n bearing += 360;\n }\n return bearing;\n }\n\n private normalizeCenter(center: LngLat) {\n const tr = this.transform;\n if (!tr.renderWorldCopies || tr.lngRange) {\n return;\n }\n\n const delta = center.lng - tr.center.lng;\n center.lng += delta > 180 ? -360 : delta < -180 ? 360 : 0;\n }\n\n private fireMoveEvents(eventData?: any) {\n this.emit('move', new Event('move', eventData));\n if (this.zooming) {\n this.emit('zoom', new Event('zoom', eventData));\n }\n if (this.rotating) {\n this.emit('rotate', new Event('rotate', eventData));\n }\n if (this.pitching) {\n this.emit('rotate', new Event('pitch', eventData));\n }\n }\n private prepareEase(\n eventData: object | undefined,\n noMoveStart: boolean = false,\n currently: { [key: string]: boolean } = {},\n ) {\n this.moving = true;\n\n if (!noMoveStart && !currently.moving) {\n this.emit('movestart', new Event('movestart', eventData));\n }\n if (this.zooming && !currently.zooming) {\n this.emit('zoomstart', new Event('zoomstart', eventData));\n }\n if (this.rotating && !currently.rotating) {\n this.emit('rotatestart', new Event('rotatestart', eventData));\n }\n if (this.pitching && !currently.pitching) {\n this.emit('pitchstart', new Event('pitchstart', eventData));\n }\n }\n\n private afterEase(eventData: object | undefined, easeId?: string) {\n // if this easing is being stopped to start another easing with\n // the same id then don't fire any events to avoid extra start/stop events\n if (this.easeId && easeId && this.easeId === easeId) {\n return;\n }\n delete this.easeId;\n\n const wasZooming = this.zooming;\n const wasRotating = this.rotating;\n const wasPitching = this.pitching;\n this.moving = false;\n this.zooming = false;\n this.rotating = false;\n this.pitching = false;\n this.padding = false;\n\n if (wasZooming) {\n this.emit('zoomend', new Event('zoomend', eventData));\n }\n if (wasRotating) {\n this.emit('rotateend', new Event('rotateend', eventData));\n }\n if (wasPitching) {\n this.emit('pitchend', new Event('pitchend', eventData));\n }\n this.emit('moveend', new Event('moveend', eventData));\n }\n\n private ease(\n frame: (_: number) => void,\n finish: () => void,\n options: {\n animate: boolean;\n duration: number;\n easing: (_: number) => number;\n },\n ) {\n if (options.animate === false || options.duration === 0) {\n frame(1);\n finish();\n } else {\n this.easeStart = now();\n this.easeOptions = options;\n this.onEaseFrame = frame;\n this.onEaseEnd = finish;\n this.easeFrameId = this.requestRenderFrame(this.renderFrameCallback);\n }\n }\n\n private cameraForBoxAndBearing(\n p0: LngLatLike,\n p1: LngLatLike,\n bearing: number,\n options?: ICameraOptions & {\n offset: [number, number];\n maxZoom: number;\n padding: IPaddingOptions;\n },\n ): void | (ICameraOptions & IAnimationOptions) {\n const defaultPadding = {\n top: 0,\n bottom: 0,\n right: 0,\n left: 0,\n };\n options = merge(\n {\n padding: defaultPadding,\n offset: [0, 0],\n maxZoom: this.transform.maxZoom,\n },\n options,\n );\n\n if (typeof options.padding === 'number') {\n const p = options.padding;\n options.padding = {\n top: p,\n bottom: p,\n right: p,\n left: p,\n };\n }\n\n options.padding = merge(defaultPadding, options.padding);\n const tr = this.transform;\n const edgePadding = tr.padding as IPaddingOptions;\n\n // We want to calculate the upper right and lower left of the box defined by p0 and p1\n // in a coordinate system rotate to match the destination bearing.\n const p0world = tr.project(LngLat.convert(p0));\n const p1world = tr.project(LngLat.convert(p1));\n const p0rotated = p0world.rotate((-bearing * Math.PI) / 180);\n const p1rotated = p1world.rotate((-bearing * Math.PI) / 180);\n\n const upperRight = new Point(\n Math.max(p0rotated.x, p1rotated.x),\n Math.max(p0rotated.y, p1rotated.y),\n );\n const lowerLeft = new Point(\n Math.min(p0rotated.x, p1rotated.x),\n Math.min(p0rotated.y, p1rotated.y),\n );\n\n // Calculate zoom: consider the original bbox and padding.\n const size = upperRight.sub(lowerLeft);\n const scaleX =\n (tr.width -\n // @ts-ignore\n (edgePadding.left +\n // @ts-ignore\n edgePadding.right +\n // @ts-ignore\n options.padding.left +\n // @ts-ignore\n options.padding.right)) /\n size.x;\n const scaleY =\n (tr.height -\n // @ts-ignore\n (edgePadding.top +\n // @ts-ignore\n edgePadding.bottom +\n // @ts-ignore\n options.padding.top +\n // @ts-ignore\n options.padding.bottom)) /\n size.y;\n\n if (scaleY < 0 || scaleX < 0) {\n return;\n }\n\n const zoom = Math.min(\n tr.scaleZoom(tr.scale * Math.min(scaleX, scaleY)),\n options.maxZoom,\n );\n\n // Calculate center: apply the zoom, the configured offset, as well as offset that exists as a result of padding.\n const offset = Point.convert(options.offset);\n // @ts-ignore\n const paddingOffsetX = (options.padding.left - options.padding.right) / 2;\n // @ts-ignore\n const paddingOffsetY = (options.padding.top - options.padding.bottom) / 2;\n const offsetAtInitialZoom = new Point(\n offset.x + paddingOffsetX,\n offset.y + paddingOffsetY,\n );\n const offsetAtFinalZoom = offsetAtInitialZoom.mult(\n tr.scale / tr.zoomScale(zoom),\n );\n\n const center = tr.unproject(\n p0world\n .add(p1world)\n .div(2)\n .sub(offsetAtFinalZoom),\n );\n\n return {\n center,\n zoom,\n bearing,\n };\n }\n\n private fitInternal(\n calculatedOptions?: ICameraOptions & IAnimationOptions,\n options?: IAnimationOptions & ICameraOptions,\n eventData?: any,\n ) {\n // cameraForBounds warns + returns undefined if unable to fit:\n if (!calculatedOptions) {\n return this;\n }\n\n options = merge(calculatedOptions, options);\n // Explictly remove the padding field because, calculatedOptions already accounts for padding by setting zoom and center accordingly.\n delete options.padding;\n // @ts-ignore\n return options.linear\n ? this.easeTo(options, eventData)\n : this.flyTo(options, eventData);\n }\n}\n"],"file":"camera.js"}
package/lib/earthmap.js CHANGED
@@ -35,6 +35,8 @@ var _point = _interopRequireDefault(require("./geo/point"));
35
35
 
36
36
  var _handler_manager = _interopRequireDefault(require("./handler/handler_manager"));
37
37
 
38
+ var _hash = _interopRequireDefault(require("./hash"));
39
+
38
40
  var _util = require("./util");
39
41
 
40
42
  var _performance = require("./utils/performance");
@@ -46,13 +48,6 @@ function _createSuper(Derived) { var hasNativeReflectConstruct = _isNativeReflec
46
48
  function _isNativeReflectConstruct() { if (typeof Reflect === "undefined" || !Reflect.construct) return false; if (Reflect.construct.sham) return false; if (typeof Proxy === "function") return true; try { Boolean.prototype.valueOf.call(Reflect.construct(Boolean, [], function () {})); return true; } catch (e) { return false; } }
47
49
 
48
50
  function loadStyles(css, doc) {
49
- var isMiniAli = typeof my !== 'undefined' && !!my && typeof my.showToast === 'function';
50
- var isWeChatMiniProgram = typeof wx !== 'undefined' && wx !== null && (typeof wx.request !== 'undefined' || typeof wx.miniProgram !== 'undefined');
51
-
52
- if (isMiniAli || isWeChatMiniProgram) {
53
- return;
54
- }
55
-
56
51
  if (!doc) doc = document;
57
52
 
58
53
  if (!doc) {
@@ -141,6 +136,7 @@ var EarthMap = function (_Camera) {
141
136
  (0, _defineProperty2.default)((0, _assertThisInitialized2.default)(_this), "renderTaskQueue", new _task_queue.default());
142
137
  (0, _defineProperty2.default)((0, _assertThisInitialized2.default)(_this), "frame", void 0);
143
138
  (0, _defineProperty2.default)((0, _assertThisInitialized2.default)(_this), "trackResize", true);
139
+ (0, _defineProperty2.default)((0, _assertThisInitialized2.default)(_this), "hash", void 0);
144
140
  (0, _defineProperty2.default)((0, _assertThisInitialized2.default)(_this), "onWindowOnline", function () {
145
141
  _this.update();
146
142
  });
@@ -164,6 +160,29 @@ var EarthMap = function (_Camera) {
164
160
  window.addEventListener('orientationchange', _this.onWindowResize, false);
165
161
  }
166
162
 
163
+ var hashName = typeof options.hash === 'string' && options.hash || undefined;
164
+
165
+ if (options.hash) {
166
+ _this.hash = new _hash.default(hashName).addTo((0, _assertThisInitialized2.default)(_this));
167
+ }
168
+
169
+ if (!_this.hash || !_this.hash.onHashChange()) {
170
+ _this.jumpTo({
171
+ center: options.center,
172
+ zoom: options.zoom,
173
+ bearing: options.bearing,
174
+ pitch: options.pitch
175
+ });
176
+
177
+ if (options.bounds) {
178
+ _this.resize();
179
+
180
+ _this.fitBounds(options.bounds, (0, _merge2.default)({}, options.fitBoundsOptions, {
181
+ duration: 0
182
+ }));
183
+ }
184
+ }
185
+
167
186
  return _this;
168
187
  }
169
188
 
@@ -1 +1 @@
1
- {"version":3,"sources":["../src/earthmap.ts"],"names":["defaultMinZoom","defaultMaxZoom","defaultMinPitch","defaultMaxPitch","DefaultOptions","hash","zoom","center","pitch","bearing","interactive","minZoom","maxZoom","minPitch","maxPitch","scrollZoom","boxZoom","dragRotate","dragPan","keyboard","doubleClickZoom","touchZoomRotate","touchPitch","bearingSnap","clickTolerance","pitchWithRotate","trackResize","renderWorldCopies","EarthMap","options","TaskQueue","update","event","resize","originalEvent","initContainer","handlers","HandlerManager","window","addEventListener","onWindowOnline","onWindowResize","eventData","dimensions","containerDimensions","width","height","transform","fireMoving","moving","stop","emit","Event","container","canvas","canvasContainer","lngLat","locationPoint","LngLat","convert","point","pointLocation","Point","getBounds","getMaxBounds","bounds","setMaxBounds","LngLatBounds","style","undefined","getZoom","setZoom","Error","getPitch","setPitch","frame","cancel","renderTaskQueue","clear","cb","add","id","remove","paintStartTimeStamp","PerformanceUtils","time","run","document","getElementById","HTMLElement","classList","DOM","create","clientWidth","clientHeight","pixelRatio","DPR","Camera"],"mappings":"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","sourcesContent":["import { DOM } from '@antv/l7-utils';\nimport { merge } from 'lodash';\nimport Camera from './camera';\nimport './css/l7.css';\nimport LngLat, { LngLatLike } from './geo/lng_lat';\nimport LngLatBounds, { LngLatBoundsLike } from './geo/lng_lat_bounds';\n// @ts-ignore\nimport Point, { PointLike } from './geo/point';\nimport BoxZoomHandler from './handler/box_zoom';\nimport HandlerManager from './handler/handler_manager';\nimport KeyboardHandler from './handler/keyboard';\n\nimport ScrollZoomHandler from './handler/scroll_zoom';\nimport DoubleClickZoomHandler from './handler/shim/dblclick_zoom';\nimport DragPanHandler from './handler/shim/drag_pan';\nimport DragRotateHandler from './handler/shim/drag_rotate';\nimport TouchZoomRotateHandler from './handler/shim/touch_zoom_rotate';\nimport { TouchPitchHandler } from './handler/touch';\nimport { IMapOptions } from './interface';\nimport { renderframe } from './util';\nimport { PerformanceUtils } from './utils/performance';\nimport TaskQueue, { TaskID } from './utils/task_queue';\ntype CallBack = (_: number) => void;\nconst defaultMinZoom = -2;\nconst defaultMaxZoom = 22;\n\n// the default values, but also the valid range\nconst defaultMinPitch = 0;\nconst defaultMaxPitch = 60;\n\nconst DefaultOptions: IMapOptions = {\n hash: false,\n zoom: -1,\n center: [112, 32],\n pitch: 0,\n bearing: 0,\n interactive: true,\n minZoom: defaultMinZoom,\n maxZoom: defaultMaxZoom,\n minPitch: defaultMinPitch,\n maxPitch: defaultMaxPitch,\n scrollZoom: true,\n boxZoom: true,\n dragRotate: true,\n dragPan: true,\n keyboard: true,\n doubleClickZoom: true,\n touchZoomRotate: true,\n touchPitch: true,\n bearingSnap: 7,\n clickTolerance: 3,\n pitchWithRotate: true,\n trackResize: true,\n renderWorldCopies: true,\n};\nexport class EarthMap extends Camera {\n public doubleClickZoom: DoubleClickZoomHandler;\n public dragRotate: DragRotateHandler;\n public dragPan: DragPanHandler;\n public touchZoomRotate: TouchZoomRotateHandler;\n public scrollZoom: ScrollZoomHandler;\n public keyboard: KeyboardHandler;\n public touchPitch: TouchPitchHandler;\n public boxZoom: BoxZoomHandler;\n public handlers: HandlerManager;\n\n private container: HTMLElement;\n private canvas: HTMLCanvasElement;\n private canvasContainer: HTMLElement;\n private renderTaskQueue: TaskQueue = new TaskQueue();\n private frame: { cancel: () => void } | null;\n private trackResize: boolean = true;\n\n constructor(options: Partial<IMapOptions>) {\n super(merge({}, DefaultOptions, options));\n this.initContainer();\n this.resize();\n this.handlers = new HandlerManager(this, this.options);\n\n if (typeof window !== 'undefined') {\n window.addEventListener('online', this.onWindowOnline, false);\n window.addEventListener('resize', this.onWindowResize, false);\n window.addEventListener('orientationchange', this.onWindowResize, false);\n }\n }\n\n public resize(eventData?: any) {\n const dimensions = this.containerDimensions();\n const width = dimensions[0];\n const height = dimensions[1];\n\n // this.resizeCanvas(width, height);\n this.transform.resize(width, height);\n const fireMoving = !this.moving;\n if (fireMoving) {\n this.stop();\n this.emit('movestart', new Event('movestart', eventData));\n this.emit('move', new Event('move', eventData));\n }\n\n this.emit('resize', new Event('resize', eventData));\n\n if (fireMoving) {\n this.emit('moveend', new Event('moveend', eventData));\n }\n\n return this;\n }\n\n public getContainer() {\n return this.container;\n }\n\n public getCanvas() {\n return this.canvas;\n }\n\n public getCanvasContainer() {\n return this.canvasContainer;\n }\n\n public project(lngLat: LngLatLike) {\n return this.transform.locationPoint(LngLat.convert(lngLat));\n }\n\n public unproject(point: PointLike) {\n return this.transform.pointLocation(Point.convert(point));\n }\n\n public getBounds(): LngLatBounds {\n return this.transform.getBounds();\n }\n\n public getMaxBounds(): LngLatBounds | null {\n return this.transform.getMaxBounds();\n }\n\n public setMaxBounds(bounds: LngLatBoundsLike) {\n this.transform.setMaxBounds(LngLatBounds.convert(bounds));\n }\n\n public setStyle(style: any) {\n return;\n }\n public setMinZoom(minZoom?: number) {\n minZoom =\n minZoom === null || minZoom === undefined ? defaultMinZoom : minZoom;\n if (minZoom >= defaultMinZoom && minZoom <= this.transform.maxZoom) {\n this.transform.minZoom = minZoom;\n if (this.getZoom() < minZoom) {\n this.setZoom(minZoom);\n }\n\n return this;\n } else {\n throw new Error(\n `minZoom must be between ${defaultMinZoom} and the current maxZoom, inclusive`,\n );\n }\n }\n\n public getMinZoom() {\n return this.transform.minZoom;\n }\n\n public setMaxZoom(maxZoom?: number) {\n maxZoom =\n maxZoom === null || maxZoom === undefined ? defaultMaxZoom : maxZoom;\n\n if (maxZoom >= this.transform.minZoom) {\n this.transform.maxZoom = maxZoom;\n if (this.getZoom() > maxZoom) {\n this.setZoom(maxZoom);\n }\n\n return this;\n } else {\n throw new Error('maxZoom must be greater than the current minZoom');\n }\n }\n public getMaxZoom() {\n return this.transform.maxZoom;\n }\n\n public setMinPitch(minPitch?: number) {\n minPitch =\n minPitch === null || minPitch === undefined ? defaultMinPitch : minPitch;\n\n if (minPitch < defaultMinPitch) {\n throw new Error(\n `minPitch must be greater than or equal to ${defaultMinPitch}`,\n );\n }\n\n if (minPitch >= defaultMinPitch && minPitch <= this.transform.maxPitch) {\n this.transform.minPitch = minPitch;\n if (this.getPitch() < minPitch) {\n this.setPitch(minPitch);\n }\n\n return this;\n } else {\n throw new Error(\n `minPitch must be between ${defaultMinPitch} and the current maxPitch, inclusive`,\n );\n }\n }\n\n public getMinPitch() {\n return this.transform.minPitch;\n }\n\n public setMaxPitch(maxPitch?: number) {\n maxPitch =\n maxPitch === null || maxPitch === undefined ? defaultMaxPitch : maxPitch;\n\n if (maxPitch > defaultMaxPitch) {\n throw new Error(\n `maxPitch must be less than or equal to ${defaultMaxPitch}`,\n );\n }\n\n if (maxPitch >= this.transform.minPitch) {\n this.transform.maxPitch = maxPitch;\n if (this.getPitch() > maxPitch) {\n this.setPitch(maxPitch);\n }\n\n return this;\n } else {\n throw new Error('maxPitch must be greater than the current minPitch');\n }\n }\n\n public getMaxPitch() {\n return this.transform.maxPitch;\n }\n\n public getRenderWorldCopies() {\n return this.transform.renderWorldCopies;\n }\n\n public setRenderWorldCopies(renderWorldCopies?: boolean) {\n this.transform.renderWorldCopies = !!renderWorldCopies;\n }\n\n public remove() {\n if (this.frame) {\n this.frame.cancel();\n this.frame = null;\n }\n this.renderTaskQueue.clear();\n }\n\n public requestRenderFrame(cb: CallBack): TaskID {\n this.update();\n return this.renderTaskQueue.add(cb);\n }\n\n public cancelRenderFrame(id: TaskID) {\n return this.renderTaskQueue.remove(id);\n }\n\n public triggerRepaint() {\n if (!this.frame) {\n this.frame = renderframe((paintStartTimeStamp: number) => {\n PerformanceUtils.frame(paintStartTimeStamp);\n this.frame = null;\n this.update(paintStartTimeStamp);\n });\n }\n }\n\n public update(time?: number) {\n if (!this.frame) {\n this.frame = renderframe((paintStartTimeStamp: number) => {\n PerformanceUtils.frame(paintStartTimeStamp);\n this.frame = null;\n this.renderTaskQueue.run(time);\n });\n }\n }\n\n private initContainer() {\n if (typeof this.options.container === 'string') {\n this.container = window.document.getElementById(\n this.options.container,\n ) as HTMLElement;\n if (!this.container) {\n throw new Error(`Container '${this.options.container}' not found.`);\n }\n } else if (this.options.container instanceof HTMLElement) {\n this.container = this.options.container;\n } else {\n throw new Error(\n \"Invalid type: 'container' must be a String or HTMLElement.\",\n );\n }\n\n const container = this.container;\n container.classList.add('l7-map');\n\n const canvasContainer = (this.canvasContainer = DOM.create(\n 'div',\n 'l7-canvas-container',\n container,\n ));\n if (this.options.interactive) {\n canvasContainer.classList.add('l7-interactive');\n }\n\n // this.canvas = DOM.create(\n // 'canvas',\n // 'l7-canvas',\n // canvasContainer,\n // ) as HTMLCanvasElement;\n // this.canvas.setAttribute('tabindex', '-');\n // this.canvas.setAttribute('aria-label', 'Map');\n }\n\n private containerDimensions(): [number, number] {\n let width = 0;\n let height = 0;\n if (this.container) {\n width = this.container.clientWidth || 400;\n height = this.container.clientHeight || 300;\n }\n return [width, height];\n }\n\n private resizeCanvas(width: number, height: number) {\n const pixelRatio = DOM.DPR || 1;\n this.canvas.width = pixelRatio * width;\n this.canvas.height = pixelRatio * height;\n\n // Maintain the same canvas size, potentially downscaling it for HiDPI displays\n this.canvas.style.width = `${width}px`;\n this.canvas.style.height = `${height}px`;\n }\n\n private onWindowOnline = () => {\n this.update();\n };\n\n private onWindowResize = (event: Event) => {\n if (this.trackResize) {\n this.resize({ originalEvent: event }).update();\n }\n };\n}\n"],"file":"earthmap.js"}
1
+ {"version":3,"sources":["../src/earthmap.ts"],"names":["defaultMinZoom","defaultMaxZoom","defaultMinPitch","defaultMaxPitch","DefaultOptions","hash","zoom","center","pitch","bearing","interactive","minZoom","maxZoom","minPitch","maxPitch","scrollZoom","boxZoom","dragRotate","dragPan","keyboard","doubleClickZoom","touchZoomRotate","touchPitch","bearingSnap","clickTolerance","pitchWithRotate","trackResize","renderWorldCopies","EarthMap","options","TaskQueue","update","event","resize","originalEvent","initContainer","handlers","HandlerManager","window","addEventListener","onWindowOnline","onWindowResize","hashName","undefined","Hash","addTo","onHashChange","jumpTo","bounds","fitBounds","fitBoundsOptions","duration","eventData","dimensions","containerDimensions","width","height","transform","fireMoving","moving","stop","emit","Event","container","canvas","canvasContainer","lngLat","locationPoint","LngLat","convert","point","pointLocation","Point","getBounds","getMaxBounds","setMaxBounds","LngLatBounds","style","getZoom","setZoom","Error","getPitch","setPitch","frame","cancel","renderTaskQueue","clear","cb","add","id","remove","paintStartTimeStamp","PerformanceUtils","time","run","document","getElementById","HTMLElement","classList","DOM","create","clientWidth","clientHeight","pixelRatio","DPR","Camera"],"mappings":"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","sourcesContent":["import { DOM } from '@antv/l7-utils';\nimport { merge } from 'lodash';\nimport Camera from './camera';\nimport './css/l7.css';\nimport LngLat, { LngLatLike } from './geo/lng_lat';\nimport LngLatBounds, { LngLatBoundsLike } from './geo/lng_lat_bounds';\n// @ts-ignore\nimport Point, { PointLike } from './geo/point';\nimport BoxZoomHandler from './handler/box_zoom';\nimport HandlerManager from './handler/handler_manager';\nimport KeyboardHandler from './handler/keyboard';\n\nimport ScrollZoomHandler from './handler/scroll_zoom';\nimport DoubleClickZoomHandler from './handler/shim/dblclick_zoom';\nimport DragPanHandler from './handler/shim/drag_pan';\nimport DragRotateHandler from './handler/shim/drag_rotate';\nimport TouchZoomRotateHandler from './handler/shim/touch_zoom_rotate';\nimport { TouchPitchHandler } from './handler/touch';\nimport Hash from './hash';\nimport { IMapOptions } from './interface';\nimport { renderframe } from './util';\nimport { PerformanceUtils } from './utils/performance';\nimport TaskQueue, { TaskID } from './utils/task_queue';\ntype CallBack = (_: number) => void;\nconst defaultMinZoom = -2;\nconst defaultMaxZoom = 22;\n\n// the default values, but also the valid range\nconst defaultMinPitch = 0;\nconst defaultMaxPitch = 60;\n\nconst DefaultOptions: IMapOptions = {\n hash: false,\n zoom: -1,\n center: [112, 32],\n pitch: 0,\n bearing: 0,\n interactive: true,\n minZoom: defaultMinZoom,\n maxZoom: defaultMaxZoom,\n minPitch: defaultMinPitch,\n maxPitch: defaultMaxPitch,\n scrollZoom: true,\n boxZoom: true,\n dragRotate: true,\n dragPan: true,\n keyboard: true,\n doubleClickZoom: true,\n touchZoomRotate: true,\n touchPitch: true,\n bearingSnap: 7,\n clickTolerance: 3,\n pitchWithRotate: true,\n trackResize: true,\n renderWorldCopies: true,\n};\nexport class EarthMap extends Camera {\n public doubleClickZoom: DoubleClickZoomHandler;\n public dragRotate: DragRotateHandler;\n public dragPan: DragPanHandler;\n public touchZoomRotate: TouchZoomRotateHandler;\n public scrollZoom: ScrollZoomHandler;\n public keyboard: KeyboardHandler;\n public touchPitch: TouchPitchHandler;\n public boxZoom: BoxZoomHandler;\n public handlers: HandlerManager;\n\n private container: HTMLElement;\n private canvas: HTMLCanvasElement;\n private canvasContainer: HTMLElement;\n private renderTaskQueue: TaskQueue = new TaskQueue();\n private frame: { cancel: () => void } | null;\n private trackResize: boolean = true;\n private hash: Hash | undefined;\n constructor(options: Partial<IMapOptions>) {\n super(merge({}, DefaultOptions, options));\n this.initContainer();\n this.resize();\n this.handlers = new HandlerManager(this, this.options);\n\n if (typeof window !== 'undefined') {\n window.addEventListener('online', this.onWindowOnline, false);\n window.addEventListener('resize', this.onWindowResize, false);\n window.addEventListener('orientationchange', this.onWindowResize, false);\n }\n\n const hashName =\n (typeof options.hash === 'string' && options.hash) || undefined;\n if (options.hash) {\n this.hash = new Hash(hashName).addTo(this) as Hash;\n }\n\n // don't set position from options if set through hash\n if (!this.hash || !this.hash.onHashChange()) {\n this.jumpTo({\n center: options.center,\n zoom: options.zoom,\n bearing: options.bearing,\n pitch: options.pitch,\n });\n\n if (options.bounds) {\n this.resize();\n this.fitBounds(\n options.bounds,\n merge({}, options.fitBoundsOptions, { duration: 0 }),\n );\n }\n }\n }\n\n public resize(eventData?: any) {\n const dimensions = this.containerDimensions();\n const width = dimensions[0];\n const height = dimensions[1];\n\n // this.resizeCanvas(width, height);\n this.transform.resize(width, height);\n const fireMoving = !this.moving;\n if (fireMoving) {\n this.stop();\n this.emit('movestart', new Event('movestart', eventData));\n this.emit('move', new Event('move', eventData));\n }\n\n this.emit('resize', new Event('resize', eventData));\n\n if (fireMoving) {\n this.emit('moveend', new Event('moveend', eventData));\n }\n\n return this;\n }\n\n public getContainer() {\n return this.container;\n }\n\n public getCanvas() {\n return this.canvas;\n }\n\n public getCanvasContainer() {\n return this.canvasContainer;\n }\n\n public project(lngLat: LngLatLike) {\n return this.transform.locationPoint(LngLat.convert(lngLat));\n }\n\n public unproject(point: PointLike) {\n return this.transform.pointLocation(Point.convert(point));\n }\n\n public getBounds(): LngLatBounds {\n return this.transform.getBounds();\n }\n\n public getMaxBounds(): LngLatBounds | null {\n return this.transform.getMaxBounds();\n }\n\n public setMaxBounds(bounds: LngLatBoundsLike) {\n this.transform.setMaxBounds(LngLatBounds.convert(bounds));\n }\n\n public setStyle(style: any) {\n return;\n }\n public setMinZoom(minZoom?: number) {\n minZoom =\n minZoom === null || minZoom === undefined ? defaultMinZoom : minZoom;\n if (minZoom >= defaultMinZoom && minZoom <= this.transform.maxZoom) {\n this.transform.minZoom = minZoom;\n if (this.getZoom() < minZoom) {\n this.setZoom(minZoom);\n }\n\n return this;\n } else {\n throw new Error(\n `minZoom must be between ${defaultMinZoom} and the current maxZoom, inclusive`,\n );\n }\n }\n\n public getMinZoom() {\n return this.transform.minZoom;\n }\n\n public setMaxZoom(maxZoom?: number) {\n maxZoom =\n maxZoom === null || maxZoom === undefined ? defaultMaxZoom : maxZoom;\n\n if (maxZoom >= this.transform.minZoom) {\n this.transform.maxZoom = maxZoom;\n if (this.getZoom() > maxZoom) {\n this.setZoom(maxZoom);\n }\n\n return this;\n } else {\n throw new Error('maxZoom must be greater than the current minZoom');\n }\n }\n public getMaxZoom() {\n return this.transform.maxZoom;\n }\n\n public setMinPitch(minPitch?: number) {\n minPitch =\n minPitch === null || minPitch === undefined ? defaultMinPitch : minPitch;\n\n if (minPitch < defaultMinPitch) {\n throw new Error(\n `minPitch must be greater than or equal to ${defaultMinPitch}`,\n );\n }\n\n if (minPitch >= defaultMinPitch && minPitch <= this.transform.maxPitch) {\n this.transform.minPitch = minPitch;\n if (this.getPitch() < minPitch) {\n this.setPitch(minPitch);\n }\n\n return this;\n } else {\n throw new Error(\n `minPitch must be between ${defaultMinPitch} and the current maxPitch, inclusive`,\n );\n }\n }\n\n public getMinPitch() {\n return this.transform.minPitch;\n }\n\n public setMaxPitch(maxPitch?: number) {\n maxPitch =\n maxPitch === null || maxPitch === undefined ? defaultMaxPitch : maxPitch;\n\n if (maxPitch > defaultMaxPitch) {\n throw new Error(\n `maxPitch must be less than or equal to ${defaultMaxPitch}`,\n );\n }\n\n if (maxPitch >= this.transform.minPitch) {\n this.transform.maxPitch = maxPitch;\n if (this.getPitch() > maxPitch) {\n this.setPitch(maxPitch);\n }\n\n return this;\n } else {\n throw new Error('maxPitch must be greater than the current minPitch');\n }\n }\n\n public getMaxPitch() {\n return this.transform.maxPitch;\n }\n\n public getRenderWorldCopies() {\n return this.transform.renderWorldCopies;\n }\n\n public setRenderWorldCopies(renderWorldCopies?: boolean) {\n this.transform.renderWorldCopies = !!renderWorldCopies;\n }\n\n public remove() {\n if (this.frame) {\n this.frame.cancel();\n this.frame = null;\n }\n this.renderTaskQueue.clear();\n }\n\n public requestRenderFrame(cb: CallBack): TaskID {\n this.update();\n return this.renderTaskQueue.add(cb);\n }\n\n public cancelRenderFrame(id: TaskID) {\n return this.renderTaskQueue.remove(id);\n }\n\n public triggerRepaint() {\n if (!this.frame) {\n this.frame = renderframe((paintStartTimeStamp: number) => {\n PerformanceUtils.frame(paintStartTimeStamp);\n this.frame = null;\n this.update(paintStartTimeStamp);\n });\n }\n }\n\n public update(time?: number) {\n if (!this.frame) {\n this.frame = renderframe((paintStartTimeStamp: number) => {\n PerformanceUtils.frame(paintStartTimeStamp);\n this.frame = null;\n this.renderTaskQueue.run(time);\n });\n }\n }\n\n private initContainer() {\n if (typeof this.options.container === 'string') {\n this.container = window.document.getElementById(\n this.options.container,\n ) as HTMLElement;\n if (!this.container) {\n throw new Error(`Container '${this.options.container}' not found.`);\n }\n } else if (this.options.container instanceof HTMLElement) {\n this.container = this.options.container;\n } else {\n throw new Error(\n \"Invalid type: 'container' must be a String or HTMLElement.\",\n );\n }\n\n const container = this.container;\n container.classList.add('l7-map');\n\n const canvasContainer = (this.canvasContainer = DOM.create(\n 'div',\n 'l7-canvas-container',\n container,\n ));\n if (this.options.interactive) {\n canvasContainer.classList.add('l7-interactive');\n }\n\n // this.canvas = DOM.create(\n // 'canvas',\n // 'l7-canvas',\n // canvasContainer,\n // ) as HTMLCanvasElement;\n // this.canvas.setAttribute('tabindex', '-');\n // this.canvas.setAttribute('aria-label', 'Map');\n }\n\n private containerDimensions(): [number, number] {\n let width = 0;\n let height = 0;\n if (this.container) {\n width = this.container.clientWidth || 400;\n height = this.container.clientHeight || 300;\n }\n return [width, height];\n }\n\n private resizeCanvas(width: number, height: number) {\n const pixelRatio = DOM.DPR || 1;\n this.canvas.width = pixelRatio * width;\n this.canvas.height = pixelRatio * height;\n\n // Maintain the same canvas size, potentially downscaling it for HiDPI displays\n this.canvas.style.width = `${width}px`;\n this.canvas.style.height = `${height}px`;\n }\n\n private onWindowOnline = () => {\n this.update();\n };\n\n private onWindowResize = (event: Event) => {\n if (this.trackResize) {\n this.resize({ originalEvent: event }).update();\n }\n };\n}\n"],"file":"earthmap.js"}
@@ -5,7 +5,7 @@ var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefau
5
5
  Object.defineProperty(exports, "__esModule", {
6
6
  value: true
7
7
  });
8
- exports.default = exports.earthRadius = void 0;
8
+ exports.earthRadius = exports.default = void 0;
9
9
 
10
10
  var _typeof2 = _interopRequireDefault(require("@babel/runtime/helpers/typeof"));
11
11
 
@@ -1,20 +1,20 @@
1
1
  "use strict";
2
2
 
3
- var _interopRequireWildcard = require("@babel/runtime/helpers/interopRequireWildcard");
4
-
5
3
  var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
6
4
 
5
+ var _typeof = require("@babel/runtime/helpers/typeof");
6
+
7
7
  Object.defineProperty(exports, "__esModule", {
8
8
  value: true
9
9
  });
10
+ exports.altitudeFromMercatorZ = altitudeFromMercatorZ;
11
+ exports.default = void 0;
12
+ exports.latFromMercatorY = latFromMercatorY;
13
+ exports.lngFromMercatorX = lngFromMercatorX;
14
+ exports.mercatorScale = mercatorScale;
10
15
  exports.mercatorXfromLng = mercatorXfromLng;
11
16
  exports.mercatorYfromLat = mercatorYfromLat;
12
17
  exports.mercatorZfromAltitude = mercatorZfromAltitude;
13
- exports.lngFromMercatorX = lngFromMercatorX;
14
- exports.latFromMercatorY = latFromMercatorY;
15
- exports.altitudeFromMercatorZ = altitudeFromMercatorZ;
16
- exports.mercatorScale = mercatorScale;
17
- exports.default = void 0;
18
18
 
19
19
  var _classCallCheck2 = _interopRequireDefault(require("@babel/runtime/helpers/classCallCheck"));
20
20
 
@@ -24,6 +24,10 @@ var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/de
24
24
 
25
25
  var _lng_lat = _interopRequireWildcard(require("../geo/lng_lat"));
26
26
 
27
+ function _getRequireWildcardCache(nodeInterop) { if (typeof WeakMap !== "function") return null; var cacheBabelInterop = new WeakMap(); var cacheNodeInterop = new WeakMap(); return (_getRequireWildcardCache = function _getRequireWildcardCache(nodeInterop) { return nodeInterop ? cacheNodeInterop : cacheBabelInterop; })(nodeInterop); }
28
+
29
+ function _interopRequireWildcard(obj, nodeInterop) { if (!nodeInterop && obj && obj.__esModule) { return obj; } if (obj === null || _typeof(obj) !== "object" && typeof obj !== "function") { return { default: obj }; } var cache = _getRequireWildcardCache(nodeInterop); if (cache && cache.has(obj)) { return cache.get(obj); } var newObj = {}; var hasPropertyDescriptor = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var key in obj) { if (key !== "default" && Object.prototype.hasOwnProperty.call(obj, key)) { var desc = hasPropertyDescriptor ? Object.getOwnPropertyDescriptor(obj, key) : null; if (desc && (desc.get || desc.set)) { Object.defineProperty(newObj, key, desc); } else { newObj[key] = obj[key]; } } } newObj.default = obj; if (cache) { cache.set(obj, newObj); } return newObj; }
30
+
27
31
  var earthCircumfrence = 2 * Math.PI * _lng_lat.earthRadius;
28
32
 
29
33
  function circumferenceAtLatitude(latitude) {
@@ -1 +1 @@
1
- {"version":3,"sources":["../../src/geo/mercator.ts"],"names":["earthCircumfrence","Math","PI","earthRadius","circumferenceAtLatitude","latitude","cos","mercatorXfromLng","lng","mercatorYfromLat","lat","log","tan","mercatorZfromAltitude","altitude","lngFromMercatorX","x","latFromMercatorY","y","y2","atan","exp","altitudeFromMercatorZ","z","mercatorScale","MercatorCoordinate","LngLat","lngLatLike","lngLat","convert"],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;AAAA;;AAKA,IAAMA,iBAAiB,GAAG,IAAIC,IAAI,CAACC,EAAT,GAAcC,oBAAxC;;AAKA,SAASC,uBAAT,CAAiCC,QAAjC,EAAmD;AACjD,SAAOL,iBAAiB,GAAGC,IAAI,CAACK,GAAL,CAAUD,QAAQ,GAAGJ,IAAI,CAACC,EAAjB,GAAuB,GAAhC,CAA3B;AACD;;AAEM,SAASK,gBAAT,CAA0BC,GAA1B,EAAuC;AAC5C,SAAO,CAAC,MAAMA,GAAP,IAAc,GAArB;AACD;;AAEM,SAASC,gBAAT,CAA0BC,GAA1B,EAAuC;AAC5C,SACE,CAAC,MACE,MAAMT,IAAI,CAACC,EAAZ,GACED,IAAI,CAACU,GAAL,CAASV,IAAI,CAACW,GAAL,CAASX,IAAI,CAACC,EAAL,GAAU,CAAV,GAAeQ,GAAG,GAAGT,IAAI,CAACC,EAAZ,GAAkB,GAAzC,CAAT,CAFJ,IAGA,GAJF;AAMD;;AAEM,SAASW,qBAAT,CAA+BC,QAA/B,EAAiDJ,GAAjD,EAA8D;AACnE,SAAOI,QAAQ,GAAGV,uBAAuB,CAACM,GAAD,CAAzC;AACD;;AAEM,SAASK,gBAAT,CAA0BC,CAA1B,EAAqC;AAC1C,SAAOA,CAAC,GAAG,GAAJ,GAAU,GAAjB;AACD;;AAEM,SAASC,gBAAT,CAA0BC,CAA1B,EAAqC;AAC1C,MAAMC,EAAE,GAAG,MAAMD,CAAC,GAAG,GAArB;AACA,SAAQ,MAAMjB,IAAI,CAACC,EAAZ,GAAkBD,IAAI,CAACmB,IAAL,CAAUnB,IAAI,CAACoB,GAAL,CAAUF,EAAE,GAAGlB,IAAI,CAACC,EAAX,GAAiB,GAA1B,CAAV,CAAlB,GAA8D,EAArE;AACD;;AAEM,SAASoB,qBAAT,CAA+BC,CAA/B,EAA0CL,CAA1C,EAAqD;AAC1D,SAAOK,CAAC,GAAGnB,uBAAuB,CAACa,gBAAgB,CAACC,CAAD,CAAjB,CAAlC;AACD;;AAYM,SAASM,aAAT,CAAuBd,GAAvB,EAAoC;AACzC,SAAO,IAAIT,IAAI,CAACK,GAAL,CAAUI,GAAG,GAAGT,IAAI,CAACC,EAAZ,GAAkB,GAA3B,CAAX;AACD;;IAEoBuB,kB;AAcnB,8BAAYT,CAAZ,EAAuBE,CAAvB,EAAiD;AAAA,QAAfK,CAAe,uEAAH,CAAG;AAAA;AAAA;AAAA;AAAA;AAC/C,SAAKP,CAAL,GAAS,CAACA,CAAV;AACA,SAAKE,CAAL,GAAS,CAACA,CAAV;AACA,SAAKK,CAAL,GAAS,CAACA,CAAV;AACD;;;;WAED,oBAAkB;AAChB,aAAO,IAAIG,gBAAJ,CAAWX,gBAAgB,CAAC,KAAKC,CAAN,CAA3B,EAAqCC,gBAAgB,CAAC,KAAKC,CAAN,CAArD,CAAP;AACD;;;WAED,sBAAoB;AAClB,aAAOI,qBAAqB,CAAC,KAAKC,CAAN,EAAS,KAAKL,CAAd,CAA5B;AACD;;;WAED,0CAAwC;AAEtC,aAAQ,IAAIlB,iBAAL,GAA0BwB,aAAa,CAACP,gBAAgB,CAAC,KAAKC,CAAN,CAAjB,CAA9C;AACD;;;WA9BD,oBAAyBS,UAAzB,EAAuE;AAAA,UAAtBb,QAAsB,uEAAH,CAAG;;AACrE,UAAMc,MAAM,GAAGF,iBAAOG,OAAP,CAAeF,UAAf,CAAf;;AAEA,aAAO,IAAIF,kBAAJ,CACLlB,gBAAgB,CAACqB,MAAM,CAACpB,GAAR,CADX,EAELC,gBAAgB,CAACmB,MAAM,CAAClB,GAAR,CAFX,EAGLG,qBAAqB,CAACC,QAAD,EAAWc,MAAM,CAAClB,GAAlB,CAHhB,CAAP;AAKD","sourcesContent":["import LngLat, { earthRadius, LngLatLike } from '../geo/lng_lat';\n\n/*\n * The average circumference of the world in meters.\n */\nconst earthCircumfrence = 2 * Math.PI * earthRadius; // meters\n\n/*\n * The circumference at a line of latitude in meters.\n */\nfunction circumferenceAtLatitude(latitude: number) {\n return earthCircumfrence * Math.cos((latitude * Math.PI) / 180);\n}\n\nexport function mercatorXfromLng(lng: number) {\n return (180 + lng) / 360;\n}\n\nexport function mercatorYfromLat(lat: number) {\n return (\n (180 -\n (180 / Math.PI) *\n Math.log(Math.tan(Math.PI / 4 + (lat * Math.PI) / 360))) /\n 360\n );\n}\n\nexport function mercatorZfromAltitude(altitude: number, lat: number) {\n return altitude / circumferenceAtLatitude(lat);\n}\n\nexport function lngFromMercatorX(x: number) {\n return x * 360 - 180;\n}\n\nexport function latFromMercatorY(y: number) {\n const y2 = 180 - y * 360;\n return (360 / Math.PI) * Math.atan(Math.exp((y2 * Math.PI) / 180)) - 90;\n}\n\nexport function altitudeFromMercatorZ(z: number, y: number) {\n return z * circumferenceAtLatitude(latFromMercatorY(y));\n}\n\n/**\n * Determine the Mercator scale factor for a given latitude, see\n * https://en.wikipedia.org/wiki/Mercator_projection#Scale_factor\n *\n * At the equator the scale factor will be 1, which increases at higher latitudes.\n *\n * @param {number} lat Latitude\n * @returns {number} scale factor\n * @private\n */\nexport function mercatorScale(lat: number) {\n return 1 / Math.cos((lat * Math.PI) / 180);\n}\n\nexport default class MercatorCoordinate {\n public static fromLngLat(lngLatLike: LngLatLike, altitude: number = 0) {\n const lngLat = LngLat.convert(lngLatLike);\n\n return new MercatorCoordinate(\n mercatorXfromLng(lngLat.lng),\n mercatorYfromLat(lngLat.lat),\n mercatorZfromAltitude(altitude, lngLat.lat),\n );\n }\n public x: number;\n public y: number;\n public z: number;\n\n constructor(x: number, y: number, z: number = 0) {\n this.x = +x;\n this.y = +y;\n this.z = +z;\n }\n\n public toLngLat() {\n return new LngLat(lngFromMercatorX(this.x), latFromMercatorY(this.y));\n }\n\n public toAltitude() {\n return altitudeFromMercatorZ(this.z, this.y);\n }\n\n public meterInMercatorCoordinateUnits() {\n // 1 meter / circumference at equator in meters * Mercator projection scale factor at this latitude\n return (1 / earthCircumfrence) * mercatorScale(latFromMercatorY(this.y));\n }\n}\n"],"file":"mercator.js"}
1
+ {"version":3,"sources":["../../src/geo/mercator.ts"],"names":["earthCircumfrence","Math","PI","earthRadius","circumferenceAtLatitude","latitude","cos","mercatorXfromLng","lng","mercatorYfromLat","lat","log","tan","mercatorZfromAltitude","altitude","lngFromMercatorX","x","latFromMercatorY","y","y2","atan","exp","altitudeFromMercatorZ","z","mercatorScale","MercatorCoordinate","LngLat","lngLatLike","lngLat","convert"],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;AAAA;;;;;;AAKA,IAAMA,iBAAiB,GAAG,IAAIC,IAAI,CAACC,EAAT,GAAcC,oBAAxC;;AAKA,SAASC,uBAAT,CAAiCC,QAAjC,EAAmD;AACjD,SAAOL,iBAAiB,GAAGC,IAAI,CAACK,GAAL,CAAUD,QAAQ,GAAGJ,IAAI,CAACC,EAAjB,GAAuB,GAAhC,CAA3B;AACD;;AAEM,SAASK,gBAAT,CAA0BC,GAA1B,EAAuC;AAC5C,SAAO,CAAC,MAAMA,GAAP,IAAc,GAArB;AACD;;AAEM,SAASC,gBAAT,CAA0BC,GAA1B,EAAuC;AAC5C,SACE,CAAC,MACE,MAAMT,IAAI,CAACC,EAAZ,GACED,IAAI,CAACU,GAAL,CAASV,IAAI,CAACW,GAAL,CAASX,IAAI,CAACC,EAAL,GAAU,CAAV,GAAeQ,GAAG,GAAGT,IAAI,CAACC,EAAZ,GAAkB,GAAzC,CAAT,CAFJ,IAGA,GAJF;AAMD;;AAEM,SAASW,qBAAT,CAA+BC,QAA/B,EAAiDJ,GAAjD,EAA8D;AACnE,SAAOI,QAAQ,GAAGV,uBAAuB,CAACM,GAAD,CAAzC;AACD;;AAEM,SAASK,gBAAT,CAA0BC,CAA1B,EAAqC;AAC1C,SAAOA,CAAC,GAAG,GAAJ,GAAU,GAAjB;AACD;;AAEM,SAASC,gBAAT,CAA0BC,CAA1B,EAAqC;AAC1C,MAAMC,EAAE,GAAG,MAAMD,CAAC,GAAG,GAArB;AACA,SAAQ,MAAMjB,IAAI,CAACC,EAAZ,GAAkBD,IAAI,CAACmB,IAAL,CAAUnB,IAAI,CAACoB,GAAL,CAAUF,EAAE,GAAGlB,IAAI,CAACC,EAAX,GAAiB,GAA1B,CAAV,CAAlB,GAA8D,EAArE;AACD;;AAEM,SAASoB,qBAAT,CAA+BC,CAA/B,EAA0CL,CAA1C,EAAqD;AAC1D,SAAOK,CAAC,GAAGnB,uBAAuB,CAACa,gBAAgB,CAACC,CAAD,CAAjB,CAAlC;AACD;;AAYM,SAASM,aAAT,CAAuBd,GAAvB,EAAoC;AACzC,SAAO,IAAIT,IAAI,CAACK,GAAL,CAAUI,GAAG,GAAGT,IAAI,CAACC,EAAZ,GAAkB,GAA3B,CAAX;AACD;;IAEoBuB,kB;AAcnB,8BAAYT,CAAZ,EAAuBE,CAAvB,EAAiD;AAAA,QAAfK,CAAe,uEAAH,CAAG;AAAA;AAAA;AAAA;AAAA;AAC/C,SAAKP,CAAL,GAAS,CAACA,CAAV;AACA,SAAKE,CAAL,GAAS,CAACA,CAAV;AACA,SAAKK,CAAL,GAAS,CAACA,CAAV;AACD;;;;WAED,oBAAkB;AAChB,aAAO,IAAIG,gBAAJ,CAAWX,gBAAgB,CAAC,KAAKC,CAAN,CAA3B,EAAqCC,gBAAgB,CAAC,KAAKC,CAAN,CAArD,CAAP;AACD;;;WAED,sBAAoB;AAClB,aAAOI,qBAAqB,CAAC,KAAKC,CAAN,EAAS,KAAKL,CAAd,CAA5B;AACD;;;WAED,0CAAwC;AAEtC,aAAQ,IAAIlB,iBAAL,GAA0BwB,aAAa,CAACP,gBAAgB,CAAC,KAAKC,CAAN,CAAjB,CAA9C;AACD;;;WA9BD,oBAAyBS,UAAzB,EAAuE;AAAA,UAAtBb,QAAsB,uEAAH,CAAG;;AACrE,UAAMc,MAAM,GAAGF,iBAAOG,OAAP,CAAeF,UAAf,CAAf;;AAEA,aAAO,IAAIF,kBAAJ,CACLlB,gBAAgB,CAACqB,MAAM,CAACpB,GAAR,CADX,EAELC,gBAAgB,CAACmB,MAAM,CAAClB,GAAR,CAFX,EAGLG,qBAAqB,CAACC,QAAD,EAAWc,MAAM,CAAClB,GAAlB,CAHhB,CAAP;AAKD","sourcesContent":["import LngLat, { earthRadius, LngLatLike } from '../geo/lng_lat';\n\n/*\n * The average circumference of the world in meters.\n */\nconst earthCircumfrence = 2 * Math.PI * earthRadius; // meters\n\n/*\n * The circumference at a line of latitude in meters.\n */\nfunction circumferenceAtLatitude(latitude: number) {\n return earthCircumfrence * Math.cos((latitude * Math.PI) / 180);\n}\n\nexport function mercatorXfromLng(lng: number) {\n return (180 + lng) / 360;\n}\n\nexport function mercatorYfromLat(lat: number) {\n return (\n (180 -\n (180 / Math.PI) *\n Math.log(Math.tan(Math.PI / 4 + (lat * Math.PI) / 360))) /\n 360\n );\n}\n\nexport function mercatorZfromAltitude(altitude: number, lat: number) {\n return altitude / circumferenceAtLatitude(lat);\n}\n\nexport function lngFromMercatorX(x: number) {\n return x * 360 - 180;\n}\n\nexport function latFromMercatorY(y: number) {\n const y2 = 180 - y * 360;\n return (360 / Math.PI) * Math.atan(Math.exp((y2 * Math.PI) / 180)) - 90;\n}\n\nexport function altitudeFromMercatorZ(z: number, y: number) {\n return z * circumferenceAtLatitude(latFromMercatorY(y));\n}\n\n/**\n * Determine the Mercator scale factor for a given latitude, see\n * https://en.wikipedia.org/wiki/Mercator_projection#Scale_factor\n *\n * At the equator the scale factor will be 1, which increases at higher latitudes.\n *\n * @param {number} lat Latitude\n * @returns {number} scale factor\n * @private\n */\nexport function mercatorScale(lat: number) {\n return 1 / Math.cos((lat * Math.PI) / 180);\n}\n\nexport default class MercatorCoordinate {\n public static fromLngLat(lngLatLike: LngLatLike, altitude: number = 0) {\n const lngLat = LngLat.convert(lngLatLike);\n\n return new MercatorCoordinate(\n mercatorXfromLng(lngLat.lng),\n mercatorYfromLat(lngLat.lat),\n mercatorZfromAltitude(altitude, lngLat.lat),\n );\n }\n public x: number;\n public y: number;\n public z: number;\n\n constructor(x: number, y: number, z: number = 0) {\n this.x = +x;\n this.y = +y;\n this.z = +z;\n }\n\n public toLngLat() {\n return new LngLat(lngFromMercatorX(this.x), latFromMercatorY(this.y));\n }\n\n public toAltitude() {\n return altitudeFromMercatorZ(this.z, this.y);\n }\n\n public meterInMercatorCoordinateUnits() {\n // 1 meter / circumference at equator in meters * Mercator projection scale factor at this latitude\n return (1 / earthCircumfrence) * mercatorScale(latFromMercatorY(this.y));\n }\n}\n"],"file":"mercator.js"}
package/lib/geo/simple.js CHANGED
@@ -1,20 +1,20 @@
1
1
  "use strict";
2
2
 
3
- var _interopRequireWildcard = require("@babel/runtime/helpers/interopRequireWildcard");
4
-
5
3
  var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
6
4
 
5
+ var _typeof = require("@babel/runtime/helpers/typeof");
6
+
7
7
  Object.defineProperty(exports, "__esModule", {
8
8
  value: true
9
9
  });
10
+ exports.altitudeFromMercatorZ = altitudeFromMercatorZ;
11
+ exports.default = void 0;
12
+ exports.latFromMercatorY = latFromMercatorY;
13
+ exports.lngFromMercatorX = lngFromMercatorX;
14
+ exports.mercatorScale = mercatorScale;
10
15
  exports.mercatorXfromLng = mercatorXfromLng;
11
16
  exports.mercatorYfromLat = mercatorYfromLat;
12
17
  exports.mercatorZfromAltitude = mercatorZfromAltitude;
13
- exports.lngFromMercatorX = lngFromMercatorX;
14
- exports.latFromMercatorY = latFromMercatorY;
15
- exports.altitudeFromMercatorZ = altitudeFromMercatorZ;
16
- exports.mercatorScale = mercatorScale;
17
- exports.default = void 0;
18
18
 
19
19
  var _classCallCheck2 = _interopRequireDefault(require("@babel/runtime/helpers/classCallCheck"));
20
20
 
@@ -24,6 +24,10 @@ var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/de
24
24
 
25
25
  var _lng_lat = _interopRequireWildcard(require("../geo/lng_lat"));
26
26
 
27
+ function _getRequireWildcardCache(nodeInterop) { if (typeof WeakMap !== "function") return null; var cacheBabelInterop = new WeakMap(); var cacheNodeInterop = new WeakMap(); return (_getRequireWildcardCache = function _getRequireWildcardCache(nodeInterop) { return nodeInterop ? cacheNodeInterop : cacheBabelInterop; })(nodeInterop); }
28
+
29
+ function _interopRequireWildcard(obj, nodeInterop) { if (!nodeInterop && obj && obj.__esModule) { return obj; } if (obj === null || _typeof(obj) !== "object" && typeof obj !== "function") { return { default: obj }; } var cache = _getRequireWildcardCache(nodeInterop); if (cache && cache.has(obj)) { return cache.get(obj); } var newObj = {}; var hasPropertyDescriptor = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var key in obj) { if (key !== "default" && Object.prototype.hasOwnProperty.call(obj, key)) { var desc = hasPropertyDescriptor ? Object.getOwnPropertyDescriptor(obj, key) : null; if (desc && (desc.get || desc.set)) { Object.defineProperty(newObj, key, desc); } else { newObj[key] = obj[key]; } } } newObj.default = obj; if (cache) { cache.set(obj, newObj); } return newObj; }
30
+
27
31
  var earthCircumfrence = 2 * Math.PI * _lng_lat.earthRadius;
28
32
 
29
33
  function circumferenceAtLatitude(latitude) {
@@ -1 +1 @@
1
- {"version":3,"sources":["../../src/geo/simple.ts"],"names":["earthCircumfrence","Math","PI","earthRadius","circumferenceAtLatitude","latitude","cos","mercatorXfromLng","lng","mercatorYfromLat","lat","mercatorZfromAltitude","altitude","lngFromMercatorX","x","latFromMercatorY","y","altitudeFromMercatorZ","z","mercatorScale","SimpleCoordinate","LngLat","lngLatLike","lngLat","convert"],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;AAAA;;AAKA,IAAMA,iBAAiB,GAAG,IAAIC,IAAI,CAACC,EAAT,GAAcC,oBAAxC;;AAKA,SAASC,uBAAT,CAAiCC,QAAjC,EAAmD;AACjD,SAAOL,iBAAiB,GAAGC,IAAI,CAACK,GAAL,CAAUD,QAAQ,GAAGJ,IAAI,CAACC,EAAjB,GAAuB,GAAhC,CAA3B;AACD;;AAEM,SAASK,gBAAT,CAA0BC,GAA1B,EAAuC;AAC5C,SAAOA,GAAP;AACD;;AAEM,SAASC,gBAAT,CAA0BC,GAA1B,EAAuC;AAC5C,SAAOA,GAAP;AACD;;AAEM,SAASC,qBAAT,CAA+BC,QAA/B,EAAiDF,GAAjD,EAA8D;AACnE,SAAOE,QAAP;AACD;;AAEM,SAASC,gBAAT,CAA0BC,CAA1B,EAAqC;AAC1C,SAAOA,CAAP;AACD;;AAEM,SAASC,gBAAT,CAA0BC,CAA1B,EAAqC;AAC1C,SAAOA,CAAP;AACD;;AAEM,SAASC,qBAAT,CAA+BC,CAA/B,EAA0CF,CAA1C,EAAqD;AAC1D,SAAOE,CAAP;AACD;;AAYM,SAASC,aAAT,CAAuBT,GAAvB,EAAoC;AACzC,SAAO,CAAP;AACD;;IAEoBU,gB;AAcnB,4BAAYN,CAAZ,EAAuBE,CAAvB,EAAiD;AAAA,QAAfE,CAAe,uEAAH,CAAG;AAAA;AAAA;AAAA;AAAA;AAC/C,SAAKJ,CAAL,GAAS,CAACA,CAAV;AACA,SAAKE,CAAL,GAAS,CAACA,CAAV;AACA,SAAKE,CAAL,GAAS,CAACA,CAAV;AACD;;;;WACD,oBAAkB;AAChB,aAAO,IAAIG,gBAAJ,CAAW,KAAKP,CAAhB,EAAmB,KAAKE,CAAxB,CAAP;AACD;;;WAED,sBAAoB;AAClB,aAAO,KAAKE,CAAZ;AACD;;;WAED,0CAAwC;AAEtC,aAAO,CAAP;AACD;;;WA7BD,oBAAyBI,UAAzB,EAAuE;AAAA,UAAtBV,QAAsB,uEAAH,CAAG;;AACrE,UAAMW,MAAM,GAAGF,iBAAOG,OAAP,CAAeF,UAAf,CAAf;;AAEA,aAAO,IAAIF,gBAAJ,CACLb,gBAAgB,CAACgB,MAAM,CAACf,GAAR,CADX,EAELC,gBAAgB,CAACc,MAAM,CAACb,GAAR,CAFX,EAGLC,qBAAqB,CAACC,QAAD,EAAWW,MAAM,CAACb,GAAlB,CAHhB,CAAP;AAKD","sourcesContent":["import LngLat, { earthRadius, LngLatLike } from '../geo/lng_lat';\n\n/*\n * The average circumference of the world in meters.\n */\nconst earthCircumfrence = 2 * Math.PI * earthRadius; // meters\n\n/*\n * The circumference at a line of latitude in meters.\n */\nfunction circumferenceAtLatitude(latitude: number) {\n return earthCircumfrence * Math.cos((latitude * Math.PI) / 180);\n}\n\nexport function mercatorXfromLng(lng: number) {\n return lng;\n}\n\nexport function mercatorYfromLat(lat: number) {\n return lat;\n}\n\nexport function mercatorZfromAltitude(altitude: number, lat: number) {\n return altitude;\n}\n\nexport function lngFromMercatorX(x: number) {\n return x;\n}\n\nexport function latFromMercatorY(y: number) {\n return y;\n}\n\nexport function altitudeFromMercatorZ(z: number, y: number) {\n return z;\n}\n\n/**\n * Determine the Mercator scale factor for a given latitude, see\n * https://en.wikipedia.org/wiki/Mercator_projection#Scale_factor\n *\n * At the equator the scale factor will be 1, which increases at higher latitudes.\n *\n * @param {number} lat Latitude\n * @returns {number} scale factor\n * @private\n */\nexport function mercatorScale(lat: number) {\n return 1;\n}\n\nexport default class SimpleCoordinate {\n public static fromLngLat(lngLatLike: LngLatLike, altitude: number = 0) {\n const lngLat = LngLat.convert(lngLatLike);\n\n return new SimpleCoordinate(\n mercatorXfromLng(lngLat.lng),\n mercatorYfromLat(lngLat.lat),\n mercatorZfromAltitude(altitude, lngLat.lat),\n );\n }\n public x: number;\n public y: number;\n public z: number;\n\n constructor(x: number, y: number, z: number = 0) {\n this.x = +x;\n this.y = +y;\n this.z = +z;\n }\n public toLngLat() {\n return new LngLat(this.x, this.y);\n }\n\n public toAltitude() {\n return this.z;\n }\n\n public meterInMercatorCoordinateUnits() {\n // 1 meter / circumference at equator in meters * Mercator projection scale factor at this latitude\n return 1;\n }\n}\n"],"file":"simple.js"}
1
+ {"version":3,"sources":["../../src/geo/simple.ts"],"names":["earthCircumfrence","Math","PI","earthRadius","circumferenceAtLatitude","latitude","cos","mercatorXfromLng","lng","mercatorYfromLat","lat","mercatorZfromAltitude","altitude","lngFromMercatorX","x","latFromMercatorY","y","altitudeFromMercatorZ","z","mercatorScale","SimpleCoordinate","LngLat","lngLatLike","lngLat","convert"],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;AAAA;;;;;;AAKA,IAAMA,iBAAiB,GAAG,IAAIC,IAAI,CAACC,EAAT,GAAcC,oBAAxC;;AAKA,SAASC,uBAAT,CAAiCC,QAAjC,EAAmD;AACjD,SAAOL,iBAAiB,GAAGC,IAAI,CAACK,GAAL,CAAUD,QAAQ,GAAGJ,IAAI,CAACC,EAAjB,GAAuB,GAAhC,CAA3B;AACD;;AAEM,SAASK,gBAAT,CAA0BC,GAA1B,EAAuC;AAC5C,SAAOA,GAAP;AACD;;AAEM,SAASC,gBAAT,CAA0BC,GAA1B,EAAuC;AAC5C,SAAOA,GAAP;AACD;;AAEM,SAASC,qBAAT,CAA+BC,QAA/B,EAAiDF,GAAjD,EAA8D;AACnE,SAAOE,QAAP;AACD;;AAEM,SAASC,gBAAT,CAA0BC,CAA1B,EAAqC;AAC1C,SAAOA,CAAP;AACD;;AAEM,SAASC,gBAAT,CAA0BC,CAA1B,EAAqC;AAC1C,SAAOA,CAAP;AACD;;AAEM,SAASC,qBAAT,CAA+BC,CAA/B,EAA0CF,CAA1C,EAAqD;AAC1D,SAAOE,CAAP;AACD;;AAYM,SAASC,aAAT,CAAuBT,GAAvB,EAAoC;AACzC,SAAO,CAAP;AACD;;IAEoBU,gB;AAcnB,4BAAYN,CAAZ,EAAuBE,CAAvB,EAAiD;AAAA,QAAfE,CAAe,uEAAH,CAAG;AAAA;AAAA;AAAA;AAAA;AAC/C,SAAKJ,CAAL,GAAS,CAACA,CAAV;AACA,SAAKE,CAAL,GAAS,CAACA,CAAV;AACA,SAAKE,CAAL,GAAS,CAACA,CAAV;AACD;;;;WACD,oBAAkB;AAChB,aAAO,IAAIG,gBAAJ,CAAW,KAAKP,CAAhB,EAAmB,KAAKE,CAAxB,CAAP;AACD;;;WAED,sBAAoB;AAClB,aAAO,KAAKE,CAAZ;AACD;;;WAED,0CAAwC;AAEtC,aAAO,CAAP;AACD;;;WA7BD,oBAAyBI,UAAzB,EAAuE;AAAA,UAAtBV,QAAsB,uEAAH,CAAG;;AACrE,UAAMW,MAAM,GAAGF,iBAAOG,OAAP,CAAeF,UAAf,CAAf;;AAEA,aAAO,IAAIF,gBAAJ,CACLb,gBAAgB,CAACgB,MAAM,CAACf,GAAR,CADX,EAELC,gBAAgB,CAACc,MAAM,CAACb,GAAR,CAFX,EAGLC,qBAAqB,CAACC,QAAD,EAAWW,MAAM,CAACb,GAAlB,CAHhB,CAAP;AAKD","sourcesContent":["import LngLat, { earthRadius, LngLatLike } from '../geo/lng_lat';\n\n/*\n * The average circumference of the world in meters.\n */\nconst earthCircumfrence = 2 * Math.PI * earthRadius; // meters\n\n/*\n * The circumference at a line of latitude in meters.\n */\nfunction circumferenceAtLatitude(latitude: number) {\n return earthCircumfrence * Math.cos((latitude * Math.PI) / 180);\n}\n\nexport function mercatorXfromLng(lng: number) {\n return lng;\n}\n\nexport function mercatorYfromLat(lat: number) {\n return lat;\n}\n\nexport function mercatorZfromAltitude(altitude: number, lat: number) {\n return altitude;\n}\n\nexport function lngFromMercatorX(x: number) {\n return x;\n}\n\nexport function latFromMercatorY(y: number) {\n return y;\n}\n\nexport function altitudeFromMercatorZ(z: number, y: number) {\n return z;\n}\n\n/**\n * Determine the Mercator scale factor for a given latitude, see\n * https://en.wikipedia.org/wiki/Mercator_projection#Scale_factor\n *\n * At the equator the scale factor will be 1, which increases at higher latitudes.\n *\n * @param {number} lat Latitude\n * @returns {number} scale factor\n * @private\n */\nexport function mercatorScale(lat: number) {\n return 1;\n}\n\nexport default class SimpleCoordinate {\n public static fromLngLat(lngLatLike: LngLatLike, altitude: number = 0) {\n const lngLat = LngLat.convert(lngLatLike);\n\n return new SimpleCoordinate(\n mercatorXfromLng(lngLat.lng),\n mercatorYfromLat(lngLat.lat),\n mercatorZfromAltitude(altitude, lngLat.lat),\n );\n }\n public x: number;\n public y: number;\n public z: number;\n\n constructor(x: number, y: number, z: number = 0) {\n this.x = +x;\n this.y = +y;\n this.z = +z;\n }\n public toLngLat() {\n return new LngLat(this.x, this.y);\n }\n\n public toAltitude() {\n return this.z;\n }\n\n public meterInMercatorCoordinateUnits() {\n // 1 meter / circumference at equator in meters * Mercator projection scale factor at this latitude\n return 1;\n }\n}\n"],"file":"simple.js"}
@@ -1,9 +1,9 @@
1
1
  "use strict";
2
2
 
3
- var _interopRequireWildcard = require("@babel/runtime/helpers/interopRequireWildcard");
4
-
5
3
  var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
6
4
 
5
+ var _typeof = require("@babel/runtime/helpers/typeof");
6
+
7
7
  Object.defineProperty(exports, "__esModule", {
8
8
  value: true
9
9
  });
@@ -29,6 +29,10 @@ var _lng_lat_bounds = _interopRequireDefault(require("./lng_lat_bounds"));
29
29
 
30
30
  var _mercator = _interopRequireWildcard(require("./mercator"));
31
31
 
32
+ function _getRequireWildcardCache(nodeInterop) { if (typeof WeakMap !== "function") return null; var cacheBabelInterop = new WeakMap(); var cacheNodeInterop = new WeakMap(); return (_getRequireWildcardCache = function _getRequireWildcardCache(nodeInterop) { return nodeInterop ? cacheNodeInterop : cacheBabelInterop; })(nodeInterop); }
33
+
34
+ function _interopRequireWildcard(obj, nodeInterop) { if (!nodeInterop && obj && obj.__esModule) { return obj; } if (obj === null || _typeof(obj) !== "object" && typeof obj !== "function") { return { default: obj }; } var cache = _getRequireWildcardCache(nodeInterop); if (cache && cache.has(obj)) { return cache.get(obj); } var newObj = {}; var hasPropertyDescriptor = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var key in obj) { if (key !== "default" && Object.prototype.hasOwnProperty.call(obj, key)) { var desc = hasPropertyDescriptor ? Object.getOwnPropertyDescriptor(obj, key) : null; if (desc && (desc.get || desc.set)) { Object.defineProperty(newObj, key, desc); } else { newObj[key] = obj[key]; } } } newObj.default = obj; if (cache) { cache.set(obj, newObj); } return newObj; }
35
+
32
36
  function _createForOfIteratorHelper(o, allowArrayLike) { var it = typeof Symbol !== "undefined" && o[Symbol.iterator] || o["@@iterator"]; if (!it) { if (Array.isArray(o) || (it = _unsupportedIterableToArray(o)) || allowArrayLike && o && typeof o.length === "number") { if (it) o = it; var i = 0; var F = function F() {}; return { s: F, n: function n() { if (i >= o.length) return { done: true }; return { done: false, value: o[i++] }; }, e: function e(_e) { throw _e; }, f: F }; } throw new TypeError("Invalid attempt to iterate non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); } var normalCompletion = true, didErr = false, err; return { s: function s() { it = it.call(o); }, n: function n() { var step = it.next(); normalCompletion = step.done; return step; }, e: function e(_e2) { didErr = true; err = _e2; }, f: function f() { try { if (!normalCompletion && it.return != null) it.return(); } finally { if (didErr) throw err; } } }; }
33
37
 
34
38
  function _unsupportedIterableToArray(o, minLen) { if (!o) return; if (typeof o === "string") return _arrayLikeToArray(o, minLen); var n = Object.prototype.toString.call(o).slice(8, -1); if (n === "Object" && o.constructor) n = o.constructor.name; if (n === "Map" || n === "Set") return Array.from(o); if (n === "Arguments" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return _arrayLikeToArray(o, minLen); }