From 4674ec0e4b833ab0d0365225ba99228df14abe87 Mon Sep 17 00:00:00 2001 From: Mattias Andrée Date: Fri, 13 Jan 2017 09:05:08 +0100 Subject: Rename to blind MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Signed-off-by: Mattias Andrée --- src/blind-set-alpha.c | 69 +++++++++++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 69 insertions(+) create mode 100644 src/blind-set-alpha.c (limited to 'src/blind-set-alpha.c') diff --git a/src/blind-set-alpha.c b/src/blind-set-alpha.c new file mode 100644 index 0000000..2e80154 --- /dev/null +++ b/src/blind-set-alpha.c @@ -0,0 +1,69 @@ +/* See LICENSE file for copyright and license details. */ +#include "stream.h" +#include "util.h" + +#include +#include +#include +#include + +USAGE("[-i] alpha-stream") + +static void +process_xyza(struct stream *colour, struct stream *alpha, size_t n) +{ + size_t i; + double a; + for (i = 0; i < n; i += colour->pixel_size) { + a = ((double *)(alpha->buf + i))[1]; + a *= ((double *)(alpha->buf + i))[3]; + ((double *)(colour->buf + i))[3] *= a; + } +} + +static void +process_xyza_i(struct stream *colour, struct stream *alpha, size_t n) +{ + size_t i; + double a; + for (i = 0; i < n; i += colour->pixel_size) { + a = 1 - ((double *)(alpha->buf + i))[1]; + a *= ((double *)(alpha->buf + i))[3]; + ((double *)(colour->buf + i))[3] *= a; + } +} + +int +main(int argc, char *argv[]) +{ + int invert = 0; + struct stream colour, alpha; + void (*process)(struct stream *colour, struct stream *alpha, size_t n) = NULL; + + ARGBEGIN { + case 'i': + invert = 1; + break; + default: + usage(); + } ARGEND; + + if (argc != 1) + usage(); + + colour.file = ""; + colour.fd = STDIN_FILENO; + einit_stream(&colour); + + alpha.file = argv[0]; + alpha.fd = eopen(alpha.file, O_RDONLY); + einit_stream(&alpha); + + if (!strcmp(colour.pixfmt, "xyza")) + process = invert ? process_xyza_i : process_xyza; + else + eprintf("pixel format %s is not supported, try xyza\n", colour.pixfmt); + + process_two_streams(&colour, &alpha, STDOUT_FILENO, "", process); + return 0; +} -- cgit v1.2.3-70-g09d2