- 采用GridLayout布局,子控件为TextView,在使用过程中,由于数据都是从数据库中读取出来的,所以在TextView中显示的文字长度不同,造成字数过多时字会换行或溢出,那么,根据这个情况,针对字数的多少进行更改TextSize的处理
- 在处理完字体大小之后,发现TextView在GridLayout中出现未对齐的情况(TextView长宽一定下,水平未对齐)
- 怀疑与Margin有关,进行调试发现值相同,排除
- 怀疑与TextView的Style有关,将使用该Style的两个TextView放入水平线性布局,更改TextSize后为对齐的,排除
- 怀疑与GridLayout布局参数有关,一共就几个参数,依次进行试验,排除
- 打算放弃,便找替代方案,为TextView设置上边距(padding),该方法可行,但是比较麻烦,还得换算具体的数值
- 此时,发现Style中有个东西比较可疑:
<item name="android:layout_gravity">fill_horizontal</item>
- 查找api,找到:
| top | 将对象放在其容器的顶部,不改变其大小. |
| bottom | 将对象放在其容器的底部,不改变其大小. |
| left | 将对象放在其容器的左侧,不改变其大小. |
| right | 将对象放在其容器的右侧,不改变其大小. |
| center_vertical | 将对象纵向居中,不改变其大小. 垂直对齐方式:垂直方向上居中对齐。 |
| fill_vertical | 必要的时候增加对象的纵向大小,以完全充满其容器. 垂直方向填充 |
| center_horizontal | 将对象横向居中,不改变其大小. 水平对齐方式:水平方向上居中对齐 |
| fill_horizontal | 必要的时候增加对象的横向大小,以完全充满其容器. 水平方向填充 |
| center | 将对象横纵居中,不改变其大小. |
| fill | 必要的时候增加对象的横纵向大小,以完全充满其容器. |
| clip_vertical | 附加选项,用于按照容器的边来剪切对象的顶部和/或底部的内容. 剪切基于其纵向对齐设置:顶部对齐时,剪切底部;底部对齐时剪切顶部;除此之外剪切顶部和底部. 垂直方向裁剪 |
| clip_horizontal | 附加选项,用于按照容器的边来剪切对象的左侧和/或右侧的内容. 剪切基于其横向对齐设置:左侧对齐时,剪切右侧;右侧对齐时剪切左侧;除此之外剪切左侧和右侧. 水平方向裁剪 |
- 调整代码进行尝试:
LayoutParams params = (LayoutParams)tView.getLayoutParams();
params.setGravity(Gravity.CENTER|Gravity.FILL_HORIZONTAL);
tView.setLayoutParams(params);
- 至此,调试6个小时的对齐问题解决。
- 原文地址:http://blog.csdn.net/yueritian/article/details/46511111
在使用GridLayout布局并动态调整TextView的TextSize时,出现控件未对齐的问题。排查过程包括检查Margin、TextView Style及GridLayout参数,最终通过调整android:gravity属性在Style中解决问题,避免了使用复杂的方法如设置TextView的上边距。
253

被折叠的 条评论
为什么被折叠?



