Android SpannableString在部分文字后面设置背景

发布于 2021-01-30 17:07:36

我想创建类似此图片所示的内容: 在此处输入图片说明

我设法用SpannableStringBuilder创建了Evertyhing,除了橙色的圆角矩形。我可以使用BackgroundColorSpan将背景设置为该颜色,但是我找不到使它变圆的方法。有什么想法可以实现吗?

提前致谢!

编辑:我正在使用Xamarin.Android,但这是我的代码:

stringBuilder.SetSpan(new BackgroundColorSpan(Application.Context.Resources.GetColor(Resource.Color.orangeColor)), stringBuilder.Length() - length, stringBuilder.Length(), SpanTypes.ExclusiveExclusive);
关注者
0
被浏览
313
1 个回答
  • 面试哥
    面试哥 2021-01-30
    为面试而生,有面试问题,就找面试哥。

    如果有人在处理罗斯福的代码示例时遇到困难(我肯定是,也许是因为它是Xamarin.Android?),这是一个更基本的Android Java版本的翻译:

        public class RoundedBackgroundSpan extends ReplacementSpan {
    
            private static int CORNER_RADIUS = 8;
            private int backgroundColor = 0;
            private int textColor = 0;
    
            public RoundedBackgroundSpan(Context context) {
                super();
                backgroundColor = context.getResources().getColor(R.color.gray);
                textColor = context.getResources().getColor(R.color.white);
            }
    
            @Override
            public void draw(Canvas canvas, CharSequence text, int start, int end, float x, int top, int y, int bottom, Paint paint) {
                RectF rect = new RectF(x, top, x + measureText(paint, text, start, end), bottom);
                paint.setColor(backgroundColor);
                canvas.drawRoundRect(rect, CORNER_RADIUS, CORNER_RADIUS, paint);
                paint.setColor(textColor);
                canvas.drawText(text, start, end, x, y, paint);
            }
    
            @Override
            public int getSize(Paint paint, CharSequence text, int start, int end, Paint.FontMetricsInt fm) {
                return Math.round(paint.measureText(text, start, end));
            }
    
            private float measureText(Paint paint, CharSequence text, int start, int end) {
                return paint.measureText(text, start, end);
            }
        }
    

    为了便于使用,以下代码段取自Activity,基本上在每个标签字符串周围放置了一个圆角背景,每个标签之间都有一个空格缓冲区。请注意,注释掉的行仅带有背景色,看起来效果不佳。

    
        SpannableStringBuilder stringBuilder = new SpannableStringBuilder();
    
        String between = "";
        for (String tag : eventListing.getTags()) {
           stringBuilder.append(between);
           if (between.length() == 0) between = "  ";
           String thisTag = "  "+tag+"  ";
           stringBuilder.append(thisTag);
           stringBuilder.setSpan(new RoundedBackgroundSpan(this), stringBuilder.length() - thisTag.length(), stringBuilder.length() - thisTag.length() + thisTag.length(), Spanned.SPAN_EXCLUSIVE_EXCLUSIVE);
           //stringBuilder.setSpan(new BackgroundColorSpan(getResources().getColor(R.color.gray)), stringBuilder.length() - thisTag.length(), stringBuilder.length(), Spanned.SPAN_EXCLUSIVE_EXCLUSIVE);
        }
    
        TextView tv = new TextView(this);
        tv.setText(stringBuilder);
    


  • 面试哥
    面试哥 2021-01-30
    为面试而生,有面试问题,就找面试哥。

    根据pskink的建议,我设法解决了我的问题。这是我的课:

    public class RoundedBackgroundSpan : ReplacementSpan
    {
        public override void Draw(Canvas canvas, ICharSequence text, int start, int end, float x, int top, int y, int bottom, Paint paint)
        {
            var rect = new RectF(x, top, x + MeasureText(paint, text, start, end), bottom);
            paint.Color = Application.Context.Resources.GetColor(Resource.Color.nextTimeBackgroundColor);
            canvas.DrawRoundRect(rect, Application.Context.Resources.GetDimensionPixelSize(Resource.Dimension.localRouteDetailsRoundRectValue), Application.Context.Resources.GetDimensionPixelSize(Resource.Dimension.localRouteDetailsRoundRectValue), paint);
            paint.Color = Application.Context.Resources.GetColor(Resource.Color.nextTimeTextColor);
            canvas.DrawText(text, start, end, x, y, paint);
        }
    
        public override int GetSize(Paint paint, ICharSequence text, int start, int end, Paint.FontMetricsInt fm)
        {
            return Math.Round(MeasureText(paint, text, start, end));
        }
    
        private float MeasureText(Paint paint, ICharSequence text, int start, int end)
        {
            return paint.MeasureText(text, start, end);
        }
    }
    

    用法示例:

    var stringBuilder = new SpannableStringBuilder();
    var stringToAppend = "hello world";
    stringBuilder.Append(stringToAppend);
    stringBuilder.SetSpan(new RoundedBackgroundSpan(), stringBuilder.Length() - stringToAppend.Length, stringBuilder.Length(), SpanTypes.ExclusiveExclusive);
    


知识点
面圈网VIP题库

面圈网VIP题库全新上线,海量真题题库资源。 90大类考试,超10万份考试真题开放下载啦

去下载看看