@loaders.gl/mvt 3.1.3 → 4.0.0-alpha.5

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.
Files changed (89) hide show
  1. package/dist/bundle.js +2 -2
  2. package/dist/bundle.js.map +1 -0
  3. package/dist/helpers/binary-util-functions.js +77 -111
  4. package/dist/helpers/binary-util-functions.js.map +1 -0
  5. package/dist/helpers/mapbox-util-functions.js +45 -78
  6. package/dist/helpers/mapbox-util-functions.js.map +1 -0
  7. package/dist/index.js +2 -6
  8. package/dist/index.js.map +1 -0
  9. package/dist/{es5/lib → lib}/binary-vector-tile/LICENSE.txt +0 -0
  10. package/dist/lib/binary-vector-tile/vector-tile-feature.js +143 -138
  11. package/dist/lib/binary-vector-tile/vector-tile-feature.js.map +1 -0
  12. package/dist/lib/binary-vector-tile/vector-tile-layer.js +58 -85
  13. package/dist/lib/binary-vector-tile/vector-tile-layer.js.map +1 -0
  14. package/dist/lib/binary-vector-tile/vector-tile.js +19 -25
  15. package/dist/lib/binary-vector-tile/vector-tile.js.map +1 -0
  16. package/dist/{es5/lib → lib}/mapbox-vector-tile/LICENSE.txt +0 -0
  17. package/dist/lib/mapbox-vector-tile/vector-tile-feature.js +193 -161
  18. package/dist/lib/mapbox-vector-tile/vector-tile-feature.js.map +1 -0
  19. package/dist/lib/mapbox-vector-tile/vector-tile-layer.js +58 -83
  20. package/dist/lib/mapbox-vector-tile/vector-tile-layer.js.map +1 -0
  21. package/dist/lib/mapbox-vector-tile/vector-tile.js +19 -25
  22. package/dist/lib/mapbox-vector-tile/vector-tile.js.map +1 -0
  23. package/dist/lib/parse-mvt.js +101 -127
  24. package/dist/lib/parse-mvt.js.map +1 -0
  25. package/dist/lib/types.js +2 -2
  26. package/dist/{es5/lib → lib}/types.js.map +0 -0
  27. package/dist/mvt-loader.js +23 -42
  28. package/dist/mvt-loader.js.map +1 -0
  29. package/dist/mvt-worker.js +1 -1
  30. package/dist/workers/mvt-worker.js +4 -5
  31. package/dist/workers/mvt-worker.js.map +1 -0
  32. package/package.json +8 -8
  33. package/dist/es5/bundle.js +0 -7
  34. package/dist/es5/bundle.js.map +0 -1
  35. package/dist/es5/helpers/binary-util-functions.js +0 -98
  36. package/dist/es5/helpers/binary-util-functions.js.map +0 -1
  37. package/dist/es5/helpers/mapbox-util-functions.js +0 -62
  38. package/dist/es5/helpers/mapbox-util-functions.js.map +0 -1
  39. package/dist/es5/index.js +0 -20
  40. package/dist/es5/index.js.map +0 -1
  41. package/dist/es5/lib/binary-vector-tile/vector-tile-feature.js +0 -191
  42. package/dist/es5/lib/binary-vector-tile/vector-tile-feature.js.map +0 -1
  43. package/dist/es5/lib/binary-vector-tile/vector-tile-layer.js +0 -77
  44. package/dist/es5/lib/binary-vector-tile/vector-tile-layer.js.map +0 -1
  45. package/dist/es5/lib/binary-vector-tile/vector-tile.js +0 -35
  46. package/dist/es5/lib/binary-vector-tile/vector-tile.js.map +0 -1
  47. package/dist/es5/lib/mapbox-vector-tile/vector-tile-feature.js +0 -217
  48. package/dist/es5/lib/mapbox-vector-tile/vector-tile-feature.js.map +0 -1
  49. package/dist/es5/lib/mapbox-vector-tile/vector-tile-layer.js +0 -77
  50. package/dist/es5/lib/mapbox-vector-tile/vector-tile-layer.js.map +0 -1
  51. package/dist/es5/lib/mapbox-vector-tile/vector-tile.js +0 -35
  52. package/dist/es5/lib/mapbox-vector-tile/vector-tile.js.map +0 -1
  53. package/dist/es5/lib/parse-mvt.js +0 -132
  54. package/dist/es5/lib/parse-mvt.js.map +0 -1
  55. package/dist/es5/lib/types.js +0 -2
  56. package/dist/es5/mvt-loader.js +0 -71
  57. package/dist/es5/mvt-loader.js.map +0 -1
  58. package/dist/es5/workers/mvt-worker.js +0 -8
  59. package/dist/es5/workers/mvt-worker.js.map +0 -1
  60. package/dist/esm/bundle.js +0 -5
  61. package/dist/esm/bundle.js.map +0 -1
  62. package/dist/esm/helpers/binary-util-functions.js +0 -84
  63. package/dist/esm/helpers/binary-util-functions.js.map +0 -1
  64. package/dist/esm/helpers/mapbox-util-functions.js +0 -49
  65. package/dist/esm/helpers/mapbox-util-functions.js.map +0 -1
  66. package/dist/esm/index.js +0 -2
  67. package/dist/esm/index.js.map +0 -1
  68. package/dist/esm/lib/binary-vector-tile/LICENSE.txt +0 -31
  69. package/dist/esm/lib/binary-vector-tile/vector-tile-feature.js +0 -157
  70. package/dist/esm/lib/binary-vector-tile/vector-tile-feature.js.map +0 -1
  71. package/dist/esm/lib/binary-vector-tile/vector-tile-layer.js +0 -64
  72. package/dist/esm/lib/binary-vector-tile/vector-tile-layer.js.map +0 -1
  73. package/dist/esm/lib/binary-vector-tile/vector-tile.js +0 -23
  74. package/dist/esm/lib/binary-vector-tile/vector-tile.js.map +0 -1
  75. package/dist/esm/lib/mapbox-vector-tile/LICENSE.txt +0 -31
  76. package/dist/esm/lib/mapbox-vector-tile/vector-tile-feature.js +0 -202
  77. package/dist/esm/lib/mapbox-vector-tile/vector-tile-feature.js.map +0 -1
  78. package/dist/esm/lib/mapbox-vector-tile/vector-tile-layer.js +0 -64
  79. package/dist/esm/lib/mapbox-vector-tile/vector-tile-layer.js.map +0 -1
  80. package/dist/esm/lib/mapbox-vector-tile/vector-tile.js +0 -23
  81. package/dist/esm/lib/mapbox-vector-tile/vector-tile.js.map +0 -1
  82. package/dist/esm/lib/parse-mvt.js +0 -117
  83. package/dist/esm/lib/parse-mvt.js.map +0 -1
  84. package/dist/esm/lib/types.js +0 -2
  85. package/dist/esm/lib/types.js.map +0 -1
  86. package/dist/esm/mvt-loader.js +0 -26
  87. package/dist/esm/mvt-loader.js.map +0 -1
  88. package/dist/esm/workers/mvt-worker.js +0 -4
  89. package/dist/esm/workers/mvt-worker.js.map +0 -1
@@ -1,143 +1,117 @@
1
- "use strict";
2
- var __importDefault = (this && this.__importDefault) || function (mod) {
3
- return (mod && mod.__esModule) ? mod : { "default": mod };
4
- };
5
- Object.defineProperty(exports, "__esModule", { value: true });
6
- // import {VectorTile} from '@mapbox/vector-tile';
7
- const vector_tile_1 = __importDefault(require("./mapbox-vector-tile/vector-tile"));
8
- const vector_tile_2 = __importDefault(require("./binary-vector-tile/vector-tile"));
9
- const gis_1 = require("@loaders.gl/gis");
10
- const pbf_1 = __importDefault(require("pbf"));
11
- /**
12
- * Parse MVT arrayBuffer and return GeoJSON.
13
- *
14
- * @param arrayBuffer A MVT arrayBuffer
15
- * @param options
16
- * @returns A GeoJSON geometry object or a binary representation
17
- */
18
- function parseMVT(arrayBuffer, options) {
19
- options = normalizeOptions(options);
20
- const features = [];
21
- if (options) {
22
- const binary = options.gis.format === 'binary';
23
- const geometryInfo = {
24
- coordLength: 2,
25
- pointPositionsCount: 0,
26
- pointFeaturesCount: 0,
27
- linePositionsCount: 0,
28
- linePathsCount: 0,
29
- lineFeaturesCount: 0,
30
- polygonPositionsCount: 0,
31
- polygonObjectsCount: 0,
32
- polygonRingsCount: 0,
33
- polygonFeaturesCount: 0
1
+ import VectorTile from './mapbox-vector-tile/vector-tile';
2
+ import BinaryVectorTile from './binary-vector-tile/vector-tile';
3
+ import { flatGeojsonToBinary } from '@loaders.gl/gis';
4
+ import Protobuf from 'pbf';
5
+ export default function parseMVT(arrayBuffer, options) {
6
+ options = normalizeOptions(options);
7
+ const features = [];
8
+
9
+ if (options) {
10
+ const binary = options.gis.format === 'binary';
11
+ const geometryInfo = {
12
+ coordLength: 2,
13
+ pointPositionsCount: 0,
14
+ pointFeaturesCount: 0,
15
+ linePositionsCount: 0,
16
+ linePathsCount: 0,
17
+ lineFeaturesCount: 0,
18
+ polygonPositionsCount: 0,
19
+ polygonObjectsCount: 0,
20
+ polygonRingsCount: 0,
21
+ polygonFeaturesCount: 0
22
+ };
23
+
24
+ if (arrayBuffer.byteLength > 0) {
25
+ const tile = binary ? new BinaryVectorTile(new Protobuf(arrayBuffer)) : new VectorTile(new Protobuf(arrayBuffer));
26
+ const loaderOptions = options.mvt;
27
+ const selectedLayers = Array.isArray(loaderOptions.layers) ? loaderOptions.layers : Object.keys(tile.layers);
28
+ selectedLayers.forEach(layerName => {
29
+ const vectorTileLayer = tile.layers[layerName];
30
+ const featureOptions = { ...loaderOptions,
31
+ layerName
34
32
  };
35
- if (arrayBuffer.byteLength > 0) {
36
- const tile = binary
37
- ? new vector_tile_2.default(new pbf_1.default(arrayBuffer))
38
- : new vector_tile_1.default(new pbf_1.default(arrayBuffer));
39
- const loaderOptions = options.mvt;
40
- const selectedLayers = Array.isArray(loaderOptions.layers)
41
- ? loaderOptions.layers
42
- : Object.keys(tile.layers);
43
- selectedLayers.forEach((layerName) => {
44
- const vectorTileLayer = tile.layers[layerName];
45
- const featureOptions = { ...loaderOptions, layerName };
46
- if (!vectorTileLayer) {
47
- return;
48
- }
49
- for (let i = 0; i < vectorTileLayer.length; i++) {
50
- const vectorTileFeature = vectorTileLayer.feature(i, geometryInfo);
51
- const decodedFeature = binary
52
- ? getDecodedFeatureBinary(vectorTileFeature, featureOptions)
53
- : getDecodedFeature(vectorTileFeature, featureOptions);
54
- features.push(decodedFeature);
55
- }
56
- });
33
+
34
+ if (!vectorTileLayer) {
35
+ return;
57
36
  }
58
- if (binary) {
59
- const data = (0, gis_1.flatGeojsonToBinary)(features, geometryInfo);
60
- // Add the original byteLength (as a reasonable approximation of the size of the binary data)
61
- // TODO decide where to store extra fields like byteLength (header etc) and document
62
- // @ts-ignore
63
- data.byteLength = arrayBuffer.byteLength;
64
- return data;
37
+
38
+ for (let i = 0; i < vectorTileLayer.length; i++) {
39
+ const vectorTileFeature = vectorTileLayer.feature(i, geometryInfo);
40
+ const decodedFeature = binary ? getDecodedFeatureBinary(vectorTileFeature, featureOptions) : getDecodedFeature(vectorTileFeature, featureOptions);
41
+ features.push(decodedFeature);
65
42
  }
43
+ });
66
44
  }
67
- return features;
45
+
46
+ if (binary) {
47
+ const data = flatGeojsonToBinary(features, geometryInfo);
48
+ data.byteLength = arrayBuffer.byteLength;
49
+ return data;
50
+ }
51
+ }
52
+
53
+ return features;
68
54
  }
69
- exports.default = parseMVT;
70
- /**
71
- * @param options
72
- * @returns options
73
- */
55
+
74
56
  function normalizeOptions(options) {
75
- if (options) {
76
- options = {
77
- ...options,
78
- mvt: options.mvt || {},
79
- gis: options.gis || {}
80
- };
81
- // Validate
82
- const wgs84Coordinates = options.coordinates === 'wgs84';
83
- const { tileIndex } = options;
84
- const hasTileIndex = tileIndex &&
85
- Number.isFinite(tileIndex.x) &&
86
- Number.isFinite(tileIndex.y) &&
87
- Number.isFinite(tileIndex.z);
88
- if (wgs84Coordinates && !hasTileIndex) {
89
- throw new Error('MVT Loader: WGS84 coordinates need tileIndex property. Check documentation.');
90
- }
57
+ if (options) {
58
+ options = { ...options,
59
+ mvt: options.mvt || {},
60
+ gis: options.gis || {}
61
+ };
62
+ const wgs84Coordinates = options.coordinates === 'wgs84';
63
+ const {
64
+ tileIndex
65
+ } = options;
66
+ const hasTileIndex = tileIndex && Number.isFinite(tileIndex.x) && Number.isFinite(tileIndex.y) && Number.isFinite(tileIndex.z);
67
+
68
+ if (wgs84Coordinates && !hasTileIndex) {
69
+ throw new Error('MVT Loader: WGS84 coordinates need tileIndex property. Check documentation.');
91
70
  }
92
- return options;
71
+ }
72
+
73
+ return options;
93
74
  }
94
- /**
95
- * @param feature
96
- * @param options
97
- * @returns decoded feature
98
- */
75
+
99
76
  function getDecodedFeature(feature, options) {
100
- const decodedFeature = feature.toGeoJSON(options.coordinates === 'wgs84' ? options.tileIndex : transformToLocalCoordinates);
101
- // Add layer name to GeoJSON properties
102
- if (options.layerProperty) {
103
- decodedFeature.properties[options.layerProperty] = options.layerName;
104
- }
105
- return decodedFeature;
77
+ const decodedFeature = feature.toGeoJSON(options.coordinates === 'wgs84' ? options.tileIndex : transformToLocalCoordinates);
78
+
79
+ if (options.layerProperty) {
80
+ decodedFeature.properties[options.layerProperty] = options.layerName;
81
+ }
82
+
83
+ return decodedFeature;
106
84
  }
107
- /**
108
- * @param feature
109
- * @param options
110
- * @returns decoded binary feature
111
- */
85
+
112
86
  function getDecodedFeatureBinary(feature, options) {
113
- const decodedFeature = feature.toBinaryCoordinates(options.coordinates === 'wgs84' ? options.tileIndex : transformToLocalCoordinatesBinary);
114
- // Add layer name to GeoJSON properties
115
- if (options.layerProperty && decodedFeature.properties) {
116
- decodedFeature.properties[options.layerProperty] = options.layerName;
117
- }
118
- return decodedFeature;
87
+ const decodedFeature = feature.toBinaryCoordinates(options.coordinates === 'wgs84' ? options.tileIndex : transformToLocalCoordinatesBinary);
88
+
89
+ if (options.layerProperty && decodedFeature.properties) {
90
+ decodedFeature.properties[options.layerProperty] = options.layerName;
91
+ }
92
+
93
+ return decodedFeature;
119
94
  }
120
- /**
121
- * @param line
122
- * @param feature
123
- */
95
+
124
96
  function transformToLocalCoordinates(line, feature) {
125
- // This function transforms local coordinates in a
126
- // [0 - bufferSize, this.extent + bufferSize] range to a
127
- // [0 - (bufferSize / this.extent), 1 + (bufferSize / this.extent)] range.
128
- // The resulting extent would be 1.
129
- const { extent } = feature;
130
- for (let i = 0; i < line.length; i++) {
131
- const p = line[i];
132
- p[0] /= extent;
133
- p[1] /= extent;
134
- }
97
+ const {
98
+ extent
99
+ } = feature;
100
+
101
+ for (let i = 0; i < line.length; i++) {
102
+ const p = line[i];
103
+ p[0] /= extent;
104
+ p[1] /= extent;
105
+ }
135
106
  }
107
+
136
108
  function transformToLocalCoordinatesBinary(data, feature) {
137
- // For the binary code path, the feature data is just
138
- // one big flat array, so we just divide each value
139
- const { extent } = feature;
140
- for (let i = 0, il = data.length; i < il; ++i) {
141
- data[i] /= extent;
142
- }
109
+ const {
110
+ extent
111
+ } = feature;
112
+
113
+ for (let i = 0, il = data.length; i < il; ++i) {
114
+ data[i] /= extent;
115
+ }
143
116
  }
117
+ //# sourceMappingURL=parse-mvt.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../../src/lib/parse-mvt.ts"],"names":["VectorTile","BinaryVectorTile","flatGeojsonToBinary","Protobuf","parseMVT","arrayBuffer","options","normalizeOptions","features","binary","gis","format","geometryInfo","coordLength","pointPositionsCount","pointFeaturesCount","linePositionsCount","linePathsCount","lineFeaturesCount","polygonPositionsCount","polygonObjectsCount","polygonRingsCount","polygonFeaturesCount","byteLength","tile","loaderOptions","mvt","selectedLayers","Array","isArray","layers","Object","keys","forEach","layerName","vectorTileLayer","featureOptions","i","length","vectorTileFeature","feature","decodedFeature","getDecodedFeatureBinary","getDecodedFeature","push","data","wgs84Coordinates","coordinates","tileIndex","hasTileIndex","Number","isFinite","x","y","z","Error","toGeoJSON","transformToLocalCoordinates","layerProperty","properties","toBinaryCoordinates","transformToLocalCoordinatesBinary","line","extent","p","il"],"mappings":"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","sourcesContent":["// import {VectorTile} from '@mapbox/vector-tile';\nimport VectorTile from './mapbox-vector-tile/vector-tile';\nimport BinaryVectorTile from './binary-vector-tile/vector-tile';\n\nimport {flatGeojsonToBinary} from '@loaders.gl/gis';\nimport Protobuf from 'pbf';\nimport type {FlatFeature} from '@loaders.gl/schema';\nimport type {MvtMapboxCoordinates, MvtOptions} from '../lib/types';\nimport VectorTileFeatureBinary from './binary-vector-tile/vector-tile-feature';\nimport VectorTileFeatureMapBox from './mapbox-vector-tile/vector-tile-feature';\nimport {LoaderOptions} from '@loaders.gl/loader-utils';\n\n/**\n * Parse MVT arrayBuffer and return GeoJSON.\n *\n * @param arrayBuffer A MVT arrayBuffer\n * @param options\n * @returns A GeoJSON geometry object or a binary representation\n */\nexport default function parseMVT(arrayBuffer: ArrayBuffer, options?: LoaderOptions) {\n options = normalizeOptions(options);\n const features: (FlatFeature | MvtMapboxCoordinates)[] = [];\n\n if (options) {\n const binary = options.gis.format === 'binary';\n const geometryInfo = {\n coordLength: 2,\n pointPositionsCount: 0,\n pointFeaturesCount: 0,\n linePositionsCount: 0,\n linePathsCount: 0,\n lineFeaturesCount: 0,\n polygonPositionsCount: 0,\n polygonObjectsCount: 0,\n polygonRingsCount: 0,\n polygonFeaturesCount: 0\n };\n\n if (arrayBuffer.byteLength > 0) {\n const tile = binary\n ? new BinaryVectorTile(new Protobuf(arrayBuffer))\n : new VectorTile(new Protobuf(arrayBuffer));\n const loaderOptions = options.mvt;\n\n const selectedLayers = Array.isArray(loaderOptions.layers)\n ? loaderOptions.layers\n : Object.keys(tile.layers);\n\n selectedLayers.forEach((layerName: string) => {\n const vectorTileLayer = tile.layers[layerName];\n const featureOptions = {...loaderOptions, layerName};\n\n if (!vectorTileLayer) {\n return;\n }\n\n for (let i = 0; i < vectorTileLayer.length; i++) {\n const vectorTileFeature = vectorTileLayer.feature(i, geometryInfo);\n\n const decodedFeature = binary\n ? getDecodedFeatureBinary(vectorTileFeature as VectorTileFeatureBinary, featureOptions)\n : getDecodedFeature(vectorTileFeature as VectorTileFeatureMapBox, featureOptions);\n features.push(decodedFeature);\n }\n });\n }\n\n if (binary) {\n const data = flatGeojsonToBinary(features as FlatFeature[], geometryInfo);\n // Add the original byteLength (as a reasonable approximation of the size of the binary data)\n // TODO decide where to store extra fields like byteLength (header etc) and document\n // @ts-ignore\n data.byteLength = arrayBuffer.byteLength;\n return data;\n }\n }\n return features;\n}\n\n/**\n * @param options\n * @returns options\n */\nfunction normalizeOptions(options: LoaderOptions | undefined) {\n if (options) {\n options = {\n ...options,\n mvt: options.mvt || {},\n gis: options.gis || {}\n };\n\n // Validate\n const wgs84Coordinates = options.coordinates === 'wgs84';\n const {tileIndex} = options;\n const hasTileIndex =\n tileIndex &&\n Number.isFinite(tileIndex.x) &&\n Number.isFinite(tileIndex.y) &&\n Number.isFinite(tileIndex.z);\n\n if (wgs84Coordinates && !hasTileIndex) {\n throw new Error(\n 'MVT Loader: WGS84 coordinates need tileIndex property. Check documentation.'\n );\n }\n }\n return options;\n}\n\n/**\n * @param feature\n * @param options\n * @returns decoded feature\n */\nfunction getDecodedFeature(\n feature: VectorTileFeatureMapBox,\n options: MvtOptions\n): MvtMapboxCoordinates {\n const decodedFeature = feature.toGeoJSON(\n options.coordinates === 'wgs84' ? options.tileIndex : transformToLocalCoordinates\n );\n\n // Add layer name to GeoJSON properties\n if (options.layerProperty) {\n decodedFeature.properties[options.layerProperty] = options.layerName;\n }\n\n return decodedFeature;\n}\n\n/**\n * @param feature\n * @param options\n * @returns decoded binary feature\n */\nfunction getDecodedFeatureBinary(\n feature: VectorTileFeatureBinary,\n options: MvtOptions\n): FlatFeature {\n const decodedFeature = feature.toBinaryCoordinates(\n options.coordinates === 'wgs84' ? options.tileIndex : transformToLocalCoordinatesBinary\n );\n\n // Add layer name to GeoJSON properties\n if (options.layerProperty && decodedFeature.properties) {\n decodedFeature.properties[options.layerProperty] = options.layerName;\n }\n\n return decodedFeature;\n}\n\n/**\n * @param line\n * @param feature\n */\nfunction transformToLocalCoordinates(line: number[], feature: {extent: any}): void {\n // This function transforms local coordinates in a\n // [0 - bufferSize, this.extent + bufferSize] range to a\n // [0 - (bufferSize / this.extent), 1 + (bufferSize / this.extent)] range.\n // The resulting extent would be 1.\n const {extent} = feature;\n for (let i = 0; i < line.length; i++) {\n const p = line[i];\n p[0] /= extent;\n p[1] /= extent;\n }\n}\n\nfunction transformToLocalCoordinatesBinary(data: number[], feature: {extent: any}) {\n // For the binary code path, the feature data is just\n // one big flat array, so we just divide each value\n const {extent} = feature;\n for (let i = 0, il = data.length; i < il; ++i) {\n data[i] /= extent;\n }\n}\n"],"file":"parse-mvt.js"}
package/dist/lib/types.js CHANGED
@@ -1,2 +1,2 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
1
+ export {};
2
+ //# sourceMappingURL=types.js.map
File without changes
@@ -1,45 +1,26 @@
1
- "use strict";
2
- var __importDefault = (this && this.__importDefault) || function (mod) {
3
- return (mod && mod.__esModule) ? mod : { "default": mod };
4
- };
5
- Object.defineProperty(exports, "__esModule", { value: true });
6
- exports.MVTLoader = exports.MVTWorkerLoader = void 0;
7
- const parse_mvt_1 = __importDefault(require("./lib/parse-mvt"));
8
- // __VERSION__ is injected by babel-plugin-version-inline
9
- // @ts-ignore TS2304: Cannot find name '__VERSION__'.
10
- const VERSION = typeof __VERSION__ !== 'undefined' ? __VERSION__ : 'latest';
11
- /**
12
- * Worker loader for the Mapbox Vector Tile format
13
- */
14
- exports.MVTWorkerLoader = {
15
- name: 'Mapbox Vector Tile',
16
- id: 'mvt',
17
- module: 'mvt',
18
- version: VERSION,
19
- // Note: ArcGIS uses '.pbf' extension and 'application/octet-stream'
20
- extensions: ['mvt', 'pbf'],
21
- mimeTypes: [
22
- 'application/vnd.mapbox-vector-tile',
23
- 'application/x-protobuf'
24
- // 'application/octet-stream'
25
- ],
26
- worker: true,
27
- category: 'geometry',
28
- options: {
29
- mvt: {
30
- coordinates: 'local',
31
- layerProperty: 'layerName',
32
- layers: null,
33
- tileIndex: null
34
- }
1
+ import parseMVT from './lib/parse-mvt';
2
+ const VERSION = typeof "4.0.0-alpha.5" !== 'undefined' ? "4.0.0-alpha.5" : 'latest';
3
+ export const MVTWorkerLoader = {
4
+ name: 'Mapbox Vector Tile',
5
+ id: 'mvt',
6
+ module: 'mvt',
7
+ version: VERSION,
8
+ extensions: ['mvt', 'pbf'],
9
+ mimeTypes: ['application/vnd.mapbox-vector-tile', 'application/x-protobuf'],
10
+ worker: true,
11
+ category: 'geometry',
12
+ options: {
13
+ mvt: {
14
+ coordinates: 'local',
15
+ layerProperty: 'layerName',
16
+ layers: null,
17
+ tileIndex: null
35
18
  }
19
+ }
36
20
  };
37
- /**
38
- * Loader for the Mapbox Vector Tile format
39
- */
40
- exports.MVTLoader = {
41
- ...exports.MVTWorkerLoader,
42
- parse: async (arrayBuffer, options) => (0, parse_mvt_1.default)(arrayBuffer, options),
43
- parseSync: parse_mvt_1.default,
44
- binary: true
21
+ export const MVTLoader = { ...MVTWorkerLoader,
22
+ parse: async (arrayBuffer, options) => parseMVT(arrayBuffer, options),
23
+ parseSync: parseMVT,
24
+ binary: true
45
25
  };
26
+ //# sourceMappingURL=mvt-loader.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../src/mvt-loader.ts"],"names":["parseMVT","VERSION","MVTWorkerLoader","name","id","module","version","extensions","mimeTypes","worker","category","options","mvt","coordinates","layerProperty","layers","tileIndex","MVTLoader","parse","arrayBuffer","parseSync","binary"],"mappings":"AACA,OAAOA,QAAP,MAAqB,iBAArB;AAIA,MAAMC,OAAO,GAAG,2BAAuB,WAAvB,qBAAmD,QAAnE;AAKA,OAAO,MAAMC,eAAuB,GAAG;AACrCC,EAAAA,IAAI,EAAE,oBAD+B;AAErCC,EAAAA,EAAE,EAAE,KAFiC;AAGrCC,EAAAA,MAAM,EAAE,KAH6B;AAIrCC,EAAAA,OAAO,EAAEL,OAJ4B;AAMrCM,EAAAA,UAAU,EAAE,CAAC,KAAD,EAAQ,KAAR,CANyB;AAOrCC,EAAAA,SAAS,EAAE,CACT,oCADS,EAET,wBAFS,CAP0B;AAYrCC,EAAAA,MAAM,EAAE,IAZ6B;AAarCC,EAAAA,QAAQ,EAAE,UAb2B;AAcrCC,EAAAA,OAAO,EAAE;AACPC,IAAAA,GAAG,EAAE;AACHC,MAAAA,WAAW,EAAE,OADV;AAEHC,MAAAA,aAAa,EAAE,WAFZ;AAGHC,MAAAA,MAAM,EAAE,IAHL;AAIHC,MAAAA,SAAS,EAAE;AAJR;AADE;AAd4B,CAAhC;AA2BP,OAAO,MAAMC,SAA2B,GAAG,EACzC,GAAGf,eADsC;AAEzCgB,EAAAA,KAAK,EAAE,OAAOC,WAAP,EAAoBR,OAApB,KAAgCX,QAAQ,CAACmB,WAAD,EAAcR,OAAd,CAFN;AAGzCS,EAAAA,SAAS,EAAEpB,QAH8B;AAIzCqB,EAAAA,MAAM,EAAE;AAJiC,CAApC","sourcesContent":["import type {Loader, LoaderWithParser} from '@loaders.gl/loader-utils';\nimport parseMVT from './lib/parse-mvt';\n\n// __VERSION__ is injected by babel-plugin-version-inline\n// @ts-ignore TS2304: Cannot find name '__VERSION__'.\nconst VERSION = typeof __VERSION__ !== 'undefined' ? __VERSION__ : 'latest';\n\n/**\n * Worker loader for the Mapbox Vector Tile format\n */\nexport const MVTWorkerLoader: Loader = {\n name: 'Mapbox Vector Tile',\n id: 'mvt',\n module: 'mvt',\n version: VERSION,\n // Note: ArcGIS uses '.pbf' extension and 'application/octet-stream'\n extensions: ['mvt', 'pbf'],\n mimeTypes: [\n 'application/vnd.mapbox-vector-tile',\n 'application/x-protobuf'\n // 'application/octet-stream'\n ],\n worker: true,\n category: 'geometry',\n options: {\n mvt: {\n coordinates: 'local',\n layerProperty: 'layerName',\n layers: null,\n tileIndex: null\n }\n }\n};\n\n/**\n * Loader for the Mapbox Vector Tile format\n */\nexport const MVTLoader: LoaderWithParser = {\n ...MVTWorkerLoader,\n parse: async (arrayBuffer, options) => parseMVT(arrayBuffer, options),\n parseSync: parseMVT,\n binary: true\n};\n"],"file":"mvt-loader.js"}
@@ -2105,7 +2105,7 @@
2105
2105
  }
2106
2106
 
2107
2107
  // src/mvt-loader.ts
2108
- var VERSION = typeof __VERSION__ !== "undefined" ? __VERSION__ : "latest";
2108
+ var VERSION = true ? "4.0.0-alpha.5" : "latest";
2109
2109
  var MVTWorkerLoader = {
2110
2110
  name: "Mapbox Vector Tile",
2111
2111
  id: "mvt",
@@ -1,5 +1,4 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- const mvt_loader_1 = require("../mvt-loader");
4
- const loader_utils_1 = require("@loaders.gl/loader-utils");
5
- (0, loader_utils_1.createLoaderWorker)(mvt_loader_1.MVTLoader);
1
+ import { MVTLoader } from '../mvt-loader';
2
+ import { createLoaderWorker } from '@loaders.gl/loader-utils';
3
+ createLoaderWorker(MVTLoader);
4
+ //# sourceMappingURL=mvt-worker.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../../src/workers/mvt-worker.ts"],"names":["MVTLoader","createLoaderWorker"],"mappings":"AAAA,SAAQA,SAAR,QAAwB,eAAxB;AACA,SAAQC,kBAAR,QAAiC,0BAAjC;AAEAA,kBAAkB,CAACD,SAAD,CAAlB","sourcesContent":["import {MVTLoader} from '../mvt-loader';\nimport {createLoaderWorker} from '@loaders.gl/loader-utils';\n\ncreateLoaderWorker(MVTLoader);\n"],"file":"mvt-worker.js"}
package/package.json CHANGED
@@ -1,7 +1,7 @@
1
1
  {
2
2
  "name": "@loaders.gl/mvt",
3
3
  "description": "Loader for Mapbox Vector Tiles",
4
- "version": "3.1.3",
4
+ "version": "4.0.0-alpha.5",
5
5
  "license": "MIT",
6
6
  "publishConfig": {
7
7
  "access": "public"
@@ -18,8 +18,8 @@
18
18
  "Mapbox Vector Tiles"
19
19
  ],
20
20
  "types": "dist/index.d.ts",
21
- "main": "dist/es5/index.js",
22
- "module": "dist/esm/index.js",
21
+ "main": "dist/index.js",
22
+ "module": "dist/index.js",
23
23
  "sideEffects": false,
24
24
  "files": [
25
25
  "src",
@@ -29,17 +29,17 @@
29
29
  "scripts": {
30
30
  "pre-build": "npm run build-worker && npm run build-worker --env.dev && npm run build-bundle",
31
31
  "build-bundle": "esbuild src/bundle.ts --bundle --outfile=dist/dist.min.js",
32
- "build-worker": "esbuild src/workers/mvt-worker.ts --bundle --outfile=dist/mvt-worker.js"
32
+ "build-worker": "esbuild src/workers/mvt-worker.ts --bundle --outfile=dist/mvt-worker.js --define:__VERSION__=\\\"$npm_package_version\\\""
33
33
  },
34
34
  "dependencies": {
35
- "@loaders.gl/gis": "3.1.3",
36
- "@loaders.gl/loader-utils": "3.1.3",
37
- "@loaders.gl/schema": "3.1.3",
35
+ "@loaders.gl/gis": "4.0.0-alpha.5",
36
+ "@loaders.gl/loader-utils": "4.0.0-alpha.5",
37
+ "@loaders.gl/schema": "4.0.0-alpha.5",
38
38
  "@math.gl/polygon": "^3.5.1",
39
39
  "pbf": "^3.2.1"
40
40
  },
41
41
  "devDependencies": {
42
42
  "@types/pbf": "^3.0.2"
43
43
  },
44
- "gitHead": "4a690c369779346d73c9a27395d1c08d77d279a4"
44
+ "gitHead": "7a71a54bdf1ddf985cc3af3db90b82e7fa97d025"
45
45
  }
@@ -1,7 +0,0 @@
1
- "use strict";
2
-
3
- var moduleExports = require('./index');
4
-
5
- globalThis.loaders = globalThis.loaders || {};
6
- module.exports = Object.assign(globalThis.loaders, moduleExports);
7
- //# sourceMappingURL=bundle.js.map
@@ -1 +0,0 @@
1
- {"version":3,"sources":["../../src/bundle.ts"],"names":["moduleExports","require","globalThis","loaders","module","exports","Object","assign"],"mappings":";;AACA,IAAMA,aAAa,GAAGC,OAAO,CAAC,SAAD,CAA7B;;AACAC,UAAU,CAACC,OAAX,GAAqBD,UAAU,CAACC,OAAX,IAAsB,EAA3C;AACAC,MAAM,CAACC,OAAP,GAAiBC,MAAM,CAACC,MAAP,CAAcL,UAAU,CAACC,OAAzB,EAAkCH,aAAlC,CAAjB","sourcesContent":["// @ts-nocheck\nconst moduleExports = require('./index');\nglobalThis.loaders = globalThis.loaders || {};\nmodule.exports = Object.assign(globalThis.loaders, moduleExports);\n"],"file":"bundle.js"}
@@ -1,98 +0,0 @@
1
- "use strict";
2
-
3
- Object.defineProperty(exports, "__esModule", {
4
- value: true
5
- });
6
- exports.classifyRings = classifyRings;
7
- exports.project = project;
8
- exports.readFeature = readFeature;
9
- exports.readTag = readTag;
10
-
11
- var _polygon = require("@math.gl/polygon");
12
-
13
- function classifyRings(geom) {
14
- var len = geom.indices.length;
15
- var type = 'Polygon';
16
-
17
- if (len <= 1) {
18
- return {
19
- type: type,
20
- data: geom.data,
21
- areas: [[(0, _polygon.getPolygonSignedArea)(geom.data)]],
22
- indices: [geom.indices]
23
- };
24
- }
25
-
26
- var areas = [];
27
- var polygons = [];
28
- var ringAreas = [];
29
- var polygon = [];
30
- var ccw;
31
- var offset = 0;
32
-
33
- for (var endIndex, i = 0, startIndex; i < len; i++) {
34
- startIndex = geom.indices[i] - offset;
35
- endIndex = geom.indices[i + 1] - offset || geom.data.length;
36
- var shape = geom.data.slice(startIndex, endIndex);
37
- var area = (0, _polygon.getPolygonSignedArea)(shape);
38
-
39
- if (area === 0) {
40
- var before = geom.data.slice(0, startIndex);
41
- var after = geom.data.slice(endIndex);
42
- geom.data = before.concat(after);
43
- offset += endIndex - startIndex;
44
- continue;
45
- }
46
-
47
- if (ccw === undefined) ccw = area < 0;
48
-
49
- if (ccw === area < 0) {
50
- if (polygon.length) {
51
- areas.push(ringAreas);
52
- polygons.push(polygon);
53
- }
54
-
55
- polygon = [startIndex];
56
- ringAreas = [area];
57
- } else {
58
- ringAreas.push(area);
59
- polygon.push(startIndex);
60
- }
61
- }
62
-
63
- if (ringAreas) areas.push(ringAreas);
64
- if (polygon.length) polygons.push(polygon);
65
- return {
66
- type: type,
67
- areas: areas,
68
- indices: polygons,
69
- data: geom.data
70
- };
71
- }
72
-
73
- function project(data, x0, y0, size) {
74
- for (var j = 0, jl = data.length; j < jl; j += 2) {
75
- data[j] = (data[j] + x0) * 360 / size - 180;
76
- var y2 = 180 - (data[j + 1] + y0) * 360 / size;
77
- data[j + 1] = 360 / Math.PI * Math.atan(Math.exp(y2 * Math.PI / 180)) - 90;
78
- }
79
- }
80
-
81
- function readFeature(tag, feature, pbf) {
82
- if (feature && pbf) {
83
- if (tag === 1) feature.id = pbf.readVarint();else if (tag === 2) readTag(pbf, feature);else if (tag === 3) feature.type = pbf.readVarint();else if (tag === 4) feature._geometry = pbf.pos;
84
- }
85
- }
86
-
87
- function readTag(pbf, feature) {
88
- var end = pbf.readVarint() + pbf.pos;
89
-
90
- while (pbf.pos < end) {
91
- var key = feature._keys[pbf.readVarint()];
92
-
93
- var value = feature._values[pbf.readVarint()];
94
-
95
- feature.properties[key] = value;
96
- }
97
- }
98
- //# sourceMappingURL=binary-util-functions.js.map
@@ -1 +0,0 @@
1
- {"version":3,"sources":["../../../src/helpers/binary-util-functions.ts"],"names":["classifyRings","geom","len","indices","length","type","data","areas","polygons","ringAreas","polygon","ccw","offset","endIndex","i","startIndex","shape","slice","area","before","after","concat","undefined","push","project","x0","y0","size","j","jl","y2","Math","PI","atan","exp","readFeature","tag","feature","pbf","id","readVarint","readTag","_geometry","pos","end","key","_keys","value","_values","properties"],"mappings":"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","sourcesContent":["import Protobuf from 'pbf';\nimport {getPolygonSignedArea} from '@math.gl/polygon';\nimport {FlatIndexedGeometry, FlatPolygon} from '@loaders.gl/schema';\nimport VectorTileFeature from '../lib/binary-vector-tile/vector-tile-feature';\n\n/**\n * Classifies an array of rings into polygons with outer rings and holes\n * The function also detects holes which have zero area and\n * removes them. In doing so it modifies the input\n * `geom.data` array to remove the unneeded data\n *\n * @param geometry\n * @returns object\n */\n// eslint-disable-next-line max-statements\nexport function classifyRings(geom: FlatIndexedGeometry): FlatPolygon {\n const len = geom.indices.length;\n const type = 'Polygon';\n\n if (len <= 1) {\n return {\n type,\n data: geom.data,\n areas: [[getPolygonSignedArea(geom.data)]],\n indices: [geom.indices]\n };\n }\n\n const areas: any[] = [];\n const polygons: any[] = [];\n let ringAreas: number[] = [];\n let polygon: number[] = [];\n let ccw: boolean | undefined;\n let offset = 0;\n\n for (let endIndex: number, i = 0, startIndex: number; i < len; i++) {\n startIndex = geom.indices[i] - offset;\n\n endIndex = geom.indices[i + 1] - offset || geom.data.length;\n const shape = geom.data.slice(startIndex, endIndex);\n const area = getPolygonSignedArea(shape);\n\n if (area === 0) {\n // This polygon has no area, so remove it from the shape\n // Remove the section from the data array\n const before = geom.data.slice(0, startIndex);\n const after = geom.data.slice(endIndex);\n geom.data = before.concat(after);\n\n // Need to offset any remaining indices as we have\n // modified the data buffer\n offset += endIndex - startIndex;\n\n // Do not add this index to the output and process next shape\n continue; // eslint-disable-line no-continue\n }\n\n if (ccw === undefined) ccw = area < 0;\n\n if (ccw === area < 0) {\n if (polygon.length) {\n areas.push(ringAreas);\n polygons.push(polygon);\n }\n polygon = [startIndex];\n ringAreas = [area];\n } else {\n ringAreas.push(area);\n polygon.push(startIndex);\n }\n }\n if (ringAreas) areas.push(ringAreas);\n if (polygon.length) polygons.push(polygon);\n\n return {type, areas, indices: polygons, data: geom.data};\n}\n\n/**\n *\n * @param data\n * @param x0\n * @param y0\n * @param size\n */\nexport function project(data: number[], x0: number, y0: number, size: number): void {\n for (let j = 0, jl = data.length; j < jl; j += 2) {\n data[j] = ((data[j] + x0) * 360) / size - 180;\n const y2 = 180 - ((data[j + 1] + y0) * 360) / size;\n data[j + 1] = (360 / Math.PI) * Math.atan(Math.exp((y2 * Math.PI) / 180)) - 90;\n }\n}\n\n/**\n * All code below is unchanged from the original Mapbox implemenation\n *\n * @param tag\n * @param feature\n * @param pbf\n */\nexport function readFeature(tag: number, feature?: VectorTileFeature, pbf?: Protobuf): void {\n if (feature && pbf) {\n if (tag === 1) feature.id = pbf.readVarint();\n else if (tag === 2) readTag(pbf, feature);\n else if (tag === 3) feature.type = pbf.readVarint();\n else if (tag === 4) feature._geometry = pbf.pos;\n }\n}\n\n/**\n * @param pbf\n * @param feature\n */\nexport function readTag(pbf: Protobuf, feature: VectorTileFeature): void {\n const end = pbf.readVarint() + pbf.pos;\n\n while (pbf.pos < end) {\n const key = feature._keys[pbf.readVarint()];\n const value = feature._values[pbf.readVarint()];\n feature.properties[key] = value;\n }\n}\n"],"file":"binary-util-functions.js"}
@@ -1,62 +0,0 @@
1
- "use strict";
2
-
3
- Object.defineProperty(exports, "__esModule", {
4
- value: true
5
- });
6
- exports.classifyRings = classifyRings;
7
- exports.signedArea = signedArea;
8
- exports.readFeature = readFeature;
9
- exports.readTag = readTag;
10
-
11
- function classifyRings(rings) {
12
- var len = rings.length;
13
- if (len <= 1) return [rings];
14
- var polygons = [];
15
- var polygon;
16
- var ccw;
17
-
18
- for (var i = 0; i < len; i++) {
19
- var area = signedArea(rings[i]);
20
- if (area === 0) continue;
21
- if (ccw === undefined) ccw = area < 0;
22
-
23
- if (ccw === area < 0) {
24
- if (polygon) polygons.push(polygon);
25
- polygon = [rings[i]];
26
- } else if (polygon) polygon.push(rings[i]);
27
- }
28
-
29
- if (polygon) polygons.push(polygon);
30
- return polygons;
31
- }
32
-
33
- function signedArea(ring) {
34
- var sum = 0;
35
-
36
- for (var i = 0, j = ring.length - 1, p1, p2; i < ring.length; j = i++) {
37
- p1 = ring[i];
38
- p2 = ring[j];
39
- sum += (p2[0] - p1[0]) * (p1[1] + p2[1]);
40
- }
41
-
42
- return sum;
43
- }
44
-
45
- function readFeature(tag, feature, pbf) {
46
- if (feature && pbf) {
47
- if (tag === 1) feature.id = pbf.readVarint();else if (tag === 2) readTag(pbf, feature);else if (tag === 3) feature.type = pbf.readVarint();else if (tag === 4) feature._geometry = pbf.pos;
48
- }
49
- }
50
-
51
- function readTag(pbf, feature) {
52
- var end = pbf.readVarint() + pbf.pos;
53
-
54
- while (pbf.pos < end) {
55
- var key = feature._keys[pbf.readVarint()];
56
-
57
- var value = feature._values[pbf.readVarint()];
58
-
59
- feature.properties[key] = value;
60
- }
61
- }
62
- //# sourceMappingURL=mapbox-util-functions.js.map
@@ -1 +0,0 @@
1
- {"version":3,"sources":["../../../src/helpers/mapbox-util-functions.ts"],"names":["classifyRings","rings","len","length","polygons","polygon","ccw","i","area","signedArea","undefined","push","ring","sum","j","p1","p2","readFeature","tag","feature","pbf","id","readVarint","readTag","type","_geometry","pos","end","key","_keys","value","_values","properties"],"mappings":";;;;;;;;;;AASO,SAASA,aAAT,CAAuBC,KAAvB,EAAiD;AACtD,MAAMC,GAAG,GAAGD,KAAK,CAACE,MAAlB;AAEA,MAAID,GAAG,IAAI,CAAX,EAAc,OAAO,CAACD,KAAD,CAAP;AAEd,MAAMG,QAAsB,GAAG,EAA/B;AACA,MAAIC,OAAJ;AACA,MAAIC,GAAJ;;AAEA,OAAK,IAAIC,CAAC,GAAG,CAAb,EAAgBA,CAAC,GAAGL,GAApB,EAAyBK,CAAC,EAA1B,EAA8B;AAC5B,QAAMC,IAAI,GAAGC,UAAU,CAACR,KAAK,CAACM,CAAD,CAAN,CAAvB;AACA,QAAIC,IAAI,KAAK,CAAb,EAAgB;AAEhB,QAAIF,GAAG,KAAKI,SAAZ,EAAuBJ,GAAG,GAAGE,IAAI,GAAG,CAAb;;AAEvB,QAAIF,GAAG,KAAKE,IAAI,GAAG,CAAnB,EAAsB;AACpB,UAAIH,OAAJ,EAAaD,QAAQ,CAACO,IAAT,CAAcN,OAAd;AACbA,MAAAA,OAAO,GAAG,CAACJ,KAAK,CAACM,CAAD,CAAN,CAAV;AACD,KAHD,MAGO,IAAIF,OAAJ,EAAaA,OAAO,CAACM,IAAR,CAAaV,KAAK,CAACM,CAAD,CAAlB;AACrB;;AACD,MAAIF,OAAJ,EAAaD,QAAQ,CAACO,IAAT,CAAcN,OAAd;AAEb,SAAOD,QAAP;AACD;;AAOM,SAASK,UAAT,CAAoBG,IAApB,EAAsC;AAC3C,MAAIC,GAAG,GAAG,CAAV;;AACA,OAAK,IAAIN,CAAC,GAAG,CAAR,EAAWO,CAAC,GAAGF,IAAI,CAACT,MAAL,GAAc,CAA7B,EAAgCY,EAAhC,EAA8CC,EAAnD,EAAiET,CAAC,GAAGK,IAAI,CAACT,MAA1E,EAAkFW,CAAC,GAAGP,CAAC,EAAvF,EAA2F;AACzFQ,IAAAA,EAAE,GAAGH,IAAI,CAACL,CAAD,CAAT;AACAS,IAAAA,EAAE,GAAGJ,IAAI,CAACE,CAAD,CAAT;AACAD,IAAAA,GAAG,IAAI,CAACG,EAAE,CAAC,CAAD,CAAF,GAAQD,EAAE,CAAC,CAAD,CAAX,KAAmBA,EAAE,CAAC,CAAD,CAAF,GAAQC,EAAE,CAAC,CAAD,CAA7B,CAAP;AACD;;AACD,SAAOH,GAAP;AACD;;AAQM,SAASI,WAAT,CAAqBC,GAArB,EAAkCC,OAAlC,EAA+DC,GAA/D,EAAqF;AAC1F,MAAID,OAAO,IAAIC,GAAf,EAAoB;AAClB,QAAIF,GAAG,KAAK,CAAZ,EAAeC,OAAO,CAACE,EAAR,GAAaD,GAAG,CAACE,UAAJ,EAAb,CAAf,KACK,IAAIJ,GAAG,KAAK,CAAZ,EAAeK,OAAO,CAACH,GAAD,EAAMD,OAAN,CAAP,CAAf,KACA,IAAID,GAAG,KAAK,CAAZ,EAAeC,OAAO,CAACK,IAAR,GAAeJ,GAAG,CAACE,UAAJ,EAAf,CAAf,KACA,IAAIJ,GAAG,KAAK,CAAZ,EAAeC,OAAO,CAACM,SAAR,GAAoBL,GAAG,CAACM,GAAxB;AACrB;AACF;;AAOM,SAASH,OAAT,CAAiBH,GAAjB,EAAgCD,OAAhC,EAAkE;AACvE,MAAMQ,GAAG,GAAGP,GAAG,CAACE,UAAJ,KAAmBF,GAAG,CAACM,GAAnC;;AAEA,SAAON,GAAG,CAACM,GAAJ,GAAUC,GAAjB,EAAsB;AACpB,QAAMC,GAAG,GAAGT,OAAO,CAACU,KAAR,CAAcT,GAAG,CAACE,UAAJ,EAAd,CAAZ;;AACA,QAAMQ,KAAK,GAAGX,OAAO,CAACY,OAAR,CAAgBX,GAAG,CAACE,UAAJ,EAAhB,CAAd;;AACAH,IAAAA,OAAO,CAACa,UAAR,CAAmBJ,GAAnB,IAA0BE,KAA1B;AACD;AACF","sourcesContent":["import Protobuf from 'pbf';\nimport {MvtMapboxGeometry} from '../lib/types';\nimport VectorTileFeature from '../lib/mapbox-vector-tile/vector-tile-feature';\n\n/**\n * Classifies an array of rings into polygons with outer rings and holes\n * @param rings\n * @returns polygons\n */\nexport function classifyRings(rings: MvtMapboxGeometry) {\n const len = rings.length;\n\n if (len <= 1) return [rings];\n\n const polygons: number[][][] = [];\n let polygon: number[][] | undefined;\n let ccw: boolean | undefined;\n\n for (let i = 0; i < len; i++) {\n const area = signedArea(rings[i]);\n if (area === 0) continue; // eslint-disable-line no-continue\n\n if (ccw === undefined) ccw = area < 0;\n\n if (ccw === area < 0) {\n if (polygon) polygons.push(polygon);\n polygon = [rings[i]];\n } else if (polygon) polygon.push(rings[i]);\n }\n if (polygon) polygons.push(polygon);\n\n return polygons;\n}\n\n/**\n *\n * @param ring\n * @returns sum\n */\nexport function signedArea(ring: number[][]) {\n let sum = 0;\n for (let i = 0, j = ring.length - 1, p1: number[], p2: number[]; i < ring.length; j = i++) {\n p1 = ring[i];\n p2 = ring[j];\n sum += (p2[0] - p1[0]) * (p1[1] + p2[1]);\n }\n return sum;\n}\n\n/**\n *\n * @param tag\n * @param feature\n * @param pbf\n */\nexport function readFeature(tag: number, feature?: VectorTileFeature, pbf?: Protobuf): void {\n if (feature && pbf) {\n if (tag === 1) feature.id = pbf.readVarint();\n else if (tag === 2) readTag(pbf, feature);\n else if (tag === 3) feature.type = pbf.readVarint();\n else if (tag === 4) feature._geometry = pbf.pos;\n }\n}\n\n/**\n *\n * @param pbf\n * @param feature\n */\nexport function readTag(pbf: Protobuf, feature: VectorTileFeature): void {\n const end = pbf.readVarint() + pbf.pos;\n\n while (pbf.pos < end) {\n const key = feature._keys[pbf.readVarint()];\n const value = feature._values[pbf.readVarint()];\n feature.properties[key] = value;\n }\n}\n"],"file":"mapbox-util-functions.js"}