在Android TextView中顯示圖片的4種方式詳解
我們知道,TextView控件一般是用來顯示文本的,而圖片一般是用ImageView控件來顯示。
那TextView能否顯示圖片呢?答案是肯定的!下面列出常見的4種方式。
1、XML文件中指定屬性值
這種方式應(yīng)該是最常用的了,在TextView的左上右下顯示圖片,可用
android:drawableLeft
android:drawableTop
android:drawableRight
android:drawableBottom
比如我們要在TextView的頂部設(shè)置圖片,代碼如下:
<TextView android:id="@+id/textview_01" android:layout_width="wrap_content" android:layout_height="wrap_content" android:drawableTop="@drawable/ic_launcher" android:text="hello_world" />
這種顯示方式圖片跟文本是居中對(duì)齊的,此種方式對(duì)應(yīng)的方法是setCompoundDrawablesWithIntrinsicBounds:
mTextView01.setCompoundDrawablesWithIntrinsicBounds(null,
getResources().getDrawable(R.drawable.ic_launcher, null), null, null);
效果圖:

如果覺得圖片離文字太近,也可以設(shè)置他們之間的間距,xml或者代碼中都可以實(shí)現(xiàn):
android:drawablePadding="10dp"
或者
mTextView01.setCompoundDrawablePadding(10);
2、通過解析HTML來顯示圖片
這種方式可以顯示項(xiàng)目中的圖片、本地SDCARD和網(wǎng)絡(luò)的圖片,當(dāng)然網(wǎng)絡(luò)的圖片必須先下載到本地然后顯示。
顯示項(xiàng)目中圖片
看代碼
// 第二種方式:顯示項(xiàng)目中的圖片mTextView02 = (TextView) findViewById(R.id.textview_02);// 把圖片生成的ID加入img標(biāo)簽中 <img src='123'>String htmlFor02 = "項(xiàng)目圖片測(cè)試:" + "<img src='" + R.drawable.ic_launcher + "'>" + "<img src='"
+ R.drawable.apple + "'>";
mTextView02.setText(Html.fromHtml(htmlFor02, new Html.ImageGetter() {
@Override public Drawable getDrawable(String source) { Log.d(TAG, "項(xiàng)目圖片測(cè)試_source:" + source);
int id = Integer.parseInt(source);
Drawable drawable = getResources().getDrawable(id, null);
drawable.setBounds(0, 0, drawable.getIntrinsicWidth() ,
drawable.getIntrinsicHeight()); return drawable;
}
}, null));
可以看到,ic_launcher和apple這兩張圖片的ID是加到了img標(biāo)簽中,然后通過實(shí)現(xiàn)html的ImageGetter接口中的getDrawable()方法取得圖片。
效果圖如下:

獲取網(wǎng)絡(luò)圖片
為了簡(jiǎn)化代碼,我們用到了google的volley網(wǎng)絡(luò)框架去請(qǐng)求圖片,然后保存到sdcard再顯示,這種方式略顯麻煩,看代碼:
private static final String htmlFor03 = "網(wǎng)絡(luò)圖片測(cè)試:"
+ "<img src='http://img1.imgtn.bdimg.com/it/u=4190601239,967361436&fm=11&gp=0.jpg'>";private static final String NET_PIC_NAME = "NetPic.png";// 第二種方式:顯示網(wǎng)絡(luò)圖片mTextView03 = (TextView) findViewById(R.id.textview_03);
mTextView03.setText(Html.fromHtml(htmlFor03, mNetWorkImageGetter, null));private NetWorkImageGetter mNetWorkImageGetter = new NetWorkImageGetter();
class NetWorkImageGetter implements Html.ImageGetter { /*
* (non-Javadoc)
* @see android.text.Html.ImageGetter#getDrawable(java.lang.String)
*/
@Override
public Drawable getDrawable(String source) {
Drawable drawable = null;
File file = new File(Environment.getExternalStorageDirectory(), NET_PIC_NAME); if (file.exists()) {
drawable = Drawable.createFromPath(file.getAbsolutePath());
drawable.setBounds(0, 0, drawable.getIntrinsicWidth() * 2,
drawable.getIntrinsicHeight() * 2);
} else {
getNetworkImg(source);
} return drawable;
}
}/**
* 通過volley請(qǐng)求網(wǎng)絡(luò)圖片
* @param url
*/private void getNetworkImg(String url) {
Log.d(TAG, "url: " + url);
RequestQueue queue = Volley.newRequestQueue(this);
ImageRequest request = new ImageRequest(url, new Response.Listener<Bitmap>() { @Override
public void onResponse(Bitmap bitmap) {
Log.d(TAG, "onResponse");
saveMyBitmap(NET_PIC_NAME, bitmap);
mTextView03.setText(Html.fromHtml(htmlFor03, mNetWorkImageGetter, null));
}
}, 0, 0, ScaleType.CENTER, Config.RGB_565, new ErrorListener() { @Override
public void onErrorResponse(VolleyError error) {
Log.d(TAG, "onErrorResponse:" + error);
}
});
queue.add(request);
}/**
* 保存獲取到的網(wǎng)絡(luò)圖片到sdcard
* @param bitName
* @param mBitmap
*/public void saveMyBitmap(String bitName, Bitmap mBitmap) {
File f = new File("/sdcard/" + bitName); try {
f.createNewFile();
} catch (IOException e) {
}
FileOutputStream fOut = null; try {
fOut = new FileOutputStream(f);
} catch (FileNotFoundException e) {
e.printStackTrace();
}
mBitmap.compress(Bitmap.CompressFormat.PNG, 100, fOut); try {
fOut.flush();
} catch (IOException e) {
e.printStackTrace();
} try {
fOut.close();
} catch (IOException e) {
e.printStackTrace();
}
}
代碼比較多,弄明白流程就行,先從本地找–>沒找到的話通過網(wǎng)絡(luò)下載并保存到本地–>顯示本地圖片。
效果圖如下:

3、通過ImageSpan和SpannableString
這種方式很簡(jiǎn)單,通過新建ImageSpan對(duì)象得到圖片,然后作為參數(shù)傳入SpannableString的setSpan方法中即可??创a:
// 第三種方式
mTextView04 = (TextView) findViewById(R.id.textview_04);ImageSpan imgSpan = new ImageSpan(this, R.drawable.apple);SpannableString spannableString = new SpannableString("012345");spannableString.setSpan(imgSpan, 1, 5, Spannable.SPAN_EXCLUSIVE_EXCLUSIVE);mTextView04.setText(spannableString);
注意:setSpan(Object what, int start, int end, int flags)方法中的start和end值是用圖片來取代的文本范圍,flags是用來標(biāo)識(shí)在 Span 范圍內(nèi)的文本前后輸入新的字符時(shí)是否把它們也應(yīng)用這個(gè)效果。
效果圖:

4、通過繼承TextView方式
這種方式的原理是通過繼承TextView,并重寫onDraw(),讓圖片直接畫到文本上,這會(huì)導(dǎo)致圖片跟文本重疊,它們之間的間距不好控制。
public class MyTextView extends TextView {
private Bitmap mBitmap; /**
* @param context
* @param attrs
*/
public MyTextView(Context context, AttributeSet attrs) { super(context, attrs);
mBitmap = BitmapFactory.decodeResource(context.getResources(), R.drawable.apple);
setTextSize(40);
} @Override
protected void onDraw(Canvas canvas) {
canvas.drawBitmap(mBitmap, 0, 0, getPaint()); super.onDraw(canvas);
}
}
然后在xml文件中引用自定義控件:
<com.example.imageintextview.MyTextViewandroid:layout_width="wrap_content"android:layout_height="wrap_content"android:layout_marginTop="20dp"android:text="@string/hello_world" />
效果圖:

以上就是在Android TextView中顯示圖片的4種方式,每種方式都是自己的應(yīng)用場(chǎng)景,大家根據(jù)自己的情況選擇正確的方式
- Android文本視圖TextView實(shí)現(xiàn)跑馬燈效果
- Android文本視圖TextView實(shí)現(xiàn)聊天室效果
- Android使用TypeFace設(shè)置TextView的文字字體
- Flutter中嵌入Android 原生TextView實(shí)例教程
- android使用TextView實(shí)現(xiàn)跑馬燈效果
- Android開發(fā)實(shí)現(xiàn)TextView超鏈接5種方式源碼實(shí)例
- android TextView中識(shí)別多個(gè)url并分別點(diǎn)擊跳轉(zhuǎn)方法詳解
- Android開發(fā)中TextView各種常見使用方法小結(jié)
- Android開發(fā)之TextView使用intent傳遞信息,實(shí)現(xiàn)注冊(cè)界面功能示例
- Android使用AutoCompleteTextView實(shí)現(xiàn)自動(dòng)填充功能的案例
- Android為textView設(shè)置setText的時(shí)候報(bào)錯(cuò)的講解方案
- 詳解Android TextView屬性ellipsize多行失效的解決思路
- Android實(shí)現(xiàn)梯形TextView效果
相關(guān)文章
Android Studio自動(dòng)提取控件Style樣式教程
這篇文章主要介紹了Android Studio自動(dòng)提取控件Style樣式教程,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧2020-03-03
Android基于廣播事件機(jī)制實(shí)現(xiàn)簡(jiǎn)單定時(shí)提醒功能代碼
這篇文章主要介紹了Android基于廣播事件機(jī)制實(shí)現(xiàn)簡(jiǎn)單定時(shí)提醒功能代碼,較為詳細(xì)的分析了Android廣播事件機(jī)制及提醒功能的相關(guān)實(shí)現(xiàn)技巧,具有一定參考借鑒價(jià)值,需要的朋友可以參考下2015-10-10
android開發(fā)環(huán)境遇到adt無(wú)法啟動(dòng)的問題分析及解決方法
開始研究android開發(fā),搭建開發(fā)環(huán)境的時(shí)候就出了問題,真是束手無(wú)策2013-02-02
Android用PopupWindow實(shí)現(xiàn)自定義overflow
這篇文章主要介紹了Android用PopupWindow實(shí)現(xiàn)自定義overflow的相關(guān)資料,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2016-11-11
android studio與手機(jī)連接調(diào)試步驟詳解
這篇文章主要為大家詳細(xì)介紹了android studio與手機(jī)連接調(diào)試步驟,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2018-07-07
android開發(fā)教程之文本框加滾動(dòng)條scrollview
EditText與TextView加上滾動(dòng)條其實(shí)很簡(jiǎn)單,只需要在文本輸入框或者文本顯示框上面加上滾動(dòng)條控件即可2014-02-02
Android使用URLConnection提交請(qǐng)求的實(shí)現(xiàn)
這篇文章主要為大家詳細(xì)介紹了Android使用URLConnection提交請(qǐng)求的實(shí)現(xiàn),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2017-10-10
Android手機(jī)通過藍(lán)牙連接佳博打印機(jī)的實(shí)例代碼
這篇文章主要介紹了Android手機(jī)通過藍(lán)牙連接佳博打印機(jī)的實(shí)例代碼,非常不錯(cuò)具有參考借鑒價(jià)值,需要的朋友可以參考下2016-11-11
解決Android Studio Design界面不顯示layout控件的問題
這篇文章主要介紹了解決Android Studio Design界面不顯示layout控件的問題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧2020-03-03

