f28af7da2c284c867cecc777d43e84b15fc8f379
[bertos.git] / icons / flipimage.cpp
1 /**
2  * \file
3  * <!--
4  * This file is part of BeRTOS.
5  *
6  * Bertos is free software; you can redistribute it and/or modify
7  * it under the terms of the GNU General Public License as published by
8  * the Free Software Foundation; either version 2 of the License, or
9  * (at your option) any later version.
10  *
11  * This program is distributed in the hope that it will be useful,
12  * but WITHOUT ANY WARRANTY; without even the implied warranty of
13  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
14  * GNU General Public License for more details.
15  *
16  * You should have received a copy of the GNU General Public License
17  * along with this program; if not, write to the Free Software
18  * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA  02110-1301  USA
19  *
20  * As a special exception, you may use this file as part of a free software
21  * library without restriction.  Specifically, if other files instantiate
22  * templates or use macros or inline functions from this file, or you compile
23  * this file and link it with other files to produce an executable, this
24  * file does not by itself cause the resulting executable to be covered by
25  * the GNU General Public License.  This exception does not however
26  * invalidate any other reasons why the executable file might be covered by
27  * the GNU General Public License.
28  *
29  * Copyright (C) 2004 Develer S.r.l. (http://www.develer.com/)
30  * All Rights Reserved.
31  * -->
32  *
33  * \version $Id$
34  * \author Stefano Fedrigo <aleph@develer.com>
35  *
36  * \brief Conversion tool from image TXT format to LCD bitmap
37  */
38
39 /*
40  * $Log$
41  * Revision 1.1  2006/09/19 17:48:00  bernie
42  * Add temporary logo.
43  *
44  * Revision 1.3  2004/09/24 17:25:32  powersoft
45  * Fix for new version of ImageMagick.
46  *
47  * Revision 1.2  2004/03/13 22:52:54  aleph
48  * documentation fixes
49  *
50  * Revision 1.1  2004/01/26 15:31:17  aleph
51  * Add boot images and tools for importing them
52  *
53  */
54
55 #include <iostream>
56 #include <sstream>
57 #include <iomanip>
58
59 #define RASTER_WIDTH 82
60 #define RASTER_HEIGHT 64
61
62 // Minimum color level to consider a pixel on
63 #define COLOR_THRESHOLD 128
64
65
66 using namespace std;
67
68
69 int main(void)
70 {
71         char buf[64];
72         int n;
73         unsigned char mask;
74         unsigned char line[RASTER_WIDTH];
75
76         for (int l = 0; l < RASTER_HEIGHT/8; l++)
77         {
78                 mask = 1;
79                 memset(line, 0, sizeof(line));
80
81                 do
82                 {
83                         for (int x = 0; x < RASTER_WIDTH; x++)
84                         {
85                                 if (!cin.getline(buf, sizeof(buf)))
86                                         goto print_line;
87
88                                 istringstream ss(buf);
89                                 string s;
90                                 char c;
91
92                                 ss
93                                         >> s  // skip glob coord spec
94                                         >> c  // skip open paren
95                                         >> n; // this is the red level
96
97                                 //DEBUG
98                                 //cout << "s='" << s << "' n='" << n << "'" << endl;
99
100                                 if (n < COLOR_THRESHOLD)
101                                         line[x] |= mask;
102                         }
103                 }
104                 while (mask <<= 1);
105
106 print_line:
107                 cout << "\n\t";
108                 for (int x = 0; x < RASTER_WIDTH; x++)
109                 {
110                         printf("0x%02X", line[x]);
111                         if (x % 8 == 7)
112                                 cout << ",\n\t";
113                         else
114                                 cout << ", ";
115                 }
116                 cout << endl;
117         }
118
119         return 0;
120 }