2024年2月8日发(作者:)
Android Layout 之 RelativeLayout,代码实现相对布局
作者:喜之郎
常年担任java开发小组负责人
使用 AbsoluteLayout 可以直接指定其子 View 的绝对位置, 这种布局方式虽然简单,但是不够灵活。比如在一个程序中,按钮2 位于 按钮1 的下方且和 按钮1 左对齐,我们可以使用指定两个按钮的绝对位置的方式布局,但是当布局完成后,由于某些原因,这两个按钮需要相左平移一些距离以便在父 View 右边留出一些空白区域,那么我们就需要同时修改
按钮1 和 按钮2 的 layout params。如果布局更复杂一些呢?这样“牵一发而动全身”的布局模式恐怕不是那么友好吧?
RelativeLayout,顾名思义,就是以“相对”位置/对齐 为基础的布局方式。veLayout 有个 继承自Params 的内嵌类
LayoutParams,使用这个类的实例调用 w 就可以实现“相对布局”。
Params 有一个构造函数:Params(int w, int h),参数指定了子 View 的宽度和高度,这一点和其父类是一样的。而实现相对布局的关键在它的 两个 addRule 方法上。anchor 参数指定可以是 View 的 id(“相对于谁”)、(启用某种对齐方式) 或者 是-1(应用于某些不需要 anchor 的 verb);AddRule 方法的 verb 参数指定相对的“动作”(以下常量均定义于 veLayout中,为了简便不给出其全名):
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 自动为 Parent View。
CENTER_HORIZONTAL、CENTER_IN_PARENT 、CENTER_VERTICAL : 如果 anchor 为 TRUE,在 Parent 中 水平居中/水平和垂直均居中/垂直居中。
POSITION_ABOVE 、POSITION_BELOW 、 POSITION_TO_LEFT 、POSITION_TO_RIGHT : 本
View 位于 anchor 指定的 View 的 上边/下边/左边/右边。
看一个例子:
package ;
import ty;
import ;
import .*;
import .*;
public class RLTest extends Activity {
private RelativeLayout rl;
private Button btn1;
private Button btn2;
private Button btn3;
private Button btn4;
private static final int ID_BTN1 = 1;
private static final int ID_BTN2 = 2;
private static final int ID_BTN3 = 3;
private static final int ID_BTN4 = 4;
/** Called when the activity is first created. */
@Override
public void onCreate(Bundle icicle) {
te(icicle);
rl = new RelativeLayout(this);
btn1 = new Button(this);
t("----------------------");
(ID_BTN1);
Params lp1 =
Params(_CONTENT,
_CONTENT);
e(_WITH_PARENT_TOP);
e(_HORIZONTAL, );
// btn1 位于父 View 的顶部,在父 View 中水平居中
w(btn1, lp1 );
btn2 = new Button(this);
t("|n|n|n|n|n|");
(ID_BTN2);
Params lp2 =
Params(_CONTENT,
_CONTENT);
e(ON_BELOW, ID_BTN1);
e(_LEFT, ID_BTN1);
// btn2 位于 btn1 的下方、其左边和 btn1 的左边对齐
w(btn2, lp2);
new
new
btn3 = new Button(this);
t("|n|n|n|n|n|");
(ID_BTN3);
Params lp3 = new
Params(_CONTENT,
_CONTENT);
e(ON_BELOW, ID_BTN1);
e(ON_TO_RIGHT, ID_BTN2);
e(_RIGHT, ID_BTN1);
// btn3 位于 btn1 的下方、btn2 的右方且其右边和 btn1 的右边对齐(要扩充)
w(btn3,lp3);
btn4 = new Button(this);
t("--------------------------------------------");
(ID_BTN4);
Params lp4 = new
Params(_CONTENT,
_CONTENT);
e(ON_BELOW, ID_BTN2);
e(_HORIZONTAL, );
// btn4 位于 btn2 的下方,在父 Veiw 中水平居中
w(btn4,lp4);
setContentView(rl);
}
}
本文发布于:2024-02-08 19:20:44,感谢您对本站的认可!
本文链接:https://www.4u4v.net/it/170739124468316.html
版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系,我们将在24小时内删除。
留言与评论(共有 0 条评论) |