Android布局属性详解之RelativeLayout

转载 2013年12月04日 13:37:32

RelativeLayout用到的一些重要的属性:

 

第一类:属性值为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 离某元素上边缘的距离


EditText的android:hint

设置EditText为空时输入框内的提示信息。

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

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

android:layout_alignParentRight

使当前控件的右端和父控件的右端对齐。这里属性值只能为true或false,默认false。

android:scaleType:
android:scaleType是控制图片如何resized/moved来匹对ImageView的size。ImageView.ScaleType / android:scaleType值的意义区别:

CENTER /center 按图片的原来size居中显示,当图片长/宽超过View的长/宽,则截取图片的居中部分显示

CENTER_CROP / centerCrop 按比例扩大图片的size居中显示,使得图片长(宽)等于或大于View的长(宽)

CENTER_INSIDE / centerInside 将图片的内容完整居中显示,通过按比例缩小或原来的size使得图片长/宽等于或小于View的长/宽

FIT_CENTER / fitCenter 把图片按比例扩大/缩小到View的宽度,居中显示

FIT_END / fitEnd 把图片按比例扩大/缩小到View的宽度,显示在View的下部分位置

FIT_START / fitStart 把图片按比例扩大/缩小到View的宽度,显示在View的上部分位置

FIT_XY / fitXY 把图片不按比例扩大/缩小到View的大小显示

MATRIX / matrix 用矩阵来绘制,动态缩小放大图片来显示。

** 要注意一点,Drawable文件夹里面的图片命名是不能大写的。

1.Android RelativeLayout 属性

 // 相对于给定ID控件

android:layout_above 将该控件的底部置于给定ID的控件之上;

android:layout_below 将该控件的底部置于给定ID的控件之下;

android:layout_toLeftOf    将该控件的右边缘与给定ID的控件左边缘对齐;

android:layout_toRightOf  将该控件的左边缘与给定ID的控件右边缘对齐;

android:layout_alignBaseline  将该控件的baseline与给定ID的baseline对齐;

android:layout_alignTop        将该控件的顶部边缘与给定ID的顶部边缘对齐;

android:layout_alignBottom   将该控件的底部边缘与给定ID的底部边缘对齐; 

android:layout_alignLeft        将该控件的左边缘与给定ID的左边缘对齐;

android:layout_alignRight      将该控件的右边缘与给定ID的右边缘对齐;

// 相对于父组件

android:layout_alignParentTop      如果为true,将该控件的顶部与其父控件的顶部对齐;

android:layout_alignParentBottom 如果为true,将该控件的底部与其父控件的底部对齐;

android:layout_alignParentLeft      如果为true,将该控件的左部与其父控件的左部对齐;

android:layout_alignParentRight    如果为true,将该控件的右部与其父控件的右部对齐;

// 居中

android:layout_centerHorizontal 如果为true,将该控件的置于水平居中;

android:layout_centerVertical     如果为true,将该控件的置于垂直居中;

android:layout_centerInParent   如果为true,将该控件的置于父控件的中央;

// 指定移动像素

android:layout_marginTop      上偏移的值;

android:layout_marginBottom 下偏移的值;

android:layout_marginLeft   左偏移的值;

android:layout_marginRight   右偏移的值;

example: android:layout_below = "@id/***" android:layout_alignBaseline = "@id/***"

android:layout_alignParentTop = true

android:layout_marginLeft = “10px” 、

2.一些常用的公共属性介绍

1) layout_width -宽    

 fill_parent: 宽度和父元素相同

wrap_content: 宽度随本身的内容所调整或者指定 px值来设置宽

 2) layout_height - 高  

   fill_parent: 高度和父元素相同

wrap_content: 高度随本身的内容所调整或者指定 px值来设置高

 3) background -设置背景图

 4) padding -设置边距      可以具体设置paddingBottompaddingLeftpaddingRightpaddingTop来设定不同的px值

 5) id -该object的id号      @+id/id1 代表添加新的id名为id1 @id/id1 代表引用id1的控件

 6) layout_weight -重要度       个人理解为显示的优先级。默认为0(最高)数值越大优先级越低参考下面的Linear      Layout例子。

要让layout_weight生效需要父层或父父层的相应    

 layout_width/layout_height = "fill_parent"否则wrap_content      会压缩到最小足够空间

 7) layout_gravity- Container组件的对齐方式       组件在layout里面的对齐方式。

 8) gravity-文字在组件里的对齐方式      例如设置button里面的文字在button中居中显示。

 * 大多数属性是可以调用对应的函数来动态改变状态的请查看SDK Doc。

 2. Linear Layout 线形布局  

   orientation -容器内元素的排列方式。

vertical: 子元素们垂直排列

horizontal:       子元素们水平排列。

在代码里可通过setOrientation()进行动态改变      

值分别为HORIZONTAL或者VERTICAL。    

  *在Linear Layout, 宽度/高度都是按着组件的次序逐个占用的所以当某个组件设置 

 

    "fill_parent"在没有设置Layout_weight的情况下该组件会占用了余下的空间    

 那么在它后面的组件就会显示不出来。

如下图的EditText如果没有设置  

   android:layout_weight="1",它下面的其他组件就看不见了    

  baselineAligned 一般情况下这个属性默认为true代表在同一方向的组件都基于    

 第一个组件对齐。所以可以看到下图的text1, button1, text2是在同一水平线的。    

 当不需要这效果时可以设置为false。

3.android常用控件  

1,EditText      

主要函数:setText/getText设置/获取文本内容,setHint设置缺省显示内容;

2,RadioGroup,RadioButton RadioButton的isChecked()判断是否被选中 获取选中RadioButon的ID:设置RadioGroup.setOnCheckedChangeListener方法

public onCheckedChanged(RadioGroup group,int checkedId)//checkedId是选中RadioButton的ID

3,CheckBox isChecked()判断是否被选中 setOnCheckedChangeListener方法监视选中状态改变情况

4,Spinner     a,显示数据

1),硬编码加载 通过setAdapter方法设置类型为ArrayAdapter (Context context, int textViewResId, String []objects)  

  textViewResourceId:显示内容的ViewID默认设置为R.layout.simple_spinner_item    objects:显示的内容

2),从资源文件中加载 

ArrayAdapter.createFromResource (Context context, int textArrayResId, int textViewResId) //textArrayResId是资源ID 返回ArrayAdapter<CharSequence>    

b,设置下拉列表的风格(可选) adapter.setDropDownViewResource(android.R.layout.simple_spinner_dropdown_item);    

c,监听选项选择变更事件 setOnItemSelectedListener设置监听去 Spinner.OnItemSelectedListener类须实现以下两个方法

public void onItemSelected (AdapterView<?> parent, View view, int position, long id)//view 选中项实例,position选择项在adapter中的位置 public void onNothingSelected(AdapterView<?> arg0)  

  d,设置选中项 Spinner.setSelection(position)//索引从0开始    

d,获取选中项 getSelectedItemPosition ()  getSelectedItem () //该值toString()则为选中内容的字符串 getSelectedItemId ()

 getSelectedView ()

5,AutoCompleteTextView

1,setAdapter设置数据adapter

2,设置输入多少个字符显示提示AutoCompleteTextView.setThreshold(int threshold)

6,MultiAutoCompleteTextView (允许输入多值,多值之间会自动地用指定的分隔符分开)

1,setAdapter设置数据adapter

2,setTokenizer设置提示Tokenizer缺省的为new MultiAutoCompleteTextView.CommaTokenizer()以逗号分隔 

7,DatePicker,TimePicker

a,DatePicker

1),设置初始显示日期init(int Year, int month, int day, new DatePicker.OnDateChangedListener(){     public void onDateChanged(DatePicker view, int year, int monthOfYear, int dayOfMonth){}    })

2),获取设置值 getYeah()/getMonth()/getDayOfMonth() b,TimePicker

1),设置setCurrentHour (Integer currentHour) /setCurrentMinuter (Integer currentHour)

 2,setIs24HourView(Boolean)设置是否为24小时制显示

3,监听设置改变setOnTimeChangedListener

c,获取系统当期时间和日期 Calendar.getInstance()返回Calendar Calendar.get (int field) ---field 可以为Calendar.YEAR/ Calendar.MONTH/ Calendar.DAY_OF_MONTH/ Calendar.HOUR_OF_DAY/ Calendar.MINUTE

8,ImageView/ImageButton 主要方法 setImageResource 设置显示图片 setAlpha 设置Alpha invalidate 强制更新

setScaleType( ScaleType st) 设置图片显示方式,st是一枚举 setAdjustViewBounds 设置是否调整控件适应图片大小 setBackgroundResource 设置背景

9,ImageSwitcher(显示一系列的图片,但当前只显示一张图片)      显示数据 

setFactory( ViewSwitcher.ViewFactory factory)设置要显示的数据 ,ViewFactory接口须实现方法

public View makeView(){}负责提供当前显示的视图(ImageView),且View必须为新实例  

   方法 setImageResource设置当前显示的图片 getCurrentView()返回当前显示的视图

setInAnimation(Animation ani)设置视图装载入时的动画效果,AnimationUtils.loadAnimation(Context context, int id)

获取动画效果android.R.anim.XX setOutAnimation(Animation ani)设置视图装载入时的动画效果

10,Gallery(显示一系列的图片,提供拖动等特效)      显示数据 setAdapter(SpinnerAdapter adapter)设置数据适配器.  

 数据适配器可以继承自BaseAdapter,该类 public View getView(int position, View convertView, ViewGroup parent) 返回当前选择的视图(ImageView)    

 选项选中监听setOnItemSelectedListener

11,GridView(表格显示一系列图片)      

显示数据 setAdapter(ListAdapter adapter)设置数据适配器.  

 数据适配器可以继承自BaseAdapter,该类 public View getView(int position, View convertView, ViewGroup parent) 返回当前选择的视图(ImageView)    

 选项选中监听setOnItemSelectedListener  

   getSelectedView()返回当前选中的视图

12,ScrollView

13,ProgressBar setIndeterminate 设置进度条是否自动运转

   setProgressStyle 设置显示风格.ProgressDialog.STYLE_HORIZONTAL/ProgressDialog.STYLE_SPINNER 

 

setProgress 设置进度

setMax 设置最大值

getProgress()获取当前进度

14,SeekBar 方法

setMax 设置最大值

getProgress()获取当前值

setProgress 设置值

setIndeterminate 监听器

setOnSeekBarChangeListener其下有三个方法  

 public void onProgressChanged(SeekBar arg0, int arg1, boolean arg2) //数值变更,arg1新值,是否Touch  

 public void onStartTrackingTouch(SeekBar seekBar)//开始拖动  

 public void onStopTrackingTouch(SeekBar seekBar) //结束拖动

15,ListView    

  a,显示数据setAdapter(ListAdapter adapter)      

 adapter可为new SimpleCursorAdapter/SimpleAdapter(Context context, int layout, Cursor c, String[] from, int[] to)    

   layout 用来显示数据的模板.显示一列可用android.R.layout.simple_list_item_1 两列可用android.R.layout.simple_list_item_2            

   多列则需要自己实现xml视图布局文件    

   c   数据(可用ArrayList构造数据)    

   from ':        to 用来显示对应列的空件id      

b,动态增删数据 

  adapter.notifyDataSetChanged()    

  d,设置背景色         setBackGroudRource  

Android布局RelativeLayout(相对布局)详解

RelativeLayout(相对布局) 前言 和线性布局(LinearLayout)一样,RelaiveLayout相对布局也是我们用的比较多的一个布局之一 好的编程建议: 合理地利用好Line...
  • apple_4872330
  • apple_4872330
  • 2015年01月14日 17:34
  • 1767

RelativeLayout相对布局 安卓布局技巧

RelativeLayout相对布局 相对布局 RelativeLayout 允许子元素指定它们相对于其父元素或兄弟元素的位置,这是实际布局中最常用的布局方式之一。它灵活性大很多,当然属性也多,...
  • nieweiking
  • nieweiking
  • 2014年08月07日 13:40
  • 15220

Android相对布局RelativeLayout各属性介绍

Android相对布局RelativeLayout各属性介绍 相对于兄弟元素 android:layout_below="@id/xxx":在指定View的下方 android:layout_abov...
  • wu_wxc
  • wu_wxc
  • 2015年06月22日 22:58
  • 1378

RelativeLayout实现百分比布局

Android没有百分比说 线性布局用权重设置layout_width="0dp",加android:layout_weight="1.0"//权重 相对布局设置layout_width="0dp...
  • u013037007
  • u013037007
  • 2014年07月12日 14:42
  • 1244

Android 开发:(七)常用布局属性详解

第一类:属性值为true或false android:layout_centerHrizontal 水平居中 android:layout_centerVer...
  • Kevindongkun
  • Kevindongkun
  • 2017年03月13日 15:29
  • 400

代码中进行RelativeLayout布局的修改添加

android用java为编程语言,很多地方都很相似,界面这块也很像。我们都知道java画界面是一行一行代码去添加界面的控件的,所以那是一件让人崩溃的事。Android完美解决了这一问题,Androi...
  • qq_32969313
  • qq_32969313
  • 2016年04月12日 15:06
  • 3219

相对布局RelativeLayout的子控件属性和操作

RelativeLayout是相对布局控件,它包含的子控件将以控件之间的相对位置或者子类控件相对父类容器的位置方式排列。 子类控件常用属性 android:layout_alignParentLe...
  • qq_23893313
  • qq_23893313
  • 2017年03月22日 18:59
  • 566

android-RelativeLayout实现顶部、中部、底部布局

主要使用: 设置为最顶部:android:layout_alignParentTop ="true" 设置为中部: android:layout_above ="@+id/panelBottom...
  • mjjmjc
  • mjjmjc
  • 2015年07月29日 10:50
  • 4622

Android应用的LinearLayout中嵌套RelativeLayout的布局用法

想将Button和ListView分别放在屏幕的一左一右。 单纯使用android:gravity和android:layout_gravity不成功。 于是涉及到RelativeLayout。 关键...
  • phenixyf
  • phenixyf
  • 2016年05月10日 14:02
  • 2149

RelativeLayout布局属性详解

RelativeLayout用到的一些重要的属性:   第一类:属性值为true或false   android:layout_centerHrizontal 水平居中   android:layou...
  • qq_27298687
  • qq_27298687
  • 2016年01月14日 15:53
  • 200
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:Android布局属性详解之RelativeLayout
举报原因:
原因补充:

(最多只允许输入30个字)