PSD-Tutorials.de
Forum für Design, Fotografie & Bildbearbeitung
Tutkit
Agentur
Hilfe
Kontakt
Start
Forum
Aktuelles
Besonderer Inhalt
Foren durchsuchen
Tutorials
News
Anmelden
Kostenlos registrieren
Aktuelles
Suche
Suche
Nur Titel durchsuchen
Von:
Menü
Anmelden
Kostenlos registrieren
App installieren
Installieren
JavaScript ist deaktiviert. Für eine bessere Darstellung aktiviere bitte JavaScript in deinem Browser, bevor du fortfährst.
Du verwendest einen veralteten Browser. Es ist möglich, dass diese oder andere Websites nicht korrekt angezeigt werden.
Du solltest ein Upgrade durchführen oder einen
alternativen Browser
verwenden.
Antworten auf deine Fragen:
Neues Thema erstellen
Start
Forum
Sonstiges
Webdesign, Webentwicklung & Programmierung
PHP, Javascript, jQuery, Ajax, nodeJS, MySQL...
Plz-Umkreissuche geodb Distanzberechnung
Beitrag
<blockquote data-quote="Philipp88" data-source="post: 2087395" data-attributes="member: 579516"><p>Hallo,</p><p>ich habe eine Plz-Umkreissuche, die soweit auch erstmal funktioniert. Jetzt möchte ich allerdings noch die Distanz vom Suchort angeben. Leider funktioniert die Berechnung bei mir noch nicht exakt.</p><p></p><p>Beispieldaten:</p><p>Ich suche im Umkreis von 100 km mit der Postleitzahl 87700 (Memmingen). Als Ergebnis wird mir 87600 (Kaufbeuren) angezeigt. Als Distanz wird mir aber eine nicht realistische Zahl (6671,7 km) ausgegeben.</p><p></p><p>Die Koordinaten von Kaufbeuren sind:</p><p>longitude: 10.6167</p><p>latitude: 47.8833</p><p>koordx: 4199.5248139112</p><p>koordy: 787.18668108547</p><p>koordz: 4725.8829298307 </p><p></p><p>Mein PHP-Script:</p><p>[PHP]</p><p>function distance($erdradius, $plz) {</p><p> #echo $plz;</p><p> </p><p> $res = $GLOBALS["TYPO3_DB"]->exec_SELECTquery("plz, longitude, latitude, koordx, koordy, koordz", "tx_implantatelabor_adr", "plz = $plz");</p><p> $num = $GLOBALS["TYPO3_DB"]->sql_num_rows($res);</p><p></p><p> for ($i = 0; $i < 1; $i++) {</p><p></p><p> $row = $GLOBALS["TYPO3_DB"]->sql_fetch_assoc($res);</p><p> $lon = $row["longitude"];</p><p> $lat = $row["latitude"];</p><p> $koordx = $row["koordx"];</p><p> $koordy = $row["koordy"];</p><p> $koordz = $row["koordz"];</p><p></p><p> list($lon, $lat) = $this->plzcoord($plz);</p><p> </p><p> list($x, $y, $z) = $this->kugel2kartesisch($erdradius, $lon, $lat);</p><p></p><p>#echo "<p>x: $x<br>y: $y<br>z: $z</p>";</p><p> $distance = 2 * $erdradius * asin(sqrt(</p><p> pow($x - $koordx, 2)</p><p> + pow($y - $koordy, 2)</p><p> + pow($z - $koordz, 2)</p><p> ) / (2 * $erdradius));</p><p>#echo "$distance<br>";</p><p>#$distance = 4.8556392367201;</p><p> $dist = round($distance, 2);</p><p> </p><p> /*if($dist <= 0.5) {</p><p> $dist = 0.5;</p><p> }*/</p><p> </p><p> $dist = str_replace(".", ",", $dist);</p><p> }</p><p> </p><p> return "ca. $dist km";</p><p> }</p><p></p><p>function plzcoord($plz) {</p><p> $sql = "SELECT coo.lon, coo.lat FROM geodb_coordinates AS coo INNER JOIN geodb_textdata AS textdata ON textdata.loc_id = coo.loc_id WHERE textdata.text_val = $plz</p><p> AND textdata.text_type = '500300000' LIMIT 1";</p><p></p><p> $res = $GLOBALS["TYPO3_DB"]->sql_query($sql);</p><p></p><p> $num = $GLOBALS["TYPO3_DB"]->sql_num_rows($res);</p><p></p><p> if($num != 1) {</p><p> return false;</p><p> }</p><p></p><p> $row = $GLOBALS["TYPO3_DB"]->sql_fetch_assoc($res);</p><p></p><p> $lonlat = array($row["lon"], $row["lat"]);</p><p></p><p> return $lonlat;</p><p> }</p><p></p><p>function kugel2kartesisch($erdradius, $lon, $lat) {</p><p> $lambda = $lon * pi() / 180;</p><p> $phi = $lat * pi() / 180;</p><p> $ursprungx = $erdradius * cos($phi) * cos($lambda);</p><p> $ursprungy = $erdradius * cos($phi) * sin($lambda);</p><p> $ursprungz = $erdradius * sin($phi);</p><p></p><p> $coord = array($ursprungx, $ursprungy, $ursprungz);</p><p></p><p> return $coord;</p><p> }</p><p>[/PHP]</p><p></p><p>Es wäre schön, wenn Ihr mir dabei helfen könntet.</p><p>Danke im Voraus.</p><p>Philipp</p></blockquote><p></p>
[QUOTE="Philipp88, post: 2087395, member: 579516"] Hallo, ich habe eine Plz-Umkreissuche, die soweit auch erstmal funktioniert. Jetzt möchte ich allerdings noch die Distanz vom Suchort angeben. Leider funktioniert die Berechnung bei mir noch nicht exakt. Beispieldaten: Ich suche im Umkreis von 100 km mit der Postleitzahl 87700 (Memmingen). Als Ergebnis wird mir 87600 (Kaufbeuren) angezeigt. Als Distanz wird mir aber eine nicht realistische Zahl (6671,7 km) ausgegeben. Die Koordinaten von Kaufbeuren sind: longitude: 10.6167 latitude: 47.8833 koordx: 4199.5248139112 koordy: 787.18668108547 koordz: 4725.8829298307 Mein PHP-Script: [PHP] function distance($erdradius, $plz) { #echo $plz; $res = $GLOBALS["TYPO3_DB"]->exec_SELECTquery("plz, longitude, latitude, koordx, koordy, koordz", "tx_implantatelabor_adr", "plz = $plz"); $num = $GLOBALS["TYPO3_DB"]->sql_num_rows($res); for ($i = 0; $i < 1; $i++) { $row = $GLOBALS["TYPO3_DB"]->sql_fetch_assoc($res); $lon = $row["longitude"]; $lat = $row["latitude"]; $koordx = $row["koordx"]; $koordy = $row["koordy"]; $koordz = $row["koordz"]; list($lon, $lat) = $this->plzcoord($plz); list($x, $y, $z) = $this->kugel2kartesisch($erdradius, $lon, $lat); #echo "<p>x: $x<br>y: $y<br>z: $z</p>"; $distance = 2 * $erdradius * asin(sqrt( pow($x - $koordx, 2) + pow($y - $koordy, 2) + pow($z - $koordz, 2) ) / (2 * $erdradius)); #echo "$distance<br>"; #$distance = 4.8556392367201; $dist = round($distance, 2); /*if($dist <= 0.5) { $dist = 0.5; }*/ $dist = str_replace(".", ",", $dist); } return "ca. $dist km"; } function plzcoord($plz) { $sql = "SELECT coo.lon, coo.lat FROM geodb_coordinates AS coo INNER JOIN geodb_textdata AS textdata ON textdata.loc_id = coo.loc_id WHERE textdata.text_val = $plz AND textdata.text_type = '500300000' LIMIT 1"; $res = $GLOBALS["TYPO3_DB"]->sql_query($sql); $num = $GLOBALS["TYPO3_DB"]->sql_num_rows($res); if($num != 1) { return false; } $row = $GLOBALS["TYPO3_DB"]->sql_fetch_assoc($res); $lonlat = array($row["lon"], $row["lat"]); return $lonlat; } function kugel2kartesisch($erdradius, $lon, $lat) { $lambda = $lon * pi() / 180; $phi = $lat * pi() / 180; $ursprungx = $erdradius * cos($phi) * cos($lambda); $ursprungy = $erdradius * cos($phi) * sin($lambda); $ursprungz = $erdradius * sin($phi); $coord = array($ursprungx, $ursprungy, $ursprungz); return $coord; } [/PHP] Es wäre schön, wenn Ihr mir dabei helfen könntet. Danke im Voraus. Philipp [/QUOTE]
Bilder bitte
hier hochladen
und danach über das Bild-Icon (Direktlink vorher kopieren) platzieren.
Zitate einfügen…
Authentifizierung
Wenn ▲ = 7, ▼ = 3, ◇ = 2 und die Summe von ▲ und ▼ durch ◇ geteilt wird, was ist das Ergebnis?
Antworten
Start
Forum
Sonstiges
Webdesign, Webentwicklung & Programmierung
PHP, Javascript, jQuery, Ajax, nodeJS, MySQL...
Plz-Umkreissuche geodb Distanzberechnung
Oben