summaryrefslogtreecommitdiff
Unidiff
Diffstat (more/less context) (ignore whitespace changes)
-rw-r--r--core/settings/citytime/zonemap.cpp2
-rw-r--r--pics/simple_grid_400.pngbin4533 -> 0 bytes
2 files changed, 1 insertions, 1 deletions
diff --git a/core/settings/citytime/zonemap.cpp b/core/settings/citytime/zonemap.cpp
index 337f4d9..1d60aee 100644
--- a/core/settings/citytime/zonemap.cpp
+++ b/core/settings/citytime/zonemap.cpp
@@ -1,670 +1,670 @@
1/********************************************************************** 1/**********************************************************************
2** Copyright (C) 2000 Trolltech AS. All rights reserved. 2** Copyright (C) 2000 Trolltech AS. All rights reserved.
3** 3**
4** This file is part of Qtopia Environment. 4** This file is part of Qtopia Environment.
5** 5**
6** This file may be distributed and/or modified under the terms of the 6** This file may be distributed and/or modified under the terms of the
7** GNU General Public License version 2 as published by the Free Software 7** GNU General Public License version 2 as published by the Free Software
8** Foundation and appearing in the file LICENSE.GPL included in the 8** Foundation and appearing in the file LICENSE.GPL included in the
9** packaging of this file. 9** packaging of this file.
10** 10**
11** This file is provided AS IS with NO WARRANTY OF ANY KIND, INCLUDING THE 11** This file is provided AS IS with NO WARRANTY OF ANY KIND, INCLUDING THE
12** WARRANTY OF DESIGN, MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE. 12** WARRANTY OF DESIGN, MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE.
13** 13**
14** See http://www.trolltech.com/gpl/ for GPL licensing information. 14** See http://www.trolltech.com/gpl/ for GPL licensing information.
15** 15**
16** Contact info@trolltech.com if any conditions of this licensing are 16** Contact info@trolltech.com if any conditions of this licensing are
17** not clear to you. 17** not clear to you.
18** 18**
19**********************************************************************/ 19**********************************************************************/
20 20
21#include "sun.h" 21#include "sun.h"
22#include "zonemap.h" 22#include "zonemap.h"
23 23
24#include <qpe/resource.h> 24#include <qpe/resource.h>
25#include <qpe/timestring.h> 25#include <qpe/timestring.h>
26#include <qpe/qpeapplication.h> 26#include <qpe/qpeapplication.h>
27 27
28#include <qdatetime.h> 28#include <qdatetime.h>
29#include <qfile.h> 29#include <qfile.h>
30#include <qimage.h> 30#include <qimage.h>
31#include <qlabel.h> 31#include <qlabel.h>
32#include <qlist.h> 32#include <qlist.h>
33#include <qmessagebox.h> 33#include <qmessagebox.h>
34#include <qpixmap.h> 34#include <qpixmap.h>
35#include <qpainter.h> 35#include <qpainter.h>
36#include <qregexp.h> 36#include <qregexp.h>
37#include <qtextstream.h> 37#include <qtextstream.h>
38#include <qtimer.h> 38#include <qtimer.h>
39#include <qtoolbutton.h> 39#include <qtoolbutton.h>
40 40
41#include <limits.h> 41#include <limits.h>
42 42
43// the map file... 43// the map file...
44static const char strZONEINFO[] = "/usr/share/zoneinfo/zone.tab"; 44static const char strZONEINFO[] = "/usr/share/zoneinfo/zone.tab";
45static const char strMAP[] = "simple_grid_400"; 45static const char strMAP[] = "citytime/simple_grid_400";
46 46
47// the maximum distance we'll allow the pointer to be away from a city 47// the maximum distance we'll allow the pointer to be away from a city
48// and still show the city's time 48// and still show the city's time
49static const int iTHRESHOLD = 50000; 49static const int iTHRESHOLD = 50000;
50 50
51// The label offset (how far away from pointer) 51// The label offset (how far away from pointer)
52static const int iLABELOFFSET = 8; 52static const int iLABELOFFSET = 8;
53 53
54// the size of the dot to draw, and where to start it 54// the size of the dot to draw, and where to start it
55static const int iCITYSIZE = 3; 55static const int iCITYSIZE = 3;
56const int iCITYOFFSET = 2; 56const int iCITYOFFSET = 2;
57 57
58// the darkening function 58// the darkening function
59static inline void darken( QImage *pImage, int start, int stop, int row ); 59static inline void darken( QImage *pImage, int start, int stop, int row );
60static void dayNight( QImage *pImage ); 60static void dayNight( QImage *pImage );
61 61
62ZoneField::ZoneField( const QString& strLine ) 62ZoneField::ZoneField( const QString& strLine )
63{ 63{
64 // make a bunch of RegExp's to match the data from the line 64 // make a bunch of RegExp's to match the data from the line
65 QRegExp regCoord( "[-+][0-9]+" );// the latitude 65 QRegExp regCoord( "[-+][0-9]+" );// the latitude
66 QRegExp regCountry( "[A-Za-z]+/" ); // the country (not good enough) 66 QRegExp regCountry( "[A-Za-z]+/" ); // the country (not good enough)
67 QRegExp regCity( "[A-Za-z_-]*" ); // the city 67 QRegExp regCity( "[A-Za-z_-]*" ); // the city
68 68
69 int iStart, 69 int iStart,
70 iStop, 70 iStop,
71 iLen, 71 iLen,
72 tmp; 72 tmp;
73 QString strTmp; 73 QString strTmp;
74 // we should be able to assume that the country code is always the first 74 // we should be able to assume that the country code is always the first
75 // two chars, so just grap them and let it go... 75 // two chars, so just grap them and let it go...
76 strCountryCode = strLine.left( 2 ); 76 strCountryCode = strLine.left( 2 );
77 iStart = regCoord.match( strLine, 0, &iLen ); 77 iStart = regCoord.match( strLine, 0, &iLen );
78 if ( iStart >= 0 ) { 78 if ( iStart >= 0 ) {
79 strTmp = strLine.mid( iStart, iLen ); 79 strTmp = strLine.mid( iStart, iLen );
80 tmp = strTmp.toInt(); 80 tmp = strTmp.toInt();
81 // okay, there are two versions of the format, make a decision based on 81 // okay, there are two versions of the format, make a decision based on
82 // the size... 82 // the size...
83 // Oh BTW, we are storing everything in seconds! 83 // Oh BTW, we are storing everything in seconds!
84 if ( iLen < 7 ) { 84 if ( iLen < 7 ) {
85 _y = tmp / 100; 85 _y = tmp / 100;
86 _y *= 60; 86 _y *= 60;
87 _y += tmp % 100; 87 _y += tmp % 100;
88 _y *= 60; 88 _y *= 60;
89 } else { 89 } else {
90 _y = tmp / 10000; 90 _y = tmp / 10000;
91 _y *= 60; 91 _y *= 60;
92 tmp %= 10000; 92 tmp %= 10000;
93 _y += tmp / 100; 93 _y += tmp / 100;
94 _y *= 60; 94 _y *= 60;
95 tmp %= 100; 95 tmp %= 100;
96 _y += tmp; 96 _y += tmp;
97 } 97 }
98 } 98 }
99 iStart = regCoord.match( strLine, iStart + iLen, &iLen ); 99 iStart = regCoord.match( strLine, iStart + iLen, &iLen );
100 if ( iStart >= 0 ) { 100 if ( iStart >= 0 ) {
101 strTmp = strLine.mid( iStart, iLen ); 101 strTmp = strLine.mid( iStart, iLen );
102 tmp = strTmp.toInt(); 102 tmp = strTmp.toInt();
103 if ( iLen < 8 ) { 103 if ( iLen < 8 ) {
104 _x = tmp / 100; 104 _x = tmp / 100;
105 _x *= 60; 105 _x *= 60;
106 _x += tmp % 100; 106 _x += tmp % 100;
107 _x *= 60; 107 _x *= 60;
108 } else { 108 } else {
109 _x = tmp / 10000; 109 _x = tmp / 10000;
110 _x *= 60; 110 _x *= 60;
111 tmp %= 10000; 111 tmp %= 10000;
112 _x += tmp / 100; 112 _x += tmp / 100;
113 _x *= 60; 113 _x *= 60;
114 tmp %= 100; 114 tmp %= 100;
115 _x += tmp; 115 _x += tmp;
116 } 116 }
117 } 117 }
118 iStart = regCountry.match( strLine, 0, &iLen ); 118 iStart = regCountry.match( strLine, 0, &iLen );
119 // help with the shortcoming in 2.x regexp... 119 // help with the shortcoming in 2.x regexp...
120 iStop = strLine.findRev( '/' ); 120 iStop = strLine.findRev( '/' );
121 if ( iStart >= 0 ) { 121 if ( iStart >= 0 ) {
122 iLen = (iStop - iStart) + 1; 122 iLen = (iStop - iStart) + 1;
123 strCountry = strLine.mid( iStart, iLen ); 123 strCountry = strLine.mid( iStart, iLen );
124 } 124 }
125 // now match the city... 125 // now match the city...
126 iStart = regCity.match( strLine, iStart + iLen, &iLen ); 126 iStart = regCity.match( strLine, iStart + iLen, &iLen );
127 if ( iStart >= 0 ) { 127 if ( iStart >= 0 ) {
128 strCity = strLine.mid( iStart, iLen ); 128 strCity = strLine.mid( iStart, iLen );
129 } 129 }
130} 130}
131 131
132void ZoneField::showStructure( void ) const 132void ZoneField::showStructure( void ) const
133{ 133{
134 qDebug( "Country: %s", strCountry.latin1() ); 134 qDebug( "Country: %s", strCountry.latin1() );
135 qDebug( "City: %s", strCity.latin1() ); 135 qDebug( "City: %s", strCity.latin1() );
136 qDebug( "x: %d", _x ); 136 qDebug( "x: %d", _x );
137 qDebug( "y: %d\n", _y ); 137 qDebug( "y: %d\n", _y );
138} 138}
139 139
140ZoneMap::ZoneMap( QWidget *parent, const char* name ) 140ZoneMap::ZoneMap( QWidget *parent, const char* name )
141 : QScrollView( parent, name ), 141 : QScrollView( parent, name ),
142 pLast( 0 ), 142 pLast( 0 ),
143 pRepaint( 0 ), 143 pRepaint( 0 ),
144 ox( 0 ), 144 ox( 0 ),
145 oy( 0 ), 145 oy( 0 ),
146 drawableW( -1 ), 146 drawableW( -1 ),
147 drawableH( -1 ), 147 drawableH( -1 ),
148 bZoom( FALSE ), 148 bZoom( FALSE ),
149 bIllum( TRUE ), 149 bIllum( TRUE ),
150 cursor( 0 ) 150 cursor( 0 )
151{ 151{
152 viewport()->setFocusPolicy( StrongFocus ); 152 viewport()->setFocusPolicy( StrongFocus );
153 153
154 // set mouse tracking so we can use the mouse move event 154 // set mouse tracking so we can use the mouse move event
155 zones.setAutoDelete( true ); 155 zones.setAutoDelete( true );
156 // get the map loaded 156 // get the map loaded
157 // just set the current image to point 157 // just set the current image to point
158 pixCurr = new QPixmap(); 158 pixCurr = new QPixmap();
159 159
160 QPixmap pixZoom = Resource::loadPixmap( "mag" ); 160 QPixmap pixZoom = Resource::loadPixmap( "mag" );
161 161
162 cmdZoom = new QToolButton( this, "Zoom command" ); 162 cmdZoom = new QToolButton( this, "Zoom command" );
163 cmdZoom->setPixmap( pixZoom ); 163 cmdZoom->setPixmap( pixZoom );
164 cmdZoom->setToggleButton( true ); 164 cmdZoom->setToggleButton( true );
165 165
166 cmdZoom->setSizePolicy( QSizePolicy( (QSizePolicy::SizeType)0, 166 cmdZoom->setSizePolicy( QSizePolicy( (QSizePolicy::SizeType)0,
167 (QSizePolicy::SizeType)0, 167 (QSizePolicy::SizeType)0,
168 cmdZoom->sizePolicy().hasHeightForWidth() ) ); 168 cmdZoom->sizePolicy().hasHeightForWidth() ) );
169 cmdZoom->setMaximumSize( cmdZoom->sizeHint() ); 169 cmdZoom->setMaximumSize( cmdZoom->sizeHint() );
170 // probably don't need this, but just in case... 170 // probably don't need this, but just in case...
171 cmdZoom->move( width() - cmdZoom->width(), height() - cmdZoom->height() ); 171 cmdZoom->move( width() - cmdZoom->width(), height() - cmdZoom->height() );
172 172
173 173
174 lblCity = new QLabel( tr( "CITY" ), this, "City Label" ); 174 lblCity = new QLabel( tr( "CITY" ), this, "City Label" );
175 lblCity->setMinimumSize( lblCity->sizeHint() ); 175 lblCity->setMinimumSize( lblCity->sizeHint() );
176 lblCity->setFrameStyle( QFrame::Plain | QFrame::Box ); 176 lblCity->setFrameStyle( QFrame::Plain | QFrame::Box );
177 lblCity->setBackgroundColor( yellow ); 177 lblCity->setBackgroundColor( yellow );
178 lblCity->hide(); 178 lblCity->hide();
179 179
180 // A timer to make sure the label gets hidden 180 // A timer to make sure the label gets hidden
181 tHide = new QTimer( this, "Label Timer" ); 181 tHide = new QTimer( this, "Label Timer" );
182 QObject::connect( tHide, SIGNAL( timeout() ), 182 QObject::connect( tHide, SIGNAL( timeout() ),
183 lblCity, SLOT( hide() ) ); 183 lblCity, SLOT( hide() ) );
184 QObject::connect( tHide, SIGNAL( timeout() ), 184 QObject::connect( tHide, SIGNAL( timeout() ),
185 this, SLOT( slotRedraw() ) ); 185 this, SLOT( slotRedraw() ) );
186 QTimer *tUpdate = new QTimer( this, "Update Timer" ); 186 QTimer *tUpdate = new QTimer( this, "Update Timer" );
187 QObject::connect( tUpdate, SIGNAL( timeout() ), 187 QObject::connect( tUpdate, SIGNAL( timeout() ),
188 this, SLOT( slotUpdate() ) ); 188 this, SLOT( slotUpdate() ) );
189 QObject::connect( qApp, SIGNAL( timeChanged() ), 189 QObject::connect( qApp, SIGNAL( timeChanged() ),
190 this, SLOT( slotUpdate() ) ); 190 this, SLOT( slotUpdate() ) );
191 QObject::connect( cmdZoom, SIGNAL( toggled( bool ) ), 191 QObject::connect( cmdZoom, SIGNAL( toggled( bool ) ),
192 this, SLOT( slotZoom( bool ) ) ); 192 this, SLOT( slotZoom( bool ) ) );
193 QObject::connect( &norm, SIGNAL( signalNewPoint( const QPoint& ) ), 193 QObject::connect( &norm, SIGNAL( signalNewPoint( const QPoint& ) ),
194 this, SLOT( slotFindCity( const QPoint& ) ) ); 194 this, SLOT( slotFindCity( const QPoint& ) ) );
195 QObject::connect( qApp, SIGNAL( clockChanged( bool ) ), 195 QObject::connect( qApp, SIGNAL( clockChanged( bool ) ),
196 this, SLOT( changeClock( bool ) ) ); 196 this, SLOT( changeClock( bool ) ) );
197 // update the sun's movement every 5 minutes 197 // update the sun's movement every 5 minutes
198 tUpdate->start( 5 * 60 * 1000 ); 198 tUpdate->start( 5 * 60 * 1000 );
199 // May as well read in the timezone information too... 199 // May as well read in the timezone information too...
200 readZones(); 200 readZones();
201} 201}
202 202
203ZoneMap::~ZoneMap() 203ZoneMap::~ZoneMap()
204{ 204{
205} 205}
206 206
207void ZoneMap::readZones( void ) 207void ZoneMap::readZones( void )
208{ 208{
209 QFile fZone( strZONEINFO ); 209 QFile fZone( strZONEINFO );
210 if ( !fZone.open( IO_ReadOnly ) ) { 210 if ( !fZone.open( IO_ReadOnly ) ) {
211 QMessageBox::warning (this, 211 QMessageBox::warning (this,
212 tr( "Unable to Find Timezone Info" ), 212 tr( "Unable to Find Timezone Info" ),
213 tr( "<p>Unable to find any timezone information in %1" ) 213 tr( "<p>Unable to find any timezone information in %1" )
214 .arg( strZONEINFO )); 214 .arg( strZONEINFO ));
215 exit(-1); 215 exit(-1);
216 } else { 216 } else {
217 QTextStream tZone( &fZone ); 217 QTextStream tZone( &fZone );
218 while ( !tZone.atEnd() ) { 218 while ( !tZone.atEnd() ) {
219 QString strLine = tZone.readLine(); 219 QString strLine = tZone.readLine();
220 // only pass on lines that aren't comments 220 // only pass on lines that aren't comments
221 if ( strLine[0] != '#' ) { 221 if ( strLine[0] != '#' ) {
222 zones.append( new ZoneField( strLine ) ); 222 zones.append( new ZoneField( strLine ) );
223 } 223 }
224 } 224 }
225 fZone.close(); 225 fZone.close();
226 } 226 }
227} 227}
228 228
229void ZoneMap::viewportMousePressEvent( QMouseEvent* event ) 229void ZoneMap::viewportMousePressEvent( QMouseEvent* event )
230{ 230{
231 // add the mouse event into the normalizer, and get the average, 231 // add the mouse event into the normalizer, and get the average,
232 // pass it along 232 // pass it along
233 slotRedraw(); 233 slotRedraw();
234 norm.start(); 234 norm.start();
235 norm.addEvent( event->pos() ); 235 norm.addEvent( event->pos() );
236} 236}
237 237
238void ZoneMap::viewportMouseMoveEvent( QMouseEvent* event ) 238void ZoneMap::viewportMouseMoveEvent( QMouseEvent* event )
239{ 239{
240 norm.addEvent( event->pos() ); 240 norm.addEvent( event->pos() );
241} 241}
242 242
243void ZoneMap::viewportMouseReleaseEvent( QMouseEvent* ) 243void ZoneMap::viewportMouseReleaseEvent( QMouseEvent* )
244{ 244{
245 // get the averaged points in case a timeout hasn't occurred, 245 // get the averaged points in case a timeout hasn't occurred,
246 // more for "mouse clicks" 246 // more for "mouse clicks"
247 norm.stop(); 247 norm.stop();
248 if ( pLast != NULL ) { 248 if ( pLast != NULL ) {
249 emit signalTz( pLast->country(), pLast->city() ); 249 emit signalTz( pLast->country(), pLast->city() );
250 pLast = NULL; 250 pLast = NULL;
251 } 251 }
252 tHide->start( 2000, true ); 252 tHide->start( 2000, true );
253} 253}
254 254
255void ZoneMap::keyPressEvent( QKeyEvent *ke ) 255void ZoneMap::keyPressEvent( QKeyEvent *ke )
256{ 256{
257 switch ( ke->key() ) { 257 switch ( ke->key() ) {
258 case Key_Left: 258 case Key_Left:
259 case Key_Right: 259 case Key_Right:
260 case Key_Up: 260 case Key_Up:
261 case Key_Down: { 261 case Key_Down: {
262 tHide->stop(); 262 tHide->stop();
263 if ( !cursor ) 263 if ( !cursor )
264 slotFindCity( QPoint( contentsWidth(), contentsHeight() ) / 2 ); 264 slotFindCity( QPoint( contentsWidth(), contentsHeight() ) / 2 );
265 ZoneField *city = findCityNear( cursor, ke->key() ); 265 ZoneField *city = findCityNear( cursor, ke->key() );
266 if ( city ) { 266 if ( city ) {
267 cursor = city; 267 cursor = city;
268 int tmpx, tmpy; 268 int tmpx, tmpy;
269 zoneToWin( cursor->x(), cursor->y(), tmpx, tmpy ); 269 zoneToWin( cursor->x(), cursor->y(), tmpx, tmpy );
270 ensureVisible( tmpx, tmpy ); 270 ensureVisible( tmpx, tmpy );
271 showCity( cursor ); 271 showCity( cursor );
272 tHide->start( 3000, true ); 272 tHide->start( 3000, true );
273 } 273 }
274 } 274 }
275 break; 275 break;
276 276
277 case Key_Space: 277 case Key_Space:
278 case Key_Enter: 278 case Key_Enter:
279 case Key_Return: 279 case Key_Return:
280 if ( cursor ) { 280 if ( cursor ) {
281 emit signalTz( cursor->country(), cursor->city() ); 281 emit signalTz( cursor->country(), cursor->city() );
282 tHide->start( 0, true ); 282 tHide->start( 0, true );
283 } 283 }
284 break; 284 break;
285 } 285 }
286} 286}
287 287
288ZoneField *ZoneMap::findCityNear( ZoneField *city, int key ) 288ZoneField *ZoneMap::findCityNear( ZoneField *city, int key )
289{ 289{
290 ZoneField *pZone; 290 ZoneField *pZone;
291 ZoneField *pClosest = 0; 291 ZoneField *pClosest = 0;
292 long ddist = LONG_MAX; 292 long ddist = LONG_MAX;
293 293
294 QListIterator<ZoneField> it( zones ); 294 QListIterator<ZoneField> it( zones );
295 for (; it.current(); ++it) { 295 for (; it.current(); ++it) {
296 pZone = it.current(); 296 pZone = it.current();
297 long dx = (pZone->x() - city->x())/100; 297 long dx = (pZone->x() - city->x())/100;
298 long dy = (pZone->y() - city->y())/100; 298 long dy = (pZone->y() - city->y())/100;
299 switch ( key ) { 299 switch ( key ) {
300 case Key_Right: 300 case Key_Right:
301 case Key_Left: 301 case Key_Left:
302 if ( key == Key_Left ) 302 if ( key == Key_Left )
303 dx = -dx; 303 dx = -dx;
304 if ( dx > 0 ) { 304 if ( dx > 0 ) {
305 long dist = QABS(dy)*4 + dx; 305 long dist = QABS(dy)*4 + dx;
306 if ( dist < ddist ) { 306 if ( dist < ddist ) {
307 ddist = dist; 307 ddist = dist;
308 pClosest = pZone; 308 pClosest = pZone;
309 } 309 }
310 } 310 }
311 break; 311 break;
312 case Key_Down: 312 case Key_Down:
313 case Key_Up: 313 case Key_Up:
314 if ( key == Key_Down ) 314 if ( key == Key_Down )
315 dy = -dy; 315 dy = -dy;
316 if ( dy > 0 ) { 316 if ( dy > 0 ) {
317 long dist = QABS(dx)*4 + dy; 317 long dist = QABS(dx)*4 + dy;
318 if ( dist < ddist ) { 318 if ( dist < ddist ) {
319 ddist = dist; 319 ddist = dist;
320 pClosest = pZone; 320 pClosest = pZone;
321 } 321 }
322 } 322 }
323 break; 323 break;
324 } 324 }
325 } 325 }
326 326
327 return pClosest; 327 return pClosest;
328} 328}
329 329
330void ZoneMap::slotFindCity( const QPoint &pos ) 330void ZoneMap::slotFindCity( const QPoint &pos )
331{ 331{
332 lblCity->hide(); 332 lblCity->hide();
333 // given coordinates on the screen find the closest city and display the 333 // given coordinates on the screen find the closest city and display the
334 // label close to it 334 // label close to it
335 int tmpx, tmpy, x, y; 335 int tmpx, tmpy, x, y;
336 long lDistance, 336 long lDistance,
337 lClosest; 337 lClosest;
338 ZoneField *pZone, 338 ZoneField *pZone,
339 *pClosest; 339 *pClosest;
340 340
341 if ( tHide->isActive() ) { 341 if ( tHide->isActive() ) {
342 tHide->stop(); 342 tHide->stop();
343 } 343 }
344 viewportToContents(pos.x(), pos.y(), tmpx, tmpy); 344 viewportToContents(pos.x(), pos.y(), tmpx, tmpy);
345 winToZone( tmpx, tmpy, x, y ); 345 winToZone( tmpx, tmpy, x, y );
346 // Find city alogorithim: start out at an (near) infinite distance away and 346 // Find city alogorithim: start out at an (near) infinite distance away and
347 // then find the closest city, (similar to the Z-buffer technique, I guess) 347 // then find the closest city, (similar to the Z-buffer technique, I guess)
348 // the only problem is that this is all done with doubles, but I don't know 348 // the only problem is that this is all done with doubles, but I don't know
349 // another way to do it at the moment. Another problem is a linked list is 349 // another way to do it at the moment. Another problem is a linked list is
350 // used obviously something indexed would help 350 // used obviously something indexed would help
351 QListIterator<ZoneField> it( zones ); 351 QListIterator<ZoneField> it( zones );
352 pClosest = 0; 352 pClosest = 0;
353 lClosest = LONG_MAX; 353 lClosest = LONG_MAX;
354 for (; it.current(); ++it) { 354 for (; it.current(); ++it) {
355 pZone = it.current(); 355 pZone = it.current();
356 // use the manhattenLength, a good enough of an appoximation here 356 // use the manhattenLength, a good enough of an appoximation here
357 lDistance = QABS( x - pZone->x() ) + QABS( y - pZone->y() ); 357 lDistance = QABS( x - pZone->x() ) + QABS( y - pZone->y() );
358 // first to zero wins! 358 // first to zero wins!
359 if ( lDistance < lClosest ) { 359 if ( lDistance < lClosest ) {
360 lClosest = lDistance; 360 lClosest = lDistance;
361 pClosest = pZone; 361 pClosest = pZone;
362 } 362 }
363 } 363 }
364 364
365 // Okay, we found the closest city, but it might still be too far away. 365 // Okay, we found the closest city, but it might still be too far away.
366 if ( lClosest <= iTHRESHOLD ) { 366 if ( lClosest <= iTHRESHOLD ) {
367 showCity( pClosest ); 367 showCity( pClosest );
368 cursor = pClosest; 368 cursor = pClosest;
369 } 369 }
370} 370}
371 371
372void ZoneMap::showCity( ZoneField *city ) 372void ZoneMap::showCity( ZoneField *city )
373{ 373{
374 pLast = city; 374 pLast = city;
375 // we'll use city and country a couple of times, get them to save some 375 // we'll use city and country a couple of times, get them to save some
376 // time 376 // time
377 QString strCity = pLast->city(); 377 QString strCity = pLast->city();
378 QString strCountry = pLast->country(); 378 QString strCountry = pLast->country();
379 // Display the time at this location by setting the environment timezone 379 // Display the time at this location by setting the environment timezone
380 // getting the current time [there] and then swapping back the variable 380 // getting the current time [there] and then swapping back the variable
381 // so no one notices... 381 // so no one notices...
382 QString strSave; 382 QString strSave;
383 char *p = getenv( "TZ" ); 383 char *p = getenv( "TZ" );
384 if ( p ) { 384 if ( p ) {
385 strSave = p; 385 strSave = p;
386 } 386 }
387 // set the timezone :) 387 // set the timezone :)
388 setenv( "TZ", strCountry + strCity, true ); 388 setenv( "TZ", strCountry + strCity, true );
389 lblCity->setText( strCity.replace( QRegExp("_"), " ") + "\n" + 389 lblCity->setText( strCity.replace( QRegExp("_"), " ") + "\n" +
390 TimeString::shortTime( ampm ) ); 390 TimeString::shortTime( ampm ) );
391 lblCity->setMinimumSize( lblCity->sizeHint() ); 391 lblCity->setMinimumSize( lblCity->sizeHint() );
392 // undue our damage... 392 // undue our damage...
393 unsetenv( "TZ" ); 393 unsetenv( "TZ" );
394 if ( p ) 394 if ( p )
395 setenv( "TZ", strSave, true ); 395 setenv( "TZ", strSave, true );
396 // Now decide where to move the label, x & y can be reused 396 // Now decide where to move the label, x & y can be reused
397 int tmpx, tmpy, x, y; 397 int tmpx, tmpy, x, y;
398 zoneToWin( pLast->x(), pLast->y(), tmpx, tmpy ); 398 zoneToWin( pLast->x(), pLast->y(), tmpx, tmpy );
399 contentsToViewport(tmpx, tmpy, x, y); 399 contentsToViewport(tmpx, tmpy, x, y);
400 if ( lblCity->width() > drawableW - x ) { 400 if ( lblCity->width() > drawableW - x ) {
401 // oops... try putting it on the right 401 // oops... try putting it on the right
402 x = x - lblCity->width() - iLABELOFFSET; 402 x = x - lblCity->width() - iLABELOFFSET;
403 } else { 403 } else {
404 // the default... 404 // the default...
405 x += iLABELOFFSET; 405 x += iLABELOFFSET;
406 } 406 }
407 if ( lblCity->height() > drawableH - y ) { 407 if ( lblCity->height() > drawableH - y ) {
408 // move it up... 408 // move it up...
409 y = y - lblCity->height() - iLABELOFFSET; 409 y = y - lblCity->height() - iLABELOFFSET;
410 } else if ( y < 0 ) { 410 } else if ( y < 0 ) {
411 // the city is actually off the screen... 411 // the city is actually off the screen...
412 // this only happens on the a zoom when you are near the top, 412 // this only happens on the a zoom when you are near the top,
413 // a quick workaround.. 413 // a quick workaround..
414 y = iLABELOFFSET; 414 y = iLABELOFFSET;
415 } else { 415 } else {
416 // the default 416 // the default
417 y += iLABELOFFSET; 417 y += iLABELOFFSET;
418 } 418 }
419 419
420 // draw in the city and the label 420 // draw in the city and the label
421 if ( pRepaint ) { 421 if ( pRepaint ) {
422 int repx, 422 int repx,
423 repy; 423 repy;
424 zoneToWin( pRepaint->x(), pRepaint->y(), repx, repy ); 424 zoneToWin( pRepaint->x(), pRepaint->y(), repx, repy );
425 updateContents( repx - iCITYOFFSET, repy - iCITYOFFSET, 425 updateContents( repx - iCITYOFFSET, repy - iCITYOFFSET,
426 iCITYSIZE, iCITYSIZE ); 426 iCITYSIZE, iCITYSIZE );
427 } 427 }
428 updateContents( tmpx - iCITYOFFSET, tmpy - iCITYOFFSET, iCITYSIZE, 428 updateContents( tmpx - iCITYOFFSET, tmpy - iCITYOFFSET, iCITYSIZE,
429 iCITYSIZE ); 429 iCITYSIZE );
430 pRepaint = pLast; 430 pRepaint = pLast;
431 431
432 lblCity->move( x, y ); 432 lblCity->move( x, y );
433 lblCity->show(); 433 lblCity->show();
434} 434}
435 435
436void ZoneMap::resizeEvent( QResizeEvent *e ) 436void ZoneMap::resizeEvent( QResizeEvent *e )
437{ 437{
438 // keep the zoom button down in the corner 438 // keep the zoom button down in the corner
439 QSize _size = e->size(); 439 QSize _size = e->size();
440 cmdZoom->move( _size.width() - cmdZoom->width(), 440 cmdZoom->move( _size.width() - cmdZoom->width(),
441 _size.height() - cmdZoom->height() ); 441 _size.height() - cmdZoom->height() );
442 if ( !bZoom ) { 442 if ( !bZoom ) {
443 drawableW = width() - 2 * frameWidth(); 443 drawableW = width() - 2 * frameWidth();
444 drawableH = height() - 2 * frameWidth(); 444 drawableH = height() - 2 * frameWidth();
445 makeMap( drawableW, drawableH ); 445 makeMap( drawableW, drawableH );
446 resizeContents( drawableW, drawableH ); 446 resizeContents( drawableW, drawableH );
447 } 447 }
448} 448}
449 449
450void ZoneMap::showZones( void ) const 450void ZoneMap::showZones( void ) const
451{ 451{
452 // go through the zones in the list and just display the values... 452 // go through the zones in the list and just display the values...
453 QListIterator<ZoneField> itZone( zones ); 453 QListIterator<ZoneField> itZone( zones );
454 for ( itZone.toFirst(); itZone.current(); ++itZone ) { 454 for ( itZone.toFirst(); itZone.current(); ++itZone ) {
455 ZoneField *pZone = itZone.current(); 455 ZoneField *pZone = itZone.current();
456 pZone->showStructure(); 456 pZone->showStructure();
457 } 457 }
458} 458}
459 459
460void ZoneMap::drawCities( QPainter *p ) 460void ZoneMap::drawCities( QPainter *p )
461{ 461{
462 int x, 462 int x,
463 y, 463 y,
464 j; 464 j;
465 // draw in the cities 465 // draw in the cities
466 // for testing only as when you put it 466 // for testing only as when you put it
467 // on the small screen it looks awful and not to mention useless 467 // on the small screen it looks awful and not to mention useless
468 p->setPen( red ); 468 p->setPen( red );
469 QListIterator<ZoneField> itZone( zones ); 469 QListIterator<ZoneField> itZone( zones );
470 for ( itZone.toFirst(), j = 0; itZone.current(); ++itZone, j++ ) { 470 for ( itZone.toFirst(), j = 0; itZone.current(); ++itZone, j++ ) {
471 ZoneField *pZone = itZone.current(); 471 ZoneField *pZone = itZone.current();
472 zoneToWin( pZone->x(), pZone->y(), x, y ); 472 zoneToWin( pZone->x(), pZone->y(), x, y );
473 if ( x > wImg ) 473 if ( x > wImg )
474 x = x - wImg; 474 x = x - wImg;
475 p->drawRect( x - iCITYOFFSET, y - iCITYOFFSET, iCITYSIZE, iCITYSIZE); 475 p->drawRect( x - iCITYOFFSET, y - iCITYOFFSET, iCITYSIZE, iCITYSIZE);
476 } 476 }
477} 477}
478 478
479static void dayNight(QImage *pImage) 479static void dayNight(QImage *pImage)
480{ 480{
481 // create a mask the functions from sun.h 481 // create a mask the functions from sun.h
482 double dJulian, 482 double dJulian,
483 dSunRad, 483 dSunRad,
484 dSunDecl, 484 dSunDecl,
485 dSunRadius, 485 dSunRadius,
486 dSunLong; 486 dSunLong;
487 int wImage = pImage->width(), 487 int wImage = pImage->width(),
488 hImage = pImage->height(), 488 hImage = pImage->height(),
489 iStart, 489 iStart,
490 iStop, 490 iStop,
491 iMid, 491 iMid,
492 relw, 492 relw,
493 i; 493 i;
494 short wtab[ wImage ]; 494 short wtab[ wImage ];
495 time_t tCurrent; 495 time_t tCurrent;
496 struct tm *pTm; 496 struct tm *pTm;
497 497
498 // get the position of the sun bassed on our current time... 498 // get the position of the sun bassed on our current time...
499 tCurrent = time( NULL ); 499 tCurrent = time( NULL );
500 pTm = gmtime( &tCurrent ); 500 pTm = gmtime( &tCurrent );
501 dJulian = jtime( pTm ); 501 dJulian = jtime( pTm );
502 sunpos( dJulian, 0, &dSunRad, &dSunDecl, &dSunRadius, &dSunLong ); 502 sunpos( dJulian, 0, &dSunRad, &dSunDecl, &dSunRadius, &dSunLong );
503 503
504 // now get the projected illumination 504 // now get the projected illumination
505 projillum( wtab, wImage, hImage, dSunDecl ); 505 projillum( wtab, wImage, hImage, dSunDecl );
506 relw = wImage - int( wImage * 0.0275 ); 506 relw = wImage - int( wImage * 0.0275 );
507 507
508 // draw the map, keeping in mind that we may go too far off the map... 508 // draw the map, keeping in mind that we may go too far off the map...
509 iMid = ( relw * ( 24*60 - pTm->tm_hour * 60 - pTm->tm_min ) ) / ( 24*60 ); 509 iMid = ( relw * ( 24*60 - pTm->tm_hour * 60 - pTm->tm_min ) ) / ( 24*60 );
510 510
511 for ( i = 0; i < hImage; i++ ) { 511 for ( i = 0; i < hImage; i++ ) {
512 if ( wtab[i] > 0 ) { 512 if ( wtab[i] > 0 ) {
513 iStart = iMid - wtab[i]; 513 iStart = iMid - wtab[i];
514 iStop = iMid + wtab[i]; 514 iStop = iMid + wtab[i];
515 if ( iStart < 0 ) { 515 if ( iStart < 0 ) {
516 darken( pImage, iStop, wImage + iStart, i ); 516 darken( pImage, iStop, wImage + iStart, i );
517 } else if ( iStop > wImage ) { 517 } else if ( iStop > wImage ) {
518 darken( pImage, iStop - wImage, iStart, i ); 518 darken( pImage, iStop - wImage, iStart, i );
519 } else { 519 } else {
520 darken( pImage, 0, iStart, i ); 520 darken( pImage, 0, iStart, i );
521 darken( pImage, iStop, wImage, i ); 521 darken( pImage, iStop, wImage, i );
522 } 522 }
523 } else { 523 } else {
524 darken( pImage, 0, wImage, i ); 524 darken( pImage, 0, wImage, i );
525 } 525 }
526 } 526 }
527} 527}
528 528
529static inline void darken( QImage *pImage, int start, int stop, int row ) 529static inline void darken( QImage *pImage, int start, int stop, int row )
530{ 530{
531 int colors, 531 int colors,
532 j; 532 j;
533 uchar *p; 533 uchar *p;
534 534
535 // assume that the image is similar to the one we have... 535 // assume that the image is similar to the one we have...
536 colors = pImage->numColors() / 2; 536 colors = pImage->numColors() / 2;
537 537
538 p = pImage->scanLine( row ); 538 p = pImage->scanLine( row );
539 for ( j = start; j <= stop; j++ ) { 539 for ( j = start; j <= stop; j++ ) {
540 if ( p[j] < colors ) 540 if ( p[j] < colors )
541 p[j] += colors; 541 p[j] += colors;
542 } 542 }
543} 543}
544 544
545void ZoneMap::makeMap( int w, int h ) 545void ZoneMap::makeMap( int w, int h )
546{ 546{
547 QImage imgOrig = Resource::loadImage( strMAP ); 547 QImage imgOrig = Resource::loadImage( strMAP );
548 if ( imgOrig.isNull() ) { 548 if ( imgOrig.isNull() ) {
549 QMessageBox::warning( this, 549 QMessageBox::warning( this,
550 tr( "Couldn't Find Map" ), 550 tr( "Couldn't Find Map" ),
551 tr( "<p>Couldn't load map: %1, exiting") 551 tr( "<p>Couldn't load map: %1, exiting")
552 .arg( strMAP ) ); 552 .arg( strMAP ) );
553 exit(-1); 553 exit(-1);
554 } 554 }
555 555
556 // set up the color table for darkening... 556 // set up the color table for darkening...
557 imgOrig = imgOrig.convertDepth( 8 ); 557 imgOrig = imgOrig.convertDepth( 8 );
558 int numColors = imgOrig.numColors(); 558 int numColors = imgOrig.numColors();
559 // double the colors 559 // double the colors
560 imgOrig.setNumColors( 2 * numColors ); 560 imgOrig.setNumColors( 2 * numColors );
561 // darken the new ones... 561 // darken the new ones...
562 for ( int i = 0; i < numColors; i++ ) { 562 for ( int i = 0; i < numColors; i++ ) {
563 QRgb rgb = imgOrig.color( i ); 563 QRgb rgb = imgOrig.color( i );
564 imgOrig.setColor ( i + numColors, qRgb( 2 * qRed( rgb ) / 3, 564 imgOrig.setColor ( i + numColors, qRgb( 2 * qRed( rgb ) / 3,
565 2 * qGreen( rgb ) / 3, 2 * qBlue( rgb ) / 3 ) ); 565 2 * qGreen( rgb ) / 3, 2 * qBlue( rgb ) / 3 ) );
566 } 566 }
567 567
568 // else go one with making the map... 568 // else go one with making the map...
569 if ( bIllum ) { 569 if ( bIllum ) {
570 // do a daylight mask 570 // do a daylight mask
571 dayNight(&imgOrig); 571 dayNight(&imgOrig);
572 } 572 }
573 // redo the width and height 573 // redo the width and height
574 wImg = w; 574 wImg = w;
575 hImg = h; 575 hImg = h;
576 ox = ( wImg / 2 ) - int( wImg * 0.0275 ); 576 ox = ( wImg / 2 ) - int( wImg * 0.0275 );
577 oy = hImg / 2; 577 oy = hImg / 2;
578 pixCurr->convertFromImage( imgOrig.smoothScale(w, h), 578 pixCurr->convertFromImage( imgOrig.smoothScale(w, h),
579 QPixmap::ThresholdDither ); 579 QPixmap::ThresholdDither );
580} 580}
581 581
582void ZoneMap::drawCity( QPainter *p, const ZoneField *pCity ) 582void ZoneMap::drawCity( QPainter *p, const ZoneField *pCity )
583{ 583{
584 int x, 584 int x,
585 y; 585 y;
586 586
587 p->setPen( red ); 587 p->setPen( red );
588 zoneToWin( pCity->x(), pCity->y(), x, y ); 588 zoneToWin( pCity->x(), pCity->y(), x, y );
589 p->drawRect( x - iCITYOFFSET, y - iCITYOFFSET, iCITYSIZE, iCITYSIZE ); 589 p->drawRect( x - iCITYOFFSET, y - iCITYOFFSET, iCITYSIZE, iCITYSIZE );
590} 590}
591 591
592void ZoneMap::drawContents( QPainter *p, int cx, int cy, int cw, int ch ) 592void ZoneMap::drawContents( QPainter *p, int cx, int cy, int cw, int ch )
593{ 593{
594 // if there is a need to resize, then do it... 594 // if there is a need to resize, then do it...
595 // get our drawable area 595 // get our drawable area
596 drawableW = width() - 2 * frameWidth(); 596 drawableW = width() - 2 * frameWidth();
597 drawableH = height() - 2 * frameWidth(); 597 drawableH = height() - 2 * frameWidth();
598 598
599 int pixmapW = pixCurr->width(), 599 int pixmapW = pixCurr->width(),
600 pixmapH = pixCurr->height(); 600 pixmapH = pixCurr->height();
601 if ( !bZoom && ( ( pixmapW != drawableW ) || 601 if ( !bZoom && ( ( pixmapW != drawableW ) ||
602 ( pixmapH != drawableH) ) ) { 602 ( pixmapH != drawableH) ) ) {
603 makeMap( drawableW, drawableH ); 603 makeMap( drawableW, drawableH );
604 } 604 }
605 605
606 // taken from the scrollview example... 606 // taken from the scrollview example...
607 int rowheight = pixCurr->height(); 607 int rowheight = pixCurr->height();
608 int toprow = cy / rowheight; 608 int toprow = cy / rowheight;
609 int bottomrow = ( cy + ch + rowheight - 1 ) / rowheight; 609 int bottomrow = ( cy + ch + rowheight - 1 ) / rowheight;
610 int colwidth = pixCurr->width(); 610 int colwidth = pixCurr->width();
611 int leftcol= cx / colwidth; 611 int leftcol= cx / colwidth;
612 int rightcol= ( cx + cw + colwidth - 1 ) / colwidth; 612 int rightcol= ( cx + cw + colwidth - 1 ) / colwidth;
613 for ( int r = toprow; r <= bottomrow; r++ ) { 613 for ( int r = toprow; r <= bottomrow; r++ ) {
614 int py = r * rowheight; 614 int py = r * rowheight;
615 for ( int c = leftcol; c <= rightcol; c++ ) { 615 for ( int c = leftcol; c <= rightcol; c++ ) {
616 int px = c * colwidth; 616 int px = c * colwidth;
617 p->drawPixmap( px, py, *pixCurr ); 617 p->drawPixmap( px, py, *pixCurr );
618 } 618 }
619 } 619 }
620 620
621 // Draw that city! 621 // Draw that city!
622 if ( pLast ) 622 if ( pLast )
623 drawCity( p, pLast ); 623 drawCity( p, pLast );
624} 624}
625 625
626void ZoneMap::slotZoom( bool setZoom ) 626void ZoneMap::slotZoom( bool setZoom )
627{ 627{
628 bZoom = setZoom; 628 bZoom = setZoom;
629 if ( bZoom ) { 629 if ( bZoom ) {
630 makeMap( 2 * wImg , 2 * hImg ); 630 makeMap( 2 * wImg , 2 * hImg );
631 resizeContents( wImg, hImg ); 631 resizeContents( wImg, hImg );
632 } else { 632 } else {
633 makeMap( drawableW, drawableH ); 633 makeMap( drawableW, drawableH );
634 resizeContents( drawableW, drawableH ); 634 resizeContents( drawableW, drawableH );
635 } 635 }
636} 636}
637 637
638void ZoneMap::slotIllum( bool setIllum ) 638void ZoneMap::slotIllum( bool setIllum )
639{ 639{
640 bIllum = !setIllum; 640 bIllum = !setIllum;
641 // make the map... 641 // make the map...
642 makeMap( pixCurr->width(), pixCurr->height() ); 642 makeMap( pixCurr->width(), pixCurr->height() );
643 updateContents( 0, 0, wImg, hImg ); 643 updateContents( 0, 0, wImg, hImg );
644} 644}
645 645
646void ZoneMap::slotUpdate( void ) 646void ZoneMap::slotUpdate( void )
647{ 647{
648 // recalculate the light, most people will never see this, 648 // recalculate the light, most people will never see this,
649 // but it is good to be complete 649 // but it is good to be complete
650 makeMap ( pixCurr->width(), pixCurr->height() ); 650 makeMap ( pixCurr->width(), pixCurr->height() );
651 updateContents( contentsX(), contentsY(), drawableW, drawableH ); 651 updateContents( contentsX(), contentsY(), drawableW, drawableH );
652} 652}
653 653
654void ZoneMap::slotRedraw( void ) 654void ZoneMap::slotRedraw( void )
655{ 655{
656 // paint over that pesky city... 656 // paint over that pesky city...
657 int x, 657 int x,
658 y; 658 y;
659 if ( pRepaint ) { 659 if ( pRepaint ) {
660 pLast = 0; 660 pLast = 0;
661 zoneToWin(pRepaint->x(), pRepaint->y(), x, y); 661 zoneToWin(pRepaint->x(), pRepaint->y(), x, y);
662 updateContents( x - iCITYOFFSET, y - iCITYOFFSET, iCITYSIZE, iCITYSIZE); 662 updateContents( x - iCITYOFFSET, y - iCITYOFFSET, iCITYSIZE, iCITYSIZE);
663 pRepaint = 0; 663 pRepaint = 0;
664 } 664 }
665} 665}
666 666
667void ZoneMap::changeClock( bool whichClock ) 667void ZoneMap::changeClock( bool whichClock )
668{ 668{
669 ampm = whichClock; 669 ampm = whichClock;
670} 670}
diff --git a/pics/simple_grid_400.png b/pics/simple_grid_400.png
deleted file mode 100644
index 5e0e21d..0000000
--- a/pics/simple_grid_400.png
+++ b/dev/null
Binary files differ