@swissgeo/coordinates 1.0.0-beta.2 → 1.0.0
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/README.md +118 -0
- package/dist/index.cjs +7 -0
- package/dist/index.d.ts +3 -14
- package/dist/index.js +8012 -18103
- package/dist/ol.cjs +1 -0
- package/dist/ol.d.ts +10 -0
- package/dist/ol.js +4467 -0
- package/dist/registerProj4-BuUOcPpF.cjs +23 -0
- package/dist/registerProj4-CwR_kPOz.js +10172 -0
- package/eslint.config.mts +12 -0
- package/index.html +14 -0
- package/package.json +30 -29
- package/setup-vitest.ts +8 -0
- package/src/DevApp.vue +65 -0
- package/src/__test__/coordinatesUtils.spec.ts +178 -0
- package/src/__test__/extentUtils.spec.ts +92 -0
- package/src/coordinatesUtils.ts +188 -0
- package/src/dev.ts +6 -0
- package/src/extentUtils.ts +196 -0
- package/src/index.ts +29 -0
- package/src/ol.ts +52 -0
- package/src/proj/CoordinateSystem.ts +315 -0
- package/src/proj/CoordinateSystemBounds.ts +170 -0
- package/src/proj/CustomCoordinateSystem.ts +58 -0
- package/src/proj/LV03CoordinateSystem.ts +23 -0
- package/src/proj/LV95CoordinateSystem.ts +35 -0
- package/src/proj/StandardCoordinateSystem.ts +22 -0
- package/src/proj/SwissCoordinateSystem.ts +233 -0
- package/src/proj/WGS84CoordinateSystem.ts +97 -0
- package/src/proj/WebMercatorCoordinateSystem.ts +89 -0
- package/src/proj/__test__/CoordinateSystem.spec.ts +63 -0
- package/src/proj/__test__/CoordinateSystemBounds.spec.ts +252 -0
- package/src/proj/__test__/SwissCoordinateSystem.spec.ts +136 -0
- package/src/proj/index.ts +65 -0
- package/src/proj/types.ts +22 -0
- package/src/registerProj4.ts +38 -0
- package/tsconfig.json +4 -0
- package/vite.config.ts +46 -0
- package/dist/index.umd.cjs +0 -29
package/dist/ol.js
ADDED
|
@@ -0,0 +1,4467 @@
|
|
|
1
|
+
import { v as Le, o as jt, L as P, E as _t } from "./registerProj4-CwR_kPOz.js";
|
|
2
|
+
const be = {
|
|
3
|
+
/**
|
|
4
|
+
* Triggered when a property is changed.
|
|
5
|
+
* @event module:ol/Object.ObjectEvent#propertychange
|
|
6
|
+
* @api
|
|
7
|
+
*/
|
|
8
|
+
PROPERTYCHANGE: "propertychange"
|
|
9
|
+
}, Ue = {
|
|
10
|
+
/**
|
|
11
|
+
* Generic change event. Triggered when the revision counter is increased.
|
|
12
|
+
* @event module:ol/events/Event~BaseEvent#change
|
|
13
|
+
* @api
|
|
14
|
+
*/
|
|
15
|
+
CHANGE: "change"
|
|
16
|
+
};
|
|
17
|
+
class Ve {
|
|
18
|
+
constructor() {
|
|
19
|
+
this.disposed = !1;
|
|
20
|
+
}
|
|
21
|
+
/**
|
|
22
|
+
* Clean up.
|
|
23
|
+
*/
|
|
24
|
+
dispose() {
|
|
25
|
+
this.disposed || (this.disposed = !0, this.disposeInternal());
|
|
26
|
+
}
|
|
27
|
+
/**
|
|
28
|
+
* Extension point for disposable objects.
|
|
29
|
+
* @protected
|
|
30
|
+
*/
|
|
31
|
+
disposeInternal() {
|
|
32
|
+
}
|
|
33
|
+
}
|
|
34
|
+
function ue(i, t) {
|
|
35
|
+
return i > t ? 1 : i < t ? -1 : 0;
|
|
36
|
+
}
|
|
37
|
+
function wt(i, t, e) {
|
|
38
|
+
if (i[0] <= t)
|
|
39
|
+
return 0;
|
|
40
|
+
const n = i.length;
|
|
41
|
+
if (t <= i[n - 1])
|
|
42
|
+
return n - 1;
|
|
43
|
+
if (typeof e == "function") {
|
|
44
|
+
for (let s = 1; s < n; ++s) {
|
|
45
|
+
const r = i[s];
|
|
46
|
+
if (r === t)
|
|
47
|
+
return s;
|
|
48
|
+
if (r < t)
|
|
49
|
+
return e(t, i[s - 1], r) > 0 ? s - 1 : s;
|
|
50
|
+
}
|
|
51
|
+
return n - 1;
|
|
52
|
+
}
|
|
53
|
+
if (e > 0) {
|
|
54
|
+
for (let s = 1; s < n; ++s)
|
|
55
|
+
if (i[s] < t)
|
|
56
|
+
return s - 1;
|
|
57
|
+
return n - 1;
|
|
58
|
+
}
|
|
59
|
+
if (e < 0) {
|
|
60
|
+
for (let s = 1; s < n; ++s)
|
|
61
|
+
if (i[s] <= t)
|
|
62
|
+
return s;
|
|
63
|
+
return n - 1;
|
|
64
|
+
}
|
|
65
|
+
for (let s = 1; s < n; ++s) {
|
|
66
|
+
if (i[s] == t)
|
|
67
|
+
return s;
|
|
68
|
+
if (i[s] < t)
|
|
69
|
+
return i[s - 1] - t < t - i[s] ? s - 1 : s;
|
|
70
|
+
}
|
|
71
|
+
return n - 1;
|
|
72
|
+
}
|
|
73
|
+
function De(i, t) {
|
|
74
|
+
const e = Array.isArray(t) ? t : [t], n = e.length;
|
|
75
|
+
for (let s = 0; s < n; s++)
|
|
76
|
+
i[i.length] = e[s];
|
|
77
|
+
}
|
|
78
|
+
function We(i, t) {
|
|
79
|
+
const e = i.length;
|
|
80
|
+
if (e !== t.length)
|
|
81
|
+
return !1;
|
|
82
|
+
for (let n = 0; n < e; n++)
|
|
83
|
+
if (i[n] !== t[n])
|
|
84
|
+
return !1;
|
|
85
|
+
return !0;
|
|
86
|
+
}
|
|
87
|
+
function $e(i, t, e) {
|
|
88
|
+
const n = t || ue;
|
|
89
|
+
return i.every(function(s, r) {
|
|
90
|
+
if (r === 0)
|
|
91
|
+
return !0;
|
|
92
|
+
const o = n(i[r - 1], s);
|
|
93
|
+
return !(o > 0 || o === 0);
|
|
94
|
+
});
|
|
95
|
+
}
|
|
96
|
+
function Ct() {
|
|
97
|
+
}
|
|
98
|
+
function He(i) {
|
|
99
|
+
let t, e, n;
|
|
100
|
+
return function() {
|
|
101
|
+
const s = Array.prototype.slice.call(arguments);
|
|
102
|
+
return (!e || this !== n || !We(s, e)) && (n = this, e = s, t = i.apply(this, arguments)), t;
|
|
103
|
+
};
|
|
104
|
+
}
|
|
105
|
+
function he(i) {
|
|
106
|
+
for (const t in i)
|
|
107
|
+
delete i[t];
|
|
108
|
+
}
|
|
109
|
+
function ke(i) {
|
|
110
|
+
let t;
|
|
111
|
+
for (t in i)
|
|
112
|
+
return !1;
|
|
113
|
+
return !t;
|
|
114
|
+
}
|
|
115
|
+
class ce {
|
|
116
|
+
/**
|
|
117
|
+
* @param {string} type Type.
|
|
118
|
+
*/
|
|
119
|
+
constructor(t) {
|
|
120
|
+
this.propagationStopped, this.defaultPrevented, this.type = t, this.target = null;
|
|
121
|
+
}
|
|
122
|
+
/**
|
|
123
|
+
* Prevent default. This means that no emulated `click`, `singleclick` or `doubleclick` events
|
|
124
|
+
* will be fired.
|
|
125
|
+
* @api
|
|
126
|
+
*/
|
|
127
|
+
preventDefault() {
|
|
128
|
+
this.defaultPrevented = !0;
|
|
129
|
+
}
|
|
130
|
+
/**
|
|
131
|
+
* Stop event propagation.
|
|
132
|
+
* @api
|
|
133
|
+
*/
|
|
134
|
+
stopPropagation() {
|
|
135
|
+
this.propagationStopped = !0;
|
|
136
|
+
}
|
|
137
|
+
}
|
|
138
|
+
class qe extends Ve {
|
|
139
|
+
/**
|
|
140
|
+
* @param {*} [target] Default event target for dispatched events.
|
|
141
|
+
*/
|
|
142
|
+
constructor(t) {
|
|
143
|
+
super(), this.eventTarget_ = t, this.pendingRemovals_ = null, this.dispatching_ = null, this.listeners_ = null;
|
|
144
|
+
}
|
|
145
|
+
/**
|
|
146
|
+
* @param {string} type Type.
|
|
147
|
+
* @param {import("../events.js").Listener} listener Listener.
|
|
148
|
+
*/
|
|
149
|
+
addEventListener(t, e) {
|
|
150
|
+
if (!t || !e)
|
|
151
|
+
return;
|
|
152
|
+
const n = this.listeners_ || (this.listeners_ = {}), s = n[t] || (n[t] = []);
|
|
153
|
+
s.includes(e) || s.push(e);
|
|
154
|
+
}
|
|
155
|
+
/**
|
|
156
|
+
* Dispatches an event and calls all listeners listening for events
|
|
157
|
+
* of this type. The event parameter can either be a string or an
|
|
158
|
+
* Object with a `type` property.
|
|
159
|
+
*
|
|
160
|
+
* @param {import("./Event.js").default|string} event Event object.
|
|
161
|
+
* @return {boolean|undefined} `false` if anyone called preventDefault on the
|
|
162
|
+
* event object or if any of the listeners returned false.
|
|
163
|
+
* @api
|
|
164
|
+
*/
|
|
165
|
+
dispatchEvent(t) {
|
|
166
|
+
const e = typeof t == "string", n = e ? t : t.type, s = this.listeners_ && this.listeners_[n];
|
|
167
|
+
if (!s)
|
|
168
|
+
return;
|
|
169
|
+
const r = e ? new ce(t) : (
|
|
170
|
+
/** @type {Event} */
|
|
171
|
+
t
|
|
172
|
+
);
|
|
173
|
+
r.target || (r.target = this.eventTarget_ || this);
|
|
174
|
+
const o = this.dispatching_ || (this.dispatching_ = {}), a = this.pendingRemovals_ || (this.pendingRemovals_ = {});
|
|
175
|
+
n in o || (o[n] = 0, a[n] = 0), ++o[n];
|
|
176
|
+
let l;
|
|
177
|
+
for (let h = 0, u = s.length; h < u; ++h)
|
|
178
|
+
if ("handleEvent" in s[h] ? l = /** @type {import("../events.js").ListenerObject} */
|
|
179
|
+
s[h].handleEvent(r) : l = /** @type {import("../events.js").ListenerFunction} */
|
|
180
|
+
s[h].call(this, r), l === !1 || r.propagationStopped) {
|
|
181
|
+
l = !1;
|
|
182
|
+
break;
|
|
183
|
+
}
|
|
184
|
+
if (--o[n] === 0) {
|
|
185
|
+
let h = a[n];
|
|
186
|
+
for (delete a[n]; h--; )
|
|
187
|
+
this.removeEventListener(n, Ct);
|
|
188
|
+
delete o[n];
|
|
189
|
+
}
|
|
190
|
+
return l;
|
|
191
|
+
}
|
|
192
|
+
/**
|
|
193
|
+
* Clean up.
|
|
194
|
+
* @override
|
|
195
|
+
*/
|
|
196
|
+
disposeInternal() {
|
|
197
|
+
this.listeners_ && he(this.listeners_);
|
|
198
|
+
}
|
|
199
|
+
/**
|
|
200
|
+
* Get the listeners for a specified event type. Listeners are returned in the
|
|
201
|
+
* order that they will be called in.
|
|
202
|
+
*
|
|
203
|
+
* @param {string} type Type.
|
|
204
|
+
* @return {Array<import("../events.js").Listener>|undefined} Listeners.
|
|
205
|
+
*/
|
|
206
|
+
getListeners(t) {
|
|
207
|
+
return this.listeners_ && this.listeners_[t] || void 0;
|
|
208
|
+
}
|
|
209
|
+
/**
|
|
210
|
+
* @param {string} [type] Type. If not provided,
|
|
211
|
+
* `true` will be returned if this event target has any listeners.
|
|
212
|
+
* @return {boolean} Has listeners.
|
|
213
|
+
*/
|
|
214
|
+
hasListener(t) {
|
|
215
|
+
return this.listeners_ ? t ? t in this.listeners_ : Object.keys(this.listeners_).length > 0 : !1;
|
|
216
|
+
}
|
|
217
|
+
/**
|
|
218
|
+
* @param {string} type Type.
|
|
219
|
+
* @param {import("../events.js").Listener} listener Listener.
|
|
220
|
+
*/
|
|
221
|
+
removeEventListener(t, e) {
|
|
222
|
+
if (!this.listeners_)
|
|
223
|
+
return;
|
|
224
|
+
const n = this.listeners_[t];
|
|
225
|
+
if (!n)
|
|
226
|
+
return;
|
|
227
|
+
const s = n.indexOf(e);
|
|
228
|
+
s !== -1 && (this.pendingRemovals_ && t in this.pendingRemovals_ ? (n[s] = Ct, ++this.pendingRemovals_[t]) : (n.splice(s, 1), n.length === 0 && delete this.listeners_[t]));
|
|
229
|
+
}
|
|
230
|
+
}
|
|
231
|
+
function Et(i, t, e, n, s) {
|
|
232
|
+
if (s) {
|
|
233
|
+
const o = e;
|
|
234
|
+
e = function(a) {
|
|
235
|
+
return i.removeEventListener(t, e), o.call(this, a);
|
|
236
|
+
};
|
|
237
|
+
}
|
|
238
|
+
const r = {
|
|
239
|
+
target: i,
|
|
240
|
+
type: t,
|
|
241
|
+
listener: e
|
|
242
|
+
};
|
|
243
|
+
return i.addEventListener(t, e), r;
|
|
244
|
+
}
|
|
245
|
+
function zt(i, t, e, n) {
|
|
246
|
+
return Et(i, t, e, n, !0);
|
|
247
|
+
}
|
|
248
|
+
function Gt(i) {
|
|
249
|
+
i && i.target && (i.target.removeEventListener(i.type, i.listener), he(i));
|
|
250
|
+
}
|
|
251
|
+
class Be extends qe {
|
|
252
|
+
constructor() {
|
|
253
|
+
super(), this.on = /** @type {ObservableOnSignature<import("./events").EventsKey>} */
|
|
254
|
+
this.onInternal, this.once = /** @type {ObservableOnSignature<import("./events").EventsKey>} */
|
|
255
|
+
this.onceInternal, this.un = /** @type {ObservableOnSignature<void>} */
|
|
256
|
+
this.unInternal, this.revision_ = 0;
|
|
257
|
+
}
|
|
258
|
+
/**
|
|
259
|
+
* Increases the revision counter and dispatches a 'change' event.
|
|
260
|
+
* @api
|
|
261
|
+
*/
|
|
262
|
+
changed() {
|
|
263
|
+
++this.revision_, this.dispatchEvent(Ue.CHANGE);
|
|
264
|
+
}
|
|
265
|
+
/**
|
|
266
|
+
* Get the version number for this object. Each time the object is modified,
|
|
267
|
+
* its version number will be incremented.
|
|
268
|
+
* @return {number} Revision.
|
|
269
|
+
* @api
|
|
270
|
+
*/
|
|
271
|
+
getRevision() {
|
|
272
|
+
return this.revision_;
|
|
273
|
+
}
|
|
274
|
+
/**
|
|
275
|
+
* @param {string|Array<string>} type Type.
|
|
276
|
+
* @param {function((Event|import("./events/Event").default)): ?} listener Listener.
|
|
277
|
+
* @return {import("./events.js").EventsKey|Array<import("./events.js").EventsKey>} Event key.
|
|
278
|
+
* @protected
|
|
279
|
+
*/
|
|
280
|
+
onInternal(t, e) {
|
|
281
|
+
if (Array.isArray(t)) {
|
|
282
|
+
const n = t.length, s = new Array(n);
|
|
283
|
+
for (let r = 0; r < n; ++r)
|
|
284
|
+
s[r] = Et(this, t[r], e);
|
|
285
|
+
return s;
|
|
286
|
+
}
|
|
287
|
+
return Et(
|
|
288
|
+
this,
|
|
289
|
+
/** @type {string} */
|
|
290
|
+
t,
|
|
291
|
+
e
|
|
292
|
+
);
|
|
293
|
+
}
|
|
294
|
+
/**
|
|
295
|
+
* @param {string|Array<string>} type Type.
|
|
296
|
+
* @param {function((Event|import("./events/Event").default)): ?} listener Listener.
|
|
297
|
+
* @return {import("./events.js").EventsKey|Array<import("./events.js").EventsKey>} Event key.
|
|
298
|
+
* @protected
|
|
299
|
+
*/
|
|
300
|
+
onceInternal(t, e) {
|
|
301
|
+
let n;
|
|
302
|
+
if (Array.isArray(t)) {
|
|
303
|
+
const s = t.length;
|
|
304
|
+
n = new Array(s);
|
|
305
|
+
for (let r = 0; r < s; ++r)
|
|
306
|
+
n[r] = zt(this, t[r], e);
|
|
307
|
+
} else
|
|
308
|
+
n = zt(
|
|
309
|
+
this,
|
|
310
|
+
/** @type {string} */
|
|
311
|
+
t,
|
|
312
|
+
e
|
|
313
|
+
);
|
|
314
|
+
return e.ol_key = n, n;
|
|
315
|
+
}
|
|
316
|
+
/**
|
|
317
|
+
* Unlisten for a certain type of event.
|
|
318
|
+
* @param {string|Array<string>} type Type.
|
|
319
|
+
* @param {function((Event|import("./events/Event").default)): ?} listener Listener.
|
|
320
|
+
* @protected
|
|
321
|
+
*/
|
|
322
|
+
unInternal(t, e) {
|
|
323
|
+
const n = (
|
|
324
|
+
/** @type {Object} */
|
|
325
|
+
e.ol_key
|
|
326
|
+
);
|
|
327
|
+
if (n)
|
|
328
|
+
Ke(n);
|
|
329
|
+
else if (Array.isArray(t))
|
|
330
|
+
for (let s = 0, r = t.length; s < r; ++s)
|
|
331
|
+
this.removeEventListener(t[s], e);
|
|
332
|
+
else
|
|
333
|
+
this.removeEventListener(t, e);
|
|
334
|
+
}
|
|
335
|
+
}
|
|
336
|
+
function Ke(i) {
|
|
337
|
+
if (Array.isArray(i))
|
|
338
|
+
for (let t = 0, e = i.length; t < e; ++t)
|
|
339
|
+
Gt(i[t]);
|
|
340
|
+
else
|
|
341
|
+
Gt(
|
|
342
|
+
/** @type {import("./events.js").EventsKey} */
|
|
343
|
+
i
|
|
344
|
+
);
|
|
345
|
+
}
|
|
346
|
+
function E() {
|
|
347
|
+
throw new Error("Unimplemented abstract method.");
|
|
348
|
+
}
|
|
349
|
+
let Je = 0;
|
|
350
|
+
function Qe(i) {
|
|
351
|
+
return i.ol_uid || (i.ol_uid = String(++Je));
|
|
352
|
+
}
|
|
353
|
+
class Ot extends ce {
|
|
354
|
+
/**
|
|
355
|
+
* @param {string} type The event type.
|
|
356
|
+
* @param {string} key The property name.
|
|
357
|
+
* @param {*} oldValue The old value for `key`.
|
|
358
|
+
*/
|
|
359
|
+
constructor(t, e, n) {
|
|
360
|
+
super(t), this.key = e, this.oldValue = n;
|
|
361
|
+
}
|
|
362
|
+
}
|
|
363
|
+
class fe extends Be {
|
|
364
|
+
/**
|
|
365
|
+
* @param {Object<string, *>} [values] An object with key-value pairs.
|
|
366
|
+
*/
|
|
367
|
+
constructor(t) {
|
|
368
|
+
super(), this.on, this.once, this.un, Qe(this), this.values_ = null, t !== void 0 && this.setProperties(t);
|
|
369
|
+
}
|
|
370
|
+
/**
|
|
371
|
+
* Gets a value.
|
|
372
|
+
* @param {string} key Key name.
|
|
373
|
+
* @return {*} Value.
|
|
374
|
+
* @api
|
|
375
|
+
*/
|
|
376
|
+
get(t) {
|
|
377
|
+
let e;
|
|
378
|
+
return this.values_ && this.values_.hasOwnProperty(t) && (e = this.values_[t]), e;
|
|
379
|
+
}
|
|
380
|
+
/**
|
|
381
|
+
* Get a list of object property names.
|
|
382
|
+
* @return {Array<string>} List of property names.
|
|
383
|
+
* @api
|
|
384
|
+
*/
|
|
385
|
+
getKeys() {
|
|
386
|
+
return this.values_ && Object.keys(this.values_) || [];
|
|
387
|
+
}
|
|
388
|
+
/**
|
|
389
|
+
* Get an object of all property names and values.
|
|
390
|
+
* @return {Object<string, *>} Object.
|
|
391
|
+
* @api
|
|
392
|
+
*/
|
|
393
|
+
getProperties() {
|
|
394
|
+
return this.values_ && Object.assign({}, this.values_) || {};
|
|
395
|
+
}
|
|
396
|
+
/**
|
|
397
|
+
* Get an object of all property names and values.
|
|
398
|
+
* @return {Object<string, *>?} Object.
|
|
399
|
+
*/
|
|
400
|
+
getPropertiesInternal() {
|
|
401
|
+
return this.values_;
|
|
402
|
+
}
|
|
403
|
+
/**
|
|
404
|
+
* @return {boolean} The object has properties.
|
|
405
|
+
*/
|
|
406
|
+
hasProperties() {
|
|
407
|
+
return !!this.values_;
|
|
408
|
+
}
|
|
409
|
+
/**
|
|
410
|
+
* @param {string} key Key name.
|
|
411
|
+
* @param {*} oldValue Old value.
|
|
412
|
+
*/
|
|
413
|
+
notify(t, e) {
|
|
414
|
+
let n;
|
|
415
|
+
n = `change:${t}`, this.hasListener(n) && this.dispatchEvent(new Ot(n, t, e)), n = be.PROPERTYCHANGE, this.hasListener(n) && this.dispatchEvent(new Ot(n, t, e));
|
|
416
|
+
}
|
|
417
|
+
/**
|
|
418
|
+
* @param {string} key Key name.
|
|
419
|
+
* @param {import("./events.js").Listener} listener Listener.
|
|
420
|
+
*/
|
|
421
|
+
addChangeListener(t, e) {
|
|
422
|
+
this.addEventListener(`change:${t}`, e);
|
|
423
|
+
}
|
|
424
|
+
/**
|
|
425
|
+
* @param {string} key Key name.
|
|
426
|
+
* @param {import("./events.js").Listener} listener Listener.
|
|
427
|
+
*/
|
|
428
|
+
removeChangeListener(t, e) {
|
|
429
|
+
this.removeEventListener(`change:${t}`, e);
|
|
430
|
+
}
|
|
431
|
+
/**
|
|
432
|
+
* Sets a value.
|
|
433
|
+
* @param {string} key Key name.
|
|
434
|
+
* @param {*} value Value.
|
|
435
|
+
* @param {boolean} [silent] Update without triggering an event.
|
|
436
|
+
* @api
|
|
437
|
+
*/
|
|
438
|
+
set(t, e, n) {
|
|
439
|
+
const s = this.values_ || (this.values_ = {});
|
|
440
|
+
if (n)
|
|
441
|
+
s[t] = e;
|
|
442
|
+
else {
|
|
443
|
+
const r = s[t];
|
|
444
|
+
s[t] = e, r !== e && this.notify(t, r);
|
|
445
|
+
}
|
|
446
|
+
}
|
|
447
|
+
/**
|
|
448
|
+
* Sets a collection of key-value pairs. Note that this changes any existing
|
|
449
|
+
* properties and adds new ones (it does not remove any existing properties).
|
|
450
|
+
* @param {Object<string, *>} values Values.
|
|
451
|
+
* @param {boolean} [silent] Update without triggering an event.
|
|
452
|
+
* @api
|
|
453
|
+
*/
|
|
454
|
+
setProperties(t, e) {
|
|
455
|
+
for (const n in t)
|
|
456
|
+
this.set(n, t[n], e);
|
|
457
|
+
}
|
|
458
|
+
/**
|
|
459
|
+
* Apply any properties from another object without triggering events.
|
|
460
|
+
* @param {BaseObject} source The source object.
|
|
461
|
+
* @protected
|
|
462
|
+
*/
|
|
463
|
+
applyProperties(t) {
|
|
464
|
+
t.values_ && Object.assign(this.values_ || (this.values_ = {}), t.values_);
|
|
465
|
+
}
|
|
466
|
+
/**
|
|
467
|
+
* Unsets a property.
|
|
468
|
+
* @param {string} key Key name.
|
|
469
|
+
* @param {boolean} [silent] Unset without triggering an event.
|
|
470
|
+
* @api
|
|
471
|
+
*/
|
|
472
|
+
unset(t, e) {
|
|
473
|
+
if (this.values_ && t in this.values_) {
|
|
474
|
+
const n = this.values_[t];
|
|
475
|
+
delete this.values_[t], ke(this.values_) && (this.values_ = null), e || this.notify(t, n);
|
|
476
|
+
}
|
|
477
|
+
}
|
|
478
|
+
}
|
|
479
|
+
function y(i, t) {
|
|
480
|
+
if (!i)
|
|
481
|
+
throw new Error(t);
|
|
482
|
+
}
|
|
483
|
+
const M = {
|
|
484
|
+
UNKNOWN: 0,
|
|
485
|
+
INTERSECTING: 1,
|
|
486
|
+
ABOVE: 2,
|
|
487
|
+
RIGHT: 4,
|
|
488
|
+
BELOW: 8,
|
|
489
|
+
LEFT: 16
|
|
490
|
+
};
|
|
491
|
+
function ge(i, t, e) {
|
|
492
|
+
let n, s;
|
|
493
|
+
return t < i[0] ? n = i[0] - t : i[2] < t ? n = t - i[2] : n = 0, e < i[1] ? s = i[1] - e : i[3] < e ? s = e - i[3] : s = 0, n * n + s * s;
|
|
494
|
+
}
|
|
495
|
+
function tn(i, t, e) {
|
|
496
|
+
return i[0] <= t && t <= i[2] && i[1] <= e && e <= i[3];
|
|
497
|
+
}
|
|
498
|
+
function Lt(i, t) {
|
|
499
|
+
const e = i[0], n = i[1], s = i[2], r = i[3], o = t[0], a = t[1];
|
|
500
|
+
let l = M.UNKNOWN;
|
|
501
|
+
return o < e ? l = l | M.LEFT : o > s && (l = l | M.RIGHT), a < n ? l = l | M.BELOW : a > r && (l = l | M.ABOVE), l === M.UNKNOWN && (l = M.INTERSECTING), l;
|
|
502
|
+
}
|
|
503
|
+
function de() {
|
|
504
|
+
return [1 / 0, 1 / 0, -1 / 0, -1 / 0];
|
|
505
|
+
}
|
|
506
|
+
function ct(i, t, e, n, s) {
|
|
507
|
+
return s ? (s[0] = i, s[1] = t, s[2] = e, s[3] = n, s) : [i, t, e, n];
|
|
508
|
+
}
|
|
509
|
+
function me(i) {
|
|
510
|
+
return ct(1 / 0, 1 / 0, -1 / 0, -1 / 0, i);
|
|
511
|
+
}
|
|
512
|
+
function en(i, t) {
|
|
513
|
+
const e = i[0], n = i[1];
|
|
514
|
+
return ct(e, n, e, n, t);
|
|
515
|
+
}
|
|
516
|
+
function nn(i, t, e, n, s) {
|
|
517
|
+
const r = me(s);
|
|
518
|
+
return _e(r, i, t, e, n);
|
|
519
|
+
}
|
|
520
|
+
function _e(i, t, e, n, s) {
|
|
521
|
+
for (; e < n; e += s)
|
|
522
|
+
sn(i, t[e], t[e + 1]);
|
|
523
|
+
return i;
|
|
524
|
+
}
|
|
525
|
+
function sn(i, t, e) {
|
|
526
|
+
i[0] = Math.min(i[0], t), i[1] = Math.min(i[1], e), i[2] = Math.max(i[2], t), i[3] = Math.max(i[3], e);
|
|
527
|
+
}
|
|
528
|
+
function rn(i, t) {
|
|
529
|
+
let e;
|
|
530
|
+
return e = t(on(i)), e || (e = t(an(i)), e) || (e = t(hn(i)), e) || (e = t(Re(i)), e) ? e : !1;
|
|
531
|
+
}
|
|
532
|
+
function on(i) {
|
|
533
|
+
return [i[0], i[1]];
|
|
534
|
+
}
|
|
535
|
+
function an(i) {
|
|
536
|
+
return [i[2], i[1]];
|
|
537
|
+
}
|
|
538
|
+
function rt(i) {
|
|
539
|
+
return [(i[0] + i[2]) / 2, (i[1] + i[3]) / 2];
|
|
540
|
+
}
|
|
541
|
+
function ln(i, t, e, n, s) {
|
|
542
|
+
const [r, o, a, l, h, u, c, f] = un(
|
|
543
|
+
i,
|
|
544
|
+
t,
|
|
545
|
+
e,
|
|
546
|
+
n
|
|
547
|
+
);
|
|
548
|
+
return ct(
|
|
549
|
+
Math.min(r, a, h, c),
|
|
550
|
+
Math.min(o, l, u, f),
|
|
551
|
+
Math.max(r, a, h, c),
|
|
552
|
+
Math.max(o, l, u, f),
|
|
553
|
+
s
|
|
554
|
+
);
|
|
555
|
+
}
|
|
556
|
+
function un(i, t, e, n) {
|
|
557
|
+
const s = t * n[0] / 2, r = t * n[1] / 2, o = Math.cos(e), a = Math.sin(e), l = s * o, h = s * a, u = r * o, c = r * a, f = i[0], g = i[1];
|
|
558
|
+
return [
|
|
559
|
+
f - l + c,
|
|
560
|
+
g - h - u,
|
|
561
|
+
f - l - c,
|
|
562
|
+
g - h + u,
|
|
563
|
+
f + l - c,
|
|
564
|
+
g + h + u,
|
|
565
|
+
f + l + c,
|
|
566
|
+
g + h - u,
|
|
567
|
+
f - l + c,
|
|
568
|
+
g - h - u
|
|
569
|
+
];
|
|
570
|
+
}
|
|
571
|
+
function k(i) {
|
|
572
|
+
return i[3] - i[1];
|
|
573
|
+
}
|
|
574
|
+
function Re(i) {
|
|
575
|
+
return [i[0], i[3]];
|
|
576
|
+
}
|
|
577
|
+
function hn(i) {
|
|
578
|
+
return [i[2], i[3]];
|
|
579
|
+
}
|
|
580
|
+
function D(i) {
|
|
581
|
+
return i[2] - i[0];
|
|
582
|
+
}
|
|
583
|
+
function cn(i, t) {
|
|
584
|
+
return i[0] <= t[2] && i[2] >= t[0] && i[1] <= t[3] && i[3] >= t[1];
|
|
585
|
+
}
|
|
586
|
+
function xe(i) {
|
|
587
|
+
return i[2] < i[0] || i[3] < i[1];
|
|
588
|
+
}
|
|
589
|
+
function fn(i, t) {
|
|
590
|
+
return t ? (t[0] = i[0], t[1] = i[1], t[2] = i[2], t[3] = i[3], t) : i;
|
|
591
|
+
}
|
|
592
|
+
function gn(i, t, e) {
|
|
593
|
+
let n = !1;
|
|
594
|
+
const s = Lt(i, t), r = Lt(i, e);
|
|
595
|
+
if (s === M.INTERSECTING || r === M.INTERSECTING)
|
|
596
|
+
n = !0;
|
|
597
|
+
else {
|
|
598
|
+
const o = i[0], a = i[1], l = i[2], h = i[3], u = t[0], c = t[1], f = e[0], g = e[1], d = (g - c) / (f - u);
|
|
599
|
+
let m, _;
|
|
600
|
+
r & M.ABOVE && !(s & M.ABOVE) && (m = f - (g - h) / d, n = m >= o && m <= l), !n && r & M.RIGHT && !(s & M.RIGHT) && (_ = g - (f - l) * d, n = _ >= a && _ <= h), !n && r & M.BELOW && !(s & M.BELOW) && (m = f - (g - a) / d, n = m >= o && m <= l), !n && r & M.LEFT && !(s & M.LEFT) && (_ = g - (f - o) * d, n = _ >= a && _ <= h);
|
|
601
|
+
}
|
|
602
|
+
return n;
|
|
603
|
+
}
|
|
604
|
+
function T(i, t, e) {
|
|
605
|
+
return Math.min(Math.max(i, t), e);
|
|
606
|
+
}
|
|
607
|
+
function dn(i, t, e, n, s, r) {
|
|
608
|
+
const o = s - e, a = r - n;
|
|
609
|
+
if (o !== 0 || a !== 0) {
|
|
610
|
+
const l = ((i - e) * o + (t - n) * a) / (o * o + a * a);
|
|
611
|
+
l > 1 ? (e = s, n = r) : l > 0 && (e += o * l, n += a * l);
|
|
612
|
+
}
|
|
613
|
+
return U(i, t, e, n);
|
|
614
|
+
}
|
|
615
|
+
function U(i, t, e, n) {
|
|
616
|
+
const s = e - i, r = n - t;
|
|
617
|
+
return s * s + r * r;
|
|
618
|
+
}
|
|
619
|
+
function bt(i) {
|
|
620
|
+
return i * 180 / Math.PI;
|
|
621
|
+
}
|
|
622
|
+
function H(i) {
|
|
623
|
+
return i * Math.PI / 180;
|
|
624
|
+
}
|
|
625
|
+
function Ut(i, t) {
|
|
626
|
+
const e = i % t;
|
|
627
|
+
return e * t < 0 ? e + t : e;
|
|
628
|
+
}
|
|
629
|
+
function mn(i, t, e) {
|
|
630
|
+
return i + e * (t - i);
|
|
631
|
+
}
|
|
632
|
+
function Me(i, t) {
|
|
633
|
+
const e = Math.pow(10, t);
|
|
634
|
+
return Math.round(i * e) / e;
|
|
635
|
+
}
|
|
636
|
+
function K(i, t) {
|
|
637
|
+
return Math.floor(Me(i, t));
|
|
638
|
+
}
|
|
639
|
+
function J(i, t) {
|
|
640
|
+
return Math.ceil(Me(i, t));
|
|
641
|
+
}
|
|
642
|
+
function pt(i, t, e) {
|
|
643
|
+
if (i >= t && i < e)
|
|
644
|
+
return i;
|
|
645
|
+
const n = e - t;
|
|
646
|
+
return ((i - t) % n + n) % n + t;
|
|
647
|
+
}
|
|
648
|
+
function _n(...i) {
|
|
649
|
+
console.warn(...i);
|
|
650
|
+
}
|
|
651
|
+
function Rn(i, t) {
|
|
652
|
+
return i[0] += +t[0], i[1] += +t[1], i;
|
|
653
|
+
}
|
|
654
|
+
function ot(i, t) {
|
|
655
|
+
let e = !0;
|
|
656
|
+
for (let n = i.length - 1; n >= 0; --n)
|
|
657
|
+
if (i[n] != t[n]) {
|
|
658
|
+
e = !1;
|
|
659
|
+
break;
|
|
660
|
+
}
|
|
661
|
+
return e;
|
|
662
|
+
}
|
|
663
|
+
function xn(i, t) {
|
|
664
|
+
const e = Math.cos(t), n = Math.sin(t), s = i[0] * e - i[1] * n, r = i[1] * e + i[0] * n;
|
|
665
|
+
return i[0] = s, i[1] = r, i;
|
|
666
|
+
}
|
|
667
|
+
function Mn(i, t, e) {
|
|
668
|
+
const n = t.getExtent();
|
|
669
|
+
let s = 0;
|
|
670
|
+
return t.canWrapX() && (i[0] < n[0] || i[0] > n[2]) && (e = e || D(n), s = Math.floor(
|
|
671
|
+
(i[0] - n[0]) / e
|
|
672
|
+
)), s;
|
|
673
|
+
}
|
|
674
|
+
const Ce = {
|
|
675
|
+
// use the radius of the Normal sphere
|
|
676
|
+
radians: 6370997 / (2 * Math.PI),
|
|
677
|
+
degrees: 2 * Math.PI * 6370997 / 360,
|
|
678
|
+
ft: 0.3048,
|
|
679
|
+
m: 1,
|
|
680
|
+
"us-ft": 1200 / 3937
|
|
681
|
+
};
|
|
682
|
+
class ft {
|
|
683
|
+
/**
|
|
684
|
+
* @param {Options} options Projection options.
|
|
685
|
+
*/
|
|
686
|
+
constructor(t) {
|
|
687
|
+
this.code_ = t.code, this.units_ = /** @type {import("./Units.js").Units} */
|
|
688
|
+
t.units, this.extent_ = t.extent !== void 0 ? t.extent : null, this.worldExtent_ = t.worldExtent !== void 0 ? t.worldExtent : null, this.axisOrientation_ = t.axisOrientation !== void 0 ? t.axisOrientation : "enu", this.global_ = t.global !== void 0 ? t.global : !1, this.canWrapX_ = !!(this.global_ && this.extent_), this.getPointResolutionFunc_ = t.getPointResolution, this.defaultTileGrid_ = null, this.metersPerUnit_ = t.metersPerUnit;
|
|
689
|
+
}
|
|
690
|
+
/**
|
|
691
|
+
* @return {boolean} The projection is suitable for wrapping the x-axis
|
|
692
|
+
*/
|
|
693
|
+
canWrapX() {
|
|
694
|
+
return this.canWrapX_;
|
|
695
|
+
}
|
|
696
|
+
/**
|
|
697
|
+
* Get the code for this projection, e.g. 'EPSG:4326'.
|
|
698
|
+
* @return {string} Code.
|
|
699
|
+
* @api
|
|
700
|
+
*/
|
|
701
|
+
getCode() {
|
|
702
|
+
return this.code_;
|
|
703
|
+
}
|
|
704
|
+
/**
|
|
705
|
+
* Get the validity extent for this projection.
|
|
706
|
+
* @return {import("../extent.js").Extent} Extent.
|
|
707
|
+
* @api
|
|
708
|
+
*/
|
|
709
|
+
getExtent() {
|
|
710
|
+
return this.extent_;
|
|
711
|
+
}
|
|
712
|
+
/**
|
|
713
|
+
* Get the units of this projection.
|
|
714
|
+
* @return {import("./Units.js").Units} Units.
|
|
715
|
+
* @api
|
|
716
|
+
*/
|
|
717
|
+
getUnits() {
|
|
718
|
+
return this.units_;
|
|
719
|
+
}
|
|
720
|
+
/**
|
|
721
|
+
* Get the amount of meters per unit of this projection. If the projection is
|
|
722
|
+
* not configured with `metersPerUnit` or a units identifier, the return is
|
|
723
|
+
* `undefined`.
|
|
724
|
+
* @return {number|undefined} Meters.
|
|
725
|
+
* @api
|
|
726
|
+
*/
|
|
727
|
+
getMetersPerUnit() {
|
|
728
|
+
return this.metersPerUnit_ || Ce[this.units_];
|
|
729
|
+
}
|
|
730
|
+
/**
|
|
731
|
+
* Get the world extent for this projection.
|
|
732
|
+
* @return {import("../extent.js").Extent} Extent.
|
|
733
|
+
* @api
|
|
734
|
+
*/
|
|
735
|
+
getWorldExtent() {
|
|
736
|
+
return this.worldExtent_;
|
|
737
|
+
}
|
|
738
|
+
/**
|
|
739
|
+
* Get the axis orientation of this projection.
|
|
740
|
+
* Example values are:
|
|
741
|
+
* enu - the default easting, northing, elevation.
|
|
742
|
+
* neu - northing, easting, up - useful for "lat/long" geographic coordinates,
|
|
743
|
+
* or south orientated transverse mercator.
|
|
744
|
+
* wnu - westing, northing, up - some planetary coordinate systems have
|
|
745
|
+
* "west positive" coordinate systems
|
|
746
|
+
* @return {string} Axis orientation.
|
|
747
|
+
* @api
|
|
748
|
+
*/
|
|
749
|
+
getAxisOrientation() {
|
|
750
|
+
return this.axisOrientation_;
|
|
751
|
+
}
|
|
752
|
+
/**
|
|
753
|
+
* Is this projection a global projection which spans the whole world?
|
|
754
|
+
* @return {boolean} Whether the projection is global.
|
|
755
|
+
* @api
|
|
756
|
+
*/
|
|
757
|
+
isGlobal() {
|
|
758
|
+
return this.global_;
|
|
759
|
+
}
|
|
760
|
+
/**
|
|
761
|
+
* Set if the projection is a global projection which spans the whole world
|
|
762
|
+
* @param {boolean} global Whether the projection is global.
|
|
763
|
+
* @api
|
|
764
|
+
*/
|
|
765
|
+
setGlobal(t) {
|
|
766
|
+
this.global_ = t, this.canWrapX_ = !!(t && this.extent_);
|
|
767
|
+
}
|
|
768
|
+
/**
|
|
769
|
+
* @return {import("../tilegrid/TileGrid.js").default} The default tile grid.
|
|
770
|
+
*/
|
|
771
|
+
getDefaultTileGrid() {
|
|
772
|
+
return this.defaultTileGrid_;
|
|
773
|
+
}
|
|
774
|
+
/**
|
|
775
|
+
* @param {import("../tilegrid/TileGrid.js").default} tileGrid The default tile grid.
|
|
776
|
+
*/
|
|
777
|
+
setDefaultTileGrid(t) {
|
|
778
|
+
this.defaultTileGrid_ = t;
|
|
779
|
+
}
|
|
780
|
+
/**
|
|
781
|
+
* Set the validity extent for this projection.
|
|
782
|
+
* @param {import("../extent.js").Extent} extent Extent.
|
|
783
|
+
* @api
|
|
784
|
+
*/
|
|
785
|
+
setExtent(t) {
|
|
786
|
+
this.extent_ = t, this.canWrapX_ = !!(this.global_ && t);
|
|
787
|
+
}
|
|
788
|
+
/**
|
|
789
|
+
* Set the world extent for this projection.
|
|
790
|
+
* @param {import("../extent.js").Extent} worldExtent World extent
|
|
791
|
+
* [minlon, minlat, maxlon, maxlat].
|
|
792
|
+
* @api
|
|
793
|
+
*/
|
|
794
|
+
setWorldExtent(t) {
|
|
795
|
+
this.worldExtent_ = t;
|
|
796
|
+
}
|
|
797
|
+
/**
|
|
798
|
+
* Set the getPointResolution function (see {@link module:ol/proj.getPointResolution}
|
|
799
|
+
* for this projection.
|
|
800
|
+
* @param {function(number, import("../coordinate.js").Coordinate):number} func Function
|
|
801
|
+
* @api
|
|
802
|
+
*/
|
|
803
|
+
setGetPointResolution(t) {
|
|
804
|
+
this.getPointResolutionFunc_ = t;
|
|
805
|
+
}
|
|
806
|
+
/**
|
|
807
|
+
* Get the custom point resolution function for this projection (if set).
|
|
808
|
+
* @return {GetPointResolution|undefined} The custom point
|
|
809
|
+
* resolution function (if set).
|
|
810
|
+
*/
|
|
811
|
+
getPointResolutionFunc() {
|
|
812
|
+
return this.getPointResolutionFunc_;
|
|
813
|
+
}
|
|
814
|
+
}
|
|
815
|
+
const B = 6378137, b = Math.PI * B, Cn = [-b, -b, b, b], En = [-180, -85, 180, 85], Q = B * Math.log(Math.tan(Math.PI / 2));
|
|
816
|
+
class z extends ft {
|
|
817
|
+
/**
|
|
818
|
+
* @param {string} code Code.
|
|
819
|
+
*/
|
|
820
|
+
constructor(t) {
|
|
821
|
+
super({
|
|
822
|
+
code: t,
|
|
823
|
+
units: "m",
|
|
824
|
+
extent: Cn,
|
|
825
|
+
global: !0,
|
|
826
|
+
worldExtent: En,
|
|
827
|
+
getPointResolution: function(e, n) {
|
|
828
|
+
return e / Math.cosh(n[1] / B);
|
|
829
|
+
}
|
|
830
|
+
});
|
|
831
|
+
}
|
|
832
|
+
}
|
|
833
|
+
const Vt = [
|
|
834
|
+
new z("EPSG:3857"),
|
|
835
|
+
new z("EPSG:102100"),
|
|
836
|
+
new z("EPSG:102113"),
|
|
837
|
+
new z("EPSG:900913"),
|
|
838
|
+
new z("http://www.opengis.net/def/crs/EPSG/0/3857"),
|
|
839
|
+
new z("http://www.opengis.net/gml/srs/epsg.xml#3857")
|
|
840
|
+
];
|
|
841
|
+
function pn(i, t, e, n) {
|
|
842
|
+
const s = i.length;
|
|
843
|
+
e = e > 1 ? e : 2, n = n ?? e, t === void 0 && (e > 2 ? t = i.slice() : t = new Array(s));
|
|
844
|
+
for (let r = 0; r < s; r += n) {
|
|
845
|
+
t[r] = b * i[r] / 180;
|
|
846
|
+
let o = B * Math.log(Math.tan(Math.PI * (+i[r + 1] + 90) / 360));
|
|
847
|
+
o > Q ? o = Q : o < -Q && (o = -Q), t[r + 1] = o;
|
|
848
|
+
}
|
|
849
|
+
return t;
|
|
850
|
+
}
|
|
851
|
+
function Tn(i, t, e, n) {
|
|
852
|
+
const s = i.length;
|
|
853
|
+
e = e > 1 ? e : 2, n = n ?? e, t === void 0 && (e > 2 ? t = i.slice() : t = new Array(s));
|
|
854
|
+
for (let r = 0; r < s; r += n)
|
|
855
|
+
t[r] = 180 * i[r] / b, t[r + 1] = 360 * Math.atan(Math.exp(i[r + 1] / B)) / Math.PI - 90;
|
|
856
|
+
return t;
|
|
857
|
+
}
|
|
858
|
+
const In = 6378137, Dt = [-180, -90, 180, 90], yn = Math.PI * In / 180;
|
|
859
|
+
class X extends ft {
|
|
860
|
+
/**
|
|
861
|
+
* @param {string} code Code.
|
|
862
|
+
* @param {string} [axisOrientation] Axis orientation.
|
|
863
|
+
*/
|
|
864
|
+
constructor(t, e) {
|
|
865
|
+
super({
|
|
866
|
+
code: t,
|
|
867
|
+
units: "degrees",
|
|
868
|
+
extent: Dt,
|
|
869
|
+
axisOrientation: e,
|
|
870
|
+
global: !0,
|
|
871
|
+
metersPerUnit: yn,
|
|
872
|
+
worldExtent: Dt
|
|
873
|
+
});
|
|
874
|
+
}
|
|
875
|
+
}
|
|
876
|
+
const Wt = [
|
|
877
|
+
new X("CRS:84"),
|
|
878
|
+
new X("EPSG:4326", "neu"),
|
|
879
|
+
new X("urn:ogc:def:crs:OGC:1.3:CRS84"),
|
|
880
|
+
new X("urn:ogc:def:crs:OGC:2:84"),
|
|
881
|
+
new X("http://www.opengis.net/def/crs/OGC/1.3/CRS84"),
|
|
882
|
+
new X("http://www.opengis.net/gml/srs/epsg.xml#4326", "neu"),
|
|
883
|
+
new X("http://www.opengis.net/def/crs/EPSG/0/4326", "neu")
|
|
884
|
+
];
|
|
885
|
+
let Tt = {};
|
|
886
|
+
function it(i) {
|
|
887
|
+
return Tt[i] || Tt[i.replace(/urn:(x-)?ogc:def:crs:EPSG:(.*:)?(\w+)$/, "EPSG:$3")] || null;
|
|
888
|
+
}
|
|
889
|
+
function wn(i, t) {
|
|
890
|
+
Tt[i] = t;
|
|
891
|
+
}
|
|
892
|
+
let V = {};
|
|
893
|
+
function Z(i, t, e) {
|
|
894
|
+
const n = i.getCode(), s = t.getCode();
|
|
895
|
+
n in V || (V[n] = {}), V[n][s] = e;
|
|
896
|
+
}
|
|
897
|
+
function st(i, t) {
|
|
898
|
+
return i in V && t in V[i] ? V[i][t] : null;
|
|
899
|
+
}
|
|
900
|
+
const at = 0.9996, p = 669438e-8, gt = p * p, dt = gt * p, N = p / (1 - p), $t = Math.sqrt(1 - p), W = (1 - $t) / (1 + $t), Ee = W * W, St = Ee * W, At = St * W, pe = At * W, Te = 1 - p / 4 - 3 * gt / 64 - 5 * dt / 256, Sn = 3 * p / 8 + 3 * gt / 32 + 45 * dt / 1024, An = 15 * gt / 256 + 45 * dt / 1024, vn = 35 * dt / 3072, Pn = 3 / 2 * W - 27 / 32 * St + 269 / 512 * pe, Fn = 21 / 16 * Ee - 55 / 32 * At, Xn = 151 / 96 * St - 417 / 128 * pe, Nn = 1097 / 512 * At, lt = 6378137;
|
|
901
|
+
function Yn(i, t, e) {
|
|
902
|
+
const n = i - 5e5, o = (e.north ? t : t - 1e7) / at / (lt * Te), a = o + Pn * Math.sin(2 * o) + Fn * Math.sin(4 * o) + Xn * Math.sin(6 * o) + Nn * Math.sin(8 * o), l = Math.sin(a), h = l * l, u = Math.cos(a), c = l / u, f = c * c, g = f * f, d = 1 - p * h, m = Math.sqrt(1 - p * h), _ = lt / m, x = (1 - p) / d, R = N * u ** 2, w = R * R, C = n / (_ * at), F = C * C, $ = F * C, Yt = $ * C, Zt = Yt * C, Ge = Zt * C, Oe = a - c / x * (F / 2 - Yt / 24 * (5 + 3 * f + 10 * R - 4 * w - 9 * N)) + Ge / 720 * (61 + 90 * f + 298 * R + 45 * g - 252 * N - 3 * w);
|
|
903
|
+
let mt = (C - $ / 6 * (1 + 2 * f + R) + Zt / 120 * (5 - 2 * R + 28 * f - 3 * w + 8 * N + 24 * g)) / u;
|
|
904
|
+
return mt = pt(
|
|
905
|
+
mt + H(Ie(e.number)),
|
|
906
|
+
-Math.PI,
|
|
907
|
+
Math.PI
|
|
908
|
+
), [bt(mt), bt(Oe)];
|
|
909
|
+
}
|
|
910
|
+
const Ht = -80, kt = 84, Zn = -180, jn = 180;
|
|
911
|
+
function zn(i, t, e) {
|
|
912
|
+
i = pt(i, Zn, jn), t < Ht ? t = Ht : t > kt && (t = kt);
|
|
913
|
+
const n = H(t), s = Math.sin(n), r = Math.cos(n), o = s / r, a = o * o, l = a * a, h = H(i), u = Ie(e.number), c = H(u), f = lt / Math.sqrt(1 - p * s ** 2), g = N * r ** 2, d = r * pt(h - c, -Math.PI, Math.PI), m = d * d, _ = m * d, x = _ * d, R = x * d, w = R * d, C = lt * (Te * n - Sn * Math.sin(2 * n) + An * Math.sin(4 * n) - vn * Math.sin(6 * n)), F = at * f * (d + _ / 6 * (1 - a + g) + R / 120 * (5 - 18 * a + l + 72 * g - 58 * N)) + 5e5;
|
|
914
|
+
let $ = at * (C + f * o * (m / 2 + x / 24 * (5 - a + 9 * g + 4 * g ** 2) + w / 720 * (61 - 58 * a + l + 600 * g - 330 * N)));
|
|
915
|
+
return e.north || ($ += 1e7), [F, $];
|
|
916
|
+
}
|
|
917
|
+
function Ie(i) {
|
|
918
|
+
return (i - 1) * 6 - 180 + 3;
|
|
919
|
+
}
|
|
920
|
+
const Gn = [
|
|
921
|
+
/^EPSG:(\d+)$/,
|
|
922
|
+
/^urn:ogc:def:crs:EPSG::(\d+)$/,
|
|
923
|
+
/^http:\/\/www\.opengis\.net\/def\/crs\/EPSG\/0\/(\d+)$/
|
|
924
|
+
];
|
|
925
|
+
function ye(i) {
|
|
926
|
+
let t = 0;
|
|
927
|
+
for (const s of Gn) {
|
|
928
|
+
const r = i.match(s);
|
|
929
|
+
if (r) {
|
|
930
|
+
t = parseInt(r[1]);
|
|
931
|
+
break;
|
|
932
|
+
}
|
|
933
|
+
}
|
|
934
|
+
if (!t)
|
|
935
|
+
return null;
|
|
936
|
+
let e = 0, n = !1;
|
|
937
|
+
return t > 32700 && t < 32761 ? e = t - 32700 : t > 32600 && t < 32661 && (n = !0, e = t - 32600), e ? { number: e, north: n } : null;
|
|
938
|
+
}
|
|
939
|
+
function qt(i, t) {
|
|
940
|
+
return function(e, n, s, r) {
|
|
941
|
+
const o = e.length;
|
|
942
|
+
s = s > 1 ? s : 2, r = r ?? s, n || (s > 2 ? n = e.slice() : n = new Array(o));
|
|
943
|
+
for (let a = 0; a < o; a += r) {
|
|
944
|
+
const l = e[a], h = e[a + 1], u = i(l, h, t);
|
|
945
|
+
n[a] = u[0], n[a + 1] = u[1];
|
|
946
|
+
}
|
|
947
|
+
return n;
|
|
948
|
+
};
|
|
949
|
+
}
|
|
950
|
+
function On(i) {
|
|
951
|
+
return ye(i) ? new ft({ code: i, units: "m" }) : null;
|
|
952
|
+
}
|
|
953
|
+
function Ln(i) {
|
|
954
|
+
const t = ye(i.getCode());
|
|
955
|
+
return t ? {
|
|
956
|
+
forward: qt(zn, t),
|
|
957
|
+
inverse: qt(Yn, t)
|
|
958
|
+
} : null;
|
|
959
|
+
}
|
|
960
|
+
const bn = [Ln], Un = [On];
|
|
961
|
+
let It = !0;
|
|
962
|
+
function Vn(i) {
|
|
963
|
+
It = !1;
|
|
964
|
+
}
|
|
965
|
+
function we(i, t) {
|
|
966
|
+
if (t !== void 0) {
|
|
967
|
+
for (let e = 0, n = i.length; e < n; ++e)
|
|
968
|
+
t[e] = i[e];
|
|
969
|
+
t = t;
|
|
970
|
+
} else
|
|
971
|
+
t = i.slice();
|
|
972
|
+
return t;
|
|
973
|
+
}
|
|
974
|
+
function ut(i) {
|
|
975
|
+
wn(i.getCode(), i), Z(i, i, we);
|
|
976
|
+
}
|
|
977
|
+
function Dn(i) {
|
|
978
|
+
i.forEach(ut);
|
|
979
|
+
}
|
|
980
|
+
function j(i) {
|
|
981
|
+
if (typeof i != "string")
|
|
982
|
+
return i;
|
|
983
|
+
const t = it(i);
|
|
984
|
+
if (t)
|
|
985
|
+
return t;
|
|
986
|
+
for (const e of Un) {
|
|
987
|
+
const n = e(i);
|
|
988
|
+
if (n)
|
|
989
|
+
return n;
|
|
990
|
+
}
|
|
991
|
+
return null;
|
|
992
|
+
}
|
|
993
|
+
function yt(i) {
|
|
994
|
+
Dn(i), i.forEach(function(t) {
|
|
995
|
+
i.forEach(function(e) {
|
|
996
|
+
t !== e && Z(t, e, we);
|
|
997
|
+
});
|
|
998
|
+
});
|
|
999
|
+
}
|
|
1000
|
+
function Wn(i, t, e, n) {
|
|
1001
|
+
i.forEach(function(s) {
|
|
1002
|
+
t.forEach(function(r) {
|
|
1003
|
+
Z(s, r, e), Z(r, s, n);
|
|
1004
|
+
});
|
|
1005
|
+
});
|
|
1006
|
+
}
|
|
1007
|
+
function vt(i, t) {
|
|
1008
|
+
return i ? typeof i == "string" ? j(i) : (
|
|
1009
|
+
/** @type {Projection} */
|
|
1010
|
+
i
|
|
1011
|
+
) : j(t);
|
|
1012
|
+
}
|
|
1013
|
+
function Bt(i) {
|
|
1014
|
+
return (
|
|
1015
|
+
/**
|
|
1016
|
+
* @param {Array<number>} input Input.
|
|
1017
|
+
* @param {Array<number>} [output] Output.
|
|
1018
|
+
* @param {number} [dimension] Dimensions that should be transformed.
|
|
1019
|
+
* @param {number} [stride] Stride.
|
|
1020
|
+
* @return {Array<number>} Output.
|
|
1021
|
+
*/
|
|
1022
|
+
function(t, e, n, s) {
|
|
1023
|
+
const r = t.length;
|
|
1024
|
+
n = n !== void 0 ? n : 2, s = s ?? n, e = e !== void 0 ? e : new Array(r);
|
|
1025
|
+
for (let o = 0; o < r; o += s) {
|
|
1026
|
+
const a = i(t.slice(o, o + n)), l = a.length;
|
|
1027
|
+
for (let h = 0, u = s; h < u; ++h)
|
|
1028
|
+
e[o + h] = h >= l ? t[o + h] : a[h];
|
|
1029
|
+
}
|
|
1030
|
+
return e;
|
|
1031
|
+
}
|
|
1032
|
+
);
|
|
1033
|
+
}
|
|
1034
|
+
function $n(i, t, e, n) {
|
|
1035
|
+
const s = j(i), r = j(t);
|
|
1036
|
+
Z(
|
|
1037
|
+
s,
|
|
1038
|
+
r,
|
|
1039
|
+
Bt(e)
|
|
1040
|
+
), Z(
|
|
1041
|
+
r,
|
|
1042
|
+
s,
|
|
1043
|
+
Bt(n)
|
|
1044
|
+
);
|
|
1045
|
+
}
|
|
1046
|
+
function Hn(i, t) {
|
|
1047
|
+
const e = i.getCode(), n = t.getCode();
|
|
1048
|
+
let s = st(e, n);
|
|
1049
|
+
if (s)
|
|
1050
|
+
return s;
|
|
1051
|
+
let r = null, o = null;
|
|
1052
|
+
for (const l of bn)
|
|
1053
|
+
r || (r = l(i)), o || (o = l(t));
|
|
1054
|
+
if (!r && !o)
|
|
1055
|
+
return null;
|
|
1056
|
+
const a = "EPSG:4326";
|
|
1057
|
+
if (o)
|
|
1058
|
+
if (r)
|
|
1059
|
+
s = Rt(
|
|
1060
|
+
r.inverse,
|
|
1061
|
+
o.forward
|
|
1062
|
+
);
|
|
1063
|
+
else {
|
|
1064
|
+
const l = st(e, a);
|
|
1065
|
+
l && (s = Rt(
|
|
1066
|
+
l,
|
|
1067
|
+
o.forward
|
|
1068
|
+
));
|
|
1069
|
+
}
|
|
1070
|
+
else {
|
|
1071
|
+
const l = st(a, n);
|
|
1072
|
+
l && (s = Rt(
|
|
1073
|
+
r.inverse,
|
|
1074
|
+
l
|
|
1075
|
+
));
|
|
1076
|
+
}
|
|
1077
|
+
return s && (ut(i), ut(t), Z(i, t, s)), s;
|
|
1078
|
+
}
|
|
1079
|
+
function Rt(i, t) {
|
|
1080
|
+
return function(e, n, s, r) {
|
|
1081
|
+
return n = i(e, n, s, r), t(n, n, s, r);
|
|
1082
|
+
};
|
|
1083
|
+
}
|
|
1084
|
+
function Kt(i, t) {
|
|
1085
|
+
const e = j(i), n = j(t);
|
|
1086
|
+
return Hn(e, n);
|
|
1087
|
+
}
|
|
1088
|
+
function Jt(i, t) {
|
|
1089
|
+
return i;
|
|
1090
|
+
}
|
|
1091
|
+
function S(i, t) {
|
|
1092
|
+
return It && !ot(i, [0, 0]) && i[0] >= -180 && i[0] <= 180 && i[1] >= -90 && i[1] <= 90 && (It = !1, _n(
|
|
1093
|
+
"Call useGeographic() from ol/proj once to work with [longitude, latitude] coordinates."
|
|
1094
|
+
)), i;
|
|
1095
|
+
}
|
|
1096
|
+
function kn(i, t) {
|
|
1097
|
+
return i;
|
|
1098
|
+
}
|
|
1099
|
+
function tt(i, t) {
|
|
1100
|
+
return i;
|
|
1101
|
+
}
|
|
1102
|
+
function Qt(i, t, e) {
|
|
1103
|
+
return function(n) {
|
|
1104
|
+
let s, r;
|
|
1105
|
+
if (i.canWrapX()) {
|
|
1106
|
+
const o = i.getExtent(), a = D(o);
|
|
1107
|
+
n = n.slice(0), r = Mn(n, i, a), r && (n[0] = n[0] - r * a), n[0] = T(n[0], o[0], o[2]), n[1] = T(n[1], o[1], o[3]), s = e(n);
|
|
1108
|
+
} else
|
|
1109
|
+
s = e(n);
|
|
1110
|
+
return r && t.canWrapX() && (s[0] += r * D(t.getExtent())), s;
|
|
1111
|
+
};
|
|
1112
|
+
}
|
|
1113
|
+
function qn() {
|
|
1114
|
+
yt(Vt), yt(Wt), Wn(
|
|
1115
|
+
Wt,
|
|
1116
|
+
Vt,
|
|
1117
|
+
pn,
|
|
1118
|
+
Tn
|
|
1119
|
+
);
|
|
1120
|
+
}
|
|
1121
|
+
qn();
|
|
1122
|
+
new Array(6);
|
|
1123
|
+
function Bn() {
|
|
1124
|
+
return [1, 0, 0, 1, 0, 0];
|
|
1125
|
+
}
|
|
1126
|
+
function Kn(i, t, e, n, s, r, o, a) {
|
|
1127
|
+
const l = Math.sin(r), h = Math.cos(r);
|
|
1128
|
+
return i[0] = n * h, i[1] = s * l, i[2] = -n * l, i[3] = s * h, i[4] = o * n * h - a * n * l + t, i[5] = o * s * l + a * s * h + e, i;
|
|
1129
|
+
}
|
|
1130
|
+
function Jn(i, t, e, n, s, r, o) {
|
|
1131
|
+
r = r || [], o = o || 2;
|
|
1132
|
+
let a = 0;
|
|
1133
|
+
for (let l = t; l < e; l += n) {
|
|
1134
|
+
const h = i[l], u = i[l + 1];
|
|
1135
|
+
r[a++] = s[0] * h + s[2] * u + s[4], r[a++] = s[1] * h + s[3] * u + s[5];
|
|
1136
|
+
for (let c = 2; c < o; c++)
|
|
1137
|
+
r[a++] = i[l + c];
|
|
1138
|
+
}
|
|
1139
|
+
return r && r.length != a && (r.length = a), r;
|
|
1140
|
+
}
|
|
1141
|
+
function Qn(i, t, e, n, s, r, o) {
|
|
1142
|
+
o = o || [];
|
|
1143
|
+
const a = Math.cos(s), l = Math.sin(s), h = r[0], u = r[1];
|
|
1144
|
+
let c = 0;
|
|
1145
|
+
for (let f = t; f < e; f += n) {
|
|
1146
|
+
const g = i[f] - h, d = i[f + 1] - u;
|
|
1147
|
+
o[c++] = h + g * a - d * l, o[c++] = u + g * l + d * a;
|
|
1148
|
+
for (let m = f + 2; m < f + n; ++m)
|
|
1149
|
+
o[c++] = i[m];
|
|
1150
|
+
}
|
|
1151
|
+
return o && o.length != c && (o.length = c), o;
|
|
1152
|
+
}
|
|
1153
|
+
function ti(i, t, e, n, s, r, o, a) {
|
|
1154
|
+
a = a || [];
|
|
1155
|
+
const l = o[0], h = o[1];
|
|
1156
|
+
let u = 0;
|
|
1157
|
+
for (let c = t; c < e; c += n) {
|
|
1158
|
+
const f = i[c] - l, g = i[c + 1] - h;
|
|
1159
|
+
a[u++] = l + s * f, a[u++] = h + r * g;
|
|
1160
|
+
for (let d = c + 2; d < c + n; ++d)
|
|
1161
|
+
a[u++] = i[d];
|
|
1162
|
+
}
|
|
1163
|
+
return a && a.length != u && (a.length = u), a;
|
|
1164
|
+
}
|
|
1165
|
+
function ei(i, t, e, n, s, r, o) {
|
|
1166
|
+
o = o || [];
|
|
1167
|
+
let a = 0;
|
|
1168
|
+
for (let l = t; l < e; l += n) {
|
|
1169
|
+
o[a++] = i[l] + s, o[a++] = i[l + 1] + r;
|
|
1170
|
+
for (let h = l + 2; h < l + n; ++h)
|
|
1171
|
+
o[a++] = i[h];
|
|
1172
|
+
}
|
|
1173
|
+
return o && o.length != a && (o.length = a), o;
|
|
1174
|
+
}
|
|
1175
|
+
const te = Bn(), ni = [NaN, NaN];
|
|
1176
|
+
class ii extends fe {
|
|
1177
|
+
constructor() {
|
|
1178
|
+
super(), this.extent_ = de(), this.extentRevision_ = -1, this.simplifiedGeometryMaxMinSquaredTolerance = 0, this.simplifiedGeometryRevision = 0, this.simplifyTransformedInternal = He(
|
|
1179
|
+
(t, e, n) => {
|
|
1180
|
+
if (!n)
|
|
1181
|
+
return this.getSimplifiedGeometry(e);
|
|
1182
|
+
const s = this.clone();
|
|
1183
|
+
return s.applyTransform(n), s.getSimplifiedGeometry(e);
|
|
1184
|
+
}
|
|
1185
|
+
);
|
|
1186
|
+
}
|
|
1187
|
+
/**
|
|
1188
|
+
* Get a transformed and simplified version of the geometry.
|
|
1189
|
+
* @abstract
|
|
1190
|
+
* @param {number} squaredTolerance Squared tolerance.
|
|
1191
|
+
* @param {import("../proj.js").TransformFunction} [transform] Optional transform function.
|
|
1192
|
+
* @return {Geometry} Simplified geometry.
|
|
1193
|
+
*/
|
|
1194
|
+
simplifyTransformed(t, e) {
|
|
1195
|
+
return this.simplifyTransformedInternal(
|
|
1196
|
+
this.getRevision(),
|
|
1197
|
+
t,
|
|
1198
|
+
e
|
|
1199
|
+
);
|
|
1200
|
+
}
|
|
1201
|
+
/**
|
|
1202
|
+
* Make a complete copy of the geometry.
|
|
1203
|
+
* @abstract
|
|
1204
|
+
* @return {!Geometry} Clone.
|
|
1205
|
+
*/
|
|
1206
|
+
clone() {
|
|
1207
|
+
return E();
|
|
1208
|
+
}
|
|
1209
|
+
/**
|
|
1210
|
+
* @abstract
|
|
1211
|
+
* @param {number} x X.
|
|
1212
|
+
* @param {number} y Y.
|
|
1213
|
+
* @param {import("../coordinate.js").Coordinate} closestPoint Closest point.
|
|
1214
|
+
* @param {number} minSquaredDistance Minimum squared distance.
|
|
1215
|
+
* @return {number} Minimum squared distance.
|
|
1216
|
+
*/
|
|
1217
|
+
closestPointXY(t, e, n, s) {
|
|
1218
|
+
return E();
|
|
1219
|
+
}
|
|
1220
|
+
/**
|
|
1221
|
+
* @param {number} x X.
|
|
1222
|
+
* @param {number} y Y.
|
|
1223
|
+
* @return {boolean} Contains (x, y).
|
|
1224
|
+
*/
|
|
1225
|
+
containsXY(t, e) {
|
|
1226
|
+
return this.closestPointXY(t, e, ni, Number.MIN_VALUE) === 0;
|
|
1227
|
+
}
|
|
1228
|
+
/**
|
|
1229
|
+
* Return the closest point of the geometry to the passed point as
|
|
1230
|
+
* {@link module:ol/coordinate~Coordinate coordinate}.
|
|
1231
|
+
* @param {import("../coordinate.js").Coordinate} point Point.
|
|
1232
|
+
* @param {import("../coordinate.js").Coordinate} [closestPoint] Closest point.
|
|
1233
|
+
* @return {import("../coordinate.js").Coordinate} Closest point.
|
|
1234
|
+
* @api
|
|
1235
|
+
*/
|
|
1236
|
+
getClosestPoint(t, e) {
|
|
1237
|
+
return e = e || [NaN, NaN], this.closestPointXY(t[0], t[1], e, 1 / 0), e;
|
|
1238
|
+
}
|
|
1239
|
+
/**
|
|
1240
|
+
* Returns true if this geometry includes the specified coordinate. If the
|
|
1241
|
+
* coordinate is on the boundary of the geometry, returns false.
|
|
1242
|
+
* @param {import("../coordinate.js").Coordinate} coordinate Coordinate.
|
|
1243
|
+
* @return {boolean} Contains coordinate.
|
|
1244
|
+
* @api
|
|
1245
|
+
*/
|
|
1246
|
+
intersectsCoordinate(t) {
|
|
1247
|
+
return this.containsXY(t[0], t[1]);
|
|
1248
|
+
}
|
|
1249
|
+
/**
|
|
1250
|
+
* @abstract
|
|
1251
|
+
* @param {import("../extent.js").Extent} extent Extent.
|
|
1252
|
+
* @protected
|
|
1253
|
+
* @return {import("../extent.js").Extent} extent Extent.
|
|
1254
|
+
*/
|
|
1255
|
+
computeExtent(t) {
|
|
1256
|
+
return E();
|
|
1257
|
+
}
|
|
1258
|
+
/**
|
|
1259
|
+
* Get the extent of the geometry.
|
|
1260
|
+
* @param {import("../extent.js").Extent} [extent] Extent.
|
|
1261
|
+
* @return {import("../extent.js").Extent} extent Extent.
|
|
1262
|
+
* @api
|
|
1263
|
+
*/
|
|
1264
|
+
getExtent(t) {
|
|
1265
|
+
if (this.extentRevision_ != this.getRevision()) {
|
|
1266
|
+
const e = this.computeExtent(this.extent_);
|
|
1267
|
+
(isNaN(e[0]) || isNaN(e[1])) && me(e), this.extentRevision_ = this.getRevision();
|
|
1268
|
+
}
|
|
1269
|
+
return fn(this.extent_, t);
|
|
1270
|
+
}
|
|
1271
|
+
/**
|
|
1272
|
+
* Rotate the geometry around a given coordinate. This modifies the geometry
|
|
1273
|
+
* coordinates in place.
|
|
1274
|
+
* @abstract
|
|
1275
|
+
* @param {number} angle Rotation angle in radians.
|
|
1276
|
+
* @param {import("../coordinate.js").Coordinate} anchor The rotation center.
|
|
1277
|
+
* @api
|
|
1278
|
+
*/
|
|
1279
|
+
rotate(t, e) {
|
|
1280
|
+
E();
|
|
1281
|
+
}
|
|
1282
|
+
/**
|
|
1283
|
+
* Scale the geometry (with an optional origin). This modifies the geometry
|
|
1284
|
+
* coordinates in place.
|
|
1285
|
+
* @abstract
|
|
1286
|
+
* @param {number} sx The scaling factor in the x-direction.
|
|
1287
|
+
* @param {number} [sy] The scaling factor in the y-direction (defaults to sx).
|
|
1288
|
+
* @param {import("../coordinate.js").Coordinate} [anchor] The scale origin (defaults to the center
|
|
1289
|
+
* of the geometry extent).
|
|
1290
|
+
* @api
|
|
1291
|
+
*/
|
|
1292
|
+
scale(t, e, n) {
|
|
1293
|
+
E();
|
|
1294
|
+
}
|
|
1295
|
+
/**
|
|
1296
|
+
* Create a simplified version of this geometry. For linestrings, this uses
|
|
1297
|
+
* the [Douglas Peucker](https://en.wikipedia.org/wiki/Ramer-Douglas-Peucker_algorithm)
|
|
1298
|
+
* algorithm. For polygons, a quantization-based
|
|
1299
|
+
* simplification is used to preserve topology.
|
|
1300
|
+
* @param {number} tolerance The tolerance distance for simplification.
|
|
1301
|
+
* @return {Geometry} A new, simplified version of the original geometry.
|
|
1302
|
+
* @api
|
|
1303
|
+
*/
|
|
1304
|
+
simplify(t) {
|
|
1305
|
+
return this.getSimplifiedGeometry(t * t);
|
|
1306
|
+
}
|
|
1307
|
+
/**
|
|
1308
|
+
* Create a simplified version of this geometry using the Douglas Peucker
|
|
1309
|
+
* algorithm.
|
|
1310
|
+
* See https://en.wikipedia.org/wiki/Ramer-Douglas-Peucker_algorithm.
|
|
1311
|
+
* @abstract
|
|
1312
|
+
* @param {number} squaredTolerance Squared tolerance.
|
|
1313
|
+
* @return {Geometry} Simplified geometry.
|
|
1314
|
+
*/
|
|
1315
|
+
getSimplifiedGeometry(t) {
|
|
1316
|
+
return E();
|
|
1317
|
+
}
|
|
1318
|
+
/**
|
|
1319
|
+
* Get the type of this geometry.
|
|
1320
|
+
* @abstract
|
|
1321
|
+
* @return {Type} Geometry type.
|
|
1322
|
+
*/
|
|
1323
|
+
getType() {
|
|
1324
|
+
return E();
|
|
1325
|
+
}
|
|
1326
|
+
/**
|
|
1327
|
+
* Apply a transform function to the coordinates of the geometry.
|
|
1328
|
+
* The geometry is modified in place.
|
|
1329
|
+
* If you do not want the geometry modified in place, first `clone()` it and
|
|
1330
|
+
* then use this function on the clone.
|
|
1331
|
+
* @abstract
|
|
1332
|
+
* @param {import("../proj.js").TransformFunction} transformFn Transform function.
|
|
1333
|
+
* Called with a flat array of geometry coordinates.
|
|
1334
|
+
*/
|
|
1335
|
+
applyTransform(t) {
|
|
1336
|
+
E();
|
|
1337
|
+
}
|
|
1338
|
+
/**
|
|
1339
|
+
* Test if the geometry and the passed extent intersect.
|
|
1340
|
+
* @abstract
|
|
1341
|
+
* @param {import("../extent.js").Extent} extent Extent.
|
|
1342
|
+
* @return {boolean} `true` if the geometry and the extent intersect.
|
|
1343
|
+
*/
|
|
1344
|
+
intersectsExtent(t) {
|
|
1345
|
+
return E();
|
|
1346
|
+
}
|
|
1347
|
+
/**
|
|
1348
|
+
* Translate the geometry. This modifies the geometry coordinates in place. If
|
|
1349
|
+
* instead you want a new geometry, first `clone()` this geometry.
|
|
1350
|
+
* @abstract
|
|
1351
|
+
* @param {number} deltaX Delta X.
|
|
1352
|
+
* @param {number} deltaY Delta Y.
|
|
1353
|
+
* @api
|
|
1354
|
+
*/
|
|
1355
|
+
translate(t, e) {
|
|
1356
|
+
E();
|
|
1357
|
+
}
|
|
1358
|
+
/**
|
|
1359
|
+
* Transform each coordinate of the geometry from one coordinate reference
|
|
1360
|
+
* system to another. The geometry is modified in place.
|
|
1361
|
+
* For example, a line will be transformed to a line and a circle to a circle.
|
|
1362
|
+
* If you do not want the geometry modified in place, first `clone()` it and
|
|
1363
|
+
* then use this function on the clone.
|
|
1364
|
+
*
|
|
1365
|
+
* @param {import("../proj.js").ProjectionLike} source The current projection. Can be a
|
|
1366
|
+
* string identifier or a {@link module:ol/proj/Projection~Projection} object.
|
|
1367
|
+
* @param {import("../proj.js").ProjectionLike} destination The desired projection. Can be a
|
|
1368
|
+
* string identifier or a {@link module:ol/proj/Projection~Projection} object.
|
|
1369
|
+
* @return {this} This geometry. Note that original geometry is
|
|
1370
|
+
* modified in place.
|
|
1371
|
+
* @api
|
|
1372
|
+
*/
|
|
1373
|
+
transform(t, e) {
|
|
1374
|
+
const n = j(t), s = n.getUnits() == "tile-pixels" ? function(r, o, a) {
|
|
1375
|
+
const l = n.getExtent(), h = n.getWorldExtent(), u = k(h) / k(l);
|
|
1376
|
+
Kn(
|
|
1377
|
+
te,
|
|
1378
|
+
h[0],
|
|
1379
|
+
h[3],
|
|
1380
|
+
u,
|
|
1381
|
+
-u,
|
|
1382
|
+
0,
|
|
1383
|
+
0,
|
|
1384
|
+
0
|
|
1385
|
+
);
|
|
1386
|
+
const c = Jn(
|
|
1387
|
+
r,
|
|
1388
|
+
0,
|
|
1389
|
+
r.length,
|
|
1390
|
+
a,
|
|
1391
|
+
te,
|
|
1392
|
+
o
|
|
1393
|
+
), f = Kt(n, e);
|
|
1394
|
+
return f ? f(c, c, a) : c;
|
|
1395
|
+
} : Kt(n, e);
|
|
1396
|
+
return this.applyTransform(s), this;
|
|
1397
|
+
}
|
|
1398
|
+
}
|
|
1399
|
+
class Pt extends ii {
|
|
1400
|
+
constructor() {
|
|
1401
|
+
super(), this.layout = "XY", this.stride = 2, this.flatCoordinates;
|
|
1402
|
+
}
|
|
1403
|
+
/**
|
|
1404
|
+
* @param {import("../extent.js").Extent} extent Extent.
|
|
1405
|
+
* @protected
|
|
1406
|
+
* @return {import("../extent.js").Extent} extent Extent.
|
|
1407
|
+
* @override
|
|
1408
|
+
*/
|
|
1409
|
+
computeExtent(t) {
|
|
1410
|
+
return nn(
|
|
1411
|
+
this.flatCoordinates,
|
|
1412
|
+
0,
|
|
1413
|
+
this.flatCoordinates.length,
|
|
1414
|
+
this.stride,
|
|
1415
|
+
t
|
|
1416
|
+
);
|
|
1417
|
+
}
|
|
1418
|
+
/**
|
|
1419
|
+
* @abstract
|
|
1420
|
+
* @return {Array<*> | null} Coordinates.
|
|
1421
|
+
*/
|
|
1422
|
+
getCoordinates() {
|
|
1423
|
+
return E();
|
|
1424
|
+
}
|
|
1425
|
+
/**
|
|
1426
|
+
* Return the first coordinate of the geometry.
|
|
1427
|
+
* @return {import("../coordinate.js").Coordinate} First coordinate.
|
|
1428
|
+
* @api
|
|
1429
|
+
*/
|
|
1430
|
+
getFirstCoordinate() {
|
|
1431
|
+
return this.flatCoordinates.slice(0, this.stride);
|
|
1432
|
+
}
|
|
1433
|
+
/**
|
|
1434
|
+
* @return {Array<number>} Flat coordinates.
|
|
1435
|
+
*/
|
|
1436
|
+
getFlatCoordinates() {
|
|
1437
|
+
return this.flatCoordinates;
|
|
1438
|
+
}
|
|
1439
|
+
/**
|
|
1440
|
+
* Return the last coordinate of the geometry.
|
|
1441
|
+
* @return {import("../coordinate.js").Coordinate} Last point.
|
|
1442
|
+
* @api
|
|
1443
|
+
*/
|
|
1444
|
+
getLastCoordinate() {
|
|
1445
|
+
return this.flatCoordinates.slice(
|
|
1446
|
+
this.flatCoordinates.length - this.stride
|
|
1447
|
+
);
|
|
1448
|
+
}
|
|
1449
|
+
/**
|
|
1450
|
+
* Return the {@link import("./Geometry.js").GeometryLayout layout} of the geometry.
|
|
1451
|
+
* @return {import("./Geometry.js").GeometryLayout} Layout.
|
|
1452
|
+
* @api
|
|
1453
|
+
*/
|
|
1454
|
+
getLayout() {
|
|
1455
|
+
return this.layout;
|
|
1456
|
+
}
|
|
1457
|
+
/**
|
|
1458
|
+
* Create a simplified version of this geometry using the Douglas Peucker algorithm.
|
|
1459
|
+
* @param {number} squaredTolerance Squared tolerance.
|
|
1460
|
+
* @return {SimpleGeometry} Simplified geometry.
|
|
1461
|
+
* @override
|
|
1462
|
+
*/
|
|
1463
|
+
getSimplifiedGeometry(t) {
|
|
1464
|
+
if (this.simplifiedGeometryRevision !== this.getRevision() && (this.simplifiedGeometryMaxMinSquaredTolerance = 0, this.simplifiedGeometryRevision = this.getRevision()), t < 0 || this.simplifiedGeometryMaxMinSquaredTolerance !== 0 && t <= this.simplifiedGeometryMaxMinSquaredTolerance)
|
|
1465
|
+
return this;
|
|
1466
|
+
const e = this.getSimplifiedGeometryInternal(t);
|
|
1467
|
+
return e.getFlatCoordinates().length < this.flatCoordinates.length ? e : (this.simplifiedGeometryMaxMinSquaredTolerance = t, this);
|
|
1468
|
+
}
|
|
1469
|
+
/**
|
|
1470
|
+
* @param {number} squaredTolerance Squared tolerance.
|
|
1471
|
+
* @return {SimpleGeometry} Simplified geometry.
|
|
1472
|
+
* @protected
|
|
1473
|
+
*/
|
|
1474
|
+
getSimplifiedGeometryInternal(t) {
|
|
1475
|
+
return this;
|
|
1476
|
+
}
|
|
1477
|
+
/**
|
|
1478
|
+
* @return {number} Stride.
|
|
1479
|
+
*/
|
|
1480
|
+
getStride() {
|
|
1481
|
+
return this.stride;
|
|
1482
|
+
}
|
|
1483
|
+
/**
|
|
1484
|
+
* @param {import("./Geometry.js").GeometryLayout} layout Layout.
|
|
1485
|
+
* @param {Array<number>} flatCoordinates Flat coordinates.
|
|
1486
|
+
*/
|
|
1487
|
+
setFlatCoordinates(t, e) {
|
|
1488
|
+
this.stride = ee(t), this.layout = t, this.flatCoordinates = e;
|
|
1489
|
+
}
|
|
1490
|
+
/**
|
|
1491
|
+
* @abstract
|
|
1492
|
+
* @param {!Array<*>} coordinates Coordinates.
|
|
1493
|
+
* @param {import("./Geometry.js").GeometryLayout} [layout] Layout.
|
|
1494
|
+
*/
|
|
1495
|
+
setCoordinates(t, e) {
|
|
1496
|
+
E();
|
|
1497
|
+
}
|
|
1498
|
+
/**
|
|
1499
|
+
* @param {import("./Geometry.js").GeometryLayout|undefined} layout Layout.
|
|
1500
|
+
* @param {Array<*>} coordinates Coordinates.
|
|
1501
|
+
* @param {number} nesting Nesting.
|
|
1502
|
+
* @protected
|
|
1503
|
+
*/
|
|
1504
|
+
setLayout(t, e, n) {
|
|
1505
|
+
let s;
|
|
1506
|
+
if (t)
|
|
1507
|
+
s = ee(t);
|
|
1508
|
+
else {
|
|
1509
|
+
for (let r = 0; r < n; ++r) {
|
|
1510
|
+
if (e.length === 0) {
|
|
1511
|
+
this.layout = "XY", this.stride = 2;
|
|
1512
|
+
return;
|
|
1513
|
+
}
|
|
1514
|
+
e = /** @type {Array<unknown>} */
|
|
1515
|
+
e[0];
|
|
1516
|
+
}
|
|
1517
|
+
s = e.length, t = si(s);
|
|
1518
|
+
}
|
|
1519
|
+
this.layout = t, this.stride = s;
|
|
1520
|
+
}
|
|
1521
|
+
/**
|
|
1522
|
+
* Apply a transform function to the coordinates of the geometry.
|
|
1523
|
+
* The geometry is modified in place.
|
|
1524
|
+
* If you do not want the geometry modified in place, first `clone()` it and
|
|
1525
|
+
* then use this function on the clone.
|
|
1526
|
+
* @param {import("../proj.js").TransformFunction} transformFn Transform function.
|
|
1527
|
+
* Called with a flat array of geometry coordinates.
|
|
1528
|
+
* @api
|
|
1529
|
+
* @override
|
|
1530
|
+
*/
|
|
1531
|
+
applyTransform(t) {
|
|
1532
|
+
this.flatCoordinates && (t(
|
|
1533
|
+
this.flatCoordinates,
|
|
1534
|
+
this.flatCoordinates,
|
|
1535
|
+
this.layout.startsWith("XYZ") ? 3 : 2,
|
|
1536
|
+
this.stride
|
|
1537
|
+
), this.changed());
|
|
1538
|
+
}
|
|
1539
|
+
/**
|
|
1540
|
+
* Rotate the geometry around a given coordinate. This modifies the geometry
|
|
1541
|
+
* coordinates in place.
|
|
1542
|
+
* @param {number} angle Rotation angle in counter-clockwise radians.
|
|
1543
|
+
* @param {import("../coordinate.js").Coordinate} anchor The rotation center.
|
|
1544
|
+
* @api
|
|
1545
|
+
* @override
|
|
1546
|
+
*/
|
|
1547
|
+
rotate(t, e) {
|
|
1548
|
+
const n = this.getFlatCoordinates();
|
|
1549
|
+
if (n) {
|
|
1550
|
+
const s = this.getStride();
|
|
1551
|
+
Qn(
|
|
1552
|
+
n,
|
|
1553
|
+
0,
|
|
1554
|
+
n.length,
|
|
1555
|
+
s,
|
|
1556
|
+
t,
|
|
1557
|
+
e,
|
|
1558
|
+
n
|
|
1559
|
+
), this.changed();
|
|
1560
|
+
}
|
|
1561
|
+
}
|
|
1562
|
+
/**
|
|
1563
|
+
* Scale the geometry (with an optional origin). This modifies the geometry
|
|
1564
|
+
* coordinates in place.
|
|
1565
|
+
* @param {number} sx The scaling factor in the x-direction.
|
|
1566
|
+
* @param {number} [sy] The scaling factor in the y-direction (defaults to sx).
|
|
1567
|
+
* @param {import("../coordinate.js").Coordinate} [anchor] The scale origin (defaults to the center
|
|
1568
|
+
* of the geometry extent).
|
|
1569
|
+
* @api
|
|
1570
|
+
* @override
|
|
1571
|
+
*/
|
|
1572
|
+
scale(t, e, n) {
|
|
1573
|
+
e === void 0 && (e = t), n || (n = rt(this.getExtent()));
|
|
1574
|
+
const s = this.getFlatCoordinates();
|
|
1575
|
+
if (s) {
|
|
1576
|
+
const r = this.getStride();
|
|
1577
|
+
ti(
|
|
1578
|
+
s,
|
|
1579
|
+
0,
|
|
1580
|
+
s.length,
|
|
1581
|
+
r,
|
|
1582
|
+
t,
|
|
1583
|
+
e,
|
|
1584
|
+
n,
|
|
1585
|
+
s
|
|
1586
|
+
), this.changed();
|
|
1587
|
+
}
|
|
1588
|
+
}
|
|
1589
|
+
/**
|
|
1590
|
+
* Translate the geometry. This modifies the geometry coordinates in place. If
|
|
1591
|
+
* instead you want a new geometry, first `clone()` this geometry.
|
|
1592
|
+
* @param {number} deltaX Delta X.
|
|
1593
|
+
* @param {number} deltaY Delta Y.
|
|
1594
|
+
* @api
|
|
1595
|
+
* @override
|
|
1596
|
+
*/
|
|
1597
|
+
translate(t, e) {
|
|
1598
|
+
const n = this.getFlatCoordinates();
|
|
1599
|
+
if (n) {
|
|
1600
|
+
const s = this.getStride();
|
|
1601
|
+
ei(
|
|
1602
|
+
n,
|
|
1603
|
+
0,
|
|
1604
|
+
n.length,
|
|
1605
|
+
s,
|
|
1606
|
+
t,
|
|
1607
|
+
e,
|
|
1608
|
+
n
|
|
1609
|
+
), this.changed();
|
|
1610
|
+
}
|
|
1611
|
+
}
|
|
1612
|
+
}
|
|
1613
|
+
function si(i) {
|
|
1614
|
+
let t;
|
|
1615
|
+
return i == 2 ? t = "XY" : i == 3 ? t = "XYZ" : i == 4 && (t = "XYZM"), /** @type {import("./Geometry.js").GeometryLayout} */
|
|
1616
|
+
t;
|
|
1617
|
+
}
|
|
1618
|
+
function ee(i) {
|
|
1619
|
+
let t;
|
|
1620
|
+
return i == "XY" ? t = 2 : i == "XYZ" || i == "XYM" ? t = 3 : i == "XYZM" && (t = 4), /** @type {number} */
|
|
1621
|
+
t;
|
|
1622
|
+
}
|
|
1623
|
+
function Se(i, t, e, n) {
|
|
1624
|
+
let s = 0;
|
|
1625
|
+
const r = i[e - n], o = i[e - n + 1];
|
|
1626
|
+
let a = 0, l = 0;
|
|
1627
|
+
for (; t < e; t += n) {
|
|
1628
|
+
const h = i[t] - r, u = i[t + 1] - o;
|
|
1629
|
+
s += l * h - a * u, a = h, l = u;
|
|
1630
|
+
}
|
|
1631
|
+
return s / 2;
|
|
1632
|
+
}
|
|
1633
|
+
function ri(i, t, e, n) {
|
|
1634
|
+
let s = 0;
|
|
1635
|
+
for (let r = 0, o = e.length; r < o; ++r) {
|
|
1636
|
+
const a = e[r];
|
|
1637
|
+
s += Se(i, t, a, n), t = a;
|
|
1638
|
+
}
|
|
1639
|
+
return s;
|
|
1640
|
+
}
|
|
1641
|
+
function ne(i, t, e, n, s, r, o) {
|
|
1642
|
+
const a = i[t], l = i[t + 1], h = i[e] - a, u = i[e + 1] - l;
|
|
1643
|
+
let c;
|
|
1644
|
+
if (h === 0 && u === 0)
|
|
1645
|
+
c = t;
|
|
1646
|
+
else {
|
|
1647
|
+
const f = ((s - a) * h + (r - l) * u) / (h * h + u * u);
|
|
1648
|
+
if (f > 1)
|
|
1649
|
+
c = e;
|
|
1650
|
+
else if (f > 0) {
|
|
1651
|
+
for (let g = 0; g < n; ++g)
|
|
1652
|
+
o[g] = mn(
|
|
1653
|
+
i[t + g],
|
|
1654
|
+
i[e + g],
|
|
1655
|
+
f
|
|
1656
|
+
);
|
|
1657
|
+
o.length = n;
|
|
1658
|
+
return;
|
|
1659
|
+
} else
|
|
1660
|
+
c = t;
|
|
1661
|
+
}
|
|
1662
|
+
for (let f = 0; f < n; ++f)
|
|
1663
|
+
o[f] = i[c + f];
|
|
1664
|
+
o.length = n;
|
|
1665
|
+
}
|
|
1666
|
+
function Ae(i, t, e, n, s) {
|
|
1667
|
+
let r = i[t], o = i[t + 1];
|
|
1668
|
+
for (t += n; t < e; t += n) {
|
|
1669
|
+
const a = i[t], l = i[t + 1], h = U(r, o, a, l);
|
|
1670
|
+
h > s && (s = h), r = a, o = l;
|
|
1671
|
+
}
|
|
1672
|
+
return s;
|
|
1673
|
+
}
|
|
1674
|
+
function oi(i, t, e, n, s) {
|
|
1675
|
+
for (let r = 0, o = e.length; r < o; ++r) {
|
|
1676
|
+
const a = e[r];
|
|
1677
|
+
s = Ae(i, t, a, n, s), t = a;
|
|
1678
|
+
}
|
|
1679
|
+
return s;
|
|
1680
|
+
}
|
|
1681
|
+
function ve(i, t, e, n, s, r, o, a, l, h, u) {
|
|
1682
|
+
if (t == e)
|
|
1683
|
+
return h;
|
|
1684
|
+
let c, f;
|
|
1685
|
+
if (s === 0) {
|
|
1686
|
+
if (f = U(
|
|
1687
|
+
o,
|
|
1688
|
+
a,
|
|
1689
|
+
i[t],
|
|
1690
|
+
i[t + 1]
|
|
1691
|
+
), f < h) {
|
|
1692
|
+
for (c = 0; c < n; ++c)
|
|
1693
|
+
l[c] = i[t + c];
|
|
1694
|
+
return l.length = n, f;
|
|
1695
|
+
}
|
|
1696
|
+
return h;
|
|
1697
|
+
}
|
|
1698
|
+
u = u || [NaN, NaN];
|
|
1699
|
+
let g = t + n;
|
|
1700
|
+
for (; g < e; )
|
|
1701
|
+
if (ne(
|
|
1702
|
+
i,
|
|
1703
|
+
g - n,
|
|
1704
|
+
g,
|
|
1705
|
+
n,
|
|
1706
|
+
o,
|
|
1707
|
+
a,
|
|
1708
|
+
u
|
|
1709
|
+
), f = U(o, a, u[0], u[1]), f < h) {
|
|
1710
|
+
for (h = f, c = 0; c < n; ++c)
|
|
1711
|
+
l[c] = u[c];
|
|
1712
|
+
l.length = n, g += n;
|
|
1713
|
+
} else
|
|
1714
|
+
g += n * Math.max(
|
|
1715
|
+
(Math.sqrt(f) - Math.sqrt(h)) / s | 0,
|
|
1716
|
+
1
|
|
1717
|
+
);
|
|
1718
|
+
if (ne(
|
|
1719
|
+
i,
|
|
1720
|
+
e - n,
|
|
1721
|
+
t,
|
|
1722
|
+
n,
|
|
1723
|
+
o,
|
|
1724
|
+
a,
|
|
1725
|
+
u
|
|
1726
|
+
), f = U(o, a, u[0], u[1]), f < h) {
|
|
1727
|
+
for (h = f, c = 0; c < n; ++c)
|
|
1728
|
+
l[c] = u[c];
|
|
1729
|
+
l.length = n;
|
|
1730
|
+
}
|
|
1731
|
+
return h;
|
|
1732
|
+
}
|
|
1733
|
+
function ai(i, t, e, n, s, r, o, a, l, h, u) {
|
|
1734
|
+
u = u || [NaN, NaN];
|
|
1735
|
+
for (let c = 0, f = e.length; c < f; ++c) {
|
|
1736
|
+
const g = e[c];
|
|
1737
|
+
h = ve(
|
|
1738
|
+
i,
|
|
1739
|
+
t,
|
|
1740
|
+
g,
|
|
1741
|
+
n,
|
|
1742
|
+
s,
|
|
1743
|
+
r,
|
|
1744
|
+
o,
|
|
1745
|
+
a,
|
|
1746
|
+
l,
|
|
1747
|
+
h,
|
|
1748
|
+
u
|
|
1749
|
+
), t = g;
|
|
1750
|
+
}
|
|
1751
|
+
return h;
|
|
1752
|
+
}
|
|
1753
|
+
function li(i, t, e, n) {
|
|
1754
|
+
for (let s = 0, r = e.length; s < r; ++s)
|
|
1755
|
+
i[t++] = e[s];
|
|
1756
|
+
return t;
|
|
1757
|
+
}
|
|
1758
|
+
function Pe(i, t, e, n) {
|
|
1759
|
+
for (let s = 0, r = e.length; s < r; ++s) {
|
|
1760
|
+
const o = e[s];
|
|
1761
|
+
for (let a = 0; a < n; ++a)
|
|
1762
|
+
i[t++] = o[a];
|
|
1763
|
+
}
|
|
1764
|
+
return t;
|
|
1765
|
+
}
|
|
1766
|
+
function ui(i, t, e, n, s) {
|
|
1767
|
+
s = s || [];
|
|
1768
|
+
let r = 0;
|
|
1769
|
+
for (let o = 0, a = e.length; o < a; ++o) {
|
|
1770
|
+
const l = Pe(
|
|
1771
|
+
i,
|
|
1772
|
+
t,
|
|
1773
|
+
e[o],
|
|
1774
|
+
n
|
|
1775
|
+
);
|
|
1776
|
+
s[r++] = l, t = l;
|
|
1777
|
+
}
|
|
1778
|
+
return s.length = r, s;
|
|
1779
|
+
}
|
|
1780
|
+
function Fe(i, t, e, n, s) {
|
|
1781
|
+
s = s !== void 0 ? s : [];
|
|
1782
|
+
let r = 0;
|
|
1783
|
+
for (let o = t; o < e; o += n)
|
|
1784
|
+
s[r++] = i.slice(o, o + n);
|
|
1785
|
+
return s.length = r, s;
|
|
1786
|
+
}
|
|
1787
|
+
function hi(i, t, e, n, s) {
|
|
1788
|
+
s = s !== void 0 ? s : [];
|
|
1789
|
+
let r = 0;
|
|
1790
|
+
for (let o = 0, a = e.length; o < a; ++o) {
|
|
1791
|
+
const l = e[o];
|
|
1792
|
+
s[r++] = Fe(
|
|
1793
|
+
i,
|
|
1794
|
+
t,
|
|
1795
|
+
l,
|
|
1796
|
+
n,
|
|
1797
|
+
s[r]
|
|
1798
|
+
), t = l;
|
|
1799
|
+
}
|
|
1800
|
+
return s.length = r, s;
|
|
1801
|
+
}
|
|
1802
|
+
function ci(i, t, e, n, s, r, o) {
|
|
1803
|
+
const a = (e - t) / n;
|
|
1804
|
+
if (a < 3) {
|
|
1805
|
+
for (; t < e; t += n)
|
|
1806
|
+
r[o++] = i[t], r[o++] = i[t + 1];
|
|
1807
|
+
return o;
|
|
1808
|
+
}
|
|
1809
|
+
const l = new Array(a);
|
|
1810
|
+
l[0] = 1, l[a - 1] = 1;
|
|
1811
|
+
const h = [t, e - n];
|
|
1812
|
+
let u = 0;
|
|
1813
|
+
for (; h.length > 0; ) {
|
|
1814
|
+
const c = h.pop(), f = h.pop();
|
|
1815
|
+
let g = 0;
|
|
1816
|
+
const d = i[f], m = i[f + 1], _ = i[c], x = i[c + 1];
|
|
1817
|
+
for (let R = f + n; R < c; R += n) {
|
|
1818
|
+
const w = i[R], C = i[R + 1], F = dn(w, C, d, m, _, x);
|
|
1819
|
+
F > g && (u = R, g = F);
|
|
1820
|
+
}
|
|
1821
|
+
g > s && (l[(u - t) / n] = 1, f + n < u && h.push(f, u), u + n < c && h.push(u, c));
|
|
1822
|
+
}
|
|
1823
|
+
for (let c = 0; c < a; ++c)
|
|
1824
|
+
l[c] && (r[o++] = i[t + c * n], r[o++] = i[t + c * n + 1]);
|
|
1825
|
+
return o;
|
|
1826
|
+
}
|
|
1827
|
+
function G(i, t) {
|
|
1828
|
+
return t * Math.round(i / t);
|
|
1829
|
+
}
|
|
1830
|
+
function fi(i, t, e, n, s, r, o) {
|
|
1831
|
+
if (t == e)
|
|
1832
|
+
return o;
|
|
1833
|
+
let a = G(i[t], s), l = G(i[t + 1], s);
|
|
1834
|
+
t += n, r[o++] = a, r[o++] = l;
|
|
1835
|
+
let h, u;
|
|
1836
|
+
do
|
|
1837
|
+
if (h = G(i[t], s), u = G(i[t + 1], s), t += n, t == e)
|
|
1838
|
+
return r[o++] = h, r[o++] = u, o;
|
|
1839
|
+
while (h == a && u == l);
|
|
1840
|
+
for (; t < e; ) {
|
|
1841
|
+
const c = G(i[t], s), f = G(i[t + 1], s);
|
|
1842
|
+
if (t += n, c == h && f == u)
|
|
1843
|
+
continue;
|
|
1844
|
+
const g = h - a, d = u - l, m = c - a, _ = f - l;
|
|
1845
|
+
if (g * _ == d * m && (g < 0 && m < g || g == m || g > 0 && m > g) && (d < 0 && _ < d || d == _ || d > 0 && _ > d)) {
|
|
1846
|
+
h = c, u = f;
|
|
1847
|
+
continue;
|
|
1848
|
+
}
|
|
1849
|
+
r[o++] = h, r[o++] = u, a = h, l = u, h = c, u = f;
|
|
1850
|
+
}
|
|
1851
|
+
return r[o++] = h, r[o++] = u, o;
|
|
1852
|
+
}
|
|
1853
|
+
function gi(i, t, e, n, s, r, o, a) {
|
|
1854
|
+
for (let l = 0, h = e.length; l < h; ++l) {
|
|
1855
|
+
const u = e[l];
|
|
1856
|
+
o = fi(
|
|
1857
|
+
i,
|
|
1858
|
+
t,
|
|
1859
|
+
u,
|
|
1860
|
+
n,
|
|
1861
|
+
s,
|
|
1862
|
+
r,
|
|
1863
|
+
o
|
|
1864
|
+
), a.push(o), t = u;
|
|
1865
|
+
}
|
|
1866
|
+
return o;
|
|
1867
|
+
}
|
|
1868
|
+
class q extends Pt {
|
|
1869
|
+
/**
|
|
1870
|
+
* @param {Array<import("../coordinate.js").Coordinate>|Array<number>} coordinates Coordinates.
|
|
1871
|
+
* For internal use, flat coordinates in combination with `layout` are also accepted.
|
|
1872
|
+
* @param {import("./Geometry.js").GeometryLayout} [layout] Layout.
|
|
1873
|
+
*/
|
|
1874
|
+
constructor(t, e) {
|
|
1875
|
+
super(), this.maxDelta_ = -1, this.maxDeltaRevision_ = -1, e !== void 0 && !Array.isArray(t[0]) ? this.setFlatCoordinates(
|
|
1876
|
+
e,
|
|
1877
|
+
/** @type {Array<number>} */
|
|
1878
|
+
t
|
|
1879
|
+
) : this.setCoordinates(
|
|
1880
|
+
/** @type {Array<import("../coordinate.js").Coordinate>} */
|
|
1881
|
+
t,
|
|
1882
|
+
e
|
|
1883
|
+
);
|
|
1884
|
+
}
|
|
1885
|
+
/**
|
|
1886
|
+
* Make a complete copy of the geometry.
|
|
1887
|
+
* @return {!LinearRing} Clone.
|
|
1888
|
+
* @api
|
|
1889
|
+
* @override
|
|
1890
|
+
*/
|
|
1891
|
+
clone() {
|
|
1892
|
+
return new q(this.flatCoordinates.slice(), this.layout);
|
|
1893
|
+
}
|
|
1894
|
+
/**
|
|
1895
|
+
* @param {number} x X.
|
|
1896
|
+
* @param {number} y Y.
|
|
1897
|
+
* @param {import("../coordinate.js").Coordinate} closestPoint Closest point.
|
|
1898
|
+
* @param {number} minSquaredDistance Minimum squared distance.
|
|
1899
|
+
* @return {number} Minimum squared distance.
|
|
1900
|
+
* @override
|
|
1901
|
+
*/
|
|
1902
|
+
closestPointXY(t, e, n, s) {
|
|
1903
|
+
return s < ge(this.getExtent(), t, e) ? s : (this.maxDeltaRevision_ != this.getRevision() && (this.maxDelta_ = Math.sqrt(
|
|
1904
|
+
Ae(
|
|
1905
|
+
this.flatCoordinates,
|
|
1906
|
+
0,
|
|
1907
|
+
this.flatCoordinates.length,
|
|
1908
|
+
this.stride,
|
|
1909
|
+
0
|
|
1910
|
+
)
|
|
1911
|
+
), this.maxDeltaRevision_ = this.getRevision()), ve(
|
|
1912
|
+
this.flatCoordinates,
|
|
1913
|
+
0,
|
|
1914
|
+
this.flatCoordinates.length,
|
|
1915
|
+
this.stride,
|
|
1916
|
+
this.maxDelta_,
|
|
1917
|
+
!0,
|
|
1918
|
+
t,
|
|
1919
|
+
e,
|
|
1920
|
+
n,
|
|
1921
|
+
s
|
|
1922
|
+
));
|
|
1923
|
+
}
|
|
1924
|
+
/**
|
|
1925
|
+
* Return the area of the linear ring on projected plane.
|
|
1926
|
+
* @return {number} Area (on projected plane).
|
|
1927
|
+
* @api
|
|
1928
|
+
*/
|
|
1929
|
+
getArea() {
|
|
1930
|
+
return Se(
|
|
1931
|
+
this.flatCoordinates,
|
|
1932
|
+
0,
|
|
1933
|
+
this.flatCoordinates.length,
|
|
1934
|
+
this.stride
|
|
1935
|
+
);
|
|
1936
|
+
}
|
|
1937
|
+
/**
|
|
1938
|
+
* Return the coordinates of the linear ring.
|
|
1939
|
+
* @return {Array<import("../coordinate.js").Coordinate>} Coordinates.
|
|
1940
|
+
* @api
|
|
1941
|
+
* @override
|
|
1942
|
+
*/
|
|
1943
|
+
getCoordinates() {
|
|
1944
|
+
return Fe(
|
|
1945
|
+
this.flatCoordinates,
|
|
1946
|
+
0,
|
|
1947
|
+
this.flatCoordinates.length,
|
|
1948
|
+
this.stride
|
|
1949
|
+
);
|
|
1950
|
+
}
|
|
1951
|
+
/**
|
|
1952
|
+
* @param {number} squaredTolerance Squared tolerance.
|
|
1953
|
+
* @return {LinearRing} Simplified LinearRing.
|
|
1954
|
+
* @protected
|
|
1955
|
+
* @override
|
|
1956
|
+
*/
|
|
1957
|
+
getSimplifiedGeometryInternal(t) {
|
|
1958
|
+
const e = [];
|
|
1959
|
+
return e.length = ci(
|
|
1960
|
+
this.flatCoordinates,
|
|
1961
|
+
0,
|
|
1962
|
+
this.flatCoordinates.length,
|
|
1963
|
+
this.stride,
|
|
1964
|
+
t,
|
|
1965
|
+
e,
|
|
1966
|
+
0
|
|
1967
|
+
), new q(e, "XY");
|
|
1968
|
+
}
|
|
1969
|
+
/**
|
|
1970
|
+
* Get the type of this geometry.
|
|
1971
|
+
* @return {import("./Geometry.js").Type} Geometry type.
|
|
1972
|
+
* @api
|
|
1973
|
+
* @override
|
|
1974
|
+
*/
|
|
1975
|
+
getType() {
|
|
1976
|
+
return "LinearRing";
|
|
1977
|
+
}
|
|
1978
|
+
/**
|
|
1979
|
+
* Test if the geometry and the passed extent intersect.
|
|
1980
|
+
* @param {import("../extent.js").Extent} extent Extent.
|
|
1981
|
+
* @return {boolean} `true` if the geometry and the extent intersect.
|
|
1982
|
+
* @api
|
|
1983
|
+
* @override
|
|
1984
|
+
*/
|
|
1985
|
+
intersectsExtent(t) {
|
|
1986
|
+
return !1;
|
|
1987
|
+
}
|
|
1988
|
+
/**
|
|
1989
|
+
* Set the coordinates of the linear ring.
|
|
1990
|
+
* @param {!Array<import("../coordinate.js").Coordinate>} coordinates Coordinates.
|
|
1991
|
+
* @param {import("./Geometry.js").GeometryLayout} [layout] Layout.
|
|
1992
|
+
* @api
|
|
1993
|
+
* @override
|
|
1994
|
+
*/
|
|
1995
|
+
setCoordinates(t, e) {
|
|
1996
|
+
this.setLayout(e, t, 1), this.flatCoordinates || (this.flatCoordinates = []), this.flatCoordinates.length = Pe(
|
|
1997
|
+
this.flatCoordinates,
|
|
1998
|
+
0,
|
|
1999
|
+
t,
|
|
2000
|
+
this.stride
|
|
2001
|
+
), this.changed();
|
|
2002
|
+
}
|
|
2003
|
+
}
|
|
2004
|
+
class Ft extends Pt {
|
|
2005
|
+
/**
|
|
2006
|
+
* @param {import("../coordinate.js").Coordinate} coordinates Coordinates.
|
|
2007
|
+
* @param {import("./Geometry.js").GeometryLayout} [layout] Layout.
|
|
2008
|
+
*/
|
|
2009
|
+
constructor(t, e) {
|
|
2010
|
+
super(), this.setCoordinates(t, e);
|
|
2011
|
+
}
|
|
2012
|
+
/**
|
|
2013
|
+
* Make a complete copy of the geometry.
|
|
2014
|
+
* @return {!Point} Clone.
|
|
2015
|
+
* @api
|
|
2016
|
+
* @override
|
|
2017
|
+
*/
|
|
2018
|
+
clone() {
|
|
2019
|
+
const t = new Ft(this.flatCoordinates.slice(), this.layout);
|
|
2020
|
+
return t.applyProperties(this), t;
|
|
2021
|
+
}
|
|
2022
|
+
/**
|
|
2023
|
+
* @param {number} x X.
|
|
2024
|
+
* @param {number} y Y.
|
|
2025
|
+
* @param {import("../coordinate.js").Coordinate} closestPoint Closest point.
|
|
2026
|
+
* @param {number} minSquaredDistance Minimum squared distance.
|
|
2027
|
+
* @return {number} Minimum squared distance.
|
|
2028
|
+
* @override
|
|
2029
|
+
*/
|
|
2030
|
+
closestPointXY(t, e, n, s) {
|
|
2031
|
+
const r = this.flatCoordinates, o = U(
|
|
2032
|
+
t,
|
|
2033
|
+
e,
|
|
2034
|
+
r[0],
|
|
2035
|
+
r[1]
|
|
2036
|
+
);
|
|
2037
|
+
if (o < s) {
|
|
2038
|
+
const a = this.stride;
|
|
2039
|
+
for (let l = 0; l < a; ++l)
|
|
2040
|
+
n[l] = r[l];
|
|
2041
|
+
return n.length = a, o;
|
|
2042
|
+
}
|
|
2043
|
+
return s;
|
|
2044
|
+
}
|
|
2045
|
+
/**
|
|
2046
|
+
* Return the coordinate of the point.
|
|
2047
|
+
* @return {import("../coordinate.js").Coordinate} Coordinates.
|
|
2048
|
+
* @api
|
|
2049
|
+
* @override
|
|
2050
|
+
*/
|
|
2051
|
+
getCoordinates() {
|
|
2052
|
+
return this.flatCoordinates.slice();
|
|
2053
|
+
}
|
|
2054
|
+
/**
|
|
2055
|
+
* @param {import("../extent.js").Extent} extent Extent.
|
|
2056
|
+
* @protected
|
|
2057
|
+
* @return {import("../extent.js").Extent} extent Extent.
|
|
2058
|
+
* @override
|
|
2059
|
+
*/
|
|
2060
|
+
computeExtent(t) {
|
|
2061
|
+
return en(this.flatCoordinates, t);
|
|
2062
|
+
}
|
|
2063
|
+
/**
|
|
2064
|
+
* Get the type of this geometry.
|
|
2065
|
+
* @return {import("./Geometry.js").Type} Geometry type.
|
|
2066
|
+
* @api
|
|
2067
|
+
* @override
|
|
2068
|
+
*/
|
|
2069
|
+
getType() {
|
|
2070
|
+
return "Point";
|
|
2071
|
+
}
|
|
2072
|
+
/**
|
|
2073
|
+
* Test if the geometry and the passed extent intersect.
|
|
2074
|
+
* @param {import("../extent.js").Extent} extent Extent.
|
|
2075
|
+
* @return {boolean} `true` if the geometry and the extent intersect.
|
|
2076
|
+
* @api
|
|
2077
|
+
* @override
|
|
2078
|
+
*/
|
|
2079
|
+
intersectsExtent(t) {
|
|
2080
|
+
return tn(t, this.flatCoordinates[0], this.flatCoordinates[1]);
|
|
2081
|
+
}
|
|
2082
|
+
/**
|
|
2083
|
+
* @param {!Array<*>} coordinates Coordinates.
|
|
2084
|
+
* @param {import("./Geometry.js").GeometryLayout} [layout] Layout.
|
|
2085
|
+
* @api
|
|
2086
|
+
* @override
|
|
2087
|
+
*/
|
|
2088
|
+
setCoordinates(t, e) {
|
|
2089
|
+
this.setLayout(e, t, 0), this.flatCoordinates || (this.flatCoordinates = []), this.flatCoordinates.length = li(
|
|
2090
|
+
this.flatCoordinates,
|
|
2091
|
+
0,
|
|
2092
|
+
t,
|
|
2093
|
+
this.stride
|
|
2094
|
+
), this.changed();
|
|
2095
|
+
}
|
|
2096
|
+
}
|
|
2097
|
+
function di(i, t, e, n, s) {
|
|
2098
|
+
return !rn(
|
|
2099
|
+
s,
|
|
2100
|
+
/**
|
|
2101
|
+
* @param {import("../../coordinate.js").Coordinate} coordinate Coordinate.
|
|
2102
|
+
* @return {boolean} Contains (x, y).
|
|
2103
|
+
*/
|
|
2104
|
+
function(o) {
|
|
2105
|
+
return !Y(
|
|
2106
|
+
i,
|
|
2107
|
+
t,
|
|
2108
|
+
e,
|
|
2109
|
+
n,
|
|
2110
|
+
o[0],
|
|
2111
|
+
o[1]
|
|
2112
|
+
);
|
|
2113
|
+
}
|
|
2114
|
+
);
|
|
2115
|
+
}
|
|
2116
|
+
function Y(i, t, e, n, s, r) {
|
|
2117
|
+
let o = 0, a = i[e - n], l = i[e - n + 1];
|
|
2118
|
+
for (; t < e; t += n) {
|
|
2119
|
+
const h = i[t], u = i[t + 1];
|
|
2120
|
+
l <= r ? u > r && (h - a) * (r - l) - (s - a) * (u - l) > 0 && o++ : u <= r && (h - a) * (r - l) - (s - a) * (u - l) < 0 && o--, a = h, l = u;
|
|
2121
|
+
}
|
|
2122
|
+
return o !== 0;
|
|
2123
|
+
}
|
|
2124
|
+
function Xe(i, t, e, n, s, r) {
|
|
2125
|
+
if (e.length === 0 || !Y(i, t, e[0], n, s, r))
|
|
2126
|
+
return !1;
|
|
2127
|
+
for (let o = 1, a = e.length; o < a; ++o)
|
|
2128
|
+
if (Y(i, e[o - 1], e[o], n, s, r))
|
|
2129
|
+
return !1;
|
|
2130
|
+
return !0;
|
|
2131
|
+
}
|
|
2132
|
+
function mi(i, t, e, n, s, r, o) {
|
|
2133
|
+
let a, l, h, u, c, f, g;
|
|
2134
|
+
const d = s[r + 1], m = [];
|
|
2135
|
+
for (let R = 0, w = e.length; R < w; ++R) {
|
|
2136
|
+
const C = e[R];
|
|
2137
|
+
for (u = i[C - n], f = i[C - n + 1], a = t; a < C; a += n)
|
|
2138
|
+
c = i[a], g = i[a + 1], (d <= f && g <= d || f <= d && d <= g) && (h = (d - f) / (g - f) * (c - u) + u, m.push(h)), u = c, f = g;
|
|
2139
|
+
}
|
|
2140
|
+
let _ = NaN, x = -1 / 0;
|
|
2141
|
+
for (m.sort(ue), u = m[0], a = 1, l = m.length; a < l; ++a) {
|
|
2142
|
+
c = m[a];
|
|
2143
|
+
const R = Math.abs(c - u);
|
|
2144
|
+
R > x && (h = (u + c) / 2, Xe(i, t, e, n, h, d) && (_ = h, x = R)), u = c;
|
|
2145
|
+
}
|
|
2146
|
+
return isNaN(_) && (_ = s[r]), [_, d, x];
|
|
2147
|
+
}
|
|
2148
|
+
function _i(i, t, e, n, s) {
|
|
2149
|
+
let r;
|
|
2150
|
+
for (t += n; t < e; t += n)
|
|
2151
|
+
if (r = s(
|
|
2152
|
+
i.slice(t - n, t),
|
|
2153
|
+
i.slice(t, t + n)
|
|
2154
|
+
), r)
|
|
2155
|
+
return r;
|
|
2156
|
+
return !1;
|
|
2157
|
+
}
|
|
2158
|
+
function Ne(i, t, e, n, s, r) {
|
|
2159
|
+
return r = r ?? _e(de(), i, t, e, n), cn(s, r) ? r[0] >= s[0] && r[2] <= s[2] || r[1] >= s[1] && r[3] <= s[3] ? !0 : _i(
|
|
2160
|
+
i,
|
|
2161
|
+
t,
|
|
2162
|
+
e,
|
|
2163
|
+
n,
|
|
2164
|
+
/**
|
|
2165
|
+
* @param {import("../../coordinate.js").Coordinate} point1 Start point.
|
|
2166
|
+
* @param {import("../../coordinate.js").Coordinate} point2 End point.
|
|
2167
|
+
* @return {boolean} `true` if the segment and the extent intersect,
|
|
2168
|
+
* `false` otherwise.
|
|
2169
|
+
*/
|
|
2170
|
+
function(o, a) {
|
|
2171
|
+
return gn(s, o, a);
|
|
2172
|
+
}
|
|
2173
|
+
) : !1;
|
|
2174
|
+
}
|
|
2175
|
+
function Ye(i, t, e, n, s) {
|
|
2176
|
+
return !!(Ne(i, t, e, n, s) || Y(
|
|
2177
|
+
i,
|
|
2178
|
+
t,
|
|
2179
|
+
e,
|
|
2180
|
+
n,
|
|
2181
|
+
s[0],
|
|
2182
|
+
s[1]
|
|
2183
|
+
) || Y(
|
|
2184
|
+
i,
|
|
2185
|
+
t,
|
|
2186
|
+
e,
|
|
2187
|
+
n,
|
|
2188
|
+
s[0],
|
|
2189
|
+
s[3]
|
|
2190
|
+
) || Y(
|
|
2191
|
+
i,
|
|
2192
|
+
t,
|
|
2193
|
+
e,
|
|
2194
|
+
n,
|
|
2195
|
+
s[2],
|
|
2196
|
+
s[1]
|
|
2197
|
+
) || Y(
|
|
2198
|
+
i,
|
|
2199
|
+
t,
|
|
2200
|
+
e,
|
|
2201
|
+
n,
|
|
2202
|
+
s[2],
|
|
2203
|
+
s[3]
|
|
2204
|
+
));
|
|
2205
|
+
}
|
|
2206
|
+
function Ri(i, t, e, n, s) {
|
|
2207
|
+
if (!Ye(i, t, e[0], n, s))
|
|
2208
|
+
return !1;
|
|
2209
|
+
if (e.length === 1)
|
|
2210
|
+
return !0;
|
|
2211
|
+
for (let r = 1, o = e.length; r < o; ++r)
|
|
2212
|
+
if (di(
|
|
2213
|
+
i,
|
|
2214
|
+
e[r - 1],
|
|
2215
|
+
e[r],
|
|
2216
|
+
n,
|
|
2217
|
+
s
|
|
2218
|
+
) && !Ne(
|
|
2219
|
+
i,
|
|
2220
|
+
e[r - 1],
|
|
2221
|
+
e[r],
|
|
2222
|
+
n,
|
|
2223
|
+
s
|
|
2224
|
+
))
|
|
2225
|
+
return !1;
|
|
2226
|
+
return !0;
|
|
2227
|
+
}
|
|
2228
|
+
function xi(i, t, e, n) {
|
|
2229
|
+
for (; t < e - n; ) {
|
|
2230
|
+
for (let s = 0; s < n; ++s) {
|
|
2231
|
+
const r = i[t + s];
|
|
2232
|
+
i[t + s] = i[e - n + s], i[e - n + s] = r;
|
|
2233
|
+
}
|
|
2234
|
+
t += n, e -= n;
|
|
2235
|
+
}
|
|
2236
|
+
}
|
|
2237
|
+
function Ze(i, t, e, n) {
|
|
2238
|
+
let s = 0, r = i[e - n], o = i[e - n + 1];
|
|
2239
|
+
for (; t < e; t += n) {
|
|
2240
|
+
const a = i[t], l = i[t + 1];
|
|
2241
|
+
s += (a - r) * (l + o), r = a, o = l;
|
|
2242
|
+
}
|
|
2243
|
+
return s === 0 ? void 0 : s > 0;
|
|
2244
|
+
}
|
|
2245
|
+
function Mi(i, t, e, n, s) {
|
|
2246
|
+
s = s !== void 0 ? s : !1;
|
|
2247
|
+
for (let r = 0, o = e.length; r < o; ++r) {
|
|
2248
|
+
const a = e[r], l = Ze(
|
|
2249
|
+
i,
|
|
2250
|
+
t,
|
|
2251
|
+
a,
|
|
2252
|
+
n
|
|
2253
|
+
);
|
|
2254
|
+
if (r === 0) {
|
|
2255
|
+
if (s && l || !s && !l)
|
|
2256
|
+
return !1;
|
|
2257
|
+
} else if (s && !l || !s && l)
|
|
2258
|
+
return !1;
|
|
2259
|
+
t = a;
|
|
2260
|
+
}
|
|
2261
|
+
return !0;
|
|
2262
|
+
}
|
|
2263
|
+
function ie(i, t, e, n, s) {
|
|
2264
|
+
s = s !== void 0 ? s : !1;
|
|
2265
|
+
for (let r = 0, o = e.length; r < o; ++r) {
|
|
2266
|
+
const a = e[r], l = Ze(
|
|
2267
|
+
i,
|
|
2268
|
+
t,
|
|
2269
|
+
a,
|
|
2270
|
+
n
|
|
2271
|
+
);
|
|
2272
|
+
(r === 0 ? s && l || !s && !l : s && !l || !s && l) && xi(i, t, a, n), t = a;
|
|
2273
|
+
}
|
|
2274
|
+
return t;
|
|
2275
|
+
}
|
|
2276
|
+
class ht extends Pt {
|
|
2277
|
+
/**
|
|
2278
|
+
* @param {!Array<Array<import("../coordinate.js").Coordinate>>|!Array<number>} coordinates
|
|
2279
|
+
* Array of linear rings that define the polygon. The first linear ring of the
|
|
2280
|
+
* array defines the outer-boundary or surface of the polygon. Each subsequent
|
|
2281
|
+
* linear ring defines a hole in the surface of the polygon. A linear ring is
|
|
2282
|
+
* an array of vertices' coordinates where the first coordinate and the last are
|
|
2283
|
+
* equivalent. (For internal use, flat coordinates in combination with
|
|
2284
|
+
* `layout` and `ends` are also accepted.)
|
|
2285
|
+
* @param {import("./Geometry.js").GeometryLayout} [layout] Layout.
|
|
2286
|
+
* @param {Array<number>} [ends] Ends (for internal use with flat coordinates).
|
|
2287
|
+
*/
|
|
2288
|
+
constructor(t, e, n) {
|
|
2289
|
+
super(), this.ends_ = [], this.flatInteriorPointRevision_ = -1, this.flatInteriorPoint_ = null, this.maxDelta_ = -1, this.maxDeltaRevision_ = -1, this.orientedRevision_ = -1, this.orientedFlatCoordinates_ = null, e !== void 0 && n ? (this.setFlatCoordinates(
|
|
2290
|
+
e,
|
|
2291
|
+
/** @type {Array<number>} */
|
|
2292
|
+
t
|
|
2293
|
+
), this.ends_ = n) : this.setCoordinates(
|
|
2294
|
+
/** @type {Array<Array<import("../coordinate.js").Coordinate>>} */
|
|
2295
|
+
t,
|
|
2296
|
+
e
|
|
2297
|
+
);
|
|
2298
|
+
}
|
|
2299
|
+
/**
|
|
2300
|
+
* Append the passed linear ring to this polygon.
|
|
2301
|
+
* @param {LinearRing} linearRing Linear ring.
|
|
2302
|
+
* @api
|
|
2303
|
+
*/
|
|
2304
|
+
appendLinearRing(t) {
|
|
2305
|
+
this.flatCoordinates ? De(this.flatCoordinates, t.getFlatCoordinates()) : this.flatCoordinates = t.getFlatCoordinates().slice(), this.ends_.push(this.flatCoordinates.length), this.changed();
|
|
2306
|
+
}
|
|
2307
|
+
/**
|
|
2308
|
+
* Make a complete copy of the geometry.
|
|
2309
|
+
* @return {!Polygon} Clone.
|
|
2310
|
+
* @api
|
|
2311
|
+
* @override
|
|
2312
|
+
*/
|
|
2313
|
+
clone() {
|
|
2314
|
+
const t = new ht(
|
|
2315
|
+
this.flatCoordinates.slice(),
|
|
2316
|
+
this.layout,
|
|
2317
|
+
this.ends_.slice()
|
|
2318
|
+
);
|
|
2319
|
+
return t.applyProperties(this), t;
|
|
2320
|
+
}
|
|
2321
|
+
/**
|
|
2322
|
+
* @param {number} x X.
|
|
2323
|
+
* @param {number} y Y.
|
|
2324
|
+
* @param {import("../coordinate.js").Coordinate} closestPoint Closest point.
|
|
2325
|
+
* @param {number} minSquaredDistance Minimum squared distance.
|
|
2326
|
+
* @return {number} Minimum squared distance.
|
|
2327
|
+
* @override
|
|
2328
|
+
*/
|
|
2329
|
+
closestPointXY(t, e, n, s) {
|
|
2330
|
+
return s < ge(this.getExtent(), t, e) ? s : (this.maxDeltaRevision_ != this.getRevision() && (this.maxDelta_ = Math.sqrt(
|
|
2331
|
+
oi(
|
|
2332
|
+
this.flatCoordinates,
|
|
2333
|
+
0,
|
|
2334
|
+
this.ends_,
|
|
2335
|
+
this.stride,
|
|
2336
|
+
0
|
|
2337
|
+
)
|
|
2338
|
+
), this.maxDeltaRevision_ = this.getRevision()), ai(
|
|
2339
|
+
this.flatCoordinates,
|
|
2340
|
+
0,
|
|
2341
|
+
this.ends_,
|
|
2342
|
+
this.stride,
|
|
2343
|
+
this.maxDelta_,
|
|
2344
|
+
!0,
|
|
2345
|
+
t,
|
|
2346
|
+
e,
|
|
2347
|
+
n,
|
|
2348
|
+
s
|
|
2349
|
+
));
|
|
2350
|
+
}
|
|
2351
|
+
/**
|
|
2352
|
+
* @param {number} x X.
|
|
2353
|
+
* @param {number} y Y.
|
|
2354
|
+
* @return {boolean} Contains (x, y).
|
|
2355
|
+
* @override
|
|
2356
|
+
*/
|
|
2357
|
+
containsXY(t, e) {
|
|
2358
|
+
return Xe(
|
|
2359
|
+
this.getOrientedFlatCoordinates(),
|
|
2360
|
+
0,
|
|
2361
|
+
this.ends_,
|
|
2362
|
+
this.stride,
|
|
2363
|
+
t,
|
|
2364
|
+
e
|
|
2365
|
+
);
|
|
2366
|
+
}
|
|
2367
|
+
/**
|
|
2368
|
+
* Return the area of the polygon on projected plane.
|
|
2369
|
+
* @return {number} Area (on projected plane).
|
|
2370
|
+
* @api
|
|
2371
|
+
*/
|
|
2372
|
+
getArea() {
|
|
2373
|
+
return ri(
|
|
2374
|
+
this.getOrientedFlatCoordinates(),
|
|
2375
|
+
0,
|
|
2376
|
+
this.ends_,
|
|
2377
|
+
this.stride
|
|
2378
|
+
);
|
|
2379
|
+
}
|
|
2380
|
+
/**
|
|
2381
|
+
* Get the coordinate array for this geometry. This array has the structure
|
|
2382
|
+
* of a GeoJSON coordinate array for polygons.
|
|
2383
|
+
*
|
|
2384
|
+
* @param {boolean} [right] Orient coordinates according to the right-hand
|
|
2385
|
+
* rule (counter-clockwise for exterior and clockwise for interior rings).
|
|
2386
|
+
* If `false`, coordinates will be oriented according to the left-hand rule
|
|
2387
|
+
* (clockwise for exterior and counter-clockwise for interior rings).
|
|
2388
|
+
* By default, coordinate orientation will depend on how the geometry was
|
|
2389
|
+
* constructed.
|
|
2390
|
+
* @return {Array<Array<import("../coordinate.js").Coordinate>>} Coordinates.
|
|
2391
|
+
* @api
|
|
2392
|
+
* @override
|
|
2393
|
+
*/
|
|
2394
|
+
getCoordinates(t) {
|
|
2395
|
+
let e;
|
|
2396
|
+
return t !== void 0 ? (e = this.getOrientedFlatCoordinates().slice(), ie(e, 0, this.ends_, this.stride, t)) : e = this.flatCoordinates, hi(e, 0, this.ends_, this.stride);
|
|
2397
|
+
}
|
|
2398
|
+
/**
|
|
2399
|
+
* @return {Array<number>} Ends.
|
|
2400
|
+
*/
|
|
2401
|
+
getEnds() {
|
|
2402
|
+
return this.ends_;
|
|
2403
|
+
}
|
|
2404
|
+
/**
|
|
2405
|
+
* @return {Array<number>} Interior point.
|
|
2406
|
+
*/
|
|
2407
|
+
getFlatInteriorPoint() {
|
|
2408
|
+
if (this.flatInteriorPointRevision_ != this.getRevision()) {
|
|
2409
|
+
const t = rt(this.getExtent());
|
|
2410
|
+
this.flatInteriorPoint_ = mi(
|
|
2411
|
+
this.getOrientedFlatCoordinates(),
|
|
2412
|
+
0,
|
|
2413
|
+
this.ends_,
|
|
2414
|
+
this.stride,
|
|
2415
|
+
t,
|
|
2416
|
+
0
|
|
2417
|
+
), this.flatInteriorPointRevision_ = this.getRevision();
|
|
2418
|
+
}
|
|
2419
|
+
return (
|
|
2420
|
+
/** @type {import("../coordinate.js").Coordinate} */
|
|
2421
|
+
this.flatInteriorPoint_
|
|
2422
|
+
);
|
|
2423
|
+
}
|
|
2424
|
+
/**
|
|
2425
|
+
* Return an interior point of the polygon.
|
|
2426
|
+
* @return {Point} Interior point as XYM coordinate, where M is the
|
|
2427
|
+
* length of the horizontal intersection that the point belongs to.
|
|
2428
|
+
* @api
|
|
2429
|
+
*/
|
|
2430
|
+
getInteriorPoint() {
|
|
2431
|
+
return new Ft(this.getFlatInteriorPoint(), "XYM");
|
|
2432
|
+
}
|
|
2433
|
+
/**
|
|
2434
|
+
* Return the number of rings of the polygon, this includes the exterior
|
|
2435
|
+
* ring and any interior rings.
|
|
2436
|
+
*
|
|
2437
|
+
* @return {number} Number of rings.
|
|
2438
|
+
* @api
|
|
2439
|
+
*/
|
|
2440
|
+
getLinearRingCount() {
|
|
2441
|
+
return this.ends_.length;
|
|
2442
|
+
}
|
|
2443
|
+
/**
|
|
2444
|
+
* Return the Nth linear ring of the polygon geometry. Return `null` if the
|
|
2445
|
+
* given index is out of range.
|
|
2446
|
+
* The exterior linear ring is available at index `0` and the interior rings
|
|
2447
|
+
* at index `1` and beyond.
|
|
2448
|
+
*
|
|
2449
|
+
* @param {number} index Index.
|
|
2450
|
+
* @return {LinearRing|null} Linear ring.
|
|
2451
|
+
* @api
|
|
2452
|
+
*/
|
|
2453
|
+
getLinearRing(t) {
|
|
2454
|
+
return t < 0 || this.ends_.length <= t ? null : new q(
|
|
2455
|
+
this.flatCoordinates.slice(
|
|
2456
|
+
t === 0 ? 0 : this.ends_[t - 1],
|
|
2457
|
+
this.ends_[t]
|
|
2458
|
+
),
|
|
2459
|
+
this.layout
|
|
2460
|
+
);
|
|
2461
|
+
}
|
|
2462
|
+
/**
|
|
2463
|
+
* Return the linear rings of the polygon.
|
|
2464
|
+
* @return {Array<LinearRing>} Linear rings.
|
|
2465
|
+
* @api
|
|
2466
|
+
*/
|
|
2467
|
+
getLinearRings() {
|
|
2468
|
+
const t = this.layout, e = this.flatCoordinates, n = this.ends_, s = [];
|
|
2469
|
+
let r = 0;
|
|
2470
|
+
for (let o = 0, a = n.length; o < a; ++o) {
|
|
2471
|
+
const l = n[o], h = new q(
|
|
2472
|
+
e.slice(r, l),
|
|
2473
|
+
t
|
|
2474
|
+
);
|
|
2475
|
+
s.push(h), r = l;
|
|
2476
|
+
}
|
|
2477
|
+
return s;
|
|
2478
|
+
}
|
|
2479
|
+
/**
|
|
2480
|
+
* @return {Array<number>} Oriented flat coordinates.
|
|
2481
|
+
*/
|
|
2482
|
+
getOrientedFlatCoordinates() {
|
|
2483
|
+
if (this.orientedRevision_ != this.getRevision()) {
|
|
2484
|
+
const t = this.flatCoordinates;
|
|
2485
|
+
Mi(t, 0, this.ends_, this.stride) ? this.orientedFlatCoordinates_ = t : (this.orientedFlatCoordinates_ = t.slice(), this.orientedFlatCoordinates_.length = ie(
|
|
2486
|
+
this.orientedFlatCoordinates_,
|
|
2487
|
+
0,
|
|
2488
|
+
this.ends_,
|
|
2489
|
+
this.stride
|
|
2490
|
+
)), this.orientedRevision_ = this.getRevision();
|
|
2491
|
+
}
|
|
2492
|
+
return (
|
|
2493
|
+
/** @type {Array<number>} */
|
|
2494
|
+
this.orientedFlatCoordinates_
|
|
2495
|
+
);
|
|
2496
|
+
}
|
|
2497
|
+
/**
|
|
2498
|
+
* @param {number} squaredTolerance Squared tolerance.
|
|
2499
|
+
* @return {Polygon} Simplified Polygon.
|
|
2500
|
+
* @protected
|
|
2501
|
+
* @override
|
|
2502
|
+
*/
|
|
2503
|
+
getSimplifiedGeometryInternal(t) {
|
|
2504
|
+
const e = [], n = [];
|
|
2505
|
+
return e.length = gi(
|
|
2506
|
+
this.flatCoordinates,
|
|
2507
|
+
0,
|
|
2508
|
+
this.ends_,
|
|
2509
|
+
this.stride,
|
|
2510
|
+
Math.sqrt(t),
|
|
2511
|
+
e,
|
|
2512
|
+
0,
|
|
2513
|
+
n
|
|
2514
|
+
), new ht(e, "XY", n);
|
|
2515
|
+
}
|
|
2516
|
+
/**
|
|
2517
|
+
* Get the type of this geometry.
|
|
2518
|
+
* @return {import("./Geometry.js").Type} Geometry type.
|
|
2519
|
+
* @api
|
|
2520
|
+
* @override
|
|
2521
|
+
*/
|
|
2522
|
+
getType() {
|
|
2523
|
+
return "Polygon";
|
|
2524
|
+
}
|
|
2525
|
+
/**
|
|
2526
|
+
* Test if the geometry and the passed extent intersect.
|
|
2527
|
+
* @param {import("../extent.js").Extent} extent Extent.
|
|
2528
|
+
* @return {boolean} `true` if the geometry and the extent intersect.
|
|
2529
|
+
* @api
|
|
2530
|
+
* @override
|
|
2531
|
+
*/
|
|
2532
|
+
intersectsExtent(t) {
|
|
2533
|
+
return Ri(
|
|
2534
|
+
this.getOrientedFlatCoordinates(),
|
|
2535
|
+
0,
|
|
2536
|
+
this.ends_,
|
|
2537
|
+
this.stride,
|
|
2538
|
+
t
|
|
2539
|
+
);
|
|
2540
|
+
}
|
|
2541
|
+
/**
|
|
2542
|
+
* Set the coordinates of the polygon.
|
|
2543
|
+
* @param {!Array<Array<import("../coordinate.js").Coordinate>>} coordinates Coordinates.
|
|
2544
|
+
* @param {import("./Geometry.js").GeometryLayout} [layout] Layout.
|
|
2545
|
+
* @api
|
|
2546
|
+
* @override
|
|
2547
|
+
*/
|
|
2548
|
+
setCoordinates(t, e) {
|
|
2549
|
+
this.setLayout(e, t, 2), this.flatCoordinates || (this.flatCoordinates = []);
|
|
2550
|
+
const n = ui(
|
|
2551
|
+
this.flatCoordinates,
|
|
2552
|
+
0,
|
|
2553
|
+
t,
|
|
2554
|
+
this.stride,
|
|
2555
|
+
this.ends_
|
|
2556
|
+
);
|
|
2557
|
+
this.flatCoordinates.length = n.length === 0 ? 0 : n[n.length - 1], this.changed();
|
|
2558
|
+
}
|
|
2559
|
+
}
|
|
2560
|
+
function se(i) {
|
|
2561
|
+
if (xe(i))
|
|
2562
|
+
throw new Error("Cannot create polygon from empty extent");
|
|
2563
|
+
const t = i[0], e = i[1], n = i[2], s = i[3], r = [
|
|
2564
|
+
t,
|
|
2565
|
+
e,
|
|
2566
|
+
t,
|
|
2567
|
+
s,
|
|
2568
|
+
n,
|
|
2569
|
+
s,
|
|
2570
|
+
n,
|
|
2571
|
+
e,
|
|
2572
|
+
t,
|
|
2573
|
+
e
|
|
2574
|
+
];
|
|
2575
|
+
return new ht(r, "XY", [r.length]);
|
|
2576
|
+
}
|
|
2577
|
+
function et(i, t) {
|
|
2578
|
+
return Array.isArray(i) ? i : (t === void 0 ? t = [i, i] : (t[0] = i, t[1] = i), t);
|
|
2579
|
+
}
|
|
2580
|
+
const A = {
|
|
2581
|
+
ANIMATING: 0,
|
|
2582
|
+
INTERACTING: 1
|
|
2583
|
+
}, I = {
|
|
2584
|
+
CENTER: "center",
|
|
2585
|
+
RESOLUTION: "resolution",
|
|
2586
|
+
ROTATION: "rotation"
|
|
2587
|
+
};
|
|
2588
|
+
function re(i, t, e) {
|
|
2589
|
+
return (
|
|
2590
|
+
/**
|
|
2591
|
+
* @param {import("./coordinate.js").Coordinate|undefined} center Center.
|
|
2592
|
+
* @param {number|undefined} resolution Resolution.
|
|
2593
|
+
* @param {import("./size.js").Size} size Viewport size; unused if `onlyCenter` was specified.
|
|
2594
|
+
* @param {boolean} [isMoving] True if an interaction or animation is in progress.
|
|
2595
|
+
* @param {Array<number>} [centerShift] Shift between map center and viewport center.
|
|
2596
|
+
* @return {import("./coordinate.js").Coordinate|undefined} Center.
|
|
2597
|
+
*/
|
|
2598
|
+
function(n, s, r, o, a) {
|
|
2599
|
+
if (!n)
|
|
2600
|
+
return;
|
|
2601
|
+
if (!s && !t)
|
|
2602
|
+
return n;
|
|
2603
|
+
const l = t ? 0 : r[0] * s, h = t ? 0 : r[1] * s, u = a ? a[0] : 0, c = a ? a[1] : 0;
|
|
2604
|
+
let f = i[0] + l / 2 + u, g = i[2] - l / 2 + u, d = i[1] + h / 2 + c, m = i[3] - h / 2 + c;
|
|
2605
|
+
f > g && (f = (g + f) / 2, g = f), d > m && (d = (m + d) / 2, m = d);
|
|
2606
|
+
let _ = T(n[0], f, g), x = T(n[1], d, m);
|
|
2607
|
+
if (o && e && s) {
|
|
2608
|
+
const R = 30 * s;
|
|
2609
|
+
_ += -R * Math.log(1 + Math.max(0, f - n[0]) / R) + R * Math.log(1 + Math.max(0, n[0] - g) / R), x += -R * Math.log(1 + Math.max(0, d - n[1]) / R) + R * Math.log(1 + Math.max(0, n[1] - m) / R);
|
|
2610
|
+
}
|
|
2611
|
+
return [_, x];
|
|
2612
|
+
}
|
|
2613
|
+
);
|
|
2614
|
+
}
|
|
2615
|
+
function Ci(i) {
|
|
2616
|
+
return i;
|
|
2617
|
+
}
|
|
2618
|
+
function Ei(i) {
|
|
2619
|
+
return Math.pow(i, 3);
|
|
2620
|
+
}
|
|
2621
|
+
function pi(i) {
|
|
2622
|
+
return 1 - Ei(1 - i);
|
|
2623
|
+
}
|
|
2624
|
+
function Ti(i) {
|
|
2625
|
+
return 3 * i * i - 2 * i * i * i;
|
|
2626
|
+
}
|
|
2627
|
+
function Xt(i, t, e, n) {
|
|
2628
|
+
const s = D(t) / e[0], r = k(t) / e[1];
|
|
2629
|
+
return n ? Math.min(i, Math.max(s, r)) : Math.min(i, Math.min(s, r));
|
|
2630
|
+
}
|
|
2631
|
+
function Nt(i, t, e) {
|
|
2632
|
+
let n = Math.min(i, t);
|
|
2633
|
+
const s = 50;
|
|
2634
|
+
return n *= Math.log(1 + s * Math.max(0, i / t - 1)) / s + 1, e && (n = Math.max(n, e), n /= Math.log(1 + s * Math.max(0, e / i - 1)) / s + 1), T(n, e / 2, t * 2);
|
|
2635
|
+
}
|
|
2636
|
+
function Ii(i, t, e, n) {
|
|
2637
|
+
return t = t !== void 0 ? t : !0, /**
|
|
2638
|
+
* @param {number|undefined} resolution Resolution.
|
|
2639
|
+
* @param {number} direction Direction.
|
|
2640
|
+
* @param {import("./size.js").Size} size Viewport size.
|
|
2641
|
+
* @param {boolean} [isMoving] True if an interaction or animation is in progress.
|
|
2642
|
+
* @return {number|undefined} Resolution.
|
|
2643
|
+
*/
|
|
2644
|
+
function(s, r, o, a) {
|
|
2645
|
+
if (s !== void 0) {
|
|
2646
|
+
const l = i[0], h = i[i.length - 1], u = e ? Xt(
|
|
2647
|
+
l,
|
|
2648
|
+
e,
|
|
2649
|
+
o,
|
|
2650
|
+
n
|
|
2651
|
+
) : l;
|
|
2652
|
+
if (a)
|
|
2653
|
+
return t ? Nt(
|
|
2654
|
+
s,
|
|
2655
|
+
u,
|
|
2656
|
+
h
|
|
2657
|
+
) : T(s, h, u);
|
|
2658
|
+
const c = Math.min(u, s), f = Math.floor(wt(i, c, r));
|
|
2659
|
+
return i[f] > u && f < i.length - 1 ? i[f + 1] : i[f];
|
|
2660
|
+
}
|
|
2661
|
+
};
|
|
2662
|
+
}
|
|
2663
|
+
function yi(i, t, e, n, s, r) {
|
|
2664
|
+
return n = n !== void 0 ? n : !0, e = e !== void 0 ? e : 0, /**
|
|
2665
|
+
* @param {number|undefined} resolution Resolution.
|
|
2666
|
+
* @param {number} direction Direction.
|
|
2667
|
+
* @param {import("./size.js").Size} size Viewport size.
|
|
2668
|
+
* @param {boolean} [isMoving] True if an interaction or animation is in progress.
|
|
2669
|
+
* @return {number|undefined} Resolution.
|
|
2670
|
+
*/
|
|
2671
|
+
function(o, a, l, h) {
|
|
2672
|
+
if (o !== void 0) {
|
|
2673
|
+
const u = s ? Xt(
|
|
2674
|
+
t,
|
|
2675
|
+
s,
|
|
2676
|
+
l,
|
|
2677
|
+
r
|
|
2678
|
+
) : t;
|
|
2679
|
+
if (h)
|
|
2680
|
+
return n ? Nt(
|
|
2681
|
+
o,
|
|
2682
|
+
u,
|
|
2683
|
+
e
|
|
2684
|
+
) : T(o, e, u);
|
|
2685
|
+
const c = 1e-9, f = Math.ceil(
|
|
2686
|
+
Math.log(t / u) / Math.log(i) - c
|
|
2687
|
+
), g = -a * (0.5 - c) + 0.5, d = Math.min(u, o), m = Math.floor(
|
|
2688
|
+
Math.log(t / d) / Math.log(i) + g
|
|
2689
|
+
), _ = Math.max(f, m), x = t / Math.pow(i, _);
|
|
2690
|
+
return T(x, e, u);
|
|
2691
|
+
}
|
|
2692
|
+
};
|
|
2693
|
+
}
|
|
2694
|
+
function oe(i, t, e, n, s) {
|
|
2695
|
+
return e = e !== void 0 ? e : !0, /**
|
|
2696
|
+
* @param {number|undefined} resolution Resolution.
|
|
2697
|
+
* @param {number} direction Direction.
|
|
2698
|
+
* @param {import("./size.js").Size} size Viewport size.
|
|
2699
|
+
* @param {boolean} [isMoving] True if an interaction or animation is in progress.
|
|
2700
|
+
* @return {number|undefined} Resolution.
|
|
2701
|
+
*/
|
|
2702
|
+
function(r, o, a, l) {
|
|
2703
|
+
if (r !== void 0) {
|
|
2704
|
+
const h = n ? Xt(
|
|
2705
|
+
i,
|
|
2706
|
+
n,
|
|
2707
|
+
a,
|
|
2708
|
+
s
|
|
2709
|
+
) : i;
|
|
2710
|
+
return !e || !l ? T(r, t, h) : Nt(
|
|
2711
|
+
r,
|
|
2712
|
+
h,
|
|
2713
|
+
t
|
|
2714
|
+
);
|
|
2715
|
+
}
|
|
2716
|
+
};
|
|
2717
|
+
}
|
|
2718
|
+
function wi(i) {
|
|
2719
|
+
if (i !== void 0)
|
|
2720
|
+
return 0;
|
|
2721
|
+
}
|
|
2722
|
+
function ae(i) {
|
|
2723
|
+
if (i !== void 0)
|
|
2724
|
+
return i;
|
|
2725
|
+
}
|
|
2726
|
+
function Si(i) {
|
|
2727
|
+
const t = 2 * Math.PI / i;
|
|
2728
|
+
return (
|
|
2729
|
+
/**
|
|
2730
|
+
* @param {number|undefined} rotation Rotation.
|
|
2731
|
+
* @param {boolean} [isMoving] True if an interaction or animation is in progress.
|
|
2732
|
+
* @return {number|undefined} Rotation.
|
|
2733
|
+
*/
|
|
2734
|
+
function(e, n) {
|
|
2735
|
+
if (n)
|
|
2736
|
+
return e;
|
|
2737
|
+
if (e !== void 0)
|
|
2738
|
+
return e = Math.floor(e / t + 0.5) * t, e;
|
|
2739
|
+
}
|
|
2740
|
+
);
|
|
2741
|
+
}
|
|
2742
|
+
function Ai(i) {
|
|
2743
|
+
const t = H(5);
|
|
2744
|
+
return (
|
|
2745
|
+
/**
|
|
2746
|
+
* @param {number|undefined} rotation Rotation.
|
|
2747
|
+
* @param {boolean} [isMoving] True if an interaction or animation is in progress.
|
|
2748
|
+
* @return {number|undefined} Rotation.
|
|
2749
|
+
*/
|
|
2750
|
+
function(e, n) {
|
|
2751
|
+
return n || e === void 0 ? e : Math.abs(e) <= t ? 0 : e;
|
|
2752
|
+
}
|
|
2753
|
+
);
|
|
2754
|
+
}
|
|
2755
|
+
const je = 256, xt = 0;
|
|
2756
|
+
class vi extends fe {
|
|
2757
|
+
/**
|
|
2758
|
+
* @param {ViewOptions} [options] View options.
|
|
2759
|
+
*/
|
|
2760
|
+
constructor(t) {
|
|
2761
|
+
super(), this.on, this.once, this.un, t = Object.assign({}, t), this.hints_ = [0, 0], this.animations_ = [], this.updateAnimationKey_, this.projection_ = vt(t.projection, "EPSG:3857"), this.viewportSize_ = [100, 100], this.targetCenter_ = null, this.targetResolution_, this.targetRotation_, this.nextCenter_ = null, this.nextResolution_, this.nextRotation_, this.cancelAnchor_ = void 0, t.projection && Vn(), t.center && (t.center = S(t.center, this.projection_)), t.extent && (t.extent = tt(t.extent, this.projection_)), this.applyOptions_(t);
|
|
2762
|
+
}
|
|
2763
|
+
/**
|
|
2764
|
+
* Set up the view with the given options.
|
|
2765
|
+
* @param {ViewOptions} options View options.
|
|
2766
|
+
*/
|
|
2767
|
+
applyOptions_(t) {
|
|
2768
|
+
const e = Object.assign({}, t);
|
|
2769
|
+
for (const a in I)
|
|
2770
|
+
delete e[a];
|
|
2771
|
+
this.setProperties(e, !0);
|
|
2772
|
+
const n = Fi(t);
|
|
2773
|
+
this.maxResolution_ = n.maxResolution, this.minResolution_ = n.minResolution, this.zoomFactor_ = n.zoomFactor, this.resolutions_ = t.resolutions, this.padding_ = t.padding, this.minZoom_ = n.minZoom;
|
|
2774
|
+
const s = Pi(t), r = n.constraint, o = Xi(t);
|
|
2775
|
+
this.constraints_ = {
|
|
2776
|
+
center: s,
|
|
2777
|
+
resolution: r,
|
|
2778
|
+
rotation: o
|
|
2779
|
+
}, this.setRotation(t.rotation !== void 0 ? t.rotation : 0), this.setCenterInternal(
|
|
2780
|
+
t.center !== void 0 ? t.center : null
|
|
2781
|
+
), t.resolution !== void 0 ? this.setResolution(t.resolution) : t.zoom !== void 0 && this.setZoom(t.zoom);
|
|
2782
|
+
}
|
|
2783
|
+
/**
|
|
2784
|
+
* Padding (in css pixels).
|
|
2785
|
+
* If the map viewport is partially covered with other content (overlays) along
|
|
2786
|
+
* its edges, this setting allows to shift the center of the viewport away from that
|
|
2787
|
+
* content. The order of the values in the array is top, right, bottom, left.
|
|
2788
|
+
* The default is no padding, which is equivalent to `[0, 0, 0, 0]`.
|
|
2789
|
+
* @type {Array<number>|undefined}
|
|
2790
|
+
* @api
|
|
2791
|
+
*/
|
|
2792
|
+
get padding() {
|
|
2793
|
+
return this.padding_;
|
|
2794
|
+
}
|
|
2795
|
+
set padding(t) {
|
|
2796
|
+
let e = this.padding_;
|
|
2797
|
+
this.padding_ = t;
|
|
2798
|
+
const n = this.getCenterInternal();
|
|
2799
|
+
if (n) {
|
|
2800
|
+
const s = t || [0, 0, 0, 0];
|
|
2801
|
+
e = e || [0, 0, 0, 0];
|
|
2802
|
+
const r = this.getResolution(), o = r / 2 * (s[3] - e[3] + e[1] - s[1]), a = r / 2 * (s[0] - e[0] + e[2] - s[2]);
|
|
2803
|
+
this.setCenterInternal([n[0] + o, n[1] - a]);
|
|
2804
|
+
}
|
|
2805
|
+
}
|
|
2806
|
+
/**
|
|
2807
|
+
* Get an updated version of the view options used to construct the view. The
|
|
2808
|
+
* current resolution (or zoom), center, and rotation are applied to any stored
|
|
2809
|
+
* options. The provided options can be used to apply new min/max zoom or
|
|
2810
|
+
* resolution limits.
|
|
2811
|
+
* @param {ViewOptions} newOptions New options to be applied.
|
|
2812
|
+
* @return {ViewOptions} New options updated with the current view state.
|
|
2813
|
+
*/
|
|
2814
|
+
getUpdatedOptions_(t) {
|
|
2815
|
+
const e = this.getProperties();
|
|
2816
|
+
return e.resolution !== void 0 ? e.resolution = this.getResolution() : e.zoom = this.getZoom(), e.center = this.getCenterInternal(), e.rotation = this.getRotation(), Object.assign({}, e, t);
|
|
2817
|
+
}
|
|
2818
|
+
/**
|
|
2819
|
+
* Animate the view. The view's center, zoom (or resolution), and rotation
|
|
2820
|
+
* can be animated for smooth transitions between view states. For example,
|
|
2821
|
+
* to animate the view to a new zoom level:
|
|
2822
|
+
*
|
|
2823
|
+
* view.animate({zoom: view.getZoom() + 1});
|
|
2824
|
+
*
|
|
2825
|
+
* By default, the animation lasts one second and uses in-and-out easing. You
|
|
2826
|
+
* can customize this behavior by including `duration` (in milliseconds) and
|
|
2827
|
+
* `easing` options (see {@link module:ol/easing}).
|
|
2828
|
+
*
|
|
2829
|
+
* To chain together multiple animations, call the method with multiple
|
|
2830
|
+
* animation objects. For example, to first zoom and then pan:
|
|
2831
|
+
*
|
|
2832
|
+
* view.animate({zoom: 10}, {center: [0, 0]});
|
|
2833
|
+
*
|
|
2834
|
+
* If you provide a function as the last argument to the animate method, it
|
|
2835
|
+
* will get called at the end of an animation series. The callback will be
|
|
2836
|
+
* called with `true` if the animation series completed on its own or `false`
|
|
2837
|
+
* if it was cancelled.
|
|
2838
|
+
*
|
|
2839
|
+
* Animations are cancelled by user interactions (e.g. dragging the map) or by
|
|
2840
|
+
* calling `view.setCenter()`, `view.setResolution()`, or `view.setRotation()`
|
|
2841
|
+
* (or another method that calls one of these).
|
|
2842
|
+
*
|
|
2843
|
+
* @param {...(AnimationOptions|function(boolean): void)} var_args Animation
|
|
2844
|
+
* options. Multiple animations can be run in series by passing multiple
|
|
2845
|
+
* options objects. To run multiple animations in parallel, call the method
|
|
2846
|
+
* multiple times. An optional callback can be provided as a final
|
|
2847
|
+
* argument. The callback will be called with a boolean indicating whether
|
|
2848
|
+
* the animation completed without being cancelled.
|
|
2849
|
+
* @api
|
|
2850
|
+
*/
|
|
2851
|
+
animate(t) {
|
|
2852
|
+
this.isDef() && !this.getAnimating() && this.resolveConstraints(0);
|
|
2853
|
+
const e = new Array(arguments.length);
|
|
2854
|
+
for (let n = 0; n < e.length; ++n) {
|
|
2855
|
+
let s = arguments[n];
|
|
2856
|
+
s.center && (s = Object.assign({}, s), s.center = S(
|
|
2857
|
+
s.center,
|
|
2858
|
+
this.getProjection()
|
|
2859
|
+
)), s.anchor && (s = Object.assign({}, s), s.anchor = S(
|
|
2860
|
+
s.anchor,
|
|
2861
|
+
this.getProjection()
|
|
2862
|
+
)), e[n] = s;
|
|
2863
|
+
}
|
|
2864
|
+
this.animateInternal.apply(this, e);
|
|
2865
|
+
}
|
|
2866
|
+
/**
|
|
2867
|
+
* @param {...(AnimationOptions|function(boolean): void)} var_args Animation options.
|
|
2868
|
+
*/
|
|
2869
|
+
animateInternal(t) {
|
|
2870
|
+
let e = arguments.length, n;
|
|
2871
|
+
e > 1 && typeof arguments[e - 1] == "function" && (n = arguments[e - 1], --e);
|
|
2872
|
+
let s = 0;
|
|
2873
|
+
for (; s < e && !this.isDef(); ++s) {
|
|
2874
|
+
const u = arguments[s];
|
|
2875
|
+
u.center && this.setCenterInternal(u.center), u.zoom !== void 0 ? this.setZoom(u.zoom) : u.resolution && this.setResolution(u.resolution), u.rotation !== void 0 && this.setRotation(u.rotation);
|
|
2876
|
+
}
|
|
2877
|
+
if (s === e) {
|
|
2878
|
+
n && nt(n, !0);
|
|
2879
|
+
return;
|
|
2880
|
+
}
|
|
2881
|
+
let r = Date.now(), o = this.targetCenter_.slice(), a = this.targetResolution_, l = this.targetRotation_;
|
|
2882
|
+
const h = [];
|
|
2883
|
+
for (; s < e; ++s) {
|
|
2884
|
+
const u = (
|
|
2885
|
+
/** @type {AnimationOptions} */
|
|
2886
|
+
arguments[s]
|
|
2887
|
+
), c = {
|
|
2888
|
+
start: r,
|
|
2889
|
+
complete: !1,
|
|
2890
|
+
anchor: u.anchor,
|
|
2891
|
+
duration: u.duration !== void 0 ? u.duration : 1e3,
|
|
2892
|
+
easing: u.easing || Ti,
|
|
2893
|
+
callback: n
|
|
2894
|
+
};
|
|
2895
|
+
if (u.center && (c.sourceCenter = o, c.targetCenter = u.center.slice(), o = c.targetCenter), u.zoom !== void 0 ? (c.sourceResolution = a, c.targetResolution = this.getResolutionForZoom(u.zoom), a = c.targetResolution) : u.resolution && (c.sourceResolution = a, c.targetResolution = u.resolution, a = c.targetResolution), u.rotation !== void 0) {
|
|
2896
|
+
c.sourceRotation = l;
|
|
2897
|
+
const f = Ut(u.rotation - l + Math.PI, 2 * Math.PI) - Math.PI;
|
|
2898
|
+
c.targetRotation = l + f, l = c.targetRotation;
|
|
2899
|
+
}
|
|
2900
|
+
Ni(c) ? c.complete = !0 : r += c.duration, h.push(c);
|
|
2901
|
+
}
|
|
2902
|
+
this.animations_.push(h), this.setHint(A.ANIMATING, 1), this.updateAnimations_();
|
|
2903
|
+
}
|
|
2904
|
+
/**
|
|
2905
|
+
* Determine if the view is being animated.
|
|
2906
|
+
* @return {boolean} The view is being animated.
|
|
2907
|
+
* @api
|
|
2908
|
+
*/
|
|
2909
|
+
getAnimating() {
|
|
2910
|
+
return this.hints_[A.ANIMATING] > 0;
|
|
2911
|
+
}
|
|
2912
|
+
/**
|
|
2913
|
+
* Determine if the user is interacting with the view, such as panning or zooming.
|
|
2914
|
+
* @return {boolean} The view is being interacted with.
|
|
2915
|
+
* @api
|
|
2916
|
+
*/
|
|
2917
|
+
getInteracting() {
|
|
2918
|
+
return this.hints_[A.INTERACTING] > 0;
|
|
2919
|
+
}
|
|
2920
|
+
/**
|
|
2921
|
+
* Cancel any ongoing animations.
|
|
2922
|
+
* @api
|
|
2923
|
+
*/
|
|
2924
|
+
cancelAnimations() {
|
|
2925
|
+
this.setHint(A.ANIMATING, -this.hints_[A.ANIMATING]);
|
|
2926
|
+
let t;
|
|
2927
|
+
for (let e = 0, n = this.animations_.length; e < n; ++e) {
|
|
2928
|
+
const s = this.animations_[e];
|
|
2929
|
+
if (s[0].callback && nt(s[0].callback, !1), !t)
|
|
2930
|
+
for (let r = 0, o = s.length; r < o; ++r) {
|
|
2931
|
+
const a = s[r];
|
|
2932
|
+
if (!a.complete) {
|
|
2933
|
+
t = a.anchor;
|
|
2934
|
+
break;
|
|
2935
|
+
}
|
|
2936
|
+
}
|
|
2937
|
+
}
|
|
2938
|
+
this.animations_.length = 0, this.cancelAnchor_ = t, this.nextCenter_ = null, this.nextResolution_ = NaN, this.nextRotation_ = NaN;
|
|
2939
|
+
}
|
|
2940
|
+
/**
|
|
2941
|
+
* Update all animations.
|
|
2942
|
+
*/
|
|
2943
|
+
updateAnimations_() {
|
|
2944
|
+
if (this.updateAnimationKey_ !== void 0 && (cancelAnimationFrame(this.updateAnimationKey_), this.updateAnimationKey_ = void 0), !this.getAnimating())
|
|
2945
|
+
return;
|
|
2946
|
+
const t = Date.now();
|
|
2947
|
+
let e = !1;
|
|
2948
|
+
for (let n = this.animations_.length - 1; n >= 0; --n) {
|
|
2949
|
+
const s = this.animations_[n];
|
|
2950
|
+
let r = !0;
|
|
2951
|
+
for (let o = 0, a = s.length; o < a; ++o) {
|
|
2952
|
+
const l = s[o];
|
|
2953
|
+
if (l.complete)
|
|
2954
|
+
continue;
|
|
2955
|
+
const h = t - l.start;
|
|
2956
|
+
let u = l.duration > 0 ? h / l.duration : 1;
|
|
2957
|
+
u >= 1 ? (l.complete = !0, u = 1) : r = !1;
|
|
2958
|
+
const c = l.easing(u);
|
|
2959
|
+
if (l.sourceCenter) {
|
|
2960
|
+
const f = l.sourceCenter[0], g = l.sourceCenter[1], d = l.targetCenter[0], m = l.targetCenter[1];
|
|
2961
|
+
this.nextCenter_ = l.targetCenter;
|
|
2962
|
+
const _ = f + c * (d - f), x = g + c * (m - g);
|
|
2963
|
+
this.targetCenter_ = [_, x];
|
|
2964
|
+
}
|
|
2965
|
+
if (l.sourceResolution && l.targetResolution) {
|
|
2966
|
+
const f = c === 1 ? l.targetResolution : l.sourceResolution + c * (l.targetResolution - l.sourceResolution);
|
|
2967
|
+
if (l.anchor) {
|
|
2968
|
+
const g = this.getViewportSize_(this.getRotation()), d = this.constraints_.resolution(
|
|
2969
|
+
f,
|
|
2970
|
+
0,
|
|
2971
|
+
g,
|
|
2972
|
+
!0
|
|
2973
|
+
);
|
|
2974
|
+
this.targetCenter_ = this.calculateCenterZoom(
|
|
2975
|
+
d,
|
|
2976
|
+
l.anchor
|
|
2977
|
+
);
|
|
2978
|
+
}
|
|
2979
|
+
this.nextResolution_ = l.targetResolution, this.targetResolution_ = f, this.applyTargetState_(!0);
|
|
2980
|
+
}
|
|
2981
|
+
if (l.sourceRotation !== void 0 && l.targetRotation !== void 0) {
|
|
2982
|
+
const f = c === 1 ? Ut(l.targetRotation + Math.PI, 2 * Math.PI) - Math.PI : l.sourceRotation + c * (l.targetRotation - l.sourceRotation);
|
|
2983
|
+
if (l.anchor) {
|
|
2984
|
+
const g = this.constraints_.rotation(
|
|
2985
|
+
f,
|
|
2986
|
+
!0
|
|
2987
|
+
);
|
|
2988
|
+
this.targetCenter_ = this.calculateCenterRotate(
|
|
2989
|
+
g,
|
|
2990
|
+
l.anchor
|
|
2991
|
+
);
|
|
2992
|
+
}
|
|
2993
|
+
this.nextRotation_ = l.targetRotation, this.targetRotation_ = f;
|
|
2994
|
+
}
|
|
2995
|
+
if (this.applyTargetState_(!0), e = !0, !l.complete)
|
|
2996
|
+
break;
|
|
2997
|
+
}
|
|
2998
|
+
if (r) {
|
|
2999
|
+
this.animations_[n] = null, this.setHint(A.ANIMATING, -1), this.nextCenter_ = null, this.nextResolution_ = NaN, this.nextRotation_ = NaN;
|
|
3000
|
+
const o = s[0].callback;
|
|
3001
|
+
o && nt(o, !0);
|
|
3002
|
+
}
|
|
3003
|
+
}
|
|
3004
|
+
this.animations_ = this.animations_.filter(Boolean), e && this.updateAnimationKey_ === void 0 && (this.updateAnimationKey_ = requestAnimationFrame(
|
|
3005
|
+
this.updateAnimations_.bind(this)
|
|
3006
|
+
));
|
|
3007
|
+
}
|
|
3008
|
+
/**
|
|
3009
|
+
* @param {number} rotation Target rotation.
|
|
3010
|
+
* @param {import("./coordinate.js").Coordinate} anchor Rotation anchor.
|
|
3011
|
+
* @return {import("./coordinate.js").Coordinate|undefined} Center for rotation and anchor.
|
|
3012
|
+
*/
|
|
3013
|
+
calculateCenterRotate(t, e) {
|
|
3014
|
+
let n;
|
|
3015
|
+
const s = this.getCenterInternal();
|
|
3016
|
+
return s !== void 0 && (n = [s[0] - e[0], s[1] - e[1]], xn(n, t - this.getRotation()), Rn(n, e)), n;
|
|
3017
|
+
}
|
|
3018
|
+
/**
|
|
3019
|
+
* @param {number} resolution Target resolution.
|
|
3020
|
+
* @param {import("./coordinate.js").Coordinate} anchor Zoom anchor.
|
|
3021
|
+
* @return {import("./coordinate.js").Coordinate|undefined} Center for resolution and anchor.
|
|
3022
|
+
*/
|
|
3023
|
+
calculateCenterZoom(t, e) {
|
|
3024
|
+
let n;
|
|
3025
|
+
const s = this.getCenterInternal(), r = this.getResolution();
|
|
3026
|
+
if (s !== void 0 && r !== void 0) {
|
|
3027
|
+
const o = e[0] - t * (e[0] - s[0]) / r, a = e[1] - t * (e[1] - s[1]) / r;
|
|
3028
|
+
n = [o, a];
|
|
3029
|
+
}
|
|
3030
|
+
return n;
|
|
3031
|
+
}
|
|
3032
|
+
/**
|
|
3033
|
+
* Returns the current viewport size.
|
|
3034
|
+
* @private
|
|
3035
|
+
* @param {number} [rotation] Take into account the rotation of the viewport when giving the size
|
|
3036
|
+
* @return {import("./size.js").Size} Viewport size or `[100, 100]` when no viewport is found.
|
|
3037
|
+
*/
|
|
3038
|
+
getViewportSize_(t) {
|
|
3039
|
+
const e = this.viewportSize_;
|
|
3040
|
+
if (t) {
|
|
3041
|
+
const n = e[0], s = e[1];
|
|
3042
|
+
return [
|
|
3043
|
+
Math.abs(n * Math.cos(t)) + Math.abs(s * Math.sin(t)),
|
|
3044
|
+
Math.abs(n * Math.sin(t)) + Math.abs(s * Math.cos(t))
|
|
3045
|
+
];
|
|
3046
|
+
}
|
|
3047
|
+
return e;
|
|
3048
|
+
}
|
|
3049
|
+
/**
|
|
3050
|
+
* Stores the viewport size on the view. The viewport size is not read every time from the DOM
|
|
3051
|
+
* to avoid performance hit and layout reflow.
|
|
3052
|
+
* This should be done on map size change.
|
|
3053
|
+
* Note: the constraints are not resolved during an animation to avoid stopping it
|
|
3054
|
+
* @param {import("./size.js").Size} [size] Viewport size; if undefined, [100, 100] is assumed
|
|
3055
|
+
*/
|
|
3056
|
+
setViewportSize(t) {
|
|
3057
|
+
this.viewportSize_ = Array.isArray(t) ? t.slice() : [100, 100], this.getAnimating() || this.resolveConstraints(0);
|
|
3058
|
+
}
|
|
3059
|
+
/**
|
|
3060
|
+
* Get the view center.
|
|
3061
|
+
* @return {import("./coordinate.js").Coordinate|undefined} The center of the view.
|
|
3062
|
+
* @observable
|
|
3063
|
+
* @api
|
|
3064
|
+
*/
|
|
3065
|
+
getCenter() {
|
|
3066
|
+
const t = this.getCenterInternal();
|
|
3067
|
+
return t && Jt(t, this.getProjection());
|
|
3068
|
+
}
|
|
3069
|
+
/**
|
|
3070
|
+
* Get the view center without transforming to user projection.
|
|
3071
|
+
* @return {import("./coordinate.js").Coordinate|undefined} The center of the view.
|
|
3072
|
+
*/
|
|
3073
|
+
getCenterInternal() {
|
|
3074
|
+
return (
|
|
3075
|
+
/** @type {import("./coordinate.js").Coordinate|undefined} */
|
|
3076
|
+
this.get(I.CENTER)
|
|
3077
|
+
);
|
|
3078
|
+
}
|
|
3079
|
+
/**
|
|
3080
|
+
* @return {Constraints} Constraints.
|
|
3081
|
+
*/
|
|
3082
|
+
getConstraints() {
|
|
3083
|
+
return this.constraints_;
|
|
3084
|
+
}
|
|
3085
|
+
/**
|
|
3086
|
+
* @return {boolean} Resolution constraint is set
|
|
3087
|
+
*/
|
|
3088
|
+
getConstrainResolution() {
|
|
3089
|
+
return this.get("constrainResolution");
|
|
3090
|
+
}
|
|
3091
|
+
/**
|
|
3092
|
+
* @param {Array<number>} [hints] Destination array.
|
|
3093
|
+
* @return {Array<number>} Hint.
|
|
3094
|
+
*/
|
|
3095
|
+
getHints(t) {
|
|
3096
|
+
return t !== void 0 ? (t[0] = this.hints_[0], t[1] = this.hints_[1], t) : this.hints_.slice();
|
|
3097
|
+
}
|
|
3098
|
+
/**
|
|
3099
|
+
* Calculate the extent for the current view state and the passed box size.
|
|
3100
|
+
* @param {import("./size.js").Size} [size] The pixel dimensions of the box
|
|
3101
|
+
* into which the calculated extent should fit. Defaults to the size of the
|
|
3102
|
+
* map the view is associated with.
|
|
3103
|
+
* If no map or multiple maps are connected to the view, provide the desired
|
|
3104
|
+
* box size (e.g. `map.getSize()`).
|
|
3105
|
+
* @return {import("./extent.js").Extent} Extent.
|
|
3106
|
+
* @api
|
|
3107
|
+
*/
|
|
3108
|
+
calculateExtent(t) {
|
|
3109
|
+
const e = this.calculateExtentInternal(t);
|
|
3110
|
+
return kn(e, this.getProjection());
|
|
3111
|
+
}
|
|
3112
|
+
/**
|
|
3113
|
+
* @param {import("./size.js").Size} [size] Box pixel size. If not provided,
|
|
3114
|
+
* the map's last known viewport size will be used.
|
|
3115
|
+
* @return {import("./extent.js").Extent} Extent.
|
|
3116
|
+
*/
|
|
3117
|
+
calculateExtentInternal(t) {
|
|
3118
|
+
t = t || this.getViewportSizeMinusPadding_();
|
|
3119
|
+
const e = (
|
|
3120
|
+
/** @type {!import("./coordinate.js").Coordinate} */
|
|
3121
|
+
this.getCenterInternal()
|
|
3122
|
+
);
|
|
3123
|
+
y(e, "The view center is not defined");
|
|
3124
|
+
const n = (
|
|
3125
|
+
/** @type {!number} */
|
|
3126
|
+
this.getResolution()
|
|
3127
|
+
);
|
|
3128
|
+
y(n !== void 0, "The view resolution is not defined");
|
|
3129
|
+
const s = (
|
|
3130
|
+
/** @type {!number} */
|
|
3131
|
+
this.getRotation()
|
|
3132
|
+
);
|
|
3133
|
+
return y(s !== void 0, "The view rotation is not defined"), ln(e, n, s, t);
|
|
3134
|
+
}
|
|
3135
|
+
/**
|
|
3136
|
+
* Get the maximum resolution of the view.
|
|
3137
|
+
* @return {number} The maximum resolution of the view.
|
|
3138
|
+
* @api
|
|
3139
|
+
*/
|
|
3140
|
+
getMaxResolution() {
|
|
3141
|
+
return this.maxResolution_;
|
|
3142
|
+
}
|
|
3143
|
+
/**
|
|
3144
|
+
* Get the minimum resolution of the view.
|
|
3145
|
+
* @return {number} The minimum resolution of the view.
|
|
3146
|
+
* @api
|
|
3147
|
+
*/
|
|
3148
|
+
getMinResolution() {
|
|
3149
|
+
return this.minResolution_;
|
|
3150
|
+
}
|
|
3151
|
+
/**
|
|
3152
|
+
* Get the maximum zoom level for the view.
|
|
3153
|
+
* @return {number} The maximum zoom level.
|
|
3154
|
+
* @api
|
|
3155
|
+
*/
|
|
3156
|
+
getMaxZoom() {
|
|
3157
|
+
return (
|
|
3158
|
+
/** @type {number} */
|
|
3159
|
+
this.getZoomForResolution(this.minResolution_)
|
|
3160
|
+
);
|
|
3161
|
+
}
|
|
3162
|
+
/**
|
|
3163
|
+
* Set a new maximum zoom level for the view.
|
|
3164
|
+
* @param {number} zoom The maximum zoom level.
|
|
3165
|
+
* @api
|
|
3166
|
+
*/
|
|
3167
|
+
setMaxZoom(t) {
|
|
3168
|
+
this.applyOptions_(this.getUpdatedOptions_({ maxZoom: t }));
|
|
3169
|
+
}
|
|
3170
|
+
/**
|
|
3171
|
+
* Get the minimum zoom level for the view.
|
|
3172
|
+
* @return {number} The minimum zoom level.
|
|
3173
|
+
* @api
|
|
3174
|
+
*/
|
|
3175
|
+
getMinZoom() {
|
|
3176
|
+
return (
|
|
3177
|
+
/** @type {number} */
|
|
3178
|
+
this.getZoomForResolution(this.maxResolution_)
|
|
3179
|
+
);
|
|
3180
|
+
}
|
|
3181
|
+
/**
|
|
3182
|
+
* Set a new minimum zoom level for the view.
|
|
3183
|
+
* @param {number} zoom The minimum zoom level.
|
|
3184
|
+
* @api
|
|
3185
|
+
*/
|
|
3186
|
+
setMinZoom(t) {
|
|
3187
|
+
this.applyOptions_(this.getUpdatedOptions_({ minZoom: t }));
|
|
3188
|
+
}
|
|
3189
|
+
/**
|
|
3190
|
+
* Set whether the view should allow intermediary zoom levels.
|
|
3191
|
+
* @param {boolean} enabled Whether the resolution is constrained.
|
|
3192
|
+
* @api
|
|
3193
|
+
*/
|
|
3194
|
+
setConstrainResolution(t) {
|
|
3195
|
+
this.applyOptions_(this.getUpdatedOptions_({ constrainResolution: t }));
|
|
3196
|
+
}
|
|
3197
|
+
/**
|
|
3198
|
+
* Get the view projection.
|
|
3199
|
+
* @return {import("./proj/Projection.js").default} The projection of the view.
|
|
3200
|
+
* @api
|
|
3201
|
+
*/
|
|
3202
|
+
getProjection() {
|
|
3203
|
+
return this.projection_;
|
|
3204
|
+
}
|
|
3205
|
+
/**
|
|
3206
|
+
* Get the view resolution.
|
|
3207
|
+
* @return {number|undefined} The resolution of the view.
|
|
3208
|
+
* @observable
|
|
3209
|
+
* @api
|
|
3210
|
+
*/
|
|
3211
|
+
getResolution() {
|
|
3212
|
+
return (
|
|
3213
|
+
/** @type {number|undefined} */
|
|
3214
|
+
this.get(I.RESOLUTION)
|
|
3215
|
+
);
|
|
3216
|
+
}
|
|
3217
|
+
/**
|
|
3218
|
+
* Get the resolutions for the view. This returns the array of resolutions
|
|
3219
|
+
* passed to the constructor of the View, or undefined if none were given.
|
|
3220
|
+
* @return {Array<number>|undefined} The resolutions of the view.
|
|
3221
|
+
* @api
|
|
3222
|
+
*/
|
|
3223
|
+
getResolutions() {
|
|
3224
|
+
return this.resolutions_;
|
|
3225
|
+
}
|
|
3226
|
+
/**
|
|
3227
|
+
* Get the resolution for a provided extent (in map units) and size (in pixels).
|
|
3228
|
+
* @param {import("./extent.js").Extent} extent Extent.
|
|
3229
|
+
* @param {import("./size.js").Size} [size] Box pixel size.
|
|
3230
|
+
* @return {number} The resolution at which the provided extent will render at
|
|
3231
|
+
* the given size.
|
|
3232
|
+
* @api
|
|
3233
|
+
*/
|
|
3234
|
+
getResolutionForExtent(t, e) {
|
|
3235
|
+
return this.getResolutionForExtentInternal(
|
|
3236
|
+
tt(t, this.getProjection()),
|
|
3237
|
+
e
|
|
3238
|
+
);
|
|
3239
|
+
}
|
|
3240
|
+
/**
|
|
3241
|
+
* Get the resolution for a provided extent (in map units) and size (in pixels).
|
|
3242
|
+
* @param {import("./extent.js").Extent} extent Extent.
|
|
3243
|
+
* @param {import("./size.js").Size} [size] Box pixel size.
|
|
3244
|
+
* @return {number} The resolution at which the provided extent will render at
|
|
3245
|
+
* the given size.
|
|
3246
|
+
*/
|
|
3247
|
+
getResolutionForExtentInternal(t, e) {
|
|
3248
|
+
e = e || this.getViewportSizeMinusPadding_();
|
|
3249
|
+
const n = D(t) / e[0], s = k(t) / e[1];
|
|
3250
|
+
return Math.max(n, s);
|
|
3251
|
+
}
|
|
3252
|
+
/**
|
|
3253
|
+
* Return a function that returns a value between 0 and 1 for a
|
|
3254
|
+
* resolution. Exponential scaling is assumed.
|
|
3255
|
+
* @param {number} [power] Power.
|
|
3256
|
+
* @return {function(number): number} Resolution for value function.
|
|
3257
|
+
*/
|
|
3258
|
+
getResolutionForValueFunction(t) {
|
|
3259
|
+
t = t || 2;
|
|
3260
|
+
const e = this.getConstrainedResolution(this.maxResolution_), n = this.minResolution_, s = Math.log(e / n) / Math.log(t);
|
|
3261
|
+
return (
|
|
3262
|
+
/**
|
|
3263
|
+
* @param {number} value Value.
|
|
3264
|
+
* @return {number} Resolution.
|
|
3265
|
+
*/
|
|
3266
|
+
function(r) {
|
|
3267
|
+
return e / Math.pow(t, r * s);
|
|
3268
|
+
}
|
|
3269
|
+
);
|
|
3270
|
+
}
|
|
3271
|
+
/**
|
|
3272
|
+
* Get the view rotation.
|
|
3273
|
+
* @return {number} The rotation of the view in radians.
|
|
3274
|
+
* @observable
|
|
3275
|
+
* @api
|
|
3276
|
+
*/
|
|
3277
|
+
getRotation() {
|
|
3278
|
+
return (
|
|
3279
|
+
/** @type {number} */
|
|
3280
|
+
this.get(I.ROTATION)
|
|
3281
|
+
);
|
|
3282
|
+
}
|
|
3283
|
+
/**
|
|
3284
|
+
* Return a function that returns a resolution for a value between
|
|
3285
|
+
* 0 and 1. Exponential scaling is assumed.
|
|
3286
|
+
* @param {number} [power] Power.
|
|
3287
|
+
* @return {function(number): number} Value for resolution function.
|
|
3288
|
+
*/
|
|
3289
|
+
getValueForResolutionFunction(t) {
|
|
3290
|
+
const e = Math.log(t || 2), n = this.getConstrainedResolution(this.maxResolution_), s = this.minResolution_, r = Math.log(n / s) / e;
|
|
3291
|
+
return (
|
|
3292
|
+
/**
|
|
3293
|
+
* @param {number} resolution Resolution.
|
|
3294
|
+
* @return {number} Value.
|
|
3295
|
+
*/
|
|
3296
|
+
function(o) {
|
|
3297
|
+
return Math.log(n / o) / e / r;
|
|
3298
|
+
}
|
|
3299
|
+
);
|
|
3300
|
+
}
|
|
3301
|
+
/**
|
|
3302
|
+
* Returns the size of the viewport minus padding.
|
|
3303
|
+
* @private
|
|
3304
|
+
* @param {number} [rotation] Take into account the rotation of the viewport when giving the size
|
|
3305
|
+
* @return {import("./size.js").Size} Viewport size reduced by the padding.
|
|
3306
|
+
*/
|
|
3307
|
+
getViewportSizeMinusPadding_(t) {
|
|
3308
|
+
let e = this.getViewportSize_(t);
|
|
3309
|
+
const n = this.padding_;
|
|
3310
|
+
return n && (e = [
|
|
3311
|
+
e[0] - n[1] - n[3],
|
|
3312
|
+
e[1] - n[0] - n[2]
|
|
3313
|
+
]), e;
|
|
3314
|
+
}
|
|
3315
|
+
/**
|
|
3316
|
+
* @return {State} View state.
|
|
3317
|
+
*/
|
|
3318
|
+
getState() {
|
|
3319
|
+
const t = this.getProjection(), e = this.getResolution(), n = this.getRotation();
|
|
3320
|
+
let s = (
|
|
3321
|
+
/** @type {import("./coordinate.js").Coordinate} */
|
|
3322
|
+
this.getCenterInternal()
|
|
3323
|
+
);
|
|
3324
|
+
const r = this.padding_;
|
|
3325
|
+
if (r) {
|
|
3326
|
+
const o = this.getViewportSizeMinusPadding_();
|
|
3327
|
+
s = Mt(
|
|
3328
|
+
s,
|
|
3329
|
+
this.getViewportSize_(),
|
|
3330
|
+
[o[0] / 2 + r[3], o[1] / 2 + r[0]],
|
|
3331
|
+
e,
|
|
3332
|
+
n
|
|
3333
|
+
);
|
|
3334
|
+
}
|
|
3335
|
+
return {
|
|
3336
|
+
center: s.slice(0),
|
|
3337
|
+
projection: t !== void 0 ? t : null,
|
|
3338
|
+
resolution: e,
|
|
3339
|
+
nextCenter: this.nextCenter_,
|
|
3340
|
+
nextResolution: this.nextResolution_,
|
|
3341
|
+
nextRotation: this.nextRotation_,
|
|
3342
|
+
rotation: n,
|
|
3343
|
+
zoom: this.getZoom()
|
|
3344
|
+
};
|
|
3345
|
+
}
|
|
3346
|
+
/**
|
|
3347
|
+
* @return {ViewStateLayerStateExtent} Like `FrameState`, but just `viewState` and `extent`.
|
|
3348
|
+
*/
|
|
3349
|
+
getViewStateAndExtent() {
|
|
3350
|
+
return {
|
|
3351
|
+
viewState: this.getState(),
|
|
3352
|
+
extent: this.calculateExtent()
|
|
3353
|
+
};
|
|
3354
|
+
}
|
|
3355
|
+
/**
|
|
3356
|
+
* Get the current zoom level. This method may return non-integer zoom levels
|
|
3357
|
+
* if the view does not constrain the resolution, or if an interaction or
|
|
3358
|
+
* animation is underway.
|
|
3359
|
+
* @return {number|undefined} Zoom.
|
|
3360
|
+
* @api
|
|
3361
|
+
*/
|
|
3362
|
+
getZoom() {
|
|
3363
|
+
let t;
|
|
3364
|
+
const e = this.getResolution();
|
|
3365
|
+
return e !== void 0 && (t = this.getZoomForResolution(e)), t;
|
|
3366
|
+
}
|
|
3367
|
+
/**
|
|
3368
|
+
* Get the zoom level for a resolution.
|
|
3369
|
+
* @param {number} resolution The resolution.
|
|
3370
|
+
* @return {number|undefined} The zoom level for the provided resolution.
|
|
3371
|
+
* @api
|
|
3372
|
+
*/
|
|
3373
|
+
getZoomForResolution(t) {
|
|
3374
|
+
let e = this.minZoom_ || 0, n, s;
|
|
3375
|
+
if (this.resolutions_) {
|
|
3376
|
+
const r = wt(this.resolutions_, t, 1);
|
|
3377
|
+
e = r, n = this.resolutions_[r], r == this.resolutions_.length - 1 ? s = 2 : s = n / this.resolutions_[r + 1];
|
|
3378
|
+
} else
|
|
3379
|
+
n = this.maxResolution_, s = this.zoomFactor_;
|
|
3380
|
+
return e + Math.log(n / t) / Math.log(s);
|
|
3381
|
+
}
|
|
3382
|
+
/**
|
|
3383
|
+
* Get the resolution for a zoom level.
|
|
3384
|
+
* @param {number} zoom Zoom level.
|
|
3385
|
+
* @return {number} The view resolution for the provided zoom level.
|
|
3386
|
+
* @api
|
|
3387
|
+
*/
|
|
3388
|
+
getResolutionForZoom(t) {
|
|
3389
|
+
if (this.resolutions_?.length) {
|
|
3390
|
+
if (this.resolutions_.length === 1)
|
|
3391
|
+
return this.resolutions_[0];
|
|
3392
|
+
const e = T(
|
|
3393
|
+
Math.floor(t),
|
|
3394
|
+
0,
|
|
3395
|
+
this.resolutions_.length - 2
|
|
3396
|
+
), n = this.resolutions_[e] / this.resolutions_[e + 1];
|
|
3397
|
+
return this.resolutions_[e] / Math.pow(n, T(t - e, 0, 1));
|
|
3398
|
+
}
|
|
3399
|
+
return this.maxResolution_ / Math.pow(this.zoomFactor_, t - this.minZoom_);
|
|
3400
|
+
}
|
|
3401
|
+
/**
|
|
3402
|
+
* Fit the given geometry or extent based on the given map size and border.
|
|
3403
|
+
* The size is pixel dimensions of the box to fit the extent into.
|
|
3404
|
+
* In most cases you will want to use the map size, that is `map.getSize()`.
|
|
3405
|
+
* Takes care of the map angle.
|
|
3406
|
+
* @param {import("./geom/SimpleGeometry.js").default|import("./extent.js").Extent} geometryOrExtent The geometry or
|
|
3407
|
+
* extent to fit the view to.
|
|
3408
|
+
* @param {FitOptions} [options] Options.
|
|
3409
|
+
* @api
|
|
3410
|
+
*/
|
|
3411
|
+
fit(t, e) {
|
|
3412
|
+
let n;
|
|
3413
|
+
if (y(
|
|
3414
|
+
Array.isArray(t) || typeof /** @type {?} */
|
|
3415
|
+
t.getSimplifiedGeometry == "function",
|
|
3416
|
+
"Invalid extent or geometry provided as `geometry`"
|
|
3417
|
+
), Array.isArray(t)) {
|
|
3418
|
+
y(
|
|
3419
|
+
!xe(t),
|
|
3420
|
+
"Cannot fit empty extent provided as `geometry`"
|
|
3421
|
+
);
|
|
3422
|
+
const s = tt(t, this.getProjection());
|
|
3423
|
+
n = se(s);
|
|
3424
|
+
} else if (t.getType() === "Circle") {
|
|
3425
|
+
const s = tt(
|
|
3426
|
+
t.getExtent(),
|
|
3427
|
+
this.getProjection()
|
|
3428
|
+
);
|
|
3429
|
+
n = se(s), n.rotate(this.getRotation(), rt(s));
|
|
3430
|
+
} else
|
|
3431
|
+
n = t;
|
|
3432
|
+
this.fitInternal(n, e);
|
|
3433
|
+
}
|
|
3434
|
+
/**
|
|
3435
|
+
* Calculate rotated extent
|
|
3436
|
+
* @param {import("./geom/SimpleGeometry.js").default} geometry The geometry.
|
|
3437
|
+
* @return {import("./extent").Extent} The rotated extent for the geometry.
|
|
3438
|
+
*/
|
|
3439
|
+
rotatedExtentForGeometry(t) {
|
|
3440
|
+
const e = this.getRotation(), n = Math.cos(e), s = Math.sin(-e), r = t.getFlatCoordinates(), o = t.getStride();
|
|
3441
|
+
let a = 1 / 0, l = 1 / 0, h = -1 / 0, u = -1 / 0;
|
|
3442
|
+
for (let c = 0, f = r.length; c < f; c += o) {
|
|
3443
|
+
const g = r[c] * n - r[c + 1] * s, d = r[c] * s + r[c + 1] * n;
|
|
3444
|
+
a = Math.min(a, g), l = Math.min(l, d), h = Math.max(h, g), u = Math.max(u, d);
|
|
3445
|
+
}
|
|
3446
|
+
return [a, l, h, u];
|
|
3447
|
+
}
|
|
3448
|
+
/**
|
|
3449
|
+
* @param {import("./geom/SimpleGeometry.js").default} geometry The geometry.
|
|
3450
|
+
* @param {FitOptions} [options] Options.
|
|
3451
|
+
*/
|
|
3452
|
+
fitInternal(t, e) {
|
|
3453
|
+
e = e || {};
|
|
3454
|
+
let n = e.size;
|
|
3455
|
+
n || (n = this.getViewportSizeMinusPadding_());
|
|
3456
|
+
const s = e.padding !== void 0 ? e.padding : [0, 0, 0, 0], r = e.nearest !== void 0 ? e.nearest : !1;
|
|
3457
|
+
let o;
|
|
3458
|
+
e.minResolution !== void 0 ? o = e.minResolution : e.maxZoom !== void 0 ? o = this.getResolutionForZoom(e.maxZoom) : o = 0;
|
|
3459
|
+
const a = this.rotatedExtentForGeometry(t);
|
|
3460
|
+
let l = this.getResolutionForExtentInternal(a, [
|
|
3461
|
+
n[0] - s[1] - s[3],
|
|
3462
|
+
n[1] - s[0] - s[2]
|
|
3463
|
+
]);
|
|
3464
|
+
l = isNaN(l) ? o : Math.max(l, o), l = this.getConstrainedResolution(l, r ? 0 : 1);
|
|
3465
|
+
const h = this.getRotation(), u = Math.sin(h), c = Math.cos(h), f = rt(a);
|
|
3466
|
+
f[0] += (s[1] - s[3]) / 2 * l, f[1] += (s[0] - s[2]) / 2 * l;
|
|
3467
|
+
const g = f[0] * c - f[1] * u, d = f[1] * c + f[0] * u, m = this.getConstrainedCenter([g, d], l), _ = e.callback ? e.callback : Ct;
|
|
3468
|
+
e.duration !== void 0 ? this.animateInternal(
|
|
3469
|
+
{
|
|
3470
|
+
resolution: l,
|
|
3471
|
+
center: m,
|
|
3472
|
+
duration: e.duration,
|
|
3473
|
+
easing: e.easing
|
|
3474
|
+
},
|
|
3475
|
+
_
|
|
3476
|
+
) : (this.targetResolution_ = l, this.targetCenter_ = m, this.applyTargetState_(!1, !0), nt(_, !0));
|
|
3477
|
+
}
|
|
3478
|
+
/**
|
|
3479
|
+
* Center on coordinate and view position.
|
|
3480
|
+
* @param {import("./coordinate.js").Coordinate} coordinate Coordinate.
|
|
3481
|
+
* @param {import("./size.js").Size} size Box pixel size.
|
|
3482
|
+
* @param {import("./pixel.js").Pixel} position Position on the view to center on.
|
|
3483
|
+
* @api
|
|
3484
|
+
*/
|
|
3485
|
+
centerOn(t, e, n) {
|
|
3486
|
+
this.centerOnInternal(
|
|
3487
|
+
S(t, this.getProjection()),
|
|
3488
|
+
e,
|
|
3489
|
+
n
|
|
3490
|
+
);
|
|
3491
|
+
}
|
|
3492
|
+
/**
|
|
3493
|
+
* @param {import("./coordinate.js").Coordinate} coordinate Coordinate.
|
|
3494
|
+
* @param {import("./size.js").Size} size Box pixel size.
|
|
3495
|
+
* @param {import("./pixel.js").Pixel} position Position on the view to center on.
|
|
3496
|
+
*/
|
|
3497
|
+
centerOnInternal(t, e, n) {
|
|
3498
|
+
this.setCenterInternal(
|
|
3499
|
+
Mt(
|
|
3500
|
+
t,
|
|
3501
|
+
e,
|
|
3502
|
+
n,
|
|
3503
|
+
this.getResolution(),
|
|
3504
|
+
this.getRotation()
|
|
3505
|
+
)
|
|
3506
|
+
);
|
|
3507
|
+
}
|
|
3508
|
+
/**
|
|
3509
|
+
* Calculates the shift between map and viewport center.
|
|
3510
|
+
* @param {import("./coordinate.js").Coordinate} center Center.
|
|
3511
|
+
* @param {number} resolution Resolution.
|
|
3512
|
+
* @param {number} rotation Rotation.
|
|
3513
|
+
* @param {import("./size.js").Size} size Size.
|
|
3514
|
+
* @return {Array<number>|undefined} Center shift.
|
|
3515
|
+
*/
|
|
3516
|
+
calculateCenterShift(t, e, n, s) {
|
|
3517
|
+
let r;
|
|
3518
|
+
const o = this.padding_;
|
|
3519
|
+
if (o && t) {
|
|
3520
|
+
const a = this.getViewportSizeMinusPadding_(-n), l = Mt(
|
|
3521
|
+
t,
|
|
3522
|
+
s,
|
|
3523
|
+
[a[0] / 2 + o[3], a[1] / 2 + o[0]],
|
|
3524
|
+
e,
|
|
3525
|
+
n
|
|
3526
|
+
);
|
|
3527
|
+
r = [
|
|
3528
|
+
t[0] - l[0],
|
|
3529
|
+
t[1] - l[1]
|
|
3530
|
+
];
|
|
3531
|
+
}
|
|
3532
|
+
return r;
|
|
3533
|
+
}
|
|
3534
|
+
/**
|
|
3535
|
+
* @return {boolean} Is defined.
|
|
3536
|
+
*/
|
|
3537
|
+
isDef() {
|
|
3538
|
+
return !!this.getCenterInternal() && this.getResolution() !== void 0;
|
|
3539
|
+
}
|
|
3540
|
+
/**
|
|
3541
|
+
* Adds relative coordinates to the center of the view. Any extent constraint will apply.
|
|
3542
|
+
* @param {import("./coordinate.js").Coordinate} deltaCoordinates Relative value to add.
|
|
3543
|
+
* @api
|
|
3544
|
+
*/
|
|
3545
|
+
adjustCenter(t) {
|
|
3546
|
+
const e = Jt(this.targetCenter_, this.getProjection());
|
|
3547
|
+
this.setCenter([
|
|
3548
|
+
e[0] + t[0],
|
|
3549
|
+
e[1] + t[1]
|
|
3550
|
+
]);
|
|
3551
|
+
}
|
|
3552
|
+
/**
|
|
3553
|
+
* Adds relative coordinates to the center of the view. Any extent constraint will apply.
|
|
3554
|
+
* @param {import("./coordinate.js").Coordinate} deltaCoordinates Relative value to add.
|
|
3555
|
+
*/
|
|
3556
|
+
adjustCenterInternal(t) {
|
|
3557
|
+
const e = this.targetCenter_;
|
|
3558
|
+
this.setCenterInternal([
|
|
3559
|
+
e[0] + t[0],
|
|
3560
|
+
e[1] + t[1]
|
|
3561
|
+
]);
|
|
3562
|
+
}
|
|
3563
|
+
/**
|
|
3564
|
+
* Multiply the view resolution by a ratio, optionally using an anchor. Any resolution
|
|
3565
|
+
* constraint will apply.
|
|
3566
|
+
* @param {number} ratio The ratio to apply on the view resolution.
|
|
3567
|
+
* @param {import("./coordinate.js").Coordinate} [anchor] The origin of the transformation.
|
|
3568
|
+
* @api
|
|
3569
|
+
*/
|
|
3570
|
+
adjustResolution(t, e) {
|
|
3571
|
+
e = e && S(e, this.getProjection()), this.adjustResolutionInternal(t, e);
|
|
3572
|
+
}
|
|
3573
|
+
/**
|
|
3574
|
+
* Multiply the view resolution by a ratio, optionally using an anchor. Any resolution
|
|
3575
|
+
* constraint will apply.
|
|
3576
|
+
* @param {number} ratio The ratio to apply on the view resolution.
|
|
3577
|
+
* @param {import("./coordinate.js").Coordinate} [anchor] The origin of the transformation.
|
|
3578
|
+
*/
|
|
3579
|
+
adjustResolutionInternal(t, e) {
|
|
3580
|
+
const n = this.getAnimating() || this.getInteracting(), s = this.getViewportSize_(this.getRotation()), r = this.constraints_.resolution(
|
|
3581
|
+
this.targetResolution_ * t,
|
|
3582
|
+
0,
|
|
3583
|
+
s,
|
|
3584
|
+
n
|
|
3585
|
+
);
|
|
3586
|
+
e && (this.targetCenter_ = this.calculateCenterZoom(r, e)), this.targetResolution_ *= t, this.applyTargetState_();
|
|
3587
|
+
}
|
|
3588
|
+
/**
|
|
3589
|
+
* Adds a value to the view zoom level, optionally using an anchor. Any resolution
|
|
3590
|
+
* constraint will apply.
|
|
3591
|
+
* @param {number} delta Relative value to add to the zoom level.
|
|
3592
|
+
* @param {import("./coordinate.js").Coordinate} [anchor] The origin of the transformation.
|
|
3593
|
+
* @api
|
|
3594
|
+
*/
|
|
3595
|
+
adjustZoom(t, e) {
|
|
3596
|
+
this.adjustResolution(Math.pow(this.zoomFactor_, -t), e);
|
|
3597
|
+
}
|
|
3598
|
+
/**
|
|
3599
|
+
* Adds a value to the view rotation, optionally using an anchor. Any rotation
|
|
3600
|
+
* constraint will apply.
|
|
3601
|
+
* @param {number} delta Relative value to add to the zoom rotation, in radians.
|
|
3602
|
+
* @param {import("./coordinate.js").Coordinate} [anchor] The rotation center.
|
|
3603
|
+
* @api
|
|
3604
|
+
*/
|
|
3605
|
+
adjustRotation(t, e) {
|
|
3606
|
+
e && (e = S(e, this.getProjection())), this.adjustRotationInternal(t, e);
|
|
3607
|
+
}
|
|
3608
|
+
/**
|
|
3609
|
+
* @param {number} delta Relative value to add to the zoom rotation, in radians.
|
|
3610
|
+
* @param {import("./coordinate.js").Coordinate} [anchor] The rotation center.
|
|
3611
|
+
*/
|
|
3612
|
+
adjustRotationInternal(t, e) {
|
|
3613
|
+
const n = this.getAnimating() || this.getInteracting(), s = this.constraints_.rotation(
|
|
3614
|
+
this.targetRotation_ + t,
|
|
3615
|
+
n
|
|
3616
|
+
);
|
|
3617
|
+
e && (this.targetCenter_ = this.calculateCenterRotate(s, e)), this.targetRotation_ += t, this.applyTargetState_();
|
|
3618
|
+
}
|
|
3619
|
+
/**
|
|
3620
|
+
* Set the center of the current view. Any extent constraint will apply.
|
|
3621
|
+
* @param {import("./coordinate.js").Coordinate|undefined} center The center of the view.
|
|
3622
|
+
* @observable
|
|
3623
|
+
* @api
|
|
3624
|
+
*/
|
|
3625
|
+
setCenter(t) {
|
|
3626
|
+
this.setCenterInternal(
|
|
3627
|
+
t && S(t, this.getProjection())
|
|
3628
|
+
);
|
|
3629
|
+
}
|
|
3630
|
+
/**
|
|
3631
|
+
* Set the center using the view projection (not the user projection).
|
|
3632
|
+
* @param {import("./coordinate.js").Coordinate|undefined} center The center of the view.
|
|
3633
|
+
*/
|
|
3634
|
+
setCenterInternal(t) {
|
|
3635
|
+
this.targetCenter_ = t, this.applyTargetState_();
|
|
3636
|
+
}
|
|
3637
|
+
/**
|
|
3638
|
+
* @param {import("./ViewHint.js").default} hint Hint.
|
|
3639
|
+
* @param {number} delta Delta.
|
|
3640
|
+
* @return {number} New value.
|
|
3641
|
+
*/
|
|
3642
|
+
setHint(t, e) {
|
|
3643
|
+
return this.hints_[t] += e, this.changed(), this.hints_[t];
|
|
3644
|
+
}
|
|
3645
|
+
/**
|
|
3646
|
+
* Set the resolution for this view. Any resolution constraint will apply.
|
|
3647
|
+
* @param {number|undefined} resolution The resolution of the view.
|
|
3648
|
+
* @observable
|
|
3649
|
+
* @api
|
|
3650
|
+
*/
|
|
3651
|
+
setResolution(t) {
|
|
3652
|
+
this.targetResolution_ = t, this.applyTargetState_();
|
|
3653
|
+
}
|
|
3654
|
+
/**
|
|
3655
|
+
* Set the rotation for this view. Any rotation constraint will apply.
|
|
3656
|
+
* @param {number} rotation The rotation of the view in radians.
|
|
3657
|
+
* @observable
|
|
3658
|
+
* @api
|
|
3659
|
+
*/
|
|
3660
|
+
setRotation(t) {
|
|
3661
|
+
this.targetRotation_ = t, this.applyTargetState_();
|
|
3662
|
+
}
|
|
3663
|
+
/**
|
|
3664
|
+
* Zoom to a specific zoom level. Any resolution constrain will apply.
|
|
3665
|
+
* @param {number} zoom Zoom level.
|
|
3666
|
+
* @api
|
|
3667
|
+
*/
|
|
3668
|
+
setZoom(t) {
|
|
3669
|
+
this.setResolution(this.getResolutionForZoom(t));
|
|
3670
|
+
}
|
|
3671
|
+
/**
|
|
3672
|
+
* Recompute rotation/resolution/center based on target values.
|
|
3673
|
+
* Note: we have to compute rotation first, then resolution and center considering that
|
|
3674
|
+
* parameters can influence one another in case a view extent constraint is present.
|
|
3675
|
+
* @param {boolean} [doNotCancelAnims] Do not cancel animations.
|
|
3676
|
+
* @param {boolean} [forceMoving] Apply constraints as if the view is moving.
|
|
3677
|
+
* @private
|
|
3678
|
+
*/
|
|
3679
|
+
applyTargetState_(t, e) {
|
|
3680
|
+
const n = this.getAnimating() || this.getInteracting() || e, s = this.constraints_.rotation(
|
|
3681
|
+
this.targetRotation_,
|
|
3682
|
+
n
|
|
3683
|
+
), r = this.getViewportSize_(s), o = this.constraints_.resolution(
|
|
3684
|
+
this.targetResolution_,
|
|
3685
|
+
0,
|
|
3686
|
+
r,
|
|
3687
|
+
n
|
|
3688
|
+
), a = this.constraints_.center(
|
|
3689
|
+
this.targetCenter_,
|
|
3690
|
+
o,
|
|
3691
|
+
r,
|
|
3692
|
+
n,
|
|
3693
|
+
this.calculateCenterShift(
|
|
3694
|
+
this.targetCenter_,
|
|
3695
|
+
o,
|
|
3696
|
+
s,
|
|
3697
|
+
r
|
|
3698
|
+
)
|
|
3699
|
+
);
|
|
3700
|
+
this.get(I.ROTATION) !== s && this.set(I.ROTATION, s), this.get(I.RESOLUTION) !== o && (this.set(I.RESOLUTION, o), this.set("zoom", this.getZoom(), !0)), (!a || !this.get(I.CENTER) || !ot(this.get(I.CENTER), a)) && this.set(I.CENTER, a), this.getAnimating() && !t && this.cancelAnimations(), this.cancelAnchor_ = void 0;
|
|
3701
|
+
}
|
|
3702
|
+
/**
|
|
3703
|
+
* If any constraints need to be applied, an animation will be triggered.
|
|
3704
|
+
* This is typically done on interaction end.
|
|
3705
|
+
* Note: calling this with a duration of 0 will apply the constrained values straight away,
|
|
3706
|
+
* without animation.
|
|
3707
|
+
* @param {number} [duration] The animation duration in ms.
|
|
3708
|
+
* @param {number} [resolutionDirection] Which direction to zoom.
|
|
3709
|
+
* @param {import("./coordinate.js").Coordinate} [anchor] The origin of the transformation.
|
|
3710
|
+
*/
|
|
3711
|
+
resolveConstraints(t, e, n) {
|
|
3712
|
+
t = t !== void 0 ? t : 200;
|
|
3713
|
+
const s = e || 0, r = this.constraints_.rotation(this.targetRotation_), o = this.getViewportSize_(r), a = this.constraints_.resolution(
|
|
3714
|
+
this.targetResolution_,
|
|
3715
|
+
s,
|
|
3716
|
+
o
|
|
3717
|
+
), l = this.constraints_.center(
|
|
3718
|
+
this.targetCenter_,
|
|
3719
|
+
a,
|
|
3720
|
+
o,
|
|
3721
|
+
!1,
|
|
3722
|
+
this.calculateCenterShift(
|
|
3723
|
+
this.targetCenter_,
|
|
3724
|
+
a,
|
|
3725
|
+
r,
|
|
3726
|
+
o
|
|
3727
|
+
)
|
|
3728
|
+
);
|
|
3729
|
+
if (t === 0 && !this.cancelAnchor_) {
|
|
3730
|
+
this.targetResolution_ = a, this.targetRotation_ = r, this.targetCenter_ = l, this.applyTargetState_();
|
|
3731
|
+
return;
|
|
3732
|
+
}
|
|
3733
|
+
n = n || (t === 0 ? this.cancelAnchor_ : void 0), this.cancelAnchor_ = void 0, (this.getResolution() !== a || this.getRotation() !== r || !this.getCenterInternal() || !ot(this.getCenterInternal(), l)) && (this.getAnimating() && this.cancelAnimations(), this.animateInternal({
|
|
3734
|
+
rotation: r,
|
|
3735
|
+
center: l,
|
|
3736
|
+
resolution: a,
|
|
3737
|
+
duration: t,
|
|
3738
|
+
easing: pi,
|
|
3739
|
+
anchor: n
|
|
3740
|
+
}));
|
|
3741
|
+
}
|
|
3742
|
+
/**
|
|
3743
|
+
* Notify the View that an interaction has started.
|
|
3744
|
+
* The view state will be resolved to a stable one if needed
|
|
3745
|
+
* (depending on its constraints).
|
|
3746
|
+
* @api
|
|
3747
|
+
*/
|
|
3748
|
+
beginInteraction() {
|
|
3749
|
+
this.resolveConstraints(0), this.setHint(A.INTERACTING, 1);
|
|
3750
|
+
}
|
|
3751
|
+
/**
|
|
3752
|
+
* Notify the View that an interaction has ended. The view state will be resolved
|
|
3753
|
+
* to a stable one if needed (depending on its constraints).
|
|
3754
|
+
* @param {number} [duration] Animation duration in ms.
|
|
3755
|
+
* @param {number} [resolutionDirection] Which direction to zoom.
|
|
3756
|
+
* @param {import("./coordinate.js").Coordinate} [anchor] The origin of the transformation.
|
|
3757
|
+
* @api
|
|
3758
|
+
*/
|
|
3759
|
+
endInteraction(t, e, n) {
|
|
3760
|
+
n = n && S(n, this.getProjection()), this.endInteractionInternal(t, e, n);
|
|
3761
|
+
}
|
|
3762
|
+
/**
|
|
3763
|
+
* Notify the View that an interaction has ended. The view state will be resolved
|
|
3764
|
+
* to a stable one if needed (depending on its constraints).
|
|
3765
|
+
* @param {number} [duration] Animation duration in ms.
|
|
3766
|
+
* @param {number} [resolutionDirection] Which direction to zoom.
|
|
3767
|
+
* @param {import("./coordinate.js").Coordinate} [anchor] The origin of the transformation.
|
|
3768
|
+
*/
|
|
3769
|
+
endInteractionInternal(t, e, n) {
|
|
3770
|
+
this.getInteracting() && (this.setHint(A.INTERACTING, -1), this.resolveConstraints(t, e, n));
|
|
3771
|
+
}
|
|
3772
|
+
/**
|
|
3773
|
+
* Get a valid position for the view center according to the current constraints.
|
|
3774
|
+
* @param {import("./coordinate.js").Coordinate|undefined} targetCenter Target center position.
|
|
3775
|
+
* @param {number} [targetResolution] Target resolution. If not supplied, the current one will be used.
|
|
3776
|
+
* This is useful to guess a valid center position at a different zoom level.
|
|
3777
|
+
* @return {import("./coordinate.js").Coordinate|undefined} Valid center position.
|
|
3778
|
+
*/
|
|
3779
|
+
getConstrainedCenter(t, e) {
|
|
3780
|
+
const n = this.getViewportSize_(this.getRotation());
|
|
3781
|
+
return this.constraints_.center(
|
|
3782
|
+
t,
|
|
3783
|
+
e || this.getResolution(),
|
|
3784
|
+
n
|
|
3785
|
+
);
|
|
3786
|
+
}
|
|
3787
|
+
/**
|
|
3788
|
+
* Get a valid zoom level according to the current view constraints.
|
|
3789
|
+
* @param {number|undefined} targetZoom Target zoom.
|
|
3790
|
+
* @param {number} [direction] Indicate which resolution should be used
|
|
3791
|
+
* by a renderer if the view resolution does not match any resolution of the tile source.
|
|
3792
|
+
* If 0, the nearest resolution will be used. If 1, the nearest lower resolution
|
|
3793
|
+
* will be used. If -1, the nearest higher resolution will be used.
|
|
3794
|
+
* @return {number|undefined} Valid zoom level.
|
|
3795
|
+
*/
|
|
3796
|
+
getConstrainedZoom(t, e) {
|
|
3797
|
+
const n = this.getResolutionForZoom(t);
|
|
3798
|
+
return this.getZoomForResolution(
|
|
3799
|
+
this.getConstrainedResolution(n, e)
|
|
3800
|
+
);
|
|
3801
|
+
}
|
|
3802
|
+
/**
|
|
3803
|
+
* Get a valid resolution according to the current view constraints.
|
|
3804
|
+
* @param {number|undefined} targetResolution Target resolution.
|
|
3805
|
+
* @param {number} [direction] Indicate which resolution should be used
|
|
3806
|
+
* by a renderer if the view resolution does not match any resolution of the tile source.
|
|
3807
|
+
* If 0, the nearest resolution will be used. If 1, the nearest lower resolution
|
|
3808
|
+
* will be used. If -1, the nearest higher resolution will be used.
|
|
3809
|
+
* @return {number|undefined} Valid resolution.
|
|
3810
|
+
*/
|
|
3811
|
+
getConstrainedResolution(t, e) {
|
|
3812
|
+
e = e || 0;
|
|
3813
|
+
const n = this.getViewportSize_(this.getRotation());
|
|
3814
|
+
return this.constraints_.resolution(t, e, n);
|
|
3815
|
+
}
|
|
3816
|
+
}
|
|
3817
|
+
function nt(i, t) {
|
|
3818
|
+
setTimeout(function() {
|
|
3819
|
+
i(t);
|
|
3820
|
+
}, 0);
|
|
3821
|
+
}
|
|
3822
|
+
function Pi(i) {
|
|
3823
|
+
if (i.extent !== void 0) {
|
|
3824
|
+
const e = i.smoothExtentConstraint !== void 0 ? i.smoothExtentConstraint : !0;
|
|
3825
|
+
return re(i.extent, i.constrainOnlyCenter, e);
|
|
3826
|
+
}
|
|
3827
|
+
const t = vt(i.projection, "EPSG:3857");
|
|
3828
|
+
if (i.multiWorld !== !0 && t.isGlobal()) {
|
|
3829
|
+
const e = t.getExtent().slice();
|
|
3830
|
+
return e[0] = -1 / 0, e[2] = 1 / 0, re(e, !1, !1);
|
|
3831
|
+
}
|
|
3832
|
+
return Ci;
|
|
3833
|
+
}
|
|
3834
|
+
function Fi(i) {
|
|
3835
|
+
let t, e, n, o = i.minZoom !== void 0 ? i.minZoom : xt, a = i.maxZoom !== void 0 ? i.maxZoom : 28;
|
|
3836
|
+
const l = i.zoomFactor !== void 0 ? i.zoomFactor : 2, h = i.multiWorld !== void 0 ? i.multiWorld : !1, u = i.smoothResolutionConstraint !== void 0 ? i.smoothResolutionConstraint : !0, c = i.showFullExtent !== void 0 ? i.showFullExtent : !1, f = vt(i.projection, "EPSG:3857"), g = f.getExtent();
|
|
3837
|
+
let d = i.constrainOnlyCenter, m = i.extent;
|
|
3838
|
+
if (!h && !m && f.isGlobal() && (d = !1, m = g), i.resolutions !== void 0) {
|
|
3839
|
+
const _ = i.resolutions;
|
|
3840
|
+
e = _[o], n = _[a] !== void 0 ? _[a] : _[_.length - 1], i.constrainResolution ? t = Ii(
|
|
3841
|
+
_,
|
|
3842
|
+
u,
|
|
3843
|
+
!d && m,
|
|
3844
|
+
c
|
|
3845
|
+
) : t = oe(
|
|
3846
|
+
e,
|
|
3847
|
+
n,
|
|
3848
|
+
u,
|
|
3849
|
+
!d && m,
|
|
3850
|
+
c
|
|
3851
|
+
);
|
|
3852
|
+
} else {
|
|
3853
|
+
const x = (g ? Math.max(D(g), k(g)) : (
|
|
3854
|
+
// use an extent that can fit the whole world if need be
|
|
3855
|
+
360 * Ce.degrees / f.getMetersPerUnit()
|
|
3856
|
+
)) / je / Math.pow(2, xt), R = x / Math.pow(2, 28 - xt);
|
|
3857
|
+
e = i.maxResolution, e !== void 0 ? o = 0 : e = x / Math.pow(l, o), n = i.minResolution, n === void 0 && (i.maxZoom !== void 0 ? i.maxResolution !== void 0 ? n = e / Math.pow(l, a) : n = x / Math.pow(l, a) : n = R), a = o + Math.floor(
|
|
3858
|
+
Math.log(e / n) / Math.log(l)
|
|
3859
|
+
), n = e / Math.pow(l, a - o), i.constrainResolution ? t = yi(
|
|
3860
|
+
l,
|
|
3861
|
+
e,
|
|
3862
|
+
n,
|
|
3863
|
+
u,
|
|
3864
|
+
!d && m,
|
|
3865
|
+
c
|
|
3866
|
+
) : t = oe(
|
|
3867
|
+
e,
|
|
3868
|
+
n,
|
|
3869
|
+
u,
|
|
3870
|
+
!d && m,
|
|
3871
|
+
c
|
|
3872
|
+
);
|
|
3873
|
+
}
|
|
3874
|
+
return {
|
|
3875
|
+
constraint: t,
|
|
3876
|
+
maxResolution: e,
|
|
3877
|
+
minResolution: n,
|
|
3878
|
+
minZoom: o,
|
|
3879
|
+
zoomFactor: l
|
|
3880
|
+
};
|
|
3881
|
+
}
|
|
3882
|
+
function Xi(i) {
|
|
3883
|
+
if (i.enableRotation !== void 0 ? i.enableRotation : !0) {
|
|
3884
|
+
const e = i.constrainRotation;
|
|
3885
|
+
return e === void 0 || e === !0 ? Ai() : e === !1 ? ae : typeof e == "number" ? Si(e) : ae;
|
|
3886
|
+
}
|
|
3887
|
+
return wi;
|
|
3888
|
+
}
|
|
3889
|
+
function Ni(i) {
|
|
3890
|
+
return !(i.sourceCenter && i.targetCenter && !ot(i.sourceCenter, i.targetCenter) || i.sourceResolution !== i.targetResolution || i.sourceRotation !== i.targetRotation);
|
|
3891
|
+
}
|
|
3892
|
+
function Mt(i, t, e, n, s) {
|
|
3893
|
+
const r = Math.cos(-s);
|
|
3894
|
+
let o = Math.sin(-s), a = i[0] * r - i[1] * o, l = i[1] * r + i[0] * o;
|
|
3895
|
+
a += (t[0] / 2 - e[0]) * n, l += (e[1] - t[1] / 2) * n, o = -o;
|
|
3896
|
+
const h = a * r - l * o, u = l * r + a * o;
|
|
3897
|
+
return [h, u];
|
|
3898
|
+
}
|
|
3899
|
+
class ze {
|
|
3900
|
+
/**
|
|
3901
|
+
* @param {number} minX Minimum X.
|
|
3902
|
+
* @param {number} maxX Maximum X.
|
|
3903
|
+
* @param {number} minY Minimum Y.
|
|
3904
|
+
* @param {number} maxY Maximum Y.
|
|
3905
|
+
*/
|
|
3906
|
+
constructor(t, e, n, s) {
|
|
3907
|
+
this.minX = t, this.maxX = e, this.minY = n, this.maxY = s;
|
|
3908
|
+
}
|
|
3909
|
+
/**
|
|
3910
|
+
* @param {import("./tilecoord.js").TileCoord} tileCoord Tile coordinate.
|
|
3911
|
+
* @return {boolean} Contains tile coordinate.
|
|
3912
|
+
*/
|
|
3913
|
+
contains(t) {
|
|
3914
|
+
return this.containsXY(t[1], t[2]);
|
|
3915
|
+
}
|
|
3916
|
+
/**
|
|
3917
|
+
* @param {TileRange} tileRange Tile range.
|
|
3918
|
+
* @return {boolean} Contains.
|
|
3919
|
+
*/
|
|
3920
|
+
containsTileRange(t) {
|
|
3921
|
+
return this.minX <= t.minX && t.maxX <= this.maxX && this.minY <= t.minY && t.maxY <= this.maxY;
|
|
3922
|
+
}
|
|
3923
|
+
/**
|
|
3924
|
+
* @param {number} x Tile coordinate x.
|
|
3925
|
+
* @param {number} y Tile coordinate y.
|
|
3926
|
+
* @return {boolean} Contains coordinate.
|
|
3927
|
+
*/
|
|
3928
|
+
containsXY(t, e) {
|
|
3929
|
+
return this.minX <= t && t <= this.maxX && this.minY <= e && e <= this.maxY;
|
|
3930
|
+
}
|
|
3931
|
+
/**
|
|
3932
|
+
* @param {TileRange} tileRange Tile range.
|
|
3933
|
+
* @return {boolean} Equals.
|
|
3934
|
+
*/
|
|
3935
|
+
equals(t) {
|
|
3936
|
+
return this.minX == t.minX && this.minY == t.minY && this.maxX == t.maxX && this.maxY == t.maxY;
|
|
3937
|
+
}
|
|
3938
|
+
/**
|
|
3939
|
+
* @param {TileRange} tileRange Tile range.
|
|
3940
|
+
*/
|
|
3941
|
+
extend(t) {
|
|
3942
|
+
t.minX < this.minX && (this.minX = t.minX), t.maxX > this.maxX && (this.maxX = t.maxX), t.minY < this.minY && (this.minY = t.minY), t.maxY > this.maxY && (this.maxY = t.maxY);
|
|
3943
|
+
}
|
|
3944
|
+
/**
|
|
3945
|
+
* @return {number} Height.
|
|
3946
|
+
*/
|
|
3947
|
+
getHeight() {
|
|
3948
|
+
return this.maxY - this.minY + 1;
|
|
3949
|
+
}
|
|
3950
|
+
/**
|
|
3951
|
+
* @return {import("./size.js").Size} Size.
|
|
3952
|
+
*/
|
|
3953
|
+
getSize() {
|
|
3954
|
+
return [this.getWidth(), this.getHeight()];
|
|
3955
|
+
}
|
|
3956
|
+
/**
|
|
3957
|
+
* @return {number} Width.
|
|
3958
|
+
*/
|
|
3959
|
+
getWidth() {
|
|
3960
|
+
return this.maxX - this.minX + 1;
|
|
3961
|
+
}
|
|
3962
|
+
/**
|
|
3963
|
+
* @param {TileRange} tileRange Tile range.
|
|
3964
|
+
* @return {boolean} Intersects.
|
|
3965
|
+
*/
|
|
3966
|
+
intersects(t) {
|
|
3967
|
+
return this.minX <= t.maxX && this.maxX >= t.minX && this.minY <= t.maxY && this.maxY >= t.minY;
|
|
3968
|
+
}
|
|
3969
|
+
}
|
|
3970
|
+
function O(i, t, e, n, s) {
|
|
3971
|
+
return s !== void 0 ? (s.minX = i, s.maxX = t, s.minY = e, s.maxY = n, s) : new ze(i, t, e, n);
|
|
3972
|
+
}
|
|
3973
|
+
function Yi(i) {
|
|
3974
|
+
const t = Object.keys(i.defs), e = t.length;
|
|
3975
|
+
let n, s;
|
|
3976
|
+
for (n = 0; n < e; ++n) {
|
|
3977
|
+
const r = t[n];
|
|
3978
|
+
if (!it(r)) {
|
|
3979
|
+
const o = i.defs(r);
|
|
3980
|
+
let a = (
|
|
3981
|
+
/** @type {import("./Units.js").Units} */
|
|
3982
|
+
o.units
|
|
3983
|
+
);
|
|
3984
|
+
!a && o.projName === "longlat" && (a = "degrees"), ut(
|
|
3985
|
+
new ft({
|
|
3986
|
+
code: r,
|
|
3987
|
+
axisOrientation: o.axis,
|
|
3988
|
+
metersPerUnit: o.to_meter,
|
|
3989
|
+
units: a
|
|
3990
|
+
})
|
|
3991
|
+
);
|
|
3992
|
+
}
|
|
3993
|
+
}
|
|
3994
|
+
for (n = 0; n < e; ++n) {
|
|
3995
|
+
const r = t[n], o = it(r);
|
|
3996
|
+
for (s = 0; s < e; ++s) {
|
|
3997
|
+
const a = t[s], l = it(a);
|
|
3998
|
+
if (!st(r, a))
|
|
3999
|
+
if (i.defs[r] === i.defs[a])
|
|
4000
|
+
yt([o, l]);
|
|
4001
|
+
else {
|
|
4002
|
+
const h = i(r, a);
|
|
4003
|
+
$n(
|
|
4004
|
+
o,
|
|
4005
|
+
l,
|
|
4006
|
+
Qt(o, l, h.forward),
|
|
4007
|
+
Qt(l, o, h.inverse)
|
|
4008
|
+
);
|
|
4009
|
+
}
|
|
4010
|
+
}
|
|
4011
|
+
}
|
|
4012
|
+
}
|
|
4013
|
+
function le(i, t, e, n) {
|
|
4014
|
+
return n !== void 0 ? (n[0] = i, n[1] = t, n[2] = e, n) : [i, t, e];
|
|
4015
|
+
}
|
|
4016
|
+
const L = [0, 0, 0], v = 5;
|
|
4017
|
+
class Zi {
|
|
4018
|
+
/**
|
|
4019
|
+
* @param {Options} options Tile grid options.
|
|
4020
|
+
*/
|
|
4021
|
+
constructor(t) {
|
|
4022
|
+
this.minZoom = t.minZoom !== void 0 ? t.minZoom : 0, this.resolutions_ = t.resolutions, y(
|
|
4023
|
+
$e(
|
|
4024
|
+
this.resolutions_,
|
|
4025
|
+
/**
|
|
4026
|
+
* @param {number} a First resolution
|
|
4027
|
+
* @param {number} b Second resolution
|
|
4028
|
+
* @return {number} Comparison result
|
|
4029
|
+
*/
|
|
4030
|
+
(s, r) => r - s
|
|
4031
|
+
),
|
|
4032
|
+
"`resolutions` must be sorted in descending order"
|
|
4033
|
+
);
|
|
4034
|
+
let e;
|
|
4035
|
+
if (!t.origins) {
|
|
4036
|
+
for (let s = 0, r = this.resolutions_.length - 1; s < r; ++s)
|
|
4037
|
+
if (!e)
|
|
4038
|
+
e = this.resolutions_[s] / this.resolutions_[s + 1];
|
|
4039
|
+
else if (this.resolutions_[s] / this.resolutions_[s + 1] !== e) {
|
|
4040
|
+
e = void 0;
|
|
4041
|
+
break;
|
|
4042
|
+
}
|
|
4043
|
+
}
|
|
4044
|
+
this.zoomFactor_ = e, this.maxZoom = this.resolutions_.length - 1, this.origin_ = t.origin !== void 0 ? t.origin : null, this.origins_ = null, t.origins !== void 0 && (this.origins_ = t.origins, y(
|
|
4045
|
+
this.origins_.length == this.resolutions_.length,
|
|
4046
|
+
"Number of `origins` and `resolutions` must be equal"
|
|
4047
|
+
));
|
|
4048
|
+
const n = t.extent;
|
|
4049
|
+
n !== void 0 && !this.origin_ && !this.origins_ && (this.origin_ = Re(n)), y(
|
|
4050
|
+
!this.origin_ && this.origins_ || this.origin_ && !this.origins_,
|
|
4051
|
+
"Either `origin` or `origins` must be configured, never both"
|
|
4052
|
+
), this.tileSizes_ = null, t.tileSizes !== void 0 && (this.tileSizes_ = t.tileSizes, y(
|
|
4053
|
+
this.tileSizes_.length == this.resolutions_.length,
|
|
4054
|
+
"Number of `tileSizes` and `resolutions` must be equal"
|
|
4055
|
+
)), this.tileSize_ = t.tileSize !== void 0 ? t.tileSize : this.tileSizes_ ? null : je, y(
|
|
4056
|
+
!this.tileSize_ && this.tileSizes_ || this.tileSize_ && !this.tileSizes_,
|
|
4057
|
+
"Either `tileSize` or `tileSizes` must be configured, never both"
|
|
4058
|
+
), this.extent_ = n !== void 0 ? n : null, this.fullTileRanges_ = null, this.tmpSize_ = [0, 0], this.tmpExtent_ = [0, 0, 0, 0], t.sizes !== void 0 ? this.fullTileRanges_ = t.sizes.map((s, r) => {
|
|
4059
|
+
const o = new ze(
|
|
4060
|
+
Math.min(0, s[0]),
|
|
4061
|
+
Math.max(s[0] - 1, -1),
|
|
4062
|
+
Math.min(0, s[1]),
|
|
4063
|
+
Math.max(s[1] - 1, -1)
|
|
4064
|
+
);
|
|
4065
|
+
if (n) {
|
|
4066
|
+
const a = this.getTileRangeForExtentAndZ(n, r);
|
|
4067
|
+
o.minX = Math.max(a.minX, o.minX), o.maxX = Math.min(a.maxX, o.maxX), o.minY = Math.max(a.minY, o.minY), o.maxY = Math.min(a.maxY, o.maxY);
|
|
4068
|
+
}
|
|
4069
|
+
return o;
|
|
4070
|
+
}) : n && this.calculateTileRanges_(n);
|
|
4071
|
+
}
|
|
4072
|
+
/**
|
|
4073
|
+
* Call a function with each tile coordinate for a given extent and zoom level.
|
|
4074
|
+
*
|
|
4075
|
+
* @param {import("../extent.js").Extent} extent Extent.
|
|
4076
|
+
* @param {number} zoom Integer zoom level.
|
|
4077
|
+
* @param {function(import("../tilecoord.js").TileCoord): void} callback Function called with each tile coordinate.
|
|
4078
|
+
* @api
|
|
4079
|
+
*/
|
|
4080
|
+
forEachTileCoord(t, e, n) {
|
|
4081
|
+
const s = this.getTileRangeForExtentAndZ(t, e);
|
|
4082
|
+
for (let r = s.minX, o = s.maxX; r <= o; ++r)
|
|
4083
|
+
for (let a = s.minY, l = s.maxY; a <= l; ++a)
|
|
4084
|
+
n([e, r, a]);
|
|
4085
|
+
}
|
|
4086
|
+
/**
|
|
4087
|
+
* @param {import("../tilecoord.js").TileCoord} tileCoord Tile coordinate.
|
|
4088
|
+
* @param {function(number, import("../TileRange.js").default): boolean} callback Callback.
|
|
4089
|
+
* @param {import("../TileRange.js").default} [tempTileRange] Temporary import("../TileRange.js").default object.
|
|
4090
|
+
* @param {import("../extent.js").Extent} [tempExtent] Temporary import("../extent.js").Extent object.
|
|
4091
|
+
* @return {boolean} Callback succeeded.
|
|
4092
|
+
*/
|
|
4093
|
+
forEachTileCoordParentTileRange(t, e, n, s) {
|
|
4094
|
+
let r, o, a, l = null, h = t[0] - 1;
|
|
4095
|
+
for (this.zoomFactor_ === 2 ? (o = t[1], a = t[2]) : l = this.getTileCoordExtent(t, s); h >= this.minZoom; ) {
|
|
4096
|
+
if (o !== void 0 && a !== void 0 ? (o = Math.floor(o / 2), a = Math.floor(a / 2), r = O(o, o, a, a, n)) : r = this.getTileRangeForExtentAndZ(
|
|
4097
|
+
l,
|
|
4098
|
+
h,
|
|
4099
|
+
n
|
|
4100
|
+
), e(h, r))
|
|
4101
|
+
return !0;
|
|
4102
|
+
--h;
|
|
4103
|
+
}
|
|
4104
|
+
return !1;
|
|
4105
|
+
}
|
|
4106
|
+
/**
|
|
4107
|
+
* Get the extent for this tile grid, if it was configured.
|
|
4108
|
+
* @return {import("../extent.js").Extent} Extent.
|
|
4109
|
+
* @api
|
|
4110
|
+
*/
|
|
4111
|
+
getExtent() {
|
|
4112
|
+
return this.extent_;
|
|
4113
|
+
}
|
|
4114
|
+
/**
|
|
4115
|
+
* Get the maximum zoom level for the grid.
|
|
4116
|
+
* @return {number} Max zoom.
|
|
4117
|
+
* @api
|
|
4118
|
+
*/
|
|
4119
|
+
getMaxZoom() {
|
|
4120
|
+
return this.maxZoom;
|
|
4121
|
+
}
|
|
4122
|
+
/**
|
|
4123
|
+
* Get the minimum zoom level for the grid.
|
|
4124
|
+
* @return {number} Min zoom.
|
|
4125
|
+
* @api
|
|
4126
|
+
*/
|
|
4127
|
+
getMinZoom() {
|
|
4128
|
+
return this.minZoom;
|
|
4129
|
+
}
|
|
4130
|
+
/**
|
|
4131
|
+
* Get the origin for the grid at the given zoom level.
|
|
4132
|
+
* @param {number} z Integer zoom level.
|
|
4133
|
+
* @return {import("../coordinate.js").Coordinate} Origin.
|
|
4134
|
+
* @api
|
|
4135
|
+
*/
|
|
4136
|
+
getOrigin(t) {
|
|
4137
|
+
return this.origin_ ? this.origin_ : this.origins_[t];
|
|
4138
|
+
}
|
|
4139
|
+
/**
|
|
4140
|
+
* Get the resolution for the given zoom level.
|
|
4141
|
+
* @param {number} z Integer zoom level.
|
|
4142
|
+
* @return {number} Resolution.
|
|
4143
|
+
* @api
|
|
4144
|
+
*/
|
|
4145
|
+
getResolution(t) {
|
|
4146
|
+
return this.resolutions_[t];
|
|
4147
|
+
}
|
|
4148
|
+
/**
|
|
4149
|
+
* Get the list of resolutions for the tile grid.
|
|
4150
|
+
* @return {Array<number>} Resolutions.
|
|
4151
|
+
* @api
|
|
4152
|
+
*/
|
|
4153
|
+
getResolutions() {
|
|
4154
|
+
return this.resolutions_;
|
|
4155
|
+
}
|
|
4156
|
+
/**
|
|
4157
|
+
* @param {import("../tilecoord.js").TileCoord} tileCoord Tile coordinate.
|
|
4158
|
+
* @param {import("../TileRange.js").default} [tempTileRange] Temporary import("../TileRange.js").default object.
|
|
4159
|
+
* @param {import("../extent.js").Extent} [tempExtent] Temporary import("../extent.js").Extent object.
|
|
4160
|
+
* @return {import("../TileRange.js").default|null} Tile range.
|
|
4161
|
+
*/
|
|
4162
|
+
getTileCoordChildTileRange(t, e, n) {
|
|
4163
|
+
if (t[0] < this.maxZoom) {
|
|
4164
|
+
if (this.zoomFactor_ === 2) {
|
|
4165
|
+
const r = t[1] * 2, o = t[2] * 2;
|
|
4166
|
+
return O(
|
|
4167
|
+
r,
|
|
4168
|
+
r + 1,
|
|
4169
|
+
o,
|
|
4170
|
+
o + 1,
|
|
4171
|
+
e
|
|
4172
|
+
);
|
|
4173
|
+
}
|
|
4174
|
+
const s = this.getTileCoordExtent(
|
|
4175
|
+
t,
|
|
4176
|
+
n || this.tmpExtent_
|
|
4177
|
+
);
|
|
4178
|
+
return this.getTileRangeForExtentAndZ(
|
|
4179
|
+
s,
|
|
4180
|
+
t[0] + 1,
|
|
4181
|
+
e
|
|
4182
|
+
);
|
|
4183
|
+
}
|
|
4184
|
+
return null;
|
|
4185
|
+
}
|
|
4186
|
+
/**
|
|
4187
|
+
* @param {import("../tilecoord.js").TileCoord} tileCoord Tile coordinate.
|
|
4188
|
+
* @param {number} z Integer zoom level.
|
|
4189
|
+
* @param {import("../TileRange.js").default} [tempTileRange] Temporary import("../TileRange.js").default object.
|
|
4190
|
+
* @return {import("../TileRange.js").default|null} Tile range.
|
|
4191
|
+
*/
|
|
4192
|
+
getTileRangeForTileCoordAndZ(t, e, n) {
|
|
4193
|
+
if (e > this.maxZoom || e < this.minZoom)
|
|
4194
|
+
return null;
|
|
4195
|
+
const s = t[0], r = t[1], o = t[2];
|
|
4196
|
+
if (e === s)
|
|
4197
|
+
return O(
|
|
4198
|
+
r,
|
|
4199
|
+
o,
|
|
4200
|
+
r,
|
|
4201
|
+
o,
|
|
4202
|
+
n
|
|
4203
|
+
);
|
|
4204
|
+
if (this.zoomFactor_) {
|
|
4205
|
+
const l = Math.pow(this.zoomFactor_, e - s), h = Math.floor(r * l), u = Math.floor(o * l);
|
|
4206
|
+
if (e < s)
|
|
4207
|
+
return O(h, h, u, u, n);
|
|
4208
|
+
const c = Math.floor(l * (r + 1)) - 1, f = Math.floor(l * (o + 1)) - 1;
|
|
4209
|
+
return O(h, c, u, f, n);
|
|
4210
|
+
}
|
|
4211
|
+
const a = this.getTileCoordExtent(t, this.tmpExtent_);
|
|
4212
|
+
return this.getTileRangeForExtentAndZ(a, e, n);
|
|
4213
|
+
}
|
|
4214
|
+
/**
|
|
4215
|
+
* Get a tile range for the given extent and integer zoom level.
|
|
4216
|
+
* @param {import("../extent.js").Extent} extent Extent.
|
|
4217
|
+
* @param {number} z Integer zoom level.
|
|
4218
|
+
* @param {import("../TileRange.js").default} [tempTileRange] Temporary tile range object.
|
|
4219
|
+
* @return {import("../TileRange.js").default} Tile range.
|
|
4220
|
+
*/
|
|
4221
|
+
getTileRangeForExtentAndZ(t, e, n) {
|
|
4222
|
+
this.getTileCoordForXYAndZ_(t[0], t[3], e, !1, L);
|
|
4223
|
+
const s = L[1], r = L[2];
|
|
4224
|
+
this.getTileCoordForXYAndZ_(t[2], t[1], e, !0, L);
|
|
4225
|
+
const o = L[1], a = L[2];
|
|
4226
|
+
return O(s, o, r, a, n);
|
|
4227
|
+
}
|
|
4228
|
+
/**
|
|
4229
|
+
* @param {import("../tilecoord.js").TileCoord} tileCoord Tile coordinate.
|
|
4230
|
+
* @return {import("../coordinate.js").Coordinate} Tile center.
|
|
4231
|
+
*/
|
|
4232
|
+
getTileCoordCenter(t) {
|
|
4233
|
+
const e = this.getOrigin(t[0]), n = this.getResolution(t[0]), s = et(this.getTileSize(t[0]), this.tmpSize_);
|
|
4234
|
+
return [
|
|
4235
|
+
e[0] + (t[1] + 0.5) * s[0] * n,
|
|
4236
|
+
e[1] - (t[2] + 0.5) * s[1] * n
|
|
4237
|
+
];
|
|
4238
|
+
}
|
|
4239
|
+
/**
|
|
4240
|
+
* Get the extent of a tile coordinate.
|
|
4241
|
+
*
|
|
4242
|
+
* @param {import("../tilecoord.js").TileCoord} tileCoord Tile coordinate.
|
|
4243
|
+
* @param {import("../extent.js").Extent} [tempExtent] Temporary extent object.
|
|
4244
|
+
* @return {import("../extent.js").Extent} Extent.
|
|
4245
|
+
* @api
|
|
4246
|
+
*/
|
|
4247
|
+
getTileCoordExtent(t, e) {
|
|
4248
|
+
const n = this.getOrigin(t[0]), s = this.getResolution(t[0]), r = et(this.getTileSize(t[0]), this.tmpSize_), o = n[0] + t[1] * r[0] * s, a = n[1] - (t[2] + 1) * r[1] * s, l = o + r[0] * s, h = a + r[1] * s;
|
|
4249
|
+
return ct(o, a, l, h, e);
|
|
4250
|
+
}
|
|
4251
|
+
/**
|
|
4252
|
+
* Get the tile coordinate for the given map coordinate and resolution. This
|
|
4253
|
+
* method considers that coordinates that intersect tile boundaries should be
|
|
4254
|
+
* assigned the higher tile coordinate.
|
|
4255
|
+
*
|
|
4256
|
+
* @param {import("../coordinate.js").Coordinate} coordinate Coordinate.
|
|
4257
|
+
* @param {number} resolution Resolution.
|
|
4258
|
+
* @param {import("../tilecoord.js").TileCoord} [opt_tileCoord] Destination import("../tilecoord.js").TileCoord object.
|
|
4259
|
+
* @return {import("../tilecoord.js").TileCoord} Tile coordinate.
|
|
4260
|
+
* @api
|
|
4261
|
+
*/
|
|
4262
|
+
getTileCoordForCoordAndResolution(t, e, n) {
|
|
4263
|
+
return this.getTileCoordForXYAndResolution_(
|
|
4264
|
+
t[0],
|
|
4265
|
+
t[1],
|
|
4266
|
+
e,
|
|
4267
|
+
!1,
|
|
4268
|
+
n
|
|
4269
|
+
);
|
|
4270
|
+
}
|
|
4271
|
+
/**
|
|
4272
|
+
* Note that this method should not be called for resolutions that correspond
|
|
4273
|
+
* to an integer zoom level. Instead call the `getTileCoordForXYAndZ_` method.
|
|
4274
|
+
* @param {number} x X.
|
|
4275
|
+
* @param {number} y Y.
|
|
4276
|
+
* @param {number} resolution Resolution (for a non-integer zoom level).
|
|
4277
|
+
* @param {boolean} reverseIntersectionPolicy Instead of letting edge
|
|
4278
|
+
* intersections go to the higher tile coordinate, let edge intersections
|
|
4279
|
+
* go to the lower tile coordinate.
|
|
4280
|
+
* @param {import("../tilecoord.js").TileCoord} [opt_tileCoord] Temporary import("../tilecoord.js").TileCoord object.
|
|
4281
|
+
* @return {import("../tilecoord.js").TileCoord} Tile coordinate.
|
|
4282
|
+
* @private
|
|
4283
|
+
*/
|
|
4284
|
+
getTileCoordForXYAndResolution_(t, e, n, s, r) {
|
|
4285
|
+
const o = this.getZForResolution(n), a = n / this.getResolution(o), l = this.getOrigin(o), h = et(this.getTileSize(o), this.tmpSize_);
|
|
4286
|
+
let u = a * (t - l[0]) / n / h[0], c = a * (l[1] - e) / n / h[1];
|
|
4287
|
+
return s ? (u = J(u, v) - 1, c = J(c, v) - 1) : (u = K(u, v), c = K(c, v)), le(o, u, c, r);
|
|
4288
|
+
}
|
|
4289
|
+
/**
|
|
4290
|
+
* Although there is repetition between this method and `getTileCoordForXYAndResolution_`,
|
|
4291
|
+
* they should have separate implementations. This method is for integer zoom
|
|
4292
|
+
* levels. The other method should only be called for resolutions corresponding
|
|
4293
|
+
* to non-integer zoom levels.
|
|
4294
|
+
* @param {number} x Map x coordinate.
|
|
4295
|
+
* @param {number} y Map y coordinate.
|
|
4296
|
+
* @param {number} z Integer zoom level.
|
|
4297
|
+
* @param {boolean} reverseIntersectionPolicy Instead of letting edge
|
|
4298
|
+
* intersections go to the higher tile coordinate, let edge intersections
|
|
4299
|
+
* go to the lower tile coordinate.
|
|
4300
|
+
* @param {import("../tilecoord.js").TileCoord} [opt_tileCoord] Temporary import("../tilecoord.js").TileCoord object.
|
|
4301
|
+
* @return {import("../tilecoord.js").TileCoord} Tile coordinate.
|
|
4302
|
+
* @private
|
|
4303
|
+
*/
|
|
4304
|
+
getTileCoordForXYAndZ_(t, e, n, s, r) {
|
|
4305
|
+
const o = this.getOrigin(n), a = this.getResolution(n), l = et(this.getTileSize(n), this.tmpSize_);
|
|
4306
|
+
let h = (t - o[0]) / a / l[0], u = (o[1] - e) / a / l[1];
|
|
4307
|
+
return s ? (h = J(h, v) - 1, u = J(u, v) - 1) : (h = K(h, v), u = K(u, v)), le(n, h, u, r);
|
|
4308
|
+
}
|
|
4309
|
+
/**
|
|
4310
|
+
* Get a tile coordinate given a map coordinate and zoom level.
|
|
4311
|
+
* @param {import("../coordinate.js").Coordinate} coordinate Coordinate.
|
|
4312
|
+
* @param {number} z Integer zoom level, e.g. the result of a `getZForResolution()` method call
|
|
4313
|
+
* @param {import("../tilecoord.js").TileCoord} [opt_tileCoord] Destination import("../tilecoord.js").TileCoord object.
|
|
4314
|
+
* @return {import("../tilecoord.js").TileCoord} Tile coordinate.
|
|
4315
|
+
* @api
|
|
4316
|
+
*/
|
|
4317
|
+
getTileCoordForCoordAndZ(t, e, n) {
|
|
4318
|
+
return this.getTileCoordForXYAndZ_(
|
|
4319
|
+
t[0],
|
|
4320
|
+
t[1],
|
|
4321
|
+
e,
|
|
4322
|
+
!1,
|
|
4323
|
+
n
|
|
4324
|
+
);
|
|
4325
|
+
}
|
|
4326
|
+
/**
|
|
4327
|
+
* @param {import("../tilecoord.js").TileCoord} tileCoord Tile coordinate.
|
|
4328
|
+
* @return {number} Tile resolution.
|
|
4329
|
+
*/
|
|
4330
|
+
getTileCoordResolution(t) {
|
|
4331
|
+
return this.resolutions_[t[0]];
|
|
4332
|
+
}
|
|
4333
|
+
/**
|
|
4334
|
+
* Get the tile size for a zoom level. The type of the return value matches the
|
|
4335
|
+
* `tileSize` or `tileSizes` that the tile grid was configured with. To always
|
|
4336
|
+
* get an {@link import("../size.js").Size}, run the result through {@link module:ol/size.toSize}.
|
|
4337
|
+
* @param {number} z Z.
|
|
4338
|
+
* @return {number|import("../size.js").Size} Tile size.
|
|
4339
|
+
* @api
|
|
4340
|
+
*/
|
|
4341
|
+
getTileSize(t) {
|
|
4342
|
+
return this.tileSize_ ? this.tileSize_ : this.tileSizes_[t];
|
|
4343
|
+
}
|
|
4344
|
+
/**
|
|
4345
|
+
* @param {number} z Zoom level.
|
|
4346
|
+
* @return {import("../TileRange.js").default|null} Extent tile range for the specified zoom level.
|
|
4347
|
+
*/
|
|
4348
|
+
getFullTileRange(t) {
|
|
4349
|
+
return this.fullTileRanges_ ? this.fullTileRanges_[t] : this.extent_ ? this.getTileRangeForExtentAndZ(this.extent_, t) : null;
|
|
4350
|
+
}
|
|
4351
|
+
/**
|
|
4352
|
+
* @param {number} resolution Resolution.
|
|
4353
|
+
* @param {number|import("../array.js").NearestDirectionFunction} [opt_direction]
|
|
4354
|
+
* If 0, the nearest resolution will be used.
|
|
4355
|
+
* If 1, the nearest higher resolution (lower Z) will be used. If -1, the
|
|
4356
|
+
* nearest lower resolution (higher Z) will be used. Default is 0.
|
|
4357
|
+
* Use a {@link module:ol/array~NearestDirectionFunction} for more precise control.
|
|
4358
|
+
*
|
|
4359
|
+
* For example to change tile Z at the midpoint of zoom levels
|
|
4360
|
+
* ```js
|
|
4361
|
+
* function(value, high, low) {
|
|
4362
|
+
* return value - low * Math.sqrt(high / low);
|
|
4363
|
+
* }
|
|
4364
|
+
* ```
|
|
4365
|
+
* @return {number} Z.
|
|
4366
|
+
* @api
|
|
4367
|
+
*/
|
|
4368
|
+
getZForResolution(t, e) {
|
|
4369
|
+
const n = wt(
|
|
4370
|
+
this.resolutions_,
|
|
4371
|
+
t,
|
|
4372
|
+
e || 0
|
|
4373
|
+
);
|
|
4374
|
+
return T(n, this.minZoom, this.maxZoom);
|
|
4375
|
+
}
|
|
4376
|
+
/**
|
|
4377
|
+
* The tile with the provided tile coordinate intersects the given viewport.
|
|
4378
|
+
* @param {import('../tilecoord.js').TileCoord} tileCoord Tile coordinate.
|
|
4379
|
+
* @param {Array<number>} viewport Viewport as returned from {@link module:ol/extent.getRotatedViewport}.
|
|
4380
|
+
* @return {boolean} The tile with the provided tile coordinate intersects the given viewport.
|
|
4381
|
+
*/
|
|
4382
|
+
tileCoordIntersectsViewport(t, e) {
|
|
4383
|
+
return Ye(
|
|
4384
|
+
e,
|
|
4385
|
+
0,
|
|
4386
|
+
e.length,
|
|
4387
|
+
2,
|
|
4388
|
+
this.getTileCoordExtent(t)
|
|
4389
|
+
);
|
|
4390
|
+
}
|
|
4391
|
+
/**
|
|
4392
|
+
* @param {!import("../extent.js").Extent} extent Extent for this tile grid.
|
|
4393
|
+
* @private
|
|
4394
|
+
*/
|
|
4395
|
+
calculateTileRanges_(t) {
|
|
4396
|
+
const e = this.resolutions_.length, n = new Array(e);
|
|
4397
|
+
for (let s = this.minZoom; s < e; ++s)
|
|
4398
|
+
n[s] = this.getTileRangeForExtentAndZ(t, s);
|
|
4399
|
+
this.fullTileRanges_ = n;
|
|
4400
|
+
}
|
|
4401
|
+
}
|
|
4402
|
+
class ji extends Zi {
|
|
4403
|
+
/**
|
|
4404
|
+
* @param {Options} options WMTS options.
|
|
4405
|
+
*/
|
|
4406
|
+
constructor(t) {
|
|
4407
|
+
super({
|
|
4408
|
+
extent: t.extent,
|
|
4409
|
+
origin: t.origin,
|
|
4410
|
+
origins: t.origins,
|
|
4411
|
+
resolutions: t.resolutions,
|
|
4412
|
+
tileSize: t.tileSize,
|
|
4413
|
+
tileSizes: t.tileSizes,
|
|
4414
|
+
sizes: t.sizes
|
|
4415
|
+
}), this.matrixIds_ = t.matrixIds;
|
|
4416
|
+
}
|
|
4417
|
+
/**
|
|
4418
|
+
* @param {number} z Z.
|
|
4419
|
+
* @return {string} MatrixId..
|
|
4420
|
+
*/
|
|
4421
|
+
getMatrixId(t) {
|
|
4422
|
+
return this.matrixIds_[t];
|
|
4423
|
+
}
|
|
4424
|
+
/**
|
|
4425
|
+
* Get the list of matrix identifiers.
|
|
4426
|
+
* @return {Array<string>} MatrixIds.
|
|
4427
|
+
* @api
|
|
4428
|
+
*/
|
|
4429
|
+
getMatrixIds() {
|
|
4430
|
+
return this.matrixIds_;
|
|
4431
|
+
}
|
|
4432
|
+
}
|
|
4433
|
+
function Oi() {
|
|
4434
|
+
Le(jt), Yi(jt);
|
|
4435
|
+
}
|
|
4436
|
+
function zi(i) {
|
|
4437
|
+
const t = P.getResolutionSteps(), e = t.find(
|
|
4438
|
+
(n) => n.resolution === i
|
|
4439
|
+
);
|
|
4440
|
+
return e ? t.indexOf(e) : t.length - 1;
|
|
4441
|
+
}
|
|
4442
|
+
function Li(i = 0.25) {
|
|
4443
|
+
const t = zi(i);
|
|
4444
|
+
let e = P.getResolutionSteps();
|
|
4445
|
+
return e.length > t && (e = e.slice(0, t + 1)), new ji({
|
|
4446
|
+
resolutions: e.map((n) => n.resolution),
|
|
4447
|
+
origin: P.getTileOrigin(),
|
|
4448
|
+
matrixIds: e.map((n, s) => s.toString()),
|
|
4449
|
+
extent: P.bounds?.flatten
|
|
4450
|
+
});
|
|
4451
|
+
}
|
|
4452
|
+
function bi() {
|
|
4453
|
+
return new vi({
|
|
4454
|
+
projection: P.epsg,
|
|
4455
|
+
center: P.bounds.center,
|
|
4456
|
+
zoom: P.getDefaultZoom(),
|
|
4457
|
+
minResolution: _t[_t.length - 1],
|
|
4458
|
+
resolutions: _t,
|
|
4459
|
+
extent: P.bounds.flatten,
|
|
4460
|
+
constrainOnlyCenter: !0
|
|
4461
|
+
});
|
|
4462
|
+
}
|
|
4463
|
+
export {
|
|
4464
|
+
Li as getLV95TileGrid,
|
|
4465
|
+
bi as getLV95View,
|
|
4466
|
+
Oi as registerSwissGeoProjections
|
|
4467
|
+
};
|