37

私のIMアプリは絵文字をサポートする必要があります。これらはGIFであり、テキスト表現があり、ユーザーがそれらの1つを選択した場合に入力ボックスで使用されます。しかし、送信後に画像として表示したいのですが、現在、カスタム配列アダプターは送信されたメッセージを行のTextViewに表示します。

テキスト表現の出現に基づいて画像を動的に表示する適切な方法は何ですか?絵文字テキストを検索する必要がありますか?見つかった場合は、レイアウトからTextViewを削除し(relativeLayoutが最も適していますか?)、IMの先頭にTextViewを追加し、絵文字を含むImageViewと別のTextViewを追加します。より多くの絵文字が同時に送信されると、面倒になる可能性があります。

より簡単で論理的な方法はありますか?

4

2 に答える 2

122

を構築する方が便利だと思いますSpannable

private static final Factory spannableFactory = Spannable.Factory
        .getInstance();

private static final Map<Pattern, Integer> emoticons = new HashMap<Pattern, Integer>();

static {
    addPattern(emoticons, ":)", R.drawable.emo_im_happy);
    addPattern(emoticons, ":-)", R.drawable.emo_im_happy);
    // ...
}

private static void addPattern(Map<Pattern, Integer> map, String smile,
        int resource) {
    map.put(Pattern.compile(Pattern.quote(smile)), resource);
}

public static boolean addSmiles(Context context, Spannable spannable) {
    boolean hasChanges = false;
    for (Entry<Pattern, Integer> entry : emoticons.entrySet()) {
        Matcher matcher = entry.getKey().matcher(spannable);
        while (matcher.find()) {
            boolean set = true;
            for (ImageSpan span : spannable.getSpans(matcher.start(),
                    matcher.end(), ImageSpan.class))
                if (spannable.getSpanStart(span) >= matcher.start()
                        && spannable.getSpanEnd(span) <= matcher.end())
                    spannable.removeSpan(span);
                else {
                    set = false;
                    break;
                }
            if (set) {
                hasChanges = true;
                spannable.setSpan(new ImageSpan(context, entry.getValue()),
                        matcher.start(), matcher.end(),
                        Spannable.SPAN_EXCLUSIVE_EXCLUSIVE);
            }
        }
    }
    return hasChanges;
}

public static Spannable getSmiledText(Context context, CharSequence text) {
    Spannable spannable = spannableFactory.newSpannable(text);
    addSmiles(context, spannable);
    return spannable;
}

Html実際、このコードはネイティブクラスのソースに基づいています。

編集:更新されたバージョンでは、速度が大幅に向上しています。

于 2010-11-29T09:04:39.053 に答える
39

<img>正規表現を使用して、各絵文字のすべての出現箇所をタグに置き換えてみます。SpannedString 次に、そのHTMLをviaHtml.fromHtml()に変換します。これは、の呼び出しでSpannedString使用できます。setText()TextView

于 2010-07-27T08:14:50.563 に答える