geotiff
Version:
GeoTIFF image decoding in JavaScript
79 lines • 3.26 kB
TypeScript
export default Pool;
/**
* Pool for workers to decode chunks of the images.
*/
declare class Pool {
/**
* @constructor
* @param {Number} [size] The size of the pool. Defaults to the number of CPUs
* available. When this parameter is `null` or 0, then the
* decoding will be done in the main thread.
* @param {function(): Worker} [createWorker] A function that creates the decoder worker.
* Defaults to a worker with all decoders that ship with geotiff.js. The `createWorker()`
* function is expected to return a `Worker` compatible with Web Workers. For code that
* runs in Node, [web-worker](https://www.npmjs.com/package/web-worker) is a good choice.
*
* A worker that uses a custom lzw decoder would look like this `my-custom-worker.js` file:
* ```js
* import { addDecoder, getDecoder } from 'geotiff';
* addDecoder(5, () => import ('./my-custom-lzw').then((m) => m.default));
* self.addEventListener('message', async (e) => {
* const { id, fileDirectory, buffer } = e.data;
* const decoder = await getDecoder(fileDirectory);
* const decoded = await decoder.decode(fileDirectory, buffer);
* self.postMessage({ decoded, id }, [decoded]);
* });
* ```
* The way the above code is built into a worker by the `createWorker()` function
* depends on the used bundler. For most bundlers, something like this will work:
* ```js
* function createWorker() {
* return new Worker(new URL('./my-custom-worker.js', import.meta.url));
* }
* ```
*/
constructor(size?: number | undefined, createWorker?: (() => Worker) | undefined);
workerWrappers: Promise<WorkerWrapper[]> | null;
/**
* Decode the given block of bytes with the set compression method.
* @param {ArrayBuffer} buffer the array buffer of bytes to decode.
* @returns {Promise<ArrayBuffer>} the decoded result as a `Promise`
*/
decode(fileDirectory: any, buffer: ArrayBuffer): Promise<ArrayBuffer>;
destroy(): Promise<void>;
}
/**
* @module pool
*/
/**
* Wrapper for a worker that can submit jobs to the worker and receive responses.
*/
declare class WorkerWrapper {
/**
* @param {Worker} worker the worker to wrap
*/
constructor(worker: Worker);
worker: Worker;
jobIdCounter: number;
jobs: Map<any, any>;
/**
* Get a new job id
* @returns {Number} the new job id
*/
newJobId(): number;
/**
* Get the number of jobs currently running
* @returns {Number} the number of jobs currently running
*/
getJobCount(): number;
_onWorkerMessage(e: any): void;
/**
* Submit a job to the worker
* @param {Object} message the message to send to the worker. A "jobId" property will be added to this object.
* @param {Object[]} [transferables] an optional array of transferable objects to transfer to the worker.
* @returns {Promise} a promise that gets resolved/rejected when a message with the same jobId is received from the worker.
*/
submitJob(message: any, transferables?: any[] | undefined): Promise<any>;
terminate(): void;
}
//# sourceMappingURL=pool.d.ts.map