0

这是我想要做的,

    SpannableString s = new SpannableString("Shiva");
    s.setSpan(new RelativeSizeSpan(2f), 0, 5, Spannable.SPAN_EXCLUSIVE_EXCLUSIVE);
    editText.setText(s, TextView.BufferType.SPANNABLE);

在 Click 事件中,我试图通过此代码将其转换为 HTML

    Log.d("SampleApp",Html.toHtml(editText.getText()));

我期待一些

 <h1> or <h2> tag

但我看到的是这个

<p dir=ltr>Shiva</p>

如果可以的话,请帮助我。

4

2 回答 2

0

另一种方法是使用 AbsoluteSizeSpan.class
s.setSpan(new AbsoluteSizeSpan(14), 0, 5, Spannable.SPAN_EXCLUSIVE_EXCLUSIVE);
这将返回类似: <font size ="2">Shiva</font>

于 2014-03-30T13:54:02.603 回答
0

Html.toHtml 将返回<p><div>标记中的内容,

你看过 Html.toHtml 的源代码吗?

检查以下代码,我从最新的 Android 4.3 版本中提取了该代码。你可以看到 toHtml 函数调用 insideHtml 和 insideHtml 函数只是将 div 放在 span 周围并设置 align 属性。

public static String toHtml(Spanned text) {
        StringBuilder out = new StringBuilder();
        withinHtml(out, text);
        return out.toString();
    } 

private static void withinHtml(StringBuilder out, Spanned text) {
        int len = text.length();

        int next;
        for (int i = 0; i < text.length(); i = next) {
            next = text.nextSpanTransition(i, len, ParagraphStyle.class);
            ParagraphStyle[] style = text.getSpans(i, next, ParagraphStyle.class);
            String elements = " ";
            boolean needDiv = false;

            for(int j = 0; j < style.length; j++) {
                if (style[j] instanceof AlignmentSpan) {
                    Layout.Alignment align =
                        ((AlignmentSpan) style[j]).getAlignment();
                    needDiv = true;
                    if (align == Layout.Alignment.ALIGN_CENTER) {
                        elements = "align=\"center\" " + elements;
                    } else if (align == Layout.Alignment.ALIGN_OPPOSITE) {
                        elements = "align=\"right\" " + elements;
                    } else {
                        elements = "align=\"left\" " + elements;
                    }
                }
            }
            if (needDiv) {
                out.append("<div ").append(elements).append(">");
            }

            withinDiv(out, text, i, next);

            if (needDiv) {
                out.append("</div>");
            }
        }
    }
于 2013-09-20T06:52:34.487 回答