昨天朋友问了我一个问题,感觉有点意思记录一下。
问题是这样的,我朋友创建了两个方法,一个是设置一个layout的对齐方式是向上对齐,一个是向下对齐,如果先向上对齐再向下对齐,向下对齐就会失效。
=================================================================
看了一下addRule的源码
public void addRule(int verb) {
addRule(verb, TRUE);
}
点进去再看addRule方法
public void addRule(int verb, int subject) {
// If we're removing a relative rule, we'll need to force layout
// resolution the next time it's requested.
if (!mNeedsLayoutResolution && isRelativeRule(verb)
&& mInitialRules[verb] != 0 && subject == 0) {
mNeedsLayoutResolution = true;
}
mRules[verb] = subject;
mInitialRules[verb] = subject;
mRulesChanged = true;
}
可以看到我们传进来的一个RULE对齐方式其实是存放在了一个mRules数组里面的,mRules就相当于携带了所有对齐方式的一个盒子,里面有每个对齐方式的开关,当我们创建了某一个对齐方式,就把当前对齐方式的开关打开。仅此而已,显然,我们在addRule了一个对齐方式的时候并不会修改其他方式,所以我们应该想到应该相对应的就有removeRule方法,在我们替换了对齐模式的同时需要把前面的对齐模式Remove掉。
所以知道这个思路之后问题就很简单了,只需要加一个removeRule就可以了
代码如下
private void showTop(){
RelativeLayout.LayoutParams layoutParams = (RelativeLayout.LayoutParams) layout.getLayoutParams();
layoutParams.removeRule(RelativeLayout.ALIGN_PARENT_BOTTOM);
layoutParams.addRule(RelativeLayout.ALIGN_PARENT_TOP);
layout.setLayoutParams(layoutParams);
}
private void showBottom(){
RelativeLayout.LayoutParams layoutParams = (RelativeLayout.LayoutParams) layout.getLayoutParams();
layoutParams.removeRule(RelativeLayout.ALIGN_PARENT_TOP);
layoutParams.addRule(RelativeLayout.ALIGN_PARENT_BOTTOM);
layout.setLayoutParams(layoutParams);
}