基于RelativeLayout实现自动换行标签控件

在开发中,我们有时会遇到显示标签的功能。比如做社交app,用户有标签;做电商app,商品也同样有标签......显示标签时,我们需要一次展示出多个标签,但是单个标签的字数可能不同,当一行不足以容纳时,需要换行显示。系统自带控件无法实现该效果,所以我们需要自定义控件来解决。

实现效果如下:


关于自动换行,有多种实现方式,这里基于RelativeLayout来实现。

实现思路:


有了思路,下面进入代码实现环节。

首先,我们自定义TagLayout继承自RelativeLayout。
public class TagLayout extends RelativeLayout {
}

判断单行空间是否够用,需要用到TagLayout的宽度,我们在onSizeChanged()方法中获取。
private int mWidth;

@Override
protected void onSizeChanged(int w, int h, int oldw, int oldh) {
    mWidth = w;
}

在RelativeLayout中,动态设置child的位置,需要使用到它的addRule()方法。
/**
 * Adds a layout rule to be interpreted by the RelativeLayout. Use this for
 * verbs that take a target, such as a sibling (ALIGN_RIGHT) or a boolean
 * value (VISIBLE).
 *
 * @param verb One of the verbs defined by
 *        {@link android.widget.RelativeLayout RelativeLayout}, such as
 *         ALIGN_WITH_PARENT_LEFT.
 * @param anchor The id of another view to use as an anchor,
 *      
  • 2
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值