TextView设置图片标签

在项目中,我们经常会碰到需要在TextView前面添加图片标签的需求,如果是文本一行就能显示的话,我们一般会使用TextView的setCompoundDrawables方法:

drawable.setBounds(0, 0, drawable.getIntrinsicWidth(), (drawable.getMinimumHeight()));
            v.setCompoundDrawables(drawable, null, null, null);
            textView.setCompoundDrawablePadding(6);

效果图:
在这里插入图片描述
但是,如果是TextView内容有多行,效果呢?
在这里插入图片描述
居然不是我们想要的样子?

class VipTagSpan(context: Context, drawable: Int, charSequence: CharSequence) : ImageSpan(context, drawable, DynamicDrawableSpan.ALIGN_BOTTOM) {

    private val spannableString: SpannableString = SpannableString("[ $charSequence").apply {
        setSpan(this@VipTagSpan, 0, 1, Spannable.SPAN_EXCLUSIVE_EXCLUSIVE)
    }

    override fun draw(
        canvas: Canvas,
        text: CharSequence,
        start: Int,
        end: Int,
        x: Float,
        top: Int,
        y: Int,
        bottom: Int,
        paint: Paint
    ) {
        canvas.save()
        val transY = ((bottom - top) - drawable.bounds.bottom) / 2 + top + 2
        canvas.translate(x, transY.toFloat())
        drawable.draw(canvas)
        canvas.restore()
    }

    fun getSpan(): SpannableString {
        return spannableString
    }
}

使用:

textView.text = VipTagSpan(
                        textView.context,
                        R.mipmap.image_paidcontent_article,
                        textView.text).getSpan()

在这里插入图片描述

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值