AndroidLayout之RelativeLayout,代码实现相对布局作者:喜之郎常年担任java开发小组负责人使用AbsoluteLayout可以直接指定其子View的绝对位置,这种布局方式虽然简单,但是不够灵活。比如在一个程序中,按钮2位于按钮1的下方且和按钮1左对齐,我们可以使用指定两个按钮的绝对位置的方式布局,但是当布局完成后,由于某些原因,这两个按钮需要相左平移一些距离以便在父View右边留出一些空白区域,那么我们就需要同时修改按钮1和按钮2的layoutparams。如果布局更复杂一些呢?这样“牵一发而动全身”的布局模式恐怕不是那么友好吧?RelativeLayout,顾名思义,就是以“相对”位置/对齐为基础的布局方式。android.widget.RelativeLayout有个继承自android.vieViewGroup.LayoutParams的内嵌类LayoutParams,使用这个类的实例调用RelativeLayout.addView就可以实现“相对布局”。android.widget.RelativeLayout.LayoutParams有一个构造函数:RelativeLayout.LayoutParams(intw,inth),参数指定了子View的宽度和高度,这一点和其父类是一样的。而实现相对布局的关键在它的两个addRule方法上。anchor参数指定可以是View的id(“相对于谁”)、RelativeLayout.TRUE(启用某种对齐方式)或者是-1(应用于某些不需要anchor的verb);AddRule方法的verb参数指定相对的“动作”(以下常量均定义于android.widget.RelativeLayout中,为了简便不给出其全名):ALIGN_BOTTOM、ALIGN_LEFT、ALIGN_RIGHT、ALIGN_TOP:本View的底边/左边/右边/顶边和anchor指定的View的底边/左边/右边/顶边对齐。ALIGN_WITH_PARENT_BOTTOM、ALIGN_WITH_PARENT_LEFT、ALIGN_WITH_PARENT_RIGHT、ALIGN_WITH_PARENT_TOP:和上面一组常量类似,只不过不需要再指定anchor,其anchor自动为ParentView。CENTER_HORIZONTAL、CENTER_IN_PARENT、CENTER_VERTICAL:如果anchor为TRUE,在Parent中水平居中/水平和垂直均居中/垂直居中。POSITION_ABOVE、POSITION_BELOW、POSITION_TO_LEFT、POSITION_TO_RIGHT:本View位于anchor指定的View的上边/下边/左边/右边。看一个例子:packagecom.farproc.RLTest;importandroid.app.Activity;importandroid.os.Bundle;importandroid.widget.*;importandroid.vie*;publicclassRLTestextendsActivity{---本文于网络,仅供参考,勿照抄,如有侵权请联系删除---privateRelativeLayoutrl;privateButtonbtn1;privateButtonbtn2;privateButtonbtn3;privateButtonbtn4;privatestaticfinalintID_BTN1=1;privatestaticfinalintID_BTN2=2;privatestaticfinalintID_BTN3=3;privatestaticfinalintID_BTN4=4;/**Calledwhentheactivityisfirstcreated.*/@OverridepublicvoidonCreate(Bundleicicle){super.onCreate(icicle);rl=newRelativeLayout(this);btn1=newButton(this);btn1.setText("----------------------");btn1.setId(ID_BTN1);RelativeLayout.LayoutParamslp1=newRelativeLayout.LayoutParams(ViewGroup.LayoutParams.WRAP_CONTENT,ViewGroup.LayoutParams.WRAP_CONTENT);lp1.addRule(RelativeLayout.ALIGN_WITH_PARENT_TOP);lp1.addRule(RelativeLayout.CENTER_HORIZONTAL,RelativeLayout.TRUE);//btn1位于父View的顶部,在父View中水平居中rl.addView(btn1,lp1);btn2=newButton(this);btn2.setText("|\n|\n|\n|\n|\n|");btn2.setId(ID_BTN2);RelativeLayout.LayoutParamslp2=newRelativeLayout.LayoutParams(ViewGroup.LayoutParams.WRAP_CONTENT,ViewGroup.LayoutParams.WRAP_CONTENT);lp2.addRule(RelativeLayout.POSITION_BELOW,ID_BTN1);lp2.addRule(RelativeLayout.ALIGN_LEFT,ID_BTN1);//btn2位于btn1的下方、其左边和btn1的左边对齐rl.addView(btn2,lp2);---本文于网络,仅供参考,勿照抄,如有侵权请联系删除---btn3=newButton(this);btn3.setText("|\n|\n|\n|\n|\n|");btn3.setId(ID_BTN3);RelativeLayout.LayoutParamslp3=newRelativeLayout.LayoutParams(ViewGroup.LayoutParams.WRAP_CONTENT,ViewGroup.LayoutParams.WRAP_CONTENT);lp3.addRule(RelativeLayout.POSITION_BELOW,ID_BTN1);lp3.addRule(RelativeLayout.POSITION_TO_RIGHT,ID_BTN2);lp3.addRule(RelativeLayout.ALIGN_RIGHT,ID_BTN1);//btn3位于btn1的下方、btn2的右方且其右边和btn1的右边对齐(要扩充)rl.addView(btn3,lp3);btn4=newButton(this);btn4.setText("--------------------------------------------");btn4.setId(ID_BTN4);RelativeLayout.LayoutParamslp4=newRelativeLayout.LayoutParams(ViewGroup.LayoutParams.WRAP_CONTENT,ViewGroup.LayoutParams.WRAP_CONTENT);lp4.addRule(RelativeLayout.POSITION_BELOW,ID_BTN2);lp4.addRule(RelativeLayout.CENTER_HORIZONTAL,RelativeLayout.TRUE);//btn4位于btn2的下方,在父Veiw中水平居中rl.addView(btn4,lp4);setContentView(rl);}}---本文于网络,仅供参考,勿照抄,如有侵权请联系删除---