mirror of
https://github.com/GoogleChromeLabs/squoosh.git
synced 2025-11-11 16:26:20 +00:00
Integrate rotate
This commit is contained in:
Binary file not shown.
@@ -29,13 +29,8 @@ async function demo() {
|
|||||||
const ctx = canvas.getContext('2d')!;
|
const ctx = canvas.getContext('2d')!;
|
||||||
ctx.drawImage(img, 0, 0);
|
ctx.drawImage(img, 0, 0);
|
||||||
const data = ctx.getImageData(0, 0, img.width, img.height);
|
const data = ctx.getImageData(0, 0, img.width, img.height);
|
||||||
const result = await api.resize(data, {
|
const result = await api.rotate(data, {
|
||||||
fitMethod: 'stretch',
|
rotate: 180,
|
||||||
height: 200,
|
|
||||||
width: 200,
|
|
||||||
linearRGB: false,
|
|
||||||
premultiply: true,
|
|
||||||
method: 'lanczos3',
|
|
||||||
});
|
});
|
||||||
|
|
||||||
{
|
{
|
||||||
|
|||||||
13
src/features/preprocessors/rotate/worker/missing-types.d.ts
vendored
Normal file
13
src/features/preprocessors/rotate/worker/missing-types.d.ts
vendored
Normal file
@@ -0,0 +1,13 @@
|
|||||||
|
/**
|
||||||
|
* Copyright 2020 Google Inc. All Rights Reserved.
|
||||||
|
* Licensed under the Apache License, Version 2.0 (the "License");
|
||||||
|
* you may not use this file except in compliance with the License.
|
||||||
|
* You may obtain a copy of the License at
|
||||||
|
* http://www.apache.org/licenses/LICENSE-2.0
|
||||||
|
* Unless required by applicable law or agreed to in writing, software
|
||||||
|
* distributed under the License is distributed on an "AS IS" BASIS,
|
||||||
|
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||||
|
* See the License for the specific language governing permissions and
|
||||||
|
* limitations under the License.
|
||||||
|
*/
|
||||||
|
/// <reference path="../../../../../missing-types.d.ts" />
|
||||||
63
src/features/preprocessors/rotate/worker/rotate.ts
Normal file
63
src/features/preprocessors/rotate/worker/rotate.ts
Normal file
@@ -0,0 +1,63 @@
|
|||||||
|
/**
|
||||||
|
* Copyright 2020 Google Inc. All Rights Reserved.
|
||||||
|
* Licensed under the Apache License, Version 2.0 (the "License");
|
||||||
|
* you may not use this file except in compliance with the License.
|
||||||
|
* You may obtain a copy of the License at
|
||||||
|
* http://www.apache.org/licenses/LICENSE-2.0
|
||||||
|
* Unless required by applicable law or agreed to in writing, software
|
||||||
|
* distributed under the License is distributed on an "AS IS" BASIS,
|
||||||
|
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||||
|
* See the License for the specific language governing permissions and
|
||||||
|
* limitations under the License.
|
||||||
|
*/
|
||||||
|
import wasmUrl from 'url:codecs/rotate/rotate.wasm';
|
||||||
|
|
||||||
|
export interface RotateOptions {
|
||||||
|
rotate: 0 | 90 | 180 | 270;
|
||||||
|
}
|
||||||
|
|
||||||
|
export interface RotateModuleInstance {
|
||||||
|
exports: {
|
||||||
|
memory: WebAssembly.Memory;
|
||||||
|
rotate(width: number, height: number, rotate: 0 | 90 | 180 | 270): void;
|
||||||
|
};
|
||||||
|
}
|
||||||
|
|
||||||
|
// We are loading a 500B module here. Loading the code to feature-detect
|
||||||
|
// `instantiateStreaming` probably takes longer to load than the time we save by
|
||||||
|
// using `instantiateStreaming` in the first place. So let’s just use
|
||||||
|
// `ArrayBuffer`s here.
|
||||||
|
const instancePromise = fetch(wasmUrl)
|
||||||
|
.then((r) => r.arrayBuffer())
|
||||||
|
.then((buf) => WebAssembly.instantiate(buf));
|
||||||
|
|
||||||
|
export default async function rotate(
|
||||||
|
data: ImageData,
|
||||||
|
opts: RotateOptions,
|
||||||
|
): Promise<ImageData> {
|
||||||
|
const instance = (await instancePromise).instance as RotateModuleInstance;
|
||||||
|
|
||||||
|
// Number of wasm memory pages (á 64KiB) needed to store the image twice.
|
||||||
|
const bytesPerImage = data.width * data.height * 4;
|
||||||
|
const numPagesNeeded = Math.ceil((bytesPerImage * 2 + 8) / (64 * 1024));
|
||||||
|
// Only count full pages, just to be safe.
|
||||||
|
const numPagesAvailable = Math.floor(
|
||||||
|
instance.exports.memory.buffer.byteLength / (64 * 1024),
|
||||||
|
);
|
||||||
|
const additionalPagesToAllocate = numPagesNeeded - numPagesAvailable;
|
||||||
|
|
||||||
|
if (additionalPagesToAllocate > 0) {
|
||||||
|
instance.exports.memory.grow(additionalPagesToAllocate);
|
||||||
|
}
|
||||||
|
const view = new Uint8ClampedArray(instance.exports.memory.buffer);
|
||||||
|
view.set(data.data, 8);
|
||||||
|
|
||||||
|
instance.exports.rotate(data.width, data.height, opts.rotate);
|
||||||
|
|
||||||
|
const flipDimensions = opts.rotate % 180 !== 0;
|
||||||
|
return new ImageData(
|
||||||
|
view.slice(bytesPerImage + 8, bytesPerImage * 2 + 8),
|
||||||
|
flipDimensions ? data.height : data.width,
|
||||||
|
flipDimensions ? data.width : data.height,
|
||||||
|
);
|
||||||
|
}
|
||||||
7
src/features/preprocessors/rotate/worker/tsconfig.json
Normal file
7
src/features/preprocessors/rotate/worker/tsconfig.json
Normal file
@@ -0,0 +1,7 @@
|
|||||||
|
{
|
||||||
|
"extends": "../../../../../generic-tsconfig.json",
|
||||||
|
"compilerOptions": {
|
||||||
|
"lib": ["webworker", "esnext"]
|
||||||
|
},
|
||||||
|
"references": [{ "path": "../../../" }]
|
||||||
|
}
|
||||||
Reference in New Issue
Block a user