123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124 |
- """!
- @package swipe.toolbars
- @brief Map Swipe toolbars and icons.
- Classes:
- - toolbars::swipeMapToolbar
- - toolbars::swipeMainToolbar
- (C) 2006-2012 by the GRASS Development Team
- This program is free software under the GNU General Public
- License (>=v2). Read the file COPYING that comes with GRASS
- for details.
- @author Anna Kratochvilova <kratochanna gmail.com>
- """
- import wx
- from gui_core.toolbars import BaseToolbar, BaseIcons
- from icons.icon import MetaIcon
- swipeIcons = {
- 'tools': MetaIcon(img = 'tools', label = _('Tools')),
- }
- class SwipeMapToolbar(BaseToolbar):
- """!Map toolbar (to control map zoom and rendering)
- """
- def __init__(self, parent):
- """!Map toolbar constructor
- """
- BaseToolbar.__init__(self, parent)
-
- self.InitToolbar(self._toolbarData())
- # realize the toolbar
- self.Realize()
-
- self.action = { 'id' : self.pan }
- self.defaultAction = { 'id' : self.pan,
- 'bind' : self.parent.OnPan }
-
- self.EnableTool(self.zoomBack, False)
-
- def _toolbarData(self):
- """!Returns toolbar data (name, icon, handler)"""
- # BaseIcons are a set of often used icons. It is possible
- # to reuse icons in ./trunk/gui/icons/grass or add new ones there.
- icons = BaseIcons
- return self._getToolbarData((("displaymap", icons["display"],
- self.parent.OnDraw),
- ("rendermap", icons["render"],
- self.parent.OnRender),
- ("erase", icons["erase"],
- self.parent.OnErase),
- (None, ), # creates separator
- ("pan", icons["pan"],
- self.parent.OnPan,
- wx.ITEM_CHECK), # toggle tool
- ("zoomIn", icons["zoomIn"],
- self.parent.OnZoomIn,
- wx.ITEM_CHECK),
- ("zoomOut", icons["zoomOut"],
- self.parent.OnZoomOut,
- wx.ITEM_CHECK),
- (None, ),
- ("zoomBack", icons["zoomBack"],
- self.parent.OnZoomBack),
- ("zoomToMap", icons["zoomExtent"],
- self.parent.OnZoomToMap),
- ))
-
- def SetActiveMap(self, index):
- """!Set currently selected map.
- Unused, needed because of DoubleMapFrame API.
- """
- pass
- class SwipeMainToolbar(BaseToolbar):
- """!Toolbar with tools related to application functionality
- """
- def __init__(self, parent):
- """!Toolbar constructor
- """
- BaseToolbar.__init__(self, parent)
-
- self.InitToolbar(self._toolbarData())
-
- # realize the toolbar
- self.Realize()
-
- def _toolbarData(self):
- """!Toolbar data"""
- icons = swipeIcons
- return self._getToolbarData((("addRaster", BaseIcons['addRast'],
- self.parent.OnSelectRasters),
- (None, ),
- ("tools", swipeIcons['tools'],
- self.OnToolMenu)
- ))
- def OnToolMenu(self, event):
- """!Menu for additional tools"""
- point = wx.GetMousePosition()
- toolMenu = wx.Menu()
-
- for label, itype, handler, desc in (
- (_("Switch orientation"),
- wx.ITEM_NORMAL, self.parent.OnSwitchOrientation, "switchOrientation"),
- (_("Switch maps"),
- wx.ITEM_NORMAL, self.parent.OnSwitchWindows, "switchMaps")):
- # Add items to the menu
- item = wx.MenuItem(parentMenu = toolMenu, id = wx.ID_ANY,
- text = label,
- kind = itype)
- toolMenu.AppendItem(item)
- self.parent.GetWindow().Bind(wx.EVT_MENU, handler, item)
-
- # Popup the menu. If an item is selected then its handler
- # will be called before PopupMenu returns.
- self.parent.GetWindow().PopupMenu(toolMenu)
- toolMenu.Destroy()
|