[CSDN博客轉(zhuǎn)移]使用官方API解決Navigation側(cè)滑導(dǎo)致的Navigationbar異常顯示和隱藏的問題

經(jīng)歷了一個多月終于基本完成公司一個項目的重構(gòu)恩袱,在這后面的幾天調(diào)試中發(fā)現(xiàn)了一些小問題,小編講寫成博客記錄下來胶哲,當(dāng)做是自己技術(shù)生涯的記錄畔塔,同時也希望能幫助一些剛?cè)隝OS的朋友們。

昨天調(diào)試navigationbar的時候發(fā)現(xiàn)了一些奇怪的問題,和預(yù)期效果差距有點遠(yuǎn)澈吨。

問題一把敢、登陸頁面隱藏了navigationbar,注冊和關(guān)于頁面顯示了navigationbar棚辽,在側(cè)滑時如果從注冊頁面?zhèn)然话耄ú灰砷_手)讓登陸頁面顯示然后再往左滑把登陸頁面收起技竟,此時點擊關(guān)于頁時頭上的navigationbar就成了注冊頁的navigationbar。效果如下(附帶正常效果):

問題二屈藐、注冊頁側(cè)滑回登陸頁的過程中榔组,注冊頁的navigationbar被隱藏了,而我們想要的效果是正常效果動畫中的樣子联逻。

異常效果:


正常效果:



當(dāng)時問了團(tuán)隊里一個老手搓扯,解決方案是在項目中添加UINavigationController+FDFullscreenPopGesture(一個很不錯的開源項目附地址:https://github.com/forkingdog)這個分類,然后在需要隱藏navigation bar的頁面設(shè)置屬性 self.fd_prefersNavigationBarHidden = YES;問題即可解決包归!

可是小編這種好奇心強的怎么甘于就這樣解決問題锨推?這個分類是如何解決的問題?一大堆問好在小編的腦力飄過公壤,于是畫了一個多小時研究人家的分類是如何實現(xiàn)的换可。

現(xiàn)在給大家分享下成果,源碼不多厦幅,一個.m文件也就200多行沾鳄,代碼,沒有寫特意寫專場動畫确憨,和之前小編做的demo一樣的使用系統(tǒng)的interactivePopGestureRecognizer.delegate也就是系統(tǒng)的轉(zhuǎn)場動畫來實現(xiàn)效果译荞。那么說,系統(tǒng)就應(yīng)該為我們實現(xiàn)好了我們想要的效果才對休弃,于是乎繼續(xù)查看搜索fd_prefersNavigationBarHidden到底是在什么地方調(diào)用吞歼,為何用了它切換時的動畫效果就解決了。于是在下面的代碼中找到了答案

- (void)fd_setupViewControllerBasedNavigationBarAppearanceIfNeeded:(UIViewController *)appearingViewController

{

if (!self.fd_viewControllerBasedNavigationBarAppearanceEnabled) {

return;

}

__weak typeof(self) weakSelf = self;

_FDViewControllerWillAppearInjectBlock block = ^(UIViewController *viewController, BOOL animated) {

__strong typeof(weakSelf) strongSelf = weakSelf;

if (strongSelf) {

[strongSelf setNavigationBarHidden:viewController.fd_prefersNavigationBarHidden animated:animated];

}

};

// Setup will appear inject block to appearing view controller.

// Setup disappearing view controller as well, because not every view controller is added into

// stack by pushing, maybe by "-setViewControllers:".

appearingViewController.fd_willAppearInjectBlock = block;

UIViewController *disappearingViewController = self.viewControllers.lastObject;

if (disappearingViewController && !disappearingViewController.fd_willAppearInjectBlock) {

disappearingViewController.fd_willAppearInjectBlock = block;

}

}

其中[strongSelfsetNavigationBarHidden:viewController.fd_prefersNavigationBarHiddenanimated:animated];就是解決問題的關(guān)鍵塔猾,我們之前一直使用self.navigationController.navigationBarHidden或者self.navigationController.navigationBar.hidden來隱藏navigatiuonbar篙骡,這樣直接更改屬性的方式是不帶動畫的,而且滑動時的轉(zhuǎn)場動畫頁不為我們處理好丈甸,才導(dǎo)致了問出的出現(xiàn)医增,而- (void)setNavigationBarHidden:(BOOL)hidden animated:(BOOL)animated;為我們完美的解決這樣的問題,于是乎小編趕緊創(chuàng)新新工程不用UINavigationController+FDFullscreenPopGesture老虫,使用系統(tǒng)默認(rèn)的API來嘗試解決:

給自定義navigation添加側(cè)滑轉(zhuǎn)場動畫:

#import "MyNavigationController.h"? ? @interface MyNavigationController()@end

@implementation MyNavigationController

- (void)viewDidLoad {

[super viewDidLoad];

// 獲取系統(tǒng)自帶滑動手勢的target對象

id target = self.interactivePopGestureRecognizer.delegate;

// 創(chuàng)建全屏滑動手勢,調(diào)用系統(tǒng)自帶滑動手勢的target的action方法

UIPanGestureRecognizer *pan = [[UIPanGestureRecognizer alloc] initWithTarget:target action:@selector(handleNavigationTransition:)];

// 設(shè)置手勢代理茫多,攔截手勢觸發(fā)

pan.delegate = self;

// 給導(dǎo)航控制器的view添加全屏滑動手勢

[self.view addGestureRecognizer:pan];

// 禁止使用系統(tǒng)自帶的滑動手勢

self.interactivePopGestureRecognizer.enabled = NO;

}

- (BOOL)gestureRecognizerShouldBegin:(UIGestureRecognizer *)gestureRecognizer

{

// 注意:只有非根控制器才有滑動返回功能祈匙,根控制器沒有。

// 判斷導(dǎo)航控制器是否只有一個子控制器,如果只有一個子控制器夺欲,肯定是根控制器

if (self.childViewControllers.count == 1) {

// 表示用戶在根控制器界面跪帝,就不需要觸發(fā)滑動手勢,

return NO;

}

return YES;

}

@end

然后再創(chuàng)建3個ViewController來相互切換些阅,第一個是隱藏navigationbar的伞剑,后面2個不隱藏

隱藏navigationbar的ViewController代碼如下:

-(void)viewWillAppear:(BOOL)animated{

[super viewWillAppear:animated];

[self.navigationController setNavigationBarHidden:YES animated:YES];

}

不隱藏navigationbar的ViewController代碼如下:

-(void)viewWillAppear:(BOOL)animated{

[super viewWillAppear:animated];

[self.navigationController setNavigationBarHidden:NO animated:YES];

}

附上使用- (void)setNavigationBarHidden:(BOOL)hidden animated:(BOOL)animated的效果圖:


附上使用navigationController.navigationBar.hidden的效果對比:


demo項目地址:https://github.com/CharmingLee/FullscreenPopGesture.git

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市市埋,隨后出現(xiàn)的幾起案子黎泣,更是在濱河造成了極大的恐慌,老刑警劉巖缤谎,帶你破解...
    沈念sama閱讀 206,968評論 6 482
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件抒倚,死亡現(xiàn)場離奇詭異,居然都是意外死亡坷澡,警方通過查閱死者的電腦和手機托呕,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 88,601評論 2 382
  • 文/潘曉璐 我一進(jìn)店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來频敛,“玉大人项郊,你說我怎么就攤上這事≌遄” “怎么了着降?”我有些...
    開封第一講書人閱讀 153,220評論 0 344
  • 文/不壞的土叔 我叫張陵,是天一觀的道長汁展。 經(jīng)常有香客問我鹊碍,道長,這世上最難降的妖魔是什么食绿? 我笑而不...
    開封第一講書人閱讀 55,416評論 1 279
  • 正文 為了忘掉前任侈咕,我火速辦了婚禮,結(jié)果婚禮上器紧,老公的妹妹穿的比我還像新娘耀销。我一直安慰自己,他們只是感情好铲汪,可當(dāng)我...
    茶點故事閱讀 64,425評論 5 374
  • 文/花漫 我一把揭開白布熊尉。 她就那樣靜靜地躺著,像睡著了一般掌腰。 火紅的嫁衣襯著肌膚如雪狰住。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 49,144評論 1 285
  • 那天齿梁,我揣著相機與錄音催植,去河邊找鬼肮蛹。 笑死,一個胖子當(dāng)著我的面吹牛创南,可吹牛的內(nèi)容都是我干的伦忠。 我是一名探鬼主播,決...
    沈念sama閱讀 38,432評論 3 401
  • 文/蒼蘭香墨 我猛地睜開眼稿辙,長吁一口氣:“原來是場噩夢啊……” “哼昆码!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起邻储,我...
    開封第一講書人閱讀 37,088評論 0 261
  • 序言:老撾萬榮一對情侶失蹤赋咽,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后芥备,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體冬耿,經(jīng)...
    沈念sama閱讀 43,586評論 1 300
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 36,028評論 2 325
  • 正文 我和宋清朗相戀三年萌壳,在試婚紗的時候發(fā)現(xiàn)自己被綠了亦镶。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 38,137評論 1 334
  • 序言:一個原本活蹦亂跳的男人離奇死亡袱瓮,死狀恐怖缤骨,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情尺借,我是刑警寧澤绊起,帶...
    沈念sama閱讀 33,783評論 4 324
  • 正文 年R本政府宣布,位于F島的核電站燎斩,受9級特大地震影響虱歪,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜栅表,卻給世界環(huán)境...
    茶點故事閱讀 39,343評論 3 307
  • 文/蒙蒙 一笋鄙、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧怪瓶,春花似錦萧落、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,333評論 0 19
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至敛滋,卻和暖如春许布,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背绎晃。 一陣腳步聲響...
    開封第一講書人閱讀 31,559評論 1 262
  • 我被黑心中介騙來泰國打工爹脾, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留帖旨,地道東北人。 一個月前我還...
    沈念sama閱讀 45,595評論 2 355
  • 正文 我出身青樓灵妨,卻偏偏與公主長得像,于是被迫代替她去往敵國和親落竹。 傳聞我的和親對象是個殘疾皇子泌霍,可洞房花燭夜當(dāng)晚...
    茶點故事閱讀 42,901評論 2 345

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