1

我想要一个自定义 Spannable,如下图所示:

在此处输入图像描述

我想在不正确的单词下创建一条锯齿线。

我能怎么做?

4

1 回答 1

0

你肯定想对我一起破解的这个实现做一些检查。但还是。希望它仍然能够为正确实现此类功能提供一些基础。

实际的跨度类,令人惊讶的是,它并没有取代任何东西。只希望在给定两行代码的情况下,真的可以按原样绘制原始跨度文本。Plus 还绘制了“下划线”。

private class ErrorSpan extends ReplacementSpan {

    private Paint errorPaint;

    public ErrorSpan() {
        errorPaint = new Paint();
        errorPaint.setColor(Color.RED);
    }

    @Override
    public int getSize(Paint paint, CharSequence text, int start, int end,
            FontMetricsInt fm) {
        return (int)paint.measureText(text, start, end);
    }

    @Override
    public void draw(Canvas canvas, CharSequence text, int start, int end,
            float x, int top, int y, int bottom, Paint paint) {
        // Render the red zigzag lines below text
        float width = paint.measureText(text, start, end);
        canvas.save();
        canvas.clipRect(x, bottom - 5, x + width, bottom);
        for (float lineX = x; lineX < x + width; lineX += 10) {
            canvas.drawLine(lineX, bottom - 5, lineX + 5, bottom, errorPaint);
            canvas.drawLine(lineX + 5, bottom, lineX + 10, bottom - 5, errorPaint);
        }
        canvas.restore();
        // Render the span text as-is
        canvas.drawText(text, start, end, x, y, paint);
    }    
};

请原谅我在画线循环中使用幻数(这很可能也更有效) - 但希望它能够为最终创建生产质量实施提供足够好的基础。

用法会在某个地方:

TextView tv = (TextView)findViewById(R.id.textview);
Spannable spannable = Spannable.Factory.getInstance()
                         .newSpannable("testtest\ntesttest");
spannable.setSpan(new ErrorSpan(), 4, 8, 0);
spannable.setSpan(new ErrorSpan(), 9, 13, 0);
tv.setText(spannable);
于 2014-06-07T20:30:41.733 回答