-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathtest-1.cpp
65 lines (50 loc) · 1.2 KB
/
test-1.cpp
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
#include <stdio.h>
#include "types.h"
#include "linearimage.h"
#include "tiledimage.h"
#include "ppm.h"
int main (int argc, char *argv[])
{
if (argc < 4)
{
printf ("error\n");
return 1;
}
int w, h;
unsigned char *img_u8 = load_ppm(argv[1], &w, &h);
rgb *img_f = new rgb [w * h];
rgb *img_g = new rgb [w * h];
for (int i=0; i < w * h; i++)
{
img_f[i].r = (img_u8[3*i+0] / 255.0f);
img_f[i].g = (img_u8[3*i+1] / 255.0f);
img_f[i].b = (img_u8[3*i+2] / 255.0f);
img_f[i].a = 1.0f;
}
rectangle r = {0, 0, w, h};
{
LinearImage<rgb> linear_img (w, h);
linear_img.set(img_f, r);
linear_img.get(img_g, r);
for (int i=0; i < w * h; i++)
{
img_u8[3*i+0] = (img_f[i].r * img_f[i].a * 255.0f);
img_u8[3*i+1] = (img_f[i].g * img_f[i].a * 255.0f);
img_u8[3*i+2] = (img_f[i].b * img_f[i].a * 255.0f);
}
save_ppm(argv[2], img_u8, w, h);
}
{
TiledImage<rgb> tiled_img (w, h, 64, 64);
tiled_img.set(img_f, r);
tiled_img.get(img_g, r);
for (int i=0; i < w * h; i++)
{
img_u8[3*i+0] = (img_f[i].r * img_f[i].a * 255.0f);
img_u8[3*i+1] = (img_f[i].g * img_f[i].a * 255.0f);
img_u8[3*i+2] = (img_f[i].b * img_f[i].a * 255.0f);
}
save_ppm(argv[3], img_u8, w, h);
}
return 0;
}