- Adobe Flex 教程
- Flex - 首页
- Flex - 概述
- Flex - 环境
- Flex - 应用程序
- Flex - 创建应用程序
- Flex - 部署应用程序
- Flex - 生命周期阶段
- Flex - 使用 CSS 设置样式
- Flex - 使用皮肤设置样式
- Flex - 数据绑定
- Flex - 基本控件
- Flex - 表单控件
- Flex - 复杂控件
- Flex - 布局面板
- Flex - 视觉效果
- Flex - 事件处理
- Flex - 自定义控件
- Flex - RPC 服务
- Flex - FlexUnit 集成
- Flex - 调试应用程序
- Flex - 国际化
- Flex - 打印支持
- Adobe Flex 资源
- Flex - 快速指南
- Flex - 有用资源
- Flex - 讨论
Flex - 可换肤容器
简介
SkinnableContainer 类是所有具有视觉内容的可换肤容器的基类。
类声明
以下是 spark.components.SkinnableContainer 类的声明:
public class SkinnableContainer
extends SkinnableContainerBase
implements IDeferredContentOwner, IVisualElementContainer
公共属性
| 序号 | 属性和描述 |
|---|---|
| 1 | autoLayout:布尔值 如果为 true,则在更改子元素的位置或大小时执行测量和布局。 |
| 2 | creationPolicy:字符串 此组件的内容创建策略。 |
| 3 | deferredContentCreated:布尔值 [只读] 如果已创建延迟内容,则包含 true。 |
| 4 | layout:LayoutBase 此容器的布局对象。 |
| 5 | mxmlContent:数组 [只写] 此组的视觉内容子元素。 |
| 6 | mxmlContentFactory:IDeferredInstance [只写] 创建内容属性初始值的工厂对象。 |
| 7 | numElements:整数 [只读] 此容器中视觉元素的数量。 |
公共方法
| 序号 | 方法和描述 |
|---|---|
| 1 | SkinnableContainer() 构造函数。 |
| 2 | addElement(element:IVisualElement):IVisualElement 将视觉元素添加到此容器。 |
| 3 | addElementAt(element:IVisualElement, index:int):IVisualElement 将视觉元素添加到此容器。 |
| 4 | createDeferredContent():void 创建此组件的内容。 |
| 5 | getElementAt(index:int):IVisualElement 返回指定索引处的视觉元素。 |
| 6 | getElementIndex(element:IVisualElement):int 返回视觉元素的索引位置。 |
| 7 | removeAllElements():void 从容器中移除所有视觉元素。 |
| 8 | removeElement(element:IVisualElement):IVisualElement 从此容器的子列表中移除指定的视觉元素。 |
| 9 | removeElementAt(index:int):IVisualElement 从容器中指定索引位置移除视觉元素。 |
| 10 | setElementIndex(element:IVisualElement, index:int):void 更改视觉容器中现有视觉元素的位置。 |
| 11 | swapElements(element1:IVisualElement, element2:IVisualElement):void 交换两个指定视觉元素的索引。 |
| 12 | swapElementsAt(index1:int, index2:int):void 交换容器中两个指定索引位置的视觉元素。 |
受保护的方法
| 序号 | 方法和描述 |
|---|---|
| 1 | createChildren():void [覆盖] 创建内容子元素,如果 creationPolicy 属性不等于 none。 |
| 2 | partAdded(partName:String, instance:Object):void [覆盖] 添加皮肤部件时调用。 |
| 3 | partRemoved(partName:String, instance:Object):void [覆盖] 移除皮肤部件实例时调用。 |
事件
| 序号 | 事件和描述 |
|---|---|
| 1 | contentCreationComplete 创建此组件的内容后调度。 |
| 2 | elementAdd 将视觉元素添加到内容持有者时调度。 |
| 3 | elementRemove 从内容持有者中移除视觉元素时调度。 |
继承的方法
此类继承以下类的的方法:
- spark.components.supportClasses.SkinnableContainerBase
- mx.core.UIComponent
- mx.core.FlexSprite
- flash.display.Sprite
- flash.display.DisplayObjectContainer
- flash.display.InteractiveObject
- flash.display.DisplayObject
- flash.events.EventDispatcher
- Object
Flex 可换肤容器示例
让我们按照以下步骤,通过创建一个测试应用程序来检查 Flex 应用程序中 SkinnableContainer 的用法:
| 步骤 | 描述 |
|---|---|
| 1 | 在包 com.tutorialspoint.client 下创建一个名为 HelloWorld 的项目,如 Flex - 创建应用程序 章节中所述。 |
| 2 | 为宿主组件 SkinnableContainer 创建一个皮肤 SkinnableContainerSkin,该组件位于包 com.tutorialspoint.skin 下,如 Flex - 使用皮肤设置样式 章节中所述。保持其余文件不变。 |
| 3 | 修改 HelloWorld.mxml,如下所述。保持其余文件不变。 |
| 4 | 编译并运行应用程序,以确保业务逻辑按要求工作。 |
以下是修改后的 mxml 文件 src/com.tutorialspoint/skin/SkinnableContainerSkin.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:fb = "http://ns.adobe.com/flashbuilder/2009" alpha.disabled = "0.5">
<fx:Metadata>
<![CDATA[
/**
* @copy spark.skins.spark.ApplicationSkin#hostComponent
*/
[HostComponent("spark.components.SkinnableContainer")]
]]>
</fx:Metadata>
<s:states>
<s:State name = "normal" />
<s:State name = "disabled" />
</s:states>
<s:Rect left = "0" right = "0" top = "0"
bottom = "0" radiusX = "5" radiusY = "5">
<s:stroke>
<s:LinearGradientStroke weight = "2" />
</s:stroke>
<s:fill>
<s:LinearGradient rotation = "90">
<s:entries>
<s:GradientEntry color = "0xdddddd" />
<s:GradientEntry color = "0x020202" alpha = ".5" />
</s:entries>
</s:LinearGradient>
</s:fill>
</s:Rect>
<s:Group id = "contentGroup" left = "0" right = "0"
top = "0" bottom = "0" minWidth = "0" minHeight = "0">
<s:layout>
<s:BasicLayout/>
</s:layout>
</s:Group>
</s:Skin>
以下是修改后的 mxml 文件 src/com.tutorialspoint/HelloWorld.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 = "100%" height = "100%" minWidth = "500" minHeight = "500">
<fx:Style source = "/com/tutorialspoint/client/Style.css" />
<s:BorderContainer width = "630" height = "480" id = "mainContainer"
styleName = "container">
<s:VGroup width = "100%" height = "100%" gap = "50"
horizontalAlign = "center" verticalAlign = "middle">
<s:Label id = "lblHeader" text = "Layout Panels Demonstration"
fontSize = "40" color = "0x777777" styleName = "heading" />
<s:Panel id = "skinnableContainerPanel" title = "Using SkinnableContainer"
width = "500" height = "300" >
<s:layout>
<s:VerticalLayout gap = "10" verticalAlign = "middle"
horizontalAlign = "center" />
</s:layout>
<s:SkinnableContainer
skinClass = "com.tutorialspoint.skin.SkinnableContainerSkin"
width = "50%" height = "50%" horizontalCenter = "0"
verticalCenter = "0">
<s:HGroup horizontalCenter = "0" verticalCenter = "0">
<s:BorderContainer width = "50" height = "50"
borderWeight = "2" color = "0x323232" />
<s:BorderContainer width = "50" height = "50"
borderWeight = "2" color = "0x323232" />
<s:BorderContainer width = "50" height = "50"
borderWeight = "2" color = "0x323232" />
</s:HGroup>
</s:SkinnableContainer>
</s:Panel>
</s:VGroup>
</s:BorderContainer>
</s:Application>
完成所有更改后,让我们像在 Flex - 创建应用程序 章节中一样,在普通模式下编译并运行应用程序。如果应用程序一切正常,它将生成以下结果:[ 在线尝试 ]