TextView文字图片混排并添加点击事件监听,Textview里面的ImageSpan添加点击响应事件

该文章介绍了如何在Android的TextView中实现文字和图片的混合排列,并添加点击事件监听。通过使用SpannableString、ImageSpan和ClickableSpan,可以创建一个在文字末尾添加图片且图片可点击的TextView。关键步骤包括设置ImageSpan、ClickableSpan以及使用LinkMovementMethod使点击生效,并去除高亮效果。
摘要由CSDN通过智能技术生成
TextView tv = findViewById(R.id.tv);

String str = "这个一个文字图片混排,文字结尾添加图片";

SpannableString ss = new SpannableString(str + " ");
int len = ss.length();
//图片,更换成自己工程里的图片
Drawable d = ContextCompat.getDrawable(this, (R.mipmap.icon_arror_expand));
d.setBounds(0, 0, d.getIntrinsicWidth(), d.getIntrinsicHeight());
//构建ImageSpan
ImageSpan span = new ImageSpan(d, ImageSpan.ALIGN_BASELINE);
ss.setSpan(span, len - 1, len, Spannable.SPAN_INCLUSIVE_EXCLUSIVE);
ss.setSpan(new ClickableSpan() {
    @Override
    public void onClick(@NonNull View widget) {
        Log.e(TAG,"textView图片点击------");
        runOnUiThread(new Runnable() {
            @Override
            public void run() {
                Toast.makeText(getBaseContext(),"图片点击", Toast.LENGTH_SHORT).show();
            }
        });
    }
}, len - 1, len, Spannable.SPAN_INCLUSIVE_EXCLUSIVE);
tv.setText(ss);
//需要设置这个才能点击
tv.setMovementMethod(LinkMovementMethod.getInstance());
//去掉高亮,不然点击时候背景会变高亮
tv.setHighlightColor(getResources().getColor(android.R.color.transparent));

注意:

1.这里使用空格来替代图片。当然也可以使用其他的字符(比如说文件的路径)来代替,只要长度别太长就可以。

2.ImageSpan和ClickableSpan的start和end要一致

3.tv.setMovementMethod(LinkMovementMethod.getInstance());这个一定要设置

4.最好使用Spannable.SPAN_INCLUSIVE_EXCLUSIVE。配合删除和添加,这个最好用

5.也可以根据源码,去自定义。提供一篇文章:Android自定义可点击的ImageSpan并在TextView中内置View - 码农教程

参考:TextView文字图片混排并添加点击事件监听,Textview里面的ImageSpan添加点击响应事件_textview 图片 点击_yayayaiii的博客-CSDN博客

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值