替换TWaver中Tree展开合并图标

2024-02-10 05:58

本文主要是介绍替换TWaver中Tree展开合并图标,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

TWaver最大的优点之一是“灵活的定制功能”。光说不练不行,来个例子演练一下:定制Tree节点的标签。

  • 默认Tree和Network上的标签显示的是网元的name属性,设置Styles.TREE_LABEL属性后,可以让Tree显示Styles.TREE_LABEL的值,以达到Tree和Network显示不同标签的目的
  • 如果觉得这样还不够,可以设置Tree#labelFunction,比如下面的代码可以让Node显示name,Link显示Styles.TREE_LABEL:
tree.labelFunction = function(e:IElement):String{if(e is Link){return e.getStyle(Styles.TREE_LABEL);}else{return e.name;}
}

 

既然TWaver这么灵活,那Tree的展开合并图标能定制么?

先来看看用最原始的方式:

 

1.  先定义2个class:

 

 

[Embed(source="assets/plus.png")]
[Bindable]
public var plus:Class;[Embed(source="assets/minus.png")]
[Bindable]
public var minus:Class;

 
2.  再设置Tree的disclosureOpenIcon和disclosureClosedIcon属性为上面定义的class

 

 

<tw:Tree id="tree2" width="100%" height="100%" disclosureOpenIcon="{minus}" disclosureClosedIcon="{plus}"/>


效果如下:

有同学就要问了,这样还是不够灵活,资源文件直接嵌入了SWF中,如果想换个图标,还得重新编译打包上传。这好说,可以用css定制组件样式(其实css也要编译成swf,这点adobe完全没有考虑到用户的实际需求,换个颜色还得编译swf,以后有时间给大家说说如何不编译swf也能用css定制样式),但是偏偏disclosureOpenIcon和disclosureClosedIcon无法用css定制样式。从mx.controls.Tree的源代码中可以看到

[Style(name="disclosureOpenIcon", type="Class", format="EmbeddedFile", inherit="no")]
[Style(name="disclosureClosedIcon", type="Class", format="EmbeddedFile", inherit="no")]

 
这说明,disclosureOpenIcon和disclosureClosedIcon的style类型为class,css可以加载class?肯定不行,不信邪的同学可以试试:

<mx:Style>Tree {disclosureOpenIcon: "assets/minus.png";disclosureClosedIcon: "assets/plus.png";}
</mx:Style>

 
运行程序会得到下面的错误:

写道
TypeError: Error #1034: Type Coercion failed: cannot convert “assets/plus.png” to Class.
at mx.controls::Tree/initListData()[C:\autobuild\3.5.0\frameworks\projects\framework\src\mx\controls\Tree.as:2663]

 
那我们就定义两个class,但是这两个class是什么class?我们来分析一下:
1.  既然是图片,我们就继承Image组件吧。
2.  既然是class,说明mx内部会不停地new这个class,所以图片资源要缓存起来。
3.  加载图片是异步的,所以要等图片加载完成后,再注册这个class。

因此就有了这2个类的定义:

package {import flash.display.Bitmap;import flash.display.Loader;import mx.controls.Image;public class disclosureOpenIcon extends Image {public static const loader:Loader = new Loader();public function disclosureOpenIcon() {this.source = new Bitmap(Bitmap(loader.content).bitmapData);this.width = loader.content.width;this.height = loader.content.height;}}
}package {import flash.display.Bitmap;import flash.display.Loader;import mx.controls.Image;public class disclosureClosedIcon extends Image {public static const loader:Loader = new Loader();public function disclosureClosedIcon() {this.source = new Bitmap(Bitmap(loader.content).bitmapData);this.width = loader.content.width;this.height = loader.content.height;}}
}

 
下面是定制Tree展开合并图标的代码:

private static function registTreeDisclosureIcon(tree:UIComponent):void {registClassStyle(tree, disclosureOpenIcon, "assets/minus.png");registClassStyle(tree, disclosureClosedIcon, "assets/plus.png");
}private static function registClassStyle(component:UIComponent, clazz:Class, value:String):void {if(clazz["loader"].content == null){clazz["loader"].contentLoaderInfo.addEventListener(Event.COMPLETE, function(e:Event):void {component.setStyle(getQualifiedClassName(clazz), clazz);});clazz["loader"].load(new URLRequest(value), new LoaderContext(true));}
}


如果想全局注册,可以考虑下面的代码:

private static function registTreeDisclosureIcon():void {var css:CSSStyleDeclaration = StyleManager.getStyleDeclaration("Tree");registClassStyle(css, disclosureOpenIcon, "assets/minus.png");registClassStyle(css, disclosureClosedIcon, "assets/plus.png");
}private static function registClassStyle(css:CSSStyleDeclaration, clazz:Class, value:String):void {if(clazz["loader"].content == null){clazz["loader"].contentLoaderInfo.addEventListener(Event.COMPLETE, function(e:Event):void {css.setStyle(getQualifiedClassName(clazz), clazz);});clazz["loader"].load(new URLRequest(value), new LoaderContext(true));}
}

 
最后看看摆脱mx.controls.Tree的FastTree怎么定制展开合并图标,比如下面的代码就让展开合并图标颠倒了:

tree4.expandIcon = "collapsed_icon";
tree4.collapseIcon = "expanded_icon";


本文完整代码见附件:见原文最下方

 

这篇关于替换TWaver中Tree展开合并图标的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/696296

相关文章

使用Python合并 Excel单元格指定行列或单元格范围

《使用Python合并Excel单元格指定行列或单元格范围》合并Excel单元格是Excel数据处理和表格设计中的一项常用操作,本文将介绍如何通过Python合并Excel中的指定行列或单... 目录python Excel库安装Python合并Excel 中的指定行Python合并Excel 中的指定列P

C#实现添加/替换/提取或删除Excel中的图片

《C#实现添加/替换/提取或删除Excel中的图片》在Excel中插入与数据相关的图片,能将关键数据或信息以更直观的方式呈现出来,使文档更加美观,下面我们来看看如何在C#中实现添加/替换/提取或删除E... 在Excandroidel中插入与数据相关的图片,能将关键数据或信息以更直观的方式呈现出来,使文档更

基于C#实现PDF文件合并工具

《基于C#实现PDF文件合并工具》这篇文章主要为大家详细介绍了如何基于C#实现一个简单的PDF文件合并工具,文中的示例代码简洁易懂,有需要的小伙伴可以跟随小编一起学习一下... 界面主要用于发票PDF文件的合并。经常出差要报销的很有用。代码using System;using System.Col

macOS怎么轻松更换App图标? Mac电脑图标更换指南

《macOS怎么轻松更换App图标?Mac电脑图标更换指南》想要给你的Mac电脑按照自己的喜好来更换App图标?其实非常简单,只需要两步就能搞定,下面我来详细讲解一下... 虽然 MACOS 的个性化定制选项已经「缩水」,不如早期版本那么丰富,www.chinasem.cn但我们仍然可以按照自己的喜好来更换

Python视频剪辑合并操作的实现示例

《Python视频剪辑合并操作的实现示例》很多人在创作视频时都需要进行剪辑,本文主要介绍了Python视频剪辑合并操作的实现示例,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习... 目录介绍安装FFmpegWindowsMACOS安装MoviePy剪切视频合并视频转换视频结论介绍

不删数据还能合并磁盘? 让电脑C盘D盘合并并保留数据的技巧

《不删数据还能合并磁盘?让电脑C盘D盘合并并保留数据的技巧》在Windows操作系统中,合并C盘和D盘是一个相对复杂的任务,尤其是当你不希望删除其中的数据时,幸运的是,有几种方法可以实现这一目标且在... 在电脑生产时,制造商常为C盘分配较小的磁盘空间,以确保软件在运行过程中不会出现磁盘空间不足的问题。但在

在C#中合并和解析相对路径方式

《在C#中合并和解析相对路径方式》Path类提供了几个用于操作文件路径的静态方法,其中包括Combine方法和GetFullPath方法,Combine方法将两个路径合并在一起,但不会解析包含相对元素... 目录C#合并和解析相对路径System.IO.Path类幸运的是总结C#合并和解析相对路径对于 C

Java操作xls替换文本或图片的功能实现

《Java操作xls替换文本或图片的功能实现》这篇文章主要给大家介绍了关于Java操作xls替换文本或图片功能实现的相关资料,文中通过示例代码讲解了文件上传、文件处理和Excel文件生成,需要的朋友可... 目录准备xls模板文件:template.xls准备需要替换的图片和数据功能实现包声明与导入类声明与

hdu2241(二分+合并数组)

题意:判断是否存在a+b+c = x,a,b,c分别属于集合A,B,C 如果用暴力会超时,所以这里用到了数组合并,将b,c数组合并成d,d数组存的是b,c数组元素的和,然后对d数组进行二分就可以了 代码如下(附注释): #include<iostream>#include<algorithm>#include<cstring>#include<stack>#include<que

day-51 合并零之间的节点

思路 直接遍历链表即可,遇到val=0跳过,val非零则加在一起,最后返回即可 解题过程 返回链表可以有头结点,方便插入,返回head.next Code /*** Definition for singly-linked list.* public class ListNode {* int val;* ListNode next;* ListNode() {}*