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

首頁 > 系統(tǒng) > Android > 正文

詳解Android SpannableString多行圖文混排的應(yīng)用實戰(zhàn)

2019-12-12 01:27:03
字體:
供稿:網(wǎng)友

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

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

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

效果圖

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

那么什么是SpannableString呢?

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

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

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

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

String title = MapUtil.getValueStr(datas.get(position), "Title");   try {    title = java.net.URLDecoder.decode(title, "utf-8");   } catch (UnsupportedEncodingException e) {    e.printStackTrace();   }   //圖文混排   Drawable drawable = getResources().getDrawable(R.mipmap.icon_top);    drawable.setBounds(0,0,drawable.getIntrinsicWidth(),drawable.getIntrinsicHeight());//這里后兩位不要填寫int類參數(shù),否則會出現(xiàn)在大屏手機上顯示不整齊的情況   ImageSpan is = new ImageSpan(drawable);   String space = " ";   title = title + 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類參數(shù),否則會出現(xiàn)在大屏手機上顯示不整齊的情況

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

以上就是本文的全部內(nèi)容,希望對大家的學習有所幫助,也希望大家多多支持武林網(wǎng)。

發(fā)表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發(fā)表
主站蜘蛛池模板: 印江| 德昌县| 永新县| 灵宝市| 宁南县| 宜川县| 孟州市| 墨竹工卡县| 鹤壁市| 大邑县| 体育| 蛟河市| 丹阳市| 镇赉县| 平舆县| 成安县| 柘城县| 宁乡县| 滦平县| 清新县| 青岛市| 彭水| 武功县| 宁远县| 普定县| 桂林市| 平果县| 边坝县| 巫山县| 开平市| 公安县| 三穗县| 吴堡县| 雷州市| 阿克| 高青县| 太湖县| 湖北省| 龙海市| 安吉县| 高青县|