blob: c9f639c09bf585c97522d2f467ec875ac0590e3e (
plain)
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
|
#include "tests.h"
#include <libplacebo/dither.h>
#include <libplacebo/shaders/dithering.h>
#define SHIFT 4
#define SIZE (1 << SHIFT)
float data[SIZE][SIZE];
int main()
{
printf("Ordered dither matrix:\n");
pl_generate_bayer_matrix(&data[0][0], SIZE);
for (int y = 0; y < SIZE; y++) {
for (int x = 0; x < SIZE; x++)
printf(" %3d", (int)(data[y][x] * SIZE * SIZE));
printf("\n");
}
printf("Blue noise dither matrix:\n");
pl_generate_blue_noise(&data[0][0], SHIFT);
for (int y = 0; y < SIZE; y++) {
for (int x = 0; x < SIZE; x++)
printf(" %3d", (int)(data[y][x] * SIZE * SIZE));
printf("\n");
}
// Generate an example of a dither shader
pl_log log = pl_test_logger();
pl_shader sh = pl_shader_alloc(log, NULL);
pl_shader_obj obj = NULL;
pl_shader_dither(sh, 8, &obj, NULL);
const struct pl_shader_res *res = pl_shader_finalize(sh);
REQUIRE(res);
printf("Generated dither shader:\n%s\n", res->glsl);
pl_shader_obj_destroy(&obj);
pl_shader_free(&sh);
pl_log_destroy(&log);
}
|