12 def __init__ ( self , type ) :
17 client = gconf.client_get_default()
19 self.homedir = client.get_string( "/apps/wifihood/basedir" ) or "/home/user/MyDocs"
20 self.dbname = client.get_string( "/apps/wifihood/dbname" ) or "wifiscanner.db"
21 self.mapsdir = client.get_string( "/apps/wifihood/maps" ) or "/home/user/MyDocs/.maps"
22 self.mapclass = client.get_string( "/apps/wifihood/maptype" ) or "OpenStreetMap I"
24 self.scan_period = client.get_float( "/apps/wifihood/scan-period" ) or 5
26 self.store_log = client.get_bool( "/apps/wifihood/store-logfile" )
28 self.use_mapper = client.get_bool( "/apps/wifihood/use-mapper" )
29 self.store_gps = client.get_bool( "/apps/wifihood/store-gps" )
31 # FIXME : This will reset the stored default
32 self.lat = client.get_float( "/apps/maemo/maemo-mapper/center_latitude" )
33 self.lon = client.get_float( "/apps/maemo/maemo-mapper/center_longitude" )
34 self.zoom = client.get_int( "/apps/maemo/maemo-mapper/zoom" )
36 self.lat = client.get_float( "/apps/wifihood/latitude" )
37 self.lon = client.get_float( "/apps/wifihood/longitude" )
38 self.zoom = client.get_int( "/apps/wifihood/map-zoom" )
40 if self._type == 'scanner' :
41 self.zoom = client.get_int( "/apps/wifihood/%s-zoom" % self._type )
43 if self.lat == 0.0 and self.lon == 0.0 :
44 self.lat , self.lon = 40.416 , -3.683
48 def set_latlon ( self , ( lat , lon ) ) :
49 if self.store_gps and not self.use_mapper :
50 client = gconf.client_get_default()
51 client.set_float( "/apps/wifihood/latitude" , lat )
52 client.set_float( "/apps/wifihood/longitude" , lon )
53 self.lat , self.lon = lat , lon
55 def set_zoom ( self , zoom ) :
56 if self._type == 'scanner' or ( self.store_gps and not self.use_mapper ) :
57 client = gconf.client_get_default()
58 client.set_int( "/apps/wifihood/%s-zoom" % self._type , zoom )
61 def save ( self , widget=None ) :
62 """Saves all the editable configuration elements"""
64 client = gconf.client_get_default()
65 client.set_string( "/apps/wifihood/basedir" , self.homedir )
66 client.set_string( "/apps/wifihood/dbname" , self.dbname )
68 client.set_float( "/apps/wifihood/scan-period" , self.scan_period )
69 client.set_bool( "/apps/wifihood/store-logfile" , self.store_log )
70 client.set_bool( "/apps/wifihood/use-mapper" , self.use_mapper )
71 client.set_bool( "/apps/wifihood/store-gps" , self.store_gps )
73 client.set_int( "/apps/wifihood/%s-zoom" % self._type , self.zoom )
75 class AbstractSettingsWindow :
77 def __init__ ( self , config , handler ) :
78 self.set_title( "Wifihood Settings" )
80 scrollwin = self.MainArea()
84 vbox = gtk.VBox(False, 0)
86 scrollwin.add_with_viewport( vbox )
89 dbframe = gtk.Frame( label="Database" )
90 dbframe.set_label_align(0 , 0.1)
92 vbox.pack_start(dbframe, True, True, 0)
94 database = gtk.Table(2, 2, False)
98 dblabel = gtk.Label( "Home directory" )
100 database.attach(dblabel, 0, 1, 0, 1, gtk.EXPAND|gtk.FILL, 0, 0, 5)
102 dbvalue = self.Entry()
103 dbvalue.connect( "changed" , self.entry_cb , config , "basedir" )
104 dbvalue.set_text( config.homedir )
106 database.attach(dbvalue, 1, 2, 0, 1, gtk.EXPAND|gtk.FILL, 0, 0, 5)
108 dblabel = gtk.Label( "Database name" )
110 database.attach(dblabel, 0, 1, 1, 2, gtk.EXPAND|gtk.FILL, 0, 0, 5)
112 dbvalue = self.Entry()
113 dbvalue.connect( "changed" , self.entry_cb , config , "dbname" )
114 dbvalue.set_text( config.dbname )
116 database.attach(dbvalue, 1, 2, 1, 2, gtk.EXPAND|gtk.FILL, 0, 0, 5)
119 mapsframe = gtk.Frame( label="Maps" )
120 mapsframe.set_label_align(0 , 0.1)
122 vbox.pack_start(mapsframe, True, True, 0)
124 maps = gtk.Table(2, 2, False)
128 button = self.CheckButton()
129 button.set_label( "Use OpenStreet maps" )
130 button.set_active( 1 )
132 maps.attach(button, 0, 1, 0, 1, gtk.EXPAND|gtk.FILL, 0, 0, 5)
134 zoomlevel = self.ZoomButton( "Zoom level" , config , handler )
136 maps.attach(zoomlevel, 1, 2, 0, 1, gtk.EXPAND|gtk.FILL, 0, 0, 5)
139 gpsframe = gtk.Frame( label="Coordinates" )
140 gpsframe.set_label_align(0 , 0.1)
142 vbox.pack_start(gpsframe, True, True, 0)
144 gps = gtk.Table(2, 2, False)
148 button = self.CheckButton()
149 button.set_label( "Take initial coordinates from maemo-mapper" )
150 button.connect( "toggled" , self.checkbutton_cb , config , "use_mapper" )
151 button.set_active( config.use_mapper )
153 gps.attach(button, 0, 2, 0, 1, gtk.EXPAND|gtk.FILL) #, 0, 0, 5)
155 button = self.CheckButton()
156 button.set_label( "Store changes in coordinates" )
157 button.connect( "toggled" , self.checkbutton_cb , config , "store_gps" )
158 button.set_active( config.store_gps )
160 gps.attach(button, 0, 2, 1, 2, gtk.EXPAND|gtk.FILL) #, 0, 0, 5)
163 dataframe = gtk.Frame( label="Data gathering" )
164 dataframe.set_label_align(0 , 0.1)
166 vbox.pack_start(dataframe, True, True, 0)
168 datatable = gtk.Table(2, 2, False)
170 dataframe.add(datatable)
172 scanlabel = gtk.Label( "Scanning interval" )
174 datatable.attach(scanlabel, 0, 1, 0, 1, gtk.EXPAND|gtk.FILL)
176 scanvalue = self.Entry()
177 scanvalue.connect( "changed" , self.float_cb , config , "scan-period" )
178 scanvalue.set_text( "%s" % config.scan_period )
180 datatable.attach(scanvalue, 1, 2, 0, 1, gtk.EXPAND|gtk.FILL)
182 button = self.CheckButton()
183 button.set_label( "Write full logfile" )
184 button.connect( "toggled" , self.checkbutton_cb , config , "store_log" )
185 button.set_active( config.store_log )
187 datatable.attach(button, 0, 2, 1, 2, gtk.EXPAND|gtk.FILL)
191 def entry_cb ( self , entry , config , keyword ) :
192 config.__dict__[ keyword ] = entry.get_text()
194 def float_cb ( self , entry , config , keyword ) :
195 config.__dict__[ keyword ] = float( entry.get_text() )
197 def int_cb ( self , entry , config , keyword , scale=1 ) :
198 config.__dict__[ keyword ] = int( scale * float( entry.get_text() ) )
200 def checkbutton_cb ( self , button , config , keyword ) :
201 config.__dict__[ keyword ] = button.get_active()
205 class ZoomDialog ( hildon.TouchSelector ) :
207 def __init__ ( self , config , handler ) :
208 hildon.TouchSelector.__init__( self )
209 self.handler = handler
211 zooms = gtk.ListStore(str)
214 for zoom in range(8,19) :
215 iter = zooms.append()
216 zooms.set( iter , 0 , "%2d" % zoom )
217 if zoom == config.zoom :
221 column = self.append_text_column( zooms , True )
223 # NOTE : with text=True, we must use 1 instead of 0
224 self.set_active( 0 , active )
226 def zoomdialog ( self , widget , conf ) :
227 newzoom = int( widget.get_selector().get_current_text() )
228 if self.handler : self.handler( newzoom )
229 conf.set_zoom( newzoom )
231 class SettingsWindow ( hildon.StackableWindow , AbstractSettingsWindow ) :
233 def __init__ ( self , config , handler=None ) :
234 hildon.StackableWindow.__init__( self )
235 AbstractSettingsWindow.__init__( self , config , handler )
237 def ZoomButton ( self , text , config , handler ) :
238 selector = ZoomDialog( config , handler )
239 button = hildon.PickerButton( gtk.HILDON_SIZE_AUTO, hildon.BUTTON_ARRANGEMENT_VERTICAL)
240 button.set_title( text )
241 button.set_selector( selector )
242 button.connect_object( "value-changed", selector.zoomdialog , button , config )
245 def MainArea ( self ) :
246 return hildon.PannableArea()
249 return hildon.Entry( gtk.HILDON_SIZE_FINGER_HEIGHT )
251 def Button ( self , text , value ) :
252 return hildon.Button( gtk.HILDON_SIZE_THUMB_HEIGHT , hildon.BUTTON_ARRANGEMENT_HORIZONTAL , text , "%s" % value )
254 def CheckButton ( self ) :
255 return hildon.CheckButton( gtk.HILDON_SIZE_FINGER_HEIGHT )
259 class ZoomDialog ( gtk.Dialog ) :
261 def __init__ ( self , config , handler , labelsetter=None ) :
262 gtk.Dialog.__init__( self , "Select zoom level",
265 ( gtk.STOCK_OK, gtk.RESPONSE_ACCEPT,
266 gtk.STOCK_CANCEL, gtk.RESPONSE_REJECT
270 zooms = gtk.ListStore(int)
271 combo = gtk.ComboBox( zooms )
273 for zoom in range(8,19) :
274 iter = zooms.append()
275 zooms.set( iter , 0 , zoom )
276 if zoom == config.zoom :
277 combo.set_active_iter( iter )
279 cell = gtk.CellRendererText()
280 combo.pack_start(cell, True)
281 combo.add_attribute(cell, 'text', 0)
283 self.vbox.pack_start(combo , True, True, 0)
285 self.connect_object( "response", self.response , combo , config , handler , labelsetter )
287 def response ( self , combo , response , config , handler , labelsetter ) :
288 if response == gtk.RESPONSE_ACCEPT :
289 item = combo.get_active_iter()
290 model = combo.get_model()
291 newzoom = model.get(item,0)[0]
292 if labelsetter : labelsetter( newzoom )
293 if handler : handler( newzoom )
294 config.set_zoom( newzoom )
297 class SettingsWindow ( gtk.Window , AbstractSettingsWindow ) :
299 def __init__ ( self , config , handler=None ) :
300 gtk.Window.__init__( self )
301 AbstractSettingsWindow.__init__( self , config , handler )
302 self.connect("unrealize", config.save )
304 def MainArea ( self ) :
305 scrollwin = gtk.ScrolledWindow()
306 scrollwin.set_size_request(-1, 290)
307 scrollwin.set_policy(gtk.POLICY_NEVER, gtk.POLICY_AUTOMATIC)
313 def Button ( self , label=None ) :
314 return gtk.Button( label )
316 def zoomdialog ( self , widget , config , handler ) :
317 dialog = ZoomDialog( config , handler , widget.set_value )
320 def ZoomButton ( self , text , config , handler ) :
321 class _button ( gtk.Button ) :
322 def __init__ ( self , text , value ) :
323 gtk.Button.__init__( self )
325 self.set_value( value )
326 def set_value ( self , value ) :
328 self.set_label( "%s -- %s" % ( self._text , self._value ) )
329 button = _button( text , config.zoom )
330 button.connect_object( "clicked", self.zoomdialog , button , config , handler )
333 def CheckButton ( self ) :
334 return gtk.CheckButton()
336 if __name__ == "__main__" :
337 config = Configuration( 'scanner' )
338 window = SettingsWindow( config )
339 window.connect("delete_event", gtk.main_quit, None)