Android開發(fā) SpannableString的使用

在Android 開發(fā)中經(jīng)常遇到這樣的問題:有一段文本转砖,需要給部分文字設(shè)置不同的樣式须鼎,而此時在用TextView就有點懵圈了。TextView雖然也可以解決府蔗,但是布局可能會非常復(fù)雜晋控,也不利于后期的維護,這時候SpannableString就出現(xiàn)了礁竞,SpannableString俗稱:富文本糖荒,而它就可以很好的解決這個問題,使用還非常簡單模捂,可以為個別字符設(shè)置鏈接捶朵,顏色,大小 狂男,點擊事件 等综看。

在一段文字中對部分字符實現(xiàn)點擊 先來看看效果:

案例1.png

在Xml中只需要使用TextView:

 <TextView
        android:id="@+id/tv"
        android:gravity="center"
        android:layout_width="match_parent"
        android:layout_height="wrap_content"/>

在Activity中創(chuàng)建SpannableString對象使用( ClickableSpan ) :

//創(chuàng)建SpannableString 對象,添加字符
SpannableString spannableString = new SpannableString("你叫什么名字岖食?");
  //設(shè)置點擊事件
        ClickableSpan clickableSpan = new ClickableSpan() {
            @Override
            public void onClick(@NonNull View view) {
                //點擊后要執(zhí)行的任務(wù)
                Toast.makeText(TextActivity.this, "我叫小明", Toast.LENGTH_SHORT).show();
            }
        };
         //設(shè)置spannableString樣式
        //start :表示設(shè)置鏈接的起始位置
        //end  : 表示設(shè)置連接的結(jié)束位置
        //flags : 表示開始和結(jié)束下標(biāo)是否包含某字符

        /** Spanned.SPAN_EXCLUSIVE_EXCLUSIVE    不包括開始红碑,也不包括結(jié)束
         *  Spanned.SPAN_EXCLUSIVE_INCLUSIVE    不包括開始,但包括結(jié)束
         *  Spanned.SPAN_INCLUSIVE_INCLUSIVE    即包括開始泡垃,也包括結(jié)束
         *  Spanned.SPAN_INCLUSIVE_EXCLUSIVE    包括開始析珊,不包括結(jié)束
         */
        spannableString.setSpan(clickableSpan, 4, 7, Spanned.SPAN_INCLUSIVE_EXCLUSIVE);
        //激活點擊事件
        mTv.setMovementMethod(LinkMovementMethod.getInstance());
        //加入到TextView中
        mTv.setText(spannableString);

還可以對文字添加鏈接 (URLSpan ) :

      SpannableString spannableString = new SpannableString("我想要打開瀏覽器");
      //設(shè)置鏈接地址
      URLSpan urlSpan = new URLSpan("https://www.baidu.com");
      spannableString.setSpan(urlSpan, 5, 8, Spanned.SPAN_INCLUSIVE_EXCLUSIVE);
        //激活鏈接
      mTv.setMovementMethod(LinkMovementMethod.getInstance());
        //加入到TextView中
      mTv.setText(spannableString);

最后找到幾個解釋比較全面的網(wǎng)址,大家可以看一下
https://blog.csdn.net/zhaizu/article/details/51038113
https://github.com/Gennki/QRichText
http://www.reibang.com/p/fd507f562676

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末蔑穴,一起剝皮案震驚了整個濱河市忠寻,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌存和,老刑警劉巖奕剃,帶你破解...
    沈念sama閱讀 218,122評論 6 505
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異捐腿,居然都是意外死亡纵朋,警方通過查閱死者的電腦和手機,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,070評論 3 395
  • 文/潘曉璐 我一進店門茄袖,熙熙樓的掌柜王于貴愁眉苦臉地迎上來操软,“玉大人,你說我怎么就攤上這事宪祥∷屡福” “怎么了猪钮?”我有些...
    開封第一講書人閱讀 164,491評論 0 354
  • 文/不壞的土叔 我叫張陵,是天一觀的道長胆建。 經(jīng)常有香客問我烤低,道長,這世上最難降的妖魔是什么笆载? 我笑而不...
    開封第一講書人閱讀 58,636評論 1 293
  • 正文 為了忘掉前任扑馁,我火速辦了婚禮,結(jié)果婚禮上凉驻,老公的妹妹穿的比我還像新娘腻要。我一直安慰自己,他們只是感情好涝登,可當(dāng)我...
    茶點故事閱讀 67,676評論 6 392
  • 文/花漫 我一把揭開白布雄家。 她就那樣靜靜地躺著,像睡著了一般胀滚。 火紅的嫁衣襯著肌膚如雪趟济。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 51,541評論 1 305
  • 那天咽笼,我揣著相機與錄音顷编,去河邊找鬼。 笑死剑刑,一個胖子當(dāng)著我的面吹牛媳纬,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播施掏,決...
    沈念sama閱讀 40,292評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼钮惠,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了七芭?” 一聲冷哼從身側(cè)響起素挽,我...
    開封第一講書人閱讀 39,211評論 0 276
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎抖苦,沒想到半個月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體米死,經(jīng)...
    沈念sama閱讀 45,655評論 1 314
  • 正文 獨居荒郊野嶺守林人離奇死亡锌历,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 37,846評論 3 336
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發(fā)現(xiàn)自己被綠了峦筒。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片究西。...
    茶點故事閱讀 39,965評論 1 348
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖物喷,靈堂內(nèi)的尸體忽然破棺而出卤材,到底是詐尸還是另有隱情遮斥,我是刑警寧澤,帶...
    沈念sama閱讀 35,684評論 5 347
  • 正文 年R本政府宣布扇丛,位于F島的核電站术吗,受9級特大地震影響,放射性物質(zhì)發(fā)生泄漏帆精。R本人自食惡果不足惜较屿,卻給世界環(huán)境...
    茶點故事閱讀 41,295評論 3 329
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望卓练。 院中可真熱鬧隘蝎,春花似錦、人聲如沸襟企。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,894評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽顽悼。三九已至曼振,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間表蝙,已是汗流浹背拴测。 一陣腳步聲響...
    開封第一講書人閱讀 33,012評論 1 269
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留府蛇,地道東北人集索。 一個月前我還...
    沈念sama閱讀 48,126評論 3 370
  • 正文 我出身青樓,卻偏偏與公主長得像汇跨,于是被迫代替她去往敵國和親务荆。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點故事閱讀 44,914評論 2 355