]> git.imager.perl.org - imager.git/blob - dynfilt/flines.c
extracted jpeg tests from t10formats.t
[imager.git] / dynfilt / flines.c
1 #include "pluginst.h"
2
3
4 char evalstr[]="Fancy lines";
5
6 /* input parameters
7    image is the image object.
8 */
9
10
11
12 unsigned char
13 static
14 saturate(int in) {
15   if (in>255) { return 255; }
16   else if (in>0) return in;
17   return 0;
18 }
19
20
21
22 void
23 flines(void *INP) {
24   i_img *im;
25   i_color vl;
26   int i,bytes,x,y;
27   int idx;
28   
29   if ( !getOBJ("image","Imager::ImgRaw",&im) ) {
30                 fprintf(stderr,"Error: image is missing\n"); 
31                 return;
32         }
33   
34   fprintf(stderr, "flines: parameters: (im 0x%x)\n",im);
35   fprintf(stderr, "flines: image info:\n size (%d,%d)\n channels (%d)\n channel mask (%d)\n bytes (%d)\n",im->xsize,im->ysize,im->channels,im->ch_mask,im->bytes); 
36
37   for(y = 0; y < im->ysize; y ++) {
38     for(x = 0; x < im->xsize; x ++ ) {
39       i_gpix(im,x,y,&vl); 
40                         if (!(y%2)) {
41                                 float yf = y/(float)im->ysize;
42                                 float mf = 1.2-0.8*yf;
43                                 vl.rgb.r = saturate(vl.rgb.r*mf);
44                                 vl.rgb.g = saturate(vl.rgb.g*mf);
45                                 vl.rgb.b = saturate(vl.rgb.b*mf);
46                         } else {
47                                 float yf = (im->ysize-y)/(float)im->ysize;
48                                 float mf = 1.2-0.8*yf;
49                                 vl.rgb.r = saturate(vl.rgb.r*mf);
50                                 vl.rgb.g = saturate(vl.rgb.g*mf);
51                                 vl.rgb.b = saturate(vl.rgb.b*mf);
52                         } 
53      i_ppix(im,x,y,&vl); 
54     }
55   }
56 }
57
58
59
60 func_ptr function_list[]={
61   {
62     "flines",
63     flines,
64     "callseq => ['image'], \
65     callsub => sub { my %hsh=@_; DSO_call($DSO_handle,0,\\%hsh); } \
66     "
67   },
68   {NULL,NULL,NULL}};
69
70
71 /* Remember to double backslash backslashes within Double quotes in C */
72