g.gui.vdigit.py 3.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106
  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 grass.script as grass
  37. import wx
  38. from core.globalvar import CheckWxVersion
  39. from core.utils import _, GuiModuleMain
  40. from mapdisp.frame import MapFrame
  41. from core.giface import StandaloneGrassInterface
  42. from core.settings import UserSettings
  43. from vdigit.main import haveVDigit, errorMsg
  44. from grass.exceptions import CalledModuleError
  45. class VDigitMapFrame(MapFrame):
  46. def __init__(self, vectorMap):
  47. MapFrame.__init__(self, parent = None, giface = StandaloneGrassInterface(),
  48. title = _("GRASS GIS Vector Digitizer"), size = (850, 600))
  49. # load vector map
  50. mapLayer = self.GetMap().AddLayer(ltype = 'vector',
  51. command = ['d.vect', 'map=%s' % vectorMap],
  52. active = True, name = vectorMap, hidden = False, opacity = 1.0,
  53. render = True)
  54. # switch toolbar
  55. self.AddToolbar('vdigit', fixed = True)
  56. # start editing
  57. self.toolbars['vdigit'].StartEditing(mapLayer)
  58. def main():
  59. # allow immediate rendering
  60. driver = UserSettings.Get(group = 'display', key = 'driver', subkey = 'type')
  61. if driver == 'png':
  62. os.environ['GRASS_RENDER_IMMEDIATE'] = 'png'
  63. else:
  64. os.environ['GRASS_RENDER_IMMEDIATE'] = 'cairo'
  65. app = wx.App()
  66. if not CheckWxVersion([2, 9]):
  67. wx.InitAllImageHandlers()
  68. frame = VDigitMapFrame(options['map'])
  69. frame.Show()
  70. app.MainLoop()
  71. if __name__ == "__main__":
  72. grass.set_raise_on_error(False)
  73. options, flags = grass.parser()
  74. if not haveVDigit:
  75. grass.fatal(_("Vector digitizer not available. %s") % errorMsg)
  76. if not grass.find_file(name = options['map'], element = 'vector',
  77. mapset = grass.gisenv()['MAPSET'])['fullname']:
  78. if not flags['c']:
  79. grass.fatal(_("Vector map <%s> not found in current mapset. "
  80. "New vector map can be created by providing '-c' flag.") % options['map'])
  81. else:
  82. grass.message(_("New vector map <%s> created") % options['map'])
  83. try:
  84. grass.run_command('v.edit', map = options['map'], tool = 'create')
  85. except CalledModuleError:
  86. grass.fatal(_("Unable to create new vector map <%s>") % options['map'])
  87. GuiModuleMain(main)