android布局属性详解

android布局方式
Android对用五大布局对象
FrameLayout  LinearLayout  RelativeLayout  TableLayout  AbsoluteLayout

FrameLayout
FrameLayout是最简单的一个布局对象。
它被定制为你屏幕上的一个空白备用区域,之后你可以在其中填充一个单一对象 
比如,一张你要发布的图片。 所有的子元素将会固定在屏幕的左上角
后一个子元素将会直接在前一个子元素之上进行覆盖填充,把它们部份或全部挡住(除非后一个子元素是透明的)。

LinearLayout
LinearLayout以你为它设置的垂直或水平的属性值,来排列所有的子元素。
所有的子元素都被堆放在其它元素之后,因此一个垂直列表的每一行只会有一个元素,而不管他们有多宽,
而一个水平列表将会只有一个行高.
LinearLayout还支持为单独的子元素指定weight 。好处就是允许子元素可以填充屏幕上的剩余空间。这也避免了在一个大屏幕中,一串小对象挤成一堆的情况,而是允许他们放大填充空白。
子元素指定一个 weight 值,剩余的空间就会按这些子元素指定的weight 比例分配给这些子元素。默认的 weight 值为0 。例如,如果有三个文本框,其中两个指定了weight 值为1,那么,这两个文本框将等比例地放大,并填满剩余的空间,而第三个文本框不会放大。

RelativeLayout
RelativeLayout 允许子元素指定他们相对于其它元素或父元素的位置(通过ID 指定)。
因此,你可以以右对齐,或上下,或置于屏幕中央的形式来 排列两个元素。

TableLayout
TableLayout 将子元素的位置分配到行或列中。
一个TableLayout由许多的TableRow 组成 ,每个TableRow 都会定义一个 row 
<TableLayout xmlns:android="http://schemas.android.com/apk/res/android"
 android:layout_width="fill_parent" android:layout_height="fill_parent"
 android:stretchColumns="1">

 <TableRow>
  <TextView android:text="用户名:" android:textStyle="bold"
   android:gravity="right" android:padding="3dip" />

  <EditText android:id="@+id/username" android:padding="3dip"
   android:scrollHorizontally="true" />
 </TableRow>

 <TableRow>
  <TextView android:text="登录密码:" android:textStyle="bold"
   android:gravity="right" android:padding="3dip" />

  <EditText android:id="@+id/password" android:password="true"
   android:padding="3dip" android:scrollHorizontally="true" />
 </TableRow>

 <TableRow android:gravity="right">

  <Button android:id="@+id/cancel"
   android:text="取消" />

  <Button android:id="@+id/login"
   android:text="登录"  android:layout_width="wrap_content"
   android:layout_height="wrap_content"/>
 </TableRow>
</TableLayout>

AbsoluteLayout
让子元素指定准确的x/y坐标值

android布局属性
android:background布局的背景
android:layout_marginTop距上一个布局的间隔距离
android:gravity布局中文字的位置,如:居中
android:layout_gravity整个布局的位置,如垂直居中等
android:layout_alignParentTop布局的位置是否处于顶部,同时还有左、右、底部
android:text需要显示文字的布局中要显示的文字,如TextView、Button
android:layout_alignTop="@id/ok"设置此组件和ID为OK的组件的高度齐平

LinearLayout有两个非常相似的属性:android:gravity与 android:layout_gravity。
android:gravity属性是对该view内容的限定.
比如一个button 上面的text.你可以设置该text在view的靠左,靠右等位置.
以button为例,android:gravity="right"则button上面的文字靠右 

android:layout_gravity是用来设置该view相对与起父view 的位置 比如一个button 在linearlayout里,你想把该button放在靠左、靠右等位置就可以通过该属性设置.以button为例,android:layout_gravity="right"则button靠右 

第一类:属性值为true或false 
android:layout_centerHrizontal  水平居中 
android:layout_centerVertical   垂直居中 
android:layout_centerInparent    相对于父元素完全居中 
android:layout_alignParentBottom 贴紧父元素的下边缘 
android:layout_alignParentLeft   贴紧父元素的左边缘 
android:layout_alignParentRight  贴紧父元素的右边缘 
android:layout_alignParentTop    贴紧父元素的上边缘 
android:layout_alignWithParentIfMissing  如果对应的兄弟元素找不到的话就以父元素做参照物 

第二类:属性值必须为id的引用名"@id/id-name" 
android:layout_below      在某元素的下方 
android:layout_above      在某元素的的上方 
android:layout_toLeftOf   在某元素的左边 
android:layout_toRightOf  在某元素的右边 

android:layout_alignTop   本元素的上边缘和某元素的的上边缘对齐 
android:layout_alignLeft  本元素的左边缘和某元素的的左边缘对齐 
android:layout_alignBottom 本元素的下边缘和某元素的的下边缘对齐 
android:layout_alignRight  本元素的右边缘和某元素的的右边缘对齐 

第三类:属性值为具体的像素值,如30dip,40px 
android:layout_marginBottom              离某元素底边缘的距离 
android:layout_marginLeft                离某元素左边缘的距离 
android:layout_marginRight               离某元素右边缘的距离 
android:layout_marginTop                 离某元素上边缘的距离 

android:scaleType: 
android:scaleType是控制图片如何resized/moved来匹对ImageView的size。ImageView.ScaleType / android:scaleType值的意义区别: 
center  按图片的原来size居中显示,当图片长/宽超过View的长/宽,则截取图片的居中部分显示 
centerCrop  按比例扩大图片的size居中显示,使得图片长(宽)等于或大于View的长(宽) 
centerInside  将图片的内容完整居中显示,通过按比例缩小或原来的size使得图片长/宽等于或小于View的长/宽 
fitCenter  把图片按比例扩大/缩小到View的宽度,居中显示 
fitEnd   把图片按比例扩大/缩小到View的宽度,显示在View的下部分位置 
fitStart  把图片按比例扩大/缩小到View的宽度,显示在View的上部分位置 
fitXY  把图片不按比例 扩大/缩小到View的大小显示 
matrix 用矩阵来绘制,动态缩小放大图片来显示。 
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值