You are not logged in.

Announcement

*** NOTICE: forum.openstreetmap.org is being retired. Please request a category for your community in the new ones as soon as possible using this process, which will allow you to propose your community moderators.
Please create new topics on the new site at community.openstreetmap.org. We expect the migration of data will take a few weeks, you can follow its progress here.***

#1 2015-09-28 13:03:38

Ghostrider82
Member
Registered: 2010-05-25
Posts: 132

Attribute aus KML Datei als perm. Label?

Hallo zusammen,

ich versuche mich gerade an einer Möglichkeit, Attribute aus einer KML als Label / Tooltip darzustellen.

Der Unterschied soll jedoch sein, dass Label / Tooltip permanent sichtbar sein sollen.

Dazu habe ich mir diverse Samples angeschaut, aber die dortigen Lösungen sehen immer nur ein Mouseover Event vor.

Wie bekomme ich aber nun die Daten aus einer KML als "Permanentes Label" auf die Karte, so dass ich mir das Tooltip / Label auch noch per CSS stylen kann und das Label immer in der Nähe des jeweiligen Features steht?

Kennt da jemand ein Beispiel, welches man sich hierzu anschauen kann?

Danke und Gruß
Boris

Offline

#2 2015-09-28 13:47:05

gormo
Member
Registered: 2013-08-01
Posts: 2,119
Website

Re: Attribute aus KML Datei als perm. Label?

Welche Slippy-Map-Bibliothek nutzt du denn? Leaflet?


OSM hat nicht das Ziel bis Ende des Monats einen vollständigen Datensatz der Welt zu enthalten.
(nach S.W.) - Aber weil die Welt vielfältig ist, weil sie auch im Detail interessant ist, mag ich genaue Karten (nach C.)

Offline

#3 2015-09-28 14:01:36

Ghostrider82
Member
Registered: 2010-05-25
Posts: 132

Re: Attribute aus KML Datei als perm. Label?

Ich verwende Openlayers

Offline

#4 2015-09-28 14:18:29

gormo
Member
Registered: 2013-08-01
Posts: 2,119
Website

Re: Attribute aus KML Datei als perm. Label?

Schade. Für leaflet gäbe es hier http://jsfiddle.net/paulovieira/yVLJf/ ein Beispiel.


OSM hat nicht das Ziel bis Ende des Monats einen vollständigen Datensatz der Welt zu enthalten.
(nach S.W.) - Aber weil die Welt vielfältig ist, weil sie auch im Detail interessant ist, mag ich genaue Karten (nach C.)

Offline

#5 2015-09-28 14:37:33

maxbe
Member
Registered: 2010-01-19
Posts: 3,255
Website

Re: Attribute aus KML Datei als perm. Label?

Ein Beispiel für OpenLayers 2.

Das Problem ist, dass man entweder im KML-Layer den Stil holt (extractStyles:true), oder sich seinen Stil selbst zusammenbastelt. Und Labels gibts nur für Selberbastler.

  kmllayer=new OpenLayers.Layer.Vector("Punkte", {
                 styleMap: new OpenLayers.StyleMap({                           <----- mein selbstgebaselter Stil
                            "default": new OpenLayers.Style({
                                        ......
                                        label: "${name}",                                  <--- Label ist das, was im KML "name" heisst
                                        labelAlign:"lm",
                                        fontSize: "30px",
                                        labelYOffset:0,
                                        labelXOffset:10
                                        }),
                             "select":  new OpenLayers.Style({fillColor:"#ff0000",fillOpacity:1})
                             }),
                 .......
                 protocol:   new OpenLayers.Protocol.HTTP({
                              url: "wegpunkteb.kml",
                              format:new
                              OpenLayers.Format.KML({extractStyles:false,extractAttributes:true})    <--- kein Stil aus der KML-Datei
                             })
                });

Ausserdem muss man mindestens 2 Stile machen, den "default" und den "select". Falls man letzteren weglässt, rutscht das Label zentriert auf den Punkt.

Grüße, Max

Nachtrag:

Tooltip / Label auch noch per CSS stylen

Wird schwer werden. Was man da sieht ist ein Schriftzug, der mit svg gerendert wird.

Last edited by maxbe (2015-09-28 16:25:28)

Offline

Board footer

Powered by FluxBB