GirdLayout布局:更改其中的TextView控件的TextSize属性后,出现控件未对齐情况

在使用GridLayout布局并动态调整TextView的TextSize时,出现控件未对齐的问题。排查过程包括检查Margin、TextView Style及GridLayout参数,最终通过调整android:gravity属性在Style中解决问题,避免了使用复杂的方法如设置TextView的上边距。
  • 采用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);







评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值