@antv/l7-map 2.5.36 → 2.5.37-mini
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 +1 -1
- package/lib/earthmap.js +7 -26
- package/lib/earthmap.js.map +1 -1
- package/lib/handler/handler_manager.js +55 -33
- package/lib/handler/handler_manager.js.map +1 -1
- package/lib/handler/shim/drag_pan.js +10 -2
- package/lib/handler/shim/drag_pan.js.map +1 -1
- package/lib/handler/shim/touch_zoom_rotate.js +10 -2
- package/lib/handler/shim/touch_zoom_rotate.js.map +1 -1
- package/lib/hash.js +9 -4
- package/lib/hash.js.map +1 -1
- package/lib/map.js +39 -19
- package/lib/map.js.map +1 -1
- package/lib/util.js +7 -5
- package/lib/util.js.map +1 -1
- package/lib/utils/dom.js +66 -26
- package/lib/utils/dom.js.map +1 -1
- package/lib/utils/performance.js +4 -1
- package/lib/utils/performance.js.map +1 -1
- package/package.json +3 -3
- package/LICENSE.md +0 -21
- package/es/camera.d.ts +0 -82
- package/es/camera.js +0 -729
- package/es/camera.js.map +0 -1
- package/es/earthmap.d.ts +0 -67
- package/es/earthmap.js +0 -454
- package/es/earthmap.js.map +0 -1
- package/es/geo/edge_insets.d.ts +0 -54
- package/es/geo/edge_insets.js +0 -88
- package/es/geo/edge_insets.js.map +0 -1
- package/es/geo/lng_lat.d.ts +0 -18
- package/es/geo/lng_lat.js +0 -77
- package/es/geo/lng_lat.js.map +0 -1
- package/es/geo/lng_lat_bounds.d.ts +0 -24
- package/es/geo/lng_lat_bounds.js +0 -170
- package/es/geo/lng_lat_bounds.js.map +0 -1
- package/es/geo/mercator.d.ts +0 -28
- package/es/geo/mercator.js +0 -79
- package/es/geo/mercator.js.map +0 -1
- package/es/geo/point.d.ts +0 -40
- package/es/geo/point.js +0 -237
- package/es/geo/point.js.map +0 -1
- package/es/geo/simple.d.ts +0 -28
- package/es/geo/simple.js +0 -78
- package/es/geo/simple.js.map +0 -1
- package/es/geo/transform.d.ts +0 -198
- package/es/geo/transform.js +0 -663
- package/es/geo/transform.js.map +0 -1
- package/es/handler/IHandler.d.ts +0 -34
- package/es/handler/IHandler.js +0 -2
- package/es/handler/IHandler.js.map +0 -1
- package/es/handler/blockable_map_event.d.ts +0 -17
- package/es/handler/blockable_map_event.js +0 -84
- package/es/handler/blockable_map_event.js.map +0 -1
- package/es/handler/box_zoom.d.ts +0 -59
- package/es/handler/box_zoom.js +0 -184
- package/es/handler/box_zoom.js.map +0 -1
- package/es/handler/click_zoom.d.ts +0 -16
- package/es/handler/click_zoom.js +0 -64
- package/es/handler/click_zoom.js.map +0 -1
- package/es/handler/events/event.d.ts +0 -4
- package/es/handler/events/event.js +0 -14
- package/es/handler/events/event.js.map +0 -1
- package/es/handler/events/index.d.ts +0 -4
- package/es/handler/events/index.js +0 -5
- package/es/handler/events/index.js.map +0 -1
- package/es/handler/events/map_mouse_event.d.ts +0 -34
- package/es/handler/events/map_mouse_event.js +0 -65
- package/es/handler/events/map_mouse_event.js.map +0 -1
- package/es/handler/events/map_touch_event.d.ts +0 -57
- package/es/handler/events/map_touch_event.js +0 -75
- package/es/handler/events/map_touch_event.js.map +0 -1
- package/es/handler/events/map_wheel_event.d.ts +0 -33
- package/es/handler/events/map_wheel_event.js +0 -52
- package/es/handler/events/map_wheel_event.js.map +0 -1
- package/es/handler/events/render_event.d.ts +0 -5
- package/es/handler/events/render_event.js +0 -41
- package/es/handler/events/render_event.js.map +0 -1
- package/es/handler/handler_inertia.d.ts +0 -23
- package/es/handler/handler_inertia.js +0 -186
- package/es/handler/handler_inertia.js.map +0 -1
- package/es/handler/handler_manager.d.ts +0 -57
- package/es/handler/handler_manager.js +0 -655
- package/es/handler/handler_manager.js.map +0 -1
- package/es/handler/handler_util.d.ts +0 -4
- package/es/handler/handler_util.js +0 -10
- package/es/handler/handler_util.js.map +0 -1
- package/es/handler/keyboard.d.ts +0 -36
- package/es/handler/keyboard.js +0 -157
- package/es/handler/keyboard.js.map +0 -1
- package/es/handler/map_event.d.ts +0 -29
- package/es/handler/map_event.js +0 -120
- package/es/handler/map_event.js.map +0 -1
- package/es/handler/mouse/index.d.ts +0 -4
- package/es/handler/mouse/index.js +0 -5
- package/es/handler/mouse/index.js.map +0 -1
- package/es/handler/mouse/mouse_handler.d.ts +0 -22
- package/es/handler/mouse/mouse_handler.js +0 -131
- package/es/handler/mouse/mouse_handler.js.map +0 -1
- package/es/handler/mouse/mousepan_handler.d.ts +0 -10
- package/es/handler/mouse/mousepan_handler.js +0 -54
- package/es/handler/mouse/mousepan_handler.js.map +0 -1
- package/es/handler/mouse/mousepitch_hander.d.ts +0 -9
- package/es/handler/mouse/mousepitch_hander.js +0 -54
- package/es/handler/mouse/mousepitch_hander.js.map +0 -1
- package/es/handler/mouse/mouserotate_hander.d.ts +0 -9
- package/es/handler/mouse/mouserotate_hander.js +0 -54
- package/es/handler/mouse/mouserotate_hander.js.map +0 -1
- package/es/handler/mouse/util.d.ts +0 -6
- package/es/handler/mouse/util.js +0 -12
- package/es/handler/mouse/util.js.map +0 -1
- package/es/handler/scroll_zoom.d.ts +0 -93
- package/es/handler/scroll_zoom.js +0 -317
- package/es/handler/scroll_zoom.js.map +0 -1
- package/es/handler/shim/dblclick_zoom.d.ts +0 -40
- package/es/handler/shim/dblclick_zoom.js +0 -45
- package/es/handler/shim/dblclick_zoom.js.map +0 -1
- package/es/handler/shim/drag_pan.d.ts +0 -61
- package/es/handler/shim/drag_pan.js +0 -53
- package/es/handler/shim/drag_pan.js.map +0 -1
- package/es/handler/shim/drag_rotate.d.ts +0 -46
- package/es/handler/shim/drag_rotate.js +0 -51
- package/es/handler/shim/drag_rotate.js.map +0 -1
- package/es/handler/shim/touch_zoom_rotate.d.ts +0 -70
- package/es/handler/shim/touch_zoom_rotate.js +0 -80
- package/es/handler/shim/touch_zoom_rotate.js.map +0 -1
- package/es/handler/tap/single_tap_recognizer.d.ts +0 -20
- package/es/handler/tap/single_tap_recognizer.js +0 -127
- package/es/handler/tap/single_tap_recognizer.js.map +0 -1
- package/es/handler/tap/tap_drag_zoom.d.ts +0 -22
- package/es/handler/tap/tap_drag_zoom.js +0 -124
- package/es/handler/tap/tap_drag_zoom.js.map +0 -1
- package/es/handler/tap/tap_recognizer.d.ts +0 -17
- package/es/handler/tap/tap_recognizer.js +0 -72
- package/es/handler/tap/tap_recognizer.js.map +0 -1
- package/es/handler/tap/tap_zoom.d.ts +0 -22
- package/es/handler/tap/tap_zoom.js +0 -124
- package/es/handler/tap/tap_zoom.js.map +0 -1
- package/es/handler/touch/index.d.ts +0 -5
- package/es/handler/touch/index.js +0 -6
- package/es/handler/touch/index.js.map +0 -1
- package/es/handler/touch/touch_pan.d.ts +0 -30
- package/es/handler/touch/touch_pan.js +0 -139
- package/es/handler/touch/touch_pan.js.map +0 -1
- package/es/handler/touch/touch_pitch.d.ts +0 -13
- package/es/handler/touch/touch_pitch.js +0 -120
- package/es/handler/touch/touch_pitch.js.map +0 -1
- package/es/handler/touch/touch_rotate.d.ts +0 -12
- package/es/handler/touch/touch_rotate.js +0 -88
- package/es/handler/touch/touch_rotate.js.map +0 -1
- package/es/handler/touch/touch_zoom.d.ts +0 -12
- package/es/handler/touch/touch_zoom.js +0 -79
- package/es/handler/touch/touch_zoom.js.map +0 -1
- package/es/handler/touch/two_touch.d.ts +0 -23
- package/es/handler/touch/two_touch.js +0 -140
- package/es/handler/touch/two_touch.js.map +0 -1
- package/es/hash.d.ts +0 -15
- package/es/hash.js +0 -143
- package/es/hash.js.map +0 -1
- package/es/index.d.ts +0 -2
- package/es/index.js +0 -3
- package/es/index.js.map +0 -1
- package/es/interface.d.ts +0 -31
- package/es/interface.js +0 -2
- package/es/interface.js.map +0 -1
- package/es/map.d.ts +0 -67
- package/es/map.js +0 -454
- package/es/map.js.map +0 -1
- package/es/util.d.ts +0 -18
- package/es/util.js +0 -74
- package/es/util.js.map +0 -1
- package/es/utils/Aabb.d.ts +0 -12
- package/es/utils/Aabb.js +0 -134
- package/es/utils/Aabb.js.map +0 -1
- package/es/utils/dom.d.ts +0 -4
- package/es/utils/dom.js +0 -165
- package/es/utils/dom.js.map +0 -1
- package/es/utils/performance.d.ts +0 -17
- package/es/utils/performance.js +0 -57
- package/es/utils/performance.js.map +0 -1
- package/es/utils/primitives.d.ts +0 -6
- package/es/utils/primitives.js +0 -44
- package/es/utils/primitives.js.map +0 -1
- package/es/utils/task_queue.d.ts +0 -13
- package/es/utils/task_queue.js +0 -113
- package/es/utils/task_queue.js.map +0 -1
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"sources":["../../src/handler/scroll_zoom.ts"],"names":["LngLat","bezier","ease","interpolate","now","DOM","wheelZoomDelta","defaultZoomRate","wheelZoomRate","maxScalePerFrame","ScrollZoomHandler","map","handler","frameId","isActive","tr","transform","delta","zoomRate","type","Math","abs","scale","exp","fromScale","targetZoom","zoomScale","min","maxZoom","max","minZoom","scaleZoom","startZoom","zoom","easing","smoothOutEasing","finished","t","lastWheelEventTime","k","active","finishTimeout","setTimeout","zooming","triggerRenderFrame","noInertia","needsRenderFrame","zoomDelta","around","aroundPoint","originalEvent","lastWheelEvent","el","getCanvasContainer","enabled","undefined","options","isEnabled","aroundCenter","e","value","deltaMode","window","WheelEvent","DOM_DELTA_LINE","deltaY","nowTime","timeDelta","lastValue","timeout","onTimeout","clearTimeout","shiftKey","start","preventDefault","onScrollFrame","initialEvent","isZooming","pos","mousePos","convert","getCenter","unproject","locationPoint","duration","prevEase","preEase","speed","x","sqrt","y"],"mappings":"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","sourcesContent":["// @ts-ignore\nimport { EarthMap } from '../earthmap';\nimport LngLat from '../geo/lng_lat';\nimport Point from '../geo/point';\nimport { Map } from '../map';\nimport { bezier, ease, interpolate, now } from '../util';\nimport DOM from '../utils/dom';\nimport HandlerManager from './handler_manager';\n\n// deltaY value for mouse scroll wheel identification\nconst wheelZoomDelta = 4.000244140625;\n\n// These magic numbers control the rate of zoom. Trackpad events fire at a greater\n// frequency than mouse scroll wheel, so reduce the zoom rate per wheel tick\nconst defaultZoomRate = 1 / 100;\nconst wheelZoomRate = 1 / 450;\n\n// upper bound on how much we scale the map in any single render frame; this\n// is used to limit zoom rate in the case of very fast scrolling\nconst maxScalePerFrame = 2;\n\n/**\n * The `ScrollZoomHandler` allows the user to zoom the map by scrolling.\n */\nclass ScrollZoomHandler {\n private map: Map | EarthMap;\n private el: HTMLElement;\n private enabled: boolean;\n private active: boolean;\n private zooming: boolean;\n private aroundCenter: boolean;\n private around: LngLat;\n private aroundPoint: Point;\n private type: 'wheel' | 'trackpad' | null;\n private lastValue: number;\n private timeout: number | null; // used for delayed-handling of a single wheel movement\n private finishTimeout: number; // used to delay final '{move,zoom}end' events\n\n private lastWheelEvent: any;\n private lastWheelEventTime: number;\n\n private startZoom: number;\n private targetZoom: number;\n private delta: number;\n private easing: (time: number) => number;\n private prevEase: {\n start: number;\n duration: number;\n easing: (_: number) => number;\n };\n\n private frameId: boolean | null;\n private handler: HandlerManager;\n\n private defaultZoomRate: number;\n private wheelZoomRate: number;\n\n /**\n * @private\n */\n constructor(map: Map | EarthMap, handler: HandlerManager) {\n this.map = map;\n this.el = map.getCanvasContainer();\n this.handler = handler;\n\n this.delta = 0;\n this.defaultZoomRate = defaultZoomRate;\n this.wheelZoomRate = wheelZoomRate;\n }\n\n /**\n * Set the zoom rate of a trackpad\n * @param {number} [zoomRate=1/100] The rate used to scale trackpad movement to a zoom value.\n * @example\n * // Speed up trackpad zoom\n * map.scrollZoom.setZoomRate(1/25);\n */\n public setZoomRate(zoomRate: number) {\n this.defaultZoomRate = zoomRate;\n }\n\n /**\n * Set the zoom rate of a mouse wheel\n * @param {number} [wheelZoomRate=1/450] The rate used to scale mouse wheel movement to a zoom value.\n * @example\n * // Slow down zoom of mouse wheel\n * map.scrollZoom.setWheelZoomRate(1/600);\n */\n public setWheelZoomRate(zoomRate: number) {\n this.wheelZoomRate = zoomRate;\n }\n\n /**\n * Returns a Boolean indicating whether the \"scroll to zoom\" interaction is enabled.\n *\n * @returns {boolean} `true` if the \"scroll to zoom\" interaction is enabled.\n */\n public isEnabled() {\n return !!this.enabled;\n }\n\n /*\n * Active state is turned on and off with every scroll wheel event and is set back to false before the map\n * render is called, so _active is not a good candidate for determining if a scroll zoom animation is in\n * progress.\n */\n public isActive() {\n return !!this.active || this.finishTimeout !== undefined;\n }\n\n public isZooming() {\n return !!this.zooming;\n }\n\n /**\n * Enables the \"scroll to zoom\" interaction.\n *\n * @param {Object} [options] Options object.\n * @param {string} [options.around] If \"center\" is passed, map will zoom around center of map\n *\n * @example\n * map.scrollZoom.enable();\n * @example\n * map.scrollZoom.enable({ around: 'center' })\n */\n public enable(options?: any) {\n if (this.isEnabled()) {\n return;\n }\n this.enabled = true;\n this.aroundCenter = options && options.around === 'center';\n }\n\n /**\n * Disables the \"scroll to zoom\" interaction.\n *\n * @example\n * map.scrollZoom.disable();\n */\n public disable() {\n if (!this.isEnabled()) {\n return;\n }\n this.enabled = false;\n }\n\n public wheel(e: WheelEvent) {\n if (!this.isEnabled()) {\n return;\n }\n // Remove `any` cast when https://github.com/facebook/flow/issues/4879 is fixed.\n let value =\n e.deltaMode === window.WheelEvent.DOM_DELTA_LINE\n ? e.deltaY * 40\n : e.deltaY;\n const nowTime = now();\n const timeDelta = nowTime - (this.lastWheelEventTime || 0);\n\n this.lastWheelEventTime = nowTime;\n\n if (value !== 0 && value % wheelZoomDelta === 0) {\n // This one is definitely a mouse wheel event.\n this.type = 'wheel';\n } else if (value !== 0 && Math.abs(value) < 4) {\n // This one is definitely a trackpad event because it is so small.\n this.type = 'trackpad';\n } else if (timeDelta > 400) {\n // This is likely a new scroll action.\n this.type = null;\n this.lastValue = value;\n\n // Start a timeout in case this was a singular event, and dely it by up to 40ms.\n // @ts-ignore\n this.timeout = setTimeout(this.onTimeout, 40, e);\n } else if (!this.type) {\n // This is a repeating event, but we don't know the type of event just yet.\n // If the delta per time is small, we assume it's a fast trackpad; otherwise we switch into wheel mode.\n this.type = Math.abs(timeDelta * value) < 200 ? 'trackpad' : 'wheel';\n\n // Make sure our delayed event isn't fired again, because we accumulate\n // the previous event (which was less than 40ms ago) into this event.\n if (this.timeout) {\n clearTimeout(this.timeout);\n this.timeout = null;\n value += this.lastValue;\n }\n }\n\n // Slow down zoom if shift key is held for more precise zooming\n if (e.shiftKey && value) {\n value = value / 4;\n }\n // Only fire the callback if we actually know what type of scrolling device the user uses.\n if (this.type) {\n this.lastWheelEvent = e;\n this.delta -= value;\n if (!this.active) {\n this.start(e);\n }\n }\n\n e.preventDefault();\n }\n\n public renderFrame() {\n return this.onScrollFrame();\n }\n\n public reset() {\n this.active = false;\n }\n\n private onScrollFrame = () => {\n if (!this.frameId) {\n return;\n }\n this.frameId = null;\n\n if (!this.isActive()) {\n return;\n }\n const tr = this.map.transform;\n\n // if we've had scroll events since the last render frame, consume the\n // accumulated delta, and update the target zoom level accordingly\n if (this.delta !== 0) {\n // For trackpad events and single mouse wheel ticks, use the default zoom rate\n const zoomRate =\n this.type === 'wheel' && Math.abs(this.delta) > wheelZoomDelta\n ? this.wheelZoomRate\n : this.defaultZoomRate;\n // Scale by sigmoid of scroll wheel delta.\n let scale =\n maxScalePerFrame / (1 + Math.exp(-Math.abs(this.delta * zoomRate)));\n\n if (this.delta < 0 && scale !== 0) {\n scale = 1 / scale;\n }\n\n const fromScale =\n typeof this.targetZoom === 'number'\n ? tr.zoomScale(this.targetZoom)\n : tr.scale;\n this.targetZoom = Math.min(\n tr.maxZoom,\n Math.max(tr.minZoom, tr.scaleZoom(fromScale * scale)),\n );\n\n // if this is a mouse wheel, refresh the starting zoom and easing\n // function we're using to smooth out the zooming between wheel\n // events\n if (this.type === 'wheel') {\n this.startZoom = tr.zoom;\n this.easing = this.smoothOutEasing(200);\n }\n\n this.delta = 0;\n }\n\n const targetZoom =\n typeof this.targetZoom === 'number' ? this.targetZoom : tr.zoom;\n const startZoom = this.startZoom;\n const easing = this.easing;\n\n let finished = false;\n let zoom;\n if (this.type === 'wheel' && startZoom && easing) {\n const t = Math.min((now() - this.lastWheelEventTime) / 200, 1);\n const k = easing(t);\n zoom = interpolate(startZoom, targetZoom, k);\n if (t < 1) {\n if (!this.frameId) {\n this.frameId = true;\n }\n } else {\n finished = true;\n }\n } else {\n zoom = targetZoom;\n finished = true;\n }\n\n this.active = true;\n\n if (finished) {\n this.active = false;\n // @ts-ignore\n this.finishTimeout = setTimeout(() => {\n this.zooming = false;\n this.handler.triggerRenderFrame();\n // @ts-ignore\n delete this.targetZoom;\n // @ts-ignore\n delete this.finishTimeout;\n }, 200);\n }\n\n return {\n noInertia: true,\n needsRenderFrame: !finished,\n zoomDelta: zoom - tr.zoom,\n around: this.aroundPoint,\n originalEvent: this.lastWheelEvent,\n };\n };\n\n private onTimeout(initialEvent: any) {\n this.type = 'wheel';\n this.delta -= this.lastValue;\n if (!this.active && this.start) {\n this.start(initialEvent);\n }\n }\n\n private start(e: any) {\n if (!this.delta) {\n return;\n }\n\n if (this.frameId) {\n this.frameId = null;\n }\n\n this.active = true;\n if (!this.isZooming()) {\n this.zooming = true;\n }\n\n if (this.finishTimeout) {\n clearTimeout(this.finishTimeout);\n // @ts-ignore\n delete this.finishTimeout;\n }\n\n const pos = DOM.mousePos(this.el, e);\n\n this.around = LngLat.convert(\n this.aroundCenter ? this.map.getCenter() : this.map.unproject(pos),\n );\n this.aroundPoint = this.map.transform.locationPoint(this.around);\n if (!this.frameId) {\n this.frameId = true;\n this.handler.triggerRenderFrame();\n }\n }\n\n private smoothOutEasing(duration: number) {\n let easing = ease;\n\n if (this.prevEase) {\n const preEase = this.prevEase;\n const t = (now() - preEase.start) / preEase.duration;\n const speed = preEase.easing(t + 0.01) - preEase.easing(t);\n\n // Quick hack to make new bezier that is continuous with last\n const x = (0.27 / Math.sqrt(speed * speed + 0.0001)) * 0.01;\n const y = Math.sqrt(0.27 * 0.27 - x * x);\n\n easing = bezier(x, y, 0.25, 1);\n }\n\n this.prevEase = {\n start: now(),\n duration,\n easing,\n };\n\n return easing;\n }\n}\n\nexport default ScrollZoomHandler;\n"],"file":"scroll_zoom.js"}
|
|
@@ -1,40 +0,0 @@
|
|
|
1
|
-
import ClickZoomHandler from '../click_zoom';
|
|
2
|
-
import TapZoomHandler from '../tap/tap_zoom';
|
|
3
|
-
/**
|
|
4
|
-
* The `DoubleClickZoomHandler` allows the user to zoom the map at a point by
|
|
5
|
-
* double clicking or double tapping.
|
|
6
|
-
*/
|
|
7
|
-
export default class DoubleClickZoomHandler {
|
|
8
|
-
private clickZoom;
|
|
9
|
-
private tapZoom;
|
|
10
|
-
/**
|
|
11
|
-
* @private
|
|
12
|
-
*/
|
|
13
|
-
constructor(clickZoom: ClickZoomHandler, TapZoom: TapZoomHandler);
|
|
14
|
-
/**
|
|
15
|
-
* Enables the "double click to zoom" interaction.
|
|
16
|
-
*
|
|
17
|
-
* @example
|
|
18
|
-
* map.doubleClickZoom.enable();
|
|
19
|
-
*/
|
|
20
|
-
enable(): void;
|
|
21
|
-
/**
|
|
22
|
-
* Disables the "double click to zoom" interaction.
|
|
23
|
-
*
|
|
24
|
-
* @example
|
|
25
|
-
* map.doubleClickZoom.disable();
|
|
26
|
-
*/
|
|
27
|
-
disable(): void;
|
|
28
|
-
/**
|
|
29
|
-
* Returns a Boolean indicating whether the "double click to zoom" interaction is enabled.
|
|
30
|
-
*
|
|
31
|
-
* @returns {boolean} `true` if the "double click to zoom" interaction is enabled.
|
|
32
|
-
*/
|
|
33
|
-
isEnabled(): boolean;
|
|
34
|
-
/**
|
|
35
|
-
* Returns a Boolean indicating whether the "double click to zoom" interaction is active, i.e. currently being used.
|
|
36
|
-
*
|
|
37
|
-
* @returns {boolean} `true` if the "double click to zoom" interaction is active.
|
|
38
|
-
*/
|
|
39
|
-
isActive(): boolean;
|
|
40
|
-
}
|
|
@@ -1,45 +0,0 @@
|
|
|
1
|
-
import _classCallCheck from "@babel/runtime/helpers/classCallCheck";
|
|
2
|
-
import _createClass from "@babel/runtime/helpers/createClass";
|
|
3
|
-
import _defineProperty from "@babel/runtime/helpers/defineProperty";
|
|
4
|
-
|
|
5
|
-
var DoubleClickZoomHandler = function () {
|
|
6
|
-
function DoubleClickZoomHandler(clickZoom, TapZoom) {
|
|
7
|
-
_classCallCheck(this, DoubleClickZoomHandler);
|
|
8
|
-
|
|
9
|
-
_defineProperty(this, "clickZoom", void 0);
|
|
10
|
-
|
|
11
|
-
_defineProperty(this, "tapZoom", void 0);
|
|
12
|
-
|
|
13
|
-
this.clickZoom = clickZoom;
|
|
14
|
-
this.tapZoom = TapZoom;
|
|
15
|
-
}
|
|
16
|
-
|
|
17
|
-
_createClass(DoubleClickZoomHandler, [{
|
|
18
|
-
key: "enable",
|
|
19
|
-
value: function enable() {
|
|
20
|
-
this.clickZoom.enable();
|
|
21
|
-
this.tapZoom.enable();
|
|
22
|
-
}
|
|
23
|
-
}, {
|
|
24
|
-
key: "disable",
|
|
25
|
-
value: function disable() {
|
|
26
|
-
this.clickZoom.disable();
|
|
27
|
-
this.tapZoom.disable();
|
|
28
|
-
}
|
|
29
|
-
}, {
|
|
30
|
-
key: "isEnabled",
|
|
31
|
-
value: function isEnabled() {
|
|
32
|
-
return this.clickZoom.isEnabled() && this.tapZoom.isEnabled();
|
|
33
|
-
}
|
|
34
|
-
}, {
|
|
35
|
-
key: "isActive",
|
|
36
|
-
value: function isActive() {
|
|
37
|
-
return this.clickZoom.isActive() || this.tapZoom.isActive();
|
|
38
|
-
}
|
|
39
|
-
}]);
|
|
40
|
-
|
|
41
|
-
return DoubleClickZoomHandler;
|
|
42
|
-
}();
|
|
43
|
-
|
|
44
|
-
export { DoubleClickZoomHandler as default };
|
|
45
|
-
//# sourceMappingURL=dblclick_zoom.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"sources":["../../../src/handler/shim/dblclick_zoom.ts"],"names":["DoubleClickZoomHandler","clickZoom","TapZoom","tapZoom","enable","disable","isEnabled","isActive"],"mappings":";;;;IAOqBA,sB;AAOnB,kCAAYC,SAAZ,EAAyCC,OAAzC,EAAkE;AAAA;;AAAA;;AAAA;;AAChE,SAAKD,SAAL,GAAiBA,SAAjB;AACA,SAAKE,OAAL,GAAeD,OAAf;AACD;;;;WAQD,kBAAgB;AACd,WAAKD,SAAL,CAAeG,MAAf;AACA,WAAKD,OAAL,CAAaC,MAAb;AACD;;;WAQD,mBAAiB;AACf,WAAKH,SAAL,CAAeI,OAAf;AACA,WAAKF,OAAL,CAAaE,OAAb;AACD;;;WAOD,qBAAmB;AACjB,aAAO,KAAKJ,SAAL,CAAeK,SAAf,MAA8B,KAAKH,OAAL,CAAaG,SAAb,EAArC;AACD;;;WAOD,oBAAkB;AAChB,aAAO,KAAKL,SAAL,CAAeM,QAAf,MAA6B,KAAKJ,OAAL,CAAaI,QAAb,EAApC;AACD;;;;;;SAlDkBP,sB","sourcesContent":["import ClickZoomHandler from '../click_zoom';\nimport TapZoomHandler from '../tap/tap_zoom';\n\n/**\n * The `DoubleClickZoomHandler` allows the user to zoom the map at a point by\n * double clicking or double tapping.\n */\nexport default class DoubleClickZoomHandler {\n private clickZoom: ClickZoomHandler;\n private tapZoom: TapZoomHandler;\n\n /**\n * @private\n */\n constructor(clickZoom: ClickZoomHandler, TapZoom: TapZoomHandler) {\n this.clickZoom = clickZoom;\n this.tapZoom = TapZoom;\n }\n\n /**\n * Enables the \"double click to zoom\" interaction.\n *\n * @example\n * map.doubleClickZoom.enable();\n */\n public enable() {\n this.clickZoom.enable();\n this.tapZoom.enable();\n }\n\n /**\n * Disables the \"double click to zoom\" interaction.\n *\n * @example\n * map.doubleClickZoom.disable();\n */\n public disable() {\n this.clickZoom.disable();\n this.tapZoom.disable();\n }\n\n /**\n * Returns a Boolean indicating whether the \"double click to zoom\" interaction is enabled.\n *\n * @returns {boolean} `true` if the \"double click to zoom\" interaction is enabled.\n */\n public isEnabled() {\n return this.clickZoom.isEnabled() && this.tapZoom.isEnabled();\n }\n\n /**\n * Returns a Boolean indicating whether the \"double click to zoom\" interaction is active, i.e. currently being used.\n *\n * @returns {boolean} `true` if the \"double click to zoom\" interaction is active.\n */\n public isActive() {\n return this.clickZoom.isActive() || this.tapZoom.isActive();\n }\n}\n"],"file":"dblclick_zoom.js"}
|
|
@@ -1,61 +0,0 @@
|
|
|
1
|
-
import { MousePanHandler } from '../mouse/';
|
|
2
|
-
import { TouchPanHandler } from '../touch/';
|
|
3
|
-
export interface IDragPanOptions {
|
|
4
|
-
linearity?: number;
|
|
5
|
-
easing?: (t: number) => number;
|
|
6
|
-
deceleration?: number;
|
|
7
|
-
maxSpeed?: number;
|
|
8
|
-
}
|
|
9
|
-
/**
|
|
10
|
-
* The `DragPanHandler` allows the user to pan the map by clicking and dragging
|
|
11
|
-
* the cursor.
|
|
12
|
-
*/
|
|
13
|
-
export default class DragPanHandler {
|
|
14
|
-
inertiaOptions: IDragPanOptions;
|
|
15
|
-
private el;
|
|
16
|
-
private mousePan;
|
|
17
|
-
private touchPan;
|
|
18
|
-
/**
|
|
19
|
-
* @private
|
|
20
|
-
*/
|
|
21
|
-
constructor(el: HTMLElement, mousePan: MousePanHandler, touchPan: TouchPanHandler);
|
|
22
|
-
/**
|
|
23
|
-
* Enables the "drag to pan" interaction.
|
|
24
|
-
*
|
|
25
|
-
* @param {Object} [options] Options object
|
|
26
|
-
* @param {number} [options.linearity=0] factor used to scale the drag velocity
|
|
27
|
-
* @param {Function} [options.easing=bezier(0, 0, 0.3, 1)] easing function applled to `map.panTo` when applying the drag.
|
|
28
|
-
* @param {number} [options.maxSpeed=1400] the maximum value of the drag velocity.
|
|
29
|
-
* @param {number} [options.deceleration=2500] the rate at which the speed reduces after the pan ends.
|
|
30
|
-
*
|
|
31
|
-
* @example
|
|
32
|
-
* map.dragPan.enable();
|
|
33
|
-
* @example
|
|
34
|
-
* map.dragPan.enable({
|
|
35
|
-
* linearity: 0.3,
|
|
36
|
-
* easing: bezier(0, 0, 0.3, 1),
|
|
37
|
-
* maxSpeed: 1400,
|
|
38
|
-
* deceleration: 2500,
|
|
39
|
-
* });
|
|
40
|
-
*/
|
|
41
|
-
enable(options?: IDragPanOptions): void;
|
|
42
|
-
/**
|
|
43
|
-
* Disables the "drag to pan" interaction.
|
|
44
|
-
*
|
|
45
|
-
* @example
|
|
46
|
-
* map.dragPan.disable();
|
|
47
|
-
*/
|
|
48
|
-
disable(): void;
|
|
49
|
-
/**
|
|
50
|
-
* Returns a Boolean indicating whether the "drag to pan" interaction is enabled.
|
|
51
|
-
*
|
|
52
|
-
* @returns {boolean} `true` if the "drag to pan" interaction is enabled.
|
|
53
|
-
*/
|
|
54
|
-
isEnabled(): boolean;
|
|
55
|
-
/**
|
|
56
|
-
* Returns a Boolean indicating whether the "drag to pan" interaction is active, i.e. currently being used.
|
|
57
|
-
*
|
|
58
|
-
* @returns {boolean} `true` if the "drag to pan" interaction is active.
|
|
59
|
-
*/
|
|
60
|
-
isActive(): boolean;
|
|
61
|
-
}
|
|
@@ -1,53 +0,0 @@
|
|
|
1
|
-
import _classCallCheck from "@babel/runtime/helpers/classCallCheck";
|
|
2
|
-
import _createClass from "@babel/runtime/helpers/createClass";
|
|
3
|
-
import _defineProperty from "@babel/runtime/helpers/defineProperty";
|
|
4
|
-
|
|
5
|
-
var DragPanHandler = function () {
|
|
6
|
-
function DragPanHandler(el, mousePan, touchPan) {
|
|
7
|
-
_classCallCheck(this, DragPanHandler);
|
|
8
|
-
|
|
9
|
-
_defineProperty(this, "inertiaOptions", void 0);
|
|
10
|
-
|
|
11
|
-
_defineProperty(this, "el", void 0);
|
|
12
|
-
|
|
13
|
-
_defineProperty(this, "mousePan", void 0);
|
|
14
|
-
|
|
15
|
-
_defineProperty(this, "touchPan", void 0);
|
|
16
|
-
|
|
17
|
-
this.el = el;
|
|
18
|
-
this.mousePan = mousePan;
|
|
19
|
-
this.touchPan = touchPan;
|
|
20
|
-
}
|
|
21
|
-
|
|
22
|
-
_createClass(DragPanHandler, [{
|
|
23
|
-
key: "enable",
|
|
24
|
-
value: function enable(options) {
|
|
25
|
-
this.inertiaOptions = options || {};
|
|
26
|
-
this.mousePan.enable();
|
|
27
|
-
this.touchPan.enable();
|
|
28
|
-
this.el.classList.add('l7-touch-drag-pan');
|
|
29
|
-
}
|
|
30
|
-
}, {
|
|
31
|
-
key: "disable",
|
|
32
|
-
value: function disable() {
|
|
33
|
-
this.mousePan.disable();
|
|
34
|
-
this.touchPan.disable();
|
|
35
|
-
this.el.classList.remove('l7-touch-drag-pan');
|
|
36
|
-
}
|
|
37
|
-
}, {
|
|
38
|
-
key: "isEnabled",
|
|
39
|
-
value: function isEnabled() {
|
|
40
|
-
return this.mousePan.isEnabled() && this.touchPan.isEnabled();
|
|
41
|
-
}
|
|
42
|
-
}, {
|
|
43
|
-
key: "isActive",
|
|
44
|
-
value: function isActive() {
|
|
45
|
-
return this.mousePan.isActive() || this.touchPan.isActive();
|
|
46
|
-
}
|
|
47
|
-
}]);
|
|
48
|
-
|
|
49
|
-
return DragPanHandler;
|
|
50
|
-
}();
|
|
51
|
-
|
|
52
|
-
export { DragPanHandler as default };
|
|
53
|
-
//# sourceMappingURL=drag_pan.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"sources":["../../../src/handler/shim/drag_pan.ts"],"names":["DragPanHandler","el","mousePan","touchPan","options","inertiaOptions","enable","classList","add","disable","remove","isEnabled","isActive"],"mappings":";;;;IAcqBA,c;AAQnB,0BACEC,EADF,EAEEC,QAFF,EAGEC,QAHF,EAIE;AAAA;;AAAA;;AAAA;;AAAA;;AAAA;;AACA,SAAKF,EAAL,GAAUA,EAAV;AACA,SAAKC,QAAL,GAAgBA,QAAhB;AACA,SAAKC,QAAL,GAAgBA,QAAhB;AACD;;;;WAqBD,gBAAcC,OAAd,EAAyC;AACvC,WAAKC,cAAL,GAAsBD,OAAO,IAAI,EAAjC;AACA,WAAKF,QAAL,CAAcI,MAAd;AACA,WAAKH,QAAL,CAAcG,MAAd;AACA,WAAKL,EAAL,CAAQM,SAAR,CAAkBC,GAAlB,CAAsB,mBAAtB;AACD;;;WAQD,mBAAiB;AACf,WAAKN,QAAL,CAAcO,OAAd;AACA,WAAKN,QAAL,CAAcM,OAAd;AACA,WAAKR,EAAL,CAAQM,SAAR,CAAkBG,MAAlB,CAAyB,mBAAzB;AACD;;;WAOD,qBAAmB;AACjB,aAAO,KAAKR,QAAL,CAAcS,SAAd,MAA6B,KAAKR,QAAL,CAAcQ,SAAd,EAApC;AACD;;;WAOD,oBAAkB;AAChB,aAAO,KAAKT,QAAL,CAAcU,QAAd,MAA4B,KAAKT,QAAL,CAAcS,QAAd,EAAnC;AACD;;;;;;SAxEkBZ,c","sourcesContent":["import { MousePanHandler } from '../mouse/';\nimport { TouchPanHandler } from '../touch/';\n\nexport interface IDragPanOptions {\n linearity?: number;\n easing?: (t: number) => number;\n deceleration?: number;\n maxSpeed?: number;\n}\n\n/**\n * The `DragPanHandler` allows the user to pan the map by clicking and dragging\n * the cursor.\n */\nexport default class DragPanHandler {\n public inertiaOptions: IDragPanOptions;\n private el: HTMLElement;\n private mousePan: MousePanHandler;\n private touchPan: TouchPanHandler;\n /**\n * @private\n */\n constructor(\n el: HTMLElement,\n mousePan: MousePanHandler,\n touchPan: TouchPanHandler,\n ) {\n this.el = el;\n this.mousePan = mousePan;\n this.touchPan = touchPan;\n }\n\n /**\n * Enables the \"drag to pan\" interaction.\n *\n * @param {Object} [options] Options object\n * @param {number} [options.linearity=0] factor used to scale the drag velocity\n * @param {Function} [options.easing=bezier(0, 0, 0.3, 1)] easing function applled to `map.panTo` when applying the drag.\n * @param {number} [options.maxSpeed=1400] the maximum value of the drag velocity.\n * @param {number} [options.deceleration=2500] the rate at which the speed reduces after the pan ends.\n *\n * @example\n * map.dragPan.enable();\n * @example\n * map.dragPan.enable({\n * linearity: 0.3,\n * easing: bezier(0, 0, 0.3, 1),\n * maxSpeed: 1400,\n * deceleration: 2500,\n * });\n */\n public enable(options?: IDragPanOptions) {\n this.inertiaOptions = options || {};\n this.mousePan.enable();\n this.touchPan.enable();\n this.el.classList.add('l7-touch-drag-pan');\n }\n\n /**\n * Disables the \"drag to pan\" interaction.\n *\n * @example\n * map.dragPan.disable();\n */\n public disable() {\n this.mousePan.disable();\n this.touchPan.disable();\n this.el.classList.remove('l7-touch-drag-pan');\n }\n\n /**\n * Returns a Boolean indicating whether the \"drag to pan\" interaction is enabled.\n *\n * @returns {boolean} `true` if the \"drag to pan\" interaction is enabled.\n */\n public isEnabled() {\n return this.mousePan.isEnabled() && this.touchPan.isEnabled();\n }\n\n /**\n * Returns a Boolean indicating whether the \"drag to pan\" interaction is active, i.e. currently being used.\n *\n * @returns {boolean} `true` if the \"drag to pan\" interaction is active.\n */\n public isActive() {\n return this.mousePan.isActive() || this.touchPan.isActive();\n }\n}\n"],"file":"drag_pan.js"}
|
|
@@ -1,46 +0,0 @@
|
|
|
1
|
-
import { MousePitchHandler, MouseRotateHandler } from '../mouse';
|
|
2
|
-
/**
|
|
3
|
-
* The `DragRotateHandler` allows the user to rotate the map by clicking and
|
|
4
|
-
* dragging the cursor while holding the right mouse button or `ctrl` key.
|
|
5
|
-
*/
|
|
6
|
-
export default class DragRotateHandler {
|
|
7
|
-
private mouseRotate;
|
|
8
|
-
private mousePitch;
|
|
9
|
-
private pitchWithRotate;
|
|
10
|
-
/**
|
|
11
|
-
* @param {Object} [options]
|
|
12
|
-
* @param {number} [options.bearingSnap] The threshold, measured in degrees, that determines when the map's
|
|
13
|
-
* bearing will snap to north.
|
|
14
|
-
* @param {bool} [options.pitchWithRotate=true] Control the map pitch in addition to the bearing
|
|
15
|
-
* @private
|
|
16
|
-
*/
|
|
17
|
-
constructor(options: {
|
|
18
|
-
pitchWithRotate: boolean;
|
|
19
|
-
}, mouseRotate: MouseRotateHandler, mousePitch: MousePitchHandler);
|
|
20
|
-
/**
|
|
21
|
-
* Enables the "drag to rotate" interaction.
|
|
22
|
-
*
|
|
23
|
-
* @example
|
|
24
|
-
* map.dragRotate.enable();
|
|
25
|
-
*/
|
|
26
|
-
enable(): void;
|
|
27
|
-
/**
|
|
28
|
-
* Disables the "drag to rotate" interaction.
|
|
29
|
-
*
|
|
30
|
-
* @example
|
|
31
|
-
* map.dragRotate.disable();
|
|
32
|
-
*/
|
|
33
|
-
disable(): void;
|
|
34
|
-
/**
|
|
35
|
-
* Returns a Boolean indicating whether the "drag to rotate" interaction is enabled.
|
|
36
|
-
*
|
|
37
|
-
* @returns {boolean} `true` if the "drag to rotate" interaction is enabled.
|
|
38
|
-
*/
|
|
39
|
-
isEnabled(): boolean;
|
|
40
|
-
/**
|
|
41
|
-
* Returns a Boolean indicating whether the "drag to rotate" interaction is active, i.e. currently being used.
|
|
42
|
-
*
|
|
43
|
-
* @returns {boolean} `true` if the "drag to rotate" interaction is active.
|
|
44
|
-
*/
|
|
45
|
-
isActive(): boolean;
|
|
46
|
-
}
|
|
@@ -1,51 +0,0 @@
|
|
|
1
|
-
import _classCallCheck from "@babel/runtime/helpers/classCallCheck";
|
|
2
|
-
import _createClass from "@babel/runtime/helpers/createClass";
|
|
3
|
-
import _defineProperty from "@babel/runtime/helpers/defineProperty";
|
|
4
|
-
|
|
5
|
-
var DragRotateHandler = function () {
|
|
6
|
-
function DragRotateHandler(options, mouseRotate, mousePitch) {
|
|
7
|
-
_classCallCheck(this, DragRotateHandler);
|
|
8
|
-
|
|
9
|
-
_defineProperty(this, "mouseRotate", void 0);
|
|
10
|
-
|
|
11
|
-
_defineProperty(this, "mousePitch", void 0);
|
|
12
|
-
|
|
13
|
-
_defineProperty(this, "pitchWithRotate", void 0);
|
|
14
|
-
|
|
15
|
-
this.pitchWithRotate = options.pitchWithRotate;
|
|
16
|
-
this.mouseRotate = mouseRotate;
|
|
17
|
-
this.mousePitch = mousePitch;
|
|
18
|
-
}
|
|
19
|
-
|
|
20
|
-
_createClass(DragRotateHandler, [{
|
|
21
|
-
key: "enable",
|
|
22
|
-
value: function enable() {
|
|
23
|
-
this.mouseRotate.enable();
|
|
24
|
-
|
|
25
|
-
if (this.pitchWithRotate) {
|
|
26
|
-
this.mousePitch.enable();
|
|
27
|
-
}
|
|
28
|
-
}
|
|
29
|
-
}, {
|
|
30
|
-
key: "disable",
|
|
31
|
-
value: function disable() {
|
|
32
|
-
this.mouseRotate.disable();
|
|
33
|
-
this.mousePitch.disable();
|
|
34
|
-
}
|
|
35
|
-
}, {
|
|
36
|
-
key: "isEnabled",
|
|
37
|
-
value: function isEnabled() {
|
|
38
|
-
return this.mouseRotate.isEnabled() && (!this.pitchWithRotate || this.mousePitch.isEnabled());
|
|
39
|
-
}
|
|
40
|
-
}, {
|
|
41
|
-
key: "isActive",
|
|
42
|
-
value: function isActive() {
|
|
43
|
-
return this.mouseRotate.isActive() || this.mousePitch.isActive();
|
|
44
|
-
}
|
|
45
|
-
}]);
|
|
46
|
-
|
|
47
|
-
return DragRotateHandler;
|
|
48
|
-
}();
|
|
49
|
-
|
|
50
|
-
export { DragRotateHandler as default };
|
|
51
|
-
//# sourceMappingURL=drag_rotate.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"sources":["../../../src/handler/shim/drag_rotate.ts"],"names":["DragRotateHandler","options","mouseRotate","mousePitch","pitchWithRotate","enable","disable","isEnabled","isActive"],"mappings":";;;;IAMqBA,iB;AAYnB,6BACEC,OADF,EAEEC,WAFF,EAGEC,UAHF,EAIE;AAAA;;AAAA;;AAAA;;AAAA;;AACA,SAAKC,eAAL,GAAuBH,OAAO,CAACG,eAA/B;AACA,SAAKF,WAAL,GAAmBA,WAAnB;AACA,SAAKC,UAAL,GAAkBA,UAAlB;AACD;;;;WAQD,kBAAgB;AACd,WAAKD,WAAL,CAAiBG,MAAjB;;AACA,UAAI,KAAKD,eAAT,EAA0B;AACxB,aAAKD,UAAL,CAAgBE,MAAhB;AACD;AACF;;;WAQD,mBAAiB;AACf,WAAKH,WAAL,CAAiBI,OAAjB;AACA,WAAKH,UAAL,CAAgBG,OAAhB;AACD;;;WAOD,qBAAmB;AACjB,aACE,KAAKJ,WAAL,CAAiBK,SAAjB,OACC,CAAC,KAAKH,eAAN,IAAyB,KAAKD,UAAL,CAAgBI,SAAhB,EAD1B,CADF;AAID;;;WAOD,oBAAkB;AAChB,aAAO,KAAKL,WAAL,CAAiBM,QAAjB,MAA+B,KAAKL,UAAL,CAAgBK,QAAhB,EAAtC;AACD;;;;;;SAjEkBR,iB","sourcesContent":["import { MousePitchHandler, MouseRotateHandler } from '../mouse';\n\n/**\n * The `DragRotateHandler` allows the user to rotate the map by clicking and\n * dragging the cursor while holding the right mouse button or `ctrl` key.\n */\nexport default class DragRotateHandler {\n private mouseRotate: MouseRotateHandler;\n private mousePitch: MousePitchHandler;\n private pitchWithRotate: boolean;\n\n /**\n * @param {Object} [options]\n * @param {number} [options.bearingSnap] The threshold, measured in degrees, that determines when the map's\n * bearing will snap to north.\n * @param {bool} [options.pitchWithRotate=true] Control the map pitch in addition to the bearing\n * @private\n */\n constructor(\n options: { pitchWithRotate: boolean },\n mouseRotate: MouseRotateHandler,\n mousePitch: MousePitchHandler,\n ) {\n this.pitchWithRotate = options.pitchWithRotate;\n this.mouseRotate = mouseRotate;\n this.mousePitch = mousePitch;\n }\n\n /**\n * Enables the \"drag to rotate\" interaction.\n *\n * @example\n * map.dragRotate.enable();\n */\n public enable() {\n this.mouseRotate.enable();\n if (this.pitchWithRotate) {\n this.mousePitch.enable();\n }\n }\n\n /**\n * Disables the \"drag to rotate\" interaction.\n *\n * @example\n * map.dragRotate.disable();\n */\n public disable() {\n this.mouseRotate.disable();\n this.mousePitch.disable();\n }\n\n /**\n * Returns a Boolean indicating whether the \"drag to rotate\" interaction is enabled.\n *\n * @returns {boolean} `true` if the \"drag to rotate\" interaction is enabled.\n */\n public isEnabled() {\n return (\n this.mouseRotate.isEnabled() &&\n (!this.pitchWithRotate || this.mousePitch.isEnabled())\n );\n }\n\n /**\n * Returns a Boolean indicating whether the \"drag to rotate\" interaction is active, i.e. currently being used.\n *\n * @returns {boolean} `true` if the \"drag to rotate\" interaction is active.\n */\n public isActive() {\n return this.mouseRotate.isActive() || this.mousePitch.isActive();\n }\n}\n"],"file":"drag_rotate.js"}
|
|
@@ -1,70 +0,0 @@
|
|
|
1
|
-
import TapDragZoomHandler from '../tap/tap_drag_zoom';
|
|
2
|
-
import { TouchRotateHandler, TouchZoomHandler } from '../touch';
|
|
3
|
-
/**
|
|
4
|
-
* The `TouchZoomRotateHandler` allows the user to zoom and rotate the map by
|
|
5
|
-
* pinching on a touchscreen.
|
|
6
|
-
*
|
|
7
|
-
* They can zoom with one finger by double tapping and dragging. On the second tap,
|
|
8
|
-
* hold the finger down and drag up or down to zoom in or out.
|
|
9
|
-
*/
|
|
10
|
-
export default class TouchZoomRotateHandler {
|
|
11
|
-
private el;
|
|
12
|
-
private touchZoom;
|
|
13
|
-
private touchRotate;
|
|
14
|
-
private tapDragZoom;
|
|
15
|
-
private rotationDisabled;
|
|
16
|
-
private enabled;
|
|
17
|
-
/**
|
|
18
|
-
* @private
|
|
19
|
-
*/
|
|
20
|
-
constructor(el: HTMLElement, touchZoom: TouchZoomHandler, touchRotate: TouchRotateHandler, tapDragZoom: TapDragZoomHandler);
|
|
21
|
-
/**
|
|
22
|
-
* Enables the "pinch to rotate and zoom" interaction.
|
|
23
|
-
*
|
|
24
|
-
* @param {Object} [options] Options object.
|
|
25
|
-
* @param {string} [options.around] If "center" is passed, map will zoom around the center
|
|
26
|
-
*
|
|
27
|
-
* @example
|
|
28
|
-
* map.touchZoomRotate.enable();
|
|
29
|
-
* @example
|
|
30
|
-
* map.touchZoomRotate.enable({ around: 'center' });
|
|
31
|
-
*/
|
|
32
|
-
enable(options: {
|
|
33
|
-
around?: 'center';
|
|
34
|
-
}): void;
|
|
35
|
-
/**
|
|
36
|
-
* Disables the "pinch to rotate and zoom" interaction.
|
|
37
|
-
*
|
|
38
|
-
* @example
|
|
39
|
-
* map.touchZoomRotate.disable();
|
|
40
|
-
*/
|
|
41
|
-
disable(): void;
|
|
42
|
-
/**
|
|
43
|
-
* Returns a Boolean indicating whether the "pinch to rotate and zoom" interaction is enabled.
|
|
44
|
-
*
|
|
45
|
-
* @returns {boolean} `true` if the "pinch to rotate and zoom" interaction is enabled.
|
|
46
|
-
*/
|
|
47
|
-
isEnabled(): boolean;
|
|
48
|
-
/**
|
|
49
|
-
* Returns true if the handler is enabled and has detected the start of a zoom/rotate gesture.
|
|
50
|
-
*
|
|
51
|
-
* @returns {boolean} //eslint-disable-line
|
|
52
|
-
*/
|
|
53
|
-
isActive(): boolean;
|
|
54
|
-
/**
|
|
55
|
-
* Disables the "pinch to rotate" interaction, leaving the "pinch to zoom"
|
|
56
|
-
* interaction enabled.
|
|
57
|
-
*
|
|
58
|
-
* @example
|
|
59
|
-
* map.touchZoomRotate.disableRotation();
|
|
60
|
-
*/
|
|
61
|
-
disableRotation(): void;
|
|
62
|
-
/**
|
|
63
|
-
* Enables the "pinch to rotate" interaction.
|
|
64
|
-
*
|
|
65
|
-
* @example
|
|
66
|
-
* map.touchZoomRotate.enable();
|
|
67
|
-
* map.touchZoomRotate.enableRotation();
|
|
68
|
-
*/
|
|
69
|
-
enableRotation(): void;
|
|
70
|
-
}
|
|
@@ -1,80 +0,0 @@
|
|
|
1
|
-
import _classCallCheck from "@babel/runtime/helpers/classCallCheck";
|
|
2
|
-
import _createClass from "@babel/runtime/helpers/createClass";
|
|
3
|
-
import _defineProperty from "@babel/runtime/helpers/defineProperty";
|
|
4
|
-
|
|
5
|
-
var TouchZoomRotateHandler = function () {
|
|
6
|
-
function TouchZoomRotateHandler(el, touchZoom, touchRotate, tapDragZoom) {
|
|
7
|
-
_classCallCheck(this, TouchZoomRotateHandler);
|
|
8
|
-
|
|
9
|
-
_defineProperty(this, "el", void 0);
|
|
10
|
-
|
|
11
|
-
_defineProperty(this, "touchZoom", void 0);
|
|
12
|
-
|
|
13
|
-
_defineProperty(this, "touchRotate", void 0);
|
|
14
|
-
|
|
15
|
-
_defineProperty(this, "tapDragZoom", void 0);
|
|
16
|
-
|
|
17
|
-
_defineProperty(this, "rotationDisabled", void 0);
|
|
18
|
-
|
|
19
|
-
_defineProperty(this, "enabled", void 0);
|
|
20
|
-
|
|
21
|
-
this.el = el;
|
|
22
|
-
this.touchZoom = touchZoom;
|
|
23
|
-
this.touchRotate = touchRotate;
|
|
24
|
-
this.tapDragZoom = tapDragZoom;
|
|
25
|
-
this.rotationDisabled = false;
|
|
26
|
-
this.enabled = true;
|
|
27
|
-
}
|
|
28
|
-
|
|
29
|
-
_createClass(TouchZoomRotateHandler, [{
|
|
30
|
-
key: "enable",
|
|
31
|
-
value: function enable(options) {
|
|
32
|
-
this.touchZoom.enable(options);
|
|
33
|
-
|
|
34
|
-
if (!this.rotationDisabled) {
|
|
35
|
-
this.touchRotate.enable(options);
|
|
36
|
-
}
|
|
37
|
-
|
|
38
|
-
this.tapDragZoom.enable();
|
|
39
|
-
this.el.classList.add('l7-touch-zoom-rotate');
|
|
40
|
-
}
|
|
41
|
-
}, {
|
|
42
|
-
key: "disable",
|
|
43
|
-
value: function disable() {
|
|
44
|
-
this.touchZoom.disable();
|
|
45
|
-
this.touchRotate.disable();
|
|
46
|
-
this.tapDragZoom.disable();
|
|
47
|
-
this.el.classList.remove('l7-touch-zoom-rotate');
|
|
48
|
-
}
|
|
49
|
-
}, {
|
|
50
|
-
key: "isEnabled",
|
|
51
|
-
value: function isEnabled() {
|
|
52
|
-
return this.touchZoom.isEnabled() && (this.rotationDisabled || this.touchRotate.isEnabled()) && this.tapDragZoom.isEnabled();
|
|
53
|
-
}
|
|
54
|
-
}, {
|
|
55
|
-
key: "isActive",
|
|
56
|
-
value: function isActive() {
|
|
57
|
-
return this.touchZoom.isActive() || this.touchRotate.isActive() || this.tapDragZoom.isActive();
|
|
58
|
-
}
|
|
59
|
-
}, {
|
|
60
|
-
key: "disableRotation",
|
|
61
|
-
value: function disableRotation() {
|
|
62
|
-
this.rotationDisabled = true;
|
|
63
|
-
this.touchRotate.disable();
|
|
64
|
-
}
|
|
65
|
-
}, {
|
|
66
|
-
key: "enableRotation",
|
|
67
|
-
value: function enableRotation() {
|
|
68
|
-
this.rotationDisabled = false;
|
|
69
|
-
|
|
70
|
-
if (this.touchZoom.isEnabled()) {
|
|
71
|
-
this.touchRotate.enable();
|
|
72
|
-
}
|
|
73
|
-
}
|
|
74
|
-
}]);
|
|
75
|
-
|
|
76
|
-
return TouchZoomRotateHandler;
|
|
77
|
-
}();
|
|
78
|
-
|
|
79
|
-
export { TouchZoomRotateHandler as default };
|
|
80
|
-
//# sourceMappingURL=touch_zoom_rotate.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"sources":["../../../src/handler/shim/touch_zoom_rotate.ts"],"names":["TouchZoomRotateHandler","el","touchZoom","touchRotate","tapDragZoom","rotationDisabled","enabled","options","enable","classList","add","disable","remove","isEnabled","isActive"],"mappings":";;;;IAUqBA,sB;AAWnB,kCACEC,EADF,EAEEC,SAFF,EAGEC,WAHF,EAIEC,WAJF,EAKE;AAAA;;AAAA;;AAAA;;AAAA;;AAAA;;AAAA;;AAAA;;AACA,SAAKH,EAAL,GAAUA,EAAV;AACA,SAAKC,SAAL,GAAiBA,SAAjB;AACA,SAAKC,WAAL,GAAmBA,WAAnB;AACA,SAAKC,WAAL,GAAmBA,WAAnB;AACA,SAAKC,gBAAL,GAAwB,KAAxB;AACA,SAAKC,OAAL,GAAe,IAAf;AACD;;;;WAaD,gBAAcC,OAAd,EAA8C;AAC5C,WAAKL,SAAL,CAAeM,MAAf,CAAsBD,OAAtB;;AACA,UAAI,CAAC,KAAKF,gBAAV,EAA4B;AAC1B,aAAKF,WAAL,CAAiBK,MAAjB,CAAwBD,OAAxB;AACD;;AACD,WAAKH,WAAL,CAAiBI,MAAjB;AACA,WAAKP,EAAL,CAAQQ,SAAR,CAAkBC,GAAlB,CAAsB,sBAAtB;AACD;;;WAQD,mBAAiB;AACf,WAAKR,SAAL,CAAeS,OAAf;AACA,WAAKR,WAAL,CAAiBQ,OAAjB;AACA,WAAKP,WAAL,CAAiBO,OAAjB;AACA,WAAKV,EAAL,CAAQQ,SAAR,CAAkBG,MAAlB,CAAyB,sBAAzB;AACD;;;WAOD,qBAAmB;AACjB,aACE,KAAKV,SAAL,CAAeW,SAAf,OACC,KAAKR,gBAAL,IAAyB,KAAKF,WAAL,CAAiBU,SAAjB,EAD1B,KAEA,KAAKT,WAAL,CAAiBS,SAAjB,EAHF;AAKD;;;WAOD,oBAAkB;AAChB,aACE,KAAKX,SAAL,CAAeY,QAAf,MACA,KAAKX,WAAL,CAAiBW,QAAjB,EADA,IAEA,KAAKV,WAAL,CAAiBU,QAAjB,EAHF;AAKD;;;WASD,2BAAyB;AACvB,WAAKT,gBAAL,GAAwB,IAAxB;AACA,WAAKF,WAAL,CAAiBQ,OAAjB;AACD;;;WASD,0BAAwB;AACtB,WAAKN,gBAAL,GAAwB,KAAxB;;AACA,UAAI,KAAKH,SAAL,CAAeW,SAAf,EAAJ,EAAgC;AAC9B,aAAKV,WAAL,CAAiBK,MAAjB;AACD;AACF;;;;;;SA5GkBR,sB","sourcesContent":["import TapDragZoomHandler from '../tap/tap_drag_zoom';\nimport { TouchRotateHandler, TouchZoomHandler } from '../touch';\n\n/**\n * The `TouchZoomRotateHandler` allows the user to zoom and rotate the map by\n * pinching on a touchscreen.\n *\n * They can zoom with one finger by double tapping and dragging. On the second tap,\n * hold the finger down and drag up or down to zoom in or out.\n */\nexport default class TouchZoomRotateHandler {\n private el: HTMLElement;\n private touchZoom: TouchZoomHandler;\n private touchRotate: TouchRotateHandler;\n private tapDragZoom: TapDragZoomHandler;\n private rotationDisabled: boolean;\n private enabled: boolean;\n\n /**\n * @private\n */\n constructor(\n el: HTMLElement,\n touchZoom: TouchZoomHandler,\n touchRotate: TouchRotateHandler,\n tapDragZoom: TapDragZoomHandler,\n ) {\n this.el = el;\n this.touchZoom = touchZoom;\n this.touchRotate = touchRotate;\n this.tapDragZoom = tapDragZoom;\n this.rotationDisabled = false;\n this.enabled = true;\n }\n\n /**\n * Enables the \"pinch to rotate and zoom\" interaction.\n *\n * @param {Object} [options] Options object.\n * @param {string} [options.around] If \"center\" is passed, map will zoom around the center\n *\n * @example\n * map.touchZoomRotate.enable();\n * @example\n * map.touchZoomRotate.enable({ around: 'center' });\n */\n public enable(options: { around?: 'center' }) {\n this.touchZoom.enable(options);\n if (!this.rotationDisabled) {\n this.touchRotate.enable(options);\n }\n this.tapDragZoom.enable();\n this.el.classList.add('l7-touch-zoom-rotate');\n }\n\n /**\n * Disables the \"pinch to rotate and zoom\" interaction.\n *\n * @example\n * map.touchZoomRotate.disable();\n */\n public disable() {\n this.touchZoom.disable();\n this.touchRotate.disable();\n this.tapDragZoom.disable();\n this.el.classList.remove('l7-touch-zoom-rotate');\n }\n\n /**\n * Returns a Boolean indicating whether the \"pinch to rotate and zoom\" interaction is enabled.\n *\n * @returns {boolean} `true` if the \"pinch to rotate and zoom\" interaction is enabled.\n */\n public isEnabled() {\n return (\n this.touchZoom.isEnabled() &&\n (this.rotationDisabled || this.touchRotate.isEnabled()) &&\n this.tapDragZoom.isEnabled()\n );\n }\n\n /**\n * Returns true if the handler is enabled and has detected the start of a zoom/rotate gesture.\n *\n * @returns {boolean} //eslint-disable-line\n */\n public isActive() {\n return (\n this.touchZoom.isActive() ||\n this.touchRotate.isActive() ||\n this.tapDragZoom.isActive()\n );\n }\n\n /**\n * Disables the \"pinch to rotate\" interaction, leaving the \"pinch to zoom\"\n * interaction enabled.\n *\n * @example\n * map.touchZoomRotate.disableRotation();\n */\n public disableRotation() {\n this.rotationDisabled = true;\n this.touchRotate.disable();\n }\n\n /**\n * Enables the \"pinch to rotate\" interaction.\n *\n * @example\n * map.touchZoomRotate.enable();\n * map.touchZoomRotate.enableRotation();\n */\n public enableRotation() {\n this.rotationDisabled = false;\n if (this.touchZoom.isEnabled()) {\n this.touchRotate.enable();\n }\n }\n}\n"],"file":"touch_zoom_rotate.js"}
|
|
@@ -1,20 +0,0 @@
|
|
|
1
|
-
import Point from '../../geo/point';
|
|
2
|
-
export declare const MAX_TAP_INTERVAL = 500;
|
|
3
|
-
export declare const MAX_TOUCH_TIME = 500;
|
|
4
|
-
export declare const MAX_DIST = 30;
|
|
5
|
-
export default class SingleTapRecognizer {
|
|
6
|
-
numTouches: number;
|
|
7
|
-
centroid: Point;
|
|
8
|
-
startTime: number;
|
|
9
|
-
aborted: boolean;
|
|
10
|
-
touches: {
|
|
11
|
-
[key: string]: Point;
|
|
12
|
-
};
|
|
13
|
-
constructor(options: {
|
|
14
|
-
numTouches: number;
|
|
15
|
-
});
|
|
16
|
-
reset(): void;
|
|
17
|
-
touchstart(e: TouchEvent, points: Point[], mapTouches: Touch[]): void;
|
|
18
|
-
touchmove(e: TouchEvent, points: Point[], mapTouches: Touch[]): void;
|
|
19
|
-
touchend(e: TouchEvent, points: Point[], mapTouches: Touch[]): Point | undefined;
|
|
20
|
-
}
|