【Android】TextView設(shè)置段落間距

TextView只提供設(shè)置行距的方法踢步,沒有提供段落間距的方法癣亚,但是提供了一個 SpannableString 類來給TextView設(shè)置各種效果,
如圖:

其中一個給文字替換為圖片的效果給我?guī)砹遂`感获印,

我可以用一個圖片(最后換成一個寬1px述雾,指定高度的透明長方形,xml中畫出來的)來模擬段落間距。

注意畫出來的高度兼丰,不能使用 用尺子直接量的值玻孟,而要比這個高度要小。
為什么呢鳍征,我也不清楚黍翎,不過我還是要上個圖,我估計應(yīng)該是兩行文字之間的line gap的原因蟆技。

后臺給我們返回的json中段落區(qū)分符是“\n”玩敏,我們先把"\n"替換為"\n\r"

“\n”用來換行,“\r”就是那個將要被替換的字符了(為什么要用\r呢质礼,陰差陽錯啦旺聚,后來發(fā)現(xiàn)\r挺合適的,也不會重復(fù))眶蕉;最后就是用SpannableString來處理文字了砰粹。

/**
     * 設(shè)置TextView段落間距
     *
     * @param context          上下文
     * @param tv               給誰設(shè)置段距,就傳誰
     * @param content          文字內(nèi)容
     * @param paragraphSpacing 請輸入段落間距(單位dp)
     * @param lineSpacingExtra xml中設(shè)置的的行距(單位dp)
     */
    public static void setParagraphSpacing(Context context, TextView tv, String content, int paragraphSpacing, int lineSpacingExtra) {
        if (!content.contains("\n")) {
            tv.setText(content);
            return;
        }
        content = content.replace("\n", "\n\r");

        int previousIndex = content.indexOf("\n\r");
        //記錄每個段落開始的index,第一段沒有碱璃,從第二段開始
        List<Integer> nextParagraphBeginIndexes = new ArrayList<>();
        nextParagraphBeginIndexes.add(previousIndex);
        while (previousIndex != -1) {
            int nextIndex = content.indexOf("\n\r", previousIndex + 2);
            previousIndex = nextIndex;
            if (previousIndex != -1) {
                nextParagraphBeginIndexes.add(previousIndex);
            }
        }
        //獲取行高(包含文字高度和行距)
        float lineHeight = tv.getLineHeight();

        //把\r替換成透明長方形(寬:1px弄痹,高:字高+段距)
        SpannableString spanString = new SpannableString(content);
        Drawable d = ContextCompat.getDrawable(context, R.drawable.paragraph_space);
        float density = context.getResources().getDisplayMetrics().density;
        //int強轉(zhuǎn)部分為:行高 - 行距 + 段距
        d.setBounds(0, 0, 1, (int) ((lineHeight - lineSpacingExtra * density) / 1.2 + (paragraphSpacing - lineSpacingExtra) * density));

        for (int index : nextParagraphBeginIndexes) {
            // \r在String中占一個index
            spanString.setSpan(new ImageSpan(d), index + 1, index + 2, Spanned.SPAN_EXCLUSIVE_EXCLUSIVE);
        }
        tv.setText(spanString);
    }

那個透明的長方形很簡單,隨手一畫就有了嵌器。

<?xml version="1.0" encoding="utf-8"?>
<shape xmlns:android="http://schemas.android.com/apk/res/android" android:shape="rectangle">
    <solid android:color="@color/transparent"/>
</shape>

下邊這個就是替換后的效果肛真,只不過這時候為了展示替換效果,那個長方形還是用了個orange色爽航。

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末蚓让,一起剝皮案震驚了整個濱河市,隨后出現(xiàn)的幾起案子讥珍,更是在濱河造成了極大的恐慌历极,老刑警劉巖,帶你破解...
    沈念sama閱讀 218,451評論 6 506
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件衷佃,死亡現(xiàn)場離奇詭異趟卸,居然都是意外死亡,警方通過查閱死者的電腦和手機氏义,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,172評論 3 394
  • 文/潘曉璐 我一進店門锄列,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人觅赊,你說我怎么就攤上這事右蕊。” “怎么了吮螺?”我有些...
    開封第一講書人閱讀 164,782評論 0 354
  • 文/不壞的土叔 我叫張陵,是天一觀的道長帕翻。 經(jīng)常有香客問我鸠补,道長,這世上最難降的妖魔是什么嘀掸? 我笑而不...
    開封第一講書人閱讀 58,709評論 1 294
  • 正文 為了忘掉前任紫岩,我火速辦了婚禮,結(jié)果婚禮上睬塌,老公的妹妹穿的比我還像新娘泉蝌。我一直安慰自己,他們只是感情好揩晴,可當(dāng)我...
    茶點故事閱讀 67,733評論 6 392
  • 文/花漫 我一把揭開白布勋陪。 她就那樣靜靜地躺著,像睡著了一般硫兰。 火紅的嫁衣襯著肌膚如雪诅愚。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 51,578評論 1 305
  • 那天劫映,我揣著相機與錄音违孝,去河邊找鬼刹前。 笑死,一個胖子當(dāng)著我的面吹牛雌桑,可吹牛的內(nèi)容都是我干的喇喉。 我是一名探鬼主播,決...
    沈念sama閱讀 40,320評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼校坑,長吁一口氣:“原來是場噩夢啊……” “哼轧飞!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起撒踪,我...
    開封第一講書人閱讀 39,241評論 0 276
  • 序言:老撾萬榮一對情侶失蹤过咬,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后制妄,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體掸绞,經(jīng)...
    沈念sama閱讀 45,686評論 1 314
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 37,878評論 3 336
  • 正文 我和宋清朗相戀三年耕捞,在試婚紗的時候發(fā)現(xiàn)自己被綠了衔掸。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 39,992評論 1 348
  • 序言:一個原本活蹦亂跳的男人離奇死亡俺抽,死狀恐怖敞映,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情磷斧,我是刑警寧澤振愿,帶...
    沈念sama閱讀 35,715評論 5 346
  • 正文 年R本政府宣布,位于F島的核電站弛饭,受9級特大地震影響冕末,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜侣颂,卻給世界環(huán)境...
    茶點故事閱讀 41,336評論 3 330
  • 文/蒙蒙 一档桃、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧憔晒,春花似錦藻肄、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,912評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至澎蛛,卻和暖如春抚垄,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 33,040評論 1 270
  • 我被黑心中介騙來泰國打工呆馁, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留桐经,地道東北人。 一個月前我還...
    沈念sama閱讀 48,173評論 3 370
  • 正文 我出身青樓浙滤,卻偏偏與公主長得像阴挣,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子纺腊,可洞房花燭夜當(dāng)晚...
    茶點故事閱讀 44,947評論 2 355

推薦閱讀更多精彩內(nèi)容

  • 字符串資源里變量替換 Android開發(fā)中是拒絕硬編碼的畔咧,我們可能會把一些字符串放在xml中當(dāng)作資源使用,假設(shè)有如...
    醉馬當(dāng)前闖閱讀 13,699評論 2 44
  • 前言 工作找完了揖膜,已經(jīng)干了兩個星期誓沸。雖然經(jīng)常加班,不過相比之前的工作壹粟,現(xiàn)在過得更加充實拜隧、更有意義。現(xiàn)在有點空閑時間...
    帶心情去旅行閱讀 72,600評論 42 237
  • ¥開啟¥ 【iAPP實現(xiàn)進入界面執(zhí)行逐一顯】 〖2017-08-25 15:22:14〗 《//首先開一個線程趁仙,因...
    小菜c閱讀 6,419評論 0 17
  • 故事似乎到這里就會結(jié)束洪添,我慢慢變得端莊穩(wěn)重,與各種各樣的女子打交道雀费,平衡著各種勢力干奢,每天略施粉黛,盈盈一笑盏袄,有著外...
    深巷梨花閱讀 140評論 0 0
  • 你說生活很安逸 而我正準(zhǔn)備逃離 我害怕在春天睡去 雙腳長出根須 歲月如流沙般靜謐 更怕鳥籠鎖住天空 把夢的羽翼 溫...
    風(fēng)紫_Rae閱讀 155評論 0 0