File: uhdr.cpp

package info (click to toggle)
vips 8.18.0-1
  • links: PTS
  • area: main
  • in suites: forky, sid
  • size: 53,240 kB
  • sloc: ansic: 172,611; cpp: 12,257; python: 5,077; sh: 773; perl: 40; makefile: 25; javascript: 6
file content (60 lines) | stat: -rw-r--r-- 1,280 bytes parent folder | download
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
54
55
56
57
58
59
60
/*
 * compile with:
 *
 *      g++ -g -Wall uhdr.cpp `pkg-config vips-cpp --cflags --libs`
 *
 * run with:
 *
 *      ./a.out test/test-suite/images/ultra-hdr.jpg x.jpg
 *
 */

#include <vips/vips8>

using namespace vips;

int
main(int argc, char **argv)
{
	if (VIPS_INIT(argv[0]))
		vips_error_exit(NULL);

	if (argc != 3)
		vips_error_exit("usage: %s infile outfile", argv[0]);

	int left = 60;
	int top = 1560;
	int width = 128;
	int height = 128;

	VImage in = VImage::new_from_file(argv[1],
		VImage::option()->set("access", VIPS_ACCESS_SEQUENTIAL));

	VImage out = in.crop(left, top, width, height);

	// also crop the gainmap, if there is one
	VImage gainmap = out.gainmap();
	if (!gainmap.is_null()) {
		// the gainmap can be smaller than the image, we must scale the
		// crop area
		double hscale = (double) gainmap.width() / in.width();
		double vscale = (double) gainmap.height() / in.height();

		VImage x = gainmap.crop(left * hscale, top * vscale,
			width * hscale, height * vscale);

		// .set() modifies the image, so we need to make a unique
		// copy ... you can skip this step if you know your image is
		// already unique
		out = out.copy();

		// update the gainmap
		out.set("gainmap", x);
	}

	out.write_to_file(argv[2]);

	vips_shutdown();

	return 0;
}