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

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

作者: 迷途小顽童 | 来源:发表于2021-06-18 15:51 被阅读0次

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

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


image.png

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

image.png

这里我们添加点击事件用的是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);
    }

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

相关文章

网友评论

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

      本文链接:https://www.haomeiwen.com/subject/deokyltx.html