`

Flex学习笔记_05 使用容器控制界面布局_01管理程序的布局

阅读更多

本文的相关文章:

Flex学习笔记_05 使用容器控制界面布局_02窗口布局

Flex学习笔记_05 使用容器控制界面布局_03动态布局、导航容器、表单布局

 

 

1.管理程序的布局

容器累组件都位于mx.containers包中。Container类是UIComponent的子类,是所有Flex容器类的父类,每个容器类都在它的基础上添加自己的功能。

 

1.1控制Application 的布局

Application 是一个特殊的容器,位于界面元素的根部,包含了整个程序的所有元素。

layout :

    值为absolute时,horizontalAlign水平对齐和verticalAlign垂直对齐不起作用,界面上的元素将由各自的坐标决定。

 

    值为vertical 或 horizontal时,元素的位置由horizontalAlign和verticalAlign控制。

 

width 长, height 高。决定SWF文件的尺寸。

 

我们可以设置如下的属性,所有组件公有:

horizontalGap 水平间距

vericalGap 垂直间距

paddingTop 顶部边距

paddingLeft 左边距

paddingRight 右边距

paddingBottom 底边距

 

Constraint layout 约束布局,只能在layout属性值为absolute才能使用,具有这一特性的容器有:Application、Canvas、Panel和Panel的子类TitleWingdow

点击元素得到如下界面:

 

如果对某一组件使用了约束布局,它会被强制定位在相应的位置,设置的X,Y坐标会失效。

 

ApplicationContolBar是和Application相关的一个容器,通常用来提供全局导航。有水平(默认)和垂直方向选择。它的dock属性,表示是否强行停靠在Application的顶部。默认false,被当作一个普通的组件。true,始终在顶部,宽度为100%。

<?xml version="1.0" encoding="utf-8"?>
<mx:Application xmlns:mx="http://www.adobe.com/2006/mxml" 
layout="absolute" horizontalAlign="left" verticalAlign="top" height="100%" width="100%"
 horizontalGap="0" verticalGap="0" paddingTop="0">	
	<mx:Button label="Button1" height="120" x="24" y="0"/>
	<mx:Button label="Button2" top="0" bottom="30" width="72" horizontalCenter="-72"/>
	<mx:Button label="Button3" width="240" x="168" y="0"/>
	<mx:ApplicationControlBar dock="true">
		<mx:Label text="这里是顶部导航" width="93" height="20"/>
	</mx:ApplicationControlBar>
</mx:Application>
 

 

1.2 Canvas

Canvas 直接继承自Container,体积小,使用灵活。在它里面的元素只能由X,Y来定位。如果元素超出 Canvas 的区域范围, Canvas 会自动增加滚动条。每个容器默认情况下都会自动带滚动条。可以通过horizontalScrollPolicy和 verticalScrollPolicy 的属性值来控制,on/off/auto。在AS中对应ScrollPolicy.ON, ScrollPolicy.OFF, ScrollPolicy.AUTO。

 

1.3 VBox 和 HBox

VBox 和 HBox 都是Box的子类,和Canvas相比,Box对子级元素采取规则的布局方式,其中VBox内的元素垂直方向分布,而HBox水平方向分布。通过horizontalAlign和verticalAlign控制容器内的元素对齐方式。

<?xml version="1.0" encoding="utf-8"?>
<mx:Application xmlns:mx="http://www.adobe.com/2006/mxml" layout="absolute">
	<mx:HBox x="27" y="30" width="50%" height="50%" horizontalAlign="left" 
            verticalAlign="middle">
		<mx:Button label="Button"/>
		<mx:Label text="这是一个HBox"/>
	</mx:HBox>
	<mx:VBox width="50%" x="263" y="30" height="100%">
		<mx:Label text="这是一个VBox"/>
		<mx:Button label="Button"/>
	</mx:VBox>	
</mx:Application>

 

1.4 用DividedBox分割界面

DividedBox继承自Box类,它有两个子类:HDividedBox和VDividedBox。类似于HBox和VBox,多了在子级元素之间增加了可以拖动的分割块。拖动分割块可以动态的调整分割块附近元素的长宽。

borderStyle是组件的样式之一,表示边框样式,默认:none,表示无边框。solid为实心线条。

liveDragging:true 表示在拖动时,在松开鼠标后,调整位置。false 拖动时调整。

<?xml version="1.0" encoding="utf-8"?>
<mx:Application xmlns:mx="http://www.adobe.com/2006/mxml" layout="absolute">
	<mx:HDividedBox width="90%" height="90%" liveDragging="false" borderStyle="solid"
            x="10" y="10">
		<mx:Canvas width="200" height="246">
			<mx:Label x="33" y="10" text="一个Canvas容器"/>		
		</mx:Canvas>
		<mx:HBox width="50%" height="50%">
			<mx:Label text="HBox容器" width="140"/>
			<mx:HBox width="50%" height="50%">
				<mx:Label text="HBox内的HBox" width="140"/>
			</mx:HBox>
		</mx:HBox>
	</mx:HDividedBox>
</mx:Application>
分享到:
评论
1 楼 Army 2009-03-02  
mx.containers.* 包里有好多呢,剩下的是放在后面讲了吗?

相关推荐

    Flex学习笔记1

    Flex学习笔记1 - 容器布局对象状态的切换和数据绑定 在 Flex 应用程序中,容器布局对象状态的切换是非常常见的需求。例如,在购物车应用程序中,我们可能需要在不同的状态之间切换,例如从商品浏览状态到购物车状态...

    flex 学习详细笔记

    7. **布局管理器**:Flex提供了多种布局管理器,如垂直布局、水平布局、网格布局等,用于控制组件在容器中的排列方式,确保UI在不同屏幕尺寸下都能正确显示。 8. **事件模型**:Flex的事件模型是基于发布-订阅模式...

    flex学习笔记beginning

    根据给定的文件信息,我们可以提炼出以下关于Flex学习的关键知识点: ### 1. ActionScript 核心概念 #### 1.1 类和对象 (Class and Object) - **定义**:类是对象的抽象,而对象是类的具体实例。一个类定义了对象...

    Flex学习笔记,入门材料

    ### Flex学习笔记:ActionScript与Flex开发入门 #### 1. ActionScript核心概念 ##### 1.1 类和对象(Class and Object) 类是对象的模板,定义了一组具有相同特性和行为的对象的共同属性和方法。在ActionScript中...

    flex4.5学习笔记

    ### Flex4.5学习笔记知识点总结 #### 一、Flex基础——布局 **知识点1:Flex布局** - **垂直布局** (`s:VerticalLayout`): 控件垂直排列。 - **水平布局** (`s:HorizontalLayout`): 控件水平排列。 - **平铺布局**...

    老师整理的extjs学习笔记

    ### ExtJS 学习笔记概览 #### 一、ExtJS 入门 **1.1 ExtJS 构成及如何引用** ExtJS 是一款基于 JavaScript 的开源框架,专为 Web 应用程序的前端界面设计。其核心优势在于提供了一套丰富的 UI 组件和强大的数据...

    uniapp笔记.rar

    - 常用组件包括视图容器(view、scroll-view)、基础内容(text、image)、表单组件(input、picker、button)、导航(navigator)、布局(flex、grid)等。 - 还有日期时间选择器、地图、视频、直播、广告等高级...

Global site tag (gtag.js) - Google Analytics