Android中LinearLayoutCompat的使用

一.基本使用

LinearLayoutCompat主要作用就是為里面的子View添加分割線姑原,它有三個(gè)基本屬性。
app:divider="":分割線奴迅,類型Drawable;
app:dividerPadding="":分割線的左右內(nèi)邊距赏寇;

app:showDividers="":展示分割線的模式,可接收none价认、beginning蹋订、end、middle四種模式刻伊。none表示不展示分割線露戒;beginning表示只在第一個(gè)子View的前面展示分割線;end表示只在最后一個(gè)子View的后面展示分割線捶箱;middle表示在每一個(gè)子View的中間展示分割線智什。這些參數(shù)也可以組合起來(lái)使用,例如:app:showDividers="beginning|middle|end"
device-2019-12-04-231706.png

二.實(shí)現(xiàn)左右邊距不等的分割線
device-2019-12-04-232526.png

app:dividerPadding="8dp"設(shè)置的是左右邊距都等于8dp丁屎,如要實(shí)現(xiàn)上圖的需求則需要從drawable入手荠锭,可以選擇使用inset修改Drawable左右邊距。

<?xml version="1.0" encoding="utf-8"?>
<inset xmlns:android="http://schemas.android.com/apk/res/android"
    android:insetLeft="56dp"
    android:insetRight="8dp">
    <shape android:shape="rectangle">

        <size
            android:width="1dp"
            android:height="1dp" />
        <solid android:color="#000" />
    </shape>
</inset>

三.指定子View添加分割線

device-2019-12-04-233500.png

上圖為前兩個(gè)Item底部不添加分割線的效果晨川,此時(shí)可以選擇繼承LinearLayoutCompat類证九,并重寫hasDividerBeforeChildAt這個(gè)方法,可以在這個(gè)方法里面去控制共虑。

public class MyLinearLayoutCompat extends LinearLayoutCompat {
    public MyLinearLayoutCompat(Context context, AttributeSet attrs) {
        super(context, attrs);
    }

    @Override
    protected boolean hasDividerBeforeChildAt(int childIndex) {
        int showDividers = getShowDividers();
        if (childIndex == 0) {
            return (showDividers & 1) != 0;
        } else if (childIndex == this.getChildCount()) {
            return (showDividers & 4) != 0;
        } else if ((showDividers & 2) == 0) {
            return false;
        } else {
            boolean hasVisibleViewBefore = false;
            for (int i = childIndex - 1; i > 1; --i) {
                if (getChildAt(i).getVisibility() != GONE) {
                    hasVisibleViewBefore = true;
                    break;
                }
            }
            return hasVisibleViewBefore;
        }
    }
}

在循環(huán)里面i > 1就是從三個(gè)子View開始hasVisibleViewBefore=true愧怜。

四.漸變色分割線

device-2019-12-04-234244.png

可以寫一個(gè)shape并對(duì)shape添加gradient屬性:

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

    <size
        android:width="1dp"
        android:height="1dp" />
    <solid android:color="#000" />

    <gradient
        android:endColor="@color/colorPrimary"
        android:startColor="@color/colorAccent"
        android:type="linear" />
</shape>

其他的很多分割線樣式都可以通過設(shè)置shape的屬性進(jìn)行實(shí)現(xiàn),如圓角妈拌、分割線高度等拥坛,如果碰到需要實(shí)現(xiàn)更加復(fù)雜的樣式,還可以使用圖片尘分。

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末猜惋,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子培愁,更是在濱河造成了極大的恐慌著摔,老刑警劉巖,帶你破解...
    沈念sama閱讀 218,755評(píng)論 6 507
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件定续,死亡現(xiàn)場(chǎng)離奇詭異谍咆,居然都是意外死亡,警方通過查閱死者的電腦和手機(jī)香罐,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,305評(píng)論 3 395
  • 文/潘曉璐 我一進(jìn)店門卧波,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái)时肿,“玉大人庇茫,你說(shuō)我怎么就攤上這事◇Τ桑” “怎么了旦签?”我有些...
    開封第一講書人閱讀 165,138評(píng)論 0 355
  • 文/不壞的土叔 我叫張陵查坪,是天一觀的道長(zhǎng)。 經(jīng)常有香客問我宁炫,道長(zhǎng)偿曙,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 58,791評(píng)論 1 295
  • 正文 為了忘掉前任羔巢,我火速辦了婚禮望忆,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘竿秆。我一直安慰自己启摄,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,794評(píng)論 6 392
  • 文/花漫 我一把揭開白布幽钢。 她就那樣靜靜地躺著歉备,像睡著了一般。 火紅的嫁衣襯著肌膚如雪匪燕。 梳的紋絲不亂的頭發(fā)上蕾羊,一...
    開封第一講書人閱讀 51,631評(píng)論 1 305
  • 那天,我揣著相機(jī)與錄音帽驯,去河邊找鬼龟再。 笑死,一個(gè)胖子當(dāng)著我的面吹牛尼变,可吹牛的內(nèi)容都是我干的吸申。 我是一名探鬼主播,決...
    沈念sama閱讀 40,362評(píng)論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼享甸,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼截碴!你這毒婦竟也來(lái)了?” 一聲冷哼從身側(cè)響起蛉威,我...
    開封第一講書人閱讀 39,264評(píng)論 0 276
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤日丹,失蹤者是張志新(化名)和其女友劉穎,沒想到半個(gè)月后蚯嫌,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體哲虾,經(jīng)...
    沈念sama閱讀 45,724評(píng)論 1 315
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,900評(píng)論 3 336
  • 正文 我和宋清朗相戀三年择示,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了束凑。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 40,040評(píng)論 1 350
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡栅盲,死狀恐怖汪诉,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情,我是刑警寧澤扒寄,帶...
    沈念sama閱讀 35,742評(píng)論 5 346
  • 正文 年R本政府宣布鱼鼓,位于F島的核電站,受9級(jí)特大地震影響该编,放射性物質(zhì)發(fā)生泄漏迄本。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,364評(píng)論 3 330
  • 文/蒙蒙 一课竣、第九天 我趴在偏房一處隱蔽的房頂上張望嘉赎。 院中可真熱鬧,春花似錦于樟、人聲如沸曹阔。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,944評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)赃份。三九已至,卻和暖如春奢米,著一層夾襖步出監(jiān)牢的瞬間抓韩,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 33,060評(píng)論 1 270
  • 我被黑心中介騙來(lái)泰國(guó)打工鬓长, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留谒拴,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 48,247評(píng)論 3 371
  • 正文 我出身青樓涉波,卻偏偏與公主長(zhǎng)得像英上,于是被迫代替她去往敵國(guó)和親。 傳聞我的和親對(duì)象是個(gè)殘疾皇子啤覆,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,979評(píng)論 2 355

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