mrmBot-Matrix/natives/invert.cc

28 lines
859 B
C++
Raw Normal View History

2022-02-27 21:37:51 +00:00
#include <vips/vips8>
#include "common.h"
using namespace std;
2022-02-27 21:37:51 +00:00
using namespace vips;
2023-03-09 01:36:39 +00:00
char *Invert(string type, string *outType, char *BufferData,
size_t BufferLength, [[maybe_unused]] ArgumentMap Arguments,
size_t *DataSize) {
2022-12-26 06:28:56 +00:00
VOption *options = VImage::option()->set("access", "sequential");
2022-12-26 06:28:56 +00:00
VImage in =
VImage::new_from_buffer(BufferData, BufferLength, "",
2023-03-09 01:36:39 +00:00
type == "gif" ? options->set("n", -1) : options)
2022-12-26 06:28:56 +00:00
.colourspace(VIPS_INTERPRETATION_sRGB);
if (!in.has_alpha()) in = in.bandjoin(255);
2022-12-26 06:28:56 +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-12-26 06:28:56 +00:00
void *buf;
2023-03-09 01:36:39 +00:00
out.write_to_buffer(("." + *outType).c_str(), &buf, DataSize);
2022-06-28 03:50:53 +00:00
2022-12-26 06:28:56 +00:00
return (char *)buf;
}