Android同一个TextView实现图文混排,部分文字可点击

前言----功能出现的原因


项目新功能,设计图如下:

这里由于文字换行的时候是跟第一行对左对齐的 ,所以这里考虑两个TextView 去实现,显示是不容易符合预期的,那么我们就要考虑只能用一个TextView去实现了,一个TextView如果只是做到部分文字变色的话,那实现起来也很容易,我们只需要使用SpannableString就可以了,但是这里产品需求是要给变色的文字添加点击事件,并且还有如下图需求,在姓名后面有时还需要添加图标,这样的话就需要我们对SpannableString添加一些Span的设置了,具体实现如下

 

 


这里我们添加点击事件用的是ClickableSpan,而添加图片则是实用ImageSpan,具体实现如下:
首先我们先自定义一个ClickableSpan类
 

public class MyClickSpan extends ClickableSpan {
    private int mHighLightColor = Color.parseColor("#3466B1");
    private View.OnClickListener mClickListener;

    public MyClickSpan(View.OnClickListener listener) {
        this.mClickListener = listener;
    }

    @Override
    public void onClick(View widget) {
        if (mClickListener != null)
            mClickListener.onClick(widget);
    }

    @Override
    public void updateDrawState(TextPaint ds) {
        ds.setColor(mHighLightColor);
    }
}



然后就是new 一个ImageSpan出来

Drawable drawable = getContext().getResources().getDrawable(R.drawable.mkz_comment_list_author);
drawable.setBounds(0, 0, drawable.getIntrinsicWidth(), drawable.getIntrinsicHeight());
ImageSpan span = new ImageSpan(drawable, ImageSpan.ALIGN_CENTER);

最后就是对SpannableString 进行设置,完整的代码逻辑如下

public void setTextHighLightWithClick(CommentBean comment, FaceTextView tv, String text, String keyWord,
                                          View.OnClickListener listener) {
        Html.ImageGetter faceImageGetter = new FaceImageGetter(Glide.with(getContext()), tv);
        Spanned spanned = Html.fromHtml(FaceUtils.getInstance().replaceHtml(text), faceImageGetter, null);
        tv.setClickable(true);
        tv.setHighlightColor(Color.TRANSPARENT);
        tv.setMovementMethod(LinkMovementMethod.getInstance());
        SpannableString s = new SpannableString(spanned);
        if (comment.isAuthor()) {
            Drawable drawable = getContext().getResources().getDrawable(R.drawable.mkz_comment_list_author);
            drawable.setBounds(0, 0, drawable.getIntrinsicWidth(), drawable.getIntrinsicHeight());
            ImageSpan span = new ImageSpan(drawable, ImageSpan.ALIGN_CENTER);
            s.setSpan(span, keyWord.length(), keyWord.length() + place.length(), Spannable.SPAN_INCLUSIVE_EXCLUSIVE);
        }

        Pattern p = Pattern.compile(keyWord);
        Matcher m = p.matcher(s);
        while (m.find()) {
            int start = m.start();
            int end = m.end();
            s.setSpan(new MyClickSpan(listener), start, end, Spanned.SPAN_EXCLUSIVE_EXCLUSIVE);
        }
        tv.setText(s);
    }


这样就能实现,设计中所需要的功能了

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值