#include #include #include #include "basisu_comp.h" #include "basisu_enc.h" using namespace emscripten; using namespace basisu; struct BasisOptions { uint8_t quality; uint8_t compression; bool uastc; bool mipmap; }; thread_local const val Uint8Array = val::global("Uint8Array"); val encode(std::string image_in, int image_width, int image_height, BasisOptions opts) { basisu_encoder_init(); basis_compressor_params params; basis_compressor compressor; image img = image(reinterpret_cast(image_in.c_str()), image_width, image_height, 4); // We don’t need the encoder to read/decode files from the filesystem params.m_read_source_images = false; // Writing is unnecessary, too params.m_read_source_images = false; // No printf pls params.m_status_output = false; // True => UASTC, False => ETC1S params.m_uastc = opts.uastc; params.m_mip_gen = opts.mipmap; params.m_quality_level = opts.quality; params.m_compression_level = opts.compression; params.m_source_images.push_back(img); if (!compressor.init(params)) { return val(std::string("Well something went wrong during init")); } if (compressor.process() != 0) { return val(std::string("Well something went wrong during processing")); } auto comp_data = compressor.get_output_basis_file(); auto js_result = Uint8Array.new_(typed_memory_view(comp_data.size(), &comp_data[0])); // Not sure if there is anything to free here return js_result; } EMSCRIPTEN_BINDINGS(my_module) { value_object("BasisOptions") .field("quality", &BasisOptions::quality) .field("compression", &BasisOptions::compression) .field("uastc", &BasisOptions::uastc) .field("mipmap", &BasisOptions::mipmap); function("encode", &encode); }