IOS實現上滑隱藏NvaigtionBar而下拉則顯示效果_IOS

來源:互聯網
上載者:User

先看看原APP的效果

實現過程

主要是給view中的滾動視圖添加一個KVO來監視它的滑動,再根據它的offset來做一下操作,下面是代碼

[myTableView addObserver:self forKeyPath:@"contentOffset" options:NSKeyValueObservingOptionOld|NSKeyValueObservingOptionNew context:nil];

擷取tableViewcontentOffset 之後再根據具體需求來實現邏輯判斷

-(void)observeValueForKeyPath:(NSString *)keyPath ofObject:(id)object change:(NSDictionary<NSString *,id> *)change context:(void *)context { if ([object isEqual:myTableView] && [keyPath isEqualToString:@"contentOffset"]) {  //擷取新值舊值  CGFloat newY = [change[@"new"] CGPointValue].y;  CGFloat oldY = [change[@"old"] CGPointValue].y;  float i = newY - oldY;//下拉是新值小於舊值的,所以i<0 是下拉 i>0 是上滑   NSLog(@"%f",myTableView.contentOffset.y);  if (myTableView.contentOffset.y > -64 && myTableView.contentOffset.y <= 24) {//邊界條件,此處不精確   if (i <= 0 && _isHide == NO && self.navigationController.navigationBar.frame.origin.y == 20){    //下拉+bar 已經顯示的狀態,不再移動    return;   }   _isHide = NO;   //設定navigationbar 的frame 使他根據tableView來滑動   self.navigationController.navigationBar.frame = CGRectMake(0, -44 - myTableView.contentOffset.y, self.view.bounds.size.width, 44);   //控制透明度   self.navigationController.navigationBar.alpha = -myTableView.contentOffset.y/64;  }else if (myTableView.contentOffset.y > 24) {   if (i > 10) {//更改數值大小可以控制觸發 navigation bar 的滑動速度    _isHide = YES;   }else if(i < -10) {    _isHide = NO;   }  }  [self.navigationController setNavigationBarHidden:_isHide animated:YES]; }}

完成效果圖

總結

其實這個效果實現起來確實沒有什麼難度,寫這個主要是給大家看一下我的實現過程與思路,希望可以幫到大家。如果有疑問可以留言交流,謝謝大家對雲棲社區的支援。

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.