2 |
# Authors: |
# Authors: |
3 |
# Jonathan Coles <[email protected]> |
# Jonathan Coles <[email protected]> |
4 |
# Frank Koormann <[email protected]> |
# Frank Koormann <[email protected]> |
5 |
|
# Jan-Oliver Wagner <[email protected]> |
6 |
# |
# |
7 |
# This program is free software under the GPL (>=v2) |
# This program is free software under the GPL (>=v2) |
8 |
# Read the file COPYING coming with Thuban for details. |
# Read the file COPYING coming with Thuban for details. |
9 |
|
|
10 |
import os, sys, math |
"""Projection dialog""" |
11 |
|
|
12 |
|
__version__ = "$Revision$" |
13 |
|
# $Source$ |
14 |
|
# $Id$ |
15 |
|
|
16 |
|
import os |
17 |
from wxPython.wx import * |
from wxPython.wx import * |
18 |
|
|
19 |
from Thuban import _ |
from Thuban import _ |
20 |
|
|
21 |
from Thuban.Model.proj import Projection, ProjFile |
from Thuban.Model.proj import Projection, ProjFile |
22 |
|
|
23 |
from Thuban.Model.resource import get_user_proj_files, get_system_proj_files, \ |
from Thuban.Model.resource import get_user_proj_file, get_system_proj_file, \ |
24 |
read_proj_file, write_proj_file |
read_proj_file, write_proj_file |
25 |
from Thuban.UI.dialogs import NonModalNonParentDialog |
from Thuban.UI.dialogs import NonModalNonParentDialog |
26 |
|
|
136 |
|
|
137 |
EVT_TEXT(self, ID_PROJ_PROJNAME, self._OnProjName) |
EVT_TEXT(self, ID_PROJ_PROJNAME, self._OnProjName) |
138 |
|
|
|
|
|
139 |
def OnApply(self, event): |
def OnApply(self, event): |
140 |
self.__SetProjection() |
self.__SetProjection() |
141 |
self.haveTried = True |
self.haveTried = True |
155 |
self.receiver.SetProjection(self.originalProjection) |
self.receiver.SetProjection(self.originalProjection) |
156 |
self.haveTried = False |
self.haveTried = False |
157 |
|
|
|
|
|
158 |
def _OnNew(self, event): |
def _OnNew(self, event): |
159 |
|
|
160 |
# clear all selections |
# clear all selections |
207 |
def _OnProjAvail(self, event): |
def _OnProjAvail(self, event): |
208 |
self.__DoOnProjAvail() |
self.__DoOnProjAvail() |
209 |
|
|
210 |
|
def show_warnings(self, title, filename, warnings): |
211 |
|
"""Show the warnings (a list of strings) in a dialog |
212 |
|
|
213 |
|
If the list is empty no dialog will be shown. |
214 |
|
""" |
215 |
|
if warnings: |
216 |
|
text = (_('Warnings when reading "%s":\n\n%s') |
217 |
|
% (filename, "\n\n".join(warnings))) |
218 |
|
self.parent.RunMessageBox(title, text) |
219 |
|
|
220 |
def _OnImport(self, event): |
def _OnImport(self, event): |
221 |
|
|
222 |
dlg = wxFileDialog(self, _("Import"), style = wxOPEN) |
dlg = wxFileDialog(self, _("Import"), style = wxOPEN) |
225 |
path = dlg.GetPath() |
path = dlg.GetPath() |
226 |
|
|
227 |
try: |
try: |
228 |
projFile = read_proj_file(path) |
projFile, warnings = read_proj_file(path) |
229 |
|
self.show_warnings(_("Warnings"), path, warnings) |
230 |
for proj in projFile.GetProjections(): |
for proj in projFile.GetProjections(): |
231 |
self.__usrProjFile.Add(proj) |
self.__usrProjFile.Add(proj) |
232 |
write_proj_file(self.__usrProjFile) |
write_proj_file(self.__usrProjFile) |
389 |
if proj is None: |
if proj is None: |
390 |
# user selected <None> |
# user selected <None> |
391 |
self.projname.Clear() |
self.projname.Clear() |
392 |
|
self.projfilepath.SetLabel(_("Projection File: ")) |
393 |
else: |
else: |
394 |
|
|
395 |
if projfile is not None: |
if projfile is not None: |
396 |
self.projfilepath.SetLabel(projfile.GetFilename()) |
self.projfilepath.SetLabel(_("Projection File: ") + |
397 |
|
os.path.basename(projfile.GetFilename())) |
398 |
else: |
else: |
399 |
# only None if the currently used projection is selected |
# only None if the currently used projection is selected |
400 |
self.projfilepath.SetLabel("") |
self.projfilepath.SetLabel(_("Projection File: ")) |
401 |
|
|
402 |
self.projname.SetValue(proj.GetName()) |
self.projname.SetValue(proj.GetName()) |
403 |
|
|
511 |
# |
# |
512 |
self.availprojs.Append("<None>", (None, None)) |
self.availprojs.Append("<None>", (None, None)) |
513 |
|
|
514 |
projfile = get_system_proj_files() |
projfile, warnings = get_system_proj_file() |
515 |
projfile = projfile[0] |
self.show_warnings(_("Warnings"), projfile.GetFilename(), warnings) |
516 |
for proj in projfile.GetProjections(): |
for proj in projfile.GetProjections(): |
517 |
self.availprojs.Append(proj.GetName(), [proj, projfile]) |
self.availprojs.Append(proj.GetName(), [proj, projfile]) |
518 |
self.__sysProjFile = projfile |
self.__sysProjFile = projfile |
519 |
|
|
520 |
projfile = get_user_proj_files() |
projfile, warnings = get_user_proj_file() |
521 |
projfile = projfile[0] |
self.show_warnings(_("Warnings"), projfile.GetFilename(), warnings) |
522 |
for proj in projfile.GetProjections(): |
for proj in projfile.GetProjections(): |
523 |
self.availprojs.Append(proj.GetName(), [proj, projfile]) |
self.availprojs.Append(proj.GetName(), [proj, projfile]) |
524 |
self.__usrProjFile = projfile |
self.__usrProjFile = projfile |
582 |
grid_sizer_1.Add(20, 20, 0, wxEXPAND, 0) |
grid_sizer_1.Add(20, 20, 0, wxEXPAND, 0) |
583 |
grid_sizer_1.Add(self.availprojs, 1, wxALL|wxEXPAND|wxADJUST_MINSIZE, 4) |
grid_sizer_1.Add(self.availprojs, 1, wxALL|wxEXPAND|wxADJUST_MINSIZE, 4) |
584 |
grid_sizer_1.Add(sizer_15, 0, wxALL|wxEXPAND, 4) |
grid_sizer_1.Add(sizer_15, 0, wxALL|wxEXPAND, 4) |
585 |
grid_sizer_1.Add(self.projfilepath, 0, wxALL|wxADJUST_MINSIZE, 4) |
grid_sizer_1.Add(self.projfilepath, 0, wxEXPAND|wxALL|wxADJUST_MINSIZE, 4) |
586 |
grid_sizer_1.AddGrowableRow(1) |
grid_sizer_1.AddGrowableRow(1) |
587 |
grid_sizer_1.AddGrowableCol(0) |
grid_sizer_1.AddGrowableCol(0) |
588 |
|
|
709 |
def _DoLayout(self): |
def _DoLayout(self): |
710 |
sizer = wxBoxSizer(wxVERTICAL) |
sizer = wxBoxSizer(wxVERTICAL) |
711 |
|
|
712 |
sizer.Add(wxStaticText(self, -1, |
sizer.Add(wxStaticText(self, -1, |
713 |
_("Thuban does not know the parameters for the " + |
_("Thuban does not know the parameters for the" |
714 |
"current projection and cannot display a " + |
" current projection and cannot display a" |
715 |
"configuration panel."))) |
" configuration panel."))) |
716 |
|
|
717 |
ProjPanel._DoLayout(self, sizer) |
ProjPanel._DoLayout(self, sizer) |
718 |
|
|
843 |
ProjPanel.Clear(self) |
ProjPanel.Clear(self) |
844 |
|
|
845 |
def _OnPropose(self, event): |
def _OnPropose(self, event): |
846 |
UTMProposeZoneDialog |
"""Call the propose dialog. |
847 |
|
If the receiver (e.g. the current map) has no bounding box, |
848 |
|
inform the user accordingly. |
849 |
|
""" |
850 |
|
bb = self.receiver.BoundingBox() |
851 |
|
if bb is None: |
852 |
|
dlg = wxMessageDialog(self, |
853 |
|
_("Can not propose: No bounding box found."), |
854 |
|
_("Projection: Propose UTM Zone"), |
855 |
|
wxOK | wxICON_INFORMATION) |
856 |
|
dlg.CenterOnParent() |
857 |
|
result = dlg.ShowModal() |
858 |
|
dlg.Destroy() |
859 |
|
return |
860 |
|
|
861 |
dlg = UTMProposeZoneDialog(self, self.receiver.BoundingBox()) |
dlg = UTMProposeZoneDialog(self, self.receiver.BoundingBox()) |
862 |
if dlg.ShowModal() == wxID_OK: |
if dlg.ShowModal() == wxID_OK: |
863 |
self.__zone.SetValue(dlg.GetProposedZone()) |
self.__zone.SetValue(dlg.GetProposedZone()) |
984 |
ID_UTM_PROPOSE_ZONE_DIALOG_TAKE = 4001 |
ID_UTM_PROPOSE_ZONE_DIALOG_TAKE = 4001 |
985 |
ID_UTM_PROPOSE_ZONE_DIALOG_CANCEL = 4002 |
ID_UTM_PROPOSE_ZONE_DIALOG_CANCEL = 4002 |
986 |
class UTMProposeZoneDialog(wxDialog): |
class UTMProposeZoneDialog(wxDialog): |
987 |
|
|
988 |
"""Propose a sensible Zone considering the current map extent.""" |
"""Propose a sensible Zone considering the current map extent.""" |
989 |
|
|
990 |
def __init__(self, parent, (x, y, x2, y2)): |
def __init__(self, parent, (x, y, x2, y2)): |
991 |
wxDialog.__init__(self, parent, -1, _("Projection: Propose UTM Zone"), |
wxDialog.__init__(self, parent, -1, _("Projection: Propose UTM Zone"), |
992 |
wxDefaultPosition, wxSize(200, 100)) |
wxDefaultPosition, wxSize(200, 100)) |
993 |
self.parent = parent |
self.parent = parent |
|
#x, y, x2, y2 = elf.parent.parent.map_bounding_box |
|
994 |
x = x + 180 |
x = x + 180 |
995 |
x2 = x2 + 180 |
x2 = x2 + 180 |
996 |
center = (x2 - x) / 2 + x |
center = (x2 - x) / 2 + x |
997 |
self.proposedZone = int(center / 6 + 1) |
self.proposedZone = int(center / 6 + 1) |
998 |
self.dialogLayout() |
self.dialogLayout() |
999 |
|
|
1000 |
def dialogLayout(self): |
def dialogLayout(self): |
1001 |
topBox = wxBoxSizer(wxVERTICAL) |
topBox = wxBoxSizer(wxVERTICAL) |
1002 |
|
|
1003 |
textBox = wxBoxSizer(wxVERTICAL) |
textBox = wxBoxSizer(wxVERTICAL) |
1004 |
textBox.Add(wxStaticText(self, -1, _("The current map extent center " + |
textBox.Add(wxStaticText(self, -1, _("The current map extent center " |
1005 |
"lies in UTM Zone")), |
"lies in UTM Zone")), |
1006 |
0, wxALIGN_CENTER|wxALL, 4) |
0, wxALIGN_CENTER|wxALL, 4) |
1007 |
textBox.Add(wxStaticText(self, -1, str(self.proposedZone)), |
textBox.Add(wxStaticText(self, -1, str(self.proposedZone)), |
1008 |
0, wxALIGN_CENTER|wxALL, 4) |
0, wxALIGN_CENTER|wxALL, 4) |
1009 |
|
|
1010 |
topBox.Add(textBox, 1, wxEXPAND|wxALL, 4) |
topBox.Add(textBox, 1, wxEXPAND|wxALL, 4) |
1011 |
|
|
1012 |
buttonBox = wxBoxSizer(wxHORIZONTAL) |
buttonBox = wxBoxSizer(wxHORIZONTAL) |
1013 |
buttonBox.Add(wxButton(self, ID_UTM_PROPOSE_ZONE_DIALOG_TAKE, |
buttonBox.Add(wxButton(self, ID_UTM_PROPOSE_ZONE_DIALOG_TAKE, |
1014 |
_("Take")), 0, wxALL, 4) |
_("Take")), 0, wxALL, 4) |
1017 |
topBox.Add(buttonBox, 0, wxALIGN_CENTER_HORIZONTAL|wxALL, 10) |
topBox.Add(buttonBox, 0, wxALIGN_CENTER_HORIZONTAL|wxALL, 10) |
1018 |
EVT_BUTTON(self, ID_UTM_PROPOSE_ZONE_DIALOG_TAKE, self.OnTake) |
EVT_BUTTON(self, ID_UTM_PROPOSE_ZONE_DIALOG_TAKE, self.OnTake) |
1019 |
EVT_BUTTON(self, ID_UTM_PROPOSE_ZONE_DIALOG_CANCEL, self.OnCancel) |
EVT_BUTTON(self, ID_UTM_PROPOSE_ZONE_DIALOG_CANCEL, self.OnCancel) |
1020 |
|
|
1021 |
self.SetAutoLayout(True) |
self.SetAutoLayout(True) |
1022 |
self.SetSizer(topBox) |
self.SetSizer(topBox) |
1023 |
topBox.Fit(self) |
topBox.Fit(self) |
1024 |
topBox.SetSizeHints(self) |
topBox.SetSizeHints(self) |
1025 |
|
|
1026 |
def OnTake(self, event): |
def OnTake(self, event): |
1027 |
self.EndModal(wxID_OK) |
self.EndModal(wxID_OK) |
1028 |
|
|
1029 |
def OnCancel(self, event): |
def OnCancel(self, event): |
1030 |
self.EndModal(wxID_CANCEL) |
self.EndModal(wxID_CANCEL) |
1031 |
|
|