import gconf
-import hildon , gtk
+import gtk
+try :
+ import hildon
+except :
+ hildon = False
class Configuration :
- def __init__ ( self ) :
- self.homedir = None
- self.dbname = None
- self.mapsdir , self.mapclass = None , None
- self.lat , self.lon = 0.0 , 0.0
- self.zoom = 0
+ def __init__ ( self , type ) :
+ self._type = type
self.read()
def read ( self ) :
client = gconf.client_get_default()
+
self.homedir = client.get_string( "/apps/wifihood/basedir" ) or "/home/user/MyDocs"
self.dbname = client.get_string( "/apps/wifihood/dbname" ) or "wifiscanner.db"
self.mapsdir = client.get_string( "/apps/wifihood/maps" ) or "/home/user/MyDocs/.maps"
self.mapclass = client.get_string( "/apps/wifihood/maptype" ) or "OpenStreetMap I"
- self.lat = client.get_float( "/apps/wifihood/lattitude" ) or client.get_float( "/apps/maemo/maemo-mapper/center_latitude" ) or 40.416
- self.lon = client.get_float( "/apps/wifihood/longitude" ) or client.get_float( "/apps/maemo/maemo-mapper/center_longitude" ) or -3.683
- self.zoom = client.get_int( "/apps/wifihood/zoom" ) or client.get_float( "/apps/maemo/maemo-mapper/zoom" ) or 15
- def save ( self ) :
+ self.scan_period = client.get_float( "/apps/wifihood/scan-period" ) or 5
+
+ self.store_log = client.get_bool( "/apps/wifihood/store-logfile" )
+
+ self.use_mapper = client.get_bool( "/apps/wifihood/use-mapper" )
+ self.store_gps = client.get_bool( "/apps/wifihood/store-gps" )
+ if self.use_mapper :
+ # FIXME : This will reset the stored default
+ self.store_gps = False
+ self.lat = client.get_float( "/apps/maemo/maemo-mapper/center_latitude" )
+ self.lon = client.get_float( "/apps/maemo/maemo-mapper/center_longitude" )
+ self.zoom = client.get_int( "/apps/maemo/maemo-mapper/zoom" )
+ else :
+ self.lat = client.get_float( "/apps/wifihood/latitude" )
+ self.lon = client.get_float( "/apps/wifihood/longitude" )
+ self.zoom = client.get_int( "/apps/wifihood/map-zoom" )
+
+ if self._type == 'scanner' :
+ self.zoom = client.get_int( "/apps/wifihood/%s-zoom" % self._type )
+
+ if self.lat == 0.0 and self.lon == 0.0 :
+ self.lat , self.lon = 40.416 , -3.683
+ if self.zoom == 0 :
+ self.zoom = 15
+
+ def set_latlon ( self , ( lat , lon ) ) :
+ if self.store_gps :
+ client = gconf.client_get_default()
+ client.set_float( "/apps/wifihood/latitude" , lat )
+ client.set_float( "/apps/wifihood/longitude" , lon )
+ self.lat , self.lon = lat , lon
+
+ def set_zoom ( self , zoom ) :
+ if self.store_gps or self._type == 'scanner' :
+ client = gconf.client_get_default()
+ client.set_int( "/apps/wifihood/%s-zoom" % self._type , zoom )
+ self.zoom = zoom
+
+ def save ( self , widget=None ) :
+ """Saves all the editable configuration elements"""
+
client = gconf.client_get_default()
client.set_string( "/apps/wifihood/basedir" , self.homedir )
client.set_string( "/apps/wifihood/dbname" , self.dbname )
- client.set_string( "/apps/wifihood/maps" , self.mapsdir )
- client.set_string( "/apps/wifihood/maptype" , self.mapclass )
- client.set_float( "/apps/wifihood/lattitude" , self.lat )
- client.set_float( "/apps/wifihood/longitude" , self.lon )
- client.set_int( "/apps/wifihood/zoom" , self.zoom )
+ client.set_float( "/apps/wifihood/scan-period" , self.scan_period )
+ client.set_bool( "/apps/wifihood/store-logfile" , self.store_log )
+ client.set_bool( "/apps/wifihood/use-mapper" , self.use_mapper )
+ client.set_bool( "/apps/wifihood/store-gps" , self.store_gps )
-class SettingsWindow ( hildon.StackableWindow ) :
+ client.set_int( "/apps/wifihood/%s-zoom" % self._type , self.zoom )
- def __init__ ( self , config ) :
- hildon.StackableWindow.__init__( self )
+class AbstractSettingsWindow :
+
+ def __init__ ( self , config , handler ) :
self.set_title( "Wifihood Settings" )
- scrollwin = gtk.ScrolledWindow(None, None)
- scrollwin.set_policy(gtk.POLICY_NEVER, gtk.POLICY_AUTOMATIC)
+ scrollwin = self.MainArea()
scrollwin.show()
self.add(scrollwin)
dblabel.show()
database.attach(dblabel, 0, 1, 0, 1, gtk.EXPAND|gtk.FILL, 0, 0, 5)
- dbvalue = hildon.Entry( gtk.HILDON_SIZE_FINGER_HEIGHT )
+ dbvalue = self.Entry()
+ dbvalue.connect( "changed" , self.entry_cb , config , "basedir" )
dbvalue.set_text( config.homedir )
dbvalue.show()
database.attach(dbvalue, 1, 2, 0, 1, gtk.EXPAND|gtk.FILL, 0, 0, 5)
dblabel.show()
database.attach(dblabel, 0, 1, 1, 2, gtk.EXPAND|gtk.FILL, 0, 0, 5)
- dbvalue = hildon.Entry( gtk.HILDON_SIZE_FINGER_HEIGHT )
+ dbvalue = self.Entry()
+ dbvalue.connect( "changed" , self.entry_cb , config , "dbname" )
dbvalue.set_text( config.dbname )
dbvalue.show()
database.attach(dbvalue, 1, 2, 1, 2, gtk.EXPAND|gtk.FILL, 0, 0, 5)
maps.show()
mapsframe.add(maps)
- button = hildon.CheckButton( gtk.HILDON_SIZE_FINGER_HEIGHT )
+ button = self.CheckButton()
button.set_label( "Use OpenStreet maps" )
button.set_active( 1 )
button.show()
maps.attach(button, 0, 1, 0, 1, gtk.EXPAND|gtk.FILL, 0, 0, 5)
- zoomlevel = hildon.Button( gtk.HILDON_SIZE_THUMB_HEIGHT , hildon.BUTTON_ARRANGEMENT_HORIZONTAL )
- zoomlevel.set_label( "Zoom level %d" % config.zoom )
- zoomlevel.connect_object( "activate", self.zoomdialog, config )
+ zoomlevel = self.ZoomButton( "Zoom level" , config , handler )
zoomlevel.show()
maps.attach(zoomlevel, 1, 2, 0, 1, gtk.EXPAND|gtk.FILL, 0, 0, 5)
gps.show()
gpsframe.add(gps)
- button = hildon.CheckButton( gtk.HILDON_SIZE_FINGER_HEIGHT )
+ button = self.CheckButton()
button.set_label( "Take initial coordinates from maemo-mapper" )
+ button.connect( "toggled" , self.checkbutton_cb , config , "use_mapper" )
+ button.set_active( config.use_mapper )
button.show()
gps.attach(button, 0, 2, 0, 1, gtk.EXPAND|gtk.FILL) #, 0, 0, 5)
- button = hildon.CheckButton( gtk.HILDON_SIZE_FINGER_HEIGHT )
+ button = self.CheckButton()
button.set_label( "Store changes in coordinates" )
+ button.connect( "toggled" , self.checkbutton_cb , config , "store_gps" )
+ button.set_active( config.store_gps )
button.show()
gps.attach(button, 0, 2, 1, 2, gtk.EXPAND|gtk.FILL) #, 0, 0, 5)
dataframe.show()
vbox.pack_start(dataframe, True, True, 0)
- button = hildon.CheckButton( gtk.HILDON_SIZE_FINGER_HEIGHT )
+ datatable = gtk.Table(2, 2, False)
+ datatable.show()
+ dataframe.add(datatable)
+
+ scanlabel = gtk.Label( "Scanning interval" )
+ scanlabel.show()
+ datatable.attach(scanlabel, 0, 1, 0, 1, gtk.EXPAND|gtk.FILL)
+
+ scanvalue = self.Entry()
+ scanvalue.connect( "changed" , self.float_cb , config , "scan-period" )
+ scanvalue.set_text( "%s" % config.scan_period )
+ scanvalue.show()
+ datatable.attach(scanvalue, 1, 2, 0, 1, gtk.EXPAND|gtk.FILL)
+
+ button = self.CheckButton()
button.set_label( "Write full logfile" )
+ button.connect( "toggled" , self.checkbutton_cb , config , "store_log" )
+ button.set_active( config.store_log )
button.show()
- dataframe.add(button)
+ datatable.attach(button, 0, 2, 1, 2, gtk.EXPAND|gtk.FILL)
self.show()
- def zoomdialog ( self , widget ) :
- dialog = ZoomDialog( widget )
- dialog.show_all()
+ def entry_cb ( self , entry , config , keyword ) :
+ config.__dict__[ keyword ] = entry.get_text()
-class ZoomDialog ( hildon.TouchSelector ) :
+ def float_cb ( self , entry , config , keyword ) :
+ config.__dict__[ keyword ] = float( entry.get_text() )
- def __init__ ( self , widget ) :
+ def int_cb ( self , entry , config , keyword , scale=1 ) :
+ config.__dict__[ keyword ] = int( scale * float( entry.get_text() ) )
+
+ def checkbutton_cb ( self , button , config , keyword ) :
+ config.__dict__[ keyword ] = button.get_active()
+
+if hildon :
+
+ class ZoomDialog ( hildon.TouchSelector ) :
+
+ def __init__ ( self , config , handler ) :
hildon.TouchSelector.__init__( self )
+ self.handler = handler
zooms = gtk.ListStore(str)
for zoom in range(8,19) :
iter = zooms.append()
zooms.set( iter , 0 , "%2d" % zoom )
- if zoom == widget.conf.zoom :
+ if zoom == config.zoom :
active = index
index += 1
column = self.append_text_column( zooms , True )
- #renderer = gtk.CellRendererText()
- #column = self.append_column( zooms , renderer )
- #column.set_property('text-column', 0)
# NOTE : with text=True, we must use 1 instead of 0
self.set_active( 0 , active )
+ def zoomdialog ( self , widget , conf ) :
+ newzoom = int( widget.get_selector().get_current_text() )
+ if self.handler : self.handler( newzoom )
+ conf.set_zoom( newzoom )
+
+ class SettingsWindow ( hildon.StackableWindow , AbstractSettingsWindow ) :
+
+ def __init__ ( self , config , handler=None ) :
+ hildon.StackableWindow.__init__( self )
+ AbstractSettingsWindow.__init__( self , config , handler )
+
+ def ZoomButton ( self , text , config , handler ) :
+ selector = ZoomDialog( config , handler )
+ button = hildon.PickerButton( gtk.HILDON_SIZE_AUTO, hildon.BUTTON_ARRANGEMENT_VERTICAL)
+ button.set_title( text )
+ button.set_selector( selector )
+ button.connect_object( "value-changed", selector.zoomdialog , button , config )
+ return button
+
+ def MainArea ( self ) :
+ return hildon.PannableArea()
+
+ def Entry ( self ) :
+ return hildon.Entry( gtk.HILDON_SIZE_FINGER_HEIGHT )
+
+ def Button ( self , text , value ) :
+ return hildon.Button( gtk.HILDON_SIZE_THUMB_HEIGHT , hildon.BUTTON_ARRANGEMENT_HORIZONTAL , text , "%s" % value )
+
+ def CheckButton ( self ) :
+ return hildon.CheckButton( gtk.HILDON_SIZE_FINGER_HEIGHT )
+
+else :
+
+ class ZoomDialog ( gtk.Dialog ) :
+
+ def __init__ ( self , config , handler , labelsetter=None ) :
+ gtk.Dialog.__init__( self , "Select zoom level",
+ None,
+ gtk.DIALOG_MODAL,
+ ( gtk.STOCK_OK, gtk.RESPONSE_ACCEPT,
+ gtk.STOCK_CANCEL, gtk.RESPONSE_REJECT
+ )
+ )
+
+ zooms = gtk.ListStore(int)
+ combo = gtk.ComboBox( zooms )
+
+ for zoom in range(8,19) :
+ iter = zooms.append()
+ zooms.set( iter , 0 , zoom )
+ if zoom == config.zoom :
+ combo.set_active_iter( iter )
+
+ cell = gtk.CellRendererText()
+ combo.pack_start(cell, True)
+ combo.add_attribute(cell, 'text', 0)
+
+ self.vbox.pack_start(combo , True, True, 0)
+
+ self.connect_object( "response", self.response , combo , config , handler , labelsetter )
+
+ def response ( self , combo , response , config , handler , labelsetter ) :
+ if response == gtk.RESPONSE_ACCEPT :
+ item = combo.get_active_iter()
+ model = combo.get_model()
+ newzoom = model.get(item,0)[0]
+ if labelsetter : labelsetter( newzoom )
+ if handler : handler( newzoom )
+ config.set_zoom( newzoom )
+ self.destroy()
+
+ class SettingsWindow ( gtk.Window , AbstractSettingsWindow ) :
+
+ def __init__ ( self , config , handler=None ) :
+ gtk.Window.__init__( self )
+ AbstractSettingsWindow.__init__( self , config , handler )
+ self.connect("unrealize", config.save )
+
+ def MainArea ( self ) :
+ scrollwin = gtk.ScrolledWindow()
+ scrollwin.set_size_request(-1, 290)
+ scrollwin.set_policy(gtk.POLICY_NEVER, gtk.POLICY_AUTOMATIC)
+ return scrollwin
+
+ def Entry ( self ) :
+ return gtk.Entry()
+
+ def Button ( self , label=None ) :
+ return gtk.Button( label )
+
+ def zoomdialog ( self , widget , config , handler ) :
+ dialog = ZoomDialog( config , handler , widget.set_value )
+ dialog.show_all()
+
+ def ZoomButton ( self , text , config , handler ) :
+ class _button ( gtk.Button ) :
+ def __init__ ( self , text , value ) :
+ gtk.Button.__init__( self )
+ self._text = text
+ self.set_value( value )
+ def set_value ( self , value ) :
+ self._value = value
+ self.set_label( "%s -- %s" % ( self._text , self._value ) )
+ button = _button( text , config.zoom )
+ button.connect_object( "clicked", self.zoomdialog , button , config , handler )
+ return button
+
+ def CheckButton ( self ) :
+ return gtk.CheckButton()
+
if __name__ == "__main__" :
- window = SettingsWindow( Configuration() )
+ config = Configuration( 'scanner' )
+ window = SettingsWindow( config )
window.connect("delete_event", gtk.main_quit, None)
window.show()
gtk.main()