source: trunk/info/info/alkis/alkisgebaeudenw.php @ 372

Revision 357, 12.2 KB checked in by frank.jaeger, 8 years ago (diff)

PostGIS-Function "st_area" mit Prefix "st_" ergänzt.

Line 
1<?php
2/*      alkisgebaeudenw.php - Gebaeudenachweis
3        ALKIS-Buchauskunft, Kommunales Rechenzentrum Minden-Ravensberg/Lippe (Lemgo).
4
5        Version:
6        2011-11-22 Feld ax_gebaeude.description ist entfallen, neue Spalte Zustand
7        2011-11-30 Fehlerkorrektur Gebaeude mit mehreren Adressen nicht mehrfach
8        2013-04-08 deprecated "import_request_variables" ersetzt
9    2014-01-30 pg_free_result
10        2014-09-04 PostNAS 0.8: ohne Tab. "alkis_beziehungen", mehr "endet IS NULL", Spalten varchar statt integer
11        2014-09-10 Bei Relationen den Timestamp abschneiden
12        2014-09-30 Umbenennung SchlÃŒsseltabellen (Prefix), RÃŒckbau substring(gml_id)
13        2015-12-09 Austausch .ico durch .png
14        2015-12-16 area -> st_area
15*/
16session_start();
17$id="n";
18$cntget = extract($_GET);
19require_once("alkis_conf_location.php");
20if ($auth == "mapbender") {require_once($mapbender);}
21include("alkisfkt.php");
22if ($id == "j") {$idanzeige=true;} else {$idanzeige=false;}
23$keys = isset($_GET["showkey"]) ? $_GET["showkey"] : "n";
24if ($keys == "j") {$showkey=true;} else {$showkey=false;}
25?>
26<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
27<html>
28<head>
29        <meta name="author" content="b600352" >
30        <meta http-equiv="cache-control" content="no-cache">
31        <meta http-equiv="pragma" content="no-cache">
32        <meta http-equiv="expires" content="0">
33        <meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
34        <title>ALKIS Geb&auml;udenachweis</title>
35        <link rel="stylesheet" type="text/css" href="alkisauszug.css">
36        <link rel="shortcut icon" type="image/x-icon" href="ico/Haus.ico">
37        <style type='text/css' media='print'>
38                .noprint {visibility: hidden;}
39        </style>
40</head>
41<body>
42<?php
43$con = pg_connect("host=".$dbhost." port=" .$dbport." dbname=".$dbname." user=".$dbuser." password=".$dbpass);
44if (!$con) echo "<p class='err'>Fehler beim Verbinden der DB</p>\n";
45
46// Flurstueck
47$sqlf ="SELECT f.name, f.flurnummer, f.zaehler, f.nenner, f.amtlicheflaeche, f.zeitpunktderentstehung, g.gemarkungsnummer, g.bezeichnung
48FROM ax_flurstueck f LEFT JOIN ax_gemarkung g ON f.land=g.land AND f.gemarkungsnummer=g.gemarkungsnummer
49WHERE f.gml_id= $1 AND f.endet IS NULL;";
50$v=array($gmlid);
51$resf=pg_prepare("", $sqlf);
52$resf=pg_execute("", $v);
53if (!$resf) {
54        echo "\n<p class='err'>Fehler bei Flurst&uuml;cksdaten.</p>\n";
55        if ($debug > 2) {echo "<p class='err'>SQL=<br>".$sqlf."<br>$1 = gml_id = '".$gmlid."'</p>";}
56}
57
58if ($rowf = pg_fetch_array($resf)) {
59        $gemkname=htmlentities($rowf["bezeichnung"], ENT_QUOTES, "UTF-8");
60        $gmkgnr=$rowf["gemarkungsnummer"];
61        $flurnummer=$rowf["flurnummer"];
62        $flstnummer=$rowf["zaehler"];
63        $nenner=$rowf["nenner"];
64        if ($nenner > 0) { // BruchNr
65                $flstnummer.="/".$nenner;
66        }
67        $flstflaeche = $rowf["amtlicheflaeche"] ;
68} else {
69        echo "<p class='err'>Fehler! Kein Treffer fuer gml_id=".$gmlid."</p>";
70}
71
72// Balken
73echo "<p class='geb'>ALKIS Flurst&uuml;ck (Geb&auml;ude) ".$gmkgnr."-".$flurnummer."-".$flstnummer."&nbsp;</p>\n";
74
75echo "\n<h2><img src='ico/Flurstueck.png' width='16' height='16' alt=''> Flurst&uuml;ck (Geb&auml;ude)</h2>\n";
76
77// Kennzeichen in Rahmen
78echo "\n<table class='outer'>\n<tr>\n<td>";
79        echo "\n\t<table class='kennzfs' title='Flurst&uuml;ckskennzeichen'>";
80    echo "\n\t<tr>";
81        echo "\n\t\t<td class='head'>Gmkg</td>";
82        echo "\n\t\t<td class='head'>Flur</td>";
83        echo "\n\t\t<td class='head'>Flurst-Nr.</td>";
84    echo "\n\t</tr>\n\t<tr>";
85        echo "\n\t\t<td title='Gemarkung'>";
86        if  ($showkey) {echo "<span class='key'>".$gmkgnr."</span><br>";}
87        echo $gemkname."&nbsp;</td>";
88        echo "\n\t\t<td title='Flurnummer'>".$flurnummer."</td>";
89        echo "\n\t\t<td title='Flurst&uuml;cksnummer (Z&auml;hler / Nenner)'><span class='wichtig'>".$flstnummer."</span></td>";
90    echo "\n\t</tr>";
91        echo "\n\t</table>";
92echo "\n</td>\n<td>";
93
94// Links zu anderen Nachweisen
95echo "\n\t<p class='nwlink noprint'>";
96        echo "\n\t\t<a href='alkisfsnw.php?gkz=".$gkz."&amp;gmlid=".$gmlid;
97        if ($idanzeige) {echo "&amp;id=j";}
98        if ($showkey)   {echo "&amp;showkey=j";}
99        echo "&amp;eig=n' title='Flurst&uuml;cksnachweis'>Flurst&uuml;ck <img src='ico/Flurstueck_Link.png' width='16' height='16' alt=''></a>";
100echo "\n\t</p>";
101if ($idanzeige) {linkgml($gkz, $gmlid, "Flurst&uuml;ck", "ax_flurstueck"); }
102echo "\n\t</td>\n</tr>\n</table>";
103// Ende Seitenkopf
104
105echo "\n<p class='fsd'>Flurst&uuml;cksfl&auml;che: <b>".number_format($flstflaeche,0,",",".") . " m&#178;</b></p>";
106pg_free_result($resf);
107
108echo "\n\n<h3><img src='ico/Haus.png' width='16' height='16' alt=''> Geb&auml;ude</h3>";
109echo "\n<p>.. auf oder an dem Flurst&uuml;ck. Ermittelt durch Verschneidung der Geometrie.</p>";
110
111// G e b a e u d e
112$sqlg ="SELECT g.gml_id, g.name, g.bauweise, g.gebaeudefunktion, h.bauweise_beschreibung, u.bezeichner, g.zustand, z.bezeichner AS bzustand, ";
113
114// GEB-Flaeche komplett auch die Fl. ausserhalb des FS
115$sqlg.="round(st_area(g.wkb_geometry)::numeric,2) AS gebflae, ";
116
117// wie viel vom GEB liegt im FS?
118$sqlg.="round(st_area(ST_Intersection(g.wkb_geometry,f.wkb_geometry))::numeric,2) AS schnittflae, ";
119
120// liegt das GEB komplett im FS?
121$sqlg.="st_within(g.wkb_geometry,f.wkb_geometry) as drin ";
122
123// FS und GEB geometrisch verschneiden
124$sqlg.="FROM ax_flurstueck f, ax_gebaeude g ";
125
126// Entschluesseln
127$sqlg.="LEFT JOIN v_geb_bauweise h ON g.bauweise=h.bauweise_id
128LEFT JOIN v_geb_funktion u ON g.gebaeudefunktion=u.wert
129LEFT JOIN v_geb_zustand z ON g.zustand=z.wert
130WHERE f.gml_id= $1 AND f.endet IS NULL and g.endet IS NULL "; // ID des akt. FS
131
132// "within" -> nur Geb., die komplett im FS liegen
133// "intersects" -> auch teil-ueberlappende Flst.
134$sqlg.="AND st_intersects(g.wkb_geometry,f.wkb_geometry) = true ";
135// RLP: keine Relationen zu NebengebÀuden. Auf Qualifizierung verzichten, sonst werden NebengebÀude nicht angezeigt
136//$sqlg.="AND (v.beziehungsart='zeigtAuf' OR v.beziehungsart='hat') ";
137$sqlg.="ORDER BY schnittflae DESC;";
138
139$v=array($gmlid);
140$resg=pg_prepare("", $sqlg);
141$resg=pg_execute("", $v);
142if (!$resg) {
143        echo "\n<p class='err'>Keine Geb&auml;ude ermittelt.</p>\n";
144        if ($debug > 2) {echo "<p class='err'>SQL=<br>".$sqlg."<br>$1 = gml_id = '".$gmlid."'</p>";}
145}
146$gebnr=0;
147$gebflsum=0;
148echo "\n<hr>\n<table class='geb'>";
149        // T-Header
150        echo "\n<tr>\n";
151                echo "\n\t<td class='head' title='ggf. Geb&auml;udename'>Name</td>";
152                echo "\n\t<td class='head fla' title='Schnittsfl&auml;che'>Fl&auml;che</td>";
153                echo "\n\t<td class='head' title='Geb&auml;udefl&auml;che'>&nbsp;</td>";
154                echo "\n\t<td class='head' title='Geb&auml;udefunktion ist die zum Zeitpunkt der Erhebung vorherrschend funktionale Bedeutung des Geb&auml;udes'>Funktion</td>";
155                echo "\n\t<td class='head' title='Bauweise (Schl&uuml;ssel und Beschreibung)'>Bauweise</td>";
156                echo "\n\t<td class='head' title='Zustand (Schl&uuml;ssel und Beschreibung)'>Zustand</td>";
157                echo "\n\t<td class='head nwlink' title='Lagebezeichnung mit Stra&szlig;e und Hausnummer'>Lage</td>";
158                echo "\n\t<td class='head nwlink' title='Link zu den kompletten Hausdaten'>Haus</td>";
159        echo "\n</tr>";
160        // T-Body
161        while($rowg = pg_fetch_array($resg)) {
162                $gebnr = $gebnr + 1;
163// ++ ToDo: Die Zeilen abwechselnd verschieden einfÀrben, Angrenzend anders einfÀrben
164                $ggml=$rowg["gml_id"];
165                $gebflsum = $gebflsum + $rowg["schnittflae"];
166        #       $skey=$rowg["lage"]; // Strassenschluessel             
167                $gnam=$rowg["name"];
168                $gzus=$rowg["zustand"];
169                $gzustand=$rowg["bzustand"];
170
171                echo "\n<tr>";
172                        echo "\n\t<td>";
173                                if ($gnam != "") {echo "<span title='Geb&auml;udename'>".$gnam."</span><br>";}
174                        echo "\n\t</td>";
175
176                        if ($rowg["drin"] == "t") { // 3 komplett enthalten
177                                echo "\n\t<td class='fla'>".$rowg["schnittflae"]." m&#178;</td>";
178                                echo "\n\t<td>&nbsp;</td>";
179                        } else {
180                if ($rowg["schnittflae"] == "0.00") { // angrenzend
181                                        echo "\n\t<td class='fla'>&nbsp;</td>";
182                                        echo "\n\t<td>angrenzend</td>";
183                                } else { // Teile enthalten
184                                        echo "\n\t<td class='fla'>".$rowg["schnittflae"]." m&#178;</td>";
185                                        echo "\n\t<td>(von ".$rowg["gebflae"]." m&#178;)</td>";
186                                }
187                        }
188                        echo "\n\t<td>";
189                        if ($showkey) {echo "<span class='key'>".$rowg["gebaeudefunktion"]."</span>&nbsp;";}
190                        echo $rowg["bezeichner"]."</td>";
191
192                        echo "\n\t<td>";
193                        if ($showkey) {echo "<span class='key'>".$rowg["bauweise"]."</span>&nbsp;";}
194                        echo $rowg["bauweise_beschreibung"]."&nbsp;</td>";
195
196                        echo "\n\t<td>";
197                        if ($showkey) {echo "<span class='key'>".$gzus."</span>&nbsp;";}
198                        echo $gzustand."&nbsp;</td>";
199
200                        echo "\n\t<td class='nwlink noprint'>";
201                        // 0 bis N Lagebezeichnungen mit Haus- oder Pseudo-Nummer, alle in ein TD zu EINEM GebÀude
202
203                        // HAUPTgebÀude  Geb >zeigtAuf> lage (mehrere)
204                        $sqll ="SELECT 'm' AS ltyp, l.gml_id AS lgml, s.lage, s.bezeichnung, l.hausnummer, '' AS laufendenummer ";
205                        $sqll.="FROM ax_gebaeude g JOIN ax_lagebezeichnungmithausnummer l ON l.gml_id=ANY(g.zeigtauf) ";
206                        $sqll.="JOIN ax_lagebezeichnungkatalogeintrag s ON l.kreis=s.kreis AND l.gemeinde=s.gemeinde AND l.lage=s.lage ";
207                        $sqll.="WHERE g.gml_id= $1 AND g.endet IS NULL AND l.endet IS NULL AND s.endet IS NULL ";
208
209                        // oder NEBENgebÀude  Geb >hat> Pseudo
210                        $sqll.="UNION SELECT 'p' AS ltyp, l.gml_id AS lgml, s.lage, s.bezeichnung, l.pseudonummer AS hausnummer, l.laufendenummer ";
211                        $sqll.="FROM ax_gebaeude g JOIN ax_lagebezeichnungmitpseudonummer l ON l.gml_id=g.hat ";
212                        $sqll.="JOIN ax_lagebezeichnungkatalogeintrag s ON l.kreis=s.kreis AND l.gemeinde=s.gemeinde AND l.lage=s.lage ";
213                        $sqll.="WHERE g.gml_id= $1 AND g.endet IS NULL AND l.endet IS NULL AND s.endet IS NULL "; // ID des Hauses"
214               
215                        $sqll.="ORDER BY bezeichnung, hausnummer;";
216
217                        $v = array($ggml);
218                        $resl = pg_prepare("", $sqll);
219                        $resl = pg_execute("", $v);
220                        if (!$resl) {
221                                echo "\n<p class='err'>Fehler bei Lage mit HsNr.</p>\n";
222                                if ($debug > 2) {echo "<p class='dbg'>SQL=<br>".$sqll."<br>$1 = gml_id = '".$gmlid."'</p>";}
223                        }
224                        while($rowl = pg_fetch_array($resl)) { // LOOP: Lagezeilen
225                                $ltyp=$rowl["ltyp"]; // Lagezeilen-Typ
226                                $skey=$rowl["lage"]; // Str.-Schluessel
227                                $snam=htmlentities($rowl["bezeichnung"], ENT_QUOTES, "UTF-8"); //-Name
228                                $hsnr=$rowl["hausnummer"];
229                                $hlfd=$rowl["laufendenummer"];
230                                $gmllag=$rowl["lgml"];
231                                if ($ltyp == "p") {
232                                        $lagetitl="NebengebÀude - Pseudonummer";
233                                        $lagetxt="Nebengeb&auml;ude Nr. ".$hlfd;
234                                } else {
235                                        $lagetitl="HauptgebÀude - Hausnummer";
236                                        $lagetxt=$snam."&nbsp;".$hsnr;
237                                }
238                                echo "\n\t\t<img src='ico/Lage_mit_Haus.png' width='16' height='16' alt=''>&nbsp;";
239                                if ($showkey) {echo "<span class='key'>(".$skey.")</span>&nbsp;";}                     
240                                echo "\n\t\t<a title='".$lagetitl."' href='alkislage.php?gkz=".$gkz."&amp;gmlid=".$gmllag."&amp;ltyp=".$ltyp;
241                                        if ($idanzeige) {echo "&amp;id=j";}
242                                        if ($showkey)   {echo "&amp;showkey=j";}
243                                echo "'>".$lagetxt."</a>";
244                                if ($idanzeige) {linkgml($gkz, $gmllag, "Lage", ""); }
245                                echo "<br>";
246                        } // Ende Loop Lage m.H.
247            pg_free_result($resl);
248                        echo "\n\t</td>";
249
250                        echo "\n\t<td class='nwlink noprint'>";
251                                echo "\n\t\t<a title='Daten zum Geb&auml;ude-Objekt' href='alkishaus.php?gkz=".$gkz."&amp;gmlid=".$ggml;
252                                if ($idanzeige) {echo "&amp;id=j";}
253                                if ($showkey)   {echo "&amp;showkey=j";}
254                                echo "'><img src='ico/Haus.png' width='16' height='16' alt=''></a>";
255                        echo "\n\t</td>";
256
257                echo "\n</tr>";
258        }
259        // Footer
260        if ($gebnr == 0) {
261                echo "\n</table>";
262                echo "<p class='err'><br>Keine Geb&auml;ude auf diesem Flurst&uuml;ck.<br>&nbsp;</p>";
263        } else {
264                echo "\n<tr>";
265                        echo "\n\t<td>Summe:</td>"; // 1
266                        echo "\n\t<td class='fla sum'>".number_format($gebflsum,0,",",".")."&nbsp;&nbsp;&nbsp;&nbsp;m&#178;</td>";
267                        echo "\n\t<td>&nbsp;</td>"; // 3
268                        echo "\n\t<td>&nbsp;</td>"; // 4
269                        echo "\n\t<td>&nbsp;</td>"; // 5
270                        echo "\n\t<td>&nbsp;</td>"; // 6
271                        echo "\n\t<td>&nbsp;</td>"; // 7
272                echo "\n</tr>";
273        echo "\n</table>";
274        $unbebaut = number_format(($flstflaeche - $gebflsum),0,",",".") . " m&#178;";
275        echo "\n<p>Flurst&uuml;cksfl&auml;che abz&uuml;glich Geb&auml;udefl&auml;che: <b>".$unbebaut."</b></p><br>";
276}
277pg_free_result($resg);
278?>
279
280<form action=''>
281        <div class='buttonbereich noprint'>
282        <hr>
283                <a title="zur&uuml;ck" href='javascript:history.back()'><img src="ico/zurueck.png" width="16" height="16" alt="zur&uuml;ck"></a>&nbsp;
284                <a title="Drucken" href='javascript:window.print()'><img src="ico/print.png" width="16" height="16" alt="Drucken"></a>
285        </div>
286</form>
287
288<?php footer($gmlid, $_SERVER['PHP_SELF']."?", ""); ?>
289
290</body>
291</html>
Note: See TracBrowser for help on using the repository browser.