aboutsummaryrefslogtreecommitdiffstats
path: root/src/blind-dissolve.c
blob: b78121e6fca8af16161c32b195f58904e72d1065 (plain) (blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
/* See LICENSE file for copyright and license details. */
#include "common.h"

USAGE("[-r]")

static size_t fm;
static double fm_double;
static float fm_float;
static int reverse = 0;

#define PROCESS(TYPE)\
	do {\
		size_t i = stream->alpha_chan * stream->chan_size;\
		TYPE a = fm ? (TYPE)(reverse ? f : fm - f) / fm_##TYPE : (TYPE)0.5;\
		for (; i < n; i += stream->pixel_size)\
			*(TYPE *)(stream->buf + i) *= a;\
	} while (0)

static void process_lf(struct stream *stream, size_t n, size_t f) {PROCESS(double);}
static void process_f (struct stream *stream, size_t n, size_t f) {PROCESS(float);}

int
main(int argc, char *argv[])
{
	struct stream stream;
	void (*process)(struct stream *stream, size_t n, size_t f);

	ARGBEGIN {
	case 'r':
		reverse = 1;
		break;
	default:
		usage();
	} ARGEND;

	if (argc)
		usage();

	eopen_stream(&stream, NULL);

	SELECT_PROCESS_FUNCTION(&stream);
	CHECK_CHANS(&stream, != -1, == stream.luma_chan);

	if (!stream.frames)
		eprintf("video's length is not recorded");

	fprint_stream_head(stdout, &stream);
	efflush(stdout, "<stdout>");
	fm_double = (double)(fm = stream.frames - 1);
	fm_float = (float)fm_double;
	process_each_frame_segmented(&stream, STDOUT_FILENO, "<stdout>", process);
	return 0;
}