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

Revision 427, 28.5 KB checked in by frank.jaeger, 2 years ago (diff)

Überarbeitung der Auskunft: Durch Functions den Code verdichtet. Drei neue Arten von Bauwerken.

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