国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 系統 > Android > 正文

詳解Android SpannableString多行圖文混排的應用實戰

2019-10-22 18:19:42
字體:
來源:轉載
供稿:網友

TeXtView大家應該都不陌生,文本展示控件嘛! 就用TextView顯示普普通通的文本,OK,很簡單,Android入門的都會,沒入門的在門縫外看兩眼也都會,哈哈,開玩笑。那要是設計在開發需求中要求類似微信聊天表情一樣在TextView中插入表情圖片呢? 有的小伙伴就會說啦,“TextView添加圖片我會啊,不就是drawableLeft,drawableRight嘛!” 嗯 ~ 也行,算是一種方法,可這有一個限制,首先,圖片只能在TextView的兩端,其次,兩端都只能設置一張圖片。要是圖片要在文本中間呢?無能為力了吧,要是你會使用SpannableString,這個問題也就不難解決了,簡直是Just So So。

所以,不論你是否正在經受以上問題的困擾,亦或是還沒有經歷到,請駐足仔細耐心的看完這篇簡短的文章。不僅能夠輕松實現以上設計需求,更能收獲其他各種炫酷的效果,也許就能幫助你解決現在你所困擾的問題。

首先我們來看下這張效果圖,注意圖片中置頂這個圖片是如何實現的呢?當然你也可也設置他的點擊事件,比如帶有視頻或者其他類的,這里我們就不多做介紹了,看項目具體需求就好。

效果圖

android,圖文混排,SpannableString,多行圖文混排

如果就涉及到一行的話我們只需要在文本后面加個imageview就行,但是如果多行顯示的話這樣做就不太好了

那么什么是SpannableString呢?

SpannableString其實和String一樣,都是一種字符串類型,同樣TextView也可以直接設置SpannableString作為顯示文本,不同的是SpannableString可以通過使用其方法setSpan方法實現字符串各種形式風格的顯示,重要的是可以指定設置的區間,也就是為字符串指定下標區間內的子字符串設置格式。

setSpan(Object what, int start, int end, int flags)方法需要用戶輸入四個參數,what表示設置的格式是什么,可以是前景色、背景色也可以是可點擊的文本等等,start表示需要設置格式的子字符串的起始下標,同理end表示末尾下標,flags就是一種標識,共有以下四種屬性:

  1. Spanned.SPAN_INCLUSIVE_EXCLUSIVE 從起始下標到末尾下標,包括起始下標,不包括后面
  2. Spanned.SPAN_INCLUSIVE_INCLUSIVE 從起始下標到末尾下標,同時包括起始下標和末尾下標,前后包括
  3. Spanned.SPAN_EXCLUSIVE_EXCLUSIVE 從起始下標到末尾下標,但都不包括起始下標和末尾下標
  4. Spanned.SPAN_EXCLUSIVE_INCLUSIVE 從起始下標到末尾下標,包括末尾下標

到此,那我們看看如何在代碼中實現這一效果呢?

String   try {   } catch (UnsupportedEncodingException e) {    e.printStackTrace();   }   //圖文混排   Drawable drawable = getResources().getDrawable(R.mipmap.icon_top);    drawable.setBounds(0,0,drawable.getIntrinsicWidth(),drawable.getIntrinsicHeight());//這里后兩位不要填寫int類參數,否則會出現在大屏手機上顯示不整齊的情況   ImageSpan is = new ImageSpan(drawable);   String space = " ";   int strLength = title.length();   SpannableString ss = new SpannableString(title);   ss .setSpan(is,strLength-1, strLength, Spannable.SPAN_INCLUSIVE_EXCLUSIVE);   if ("1".equals(TopFlag)) { //置頂顯示    viewHolder.title.setText(ss.subSequence(0,strLength));   } else {    viewHolder.title.setText(title);   }

我們拿到接口返回的title后,把我們需要的圖片通過 Drawable drawable = getResources().getDrawable(R.mipmap.icon_top);
drawable.setBounds(0,0,drawable.getIntrinsicWidth(),drawable.getIntrinsicHeight());//這里后兩位不要填寫int類參數,否則會出現在大屏手機上顯示不整齊的情況

拿到圖片后設置你想要的大小和位置即可輕松快速實現這一效果。

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持VEVB武林網。


注:相關教程知識閱讀請移步到Android開發頻道。
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 湘乡市| 孝义市| 文成县| 武夷山市| 合山市| 通辽市| 隆子县| 全椒县| 峨边| 平阳县| 晋州市| 东海县| 开封市| 牡丹江市| 肥东县| 鸡泽县| 商南县| 平潭县| 通州区| 星子县| 宁晋县| 炎陵县| 财经| 大庆市| 汝城县| 荣昌县| 黄陵县| 澄城县| 南漳县| 南川市| 福州市| 天镇县| 神池县| 秦安县| 洛隆县| 大石桥市| 子洲县| 都兰县| 甘孜| 子洲县| 什邡市|