給section整體加陰影的界面實(shí)現(xiàn)方法

今日接到一個(gè)需求抢野,UI設(shè)計(jì)圖如下:

UI設(shè)計(jì)圖.jpg

以正常的邏輯思維辕棚,沒一個(gè)卡片應(yīng)該是一個(gè)section,上面的日期和錢數(shù)扁瓢,應(yīng)該是section頭引几,下面有一個(gè)距離卡片底部8像素高度的白色區(qū)域伟桅,應(yīng)該為section尾楣铁。里面為該section對(duì)應(yīng)的cell列表。

但是問題來(lái)了盖腕,我們可以很方便的給section Header加陰影溃列,但是如何將Seciton作為一個(gè)整體來(lái)加陰影呢膛薛?

我最初的做法是,將一個(gè)卡片當(dāng)做一個(gè)view哄啄,里面的列表用自定制的Button來(lái)實(shí)現(xiàn)雅任,通過(guò)For循環(huán)來(lái)依次創(chuàng)建Button進(jìn)行布局。

  • 好處是:UI方面可以很輕松的實(shí)現(xiàn)卡片的陰影效果增淹;
  • 壞處是:cell內(nèi)的Button個(gè)數(shù)不固定椿访,如果條數(shù)多的畫會(huì)特別容易卡,而且在快速滑動(dòng)的時(shí)候虑润,可以看到卡片有卡頓的現(xiàn)象成玫。

基于上述原因,我改用UIBezierPath指定陰影的路徑來(lái)實(shí)現(xiàn)卡片效果拳喻。

但是section頭部和尾部哭当,我分別可以指定上左右和下左右的陰影路徑,但是對(duì)于列表冗澈,因?yàn)閁IBezierPath只能畫一條連續(xù)的線钦勘,無(wú)法單獨(dú)指定左邊和右邊的路徑,如果我通過(guò)把上下的陰影寫在view內(nèi)部,這樣展示的時(shí)候看起來(lái)沒有上下陰影,但是滑動(dòng)的時(shí)候虎囚,每個(gè)cell都有了邊框适揉。而且這樣組裝起來(lái)的陰影炼邀,看起來(lái)不是特別的平滑,故又棄之!

最后,安卓同事點(diǎn)醒了我袜漩,可以通過(guò)漸變view來(lái)做陰影呀座掘!

  • 1嬉愧、section頭部分,分別在上,左挂疆,右添加了一個(gè)透明的view视事,通過(guò)設(shè)置View的背景色來(lái)達(dá)到陰影效果。
UIView *leftView = [[UIView alloc] initWithFrame:CGRectMake(2, 4, 6, 48)];
    [view addSubview:leftView];
    CAGradientLayer *gradient = [CAGradientLayer layer];
    gradient.frame = leftView.bounds;
    gradient.colors = [NSArray arrayWithObjects:
                       (id)[UIColor colorWithRed:(0/255.0)  green:(0/255.0)  blue:(0/255.0)  alpha:0.0].CGColor,
                       (id)[UIColor colorWithRed:(0/255.0)  green:(0/255.0)  blue:(0/255.0)  alpha:0.12].CGColor, nil];
    gradient.startPoint = CGPointMake(0, 0);
    gradient.endPoint = CGPointMake(1, 0);
    [leftView.layer addSublayer:gradient];
    
    UIView *rightView = [[UIView alloc] initWithFrame:CGRectMake(kScreenWidth - 8, 4, 6, 48)];
    [view addSubview:rightView];
    CAGradientLayer *gradientR = [CAGradientLayer layer];
    gradientR.frame = rightView.bounds;
    gradientR.colors = [NSArray arrayWithObjects:
                        (id)[UIColor colorWithRed:(0/255.0)  green:(0/255.0)  blue:(0/255.0)  alpha:0.12].CGColor,
                        (id)[UIColor colorWithRed:(0/255.0)  green:(0/255.0)  blue:(0/255.0)  alpha:0.0].CGColor, nil];
    gradientR.startPoint = CGPointMake(0, 0);
    gradientR.endPoint = CGPointMake(1, 0);
    [rightView.layer addSublayer:gradientR];
    
    UIView *topV = [[UIView alloc] initWithFrame:CGRectMake(6, 0, kScreenWidth - 12, 4)];
    [view addSubview:topV];
    CAGradientLayer *gradientT = [CAGradientLayer layer];
    gradientT.frame = topV.bounds;
    gradientT.colors = [NSArray arrayWithObjects:
                        (id)[UIColor colorWithRed:(0/255.0)  green:(0/255.0)  blue:(0/255.0)  alpha:0.12].CGColor,
                        (id)[UIColor colorWithRed:(0/255.0)  green:(0/255.0)  blue:(0/255.0)  alpha:0.0].CGColor, nil];
    gradientT.startPoint = CGPointMake(0, 1);
    gradientT.endPoint = CGPointMake(0, 0);
    [topV.layer addSublayer:gradientT];
  • 2、section尾部分同上喊衫,設(shè)置下寝杖,左辣往,右漸變背景色
UIView *leftView = [[UIView alloc] initWithFrame:CGRectMake(2, 0, 6, 8)];
    [view addSubview:leftView];
    CAGradientLayer *gradient = [CAGradientLayer layer];
    gradient.frame = leftView.bounds;
    gradient.colors = [NSArray arrayWithObjects:
                        (id)[UIColor colorWithRed:(0/255.0)  green:(0/255.0)  blue:(0/255.0)  alpha:0.12].CGColor,
                        (id)[UIColor colorWithRed:(0/255.0)  green:(0/255.0)  blue:(0/255.0)  alpha:0.0].CGColor, nil];
    gradient.startPoint = CGPointMake(1, 0);
    gradient.endPoint = CGPointMake(0, 0);
    [leftView.layer addSublayer:gradient];
    
    
    UIView *rightView = [[UIView alloc] initWithFrame:CGRectMake(kScreenWidth - 8, 0, 6, 8)];
    [view addSubview:rightView];
    CAGradientLayer *gradientR = [CAGradientLayer layer];
    gradientR.frame = rightView.bounds;
    gradientR.colors = [NSArray arrayWithObjects:
                        (id)[UIColor colorWithRed:(0/255.0)  green:(0/255.0)  blue:(0/255.0)  alpha:0.12].CGColor,
                        (id)[UIColor colorWithRed:(0/255.0)  green:(0/255.0)  blue:(0/255.0)  alpha:0.0].CGColor, nil];
    gradientR.startPoint = CGPointMake(0, 0);
    gradientR.endPoint = CGPointMake(1, 0);
    [rightView.layer addSublayer:gradientR];
    
    UIView *bottomV = [[UIView alloc] initWithFrame:CGRectMake(6, 8, kScreenWidth - 12, 4)];
    [view addSubview:bottomV];
    CAGradientLayer *gradientB = [CAGradientLayer layer];
    gradientB.frame = bottomV.bounds;
    gradientB.colors = [NSArray arrayWithObjects:
                        (id)[UIColor colorWithRed:(0/255.0)  green:(0/255.0)  blue:(0/255.0)  alpha:0.12].CGColor,
                        (id)[UIColor colorWithRed:(0/255.0)  green:(0/255.0)  blue:(0/255.0)  alpha:0.0].CGColor, nil];
    gradientB.startPoint = CGPointMake(0, 0);
    gradientB.endPoint = CGPointMake(0, 1.0);
    [bottomV.layer addSublayer:gradientB];
  • 3、cell部分珊肃,設(shè)置左右兩個(gè)方向的陰影
UIView *leftView = [[UIView alloc] initWithFrame:CGRectMake(2, 0, 6, 72)];
        [self addSubview:leftView];
        
        CAGradientLayer *gradient = [CAGradientLayer layer];
        gradient.frame = leftView.bounds;
        gradient.colors = [NSArray arrayWithObjects:
                           (id)[UIColor colorWithRed:(0/255.0)  green:(0/255.0)  blue:(0/255.0)  alpha:0.12].CGColor,
                           (id)[UIColor colorWithRed:(0/255.0)  green:(0/255.0)  blue:(0/255.0)  alpha:0.0].CGColor, nil];
        gradient.startPoint = CGPointMake(1, 0);
        gradient.endPoint = CGPointMake(0, 0);
        [leftView.layer addSublayer:gradient];
        
        UIView *rightView = [[UIView alloc] initWithFrame:CGRectMake(kScreenWidth - 8, 0, 6, 72)];
        [self addSubview:rightView];
        
        CAGradientLayer *gradientR = [CAGradientLayer layer];
        gradientR.frame = rightView.bounds;
        gradientR.colors = [NSArray arrayWithObjects:
                           (id)[UIColor colorWithRed:(0/255.0)  green:(0/255.0)  blue:(0/255.0)  alpha:0.12].CGColor,
                           (id)[UIColor colorWithRed:(0/255.0)  green:(0/255.0)  blue:(0/255.0)  alpha:0.0].CGColor, nil];
        gradientR.startPoint = CGPointMake(0, 0);
        gradientR.endPoint = CGPointMake(1, 0);

        [rightView.layer addSublayer:gradientR];

這里需要注意的是:

  • 1厉亏、每個(gè)左右漸變View的寬度需要一致。
  • 2恬试、上下漸變view長(zhǎng)度可以稍微長(zhǎng)一點(diǎn)點(diǎn)窝趣,這樣做出來(lái)邊角也有陰影的效果幻馁。
  • 3、所有的漸變顏色設(shè)置需要保持一致铲咨,否則做出來(lái)的陰影會(huì)不平滑。
  • 4济赎、startPoint和endPoint代表的view的漸變方向滑凉。只有0和1兩個(gè)值统扳。例如如果x從1到0,則代表從右向左漸變畅姊。

這樣做也有缺點(diǎn):那就是卡片的圓角處理暫未實(shí)現(xiàn)咒钟。如果有人有更好的方法,歡迎提出指正若未。謝謝朱嘴!

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市陨瘩,隨后出現(xiàn)的幾起案子腕够,更是在濱河造成了極大的恐慌级乍,老刑警劉巖,帶你破解...
    沈念sama閱讀 212,542評(píng)論 6 493
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件帚湘,死亡現(xiàn)場(chǎng)離奇詭異玫荣,居然都是意外死亡,警方通過(guò)查閱死者的電腦和手機(jī)大诸,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 90,596評(píng)論 3 385
  • 文/潘曉璐 我一進(jìn)店門捅厂,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái),“玉大人资柔,你說(shuō)我怎么就攤上這事焙贷。” “怎么了贿堰?”我有些...
    開封第一講書人閱讀 158,021評(píng)論 0 348
  • 文/不壞的土叔 我叫張陵辙芍,是天一觀的道長(zhǎng)。 經(jīng)常有香客問我羹与,道長(zhǎng)故硅,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 56,682評(píng)論 1 284
  • 正文 為了忘掉前任纵搁,我火速辦了婚禮吃衅,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘腾誉。我一直安慰自己徘层,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 65,792評(píng)論 6 386
  • 文/花漫 我一把揭開白布利职。 她就那樣靜靜地躺著趣效,像睡著了一般。 火紅的嫁衣襯著肌膚如雪眼耀。 梳的紋絲不亂的頭發(fā)上英支,一...
    開封第一講書人閱讀 49,985評(píng)論 1 291
  • 那天,我揣著相機(jī)與錄音哮伟,去河邊找鬼。 笑死妄帘,一個(gè)胖子當(dāng)著我的面吹牛楞黄,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播抡驼,決...
    沈念sama閱讀 39,107評(píng)論 3 410
  • 文/蒼蘭香墨 我猛地睜開眼鬼廓,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼!你這毒婦竟也來(lái)了致盟?” 一聲冷哼從身側(cè)響起碎税,我...
    開封第一講書人閱讀 37,845評(píng)論 0 268
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤尤慰,失蹤者是張志新(化名)和其女友劉穎,沒想到半個(gè)月后雷蹂,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體伟端,經(jīng)...
    沈念sama閱讀 44,299評(píng)論 1 303
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 36,612評(píng)論 2 327
  • 正文 我和宋清朗相戀三年匪煌,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了责蝠。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 38,747評(píng)論 1 341
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡萎庭,死狀恐怖霜医,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情驳规,我是刑警寧澤肴敛,帶...
    沈念sama閱讀 34,441評(píng)論 4 333
  • 正文 年R本政府宣布,位于F島的核電站吗购,受9級(jí)特大地震影響值朋,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜巩搏,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 40,072評(píng)論 3 317
  • 文/蒙蒙 一昨登、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧贯底,春花似錦丰辣、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,828評(píng)論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)。三九已至胚想,卻和暖如春琐凭,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背浊服。 一陣腳步聲響...
    開封第一講書人閱讀 32,069評(píng)論 1 267
  • 我被黑心中介騙來(lái)泰國(guó)打工统屈, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人牙躺。 一個(gè)月前我還...
    沈念sama閱讀 46,545評(píng)論 2 362
  • 正文 我出身青樓愁憔,卻偏偏與公主長(zhǎng)得像,于是被迫代替她去往敵國(guó)和親孽拷。 傳聞我的和親對(duì)象是個(gè)殘疾皇子吨掌,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 43,658評(píng)論 2 350

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