显示标记Google Map API的标签

时间:2021-09-14 15:25:16

My WPF application uses the Flash API for google map. Everything works fine except that I need to show some custom details when the user clicks the balloons.

我的WPF应用程序使用Flash API进行谷歌地图。一切正常,但我需要在用户点击气球时显示一些自定义细节。

The actionscript code is below:

动作脚本代码如下:

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})); 
}

I call the onSearch function from my C# code as below:

我从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));
        }

I need to display the name corresponding to the balloon clicked

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

1 个解决方案

#1


0  

you can specify DisplayObject .icon property in your g Marker. and change it's visibility on click. Predefine label or set it on click whatever you need.

您可以在g标记中指定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;
  }
}

#1


0  

you can specify DisplayObject .icon property in your g Marker. and change it's visibility on click. Predefine label or set it on click whatever you need.

您可以在g标记中指定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;
  }
}