原来在用到这个时找了很久才找到怎么使用,后来却忘了记录,今天突然又想到这个事,现在记录下来以便以后忘了的时候能找到
在InfoSymbol中添加自定义的组件有两种方式,一种是继承<esri:InfoSymbol />重新写一个组件,在内部添加组件,如下
<?xml version="1.0" encoding="utf-8"?>
<esri:InfoSymbol xmlns:fx="http://ns.adobe.com/mxml/2009"
xmlns:s="library://ns.adobe.com/flex/spark"
xmlns:mx="library://ns.adobe.com/flex/mx"
xmlns:esri="http://www.esri.com/2008/ags">
<esri:infoRenderer>
<fx:Component>
<s:SWFLoader source="assets/images/Red_glow.swf" width="40" height="40"/>
</fx:Component>
</esri:infoRenderer>
</esri:InfoSymbol>
我不太喜欢使用这种方式,另一种就是动态的利用infoRenderer属性来控制InfoSymbol中的组件,但是这个infoRenderer属性的类型是IFactory,这让我很纠结了,一时想不起怎么使用它了,后来在网上收罗了半天,终于找到一个,如下:
var infoSymbol:InfoSymbol = new InfoSymbol(); //新建一个InfoSymbol
var infoSymbolFactory:ClassFactory = new ClassFactory(Label); //以类工厂的方式创建Label类
infoSymbolFactory.properties={text: "Hello", width: 100}; //设置MyLabel的text和width属性,也就是在Label上面显示该信息和宽度
infoSymbol.infoRenderer=infoSymbolFactory; //制定InfoSymbol显示的内容
如果想要放多个控件的,就自定义个组件,放入ClassFactory中创建。这样我们就能灵活地使用InfoSymbol了.