giface.py 9.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294
  1. """
  2. @package lmgr.giface
  3. @brief Layer Manager GRASS interface
  4. Classes:
  5. - giface::LayerManagerGrassInterface
  6. (C) 2012 by the GRASS Development Team
  7. This program is free software under the GNU General Public License
  8. (>=v2). Read the file COPYING that comes with GRASS for details.
  9. @author Anna Kratochvilova <kratochanna gmail.com>
  10. @author Vaclav Petras <wenzeslaus gmail.com>
  11. """
  12. from __future__ import print_function
  13. import os
  14. from grass.pydispatch.signal import Signal
  15. from core.giface import Notification
  16. from core.utils import GetLayerNameFromCmd
  17. class Layer(object):
  18. """@implements core::giface::Layer
  19. .. note::
  20. Currently implemented without specifying the interface.
  21. It only provides all attributes of existing layer as used in lmgr.
  22. """
  23. def __init__(self, layer, pydata):
  24. self._layer = layer
  25. self._pydata = pydata
  26. def __getattr__(self, name):
  27. return self._pydata[0][name]
  28. def __dir__(self):
  29. return self._pydata[0].keys()
  30. def __str__(self):
  31. return '' if self.maplayer.name is None else self.maplayer.name
  32. class LayerList(object):
  33. """@implements core.giface.Layer"""
  34. def __init__(self, tree):
  35. self._tree = tree
  36. def __len__(self):
  37. return len([layer for layer in self])
  38. def __iter__(self):
  39. """Iterates over the contents of the list."""
  40. item = self._tree.GetFirstChild(self._tree.root)[0]
  41. while item and item.IsOk():
  42. yield Layer(item, self._tree.GetPyData(item))
  43. item = self._tree.GetNextItem(item)
  44. def __getitem__(self, index):
  45. """Select a layer from the LayerList using the index."""
  46. return [l for l in self][index]
  47. def __repr__(self):
  48. """Return a representation of the object."""
  49. return "LayerList(%r)" % [layer for layer in self]
  50. def GetSelectedLayers(self, checkedOnly=True):
  51. items = self._tree.GetSelectedLayer(multi=True,
  52. checkedOnly=checkedOnly)
  53. layers = []
  54. for item in items:
  55. layer = Layer(item, self._tree.GetPyData(item))
  56. layers.append(layer)
  57. return layers
  58. # TODO: it is not clear if default of checkedOnly should be False or True
  59. def GetSelectedLayer(self, checkedOnly=False):
  60. """Returns selected layer or None when there is no selected layer."""
  61. item = self._tree.GetSelectedLayer(multi=False,
  62. checkedOnly=checkedOnly)
  63. if item is None:
  64. return None
  65. else:
  66. data = self._tree.GetPyData(item)
  67. return Layer(item, data)
  68. def GetLayerInfo(self, layer):
  69. """For compatibility only, will be removed."""
  70. return Layer(layer, self._tree.GetPyData(layer))
  71. def AddLayer(self, ltype, name=None, checked=None,
  72. opacity=1.0, cmd=None):
  73. """Adds a new layer to the layer list.
  74. Launches property dialog if needed (raster, vector, etc.)
  75. :param ltype: layer type (raster, vector, raster_3d, ...)
  76. :param name: layer name
  77. :param checked: if True layer is checked
  78. :param opacity: layer opacity level
  79. :param cmd: command (given as a list)
  80. """
  81. l = self._tree.AddLayer(ltype=ltype, lname=name, lchecked=checked,
  82. lopacity=opacity, lcmd=cmd)
  83. return Layer(l, self._tree.GetPyData(l))
  84. def DeleteLayer(self, layer):
  85. """Remove layer from layer list"""
  86. self._tree.Delete(layer._layer)
  87. def CheckLayer(self, layer, checked=True):
  88. """Check or uncheck layer"""
  89. self._tree.forceCheck = True
  90. self._tree.CheckItem(layer._layer, checked=checked)
  91. def SelectLayer(self, layer, select=True):
  92. "Select or unselect layer"
  93. self._tree.SelectItem(layer._layer, select)
  94. def ChangeLayer(self, layer, **kwargs):
  95. "Change layer (cmd, ltype, opacity)"
  96. if 'cmd' in kwargs:
  97. layer._pydata[0]['cmd'] = kwargs['cmd']
  98. layerName, found = GetLayerNameFromCmd(kwargs['cmd'], fullyQualified=True)
  99. if found:
  100. layer._pydata[0]['label'] = layerName
  101. if 'ltype' in kwargs:
  102. layer._pydata[0]['type'] = kwargs['ltype']
  103. if 'opacity' in kwargs:
  104. layer._pydata[0]['maplayer'].SetOpacity(kwargs['opacity'])
  105. self._tree.ChangeLayer(layer._layer)
  106. self._tree.SetItemIcon(layer._layer)
  107. self._tree.SetItemText(layer._layer, self._tree._getLayerName(layer._layer))
  108. def IsLayerChecked(self, layer):
  109. """Returns True if layer is checked, False otherwise"""
  110. return self._tree.IsItemChecked(layer._layer)
  111. def GetLayersByName(self, name):
  112. items = self._tree.FindItemByData(key='name', value=name)
  113. if items is None:
  114. return []
  115. else:
  116. layers = []
  117. for item in items:
  118. layer = Layer(item, self._tree.GetPyData(item))
  119. layers.append(layer)
  120. return layers
  121. def GetLayerByData(self, key, value):
  122. """Returns layer with specified.
  123. Returns only one layer.
  124. Avoid using this method, it might be removed in the future.
  125. """
  126. if key == 'name':
  127. print("giface.GetLayerByData(): Do not with use key='name',"
  128. " use GetLayersByName instead.")
  129. item = self._tree.FindItemByData(key=key, value=value)
  130. if item is None:
  131. return None
  132. else:
  133. return Layer(item, self._tree.GetPyData(item))
  134. class LayerManagerGrassInterface(object):
  135. """@implements core::giface::GrassInterface"""
  136. def __init__(self, lmgr):
  137. """Costructor is specific to the current implementation.
  138. Uses Layer Manager object including its private attributes.
  139. (It encapsulates existing Layer Manager so access to private members
  140. is intention.)
  141. """
  142. self.lmgr = lmgr
  143. # Signal when some map is created or updated by a module.
  144. # attributes: name: map name, ltype: map type,
  145. # add: if map should be added to layer tree (questionable attribute)
  146. self.mapCreated = Signal('LayerManagerGrassInterface.mapCreated')
  147. self.currentMapsetChanged = Signal('LayerManagerGrassInterface.currentMapsetChanged')
  148. # Signal emitted to request updating of map
  149. self.updateMap = Signal('LayerManagerGrassInterface.updateMap')
  150. def RunCmd(self, *args, **kwargs):
  151. self.lmgr._gconsole.RunCmd(*args, **kwargs)
  152. def Help(self, entry, online=False):
  153. cmdlist = ['g.manual', 'entry=%s' % entry]
  154. if online:
  155. cmdlist.append('-o')
  156. self.RunCmd(cmdlist, compReg=False,
  157. notification=Notification.NO_NOTIFICATION)
  158. def WriteLog(self, text, wrap=None,
  159. notification=Notification.HIGHLIGHT):
  160. self.lmgr._gconsole.WriteLog(text=text, wrap=wrap,
  161. notification=notification)
  162. def WriteCmdLog(self, text, pid=None,
  163. notification=Notification.MAKE_VISIBLE):
  164. self.lmgr._gconsole.WriteCmdLog(text=text, pid=pid,
  165. notification=notification)
  166. def WriteWarning(self, text):
  167. self.lmgr._gconsole.WriteWarning(text=text)
  168. def WriteError(self, text):
  169. self.lmgr._gconsole.WriteError(text=text)
  170. def GetLayerTree(self):
  171. return self.lmgr.GetLayerTree()
  172. def GetLayerList(self):
  173. return LayerList(self.lmgr.GetLayerTree())
  174. def GetMapDisplay(self):
  175. return self.lmgr.GetMapDisplay(onlyCurrent=True)
  176. def GetAllMapDisplays(self):
  177. return self.lmgr.GetMapDisplay(onlyCurrent=False)
  178. def GetMapWindow(self):
  179. if self.lmgr.GetMapDisplay(onlyCurrent=True):
  180. return self.lmgr.GetMapDisplay(onlyCurrent=True).GetMapWindow()
  181. else:
  182. return None
  183. def GetProgress(self):
  184. return self.lmgr.goutput.GetProgressBar()
  185. def UpdateCmdHistory(self, cmd):
  186. self.lmgr.goutput.GetPrompt().UpdateCmdHistory(cmd)
  187. def ShowStatusbar(self, show=True):
  188. self.lmgr.GetMapDisplay().statusbarManager.Show(show)
  189. def IsStatusbarShown(self):
  190. return self.lmgr.GetMapDisplay().statusbarManager.IsShown()
  191. def ShowAllToolbars(self, show=True):
  192. if not show: # hide
  193. action = self.lmgr.GetMapDisplay().RemoveToolbar
  194. else:
  195. action = self.lmgr.GetMapDisplay().AddToolbar
  196. for toolbar in self.lmgr.GetMapDisplay().GetToolbarNames():
  197. action(toolbar)
  198. def AreAllToolbarsShown(self):
  199. return self.lmgr.GetMapDisplay().GetMapToolbar().IsShown()
  200. class LayerManagerGrassInterfaceForMapDisplay(object):
  201. """Provides reference only to the given layer list (according to tree),
  202. not to the current.
  203. @implements core::giface::GrassInterface
  204. """
  205. def __init__(self, giface, tree):
  206. """
  207. :param giface: original grass interface
  208. :param tree: tree which will be used instead of the tree from giface
  209. """
  210. self._giface = giface
  211. self.tree = tree
  212. # Signal emitted to request updating of map
  213. self.updateMap = Signal(
  214. 'LayerManagerGrassInterfaceForMapDisplay.updateMap')
  215. def GetLayerTree(self):
  216. return self.tree
  217. def GetLayerList(self):
  218. return LayerList(self.tree)
  219. def GetMapWindow(self):
  220. return self.tree.GetMapDisplay().GetMapWindow()
  221. def __getattr__(self, name):
  222. return getattr(self._giface, name)