mrmBot-Matrix/natives/blur.cc

46 lines
1.4 KiB
C++
Raw Normal View History

#include <napi.h>
2022-02-23 01:43:22 +00:00
#include <vips/vips8>
using namespace std;
2022-02-23 01:43:22 +00:00
using namespace vips;
Napi::Value Blur(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>>();
bool sharp = obj.Get("sharp").As<Napi::Boolean>().Value();
string type = obj.Get("type").As<Napi::String>().Utf8Value();
2022-02-23 01:43:22 +00:00
VOption *options = VImage::option()->set("access", "sequential");
2022-02-23 01:43:22 +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-23 01:43:22 +00:00
// TODO: find a better way to calculate the intensity for GIFs without
// splitting frames
VImage out = sharp ? in.sharpen(VImage::option()->set("sigma", 3))
: in.gaussblur(15);
2022-02-23 01:43:22 +00:00
void *buf;
size_t length;
out.write_to_buffer(("." + type).c_str(), &buf, &length);
2022-02-23 01:43:22 +00:00
vips_thread_shutdown();
Napi::Object result = Napi::Object::New(env);
2022-02-23 01:43:22 +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");
}
}