/[thuban]/branches/WIP-pyshapelib-bramz/Doc/manual/thuban-manual.xml
ViewVC logotype

Diff of /branches/WIP-pyshapelib-bramz/Doc/manual/thuban-manual.xml

Parent Directory Parent Directory | Revision Log Revision Log | View Patch Patch

revision 1719 by jan, Fri Sep 19 09:17:10 2003 UTC revision 2447 by frank, Mon Dec 13 11:53:15 2004 UTC
# Line 2  Line 2 
2  <!DOCTYPE book  <!DOCTYPE book
3          PUBLIC "-//OASIS//DTD DocBook XML V4.2//EN"          PUBLIC "-//OASIS//DTD DocBook XML V4.2//EN"
4          "http://www.oasis-open.org/docbook/xml/4.2/docbookx.dtd"          "http://www.oasis-open.org/docbook/xml/4.2/docbookx.dtd"
5      [<!ENTITY imgscale "70">]>      [<!ENTITY imgscale "60">]>
6  <!-- $Revision$ -->  <!-- $Revision$ -->
7  <book>  <book>
8    <bookinfo>    <bookinfo>
# Line 19  Line 19 
19        </author>        </author>
20          </authorgroup>          </authorgroup>
21      <copyright>      <copyright>
22        <year>2003</year>        <year>2003, 2004</year>
23        <holder>Intevation GmbH</holder>        <holder>Intevation GmbH</holder>
24      </copyright>      </copyright>
25     <revhistory>     <revhistory>
26  <!-- comment this first revision out when releasing a real version -->  <!-- comment this first revision out when releasing a real version -->
 <!--  
27       <revision>       <revision>
28          <revnumber>CVS version $Id$</revnumber>          <revnumber>CVS version $Id$</revnumber>
29          <date></date>          <date></date>
30          <revremark>Under development.</revremark>          <revremark>Under development.</revremark>
31       </revision>       </revision>
32  -->       <revision>
33            <revnumber>1.0.0</revnumber>
34            <date>22-Jan-2004</date>
35            <revremark>
36                            Corresponds to Thuban 1.0.0.
37                            New: Installation instructions for Win32.
38                    </revremark>
39         </revision>
40         <revision>
41            <revnumber>1.0pre3</revnumber>
42            <date>04-Dec-2003</date>
43            <revremark>
44                            Corresponds to Thuban 1.0rc1.
45                            New: I18n, right button legend menu, EPSG projectons,
46                PostGIS support.
47                    </revremark>
48         </revision>
49       <revision>       <revision>
50          <revnumber>1.0pre2</revnumber>          <revnumber>1.0pre2</revnumber>
51          <date>29-Aug-2003</date>          <date>29-Aug-2003</date>
# Line 51  Line 66 
66    <chapter><title>Introduction</title>    <chapter><title>Introduction</title>
67      <para>      <para>
68      Thuban is an interactive geographic data viewer.      Thuban is an interactive geographic data viewer.
69      It has been developed because there was no simple interactive      Its development had been started because there was no simple interactive
70      viewer for geographic information available as Free Software. Thuban is      viewer for geographic information available as Free Software. Thuban is
71      written in Python and C++ and uses the wxWindows library allowing it to      written mainly in Python and uses the wxWidgets (former wxWindows)
72        library allowing it to
73      run on many different platforms, including GNU/Linux and Windows.      run on many different platforms, including GNU/Linux and Windows.
74      </para>      </para>
75      <para>      <para>
# Line 67  Line 83 
83      </para>      </para>
84      <para>      <para>
85      Thuban arranges a session in a hierarchy. A session contains a map which      Thuban arranges a session in a hierarchy. A session contains a map which
86      consists of layers. Each layer represents one kind of data set. For      consists of layers. Each layer represents a data set. For
87      instance, there may be a layer for roads and another layer for buildings.      instance, there may be a layer for roads and another layer for buildings.
88      These layers can either be vector shapes or images.      These layers can either be vector shapes or images.
89      </para>      </para>
# Line 80  Line 96 
96          <ulink url="http://thuban.intevation.org/download.html">          <ulink url="http://thuban.intevation.org/download.html">
97          Thuban Download site          Thuban Download site
98          </ulink>.          </ulink>.
99            </para>
100            <para>
101            Required:
102          <itemizedlist>          <itemizedlist>
103              <listitem><para>Python 2.2.1 (<literal>http://www.python.org</literal>)</para></listitem>              <listitem><para>Python 2.2.1
104              <listitem><para>wxWindows 2.4 (<literal>http://www.wxwindows.org</literal>)</para></listitem>                          (<literal>http://www.python.org</literal>)
105              <listitem><para>wxPython 2.4 (<literal>http://www.wxpython.org</literal>)</para></listitem>                          </para></listitem>
106              <listitem><para>proj 4.4.5 Projection Library (<literal>http://www.remotesensing.org/proj/</literal>)</para></listitem>              <listitem><para>wxWindows 2.4
107              <listitem><para>GDAL 1.1.8 (<literal>http://www.remotesensing.org/gdal/</literal>)</para></listitem>                          (<literal>http://www.wxwindows.org</literal>)
108              <listitem><para>SQLite 2.8.3 (<literal>http://www.hwaci.com/sw/sqlite/</literal>)</para></listitem>                          </para></listitem>
109              <listitem><para>PySQLite 0.4.3 (<literal>http://pysqlite.sourceforge.net</literal>)</para></listitem>              <listitem><para>wxPython 2.4
110                            (<literal>http://www.wxpython.org</literal>)
111                            </para></listitem>
112                <listitem><para>proj 4.4.5 Projection Library
113                            (<literal>http://www.remotesensing.org/proj/</literal>)
114                            </para></listitem>
115                <listitem><para>SQLite 2.8.3
116                            <literal>http://www.hwaci.com/sw/sqlite/</literal>)
117                            </para></listitem>
118                <listitem><para>PySQLite 0.4.3
119                            (<literal>http://pysqlite.sourceforge.net</literal>)
120                            </para></listitem>
121            </itemizedlist>
122            </para>
123            <para>
124            Optional:
125            <itemizedlist>
126                <listitem><para>GDAL 1.1.8
127                            (<literal>http://www.remotesensing.org/gdal/</literal>)
128                            </para></listitem>
129                <listitem><para>psycopg 1.0.8
130                            (<literal>http://initd.org/software/psycopg</literal>)
131                            </para></listitem>
132              </itemizedlist>              </itemizedlist>
133          </para>          </para>
134                  <para>                  <para>
135                  Along with the source codes, the download page also offers                  Along with the source codes, the download page also offers full
136                  full installation packages for Debian, Windows and RPM-based systems                  installation packages for Debian, Windows and RPM-based systems
137                  (Mandrake, RedHat, SuSE, etc).                  (Mandrake, RedHat, SuSE, etc).
138                  </para>                  </para>
139                  <section><title>RPM-based GNU/Linux Systems</title>                  <section><title>RPM-based GNU/Linux Systems</title>
140                          <section><title>Installing Binary Packages</title>                          <section><title>Installing Binary Packages</title>
141                                  <para>                                  <para>
142                                  The most wide-spread RPM-based GNU/Linux Systems are RedHat,                                  The most wide-spread RPM-based GNU/Linux
143                                  Mandrake and SuSE. The documentation of these distributions                                  Systems are RedHat, Mandrake and SuSE.
144                                  should contain information about how to install third-party                                  The documentation of these distributions
145                                  RPM packages. Nonetheless, a short summary is provided here.                                  should contain information about how to
146                                    install third-party RPM packages.
147                                    Nonetheless, a short summary is provided here.
148                                  </para>                                  </para>
149                                  <para>                                  <para>
150                                  RPM packages can be installed applying several tools.                                  RPM packages can be installed applying several
151                                  The most basic one is the command line program "rpm".                                  tools. The most basic one is the command line
152                                  The hardware architecture is identified in the name                                  program "rpm".  The hardware architecture is
153                                  of RPM packages, eg. 'i386' for most Intel/AMD architectures.                                  identified in the name of RPM packages, eg.
154                                  If you have a different hardware architecture, where no                                  'i386' for most Intel/AMD architectures.  
155                                  binary RPM packages are provided, you must rebuild binary                                  If you have a different hardware architecture,
156                                  packages from the RPM source packages first (see below).                                  where no binary RPM packages are provided,
157                                    you must rebuild binary packages from the
158                                    RPM source packages first (see below).
159                                  Typical rpm commands look like:                                  Typical rpm commands look like:
160    
161                                  <programlisting>                                  <programlisting>
162                                  rpm --install Thuban-0.9.0-1.i386.rpm                                  rpm --install Thuban-0.9.0-1.i386.rpm
163                                  </programlisting>                                  </programlisting>
164    
165                                  Depending on what you already have installed on your                                  Depending on what you already have installed
166                                  system, you are informed that some packages are                                  on your system, you are informed that some
167                                  required, but not installed. You need to install them                                  packages are required, but not installed.
168                                  first. Either they are provided by your GNU/Linux distributor                                  You need to install them first. Either they
169                                  or available somewhere on the Internet.                                  are provided by your GNU/Linux distributor
170                                  The more essential and special ones are provided together                                  or available somewhere on the Internet.  
171                                  with the Thuban package.                                  The more essential and special ones are
172                                    provided together with the Thuban package.
173                                  </para>                                  </para>
174    
175                                  <para>                                  <para>
# Line 238  rpm -bb thuban.spec Line 284  rpm -bb thuban.spec
284                          <ulink url="http://www.rpm.org/">homepage of RPM</ulink>.                          <ulink url="http://www.rpm.org/">homepage of RPM</ulink>.
285                                  </para>                                  </para>
286                          </section>                          </section>
287                  </section>                  </section> <!-- Intro - Installation - RPM-->
288    
289                    <section><title>Win32 Systems</title>
290                    <para>
291                            A common installation package of Thuban for Win32
292                            systems is available from the Thuban website download
293                            section. This installation package is configured for
294                            displaying file based vector data (Shapefiles). For the
295                            display of raster data or the connection to spatial
296                            databases additional steps are needed.  
297                    </para>
298                    <para>
299                            The required Python packages are listed and linked on
300                            the download page as well.  If you don't have Python
301                            installed already, download the packages for Python,
302                            wxPython for Python and the SQLite Python Libraries as
303                            well as the Thuban package. Install all four packages
304                            in the order: Python, wxPython, SQLite, Thuban. Follow
305                            the installation instructions provided by the seperate
306                            setups. The Thuban installation package will add an
307                            entry in the menu folder you configured.
308                    </para>
309                    <section><title>Raster Data: Installation of GDAL</title>
310                    <para>
311                            Enabling the raster data features of Thuban is
312                            straight forward. For the examples we assume that
313                            Thuban has been installed under
314                            <literal>C:\Thuban</literal>:
315                            <itemizedlist>
316                            <listitem>
317                            <para>
318                            Download the zip-archive <ulink
319                            url="ftp://intevation.de/thuban/win2k/gdal-win2k.zip"
320                            >gdal-win2k</ulink>.
321                            </para></listitem>
322                            <listitem><para>Extract the archive (e.g. with
323                            <ulink
324                            url="http://www.info-zip.org/pub/infozip/WiZ.html"
325                            >WiZ (InfoZip)</ulink>) into the
326                            <literal>C:\Thuban\Lib</literal>
327                            directory of your Thuban installation.
328                            </para>
329                            </listitem>
330                            <listitem>
331                            <para>
332                            Extent the <varname>PYTHONPATH</varname>
333                            environment variable (in your Windows Control Panel)
334                            to make the new libraries available for Thuban.
335                            <programlisting>
336    %PYTHONPATH%;C:\Thuban\Lib\gdal;C:\Thuban\Lib\gdal\pymod
337                            </programlisting>
338                            </para>
339                            </listitem>
340                            <listitem>
341                            <para>
342                            Extent also the <varname>PATH</varname>
343                            environment variable accordingly:
344                            <programlisting>
345    %PATH%;C:\Thuban\Lib\gdal
346                            </programlisting>
347                            </para>
348                            </listitem>
349                            </itemizedlist>
350                            After this installation steps Thuban is ready to
351                            display raster data (e.g. the
352                            <literal>island.tif</literal> from the Iceland Demo
353                            data set.
354                    </para>
355                    </section> <!-- Win32: GDAL-->
356    
357                    <section><title>Working with PostGIS: Installation of PsycoPG</title>
358                    <para>
359                            To access PostgreSQL/PostGIS spatial databases with
360                            Thuban you have to install the PsycoPG package for
361                            Windows:
362                            <itemizedlist>
363                            <listitem>
364                            <para>
365                            Download the zip-archive
366                            <ulink
367                                    url="http://stickpeople.com/projects/python/win-psycopg/win-psycopg22.zip"
368                            >win-psycopg22.zip</ulink>.
369                            </para>
370                            </listitem>
371                            <listitem>
372                            <para>
373                            Extract the zip-archive into a directory either already
374                            in your <varname>PYTHONPATH</varname> or extent your
375                            <varname>PYTHONPATH</varname> variable to the directory
376                            you have extracted the archive to.
377                            </para>
378                            </listitem>
379                            </itemizedlist>
380                            For installation and maintenance of spatial databases
381                            we refer to the  <ulink
382                            url="http://postgis.refractions.net"
383                            >PostGIS Homepage</ulink>.
384                    </para>
385                    </section> <!-- Win32: PsycoPG-->
386    
387                    </section> <!-- Intro - Installation - Win32 -->
388          </section>          </section>
389    
390            <section><title>Internationalization</title>
391            <para>
392            Thuban is implemented with internationalization support. So far Thuban
393            is translated by volunteers to the following languages (apart from its
394            main language: English):
395            <itemizedlist>
396                <listitem><para>French</para></listitem>
397                <listitem><para>German</para></listitem>
398                <listitem><para>Italian</para></listitem>
399                    <listitem><para>Portuguese (Brazilian)</para></listitem>
400                <listitem><para>Russian</para></listitem>
401                <listitem><para>Spanish</para></listitem>
402            </itemizedlist>
403            </para>
404    
405            <para>
406            To use internationalization under POSIX systems (like GNU/Linux)
407            you have to set the environment variable LC_ALL accordingly (e.g.
408            LC_ALL=fr_FR for the french language support). Please check your
409            systems documentation for details and supported settings.
410            Specifiying LC_ALL on the command line while launching thuban
411            allows appication specific language settings:
412            </para>
413            <programlisting>
414            LC_ALL=fr_FR thuban.py
415            </programlisting>
416    
417            <para>
418            MS Windows users have to specify the language to be used via the control
419            bar (which effects all applications).
420            </para>
421            </section>
422    
423          <section><title>The Main Window</title>          <section><title>The Main Window</title>
424          <para>          <para>
425          <figure>          <figure>
# Line 305  rpm -bb thuban.spec Line 484  rpm -bb thuban.spec
484          If a session is already loaded and has been modified without          If a session is already loaded and has been modified without
485          being saved a prompt will ask if the current session should          being saved a prompt will ask if the current session should
486          be saved. A new session consists of an empty map with no          be saved. A new session consists of an empty map with no
487          layers and no tables.          layers, no tables and no projection.
488          </para>          </para>
489          </section>          </section>
490    
# Line 319  rpm -bb thuban.spec Line 498  rpm -bb thuban.spec
498          for a Thuban Session file. Thuban session files end with          for a Thuban Session file. Thuban session files end with
499          <varname>.thuban</varname>. Selecting a file a clicking          <varname>.thuban</varname>. Selecting a file a clicking
500          <guibutton>OK</guibutton> will load the session into Thuban.          <guibutton>OK</guibutton> will load the session into Thuban.
501                    </para>
502    
503                    <para>
504          If a session is already loaded and has been modified without          If a session is already loaded and has been modified without
505          being saved a prompt will ask if the current session should          being saved a prompt will ask if the current session should
506          be saved.          be saved.
507          </para>          </para>
508                    
509                    <para>
510                    Thuban provides a path recovery feature: If a (shape) file referenced
511                    in a Thuban session cannot be found at the specified location, the user
512                    is prompted a file dialog. Here a new location can be selected for the
513                    currents layer data source. Cancelling the dialog removes the layer
514                    from the session. If a new location has been selected, Thuban checks
515                    this again, if further layers data sources are missing. The user is
516                    informed about this and can accept or cancel the suggestion.
517            </para>
518          </section>          </section>
519    
520          <section><title>Saving a Session</title>          <section><title>Saving a Session</title>
# Line 332  rpm -bb thuban.spec Line 523  rpm -bb thuban.spec
523          <menuchoice>          <menuchoice>
524          <guimenu>File</guimenu>          <guimenu>File</guimenu>
525          <guimenuitem>Save Session</guimenuitem>          <guimenuitem>Save Session</guimenuitem>
526          </menuchoice>. A dialog box will open allowing the user to browse          </menuchoice>.
527                    In the case the session is not a new and unsaved one,
528                    the corresponding file is updated with the current session
529                    data.
530                    In the case the current session is a new one and yet unsaved
531                    a dialog box will open allowing the user to browse
532          the file system and select a place to save the session. Thuban          the file system and select a place to save the session. Thuban
533          sessions should be saved under a name ending in          sessions should be saved under a name ending in
534          <varname>.thuban</varname>. If the file already exists the user          <varname>.thuban</varname>. If the file already exists the user
# Line 391  rpm -bb thuban.spec Line 587  rpm -bb thuban.spec
587    
588          <section><title>Adding and Removing Layers</title>          <section><title>Adding and Removing Layers</title>
589          <para>          <para>
590          There are two types of layers that can be added to a map: Shape layers          There are three types of layers that can be added to a map:
591            Shape layers, database layers
592          and image layers. Shape layers are stored in Shapefile format, a          and image layers. Shape layers are stored in Shapefile format, a
593          widely used file format for storing geographic objects. These          widely used file format for storing geographic objects. These
594          files have the extension ``.shp''. Associated with          files have the extension ``.shp''. Associated with
# Line 401  rpm -bb thuban.spec Line 598  rpm -bb thuban.spec
598          For example, if there is a shape file named roads.shp there must          For example, if there is a shape file named roads.shp there must
599          also be a file roads.dbf.          also be a file roads.dbf.
600          </para>          </para>
601          <para>          <itemizedlist>
602            <listitem>
603            <para>
604          Shape layers can be added to the map with          Shape layers can be added to the map with
605          <menuchoice>          <menuchoice>
606          <guimenu>Map</guimenu>          <guimenu>Map</guimenu>
# Line 417  rpm -bb thuban.spec Line 616  rpm -bb thuban.spec
616                  Use the shift-button together with the left mouse button to extend                  Use the shift-button together with the left mouse button to extend
617                  the selection.                  the selection.
618          </para>          </para>
619            </listitem>
620    
621            <listitem>
622            <para>Database layers can be added to the map with
623            <menuchoice>
624            <guimenu>Map</guimenu>
625            <guimenuitem>Add Database Layer</guimenuitem>
626            </menuchoice>.
627            A dialog with two is list is opened. The left list displays all
628            database connections currently open for the session. You can retrieve
629            a list of available layers from the selected database which is
630            displayed on the right hand. From this list one layer can be selected,
631            the dialog is closed afterwards.
632            </para>
633            <para>
634            See appendix ``Working with PostGIS'' for details.
635            </para>
636            </listitem>
637    
638            <listitem>
639          <para>          <para>
640          Image layers can be added to the map with          Image layers can be added to the map with
641          <menuchoice>          <menuchoice>
# Line 429  rpm -bb thuban.spec Line 647  rpm -bb thuban.spec
647          or in another file. If geographic information cannot be found, Thuban          or in another file. If geographic information cannot be found, Thuban
648          will report an error.          will report an error.
649          </para>          </para>
650            </listitem>
651            </itemizedlist>
652          </section>          </section>
653    
654          <section><title>Navigation</title>          <section><title>Navigation</title>
# Line 720  rpm -bb thuban.spec Line 940  rpm -bb thuban.spec
940          </para>          </para>
941          </listitem>          </listitem>
942          </itemizedlist>          </itemizedlist>
943    
944            <para>
945            The most used layer related actions are also available from a
946            popup menu. It is raised when a layer is clicked with the right mouse
947            button.
948            </para>
949            
950            <para>
951            <figure>
952            <title>Layer Popup Menu</title>
953            <mediaobject>
954            <imageobject><imagedata fileref="../images/3_5_popup_menu.png" format="PNG" scale="&imgscale;"/></imageobject>
955            <imageobject><imagedata fileref="./images/3_5_popup_menu.eps" format="EPS" scale="&imgscale;"/></imageobject>
956            </mediaobject>
957            </figure>
958            </para>
959    
960          <para>          <para>
961          Along the bottom of the legend is the scalebar. The scalebar          Along the bottom of the legend is the scalebar. The scalebar
962          will be available if there are any layers and the  map has a          will be available if there are any layers and the  map has a
# Line 764  rpm -bb thuban.spec Line 1001  rpm -bb thuban.spec
1001    
1002          <section><title>Types of Layers</title>          <section><title>Types of Layers</title>
1003          <para>          <para>
1004          There are two types of layers supported by Thuban: shape layers and          There are three types of layers supported by Thuban: shape layers,
1005            database layers and
1006          image layers. Shape layers consist of vector based shapes with          image layers. Shape layers consist of vector based shapes with
1007          geo-referenced coordinates. There are three types of supported          geo-referenced coordinates. There are three types of supported
1008          shapes: polygons, lines (arc), and points. Image layers can be any image          shapes: polygons, lines (arc), and points. Database layers are similar
1009            to shape layers but loaded from a database instead of the file system.
1010            Image layers can be any image
1011          file format supported by the Geo-spatial Data Abstraction Library          file format supported by the Geo-spatial Data Abstraction Library
1012          (GDAL). The images must have geographic          (GDAL). The images must have geographic
1013          coordinate data either embedded within the file or in a separate          coordinate data either embedded within the file or in a separate
# Line 1099  rpm -bb thuban.spec Line 1339  rpm -bb thuban.spec
1339      </figure>      </figure>
1340      </para>      </para>
1341      <para>      <para>
1342      Thuban is distributed with a sample collection of projections. The      Thuban is distributed with a sample collection of projections and the
1343        set of coordinate systems as used by the EPSG
1344        (European Petroleum Survey Group). This quite large set is only displayed
1345        if activated by the according checkbox. The set falls into two parts:
1346        deprecated lists all projections which are no longer part of the
1347        EPSG data base.
1348        </para>
1349        <para>
1350             The
1351      user can create new projections and make them available to all      user can create new projections and make them available to all
1352      future Thuban sessions. They may also be exported and imported so      future Thuban sessions. They may also be exported and imported so
1353      that custom projections can be distributed.      that custom projections can be distributed.
# Line 1410  rpm -bb thuban.spec Line 1658  rpm -bb thuban.spec
1658                  </para>                  </para>
1659          </section>          </section>
1660    
1661            <section><title>Extensions included in Thuban package</title>
1662                    <para>
1663                    The extensions described in this section are part of the
1664                    Thuban package, but not activated by default.
1665                    You will find them in the Thuban installation directory
1666                    under <literal>Extensions/</literal>. Activate them as personal
1667                    extensions via PYTHONPATH as described in the previous section.
1668                    Stable extensions will appear under the menu
1669                    <menuchoice><guimenu>Extensions</guimenu></menuchoice> and
1670                    extensions which are in experimental state and therefore
1671                    not fully functional under
1672                    <menuchoice><guimenu>Experimental</guimenu></menuchoice>.
1673                    </para>
1674    
1675                    <section><title>Stable extensions</title>
1676                            <para>
1677                            These extensions provide extra-functionality to Thuban
1678                            that has not (yet) been integrated in the main application.
1679                            They are considered to be free of bugs, but may be
1680                            further polished with helpful user interactions.
1681                            </para>
1682                            <section><title>gns2shp</title>
1683                                    <para>
1684                                    This tool converts data of the Geospatial Names Server
1685                                    (GNS, see <ulink url="http://www.nima.mil/gns"/>)
1686                                    into Shapefile format.
1687                                    The above web-site offer to download named places
1688                                    information grouped by countries for all of the world
1689                                    except USA for which other data are provided.
1690                                    </para>
1691                                    <para>
1692                                    If you download and unpack a package, you will have
1693                                    a text-file with suffix .txt.
1694                                    Selecting such a file via gns2shp will create the
1695                                    corresponding Shapefile with the same basename and
1696                                    place it in the same direcory. Afterwards it
1697                                    is automatically loaded into Thuban.
1698                                    The Shapefile will not automatically be delete afterwards.
1699                                    </para>
1700                                    <para>
1701                                    The gns2shp.py module can also be executed on the
1702                                    command line for batch processing purposes.
1703                                    </para>
1704                                    <para>
1705                                    A sample (<literal>ls.txt</literal> for Liechtenstein)
1706                                    is included in the directory
1707                                    <literal>Extensions/gns2shp/test</literal>.
1708                                    </para>
1709                            </section>
1710                    </section>
1711                    <section><title>Experimental extensions</title>
1712                            <para>
1713                            All all of these functions have to be handled with care,
1714                            since they are neither complete nor well tested.
1715                            They are to be seen as a proof-of-concept and may
1716                            additionally in some cases of practical help.
1717                            </para>
1718                            <para>
1719                            Any interest on further improvement of these extensions
1720                            should be communicated towards the developer and user
1721                            community.
1722                            </para>
1723    
1724                            <section><title>importAPR</title>
1725                                    <para>
1726                                    This command offer to load an ESRI� ArcView� project
1727                                    file (suffix .apr) and convert it for use within Thuban.
1728                                    After selecting a apr-file to load, a list
1729                                    will be presented that offers to select one of the views
1730                                    of the apr-file, provided there is more than one.
1731                                    Furthermore, the Session Info-Tree is extended with
1732                                    a complete representation of the parsed apr-file.
1733                                    </para>
1734                                    <para>
1735                                    The legend of Thuban does not yet cover all of the elements as
1736                                    supported by the legend of ArcView�. Therefore, the Thuban
1737                                    map will look different. Furthermore, the apr-format is
1738                                    a proprietary format, not openly documented.
1739                                    Therefore, the interpretation is
1740                                    partly based on reverse engeneering and good guessing.
1741                                    </para>
1742                                    <para>
1743                                    The file-paths within the apr-file may not fit and potentially
1744                                    are subject to fix in the apr-file. You can do this
1745                                    applying any text editor. The paths are either absolute
1746                                    or relative from where Thuban has been started.
1747                                    </para>
1748                                    <para>
1749                                    A sample for the Iceland data is included as
1750                                    <literal>Extensions/importAPR/samples/iceland.apr</literal>.
1751                                    The file-paths are relative from the Thuban main directory.
1752                                    </para>
1753                            </section>
1754                    </section>
1755            </section>
1756    
1757          <section><title>Writing simple extensions</title>          <section><title>Writing simple extensions</title>
1758                  <para>                  <para>
1759                  Writing an extension for Thuban basically means to                  Writing an extension for Thuban basically means to
# Line 1507  registry.Add(Command('hello_world', _('H Line 1851  registry.Add(Command('hello_world', _('H
1851                       helptext = _('Welcome everyone on this planet')))                       helptext = _('Welcome everyone on this planet')))
1852    
1853  # find the extensions menu (create it anew if not found)  # find the extensions menu (create it anew if not found)
1854  extensions_menu = main_menu.find_menu('extensions')  extensions_menu = main_menu.FindOrInsertMenu('extensions', _('E&xtensions'))
 if extensions_menu is None:  
     extensions_menu = main_menu.InsertMenu('extensions', _('E&xtensions'))  
1855    
1856  # finally bind the new command with an entry in the extensions menu  # finally bind the new command with an entry in the extensions menu
1857  extensions_menu.InsertItem('hello_world')  extensions_menu.InsertItem('hello_world')
# Line 1681  extensions_menu.InsertItem('hello_world' Line 2023  extensions_menu.InsertItem('hello_world'
2023      </varlistentry>      </varlistentry>
2024    
2025      <varlistentry>      <varlistentry>
2026        <term>PostGIS</term>
2027        <listitem>
2028            <para>
2029            PostGIS adds support for geographic objects to the PostgreSQL
2030            object-relational database. Different layer types (as for Shapefiles)
2031            are supported. <ulink url="http://postgis.refractions.net">PostGIS
2032            Homepage</ulink>
2033            </para>
2034        </listitem>
2035        </varlistentry>
2036    
2037        <varlistentry>
2038      <term>Raster files</term>      <term>Raster files</term>
2039      <listitem>      <listitem>
2040          <para>          <para>
# Line 1699  extensions_menu.InsertItem('hello_world' Line 2053  extensions_menu.InsertItem('hello_world'
2053      </variablelist>      </variablelist>
2054    </appendix>    </appendix>
2055    
2056      <appendix><title>Working with PostGIS</title>
2057      <para>
2058      This section focusses on the use of PostGIS in the Thuban framework. For
2059      installation and maintenance of spatial databases we refer to the  
2060      <ulink url="http://postgis.refractions.net">PostGIS Homepage</ulink>.
2061      The Thuban PostGIS support requires the
2062      <ulink url="http://initd.org/software/psycopg">psycopg module</ulink>.
2063      </para>
2064    
2065      <para>
2066            Working with PostGIS Databases is seperated into two steps:
2067            <itemizedlist>
2068            <listitem><para>Opening a Database Connection</para></listitem>
2069            <listitem><para>Loading a Data Layer</para></listitem>
2070            </itemizedlist>
2071      </para>
2072            <section><title>Opening a Database Connection</title>
2073            <para>
2074                    Before a data layer can be loaded from a PostGIS database a
2075                    connection with the database has to be established.
2076                    <menuchoice>
2077                    <guimenu>Session</guimenu>
2078                    <guimenuitem>Database Connections ...</guimenuitem>
2079                    </menuchoice> opens a dialog for database connection
2080                    management. In the dialog new connections can be added
2081                    and existing ones can be removed. Removing a database
2082                    connection is not possible if the map still displays a
2083                    layer provided by this database connection.
2084            </para>
2085        <figure>
2086        <title>Database Management Dialog</title>
2087        <mediaobject>
2088        <imageobject><imagedata fileref="../images/app_postgis_db_management.png" format="PNG" scale="&imgscale;"/></imageobject>
2089        <imageobject><imagedata fileref="./images/app_postgis_db_management.eps" format="EPS" scale="&imgscale;"/></imageobject>
2090        </mediaobject>
2091        </figure>
2092    
2093            <para>
2094                    To add a new database connection to the session a dialog is
2095                    opened to specify the relevant connection data. Enter all
2096                    data relevant for your connection. If the connection fails
2097                    the dialog remains open and provides some hints on the failure.
2098            </para>
2099            <figure>
2100            <title>Add Database Dialog</title>
2101            <mediaobject>
2102            <imageobject><imagedata fileref="../images/app_postgis_db_add.png" format="PNG" scale="&imgscale;"/></imageobject>
2103            <imageobject><imagedata fileref="./images/app_postgis_db_add.eps" format="EPS" scale="&imgscale;"/></imageobject>
2104            </mediaobject>
2105            </figure>
2106            
2107            <para>
2108            It is important to note that information on database connections are
2109            also stored with the session. Passwords are NOT stored. If you load a
2110            session with database connections you are asked to enter these
2111            passwords again where required.
2112            </para>
2113    
2114            </section>
2115    
2116            <section><title>Loading a Data Layer</title>
2117            <para>
2118            Data layers as part of a map are loaded with the
2119            <menuchoice>
2120            <guimenu>Map</guimenu>
2121            <guimenuitem>Add Database Layer ...</guimenuitem>
2122            </menuchoice> menu item. A dialog is raised displaying two choice
2123            lists. In the left list all connected databases are shown.
2124            Highlighting
2125            one of these and issuing a retrieval results in a list of available
2126            layer tables from that database. After selection of a
2127            layer the dialog is closed.
2128            </para>
2129            <figure>
2130            <title>Add Database Dialog</title>
2131            <mediaobject>
2132            <imageobject><imagedata fileref="../images/app_postgis_add_layer.png" format="PNG" scale="&imgscale;"/></imageobject>
2133            <imageobject><imagedata fileref="./images/app_postgis_add_layer.eps" format="EPS" scale="&imgscale;"/></imageobject>
2134            </mediaobject>
2135            </figure>
2136            
2137            </section>
2138    
2139      </appendix>
2140    
2141    <appendix><title>Supported Projections</title>    <appendix><title>Supported Projections</title>
2142      <para>      <para>
2143      The following types of projections are directly support by      The following types of projections are directly support by

Legend:
Removed from v.1719  
changed lines
  Added in v.2447

[email protected]
ViewVC Help
Powered by ViewVC 1.1.26