wizard.py 79 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941942943944945946947948949950951952953954955956957958959960961962963964965966967968969970971972973974975976977978979980981982983984985986987988989990991992993994995996997998999100010011002100310041005100610071008100910101011101210131014101510161017101810191020102110221023102410251026102710281029103010311032103310341035103610371038103910401041104210431044104510461047104810491050105110521053105410551056105710581059106010611062106310641065106610671068106910701071107210731074107510761077107810791080108110821083108410851086108710881089109010911092109310941095109610971098109911001101110211031104110511061107110811091110111111121113111411151116111711181119112011211122112311241125112611271128112911301131113211331134113511361137113811391140114111421143114411451146114711481149115011511152115311541155115611571158115911601161116211631164116511661167116811691170117111721173117411751176117711781179118011811182118311841185118611871188118911901191119211931194119511961197119811991200120112021203120412051206120712081209121012111212121312141215121612171218121912201221122212231224122512261227122812291230123112321233123412351236123712381239124012411242124312441245124612471248124912501251125212531254125512561257125812591260126112621263126412651266126712681269127012711272127312741275127612771278127912801281128212831284128512861287128812891290129112921293129412951296129712981299130013011302130313041305130613071308130913101311131213131314131513161317131813191320132113221323132413251326132713281329133013311332133313341335133613371338133913401341134213431344134513461347134813491350135113521353135413551356135713581359136013611362136313641365136613671368136913701371137213731374137513761377137813791380138113821383138413851386138713881389139013911392139313941395139613971398139914001401140214031404140514061407140814091410141114121413141414151416141714181419142014211422142314241425142614271428142914301431143214331434143514361437143814391440144114421443144414451446144714481449145014511452145314541455145614571458145914601461146214631464146514661467146814691470147114721473147414751476147714781479148014811482148314841485148614871488148914901491149214931494149514961497149814991500150115021503150415051506150715081509151015111512151315141515151615171518151915201521152215231524152515261527152815291530153115321533153415351536153715381539154015411542154315441545154615471548154915501551155215531554155515561557155815591560156115621563156415651566156715681569157015711572157315741575157615771578157915801581158215831584158515861587158815891590159115921593159415951596159715981599160016011602160316041605160616071608160916101611161216131614161516161617161816191620162116221623162416251626162716281629163016311632163316341635163616371638163916401641164216431644164516461647164816491650165116521653165416551656165716581659166016611662166316641665166616671668166916701671167216731674167516761677167816791680168116821683168416851686168716881689169016911692169316941695169616971698169917001701170217031704170517061707170817091710171117121713171417151716171717181719
  1. """
  2. @package rlisetup.py
  3. @brief GUI per r.li.setup module
  4. Classes:
  5. - RLiSetupFrame (first frame to show existing conf file and choose some
  6. operation)
  7. - RLIWizard (the main wizard)
  8. - FirstPage (first page of wizard, choose name of conf file, raster, vector,
  9. sampling region)
  10. - Keyboard (page to insert region areas from keyboard)
  11. - SamplingAreas (define sampling area)
  12. - SummaryPage (show choosen options)
  13. (C) 2011 by the GRASS Development Team
  14. This program is free software under the GNU General Public License
  15. (>=v2). Read the file COPYING that comes with GRASS for details.
  16. @author Luca Delucchi <lucadeluge gmail com>
  17. """
  18. import os
  19. import wx
  20. import wx.wizard as wiz
  21. import wx.lib.scrolledpanel as scrolled
  22. from gui_core import gselect
  23. from core.utils import _
  24. from location_wizard.wizard import TitledPage as TitledPage
  25. from rlisetup.functions import checkValue, retRLiPath
  26. from rlisetup.sampling_frame import RLiSetupMapPanel
  27. from grass.script import core as grass
  28. from grass.script import raster as grast
  29. from functions import SamplingType, sampleAreaVector, convertFeature, obtainAreaVector
  30. from core.gcmd import GError, GMessage, RunCommand
  31. #@NOTE: r.li.setup writes in the settings file with
  32. ## r.li.windows.tcl:
  33. #exec echo "SAMPLINGFRAME $per_x|$per_y|$per_rl|$per_cl" >> $env(TMP).set
  34. class RLIWizard(object):
  35. """
  36. !Start wizard here and finish wizard here
  37. """
  38. def __init__(self, parent):
  39. self.parent = parent
  40. self.wizard = wiz.Wizard(parent=parent, id=wx.ID_ANY,
  41. title=_("Create new configuration file for " \
  42. "r.li modules"))
  43. self.rlipath = retRLiPath()
  44. self.msAreaList = []
  45. #pages
  46. self.startpage = FirstPage(self.wizard, self)
  47. self.drawsampleframepage = DrawSampleFramePage(self.wizard, self)
  48. self.keyboardpage = KeyboardPage(self.wizard, self)
  49. self.samplingareapage = SamplingAreasPage(self.wizard, self)
  50. self.summarypage = SummaryPage(self.wizard, self)
  51. self.units = SampleUnitsKeyPage(self.wizard, self)
  52. self.drawunits = UnitsMousePage(self.wizard, self)
  53. self.drawsampleunitspage = DrawSampleUnitsPage(self.wizard, self)
  54. self.vectorareas = VectorAreasPage(self.wizard, self)
  55. self.moving = MovingKeyPage(self.wizard, self)
  56. self.regions = DrawRegionsPage(self.wizard, self)
  57. #order of pages
  58. self.startpage.SetNext(self.samplingareapage)
  59. self.keyboardpage.SetPrev(self.startpage)
  60. self.keyboardpage.SetNext(self.samplingareapage)
  61. self.drawsampleframepage.SetNext(self.samplingareapage)
  62. self.drawsampleframepage.SetPrev(self.startpage)
  63. self.samplingareapage.SetPrev(self.startpage)
  64. self.samplingareapage.SetNext(self.summarypage)
  65. self.regions.SetPrev(self.samplingareapage)
  66. self.regions.SetNext(self.summarypage)
  67. self.units.SetPrev(self.samplingareapage)
  68. self.units.SetNext(self.summarypage)
  69. self.drawunits.SetPrev(self.samplingareapage)
  70. self.drawunits.SetNext(self.drawsampleunitspage)
  71. self.drawsampleunitspage.SetPrev(self.drawunits)
  72. self.drawsampleunitspage.SetNext(self.summarypage)
  73. self.moving.SetPrev(self.samplingareapage)
  74. self.moving.SetNext(self.summarypage)
  75. self.vectorareas.SetPrev(self.samplingareapage)
  76. self.vectorareas.SetNext(self.summarypage)
  77. self.summarypage.SetPrev(self.samplingareapage)
  78. #layout
  79. self.startpage.DoLayout()
  80. self.drawsampleframepage.DoLayout()
  81. self.keyboardpage.DoLayout()
  82. self.samplingareapage.DoLayout()
  83. self.summarypage.DoLayout()
  84. self.units.DoLayout()
  85. self.drawunits.DoLayout()
  86. self.drawsampleunitspage.DoLayout()
  87. self.regions.DoLayout()
  88. self.moving.DoLayout()
  89. self.vectorareas.DoLayout()
  90. self.wizard.FitToPage(self.startpage)
  91. #run_wizard
  92. if self.wizard.RunWizard(self.startpage):
  93. dlg = wx.MessageDialog(parent=self.parent,
  94. message=_("Do you want to create r.li " \
  95. "configuration file <%s>?") % self.startpage.conf_name,
  96. caption=_("Create new r.li configuration file?"),
  97. style=wx.YES_NO | wx.YES_DEFAULT | wx.ICON_QUESTION)
  98. if dlg.ShowModal() == wx.ID_NO:
  99. self._cleanup()
  100. else:
  101. self._write_confile()
  102. self._cleanup()
  103. dlg.Destroy()
  104. else:
  105. self.wizard.Destroy()
  106. GMessage(parent=self.parent,
  107. message=_("r.li.setup wizard canceled. "
  108. "Configuration file not created."))
  109. self._cleanup()
  110. def _write_confile(self):
  111. """!Write the configuration file"""
  112. f = open(os.path.join(self.rlipath, self.startpage.conf_name), 'w')
  113. self.rasterinfo = grast.raster_info(self.startpage.rast)
  114. self._write_region(f)
  115. self._write_area(f)
  116. f.close()
  117. def _temp_region(self):
  118. # save current settings:
  119. grass.use_temp_region()
  120. # Temporarily aligning region resolution to $RASTER resolution
  121. # keep boundary settings
  122. grass.run_command('g.region', rast=self.startpage.rast)
  123. self.gregion = grass.region()
  124. self.SF_NSRES = self.gregion['nsres']
  125. self.SF_EWRES = self.gregion['ewres']
  126. def _write_region(self, fil):
  127. """!Write the region"""
  128. if self.startpage.region == 'whole':
  129. fil.write("SAMPLINGFRAME 0|0|1|1\n")
  130. self._temp_region()
  131. self.SF_X = 0.0
  132. self.SF_Y = 0.0
  133. self.SF_RL = abs(int(float(self.gregion['s'] - self.gregion['n'])
  134. / float(self.gregion['nsres'])))
  135. self.SF_CL = abs(int(float(self.gregion['e'] - self.gregion['w'])
  136. / float(self.gregion['ewres'])))
  137. self.SF_N = self.gregion['n']
  138. self.SF_S = self.gregion['s']
  139. self.SF_E = self.gregion['e']
  140. self.SF_W = self.gregion['w']
  141. self.per_x = float(self.SF_X) / float(self.rasterinfo['cols'])
  142. self.per_y = float(self.SF_Y) / float(self.rasterinfo['rows'])
  143. self.per_rl = float(self.SF_RL) / float(self.rasterinfo['rows'])
  144. self.per_cl = float(self.SF_CL) / float(self.rasterinfo['cols'])
  145. elif self.startpage.region == 'key':
  146. self._temp_region()
  147. self.SF_X = float(self.keyboardpage.col_up)
  148. self.SF_Y = float(self.keyboardpage.row_up)
  149. self.SF_RL = float(self.keyboardpage.row_len)
  150. self.SF_CL = float(self.keyboardpage.col_len)
  151. self.SF_N = self.gregion['n'] - (self.SF_NSRES * self.SF_Y)
  152. self.SF_S = self.gregion['n'] - (self.SF_NSRES * self.SF_Y + self.SF_RL)
  153. self.SF_W = self.gregion['w'] + (self.SF_EWRES * self.SF_X)
  154. self.SF_E = self.gregion['w'] + (self.SF_EWRES * self.SF_X + self.SF_CL)
  155. self.per_x = float(self.SF_X) / float(self.rasterinfo['cols'])
  156. self.per_y = float(self.SF_Y) / float(self.rasterinfo['rows'])
  157. self.per_rl = float(self.SF_RL) / float(self.rasterinfo['rows'])
  158. self.per_cl = float(self.SF_CL) / float(self.rasterinfo['cols'])
  159. fil.write("SAMPLINGFRAME %r|%r|%r|%r\n" % (self.per_x, self.per_y,
  160. self.per_rl, self.per_cl))
  161. elif self.startpage.region == 'draw':
  162. self._temp_region()
  163. tregion = self.drawsampleframepage.tregion
  164. # should we call this? with align param?
  165. RunCommand('g.region', align=self.startpage.rast,
  166. n=tregion['n'], s=tregion['s'],
  167. w=tregion['w'], e=tregion['e'])
  168. newreg = grass.region()
  169. self.SF_N = newreg['n'] # set env(SF_N) $n
  170. self.SF_S = newreg['s'] # set env(SF_S) $s
  171. self.SF_E = newreg['e'] # set env(SF_E) $e
  172. self.SF_W = newreg['w'] # set env(SF_W) $w
  173. self.SF_Y = abs(round(self.gregion['n'] - newreg['n']) / newreg['nsres'])
  174. # set env(SF_Y) [expr abs(round(($s_n - $n) / $nres)) ]
  175. self.SF_X = abs(round(self.gregion['w'] - newreg['w']) / newreg['ewres'])
  176. # set env(SF_X) [expr abs(round(($s_w - $w) / $sres)) ]
  177. self.SF_RL = abs(round(newreg['n'] - newreg['s']) / newreg['nsres'])
  178. # set env(SF_RL) [expr abs(round(($n - $s) / $nres)) ]
  179. self.SF_CL = abs(round(newreg['e'] - newreg['w']) / newreg['ewres'])
  180. # set env(SF_CL) [expr abs(round(($e - $w) / $sres)) ]
  181. self.per_x = float(self.SF_X) / float(self.rasterinfo['cols'])
  182. # double($env(SF_X)) / double($cols)
  183. self.per_y = float(self.SF_Y) / float(self.rasterinfo['rows'])
  184. # double($env(SF_Y)) / double($rows)
  185. self.per_rl = float(self.SF_RL) / float(self.rasterinfo['rows'])
  186. # double($env(SF_RL)) / double($rows)
  187. self.per_cl = float(self.SF_CL) / float(self.rasterinfo['cols'])
  188. # double($env(SF_CL)) / double($cols)
  189. fil.write("SAMPLINGFRAME %r|%r|%r|%r\n" % (self.per_x, self.per_y,
  190. self.per_rl, self.per_cl))
  191. def _value_for_circle(self, radius):
  192. self.CIR_RL = round((2 * float(radius)) / float(self.rasterinfo['ewres']))
  193. self.CIR_CL = round((2 * float(radius)) / float(self.rasterinfo['nsres']))
  194. if not self.CIR_RL % 2:
  195. self.CIR_RL += 1
  196. if not self.CIR_CL % 2:
  197. self.CIR_CL += 1
  198. return
  199. def _circle(self, radius, mask):
  200. """!Create a circle mask"""
  201. self._value_for_circle(radius)
  202. eastEdge = float(self.SF_W + (self.CIR_RL * self.SF_EWRES))
  203. southEdge = float(self.SF_N - (self.CIR_CL * self.SF_NSRES))
  204. grass.del_temp_region()
  205. grass.use_temp_region()
  206. grass.run_command('g.region', n=self.SF_N, s=southEdge, e=eastEdge,
  207. w=self.SF_W)
  208. xcenter = grass.region(complete=True)['center_easting']
  209. ycenter = grass.region(complete=True)['center_northing']
  210. grass.run_command('r.circle', flags='b', out=mask, max=radius,
  211. coordinate=[xcenter, ycenter], quiet=True)
  212. grass.del_temp_region()
  213. grass.use_temp_region()
  214. grass.run_command('g.region', rast=self.startpage.rast)
  215. def getSamplingType(self):
  216. """!Obtain the sampling type"""
  217. devicetype = self.samplingareapage.regionbox
  218. samplingtype = self.samplingareapage.samplingtype
  219. shapetype = self.units.boxtype
  220. if samplingtype == SamplingType.UNITS:
  221. if devicetype == 'mouse':
  222. if shapetype == 'circle':
  223. samtype = SamplingType.MUNITSC
  224. else:
  225. samtype = SamplingType.MUNITSR
  226. elif devicetype == 'keyboard':
  227. if shapetype == 'circle':
  228. samtype = SamplingType.KUNITSC
  229. else:
  230. samtype = SamplingType.KUNITSR
  231. elif samplingtype == SamplingType.MVWIN:
  232. if devicetype == 'mouse':
  233. if shapetype == 'circle':
  234. samtype = SamplingType.MMVWINC
  235. else:
  236. samtype = SamplingType.MMVWINR
  237. elif devicetype == 'keyboard':
  238. if shapetype == 'circle':
  239. samtype = SamplingType.KMVWINC
  240. else:
  241. samtype = SamplingType.KMVWINR
  242. elif samplingtype == SamplingType.WHOLE:
  243. samtype = SamplingType.WHOLE
  244. elif samplingtype == SamplingType.REGIONS:
  245. samtype = SamplingType.REGIONS
  246. elif samplingtype == SamplingType.VECT:
  247. samtype = SamplingType.VECT
  248. else:
  249. samtype = samplingtype
  250. return samtype
  251. def _write_area(self, fil):
  252. """!Write the area according the type"""
  253. samtype = self.getSamplingType()
  254. #sampling type is whole
  255. if samtype == SamplingType.WHOLE:
  256. cl = float(self.SF_CL) / float(self.rasterinfo['cols'])
  257. rl = float(self.SF_RL) / float(self.rasterinfo['rows'])
  258. #this two variable are unused, problably to remove
  259. x = float(self.SF_X) / float(self.rasterinfo['cols'])
  260. y = float(self.SF_Y) / float(self.rasterinfo['rows'])
  261. fil.write("SAMPLEAREA %r|%r|%r|%r\n" % (self.per_x, self.per_y,
  262. rl, cl))
  263. ##KMWINC = samplingtype=moving, regionbox=keyboard, shape=circle
  264. elif samtype == SamplingType.KMVWINC:
  265. self._circle(self.moving.width, self.moving.height)
  266. cl = float(self.CIR_CL) / float(self.rasterinfo['cols'])
  267. rl = float(self.CIR_RL) / float(self.rasterinfo['rows'])
  268. fil.write("MASKEDSAMPLEAREA -1|-1|%r|%r" % (rl, cl))
  269. fil.write("|%s" % self.moving.height)
  270. fil.write("\nMOVINGWINDOW\n")
  271. ##KMWINR = samplingtype moving, regionbox=keyboard, shape=rectangle
  272. elif samtype == SamplingType.KMVWINR:
  273. cl = float(self.moving.width) / float(self.rasterinfo['cols'])
  274. rl = float(self.moving.height) / float(self.rasterinfo['rows'])
  275. fil.write("SAMPLEAREA -1|-1|%r|%r" % (rl, cl))
  276. fil.write("\nMOVINGWINDOW\n")
  277. ##MMVWINR = samplingtype moving, regionbox=mouse, shape=rectangle
  278. elif samtype == SamplingType.MMVWINR:
  279. cl = float(self.msAreaList[0]['cols']) / float(self.rasterinfo['cols'])
  280. rl = float(self.msAreaList[0]['rows']) / float(self.rasterinfo['rows'])
  281. fil.write("SAMPLEAREA -1|-1|%r|%r" % (rl, cl))
  282. fil.write("\nMOVINGWINDOW\n")
  283. ##MMVWINR = samplingtype moving, regionbox=mouse, shape=circle
  284. elif samtype == SamplingType.MMVWINC:
  285. self._value_for_circle(self.msAreaList[0].radius)
  286. cl = float(self.CIR_CL) / float(self.rasterinfo['cols'])
  287. rl = float(self.CIR_RL) / float(self.rasterinfo['rows'])
  288. fil.write("SAMPLEAREA -1|-1|%r|%r" % (rl, cl))
  289. fil.write("|%s" % self.msAreaList[0].raster)
  290. fil.write("\nMOVINGWINDOW\n")
  291. ##KUNITSC = samplingtype=units, regionbox=keyboard, shape=cirlce
  292. ##KUNITSR = samplingtype=units, regionbox=keyboard, shape=rectangle
  293. elif samtype == SamplingType.KUNITSC or samtype == SamplingType.KUNITSR:
  294. if samtype == SamplingType.KUNITSC:
  295. self._circle(self.units.width, self.units.height)
  296. cl = float(self.CIR_CL) / float(self.rasterinfo['cols'])
  297. rl = float(self.CIR_RL) / float(self.rasterinfo['rows'])
  298. else:
  299. cl = float(self.moving.width) / float(self.rasterinfo['cols'])
  300. rl = float(self.moving.height) / float(self.rasterinfo['rows'])
  301. fil.write("SAMPLEAREA -1|-1|%r|%r\n" % (rl, cl))
  302. if self.units.distrtype == 'non_overlapping':
  303. fil.write("RANDOMNONOVERLAPPING %s\n" % self.units.distr1)
  304. elif self.units.distrtype == 'systematic_contiguos':
  305. fil.write("SYSTEMATICCONTIGUOUS\n")
  306. elif self.units.distrtype == 'stratified_random':
  307. fil.write("STRATIFIEDRANDOM %s|%s\n" % (self.units.distr1,
  308. self.units.distr2))
  309. elif self.units.distrtype == 'systematic_noncontiguos':
  310. fil.write("SYSTEMATICNONCONTIGUOUS %s\n" % self.units.distr1)
  311. elif self.units.distrtype == 'centered_oversites':
  312. fil.write("")
  313. #elif self.samplingareapage.samplingtype == SamplingType.UNITS and self.samplingareapage.regionbox=='mouse':
  314. ##MUNITSC = samplingtype=units, regionbox=mouse, shape=cirlce
  315. ##MUNITSR = samplingtype=units, regionbox=mouse, shape=rectangle
  316. elif self.samplingareapage.samplingtype in [SamplingType.MUNITSR,
  317. SamplingType.MUNITSC]:
  318. # get the raster region into rastregion
  319. grass.use_temp_region()
  320. grass.run_command('g.region', rast=self.startpage.rast)
  321. rastregion = grass.region()
  322. s_n = rastregion['n']
  323. s_w = rastregion['w']
  324. rows = float(self.rasterinfo['rows'])
  325. cols = float(self.rasterinfo['cols'])
  326. for tregion in self.msAreaList:
  327. if self.samplingareapage.samplingtype == SamplingType.MUNITSC:
  328. tregion = tregion.region
  329. abs_y = abs(round((float(s_n) - tregion['n']) / tregion['nsres']))
  330. abs_x = abs(round((float(s_w) - tregion['w']) / tregion['ewres']))
  331. abs_rl = abs(round((tregion['n'] - tregion['s']) / tregion['nsres']))
  332. abs_cl = abs(round((tregion['e'] - tregion['w']) / tregion['ewres']))
  333. x = float(abs_x) / float(cols)
  334. y = float(abs_y) / float(rows)
  335. rl = float(abs_rl) / float(rows)
  336. cl = float(abs_cl) / float(cols)
  337. sarea = str(x) + "|" + str(y) + "|" + str(rl) + "|" + str(cl)
  338. if self.samplingareapage.samplingtype == SamplingType.MUNITSR:
  339. fil.write("SQUAREAREA %s\n" % sarea)
  340. elif self.samplingareapage.samplingtype == SamplingType.MUNITSC:
  341. fil.write("MASKEDSAMPLEAREA %s" % sarea)
  342. fil.write("|%s\n" % self.msAreaList[0].raster)
  343. elif self.samplingareapage.samplingtype == SamplingType.REGIONS:
  344. rows = float(self.rasterinfo['rows'])
  345. cols = float(self.rasterinfo['cols'])
  346. for marea in self.msAreaList:
  347. gregion = marea.region
  348. abs_y = self.SF_Y + abs(round((self.SF_N - gregion['n']) / self.SF_NSRES))
  349. abs_x = self.SF_X + abs(round((self.SF_W - gregion['w']) / self.SF_EWRES))
  350. abs_rl = abs(round(gregion['n'] - gregion['s']) / self.SF_NSRES)
  351. abs_cl = abs(round(gregion['e'] - gregion['w']) / self.SF_EWRES)
  352. x = float(abs_x) / float(cols)
  353. y = float(abs_y) / float(rows)
  354. rl = float(abs_rl) / float(rows)
  355. cl = float(abs_cl) / float(cols)
  356. maskArea = str(x) + "|" + str(y) + "|" + str(rl) + "|" + str(cl) + "|" + marea.raster
  357. fil.write("SQUAREAREA %s\n" % maskArea)
  358. elif self.samplingareapage.samplingtype == SamplingType.VECT:
  359. for marea in self.msAreaList:
  360. fil.write(marea)
  361. fil.write("RASTERMAP {name}\n".format(name=self.startpage.rast))
  362. fil.write("VECTORMAP {name}\n".format(name=self.startpage.vect))
  363. def _cleanup(self):
  364. """!Clean all the variables to save into configuration file"""
  365. self.startpage.conf_name = ''
  366. self.startpage.rast = ''
  367. self.startpage.vect = ''
  368. self.startpage.region = 'whole'
  369. self.keyboardpage.col_len = ''
  370. self.keyboardpage.col_up = ''
  371. self.keyboardpage.row_len = ''
  372. self.keyboardpage.row_up = ''
  373. self.samplingareapage.samplingtype = 'whole'
  374. self.units.width = ''
  375. self.units.height = ''
  376. self.units.boxtype = ''
  377. self.regions.numregions = 0
  378. self.moving.width = ''
  379. self.moving.height = ''
  380. self.moving.boxtype = ''
  381. class FirstPage(TitledPage):
  382. """
  383. !Set name of configuration file, choose raster and optionally vector/sites
  384. """
  385. def __init__(self, wizard, parent):
  386. TitledPage.__init__(self, wizard, _("Select maps and define name"))
  387. self.region = 'whole'
  388. self.rast = ''
  389. self.conf_name = ''
  390. self.vect = ''
  391. self.parent = parent
  392. #name of output configuration file
  393. self.newconflabel = wx.StaticText(parent=self, id=wx.ID_ANY,
  394. label=_('Name for new configuration file to create'))
  395. self.newconftxt = wx.TextCtrl(parent=self, id=wx.ID_ANY,
  396. size=(250, -1))
  397. wx.CallAfter(self.newconftxt.SetFocus)
  398. self.sizer.Add(item=self.newconflabel, border=5, pos=(0, 0),
  399. flag=wx.ALIGN_LEFT | wx.ALIGN_CENTER_VERTICAL | wx.ALL)
  400. self.sizer.Add(item=self.newconftxt, border=5, pos=(0, 1),
  401. flag=wx.ALIGN_LEFT | wx.ALIGN_CENTER_VERTICAL | wx.ALL)
  402. #raster
  403. self.mapsellabel = wx.StaticText(parent=self, id=wx.ID_ANY,
  404. label=_('Raster map to use to select areas'))
  405. self.mapselect = gselect.Select(parent=self, id=wx.ID_ANY,
  406. size=(250, -1), type='cell',
  407. multiple=False)
  408. self.sizer.Add(item=self.mapsellabel, border=5, pos=(1, 0),
  409. flag=wx.ALIGN_LEFT | wx.ALIGN_CENTER_VERTICAL | wx.ALL)
  410. self.sizer.Add(item=self.mapselect, border=5, pos=(1, 1),
  411. flag=wx.ALIGN_LEFT | wx.ALIGN_CENTER_VERTICAL | wx.ALL)
  412. #vector
  413. self.vectsellabel = wx.StaticText(parent=self, id=wx.ID_ANY,
  414. label=_('Vector map to use to select areas'))
  415. self.vectselect = gselect.Select(parent=self, id=wx.ID_ANY,
  416. size=(250, -1), type='vector',
  417. multiple=False)
  418. self.sizer.Add(item=self.vectsellabel, border=5, pos=(2, 0),
  419. flag=wx.ALIGN_LEFT | wx.ALIGN_CENTER_VERTICAL | wx.ALL)
  420. self.sizer.Add(item=self.vectselect, border=5, pos=(2, 1),
  421. flag=wx.ALIGN_LEFT | wx.ALIGN_CENTER_VERTICAL | wx.ALL)
  422. #define sampling region
  423. self.sampling_reg = wx.RadioBox(parent=self, id=wx.ID_ANY,
  424. label=" %s " % _("Define sampling " \
  425. " region (region for analysis)"),
  426. choices=[_('Whole map layer'),
  427. _('Keyboard setting'),
  428. _('Draw the sampling frame')],
  429. majorDimension=1,
  430. style=wx.RA_SPECIFY_ROWS)
  431. self.sizer.Add(item=self.sampling_reg,
  432. flag=wx.ALIGN_CENTER | wx.ALL | wx.EXPAND, border=5,
  433. pos=(4, 0), span=(1, 2))
  434. #bindings
  435. self.sampling_reg.Bind(wx.EVT_RADIOBOX, self.OnSampling)
  436. self.newconftxt.Bind(wx.EVT_KILL_FOCUS, self.OnName)
  437. self.newconftxt.Bind(wx.EVT_TEXT, self.OnNameChanged)
  438. self.vectselect.Bind(wx.EVT_TEXT, self.OnVector)
  439. self.mapselect.Bind(wx.EVT_TEXT, self.OnRast)
  440. self.Bind(wiz.EVT_WIZARD_PAGE_CHANGING, self.OnExitPage)
  441. wx.CallAfter(wx.FindWindowById(wx.ID_FORWARD).Enable, False)
  442. def OnSampling(self, event):
  443. """!Change region type"""
  444. if event.GetInt() == 0:
  445. self.region = 'whole'
  446. self.SetNext(self.parent.samplingareapage)
  447. elif event.GetInt() == 1:
  448. self.region = 'key'
  449. self.SetNext(self.parent.keyboardpage)
  450. elif event.GetInt() == 2: # currently disabled
  451. self.region = 'draw'
  452. self.SetNext(self.parent.drawsampleframepage)
  453. def OnName(self, event):
  454. """!Sets the name of configuration file"""
  455. if self.conf_name in self.parent.parent.listfiles:
  456. GMessage(parent=self, message=_("The configuration file %s "
  457. "already exists, please change name") % self.conf_name)
  458. self.newconftxt.SetValue('')
  459. self.conf_name = ''
  460. def OnNameChanged(self, event):
  461. """!Name of configuration file has changed"""
  462. self.conf_name = self.newconftxt.GetValue()
  463. next = wx.FindWindowById(wx.ID_FORWARD)
  464. next.Enable(self.CheckInput())
  465. def OnRast(self, event):
  466. """!Sets raster map"""
  467. self.rast = event.GetString()
  468. next = wx.FindWindowById(wx.ID_FORWARD)
  469. next.Enable(self.CheckInput())
  470. def OnVector(self, event):
  471. """!Sets vector map"""
  472. self.vect = event.GetString()
  473. next = wx.FindWindowById(wx.ID_FORWARD)
  474. next.Enable(self.CheckInput())
  475. def CheckInput(self):
  476. """!Check input fields.
  477. @return True if configuration file is given and raster xor vector map,
  478. False otherwise
  479. """
  480. #R#return bool(self.conf_name and (bool(self.rast) != bool(self.vect)))
  481. return bool(self.conf_name and bool(self.rast))
  482. def OnExitPage(self, event=None):
  483. """!Function during exiting"""
  484. if self.conf_name == '' or self.rast == '':
  485. wx.FindWindowById(wx.ID_FORWARD).Enable(False)
  486. else:
  487. wx.FindWindowById(wx.ID_FORWARD).Enable(True)
  488. if event.GetDirection():
  489. if self.region == 'key':
  490. self.SetNext(self.parent.keyboardpage)
  491. self.parent.samplingareapage.SetPrev(self.parent.keyboardpage)
  492. elif self.region == 'whole':
  493. self.SetNext(self.parent.samplingareapage)
  494. self.parent.samplingareapage.SetPrev(self)
  495. elif self.region == 'draw':
  496. self.SetNext(self.parent.drawsampleframepage)
  497. self.parent.samplingareapage.SetPrev(self.parent.drawsampleframepage)
  498. return
  499. class KeyboardPage(TitledPage):
  500. """
  501. !Choose the region setting the values of border using the keyboard
  502. """
  503. def __init__(self, wizard, parent):
  504. TitledPage.__init__(self, wizard, _("Insert sampling frame parameter"))
  505. self.parent = parent
  506. self.sizer.AddGrowableCol(2)
  507. self.col_len = ''
  508. self.row_len = ''
  509. self.col_up = '0'
  510. self.row_up = '0'
  511. #column up/left
  512. self.ColUpLeftlabel = wx.StaticText(parent=self, id=wx.ID_ANY,
  513. label=_("Column of upper left " \
  514. "corner"))
  515. self.ColUpLefttxt = wx.TextCtrl(parent=self, id=wx.ID_ANY,
  516. size=(250, -1))
  517. wx.CallAfter(self.ColUpLeftlabel.SetFocus)
  518. self.sizer.Add(item=self.ColUpLeftlabel, border=5, pos=(1, 1),
  519. flag=wx.ALIGN_LEFT | wx.ALIGN_CENTER_VERTICAL | wx.ALL)
  520. self.sizer.Add(item=self.ColUpLefttxt, border=5, pos=(1, 2),
  521. flag=wx.ALIGN_LEFT | wx.ALIGN_CENTER_VERTICAL | wx.ALL)
  522. #row up/left
  523. self.RowUpLeftlabel = wx.StaticText(parent=self, id=wx.ID_ANY,
  524. label=_('Row of upper left corner'))
  525. self.RowUpLefttxt = wx.TextCtrl(parent=self, id=wx.ID_ANY,
  526. size=(250, -1))
  527. wx.CallAfter(self.RowUpLeftlabel.SetFocus)
  528. self.sizer.Add(item=self.RowUpLeftlabel, border=5, pos=(2, 1),
  529. flag=wx.ALIGN_LEFT | wx.ALIGN_CENTER_VERTICAL | wx.ALL)
  530. self.sizer.Add(item=self.RowUpLefttxt, border=5, pos=(2, 2),
  531. flag=wx.ALIGN_LEFT | wx.ALIGN_CENTER_VERTICAL | wx.ALL)
  532. #row lenght
  533. self.RowLenlabel = wx.StaticText(parent=self, id=wx.ID_ANY,
  534. label=_('Row lenght of sampling frame'))
  535. self.RowLentxt = wx.TextCtrl(parent=self, id=wx.ID_ANY, size=(250, -1))
  536. wx.CallAfter(self.RowLenlabel.SetFocus)
  537. self.sizer.Add(item=self.RowLenlabel, border=5, pos=(3, 1),
  538. flag=wx.ALIGN_LEFT | wx.ALIGN_CENTER_VERTICAL | wx.ALL)
  539. self.sizer.Add(item=self.RowLentxt, border=5, pos=(3, 2),
  540. flag=wx.ALIGN_LEFT | wx.ALIGN_CENTER_VERTICAL | wx.ALL)
  541. #column lenght
  542. self.ColLenlabel = wx.StaticText(parent=self, id=wx.ID_ANY,
  543. label=_('Row lenght of sampling frame'))
  544. self.ColLentxt = wx.TextCtrl(parent=self, id=wx.ID_ANY, size=(250, -1))
  545. wx.CallAfter(self.ColLenlabel.SetFocus)
  546. self.sizer.Add(item=self.ColLenlabel, border=5, pos=(4, 1),
  547. flag=wx.ALIGN_LEFT | wx.ALIGN_CENTER_VERTICAL | wx.ALL)
  548. self.sizer.Add(item=self.ColLentxt, border=5, pos=(4, 2),
  549. flag=wx.ALIGN_LEFT | wx.ALIGN_CENTER_VERTICAL | wx.ALL)
  550. self.ColUpLefttxt.SetValue(self.col_up)
  551. self.RowUpLefttxt.SetValue(self.row_up)
  552. self.ColUpLefttxt.Bind(wx.EVT_KILL_FOCUS, self.OnColLeft)
  553. self.RowUpLefttxt.Bind(wx.EVT_KILL_FOCUS, self.OnRowLeft)
  554. self.ColLentxt.Bind(wx.EVT_KILL_FOCUS, self.OnColLen)
  555. self.RowLentxt.Bind(wx.EVT_KILL_FOCUS, self.OnRowLen)
  556. self.Bind(wiz.EVT_WIZARD_PAGE_CHANGED, self.OnEnterPage)
  557. self.Bind(wiz.EVT_WIZARD_PAGE_CHANGING, self.OnExitPage)
  558. def OnColLeft(self, event):
  559. """!Sets the name of configuration file"""
  560. self.col_up = self.ColUpLefttxt.GetValue()
  561. checkValue(self.col_up)
  562. def OnRowLeft(self, event):
  563. """!Sets the name of configuration file"""
  564. self.row_up = self.RowUpLefttxt.GetValue()
  565. checkValue(self.row_up)
  566. def OnColLen(self, event):
  567. """!Sets the name of configuration file"""
  568. self.col_len = self.ColLentxt.GetValue()
  569. checkValue(self.col_len)
  570. def OnRowLen(self, event):
  571. """!Sets the name of configuration file"""
  572. self.row_len = self.RowLentxt.GetValue()
  573. checkValue(self.row_len)
  574. def OnEnterPage(self, event):
  575. """!Sets the default values, for the entire map
  576. """
  577. #R# check if raster exists before anything
  578. if self.col_len == '' and self.row_len == '':
  579. rastinfo = grast.raster_info(self.parent.startpage.rast)
  580. self.col_len = rastinfo['cols']
  581. self.row_len = rastinfo['rows']
  582. self.ColLentxt.SetValue(self.col_len)
  583. self.RowLentxt.SetValue(self.row_len)
  584. def OnExitPage(self, event=None):
  585. """!Function during exiting"""
  586. if self.row_len == '' or self.col_len == '' or self.row_up == '' or self.col_up == '':
  587. wx.FindWindowById(wx.ID_FORWARD).Enable(False)
  588. else:
  589. wx.FindWindowById(wx.ID_FORWARD).Enable(True)
  590. class DrawSampleFramePage(TitledPage):
  591. """!Choose the region setting the values drawing a box"""
  592. def __init__(self, wizard, parent):
  593. TitledPage.__init__(self, wizard, _("Draw sampling frame"))
  594. self.parent = parent
  595. self.mapPanel = None
  596. self.tregion = None
  597. self.Bind(wiz.EVT_WIZARD_PAGE_CHANGED, self.OnEnterPage)
  598. self.Bind(wiz.EVT_WIZARD_PAGE_CHANGING, self.OnExitPage)
  599. def SampleFrameChanged(self, region):
  600. """"!Enables the next dialog when region is set"""
  601. if region:
  602. self.tregion = region
  603. wx.FindWindowById(wx.ID_FORWARD).Enable(True)
  604. else:
  605. wx.FindWindowById(wx.ID_FORWARD).Enable(False)
  606. def OnEnterPage(self, event):
  607. """!Function during entering"""
  608. if self.mapPanel is None:
  609. self.mapPanel = RLiSetupMapPanel(self, samplingType='drawFrame')
  610. self.mapPanel.sampleFrameChanged.connect(self.SampleFrameChanged)
  611. self.sizer.Add(item=self.mapPanel, flag=wx.EXPAND, pos=(0, 0))
  612. self.sizer.AddGrowableCol(0)
  613. self.sizer.AddGrowableRow(0)
  614. self._raster = None
  615. else:
  616. self.mapPanel._region = {}
  617. self.SampleFrameChanged(region=None)
  618. rast = self.parent.startpage.rast
  619. if self._raster != rast:
  620. map_ = self.mapPanel.GetMap()
  621. map_.DeleteAllLayers()
  622. cmdlist = ['d.rast', 'map=%s' % rast]
  623. map_.AddLayer(ltype='raster', command=cmdlist, active=True,
  624. name=rast, hidden=False, opacity=1.0,
  625. render=True)
  626. def OnExitPage(self, event=None):
  627. """!Function during exiting"""
  628. if event.GetDirection():
  629. self.SetNext(self.parent.samplingareapage)
  630. self.parent.samplingareapage.SetPrev(self)
  631. else:
  632. wx.FindWindowById(wx.ID_FORWARD).Enable(True)
  633. class SamplingAreasPage(TitledPage):
  634. """
  635. Set name of configuration file, choose raster and optionally vector/sites.
  636. This is coming after choose the region
  637. """
  638. def __init__(self, wizard, parent):
  639. TitledPage.__init__(self, wizard, _("Insert sampling areas"))
  640. self.samplingtype = 'whole'
  641. self.parent = parent
  642. # toggles
  643. self.radioBox = wx.RadioBox(parent=self, id=wx.ID_ANY,
  644. label="",
  645. choices=[_("Whole map layer"),
  646. _("Regions"),
  647. _("Sample units"),
  648. _("Moving window"),
  649. _("Select areas from the\n"
  650. "overlayed vector map")],
  651. majorDimension=1,
  652. style=wx.RA_SPECIFY_COLS | wx.NO_BORDER)
  653. # layout
  654. self.sizer.SetVGap(10)
  655. self.sizer.Add(item=self.radioBox, flag=wx.ALIGN_LEFT, pos=(0, 0))
  656. self.regionBox = wx.RadioBox(parent=self, id=wx.ID_ANY,
  657. label=_("Choose a method"),
  658. choices=[_('Use keyboard to enter sampling area'),
  659. _('Use mouse to draw sampling area')],
  660. majorDimension=1,
  661. style=wx.RA_SPECIFY_ROWS)
  662. #self.regionBox.EnableItem(1, False)
  663. self.regionBox.SetItemToolTip(1, _("This option is not supported yet"))
  664. self.sizer.Add(self.regionBox, flag=wx.ALIGN_CENTER, pos=(1, 0))
  665. # bindings
  666. self.radioBox.Bind(wx.EVT_RADIOBOX, self.SetVal)
  667. self.regionBox.Bind(wx.EVT_RADIOBOX, self.OnRegionDraw)
  668. self.regionbox = 'keyboard'
  669. self.regionPanelSizer = wx.GridBagSizer(1, 2)
  670. self.regionNumPanel = wx.Panel(parent=self, id=wx.ID_ANY)
  671. self.regionNumLabel = wx.StaticText(parent=self.regionNumPanel,
  672. id=wx.ID_ANY,
  673. label=_('Number of regions to draw:'))
  674. self.regionNumTxt = wx.TextCtrl(parent=self.regionNumPanel,
  675. id=wx.ID_ANY, size=(50, -1))
  676. self.regionPanelSizer.Add(self.regionNumLabel, flag=wx.ALIGN_CENTER,
  677. pos=(0, 0))
  678. self.regionPanelSizer.Add(self.regionNumTxt, flag=wx.ALIGN_CENTER,
  679. pos=(0, 1))
  680. self.regionNumPanel.SetSizer(self.regionPanelSizer)
  681. self.sizer.Add(self.regionNumPanel, flag=wx.ALIGN_CENTER, pos=(2, 0))
  682. self.areaPanelSizer = wx.GridBagSizer(1, 3)
  683. self.areaPanel = wx.Panel(parent=self, id=wx.ID_ANY)
  684. self.areaText = wx.StaticText(parent=self.areaPanel, id=wx.ID_ANY,
  685. label=_('Do you want to check vector areas?'))
  686. self.areaOK = wx.Button(self.areaPanel, wx.ID_ANY, 'Yes', (50, 80))
  687. self.areaOK.SetToolTip(wx.ToolTip(_("Select if use area by area")))
  688. self.areaNO = wx.Button(self.areaPanel, wx.ID_ANY, 'No', (50, 80))
  689. self.areaNO.SetToolTip(wx.ToolTip(_("All the features will be used")))
  690. self.areaOK.Bind(wx.EVT_BUTTON, self.OnVectYes)
  691. self.areaNO.Bind(wx.EVT_BUTTON, self.OnVectNo)
  692. self.areaPanelSizer.Add(self.areaText, flag=wx.ALIGN_CENTER,
  693. pos=(0, 0))
  694. self.areaPanelSizer.Add(self.areaOK, flag=wx.ALIGN_CENTER,
  695. pos=(0, 1))
  696. self.areaPanelSizer.Add(self.areaNO, flag=wx.ALIGN_CENTER,
  697. pos=(0, 2))
  698. self.areaPanel.SetSizer(self.areaPanelSizer)
  699. self.sizer.Add(self.areaPanel, flag=wx.ALIGN_CENTER, pos=(3, 0))
  700. self.calculatingAreas = wx.StaticText(parent=self, id=wx.ID_ANY,
  701. label=_('Analysing all vector features...'))
  702. self.sizer.Add(self.calculatingAreas, flag=wx.ALIGN_CENTER, pos=(4, 0))
  703. self.numregions = ''
  704. self.regionNumTxt.Bind(wx.EVT_TEXT, self.OnNumRegions)
  705. self.Bind(wiz.EVT_WIZARD_PAGE_CHANGED, self.OnEnterPage)
  706. def OnNumRegions(self, event):
  707. """!Obtain the number of regions"""
  708. if event.GetString():
  709. self.SetNext(self.parent.regions)
  710. wx.FindWindowById(wx.ID_FORWARD).Enable(True)
  711. self.numregions = event.GetString()
  712. else:
  713. wx.FindWindowById(wx.ID_FORWARD).Enable(False)
  714. def OnEnterPage(self, event):
  715. """!Insert values into text controls for summary of location
  716. creation options
  717. """
  718. self.SetVal(None)
  719. if self.parent.startpage.vect:
  720. self.radioBox.ShowItem(4, True)
  721. self.vect_data = []
  722. else:
  723. self.radioBox.ShowItem(4, False)
  724. self.sizer.Layout()
  725. wx.FindWindowById(wx.ID_FORWARD).Enable(True)
  726. def SetVal(self, event):
  727. """!Choose method"""
  728. radio = self.radioBox.GetSelection()
  729. wx.FindWindowById(wx.ID_FORWARD).Enable(True)
  730. if radio == 0:
  731. self.samplingtype = SamplingType.WHOLE
  732. self.DrawNothing()
  733. elif radio == 1:
  734. self.samplingtype = SamplingType.REGIONS
  735. wx.FindWindowById(wx.ID_FORWARD).Enable(False)
  736. elif radio == 2:
  737. self.samplingtype = SamplingType.UNITS
  738. regtype = self.regionBox.GetSelection()
  739. self.RegionDraw(regtype)
  740. elif radio == 3:
  741. self.samplingtype = SamplingType.MVWIN
  742. regtype = self.regionBox.GetSelection()
  743. self.RegionDraw(regtype)
  744. elif radio == 4:
  745. self.samplingtype = SamplingType.VECT
  746. wx.FindWindowById(wx.ID_FORWARD).Enable(False)
  747. self.ShowExtraOptions(self.samplingtype)
  748. def ShowExtraOptions(self, samtype):
  749. """!Show some extra options for some sampling type"""
  750. if samtype == SamplingType.REGIONS:
  751. self.sizer.Hide(self.regionBox)
  752. self.sizer.Hide(self.areaPanel)
  753. self.sizer.Hide(self.calculatingAreas)
  754. self.sizer.Show(self.regionNumPanel)
  755. elif samtype == SamplingType.UNITS or samtype == SamplingType.MVWIN:
  756. self.sizer.Hide(self.regionNumPanel)
  757. self.sizer.Hide(self.areaPanel)
  758. self.sizer.Hide(self.calculatingAreas)
  759. self.sizer.Show(self.regionBox)
  760. elif samtype == SamplingType.VECT:
  761. self.sizer.Hide(self.regionBox)
  762. self.sizer.Hide(self.regionNumPanel)
  763. self.sizer.Hide(self.calculatingAreas)
  764. self.sizer.Show(self.areaPanel)
  765. self.sizer.Layout()
  766. def OnRegionDraw(self, event):
  767. self.RegionDraw(event.GetInt())
  768. return
  769. def OnVectYes(self, event):
  770. """!The user choose to select the vector areas, this function set the
  771. next page to VectorAreasPage"""
  772. self.SetNext(self.parent.vectorareas)
  773. wx.FindWindowById(wx.ID_FORWARD).Enable(True)
  774. self.parent.wizard.ShowPage(self.parent.vectorareas)
  775. def OnVectNo(self, event):
  776. """!The user choose to use all the vector areas, this function analyses
  777. all the vector areas and fill the msAreaList variable"""
  778. self.sizer.Show(self.calculatingAreas)
  779. self.sizer.Hide(self.regionNumPanel)
  780. self.sizer.Hide(self.regionBox)
  781. self.sizer.Hide(self.areaPanel)
  782. self.SetNext(self.parent.summarypage)
  783. vect_cats = sorted(set(grass.parse_command('v.category', input=self.parent.startpage.vect,
  784. option='print',
  785. type='centroid').keys()))
  786. self._progressDlg = wx.ProgressDialog(title=_("Analysing vector"),
  787. message="Analysing vector",
  788. maximum=len(vect_cats),
  789. parent=self,
  790. style=wx.PD_CAN_ABORT | wx.PD_APP_MODAL |
  791. wx.PD_AUTO_HIDE | wx.PD_SMOOTH)
  792. self._progressDlgMax = len(vect_cats)
  793. grass.use_temp_region()
  794. self.parent.msAreaList = sampleAreaVector(self.parent.startpage.vect,
  795. self.parent.startpage.rast,
  796. vect_cats,
  797. self._progressDlg)
  798. grass.del_temp_region()
  799. if self.parent.msAreaList:
  800. self.calculatingAreas.SetLabel(_("All feature are been analyzed."))
  801. wx.FindWindowById(wx.ID_FORWARD).Enable(True)
  802. self.parent.wizard.ShowPage(self.parent.summarypage)
  803. else:
  804. self.calculatingAreas.SetLabel(_("An error occurred"))
  805. self._progressDlg.Destroy()
  806. self._progressDlg = None
  807. def RegionDraw(self, regtype):
  808. """!Set the next page to units or drawunits"""
  809. if regtype == 0:
  810. self.regionbox = 'keyboard'
  811. if self.samplingtype == SamplingType.UNITS:
  812. self.SetNext(self.parent.units)
  813. elif self.samplingtype == SamplingType.MVWIN:
  814. self.SetNext(self.parent.moving)
  815. elif regtype == 1:
  816. self.regionbox = 'mouse'
  817. self.SetNext(self.parent.drawunits)
  818. def DrawNothing(self):
  819. """Remove all the optional choices. Used also when the wizard enter in
  820. SamplingAreasPage, all the optional choices should be hide here"""
  821. self.sizer.Hide(self.regionNumPanel)
  822. self.sizer.Hide(self.regionBox)
  823. self.sizer.Hide(self.areaPanel)
  824. self.sizer.Hide(self.calculatingAreas)
  825. self.sizer.Layout()
  826. self.SetNext(self.parent.summarypage)
  827. class DrawRegionsPage(TitledPage):
  828. def __init__(self, wizard, parent):
  829. self.parent = parent
  830. TitledPage.__init__(self, wizard, _("Draw sampling regions"))
  831. self.regioncount = 0
  832. self.mapPanel = None
  833. self.Bind(wiz.EVT_WIZARD_PAGE_CHANGED, self.OnEnterPage)
  834. #self.Bind(wiz.EVT_WIZARD_PAGE_CHANGING, self.OnExitPage)
  835. def afterRegionDrawn(self, marea):
  836. if marea:
  837. self.parent.msAreaList.append(marea)
  838. self.regioncount = self.regioncount + 1
  839. numregions = int(self.parent.samplingareapage.numregions)
  840. if self.regioncount > numregions:
  841. wx.FindWindowById(wx.ID_FORWARD).Enable(True)
  842. self.parent.wizard.ShowPage(self.parent.summarypage)
  843. else:
  844. self.title.SetLabel(_('Draw sample region ' + \
  845. str(self.regioncount) + ' of ' + \
  846. str(numregions)))
  847. wx.FindWindowById(wx.ID_FORWARD).Enable(False)
  848. def OnEnterPage(self, event):
  849. """!Function during entering"""
  850. if self.parent.samplingareapage.samplingtype == SamplingType.WHOLE:
  851. self.title.SetLabel(_("Draw moving windows region"))
  852. elif self.parent.samplingareapage.samplingtype == SamplingType.UNITS:
  853. self.title.SetLabel(_("Draw sampling region"))
  854. if self.mapPanel is None:
  855. self.mapPanel = RLiSetupMapPanel(self,
  856. samplingType=self.parent.samplingareapage.samplingtype,
  857. )
  858. self.mapPanel.afterRegionDrawn.connect(self.afterRegionDrawn)
  859. self.sizer.Add(item=self.mapPanel, flag=wx.EXPAND, pos=(1, 0))
  860. self.sizer.AddGrowableCol(0)
  861. self.sizer.AddGrowableRow(1)
  862. self._raster = None
  863. rast = self.parent.startpage.rast
  864. self.afterRegionDrawn(marea=None)
  865. if self._raster != rast:
  866. map_ = self.mapPanel.GetMap()
  867. map_.DeleteAllLayers()
  868. cmdlist = ['d.rast', 'map=%s' % rast]
  869. map_.AddLayer(ltype='raster', command=cmdlist, active=True,
  870. name=rast, hidden=False, opacity=1.0,
  871. render=True)
  872. #def OnExitPage(self, event=None):
  873. #!Function during exiting
  874. #print event.GetDirection()
  875. #if event.GetDirection():
  876. # self.SetNext(self.parent.samplingareapage)
  877. # self.parent.samplingareapage.SetPrev(self)
  878. class SampleUnitsKeyPage(TitledPage):
  879. """!Set values from keyboard for sample units
  880. It is used if you choose keyboard from Sampling Units or Moving windows
  881. in sampling areas page
  882. """
  883. def __init__(self, wizard, parent):
  884. TitledPage.__init__(self, wizard, _("Select sample units from keyboard"))
  885. self.parent = parent
  886. self.scrollPanel = scrolled.ScrolledPanel(parent=self, id=wx.ID_ANY)
  887. self.scrollPanel.SetupScrolling(scroll_x=False)
  888. self.panelSizer = wx.GridBagSizer(5, 5)
  889. self.width = ''
  890. self.height = ''
  891. self.boxtype = 'rectangle'
  892. self.distrtype = 'non_overlapping'
  893. # type of shape
  894. self.typeBox = wx.RadioBox(parent=self.scrollPanel, id=wx.ID_ANY,
  895. majorDimension=1, style=wx.RA_SPECIFY_COLS,
  896. label=" %s " % _("Select type of shape"),
  897. choices=[_('Rectangle'), _('Circle'),
  898. ('None')])
  899. self.panelSizer.Add(self.typeBox, flag=wx.ALIGN_LEFT, pos=(0, 0),
  900. span=(1, 2))
  901. self.widthLabel = wx.StaticText(parent=self.scrollPanel, id=wx.ID_ANY)
  902. self.widthTxt = wx.TextCtrl(parent=self.scrollPanel, id=wx.ID_ANY,
  903. size=(250, -1))
  904. self.panelSizer.Add(item=self.widthLabel, pos=(1, 0),
  905. flag=wx.ALIGN_LEFT | wx.ALIGN_CENTER_VERTICAL | wx.ALL)
  906. self.panelSizer.Add(item=self.widthTxt, pos=(1, 1),
  907. flag=wx.ALIGN_LEFT | wx.ALIGN_CENTER_VERTICAL | wx.ALL)
  908. self.heightLabel = wx.StaticText(parent=self.scrollPanel, id=wx.ID_ANY)
  909. self.heightTxt = wx.TextCtrl(parent=self.scrollPanel, id=wx.ID_ANY,
  910. size=(250, -1))
  911. self.panelSizer.Add(item=self.heightLabel, pos=(2, 0),
  912. flag=wx.ALIGN_LEFT | wx.ALIGN_CENTER_VERTICAL | wx.ALL)
  913. self.panelSizer.Add(item=self.heightTxt, pos=(2, 1),
  914. flag=wx.ALIGN_LEFT | wx.ALIGN_CENTER_VERTICAL | wx.ALL)
  915. self.widthLabels = [_('Width size (in cells)? '),
  916. _('What radius size (in meters)? ')]
  917. self.heightLabels = [_('Height size (in cells)? '),
  918. _('Name of the circle mask')]
  919. self.distributionBox = wx.RadioBox(parent=self.scrollPanel,
  920. id=wx.ID_ANY,
  921. majorDimension=1,
  922. style=wx.RA_SPECIFY_COLS,
  923. label= " %s " % _("Select method of sampling unit distribution"),
  924. choices=[_('Random non overlapping'),
  925. _('Systematic contiguos'),
  926. _('Stratified random'),
  927. _('Systematic non contiguos'),
  928. _('Centered over sites')]
  929. )
  930. self.distributionBox.EnableItem(5, False) # disable 'draw' for now
  931. self.panelSizer.Add(item=self.distributionBox, pos=(3, 0), span=(1, 2),
  932. flag=wx.ALIGN_LEFT | wx.ALIGN_CENTER_VERTICAL | wx.ALL)
  933. self.distr1Label = wx.StaticText(parent=self.scrollPanel, id=wx.ID_ANY,
  934. label=_("What number of Sampling " \
  935. "Units to use?"))
  936. self.distr1Txt = wx.TextCtrl(parent=self.scrollPanel, id=wx.ID_ANY,
  937. size=(250, -1))
  938. self.panelSizer.Add(item=self.distr1Label, pos=(4, 0),
  939. flag=wx.ALIGN_LEFT | wx.ALIGN_CENTER_VERTICAL | wx.ALL)
  940. self.panelSizer.Add(item=self.distr1Txt, pos=(4, 1),
  941. flag=wx.ALIGN_LEFT | wx.ALIGN_CENTER_VERTICAL | wx.ALL)
  942. self.distr2Label = wx.StaticText(parent=self.scrollPanel, id=wx.ID_ANY,
  943. label="")
  944. self.distr2Txt = wx.TextCtrl(parent=self.scrollPanel, id=wx.ID_ANY,
  945. size=(250, -1))
  946. self.panelSizer.Add(item=self.distr2Label, pos=(5, 0),
  947. flag=wx.ALIGN_LEFT | wx.ALIGN_CENTER_VERTICAL | wx.ALL)
  948. self.panelSizer.Add(item=self.distr2Txt, pos=(5, 1),
  949. flag=wx.ALIGN_LEFT | wx.ALIGN_CENTER_VERTICAL | wx.ALL)
  950. self.panelSizer.Hide(self.distr2Txt)
  951. self.typeBox.Bind(wx.EVT_RADIOBOX, self.OnType)
  952. self.distributionBox.Bind(wx.EVT_RADIOBOX, self.OnDistr)
  953. self.widthTxt.Bind(wx.EVT_TEXT, self.OnWidth)
  954. self.heightTxt.Bind(wx.EVT_TEXT, self.OnHeight)
  955. self.distr1Txt.Bind(wx.EVT_TEXT, self.OnDistr1)
  956. self.distr2Txt.Bind(wx.EVT_TEXT, self.OnDistr2)
  957. self.Bind(wiz.EVT_WIZARD_PAGE_CHANGED, self.OnEnterPage)
  958. self.sizer.Add(item=self.scrollPanel, pos=(0, 0), flag=wx.EXPAND)
  959. self.sizer.AddGrowableCol(0)
  960. self.sizer.AddGrowableRow(0)
  961. self.scrollPanel.SetSizer(self.panelSizer)
  962. #self.Bind(wiz.EVT_WIZARD_PAGE_CHANGING, self.OnExitPage)
  963. self.OnType(None)
  964. def OnEnterPage(self, event=None):
  965. """!Function during entering"""
  966. # This is an hack to force the user to choose Rectangle or Circle
  967. self.typeBox.SetSelection(2),
  968. self.typeBox.ShowItem(2, False)
  969. self.panelSizer.Layout()
  970. def OnExitPage(self, event=None):
  971. """!Function during exiting"""
  972. if event.GetDirection():
  973. self.SetNext(self.parent.summarypage)
  974. self.SetPrev(self.parent.samplingareapage)
  975. def OnType(self, event):
  976. """!Set if rectangle or circle will be used"""
  977. chosen = self.typeBox.GetSelection()
  978. self.widthLabel.SetLabel(self.widthLabels[chosen])
  979. self.heightLabel.SetLabel(self.heightLabels[chosen])
  980. self.panelSizer.Layout()
  981. if chosen == 0:
  982. self.boxtype = 'rectangle'
  983. else:
  984. self.boxtype = 'circle'
  985. def OnDistr(self, event):
  986. chosen = self.distributionBox.GetSelection()
  987. if chosen == 0:
  988. self.distrtype = 'non_overlapping'
  989. self.distr1Label.SetLabel(_("What number of Sampling Units to use?"))
  990. self.panelSizer.Show(self.distr1Txt)
  991. self.distr2Label.SetLabel("")
  992. self.panelSizer.Hide(self.distr2Txt)
  993. self.panelSizer.Layout()
  994. elif chosen == 1:
  995. self.distrtype = 'systematic_contiguos'
  996. self.distr1Label.SetLabel("")
  997. self.distr2Label.SetLabel("")
  998. self.panelSizer.Hide(self.distr1Txt)
  999. self.panelSizer.Hide(self.distr2Txt)
  1000. self.panelSizer.Layout()
  1001. elif chosen == 2:
  1002. self.distrtype = 'stratified_random'
  1003. self.distr1Label.SetLabel(_("Insert number of row strates"))
  1004. self.distr2Label.SetLabel(_("Insert number of column strates"))
  1005. self.panelSizer.Show(self.distr1Txt)
  1006. self.panelSizer.Show(self.distr2Txt)
  1007. self.panelSizer.Layout()
  1008. elif chosen == 3:
  1009. self.distrtype = 'systematic_noncontiguos'
  1010. self.distr1Label.SetLabel(_("Insert distance between units"))
  1011. self.panelSizer.Show(self.distr1Txt)
  1012. self.distr2Label.SetLabel("")
  1013. self.panelSizer.Hide(self.distr2Txt)
  1014. self.panelSizer.Layout()
  1015. elif chosen == 4:
  1016. self.distrtype = 'centered_oversites'
  1017. self.distr1Label.SetLabel("")
  1018. self.distr2Label.SetLabel("")
  1019. self.panelSizer.Hide(self.distr2Txt)
  1020. self.panelSizer.Hide(self.distr1Txt)
  1021. self.panelSizer.Layout()
  1022. def OnWidth(self, event):
  1023. self.width = event.GetString()
  1024. def OnHeight(self, event):
  1025. self.height = event.GetString()
  1026. def OnDistr1(self, event):
  1027. self.distr1 = event.GetString()
  1028. def OnDistr2(self, event):
  1029. self.distr2 = event.GetString()
  1030. class MovingKeyPage(TitledPage):
  1031. """!Set values from keyboard for sample units"""
  1032. def __init__(self, wizard, parent):
  1033. TitledPage.__init__(self, wizard, _("Set sample units"))
  1034. self.parent = parent
  1035. self.sizer.AddGrowableCol(2)
  1036. self.width = ''
  1037. self.height = ''
  1038. self.boxtype = ''
  1039. # type of shape
  1040. self.typeBox = wx.RadioBox(parent=self, id=wx.ID_ANY,
  1041. label=" %s " % _("Select type of shape"),
  1042. choices=[_('Rectangle'), _('Circle'),
  1043. ('None')],
  1044. majorDimension=1,
  1045. style=wx.RA_SPECIFY_COLS)
  1046. self.sizer.Add(self.typeBox, flag=wx.ALIGN_LEFT, pos=(1, 1))
  1047. self.typeBox.Bind(wx.EVT_RADIOBOX, self.OnType)
  1048. self.Bind(wiz.EVT_WIZARD_PAGE_CHANGED, self.OnEnterPage)
  1049. self.widthLabel = wx.StaticText(parent=self, id=wx.ID_ANY,
  1050. label=_('Width size (in cells) ?'))
  1051. self.widthTxt = wx.TextCtrl(parent=self, id=wx.ID_ANY, size=(250, -1))
  1052. self.sizer.Add(item=self.widthLabel, border=5, pos=(2, 1),
  1053. flag=wx.ALIGN_LEFT | wx.ALIGN_CENTER_VERTICAL | wx.ALL)
  1054. self.sizer.Add(item=self.widthTxt, border=5, pos=(2, 2),
  1055. flag=wx.ALIGN_LEFT | wx.ALIGN_CENTER_VERTICAL | wx.ALL)
  1056. self.heightLabel = wx.StaticText(parent=self, id=wx.ID_ANY,
  1057. label=_('Height size (in cells) ?'))
  1058. self.heightTxt = wx.TextCtrl(parent=self, id=wx.ID_ANY, size=(250, -1))
  1059. self.sizer.Add(item=self.heightLabel, border=5, pos=(3, 1),
  1060. flag=wx.ALIGN_LEFT | wx.ALIGN_CENTER_VERTICAL | wx.ALL)
  1061. self.sizer.Add(item=self.heightTxt, border=5, pos=(3, 2),
  1062. flag=wx.ALIGN_LEFT | wx.ALIGN_CENTER_VERTICAL | wx.ALL)
  1063. self.widthLabels = [_('Width size (in cells)? '),
  1064. _('What radius size (in meters)? ')]
  1065. self.heightLabels = [_('Height size (in cells)? '),
  1066. _('Name of the circle mask')]
  1067. self.widthTxt.Bind(wx.EVT_TEXT, self.OnWidth)
  1068. self.heightTxt.Bind(wx.EVT_TEXT, self.OnHeight)
  1069. def OnEnterPage(self, event):
  1070. # This is an hack to force the user to choose Rectangle or Circle
  1071. self.typeBox.SetSelection(2),
  1072. self.typeBox.ShowItem(2, False)
  1073. if self.parent.samplingareapage.samplingtype == SamplingType.MVWIN:
  1074. self.title.SetLabel(_("Set moving windows"))
  1075. self.OnType(None)
  1076. def OnType(self, event):
  1077. chosen = self.typeBox.GetSelection()
  1078. self.widthLabel.SetLabel(self.widthLabels[chosen])
  1079. self.heightLabel.SetLabel(self.heightLabels[chosen])
  1080. self.sizer.Layout()
  1081. if chosen == 0:
  1082. if self.parent.samplingareapage.samplingtype == SamplingType.MVWIN:
  1083. self.parent.samplingareapage.samplingtype = SamplingType.KMVWINR
  1084. else:
  1085. self.parent.samplingareapage.samplingtype = SamplingType.KUNITSR
  1086. self.boxtype = 'rectangle'
  1087. else:
  1088. if self.parent.samplingareapage.samplingtype == SamplingType.MVWIN:
  1089. self.parent.samplingareapage.samplingtype = SamplingType.KMVWINC
  1090. else:
  1091. self.parent.samplingareapage.samplingtype = SamplingType.KUNITSC
  1092. self.boxtype = 'circle'
  1093. def OnWidth(self, event):
  1094. self.width = event.GetString()
  1095. def OnHeight(self, event):
  1096. self.height = event.GetString()
  1097. class UnitsMousePage(TitledPage):
  1098. """!Choose the sampling area setting the values using the mouse drawing the
  1099. areas with rectangle or circle. It is used both from 'Moving windows'
  1100. and 'Sample units'.
  1101. """
  1102. def __init__(self, wizard, parent):
  1103. self.parent = parent
  1104. self.wizard = wizard
  1105. TitledPage.__init__(self, self.wizard, _("Draw sampling units"))
  1106. self.numregions = ''
  1107. self.mapPanel = None
  1108. # type of shape
  1109. self.typeBox = wx.RadioBox(parent=self, id=wx.ID_ANY,
  1110. majorDimension=1, style=wx.RA_SPECIFY_COLS,
  1111. label=" %s " % _("Select type of shape"),
  1112. choices=[_('Rectangle'), _('Circle'), ('')])
  1113. # This is an hack to force the user to choose Rectangle or Circle
  1114. self.typeBox.SetSelection(2),
  1115. self.typeBox.ShowItem(2, False)
  1116. self.sizer.Add(self.typeBox, flag=wx.ALIGN_LEFT, pos=(0, 0),
  1117. span=(1, 2))
  1118. self.regionPanelSizer = wx.GridBagSizer(1, 2)
  1119. self.regionNumPanel = wx.Panel(parent=self, id=wx.ID_ANY)
  1120. self.regionNumLabel = wx.StaticText(parent=self.regionNumPanel,
  1121. id=wx.ID_ANY,
  1122. label=_('Number of sampling area to draw:'))
  1123. self.regionNumTxt = wx.TextCtrl(parent=self.regionNumPanel,
  1124. id=wx.ID_ANY, size=(50, -1))
  1125. self.regionPanelSizer.Add(self.regionNumLabel, flag=wx.ALIGN_CENTER,
  1126. pos=(0, 0))
  1127. self.regionPanelSizer.Add(self.regionNumTxt, flag=wx.ALIGN_CENTER,
  1128. pos=(0, 1))
  1129. self.regionNumPanel.SetSizer(self.regionPanelSizer)
  1130. self.sizer.Add(self.regionNumPanel, flag=wx.ALIGN_LEFT, pos=(1, 0),
  1131. span=(1, 2))
  1132. self.typeBox.Bind(wx.EVT_RADIOBOX, self.OnType)
  1133. self.regionNumTxt.Bind(wx.EVT_TEXT, self.OnNumRegions)
  1134. self.Bind(wiz.EVT_WIZARD_PAGE_CHANGED, self.OnEnterPage)
  1135. self.sizer.AddGrowableCol(0)
  1136. self.OnType(None)
  1137. self.regionNumTxt.SetValue('')
  1138. def OnEnterPage(self, event):
  1139. """!Function during entering"""
  1140. if self.numregions:
  1141. wx.FindWindowById(wx.ID_FORWARD).Enable(True)
  1142. else:
  1143. wx.FindWindowById(wx.ID_FORWARD).Enable(False)
  1144. if self.parent.samplingareapage.samplingtype in [SamplingType.MVWIN,
  1145. SamplingType.MMVWINR,
  1146. SamplingType.MMVWINC]:
  1147. self.title.SetLabel(_("Draw moving windows region"))
  1148. self.sizer.Hide(self.regionNumPanel)
  1149. wx.FindWindowById(wx.ID_FORWARD).Enable(True)
  1150. elif self.parent.samplingareapage.samplingtype in [SamplingType.UNITS,
  1151. SamplingType.MUNITSR,
  1152. SamplingType.MUNITSC]:
  1153. self.title.SetLabel(_("Draw sampling region"))
  1154. self.sizer.Show(self.regionNumPanel)
  1155. if self.typeBox.GetSelection() == 2:
  1156. wx.FindWindowById(wx.ID_FORWARD).Enable(False)
  1157. self.sizer.Layout()
  1158. def OnType(self, event):
  1159. chosen = self.typeBox.GetSelection()
  1160. if chosen == 0:
  1161. if self.parent.samplingareapage.samplingtype in [SamplingType.MVWIN,
  1162. SamplingType.MMVWINR,
  1163. SamplingType.MMVWINC]:
  1164. self.parent.samplingareapage.samplingtype = SamplingType.MMVWINR
  1165. wx.FindWindowById(wx.ID_FORWARD).Enable(True)
  1166. else:
  1167. self.parent.samplingareapage.samplingtype = SamplingType.MUNITSR
  1168. self.drawtype = 'rectangle'
  1169. else:
  1170. if self.parent.samplingareapage.samplingtype in [SamplingType.MVWIN,
  1171. SamplingType.MMVWINR,
  1172. SamplingType.MMVWINC]:
  1173. self.parent.samplingareapage.samplingtype = SamplingType.MMVWINC
  1174. wx.FindWindowById(wx.ID_FORWARD).Enable(True)
  1175. else:
  1176. self.parent.samplingareapage.samplingtype = SamplingType.MUNITSC
  1177. self.drawtype = 'circle'
  1178. def OnNumRegions(self, event):
  1179. """!Set the number of region"""
  1180. if event.GetString():
  1181. self.SetNext(self.parent.drawsampleunitspage)
  1182. wx.FindWindowById(wx.ID_FORWARD).Enable(True)
  1183. self.numregions = event.GetString()
  1184. else:
  1185. wx.FindWindowById(wx.ID_FORWARD).Enable(False)
  1186. def OnExitPage(self, event=None):
  1187. """!Function during exiting"""
  1188. if event.GetDirection():
  1189. self.SetNext(self.drawsampleunitspage)
  1190. self.SetPrev(self.samplingareapage)
  1191. class DrawSampleUnitsPage(TitledPage):
  1192. """!Choose the sampling area drawing them"""
  1193. def __init__(self, wizard, parent):
  1194. TitledPage.__init__(self, wizard, _("Draw sampling units"))
  1195. self.parent = parent
  1196. self.mapPanel = None
  1197. self.Bind(wiz.EVT_WIZARD_PAGE_CHANGED, self.OnEnterPage)
  1198. #self.Bind(wiz.EVT_WIZARD_PAGE_CHANGING, self.OnExitPage)
  1199. def SampleFrameChanged(self, region):
  1200. #region = self.GetSampleUnitRegion()
  1201. if region:
  1202. self.parent.msAreaList.append(region)
  1203. self.regioncount = self.regioncount + 1
  1204. drawtype = self.parent.drawunits.drawtype
  1205. if self.regioncount > self.numregions:
  1206. wx.FindWindowById(wx.ID_FORWARD).Enable(True)
  1207. self.parent.wizard.ShowPage(self.parent.summarypage)
  1208. else:
  1209. self.title.SetLabel(_('Draw Sampling ' + drawtype + ' ' \
  1210. + str(self.regioncount) + ' of ' \
  1211. + str(self.numregions)))
  1212. wx.FindWindowById(wx.ID_FORWARD).Enable(False)
  1213. def OnEnterPage(self, event):
  1214. """!Function during entering"""
  1215. if self.parent.samplingareapage.samplingtype in [SamplingType.MVWIN,
  1216. SamplingType.MMVWINC,
  1217. SamplingType.MMVWINR]:
  1218. self.numregions = 1
  1219. else:
  1220. self.numregions = int(self.parent.drawunits.numregions)
  1221. self.regioncount = 0
  1222. if self.mapPanel:
  1223. self.sizer.Remove(self.mapPanel)
  1224. gtype = self.parent.drawunits.drawtype
  1225. self.mapPanel = RLiSetupMapPanel(self,
  1226. samplingType=self.parent.samplingareapage.samplingtype,
  1227. )
  1228. if gtype == 'circle':
  1229. self.mapPanel.afterCircleDrawn.connect(self.SampleFrameChanged)
  1230. else:
  1231. self.mapPanel.sampleFrameChanged.connect(self.SampleFrameChanged)
  1232. self.sizer.Add(item=self.mapPanel, flag=wx.EXPAND, pos=(1, 0))
  1233. self.sizer.AddGrowableCol(0)
  1234. self.sizer.AddGrowableRow(1)
  1235. self._raster = None
  1236. self.SampleFrameChanged(region=None)
  1237. rast = self.parent.startpage.rast
  1238. if self._raster != rast:
  1239. map_ = self.mapPanel.GetMap()
  1240. map_.DeleteAllLayers()
  1241. cmdlist = ['d.rast', 'map=%s' % rast]
  1242. map_.AddLayer(ltype='raster', command=cmdlist, active=True,
  1243. name=rast, hidden=False, opacity=1.0,
  1244. render=True)
  1245. def OnExitPage(self, event=None):
  1246. #!Function during exiting
  1247. print event.GetDirection()
  1248. #if event.GetDirection():
  1249. # self.SetNext(self.parent.samplingareapage)
  1250. # self.parent.samplingareapage.SetPrev(self)
  1251. class VectorAreasPage(TitledPage):
  1252. """!Choose the sampling area using the vector features"""
  1253. def __init__(self, wizard, parent):
  1254. TitledPage.__init__(self, wizard, _("Select sampling areas"))
  1255. self.parent = parent
  1256. self.areascount = 0
  1257. self.mapPanel = None
  1258. self.Bind(wiz.EVT_WIZARD_PAGE_CHANGED, self.OnEnterPage)
  1259. self.Bind(wiz.EVT_WIZARD_PAGE_CHANGING, self.OnExitPage)
  1260. self.areaPanelSizer = wx.GridBagSizer(1, 3)
  1261. self.areaPanel = wx.Panel(parent=self, id=wx.ID_ANY)
  1262. self.areaText = wx.StaticText(parent=self.areaPanel, id=wx.ID_ANY,
  1263. label=_('Is this area ok?'))
  1264. self.areaOK = wx.Button(self.areaPanel, wx.ID_ANY, 'Yes', (50, 80))
  1265. self.areaNO = wx.Button(self.areaPanel, wx.ID_ANY, 'No', (50, 80))
  1266. self.areaOK.Bind(wx.EVT_BUTTON, self.OnYes)
  1267. self.areaNO.Bind(wx.EVT_BUTTON, self.OnNo)
  1268. self.areaPanelSizer.Add(self.areaText, flag=wx.ALIGN_CENTER,
  1269. pos=(0, 0))
  1270. self.areaPanelSizer.Add(self.areaOK, flag=wx.ALIGN_CENTER,
  1271. pos=(0, 1))
  1272. self.areaPanelSizer.Add(self.areaNO, flag=wx.ALIGN_CENTER,
  1273. pos=(0, 2))
  1274. self.areaPanel.SetSizer(self.areaPanelSizer)
  1275. self.sizer.Add(self.areaPanel, flag=wx.ALIGN_CENTER, pos=(2, 0))
  1276. def afterRegionDrawn(self):
  1277. """!Function to update the title and the number of selected area"""
  1278. self.areascount = self.areascount + 1
  1279. if self.areascount == self.areanum:
  1280. wx.FindWindowById(wx.ID_FORWARD).Enable(True)
  1281. return True
  1282. else:
  1283. self.title.SetLabel(_('Select sample area ' + str(self.areascount + 1) \
  1284. + ' of ' + str(self.areanum)))
  1285. wx.FindWindowById(wx.ID_FORWARD).Enable(False)
  1286. return False
  1287. def OnYes(self, event):
  1288. """!Function to create the string for the conf file if the area
  1289. is selected"""
  1290. self.parent.msAreaList.append(obtainAreaVector(self.outname))
  1291. if not self.afterRegionDrawn():
  1292. self.newCat()
  1293. def OnNo(self, event):
  1294. """!Function to pass to the next feature if it is not selected"""
  1295. if not self.afterRegionDrawn():
  1296. self.newCat()
  1297. def newCat(self):
  1298. """!Convert to raster and draw the new feature"""
  1299. cat = self.vect_cats[self.areascount]
  1300. self.outname = "{name}_{cat}".format(name=self.vect.split('@')[0],
  1301. cat=cat)
  1302. convertFeature(self.vect, self.outname, cat, self.rast)
  1303. cmdlistcat = ['d.rast', 'map=%s' % self.outname]
  1304. self.map_.AddLayer(ltype='raster', command=cmdlistcat, active=True,
  1305. name=self.outname, hidden=False, opacity=1.0,
  1306. render=True)
  1307. for l in self.map_.GetListOfLayers():
  1308. if l.name == self.outname:
  1309. self.mapPanel.mapWindow.ZoomToMap(layers=[l], render=True,
  1310. ignoreNulls=True)
  1311. elif l.name != self.rast:
  1312. self.map_.DeleteLayer(l)
  1313. self.areaText.SetLabel("Is this area (cat={n}) ok?".format(n=cat))
  1314. def OnEnterPage(self, event):
  1315. """!Function during entering: draw the raster map and the first vector
  1316. feature"""
  1317. if self.mapPanel is None:
  1318. self.mapPanel = RLiSetupMapPanel(self, samplingType=self.parent.samplingareapage.samplingtype,
  1319. graphicsType="line")
  1320. self.sizer.Add(item=self.mapPanel, flag=wx.EXPAND, pos=(1, 0))
  1321. self.sizer.AddGrowableCol(0)
  1322. self.sizer.AddGrowableRow(1)
  1323. self._raster = None
  1324. self.rast = self.parent.startpage.rast
  1325. self.vect = self.parent.startpage.vect
  1326. self.vect_cats = sorted(set(grass.parse_command('v.category',
  1327. input=self.vect,
  1328. type='centroid',
  1329. option='print').keys()))
  1330. self.areanum = len(self.vect_cats)
  1331. if self.areanum == 0:
  1332. GError(parent=self, message=_("The polygon seems to have 0 areas"))
  1333. self.parent.wizard.ShowPage(self.parent.samplingareapage)
  1334. return
  1335. self.title.SetLabel(_('Select sample area 1 of ' + str(self.areanum)))
  1336. grass.use_temp_region()
  1337. if self._raster != self.rast:
  1338. self.map_ = self.mapPanel.GetMap()
  1339. self.map_.DeleteAllLayers()
  1340. cmdlist = ['d.rast', 'map=%s' % self.rast]
  1341. self.map_.AddLayer(ltype='raster', command=cmdlist, active=True,
  1342. name=self.rast, hidden=False, opacity=1.0,
  1343. render=True)
  1344. self.newCat()
  1345. def OnExitPage(self, event=None):
  1346. """!Function during exiting"""
  1347. grass.del_temp_region()
  1348. # if event.GetDirection():
  1349. # self.SetNext(self.parent.samplingareapage)
  1350. # self.parent.samplingareapage.SetPrev(self)
  1351. class SummaryPage(TitledPage):
  1352. """!Shows summary result of choosing data"""
  1353. def __init__(self, wizard, parent):
  1354. TitledPage.__init__(self, wizard, _("Summary"))
  1355. global rlisettings
  1356. self.parent = parent
  1357. self.sizer.AddGrowableCol(2)
  1358. #configuration file name
  1359. self.conflabel = wx.StaticText(parent=self, id=wx.ID_ANY,
  1360. label=_('Configuration file name:'))
  1361. self.conftxt = wx.StaticText(parent=self, id=wx.ID_ANY,
  1362. label="")
  1363. self.sizer.Add(item=self.conflabel, border=5, pos=(0, 0),
  1364. flag=wx.ALIGN_LEFT | wx.ALIGN_CENTER_VERTICAL | wx.ALL)
  1365. self.sizer.Add(item=self.conftxt, border=5, pos=(0, 1),
  1366. flag=wx.ALIGN_LEFT | wx.ALIGN_CENTER_VERTICAL | wx.ALL)
  1367. #raster name
  1368. self.rastlabel = wx.StaticText(parent=self, id=wx.ID_ANY,
  1369. label=_('Raster name:'))
  1370. self.rasttxt = wx.StaticText(parent=self, id=wx.ID_ANY,
  1371. label="")
  1372. self.sizer.Add(item=self.rastlabel, border=5, pos=(1, 0),
  1373. flag=wx.ALIGN_LEFT | wx.ALIGN_CENTER_VERTICAL | wx.ALL)
  1374. self.sizer.Add(item=self.rasttxt, border=5, pos=(1, 1),
  1375. flag=wx.ALIGN_LEFT | wx.ALIGN_CENTER_VERTICAL | wx.ALL)
  1376. #vector name
  1377. self.vectlabel = wx.StaticText(parent=self, id=wx.ID_ANY,
  1378. label=_('Vector name:'))
  1379. self.vecttxt = wx.StaticText(parent=self, id=wx.ID_ANY,
  1380. label="")
  1381. self.sizer.Add(item=self.vectlabel, border=5, pos=(2, 0),
  1382. flag=wx.ALIGN_LEFT | wx.ALIGN_CENTER_VERTICAL | wx.ALL)
  1383. self.sizer.Add(item=self.vecttxt, border=5, pos=(2, 1),
  1384. flag=wx.ALIGN_LEFT | wx.ALIGN_CENTER_VERTICAL | wx.ALL)
  1385. #region type name
  1386. self.regionlabel = wx.StaticText(parent=self, id=wx.ID_ANY,
  1387. label=_('Region type:'))
  1388. self.regiontxt = wx.StaticText(parent=self, id=wx.ID_ANY,
  1389. label="")
  1390. self.sizer.Add(item=self.regionlabel, border=5, pos=(3, 0),
  1391. flag=wx.ALIGN_LEFT | wx.ALIGN_CENTER_VERTICAL | wx.ALL)
  1392. self.sizer.Add(item=self.regiontxt, border=5, pos=(3, 1),
  1393. flag=wx.ALIGN_LEFT | wx.ALIGN_CENTER_VERTICAL | wx.ALL)
  1394. #region keyboard
  1395. self.regionkeylabel = wx.StaticText(parent=self, id=wx.ID_ANY,
  1396. label="")
  1397. self.regionkeytxt = wx.StaticText(parent=self, id=wx.ID_ANY,
  1398. label="")
  1399. self.sizer.Add(item=self.regionkeylabel, border=5, pos=(4, 0),
  1400. flag=wx.ALIGN_LEFT | wx.ALIGN_CENTER_VERTICAL | wx.ALL)
  1401. self.sizer.Add(item=self.regionkeytxt, border=5, pos=(4, 1),
  1402. flag=wx.ALIGN_LEFT | wx.ALIGN_CENTER_VERTICAL | wx.ALL)
  1403. self.Bind(wiz.EVT_WIZARD_PAGE_CHANGED, self.OnEnterPage)
  1404. #sampling area
  1405. self.samplinglabel = wx.StaticText(parent=self, id=wx.ID_ANY,
  1406. label=_('Sampling area type:'))
  1407. self.samplingtxt = wx.StaticText(parent=self, id=wx.ID_ANY,
  1408. label="")
  1409. self.sizer.Add(item=self.samplinglabel, border=5, pos=(5, 0),
  1410. flag=wx.ALIGN_LEFT | wx.ALIGN_CENTER_VERTICAL | wx.ALL)
  1411. self.sizer.Add(item=self.samplingtxt, border=5, pos=(5, 1),
  1412. flag=wx.ALIGN_LEFT | wx.ALIGN_CENTER_VERTICAL | wx.ALL)
  1413. #shapetype
  1414. self.shapelabel = wx.StaticText(parent=self, id=wx.ID_ANY,
  1415. label="")
  1416. self.shapetxt = wx.StaticText(parent=self, id=wx.ID_ANY,
  1417. label="")
  1418. self.sizer.Add(item=self.shapelabel, border=5, pos=(6, 0),
  1419. flag=wx.ALIGN_LEFT | wx.ALIGN_CENTER_VERTICAL | wx.ALL)
  1420. self.sizer.Add(item=self.shapetxt, border=5, pos=(6, 1),
  1421. flag=wx.ALIGN_LEFT | wx.ALIGN_CENTER_VERTICAL | wx.ALL)
  1422. #shapedim
  1423. self.shapewidthlabel = wx.StaticText(parent=self, id=wx.ID_ANY,
  1424. label="")
  1425. self.shapewidthtxt = wx.StaticText(parent=self, id=wx.ID_ANY,
  1426. label="")
  1427. self.sizer.Add(item=self.shapewidthlabel, border=5, pos=(7, 0),
  1428. flag=wx.ALIGN_LEFT | wx.ALIGN_CENTER_VERTICAL | wx.ALL)
  1429. self.sizer.Add(item=self.shapewidthtxt, border=5, pos=(7, 1),
  1430. flag=wx.ALIGN_LEFT | wx.ALIGN_CENTER_VERTICAL | wx.ALL)
  1431. self.shapeheightlabel = wx.StaticText(parent=self, id=wx.ID_ANY,
  1432. label="")
  1433. self.shapeheighttxt = wx.StaticText(parent=self, id=wx.ID_ANY,
  1434. label="")
  1435. self.sizer.Add(item=self.shapeheightlabel, border=5, pos=(8, 0),
  1436. flag=wx.ALIGN_LEFT | wx.ALIGN_CENTER_VERTICAL | wx.ALL)
  1437. self.sizer.Add(item=self.shapeheighttxt, border=5, pos=(8, 1),
  1438. flag=wx.ALIGN_LEFT | wx.ALIGN_CENTER_VERTICAL | wx.ALL)
  1439. #units type
  1440. self.unitslabel = wx.StaticText(parent=self, id=wx.ID_ANY, label="")
  1441. self.unitstxt = wx.StaticText(parent=self, id=wx.ID_ANY, label="")
  1442. self.sizer.Add(item=self.unitslabel, border=5, pos=(9, 0),
  1443. flag=wx.ALIGN_LEFT | wx.ALIGN_CENTER_VERTICAL | wx.ALL)
  1444. self.sizer.Add(item=self.unitstxt, border=5, pos=(9, 1),
  1445. flag=wx.ALIGN_LEFT | wx.ALIGN_CENTER_VERTICAL | wx.ALL)
  1446. self.unitsmorelabel = wx.StaticText(parent=self, id=wx.ID_ANY,
  1447. label="")
  1448. self.unitsmoretxt = wx.StaticText(parent=self, id=wx.ID_ANY, label="")
  1449. self.sizer.Add(item=self.unitsmorelabel, border=5, pos=(10, 0),
  1450. flag=wx.ALIGN_LEFT | wx.ALIGN_CENTER_VERTICAL | wx.ALL)
  1451. self.sizer.Add(item=self.unitsmoretxt, border=5, pos=(10, 1),
  1452. flag=wx.ALIGN_LEFT | wx.ALIGN_CENTER_VERTICAL | wx.ALL)
  1453. self.unitsmorelabel2 = wx.StaticText(parent=self, id=wx.ID_ANY,
  1454. label="")
  1455. self.unitsmoretxt2 = wx.StaticText(parent=self, id=wx.ID_ANY, label="")
  1456. self.sizer.Add(item=self.unitsmorelabel2, border=5, pos=(11, 0),
  1457. flag=wx.ALIGN_LEFT | wx.ALIGN_CENTER_VERTICAL | wx.ALL)
  1458. self.sizer.Add(item=self.unitsmoretxt2, border=5, pos=(11, 1),
  1459. flag=wx.ALIGN_LEFT | wx.ALIGN_CENTER_VERTICAL | wx.ALL)
  1460. def OnEnterPage(self, event):
  1461. """!Insert values into text controls for summary of location
  1462. creation options
  1463. """
  1464. self.conftxt.SetLabel(self.parent.startpage.conf_name)
  1465. self.rasttxt.SetLabel(self.parent.startpage.rast)
  1466. self.samplingtxt.SetLabel(self.parent.samplingareapage.samplingtype)
  1467. self.regiontxt.SetLabel(self.parent.startpage.region)
  1468. self.vecttxt.SetLabel(self.parent.startpage.vect)
  1469. if self.parent.startpage.region == 'key':
  1470. #region keyboard values
  1471. self.regionkeylabel.SetLabel(_('Region keyboard values:'))
  1472. regKeyVals = "Column left up: %s - Row left up: %s\n" \
  1473. "Column length: %s - Row length: %s\n" % (
  1474. self.parent.keyboardpage.col_up,
  1475. self.parent.keyboardpage.row_up,
  1476. self.parent.keyboardpage.col_len,
  1477. self.parent.keyboardpage.row_len)
  1478. self.regionkeytxt.SetLabel(regKeyVals)
  1479. else:
  1480. self.regionkeylabel.SetLabel("")
  1481. self.regionkeytxt.SetLabel("")
  1482. if self.parent.samplingareapage.samplingtype == SamplingType.UNITS \
  1483. and self.parent.samplingareapage.regionbox == 'keyboard':
  1484. self.shapelabel.SetLabel(_('Type of shape:'))
  1485. self.shapetxt.SetLabel(self.parent.units.boxtype)
  1486. if self.parent.units.boxtype == 'circle':
  1487. self.shapewidthlabel.SetLabel(_("Radius size:"))
  1488. self.shapeheightlabel.SetLabel(_("Name circle mask:"))
  1489. else:
  1490. self.shapewidthlabel.SetLabel(_("Width size:"))
  1491. self.shapeheightlabel.SetLabel(_("Heigth size:"))
  1492. self.shapewidthtxt.SetLabel(self.parent.units.width)
  1493. self.shapeheighttxt.SetLabel(self.parent.units.height)
  1494. self.unitslabel.SetLabel(_("Method of distribution:"))
  1495. self.unitstxt.SetLabel(self.parent.units.distrtype)
  1496. if self.parent.units.distrtype == 'non_overlapping':
  1497. self.unitsmorelabel.SetLabel(_("Number sampling units:"))
  1498. self.unitsmoretxt.SetLabel(self.parent.units.distr1)
  1499. elif self.parent.units.distrtype == 'systematic_noncontiguos':
  1500. self.unitsmorelabel.SetLabel(_("Distance between units:"))
  1501. self.unitsmoretxt.SetLabel(self.parent.units.distr1)
  1502. elif self.parent.units.distrtype == 'stratified_random':
  1503. self.unitsmorelabel.SetLabel(_("Number row strates:"))
  1504. self.unitsmoretxt.SetLabel(self.parent.units.distr1)
  1505. self.unitsmorelabel2.SetLabel(_("Number column strates:"))
  1506. self.unitsmoretxt2.SetLabel(self.parent.units.distr2)
  1507. elif self.parent.samplingareapage.samplingtype == SamplingType.UNITS \
  1508. and self.parent.samplingareapage.regionbox == 'mouse':
  1509. self.shapelabel.SetLabel(_('Type of shape:'))
  1510. self.shapetxt.SetLabel(self.parent.units.boxtype)
  1511. self.unitstxt.SetLabel('by mouse')
  1512. elif self.parent.samplingareapage.samplingtype == 'moving':
  1513. self.shapelabel.SetLabel(_('Type of shape:'))
  1514. self.shapetxt.SetLabel(self.parent.moving.boxtype)
  1515. if self.parent.moving.boxtype == 'circle':
  1516. self.shapewidthlabel.SetLabel(_("Radius size:"))
  1517. self.shapeheightlabel.SetLabel(_("Name circle mask:"))
  1518. else:
  1519. self.shapewidthlabel.SetLabel(_("Width size:"))
  1520. self.shapeheightlabel.SetLabel(_("Heigth size:"))
  1521. self.shapewidthtxt.SetLabel(self.parent.moving.width)
  1522. self.shapeheighttxt.SetLabel(self.parent.moving.height)
  1523. else:
  1524. self.shapelabel.SetLabel("")
  1525. self.shapetxt.SetLabel("")
  1526. self.shapewidthlabel.SetLabel("")
  1527. self.shapewidthtxt.SetLabel("")
  1528. self.shapeheightlabel.SetLabel("")
  1529. self.shapeheighttxt.SetLabel("")