InfoSymbol中的infoRenderer属性的使用方法(学习笔记)

原来在用到这个时找了很久才找到怎么使用,后来却忘了记录,今天突然又想到这个事,现在记录下来以便以后忘了的时候能找到

在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了.

你可能感兴趣的:(library,encoding,Components)