- 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 - 创建应用程序 章节中一样,在普通模式下编译并运行应用程序。如果应用程序一切正常,它将生成以下结果:[ 在线尝试 ]