@loaders.gl/mvt 3.3.0-alpha.1 → 3.3.0-alpha.11
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/dist/dist.min.js +782 -10
- package/dist/es5/bundle.js +0 -1
- package/dist/es5/bundle.js.map +1 -1
- package/dist/es5/helpers/binary-util-functions.js +2 -12
- package/dist/es5/helpers/binary-util-functions.js.map +1 -1
- package/dist/es5/helpers/mapbox-util-functions.js +2 -10
- package/dist/es5/helpers/mapbox-util-functions.js.map +1 -1
- package/dist/es5/index.js +7 -1
- package/dist/es5/index.js.map +1 -1
- package/dist/es5/lib/binary-vector-tile/vector-tile-feature.js +14 -35
- package/dist/es5/lib/binary-vector-tile/vector-tile-feature.js.map +1 -1
- package/dist/es5/lib/binary-vector-tile/vector-tile-layer.js +3 -14
- package/dist/es5/lib/binary-vector-tile/vector-tile-layer.js.map +1 -1
- package/dist/es5/lib/binary-vector-tile/vector-tile.js +3 -10
- package/dist/es5/lib/binary-vector-tile/vector-tile.js.map +1 -1
- package/dist/es5/lib/geojson-tiler/LICENSE +19 -0
- package/dist/es5/lib/geojson-tiler/clip.js +247 -0
- package/dist/es5/lib/geojson-tiler/clip.js.map +1 -0
- package/dist/es5/lib/geojson-tiler/convert.js +163 -0
- package/dist/es5/lib/geojson-tiler/convert.js.map +1 -0
- package/dist/es5/lib/geojson-tiler/feature.js +63 -0
- package/dist/es5/lib/geojson-tiler/feature.js.map +1 -0
- package/dist/es5/lib/geojson-tiler/geojson-tiler.js +203 -0
- package/dist/es5/lib/geojson-tiler/geojson-tiler.js.map +1 -0
- package/dist/es5/lib/geojson-tiler/simplify.js +54 -0
- package/dist/es5/lib/geojson-tiler/simplify.js.map +1 -0
- package/dist/es5/lib/geojson-tiler/tile.js +127 -0
- package/dist/es5/lib/geojson-tiler/tile.js.map +1 -0
- package/dist/es5/lib/geojson-tiler/transform.js +52 -0
- package/dist/es5/lib/geojson-tiler/transform.js.map +1 -0
- package/dist/es5/lib/geojson-tiler/wrap.js +127 -0
- package/dist/es5/lib/geojson-tiler/wrap.js.map +1 -0
- package/dist/es5/lib/mapbox-vector-tile/vector-tile-feature.js +8 -35
- package/dist/es5/lib/mapbox-vector-tile/vector-tile-feature.js.map +1 -1
- package/dist/es5/lib/mapbox-vector-tile/vector-tile-layer.js +4 -14
- package/dist/es5/lib/mapbox-vector-tile/vector-tile-layer.js.map +1 -1
- package/dist/es5/lib/mapbox-vector-tile/vector-tile.js +3 -10
- package/dist/es5/lib/mapbox-vector-tile/vector-tile.js.map +1 -1
- package/dist/es5/lib/parse-mvt.js +3 -37
- package/dist/es5/lib/parse-mvt.js.map +1 -1
- package/dist/es5/lib/types.js.map +1 -1
- package/dist/es5/mvt-loader.js +9 -18
- package/dist/es5/mvt-loader.js.map +1 -1
- package/dist/es5/workers/mvt-worker.js +0 -2
- package/dist/es5/workers/mvt-worker.js.map +1 -1
- package/dist/esm/bundle.js +1 -1
- package/dist/esm/bundle.js.map +1 -1
- package/dist/esm/helpers/binary-util-functions.js +5 -10
- package/dist/esm/helpers/binary-util-functions.js.map +1 -1
- package/dist/esm/helpers/mapbox-util-functions.js +5 -8
- package/dist/esm/helpers/mapbox-util-functions.js.map +1 -1
- package/dist/esm/index.js +4 -0
- package/dist/esm/index.js.map +1 -1
- package/dist/esm/lib/binary-vector-tile/vector-tile-feature.js +6 -25
- package/dist/esm/lib/binary-vector-tile/vector-tile-feature.js.map +1 -1
- package/dist/esm/lib/binary-vector-tile/vector-tile-layer.js +2 -14
- package/dist/esm/lib/binary-vector-tile/vector-tile-layer.js.map +1 -1
- package/dist/esm/lib/binary-vector-tile/vector-tile.js +1 -3
- package/dist/esm/lib/binary-vector-tile/vector-tile.js.map +1 -1
- package/dist/esm/lib/geojson-tiler/LICENSE +19 -0
- package/dist/esm/lib/geojson-tiler/clip.js +184 -0
- package/dist/esm/lib/geojson-tiler/clip.js.map +1 -0
- package/dist/esm/lib/geojson-tiler/convert.js +120 -0
- package/dist/esm/lib/geojson-tiler/convert.js.map +1 -0
- package/dist/esm/lib/geojson-tiler/feature.js +37 -0
- package/dist/esm/lib/geojson-tiler/feature.js.map +1 -0
- package/dist/esm/lib/geojson-tiler/geojson-tiler.js +189 -0
- package/dist/esm/lib/geojson-tiler/geojson-tiler.js.map +1 -0
- package/dist/esm/lib/geojson-tiler/simplify.js +49 -0
- package/dist/esm/lib/geojson-tiler/simplify.js.map +1 -0
- package/dist/esm/lib/geojson-tiler/tile.js +108 -0
- package/dist/esm/lib/geojson-tiler/tile.js.map +1 -0
- package/dist/esm/lib/geojson-tiler/transform.js +35 -0
- package/dist/esm/lib/geojson-tiler/transform.js.map +1 -0
- package/dist/esm/lib/geojson-tiler/wrap.js +75 -0
- package/dist/esm/lib/geojson-tiler/wrap.js.map +1 -0
- package/dist/esm/lib/mapbox-vector-tile/vector-tile-feature.js +2 -36
- package/dist/esm/lib/mapbox-vector-tile/vector-tile-feature.js.map +1 -1
- package/dist/esm/lib/mapbox-vector-tile/vector-tile-layer.js +2 -14
- package/dist/esm/lib/mapbox-vector-tile/vector-tile-layer.js.map +1 -1
- package/dist/esm/lib/mapbox-vector-tile/vector-tile.js +1 -3
- package/dist/esm/lib/mapbox-vector-tile/vector-tile.js.map +1 -1
- package/dist/esm/lib/parse-mvt.js +0 -26
- package/dist/esm/lib/parse-mvt.js.map +1 -1
- package/dist/esm/lib/types.js.map +1 -1
- package/dist/esm/mvt-loader.js +9 -3
- package/dist/esm/mvt-loader.js.map +1 -1
- package/dist/esm/workers/mvt-worker.js.map +1 -1
- package/dist/index.d.ts +2 -0
- package/dist/index.d.ts.map +1 -1
- package/dist/index.js +4 -1
- package/dist/lib/geojson-tiler/clip.d.ts +16 -0
- package/dist/lib/geojson-tiler/clip.d.ts.map +1 -0
- package/dist/lib/geojson-tiler/clip.js +209 -0
- package/dist/lib/geojson-tiler/convert.d.ts +10 -0
- package/dist/lib/geojson-tiler/convert.d.ts.map +1 -0
- package/dist/lib/geojson-tiler/convert.js +134 -0
- package/dist/lib/geojson-tiler/feature.d.ts +3 -0
- package/dist/lib/geojson-tiler/feature.d.ts.map +1 -0
- package/dist/lib/geojson-tiler/feature.js +46 -0
- package/dist/lib/geojson-tiler/geojson-tiler.d.ts +44 -0
- package/dist/lib/geojson-tiler/geojson-tiler.d.ts.map +1 -0
- package/dist/lib/geojson-tiler/geojson-tiler.js +210 -0
- package/dist/lib/geojson-tiler/simplify.d.ts +10 -0
- package/dist/lib/geojson-tiler/simplify.d.ts.map +1 -0
- package/dist/lib/geojson-tiler/simplify.js +68 -0
- package/dist/lib/geojson-tiler/tile.d.ts +38 -0
- package/dist/lib/geojson-tiler/tile.d.ts.map +1 -0
- package/dist/lib/geojson-tiler/tile.js +125 -0
- package/dist/lib/geojson-tiler/transform.d.ts +7 -0
- package/dist/lib/geojson-tiler/transform.d.ts.map +1 -0
- package/dist/lib/geojson-tiler/transform.js +43 -0
- package/dist/lib/geojson-tiler/wrap.d.ts +17 -0
- package/dist/lib/geojson-tiler/wrap.d.ts.map +1 -0
- package/dist/lib/geojson-tiler/wrap.js +86 -0
- package/dist/lib/mapbox-vector-tile/vector-tile-feature.js +3 -3
- package/dist/lib/types.d.ts +6 -6
- package/dist/lib/types.d.ts.map +1 -1
- package/dist/mvt-worker.js +10 -11
- package/package.json +5 -5
- package/src/index.ts +7 -0
- package/src/lib/geojson-tiler/LICENSE +19 -0
- package/src/lib/geojson-tiler/clip.ts +248 -0
- package/src/lib/geojson-tiler/convert.ts +158 -0
- package/src/lib/geojson-tiler/feature.ts +45 -0
- package/src/lib/geojson-tiler/geojson-tiler.ts +281 -0
- package/src/lib/geojson-tiler/simplify.ts +77 -0
- package/src/lib/geojson-tiler/tile.ts +185 -0
- package/src/lib/geojson-tiler/transform.ts +55 -0
- package/src/lib/geojson-tiler/wrap.ts +108 -0
|
@@ -0,0 +1,247 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
|
|
4
|
+
Object.defineProperty(exports, "__esModule", {
|
|
5
|
+
value: true
|
|
6
|
+
});
|
|
7
|
+
exports.clip = clip;
|
|
8
|
+
var _createClass2 = _interopRequireDefault(require("@babel/runtime/helpers/createClass"));
|
|
9
|
+
var _classCallCheck2 = _interopRequireDefault(require("@babel/runtime/helpers/classCallCheck"));
|
|
10
|
+
var _assertThisInitialized2 = _interopRequireDefault(require("@babel/runtime/helpers/assertThisInitialized"));
|
|
11
|
+
var _inherits2 = _interopRequireDefault(require("@babel/runtime/helpers/inherits"));
|
|
12
|
+
var _possibleConstructorReturn2 = _interopRequireDefault(require("@babel/runtime/helpers/possibleConstructorReturn"));
|
|
13
|
+
var _getPrototypeOf2 = _interopRequireDefault(require("@babel/runtime/helpers/getPrototypeOf"));
|
|
14
|
+
var _wrapNativeSuper2 = _interopRequireDefault(require("@babel/runtime/helpers/wrapNativeSuper"));
|
|
15
|
+
var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty"));
|
|
16
|
+
var _feature = require("./feature");
|
|
17
|
+
function _createSuper(Derived) { var hasNativeReflectConstruct = _isNativeReflectConstruct(); return function _createSuperInternal() { var Super = (0, _getPrototypeOf2.default)(Derived), result; if (hasNativeReflectConstruct) { var NewTarget = (0, _getPrototypeOf2.default)(this).constructor; result = Reflect.construct(Super, arguments, NewTarget); } else { result = Super.apply(this, arguments); } return (0, _possibleConstructorReturn2.default)(this, result); }; }
|
|
18
|
+
function _isNativeReflectConstruct() { if (typeof Reflect === "undefined" || !Reflect.construct) return false; if (Reflect.construct.sham) return false; if (typeof Proxy === "function") return true; try { Boolean.prototype.valueOf.call(Reflect.construct(Boolean, [], function () {})); return true; } catch (e) { return false; } }
|
|
19
|
+
function _createForOfIteratorHelper(o, allowArrayLike) { var it = typeof Symbol !== "undefined" && o[Symbol.iterator] || o["@@iterator"]; if (!it) { if (Array.isArray(o) || (it = _unsupportedIterableToArray(o)) || allowArrayLike && o && typeof o.length === "number") { if (it) o = it; var i = 0; var F = function F() {}; return { s: F, n: function n() { if (i >= o.length) return { done: true }; return { done: false, value: o[i++] }; }, e: function e(_e) { throw _e; }, f: F }; } throw new TypeError("Invalid attempt to iterate non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); } var normalCompletion = true, didErr = false, err; return { s: function s() { it = it.call(o); }, n: function n() { var step = it.next(); normalCompletion = step.done; return step; }, e: function e(_e2) { didErr = true; err = _e2; }, f: function f() { try { if (!normalCompletion && it.return != null) it.return(); } finally { if (didErr) throw err; } } }; }
|
|
20
|
+
function _unsupportedIterableToArray(o, minLen) { if (!o) return; if (typeof o === "string") return _arrayLikeToArray(o, minLen); var n = Object.prototype.toString.call(o).slice(8, -1); if (n === "Object" && o.constructor) n = o.constructor.name; if (n === "Map" || n === "Set") return Array.from(o); if (n === "Arguments" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return _arrayLikeToArray(o, minLen); }
|
|
21
|
+
function _arrayLikeToArray(arr, len) { if (len == null || len > arr.length) len = arr.length; for (var i = 0, arr2 = new Array(len); i < len; i++) { arr2[i] = arr[i]; } return arr2; }
|
|
22
|
+
|
|
23
|
+
function clip(features, scale, k1, k2, axis, minAll, maxAll, options) {
|
|
24
|
+
k1 /= scale;
|
|
25
|
+
k2 /= scale;
|
|
26
|
+
if (minAll >= k1 && maxAll < k2) {
|
|
27
|
+
return features;
|
|
28
|
+
}
|
|
29
|
+
else if (maxAll < k1 || minAll >= k2) {
|
|
30
|
+
return null;
|
|
31
|
+
}
|
|
32
|
+
|
|
33
|
+
var clipped = [];
|
|
34
|
+
var _iterator = _createForOfIteratorHelper(features),
|
|
35
|
+
_step;
|
|
36
|
+
try {
|
|
37
|
+
for (_iterator.s(); !(_step = _iterator.n()).done;) {
|
|
38
|
+
var feature = _step.value;
|
|
39
|
+
var geometry = feature.geometry;
|
|
40
|
+
var type = feature.type;
|
|
41
|
+
var min = axis === 0 ? feature.minX : feature.minY;
|
|
42
|
+
var max = axis === 0 ? feature.maxX : feature.maxY;
|
|
43
|
+
if (min >= k1 && max < k2) {
|
|
44
|
+
clipped.push(feature);
|
|
45
|
+
continue;
|
|
46
|
+
} else if (max < k1 || min >= k2) {
|
|
47
|
+
continue;
|
|
48
|
+
}
|
|
49
|
+
var newGeometry = [];
|
|
50
|
+
if (type === 'Point' || type === 'MultiPoint') {
|
|
51
|
+
clipPoints(geometry, newGeometry, k1, k2, axis);
|
|
52
|
+
} else if (type === 'LineString') {
|
|
53
|
+
clipLine(geometry, newGeometry, k1, k2, axis, false, options.lineMetrics);
|
|
54
|
+
} else if (type === 'MultiLineString') {
|
|
55
|
+
clipLines(geometry, newGeometry, k1, k2, axis, false);
|
|
56
|
+
} else if (type === 'Polygon') {
|
|
57
|
+
clipLines(geometry, newGeometry, k1, k2, axis, true);
|
|
58
|
+
} else if (type === 'MultiPolygon') {
|
|
59
|
+
var _iterator2 = _createForOfIteratorHelper(geometry),
|
|
60
|
+
_step2;
|
|
61
|
+
try {
|
|
62
|
+
for (_iterator2.s(); !(_step2 = _iterator2.n()).done;) {
|
|
63
|
+
var polygon = _step2.value;
|
|
64
|
+
var newPolygon = [];
|
|
65
|
+
clipLines(polygon, newPolygon, k1, k2, axis, true);
|
|
66
|
+
if (newPolygon.length) {
|
|
67
|
+
newGeometry.push(newPolygon);
|
|
68
|
+
}
|
|
69
|
+
}
|
|
70
|
+
} catch (err) {
|
|
71
|
+
_iterator2.e(err);
|
|
72
|
+
} finally {
|
|
73
|
+
_iterator2.f();
|
|
74
|
+
}
|
|
75
|
+
}
|
|
76
|
+
if (newGeometry.length) {
|
|
77
|
+
if (options.lineMetrics && type === 'LineString') {
|
|
78
|
+
var _iterator3 = _createForOfIteratorHelper(newGeometry),
|
|
79
|
+
_step3;
|
|
80
|
+
try {
|
|
81
|
+
for (_iterator3.s(); !(_step3 = _iterator3.n()).done;) {
|
|
82
|
+
var line = _step3.value;
|
|
83
|
+
clipped.push((0, _feature.createFeature)(feature.id, type, line, feature.tags));
|
|
84
|
+
}
|
|
85
|
+
} catch (err) {
|
|
86
|
+
_iterator3.e(err);
|
|
87
|
+
} finally {
|
|
88
|
+
_iterator3.f();
|
|
89
|
+
}
|
|
90
|
+
continue;
|
|
91
|
+
}
|
|
92
|
+
if (type === 'LineString' || type === 'MultiLineString') {
|
|
93
|
+
if (newGeometry.length === 1) {
|
|
94
|
+
type = 'LineString';
|
|
95
|
+
newGeometry = newGeometry[0];
|
|
96
|
+
} else {
|
|
97
|
+
type = 'MultiLineString';
|
|
98
|
+
}
|
|
99
|
+
}
|
|
100
|
+
if (type === 'Point' || type === 'MultiPoint') {
|
|
101
|
+
type = newGeometry.length === 3 ? 'Point' : 'MultiPoint';
|
|
102
|
+
}
|
|
103
|
+
clipped.push((0, _feature.createFeature)(feature.id, type, newGeometry, feature.tags));
|
|
104
|
+
}
|
|
105
|
+
}
|
|
106
|
+
} catch (err) {
|
|
107
|
+
_iterator.e(err);
|
|
108
|
+
} finally {
|
|
109
|
+
_iterator.f();
|
|
110
|
+
}
|
|
111
|
+
return clipped.length ? clipped : null;
|
|
112
|
+
}
|
|
113
|
+
function clipPoints(geom, newGeom, k1, k2, axis) {
|
|
114
|
+
for (var i = 0; i < geom.length; i += 3) {
|
|
115
|
+
var a = geom[i + axis];
|
|
116
|
+
if (a >= k1 && a <= k2) {
|
|
117
|
+
addPoint(newGeom, geom[i], geom[i + 1], geom[i + 2]);
|
|
118
|
+
}
|
|
119
|
+
}
|
|
120
|
+
}
|
|
121
|
+
|
|
122
|
+
function clipLine(geom, newGeom, k1, k2, axis, isPolygon, trackMetrics) {
|
|
123
|
+
var slice = newSlice(geom);
|
|
124
|
+
var intersect = axis === 0 ? intersectX : intersectY;
|
|
125
|
+
var len = geom.start;
|
|
126
|
+
var segLen;
|
|
127
|
+
var t;
|
|
128
|
+
for (var i = 0; i < geom.length - 3; i += 3) {
|
|
129
|
+
var _ax = geom[i];
|
|
130
|
+
var _ay = geom[i + 1];
|
|
131
|
+
var _az = geom[i + 2];
|
|
132
|
+
var bx = geom[i + 3];
|
|
133
|
+
var by = geom[i + 4];
|
|
134
|
+
var _a = axis === 0 ? _ax : _ay;
|
|
135
|
+
var b = axis === 0 ? bx : by;
|
|
136
|
+
var exited = false;
|
|
137
|
+
if (trackMetrics) {
|
|
138
|
+
segLen = Math.sqrt(Math.pow(_ax - bx, 2) + Math.pow(_ay - by, 2));
|
|
139
|
+
}
|
|
140
|
+
if (_a < k1) {
|
|
141
|
+
if (b > k1) {
|
|
142
|
+
t = intersect(slice, _ax, _ay, bx, by, k1);
|
|
143
|
+
if (trackMetrics) {
|
|
144
|
+
slice.start = len + segLen * t;
|
|
145
|
+
}
|
|
146
|
+
}
|
|
147
|
+
} else if (_a > k2) {
|
|
148
|
+
if (b < k2) {
|
|
149
|
+
t = intersect(slice, _ax, _ay, bx, by, k2);
|
|
150
|
+
if (trackMetrics) {
|
|
151
|
+
slice.start = len + segLen * t;
|
|
152
|
+
}
|
|
153
|
+
}
|
|
154
|
+
} else {
|
|
155
|
+
addPoint(slice, _ax, _ay, _az);
|
|
156
|
+
}
|
|
157
|
+
if (b < k1 && _a >= k1) {
|
|
158
|
+
t = intersect(slice, _ax, _ay, bx, by, k1);
|
|
159
|
+
exited = true;
|
|
160
|
+
}
|
|
161
|
+
if (b > k2 && _a <= k2) {
|
|
162
|
+
t = intersect(slice, _ax, _ay, bx, by, k2);
|
|
163
|
+
exited = true;
|
|
164
|
+
}
|
|
165
|
+
if (!isPolygon && exited) {
|
|
166
|
+
if (trackMetrics) {
|
|
167
|
+
slice.end = len + segLen * t;
|
|
168
|
+
}
|
|
169
|
+
newGeom.push(slice);
|
|
170
|
+
slice = newSlice(geom);
|
|
171
|
+
}
|
|
172
|
+
if (trackMetrics) {
|
|
173
|
+
len += segLen;
|
|
174
|
+
}
|
|
175
|
+
}
|
|
176
|
+
|
|
177
|
+
var last = geom.length - 3;
|
|
178
|
+
var ax = geom[last];
|
|
179
|
+
var ay = geom[last + 1];
|
|
180
|
+
var az = geom[last + 2];
|
|
181
|
+
var a = axis === 0 ? ax : ay;
|
|
182
|
+
if (a >= k1 && a <= k2) addPoint(slice, ax, ay, az);
|
|
183
|
+
|
|
184
|
+
last = slice.length - 3;
|
|
185
|
+
if (isPolygon && last >= 3 && (slice[last] !== slice[0] || slice[last + 1] !== slice[1])) {
|
|
186
|
+
addPoint(slice, slice[0], slice[1], slice[2]);
|
|
187
|
+
}
|
|
188
|
+
|
|
189
|
+
if (slice.length) {
|
|
190
|
+
newGeom.push(slice);
|
|
191
|
+
}
|
|
192
|
+
}
|
|
193
|
+
var Slice = function (_Array) {
|
|
194
|
+
(0, _inherits2.default)(Slice, _Array);
|
|
195
|
+
var _super = _createSuper(Slice);
|
|
196
|
+
function Slice() {
|
|
197
|
+
var _this;
|
|
198
|
+
(0, _classCallCheck2.default)(this, Slice);
|
|
199
|
+
for (var _len = arguments.length, args = new Array(_len), _key = 0; _key < _len; _key++) {
|
|
200
|
+
args[_key] = arguments[_key];
|
|
201
|
+
}
|
|
202
|
+
_this = _super.call.apply(_super, [this].concat(args));
|
|
203
|
+
(0, _defineProperty2.default)((0, _assertThisInitialized2.default)(_this), "size", void 0);
|
|
204
|
+
(0, _defineProperty2.default)((0, _assertThisInitialized2.default)(_this), "start", void 0);
|
|
205
|
+
(0, _defineProperty2.default)((0, _assertThisInitialized2.default)(_this), "end", void 0);
|
|
206
|
+
return _this;
|
|
207
|
+
}
|
|
208
|
+
return (0, _createClass2.default)(Slice);
|
|
209
|
+
}((0, _wrapNativeSuper2.default)(Array));
|
|
210
|
+
function newSlice(line) {
|
|
211
|
+
var slice = [];
|
|
212
|
+
slice.size = line.size;
|
|
213
|
+
slice.start = line.start;
|
|
214
|
+
slice.end = line.end;
|
|
215
|
+
return slice;
|
|
216
|
+
}
|
|
217
|
+
|
|
218
|
+
function clipLines(geom, newGeom, k1, k2, axis, isPolygon) {
|
|
219
|
+
var _iterator4 = _createForOfIteratorHelper(geom),
|
|
220
|
+
_step4;
|
|
221
|
+
try {
|
|
222
|
+
for (_iterator4.s(); !(_step4 = _iterator4.n()).done;) {
|
|
223
|
+
var line = _step4.value;
|
|
224
|
+
clipLine(line, newGeom, k1, k2, axis, isPolygon, false);
|
|
225
|
+
}
|
|
226
|
+
} catch (err) {
|
|
227
|
+
_iterator4.e(err);
|
|
228
|
+
} finally {
|
|
229
|
+
_iterator4.f();
|
|
230
|
+
}
|
|
231
|
+
}
|
|
232
|
+
function addPoint(out, x, y, z) {
|
|
233
|
+
out.push(x, y, z);
|
|
234
|
+
}
|
|
235
|
+
|
|
236
|
+
function intersectX(out, ax, ay, bx, by, x) {
|
|
237
|
+
var t = (x - ax) / (bx - ax);
|
|
238
|
+
addPoint(out, x, ay + (by - ay) * t, 1);
|
|
239
|
+
return t;
|
|
240
|
+
}
|
|
241
|
+
|
|
242
|
+
function intersectY(out, ax, ay, bx, by, y) {
|
|
243
|
+
var t = (y - ay) / (by - ay);
|
|
244
|
+
addPoint(out, ax + (bx - ax) * t, y, 1);
|
|
245
|
+
return t;
|
|
246
|
+
}
|
|
247
|
+
//# sourceMappingURL=clip.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"clip.js","names":["clip","features","scale","k1","k2","axis","minAll","maxAll","options","clipped","feature","geometry","type","min","minX","minY","max","maxX","maxY","push","newGeometry","clipPoints","clipLine","lineMetrics","clipLines","polygon","newPolygon","length","line","createFeature","id","tags","geom","newGeom","i","a","addPoint","isPolygon","trackMetrics","slice","newSlice","intersect","intersectX","intersectY","len","start","segLen","t","ax","ay","az","bx","by","b","exited","Math","sqrt","pow","end","last","Slice","Array","size","out","x","y","z"],"sources":["../../../../src/lib/geojson-tiler/clip.ts"],"sourcesContent":["// loaders.gl, MIT license\n// Forked from https://github.com/mapbox/geojson-vt under compatible ISC license\n\nimport type {GeoJSONTileFeature} from './tile';\nimport {createFeature} from './feature';\n\n/* eslint-disable no-continue */\n\n/**\n * Clip features between two vertical or horizontal axis-parallel lines:\n * | |\n * ___|___ | /\n * / | \\____|____/\n * | |\n *\n * @param k1 and k2 are the line coordinates\n * @param axis: 0 for x, 1 for y\n * @param minAll and maxAll: minimum and maximum coordinate value for all features\n */\n// eslint-disable-next-line max-params, complexity, max-statements\nexport function clip(\n features: GeoJSONTileFeature[],\n scale: number,\n k1: number,\n k2: number,\n axis,\n minAll: number,\n maxAll: number,\n options: {lineMetrics: boolean}\n): GeoJSONTileFeature[] | null {\n k1 /= scale;\n k2 /= scale;\n\n if (minAll >= k1 && maxAll < k2) {\n return features;\n }\n // trivial accept\n else if (maxAll < k1 || minAll >= k2) {\n return null; // trivial reject\n }\n\n const clipped: GeoJSONTileFeature[] = [];\n\n for (const feature of features) {\n const geometry = feature.geometry;\n let type = feature.type;\n\n const min = axis === 0 ? feature.minX : feature.minY;\n const max = axis === 0 ? feature.maxX : feature.maxY;\n\n if (min >= k1 && max < k2) {\n // trivial accept\n clipped.push(feature);\n continue;\n } else if (max < k1 || min >= k2) {\n // trivial reject\n continue;\n }\n\n let newGeometry: number[][][] | number[][] = [];\n\n if (type === 'Point' || type === 'MultiPoint') {\n clipPoints(geometry, newGeometry, k1, k2, axis);\n } else if (type === 'LineString') {\n clipLine(geometry, newGeometry, k1, k2, axis, false, options.lineMetrics);\n } else if (type === 'MultiLineString') {\n clipLines(geometry, newGeometry, k1, k2, axis, false);\n } else if (type === 'Polygon') {\n clipLines(geometry, newGeometry, k1, k2, axis, true);\n } else if (type === 'MultiPolygon') {\n for (const polygon of geometry) {\n const newPolygon = [];\n clipLines(polygon, newPolygon, k1, k2, axis, true);\n if (newPolygon.length) {\n newGeometry.push(newPolygon);\n }\n }\n }\n\n if (newGeometry.length) {\n if (options.lineMetrics && type === 'LineString') {\n for (const line of newGeometry) {\n clipped.push(createFeature(feature.id, type, line, feature.tags));\n }\n continue;\n }\n\n if (type === 'LineString' || type === 'MultiLineString') {\n if (newGeometry.length === 1) {\n type = 'LineString';\n // @ts-expect-error TODO - use proper GeoJSON geometry types\n newGeometry = newGeometry[0];\n } else {\n type = 'MultiLineString';\n }\n }\n if (type === 'Point' || type === 'MultiPoint') {\n type = newGeometry.length === 3 ? 'Point' : 'MultiPoint';\n }\n\n clipped.push(createFeature(feature.id, type, newGeometry, feature.tags));\n }\n }\n\n return clipped.length ? clipped : null;\n}\n\nfunction clipPoints(geom, newGeom, k1: number, k2: number, axis): void {\n for (let i = 0; i < geom.length; i += 3) {\n const a = geom[i + axis];\n\n if (a >= k1 && a <= k2) {\n addPoint(newGeom, geom[i], geom[i + 1], geom[i + 2]);\n }\n }\n}\n\n// eslint-disable-next-line max-params, complexity, max-statements\nfunction clipLine(\n geom,\n newGeom,\n k1: number,\n k2: number,\n axis,\n isPolygon: boolean,\n trackMetrics: boolean\n): void {\n let slice = newSlice(geom);\n const intersect = axis === 0 ? intersectX : intersectY;\n let len = geom.start;\n let segLen;\n let t;\n\n for (let i = 0; i < geom.length - 3; i += 3) {\n const ax = geom[i];\n const ay = geom[i + 1];\n const az = geom[i + 2];\n const bx = geom[i + 3];\n const by = geom[i + 4];\n const a = axis === 0 ? ax : ay;\n const b = axis === 0 ? bx : by;\n let exited = false;\n\n if (trackMetrics) {\n segLen = Math.sqrt(Math.pow(ax - bx, 2) + Math.pow(ay - by, 2));\n }\n\n if (a < k1) {\n // ---|--> | (line enters the clip region from the left)\n if (b > k1) {\n t = intersect(slice, ax, ay, bx, by, k1);\n if (trackMetrics) {\n slice.start = len + segLen * t;\n }\n }\n } else if (a > k2) {\n // | <--|--- (line enters the clip region from the right)\n if (b < k2) {\n t = intersect(slice, ax, ay, bx, by, k2);\n if (trackMetrics) {\n slice.start = len + segLen * t;\n }\n }\n } else {\n addPoint(slice, ax, ay, az);\n }\n if (b < k1 && a >= k1) {\n // <--|--- | or <--|-----|--- (line exits the clip region on the left)\n t = intersect(slice, ax, ay, bx, by, k1);\n exited = true;\n }\n if (b > k2 && a <= k2) {\n // | ---|--> or ---|-----|--> (line exits the clip region on the right)\n t = intersect(slice, ax, ay, bx, by, k2);\n exited = true;\n }\n\n if (!isPolygon && exited) {\n if (trackMetrics) {\n slice.end = len + segLen * t;\n }\n newGeom.push(slice);\n slice = newSlice(geom);\n }\n\n if (trackMetrics) {\n len += segLen;\n }\n }\n\n // add the last point\n let last = geom.length - 3;\n const ax = geom[last];\n const ay = geom[last + 1];\n const az = geom[last + 2];\n const a = axis === 0 ? ax : ay;\n if (a >= k1 && a <= k2) addPoint(slice, ax, ay, az);\n\n // close the polygon if its endpoints are not the same after clipping\n last = slice.length - 3;\n if (isPolygon && last >= 3 && (slice[last] !== slice[0] || slice[last + 1] !== slice[1])) {\n addPoint(slice, slice[0], slice[1], slice[2]);\n }\n\n // add the final slice\n if (slice.length) {\n newGeom.push(slice);\n }\n}\n\nclass Slice extends Array<number> {\n size?: number;\n start?: number;\n end?: number;\n}\n\nfunction newSlice(line: {size: number; start: number; end: number}): Slice {\n const slice: Slice = [];\n slice.size = line.size;\n slice.start = line.start;\n slice.end = line.end;\n return slice;\n}\n\n// eslint-disable-next-line max-params\nfunction clipLines(geom, newGeom, k1: number, k2: number, axis, isPolygon: boolean): void {\n for (const line of geom) {\n clipLine(line, newGeom, k1, k2, axis, isPolygon, false);\n }\n}\n\nfunction addPoint(out: number[], x: number, y: number, z: number): void {\n out.push(x, y, z);\n}\n\n// eslint-disable-next-line max-params\nfunction intersectX(out, ax: number, ay: number, bx: number, by: number, x: number): number {\n const t = (x - ax) / (bx - ax);\n addPoint(out, x, ay + (by - ay) * t, 1);\n return t;\n}\n\n// eslint-disable-next-line max-params\nfunction intersectY(out, ax: number, ay: number, bx: number, by: number, y): number {\n const t = (y - ay) / (by - ay);\n addPoint(out, ax + (bx - ax) * t, y, 1);\n return t;\n}\n"],"mappings":"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"}
|
|
@@ -0,0 +1,163 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
Object.defineProperty(exports, "__esModule", {
|
|
4
|
+
value: true
|
|
5
|
+
});
|
|
6
|
+
exports.convert = convert;
|
|
7
|
+
var _simplify = require("./simplify");
|
|
8
|
+
var _feature = require("./feature");
|
|
9
|
+
function _createForOfIteratorHelper(o, allowArrayLike) { var it = typeof Symbol !== "undefined" && o[Symbol.iterator] || o["@@iterator"]; if (!it) { if (Array.isArray(o) || (it = _unsupportedIterableToArray(o)) || allowArrayLike && o && typeof o.length === "number") { if (it) o = it; var i = 0; var F = function F() {}; return { s: F, n: function n() { if (i >= o.length) return { done: true }; return { done: false, value: o[i++] }; }, e: function e(_e) { throw _e; }, f: F }; } throw new TypeError("Invalid attempt to iterate non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); } var normalCompletion = true, didErr = false, err; return { s: function s() { it = it.call(o); }, n: function n() { var step = it.next(); normalCompletion = step.done; return step; }, e: function e(_e2) { didErr = true; err = _e2; }, f: function f() { try { if (!normalCompletion && it.return != null) it.return(); } finally { if (didErr) throw err; } } }; }
|
|
10
|
+
function _unsupportedIterableToArray(o, minLen) { if (!o) return; if (typeof o === "string") return _arrayLikeToArray(o, minLen); var n = Object.prototype.toString.call(o).slice(8, -1); if (n === "Object" && o.constructor) n = o.constructor.name; if (n === "Map" || n === "Set") return Array.from(o); if (n === "Arguments" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return _arrayLikeToArray(o, minLen); }
|
|
11
|
+
function _arrayLikeToArray(arr, len) { if (len == null || len > arr.length) len = arr.length; for (var i = 0, arr2 = new Array(len); i < len; i++) { arr2[i] = arr[i]; } return arr2; }
|
|
12
|
+
|
|
13
|
+
function convert(data, options) {
|
|
14
|
+
var features = [];
|
|
15
|
+
if (data.type === 'FeatureCollection') {
|
|
16
|
+
for (var i = 0; i < data.features.length; i++) {
|
|
17
|
+
convertFeature(features, data.features[i], options, i);
|
|
18
|
+
}
|
|
19
|
+
} else if (data.type === 'Feature') {
|
|
20
|
+
convertFeature(features, data, options);
|
|
21
|
+
} else {
|
|
22
|
+
convertFeature(features, {
|
|
23
|
+
geometry: data
|
|
24
|
+
}, options);
|
|
25
|
+
}
|
|
26
|
+
return features;
|
|
27
|
+
}
|
|
28
|
+
function convertFeature(features, geojson, options, index) {
|
|
29
|
+
if (!geojson.geometry) {
|
|
30
|
+
return;
|
|
31
|
+
}
|
|
32
|
+
var coords = geojson.geometry.coordinates;
|
|
33
|
+
var type = geojson.geometry.type;
|
|
34
|
+
var tolerance = Math.pow(options.tolerance / ((1 << options.maxZoom) * options.extent), 2);
|
|
35
|
+
var geometry = [];
|
|
36
|
+
var id = geojson.id;
|
|
37
|
+
if (options.promoteId) {
|
|
38
|
+
id = geojson.properties[options.promoteId];
|
|
39
|
+
} else if (options.generateId) {
|
|
40
|
+
id = index || 0;
|
|
41
|
+
}
|
|
42
|
+
if (type === 'Point') {
|
|
43
|
+
convertPoint(coords, geometry);
|
|
44
|
+
} else if (type === 'MultiPoint') {
|
|
45
|
+
var _iterator = _createForOfIteratorHelper(coords),
|
|
46
|
+
_step;
|
|
47
|
+
try {
|
|
48
|
+
for (_iterator.s(); !(_step = _iterator.n()).done;) {
|
|
49
|
+
var p = _step.value;
|
|
50
|
+
convertPoint(p, geometry);
|
|
51
|
+
}
|
|
52
|
+
} catch (err) {
|
|
53
|
+
_iterator.e(err);
|
|
54
|
+
} finally {
|
|
55
|
+
_iterator.f();
|
|
56
|
+
}
|
|
57
|
+
} else if (type === 'LineString') {
|
|
58
|
+
convertLine(coords, geometry, tolerance, false);
|
|
59
|
+
} else if (type === 'MultiLineString') {
|
|
60
|
+
if (options.lineMetrics) {
|
|
61
|
+
var _iterator2 = _createForOfIteratorHelper(coords),
|
|
62
|
+
_step2;
|
|
63
|
+
try {
|
|
64
|
+
for (_iterator2.s(); !(_step2 = _iterator2.n()).done;) {
|
|
65
|
+
var line = _step2.value;
|
|
66
|
+
geometry = [];
|
|
67
|
+
convertLine(line, geometry, tolerance, false);
|
|
68
|
+
features.push((0, _feature.createFeature)(id, 'LineString', geometry, geojson.properties));
|
|
69
|
+
}
|
|
70
|
+
} catch (err) {
|
|
71
|
+
_iterator2.e(err);
|
|
72
|
+
} finally {
|
|
73
|
+
_iterator2.f();
|
|
74
|
+
}
|
|
75
|
+
return;
|
|
76
|
+
} else {
|
|
77
|
+
convertLines(coords, geometry, tolerance, false);
|
|
78
|
+
}
|
|
79
|
+
} else if (type === 'Polygon') {
|
|
80
|
+
convertLines(coords, geometry, tolerance, true);
|
|
81
|
+
} else if (type === 'MultiPolygon') {
|
|
82
|
+
var _iterator3 = _createForOfIteratorHelper(coords),
|
|
83
|
+
_step3;
|
|
84
|
+
try {
|
|
85
|
+
for (_iterator3.s(); !(_step3 = _iterator3.n()).done;) {
|
|
86
|
+
var polygon = _step3.value;
|
|
87
|
+
var newPolygon = [];
|
|
88
|
+
convertLines(polygon, newPolygon, tolerance, true);
|
|
89
|
+
geometry.push(newPolygon);
|
|
90
|
+
}
|
|
91
|
+
} catch (err) {
|
|
92
|
+
_iterator3.e(err);
|
|
93
|
+
} finally {
|
|
94
|
+
_iterator3.f();
|
|
95
|
+
}
|
|
96
|
+
} else if (type === 'GeometryCollection') {
|
|
97
|
+
var _iterator4 = _createForOfIteratorHelper(geojson.geometry.geometries),
|
|
98
|
+
_step4;
|
|
99
|
+
try {
|
|
100
|
+
for (_iterator4.s(); !(_step4 = _iterator4.n()).done;) {
|
|
101
|
+
var singleGeometry = _step4.value;
|
|
102
|
+
convertFeature(features, {
|
|
103
|
+
id: id,
|
|
104
|
+
geometry: singleGeometry,
|
|
105
|
+
properties: geojson.properties
|
|
106
|
+
}, options, index);
|
|
107
|
+
}
|
|
108
|
+
} catch (err) {
|
|
109
|
+
_iterator4.e(err);
|
|
110
|
+
} finally {
|
|
111
|
+
_iterator4.f();
|
|
112
|
+
}
|
|
113
|
+
return;
|
|
114
|
+
} else {
|
|
115
|
+
throw new Error('Input data is not a valid GeoJSON object.');
|
|
116
|
+
}
|
|
117
|
+
features.push((0, _feature.createFeature)(id, type, geometry, geojson.properties));
|
|
118
|
+
}
|
|
119
|
+
function convertPoint(coords, out) {
|
|
120
|
+
out.push(projectX(coords[0]), projectY(coords[1]), 0);
|
|
121
|
+
}
|
|
122
|
+
function convertLine(ring, out, tolerance, isPolygon) {
|
|
123
|
+
var x0, y0;
|
|
124
|
+
var size = 0;
|
|
125
|
+
for (var j = 0; j < ring.length; j++) {
|
|
126
|
+
var x = projectX(ring[j][0]);
|
|
127
|
+
var y = projectY(ring[j][1]);
|
|
128
|
+
out.push(x, y, 0);
|
|
129
|
+
if (j > 0) {
|
|
130
|
+
if (isPolygon) {
|
|
131
|
+
size += (x0 * y - x * y0) / 2;
|
|
132
|
+
} else {
|
|
133
|
+
size += Math.sqrt(Math.pow(x - x0, 2) + Math.pow(y - y0, 2));
|
|
134
|
+
}
|
|
135
|
+
}
|
|
136
|
+
|
|
137
|
+
x0 = x;
|
|
138
|
+
y0 = y;
|
|
139
|
+
}
|
|
140
|
+
var last = out.length - 3;
|
|
141
|
+
out[2] = 1;
|
|
142
|
+
(0, _simplify.simplify)(out, 0, last, tolerance);
|
|
143
|
+
out[last + 2] = 1;
|
|
144
|
+
out.size = Math.abs(size);
|
|
145
|
+
out.start = 0;
|
|
146
|
+
out.end = out.size;
|
|
147
|
+
}
|
|
148
|
+
function convertLines(rings, out, tolerance, isPolygon) {
|
|
149
|
+
for (var i = 0; i < rings.length; i++) {
|
|
150
|
+
var geom = [];
|
|
151
|
+
convertLine(rings[i], geom, tolerance, isPolygon);
|
|
152
|
+
out.push(geom);
|
|
153
|
+
}
|
|
154
|
+
}
|
|
155
|
+
function projectX(x) {
|
|
156
|
+
return x / 360 + 0.5;
|
|
157
|
+
}
|
|
158
|
+
function projectY(y) {
|
|
159
|
+
var sin = Math.sin(y * Math.PI / 180);
|
|
160
|
+
var y2 = 0.5 - 0.25 * Math.log((1 + sin) / (1 - sin)) / Math.PI;
|
|
161
|
+
return y2 < 0 ? 0 : y2 > 1 ? 1 : y2;
|
|
162
|
+
}
|
|
163
|
+
//# sourceMappingURL=convert.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"convert.js","names":["convert","data","options","features","type","i","length","convertFeature","geometry","geojson","index","coords","coordinates","tolerance","Math","pow","maxZoom","extent","id","promoteId","properties","generateId","convertPoint","p","convertLine","lineMetrics","line","push","createFeature","convertLines","polygon","newPolygon","geometries","singleGeometry","Error","out","projectX","projectY","ring","isPolygon","x0","y0","size","j","x","y","sqrt","last","simplify","abs","start","end","rings","geom","sin","PI","y2","log"],"sources":["../../../../src/lib/geojson-tiler/convert.ts"],"sourcesContent":["// loaders.gl, MIT license\n// Forked from https://github.com/mapbox/geojson-vt under compatible ISC license\n\n/* eslint-disable */\n// @ts-nocheck\n\nimport type {Feature} from '@loaders.gl/schema';\nimport type {GeoJSONTileFeature} from './tile';\n\nimport {simplify} from './simplify';\nimport {createFeature} from './feature';\n\n// converts GeoJSON feature into an intermediate projected JSON vector format with simplification data\n\nexport function convert(data: Feature, options): GeoJSONTileFeature[] {\n const features = [];\n if (data.type === 'FeatureCollection') {\n for (let i = 0; i < data.features.length; i++) {\n convertFeature(features, data.features[i], options, i);\n }\n } else if (data.type === 'Feature') {\n convertFeature(features, data, options);\n } else {\n // single geometry or a geometry collection\n convertFeature(features, {geometry: data}, options);\n }\n\n return features;\n}\n\nexport type ConvertFeatureOptions = {\n maxZoom?: number;\n tolerance: number;\n extent: number;\n lineMetrics: boolean;\n};\n\nfunction convertFeature(\n features: GeoJSONTileFeature[],\n geojson: Feature,\n options: ConvertFeatureOptions,\n index: number\n): void {\n if (!geojson.geometry) {\n return;\n }\n\n const coords = geojson.geometry.coordinates;\n const type = geojson.geometry.type;\n const tolerance = Math.pow(options.tolerance / ((1 << options.maxZoom) * options.extent), 2);\n let geometry = [];\n let id = geojson.id;\n if (options.promoteId) {\n id = geojson.properties[options.promoteId];\n } else if (options.generateId) {\n id = index || 0;\n }\n if (type === 'Point') {\n convertPoint(coords, geometry);\n } else if (type === 'MultiPoint') {\n for (const p of coords) {\n convertPoint(p, geometry);\n }\n } else if (type === 'LineString') {\n convertLine(coords, geometry, tolerance, false);\n } else if (type === 'MultiLineString') {\n if (options.lineMetrics) {\n // explode into linestrings to be able to track metrics\n for (const line of coords) {\n geometry = [];\n convertLine(line, geometry, tolerance, false);\n features.push(createFeature(id, 'LineString', geometry, geojson.properties));\n }\n return;\n } else {\n convertLines(coords, geometry, tolerance, false);\n }\n } else if (type === 'Polygon') {\n convertLines(coords, geometry, tolerance, true);\n } else if (type === 'MultiPolygon') {\n for (const polygon of coords) {\n const newPolygon = [];\n convertLines(polygon, newPolygon, tolerance, true);\n geometry.push(newPolygon);\n }\n } else if (type === 'GeometryCollection') {\n for (const singleGeometry of geojson.geometry.geometries) {\n convertFeature(\n features,\n {\n id,\n geometry: singleGeometry,\n properties: geojson.properties\n },\n options,\n index\n );\n }\n return;\n } else {\n throw new Error('Input data is not a valid GeoJSON object.');\n }\n\n features.push(createFeature(id, type, geometry, geojson.properties));\n}\n\nfunction convertPoint(coords, out): void {\n out.push(projectX(coords[0]), projectY(coords[1]), 0);\n}\n\nfunction convertLine(ring: number[], out, tolerance: number, isPolygon: boolean): void {\n let x0, y0;\n let size = 0;\n\n for (let j = 0; j < ring.length; j++) {\n const x = projectX(ring[j][0]);\n const y = projectY(ring[j][1]);\n\n out.push(x, y, 0);\n\n if (j > 0) {\n if (isPolygon) {\n size += (x0 * y - x * y0) / 2; // area\n } else {\n size += Math.sqrt(Math.pow(x - x0, 2) + Math.pow(y - y0, 2)); // length\n }\n }\n x0 = x;\n y0 = y;\n }\n\n const last = out.length - 3;\n out[2] = 1;\n simplify(out, 0, last, tolerance);\n out[last + 2] = 1;\n\n out.size = Math.abs(size);\n out.start = 0;\n out.end = out.size;\n}\n\nfunction convertLines(rings: number[][], out, tolerance: number, isPolygon: boolean): void {\n for (let i = 0; i < rings.length; i++) {\n const geom = [];\n convertLine(rings[i], geom, tolerance, isPolygon);\n out.push(geom);\n }\n}\n\nfunction projectX(x: number): number {\n return x / 360 + 0.5;\n}\n\nfunction projectY(y: number): number {\n const sin = Math.sin((y * Math.PI) / 180);\n const y2 = 0.5 - (0.25 * Math.log((1 + sin) / (1 - sin))) / Math.PI;\n return y2 < 0 ? 0 : y2 > 1 ? 1 : y2;\n}\n"],"mappings":"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"}
|
|
@@ -0,0 +1,63 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
Object.defineProperty(exports, "__esModule", {
|
|
4
|
+
value: true
|
|
5
|
+
});
|
|
6
|
+
exports.createFeature = createFeature;
|
|
7
|
+
function _createForOfIteratorHelper(o, allowArrayLike) { var it = typeof Symbol !== "undefined" && o[Symbol.iterator] || o["@@iterator"]; if (!it) { if (Array.isArray(o) || (it = _unsupportedIterableToArray(o)) || allowArrayLike && o && typeof o.length === "number") { if (it) o = it; var i = 0; var F = function F() {}; return { s: F, n: function n() { if (i >= o.length) return { done: true }; return { done: false, value: o[i++] }; }, e: function e(_e) { throw _e; }, f: F }; } throw new TypeError("Invalid attempt to iterate non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); } var normalCompletion = true, didErr = false, err; return { s: function s() { it = it.call(o); }, n: function n() { var step = it.next(); normalCompletion = step.done; return step; }, e: function e(_e2) { didErr = true; err = _e2; }, f: function f() { try { if (!normalCompletion && it.return != null) it.return(); } finally { if (didErr) throw err; } } }; }
|
|
8
|
+
function _unsupportedIterableToArray(o, minLen) { if (!o) return; if (typeof o === "string") return _arrayLikeToArray(o, minLen); var n = Object.prototype.toString.call(o).slice(8, -1); if (n === "Object" && o.constructor) n = o.constructor.name; if (n === "Map" || n === "Set") return Array.from(o); if (n === "Arguments" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return _arrayLikeToArray(o, minLen); }
|
|
9
|
+
function _arrayLikeToArray(arr, len) { if (len == null || len > arr.length) len = arr.length; for (var i = 0, arr2 = new Array(len); i < len; i++) { arr2[i] = arr[i]; } return arr2; }
|
|
10
|
+
|
|
11
|
+
function createFeature(id, type, geom, tags) {
|
|
12
|
+
var feature = {
|
|
13
|
+
id: id == null ? null : id,
|
|
14
|
+
type: type,
|
|
15
|
+
geometry: geom,
|
|
16
|
+
tags: tags,
|
|
17
|
+
minX: Infinity,
|
|
18
|
+
minY: Infinity,
|
|
19
|
+
maxX: -Infinity,
|
|
20
|
+
maxY: -Infinity
|
|
21
|
+
};
|
|
22
|
+
if (type === 'Point' || type === 'MultiPoint' || type === 'LineString') {
|
|
23
|
+
calcLineBBox(feature, geom);
|
|
24
|
+
} else if (type === 'Polygon') {
|
|
25
|
+
calcLineBBox(feature, geom[0]);
|
|
26
|
+
} else if (type === 'MultiLineString') {
|
|
27
|
+
var _iterator = _createForOfIteratorHelper(geom),
|
|
28
|
+
_step;
|
|
29
|
+
try {
|
|
30
|
+
for (_iterator.s(); !(_step = _iterator.n()).done;) {
|
|
31
|
+
var line = _step.value;
|
|
32
|
+
calcLineBBox(feature, line);
|
|
33
|
+
}
|
|
34
|
+
} catch (err) {
|
|
35
|
+
_iterator.e(err);
|
|
36
|
+
} finally {
|
|
37
|
+
_iterator.f();
|
|
38
|
+
}
|
|
39
|
+
} else if (type === 'MultiPolygon') {
|
|
40
|
+
var _iterator2 = _createForOfIteratorHelper(geom),
|
|
41
|
+
_step2;
|
|
42
|
+
try {
|
|
43
|
+
for (_iterator2.s(); !(_step2 = _iterator2.n()).done;) {
|
|
44
|
+
var polygon = _step2.value;
|
|
45
|
+
calcLineBBox(feature, polygon[0]);
|
|
46
|
+
}
|
|
47
|
+
} catch (err) {
|
|
48
|
+
_iterator2.e(err);
|
|
49
|
+
} finally {
|
|
50
|
+
_iterator2.f();
|
|
51
|
+
}
|
|
52
|
+
}
|
|
53
|
+
return feature;
|
|
54
|
+
}
|
|
55
|
+
function calcLineBBox(feature, geom) {
|
|
56
|
+
for (var i = 0; i < geom.length; i += 3) {
|
|
57
|
+
feature.minX = Math.min(feature.minX, geom[i]);
|
|
58
|
+
feature.minY = Math.min(feature.minY, geom[i + 1]);
|
|
59
|
+
feature.maxX = Math.max(feature.maxX, geom[i]);
|
|
60
|
+
feature.maxY = Math.max(feature.maxY, geom[i + 1]);
|
|
61
|
+
}
|
|
62
|
+
}
|
|
63
|
+
//# sourceMappingURL=feature.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"feature.js","names":["createFeature","id","type","geom","tags","feature","geometry","minX","Infinity","minY","maxX","maxY","calcLineBBox","line","polygon","i","length","Math","min","max"],"sources":["../../../../src/lib/geojson-tiler/feature.ts"],"sourcesContent":["// loaders.gl, MIT license\n// Forked from https://github.com/mapbox/geojson-vt under compatible ISC license\n\nimport {GeoJSONTileFeature} from './tile';\n\nexport function createFeature(id, type, geom, tags): GeoJSONTileFeature {\n const feature: GeoJSONTileFeature = {\n // eslint-disable-next-line\n id: id == null ? null : id,\n type,\n geometry: geom,\n tags,\n minX: Infinity,\n minY: Infinity,\n maxX: -Infinity,\n maxY: -Infinity\n };\n\n if (type === 'Point' || type === 'MultiPoint' || type === 'LineString') {\n calcLineBBox(feature, geom);\n } else if (type === 'Polygon') {\n // the outer ring (ie [0]) contains all inner rings\n calcLineBBox(feature, geom[0]);\n } else if (type === 'MultiLineString') {\n for (const line of geom) {\n calcLineBBox(feature, line);\n }\n } else if (type === 'MultiPolygon') {\n for (const polygon of geom) {\n // the outer ring (ie [0]) contains all inner rings\n calcLineBBox(feature, polygon[0]);\n }\n }\n\n return feature;\n}\n\nfunction calcLineBBox(feature, geom) {\n for (let i = 0; i < geom.length; i += 3) {\n feature.minX = Math.min(feature.minX, geom[i]);\n feature.minY = Math.min(feature.minY, geom[i + 1]);\n feature.maxX = Math.max(feature.maxX, geom[i]);\n feature.maxY = Math.max(feature.maxY, geom[i + 1]);\n }\n}\n"],"mappings":";;;;;;;;;;AAKO,SAASA,aAAa,CAACC,EAAE,EAAEC,IAAI,EAAEC,IAAI,EAAEC,IAAI,EAAsB;EACtE,IAAMC,OAA2B,GAAG;IAElCJ,EAAE,EAAEA,EAAE,IAAI,IAAI,GAAG,IAAI,GAAGA,EAAE;IAC1BC,IAAI,EAAJA,IAAI;IACJI,QAAQ,EAAEH,IAAI;IACdC,IAAI,EAAJA,IAAI;IACJG,IAAI,EAAEC,QAAQ;IACdC,IAAI,EAAED,QAAQ;IACdE,IAAI,EAAE,CAACF,QAAQ;IACfG,IAAI,EAAE,CAACH;EACT,CAAC;EAED,IAAIN,IAAI,KAAK,OAAO,IAAIA,IAAI,KAAK,YAAY,IAAIA,IAAI,KAAK,YAAY,EAAE;IACtEU,YAAY,CAACP,OAAO,EAAEF,IAAI,CAAC;EAC7B,CAAC,MAAM,IAAID,IAAI,KAAK,SAAS,EAAE;IAE7BU,YAAY,CAACP,OAAO,EAAEF,IAAI,CAAC,CAAC,CAAC,CAAC;EAChC,CAAC,MAAM,IAAID,IAAI,KAAK,iBAAiB,EAAE;IAAA,2CAClBC,IAAI;MAAA;IAAA;MAAvB,oDAAyB;QAAA,IAAdU,IAAI;QACbD,YAAY,CAACP,OAAO,EAAEQ,IAAI,CAAC;MAC7B;IAAC;MAAA;IAAA;MAAA;IAAA;EACH,CAAC,MAAM,IAAIX,IAAI,KAAK,cAAc,EAAE;IAAA,4CACZC,IAAI;MAAA;IAAA;MAA1B,uDAA4B;QAAA,IAAjBW,OAAO;QAEhBF,YAAY,CAACP,OAAO,EAAES,OAAO,CAAC,CAAC,CAAC,CAAC;MACnC;IAAC;MAAA;IAAA;MAAA;IAAA;EACH;EAEA,OAAOT,OAAO;AAChB;AAEA,SAASO,YAAY,CAACP,OAAO,EAAEF,IAAI,EAAE;EACnC,KAAK,IAAIY,CAAC,GAAG,CAAC,EAAEA,CAAC,GAAGZ,IAAI,CAACa,MAAM,EAAED,CAAC,IAAI,CAAC,EAAE;IACvCV,OAAO,CAACE,IAAI,GAAGU,IAAI,CAACC,GAAG,CAACb,OAAO,CAACE,IAAI,EAAEJ,IAAI,CAACY,CAAC,CAAC,CAAC;IAC9CV,OAAO,CAACI,IAAI,GAAGQ,IAAI,CAACC,GAAG,CAACb,OAAO,CAACI,IAAI,EAAEN,IAAI,CAACY,CAAC,GAAG,CAAC,CAAC,CAAC;IAClDV,OAAO,CAACK,IAAI,GAAGO,IAAI,CAACE,GAAG,CAACd,OAAO,CAACK,IAAI,EAAEP,IAAI,CAACY,CAAC,CAAC,CAAC;IAC9CV,OAAO,CAACM,IAAI,GAAGM,IAAI,CAACE,GAAG,CAACd,OAAO,CAACM,IAAI,EAAER,IAAI,CAACY,CAAC,GAAG,CAAC,CAAC,CAAC;EACpD;AACF"}
|