十月 15, 2010
Posted by admin

flex4里引入了sparkSkin, spark包里的可视控件可以通过指定skinClass的值来修改控件的默认皮肤。

下面是一个如何自定义某个scrollbar的外观的例子。

新建一个flex project, 名字假设为myScrollerbar, 编辑mxml内容:

<?xml version="1.0" encoding="utf-8"?>
<s:Application xmlns:fx="http://ns.adobe.com/mxml/2009"
xmlns:s="library://ns.adobe.com/flex/spark"
xmlns:mx="library://ns.adobe.com/flex/mx" width="300" height="400" >
<fx:Declarations>
<!-- Place non-visual elements (e.g., services, value objects) here -->
 
</fx:Declarations>
<s:Scroller percentWidth="100" percentHeight="100" id="scroller">
<s:Group>
<s:Rect percentWidth="100" height="800">
<s:fill>
<s:LinearGradient rotation='250'>
<s:GradientEntry color='0x000000' ratio='0'/>
<s:GradientEntry color='0xffffff' ratio='1'/>
</s:LinearGradient>
</s:fill>
</s:Rect>
</s:Group>
</s:Scroller>
</s:Application>

编译运行程序,截图如下:

假设我们现在想改变右边verticalScrollbar的样子, 并且已经准备好了所需要的图片:
up.png: 向上箭头的图片
down.png: 向下箭头的图片
thumb.png: 拖动条的图片

Scroller.verticalScrollbar 实际上是由4部分构成,
thumb: 拖动条 (对应的类为spark.components.Button)
track: 拖动条下面的那个轨道 (对应的类为spark.components.Button)
decrementButton: 向上箭头按钮(对应的类为spark.components.Button)
incrementButton: 向下箭头按钮(对应的类为spark.components.Button)

对整个verticalScrollbar我们需要一个mxml来定义其皮肤, 里面每个部分也分别需要一个mxml来定义皮肤,那么我们一共需要5个mxml文件

下面是这5个mxml皮肤文件的定义:

1. MyVScrollBarSkin.mxml

<?xml version="1.0" encoding="utf-8"?>
<s:SparkSkin xmlns:fx="http://ns.adobe.com/mxml/2009"
xmlns:s="library://ns.adobe.com/flex/spark"
xmlns:mx="library://ns.adobe.com/flex/mx"
alpha.disabled="0.5"
alpha.inactive="0.5"
 
>
<s:states>
<s:State name="normal" />
<s:State name="disabled" />
<s:State name="inactive" />
</s:states>
 
<fx:Metadata>
<![CDATA[
[HostComponent("spark.components.VScrollBar")]
]]>
</fx:Metadata>
 
 
<s:Button id="track" top="30" bottom="30" focusEnabled="false" horizontalCenter="0"
skinClass="skins.MyVScrollBarTrackSkin"
/>
<s:Button id="thumb" focusEnabled="false" horizontalCenter="0"
skinClass="skins.MyVScrollBarThumbSkin"
/>
<s:Button id="decrementButton" top="0" focusEnabled="false" horizontalCenter="0"
skinClass="skins.MyVScrollBarDecrementButtonSkin"
/>
<s:Button id="incrementButton" bottom="0" focusEnabled="false" horizontalCenter="0"
skinClass="skins.MyVScrollBarIncrementButtonSkin"
/>
</s:SparkSkin>

2.MyVScrollBarThumbSkin.mxml

<?xml version="1.0" encoding="utf-8"?>
<s:Skin 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:pwg="com.perfectworld.gamelibs.pwgraphics.*"
 
>
<fx:Metadata>
[HostComponent("spark.components.Button")]
</fx:Metadata>
<s:states>
<s:State name="up" />
<s:State name="over" />
<s:State name="down" />
<s:State name="disabled" />
</s:states>
 
<mx:Image source="@Embed('thumb.png')" />
 
</s:Skin>

3.MyVScrollBarTrackSkin.mxml

<?xml version="1.0" encoding="utf-8"?>
<s:Skin 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:pwg="com.perfectworld.gamelibs.pwgraphics.*"
 
>
<fx:Metadata>
[HostComponent("spark.components.Button")]
</fx:Metadata>
<s:states>
<s:State name="up" />
<s:State name="over" />
<s:State name="down" />
<s:State name="disabled" />
</s:states>
 
<s:Rect top="0" bottom="0" width="29">
<s:fill>
<s:SolidColor color="0x131313" alpha="0.3" />
</s:fill>
</s:Rect>
 
</s:Skin>

4.MyVScrollBarDecrementButtonSkin.mxml

<?xml version="1.0" encoding="utf-8"?>
<s:Skin 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:pwg="com.perfectworld.gamelibs.pwgraphics.*"
>
<fx:Metadata>
[HostComponent("spark.components.Button")]
</fx:Metadata>
<s:states>
<s:State name="up" />
<s:State name="over" />
<s:State name="down" />
<s:State name="disabled" />
</s:states>
<mx:Image source="@Embed('up.png')"/>
</s:Skin>

5. MyVScrollBarIncrementButtonSkin.mxml

<?xml version="1.0" encoding="utf-8"?>
<s:Skin 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:pwg="com.perfectworld.gamelibs.pwgraphics.*"
>
<fx:Metadata>
[HostComponent("spark.components.Button")]
</fx:Metadata>
<s:states>
<s:State name="up" />
<s:State name="over" />
<s:State name="down" />
<s:State name="disabled" />
</s:states>
 
<mx:Image source="@Embed('down.png')"/>
</s:Skin>

皮肤文件定义好了,那么现在修改mySCrollbar.mxml为 scroller.verticalScrollbar指定skinClass:

<?xml version="1.0" encoding="utf-8"?>
<s:Application xmlns:fx="http://ns.adobe.com/mxml/2009"
xmlns:s="library://ns.adobe.com/flex/spark"
xmlns:mx="library://ns.adobe.com/flex/mx" width="300" height="400" creationComplete="init()">
<fx:Declarations>
<!-- Place non-visual elements (e.g., services, value objects) here -->
 
</fx:Declarations>
<fx:Script>
<![CDATA[
import skins.MyVScrollBarSkin;
private function init():void {
scroller.verticalScrollBar.setStyle("skinClass", MyVScrollBarSkin);
scroller.verticalScrollBar.setStyle( "fixedThumbSize", true);
}
]]>
</fx:Script>
 
<s:Scroller percentWidth="100" percentHeight="100" id="scroller">
<s:Group>
<s:Rect percentWidth="100" height="800">
<s:fill>
<s:LinearGradient rotation='250'>
<s:GradientEntry color='0x000000' ratio='0'/>
<s:GradientEntry color='0xffffff' ratio='1'/>
</s:LinearGradient>
</s:fill>
</s:Rect>
</s:Group>
</s:Scroller>
</s:Application>

主要是加了这2行代码:

scroller.verticalScrollBar.setStyle("skinClass", MyVScrollBarSkin);
scroller.verticalScrollBar.setStyle( "fixedThumbSize", true);

最后的样子如下:

Flex scroller皮肤的使用的更多相关文章

  1. Flex移动皮肤开发(三)

    范例文件 mobile-skinning-part3 在关于创建Flex移动皮肤系列文章的第二部分里,我们讨论了屏幕密度(DPI)对组件皮肤以及移动应用布局所带来的影响. 我还展示了如何使用缩放应用, ...

  2. Flex修改皮肤样式

    Flex修改皮肤大致有三种方式: (以button为例) 第一种:修改外观 1.flex项目中新建mxml外观.

  3. Flex移动皮肤开发(一)

    范例文件 mobile-skinning-part1.zip Flex 4.5提供的移动增强的皮肤特性,支持触摸交互.性能优良,并且考虑到了内存占用问题.尽管目前市场上有不少性能优异的设备,但典型的S ...

  4. Flex移动皮肤开发(二)

    范例文件 mobile-skinning-part2.zip 在这个讨论创建 Flex 移动 skin 的系列的 第 1 部分 中,我讨论了 Flex 团队在 Mobile 主题中所做的性能优化的原理 ...

  5. 使用Flex构建Web和移动参考应用程序

    范例文件 Shopping Cart Sales Dashboard Expense Tracker 需要的其他产品 Android 2.2及更高版本或Android 3.0及更高版本的设备 仅仅在F ...

  6. 为应用程序的选项卡及ActionBar设置样式

    示例文件  flex-mobile-dev-tips-tricks-pt2.zip 关于Flex移动开发的提示和技巧有一系列文章,这是其中的第二部分.第一部分集中讲解如何在视图切换及应用程序操作切换之 ...

  7. Flex自定义组件、皮肤,并调用

    标签:Flex  自定义组件  自定义皮肤  主应用调用模块 本程序样例学习自flex 实战教程.但因原教程代码不全,且根据个人需求有更改. 1文件列表 自定义as类Reveal.as,该类实现组件的 ...

  8. Flex学习笔记-皮肤

    1文件结构 MXML应用程序 index.mxml 皮肤文件 components.button.skin.btnSkin1.mxml  皮肤文件的组件随便引用了spark.components.Bu ...

  9. 一套扁平化界面风格的flex 皮肤

    意外在git上发现这个项目.似乎刚開始不久.部分控件的新皮肤似乎还没完毕.只是个人感觉挺不错的.大家认为呢? =>git地址:https://github.com/akamud/FlatSpar ...

随机推荐

  1. Python3 tkinter基础 event keysym 查看按键的按键名

             Python : 3.7.0          OS : Ubuntu 18.04.1 LTS         IDE : PyCharm 2018.2.4       Conda ...

  2. 《编写高质量代码:Web 前端开发修炼之道》 笔记与读后感

    编写高质量代码:Web 前端开发修炼之道/曹刘阳著. —北京:机械工业出版社,2010.5 第一版 涉及到的知识点: 1. CSS Sprites 在国内很多人叫css精灵,是一种网页图片应用处理方式 ...

  3. bzoj 1735: [Usaco2005 jan]Muddy Fields 泥泞的牧场 最小点覆盖

    链接 1735: [Usaco2005 jan]Muddy Fields 泥泞的牧场 思路 这就是个上一篇的稍微麻烦版(是变脸版,其实没麻烦) 用边长为1的模板覆盖地图上的没有长草的土地,不能覆盖草地 ...

  4. Python SSH爆破以及Python3线程池控制线程数

    源自一个朋友的要求,他的要求是只爆破一个ip,结果出来后就停止,如果是爆破多个,完全没必要停止,等他跑完就好 #!usr/bin/env python #!coding=utf-8 __author_ ...

  5. Many Website Of WallPaper

    我在这里给大家推荐几个不错的壁纸网站 毕竟一张赏心悦目的壁纸能让你的工作效率提高不少 注意前方高能 一大波网站即将来袭 一系列 如你所见 alphacoders wallpaperdj Wallhav ...

  6. python 安装wheel .whl文件

    首先得有pip没有的话安装一个. 然后:pip install wheel 然后:pip install 路径\文件名.whl ===================== pip --versionp ...

  7. c# Database类的使用

    参考资料http://ansonlh.iteye.com/blog/1689009 搜索:c# DatabaseFactory类

  8. Android Studio 快捷键、Debug的使用

    https://blog.csdn.net/q908555281/article/details/49331371 1.快捷键      个人习惯常用快捷键      在Eclipse中常用的快捷键 ...

  9. 【C#】取整函数Math.Round、Math.Ceiling和Math.Floor区别

    Math.Round 原则: 四舍六入五取偶. 也就是说 0.1-0.4为0 0.5为0 0.6-0.9为1 1.5为2 Math.Ceiling 原则: 有小数就加1 0.1 = 1 Math.Fl ...

  10. ADO.NET DBHelper

    using System; using System.Collections.Generic; using System.Linq; using System.Web; using System.Da ...