显示标记谷歌地图 API 的标签

本文关键字:标签 API 谷歌地图 显示 | 更新日期: 2023-09-27 18:34:25

我的WPF应用程序使用Flash API for google map。一切正常,除了我需要在用户单击气球时显示一些自定义详细信息。

操作脚本代码如下:

var map:Map = new Map(); 
map.key = "xxxxxxxxxxxxxxxxxxxxxxxxxxxxxx"; 
map.sensor = "true"; 
var marker : Marker; 
map.setSize(new Point(stage.stageWidth, stage.stageHeight)); 
map.addEventListener(MapEvent.MAP_READY, onMapReady); 
this.addChild(map);  
var CustN:String;
function onMapReady(event:Event):void 
{   
    var centerLL : LatLng = new LatLng(38.05,-77.036562); 
    map.setCenter( centerLL, 10, MapType.NORMAL_MAP_TYPE); 
    map.addControl(new ZoomControl());
    map.addControl(new PositionControl()); 
    map.addControl(new MapTypeControl());   
    marker = new Marker( centerLL );  
    map.addOverlay( marker );   
    ExternalInterface.addCallback("Search",onSearch); 
}
function onSearch(lat:Number, lon:Number, CustName:String ):void 
{
    CustN  = CustName; 
    var centerLL : LatLng = new LatLng(lat,lon); 
    map.setCenter(centerLL, 10, MapType.NORMAL_MAP_TYPE);   
    marker = new Marker( centerLL );  
    marker.addEventListener(MapMouseEvent.CLICK, onMapClick); 
    map.addOverlay( marker ); 
}
function onMapClick(event:MapMouseEvent):void 
{  
    map.openInfoWindow(event.latLng, new InfoWindowOptions({title: "Click Event", content: CustN})); 
}

我从我的 C# 代码调用 onSearch 函数,如下所示:

 foreach (var rec in LstCoOrdinates)
        {
            XElement call = new XElement("invoke", new XAttribute("name", "Search"), new XAttribute("returntype", "xml"), new XElement("arguments", new XElement("number", rec.latitude)),
                new XElement("arguments", new XElement("number", rec.longitude)), new XElement("arguments", new XElement("string", rec.name)));
            axFlash.CallFunction(call.ToString(SaveOptions.DisableFormatting));
        }

我需要显示与单击的气球相对应的名称

显示标记谷歌地图 API 的标签

您可以在

g Marker中指定DisplayObject .icon属性。 并在单击时更改其可见性。预定义标签或单击所需的任何内容进行设置。

marker = new Marker( centerLL );  
marker.icon = new LabelSprite();
marker.icon.visible = false;
marker.addEventListener(MapMouseEvent.CLICK, onMapClick); 
map.addOverlay( marker );
function onMapClick( e:Event ):void
{
  if(selectedMarker) 
     selectedMarker.icon.visible = false;
  selectedMarker = e.currentTarget as Marker;
  selectedMarker.icon.visible = true;
}

public class LabelSprite extends Sprite
{
  private var labelTextField:TextField;
  public function LabelSprite()
  {
    labelTextField = new TextField();
    addChild(labelTextField);
  }
  public function set labelText(value:String):void
  {
    labelTextField.text = value;
  }
}