mrmBot-Matrix/natives/invert.cc

44 lines
1.3 KiB
C++
Raw Normal View History

#include <napi.h>
2022-02-27 21:37:51 +00:00
#include <vips/vips8>
using namespace std;
2022-02-27 21:37:51 +00:00
using namespace vips;
Napi::Value Invert(const Napi::CallbackInfo &info) {
Napi::Env env = info.Env();
try {
Napi::Object obj = info[0].As<Napi::Object>();
Napi::Buffer<char> data = obj.Get("data").As<Napi::Buffer<char>>();
string type = obj.Get("type").As<Napi::String>().Utf8Value();
2022-02-27 21:37:51 +00:00
VOption *options = VImage::option()->set("access", "sequential");
2022-02-27 21:37:51 +00:00
VImage in =
VImage::new_from_buffer(data.Data(), data.Length(), "",
type == "gif" ? options->set("n", -1) : options)
.colourspace(VIPS_INTERPRETATION_sRGB);
if (!in.has_alpha()) in = in.bandjoin(255);
2022-02-27 21:37:51 +00:00
VImage noAlpha =
in.extract_band(0, VImage::option()->set("n", in.bands() - 1));
VImage inverted = noAlpha.invert();
VImage out = inverted.bandjoin(in.extract_band(3));
2022-02-27 21:37:51 +00:00
void *buf;
size_t length;
out.write_to_buffer(("." + type).c_str(), &buf, &length);
2022-02-27 21:37:51 +00:00
vips_thread_shutdown();
Napi::Object result = Napi::Object::New(env);
2022-02-27 21:37:51 +00:00
result.Set("data", Napi::Buffer<char>::Copy(env, (char *)buf, length));
result.Set("type", type);
return result;
} catch (std::exception const &err) {
throw Napi::Error::New(env, err.what());
} catch (...) {
throw Napi::Error::New(env, "Unknown error");
}
}