mirror of
https://github.com/GoogleChromeLabs/squoosh.git
synced 2025-11-13 01:07:18 +00:00
Update for encoder API changes
This commit is contained in:
File diff suppressed because it is too large
Load Diff
Binary file not shown.
@@ -5,46 +5,53 @@
|
|||||||
|
|
||||||
using namespace emscripten;
|
using namespace emscripten;
|
||||||
|
|
||||||
|
thread_local const val Uint8Array = val::global("Uint8Array");
|
||||||
|
|
||||||
struct JXLOptions {
|
struct JXLOptions {
|
||||||
// 1 = slowest
|
// 1 = slowest
|
||||||
// 7 = fastest
|
// 7 = fastest
|
||||||
int speed;
|
int speed;
|
||||||
};
|
};
|
||||||
|
|
||||||
uint8_t *result;
|
|
||||||
val encode(std::string image, int width, int height, JXLOptions options) {
|
val encode(std::string image, int width, int height, JXLOptions options) {
|
||||||
jxl::CompressParams cparams;
|
jxl::CompressParams cparams;
|
||||||
jxl::PassesEncoderState passes_enc_state;
|
jxl::PassesEncoderState passes_enc_state;
|
||||||
jxl::CodecInOut io;
|
jxl::CodecInOut io;
|
||||||
jxl::PaddedBytes bytes;
|
jxl::PaddedBytes bytes;
|
||||||
jxl::ImageBundle *main = &io.Main();
|
jxl::ImageBundle* main = &io.Main();
|
||||||
|
|
||||||
cparams.speed_tier = static_cast<jxl::SpeedTier>(options.speed);
|
cparams.speed_tier = static_cast<jxl::SpeedTier>(options.speed);
|
||||||
cparams.color_transform = jxl::ColorTransform::kNone;
|
cparams.color_transform = jxl::ColorTransform::kNone;
|
||||||
|
|
||||||
uint8_t *inBuffer = (uint8_t *)image.c_str();
|
io.metadata.SetUintSamples(8);
|
||||||
|
io.metadata.SetAlphaBits(8);
|
||||||
|
|
||||||
auto result = main->SetFromSRGB(
|
uint8_t* inBuffer = (uint8_t*)image.c_str();
|
||||||
width, height, false, true, true, (uint8_t *)image.c_str(),
|
|
||||||
(uint8_t *)image.c_str() + width * height * 4);
|
auto result =
|
||||||
|
main->SetFromSRGB(width, height, /*is_gray*/ false, /*has_alpha*/ true,
|
||||||
|
/*alpha_is_premultiplied*/ true, /*pixels*/ (uint8_t*)image.c_str(),
|
||||||
|
/* end */ (uint8_t*)image.c_str() + width * height * 4);
|
||||||
|
|
||||||
if (!result) {
|
if (!result) {
|
||||||
return val::null();
|
return val::null();
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!EncodeFile(cparams, &io, &passes_enc_state, &bytes)) {
|
auto js_result = val::null();
|
||||||
return val::null();
|
if (EncodeFile(cparams, &io, &passes_enc_state, &bytes)) {
|
||||||
|
js_result = Uint8Array.new_(typed_memory_view(bytes.size(), bytes.data()));
|
||||||
}
|
}
|
||||||
|
|
||||||
return val(typed_memory_view(bytes.size(), bytes.data()));
|
// TODO: Any freeing that needs to be done?
|
||||||
|
//
|
||||||
|
return js_result;
|
||||||
}
|
}
|
||||||
|
|
||||||
void free_result() { delete result; }
|
void free_result() {
|
||||||
|
}
|
||||||
|
|
||||||
EMSCRIPTEN_BINDINGS(my_module) {
|
EMSCRIPTEN_BINDINGS(my_module) {
|
||||||
value_object<JXLOptions>("JXLOptions")
|
value_object<JXLOptions>("JXLOptions").field("speed", &JXLOptions::speed);
|
||||||
.field("speed", &JXLOptions::speed);
|
|
||||||
|
|
||||||
function("encode", &encode);
|
function("encode", &encode);
|
||||||
function("free_result", &free_result);
|
|
||||||
}
|
}
|
||||||
|
|||||||
1
codecs/jxl/enc/jxl_enc.d.ts
vendored
1
codecs/jxl/enc/jxl_enc.d.ts
vendored
@@ -2,7 +2,6 @@ import { EncodeOptions } from '../../src/codecs/jxl/encoder-meta';
|
|||||||
|
|
||||||
interface JXLModule extends EmscriptenWasm.Module {
|
interface JXLModule extends EmscriptenWasm.Module {
|
||||||
encode(data: BufferSource, width: number, height: number, options: EncodeOptions): Uint8Array;
|
encode(data: BufferSource, width: number, height: number, options: EncodeOptions): Uint8Array;
|
||||||
free_result(): void;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|||||||
File diff suppressed because it is too large
Load Diff
Binary file not shown.
@@ -11,8 +11,6 @@ export async function encode(data: ImageData, options: EncodeOptions): Promise<A
|
|||||||
const module = await emscriptenModule;
|
const module = await emscriptenModule;
|
||||||
console.log(options);
|
console.log(options);
|
||||||
const resultView = module.encode(data.data, data.width, data.height, options);
|
const resultView = module.encode(data.data, data.width, data.height, options);
|
||||||
const result = new Uint8Array(resultView);
|
|
||||||
module.free_result();
|
|
||||||
|
|
||||||
// wasm can’t run on SharedArrayBuffers, so we hard-cast to ArrayBuffer.
|
// wasm can’t run on SharedArrayBuffers, so we hard-cast to ArrayBuffer.
|
||||||
return result.buffer as ArrayBuffer;
|
return result.buffer as ArrayBuffer;
|
||||||
|
|||||||
Reference in New Issue
Block a user