import gtk
import gobject , gconf
+try :
+ import hildon
+except :
+ hildon = False
import urllib2
import math
def __init__ ( self ) :
self.lat , self.lon = 40.40491 , -3.6774
self.zoom = 11
- self.mapsdir = "/home/user/MyDocs/.maps"
+ self.mapsdir = "/home/user/MyDocs/.maps"
self.client = gconf.client_get_default()
self.composeMap()
self.show()
+ def ZoomChange ( self , selector ) :
+ model = selector.get_model(0)
+ active = selector.get_active(0)
+ value = model.get( model.get_iter(active) , 0 )
+ self.SetZoom( value[0] )
+
def SetZoom( self , zoom ) :
self.hide()
lat = self.tiley2lat( ( self.reftile_y , self.refpix_y ) , self.zoom )
self.composeMap()
self.show()
-class ZoomDialog ( gtk.Dialog ) :
+if hildon :
+
+ class ZoomDialog ( hildon.TouchSelector ) :
+
+ def __init__ ( self , widget ) :
+ hildon.TouchSelector.__init__( self ) # , text=True )
+
+ zooms = gtk.ListStore(int,str)
+
+ active = index = 0
+ for zoom in range(8,19) :
+ iter = zooms.append()
+ zooms.set( iter , 0 , zoom , 1 , "Level %2d" % zoom )
+ if zoom == widget.zoom :
+ active = index
+ index += 1
+
+ renderer = gtk.CellRendererText()
+ column = self.append_column( zooms , renderer )
+ column.set_property('text-column', 1)
- def __init__ ( self , widget ) :
- gtk.Dialog.__init__( self , "Select zoom level",
- None,
- gtk.DIALOG_MODAL,
- ( gtk.STOCK_OK, gtk.RESPONSE_ACCEPT,
- gtk.STOCK_CANCEL, gtk.RESPONSE_REJECT
- )
- )
+ # NOTE : with text=True, we must use 1 instead of 0
+ self.set_active( 0 , active )
- zooms = gtk.ListStore(int)
- combo = gtk.ComboBox( zooms )
+else :
- for zoom in range(8,19) :
- iter = zooms.append()
- zooms.set( iter , 0 , zoom )
- if zoom == widget.zoom :
- combo.set_active_iter( iter )
+ class ZoomDialog ( gtk.Dialog ) :
- cell = gtk.CellRendererText()
- combo.pack_start(cell, True)
- combo.add_attribute(cell, 'text', 0)
+ def __init__ ( self , widget ) :
+ gtk.Dialog.__init__( self , "Select zoom level",
+ None,
+ gtk.DIALOG_MODAL,
+ ( gtk.STOCK_OK, gtk.RESPONSE_ACCEPT,
+ gtk.STOCK_CANCEL, gtk.RESPONSE_REJECT
+ )
+ )
- self.vbox.pack_start(combo , True, True, 0)
+ zooms = gtk.ListStore(int)
+ combo = gtk.ComboBox( zooms )
- self.connect_object( "response", self.response , combo , widget )
+ for zoom in range(8,19) :
+ iter = zooms.append()
+ zooms.set( iter , 0 , zoom )
+ if zoom == widget.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 , widget )
+
+ def response ( self , combo , response , widget ) :
+ if response == gtk.RESPONSE_ACCEPT :
+ item = combo.get_active_iter()
+ model = combo.get_model()
+ widget.SetZoom( model.get(item,0)[0] )
+ self.destroy()
- def response ( self , combo , response , widget ) :
- if response == gtk.RESPONSE_ACCEPT :
- item = combo.get_active_iter()
- model = combo.get_model()
- widget.SetZoom( model.get(item,0)[0] )
- self.destroy()
-
class MapWindow:
def __init__(self):
- self.window = gtk.Window(gtk.WINDOW_TOPLEVEL)
-
+ if hildon :
+ self.window = hildon.Window()
+ program = hildon.Program.get_instance()
+ program.add_window(self.window)
+ gtk.set_application_name( "Wifi View" )
+ else :
+ self.window = gtk.Window(gtk.WINDOW_TOPLEVEL)
+
self.window.connect("destroy", self.destroy)
self.window.set_border_width(10)
-
+
self.window.connect("key-press-event", self.on_key_press)
-
+
vbox = gtk.VBox(False, 0)
self.window.add( vbox )
#
self.map = mapWidget()
vbox.pack_end( self.map , True , True , 5)
-
+
self.create_menu( vbox )
# and the window
dialog.show_all()
def create_menu ( self , vbox ) :
- menubar = gtk.MenuBar()
+ if hildon :
+
+ self.menubar = menubar = hildon.AppMenu()
+
+ #zoomlevel = hildon.Button(gtk.HILDON_SIZE_AUTO,
+ # hildon.BUTTON_ARRANGEMENT_VERTICAL,
+ # "Zoom level", None)
+ #zoomlevel.connect_object( "clicked", self.zoomstack, self.map )
+ selector = ZoomDialog( self.map )
+ zoomlevel = hildon.PickerButton(gtk.HILDON_SIZE_AUTO,
+ hildon.BUTTON_ARRANGEMENT_VERTICAL)
+ zoomlevel.set_title( "Zoom" )
+ zoomlevel.set_selector( selector )
+ zoomlevel.connect_object( "value-changed", self.map.ZoomChange , selector )
+ menubar.append( zoomlevel )
+
+ menubar.show_all()
+ self.window.set_app_menu( menubar )
+
+ else :
+
+ menubar = gtk.MenuBar()
- zoomlevel = gtk.MenuItem( label="Zoom level" )
- zoomlevel.connect_object( "activate", self.zoomdialog, self.map )
- menubar.append( zoomlevel )
+ zoomlevel = gtk.MenuItem( label="Zoom level" )
+ zoomlevel.connect_object( "activate", self.zoomdialog, self.map )
+ menubar.append( zoomlevel )
- vbox.pack_start(menubar,True,True,5)
+ vbox.pack_start(menubar,True,True,5)
def main(self):
gtk.main()