source: trunk/info/info/alkisn/alkisgebaeudenw.php @ 425

Revision 425, 26.6 KB checked in by frank.jaeger, 2 years ago (diff)

Web-GIS-Auskunft und Mapbender2-Navigation: neue Konfigurations-Parameter und verbessertes Grundbuch-Modul

Line 
1<?php
2/*      alkisgebaeudenw.php - Gebaeudenachweis
3        ALKIS-Buchauskunft, Kommunales Rechenzentrum Minden-Ravensberg/Lippe (Lemgo).
4
5        Version:
6        2016-02-24 Version fÃŒr norGIS-ALKIS-Import
7        ....
8        2020-02-20 Authentifizierung ausgelegert in Function darf_ich()
9        2020-12-03 function selbstverlinkung() statt $_SERVER['PHP_SELF']
10        2020-12-15 Verschneidung mit "sonstige Bauwerke", Input-Validation und Strict Comparisation
11        2021-03-09 Verschneidung mit weiteren Bauwerks-Tabellen.
12        2021-03-11 Adresse(n) des gehörtZu-Haus zum Bauwerk nicht mehr hier anzeigen sondern im neuen Bauwerk-Modul.
13        2021-12-09 Neue Parameter: $katAmtMix (Kataster-Amt-Mix), $PrntBtn (Drucken-SchaltflÀche)
14*/
15
16// Kopf fÌr die Anzeige der GebÀude. Nur wenn tatsÀchlich GebÀude vorkommen.
17function geb_tab_head() {
18        // Überschrift
19        echo "\n\n<h3><img src='ico/Haus.png' width='16' height='16' alt=''> Geb&auml;ude</h3>"
20        ."\n<p>.. auf oder an dem Flurst&uuml;ck. Ermittelt durch Verschneidung der Geometrie.</p>";
21
22        // Tabellen-Kopf
23        echo "\n<hr>\n<table class='geb'>";
24        echo "\n<tr>"
25                ."\n\t<td class='head' title='ggf. Geb&auml;udename'>Name</td>"
26                ."\n\t<td class='heads fla' title='Schnittfl&auml;che zwischen Flurst&uuml;ck und Geb&auml;ude'><img src='ico/sortd.png' width='10' height='10' alt='' title='Sortierung (absteigend)'>Fl&auml;che</td>"
27                ."\n\t<td class='head' title='gesamte Geb&auml;udefl&auml;che, liegt teilweise auf Nachbar-Flurst&uuml;ck'>&nbsp;</td>"
28                ."\n\t<td class='head' title='Geb&auml;udefunktion ist die zum Zeitpunkt der Erhebung vorherrschend funktionale Bedeutung des Geb&auml;udes'>Funktion</td>"
29                ."\n\t<td class='head' title='Bauweise ist die Beschreibung der Art der Bauweise'>Bauweise</td>"
30                ."\n\t<td class='head' title='Zustand beschreibt die Beschaffenheit oder die Betriebsbereitschaft von Geb&auml;ude. Diese Attributart wird nur dann optional gef&uuml;hrt, wenn der Zustand des Geb&auml;udes vom nutzungsf&auml;higen Zustand abweicht.'>Zustand</td>"
31                ."\n\t<td class='head nwlink' title='Lagebezeichnung mit Stra&szlig;e und Hausnummer'>Lage</td>"
32                ."\n\t<td class='head nwlink' title='Link zu den kompletten Hausdaten'>Haus</td>"
33        ."\n</tr>";
34}
35       
36// Kopf fÌr die Anzeige der Bauwerke. Nur wenn tatsÀchlich Bauwerke vorkommen.
37function bauw_tab_head() {
38        // Überschrift
39        echo "\n\n<h3><img src='ico/Haus.png' width='16' height='16' alt=''> Bauwerke</h3>"
40        ."\n<p>.. auf oder an dem Flurst&uuml;ck. Ermittelt durch Verschneidung der Geometrie.</p>";
41
42        // Tabellen-Kopf
43        echo "\n<hr>\n<table class='geb'>";
44        echo "<tr><td colspan=3></td><td colspan=3 class='heads gw'><img src='ico/sort.png' width='10' height='10' alt='' title='Sortierung'>Bauwerks-Typ</td></tr>";
45        echo "\n<tr>";
46        echo "\n\t<td class='head' title='Bezeichnung und/oder Bauwerksname'>Name</td>"
47                ."\n\t<td class='heads fla' title='Schnittfl&auml;che zwischen Flurst&uuml;ck und Bauwerk'><img src='ico/sortd.png' width='10' height='10' alt='' title='Sortierung (absteigend)'>Fl&auml;che</td>"
48                ."\n\t<td class='head' title='gesamte Bauwerksfl&auml;che, liegt teilweise auf Nachbar-Flurst&uuml;ck'>&nbsp;</td>"
49                ."\n\t<td class='head' title='Bauwerksfunktion'>Funktion</td>"
50                ."\n\t<td class='head nwlink' title='Daten des zugehörigen Geb&auml;udes'>zum Haus</td>"
51                ."\n\t<td class='head nwlink' title='Detaillierte Daten zu diesem Bauwerk'>Bauwerk</td>"
52        ."\n</tr>";
53}
54
55// S T A R T
56
57ini_set("session.cookie_httponly", 1);
58session_start();
59$showkey="n"; $nodebug="";      // Var. aus Parameter initalisieren
60$cntget = extract($_GET);       // Parameter in Variable umwandeln
61
62// strikte Validierung aller Parameter
63if (isset($gmlid)) {
64        if (!preg_match('#^[0-9A-Za-z]{16}$#', $gmlid)) {die("Eingabefehler gmlid");}
65} else {
66        die("Fehlender Parameter");
67}
68if (isset($gkz)) {
69        if (!preg_match('#^[0-9]{3}$#', $gkz)) {die("Eingabefehler gkz");}
70} else {
71        die("Fehlender Parameter");
72}
73if (!preg_match('#^[j|n]{0,1}$#', $showkey)) {die ("Eingabefehler showkey");}
74if ($showkey === "j") {$showkey=true;} else {$showkey=false;}
75if (!preg_match('#^j{0,1}$#', $nodebug)) {die("Eingabefehler nodebug");}
76
77include "alkis_conf_location.php";
78include "alkisfkt.php";
79
80echo <<<END
81<!doctype html>
82<html lang="de">
83<head>
84        <meta charset="utf-8">
85        <meta name="viewport" content="width=device-width, initial-scale=1.0">
86        <title>ALKIS Geb&auml;udenachweis</title>
87        <link rel="stylesheet" type="text/css" href="alkisauszug.css">
88        <link rel="shortcut icon" type="image/x-icon" href="ico/Haus.ico">
89</head>
90<body>
91END;
92
93$erlaubnis = darf_ich(); if ($erlaubnis === 0) { die('<p class="stop1">Abbruch</p></body>'); }
94$dbg=$debug; // CONF in Arbeits-Variable
95
96// Mit URL-Parameter "&nodebug=j" kann man die Entwicklungsumgebung (in Conf definiert) ausschalten.
97// Wirkt temporÀr und wird nicht in Links weiter gereicht.
98if ($nodebug === "j") {$dbg=0;}
99
100$con = pg_connect($dbconn." options='--application_name=ALKIS-Auskunft_alkisgebaeudenw.php'");
101if (!$con) echo "\n<p class='err'>Fehler beim Verbinden der DB</p>";
102
103// Flurstueck
104$sqlf ="SELECT f.flurnummer, f.zaehler, f.nenner, f.amtlicheflaeche, g.gemarkungsnummer, g.bezeichnung
105FROM ax_flurstueck f LEFT JOIN ax_gemarkung g ON f.land=g.land AND f.gemarkungsnummer=g.gemarkungsnummer ".UnqKatAmt("f","g")
106."WHERE f.gml_id= $1 AND f.endet IS NULL AND g.endet IS NULL;";
107$v=array($gmlid);
108$resf=pg_prepare("", $sqlf);
109$resf=pg_execute("", $v);
110if (!$resf) {
111        echo "\n<p class='err'>Fehler bei Flurst&uuml;cksdaten.</p>";
112        if ($dbg > 2) {echo "\n<p class='err'>SQL=<br>".str_replace("$1","'".$gmlid."'",$sqlf)."'</p>";}
113        if ($dbg > 1) {echo "<p class='dbg'>Fehler:".pg_result_error($resf)."</p>";}
114}
115
116if ($dbg > 0) {
117        $zeianz=pg_num_rows($resf);
118        if ($zeianz > 1){
119                echo "\n<p class='err'>Die Abfrage liefert mehr als ein Flurst&uuml;cks-Objekt!</p>";
120                if ($dbg > 2) {echo "\n<p class='dbg'>SQL=<br>".htmlentities(str_replace("$1","'".$gmlid."'",$sqlf), ENT_QUOTES, "UTF-8")."</p>";}
121        }
122}
123if ($rowf = pg_fetch_assoc($resf)) {
124        $gemkname=htmlentities($rowf["bezeichnung"], ENT_QUOTES, "UTF-8");
125        $gmkgnr=$rowf["gemarkungsnummer"];
126        $flurnummer=$rowf["flurnummer"];
127        $flstnummer=$rowf["zaehler"];
128        $nenner=$rowf["nenner"];
129        if ($nenner > 0) { // BruchNr
130                $flstnummer.="/".$nenner;
131        }
132        $flstflaeche = $rowf["amtlicheflaeche"] ;
133} else {
134        echo "\n<p class='err'>Fehler! Kein Treffer fuer gml_id=".$gmlid."</p>";
135}
136
137echo "<p class='balken geb'>ALKIS Flurst&uuml;ck (Geb&auml;ude und Bauwerke) ".$gmkgnr."-".$flurnummer."-".$flstnummer."&nbsp;</p>"; // Balken
138echo "\n<h2>Flurst&uuml;ck (Geb&auml;ude und Bauwerke)</h2>";
139echo "\n<table class='outer'>" // Kopf
140        ."\n<tr>"
141                ."\n\t<td>"
142                ."\n\t<td class='ll'><img src='ico/Flurstueck.png' width='16' height='16' alt=''> Kennzeichen:</td>"
143                ."\n\t<td>"
144                        ."\n\t\t<table class='kennzfs' title='Flurst&uuml;ckskennzeichen'>" // Kennzeichen in Rahmen
145                                ."\n\t\t<tr>"
146                                        ."\n\t\t\t<td class='head'>Gemarkung</td>"
147                                        ."\n\t\t\t<td class='head'>Flur</td>"
148                                        ."\n\t\t\t<td class='head'>Flurst-Nr.</td>"
149                                ."\n\t\t</tr>\n\t\t<tr>"
150                                        ."\n\t\t\t<td title='Gemarkung'>";
151                                        if ($showkey) {echo "<span class='key'>".$gmkgnr."</span><br>";}
152                                        echo $gemkname."&nbsp;</td>"
153                                        ."\n\t\t\t<td title='Flurnummer'>".$flurnummer."</td>"
154                                        ."\n\t\t\t<td title='Flurst&uuml;cksnummer (Z&auml;hler / Nenner)'><span class='wichtig'>".$flstnummer."</span></td>"
155                                ."\n\t\t</tr>"
156                        ."\n\t\t</table>"
157                ."\n\t</td>"
158                ."\n\t<td>"
159                        ."\n\t\t<p class='nwlink noprint'>" // Links zu anderem Nachweis
160                                ."\n\t\t\t<a href='alkisfsnw.php?gkz=".$gkz."&amp;gmlid=".$gmlid;
161                                if ($showkey) {echo "&amp;showkey=j";}
162                                echo "&amp;eig=n' title='Flurst&uuml;cksnachweis'>Flurst&uuml;ck <img src='ico/Flurstueck_Link.png' width='16' height='16' alt=''></a>"
163                        ."\n\t\t</p>"
164                ."\n\t</td>"
165        ."\n</tr>"
166."\n</table>";
167
168echo "\n<p class='fsd'>Flurst&uuml;cksfl&auml;che: <b>".number_format($flstflaeche,0,",",".") . " m&#178;</b></p>";
169pg_free_result($resf);
170
171// G e b a e u d e
172
173$sqlg ="SELECT g.gml_id, g.name, g.bauweise, g.gebaeudefunktion, h.beschreibung AS bauweise_beschreibung, u.beschreibung AS bezeichner, u.dokumentation AS gfktd, g.zustand, z.beschreibung AS bzustand,
174round(st_area(g.wkb_geometry)::numeric,2) AS gebflae, "; // GEB-Flaeche, auch ausserhalb des FS
175$sqlg.="round(st_area(ST_Intersection(g.wkb_geometry,f.wkb_geometry))::numeric,2) AS schnittflae, "; // wie viel vom GEB liegt im FS?
176$sqlg.="st_within(g.wkb_geometry,f.wkb_geometry) as drin
177 FROM ax_flurstueck f, ax_gebaeude g
178 LEFT JOIN ax_bauweise_gebaeude h ON g.bauweise = h.wert
179 LEFT JOIN ax_gebaeudefunktion u ON g.gebaeudefunktion = u.wert
180 LEFT JOIN ax_zustand_gebaeude z ON g.zustand = z.wert
181WHERE f.gml_id= $1 AND f.endet IS NULL and g.endet IS NULL ";
182
183// "within" -> nur Geb., die komplett im FS liegen. "intersects" -> auch teil-ueberlappende Flst.
184$sqlg.="AND st_intersects(g.wkb_geometry,f.wkb_geometry) = true ";
185// RLP: keine Relationen zu NebengebÀuden. Auf Qualifizierung verzichten, sonst werden NebengebÀude nicht angezeigt
186//$sqlg.="AND (v.beziehungsart='zeigtAuf' OR v.beziehungsart='hat') ";
187$sqlg.="ORDER BY schnittflae DESC;";
188
189$v=array($gmlid);
190$resg=pg_prepare("", $sqlg);
191$resg=pg_execute("", $v);
192if (!$resg) {
193        echo "\n<p class='err'>Fehler bei Geb&auml;ude-Verschneidung.</p>";
194        if ($dbg > 2) {echo "\n<p class='err'>SQL=<br>".str_replace("$1","'".$gmlid."'",$sqlg)."'</p>";}
195        if ($dbg > 1) {echo "<p class='dbg'>Fehler:".pg_result_error($resg)."</p>";}
196}
197$gebnr=0;
198$gebflsum=0;
199while($rowg = pg_fetch_assoc($resg)) {
200        $gebnr++;
201        if ($gebnr === 1) {geb_tab_head();} // Tab.-Kopf
202        $ggml=$rowg["gml_id"];
203        $gebflsum=$gebflsum + $rowg["schnittflae"];
204        $gnam=trim(trim($rowg["name"], "{}"), '"'); // Gebaeude-Name ist ein Array in der DB: '{"A","B"}'
205        // Mehrfachbelegung nur theoretisch. Entklammern reicht. Mal mit und mal ohne "" drum!?
206        /* SELECT name FROM ax_gebaeude WHERE NOT name IS NULL AND array_length(name, 1) > 1; */
207        $gfktk=htmlentities($rowg["gebaeudefunktion"], ENT_QUOTES, "UTF-8");  // Geb.-Funktion Key
208        $gfktv=htmlentities($rowg["bezeichner"], ENT_QUOTES, "UTF-8"); // Geb.Funktion Value
209        $gfktd=htmlentities($rowg["gfktd"], ENT_QUOTES, "UTF-8"); // GebÀude-Funktion-Description
210
211        $gbauw=$rowg["bauweise"];
212        $gbauwb=htmlentities($rowg["bauweise_beschreibung"], ENT_QUOTES, "UTF-8");
213
214        $gzus=$rowg["zustand"];
215        $gzustand=htmlentities($rowg["bzustand"], ENT_QUOTES, "UTF-8");
216
217        // 3 FÀlle unterscheiden:
218        if ($rowg["drin"] === "t") { // GebÀude liegt komplett in FlurstÃŒck
219                $f1=$rowg["schnittflae"]." m&#178;";
220                $f2="&nbsp;";
221                $gstyle="gin"; // siehe .css
222        } else {
223                if ($rowg["schnittflae"] === "0.00") { // GebÀude angrenzend (Grenzbebauung)
224                        $gstyle="gan";
225                        $f1="&nbsp;";
226                        $f2="angrenzend";
227                } else { // Teile des GebÀudes stehen auf dem FlurstÃŒck
228                        $gstyle="gtl";
229                        $f1=$rowg["schnittflae"]." m&#178;";
230                        $f2="(von ".$rowg["gebflae"]." m&#178;)";
231                }
232        }
233
234        echo "\n<tr>"
235                ."\n\t<td>";
236                if ($gnam != "") {echo "<span title='Geb&auml;udename'>".$gnam."</span><br>";}
237                echo "</td>";
238
239                echo "\n\t<td class='fla'>".$f1."</td>"
240                ."\n\t<td class='".$gstyle."'>".$f2."</td>"; // FlÀchenangaben
241
242                echo "\n\t<td title='".$gfktd."'>"; // Funktion
243                        if ($showkey) {echo "<span class='key'>(".$gfktk.")</span>&nbsp;";}
244                        echo $gfktv;
245                echo "</td>";
246
247                echo "\n\t<td>";
248                if ($gbauw != "") {
249                        if ($showkey) {echo "<span class='key'>(".$gbauw.")</span>&nbsp;";}
250                        echo $gbauwb;
251                }
252                echo "</td>";
253
254                echo "\n\t<td>";
255                if ($gzus != "") {
256                        if ($showkey) {echo "<span class='key'>(".$gzus.")</span>&nbsp;";}
257                        echo $gzustand;
258                }
259                echo "</td>";
260
261                // 2 Spalten mit Links zu anderen Nachweisen: 1. Lage, 2. GebÀude
262                echo "\n\t<td class='nwlink noprint'>"; // Link Lage
263
264                // Zu EINEM GebÀude mehrere Lagebezeichnungen mit Haus- oder Pseudo-Nummer möglich, alle in ein TD
265                // HAUPTgebÀude  Geb >zeigtAuf> lage (mehrere)
266                $sqll="SELECT 'm' AS ltyp, l.gml_id AS lgml, s.lage, s.bezeichnung, l.hausnummer, '' AS laufendenummer "
267                ."FROM ax_gebaeude g JOIN ax_lagebezeichnungmithausnummer l ON l.gml_id=ANY(g.zeigtauf) "
268                ."JOIN ax_lagebezeichnungkatalogeintrag s ON l.kreis=s.kreis AND l.gemeinde=s.gemeinde AND l.lage=s.lage "
269                ."WHERE g.gml_id= $1 AND g.endet IS NULL AND l.endet IS NULL AND s.endet IS NULL ";
270
271                // UNION - oder NEBENgebÀude  Geb >hat> Pseudo
272                $sqll.="UNION SELECT 'p' AS ltyp, l.gml_id AS lgml, s.lage, s.bezeichnung, l.pseudonummer AS hausnummer, l.laufendenummer "
273                ."FROM ax_gebaeude g JOIN ax_lagebezeichnungmitpseudonummer l ON l.gml_id=g.hat "
274                ."JOIN ax_lagebezeichnungkatalogeintrag s ON l.kreis=s.kreis AND l.gemeinde=s.gemeinde AND l.lage=s.lage "
275                ."WHERE g.gml_id= $1 AND g.endet IS NULL AND l.endet IS NULL AND s.endet IS NULL "; // ID des Hauses"
276       
277                $sqll.="ORDER BY bezeichnung, hausnummer, laufendenummer;";
278                $v = array($ggml);
279                $resl = pg_prepare("", $sqll);
280                $resl = pg_execute("", $v);
281                if (!$resl) {
282                        echo "\n<p class='err'>Fehler bei Lage mit HsNr.</p>";
283                        if ($dbg > 2) {echo "\n<p class='dbg'>SQL=<br>".str_replace("$1","'".$gmlid."'",$sqll)."'</p>";}
284                        if ($dbg > 1) {echo "<p class='dbg'>Fehler:".pg_result_error($resl)."</p>";}
285                }
286                while($rowl = pg_fetch_assoc($resl)) { // LOOP: Lagezeilen
287                        $ltyp=$rowl["ltyp"]; // Lagezeilen-Typ
288                        $skey=$rowl["lage"]; // Str.-Schluessel
289                        $snam=htmlentities($rowl["bezeichnung"], ENT_QUOTES, "UTF-8"); //-Name
290                        $hsnr=$rowl["hausnummer"];
291                        $hlfd=$rowl["laufendenummer"];
292                        $gmllag=$rowl["lgml"];
293                        if ($ltyp === "p") {
294                                $lagetitl="Nebengeb&auml;ude - Pseudonummer";
295                                $lagetxt="Nebengeb. ".$hlfd; // + HausNr??
296                        } else {
297                                $lagetitl="HauptgebÀude - Hausnummer";
298                                $lagetxt=$snam." ".$hsnr;
299                        }
300                        echo "\n\t\t<a title='".$lagetitl."' href='alkislage.php?gkz=".$gkz."&amp;gmlid=".$gmllag."&amp;ltyp=".$ltyp;
301                                if ($showkey) {echo "&amp;showkey=j";}
302                                echo "'>";
303                                if ($showkey) {echo "<span class='key'>(".$skey.")</span>&nbsp;";}
304                        echo $lagetxt."&nbsp;<img src='ico/Lage_mit_Haus.png' width='16' height='16' alt=''></a><br>";
305                } // Ende Loop Lage m.H.
306                pg_free_result($resl);
307                echo "\n\t</td>";
308
309                echo "\n\t<td class='nwlink noprint'>" // Link Haus
310                        ."\n\t\t<a title='Daten zum Geb&auml;ude-Objekt' href='alkishaus.php?gkz=".$gkz."&amp;gmlid=".$ggml;
311                        if ($showkey) {echo "&amp;showkey=j";}
312                        echo "'>Haus&nbsp;<img src='ico/Haus.png' width='16' height='16' alt=''></a>"
313                ."\n\t</td>"
314        ."\n</tr>";
315}
316// Footer GebÀude
317if ($gebnr === 0) {
318        echo "<p><br>Kein Geb&auml;ude auf diesem Flurst&uuml;ck.<br>&nbsp;</p>";
319        //if ($dbg > 2) {echo "\n<p class='err'>SQL=<br>".$sqlg."<br>$1 = gml_id = '".$gmlid."'</p>";}
320} else {
321        echo "\n<tr>"
322                ."\n\t<td>Summe:</td>"
323                ."\n\t<td class='fla sum' title='von Geb&auml;uden &uuml;berbaute Fl&auml;che des Flurst&uuml;cks'>".number_format($gebflsum,0,",",".")."&nbsp;&nbsp;&nbsp;&nbsp;m&#178;</td>"
324                ."\n\t<td colspan='6'>&nbsp;</td>"
325        ."\n</tr>"
326        ."\n</table>";
327        $unbebaut = number_format(($flstflaeche - $gebflsum),0,",",".") . " m&#178;";
328        echo "\n<p>\n<br>Flurst&uuml;cksfl&auml;che abz&uuml;glich Geb&auml;udefl&auml;che: <b>".$unbebaut."</b></p>\n<br>";
329}
330pg_free_result($resg);
331
332// B a u w e r k e
333
334// Konstanten fÃŒr Sortierung und Gruppierung
335$btyp_verkehr=1; $btyp_gewaesser=2; $btyp_sonst=3; $btyp_indu=4; $btyp_sport=5;
336$btyp_leitg=6; $btyp_trans=7; $btyp_turm=8; $btyp_vorrat=9;
337
338// Tabllen-Alias, 2stellig. 1. Stelle: f_=FlurstÃŒck, b_=Bauwerk, k_=Key = SchlÃŒsseltabelle. // 2. Stelle: wie Konstante
339
340// 1 -V e r k e h r
341$sqlb="SELECT ".$btyp_verkehr." AS bwtyp, b1.gml_id,
342 b1.bauwerksfunktion, k1.beschreibung AS bezeichner, k1.dokumentation AS bfktd, b1.bezeichnung, b1.name, NULL AS gehoertzu,
343 round(st_area(b1.wkb_geometry)::numeric,2) AS gebflae, round(st_area(ST_Intersection(b1.wkb_geometry,f1.wkb_geometry))::numeric,2) AS schnittflae,
344 st_within(b1.wkb_geometry,f1.wkb_geometry) as drin, GeometryType(b1.wkb_geometry) as bgeotyp
345 FROM ax_flurstueck f1
346 JOIN ax_bauwerkimverkehrsbereich b1 ON st_intersects(b1.wkb_geometry,f1.wkb_geometry) = true
347 LEFT JOIN ax_bauwerksfunktion_bauwerkimverkehrsbereich k1 ON b1.bauwerksfunktion = k1.wert
348 WHERE f1.gml_id = $1 AND f1.endet IS NULL AND b1.endet IS NULL ";
349// 2 - G e w À s s e r
350$sqlb.="UNION
351 SELECT ".$btyp_gewaesser." AS bwtyp, b2.gml_id, b2.bauwerksfunktion, ug.beschreibung AS bezeichner, ug.dokumentation AS bfktd,
352 b2.bezeichnung, b2.name, NULL AS gehoertzu,
353 round(st_area(b2.wkb_geometry)::numeric,2) AS gebflae, round(st_area(ST_Intersection(b2.wkb_geometry,f2.wkb_geometry))::numeric,2) AS schnittflae,
354 st_within(b2.wkb_geometry,f2.wkb_geometry) as drin, GeometryType(b2.wkb_geometry) as bgeotyp
355 FROM ax_flurstueck f2
356 JOIN ax_bauwerkimgewaesserbereich b2 ON st_intersects(b2.wkb_geometry,f2.wkb_geometry) = true
357 LEFT JOIN ax_bauwerksfunktion_bauwerkimgewaesserbereich ug ON b2.bauwerksfunktion = ug.wert
358 WHERE f2.gml_id = $1 AND f2.endet IS NULL AND b2.endet IS NULL ";
359// 3 - S o n s t i g e  Bauwerke
360$sqlb.="UNION
361 SELECT ".$btyp_sonst." AS bwtyp, b3.gml_id, b3.bauwerksfunktion, k3.beschreibung AS bezeichner, k3.dokumentation AS bfktd,
362 b3.bezeichnung, b3.name, b3.gehoertzu,
363 round(st_area(b3.wkb_geometry)::numeric,2) AS gebflae, round(st_area(ST_Intersection(b3.wkb_geometry,f3.wkb_geometry))::numeric,2) AS schnittflae,
364 st_within(b3.wkb_geometry,f3.wkb_geometry) as drin, GeometryType(b3.wkb_geometry) as bgeotyp
365 FROM ax_flurstueck f3
366 JOIN ax_sonstigesbauwerkodersonstigeeinrichtung b3 ON st_intersects(b3.wkb_geometry,f3.wkb_geometry) = true
367 LEFT JOIN ax_bauwerksfunktion_sonstigesbauwerkodersonstigeeinrichtun k3 ON b3.bauwerksfunktion = k3.wert
368 WHERE f3.gml_id = $1 AND f3.endet IS NULL AND b3.endet IS NULL ";
369// 4 - Bauwerk oder Anlage fÃŒr  I n d u s t r i e  und Gewerbe
370$sqlb.="UNION
371 SELECT ".$btyp_indu." AS bwtyp, b4.gml_id, b4.bauwerksfunktion, k4.beschreibung AS bezeichner, k4.dokumentation AS bfktd,
372 b4.bezeichnung, b4.name, NULL AS gehoertzu,
373 round(st_area(b4.wkb_geometry)::numeric,2) AS gebflae, round(st_area(ST_Intersection(b4.wkb_geometry,f4.wkb_geometry))::numeric,2) AS schnittflae,
374 st_within(b4.wkb_geometry,f4.wkb_geometry) as drin, GeometryType(b4.wkb_geometry) as bgeotyp
375 FROM ax_flurstueck f4
376 JOIN ax_bauwerkoderanlagefuerindustrieundgewerbe b4 ON st_intersects(b4.wkb_geometry,f4.wkb_geometry) = true
377 LEFT JOIN ax_bauwerksfunktion_bauwerkoderanlagefuerindustrieundgewer k4 ON b4.bauwerksfunktion = k4.wert
378 WHERE f4.gml_id = $1 AND f4.endet IS NULL AND b4.endet IS NULL ";
379// 5 - Bauwerk oder Anlage fÃŒr  S p o r t , Freizeit und Erholung
380$sqlb.="UNION
381 SELECT ".$btyp_sport." AS bwtyp, b5.gml_id, b5.bauwerksfunktion, k5.beschreibung AS bezeichner, k5.dokumentation AS bfktd,
382 NULL AS bezeichnung, b5.name, NULL AS gehoertzu,
383 round(st_area(b5.wkb_geometry)::numeric,2) AS gebflae, round(st_area(ST_Intersection(b5.wkb_geometry,f5.wkb_geometry))::numeric,2) AS schnittflae,
384 st_within(b5.wkb_geometry,f5.wkb_geometry) as drin, GeometryType(b5.wkb_geometry) as bgeotyp
385 FROM ax_flurstueck f5
386 JOIN ax_bauwerkoderanlagefuersportfreizeitunderholung b5 ON st_intersects(b5.wkb_geometry,f5.wkb_geometry) = true
387 LEFT JOIN ax_bauwerksfunktion_bauwerkoderanlagefuersportfreizeitunde k5 ON b5.bauwerksfunktion = k5.wert
388 WHERE f5.gml_id = $1 AND f5.endet IS NULL AND b5.endet IS NULL ";
389// 6 - L e i t u n g
390$sqlb.="UNION
391 SELECT ".$btyp_leitg." AS bwtyp, b6.gml_id, b6.bauwerksfunktion, k6.beschreibung AS bezeichner, k6.dokumentation AS bfktd,
392 NULL AS bezeichnung, b6.name, NULL AS gehoertzu,
393 round(st_area(b6.wkb_geometry)::numeric,2) AS gebflae, round(st_area(ST_Intersection(b6.wkb_geometry,f6.wkb_geometry))::numeric,2) AS schnittflae,
394 st_within(b6.wkb_geometry,f6.wkb_geometry) as drin, GeometryType(b6.wkb_geometry) as bgeotyp
395 FROM ax_flurstueck f6
396 JOIN ax_leitung b6 ON st_intersects(b6.wkb_geometry,f6.wkb_geometry) = true
397 LEFT JOIN ax_bauwerksfunktion_leitung k6 ON b6.bauwerksfunktion = k6.wert
398 WHERE f6.gml_id = $1 AND f6.endet IS NULL AND b6.endet IS NULL ";
399// 7 - T r a n s p o r t a n l a g e
400$sqlb.="UNION
401 SELECT ".$btyp_trans." AS bwtyp, b7.gml_id, b7.bauwerksfunktion, k7.beschreibung AS bezeichner, k7.dokumentation AS bfktd,
402 NULL AS bezeichnung, NULL AS name, NULL AS gehoertzu,
403 round(st_area(b7.wkb_geometry)::numeric,2) AS gebflae, round(st_area(ST_Intersection(b7.wkb_geometry,f7.wkb_geometry))::numeric,2) AS schnittflae,
404 st_within(b7.wkb_geometry,f7.wkb_geometry) as drin, GeometryType(b7.wkb_geometry) as bgeotyp
405 FROM ax_flurstueck f7
406 JOIN ax_transportanlage b7 ON st_intersects(b7.wkb_geometry,f7.wkb_geometry) = true
407 LEFT JOIN ax_bauwerksfunktion_transportanlage k7 ON b7.bauwerksfunktion = k7.wert
408 WHERE f7.gml_id = $1 AND f7.endet IS NULL AND b7.endet IS NULL ";
409// 8 - T u r m  (Sonderfall Array)
410$sqlb.="UNION
411 SELECT ".$btyp_turm." AS bwtyp, b8.gml_id, k8.wert AS bauwerksfunktion, k8.beschreibung AS bezeichner, k8.dokumentation AS bfktd,
412 NULL AS bezeichnung, b8.name, NULL AS gehoertzu,
413 round(st_area(b8.wkb_geometry)::numeric,2) AS gebflae, round(st_area(ST_Intersection(b8.wkb_geometry,f8.wkb_geometry))::numeric,2) AS schnittflae,
414 st_within(b8.wkb_geometry,f8.wkb_geometry) as drin, GeometryType(b8.wkb_geometry) as bgeotyp
415 FROM ax_flurstueck f8
416 JOIN ax_turm b8 ON st_intersects(b8.wkb_geometry,f8.wkb_geometry) = true
417 LEFT JOIN ax_bauwerksfunktion_turm k8 ON k8.wert =ANY(b8.bauwerksfunktion)
418 WHERE f8.gml_id = $1 AND f8.endet IS NULL AND b8.endet IS NULL ";
419// 9 -  V o r r a t s b e h À l t e r ,  S p e i c h e r b a u w e r k
420$sqlb.="UNION
421 SELECT ".$btyp_vorrat." AS bwtyp, b9.gml_id, b9.bauwerksfunktion, k9.beschreibung AS bezeichner, k9.dokumentation AS bfktd,
422 NULL AS bezeichnung, b9.name, NULL AS gehoertzu,
423 round(st_area(b9.wkb_geometry)::numeric,2) AS gebflae, round(st_area(ST_Intersection(b9.wkb_geometry,f9.wkb_geometry))::numeric,2) AS schnittflae,
424 st_within(b9.wkb_geometry,f9.wkb_geometry) as drin, GeometryType(b9.wkb_geometry) as bgeotyp
425 FROM ax_flurstueck f9
426 JOIN ax_vorratsbehaelterspeicherbauwerk b9 ON st_intersects(b9.wkb_geometry,f9.wkb_geometry) = true
427 LEFT JOIN ax_bauwerksfunktion_vorratsbehaelterspeicherbauwerk k9 ON b9.bauwerksfunktion = k9.wert
428 WHERE f9.gml_id = $1 AND f9.endet IS NULL AND b9.endet IS NULL ";
429
430// Generell ...
431$sqlb.="ORDER BY bwtyp, schnittflae DESC;";
432
433$v=array($gmlid);
434$resb=pg_prepare("", $sqlb);
435$resb=pg_execute("", $v);
436if (!$resb) {
437        echo "\n<p class='err'>Fehler bei Bauwerke-Verschneidung.</p>";
438        if ($dbg > 2) {echo "\n<p class='err'>SQL=<br>".str_replace("$1","'".$gmlid."'",$sqlb)."</p>";}
439        if ($dbg > 1) {echo "<p class='dbg'>Fehler:".pg_result_error($resb)."</p>";}
440}
441$baunr=0; // ZÀhler
442$bauflsum=0; // FlÀchensumme
443$gwbwtyp=0; // Gruppen-Wechsel Bauwerks-Typ
444
445while($rowb = pg_fetch_assoc($resb)) {
446        $baunr++;
447        $btyp=$rowb["bwtyp"]; // Tabelle
448        $bgml=$rowb["gml_id"];
449        $bauflsum=$bauflsum + $rowb["schnittflae"];
450        $bbez=htmlentities($rowb["bezeichnung"], ENT_QUOTES, "UTF-8");
451        $bfktk=htmlentities($rowb["bauwerksfunktion"], ENT_QUOTES, "UTF-8");
452        $bfktv=htmlentities($rowb["bezeichner"], ENT_QUOTES, "UTF-8");
453        $bfktd=htmlentities($rowb["bfktd"], ENT_QUOTES, "UTF-8");
454        $bnam=htmlentities($rowb["name"], ENT_QUOTES, "UTF-8");
455        $bgeb=$rowb["gehoertzu"];
456        $drin=$rowb["drin"];
457        $bgeotyp=$rowb["bgeotyp"];
458
459        // Lage des Bauwerks zum FlurstÃŒck
460        if ($bgeotyp === "LINESTRING") {
461                if ($drin === "t") {
462                        $bstyle="gin";
463                } else {
464                        $bstyle="gtl";
465                }
466                $f1="&nbsp;";
467                $f2="Linie";
468        } elseif ($bgeotyp === "POINT") {
469                if ($drin === "t") {
470                        $bstyle="gin";
471                } else {
472                        $bstyle="gtl";
473                }
474                $f1="&nbsp;";
475                $f2="Punkt";           
476        } else { // FlÀche / Multi-
477                if ($drin === "t") { // komplett IM FlurstÃŒck
478                        $f1=$rowb["schnittflae"]." m&#178;";
479                        $f2="&nbsp;";
480                        $bstyle="gin"; // siehe .css
481                } else {
482                        if ($rowb["schnittflae"] === "0.00") { // nur angrenzend
483                                $bstyle="gan";
484                                $f1="&nbsp;";
485                                $f2="angrenzend";
486                        } else { // Teile auf FlurstÃŒck
487                                $bstyle="gtl";
488                                $f1=$rowb["schnittflae"]." m&#178;";
489                                $f2="(von ".$rowb["gebflae"]." m&#178;)";
490                        }
491                }       
492        }
493
494        // Gruppenwechsel Bauwerks-Typ (Quell-Tabelle) - Zwischen-Überschrift
495        If ($btyp != $gwbwtyp) {
496                $gwbwtyp = $btyp;
497                if ($baunr === 1) {bauw_tab_head();} // Tab.-Kopf
498                switch ($btyp) {
499                        case $btyp_verkehr:
500                                $btyptitle='Bauwerk im Verkehrsbereich'; break;
501                        case $btyp_gewaesser:
502                                $btyptitle='Bauwerk im GewÀsserbereich'; break;
503                        case $btyp_sonst:
504                                $btyptitle='Sonstiges Bauwerk oder sonstige Einrichtung'; break;
505                        case $btyp_indu:
506                                $btyptitle="Bauwerk oder Anlage fÃŒr Industrie und Gewerbe"; break;
507                        case $btyp_sport:
508                                $btyptitle="Bauwerk oder Anlage fÃŒr Sport, Freizeit und Erholung"; break;
509                        case $btyp_leitg:
510                                $btyptitle="Leitung"; break;
511                        case $btyp_trans:
512                                $btyptitle="Transportanlage"; break;
513                        case $btyp_turm:
514                                $btyptitle="Turm"; break;
515                        case $btyp_vorrat:
516                                $btyptitle="VorratsbehÀlter, Speicherbauwerk"; break;
517                        default:
518                                $btyptitle='Fehler'; break;
519                }
520                echo "<tr><td colspan=3></td><td colspan=2 class='gw'>".$btyptitle."</td></tr>"; // ++ Symbol?
521        }
522
523        echo "\n<tr>";
524                echo "\n\t<td>";
525                if ($bbez != "") {echo "<span title='Bezeichnung'>".$bbez."</span> ";}
526                if ($bnam != "") {echo "<span title='Name'>".$bnam."</span> ";}
527                echo "</td>";
528                echo "\n\t<td class='fla'>".$f1."</td>"
529                ."\n\t<td class='".$bstyle."'>".$f2."</td>"; // FlÀchenangaben
530                echo "\n\t<td>";
531                if ($showkey) {echo "<span class='key'>(".$bfktk.")</span>&nbsp;";} // Bauwerksfunktion
532                echo "<span title='".$bfktd ."'>".$bfktv."</span>";
533                echo "</td>";
534
535                // Lage / Haus (nur bei Typ 3 sonstige)
536                echo "\n\t<td class='nwlink noprint'>"; // Link
537                if ($bgeb != "") { // gehört zu GebÀude
538                //      bw_gz_lage($bgeb); // Function: Lage (Adresse) ausgeben
539                        echo "\n\t\t<a title='gehört zu' href='alkishaus.php?gkz=".$gkz."&amp;gmlid=".$bgeb;
540                        if ($showkey) {echo "&amp;showkey=j";}
541                        echo "'>Haus&nbsp;<img src='ico/Haus.png' width='16' height='16' alt=''></a>";
542                }
543                echo "\n\t</td>";
544
545                // Bauwerk Details
546                echo "\n\t<td class='nwlink noprint'>"; // Link
547                echo "\n\t\t<a title='Bauwerksdaten' href='alkisbauwerk.php?gkz=".$gkz."&amp;btyp=".$btyp."&amp;gmlid=".$bgml;
548                if ($showkey) {echo "&amp;showkey=j";}
549                echo "'>Bauwerk&nbsp;<img src='ico/Haus.png' width='16' height='16' alt=''></a>";  // +++ Icon fÃŒr Bauwerk schaffen +++
550                echo "\n\t</td>"
551        ."\n</tr>";
552}
553
554// Footer Bauwerk
555if ($baunr === 0) {
556        echo "\n<p>Kein Bauwerk auf diesem Flurst&uuml;ck.</p><br>";
557        // if ($dbg > 2) {echo "\n<p class='err'>SQL=<br>".$sqlb."<br>$1 = gml_id = '".$gmlid."'</p>";}
558} else {
559        echo "\n<tr>"
560                ."\n\t<td>Summe:</td>"
561                ."\n\t<td class='fla sum' title='von Bauwerken &uuml;berbaute Fl&auml;che des Flurst&uuml;cks'>".number_format($bauflsum,0,",",".")."&nbsp;&nbsp;&nbsp;&nbsp;m&#178;</td>"
562                ."\n\t<td colspan='6'>&nbsp;</td>"
563        ."\n</tr>"
564        ."\n</table>\n";
565}
566pg_free_result($resb);
567
568echo "<div class='buttonbereich noprint'>\n<hr>"
569        ."\n\t<a title='zur&uuml;ck' href='javascript:history.back()'><img src='ico/zurueck.png' width='16' height='16' alt='zur&uuml;ck'></a>&nbsp;";
570if ($PrntBtn==true){echo "\n\t<a title='Drucken' href='javascript:window.print()'><img src='ico/print.png' width='16' height='16' alt='Drucken'></a>&nbsp;";}
571echo "\n</div>";
572
573footer($gmlid, selbstverlinkung()."?", "");
574?>
575</body>
576</html>
Note: See TracBrowser for help on using the repository browser.