more changes.
[IRC.git] / Robust / src / Benchmarks / SSJava / EyeTracking / ImageReader.java
1 public class ImageReader {
2   public ImageReader() {
3   }
4
5   public Image readImage(String file) {
6
7     FileInputStream fs = new FileInputStream(file);
8     int bflen = 14; // 14 byte BITMAPFILEHEADER
9     byte bf[] = new byte[bflen];
10     // fs.read(bf,0,bflen);
11     fs.read(bf);
12     int bilen = 40; // 40-byte BITMAPINFOHEADER
13     byte bi[] = new byte[bilen];
14     // fs.read(bi,0,bilen);
15     fs.read(bi);
16     // Interperet data.
17     int nsize =
18         (((int) bf[5] & 0xff) << 24) | (((int) bf[4] & 0xff) << 16) | (((int) bf[3] & 0xff) << 8)
19             | (int) bf[2] & 0xff;
20     // System.out.println("File type is :" + (char) bf[0] + (char) bf[1]);
21     // System.out.println("Size of file is :" + nsize);
22     int nbisize =
23         (((int) bi[3] & 0xff) << 24) | (((int) bi[2] & 0xff) << 16) | (((int) bi[1] & 0xff) << 8)
24             | (int) bi[0] & 0xff;
25     // System.out.println("Size of bitmapinfoheader is :" + nbisize);
26     int nwidth =
27         (((int) bi[7] & 0xff) << 24) | (((int) bi[6] & 0xff) << 16) | (((int) bi[5] & 0xff) << 8)
28             | (int) bi[4] & 0xff;
29     // System.out.println("Width is :" + nwidth);
30     int nheight =
31         (((int) bi[11] & 0xff) << 24) | (((int) bi[10] & 0xff) << 16) | (((int) bi[9] & 0xff) << 8)
32             | (int) bi[8] & 0xff;
33     // System.out.println("Height is :" + nheight);
34     int nplanes = (((int) bi[13] & 0xff) << 8) | (int) bi[12] & 0xff;
35     // System.out.println("Planes is :" + nplanes);
36     int nbitcount = (((int) bi[15] & 0xff) << 8) | (int) bi[14] & 0xff;
37     // System.out.println("BitCount is :" + nbitcount);
38     // Look for non-zero values to indicate compression
39     int ncompression =
40         (((int) bi[19]) << 24) | (((int) bi[18]) << 16) | (((int) bi[17]) << 8) | (int) bi[16];
41     // System.out.println("Compression is :" + ncompression);
42     int nsizeimage =
43         (((int) bi[23] & 0xff) << 24) | (((int) bi[22] & 0xff) << 16)
44             | (((int) bi[21] & 0xff) << 8) | (int) bi[20] & 0xff;
45     // System.out.println("SizeImage is :" + nsizeimage);
46
47     int nxpm =
48         (((int) bi[27] & 0xff) << 24) | (((int) bi[26] & 0xff) << 16)
49             | (((int) bi[25] & 0xff) << 8) | (int) bi[24] & 0xff;
50     // System.out.println("X-Pixels per meter is :" + nxpm);
51     int nypm =
52         (((int) bi[31] & 0xff) << 24) | (((int) bi[30] & 0xff) << 16)
53             | (((int) bi[29] & 0xff) << 8) | (int) bi[28] & 0xff;
54     // System.out.println("Y-Pixels per meter is :" + nypm);
55     int nclrused =
56         (((int) bi[35] & 0xff) << 24) | (((int) bi[34] & 0xff) << 16)
57             | (((int) bi[33] & 0xff) << 8) | (int) bi[32] & 0xff;
58     // System.out.println("Colors used are :" + nclrused);
59     int nclrimp =
60         (((int) bi[39] & 0xff) << 24) | (((int) bi[38] & 0xff) << 16)
61             | (((int) bi[37] & 0xff) << 8) | (int) bi[36] & 0xff;
62     // System.out.println("Colors important are :" + nclrimp);
63
64     Image image = new Image(nwidth, nheight);
65
66     if (nbitcount == 24) {
67       // No Palatte data for 24-bit format but scan lines are
68       // padded out to even 4-byte boundaries.
69       int npad = (nsizeimage / nheight) - nwidth * 3;
70       // ndata = new int[(nheight * nwidth) + 4];
71       byte brgb[] = new byte[(nwidth + npad) * 3 * nheight];
72       // fs.read (brgb, 0, (nwidth + npad) * 3 * nheight);
73       fs.read(brgb);
74       int nindex = 0;
75       int yPos = 0;
76       for (int j = 0; j < nheight; j++) {
77         for (int i = 0; i < nwidth; i++) {
78           // ndata[nwidth * (nheight - j - 1) + i] =
79           // (255 & 0xff) << 24 | (((int) brgb[nindex + 2] & 0xff) << 16)
80           // | (((int) brgb[nindex + 1] & 0xff) << 8) | (int) brgb[nindex] &
81           // 0xff;
82 //           System.out.println("Encoded Color at (" + i + "," + j + ")is:" +
83 //           brgb + " (R,G,B)= ("
84 //           + ((int) (brgb[nindex + 2]) & 0xff) + "," + ((int) brgb[nindex + 1]
85 //           & 0xff) + ","
86 //           + ((int) brgb[nindex] & 0xff) + ")");
87           int ta =
88               ((3 * ((int) (brgb[nindex + 2]) & 0xff) + 6 * ((int) brgb[nindex + 1] & 0xff) + ((int) brgb[nindex] & 0xff))) / 10;
89           // ndata[nwidth * (nheight - j - 1) + i + 4] = ta;
90           nindex += 3;
91           // image.setPixel(i, j, ta);
92           yPos = nheight - j - 1;
93 //          System.out.println("yPos=" + yPos + " nheight=" + nheight + " j=" + j);
94           image.setPixel(i, yPos, ta);
95         }
96         nindex += npad;
97       }
98       // image = createImage
99       // ( new MemoryImageSource (nwidth, nheight,
100       // ndata, 0, nwidth));
101
102     } else if (nbitcount == 8) {
103       // Have to determine the number of colors, the clrsused
104       // parameter is dominant if it is greater than zero. If
105       // zero, calculate colors based on bitsperpixel.
106       int nNumColors = 0;
107       if (nclrused > 0) {
108         nNumColors = nclrused;
109       } else {
110         nNumColors = (1 & 0xff) << nbitcount;
111       }
112       System.out.println("The number of Colors is" + nNumColors);
113       // Some bitmaps do not have the sizeimage field calculated
114       // Ferret out these cases and fix 'em.
115       if (nsizeimage == 0) {
116         nsizeimage = ((((nwidth * nbitcount) + 31) & 31) >> 3);
117         nsizeimage *= nheight;
118         System.out.println("nsizeimage (backup) is" + nsizeimage);
119       }
120       // Read the palatte colors.
121       int npalette[] = new int[nNumColors];
122       byte bpalette[] = new byte[nNumColors * 4];
123       // fs.read (bpalette, 0, nNumColors*4);
124       fs.read(bpalette);
125       int nindex8 = 0;
126       for (int n = 0; n < nNumColors; n++) {
127         npalette[n] =
128             (255 & 0xff) << 24 | (((int) bpalette[nindex8 + 2] & 0xff) << 16)
129                 | (((int) bpalette[nindex8 + 1] & 0xff) << 8) | (int) bpalette[nindex8] & 0xff;
130         // System.out.println ("Palette Color "+n
131         // +" is:"+npalette[n]+" (res,R,G,B)= (" +((int)(bpalette[nindex8+3]) &
132         // 0xff)+"," +((int)(bpalette[nindex8+2]) & 0xff)+","
133         // +((int)bpalette[nindex8+1]&0xff)+","
134         // +((int)bpalette[nindex8]&0xff)+")");
135
136         nindex8 += 4;
137       }
138       // Read the image data (actually indices into the palette)
139       // Scan lines are still padded out to even 4-byte
140       // boundaries.
141       int npad8 = (nsizeimage / nheight) - nwidth;
142       // System.out.println("nPad is:" + npad8);
143       // int ndata8[] = new int[nwidth * nheight];
144       // ndata = new int[(nwidth * nheight) + 4];
145       byte bdata[] = new byte[(nwidth + npad8) * nheight];
146       // fs.read (bdata, 0, (nwidth+npad8)*nheight);
147       fs.read(bdata);
148       nindex8 = 0;
149       for (int j8 = 0; j8 < nheight; j8++) {
150         for (int i8 = 0; i8 < nwidth; i8++) {
151           // ndata[nwidth * (nheight - j8 - 1) + i8 + 4] = npalette[((int)
152           // bdata[nindex8] & 0xff)];
153           image.setPixel(i8, j8, npalette[((int) bdata[nindex8] & 0xff)]);
154           // System.out.println("Encoded Color at (" + i8 + "," + j8 + ")is: "
155           // + ndata[nwidth * (nheight - j8 - 1) + i8 + 4]);
156           nindex8++;
157         }
158         nindex8 += npad8;
159       }
160       // image = createImage ( new MemoryImageSource (nwidth, nheight,
161       // ndata8, 0, nwidth));
162     } else {
163       System.out.println("Not a 24-bit or 8-bit Windows Bitmap, aborting...");
164       // image = (Image)null;
165     }
166     fs.close();
167
168     // ndata[0] = nheight;
169     // ndata[1] = nwidth;
170     // ndata[2] = nheight * nwidth;
171     // ndata[3] = 2;
172
173     return image;
174     // return ndata;
175
176   }
177
178 }