首页 > 网站 > WEB开发 > 正文

7.6.使用项渲染器把SWF对象作为一个菜单项显示

2024-04-27 13:52:00
字体:
来源:转载
供稿:网友
7.6.1.问题
用一个图片或SWF 做菜单。
7.6.2.解决办法
用itemRenderer 对象加载SWF 文件,并自定义菜单。
7.6.3.讨论
自定义菜单的第一步是把你想要用到的字体和图形存在一些SWF 文件里,并且把这些SWF 文件放在一文件夹下。在我们的例子中,这个文件夹命名为“swf”,你可以用任工具生成这些SWF 文件。

接下来,创建一个renderer 组件。在本例中我们使用Canvas,并在Canvas 里增加一个SWFLoader 组件。如果我们想用Canvas 做自定义菜单,还有一个条件,就是要让Canvas实现IMenuItemRenderer 接口,因为接口的需要,我们在Canvas 里实现了menu 的set get方法,但什么也没有做。SWFLoader 的source 属性我们赋值为data.swf_wp( 因为这个Canvas 最终会用做renderer,所以用data.xxxx,原文是data.swf,太容易让人迷惑了,我改成了data.swf_wp,在原文和原文的例子中都只提到实现接口中的set menu 和getmenu 方法其实还有三个方法需要实现,下面是我改过的代码,如果对原文兴趣,请见本节结尾部分)。
文件名为: FontItemRenderer.mxml
+展开
-XML
<?xml version="1.0" encoding="utf-8"?>
<mx:Canvas xmlns:mx="http://www.adobe.com/2006/mxml"
width="100height="25"
verticalScrollPolicy="offhorizontalScrollPolicy="off"
xmlns:external="flash.external.*"
implements="mx.controls.menuClasses.IMenuItemRenderer">

<mx:Script>
<![CDATA[
import mx.controls.Menu;
public function get menu():Menu { return null ; }
public function set menu(value:Menu):void { }
public function get measuredIconWidth():Number{return 0;}
public function get measuredTypeIconWidth():Number{return 0;}
public function get measuredBranchIconWidth():Number{return 0;}

]]>
</mx:Script>
<mx:SWFLoader source="{data.swf_wp}width="100height="25"
horizontalCenter="0verticalCenter="0"/>

<mx:Label x="0y="0text="{data.label}width="100"
height="25"/>

</mx:Canvas>
发表评论 共有条评论
用户名: 密码:
验证码: 匿名发表