首页
学习
活动
专区
工具
TVP
发布
社区首页 >问答首页 >如何在TextView文本中添加图片?

如何在TextView文本中添加图片?
EN

Stack Overflow用户
提问于 2013-03-12 10:55:29
回答 8查看 182.7K关注 0票数 92

我在谷歌上到处搜索,发现了一个类似于我的问题,即如何在TextView文本中包含图像,例如“你好,我的名字是图像”,答案是这样的:

代码语言:javascript
复制
ImageSpan is = new ImageSpan(context, resId);
text.setSpan(is, index, index + strLength, 0);

我想知道在这段代码中,

  1. 我应该在上下文中键入或执行什么操作?
  2. 我是否应该对text.setSpan()执行某些操作,如导入或引用,或者将其保留为文本?

如果有人能帮我分解一下,那就太感谢了。

EN

回答 8

Stack Overflow用户

回答已采纳

发布于 2013-03-12 11:19:02

试试这个..。

代码语言:javascript
复制
    txtview.setCompoundDrawablesWithIntrinsicBounds(
                    R.drawable.image, 0, 0, 0);

另请看这个。http://developer.android.com/reference/android/widget/TextView.html

在xml文件中尝试此操作

代码语言:javascript
复制
    <TextView
        android:id="@+id/txtStatus"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_gravity="center"
        android:drawableLeft="@drawable/image"
        android:drawablePadding="5dp"
        android:maxLines="1"
        android:text="@string/name"/>
票数 209
EN

Stack Overflow用户

发布于 2014-01-21 14:27:39

com/xyz/customandroid/ TextViewWithImages .java

代码语言:javascript
复制
import java.util.regex.Matcher;
import java.util.regex.Pattern;

import android.content.Context;
import android.text.Spannable;
import android.text.style.ImageSpan;
import android.util.AttributeSet;
import android.util.Log;
import android.widget.TextView;

public class TextViewWithImages extends TextView {

    public TextViewWithImages(Context context, AttributeSet attrs, int defStyle) {
        super(context, attrs, defStyle);
    }
    public TextViewWithImages(Context context, AttributeSet attrs) {
        super(context, attrs);
    }
    public TextViewWithImages(Context context) {
        super(context);
    }
    @Override
    public void setText(CharSequence text, BufferType type) {
        Spannable s = getTextWithImages(getContext(), text);
        super.setText(s, BufferType.SPANNABLE);
    }

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

    private static boolean addImages(Context context, Spannable spannable) {
        Pattern refImg = Pattern.compile("\\Q[img src=\\E([a-zA-Z0-9_]+?)\\Q/]\\E");
        boolean hasChanges = false;

        Matcher matcher = refImg.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;
            }
        }
        String resname = spannable.subSequence(matcher.start(1), matcher.end(1)).toString().trim();
        int id = context.getResources().getIdentifier(resname, "drawable", context.getPackageName());
        if (set) {
            hasChanges = true;
            spannable.setSpan(  new ImageSpan(context, id),
                                matcher.start(),
                                matcher.end(),
                                Spannable.SPAN_EXCLUSIVE_EXCLUSIVE
                             );
        }
    }

        return hasChanges;
    }
    private static Spannable getTextWithImages(Context context, CharSequence text) {
        Spannable spannable = spannableFactory.newSpannable(text);
        addImages(context, spannable);
        return spannable;
    }
}

使用:

在res/layout/mylayout.xml中

代码语言:javascript
复制
            <com.xyz.customandroid.TextViewWithImages
                android:layout_width="wrap_content"
                android:layout_height="wrap_content"
                android:textColor="#FFFFFF00"
                android:text="@string/can_try_again"
                android:textSize="12dip"
                style=...
                />

请注意,如果将TextViewWithImages.java放在com/xyz/customandroid/以外的某个位置,还必须更改包名称com.xyz.customandroid

在res/values/strings.xml s.xml中

代码语言:javascript
复制
<string name="can_try_again">Press [img src=ok16/] to accept or [img src=retry16/] to retry</string>

其中ok16.png和retry16.png是res/drawable/文件夹中的图标

票数 79
EN

Stack Overflow用户

发布于 2017-06-28 18:19:12

我尝试了许多不同的解决方案,这对我来说是最好的:

代码语言:javascript
复制
SpannableStringBuilder ssb = new SpannableStringBuilder(" Hello world!");
ssb.setSpan(new ImageSpan(context, R.drawable.image), 0, 1, Spannable.SPAN_INCLUSIVE_INCLUSIVE);
tv_text.setText(ssb, TextView.BufferType.SPANNABLE);

这段代码使用的内存最少。

票数 24
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/15352496

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档