真实的国产乱ⅩXXX66竹夫人,五月香六月婷婷激情综合,亚洲日本VA一区二区三区,亚洲精品一区二区三区麻豆

成都創(chuàng)新互聯(lián)網(wǎng)站制作重慶分公司

AndroidTextView中如何顯示圖片

這篇文章給大家分享的是有關(guān)Android TextView中如何顯示圖片的內(nèi)容。小編覺得挺實(shí)用的,因此分享給大家做個參考,一起跟隨小編過來看看吧。

創(chuàng)新互聯(lián)公司主營太子河網(wǎng)站建設(shè)的網(wǎng)絡(luò)公司,主營網(wǎng)站建設(shè)方案,重慶APP軟件開發(fā),太子河h5重慶小程序開發(fā)搭建,太子河網(wǎng)站營銷推廣歡迎太子河等地區(qū)企業(yè)咨詢

1、XML文件中指定屬性值

這種方式應(yīng)該是最常用的了,在TextView的左上右下顯示圖片,可用 
android:drawableLeft 
android:drawableTop 
android:drawableRight 
android:drawableBottom

比如我們要在TextView的頂部設(shè)置圖片,代碼如下:

這種顯示方式圖片跟文本是居中對齊的,此種方式對應(yīng)的方法是setCompoundDrawablesWithIntrinsicBounds:

mTextView01.setCompoundDrawablesWithIntrinsicBounds(null,
    getResources().getDrawable(R.drawable.ic_launcher, null), null, null);

效果圖: 

Android TextView中如何顯示圖片

如果覺得圖片離文字太近,也可以設(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)簽中 String htmlFor02 = "項(xiàng)目圖片測試:" + "" + "";
mTextView02.setText(Html.fromHtml(htmlFor02, new Html.ImageGetter() {
  @Override  public Drawable getDrawable(String source) {    Log.d(TAG, "項(xiàng)目圖片測試_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()方法取得圖片。

效果圖如下:

 Android TextView中如何顯示圖片

獲取網(wǎng)絡(luò)圖片

為了簡化代碼,我們用到了google的volley網(wǎng)絡(luò)框架去請求圖片,然后保存到sdcard再顯示,這種方式略顯麻煩,看代碼:

private static final String htmlFor03 = "網(wǎng)絡(luò)圖片測試:"
    + "";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請求網(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() {    @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ò)下載并保存到本地–>顯示本地圖片。

效果圖如下: 

Android TextView中如何顯示圖片

3、通過ImageSpan和SpannableString

這種方式很簡單,通過新建ImageSpan對象得到圖片,然后作為參數(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)識在 Span 范圍內(nèi)的文本前后輸入新的字符時(shí)是否把它們也應(yīng)用這個效果。

效果圖: 

Android TextView中如何顯示圖片

4、通過繼承TextView方式

這種方式的原理是通過繼承TextView,并重寫onDraw(),讓圖片直接畫到文本上,這會導(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文件中引用自定義控件:

效果圖: 

Android TextView中如何顯示圖片

感謝各位的閱讀!關(guān)于“Android TextView中如何顯示圖片”這篇文章就分享到這里了,希望以上內(nèi)容可以對大家有一定的幫助,讓大家可以學(xué)到更多知識,如果覺得文章不錯,可以把它分享出去讓更多的人看到吧!


本文標(biāo)題:AndroidTextView中如何顯示圖片
網(wǎng)站地址:http://weahome.cn/article/pddjhs.html

其他資訊

在線咨詢

微信咨詢

電話咨詢

028-86922220(工作日)

18980820575(7×24)

提交需求

返回頂部