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 self.lat = client.get_float( "/apps/maemo/maemo-mapper/center_latitude" )
32 self.lon = client.get_float( "/apps/maemo/maemo-mapper/center_longitude" )
33 self.zoom = client.get_int( "/apps/maemo/maemo-mapper/zoom" )
35 self.lat = client.get_float( "/apps/wifihood/latitude" )
36 self.lon = client.get_float( "/apps/wifihood/longitude" )
37 self.zoom = client.get_int( "/apps/wifihood/map-zoom" )
39 if self._type == 'scanner' :
40 self.zoom = client.get_int( "/apps/wifihood/%s-zoom" % self._type )
42 if self.lat == 0.0 and self.lon == 0.0 :
43 self.lat , self.lon = 40.416 , -3.683
47 def set_latlon ( self , ( lat , lon ) ) :
48 if self.store_gps and not self.use_mapper :
49 client = gconf.client_get_default()
50 client.set_float( "/apps/wifihood/latitude" , lat )
51 client.set_float( "/apps/wifihood/longitude" , lon )
52 self.lat , self.lon = lat , lon
54 def set_zoom ( self , zoom ) :
55 if self._type == 'scanner' or ( self.store_gps and not self.use_mapper ) :
56 client = gconf.client_get_default()
57 client.set_int( "/apps/wifihood/%s-zoom" % self._type , zoom )
60 def save ( self , widget=None ) :
61 """Saves all the editable configuration elements"""
63 client = gconf.client_get_default()
64 client.set_string( "/apps/wifihood/basedir" , self.homedir )
65 client.set_string( "/apps/wifihood/dbname" , self.dbname )
67 client.set_float( "/apps/wifihood/scan-period" , self.scan_period )
68 client.set_bool( "/apps/wifihood/store-logfile" , self.store_log )
69 client.set_bool( "/apps/wifihood/use-mapper" , self.use_mapper )
70 client.set_bool( "/apps/wifihood/store-gps" , self.store_gps )
72 client.set_int( "/apps/wifihood/%s-zoom" % self._type , self.zoom )
74 class AbstractSettingsWindow :
76 def __init__ ( self , config , handler ) :
77 self.set_title( "Wifihood Settings" )
79 scrollwin = self.MainArea()
83 vbox = gtk.VBox(False, 0)
85 scrollwin.add_with_viewport( vbox )
87 self.add_dataframe( vbox , config )
88 self.add_mapsframe( vbox , config , handler )
89 self.add_coordsframe( vbox , config )
90 self.add_dbframe( vbox , config )
95 def add_dbframe ( self , vbox , config ) :
97 dbframe = gtk.Frame( label="Database" )
98 dbframe.set_label_align(0 , 0.1)
100 vbox.pack_start(dbframe, True, True, 0)
102 database = gtk.Table(2, 2, False)
104 dbframe.add(database)
106 dblabel = gtk.Label( "Home directory" )
108 database.attach(dblabel, 0, 1, 0, 1, gtk.EXPAND|gtk.FILL, 0, 0, 5)
110 dbvalue = self.Entry()
111 dbvalue.connect( "changed" , self.entry_cb , config , "basedir" )
112 dbvalue.set_text( config.homedir )
114 database.attach(dbvalue, 1, 2, 0, 1, gtk.EXPAND|gtk.FILL, 0, 0, 5)
116 dblabel = gtk.Label( "Database name" )
118 database.attach(dblabel, 0, 1, 1, 2, gtk.EXPAND|gtk.FILL, 0, 0, 5)
120 dbvalue = self.Entry()
121 dbvalue.connect( "changed" , self.entry_cb , config , "dbname" )
122 dbvalue.set_text( config.dbname )
124 database.attach(dbvalue, 1, 2, 1, 2, gtk.EXPAND|gtk.FILL, 0, 0, 5)
127 def add_mapsframe ( self , vbox , config , handler ) :
129 mapsframe = gtk.Frame( label="Maps" )
130 mapsframe.set_label_align(0 , 0.1)
132 vbox.pack_start(mapsframe, True, True, 0)
134 maps = gtk.Table(2, 2, False)
138 button = self.CheckButton()
139 button.set_label( "Use OpenStreet maps" )
140 button.set_active( 1 )
142 maps.attach(button, 0, 1, 0, 1, gtk.EXPAND|gtk.FILL, 0, 0, 5)
144 zoomlevel = self.ZoomButton( "Zoom level" , config , handler )
146 maps.attach(zoomlevel, 1, 2, 0, 1, gtk.EXPAND|gtk.FILL, 0, 0, 5)
149 def add_coordsframe ( self , vbox , config ) :
151 gpsframe = gtk.Frame( label="Coordinates" )
152 gpsframe.set_label_align(0 , 0.1)
154 vbox.pack_start(gpsframe, True, True, 0)
156 gps = gtk.Table(2, 2, False)
160 button = self.CheckButton()
161 button.set_label( "Take initial coordinates from maemo-mapper" )
162 button.connect( "toggled" , self.checkbutton_cb , config , "use_mapper" )
163 button.set_active( config.use_mapper )
165 gps.attach(button, 0, 2, 0, 1, gtk.EXPAND|gtk.FILL) #, 0, 0, 5)
167 button = self.CheckButton()
168 button.set_label( "Store changes in coordinates" )
169 button.connect( "toggled" , self.checkbutton_cb , config , "store_gps" )
170 button.set_active( config.store_gps )
172 gps.attach(button, 0, 2, 1, 2, gtk.EXPAND|gtk.FILL) #, 0, 0, 5)
175 def add_dataframe ( self , vbox , config ) :
177 dataframe = gtk.Frame( label="Data gathering" )
178 dataframe.set_label_align(0 , 0.1)
180 vbox.pack_start(dataframe, True, True, 0)
182 datatable = gtk.Table(2, 2, False)
184 dataframe.add(datatable)
186 scanlabel = gtk.Label( "Scanning interval" )
188 datatable.attach(scanlabel, 0, 1, 0, 1, gtk.EXPAND|gtk.FILL)
190 scanvalue = self.Entry()
191 scanvalue.connect( "changed" , self.float_cb , config , "scan-period" )
192 scanvalue.set_text( "%s" % config.scan_period )
194 datatable.attach(scanvalue, 1, 2, 0, 1, gtk.EXPAND|gtk.FILL)
196 button = self.CheckButton()
197 button.set_label( "Write full logfile" )
198 button.connect( "toggled" , self.checkbutton_cb , config , "store_log" )
199 button.set_active( config.store_log )
201 datatable.attach(button, 0, 2, 1, 2, gtk.EXPAND|gtk.FILL)
203 def entry_cb ( self , entry , config , keyword ) :
204 config.__dict__[ keyword ] = entry.get_text()
206 def float_cb ( self , entry , config , keyword ) :
207 config.__dict__[ keyword ] = float( entry.get_text() )
209 def int_cb ( self , entry , config , keyword , scale=1 ) :
210 config.__dict__[ keyword ] = int( scale * float( entry.get_text() ) )
212 def checkbutton_cb ( self , button , config , keyword ) :
213 config.__dict__[ keyword ] = button.get_active()
217 class ZoomDialog ( hildon.TouchSelector ) :
219 def __init__ ( self , config , handler ) :
220 hildon.TouchSelector.__init__( self )
221 self.handler = handler
223 zooms = gtk.ListStore(str)
226 for zoom in range(8,19) :
227 iter = zooms.append()
228 zooms.set( iter , 0 , "%2d" % zoom )
229 if zoom == config.zoom :
233 column = self.append_text_column( zooms , True )
235 # NOTE : with text=True, we must use 1 instead of 0
236 self.set_active( 0 , active )
238 def zoomdialog ( self , widget , conf ) :
239 newzoom = int( widget.get_selector().get_current_text() )
240 if self.handler : self.handler( newzoom )
241 conf.set_zoom( newzoom )
243 class SettingsWindow ( hildon.StackableWindow , AbstractSettingsWindow ) :
245 def __init__ ( self , config , handler=None ) :
246 hildon.StackableWindow.__init__( self )
247 AbstractSettingsWindow.__init__( self , config , handler )
249 def ZoomButton ( self , text , config , handler ) :
250 selector = ZoomDialog( config , handler )
251 button = hildon.PickerButton( gtk.HILDON_SIZE_AUTO, hildon.BUTTON_ARRANGEMENT_VERTICAL)
252 button.set_title( text )
253 button.set_selector( selector )
254 button.connect_object( "value-changed", selector.zoomdialog , button , config )
257 def MainArea ( self ) :
258 return hildon.PannableArea()
261 return hildon.Entry( gtk.HILDON_SIZE_FINGER_HEIGHT )
263 def Button ( self , text , value ) :
264 return hildon.Button( gtk.HILDON_SIZE_THUMB_HEIGHT , hildon.BUTTON_ARRANGEMENT_HORIZONTAL , text , "%s" % value )
266 def CheckButton ( self ) :
267 return hildon.CheckButton( gtk.HILDON_SIZE_FINGER_HEIGHT )
271 class ZoomDialog ( gtk.Dialog ) :
273 def __init__ ( self , config , handler , labelsetter=None ) :
274 gtk.Dialog.__init__( self , "Select zoom level",
277 ( gtk.STOCK_OK, gtk.RESPONSE_ACCEPT,
278 gtk.STOCK_CANCEL, gtk.RESPONSE_REJECT
282 zooms = gtk.ListStore(int)
283 combo = gtk.ComboBox( zooms )
285 for zoom in range(8,19) :
286 iter = zooms.append()
287 zooms.set( iter , 0 , zoom )
288 if zoom == config.zoom :
289 combo.set_active_iter( iter )
291 cell = gtk.CellRendererText()
292 combo.pack_start(cell, True)
293 combo.add_attribute(cell, 'text', 0)
295 self.vbox.pack_start(combo , True, True, 0)
297 self.connect_object( "response", self.response , combo , config , handler , labelsetter )
299 def response ( self , combo , response , config , handler , labelsetter ) :
300 if response == gtk.RESPONSE_ACCEPT :
301 item = combo.get_active_iter()
302 model = combo.get_model()
303 newzoom = model.get(item,0)[0]
304 if labelsetter : labelsetter( newzoom )
305 if handler : handler( newzoom )
306 config.set_zoom( newzoom )
309 class SettingsWindow ( gtk.Window , AbstractSettingsWindow ) :
311 def __init__ ( self , config , handler=None ) :
312 gtk.Window.__init__( self )
313 AbstractSettingsWindow.__init__( self , config , handler )
314 self.connect("unrealize", config.save )
316 def MainArea ( self ) :
317 scrollwin = gtk.ScrolledWindow()
318 scrollwin.set_size_request(-1, 290)
319 scrollwin.set_policy(gtk.POLICY_NEVER, gtk.POLICY_AUTOMATIC)
325 def Button ( self , label=None ) :
326 return gtk.Button( label )
328 def zoomdialog ( self , widget , config , handler ) :
329 dialog = ZoomDialog( config , handler , widget.set_value )
332 def ZoomButton ( self , text , config , handler ) :
333 class _button ( gtk.Button ) :
334 def __init__ ( self , text , value ) :
335 gtk.Button.__init__( self )
337 self.set_value( value )
338 def set_value ( self , value ) :
340 self.set_label( "%s -- %s" % ( self._text , self._value ) )
341 button = _button( text , config.zoom )
342 button.connect_object( "clicked", self.zoomdialog , button , config , handler )
345 def CheckButton ( self ) :
346 return gtk.CheckButton()
348 if __name__ == "__main__" :
349 config = Configuration( 'scanner' )
350 window = SettingsWindow( config )
351 window.connect("delete_event", gtk.main_quit, None)