LinearLayout中margin属性小结

简介: mainActivity如下: package com.c; import android.os.Bundle; import android.

mainActivity如下:

package com.c;

import android.os.Bundle;
import android.app.Activity;
/**
 * Demo描述:
 * 分析LinearLayout中margin属性的作用
 * 备注:
 * MainActivity没有实际用处,只是用来记笔记
 */
public class MainActivity extends Activity {

	@Override
	protected void onCreate(Bundle savedInstanceState) {
		super.onCreate(savedInstanceState);
	}
	public void testHorizontal(){
//		<LinearLayout 
//	    xmlns:android="http://schemas.android.com/apk/res/android"
//	    android:layout_width="match_parent"
//	    android:layout_height="match_parent"
//	    android:orientation="horizontal"
//	    >
//
//	    <Button
//	        android:layout_width="wrap_content"
//	        android:layout_height="wrap_content"
//	        android:layout_marginLeft="20dip"
//	        android:layout_marginRight="10dip"
//	        android:text="button1" />
//	    <Button
//	        android:layout_width="wrap_content"
//	        android:layout_height="wrap_content"
//	        android:layout_marginLeft="20dip"
//	        android:layout_marginRight="20dip"
//	        android:text="button2" />
//	      <Button
//	        android:layout_width="wrap_content"
//	        android:layout_height="wrap_content"
//	        android:layout_marginLeft="20dip"
//	        android:layout_marginRight="10dip"
//	        android:text="button3" />
//
//	</LinearLayout>
		
/**
 * 当第一种情况:
 * 线性布局采用的是horizontal
 * 总结1:
 * 此时我们水平放置三个Button.其中给第二个
 * Button2设置android:layout_marginRight="50dip"
 * 请注意!!!!!!!!!!!!!!!!!!
 * 此时并不是说明Button2距离父控件的最右边距离为50dip
 * 而是说明Button2距离它右边的同级子控件的距离为50dip.
 * (只有其右边没有同级子控件的时候,设置layout_marginRight
 * 才是相对于父控件的最右边而言的).
 * 这也就是说当放置Button3的时候是从距离Button2右边50dip的距离开始的.
 * 总结2:
 * button1设置了android:layout_marginRight="10dip"
 * button2设置了android:layout_marginLeft="20dip"
 * 那么两者的实际间距为10+20=30;
 * 总结3:
 * 最后一个子控件存在这么一种情况:
 * 参见上面的布局代码若设置button3中
 * android:layout_marginRight="60dip"
 * 那么button3会被挤变形.
 * 从以下几种情况:
 * (0)若只给button3设置android:layout_marginLeft="10dip"
   android:layout_marginRight="10dip",则正常显示
 * (1)若只给button3设置android:layout_marginLeft="80dip"
 *  那么button会变形
 * (2)若只给button3设置android:layout_marginLeft="80dip"
 *  android:layout_marginRight="10dip"那么button3会更加
 *  严重变形,且距离右边的边框有10dip的距离
 *  可总结出:
 *  在水平线性布局中最后一个子控件的右边缘距离父控件右边的距离为A
 *  若给该控件设置android:layout_marginRight="B"
 *  第一种情况:A>B时控件不会变形
 *  第二种情况:A<B时.控件会被压缩,并且是从右往左压缩(即控件的
 *  左基准线不会动摇),迫使距离父控件的距离为B.
 *  
 *  线性垂直布局与此类似
 */
	}

}


horizontal.xml如下:

<LinearLayout 
    xmlns:android="http://schemas.android.com/apk/res/android"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:orientation="horizontal"
    >
    <Button
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_marginLeft="20dip"
        android:layout_marginRight="10dip"
        android:text="button1" />
    <Button
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_marginLeft="10dip"
        android:layout_marginRight="20dip"
        android:text="button2" />
      <Button
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_marginLeft="10dip"
        android:layout_marginRight="10dip"
        android:text="button3" />

</LinearLayout>


vertical.xml如下:

<LinearLayout 
    xmlns:android="http://schemas.android.com/apk/res/android"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:orientation="vertical"
    >

    <Button
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_marginTop="30dip"
        android:layout_marginBottom="130dip"
        android:text="button1" />
    <Button
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_marginTop="60dip"
        android:text="button2" />
     <Button
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_marginTop="40dip"
        android:layout_marginBottom="10dip"
        android:text="button3" />
      

</LinearLayout>


 

相关文章
|
XML 前端开发 Android开发
Android XML 布局基础(四)内外边距(margin、padding)
Android XML 布局基础(四)内外边距(margin、padding)
313 0
|
6月前
|
Android开发
android padding和margin的区别
android padding和margin的区别
53 0
|
6月前
|
Java Android开发 开发者
RelativeLayout.LayoutParams布局属性详解
RelativeLayout.LayoutParams布局属性详解
|
8月前
|
XML Android开发 数据格式
Android五大布局对象---FrameLayout,LinearLayout ,Absolute
Android五大布局对象---FrameLayout,LinearLayout ,Absolute
53 1
|
XML Android开发 数据格式
|
Android开发 数据安全/隐私保护 容器
Android layout布局属性、标签属性总结大全
RelativeLayout 第一类:属性值为true可false android:layout_centerHrizontal       水平居中 android:layout_centerVertical        垂直居中 androi...
1125 0
|
Web App开发 测试技术