]> git.sesse.net Git - movit/blob - vignette_effect_test.cpp
Move to 'using namespace std;' in all .cpp files.
[movit] / vignette_effect_test.cpp
1 // Unit tests for VignetteEffect.
2
3 #include <math.h>
4
5 #include "effect_chain.h"
6 #include "vignette_effect.h"
7 #include "gtest/gtest.h"
8 #include "image_format.h"
9 #include "test_util.h"
10
11 TEST(VignetteEffectTest, HugeInnerRadiusDoesNothing) {
12         const int size = 4;
13
14         float data[size * size] = {
15                 0.0, 1.0, 0.0, 1.0,
16                 0.0, 1.0, 1.0, 0.0,
17                 0.0, 0.5, 1.0, 0.5,
18                 0.0, 0.0, 0.0, 0.0,
19         };
20         float out_data[size * size];
21
22         EffectChainTester tester(data, size, size, FORMAT_GRAYSCALE, COLORSPACE_sRGB, GAMMA_LINEAR);
23         Effect *vignette_effect = tester.get_chain()->add_effect(new VignetteEffect());
24         ASSERT_TRUE(vignette_effect->set_float("inner_radius", 10.0f));
25         tester.run(out_data, GL_RED, COLORSPACE_sRGB, GAMMA_LINEAR);
26
27         expect_equal(data, out_data, size, size);
28 }
29
30 TEST(VignetteEffectTest, HardCircle) {
31         const int size = 16;
32
33         float data[size * size], out_data[size * size], expected_data[size * size];
34         for (int y = 0; y < size; ++y) {
35                 for (int x = 0; x < size; ++x) {
36                         data[y * size + x] = 1.0f;
37                 }
38         }
39         for (int y = 0; y < size; ++y) {
40                 const float yf = (y + 0.5f) / size;
41                 for (int x = 0; x < size; ++x) {
42                         const float xf = (x + 0.5f) / size;
43                         if (hypot(xf - 0.5, yf - 0.5) < 0.3) {
44                                 expected_data[y * size + x] = 1.0f;
45                         } else {
46                                 expected_data[y * size + x] = 0.0f;
47                         }
48                 }
49         }
50
51         EffectChainTester tester(data, size, size, FORMAT_GRAYSCALE, COLORSPACE_sRGB, GAMMA_LINEAR);
52         Effect *vignette_effect = tester.get_chain()->add_effect(new VignetteEffect());
53         ASSERT_TRUE(vignette_effect->set_float("radius", 0.0f));
54         ASSERT_TRUE(vignette_effect->set_float("inner_radius", 0.3f));
55         tester.run(out_data, GL_RED, COLORSPACE_sRGB, GAMMA_LINEAR);
56
57         expect_equal(expected_data, out_data, size, size);
58 }
59
60 TEST(VignetteEffectTest, BurstFromUpperLeftCorner) {
61         const int width = 16, height = 24;
62         float radius = 0.5f;
63
64         float data[width * height], out_data[width * height], expected_data[width * height];
65         for (int y = 0; y < height; ++y) {
66                 for (int x = 0; x < width; ++x) {
67                         data[y * width + x] = 1.0f;
68                 }
69         }
70         for (int y = 0; y < height; ++y) {
71                 const float yf = (y + 0.5f) / width;  // Note: Division by width.
72                 for (int x = 0; x < width; ++x) {
73                         const float xf = (x + 0.5f) / width;
74                         const float d = hypot(xf, yf) / radius;
75                         if (d >= 1.0f) {
76                                 expected_data[y * width + x] = 0.0f;
77                         } else {
78                                 expected_data[y * width + x] = cos(d * 0.5 * M_PI) * cos(d * 0.5 * M_PI);
79                         }
80                 }
81         }
82
83         EffectChainTester tester(data, width, height, FORMAT_GRAYSCALE, COLORSPACE_sRGB, GAMMA_LINEAR);
84         Effect *vignette_effect = tester.get_chain()->add_effect(new VignetteEffect());
85         float center[] = { 0.0f, 0.0f };
86         ASSERT_TRUE(vignette_effect->set_vec2("center", center));
87         ASSERT_TRUE(vignette_effect->set_float("radius", radius));
88         ASSERT_TRUE(vignette_effect->set_float("inner_radius", 0.0f));
89         tester.run(out_data, GL_RED, COLORSPACE_sRGB, GAMMA_LINEAR);
90
91         expect_equal(expected_data, out_data, width, height);
92 }