digit.cpp 2.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110
  1. /**
  2. \file vdigit/digit.cpp
  3. \brief wxvdigit - C++ interace for wxGUI vector digitizer.
  4. This program is free software under the GNU General Public
  5. License (>=v2). Read the file COPYING that comes with GRASS
  6. for details.
  7. (C) 2008-2009 by Martin Landa, and the GRASS development team
  8. \author Martin Landa <landa.martin gmail.com>
  9. */
  10. #include "driver.h"
  11. #include "digit.h"
  12. /**
  13. \brief Initialize digit interface used by SWIG
  14. \param driver display driver instance
  15. \param window parent window for message dialog
  16. */
  17. Digit::Digit(DisplayDriver *ddriver, wxWindow *window)
  18. {
  19. display = ddriver;
  20. display->parentWin = window;
  21. if (display->mapInfo) {
  22. InitCats();
  23. }
  24. changesetEnd = changesetCurrent = -1; // initial value for undo/redo
  25. display->msgCaption = _("Digitization error");
  26. // avoid GUI crash
  27. // Vect_set_fatal_error(GV_FATAL_PRINT);
  28. }
  29. /**
  30. \brief Digit class destructor
  31. Frees changeset structure
  32. */
  33. Digit::~Digit()
  34. {
  35. for(int changeset = 0; changeset < (int) changesets.size(); changeset++) {
  36. FreeChangeset(changeset);
  37. }
  38. }
  39. /**
  40. \brief Update digit settings
  41. \param breakLines break lines on intersection
  42. \param addCentroid add centroid to left/right area
  43. \param catBoundary attach category to boundary
  44. */
  45. void Digit::UpdateSettings(bool breakLines,
  46. bool addCentroid, bool catBoundary)
  47. {
  48. settings.breakLines = breakLines;
  49. settings.addCentroid = addCentroid;
  50. settings.catBoundary = !catBoundary; /* do not attach */
  51. return;
  52. }
  53. /*!
  54. \brief Register action before operation
  55. \return changeset id
  56. */
  57. int Digit::AddActionsBefore(void)
  58. {
  59. int changeset;
  60. /* register changeset */
  61. changeset = changesets.size();
  62. for (int i = 0; i < display->selected.ids->n_values; i++) {
  63. int line = display->selected.ids->value[i];
  64. if (Vect_line_alive(display->mapInfo, line))
  65. AddActionToChangeset(changeset, DEL, line);
  66. }
  67. return changeset;
  68. }
  69. /*!
  70. \brief Register action after operation
  71. */
  72. void Digit::AddActionsAfter(int changeset, int nlines)
  73. {
  74. for (int i = 0; i < display->selected.ids->n_values; i++) {
  75. int line = display->selected.ids->value[i];
  76. if (Vect_line_alive(display->mapInfo, line)) {
  77. RemoveActionFromChangeset(changeset, DEL, line);
  78. }
  79. }
  80. for (int line = nlines + 1; line <= Vect_get_num_lines(display->mapInfo); line++) {
  81. if (Vect_line_alive(display->mapInfo, line)) {
  82. AddActionToChangeset(changeset, ADD, line);
  83. }
  84. }
  85. return;
  86. }