g.gui.vdigit.py 3.6 KB

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