0

これが私がやろうとしていることです、

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

そしてクリックイベントで、このコードでHTMLに変換しようとしています

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

私はいくつかを期待しています

 <h1> or <h2> tag

しかし、私が見ているのはこれです

<p dir=ltr>Shiva</p>

できれば、私を助けてください。

4

2 に答える 2

0

Html.toHtml は、<p>または<div>タグ内のコンテンツを返します。

Html.toHtml のソースコードを見ましたか?

次のコードを確認してください。最新の Android 4.3 ビルドからそのコードを取得しました。toHtml 関数呼び出し withinHtml および withinHtml 関数は、スパンの周りに div を配置し、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 に答える
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 に答える