@cogeotiff/core 6.1.1 → 7.0.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/CHANGELOG.md +11 -0
- package/build/cog.tiff.d.ts +2 -2
- package/build/cog.tiff.d.ts.map +1 -1
- package/build/cog.tiff.image.d.ts +6 -7
- package/build/cog.tiff.image.d.ts.map +1 -1
- package/build/cog.tiff.image.js +31 -31
- package/build/cog.tiff.js +22 -50
- package/build/read/tag/__test__/tag.test.js +1 -1
- package/build/read/tag/tiff.tag.lazy.d.ts +1 -2
- package/build/read/tag/tiff.tag.lazy.d.ts.map +1 -1
- package/build/read/tag/tiff.tag.lazy.js +3 -3
- package/build/read/tag/tiff.tag.offset.d.ts +2 -3
- package/build/read/tag/tiff.tag.offset.d.ts.map +1 -1
- package/build/read/tag/tiff.tag.offset.js +5 -5
- package/package.json +4 -5
- package/src/cog.tiff.image.ts +29 -31
- package/src/cog.tiff.ts +20 -64
- package/src/read/tag/__test__/tag.test.ts +1 -1
- package/src/read/tag/tiff.tag.lazy.ts +2 -3
- package/src/read/tag/tiff.tag.offset.ts +4 -5
package/CHANGELOG.md
CHANGED
|
@@ -3,6 +3,17 @@
|
|
|
3
3
|
All notable changes to this project will be documented in this file.
|
|
4
4
|
See [Conventional Commits](https://conventionalcommits.org) for commit guidelines.
|
|
5
5
|
|
|
6
|
+
# [7.0.0](https://github.com/blacha/cogeotiff/compare/v6.1.1...v7.0.0) (2022-03-17)
|
|
7
|
+
|
|
8
|
+
|
|
9
|
+
### Features
|
|
10
|
+
|
|
11
|
+
* **core:** upgrade chunkd and remove logger for internal fetches ([#832](https://github.com/blacha/cogeotiff/issues/832)) ([71bd740](https://github.com/blacha/cogeotiff/commit/71bd7409706e4a82e6a29b2a3fc0e8b25221e9fc))
|
|
12
|
+
|
|
13
|
+
|
|
14
|
+
|
|
15
|
+
|
|
16
|
+
|
|
6
17
|
## [6.1.1](https://github.com/blacha/cogeotiff/compare/v6.1.0...v6.1.1) (2022-01-26)
|
|
7
18
|
|
|
8
19
|
|
package/build/cog.tiff.d.ts
CHANGED
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import { ChunkSource
|
|
1
|
+
import { ChunkSource } from '@chunkd/core';
|
|
2
2
|
import { CogTiffImage } from './cog.tiff.image.js';
|
|
3
3
|
import { TiffVersion } from './const/tiff.version.js';
|
|
4
4
|
import { CogTifGhostOptions } from './read/tiff.gdal.js';
|
|
@@ -21,7 +21,7 @@ export declare class CogTiff {
|
|
|
21
21
|
*
|
|
22
22
|
* @param loadGeoKeys Whether to also initialize the GeoKeyDirectory
|
|
23
23
|
*/
|
|
24
|
-
init(loadGeoKeys?: boolean
|
|
24
|
+
init(loadGeoKeys?: boolean): Promise<CogTiff>;
|
|
25
25
|
private doInit;
|
|
26
26
|
private fetchIfd;
|
|
27
27
|
getImage(z: number): CogTiffImage;
|
package/build/cog.tiff.d.ts.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"cog.tiff.d.ts","sourceRoot":"","sources":["../src/cog.tiff.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,WAAW,EAAE,
|
|
1
|
+
{"version":3,"file":"cog.tiff.d.ts","sourceRoot":"","sources":["../src/cog.tiff.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,WAAW,EAAE,MAAM,cAAc,CAAC;AAC3C,OAAO,EAAE,YAAY,EAAE,MAAM,qBAAqB,CAAC;AAGnD,OAAO,EAAE,WAAW,EAAE,MAAM,yBAAyB,CAAC;AAEtD,OAAO,EAAE,kBAAkB,EAAE,MAAM,qBAAqB,CAAC;AACzD,OAAO,EAAmC,aAAa,EAAE,MAAM,2BAA2B,CAAC;AAK3F,qBAAa,OAAO;IAChB,MAAM,EAAE,WAAW,CAAC;IACpB,OAAO,cAAoB;IAC3B,MAAM,EAAE,YAAY,EAAE,CAAM;IAC5B,OAAO,qBAA4B;IAEnC,OAAO,CAAC,MAAM,CAAkB;IAChC,SAAS,EAAE,aAAa,CAAiB;gBAE7B,MAAM,EAAE,WAAW;IAK/B,sCAAsC;IACtC,MAAM,CAAC,MAAM,CAAC,MAAM,EAAE,WAAW,GAAG,OAAO,CAAC,OAAO,CAAC;IAIpD,6BAA6B;IAC7B,aAAa,UAAS;IAEtB,YAAY,CAAC,EAAE,OAAO,CAAC,OAAO,CAAC,CAAC;IAChC;;;;OAIG;IACH,IAAI,CAAC,WAAW,UAAQ,GAAG,OAAO,CAAC,OAAO,CAAC;YAM7B,MAAM;YAWN,QAAQ;IAkCtB,QAAQ,CAAC,CAAC,EAAE,MAAM,GAAG,YAAY;IAIjC;;;;OAIG;IACH,oBAAoB,CAAC,UAAU,EAAE,MAAM,GAAG,YAAY;IAoBtD;;;;;;;;OAQG;IACG,OAAO,CAAC,CAAC,EAAE,MAAM,EAAE,CAAC,EAAE,MAAM,EAAE,KAAK,EAAE,MAAM,GAAG,OAAO,CAAC;QAAE,QAAQ,EAAE,MAAM,CAAC;QAAC,KAAK,EAAE,UAAU,CAAA;KAAE,GAAG,IAAI,CAAC;YAQ7F,UAAU;YASV,OAAO;IAqBrB,gDAAgD;IAC1C,KAAK,IAAI,OAAO,CAAC,IAAI,CAAC;CAG/B"}
|
|
@@ -1,4 +1,3 @@
|
|
|
1
|
-
import { LogType } from '@chunkd/core';
|
|
2
1
|
import { CogTiff } from './cog.tiff.js';
|
|
3
2
|
import { TiffMimeType } from './const/tiff.mime.js';
|
|
4
3
|
import { TiffTag, TiffTagGeo } from './const/tiff.tag.id.js';
|
|
@@ -41,7 +40,7 @@ export declare class CogTiffImage {
|
|
|
41
40
|
*
|
|
42
41
|
* @param loadGeoTags Whether to load the GeoKeyDirectory and unpack it
|
|
43
42
|
*/
|
|
44
|
-
init(loadGeoTags?: boolean
|
|
43
|
+
init(loadGeoTags?: boolean): Promise<void>;
|
|
45
44
|
/**
|
|
46
45
|
* Get the value of a TiffTag if it exists null otherwise
|
|
47
46
|
*/
|
|
@@ -49,7 +48,7 @@ export declare class CogTiffImage {
|
|
|
49
48
|
/**
|
|
50
49
|
* Load and unpack the GeoKeyDirectory
|
|
51
50
|
*/
|
|
52
|
-
loadGeoTiffTags(
|
|
51
|
+
loadGeoTiffTags(): Promise<void>;
|
|
53
52
|
/**
|
|
54
53
|
* Get the associated GeoTiffTags
|
|
55
54
|
*/
|
|
@@ -58,7 +57,7 @@ export declare class CogTiffImage {
|
|
|
58
57
|
* Load a tag, if it is not currently loaded, fetch the required data for the tag.
|
|
59
58
|
* @param tag tag to fetch
|
|
60
59
|
*/
|
|
61
|
-
fetch<T>(tag: TiffTag
|
|
60
|
+
fetch<T>(tag: TiffTag): Promise<T | null>;
|
|
62
61
|
/**
|
|
63
62
|
* Get the origin point for the image
|
|
64
63
|
*
|
|
@@ -137,7 +136,7 @@ export declare class CogTiffImage {
|
|
|
137
136
|
* @param index tile index
|
|
138
137
|
* @returns file offset of the specified tile
|
|
139
138
|
*/
|
|
140
|
-
protected getTileOffset(index: number
|
|
139
|
+
protected getTileOffset(index: number): Promise<number>;
|
|
141
140
|
getTileBounds(x: number, y: number): BoundingBox;
|
|
142
141
|
/**
|
|
143
142
|
* Read a strip into a uint8 array
|
|
@@ -160,11 +159,11 @@ export declare class CogTiffImage {
|
|
|
160
159
|
* @param x Tile x offset
|
|
161
160
|
* @param y Tile y offset
|
|
162
161
|
*/
|
|
163
|
-
getTile(x: number, y: number
|
|
162
|
+
getTile(x: number, y: number): Promise<{
|
|
164
163
|
mimeType: TiffMimeType;
|
|
165
164
|
bytes: Uint8Array;
|
|
166
165
|
} | null>;
|
|
167
|
-
protected getTileSize(index: number
|
|
166
|
+
protected getTileSize(index: number): Promise<{
|
|
168
167
|
offset: number;
|
|
169
168
|
imageSize: number;
|
|
170
169
|
}>;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"cog.tiff.image.d.ts","sourceRoot":"","sources":["../src/cog.tiff.image.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,EAAE,MAAM,
|
|
1
|
+
{"version":3,"file":"cog.tiff.image.d.ts","sourceRoot":"","sources":["../src/cog.tiff.image.ts"],"names":[],"mappings":"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"}
|
package/build/cog.tiff.image.js
CHANGED
|
@@ -19,25 +19,25 @@ export class CogTiffImage {
|
|
|
19
19
|
*
|
|
20
20
|
* @param loadGeoTags Whether to load the GeoKeyDirectory and unpack it
|
|
21
21
|
*/
|
|
22
|
-
async init(loadGeoTags = false
|
|
22
|
+
async init(loadGeoTags = false) {
|
|
23
23
|
const requiredTags = [
|
|
24
|
-
this.fetch(TiffTag.Compression
|
|
25
|
-
this.fetch(TiffTag.ImageHeight
|
|
26
|
-
this.fetch(TiffTag.ImageWidth
|
|
27
|
-
this.fetch(TiffTag.ModelPixelScale
|
|
28
|
-
this.fetch(TiffTag.ModelTiePoint
|
|
29
|
-
this.fetch(TiffTag.ModelTransformation
|
|
30
|
-
this.fetch(TiffTag.TileHeight
|
|
31
|
-
this.fetch(TiffTag.TileWidth
|
|
24
|
+
this.fetch(TiffTag.Compression),
|
|
25
|
+
this.fetch(TiffTag.ImageHeight),
|
|
26
|
+
this.fetch(TiffTag.ImageWidth),
|
|
27
|
+
this.fetch(TiffTag.ModelPixelScale),
|
|
28
|
+
this.fetch(TiffTag.ModelTiePoint),
|
|
29
|
+
this.fetch(TiffTag.ModelTransformation),
|
|
30
|
+
this.fetch(TiffTag.TileHeight),
|
|
31
|
+
this.fetch(TiffTag.TileWidth),
|
|
32
32
|
];
|
|
33
33
|
if (loadGeoTags) {
|
|
34
|
-
requiredTags.push(this.fetch(TiffTag.GeoKeyDirectory
|
|
35
|
-
requiredTags.push(this.fetch(TiffTag.GeoAsciiParams
|
|
36
|
-
requiredTags.push(this.fetch(TiffTag.GeoDoubleParams
|
|
34
|
+
requiredTags.push(this.fetch(TiffTag.GeoKeyDirectory));
|
|
35
|
+
requiredTags.push(this.fetch(TiffTag.GeoAsciiParams));
|
|
36
|
+
requiredTags.push(this.fetch(TiffTag.GeoDoubleParams));
|
|
37
37
|
}
|
|
38
38
|
await Promise.all(requiredTags);
|
|
39
39
|
if (loadGeoTags) {
|
|
40
|
-
await this.loadGeoTiffTags(
|
|
40
|
+
await this.loadGeoTiffTags();
|
|
41
41
|
}
|
|
42
42
|
}
|
|
43
43
|
/**
|
|
@@ -52,7 +52,7 @@ export class CogTiffImage {
|
|
|
52
52
|
/**
|
|
53
53
|
* Load and unpack the GeoKeyDirectory
|
|
54
54
|
*/
|
|
55
|
-
async loadGeoTiffTags(
|
|
55
|
+
async loadGeoTiffTags() {
|
|
56
56
|
// Already loaded
|
|
57
57
|
if (this.tagsGeoLoaded)
|
|
58
58
|
return;
|
|
@@ -64,9 +64,9 @@ export class CogTiffImage {
|
|
|
64
64
|
if (!sourceTag.isReady && sourceTag instanceof CogTiffTagLazy) {
|
|
65
65
|
// Load all the required keys
|
|
66
66
|
await Promise.all([
|
|
67
|
-
this.fetch(TiffTag.GeoKeyDirectory
|
|
68
|
-
this.fetch(TiffTag.GeoAsciiParams
|
|
69
|
-
this.fetch(TiffTag.GeoDoubleParams
|
|
67
|
+
this.fetch(TiffTag.GeoKeyDirectory),
|
|
68
|
+
this.fetch(TiffTag.GeoAsciiParams),
|
|
69
|
+
this.fetch(TiffTag.GeoDoubleParams),
|
|
70
70
|
]);
|
|
71
71
|
}
|
|
72
72
|
this.tagsGeoLoaded = true;
|
|
@@ -107,12 +107,12 @@ export class CogTiffImage {
|
|
|
107
107
|
* Load a tag, if it is not currently loaded, fetch the required data for the tag.
|
|
108
108
|
* @param tag tag to fetch
|
|
109
109
|
*/
|
|
110
|
-
async fetch(tag
|
|
110
|
+
async fetch(tag) {
|
|
111
111
|
const sourceTag = this.tags.get(tag);
|
|
112
112
|
if (sourceTag == null)
|
|
113
113
|
return null;
|
|
114
114
|
if (CogTiffTag.isLazy(sourceTag))
|
|
115
|
-
return sourceTag.fetch(
|
|
115
|
+
return sourceTag.fetch();
|
|
116
116
|
return sourceTag.value;
|
|
117
117
|
}
|
|
118
118
|
/**
|
|
@@ -287,13 +287,13 @@ export class CogTiffImage {
|
|
|
287
287
|
* @param index tile index
|
|
288
288
|
* @returns file offset of the specified tile
|
|
289
289
|
*/
|
|
290
|
-
async getTileOffset(index
|
|
290
|
+
async getTileOffset(index) {
|
|
291
291
|
const tileOffset = this.tileOffset;
|
|
292
292
|
if (index < 0 || index > tileOffset.dataCount) {
|
|
293
293
|
throw new Error(`Tile offset: ${index} out of range: 0 -> ${tileOffset.dataCount}`);
|
|
294
294
|
}
|
|
295
295
|
// Fetch only the part of the offsets that are needed
|
|
296
|
-
return tileOffset.getValueAt(index
|
|
296
|
+
return tileOffset.getValueAt(index);
|
|
297
297
|
}
|
|
298
298
|
// Clamp the bounds of the output image to the size of the image, as sometimes the edge tiles are not full tiles
|
|
299
299
|
getTileBounds(x, y) {
|
|
@@ -334,13 +334,13 @@ export class CogTiffImage {
|
|
|
334
334
|
return actualBytes;
|
|
335
335
|
}
|
|
336
336
|
/** Read image bytes at the given offset */
|
|
337
|
-
async getBytes(offset, byteCount
|
|
337
|
+
async getBytes(offset, byteCount) {
|
|
338
338
|
const mimeType = this.compression;
|
|
339
339
|
if (mimeType == null)
|
|
340
340
|
throw new Error('Unsupported compression: ' + this.value(TiffTag.Compression));
|
|
341
341
|
if (byteCount === 0)
|
|
342
342
|
return null;
|
|
343
|
-
await this.tif.source.loadBytes(offset, byteCount
|
|
343
|
+
await this.tif.source.loadBytes(offset, byteCount);
|
|
344
344
|
const bytes = this.tif.source.bytes(offset, byteCount);
|
|
345
345
|
if (this.compression === TiffMimeType.JPEG) {
|
|
346
346
|
return { mimeType, bytes: this.getJpegHeader(bytes) };
|
|
@@ -355,7 +355,7 @@ export class CogTiffImage {
|
|
|
355
355
|
* @param x Tile x offset
|
|
356
356
|
* @param y Tile y offset
|
|
357
357
|
*/
|
|
358
|
-
async getTile(x, y
|
|
358
|
+
async getTile(x, y) {
|
|
359
359
|
const mimeType = this.compression;
|
|
360
360
|
const size = this.size;
|
|
361
361
|
const tiles = this.tileSize;
|
|
@@ -373,29 +373,29 @@ export class CogTiffImage {
|
|
|
373
373
|
const totalTiles = nxTiles * nyTiles;
|
|
374
374
|
if (idx >= totalTiles)
|
|
375
375
|
throw new Error(`Tile index is outside of tile range: ${idx} >= ${totalTiles}`);
|
|
376
|
-
const { offset, imageSize } = await this.getTileSize(idx
|
|
377
|
-
return this.getBytes(offset, imageSize
|
|
376
|
+
const { offset, imageSize } = await this.getTileSize(idx);
|
|
377
|
+
return this.getBytes(offset, imageSize);
|
|
378
378
|
}
|
|
379
|
-
async getTileSize(index
|
|
379
|
+
async getTileSize(index) {
|
|
380
380
|
// GDAL optimizes tiles by storing the size of the tile in
|
|
381
381
|
// the few bytes leading up to the tile
|
|
382
382
|
if (this.tif.options.tileLeaderByteSize) {
|
|
383
|
-
const offset = await this.getTileOffset(index
|
|
383
|
+
const offset = await this.getTileOffset(index);
|
|
384
384
|
// Sparse COG no data found
|
|
385
385
|
if (offset === 0)
|
|
386
386
|
return { offset: 0, imageSize: 0 };
|
|
387
387
|
const leaderBytes = this.tif.options.tileLeaderByteSize;
|
|
388
388
|
// This fetch will generally load in the bytes needed for the image too
|
|
389
389
|
// provided the image size is less than the size of a chunk
|
|
390
|
-
await this.tif.source.loadBytes(offset - leaderBytes, leaderBytes
|
|
390
|
+
await this.tif.source.loadBytes(offset - leaderBytes, leaderBytes);
|
|
391
391
|
return { offset, imageSize: this.tif.source.getUint(offset - leaderBytes, leaderBytes) };
|
|
392
392
|
}
|
|
393
393
|
const byteCounts = this.tags.get(TiffTag.TileByteCounts);
|
|
394
394
|
if (byteCounts == null) {
|
|
395
395
|
throw new Error('No tile byte counts found');
|
|
396
396
|
}
|
|
397
|
-
const [offset, imageSize] = await Promise.all([this.getTileOffset(index
|
|
397
|
+
const [offset, imageSize] = await Promise.all([this.getTileOffset(index), byteCounts.getValueAt(index)]);
|
|
398
398
|
return { offset, imageSize };
|
|
399
399
|
}
|
|
400
400
|
}
|
|
401
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"cog.tiff.image.js","sourceRoot":"","sources":["../src/cog.tiff.image.ts"],"names":[],"mappings":"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","sourcesContent":["import { LogType } from '@chunkd/core';\nimport { CogTiff } from './cog.tiff.js';\nimport { TiffCompression, TiffMimeType } from './const/tiff.mime.js';\nimport { TiffTag, TiffTagGeo } from './const/tiff.tag.id.js';\nimport { CogTiffTagBase } from './read/tag/tiff.tag.base.js';\nimport { CogTiffTagLazy } from './read/tag/tiff.tag.lazy.js';\nimport { CogTiffTagOffset } from './read/tag/tiff.tag.offset.js';\nimport { CogTiffTag } from './read/tiff.tag.js';\nimport { BoundingBox, Size } from './vector.js';\n\n/** Invalid EPSG code */\nexport const InvalidProjectionCode = 32767;\n\n/**\n * Number of tiles used inside this image\n */\nexport interface CogTiffImageTiledCount {\n    /** Number of tiles on the x axis */\n    x: number;\n    /** Number of tiles on the y axis */\n    y: number;\n}\n\n/**\n * Size of a individual tile\n */\nexport interface CogTiffImageTileSize {\n    /** Tile width (pixels) */\n    width: number;\n    /** Tile height (pixels) */\n    height: number;\n}\n\nexport class CogTiffImage {\n    /** All IFD tags that have been read for the image */\n    tags: Map<TiffTag, CogTiffTagBase>;\n\n    /** Id of the tif image, generally the image index inside the tif */\n    id: number;\n\n    tif: CogTiff;\n\n    /** Has loadGeoTiffTags been called */\n    private tagsGeoLoaded = false;\n    /** Sub tags stored in TiffTag.GeoKeyDirectory */\n    tagsGeo: Map<TiffTagGeo, string | number> = new Map();\n\n    constructor(tif: CogTiff, id: number, tags: Map<TiffTag, CogTiffTagBase>) {\n        this.tif = tif;\n        this.id = id;\n        this.tags = tags;\n    }\n\n    /**\n     * Force loading of important tags if they have not already been loaded\n     *\n     * @param loadGeoTags Whether to load the GeoKeyDirectory and unpack it\n     */\n    async init(loadGeoTags = false, l: LogType = null as any): Promise<void> {\n        const requiredTags = [\n            this.fetch(TiffTag.Compression, l),\n            this.fetch(TiffTag.ImageHeight, l),\n            this.fetch(TiffTag.ImageWidth, l),\n            this.fetch(TiffTag.ModelPixelScale, l),\n            this.fetch(TiffTag.ModelTiePoint, l),\n            this.fetch(TiffTag.ModelTransformation, l),\n            this.fetch(TiffTag.TileHeight, l),\n            this.fetch(TiffTag.TileWidth, l),\n        ];\n\n        if (loadGeoTags) {\n            requiredTags.push(this.fetch(TiffTag.GeoKeyDirectory, l));\n            requiredTags.push(this.fetch(TiffTag.GeoAsciiParams, l));\n            requiredTags.push(this.fetch(TiffTag.GeoDoubleParams, l));\n        }\n\n        await Promise.all(requiredTags);\n        if (loadGeoTags) {\n            await this.loadGeoTiffTags(l);\n        }\n    }\n\n    /**\n     * Get the value of a TiffTag if it exists null otherwise\n     */\n    value<T>(tag: TiffTag): T | null {\n        const sourceTag = this.tags.get(tag);\n        if (sourceTag == null) return null;\n        return sourceTag.value as T;\n    }\n\n    /**\n     * Load and unpack the GeoKeyDirectory\n     */\n    async loadGeoTiffTags(l: LogType): Promise<void> {\n        // Already loaded\n        if (this.tagsGeoLoaded) return;\n        const sourceTag = this.tags.get(TiffTag.GeoKeyDirectory);\n        if (sourceTag == null) {\n            this.tagsGeoLoaded = true;\n            return;\n        }\n        if (!sourceTag.isReady && sourceTag instanceof CogTiffTagLazy) {\n            // Load all the required keys\n            await Promise.all([\n                this.fetch(TiffTag.GeoKeyDirectory, l),\n                this.fetch(TiffTag.GeoAsciiParams, l),\n                this.fetch(TiffTag.GeoDoubleParams, l),\n            ]);\n        }\n        this.tagsGeoLoaded = true;\n        if (sourceTag.value == null) return;\n        const geoTags = sourceTag.value;\n        if (!Array.isArray(geoTags)) throw new Error('Invalid geo tags found');\n        for (let i = 4; i <= geoTags[3] * 4; i += 4) {\n            const key = geoTags[i] as TiffTagGeo;\n            const location = geoTags[i + 1];\n\n            const offset = geoTags[i + 3];\n\n            if (location === 0) {\n                this.tagsGeo.set(key, offset);\n                continue;\n            }\n            const tag = this.tags.get(location);\n            if (tag == null || tag.value == null) continue;\n            const count = geoTags[i + 2];\n            if (Array.isArray(tag.value)) {\n                this.tagsGeo.set(key, tag.value[offset + count - 1]);\n            } else if (typeof tag.value === 'string') {\n                this.tagsGeo.set(key, tag.value.substr(offset, offset + count - 1).trim());\n            }\n        }\n    }\n\n    /**\n     * Get the associated GeoTiffTags\n     */\n    valueGeo(tag: TiffTagGeo): string | number | undefined {\n        if (this.tagsGeoLoaded === false) throw new Error('loadGeoTiffTags() has not been called');\n        return this.tagsGeo.get(tag);\n    }\n\n    /**\n     * Load a tag, if it is not currently loaded, fetch the required data for the tag.\n     * @param tag tag to fetch\n     */\n    public async fetch<T>(tag: TiffTag, l: LogType): Promise<T | null> {\n        const sourceTag = this.tags.get(tag);\n        if (sourceTag == null) return null;\n        if (CogTiffTag.isLazy(sourceTag)) return sourceTag.fetch(l) as any;\n        return sourceTag.value as T;\n    }\n\n    /**\n     * Get the origin point for the image\n     *\n     * @returns origin point of the image\n     */\n    get origin(): [number, number, number] {\n        const tiePoints: number[] | null = this.value<number[]>(TiffTag.ModelTiePoint);\n        if (tiePoints != null && tiePoints.length === 6) {\n            return [tiePoints[3], tiePoints[4], tiePoints[5]];\n        }\n\n        const modelTransformation = this.value<number[]>(TiffTag.ModelTransformation);\n        if (modelTransformation != null) {\n            return [modelTransformation[3], modelTransformation[7], modelTransformation[11]];\n        }\n\n        // If this is a sub image, use the origin from the top level image\n        if (this.value(TiffTag.NewSubFileType) === 1 && this.id !== 0) {\n            return this.tif.images[0].origin;\n        }\n\n        throw new Error('Image does not have a geo transformation.');\n    }\n\n    /** Is there enough geo information on this image to figure out where its actually located */\n    get isGeoLocated(): boolean {\n        const isImageLocated =\n            this.value(TiffTag.ModelPixelScale) != null || this.value(TiffTag.ModelTransformation) != null;\n        if (isImageLocated) return true;\n        // If this is a sub image, use the isGeoLocated from the top level image\n        if (this.value(TiffTag.NewSubFileType) === 1 && this.id !== 0) return this.tif.images[0].isGeoLocated;\n        return false;\n    }\n\n    /**\n     * Get the resolution of the image\n     *\n     * @returns [x,y,z] pixel scale\n     */\n    get resolution(): [number, number, number] {\n        const modelPixelScale: number[] | null = this.value(TiffTag.ModelPixelScale);\n        if (modelPixelScale != null) {\n            return [modelPixelScale[0], -modelPixelScale[1], modelPixelScale[2]];\n        }\n        const modelTransformation: number[] | null = this.value(TiffTag.ModelTransformation);\n        if (modelTransformation != null) {\n            return [modelTransformation[0], modelTransformation[5], modelTransformation[10]];\n        }\n\n        // If this is a sub image, use the resolution from the top level image\n        if (this.value(TiffTag.NewSubFileType) === 1 && this.id !== 0) {\n            const firstImg = this.tif.images[0];\n            const [resX, resY, resZ] = firstImg.resolution;\n            const firstImgSize = firstImg.size;\n            const imgSize = this.size;\n            // scale resolution based on the size difference between the two images\n            return [(resX * firstImgSize.width) / imgSize.width, (resY * firstImgSize.height) / imgSize.height, resZ];\n        }\n\n        throw new Error('Image does not have a geo transformation.');\n    }\n\n    /**\n     * Bounding box of the image\n     *\n     * @returns [minX, minY, maxX, maxY] bounding box\n     */\n    get bbox(): [number, number, number, number] {\n        const size = this.size;\n        const origin = this.origin;\n        const resolution = this.resolution;\n\n        if (origin == null || size == null || resolution == null) {\n            throw new Error('Unable to calculate bounding box');\n        }\n\n        const x1 = origin[0];\n        const y1 = origin[1];\n\n        const x2 = x1 + resolution[0] * size.width;\n        const y2 = y1 + resolution[1] * size.height;\n\n        return [Math.min(x1, x2), Math.min(y1, y2), Math.max(x1, x2), Math.max(y1, y2)];\n    }\n\n    /**\n     * Get the compression used by the tile\n     *\n     * @see TiffCompression\n     *\n     * @returns Compression type eg webp\n     */\n    get compression(): TiffMimeType | null {\n        const compression = this.value(TiffTag.Compression);\n        if (compression == null || typeof compression !== 'number') {\n            return null;\n        }\n        return TiffCompression[compression];\n    }\n\n    /**\n     * Attempt to read the EPSG Code from TiffGeoTags\n     *\n     * @returns EPSG Code if it exists\n     */\n    get epsg(): number | null {\n        const projection = this.valueGeo(TiffTagGeo.ProjectedCSTypeGeoKey) as number;\n        if (projection === InvalidProjectionCode) return null;\n        return projection;\n    }\n\n    /**\n     * Get the size of the image\n     *\n     * @returns Size in pixels\n     */\n    get size(): Size {\n        return {\n            width: this.value<number>(TiffTag.ImageWidth) as number,\n            height: this.value<number>(TiffTag.ImageHeight) as number,\n        };\n    }\n\n    /**\n     * Get the list of IFD tags that were read\n     */\n    get tagList(): string[] {\n        return [...this.tags.keys()].map((c) => TiffTag[c]);\n    }\n\n    /**\n     * Determine if this image is tiled\n     */\n    public isTiled(): boolean {\n        return this.value(TiffTag.TileWidth) !== null;\n    }\n\n    /**\n     * Get size of individual tiles\n     */\n    get tileSize(): CogTiffImageTileSize {\n        return {\n            width: this.value<number>(TiffTag.TileWidth) as number,\n            height: this.value<number>(TiffTag.TileHeight) as number,\n        };\n    }\n\n    /**\n     * Number of tiles used to create this image\n     */\n    get tileCount(): CogTiffImageTiledCount {\n        const size = this.size;\n        const tileSize = this.tileSize;\n        const x = Math.ceil(size.width / tileSize.width);\n        const y = Math.ceil(size.height / tileSize.height);\n        return { x, y };\n    }\n\n    /**\n     * Get the pointer to where the tiles start in the Tiff file\n     *\n     * @remarks Used to read tiled tiffs\n     *\n     * @returns file offset to where the tiffs are stored\n     */\n    get tileOffset(): CogTiffTagOffset {\n        const tileOffset = this.tags.get(TiffTag.TileOffsets) as CogTiffTagOffset;\n        if (tileOffset == null) throw new Error('No tile offsets found');\n        return tileOffset;\n    }\n\n    /**\n     * Get the number of strip's inside this tiff\n     *\n     * @remarks Used to read striped tiffs\n     *\n     * @returns number of strips present\n     */\n    get stripCount(): number {\n        const tileOffset = this.tags.get(TiffTag.StripByteCounts) as CogTiffTagOffset;\n        if (tileOffset == null) return 0;\n        return tileOffset.dataCount;\n    }\n\n    /**\n     * Get a pointer to a specific tile inside the tiff file\n     *\n     * @param index tile index\n     * @returns file offset of the specified tile\n     */\n    protected async getTileOffset(index: number, l?: LogType): Promise<number> {\n        const tileOffset = this.tileOffset;\n        if (index < 0 || index > tileOffset.dataCount) {\n            throw new Error(`Tile offset: ${index} out of range: 0 -> ${tileOffset.dataCount}`);\n        }\n\n        // Fetch only the part of the offsets that are needed\n        return tileOffset.getValueAt(index, l);\n    }\n\n    // Clamp the bounds of the output image to the size of the image, as sometimes the edge tiles are not full tiles\n    getTileBounds(x: number, y: number): BoundingBox {\n        const { size, tileSize } = this;\n        const top = y * tileSize.height;\n        const left = x * tileSize.width;\n        const width = left + tileSize.width >= size.width ? size.width - left : tileSize.width;\n        const height = top + tileSize.height >= size.height ? size.height - top : tileSize.height;\n        return { x: left, y: top, width, height };\n    }\n\n    /**\n     * Read a strip into a uint8 array\n     *\n     * @param index Strip index to read\n     */\n    async getStrip(index: number): Promise<{ mimeType: TiffMimeType; bytes: Uint8Array } | null> {\n        if (this.isTiled()) throw new Error('Cannot read stripes, tiff is tiled');\n\n        const byteCounts = this.tags.get(TiffTag.StripByteCounts) as CogTiffTagOffset;\n        const offsets = this.tags.get(TiffTag.StripOffsets) as CogTiffTagOffset;\n\n        if (index >= byteCounts.dataCount) throw new Error('Cannot read strip, index out of bounds');\n\n        const [byteCount, offset] = await Promise.all([offsets.getValueAt(index), byteCounts.getValueAt(index)]);\n        return this.getBytes(byteCount, offset);\n    }\n\n    /** The jpeg header is stored in the IFD, read the JPEG header and adjust the byte array to include it */\n    private getJpegHeader(bytes: Uint8Array): Uint8Array {\n        // Both the JPEGTable and the Bytes with have the start of image and end of image markers\n        // StartOfImage 0xffd8 EndOfImage 0xffd9\n        const tables = this.value<number[]>(TiffTag.JPEGTables);\n        if (tables == null) throw new Error('Unable to find Jpeg header');\n\n        // Remove EndOfImage marker\n        const tableData = tables.slice(0, tables.length - 2);\n        const actualBytes = new Uint8Array(bytes.byteLength + tableData.length - 2);\n        actualBytes.set(tableData, 0);\n        actualBytes.set(bytes.slice(2), tableData.length);\n        return actualBytes;\n    }\n\n    /** Read image bytes at the given offset */\n    private async getBytes(\n        offset: number,\n        byteCount: number,\n        l?: LogType,\n    ): Promise<{ mimeType: TiffMimeType; bytes: Uint8Array } | null> {\n        const mimeType = this.compression;\n        if (mimeType == null) throw new Error('Unsupported compression: ' + this.value(TiffTag.Compression));\n        if (byteCount === 0) return null;\n\n        await this.tif.source.loadBytes(offset, byteCount, l);\n        const bytes = this.tif.source.bytes(offset, byteCount);\n\n        if (this.compression === TiffMimeType.JPEG) {\n            return { mimeType, bytes: this.getJpegHeader(bytes) };\n        }\n        return { mimeType, bytes };\n    }\n\n    /**\n     * Load the tile buffer, this works best with webp\n     *\n     * This will also apply the JPEG compression tables\n     *\n     * @param x Tile x offset\n     * @param y Tile y offset\n     */\n    async getTile(x: number, y: number, l?: LogType): Promise<{ mimeType: TiffMimeType; bytes: Uint8Array } | null> {\n        const mimeType = this.compression;\n        const size = this.size;\n        const tiles = this.tileSize;\n\n        if (tiles == null) throw new Error('Tiff is not tiled');\n        if (mimeType == null) throw new Error('Unsupported compression: ' + this.value(TiffTag.Compression));\n\n        // TODO support GhostOptionTileOrder\n        const nyTiles = Math.ceil(size.height / tiles.height);\n        const nxTiles = Math.ceil(size.width / tiles.width);\n\n        if (x >= nxTiles || y >= nyTiles) {\n            throw new Error(`Tile index is outside of range x:${x} >= ${nxTiles} or y:${y} >= ${nyTiles}`);\n        }\n\n        const idx = y * nxTiles + x;\n        const totalTiles = nxTiles * nyTiles;\n        if (idx >= totalTiles) throw new Error(`Tile index is outside of tile range: ${idx} >= ${totalTiles}`);\n\n        const { offset, imageSize } = await this.getTileSize(idx, l);\n        return this.getBytes(offset, imageSize, l);\n    }\n\n    protected async getTileSize(index: number, l?: LogType): Promise<{ offset: number; imageSize: number }> {\n        // GDAL optimizes tiles by storing the size of the tile in\n        // the few bytes leading up to the tile\n        if (this.tif.options.tileLeaderByteSize) {\n            const offset = await this.getTileOffset(index, l);\n            // Sparse COG no data found\n            if (offset === 0) return { offset: 0, imageSize: 0 };\n\n            const leaderBytes = this.tif.options.tileLeaderByteSize;\n            // This fetch will generally load in the bytes needed for the image too\n            // provided the image size is less than the size of a chunk\n            await this.tif.source.loadBytes(offset - leaderBytes, leaderBytes, l);\n            return { offset, imageSize: this.tif.source.getUint(offset - leaderBytes, leaderBytes) };\n        }\n\n        const byteCounts = this.tags.get(TiffTag.TileByteCounts) as CogTiffTagOffset;\n        if (byteCounts == null) {\n            throw new Error('No tile byte counts found');\n        }\n        const [offset, imageSize] = await Promise.all([this.getTileOffset(index, l), byteCounts.getValueAt(index, l)]);\n        return { offset, imageSize };\n    }\n}\n"]}
|
|
401
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"cog.tiff.image.js","sourceRoot":"","sources":["../src/cog.tiff.image.ts"],"names":[],"mappings":"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","sourcesContent":["import { CogTiff } from './cog.tiff.js';\nimport { TiffCompression, TiffMimeType } from './const/tiff.mime.js';\nimport { TiffTag, TiffTagGeo } from './const/tiff.tag.id.js';\nimport { CogTiffTagBase } from './read/tag/tiff.tag.base.js';\nimport { CogTiffTagLazy } from './read/tag/tiff.tag.lazy.js';\nimport { CogTiffTagOffset } from './read/tag/tiff.tag.offset.js';\nimport { CogTiffTag } from './read/tiff.tag.js';\nimport { BoundingBox, Size } from './vector.js';\n\n/** Invalid EPSG code */\nexport const InvalidProjectionCode = 32767;\n\n/**\n * Number of tiles used inside this image\n */\nexport interface CogTiffImageTiledCount {\n    /** Number of tiles on the x axis */\n    x: number;\n    /** Number of tiles on the y axis */\n    y: number;\n}\n\n/**\n * Size of a individual tile\n */\nexport interface CogTiffImageTileSize {\n    /** Tile width (pixels) */\n    width: number;\n    /** Tile height (pixels) */\n    height: number;\n}\n\nexport class CogTiffImage {\n    /** All IFD tags that have been read for the image */\n    tags: Map<TiffTag, CogTiffTagBase>;\n\n    /** Id of the tif image, generally the image index inside the tif */\n    id: number;\n\n    tif: CogTiff;\n\n    /** Has loadGeoTiffTags been called */\n    private tagsGeoLoaded = false;\n    /** Sub tags stored in TiffTag.GeoKeyDirectory */\n    tagsGeo: Map<TiffTagGeo, string | number> = new Map();\n\n    constructor(tif: CogTiff, id: number, tags: Map<TiffTag, CogTiffTagBase>) {\n        this.tif = tif;\n        this.id = id;\n        this.tags = tags;\n    }\n\n    /**\n     * Force loading of important tags if they have not already been loaded\n     *\n     * @param loadGeoTags Whether to load the GeoKeyDirectory and unpack it\n     */\n    async init(loadGeoTags = false): Promise<void> {\n        const requiredTags = [\n            this.fetch(TiffTag.Compression),\n            this.fetch(TiffTag.ImageHeight),\n            this.fetch(TiffTag.ImageWidth),\n            this.fetch(TiffTag.ModelPixelScale),\n            this.fetch(TiffTag.ModelTiePoint),\n            this.fetch(TiffTag.ModelTransformation),\n            this.fetch(TiffTag.TileHeight),\n            this.fetch(TiffTag.TileWidth),\n        ];\n\n        if (loadGeoTags) {\n            requiredTags.push(this.fetch(TiffTag.GeoKeyDirectory));\n            requiredTags.push(this.fetch(TiffTag.GeoAsciiParams));\n            requiredTags.push(this.fetch(TiffTag.GeoDoubleParams));\n        }\n\n        await Promise.all(requiredTags);\n        if (loadGeoTags) {\n            await this.loadGeoTiffTags();\n        }\n    }\n\n    /**\n     * Get the value of a TiffTag if it exists null otherwise\n     */\n    value<T>(tag: TiffTag): T | null {\n        const sourceTag = this.tags.get(tag);\n        if (sourceTag == null) return null;\n        return sourceTag.value as T;\n    }\n\n    /**\n     * Load and unpack the GeoKeyDirectory\n     */\n    async loadGeoTiffTags(): Promise<void> {\n        // Already loaded\n        if (this.tagsGeoLoaded) return;\n        const sourceTag = this.tags.get(TiffTag.GeoKeyDirectory);\n        if (sourceTag == null) {\n            this.tagsGeoLoaded = true;\n            return;\n        }\n        if (!sourceTag.isReady && sourceTag instanceof CogTiffTagLazy) {\n            // Load all the required keys\n            await Promise.all([\n                this.fetch(TiffTag.GeoKeyDirectory),\n                this.fetch(TiffTag.GeoAsciiParams),\n                this.fetch(TiffTag.GeoDoubleParams),\n            ]);\n        }\n        this.tagsGeoLoaded = true;\n        if (sourceTag.value == null) return;\n        const geoTags = sourceTag.value;\n        if (!Array.isArray(geoTags)) throw new Error('Invalid geo tags found');\n        for (let i = 4; i <= geoTags[3] * 4; i += 4) {\n            const key = geoTags[i] as TiffTagGeo;\n            const location = geoTags[i + 1];\n\n            const offset = geoTags[i + 3];\n\n            if (location === 0) {\n                this.tagsGeo.set(key, offset);\n                continue;\n            }\n            const tag = this.tags.get(location);\n            if (tag == null || tag.value == null) continue;\n            const count = geoTags[i + 2];\n            if (Array.isArray(tag.value)) {\n                this.tagsGeo.set(key, tag.value[offset + count - 1]);\n            } else if (typeof tag.value === 'string') {\n                this.tagsGeo.set(key, tag.value.substr(offset, offset + count - 1).trim());\n            }\n        }\n    }\n\n    /**\n     * Get the associated GeoTiffTags\n     */\n    valueGeo(tag: TiffTagGeo): string | number | undefined {\n        if (this.tagsGeoLoaded === false) throw new Error('loadGeoTiffTags() has not been called');\n        return this.tagsGeo.get(tag);\n    }\n\n    /**\n     * Load a tag, if it is not currently loaded, fetch the required data for the tag.\n     * @param tag tag to fetch\n     */\n    public async fetch<T>(tag: TiffTag): Promise<T | null> {\n        const sourceTag = this.tags.get(tag);\n        if (sourceTag == null) return null;\n        if (CogTiffTag.isLazy(sourceTag)) return sourceTag.fetch() as any;\n        return sourceTag.value as T;\n    }\n\n    /**\n     * Get the origin point for the image\n     *\n     * @returns origin point of the image\n     */\n    get origin(): [number, number, number] {\n        const tiePoints: number[] | null = this.value<number[]>(TiffTag.ModelTiePoint);\n        if (tiePoints != null && tiePoints.length === 6) {\n            return [tiePoints[3], tiePoints[4], tiePoints[5]];\n        }\n\n        const modelTransformation = this.value<number[]>(TiffTag.ModelTransformation);\n        if (modelTransformation != null) {\n            return [modelTransformation[3], modelTransformation[7], modelTransformation[11]];\n        }\n\n        // If this is a sub image, use the origin from the top level image\n        if (this.value(TiffTag.NewSubFileType) === 1 && this.id !== 0) {\n            return this.tif.images[0].origin;\n        }\n\n        throw new Error('Image does not have a geo transformation.');\n    }\n\n    /** Is there enough geo information on this image to figure out where its actually located */\n    get isGeoLocated(): boolean {\n        const isImageLocated =\n            this.value(TiffTag.ModelPixelScale) != null || this.value(TiffTag.ModelTransformation) != null;\n        if (isImageLocated) return true;\n        // If this is a sub image, use the isGeoLocated from the top level image\n        if (this.value(TiffTag.NewSubFileType) === 1 && this.id !== 0) return this.tif.images[0].isGeoLocated;\n        return false;\n    }\n\n    /**\n     * Get the resolution of the image\n     *\n     * @returns [x,y,z] pixel scale\n     */\n    get resolution(): [number, number, number] {\n        const modelPixelScale: number[] | null = this.value(TiffTag.ModelPixelScale);\n        if (modelPixelScale != null) {\n            return [modelPixelScale[0], -modelPixelScale[1], modelPixelScale[2]];\n        }\n        const modelTransformation: number[] | null = this.value(TiffTag.ModelTransformation);\n        if (modelTransformation != null) {\n            return [modelTransformation[0], modelTransformation[5], modelTransformation[10]];\n        }\n\n        // If this is a sub image, use the resolution from the top level image\n        if (this.value(TiffTag.NewSubFileType) === 1 && this.id !== 0) {\n            const firstImg = this.tif.images[0];\n            const [resX, resY, resZ] = firstImg.resolution;\n            const firstImgSize = firstImg.size;\n            const imgSize = this.size;\n            // scale resolution based on the size difference between the two images\n            return [(resX * firstImgSize.width) / imgSize.width, (resY * firstImgSize.height) / imgSize.height, resZ];\n        }\n\n        throw new Error('Image does not have a geo transformation.');\n    }\n\n    /**\n     * Bounding box of the image\n     *\n     * @returns [minX, minY, maxX, maxY] bounding box\n     */\n    get bbox(): [number, number, number, number] {\n        const size = this.size;\n        const origin = this.origin;\n        const resolution = this.resolution;\n\n        if (origin == null || size == null || resolution == null) {\n            throw new Error('Unable to calculate bounding box');\n        }\n\n        const x1 = origin[0];\n        const y1 = origin[1];\n\n        const x2 = x1 + resolution[0] * size.width;\n        const y2 = y1 + resolution[1] * size.height;\n\n        return [Math.min(x1, x2), Math.min(y1, y2), Math.max(x1, x2), Math.max(y1, y2)];\n    }\n\n    /**\n     * Get the compression used by the tile\n     *\n     * @see TiffCompression\n     *\n     * @returns Compression type eg webp\n     */\n    get compression(): TiffMimeType | null {\n        const compression = this.value(TiffTag.Compression);\n        if (compression == null || typeof compression !== 'number') {\n            return null;\n        }\n        return TiffCompression[compression];\n    }\n\n    /**\n     * Attempt to read the EPSG Code from TiffGeoTags\n     *\n     * @returns EPSG Code if it exists\n     */\n    get epsg(): number | null {\n        const projection = this.valueGeo(TiffTagGeo.ProjectedCSTypeGeoKey) as number;\n        if (projection === InvalidProjectionCode) return null;\n        return projection;\n    }\n\n    /**\n     * Get the size of the image\n     *\n     * @returns Size in pixels\n     */\n    get size(): Size {\n        return {\n            width: this.value<number>(TiffTag.ImageWidth) as number,\n            height: this.value<number>(TiffTag.ImageHeight) as number,\n        };\n    }\n\n    /**\n     * Get the list of IFD tags that were read\n     */\n    get tagList(): string[] {\n        return [...this.tags.keys()].map((c) => TiffTag[c]);\n    }\n\n    /**\n     * Determine if this image is tiled\n     */\n    public isTiled(): boolean {\n        return this.value(TiffTag.TileWidth) !== null;\n    }\n\n    /**\n     * Get size of individual tiles\n     */\n    get tileSize(): CogTiffImageTileSize {\n        return {\n            width: this.value<number>(TiffTag.TileWidth) as number,\n            height: this.value<number>(TiffTag.TileHeight) as number,\n        };\n    }\n\n    /**\n     * Number of tiles used to create this image\n     */\n    get tileCount(): CogTiffImageTiledCount {\n        const size = this.size;\n        const tileSize = this.tileSize;\n        const x = Math.ceil(size.width / tileSize.width);\n        const y = Math.ceil(size.height / tileSize.height);\n        return { x, y };\n    }\n\n    /**\n     * Get the pointer to where the tiles start in the Tiff file\n     *\n     * @remarks Used to read tiled tiffs\n     *\n     * @returns file offset to where the tiffs are stored\n     */\n    get tileOffset(): CogTiffTagOffset {\n        const tileOffset = this.tags.get(TiffTag.TileOffsets) as CogTiffTagOffset;\n        if (tileOffset == null) throw new Error('No tile offsets found');\n        return tileOffset;\n    }\n\n    /**\n     * Get the number of strip's inside this tiff\n     *\n     * @remarks Used to read striped tiffs\n     *\n     * @returns number of strips present\n     */\n    get stripCount(): number {\n        const tileOffset = this.tags.get(TiffTag.StripByteCounts) as CogTiffTagOffset;\n        if (tileOffset == null) return 0;\n        return tileOffset.dataCount;\n    }\n\n    /**\n     * Get a pointer to a specific tile inside the tiff file\n     *\n     * @param index tile index\n     * @returns file offset of the specified tile\n     */\n    protected async getTileOffset(index: number): Promise<number> {\n        const tileOffset = this.tileOffset;\n        if (index < 0 || index > tileOffset.dataCount) {\n            throw new Error(`Tile offset: ${index} out of range: 0 -> ${tileOffset.dataCount}`);\n        }\n\n        // Fetch only the part of the offsets that are needed\n        return tileOffset.getValueAt(index);\n    }\n\n    // Clamp the bounds of the output image to the size of the image, as sometimes the edge tiles are not full tiles\n    getTileBounds(x: number, y: number): BoundingBox {\n        const { size, tileSize } = this;\n        const top = y * tileSize.height;\n        const left = x * tileSize.width;\n        const width = left + tileSize.width >= size.width ? size.width - left : tileSize.width;\n        const height = top + tileSize.height >= size.height ? size.height - top : tileSize.height;\n        return { x: left, y: top, width, height };\n    }\n\n    /**\n     * Read a strip into a uint8 array\n     *\n     * @param index Strip index to read\n     */\n    async getStrip(index: number): Promise<{ mimeType: TiffMimeType; bytes: Uint8Array } | null> {\n        if (this.isTiled()) throw new Error('Cannot read stripes, tiff is tiled');\n\n        const byteCounts = this.tags.get(TiffTag.StripByteCounts) as CogTiffTagOffset;\n        const offsets = this.tags.get(TiffTag.StripOffsets) as CogTiffTagOffset;\n\n        if (index >= byteCounts.dataCount) throw new Error('Cannot read strip, index out of bounds');\n\n        const [byteCount, offset] = await Promise.all([offsets.getValueAt(index), byteCounts.getValueAt(index)]);\n        return this.getBytes(byteCount, offset);\n    }\n\n    /** The jpeg header is stored in the IFD, read the JPEG header and adjust the byte array to include it */\n    private getJpegHeader(bytes: Uint8Array): Uint8Array {\n        // Both the JPEGTable and the Bytes with have the start of image and end of image markers\n        // StartOfImage 0xffd8 EndOfImage 0xffd9\n        const tables = this.value<number[]>(TiffTag.JPEGTables);\n        if (tables == null) throw new Error('Unable to find Jpeg header');\n\n        // Remove EndOfImage marker\n        const tableData = tables.slice(0, tables.length - 2);\n        const actualBytes = new Uint8Array(bytes.byteLength + tableData.length - 2);\n        actualBytes.set(tableData, 0);\n        actualBytes.set(bytes.slice(2), tableData.length);\n        return actualBytes;\n    }\n\n    /** Read image bytes at the given offset */\n    private async getBytes(\n        offset: number,\n        byteCount: number,\n    ): Promise<{ mimeType: TiffMimeType; bytes: Uint8Array } | null> {\n        const mimeType = this.compression;\n        if (mimeType == null) throw new Error('Unsupported compression: ' + this.value(TiffTag.Compression));\n        if (byteCount === 0) return null;\n\n        await this.tif.source.loadBytes(offset, byteCount);\n        const bytes = this.tif.source.bytes(offset, byteCount);\n\n        if (this.compression === TiffMimeType.JPEG) {\n            return { mimeType, bytes: this.getJpegHeader(bytes) };\n        }\n        return { mimeType, bytes };\n    }\n\n    /**\n     * Load the tile buffer, this works best with webp\n     *\n     * This will also apply the JPEG compression tables\n     *\n     * @param x Tile x offset\n     * @param y Tile y offset\n     */\n    async getTile(x: number, y: number): Promise<{ mimeType: TiffMimeType; bytes: Uint8Array } | null> {\n        const mimeType = this.compression;\n        const size = this.size;\n        const tiles = this.tileSize;\n\n        if (tiles == null) throw new Error('Tiff is not tiled');\n        if (mimeType == null) throw new Error('Unsupported compression: ' + this.value(TiffTag.Compression));\n\n        // TODO support GhostOptionTileOrder\n        const nyTiles = Math.ceil(size.height / tiles.height);\n        const nxTiles = Math.ceil(size.width / tiles.width);\n\n        if (x >= nxTiles || y >= nyTiles) {\n            throw new Error(`Tile index is outside of range x:${x} >= ${nxTiles} or y:${y} >= ${nyTiles}`);\n        }\n\n        const idx = y * nxTiles + x;\n        const totalTiles = nxTiles * nyTiles;\n        if (idx >= totalTiles) throw new Error(`Tile index is outside of tile range: ${idx} >= ${totalTiles}`);\n\n        const { offset, imageSize } = await this.getTileSize(idx);\n        return this.getBytes(offset, imageSize);\n    }\n\n    protected async getTileSize(index: number): Promise<{ offset: number; imageSize: number }> {\n        // GDAL optimizes tiles by storing the size of the tile in\n        // the few bytes leading up to the tile\n        if (this.tif.options.tileLeaderByteSize) {\n            const offset = await this.getTileOffset(index);\n            // Sparse COG no data found\n            if (offset === 0) return { offset: 0, imageSize: 0 };\n\n            const leaderBytes = this.tif.options.tileLeaderByteSize;\n            // This fetch will generally load in the bytes needed for the image too\n            // provided the image size is less than the size of a chunk\n            await this.tif.source.loadBytes(offset - leaderBytes, leaderBytes);\n            return { offset, imageSize: this.tif.source.getUint(offset - leaderBytes, leaderBytes) };\n        }\n\n        const byteCounts = this.tags.get(TiffTag.TileByteCounts) as CogTiffTagOffset;\n        if (byteCounts == null) {\n            throw new Error('No tile byte counts found');\n        }\n        const [offset, imageSize] = await Promise.all([this.getTileOffset(index), byteCounts.getValueAt(index)]);\n        return { offset, imageSize };\n    }\n}\n"]}
|
package/build/cog.tiff.js
CHANGED
|
@@ -26,23 +26,23 @@ export class CogTiff {
|
|
|
26
26
|
*
|
|
27
27
|
* @param loadGeoKeys Whether to also initialize the GeoKeyDirectory
|
|
28
28
|
*/
|
|
29
|
-
init(loadGeoKeys = false
|
|
29
|
+
init(loadGeoKeys = false) {
|
|
30
30
|
if (this._initPromise)
|
|
31
31
|
return this._initPromise;
|
|
32
|
-
this._initPromise = this.doInit(loadGeoKeys
|
|
32
|
+
this._initPromise = this.doInit(loadGeoKeys);
|
|
33
33
|
return this._initPromise;
|
|
34
34
|
}
|
|
35
|
-
async doInit(loadGeoKeys = false
|
|
35
|
+
async doInit(loadGeoKeys = false) {
|
|
36
36
|
if (this.isInitialized)
|
|
37
37
|
return this;
|
|
38
38
|
// Load the first few KB in, more loads will run as more data is required
|
|
39
|
-
await this.source.loadBytes(0, this.source.chunkSize
|
|
40
|
-
await this.fetchIfd(
|
|
41
|
-
await Promise.all(this.images.map((c) => c.init(loadGeoKeys
|
|
39
|
+
await this.source.loadBytes(0, this.source.chunkSize);
|
|
40
|
+
await this.fetchIfd();
|
|
41
|
+
await Promise.all(this.images.map((c) => c.init(loadGeoKeys)));
|
|
42
42
|
this.isInitialized = true;
|
|
43
43
|
return this;
|
|
44
44
|
}
|
|
45
|
-
async fetchIfd(
|
|
45
|
+
async fetchIfd() {
|
|
46
46
|
const view = this.cursor.seekTo(0);
|
|
47
47
|
const endian = view.uint16();
|
|
48
48
|
this.source.isLittleEndian = endian === TiffEndian.Little;
|
|
@@ -69,10 +69,13 @@ export class CogTiff {
|
|
|
69
69
|
const ghostSize = nextOffsetIfd - this.cursor.currentOffset;
|
|
70
70
|
// GDAL now stores metadata between the IFD inside a ghost storage area
|
|
71
71
|
if (ghostSize > 0 && ghostSize < 16 * 1024) {
|
|
72
|
-
|
|
72
|
+
// logger?.debug(
|
|
73
|
+
// { offset: toHexString(this.cursor.currentOffset), length: toHexString(ghostSize) },
|
|
74
|
+
// 'GhostOptions',
|
|
75
|
+
// );
|
|
73
76
|
// this.options.process(this.source, view.currentOffset, ghostSize);
|
|
74
77
|
}
|
|
75
|
-
return this.processIfd(nextOffsetIfd
|
|
78
|
+
return this.processIfd(nextOffsetIfd);
|
|
76
79
|
}
|
|
77
80
|
getImage(z) {
|
|
78
81
|
return this.images[z];
|
|
@@ -116,58 +119,27 @@ export class CogTiff {
|
|
|
116
119
|
throw new Error('Tif is not tiled');
|
|
117
120
|
return image.getTile(x, y);
|
|
118
121
|
}
|
|
119
|
-
async processIfd(offset
|
|
120
|
-
|
|
121
|
-
|
|
122
|
-
|
|
123
|
-
}
|
|
124
|
-
const { image, nextOffset } = await this.readIfd(offset, logger);
|
|
122
|
+
async processIfd(offset) {
|
|
123
|
+
if (!this.source.hasBytes(offset, 4096))
|
|
124
|
+
await this.source.loadBytes(offset, 4096);
|
|
125
|
+
const { image, nextOffset } = await this.readIfd(offset);
|
|
125
126
|
this.images.push(image);
|
|
126
|
-
const size = image.size;
|
|
127
|
-
if (image.isTiled()) {
|
|
128
|
-
const tile = image.tileSize;
|
|
129
|
-
logger === null || logger === void 0 ? void 0 : logger.debug({
|
|
130
|
-
...size,
|
|
131
|
-
tileWidth: tile.width,
|
|
132
|
-
tileHeight: tile.height,
|
|
133
|
-
tileCount: Math.ceil(size.width / tile.width),
|
|
134
|
-
}, 'GotImage');
|
|
135
|
-
}
|
|
136
127
|
if (nextOffset)
|
|
137
|
-
await this.processIfd(nextOffset
|
|
128
|
+
await this.processIfd(nextOffset);
|
|
138
129
|
}
|
|
139
|
-
async readIfd(offset
|
|
130
|
+
async readIfd(offset) {
|
|
140
131
|
if (!this.source.hasBytes(offset, 1024))
|
|
141
|
-
await this.source.loadBytes(offset, this.source.chunkSize
|
|
132
|
+
await this.source.loadBytes(offset, this.source.chunkSize);
|
|
142
133
|
const view = this.cursor.seekTo(offset);
|
|
143
134
|
const tagCount = view.offset();
|
|
144
135
|
const byteStart = offset + this.ifdConfig.offset;
|
|
145
|
-
const logger = log === null || log === void 0 ? void 0 : log.child({ imageId: this.images.length });
|
|
146
136
|
const tags = new Map();
|
|
147
137
|
let pos = byteStart;
|
|
148
138
|
for (let i = 0; i < tagCount; i++) {
|
|
149
139
|
const tag = CogTiffTag.create(this, pos);
|
|
150
140
|
pos += tag.size;
|
|
151
|
-
if (tag.name == null)
|
|
152
|
-
|
|
153
|
-
continue;
|
|
154
|
-
}
|
|
155
|
-
if (!tag.isReady) {
|
|
156
|
-
logger === null || logger === void 0 ? void 0 : logger.trace({
|
|
157
|
-
offset: toHexString(pos - offset),
|
|
158
|
-
code: toHexString(tag.id),
|
|
159
|
-
tagName: tag.name,
|
|
160
|
-
ptr: toHexString(tag.valuePointer),
|
|
161
|
-
}, 'PartialReadIFD');
|
|
162
|
-
}
|
|
163
|
-
else {
|
|
164
|
-
logger === null || logger === void 0 ? void 0 : logger.trace({
|
|
165
|
-
offset: toHexString(pos - offset),
|
|
166
|
-
code: toHexString(tag.id),
|
|
167
|
-
tagName: tag.name,
|
|
168
|
-
value: Array.isArray(tag.value) ? `[${tag.value.length}]` : tag.value,
|
|
169
|
-
}, 'ReadIFD');
|
|
170
|
-
}
|
|
141
|
+
if (tag.name == null)
|
|
142
|
+
throw new Error('Unknown IFD Tag: ' + toHexString(tag.id));
|
|
171
143
|
tags.set(tag.id, tag);
|
|
172
144
|
}
|
|
173
145
|
const image = new CogTiffImage(this, this.images.length, tags);
|
|
@@ -180,4 +152,4 @@ export class CogTiff {
|
|
|
180
152
|
await ((_b = (_a = this.source) === null || _a === void 0 ? void 0 : _a.close) === null || _b === void 0 ? void 0 : _b.call(_a));
|
|
181
153
|
}
|
|
182
154
|
}
|
|
183
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"cog.tiff.js","sourceRoot":"","sources":["../src/cog.tiff.ts"],"names":[],"mappings":"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","sourcesContent":["import { ChunkSource, LogType } from '@chunkd/core';\nimport { CogTiffImage } from './cog.tiff.image.js';\nimport { TiffEndian } from './const/tiff.endian.js';\nimport { TiffTag } from './const/tiff.tag.id.js';\nimport { TiffVersion } from './const/tiff.version.js';\nimport { CogTiffTagBase } from './read/tag/tiff.tag.base.js';\nimport { CogTifGhostOptions } from './read/tiff.gdal.js';\nimport { TagTiffBigConfig, TagTiffConfig, TiffIfdConfig } from './read/tiff.ifd.config.js';\nimport { CogTiffTag } from './read/tiff.tag.js';\nimport { CogSourceCursor } from './source/cog.source.view.js';\nimport { toHexString } from './util/util.hex.js';\n\nexport class CogTiff {\n    source: ChunkSource;\n    version = TiffVersion.Tiff;\n    images: CogTiffImage[] = [];\n    options = new CogTifGhostOptions();\n\n    private cursor: CogSourceCursor;\n    ifdConfig: TiffIfdConfig = TagTiffConfig;\n\n    constructor(source: ChunkSource) {\n        this.source = source;\n        this.cursor = new CogSourceCursor(this);\n    }\n\n    /** Create and initialize a CogTiff */\n    static create(source: ChunkSource): Promise<CogTiff> {\n        return new CogTiff(source).init();\n    }\n\n    /** Has init() been called */\n    isInitialized = false;\n\n    _initPromise?: Promise<CogTiff>;\n    /**\n     * Initialize the COG loading in the header and all image headers\n     *\n     * @param loadGeoKeys Whether to also initialize the GeoKeyDirectory\n     */\n    init(loadGeoKeys = false, logger?: LogType): Promise<CogTiff> {\n        if (this._initPromise) return this._initPromise;\n        this._initPromise = this.doInit(loadGeoKeys, logger);\n        return this._initPromise;\n    }\n\n    private async doInit(loadGeoKeys = false, logger?: LogType): Promise<CogTiff> {\n        if (this.isInitialized) return this;\n        // Load the first few KB in, more loads will run as more data is required\n        await this.source.loadBytes(0, this.source.chunkSize, logger);\n        await this.fetchIfd(logger);\n        await Promise.all(this.images.map((c) => c.init(loadGeoKeys, logger)));\n\n        this.isInitialized = true;\n        return this;\n    }\n\n    private async fetchIfd(logger?: LogType): Promise<void> {\n        const view = this.cursor.seekTo(0);\n        const endian = view.uint16();\n        this.source.isLittleEndian = endian === TiffEndian.Little;\n        if (!this.source.isLittleEndian) throw new Error('Only little endian is supported');\n        this.version = view.uint16();\n\n        let nextOffsetIfd: number;\n        if (this.version === TiffVersion.BigTiff) {\n            this.ifdConfig = TagTiffBigConfig;\n            const pointerSize = view.uint16();\n            if (pointerSize !== 8) throw new Error('Only 8byte pointers are supported');\n            const zeros = view.uint16();\n            if (zeros !== 0) throw new Error('Invalid big tiff header');\n            nextOffsetIfd = view.pointer();\n        } else if (this.version === TiffVersion.Tiff) {\n            nextOffsetIfd = view.pointer();\n        } else {\n            throw new Error(`Only tiff supported version:${this.version}`);\n        }\n\n        const ghostSize = nextOffsetIfd - this.cursor.currentOffset;\n        // GDAL now stores metadata between the IFD inside a ghost storage area\n        if (ghostSize > 0 && ghostSize < 16 * 1024) {\n            logger?.debug(\n                { offset: toHexString(this.cursor.currentOffset), length: toHexString(ghostSize) },\n                'GhostOptions',\n            );\n            // this.options.process(this.source, view.currentOffset, ghostSize);\n        }\n\n        return this.processIfd(nextOffsetIfd, logger);\n    }\n\n    getImage(z: number): CogTiffImage {\n        return this.images[z];\n    }\n\n    /**\n     * Find a image which has a resolution similar to the provided resolution\n     *\n     * @param resolution resolution to find\n     */\n    getImageByResolution(resolution: number): CogTiffImage {\n        const firstImage = this.images[0];\n        const firstImageSize = firstImage.size;\n        const [refX] = firstImage.resolution;\n\n        const resolutionBaseX = refX * firstImageSize.width;\n        // const resolutionBaseY = refY * firstImageSize.height;\n        for (let i = this.images.length - 1; i > 0; i--) {\n            const img = this.images[i];\n            const imgSize = img.size;\n\n            const imgResolutionX = resolutionBaseX / imgSize.width;\n            // TODO do we care about y resolution\n            // const imgResolutionY = resolutionBaseY / imgSize.height;\n\n            if (imgResolutionX - resolution <= 0.01) return img;\n        }\n        return firstImage;\n    }\n\n    /**\n     * Get the raw bytes for a tile at a given x,y, index.\n     *\n     * This may return null if the tile does not exist eg Sparse cogs,\n     *\n     * @param x tile x index\n     * @param y tile y index\n     * @param index image index\n     */\n    async getTile(x: number, y: number, index: number): Promise<{ mimeType: string; bytes: Uint8Array } | null> {\n        const image = this.getImage(index);\n        if (image == null) throw new Error(`Missing z: ${index}`);\n        if (!image.isTiled()) throw new Error('Tif is not tiled');\n\n        return image.getTile(x, y);\n    }\n\n    private async processIfd(offset: number, logger?: LogType): Promise<void> {\n        logger?.trace({ offset: toHexString(offset) }, 'NextImageOffset');\n\n        if (!this.source.hasBytes(offset, 4096)) {\n            await this.source.loadBytes(offset, 4096, logger);\n        }\n\n        const { image, nextOffset } = await this.readIfd(offset, logger);\n        this.images.push(image);\n        const size = image.size;\n        if (image.isTiled()) {\n            const tile = image.tileSize;\n            logger?.debug(\n                {\n                    ...size,\n                    tileWidth: tile.width,\n                    tileHeight: tile.height,\n                    tileCount: Math.ceil(size.width / tile.width),\n                },\n                'GotImage',\n            );\n        }\n\n        if (nextOffset) await this.processIfd(nextOffset, logger);\n    }\n\n    private async readIfd(offset: number, log?: LogType): Promise<{ nextOffset: number; image: CogTiffImage }> {\n        if (!this.source.hasBytes(offset, 1024)) await this.source.loadBytes(offset, this.source.chunkSize, log);\n        const view = this.cursor.seekTo(offset);\n        const tagCount = view.offset();\n        const byteStart = offset + this.ifdConfig.offset;\n        const logger = log?.child({ imageId: this.images.length });\n        const tags: Map<TiffTag, CogTiffTagBase> = new Map();\n\n        let pos = byteStart;\n        for (let i = 0; i < tagCount; i++) {\n            const tag = CogTiffTag.create(this, pos);\n            pos += tag.size;\n\n            if (tag.name == null) {\n                logger?.error({ code: toHexString(tag.id) }, `IFDUnknown`);\n                continue;\n            }\n\n            if (!tag.isReady) {\n                logger?.trace(\n                    {\n                        offset: toHexString(pos - offset),\n                        code: toHexString(tag.id),\n                        tagName: tag.name,\n                        ptr: toHexString(tag.valuePointer),\n                    },\n                    'PartialReadIFD',\n                );\n            } else {\n                logger?.trace(\n                    {\n                        offset: toHexString(pos - offset),\n                        code: toHexString(tag.id),\n                        tagName: tag.name,\n                        value: Array.isArray(tag.value) ? `[${tag.value.length}]` : tag.value,\n                    },\n                    'ReadIFD',\n                );\n            }\n\n            tags.set(tag.id, tag);\n        }\n\n        const image = new CogTiffImage(this, this.images.length, tags);\n        const nextOffset = this.source.getUint(pos, this.ifdConfig.pointer);\n        return { nextOffset, image };\n    }\n\n    /** Close the file source if it needs closing */\n    async close(): Promise<void> {\n        await this.source?.close?.();\n    }\n}\n"]}
|
|
155
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"cog.tiff.js","sourceRoot":"","sources":["../src/cog.tiff.ts"],"names":[],"mappings":"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","sourcesContent":["import { ChunkSource } from '@chunkd/core';\nimport { CogTiffImage } from './cog.tiff.image.js';\nimport { TiffEndian } from './const/tiff.endian.js';\nimport { TiffTag } from './const/tiff.tag.id.js';\nimport { TiffVersion } from './const/tiff.version.js';\nimport { CogTiffTagBase } from './read/tag/tiff.tag.base.js';\nimport { CogTifGhostOptions } from './read/tiff.gdal.js';\nimport { TagTiffBigConfig, TagTiffConfig, TiffIfdConfig } from './read/tiff.ifd.config.js';\nimport { CogTiffTag } from './read/tiff.tag.js';\nimport { CogSourceCursor } from './source/cog.source.view.js';\nimport { toHexString } from './util/util.hex.js';\n\nexport class CogTiff {\n    source: ChunkSource;\n    version = TiffVersion.Tiff;\n    images: CogTiffImage[] = [];\n    options = new CogTifGhostOptions();\n\n    private cursor: CogSourceCursor;\n    ifdConfig: TiffIfdConfig = TagTiffConfig;\n\n    constructor(source: ChunkSource) {\n        this.source = source;\n        this.cursor = new CogSourceCursor(this);\n    }\n\n    /** Create and initialize a CogTiff */\n    static create(source: ChunkSource): Promise<CogTiff> {\n        return new CogTiff(source).init();\n    }\n\n    /** Has init() been called */\n    isInitialized = false;\n\n    _initPromise?: Promise<CogTiff>;\n    /**\n     * Initialize the COG loading in the header and all image headers\n     *\n     * @param loadGeoKeys Whether to also initialize the GeoKeyDirectory\n     */\n    init(loadGeoKeys = false): Promise<CogTiff> {\n        if (this._initPromise) return this._initPromise;\n        this._initPromise = this.doInit(loadGeoKeys);\n        return this._initPromise;\n    }\n\n    private async doInit(loadGeoKeys = false): Promise<CogTiff> {\n        if (this.isInitialized) return this;\n        // Load the first few KB in, more loads will run as more data is required\n        await this.source.loadBytes(0, this.source.chunkSize);\n        await this.fetchIfd();\n        await Promise.all(this.images.map((c) => c.init(loadGeoKeys)));\n\n        this.isInitialized = true;\n        return this;\n    }\n\n    private async fetchIfd(): Promise<void> {\n        const view = this.cursor.seekTo(0);\n        const endian = view.uint16();\n        this.source.isLittleEndian = endian === TiffEndian.Little;\n        if (!this.source.isLittleEndian) throw new Error('Only little endian is supported');\n        this.version = view.uint16();\n\n        let nextOffsetIfd: number;\n        if (this.version === TiffVersion.BigTiff) {\n            this.ifdConfig = TagTiffBigConfig;\n            const pointerSize = view.uint16();\n            if (pointerSize !== 8) throw new Error('Only 8byte pointers are supported');\n            const zeros = view.uint16();\n            if (zeros !== 0) throw new Error('Invalid big tiff header');\n            nextOffsetIfd = view.pointer();\n        } else if (this.version === TiffVersion.Tiff) {\n            nextOffsetIfd = view.pointer();\n        } else {\n            throw new Error(`Only tiff supported version:${this.version}`);\n        }\n\n        const ghostSize = nextOffsetIfd - this.cursor.currentOffset;\n        // GDAL now stores metadata between the IFD inside a ghost storage area\n        if (ghostSize > 0 && ghostSize < 16 * 1024) {\n            // logger?.debug(\n            //     { offset: toHexString(this.cursor.currentOffset), length: toHexString(ghostSize) },\n            //     'GhostOptions',\n            // );\n            // this.options.process(this.source, view.currentOffset, ghostSize);\n        }\n\n        return this.processIfd(nextOffsetIfd);\n    }\n\n    getImage(z: number): CogTiffImage {\n        return this.images[z];\n    }\n\n    /**\n     * Find a image which has a resolution similar to the provided resolution\n     *\n     * @param resolution resolution to find\n     */\n    getImageByResolution(resolution: number): CogTiffImage {\n        const firstImage = this.images[0];\n        const firstImageSize = firstImage.size;\n        const [refX] = firstImage.resolution;\n\n        const resolutionBaseX = refX * firstImageSize.width;\n        // const resolutionBaseY = refY * firstImageSize.height;\n        for (let i = this.images.length - 1; i > 0; i--) {\n            const img = this.images[i];\n            const imgSize = img.size;\n\n            const imgResolutionX = resolutionBaseX / imgSize.width;\n            // TODO do we care about y resolution\n            // const imgResolutionY = resolutionBaseY / imgSize.height;\n\n            if (imgResolutionX - resolution <= 0.01) return img;\n        }\n        return firstImage;\n    }\n\n    /**\n     * Get the raw bytes for a tile at a given x,y, index.\n     *\n     * This may return null if the tile does not exist eg Sparse cogs,\n     *\n     * @param x tile x index\n     * @param y tile y index\n     * @param index image index\n     */\n    async getTile(x: number, y: number, index: number): Promise<{ mimeType: string; bytes: Uint8Array } | null> {\n        const image = this.getImage(index);\n        if (image == null) throw new Error(`Missing z: ${index}`);\n        if (!image.isTiled()) throw new Error('Tif is not tiled');\n\n        return image.getTile(x, y);\n    }\n\n    private async processIfd(offset: number): Promise<void> {\n        if (!this.source.hasBytes(offset, 4096)) await this.source.loadBytes(offset, 4096);\n\n        const { image, nextOffset } = await this.readIfd(offset);\n        this.images.push(image);\n\n        if (nextOffset) await this.processIfd(nextOffset);\n    }\n\n    private async readIfd(offset: number): Promise<{ nextOffset: number; image: CogTiffImage }> {\n        if (!this.source.hasBytes(offset, 1024)) await this.source.loadBytes(offset, this.source.chunkSize);\n        const view = this.cursor.seekTo(offset);\n        const tagCount = view.offset();\n        const byteStart = offset + this.ifdConfig.offset;\n        const tags: Map<TiffTag, CogTiffTagBase> = new Map();\n\n        let pos = byteStart;\n        for (let i = 0; i < tagCount; i++) {\n            const tag = CogTiffTag.create(this, pos);\n            pos += tag.size;\n\n            if (tag.name == null) throw new Error('Unknown IFD Tag: ' + toHexString(tag.id));\n            tags.set(tag.id, tag);\n        }\n\n        const image = new CogTiffImage(this, this.images.length, tags);\n        const nextOffset = this.source.getUint(pos, this.ifdConfig.pointer);\n        return { nextOffset, image };\n    }\n\n    /** Close the file source if it needs closing */\n    async close(): Promise<void> {\n        await this.source?.close?.();\n    }\n}\n"]}
|
|
@@ -20,4 +20,4 @@ o.spec('TiffTag', () => {
|
|
|
20
20
|
o(lazy.value).deepEquals(res);
|
|
21
21
|
});
|
|
22
22
|
});
|
|
23
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
23
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGFnLnRlc3QuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9zcmMvcmVhZC90YWcvX190ZXN0X18vdGFnLnRlc3QudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLG1CQUFtQixFQUFFLE1BQU0sa0RBQWtELENBQUM7QUFDdkYsT0FBTyxDQUFDLE1BQU0sT0FBTyxDQUFDO0FBQ3RCLE9BQU8sS0FBSyxJQUFJLE1BQU0sTUFBTSxDQUFDO0FBQzdCLE9BQU8sRUFBRSxhQUFhLEVBQUUsTUFBTSxLQUFLLENBQUM7QUFDcEMsT0FBTyxFQUFFLE9BQU8sRUFBRSxNQUFNLHNCQUFzQixDQUFDO0FBQy9DLE9BQU8sRUFBRSxjQUFjLEVBQUUsTUFBTSxxQkFBcUIsQ0FBQztBQUVyRCxDQUFDLENBQUMsSUFBSSxDQUFDLFNBQVMsRUFBRSxHQUFHLEVBQUU7SUFDbkIsTUFBTSxPQUFPLEdBQUcsYUFBYSxDQUFDLE1BQU0sQ0FBQyxJQUFJLENBQUMsR0FBRyxDQUFDLENBQUM7SUFDL0MsTUFBTSxhQUFhLEdBQUcsSUFBSSxtQkFBbUIsQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDLE9BQU8sRUFBRSxzQ0FBc0MsQ0FBQyxDQUFDLENBQUM7SUFFMUcsQ0FBQyxDQUFDLFVBQVUsQ0FBQyxHQUFHLEVBQUU7UUFDYixhQUFhLENBQUMsTUFBZ0MsQ0FBQyxLQUFLLEVBQUUsQ0FBQztJQUM1RCxDQUFDLENBQUMsQ0FBQztJQUVILENBQUMsQ0FBQyx1QkFBdUIsRUFBRSxLQUFLLElBQUksRUFBRTtRQUNsQyxNQUFNLElBQUksR0FBRyxJQUFJLE9BQU8sQ0FBQyxhQUFhLENBQUMsQ0FBQztRQUV4QyxNQUFNLGFBQWEsQ0FBQyxTQUFTLENBQUMsSUFBSSxFQUFFLENBQUMsQ0FBQyxDQUFDO1FBQ3ZDLE1BQU0sSUFBSSxHQUFHLElBQUksY0FBYyxDQUFDLEdBQUcsRUFBRSxJQUFJLEVBQUUsSUFBSSxDQUFDLENBQUM7UUFDakQsQ0FBQyxDQUFDLElBQUksQ0FBQyxLQUFLLENBQUMsQ0FBQyxNQUFNLENBQUMsSUFBSSxDQUFDLENBQUM7UUFFM0IsTUFBTSxHQUFHLEdBQUcsTUFBTSxJQUFJLENBQUMsS0FBSyxFQUFFLENBQUM7UUFDL0IsQ0FBQyxDQUFDLEdBQUcsQ0FBQyxDQUFDLFVBQVUsQ0FBQyxDQUFDLEtBQUssRUFBRSxFQUFFLEVBQUUsQ0FBQyxFQUFFLENBQUMsQ0FBQyxDQUFDLENBQUM7UUFDckMsQ0FBQyxDQUFDLElBQUksQ0FBQyxLQUFLLENBQUMsQ0FBQyxVQUFVLENBQUMsR0FBRyxDQUFDLENBQUM7SUFDbEMsQ0FBQyxDQUFDLENBQUM7QUFDUCxDQUFDLENBQUMsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IFRlc3RGaWxlQ2h1bmtTb3VyY2UgfSBmcm9tICdAY2h1bmtkL2NvcmUvYnVpbGQvX190ZXN0X18vY2h1bmsuc291cmNlLmZha2UuanMnO1xuaW1wb3J0IG8gZnJvbSAnb3NwZWMnO1xuaW1wb3J0ICogYXMgcGF0aCBmcm9tICdwYXRoJztcbmltcG9ydCB7IGZpbGVVUkxUb1BhdGggfSBmcm9tICd1cmwnO1xuaW1wb3J0IHsgQ29nVGlmZiB9IGZyb20gJy4uLy4uLy4uL2NvZy50aWZmLmpzJztcbmltcG9ydCB7IENvZ1RpZmZUYWdMYXp5IH0gZnJvbSAnLi4vdGlmZi50YWcubGF6eS5qcyc7XG5cbm8uc3BlYygnVGlmZlRhZycsICgpID0+IHtcbiAgICBjb25zdCBkaXJOYW1lID0gZmlsZVVSTFRvUGF0aChpbXBvcnQubWV0YS51cmwpO1xuICAgIGNvbnN0IGNvZ1NvdXJjZUZpbGUgPSBuZXcgVGVzdEZpbGVDaHVua1NvdXJjZShwYXRoLmpvaW4oZGlyTmFtZSwgJy4uLy4uLy4uLy4uLy4uL2RhdGEvcmdiYThfdGlsZWQudGlmZicpKTtcblxuICAgIG8uYmVmb3JlRWFjaCgoKSA9PiB7XG4gICAgICAgIChjb2dTb3VyY2VGaWxlLmNodW5rcyBhcyBNYXA8dW5rbm93biwgdW5rbm93bj4pLmNsZWFyKCk7XG4gICAgfSk7XG5cbiAgICBvKCdzaG91bGQgbG9hZCBsYXp5IHRhZ3MnLCBhc3luYyAoKSA9PiB7XG4gICAgICAgIGNvbnN0IHRpZmYgPSBuZXcgQ29nVGlmZihjb2dTb3VyY2VGaWxlKTtcblxuICAgICAgICBhd2FpdCBjb2dTb3VyY2VGaWxlLmxvYWRCeXRlcygzNjgwLCA4KTtcbiAgICAgICAgY29uc3QgbGF6eSA9IG5ldyBDb2dUaWZmVGFnTGF6eSgzMzksIHRpZmYsIDM2ODApO1xuICAgICAgICBvKGxhenkudmFsdWUpLmVxdWFscyhudWxsKTtcblxuICAgICAgICBjb25zdCByZXMgPSBhd2FpdCBsYXp5LmZldGNoKCk7XG4gICAgICAgIG8ocmVzKS5kZWVwRXF1YWxzKFsxODc2MSwgNDMsIDgsIDBdKTtcbiAgICAgICAgbyhsYXp5LnZhbHVlKS5kZWVwRXF1YWxzKHJlcyk7XG4gICAgfSk7XG59KTtcbiJdfQ==
|
|
@@ -1,8 +1,7 @@
|
|
|
1
|
-
import { LogType } from '@chunkd/core';
|
|
2
1
|
import { CogTiffTagBase } from './tiff.tag.base.js';
|
|
3
2
|
export declare class CogTiffTagLazy<T> extends CogTiffTagBase<T> {
|
|
4
3
|
value: T | null;
|
|
5
4
|
get isReady(): boolean;
|
|
6
|
-
fetch(
|
|
5
|
+
fetch(): Promise<T>;
|
|
7
6
|
}
|
|
8
7
|
//# sourceMappingURL=tiff.tag.lazy.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"tiff.tag.lazy.d.ts","sourceRoot":"","sources":["../../../src/read/tag/tiff.tag.lazy.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,
|
|
1
|
+
{"version":3,"file":"tiff.tag.lazy.d.ts","sourceRoot":"","sources":["../../../src/read/tag/tiff.tag.lazy.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,cAAc,EAAE,MAAM,oBAAoB,CAAC;AAEpD,qBAAa,cAAc,CAAC,CAAC,CAAE,SAAQ,cAAc,CAAC,CAAC,CAAC;IACpD,KAAK,EAAE,CAAC,GAAG,IAAI,CAAQ;IAEvB,IAAI,OAAO,IAAI,OAAO,CAErB;IAEK,KAAK,IAAI,OAAO,CAAC,CAAC,CAAC;CAO5B"}
|
|
@@ -7,12 +7,12 @@ export class CogTiffTagLazy extends CogTiffTagBase {
|
|
|
7
7
|
get isReady() {
|
|
8
8
|
return this.value != null;
|
|
9
9
|
}
|
|
10
|
-
async fetch(
|
|
10
|
+
async fetch() {
|
|
11
11
|
if (this.tiff.source.hasBytes(this.valuePointer, this.dataLength) === false) {
|
|
12
|
-
await this.tiff.source.loadBytes(this.valuePointer, this.dataLength
|
|
12
|
+
await this.tiff.source.loadBytes(this.valuePointer, this.dataLength);
|
|
13
13
|
}
|
|
14
14
|
this.value = this.readValue();
|
|
15
15
|
return this.value;
|
|
16
16
|
}
|
|
17
17
|
}
|
|
18
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
18
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGlmZi50YWcubGF6eS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9yZWFkL3RhZy90aWZmLnRhZy5sYXp5LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxjQUFjLEVBQUUsTUFBTSxvQkFBb0IsQ0FBQztBQUVwRCxNQUFNLE9BQU8sY0FBa0IsU0FBUSxjQUFpQjtJQUF4RDs7UUFDSSxVQUFLLEdBQWEsSUFBSSxDQUFDO0lBYTNCLENBQUM7SUFYRyxJQUFJLE9BQU87UUFDUCxPQUFPLElBQUksQ0FBQyxLQUFLLElBQUksSUFBSSxDQUFDO0lBQzlCLENBQUM7SUFFRCxLQUFLLENBQUMsS0FBSztRQUNQLElBQUksSUFBSSxDQUFDLElBQUksQ0FBQyxNQUFNLENBQUMsUUFBUSxDQUFDLElBQUksQ0FBQyxZQUFZLEVBQUUsSUFBSSxDQUFDLFVBQVUsQ0FBQyxLQUFLLEtBQUssRUFBRTtZQUN6RSxNQUFNLElBQUksQ0FBQyxJQUFJLENBQUMsTUFBTSxDQUFDLFNBQVMsQ0FBQyxJQUFJLENBQUMsWUFBWSxFQUFFLElBQUksQ0FBQyxVQUFVLENBQUMsQ0FBQztTQUN4RTtRQUNELElBQUksQ0FBQyxLQUFLLEdBQUcsSUFBSSxDQUFDLFNBQVMsRUFBRSxDQUFDO1FBQzlCLE9BQU8sSUFBSSxDQUFDLEtBQUssQ0FBQztJQUN0QixDQUFDO0NBQ0oiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDb2dUaWZmVGFnQmFzZSB9IGZyb20gJy4vdGlmZi50YWcuYmFzZS5qcyc7XG5cbmV4cG9ydCBjbGFzcyBDb2dUaWZmVGFnTGF6eTxUPiBleHRlbmRzIENvZ1RpZmZUYWdCYXNlPFQ+IHtcbiAgICB2YWx1ZTogVCB8IG51bGwgPSBudWxsO1xuXG4gICAgZ2V0IGlzUmVhZHkoKTogYm9vbGVhbiB7XG4gICAgICAgIHJldHVybiB0aGlzLnZhbHVlICE9IG51bGw7XG4gICAgfVxuXG4gICAgYXN5bmMgZmV0Y2goKTogUHJvbWlzZTxUPiB7XG4gICAgICAgIGlmICh0aGlzLnRpZmYuc291cmNlLmhhc0J5dGVzKHRoaXMudmFsdWVQb2ludGVyLCB0aGlzLmRhdGFMZW5ndGgpID09PSBmYWxzZSkge1xuICAgICAgICAgICAgYXdhaXQgdGhpcy50aWZmLnNvdXJjZS5sb2FkQnl0ZXModGhpcy52YWx1ZVBvaW50ZXIsIHRoaXMuZGF0YUxlbmd0aCk7XG4gICAgICAgIH1cbiAgICAgICAgdGhpcy52YWx1ZSA9IHRoaXMucmVhZFZhbHVlKCk7XG4gICAgICAgIHJldHVybiB0aGlzLnZhbHVlO1xuICAgIH1cbn1cbiJdfQ==
|
|
@@ -1,4 +1,3 @@
|
|
|
1
|
-
import { LogType } from '@chunkd/core';
|
|
2
1
|
import { CogTiff } from '../../cog.tiff.js';
|
|
3
2
|
import { CogTiffTagBase } from './tiff.tag.base.js';
|
|
4
3
|
/**
|
|
@@ -11,12 +10,12 @@ export declare class CogTiffTagOffset extends CogTiffTagBase<number[]> {
|
|
|
11
10
|
constructor(tagId: number, tiff: CogTiff, offset: number);
|
|
12
11
|
get value(): number[] | null;
|
|
13
12
|
/** Load the entire index into memory */
|
|
14
|
-
load(
|
|
13
|
+
load(): Promise<void>;
|
|
15
14
|
readValue(): number[];
|
|
16
15
|
/**
|
|
17
16
|
* Read a specific value from the offset array
|
|
18
17
|
* @param index index to read at
|
|
19
18
|
*/
|
|
20
|
-
getValueAt(index: number
|
|
19
|
+
getValueAt(index: number): Promise<number>;
|
|
21
20
|
}
|
|
22
21
|
//# sourceMappingURL=tiff.tag.offset.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"tiff.tag.offset.d.ts","sourceRoot":"","sources":["../../../src/read/tag/tiff.tag.offset.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,EAAE,MAAM,
|
|
1
|
+
{"version":3,"file":"tiff.tag.offset.d.ts","sourceRoot":"","sources":["../../../src/read/tag/tiff.tag.offset.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,EAAE,MAAM,mBAAmB,CAAC;AAE5C,OAAO,EAAE,cAAc,EAAE,MAAM,oBAAoB,CAAC;AAEpD;;;;GAIG;AACH,qBAAa,gBAAiB,SAAQ,cAAc,CAAC,MAAM,EAAE,CAAC;IAC1D,OAAO,CAAC,YAAY,CAAyB;gBAEjC,KAAK,EAAE,MAAM,EAAE,IAAI,EAAE,OAAO,EAAE,MAAM,EAAE,MAAM;IAIxD,IAAI,KAAK,IAAI,MAAM,EAAE,GAAG,IAAI,CAS3B;IAED,wCAAwC;IAClC,IAAI,IAAI,OAAO,CAAC,IAAI,CAAC;IAK3B,SAAS,IAAI,MAAM,EAAE;IAWrB;;;OAGG;IACG,UAAU,CAAC,KAAK,EAAE,MAAM,GAAG,OAAO,CAAC,MAAM,CAAC;CAYnD"}
|
|
@@ -20,8 +20,8 @@ export class CogTiffTagOffset extends CogTiffTagBase {
|
|
|
20
20
|
return null;
|
|
21
21
|
}
|
|
22
22
|
/** Load the entire index into memory */
|
|
23
|
-
async load(
|
|
24
|
-
await this.tiff.source.loadBytes(this.valuePointer, this.dataLength
|
|
23
|
+
async load() {
|
|
24
|
+
await this.tiff.source.loadBytes(this.valuePointer, this.dataLength);
|
|
25
25
|
this.readValue();
|
|
26
26
|
}
|
|
27
27
|
readValue() {
|
|
@@ -39,16 +39,16 @@ export class CogTiffTagOffset extends CogTiffTagBase {
|
|
|
39
39
|
* Read a specific value from the offset array
|
|
40
40
|
* @param index index to read at
|
|
41
41
|
*/
|
|
42
|
-
async getValueAt(index
|
|
42
|
+
async getValueAt(index) {
|
|
43
43
|
if (this.loadedValues)
|
|
44
44
|
return this.loadedValues[index];
|
|
45
45
|
const dataSize = this.dataTypeSize;
|
|
46
46
|
const valueOffset = this.valuePointer + dataSize * index;
|
|
47
47
|
const convert = getTiffTagValueReader(this.dataType);
|
|
48
48
|
if (!this.tiff.source.hasBytes(valueOffset, dataSize)) {
|
|
49
|
-
await this.tiff.source.loadBytes(valueOffset, dataSize
|
|
49
|
+
await this.tiff.source.loadBytes(valueOffset, dataSize);
|
|
50
50
|
}
|
|
51
51
|
return convert(this.tiff.source, valueOffset);
|
|
52
52
|
}
|
|
53
53
|
}
|
|
54
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
54
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGlmZi50YWcub2Zmc2V0LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vc3JjL3JlYWQvdGFnL3RpZmYudGFnLm9mZnNldC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFDQSxPQUFPLEVBQUUscUJBQXFCLEVBQUUsTUFBTSx5QkFBeUIsQ0FBQztBQUNoRSxPQUFPLEVBQUUsY0FBYyxFQUFFLE1BQU0sb0JBQW9CLENBQUM7QUFFcEQ7Ozs7R0FJRztBQUNILE1BQU0sT0FBTyxnQkFBaUIsU0FBUSxjQUF3QjtJQUcxRCxZQUFZLEtBQWEsRUFBRSxJQUFhLEVBQUUsTUFBYztRQUNwRCxLQUFLLENBQUMsS0FBSyxFQUFFLElBQUksRUFBRSxNQUFNLENBQUMsQ0FBQztRQUh2QixpQkFBWSxHQUFvQixJQUFJLENBQUM7SUFJN0MsQ0FBQztJQUVELElBQUksS0FBSztRQUNMLElBQUksSUFBSSxDQUFDLFlBQVksSUFBSSxJQUFJO1lBQUUsT0FBTyxJQUFJLENBQUMsWUFBWSxDQUFDO1FBRXhELElBQUksSUFBSSxDQUFDLFFBQVEsRUFBRTtZQUNmLElBQUksQ0FBQyxTQUFTLEVBQUUsQ0FBQztZQUNqQixPQUFPLElBQUksQ0FBQyxZQUFZLENBQUM7U0FDNUI7UUFFRCxPQUFPLElBQUksQ0FBQztJQUNoQixDQUFDO0lBRUQsd0NBQXdDO0lBQ3hDLEtBQUssQ0FBQyxJQUFJO1FBQ04sTUFBTSxJQUFJLENBQUMsSUFBSSxDQUFDLE1BQU0sQ0FBQyxTQUFTLENBQUMsSUFBSSxDQUFDLFlBQVksRUFBRSxJQUFJLENBQUMsVUFBVSxDQUFDLENBQUM7UUFDckUsSUFBSSxDQUFDLFNBQVMsRUFBRSxDQUFDO0lBQ3JCLENBQUM7SUFFRCxTQUFTO1FBQ0wsTUFBTSxHQUFHLEdBQUcsS0FBSyxDQUFDLFNBQVMsRUFBRSxDQUFDO1FBQzlCLG1FQUFtRTtRQUNuRSxJQUFJLE9BQU8sR0FBRyxLQUFLLFFBQVEsRUFBRTtZQUN6QixJQUFJLENBQUMsWUFBWSxHQUFHLENBQUMsR0FBRyxDQUFDLENBQUM7U0FDN0I7YUFBTTtZQUNILElBQUksQ0FBQyxZQUFZLEdBQUcsR0FBRyxDQUFDO1NBQzNCO1FBQ0QsT0FBTyxJQUFJLENBQUMsWUFBWSxDQUFDO0lBQzdCLENBQUM7SUFFRDs7O09BR0c7SUFDSCxLQUFLLENBQUMsVUFBVSxDQUFDLEtBQWE7UUFDMUIsSUFBSSxJQUFJLENBQUMsWUFBWTtZQUFFLE9BQU8sSUFBSSxDQUFDLFlBQVksQ0FBQyxLQUFLLENBQUMsQ0FBQztRQUV2RCxNQUFNLFFBQVEsR0FBRyxJQUFJLENBQUMsWUFBWSxDQUFDO1FBQ25DLE1BQU0sV0FBVyxHQUFHLElBQUksQ0FBQyxZQUFZLEdBQUcsUUFBUSxHQUFHLEtBQUssQ0FBQztRQUN6RCxNQUFNLE9BQU8sR0FBRyxxQkFBcUIsQ0FBQyxJQUFJLENBQUMsUUFBUSxDQUFDLENBQUM7UUFFckQsSUFBSSxDQUFDLElBQUksQ0FBQyxJQUFJLENBQUMsTUFBTSxDQUFDLFFBQVEsQ0FBQyxXQUFXLEVBQUUsUUFBUSxDQUFDLEVBQUU7WUFDbkQsTUFBTSxJQUFJLENBQUMsSUFBSSxDQUFDLE1BQU0sQ0FBQyxTQUFTLENBQUMsV0FBVyxFQUFFLFFBQVEsQ0FBQyxDQUFDO1NBQzNEO1FBQ0QsT0FBTyxPQUFPLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQyxNQUFNLEVBQUUsV0FBVyxDQUFXLENBQUM7SUFDNUQsQ0FBQztDQUNKIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ29nVGlmZiB9IGZyb20gJy4uLy4uL2NvZy50aWZmLmpzJztcbmltcG9ydCB7IGdldFRpZmZUYWdWYWx1ZVJlYWRlciB9IGZyb20gJy4uL3RpZmYudmFsdWUucmVhZGVyLmpzJztcbmltcG9ydCB7IENvZ1RpZmZUYWdCYXNlIH0gZnJvbSAnLi90aWZmLnRhZy5iYXNlLmpzJztcblxuLyoqXG4gKiBUaWZmVGFnIGZvciBvZmZzZXQgYXJyYXlzXG4gKlxuICogQWxsb3dzIGluZGl2aWR1YWwgYWNjZXNzIHRvIHNwZWNpZmljIHJlY29yZHMgd2l0aG91dCBoYXZpbmcgdG8gcmVhZCB0aGUgZW50aXJlIHRhZyBpbi5cbiAqL1xuZXhwb3J0IGNsYXNzIENvZ1RpZmZUYWdPZmZzZXQgZXh0ZW5kcyBDb2dUaWZmVGFnQmFzZTxudW1iZXJbXT4ge1xuICAgIHByaXZhdGUgbG9hZGVkVmFsdWVzOiBudW1iZXJbXSB8IG51bGwgPSBudWxsO1xuXG4gICAgY29uc3RydWN0b3IodGFnSWQ6IG51bWJlciwgdGlmZjogQ29nVGlmZiwgb2Zmc2V0OiBudW1iZXIpIHtcbiAgICAgICAgc3VwZXIodGFnSWQsIHRpZmYsIG9mZnNldCk7XG4gICAgfVxuXG4gICAgZ2V0IHZhbHVlKCk6IG51bWJlcltdIHwgbnVsbCB7XG4gICAgICAgIGlmICh0aGlzLmxvYWRlZFZhbHVlcyAhPSBudWxsKSByZXR1cm4gdGhpcy5sb2FkZWRWYWx1ZXM7XG5cbiAgICAgICAgaWYgKHRoaXMuaGFzQnl0ZXMpIHtcbiAgICAgICAgICAgIHRoaXMucmVhZFZhbHVlKCk7XG4gICAgICAgICAgICByZXR1cm4gdGhpcy5sb2FkZWRWYWx1ZXM7XG4gICAgICAgIH1cblxuICAgICAgICByZXR1cm4gbnVsbDtcbiAgICB9XG5cbiAgICAvKiogTG9hZCB0aGUgZW50aXJlIGluZGV4IGludG8gbWVtb3J5ICovXG4gICAgYXN5bmMgbG9hZCgpOiBQcm9taXNlPHZvaWQ+IHtcbiAgICAgICAgYXdhaXQgdGhpcy50aWZmLnNvdXJjZS5sb2FkQnl0ZXModGhpcy52YWx1ZVBvaW50ZXIsIHRoaXMuZGF0YUxlbmd0aCk7XG4gICAgICAgIHRoaXMucmVhZFZhbHVlKCk7XG4gICAgfVxuXG4gICAgcmVhZFZhbHVlKCk6IG51bWJlcltdIHtcbiAgICAgICAgY29uc3QgdmFsID0gc3VwZXIucmVhZFZhbHVlKCk7XG4gICAgICAgIC8vIGlmIG9ubHkgb25lIHZhbHVlIGlzIHJlYWQgaW4sIGl0IHdpbGwgbm90IGJlIHJldHVybmVkIGFzIGEgYXJyYXlcbiAgICAgICAgaWYgKHR5cGVvZiB2YWwgPT09ICdudW1iZXInKSB7XG4gICAgICAgICAgICB0aGlzLmxvYWRlZFZhbHVlcyA9IFt2YWxdO1xuICAgICAgICB9IGVsc2Uge1xuICAgICAgICAgICAgdGhpcy5sb2FkZWRWYWx1ZXMgPSB2YWw7XG4gICAgICAgIH1cbiAgICAgICAgcmV0dXJuIHRoaXMubG9hZGVkVmFsdWVzO1xuICAgIH1cblxuICAgIC8qKlxuICAgICAqIFJlYWQgYSBzcGVjaWZpYyB2YWx1ZSBmcm9tIHRoZSBvZmZzZXQgYXJyYXlcbiAgICAgKiBAcGFyYW0gaW5kZXggaW5kZXggdG8gcmVhZCBhdFxuICAgICAqL1xuICAgIGFzeW5jIGdldFZhbHVlQXQoaW5kZXg6IG51bWJlcik6IFByb21pc2U8bnVtYmVyPiB7XG4gICAgICAgIGlmICh0aGlzLmxvYWRlZFZhbHVlcykgcmV0dXJuIHRoaXMubG9hZGVkVmFsdWVzW2luZGV4XTtcblxuICAgICAgICBjb25zdCBkYXRhU2l6ZSA9IHRoaXMuZGF0YVR5cGVTaXplO1xuICAgICAgICBjb25zdCB2YWx1ZU9mZnNldCA9IHRoaXMudmFsdWVQb2ludGVyICsgZGF0YVNpemUgKiBpbmRleDtcbiAgICAgICAgY29uc3QgY29udmVydCA9IGdldFRpZmZUYWdWYWx1ZVJlYWRlcih0aGlzLmRhdGFUeXBlKTtcblxuICAgICAgICBpZiAoIXRoaXMudGlmZi5zb3VyY2UuaGFzQnl0ZXModmFsdWVPZmZzZXQsIGRhdGFTaXplKSkge1xuICAgICAgICAgICAgYXdhaXQgdGhpcy50aWZmLnNvdXJjZS5sb2FkQnl0ZXModmFsdWVPZmZzZXQsIGRhdGFTaXplKTtcbiAgICAgICAgfVxuICAgICAgICByZXR1cm4gY29udmVydCh0aGlzLnRpZmYuc291cmNlLCB2YWx1ZU9mZnNldCkgYXMgbnVtYmVyO1xuICAgIH1cbn1cbiJdfQ==
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@cogeotiff/core",
|
|
3
|
-
"version": "
|
|
3
|
+
"version": "7.0.0",
|
|
4
4
|
"repository": {
|
|
5
5
|
"type": "git",
|
|
6
6
|
"url": "https://github.com/blacha/cogeotiff.git",
|
|
@@ -18,16 +18,15 @@
|
|
|
18
18
|
"test": "ospec --globs 'build/**/*.test.js'"
|
|
19
19
|
},
|
|
20
20
|
"dependencies": {
|
|
21
|
-
"@chunkd/core": "^8.0
|
|
21
|
+
"@chunkd/core": "^8.1.0",
|
|
22
22
|
"ieee754": "^1.1.13"
|
|
23
23
|
},
|
|
24
24
|
"devDependencies": {
|
|
25
25
|
"@types/node": "^14.14.22",
|
|
26
|
-
"@types/ospec": "^4.0.
|
|
27
|
-
"ospec": "^4.0.0"
|
|
26
|
+
"@types/ospec": "^4.0.3"
|
|
28
27
|
},
|
|
29
28
|
"publishConfig": {
|
|
30
29
|
"access": "public"
|
|
31
30
|
},
|
|
32
|
-
"gitHead": "
|
|
31
|
+
"gitHead": "a2352ec8df0f0eb5f5dddacc0f3cdea855dceda3"
|
|
33
32
|
}
|
package/src/cog.tiff.image.ts
CHANGED
|
@@ -1,4 +1,3 @@
|
|
|
1
|
-
import { LogType } from '@chunkd/core';
|
|
2
1
|
import { CogTiff } from './cog.tiff.js';
|
|
3
2
|
import { TiffCompression, TiffMimeType } from './const/tiff.mime.js';
|
|
4
3
|
import { TiffTag, TiffTagGeo } from './const/tiff.tag.id.js';
|
|
@@ -56,27 +55,27 @@ export class CogTiffImage {
|
|
|
56
55
|
*
|
|
57
56
|
* @param loadGeoTags Whether to load the GeoKeyDirectory and unpack it
|
|
58
57
|
*/
|
|
59
|
-
async init(loadGeoTags = false
|
|
58
|
+
async init(loadGeoTags = false): Promise<void> {
|
|
60
59
|
const requiredTags = [
|
|
61
|
-
this.fetch(TiffTag.Compression
|
|
62
|
-
this.fetch(TiffTag.ImageHeight
|
|
63
|
-
this.fetch(TiffTag.ImageWidth
|
|
64
|
-
this.fetch(TiffTag.ModelPixelScale
|
|
65
|
-
this.fetch(TiffTag.ModelTiePoint
|
|
66
|
-
this.fetch(TiffTag.ModelTransformation
|
|
67
|
-
this.fetch(TiffTag.TileHeight
|
|
68
|
-
this.fetch(TiffTag.TileWidth
|
|
60
|
+
this.fetch(TiffTag.Compression),
|
|
61
|
+
this.fetch(TiffTag.ImageHeight),
|
|
62
|
+
this.fetch(TiffTag.ImageWidth),
|
|
63
|
+
this.fetch(TiffTag.ModelPixelScale),
|
|
64
|
+
this.fetch(TiffTag.ModelTiePoint),
|
|
65
|
+
this.fetch(TiffTag.ModelTransformation),
|
|
66
|
+
this.fetch(TiffTag.TileHeight),
|
|
67
|
+
this.fetch(TiffTag.TileWidth),
|
|
69
68
|
];
|
|
70
69
|
|
|
71
70
|
if (loadGeoTags) {
|
|
72
|
-
requiredTags.push(this.fetch(TiffTag.GeoKeyDirectory
|
|
73
|
-
requiredTags.push(this.fetch(TiffTag.GeoAsciiParams
|
|
74
|
-
requiredTags.push(this.fetch(TiffTag.GeoDoubleParams
|
|
71
|
+
requiredTags.push(this.fetch(TiffTag.GeoKeyDirectory));
|
|
72
|
+
requiredTags.push(this.fetch(TiffTag.GeoAsciiParams));
|
|
73
|
+
requiredTags.push(this.fetch(TiffTag.GeoDoubleParams));
|
|
75
74
|
}
|
|
76
75
|
|
|
77
76
|
await Promise.all(requiredTags);
|
|
78
77
|
if (loadGeoTags) {
|
|
79
|
-
await this.loadGeoTiffTags(
|
|
78
|
+
await this.loadGeoTiffTags();
|
|
80
79
|
}
|
|
81
80
|
}
|
|
82
81
|
|
|
@@ -92,7 +91,7 @@ export class CogTiffImage {
|
|
|
92
91
|
/**
|
|
93
92
|
* Load and unpack the GeoKeyDirectory
|
|
94
93
|
*/
|
|
95
|
-
async loadGeoTiffTags(
|
|
94
|
+
async loadGeoTiffTags(): Promise<void> {
|
|
96
95
|
// Already loaded
|
|
97
96
|
if (this.tagsGeoLoaded) return;
|
|
98
97
|
const sourceTag = this.tags.get(TiffTag.GeoKeyDirectory);
|
|
@@ -103,9 +102,9 @@ export class CogTiffImage {
|
|
|
103
102
|
if (!sourceTag.isReady && sourceTag instanceof CogTiffTagLazy) {
|
|
104
103
|
// Load all the required keys
|
|
105
104
|
await Promise.all([
|
|
106
|
-
this.fetch(TiffTag.GeoKeyDirectory
|
|
107
|
-
this.fetch(TiffTag.GeoAsciiParams
|
|
108
|
-
this.fetch(TiffTag.GeoDoubleParams
|
|
105
|
+
this.fetch(TiffTag.GeoKeyDirectory),
|
|
106
|
+
this.fetch(TiffTag.GeoAsciiParams),
|
|
107
|
+
this.fetch(TiffTag.GeoDoubleParams),
|
|
109
108
|
]);
|
|
110
109
|
}
|
|
111
110
|
this.tagsGeoLoaded = true;
|
|
@@ -145,10 +144,10 @@ export class CogTiffImage {
|
|
|
145
144
|
* Load a tag, if it is not currently loaded, fetch the required data for the tag.
|
|
146
145
|
* @param tag tag to fetch
|
|
147
146
|
*/
|
|
148
|
-
public async fetch<T>(tag: TiffTag
|
|
147
|
+
public async fetch<T>(tag: TiffTag): Promise<T | null> {
|
|
149
148
|
const sourceTag = this.tags.get(tag);
|
|
150
149
|
if (sourceTag == null) return null;
|
|
151
|
-
if (CogTiffTag.isLazy(sourceTag)) return sourceTag.fetch(
|
|
150
|
+
if (CogTiffTag.isLazy(sourceTag)) return sourceTag.fetch() as any;
|
|
152
151
|
return sourceTag.value as T;
|
|
153
152
|
}
|
|
154
153
|
|
|
@@ -342,14 +341,14 @@ export class CogTiffImage {
|
|
|
342
341
|
* @param index tile index
|
|
343
342
|
* @returns file offset of the specified tile
|
|
344
343
|
*/
|
|
345
|
-
protected async getTileOffset(index: number
|
|
344
|
+
protected async getTileOffset(index: number): Promise<number> {
|
|
346
345
|
const tileOffset = this.tileOffset;
|
|
347
346
|
if (index < 0 || index > tileOffset.dataCount) {
|
|
348
347
|
throw new Error(`Tile offset: ${index} out of range: 0 -> ${tileOffset.dataCount}`);
|
|
349
348
|
}
|
|
350
349
|
|
|
351
350
|
// Fetch only the part of the offsets that are needed
|
|
352
|
-
return tileOffset.getValueAt(index
|
|
351
|
+
return tileOffset.getValueAt(index);
|
|
353
352
|
}
|
|
354
353
|
|
|
355
354
|
// Clamp the bounds of the output image to the size of the image, as sometimes the edge tiles are not full tiles
|
|
@@ -398,13 +397,12 @@ export class CogTiffImage {
|
|
|
398
397
|
private async getBytes(
|
|
399
398
|
offset: number,
|
|
400
399
|
byteCount: number,
|
|
401
|
-
l?: LogType,
|
|
402
400
|
): Promise<{ mimeType: TiffMimeType; bytes: Uint8Array } | null> {
|
|
403
401
|
const mimeType = this.compression;
|
|
404
402
|
if (mimeType == null) throw new Error('Unsupported compression: ' + this.value(TiffTag.Compression));
|
|
405
403
|
if (byteCount === 0) return null;
|
|
406
404
|
|
|
407
|
-
await this.tif.source.loadBytes(offset, byteCount
|
|
405
|
+
await this.tif.source.loadBytes(offset, byteCount);
|
|
408
406
|
const bytes = this.tif.source.bytes(offset, byteCount);
|
|
409
407
|
|
|
410
408
|
if (this.compression === TiffMimeType.JPEG) {
|
|
@@ -421,7 +419,7 @@ export class CogTiffImage {
|
|
|
421
419
|
* @param x Tile x offset
|
|
422
420
|
* @param y Tile y offset
|
|
423
421
|
*/
|
|
424
|
-
async getTile(x: number, y: number
|
|
422
|
+
async getTile(x: number, y: number): Promise<{ mimeType: TiffMimeType; bytes: Uint8Array } | null> {
|
|
425
423
|
const mimeType = this.compression;
|
|
426
424
|
const size = this.size;
|
|
427
425
|
const tiles = this.tileSize;
|
|
@@ -441,22 +439,22 @@ export class CogTiffImage {
|
|
|
441
439
|
const totalTiles = nxTiles * nyTiles;
|
|
442
440
|
if (idx >= totalTiles) throw new Error(`Tile index is outside of tile range: ${idx} >= ${totalTiles}`);
|
|
443
441
|
|
|
444
|
-
const { offset, imageSize } = await this.getTileSize(idx
|
|
445
|
-
return this.getBytes(offset, imageSize
|
|
442
|
+
const { offset, imageSize } = await this.getTileSize(idx);
|
|
443
|
+
return this.getBytes(offset, imageSize);
|
|
446
444
|
}
|
|
447
445
|
|
|
448
|
-
protected async getTileSize(index: number
|
|
446
|
+
protected async getTileSize(index: number): Promise<{ offset: number; imageSize: number }> {
|
|
449
447
|
// GDAL optimizes tiles by storing the size of the tile in
|
|
450
448
|
// the few bytes leading up to the tile
|
|
451
449
|
if (this.tif.options.tileLeaderByteSize) {
|
|
452
|
-
const offset = await this.getTileOffset(index
|
|
450
|
+
const offset = await this.getTileOffset(index);
|
|
453
451
|
// Sparse COG no data found
|
|
454
452
|
if (offset === 0) return { offset: 0, imageSize: 0 };
|
|
455
453
|
|
|
456
454
|
const leaderBytes = this.tif.options.tileLeaderByteSize;
|
|
457
455
|
// This fetch will generally load in the bytes needed for the image too
|
|
458
456
|
// provided the image size is less than the size of a chunk
|
|
459
|
-
await this.tif.source.loadBytes(offset - leaderBytes, leaderBytes
|
|
457
|
+
await this.tif.source.loadBytes(offset - leaderBytes, leaderBytes);
|
|
460
458
|
return { offset, imageSize: this.tif.source.getUint(offset - leaderBytes, leaderBytes) };
|
|
461
459
|
}
|
|
462
460
|
|
|
@@ -464,7 +462,7 @@ export class CogTiffImage {
|
|
|
464
462
|
if (byteCounts == null) {
|
|
465
463
|
throw new Error('No tile byte counts found');
|
|
466
464
|
}
|
|
467
|
-
const [offset, imageSize] = await Promise.all([this.getTileOffset(index
|
|
465
|
+
const [offset, imageSize] = await Promise.all([this.getTileOffset(index), byteCounts.getValueAt(index)]);
|
|
468
466
|
return { offset, imageSize };
|
|
469
467
|
}
|
|
470
468
|
}
|
package/src/cog.tiff.ts
CHANGED
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import { ChunkSource
|
|
1
|
+
import { ChunkSource } from '@chunkd/core';
|
|
2
2
|
import { CogTiffImage } from './cog.tiff.image.js';
|
|
3
3
|
import { TiffEndian } from './const/tiff.endian.js';
|
|
4
4
|
import { TiffTag } from './const/tiff.tag.id.js';
|
|
@@ -38,24 +38,24 @@ export class CogTiff {
|
|
|
38
38
|
*
|
|
39
39
|
* @param loadGeoKeys Whether to also initialize the GeoKeyDirectory
|
|
40
40
|
*/
|
|
41
|
-
init(loadGeoKeys = false
|
|
41
|
+
init(loadGeoKeys = false): Promise<CogTiff> {
|
|
42
42
|
if (this._initPromise) return this._initPromise;
|
|
43
|
-
this._initPromise = this.doInit(loadGeoKeys
|
|
43
|
+
this._initPromise = this.doInit(loadGeoKeys);
|
|
44
44
|
return this._initPromise;
|
|
45
45
|
}
|
|
46
46
|
|
|
47
|
-
private async doInit(loadGeoKeys = false
|
|
47
|
+
private async doInit(loadGeoKeys = false): Promise<CogTiff> {
|
|
48
48
|
if (this.isInitialized) return this;
|
|
49
49
|
// Load the first few KB in, more loads will run as more data is required
|
|
50
|
-
await this.source.loadBytes(0, this.source.chunkSize
|
|
51
|
-
await this.fetchIfd(
|
|
52
|
-
await Promise.all(this.images.map((c) => c.init(loadGeoKeys
|
|
50
|
+
await this.source.loadBytes(0, this.source.chunkSize);
|
|
51
|
+
await this.fetchIfd();
|
|
52
|
+
await Promise.all(this.images.map((c) => c.init(loadGeoKeys)));
|
|
53
53
|
|
|
54
54
|
this.isInitialized = true;
|
|
55
55
|
return this;
|
|
56
56
|
}
|
|
57
57
|
|
|
58
|
-
private async fetchIfd(
|
|
58
|
+
private async fetchIfd(): Promise<void> {
|
|
59
59
|
const view = this.cursor.seekTo(0);
|
|
60
60
|
const endian = view.uint16();
|
|
61
61
|
this.source.isLittleEndian = endian === TiffEndian.Little;
|
|
@@ -79,14 +79,14 @@ export class CogTiff {
|
|
|
79
79
|
const ghostSize = nextOffsetIfd - this.cursor.currentOffset;
|
|
80
80
|
// GDAL now stores metadata between the IFD inside a ghost storage area
|
|
81
81
|
if (ghostSize > 0 && ghostSize < 16 * 1024) {
|
|
82
|
-
logger?.debug(
|
|
83
|
-
|
|
84
|
-
|
|
85
|
-
);
|
|
82
|
+
// logger?.debug(
|
|
83
|
+
// { offset: toHexString(this.cursor.currentOffset), length: toHexString(ghostSize) },
|
|
84
|
+
// 'GhostOptions',
|
|
85
|
+
// );
|
|
86
86
|
// this.options.process(this.source, view.currentOffset, ghostSize);
|
|
87
87
|
}
|
|
88
88
|
|
|
89
|
-
return this.processIfd(nextOffsetIfd
|
|
89
|
+
return this.processIfd(nextOffsetIfd);
|
|
90
90
|
}
|
|
91
91
|
|
|
92
92
|
getImage(z: number): CogTiffImage {
|
|
@@ -135,38 +135,20 @@ export class CogTiff {
|
|
|
135
135
|
return image.getTile(x, y);
|
|
136
136
|
}
|
|
137
137
|
|
|
138
|
-
private async processIfd(offset: number
|
|
139
|
-
|
|
138
|
+
private async processIfd(offset: number): Promise<void> {
|
|
139
|
+
if (!this.source.hasBytes(offset, 4096)) await this.source.loadBytes(offset, 4096);
|
|
140
140
|
|
|
141
|
-
|
|
142
|
-
await this.source.loadBytes(offset, 4096, logger);
|
|
143
|
-
}
|
|
144
|
-
|
|
145
|
-
const { image, nextOffset } = await this.readIfd(offset, logger);
|
|
141
|
+
const { image, nextOffset } = await this.readIfd(offset);
|
|
146
142
|
this.images.push(image);
|
|
147
|
-
const size = image.size;
|
|
148
|
-
if (image.isTiled()) {
|
|
149
|
-
const tile = image.tileSize;
|
|
150
|
-
logger?.debug(
|
|
151
|
-
{
|
|
152
|
-
...size,
|
|
153
|
-
tileWidth: tile.width,
|
|
154
|
-
tileHeight: tile.height,
|
|
155
|
-
tileCount: Math.ceil(size.width / tile.width),
|
|
156
|
-
},
|
|
157
|
-
'GotImage',
|
|
158
|
-
);
|
|
159
|
-
}
|
|
160
143
|
|
|
161
|
-
if (nextOffset) await this.processIfd(nextOffset
|
|
144
|
+
if (nextOffset) await this.processIfd(nextOffset);
|
|
162
145
|
}
|
|
163
146
|
|
|
164
|
-
private async readIfd(offset: number
|
|
165
|
-
if (!this.source.hasBytes(offset, 1024)) await this.source.loadBytes(offset, this.source.chunkSize
|
|
147
|
+
private async readIfd(offset: number): Promise<{ nextOffset: number; image: CogTiffImage }> {
|
|
148
|
+
if (!this.source.hasBytes(offset, 1024)) await this.source.loadBytes(offset, this.source.chunkSize);
|
|
166
149
|
const view = this.cursor.seekTo(offset);
|
|
167
150
|
const tagCount = view.offset();
|
|
168
151
|
const byteStart = offset + this.ifdConfig.offset;
|
|
169
|
-
const logger = log?.child({ imageId: this.images.length });
|
|
170
152
|
const tags: Map<TiffTag, CogTiffTagBase> = new Map();
|
|
171
153
|
|
|
172
154
|
let pos = byteStart;
|
|
@@ -174,33 +156,7 @@ export class CogTiff {
|
|
|
174
156
|
const tag = CogTiffTag.create(this, pos);
|
|
175
157
|
pos += tag.size;
|
|
176
158
|
|
|
177
|
-
if (tag.name == null)
|
|
178
|
-
logger?.error({ code: toHexString(tag.id) }, `IFDUnknown`);
|
|
179
|
-
continue;
|
|
180
|
-
}
|
|
181
|
-
|
|
182
|
-
if (!tag.isReady) {
|
|
183
|
-
logger?.trace(
|
|
184
|
-
{
|
|
185
|
-
offset: toHexString(pos - offset),
|
|
186
|
-
code: toHexString(tag.id),
|
|
187
|
-
tagName: tag.name,
|
|
188
|
-
ptr: toHexString(tag.valuePointer),
|
|
189
|
-
},
|
|
190
|
-
'PartialReadIFD',
|
|
191
|
-
);
|
|
192
|
-
} else {
|
|
193
|
-
logger?.trace(
|
|
194
|
-
{
|
|
195
|
-
offset: toHexString(pos - offset),
|
|
196
|
-
code: toHexString(tag.id),
|
|
197
|
-
tagName: tag.name,
|
|
198
|
-
value: Array.isArray(tag.value) ? `[${tag.value.length}]` : tag.value,
|
|
199
|
-
},
|
|
200
|
-
'ReadIFD',
|
|
201
|
-
);
|
|
202
|
-
}
|
|
203
|
-
|
|
159
|
+
if (tag.name == null) throw new Error('Unknown IFD Tag: ' + toHexString(tag.id));
|
|
204
160
|
tags.set(tag.id, tag);
|
|
205
161
|
}
|
|
206
162
|
|
|
@@ -10,7 +10,7 @@ o.spec('TiffTag', () => {
|
|
|
10
10
|
const cogSourceFile = new TestFileChunkSource(path.join(dirName, '../../../../../data/rgba8_tiled.tiff'));
|
|
11
11
|
|
|
12
12
|
o.beforeEach(() => {
|
|
13
|
-
cogSourceFile.chunks.clear();
|
|
13
|
+
(cogSourceFile.chunks as Map<unknown, unknown>).clear();
|
|
14
14
|
});
|
|
15
15
|
|
|
16
16
|
o('should load lazy tags', async () => {
|
|
@@ -1,4 +1,3 @@
|
|
|
1
|
-
import { LogType } from '@chunkd/core';
|
|
2
1
|
import { CogTiffTagBase } from './tiff.tag.base.js';
|
|
3
2
|
|
|
4
3
|
export class CogTiffTagLazy<T> extends CogTiffTagBase<T> {
|
|
@@ -8,9 +7,9 @@ export class CogTiffTagLazy<T> extends CogTiffTagBase<T> {
|
|
|
8
7
|
return this.value != null;
|
|
9
8
|
}
|
|
10
9
|
|
|
11
|
-
async fetch(
|
|
10
|
+
async fetch(): Promise<T> {
|
|
12
11
|
if (this.tiff.source.hasBytes(this.valuePointer, this.dataLength) === false) {
|
|
13
|
-
await this.tiff.source.loadBytes(this.valuePointer, this.dataLength
|
|
12
|
+
await this.tiff.source.loadBytes(this.valuePointer, this.dataLength);
|
|
14
13
|
}
|
|
15
14
|
this.value = this.readValue();
|
|
16
15
|
return this.value;
|
|
@@ -1,4 +1,3 @@
|
|
|
1
|
-
import { LogType } from '@chunkd/core';
|
|
2
1
|
import { CogTiff } from '../../cog.tiff.js';
|
|
3
2
|
import { getTiffTagValueReader } from '../tiff.value.reader.js';
|
|
4
3
|
import { CogTiffTagBase } from './tiff.tag.base.js';
|
|
@@ -27,8 +26,8 @@ export class CogTiffTagOffset extends CogTiffTagBase<number[]> {
|
|
|
27
26
|
}
|
|
28
27
|
|
|
29
28
|
/** Load the entire index into memory */
|
|
30
|
-
async load(
|
|
31
|
-
await this.tiff.source.loadBytes(this.valuePointer, this.dataLength
|
|
29
|
+
async load(): Promise<void> {
|
|
30
|
+
await this.tiff.source.loadBytes(this.valuePointer, this.dataLength);
|
|
32
31
|
this.readValue();
|
|
33
32
|
}
|
|
34
33
|
|
|
@@ -47,7 +46,7 @@ export class CogTiffTagOffset extends CogTiffTagBase<number[]> {
|
|
|
47
46
|
* Read a specific value from the offset array
|
|
48
47
|
* @param index index to read at
|
|
49
48
|
*/
|
|
50
|
-
async getValueAt(index: number
|
|
49
|
+
async getValueAt(index: number): Promise<number> {
|
|
51
50
|
if (this.loadedValues) return this.loadedValues[index];
|
|
52
51
|
|
|
53
52
|
const dataSize = this.dataTypeSize;
|
|
@@ -55,7 +54,7 @@ export class CogTiffTagOffset extends CogTiffTagBase<number[]> {
|
|
|
55
54
|
const convert = getTiffTagValueReader(this.dataType);
|
|
56
55
|
|
|
57
56
|
if (!this.tiff.source.hasBytes(valueOffset, dataSize)) {
|
|
58
|
-
await this.tiff.source.loadBytes(valueOffset, dataSize
|
|
57
|
+
await this.tiff.source.loadBytes(valueOffset, dataSize);
|
|
59
58
|
}
|
|
60
59
|
return convert(this.tiff.source, valueOffset) as number;
|
|
61
60
|
}
|