SM-Finder-Logo        
herz Karte Kalender Suche Bookmarks Experte FAQ

Module

Download

SMFinder_Admin_genMap

Wird verwendet von:
SMFinder_Main

Diese Funktion aktualisiert die Übersichtskarte - da dies etwas dauert, wird die Funktion nur gelegentlich von einem Admin aufgerufen und nicht bei jedem Abruf der Karte.

Es werden alle Einträge <adr> abgefragt und wenn
deren status='ok' ist,
die geographische Länge nicht leer und
die Länderkennung mit 'D' beginnt,
erhält der Eintrag einen Punkt in der Karte und die UID wird grün angezeigt.

Von aussortierten Einträgen wird die UID rot angezeigt, wenn keine geographischen Angaben gefunden wurden und blau, wenn es sich nicht um einen Eintrag aus Deutschland handelt.
Sowohl das Datenformat als auch die Skripte sind in der Lage, internationale Einträge zu verarbeiten. Die Pflege nationaler Karten bleibt Anbietern aus den jeweiligen Ländern vorbehalten, der AK-SM-Finder leistet hierzu gerne Support.

Neue Version mit svg-Grafik:
SMFinder_MapDACH

Alte Version mit png-Grafik:
Die Treffer werden noch nach Ortsnamen sortiert und Doppelte aussortiert, um Punktwolken zu vermeiden.

Die Anzeige der Karte erfolgt mit per css positionierten Grafikelementen. Die Karte liegt im Hintergrund und für jeden Ort wird ein Symbol eingeblendet.
Hierzu bedarf es im Kopf der Seite jeweils der Positionierungsangabe und im Body des aufrufbaren Links. Die Bausteine dafür SMFinder_Kartenstyle.php und SMFinder_Kartenteil.php werden generiert und im Arbeitsverzeichnis gespeichert, so dass sie der Kartenanzeige (index.php?what2do=map) zur Verfügung stehen. Die geographischen Angaben müssen entsprechend der Karte skaliert werden. Hierzu habe ich einmalig markante Städte (Flensburg, Freiburg, Aachen, ...) manuell positioniert, und die gewählten Koordinaten gegen die realen geogrphischen Positionen (für Länge und Breite) aufgetragen und mittels linearer Regression die Skalierung für die verwendete Karte gefunden.
Falls die Karte in Relation zum Pagelayout (wahrscheinlich ein Tabellenfeld) verschoben werden soll, kann bei dieser Umskalierung ein Offset angegeben werden.

Die Karte wurde mit xFig erzeugt, indem eine geeignete Vorlage in den Hintergrund gelegt wurde. Dann können die Kontouren - ggf. in verschiedenen Ebenen für verschiedene Informationen, wie Bundesländer oder Flüsse oder einige Städte zur Festlegung der Skalierung (s.o.) - nachgezeichnet werden. So entsteht eine Vektorgrafik, die sich beliebig skalieren und (ohne die Hintergrundgrafik) in verschiedenen Formaten speichern lässt. Da das xFig-Format ASCII-basiert ist, können die Farben mit Suchen&Ersetzen getauscht werden - und man könnte einen Export der SM-Finder-Übersichtskarte schreiben, der auf diesem Weg eine Vektorgrafik erzeugt, die großformatig zu Präsentationszwecken genutzt werden könnte. Die existenten Graphiken findest du unter SMFinder_Help_Download.

<?php 
/* published under GPL www.gnu.org/licenses/gpl.html */
function SMFinder_Admin_genMap(){
  include_once("SMFinder_Config.php");
  $cityColor="yellow";
  $searchRadius=30; #km
  $symbolRadius=7;
  $svg=SMFinder_genMapReadMap($GLOBALS['docDir'],"SMFinder_MapDACH.svg");
  /* delte example cities from documentation */
  $splitPos=strpos($svg,"<g id=\"staedte\"")+16;
  $svg=substr($svg,0,$splitPos)." transform=\"translate(42,0)\">";
  /* add each existing city */
  $fname=$GLOBALS['someDir']."SMFinder_Map.svg";
  $fid = fopen($fname, "w");
  fwrite($fid, $svg);
  list($city,$geoLat,$geoLon) = getGeo4Map();
  $bad =array(" ","ä","ö","ü","ß");
  $good=array("_","ae","oe","ue","ss");
  for ($c=0;$c<count($city);$c++){
    $cy=8862 -161*$geoLat[$c];
    $cx=-621 +107*$geoLon[$c];
    $thisCity ="<a xlink:href='../index.php?what2do=find&lat=".$geoLat[$c]."&lon=".$geoLon[$c]."&Radius=".$searchRadius."&calType=static' target='_parent'>\n";
    $thisCity.="  <circle class='citySymbol'\n";
    $thisCity.="  cx='".$cx."' cy='".$cy."' r='".$symbolRadius."'>\n";
    $cityID=str_replace($bad,$good,$city[$c]);
    $thisCity.="  <title id='".$cityID."'>".$cityID."</title>\n";
    $thisCity.="</circle>\n";
    $thisCity.="</a>\n";
    fwrite($fid, $thisCity);
  } #c
  $svgFoot="</g>\n</g> <!-- EndOfKarte -->\n</svg>\n";
  fwrite($fid, $svgFoot);
  fclose($fid);
  /* for old InternetExplorer which does not support SVG */
  SMFinder_Admin_genMap_old($city,$geoLat,$geoLon);
}

function SMFinder_genMapReadMap($dir,$SVGname){
  /* read original Map.svg */
  $fname=$dir.$SVGname;
  if (file_exists($fname)) {
    $fid = fopen($fname, "r");
    $line = fgets( $fid, 240000 );
    while(!feof($fid)){
      $svg.=trim($line)."\n";
      $line = fgets( $fid, 240000 );
    }
    fclose($fid);
  }else{
    echo "<p><aj>File not found: ".$fname."</aj></p>";
  }
  /*
  $colorOrig=array(":green;",":lime;",":teal;");
  for ($c=0;$c<count($color);$c++){
    $color[$c]=":".$color[$c].";";
    $svg=str_replace($colorOrig[$c],$color[$c],$svg);
  } #c
  */
  return $svg;
}

function SMFinder_Admin_genMap4Variants(){
  $SVGorig = SMFinder_genMapReadMap($GLOBALS['someDir'],"SMFinder_Map.svg");
  for($variant=1;$variant<=count($GLOBALS['extSMFinder']);$variant++){
    $style=$GLOBALS['extSMFinder'][$variant];
    if($style[0]=="."){$style=".".$style;}
    $varNo=sprintf("%03d",$variant);
    $SVGvar = str_replace("index.php?w","index.php?pageID=".$varNo."&w",$SVGorig);
    $SVGvar = str_replace("../SMFinder_Style.css",$style,$SVGvar);
    $fname=$GLOBALS['someDir']."SMFinder_Map".$varNo.".svg";
    $fid = fopen($fname, "w");
    fwrite($fid, $SVGvar);
    fclose($fid);
  } #variant
}

function getGeo4Map(){
  $dblink=mysql_connect($GLOBALS['dbserver'],$GLOBALS['dbuser'],$GLOBALS['dbpasswd']);
  mysql_select_db($GLOBALS['dbname'],$dblink);
  $Orte=array();
  $lats=array();
  $lons=array();
  $PLZn=array();
  $anfrage="select * from ".$GLOBALS['DBTadr'].";";
  if ($ergebnis=mysql_query($anfrage)){
    while ($zeile=mysql_fetch_row($ergebnis)){
      $testStatus="select * from ".$GLOBALS['DBTaddress']." where UID='".$zeile[2]."';";
      $finger=mysql_query($testStatus);
      $status=mysql_fetch_row($finger);
      if ($status[1]=="ok" ){
	if ($zeile[9+1]!=0){
	  $country=$zeile[8+1];
	  if ($country[0]=="D"){
            #Germany
	    array_push($Orte, $zeile[5+1]);
	    array_push($PLZn, $zeile[4+1]);
	    array_push($lats, $zeile[9+1]);
	    array_push($lons, $zeile[10+1]);
	    echo " <span style='background-color:#00ff00;'>".$zeile[2]."</span><br>";
	  }elseif($country[0]=="A"){
            #Austria
	    array_push($Orte, $zeile[5+1]);
	    array_push($PLZn, $zeile[4+1]);
	    array_push($lats, $zeile[9+1]);
	    array_push($lons, $zeile[10+1]);
	    echo " <span style='background-color:teal;'>".$zeile[2]."</span><br>";
	  }else{
            #rest of world
	    echo " <span style='background-color:#0000ff;'>".$zeile[2]."</span>".$country."<br>";
	  }
	}else{
	  echo " <span style='background-color:red;'>".$zeile[2]."</span><br>";
	}
      }
    } //while
    mysql_free_result($ergebnis);
  }else{
    echo "Fehler=".mysql_error()."<br>";
  }
  mysql_close($dblink);

  /* sort by cities and delete multiples */
  array_multisort($Orte, $lats, $lons);
  $city[0]=$Orte[0];
  $geoLat[0]=$lats[0];
  $geoLon[0]=$lons[0];
  $j=0;
  for ($i=1; $i<count($lats); $i++){
    if ($Orte[$i]!=$city[$j]){
      $j++;
      $city[$j]=$Orte[$i];
      $geoLat[$j]=$lats[$i];
      $geoLon[$j]=$lons[$i];
    }
  } #i
  return array($city,$geoLat,$geoLon);
}

function SMFinder_Admin_genMap_old($city,$geoLat,$geoLon){
  #list($city,$geoLat,$geoLon) = getGeo4Map();
  $headerteil="";
  $katenteil="";
  for ($i=0; $i<count($geoLat); $i++){
    if ($geoLat[$i]!=0){
      $y=5768.2-102.8*$geoLat[$i]+15-125; /* 10 weil BVSM-Logo so gross 8-( */
      $x=-190.5+64*$geoLon[$i]+18-200;    /* 18 ist Zugestaendnis an IE */
      $yy=5768.2-102.8*$geoLat[$i]+15;
      settype($x,"integer");
      settype($y,"integer");
      settype($yy,"integer");
      $ort=$city[$i];
      $city[$i]=preg_replace('/\s/m', '_', $city[$i]);
      $headerteil.="#".$city[$i]." {position:absolute; top:".$y."px; left:".$x."px; }\n";
      $headerteil_00.="#".$city[$i]." {position:absolute; top:".$yy."px; left:".$x."px; }\n";
      $kartenteil.="<div class='stadt' id='".$city[$i].#
	"'><a class='ort' href='".$_SERVER['PHP_SELF']."?what2do=find&lat=".#
	$geoLat[$i]."&lon=".$geoLon[$i].#
	"&Radius=30'><img src='./Grafik/stadt.png' title='".$city[$i].#
	"' border='0'></a></div>\n";
    }
  }
  $kartenteil.="<p height='810px'></p>";

  $fname=$GLOBALS['someDir']."SMFinder_Kartenstyle.php";
  $fid = fopen($fname, "w");
  fwrite($fid, $headerteil);
  fclose($fid);
  $fname=$GLOBALS['someDir']."SMFinder_Kartenstyle_00.php";
  $fid = fopen($fname, "w");
  fwrite($fid, $headerteil_00);
  fclose($fid);
  $fname=$GLOBALS['someDir']."SMFinder_Kartenteil.php";
  $fid = fopen($fname, "w");
  fwrite($fid, $kartenteil); 
  fclose($fid);

  echo "neue Karte erzeugt";
}
?>

Index

Für die Funktionalität des SM-Finders sind viele kleine Tools notwendig. Alle Funktionen beginnen mit SMFinder_ um deren Ursprung zu kennzeichnen. Dem schließt sich die Funktionsgruppe, z.B. Geo_ an, gefolgt vom eigentlichen Namen, der die Aufgabe der Funktion widerspiegeln soll, z.B. PLZ2DB.

Der gesamte Sourcecode darf gemäß GNU General Public License weiterverbreitet werden.

1Makefile
2SMFinder_Admin
3SMFinder_Admin_addCategories
4SMFinder_Admin_checkAllLinks
5SMFinder_Admin_clean
6SMFinder_Admin_exportXML
7SMFinder_Admin_genMap
8SMFinder_Admin_getTimefInt
9SMFinder_Admin_importGeo
10SMFinder_Admin_sendXML2user
11SMFinder_Admin_uploadXML
12SMFinder_Config
13SMFinder_DTD
14SMFinder_Datenbanken
15SMFinder_Edit
16SMFinder_Edit_AddressFields
17SMFinder_Edit_AdrFields
18SMFinder_Edit_CatsAtrs
19SMFinder_Edit_EventFields
20SMFinder_Edit_LinkFields
21SMFinder_Edit_Modus
22SMFinder_Edit_POST
23SMFinder_Edit_PersFields
24SMFinder_Edit_genUID
25SMFinder_Elementdefinitions
26SMFinder_Geo
27SMFinder_Geo_PLZ2DB
28SMFinder_Geo_Umkreis
29SMFinder_Geo_getGeo
30SMFinder_Help
31SMFinder_Help_Download
32SMFinder_Help_FAQ
33SMFinder_Help_KategorienInfo
34SMFinder_Help_editAddress
35SMFinder_Help_editEvent
36SMFinder_Main
37SMFinder_MapDACH
38SMFinder_Menu
39SMFinder_Modules
40SMFinder_ModulesIndex
41SMFinder_Pagelayout
42SMFinder_Query_ABC
43SMFinder_Query_Calendar
44SMFinder_Query_CheckCatsAtrs
45SMFinder_Query_Map
46SMFinder_Query_Mask
47SMFinder_Query_SearchEngine
48SMFinder_Query_analyzeSearch
49SMFinder_Query_composeDates4UIDs
50SMFinder_Query_dateFormat
51SMFinder_Query_dmoz
52SMFinder_Query_expandSeries
53SMFinder_Query_find
54SMFinder_Query_getAllUID
55SMFinder_Query_getUID4CatsAtrsGeo
56SMFinder_Query_getUID4Geo
57SMFinder_Query_getUID4adr
58SMFinder_Query_getUID4fn
59SMFinder_Query_readAddress
60SMFinder_Query_readAdr
61SMFinder_Query_readBookmark
62SMFinder_Query_readEvent
63SMFinder_Query_readLink
64SMFinder_Query_readPers
65SMFinder_Query_showAddress
66SMFinder_Query_showAdr
67SMFinder_Query_showCalendar
68SMFinder_Query_showCalendarDynamic
69SMFinder_Query_showEvent
70SMFinder_Query_showEventList
71SMFinder_Query_showEventsChronological
72SMFinder_Query_showLink
73SMFinder_Query_showPers
74SMFinder_Query_showResult
75SMFinder_Query_validDate
76SMFinder_Style
77SMFinder_Write_Address
78SMFinder_Write_Adr
79SMFinder_Write_Event
80SMFinder_Write_Link
81SMFinder_Write_Pers
82SMFinder_Write_deleteEntry
83SMFinder_XML_checkType
84SMFinder_XML_export
85SMFinder_XML_extractAttribute
86SMFinder_XML_extractTag
87SMFinder_XML_findAllElements
88SMFinder_XML_import
89SMFinder_XML_importParseAddress
90SMFinder_XML_importParseAdr
91SMFinder_XML_importParseCatsAtrs
92SMFinder_XML_importParseEvent
93SMFinder_XML_importParseLink
94SMFinder_XML_importParsePerson
95SMFinder_XML_readFile
96SMallGiessen_SMFinder
97ShowCatsAtrsNice
98index
99php2txt.pl
100sm-finder-02.dtd
101testGeo
102sm-finder-02.dtd
103

Datenbanken

 

SM-Finder-Logo

Die hier zur Verfügung gestellten Informationen basieren auf dem Austauschnetzwerk des SM-Finders.
Änderungen an eurem Datensatz könnt ihr z.B. beim Arbeitskreis SM-Finder vornehmen.
Bei Fragen und Problemen schreibt bitte an: sm-finderATki-co.org
Der AK-SM-Finder ist korporatives Mitglied der BVSM e.V.

Für Aktualität und Richtigkeit der dargebotenen Infomationen kann keine Gewähr übernommen werden!

blank

blank