source: trunk/var/www/info/alkis/alkisgebaeudenw.php @ 132

Revision 132, 12.0 KB checked in by frank.jaeger, 12 years ago (diff)

ALKIS-Buchauskunft: Gebäudedaten

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