-
Notifications
You must be signed in to change notification settings - Fork 166
/
Copy pathcompositing.test.js
127 lines (119 loc) · 5.43 KB
/
compositing.test.js
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
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
"use strict";
var test = require('tape');
var mapnik = require('../');
var exists = require('fs').existsSync || require('path').existsSync;
for (var name in mapnik.compositeOp) {
// http://blog.mixu.net/2011/02/03/javascript-node-js-and-for-loops/
(function(name) {
test('should blend image correctly with op:' + name, (assert) => {
var im1 = mapnik.Image.open('test/support/a.png');
im1.premultiplySync();
var im2 = mapnik.Image.open('test/support/b.png');
im2.premultiplySync();
im2.composite(im1, {comp_op:mapnik.compositeOp[name], opacity:1, dx:0, dy:0}, function(err,im_out) {
if (err) throw err;
assert.ok(im_out);
var out = './test/tmp/' + name + '.png';
im_out.demultiplySync();
im_out.save(out);
assert.ok(exists(out));
assert.end();
});
});
})(name); // jshint ignore:line
}
// Ensure `composite` op can correctly stitch images together into larger output image
// and test `view` pixels are identical to those in `input` images
test('should stitch input images correctly', (assert) => {
var input = [ [mapnik.Image.open('test/support/a.png'), 0, 0],
[mapnik.Image.open('test/support/b.png'), 256, 0],
[mapnik.Image.open('test/support/a.png'), 256, 256],
[mapnik.Image.open('test/support/b.png'), 0, 256]];
var output_image = new mapnik.Image(512, 512);
output_image.premultiply();
assert.plan(20);
input.forEach(function (item, index) {
item[0].premultiply();
output_image.composite(item[0], {dx: item[1], dy: item[2]}, function(err) {
if (err) throw err;
assert.ok(output_image);
var views = [output_image.view(0, 0, 256, 256),
output_image.view(256, 0, 256, 256),
output_image.view(256, 256, 256, 256),
output_image.view(0, 256, 256, 256)];
views.forEach(function(view, index) {
var equals = true;
for (var x = 0; x < view.width(); ++x) {
for (var y = 0; y < view.height(); ++y) {
if (view.getPixel(x, y) != input[index][0].getPixel(x, y)) {
equals = false;
break;
}
}
}
assert.equal(equals, true);
});
});
});
});
test('should fail with bad parameters', (assert) => {
var im1 = mapnik.Image.open('test/support/a.png');
im1.premultiply();
assert.equal(im1.premultiplied(), true);
var im2 = mapnik.Image.open('test/support/b.png');
im2.premultiply();
assert.equal(im2.premultiplied(), true);
var im3 = new mapnik.Image(5,5,{type:mapnik.imageType.null});
var im4 = mapnik.Image.open('test/support/a.png');
assert.equal(im4.premultiplied(), false);
var im5 = mapnik.Image.open('test/data/images/sat_image.tif');
assert.throws(function() { im2.composite(); });
assert.throws(function() { im2.composite(null); });
assert.throws(function() { im2.composite({}); });
assert.throws(function() { im2.composite(im1, null); });
assert.throws(function() { im2.composite(im1, null, function(err, im_out) {}); });
assert.throws(function() { im2.composite(im1, {comp_op:null}, function(err, im_out) {}); });
assert.throws(function() { im2.composite(im1, {comp_op:999}, function(err, im_out) {}); });
assert.throws(function() { im2.composite(im1, {comp_op:-9}, function(err, im_out) {}); });
assert.throws(function() { im2.composite(im1, {opacity:null}, function(err, im_out) {}); });
assert.throws(function() { im2.composite(im1, {opacity:1000}, function(err, im_out) {}); });
assert.throws(function() { im2.composite(im1, {opacity:-1000}, function(err, im_out) {}); });
assert.throws(function() { im2.composite(im1, {dx:null}, function(err, im_out) {}); });
assert.throws(function() { im2.composite(im1, {dy:null}, function(err, im_out) {}); });
assert.throws(function() { im2.composite(im1, {image_filters:null}, function(err, im_out) {}); });
assert.throws(function() { im2.composite(im1, {image_filters:'foo'}, function(err, im_out) {}); });
// Fails because im3 is null - will not be premultiplied ever.
assert.throws(function() { im3.composite(im2, {}, function(err, im_out) {}); });
// Fails due to not being premultiplied
assert.throws(function() { im2.composite(im4, {}, function(err, im_out) {}); });
// Fails due to not being premultiplied
assert.throws(function() { im4.composite(im2, {}, function(err, im_out) {}); });
// Fails because gray8 images are not supported
im5.composite(im5, {}, function(err, im_out) {
assert.throws(function() { if (err) throw err; });
assert.end();
});
});
for (var name in mapnik.compositeOp) {
// http://blog.mixu.net/2011/02/03/javascript-node-js-and-for-loops/
(function(name) {
test('should blend image correctly with op:' + name, (assert) => {
var im1 = mapnik.Image.open('test/support/a.png');
im1.premultiply(function(err,im1) {
var im2 = mapnik.Image.open('test/support/b.png');
im2.premultiply(function(err,im2) {
im2.composite(im1, {comp_op:mapnik.compositeOp[name], image_filters:'invert agg-stack-blur(10,10)'}, function(err,im_out) {
if (err) throw err;
assert.ok(im_out);
var out = './test/tmp/' + name + '-async.png';
im_out.demultiply(function(err,im_out) {
im_out.save(out);
assert.ok(exists(out));
assert.end();
});
});
});
});
});
})(name); // jshint ignore:line
}