`
#天琪#
  • 浏览: 160350 次
  • 性别: Icon_minigender_2
  • 来自: 长沙
社区版块
存档分类
最新评论

运行时加裁FLEXSKIN

    博客分类:
  • FLEX
阅读更多
本文来源于 冰山上的播客 http://xinsync.xju.edu.cn , 原文地址:http://xinsync.xju.edu.cn/index.php/archives/1953


现在有许多关于如何为Flex程序加上皮肤的很好的资料。简单来说:Flex支持两种加载皮肤的方法:graphical和programmatic。graphical方法是在Flash,Photoshop,Fireworks等工具中创建图形资源,并把他们嵌入到你的Flex程序中。programmatic方法是创建一个为控件定义skin的ActionScript类。正如你猜测的那样,graphical方法比较简单,programmatic方法则比较强大。
这两种方法共同的一个缺点就是:为了能应用skin这些资源(graphical方法中的SWF/PNG/GIF/其他, programmatic方法中的AS类)都必须在编译时就是可用的。必须如此吗?在这篇文章中我将介绍一个巧妙的方法让graphical skins在运行时加载(通过一个带有源代码的示例)。
为了让这个例子尽量简单,我将创建一个允许Button控件动态加载皮肤的Flex程序。这个程序将在运行时连接到一个SWF,加载皮肤并且把它应用到Button控件。为了使它简单我将使用NJ文章中提供的皮肤模板文件,把RadioButton皮肤应用到Button控件。
第一步:为skin资源创建一个wrapper SWF
Skin资源在上述的skin模板文件中。我希望创建一个Flex程序可以在运行时加载并且可以从中提取适当资源的wrapper SWF,在这个例子中它就是RadioButton控件的四个symbol。下面是源码:
package
{
import flash.display.Sprite;
public class Wrapper extends Sprite
{
[Embed(source=”flex_skins.swf”,symbol=”RadioButton_upIcon”)]
public var rbUpSkin: Class;
[Embed(source=”flex_skins.swf”,symbol=”RadioButton_downIcon”)]
public var rbDownSkin: Class;
[Embed(source=”flex_skins.swf”,symbol=”RadioButton_disabledIcon”)]
public var rbDisabledSkin: Class;
[Embed(source=”flex_skins.swf”,symbol=”RadioButton_overIcon”)]
public var rbOverSkin: Class;
}
}
第二步:把这个wrapper SWF放到你的服务器上
Flex程序需要从一个地方加载这个wrapper SWF!
第三步:在你的Flex程序中,使用Loader来加载这个wrapper SWF
我创建了一个叫做ClassLoader的有用的类来包装与加载SWF有关的功能并提取了这个类。下面是关键代码:
loader = new Loader();
loader.contentLoaderInfo.addEventListener(Event.COMPLETE, completeHandler);
loader.contentLoaderInfo.addEventListener(IOErrorEvent.IO_ERROR, ioErrorHandler);
loader.contentLoaderInfo.addEventListener(SecurityErrorEvent.SECURITY_ERROR, securityErrorHandler);

request = new URLRequest(swfLib);
var context:LoaderContext = new LoaderContext();
context.applicationDomain = new ApplicationDomain(ApplicationDomain.currentDomain);
loader.load(request, context);
注意这个Loader把SWF加载到了一个ApplicationDomain中,当前的domain是它的parent。这是保证程序可以访问加载的类以及其中的资源的关键。
第四步:从加载的SWF中获得类并将它实例化。
这里我们使用一个一致的类名(这个例子中,是“Wrapper”)来加载类:
var wrapperClass:Class = loader.contentLoaderInfo.applicationDomain.getDefinition(className) as Class;
var wrapper:Object = new wrapperClass();
第五步:使用setStyle应用skins
你可以把skins应用到一个Button实例或者Button的所有实例。下面是方法:
StyleManager.getStyleDeclaration(”Button”).setStyle(”upSkin”, wrapper.rbUpSkin);
StyleManager.getStyleDeclaration(”Button”).setStyle(”downSkin”, wrapper.rbDownSkin);
StyleManager.getStyleDeclaration(”Button”).setStyle(”disabledSkin”, wrapper.rbDisabledSkin);
StyleManager.getStyleDeclaration(”Button”).setStyle(”overSkin”, wrapper.rbOverSkin);
第六步:运行程序
我的例程(点击这里察看,可以“View Source”)展示了一个文本域,你可以向其中你输入wrapper SWF的URL(点击这里)。输入wrapper SWF的URL,点击Apply按钮,你会看到按钮现在看起来像一个特大型的单选按钮。当你将鼠标放在上面或者点击它的时候,你会发现它的外观会改变并显示适当的skin。如果你创建了自己的wrapper SWF并且其中包含了具有相同类名(rbUpSkin,等)的不同symbols,你可以把这个例程指向并加载它,从而显示不同的skins集合。
为什么你想要这样做呢?动态加载skin提供了一个难以置信的强大的功能:你可以让你的用户把他们的skin加载到你的程序中。想象一下一个用Flex创建的像Winamp一样的MP3播放器吧。开发者不需要为这个程序创建一个skin库,他只需要公布一个设置skin SWF(比如在参数对话框中)的UI并且让用户从一些团体创建的skin中任意选择。同样重要的是,开发者可以很精确地控制哪些控件可以加载skin那些需要保持原样(只在需要的控件上调用setStyle)。最后,把skins放在程序SWF外部将使得程序文件的大小不会因为skin文件的扩散而急速增加。
分享到:
评论

相关推荐

    flexskin天蓝色皮肤.rar

    FlexSkin是一款广泛应用于软件开发中的皮肤库,尤其在创建具有美观界面的桌面应用程序时非常受欢迎。天蓝色皮肤是FlexSkin库中的一个特定主题,它为用户提供了一种清新、舒缓的视觉体验,常用于给软件界面增添现代感...

    delphi实现类似QQ窗体伸缩效果

    - 要实现类似QQ的皮肤效果,首先需要引入皮肤库,比如 popular 的 TMS Skin VCL 或 TMS FlexSkin。这些库提供了丰富的皮肤资源和方便的皮肤应用接口。 - 使用 SkinManager 组件管理皮肤,通过 SkinName 属性设置所...

    基于65nm工艺与1.2V电源电压的12bit Pipelined SAR ADC转换器设计与实现指导,12bit 100MHz pipelined SAR ADC模数转器 设计 65nm工艺,电源电

    基于65nm工艺与1.2V电源电压的12bit Pipelined SAR ADC转换器设计与实现指导,12bit 100MHz pipelined SAR ADC模数转器 设计 65nm工艺,电源电压1.2V,ENOB=11.6 有详细教程原理文档 有工艺库,直接导入自己的cadence [绿圆]结构: 栅压自举开关 CDAC 两级动态比较器 第一级6位SAR ADC 余量放大器 第二级8位SAR ADC 同步和异步SAR logic都有 原理仿真讲解,文档里都有 适合入门pipelined ADC的拿来练手 ,12bit; 100MHz; pipelined SAR ADC; 模数转换器设计; 65nm工艺; 电源电压1.2V; ENOB=11.6; 栅压自举开关; CDAC; 两级动态比较器; 第一级6位SAR ADC; 余量放大器; 第二级8位SAR ADC; 同步和异步SAR logic; 原理仿真讲解; 工艺库导入; 详细教程原理文档。 关键词:12bit; pipelined SAR ADC; 模数转换器设计; 65nm工艺; 电源电压; ENOB; 栅压自举开关;

    VPN 和 VPS 之间的区别

    VPN 和 VPS 之间的区别

    2025年计算机网络技术考试题库(含答案).doc

    2025年计算机网络技术考试题库(含答案).doc

    Java毕业设计-springboot-vue-母婴商城(源码+sql脚本+29页零基础部署图文详解+30页论文+环境工具+教程+视频+模板).zip

    资源说明: 1:csdn平台资源详情页的文档预览若发现'异常',属平台多文档切片混合解析和叠加展示风格,请放心使用。 2:29页图文详解文档(从零开始项目全套环境工具安装搭建调试运行部署,保姆级图文详解),旨在为更多的人甚至零基础的人也能运行、使用和学习。 3:配套毕业论文,万字长文,word文档,支持二次编辑。 4:范例参考答辩ppt,pptx格式,支持二次编辑。 5:工具环境、ppt参考模板、相关电子教程、视频教学资源分享。 6:资源项目源码均已通过严格测试验证,保证能够正常运行,本项目仅用作交流学习参考,请切勿用于商业用途。 7:项目问题、技术讨论,可以给博主私信或留言,博主看到后会第一时间与您进行沟通。 内容概要: 本系统基于 B/S 网络结构,在 IDEA 中开发。服务端用 Java 并借 Spring Boot 框架搭建后台。前台采用支持 HTML5 的 VUE 框架。用 MySQL 存储数据,可靠性强。 能学到什么: 使用Spring Boot搭建后台。VUE 框架构建前端交互界面、前后端数据交互、MySQL管理数据、从零开始环境搭建、调试、运行、打包、部署流程。

    cefsharp 64位支持mp4,131.4.1版本已在nuget版本131.3.5上测试可用

    NuGet版本131.3.5发布版本下可用,下载直接复制到packages\chromiumembeddedframework.runtime.win-x64.131.3.5\runtimes\win-x64\native;这样每次生成的时候就自动拷贝到软件目录中了;在我的凤希AI伴侣最新版本中已使用,如果你需要一个好的AI工具,可下载此程序。如需技术支持,可联系:fxqmg168

    Java毕业设计-springboot-vue-旅游管理系统(源码+sql脚本+29页零基础部署图文详解+33页论文+环境工具+教程+视频+模板).zip

    资源说明: 1:csdn平台资源详情页的文档预览若发现'异常',属平台多文档切片混合解析和叠加展示风格,请放心使用。 2:29页图文详解文档(从零开始项目全套环境工具安装搭建调试运行部署,保姆级图文详解),旨在为更多的人甚至零基础的人也能运行、使用和学习。 3:配套毕业论文,万字长文,word文档,支持二次编辑。 4:范例参考答辩ppt,pptx格式,支持二次编辑。 5:工具环境、ppt参考模板、相关电子教程、视频教学资源分享。 6:资源项目源码均已通过严格测试验证,保证能够正常运行,本项目仅用作交流学习参考,请切勿用于商业用途。 7:项目问题、技术讨论,可以给博主私信或留言,博主看到后会第一时间与您进行沟通。 内容概要: 本系统基于 B/S 网络结构,在 IDEA 中开发。服务端用 Java 并借 Spring Boot 框架搭建后台。前台采用支持 HTML5 的 VUE 框架。用 MySQL 存储数据,可靠性强。 能学到什么: 使用Spring Boot搭建后台。VUE 框架构建前端交互界面、前后端数据交互、MySQL管理数据、从零开始环境搭建、调试、运行、打包、部署流程。

    《已调试》springboot大学生竞赛项目过程管理系统(源码+sql).zip

    1、资源项目源码均已通过严格测试验证,保证能够正常运行; 2、项目问题、技术讨论,可以给博主私信或留言,博主看到后会第一时间与您进行沟通; 3、本项目比较适合计算机领域相关的毕业设计课题、课程作业等使用,尤其对于人工智能、计算机科学与技术等相关专业,更为适合; 4、下载使用后,可先查看README.md或论文文件(如有),本项目仅用作交流学习参考,请切勿用于商业用途。 5、资源来自互联网采集,如有侵权,私聊博主删除。 6、可私信博主看论文后选择购买源代码。

    纯电动汽车整车Matlab Simulink仿真模型:包含电机、电池等五大模块及整车动力学仿真参数可直接运行分析,纯电动汽车整车Matlab simulink仿真模型(电机模型、电池模型、变速器模型、

    纯电动汽车整车Matlab Simulink仿真模型:包含电机、电池等五大模块及整车动力学仿真参数可直接运行分析,纯电动汽车整车Matlab simulink仿真模型(电机模型、电池模型、变速器模型、驾驶员模型、整车动力学模型) ——整车总成参数都有,可直接运行仿真 ,核心关键词: 纯电动汽车; Matlab simulink仿真模型; 电机模型; 电池模型; 变速器模型; 驾驶员模型; 整车动力学模型; 整车总成参数; 可直接运行仿真。,"纯电动整车Matlab Simulink仿真模型:多模块协同仿真系统"

    Java毕业设计-springboot-vue-论坛网站(源码+sql脚本+29页零基础部署图文详解+25页论文+环境工具+教程+视频+模板).zip

    资源说明: 1:csdn平台资源详情页的文档预览若发现'异常',属平台多文档切片混合解析和叠加展示风格,请放心使用。 2:29页图文详解文档(从零开始项目全套环境工具安装搭建调试运行部署,保姆级图文详解),旨在为更多的人甚至零基础的人也能运行、使用和学习。 3:配套毕业论文,万字长文,word文档,支持二次编辑。 4:范例参考答辩ppt,pptx格式,支持二次编辑。 5:工具环境、ppt参考模板、相关电子教程、视频教学资源分享。 6:资源项目源码均已通过严格测试验证,保证能够正常运行,本项目仅用作交流学习参考,请切勿用于商业用途。 7:项目问题、技术讨论,可以给博主私信或留言,博主看到后会第一时间与您进行沟通。 内容概要: 本系统基于 B/S 网络结构,在 IDEA 中开发。服务端用 Java 并借 Spring Boot 框架搭建后台。前台采用支持 HTML5 的 VUE 框架。用 MySQL 存储数据,可靠性强。 能学到什么: 使用Spring Boot搭建后台。VUE 框架构建前端交互界面、前后端数据交互、MySQL管理数据、从零开始环境搭建、调试、运行、打包、部署流程。

    BMS电池管理控制策略:基于AUTOSAR架构的量产车型应用层软件开发与模型构建说明,BMS电池管理控制策略 策略说明,量产车型使用 电池管理系统策略开发,FEV应用层软件,在车型最新版本软件

    BMS电池管理控制策略:基于AUTOSAR架构的量产车型应用层软件开发与模型构建说明,BMS电池管理控制策略 策略说明,量产车型使用。 电池管理系统策略开发,FEV应用层软件,在车型最新版本软件。 按照ASPIC 开发流程开发,基于AUTOSAR架构开发,满足功能安全ASIL C。 模型和策略 BMS电池管理系统应用层软件,策略说明 都是量产车型在用,不是仿真不是仿真不是仿真 BMS,simulink应用层模型。 ,BMS电池管理控制策略; 策略说明; FEV应用层软件; 在售车型软件; ASPIC开发流程; AUTOSAR架构; 功能安全ASIL C; 模型; 量产车型在用; simulink应用层模型。,基于AUTOSAR架构的BMS电池管理控制策略:量产车型应用说明

    全桥LLC谐振变换器变频与移相混合控制仿真研究:拓宽电压范围,实现MOS管ZVS开通与二极管ZCS关断,基于Matlab Simulink Plecs环境,全桥LLC谐振变器变频-移相混合控制仿真

    全桥LLC谐振变换器变频与移相混合控制仿真研究:拓宽电压范围,实现MOS管ZVS开通与二极管ZCS关断,基于Matlab Simulink Plecs环境,全桥LLC谐振变器变频-移相混合控制仿真。 拓宽电压范围。 保证mos管的ZVS零电压开通和二极管的ZCS零电流关断。 运行环境为matlab simulink plecs等 ,全桥LLC谐振变换器; 变频移相混合控制仿真; 拓宽电压范围; mos管ZVS零电压开通; 二极管ZCS零电流关断; 运行环境(matlab simulink plecs),"全桥LLC谐振变换器:变频移相混合控制仿真研究,拓宽电压范围并实现ZVS/ZCS优化"

    《已调试》springboot+redis水果超市商城系统(源码+sql+论文报告).zip

    1、资源项目源码均已通过严格测试验证,保证能够正常运行; 2、项目问题、技术讨论,可以给博主私信或留言,博主看到后会第一时间与您进行沟通; 3、本项目比较适合计算机领域相关的毕业设计课题、课程作业等使用,尤其对于人工智能、计算机科学与技术等相关专业,更为适合; 4、下载使用后,可先查看README.md或论文文件(如有),本项目仅用作交流学习参考,请切勿用于商业用途。 5、资源来自互联网采集,如有侵权,私聊博主删除。 6、可私信博主看论文后选择购买源代码。

    数字图像处理期末复习山东大学软件学院数字图像处理期末复习

    数字图像处理期末复习山东大学软件学院数字图像处理期末复习

    Java毕业设计-springboot-vue-信息化在线教学平台(源码+sql脚本+29页零基础部署图文详解+26页论文+环境工具+教程+视频+模板).zip

    资源说明: 1:csdn平台资源详情页的文档预览若发现'异常',属平台多文档切片混合解析和叠加展示风格,请放心使用。 2:29页图文详解文档(从零开始项目全套环境工具安装搭建调试运行部署,保姆级图文详解),旨在为更多的人甚至零基础的人也能运行、使用和学习。 3:配套毕业论文,万字长文,word文档,支持二次编辑。 4:范例参考答辩ppt,pptx格式,支持二次编辑。 5:工具环境、ppt参考模板、相关电子教程、视频教学资源分享。 6:资源项目源码均已通过严格测试验证,保证能够正常运行,本项目仅用作交流学习参考,请切勿用于商业用途。 7:项目问题、技术讨论,可以给博主私信或留言,博主看到后会第一时间与您进行沟通。 内容概要: 本系统基于 B/S 网络结构,在 IDEA 中开发。服务端用 Java 并借 Spring Boot 框架搭建后台。前台采用支持 HTML5 的 VUE 框架。用 MySQL 存储数据,可靠性强。 能学到什么: 使用Spring Boot搭建后台。VUE 框架构建前端交互界面、前后端数据交互、MySQL管理数据、从零开始环境搭建、调试、运行、打包、部署流程。

    Java毕业设计-springboot-vue-校园管理系统(源码+sql脚本+29页零基础部署图文详解+38页论文+13页答辩+环境工具+教程+视频+模板).zip

    资源说明: 1:csdn平台资源详情页的文档预览若发现'异常',属平台多文档切片混合解析和叠加展示风格,请放心使用。 2:29页图文详解文档(从零开始项目全套环境工具安装搭建调试运行部署,保姆级图文详解),旨在为更多的人甚至零基础的人也能运行、使用和学习。 3:配套毕业论文,万字长文,word文档,支持二次编辑。 4:配套答辩ppt,pptx格式,支持二次编辑。 5:工具环境、ppt参考模板、相关电子教程、视频教学资源分享。 6:资源项目源码均已通过严格测试验证,保证能够正常运行,本项目仅用作交流学习参考,请切勿用于商业用途。 7:项目问题、技术讨论,可以给博主私信或留言,博主看到后会第一时间与您进行沟通。 内容概要: 本系统基于 B/S 网络结构,在 IDEA 中开发。服务端用 Java 并借 Spring Boot 框架搭建后台。前台采用支持 HTML5 的 VUE 框架。用 MySQL 存储数据,可靠性强。 能学到什么: 使用Spring Boot搭建后台。VUE 框架构建前端交互界面、前后端数据交互、MySQL管理数据、从零开始环境搭建、调试、运行、打包、部署流程。

    双闭环直流调速系统图示:包含三相桥式电路参数与反馈控制特性分析,双闭环直流调速系统如图所示,包含数学和物理模型 整流装置采用三相桥式电路,基本数据如下: 直流电动机:额定电枢电压=220V,额定电枢电

    双闭环直流调速系统图示:包含三相桥式电路参数与反馈控制特性分析,双闭环直流调速系统如图所示,包含数学和物理模型 整流装置采用三相桥式电路,基本数据如下: 直流电动机:额定电枢电压=220V,额定电枢电流=55A,额定转速=1000r min,电动机电动势系数Ce=0.1925Vmin r,允许过载倍数λ=1.5; 晶闸管装置放大系数:Ks=44;整流装置平均滞后时间常数=0.00167s, 电枢回路总电阻:R=1.0Ω; 时间常数:电枢回路电磁时间常数=0.017s,电力拖动系统机电时间常数Tm=0.075s; 电枢电流反馈系数:β=0.121V A(≈10V 1.5),电流滤波时间常数=0.002s; 转速反馈系数α=0.01 V.min r(≈10V );转速滤波时间常数=0.01s ,核心关键词:双闭环直流调速系统; 数学和物理模型; 三相桥式电路; 直流电动机; 额定电枢电压电流转速; 电动机电动势系数; 晶闸管装置放大系数; 整流装置滞后时间常数; 电枢回路总电阻; 时间常数; 电枢电流反馈系数; 转速反馈系数。,基于双闭环直流调速系统的数学物理模型研究

    html5+svg绘制的云雾水墨背景动画特效源码.zip

    html5+svg绘制的云雾水墨背景动画特效源码。画面呈现出带有水墨风格的背景动画变换效果,且响应鼠标移动变换动画效果。是一款比较经典的滤镜动画特效

    基于深度学习的乳腺癌分类 源代码与数据集

    **背景** 浸润性导管癌(IDC)是所有乳腺癌中最常见的亚型。为了对整个组织样本进行侵袭性分级,病理学家通常专注于包含 IDC 的区域。因此,自动侵袭性分级的常见预处理步骤之一是划定整个组织切片中 IDC 的确切区域。 **内容** 原始数据集包含 162 张乳腺癌(BCa)标本的整个组织切片图像,扫描倍率为 40 倍。从中提取了 277,524 个大小为 50 x 50 的 patches(198,738 个 IDC 阴性,78,786 个 IDC 阳性)。每个 patch 的文件名格式为:u_xX_yY_classC.png —— 例如 10253_idx5_x1351_y1101_class0.png。其中,u 是患者 ID(10253_idx5),X 是该 patch 裁剪位置的 x 坐标,Y 是该 patch 裁剪位置的 y 坐标,C 表示类别,0 为非 IDC,1 为 IDC。

Global site tag (gtag.js) - Google Analytics