@developmentseed/deck.gl-geotiff 0.3.0-beta.3 → 0.3.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 +33 -4
- package/dist/cog-layer.d.ts +34 -27
- package/dist/cog-layer.d.ts.map +1 -1
- package/dist/cog-layer.js +50 -14
- package/dist/cog-layer.js.map +1 -1
- package/dist/geotiff/geotiff.d.ts.map +1 -1
- package/dist/geotiff/geotiff.js +6 -2
- package/dist/geotiff/geotiff.js.map +1 -1
- package/dist/geotiff/render-pipeline.d.ts +6 -4
- package/dist/geotiff/render-pipeline.d.ts.map +1 -1
- package/dist/geotiff/render-pipeline.js +116 -16
- package/dist/geotiff/render-pipeline.js.map +1 -1
- package/dist/geotiff-layer.d.ts +5 -4
- package/dist/geotiff-layer.d.ts.map +1 -1
- package/dist/geotiff-layer.js.map +1 -1
- package/dist/geotiff-reprojection.d.ts +2 -1
- package/dist/geotiff-reprojection.d.ts.map +1 -1
- package/dist/geotiff-reprojection.js.map +1 -1
- package/dist/index.d.ts +3 -2
- package/dist/index.d.ts.map +1 -1
- package/dist/index.js +1 -1
- package/dist/index.js.map +1 -1
- package/package.json +12 -12
- package/dist/cog-tile-matrix-set.d.ts +0 -3
- package/dist/cog-tile-matrix-set.d.ts.map +0 -1
- package/dist/cog-tile-matrix-set.js +0 -23
- package/dist/cog-tile-matrix-set.js.map +0 -1
- package/dist/ellipsoids.d.ts +0 -153
- package/dist/ellipsoids.d.ts.map +0 -1
- package/dist/ellipsoids.js +0 -153
- package/dist/ellipsoids.js.map +0 -1
- package/dist/geotiff/high-level/affine.d.ts +0 -16
- package/dist/geotiff/high-level/affine.d.ts.map +0 -1
- package/dist/geotiff/high-level/affine.js +0 -2
- package/dist/geotiff/high-level/affine.js.map +0 -1
- package/dist/geotiff/high-level/array.d.ts +0 -37
- package/dist/geotiff/high-level/array.d.ts.map +0 -1
- package/dist/geotiff/high-level/array.js +0 -2
- package/dist/geotiff/high-level/array.js.map +0 -1
- package/dist/geotiff/high-level/geotiff.d.ts +0 -63
- package/dist/geotiff/high-level/geotiff.d.ts.map +0 -1
- package/dist/geotiff/high-level/geotiff.js +0 -135
- package/dist/geotiff/high-level/geotiff.js.map +0 -1
- package/dist/geotiff/high-level/index.d.ts +0 -8
- package/dist/geotiff/high-level/index.d.ts.map +0 -1
- package/dist/geotiff/high-level/index.js +0 -5
- package/dist/geotiff/high-level/index.js.map +0 -1
- package/dist/geotiff/high-level/options.d.ts +0 -11
- package/dist/geotiff/high-level/options.d.ts.map +0 -1
- package/dist/geotiff/high-level/options.js +0 -2
- package/dist/geotiff/high-level/options.js.map +0 -1
- package/dist/geotiff/high-level/overview.d.ts +0 -46
- package/dist/geotiff/high-level/overview.d.ts.map +0 -1
- package/dist/geotiff/high-level/overview.js +0 -124
- package/dist/geotiff/high-level/overview.js.map +0 -1
- package/dist/geotiff/high-level/tile.d.ts +0 -11
- package/dist/geotiff/high-level/tile.d.ts.map +0 -1
- package/dist/geotiff/high-level/tile.js +0 -2
- package/dist/geotiff/high-level/tile.js.map +0 -1
- package/dist/geotiff/high-level/transform.d.ts +0 -23
- package/dist/geotiff/high-level/transform.d.ts.map +0 -1
- package/dist/geotiff/high-level/transform.js +0 -55
- package/dist/geotiff/high-level/transform.js.map +0 -1
- package/dist/geotiff/high-level/window.d.ts +0 -23
- package/dist/geotiff/high-level/window.d.ts.map +0 -1
- package/dist/geotiff/high-level/window.js +0 -31
- package/dist/geotiff/high-level/window.js.map +0 -1
- package/dist/geotiff/types.d.ts +0 -5
- package/dist/geotiff/types.d.ts.map +0 -1
- package/dist/geotiff/types.js +0 -7
- package/dist/geotiff/types.js.map +0 -1
- package/dist/geotiff-types.d.ts +0 -13
- package/dist/geotiff-types.d.ts.map +0 -1
- package/dist/geotiff-types.js +0 -2
- package/dist/geotiff-types.js.map +0 -1
- package/dist/geotiff.d.ts +0 -50
- package/dist/geotiff.d.ts.map +0 -1
- package/dist/geotiff.js +0 -135
- package/dist/geotiff.js.map +0 -1
- package/dist/mosaic-layer/mosaic-tile-traversal.d.ts +0 -1
- package/dist/mosaic-layer/mosaic-tile-traversal.d.ts.map +0 -1
- package/dist/mosaic-layer/mosaic-tile-traversal.js +0 -2
- package/dist/mosaic-layer/mosaic-tile-traversal.js.map +0 -1
- package/dist/mosaic-layer.d.ts +0 -1
- package/dist/mosaic-layer.d.ts.map +0 -1
- package/dist/mosaic-layer.js +0 -2
- package/dist/mosaic-layer.js.map +0 -1
- package/dist/texture.d.ts +0 -10
- package/dist/texture.d.ts.map +0 -1
- package/dist/texture.js +0 -135
- package/dist/texture.js.map +0 -1
- package/dist/tsconfig.tsbuildinfo +0 -1
package/dist/geotiff.d.ts
DELETED
|
@@ -1,50 +0,0 @@
|
|
|
1
|
-
import type { GeoTIFF, GeoTIFFImage } from "geotiff";
|
|
2
|
-
import { BaseClient, Pool } from "geotiff";
|
|
3
|
-
import type { Converter } from "proj4";
|
|
4
|
-
/**
|
|
5
|
-
* Options that may be passed when reading image data from geotiff.js
|
|
6
|
-
*/
|
|
7
|
-
type ReadRasterOptions = {
|
|
8
|
-
/** the subset to read data from in pixels. */
|
|
9
|
-
window?: [number, number, number, number];
|
|
10
|
-
/** The optional decoder pool to use. */
|
|
11
|
-
pool?: Pool;
|
|
12
|
-
/** An AbortSignal that may be signalled if the request is to be aborted */
|
|
13
|
-
signal?: AbortSignal;
|
|
14
|
-
};
|
|
15
|
-
/**
|
|
16
|
-
* Retrieve the default geotiff.js decoder Pool.
|
|
17
|
-
*
|
|
18
|
-
* If a Pool has not yet been created, it will be created on first call.
|
|
19
|
-
*
|
|
20
|
-
* The Pool will be shared between all COGLayer and GeoTIFFLayer instances.
|
|
21
|
-
*/
|
|
22
|
-
export declare function defaultPool(): Pool;
|
|
23
|
-
/**
|
|
24
|
-
* Load an RGBA image from a GeoTIFFImage.
|
|
25
|
-
*/
|
|
26
|
-
export declare function loadRgbImage(image: GeoTIFFImage, options?: ReadRasterOptions): Promise<{
|
|
27
|
-
texture: ImageData;
|
|
28
|
-
height: number;
|
|
29
|
-
width: number;
|
|
30
|
-
}>;
|
|
31
|
-
/**
|
|
32
|
-
* Parse the GeoTIFF `ColorMap` tag into an ImageData.
|
|
33
|
-
*
|
|
34
|
-
* @param {Uint16Array} cmap The colormap array from the GeoTIFF `ColorMap` tag.
|
|
35
|
-
*
|
|
36
|
-
* @return {ImageData} The parsed colormap as an ImageData object.
|
|
37
|
-
*/
|
|
38
|
-
export declare function parseColormap(cmap: Uint16Array): ImageData;
|
|
39
|
-
export declare function fetchGeoTIFF(input: GeoTIFF | string | ArrayBuffer | Blob | BaseClient): Promise<GeoTIFF>;
|
|
40
|
-
/**
|
|
41
|
-
* Calculate the WGS84 bounding box of a GeoTIFF image
|
|
42
|
-
*/
|
|
43
|
-
export declare function getGeographicBounds(image: GeoTIFFImage, converter: Converter): {
|
|
44
|
-
west: number;
|
|
45
|
-
south: number;
|
|
46
|
-
east: number;
|
|
47
|
-
north: number;
|
|
48
|
-
};
|
|
49
|
-
export {};
|
|
50
|
-
//# sourceMappingURL=geotiff.d.ts.map
|
package/dist/geotiff.d.ts.map
DELETED
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"geotiff.d.ts","sourceRoot":"","sources":["../src/geotiff.ts"],"names":[],"mappings":"AAEA,OAAO,KAAK,EAAE,OAAO,EAAE,YAAY,EAA4B,MAAM,SAAS,CAAC;AAC/E,OAAO,EACL,UAAU,EAKV,IAAI,EACL,MAAM,SAAS,CAAC;AACjB,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,OAAO,CAAC;AAEvC;;GAEG;AACH,KAAK,iBAAiB,GAAG;IACvB,8CAA8C;IAC9C,MAAM,CAAC,EAAE,CAAC,MAAM,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,CAAC,CAAC;IAE1C,wCAAwC;IACxC,IAAI,CAAC,EAAE,IAAI,CAAC;IAEZ,2EAA2E;IAC3E,MAAM,CAAC,EAAE,WAAW,CAAC;CACtB,CAAC;AASF;;;;;;GAMG;AACH,wBAAgB,WAAW,IAAI,IAAI,CAMlC;AAED;;GAEG;AACH,wBAAsB,YAAY,CAChC,KAAK,EAAE,YAAY,EACnB,OAAO,CAAC,EAAE,iBAAiB,GAC1B,OAAO,CAAC;IAAE,OAAO,EAAE,SAAS,CAAC;IAAC,MAAM,EAAE,MAAM,CAAC;IAAC,KAAK,EAAE,MAAM,CAAA;CAAE,CAAC,CAmBhE;AAkCD;;;;;;GAMG;AACH,wBAAgB,aAAa,CAAC,IAAI,EAAE,WAAW,GAAG,SAAS,CAqB1D;AAED,wBAAsB,YAAY,CAChC,KAAK,EAAE,OAAO,GAAG,MAAM,GAAG,WAAW,GAAG,IAAI,GAAG,UAAU,GACxD,OAAO,CAAC,OAAO,CAAC,CAoBlB;AAED;;GAEG;AACH,wBAAgB,mBAAmB,CACjC,KAAK,EAAE,YAAY,EACnB,SAAS,EAAE,SAAS,GACnB;IAAE,IAAI,EAAE,MAAM,CAAC;IAAC,KAAK,EAAE,MAAM,CAAC;IAAC,IAAI,EAAE,MAAM,CAAC;IAAC,KAAK,EAAE,MAAM,CAAA;CAAE,CA4B9D"}
|
package/dist/geotiff.js
DELETED
|
@@ -1,135 +0,0 @@
|
|
|
1
|
-
// Utilities for interacting with geotiff.js.
|
|
2
|
-
import { BaseClient, fromArrayBuffer, fromBlob, fromCustomClient, fromUrl, Pool, } from "geotiff";
|
|
3
|
-
/**
|
|
4
|
-
* A default geotiff.js decoder pool instance.
|
|
5
|
-
*
|
|
6
|
-
* It will be created on first call of `defaultPool`.
|
|
7
|
-
*/
|
|
8
|
-
let DEFAULT_POOL = null;
|
|
9
|
-
/**
|
|
10
|
-
* Retrieve the default geotiff.js decoder Pool.
|
|
11
|
-
*
|
|
12
|
-
* If a Pool has not yet been created, it will be created on first call.
|
|
13
|
-
*
|
|
14
|
-
* The Pool will be shared between all COGLayer and GeoTIFFLayer instances.
|
|
15
|
-
*/
|
|
16
|
-
export function defaultPool() {
|
|
17
|
-
if (DEFAULT_POOL === null) {
|
|
18
|
-
DEFAULT_POOL = new Pool();
|
|
19
|
-
}
|
|
20
|
-
return DEFAULT_POOL;
|
|
21
|
-
}
|
|
22
|
-
/**
|
|
23
|
-
* Load an RGBA image from a GeoTIFFImage.
|
|
24
|
-
*/
|
|
25
|
-
export async function loadRgbImage(image, options) {
|
|
26
|
-
const mergedOptions = {
|
|
27
|
-
...options,
|
|
28
|
-
interleave: true,
|
|
29
|
-
enableAlpha: true,
|
|
30
|
-
};
|
|
31
|
-
// Since we set interleave: true, the result is a single array with all
|
|
32
|
-
// samples, so we cast to TypedArrayWithDimensions
|
|
33
|
-
// https://github.com/geotiffjs/geotiff.js/issues/486
|
|
34
|
-
const rgbImage = (await image.readRGB(mergedOptions));
|
|
35
|
-
const imageData = addAlphaChannel(rgbImage);
|
|
36
|
-
return {
|
|
37
|
-
texture: imageData,
|
|
38
|
-
height: rgbImage.height,
|
|
39
|
-
width: rgbImage.width,
|
|
40
|
-
};
|
|
41
|
-
}
|
|
42
|
-
/**
|
|
43
|
-
* Add an alpha channel to an RGB image array.
|
|
44
|
-
*
|
|
45
|
-
* Only supports input arrays with 3 (RGB) or 4 (RGBA) channels. If the input is
|
|
46
|
-
* already RGBA, it is returned unchanged.
|
|
47
|
-
*/
|
|
48
|
-
function addAlphaChannel(rgbImage) {
|
|
49
|
-
const { height, width } = rgbImage;
|
|
50
|
-
if (rgbImage.length === height * width * 4) {
|
|
51
|
-
// Already has alpha channel
|
|
52
|
-
return new ImageData(new Uint8ClampedArray(rgbImage), width, height);
|
|
53
|
-
}
|
|
54
|
-
else if (rgbImage.length === height * width * 3) {
|
|
55
|
-
// Need to add alpha channel
|
|
56
|
-
const rgbaLength = (rgbImage.length / 3) * 4;
|
|
57
|
-
const rgbaArray = new Uint8ClampedArray(rgbaLength);
|
|
58
|
-
for (let i = 0; i < rgbImage.length / 3; ++i) {
|
|
59
|
-
rgbaArray[i * 4] = rgbImage[i * 3];
|
|
60
|
-
rgbaArray[i * 4 + 1] = rgbImage[i * 3 + 1];
|
|
61
|
-
rgbaArray[i * 4 + 2] = rgbImage[i * 3 + 2];
|
|
62
|
-
rgbaArray[i * 4 + 3] = 255;
|
|
63
|
-
}
|
|
64
|
-
return new ImageData(rgbaArray, width, height);
|
|
65
|
-
}
|
|
66
|
-
else {
|
|
67
|
-
throw new Error(`Unexpected number of channels in raster data: ${rgbImage.length / (height * width)}`);
|
|
68
|
-
}
|
|
69
|
-
}
|
|
70
|
-
/**
|
|
71
|
-
* Parse the GeoTIFF `ColorMap` tag into an ImageData.
|
|
72
|
-
*
|
|
73
|
-
* @param {Uint16Array} cmap The colormap array from the GeoTIFF `ColorMap` tag.
|
|
74
|
-
*
|
|
75
|
-
* @return {ImageData} The parsed colormap as an ImageData object.
|
|
76
|
-
*/
|
|
77
|
-
export function parseColormap(cmap) {
|
|
78
|
-
// TODO: test colormap handling on a 16-bit image with 2^16 entries?
|
|
79
|
-
const size = cmap.length / 3;
|
|
80
|
-
const rgba = new Uint8ClampedArray(size * 4);
|
|
81
|
-
const rOffset = 0;
|
|
82
|
-
const gOffset = size;
|
|
83
|
-
const bOffset = size * 2;
|
|
84
|
-
// Note: >> 8 is needed to convert from 16-bit to 8-bit color values
|
|
85
|
-
// It just divides by 256 and floors to nearest integer
|
|
86
|
-
for (let i = 0; i < size; i++) {
|
|
87
|
-
rgba[4 * i + 0] = cmap[rOffset + i] >> 8;
|
|
88
|
-
rgba[4 * i + 1] = cmap[gOffset + i] >> 8;
|
|
89
|
-
rgba[4 * i + 2] = cmap[bOffset + i] >> 8;
|
|
90
|
-
// Full opacity
|
|
91
|
-
rgba[4 * i + 3] = 255;
|
|
92
|
-
}
|
|
93
|
-
return new ImageData(rgba, size, 1);
|
|
94
|
-
}
|
|
95
|
-
export async function fetchGeoTIFF(input) {
|
|
96
|
-
if (typeof input === "string") {
|
|
97
|
-
return fromUrl(input);
|
|
98
|
-
}
|
|
99
|
-
if (input instanceof ArrayBuffer) {
|
|
100
|
-
return fromArrayBuffer(input);
|
|
101
|
-
}
|
|
102
|
-
if (input instanceof Blob) {
|
|
103
|
-
return fromBlob(input);
|
|
104
|
-
}
|
|
105
|
-
// TODO: instanceof may fail here if multiple versions of geotiff.js are
|
|
106
|
-
// present
|
|
107
|
-
if (input instanceof BaseClient) {
|
|
108
|
-
return fromCustomClient(input);
|
|
109
|
-
}
|
|
110
|
-
return input;
|
|
111
|
-
}
|
|
112
|
-
/**
|
|
113
|
-
* Calculate the WGS84 bounding box of a GeoTIFF image
|
|
114
|
-
*/
|
|
115
|
-
export function getGeographicBounds(image, converter) {
|
|
116
|
-
const projectedBbox = image.getBoundingBox();
|
|
117
|
-
// Reproject all four corners to handle rotation/skew
|
|
118
|
-
const [minX, minY, maxX, maxY] = projectedBbox;
|
|
119
|
-
const corners = [
|
|
120
|
-
converter.forward([minX, minY]), // bottom-left
|
|
121
|
-
converter.forward([maxX, minY]), // bottom-right
|
|
122
|
-
converter.forward([maxX, maxY]), // top-right
|
|
123
|
-
converter.forward([minX, maxY]), // top-left
|
|
124
|
-
];
|
|
125
|
-
// Find the bounding box that encompasses all reprojected corners
|
|
126
|
-
const lons = corners.map((c) => c[0]);
|
|
127
|
-
const lats = corners.map((c) => c[1]);
|
|
128
|
-
const west = Math.min(...lons);
|
|
129
|
-
const south = Math.min(...lats);
|
|
130
|
-
const east = Math.max(...lons);
|
|
131
|
-
const north = Math.max(...lats);
|
|
132
|
-
// Return bounds in MapLibre format: [[west, south], [east, north]]
|
|
133
|
-
return { west, south, east, north };
|
|
134
|
-
}
|
|
135
|
-
//# sourceMappingURL=geotiff.js.map
|
package/dist/geotiff.js.map
DELETED
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"geotiff.js","sourceRoot":"","sources":["../src/geotiff.ts"],"names":[],"mappings":"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"}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
//# sourceMappingURL=mosaic-tile-traversal.d.ts.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"mosaic-tile-traversal.d.ts","sourceRoot":"","sources":["../../src/mosaic-layer/mosaic-tile-traversal.ts"],"names":[],"mappings":""}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"mosaic-tile-traversal.js","sourceRoot":"","sources":["../../src/mosaic-layer/mosaic-tile-traversal.ts"],"names":[],"mappings":""}
|
package/dist/mosaic-layer.d.ts
DELETED
|
@@ -1 +0,0 @@
|
|
|
1
|
-
//# sourceMappingURL=mosaic-layer.d.ts.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"mosaic-layer.d.ts","sourceRoot":"","sources":["../src/mosaic-layer.ts"],"names":[],"mappings":""}
|
package/dist/mosaic-layer.js
DELETED
package/dist/mosaic-layer.js.map
DELETED
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"mosaic-layer.js","sourceRoot":"","sources":["../src/mosaic-layer.ts"],"names":[],"mappings":""}
|
package/dist/texture.d.ts
DELETED
|
@@ -1,10 +0,0 @@
|
|
|
1
|
-
import type { TextureProps } from "@luma.gl/core";
|
|
2
|
-
import type { GeoTIFFImage, TypedArray } from "geotiff";
|
|
3
|
-
/**
|
|
4
|
-
* Infers texture properties from a GeoTIFF image and its associated data.
|
|
5
|
-
*/
|
|
6
|
-
export declare function createTextureProps(image: GeoTIFFImage, data: TypedArray, options: {
|
|
7
|
-
width: number;
|
|
8
|
-
height: number;
|
|
9
|
-
}): TextureProps;
|
|
10
|
-
//# sourceMappingURL=texture.d.ts.map
|
package/dist/texture.d.ts.map
DELETED
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"texture.d.ts","sourceRoot":"","sources":["../src/texture.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAiB,YAAY,EAAE,MAAM,eAAe,CAAC;AACjE,OAAO,KAAK,EAAE,YAAY,EAAE,UAAU,EAAE,MAAM,SAAS,CAAC;AAGxD;;GAEG;AACH,wBAAgB,kBAAkB,CAChC,KAAK,EAAE,YAAY,EACnB,IAAI,EAAE,UAAU,EAChB,OAAO,EAAE;IAAE,KAAK,EAAE,MAAM,CAAC;IAAC,MAAM,EAAE,MAAM,CAAA;CAAE,GACzC,YAAY,CAiBd"}
|
package/dist/texture.js
DELETED
|
@@ -1,135 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* Infers texture properties from a GeoTIFF image and its associated data.
|
|
3
|
-
*/
|
|
4
|
-
export function createTextureProps(image, data, options) {
|
|
5
|
-
const ifd = image.getFileDirectory();
|
|
6
|
-
const samplesPerPixel = ifd.SamplesPerPixel;
|
|
7
|
-
const textureFormat = inferTextureFormat(samplesPerPixel, ifd.BitsPerSample, ifd.SampleFormat);
|
|
8
|
-
return {
|
|
9
|
-
data,
|
|
10
|
-
dimension: "2d",
|
|
11
|
-
format: textureFormat,
|
|
12
|
-
width: options.width,
|
|
13
|
-
height: options.height,
|
|
14
|
-
};
|
|
15
|
-
}
|
|
16
|
-
/**
|
|
17
|
-
* Infer the TextureFormat given values from GeoTIFF tags.
|
|
18
|
-
*/
|
|
19
|
-
function inferTextureFormat(samplesPerPixel, bitsPerSample, sampleFormat) {
|
|
20
|
-
const channelCount = verifySamplesPerPixel(samplesPerPixel);
|
|
21
|
-
const bitWidth = verifyIdenticalBitsPerSample(bitsPerSample);
|
|
22
|
-
const scalarKind = inferScalarKind(sampleFormat);
|
|
23
|
-
const formatKey = `${channelCount}:${scalarKind}:${bitWidth}`;
|
|
24
|
-
const format = FORMAT_TABLE[formatKey];
|
|
25
|
-
if (!format) {
|
|
26
|
-
throw new Error(`Unsupported texture format for SamplesPerPixel=${samplesPerPixel}, BitsPerSample=${bitsPerSample}, SampleFormat=${sampleFormat}`);
|
|
27
|
-
}
|
|
28
|
-
return format;
|
|
29
|
-
}
|
|
30
|
-
function verifySamplesPerPixel(samplesPerPixel) {
|
|
31
|
-
if (samplesPerPixel === 1 ||
|
|
32
|
-
samplesPerPixel === 2 ||
|
|
33
|
-
samplesPerPixel === 3 ||
|
|
34
|
-
samplesPerPixel === 4) {
|
|
35
|
-
return samplesPerPixel;
|
|
36
|
-
}
|
|
37
|
-
throw new Error(`Unsupported SamplesPerPixel ${samplesPerPixel}. Only 1, 2, 3, or 4 are supported.`);
|
|
38
|
-
}
|
|
39
|
-
function verifyIdenticalBitsPerSample(bitsPerSample) {
|
|
40
|
-
// bitsPerSamples is non-empty
|
|
41
|
-
const first = bitsPerSample[0];
|
|
42
|
-
for (let i = 1; i < bitsPerSample.length; i++) {
|
|
43
|
-
if (bitsPerSample[i] !== first) {
|
|
44
|
-
throw new Error(`Unsupported varying BitsPerSample ${bitsPerSample}. All samples must have the same bit width.`);
|
|
45
|
-
}
|
|
46
|
-
}
|
|
47
|
-
if (first !== 8 && first !== 16 && first !== 32) {
|
|
48
|
-
throw new Error(`Unsupported BitsPerSample ${first}. Only 8, 16, or 32 are supported.`);
|
|
49
|
-
}
|
|
50
|
-
return first;
|
|
51
|
-
}
|
|
52
|
-
/**
|
|
53
|
-
* Map the geotiff tag SampleFormat to known kinds of scalars
|
|
54
|
-
*/
|
|
55
|
-
function inferScalarKind(sampleFormat) {
|
|
56
|
-
// Only support identical SampleFormats for all samples
|
|
57
|
-
const first = sampleFormat[0];
|
|
58
|
-
for (let i = 1; i < sampleFormat.length; i++) {
|
|
59
|
-
if (sampleFormat[i] !== first) {
|
|
60
|
-
throw new Error(`Unsupported varying SampleFormat ${sampleFormat}. All samples must have the same format.`);
|
|
61
|
-
}
|
|
62
|
-
}
|
|
63
|
-
switch (first) {
|
|
64
|
-
case 1:
|
|
65
|
-
return "uint";
|
|
66
|
-
case 2:
|
|
67
|
-
return "sint";
|
|
68
|
-
case 3:
|
|
69
|
-
return "float";
|
|
70
|
-
default:
|
|
71
|
-
throw new Error(`Unsupported SampleFormat ${sampleFormat}`);
|
|
72
|
-
}
|
|
73
|
-
}
|
|
74
|
-
/**
|
|
75
|
-
* A mapping of our texture format "key" to allowed TextureFormats defined by
|
|
76
|
-
* luma.gl.
|
|
77
|
-
*
|
|
78
|
-
* See https://luma.gl/docs/api-reference/core/texture-formats for details on
|
|
79
|
-
* texture formats.
|
|
80
|
-
*
|
|
81
|
-
* You can use `device.isTextureFormatSupported(format)` check if it is possible
|
|
82
|
-
* to create and sample textures with a specific texture format on your current
|
|
83
|
-
* device.
|
|
84
|
-
*
|
|
85
|
-
* This explicit mapping ensures that Typescript can verify that all keys
|
|
86
|
-
* correspond to valid TextureFormats.
|
|
87
|
-
*/
|
|
88
|
-
const FORMAT_TABLE = {
|
|
89
|
-
// 1 byte per pixel
|
|
90
|
-
"1:sint:8": "r8sint",
|
|
91
|
-
"1:uint:8": "r8uint",
|
|
92
|
-
"1:unorm:8": "r8unorm",
|
|
93
|
-
// 2 bytes per pixel (one channel)
|
|
94
|
-
"1:float:16": "r16float",
|
|
95
|
-
"1:sint:16": "r16sint",
|
|
96
|
-
"1:uint:16": "r16uint",
|
|
97
|
-
"1:unorm:16": "r16unorm",
|
|
98
|
-
// 2 bytes per pixel (two channels)
|
|
99
|
-
"2:sint:8": "rg8sint",
|
|
100
|
-
"2:uint:8": "rg8uint",
|
|
101
|
-
"2:unorm:8": "rg8unorm",
|
|
102
|
-
// 4 bytes per pixel (one channel)
|
|
103
|
-
"1:float:32": "r32float",
|
|
104
|
-
"1:sint:32": "r32sint",
|
|
105
|
-
"1:uint:32": "r32uint",
|
|
106
|
-
// 4 bytes per pixel (two channels)
|
|
107
|
-
"2:float:16": "rg16float",
|
|
108
|
-
"2:sint:16": "rg16sint",
|
|
109
|
-
"2:uint:16": "rg16uint",
|
|
110
|
-
"2:unorm:16": "rg16unorm",
|
|
111
|
-
// 4 bytes per pixel (four channels)
|
|
112
|
-
"4:sint:8": "rgba8sint",
|
|
113
|
-
"4:uint:8": "rgba8uint",
|
|
114
|
-
"4:unorm:8": "rgba8unorm",
|
|
115
|
-
// 6 bytes per pixel (three channels)
|
|
116
|
-
// Note: this is supported on WebGL2 but not supported on WebGPU
|
|
117
|
-
// I expect actual switch to WebGPU to be quite a ways off still
|
|
118
|
-
"3:uint:16": "rgb16unorm-webgl",
|
|
119
|
-
// 8 bytes per pixel (two channels)
|
|
120
|
-
"2:float:32": "rg32float",
|
|
121
|
-
"2:sint:32": "rg32sint",
|
|
122
|
-
"2:uint:32": "rg32uint",
|
|
123
|
-
// 8 bytes per pixel (four channels)
|
|
124
|
-
"4:float:16": "rgba16float",
|
|
125
|
-
"4:sint:16": "rgba16sint",
|
|
126
|
-
"4:uint:16": "rgba16uint",
|
|
127
|
-
"4:unorm:16": "rgba16unorm",
|
|
128
|
-
// 12 bytes per pixel (three channels)
|
|
129
|
-
"3:float:32": "rgb32float-webgl",
|
|
130
|
-
// 16 bytes per pixel (four channels)
|
|
131
|
-
"4:float:32": "rgba32float",
|
|
132
|
-
"4:sint:32": "rgba32sint",
|
|
133
|
-
"4:uint:32": "rgba32uint",
|
|
134
|
-
};
|
|
135
|
-
//# sourceMappingURL=texture.js.map
|
package/dist/texture.js.map
DELETED
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"texture.js","sourceRoot":"","sources":["../src/texture.ts"],"names":[],"mappings":"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"}
|