scrollView滾動導(dǎo)航條漸變

很多時候 項(xiàng)目中要求導(dǎo)航欄的顏色隨著scrollview的滾動發(fā)生漸變,于是自己就寫了一個demo沒方法比較簡單 寫一個UINavigationBar的分類 在分類的.h文件中聲明兩個方法?

#import@interface UINavigationBar (LH)

- (void)lhSetBackgroundColor:(UIColor *)backgroundColor;

- (void)lhReset;

@end

在.m文件中實(shí)現(xiàn)方法 其中需要注意的是 用到了runtime的關(guān)聯(lián)對象 ,關(guān)聯(lián)對象就是把兩個對象相互關(guān)聯(lián)起來,使得一個對象多為另一個對象的一部分.具體講解以后會給大家以文章形式寫出來 ,這里就不過多講解了

#import@implementation UINavigationBar (LH)

static char overlayKey;

- (UIView *)overlay{

return objc_getAssociatedObject(self, &overlayKey);

}

- (void)setOverlay:(UIView *)overlay{

objc_setAssociatedObject(self, &overlayKey, overlay, OBJC_ASSOCIATION_RETAIN_NONATOMIC);

}

- (void)lhSetBackgroundColor:(UIColor *)backgroundColor{

if (!self.overlay) {

[self setBackgroundImage:[UIImage new] forBarMetrics:UIBarMetricsDefault];

self.overlay? = [[UIView alloc] initWithFrame:CGRectMake(0, -20, [UIScreen mainScreen].bounds.size.width, CGRectGetHeight(self.bounds)+20)];

self.overlay.userInteractionEnabled = NO;

self.overlay.autoresizingMask = UIViewAutoresizingFlexibleWidth;

[self insertSubview:self.overlay atIndex:0];

}

self.overlay.backgroundColor = backgroundColor;

}

- (void)lhReset{

[self setBackgroundImage:nil forBarMetrics:UIBarMetricsDefault];

[self.overlay removeFromSuperview];

self.overlay = nil;

}

@end

現(xiàn)在是只要在你要實(shí)現(xiàn)的控制器中調(diào)用這連個方法就好了 其中最主要的方法就是

#pragma mark UIScrollViewDelegate

- (void)scrollViewDidScroll:(UIScrollView *)scrollView

{

UIColor *color = [UIColor colorWithRed:45/255.0 green:45/255.0 blue:45/255.0 alpha:1];

CGFloat offsetY = scrollView.contentOffset.y;

if (offsetY >= - self.view.frame.size.height ) {

CGFloat alpha = 1- offsetY/self.view.frame.size.height;

[self.navigationController.navigationBar lhSetBackgroundColor:[color colorWithAlphaComponent:alpha]];

self.titlelabel.alpha = alpha;

} else {

[self.navigationController.navigationBar lhSetBackgroundColor:[color colorWithAlphaComponent:0]];

}

}

當(dāng)然不會忘了demo的連接的:https://git.oschina.net/huanni/scrollviewNav.git

效果圖如下


最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末采记,一起剝皮案震驚了整個濱河市,隨后出現(xiàn)的幾起案子狰住,更是在濱河造成了極大的恐慌官辽,老刑警劉巖建蹄,帶你破解...
    沈念sama閱讀 211,194評論 6 490
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件耀鸦,死亡現(xiàn)場離奇詭異紫岩,居然都是意外死亡赡鲜,警方通過查閱死者的電腦和手機(jī)卸奉,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 90,058評論 2 385
  • 文/潘曉璐 我一進(jìn)店門钝诚,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人榄棵,你說我怎么就攤上這事凝颇。” “怎么了疹鳄?”我有些...
    開封第一講書人閱讀 156,780評論 0 346
  • 文/不壞的土叔 我叫張陵拧略,是天一觀的道長。 經(jīng)常有香客問我瘪弓,道長垫蛆,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 56,388評論 1 283
  • 正文 為了忘掉前任腺怯,我火速辦了婚禮袱饭,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘呛占。我一直安慰自己虑乖,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 65,430評論 5 384
  • 文/花漫 我一把揭開白布栓票。 她就那樣靜靜地躺著决左,像睡著了一般愕够。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上佛猛,一...
    開封第一講書人閱讀 49,764評論 1 290
  • 那天惑芭,我揣著相機(jī)與錄音,去河邊找鬼继找。 笑死遂跟,一個胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的婴渡。 我是一名探鬼主播幻锁,決...
    沈念sama閱讀 38,907評論 3 406
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼边臼!你這毒婦竟也來了哄尔?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 37,679評論 0 266
  • 序言:老撾萬榮一對情侶失蹤柠并,失蹤者是張志新(化名)和其女友劉穎岭接,沒想到半個月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體臼予,經(jīng)...
    沈念sama閱讀 44,122評論 1 303
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡鸣戴,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 36,459評論 2 325
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發(fā)現(xiàn)自己被綠了粘拾。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片窄锅。...
    茶點(diǎn)故事閱讀 38,605評論 1 340
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖缰雇,靈堂內(nèi)的尸體忽然破棺而出入偷,到底是詐尸還是另有隱情,我是刑警寧澤寓涨,帶...
    沈念sama閱讀 34,270評論 4 329
  • 正文 年R本政府宣布盯串,位于F島的核電站氯檐,受9級特大地震影響戒良,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜冠摄,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 39,867評論 3 312
  • 文/蒙蒙 一糯崎、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧河泳,春花似錦沃呢、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,734評論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽某抓。三九已至,卻和暖如春惰瓜,著一層夾襖步出監(jiān)牢的瞬間否副,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 31,961評論 1 265
  • 我被黑心中介騙來泰國打工崎坊, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留备禀,地道東北人。 一個月前我還...
    沈念sama閱讀 46,297評論 2 360
  • 正文 我出身青樓奈揍,卻偏偏與公主長得像曲尸,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子男翰,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 43,472評論 2 348

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