g.gui.vdigit.py 3.5 KB

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