用户名: 密码: 验证码: QQ--程序群:31736530 动画群:38836599
闪无忧
 
首 页 业界新闻 业界杂谈 Flash教程 Flash源码 Flash图书 Flash酷站 Flex & AIR 供求信息
   本栏目通告:   有意向写收费精品教程的朋友,请联系本站合作
当前位置 :首页>flash教程>Flash组件学习>列表

在List组件中使用渲染器

[来源:Liu21sts Blog | 作者:Liu21sts | 时间:2008-03-29 | 点击:  | 收藏本文  【 】]
网上看过很多人转载darronschall的 LabelCellRenderer 例子,其中有个错误,把myList.cellRenderer = "LabelCellRenderer";这行代码放到了注释里面去了,但是到处转载的依然没有修正(其实原文是正确的)。

其实看了这个我们并没有求甚解,要知道授人予鱼,不如授人予渔。我们再来看下为什么通过cellrenderer可以给List、DataGrid、Tree 和 Menu 组件以及其它列表组件增强单元格内容显示。

我们首先要从List组件开始分析,List 类至关重要。DataGrid、Tree 和 Menu 组件是 List 类的扩展。

List 类由行构成。这些行显示滑过和选区突出显示,用作行选区的点击状态,并在滚动中扮演重要的角色。除了选区突出显示和图标(如节点图标和 Tree 组件的展开箭头)之外,行还包含一个单元格(或者,如果是 DataGrid,则包含多个单元格)。在默认情况下,这些单元格是实现 CellRenderer API 的 TextField 对象。但是,您可以让 List 使用不同的组件类作为每一行的单元格。唯一的要求是该类必须实现 List 用于与单元格通信的 CellRenderer API。

List 类使用一种非常复杂的算法进行滚动。一个列表只会列出它一次能显示的最多行数,超出 rowCount 属性的值的项目根本不会获得行。在列表滚动时,它会将所有行上下移动(取决于滚动方向)。然后,列表将重复使用滚出视图的行;列表会重新初始化这些行,并使用它们作为正在滚入视图的新行,方法是将旧行的值设置为视图中的新行,然后将旧行移到新项目滚入视图的位置。

要使用 CellRenderer API,您必须编写包含下面四个方法的类

CellRenderer.getPreferredHeight() 返回单元格的首选高度
CellRenderer.getPreferredWidth() 返回单元格的首选宽度
CellRenderer.setSize() 设置单元格的宽度和高度
CellRenderer.setValue() 设置要显示在单元格中的内容

基于列表的组件将使用该类与单元格通信。这就是我们看到的darronschall定义的LabelCellRenderer类。

系统将为单元格自动指定两个方法和一个属性

CellRenderer.getCellIndex() 返回包含单元格渲染器数据字段的名称的字符串
CellRenderer.getDataLabel() 返回包含两个字段(columnIndex 和 rowIndex)的对象,这两个字段指明单元格的位置
CellRenderer.listOwner 指向包含单元格的列表的引用
以便允许它与基于列表的组件通信。例如,假设单元格内包含一个复选框,该复选框导致行在单击时被选中。单元格渲染器需要引用包含它的基于列表的组件,以便调用基于列表的组件的 selectedIndex 属性。同时,单元格需要知道它当前正在渲染的项目索引,以便能够将 selectedIndex 设置为正确的编号;单元格可以使用 CellRenderer.listOwner 和 CellRenderer.getCellIndex() 达到此目的。您不需要实现这些 API;在将单元格放到基于列表的组件内时,单元格将自动接收这些 API。
我们来看下LabelCellRenderer类实现的这几个方法代码:

function createChildren(Void) : Void { 
    label = createObject("Label", "label", 1, { styleName:this, owner:this });
    label.html = true;
    size();
}
 
// setSize is implemented by UIComponent and calls size(), after setting
// __width and __height
function size(Void) : Void { 
    label.setSize(__width, __height);
    // make sure the label field is in the top-left corner 
    // of the row
    label._x = 0;
    label._y = 0;
}
 
function setValue(str:String, item:Object, sel:Boolean) : Void { 
    // hide the label if no data to display

label._visible = (item!=undefined);
    // this line actually sets htmlText 
    label.text = item.label;
}
 
function getPreferredHeight(Void) : Number { 
    // this is the height with the default font, you might
    // need to adjust this to suit your needs
    return 18; 
}
 
function getPreferredWidth(Void) : Number { 
    // default to the width of the listbox
    return __width;
}

 

其中用来显示html标记的就是setValue方法了。
我们定义了这个类后,剩下就是对List组件来设置新的单元格渲染器了。使用下面的代码:

上一页12 下一页
文章如果有错误或者缺少文件,请发邮件提交给我们
上一篇:Flash MX 2004 video
下一篇:Flash MX 2004视频插件的应用教程
Tags:     使用 组件 单元 List // 包含 the Void 显示 这些 渲染
>>> 最新评论:(共有 0 位网友发表了评论)      查看所有评论
  发表评论
用户名: 新注册) 密码: 匿名评论
评论内容:(不能超过250字,需审核后才会公布,请自觉遵守互联网相关政策法规。
·本站发布内容均为客观表达作者观点,不代表闪无忧立场,请勿攻击和漫骂
·用户发表意见仅代表其个人意见,并且承担一切因发表内容引起的纠纷和责任
·本站管理人员有权在不通知用户的情况下删除不符合规定的评论信息或留做证据
·请客观的评价您所看到的资讯,提倡就事论事,杜绝漫骂和人身攻击等不文明行为
  教程分类
  基础操作   动画特效
  应用开发   组件学习
  As程序   动画教程
  Flash cs3   AS 3.0
  FCS/FMS教程   Loading教程
  Flash与Web   Flash教程连载
  相关文章
·虚线分隔List项目(drawRowBackgr
·利用flashComboBox组件制作友情
·利用ComboBox组件制作友情链接(
·flash DataGrid组件的运用(二)
·flash DataGrid组件的运用(一)
·flash Tree组件构建仿Windows资
·KTooltip 工具提示组件
·习作:组件HTML UI Components
·FLV Playback组件优劣分析
·标题栏可添加组件的PanelAdvance
  热门文章
·Flash进度条的制作详细讲解(组图)
·flash幻灯片网页效果
·Flex 3 AdvancedDataGrid的使用(第二
·全Flash动画网站实现的基础教学
·flash水影效果字
·Flash打造简单的飘雪动画视觉特效
·FLASH+XML相册(附源码)
·超酷flash光晕移动效果
·Flash旋转拖尾文字效果的制作教程
·Flash制作大雪纷飞效果动画
·flash春雷闪电效果
关于我们 - 免责声明 - 网站地图 - 商务服务 - 联系我们 - RSS地图
©CopyRight 2006-2008, 5UFlash.COM, Inc. All Rights Reserved
鲁ICP备06034971号