TextView图文混排,设置部分字体背景色

          效果图如下:

                     

             一。实现方式

             android对于TextView的图文混排有好几种方式,我采用的是textview加载html标签的方式实现,在实现的过程中,遇到了比较多的问题,具体的问题是,在使用html的font

标签时,发现不可以设置它的背景颜色,只能设置颜色和一些字体的样式,查阅一些资料,发现BackgroundColorSpan这个类可以设置部分字体的背景色,具体api使用如下:


Spannable wordtoSpan = new SpannableString(text);

 wordtoSpan.setSpan(new BackgroundColorSpan(Color.RED), 0, reward.length(), Spannable.SPAN_EXCLUSIVE_EXCLUSIVE);

刚开始要创建Spannbale对象,然后在给这个对象设置一个字体背景颜色的对象,具体的传入参数是,字体颜色,需要改变的文字的字体的起始长度,通过这种方式就可以为textview部分字体设置背景颜色。


           二。具体图文混排代码如下:

          

String html="<font color = \"#ffffff\">" + (price > 0 ? reward : "");
        if (data.isHas_image()){
            html = html + "</font>  " + "<img src=‘strawberry’>" + "  <font>" + data.getKeyword() + "</font>";
        }else {
            html = html + "</font>  " +  "<font>" + data.getKeyword() + "</font>";
        }
 CharSequence text= Html.fromHtml(html, new Html.ImageGetter() {

            public Drawable getDrawable(String source) {
                //根据图片资源ID获取图片
                if(source.equals("‘strawberry’")){
                    Drawable draw=mContext.getResources().getDrawable(R.mipmap.figure);
                    draw.setBounds(0, 0, draw.getIntrinsicWidth(), draw.getIntrinsicHeight());
                    return draw;
                }
                return null;
            }
        }, null);


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值