g.gui.vdigit.py 3.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108
  1. #!/usr/bin/env python
  2. ############################################################################
  3. #
  4. # MODULE: g.gui.vdigit
  5. # AUTHOR(S): Martin Landa <landa.martin gmail.com>
  6. # PURPOSE: wxGUI Vector Digitizer
  7. # COPYRIGHT: (C) 2007-2013 by Martin Landa, and the GRASS Development Team
  8. #
  9. # This program is free software; you can 1redistribute it and/or
  10. # modify it under the terms of the GNU General Public License as
  11. # published by the Free Software Foundation; either version 2 of the
  12. # License, or (at your option) any later version.
  13. #
  14. # This program is distributed in the hope that it will be useful, but
  15. # WITHOUT ANY WARRANTY; without even the implied warranty of
  16. # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
  17. # General Public License for more details.
  18. #
  19. ############################################################################
  20. #%module
  21. #% description: Interactive editing and digitization of vector maps.
  22. #% keywords: general
  23. #% keywords: GUI
  24. #% keywords: vector
  25. #% keywords: editing
  26. #% keywords: digitization
  27. #%end
  28. #%flag
  29. #% key: c
  30. #% description: Create new vector map if doesn't exist
  31. #%end
  32. #%option G_OPT_V_MAP
  33. #% label: Name of vector map to edit
  34. #%end
  35. import os
  36. import sys
  37. import grass.script as grass
  38. import wx
  39. if __name__ == '__main__':
  40. gui_wx_path = os.path.join(os.getenv('GISBASE'), 'etc', 'gui', 'wxpython')
  41. if gui_wx_path not in sys.path:
  42. sys.path.append(gui_wx_path)
  43. from core.globalvar import CheckWxVersion
  44. from core.utils import _, GuiModuleMain
  45. from mapdisp.frame import MapFrame
  46. from core.giface import StandaloneGrassInterface
  47. from core.settings import UserSettings
  48. from vdigit.main import haveVDigit, errorMsg
  49. class VDigitMapFrame(MapFrame):
  50. def __init__(self, vectorMap):
  51. MapFrame.__init__(self, parent = None, giface = StandaloneGrassInterface(),
  52. title = _("GRASS GIS Vector Digitizer"), size = (850, 600))
  53. # load vector map
  54. mapLayer = self.GetMap().AddLayer(ltype = 'vector',
  55. command = ['d.vect', 'map=%s' % vectorMap],
  56. active = True, name = vectorMap, hidden = False, opacity = 1.0,
  57. render = True)
  58. # switch toolbar
  59. self.AddToolbar('vdigit', fixed = True)
  60. # start editing
  61. self.toolbars['vdigit'].StartEditing(mapLayer)
  62. def main():
  63. # allow immediate rendering
  64. driver = UserSettings.Get(group = 'display', key = 'driver', subkey = 'type')
  65. if driver == 'png':
  66. os.environ['GRASS_RENDER_IMMEDIATE'] = 'png'
  67. else:
  68. os.environ['GRASS_RENDER_IMMEDIATE'] = 'cairo'
  69. app = wx.App()
  70. if not CheckWxVersion([2, 9]):
  71. wx.InitAllImageHandlers()
  72. frame = VDigitMapFrame(options['map'])
  73. frame.Show()
  74. app.MainLoop()
  75. if __name__ == "__main__":
  76. grass.set_raise_on_error(False)
  77. options, flags = grass.parser()
  78. if not haveVDigit:
  79. grass.fatal(_("Vector digitizer not available. %s") % errorMsg)
  80. if not grass.find_file(name = options['map'], element = 'vector',
  81. mapset = grass.gisenv()['MAPSET'])['fullname']:
  82. if not flags['c']:
  83. grass.fatal(_("Vector map <%s> not found in current mapset. "
  84. "New vector map can be created by providing '-c' flag.") % options['map'])
  85. else:
  86. grass.message(_("New vector map <%s> created") % options['map'])
  87. if 0 != grass.run_command('v.edit', map = options['map'], tool = 'create'):
  88. grass.fatal(_("Unable to create new vector map <%s>") % options['map'])
  89. GuiModuleMain(main)