显示标记谷歌地图 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));
}
我需要显示与单击的气球相对应的名称
您可以在
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;
}
}