iOS開發(fā)上下滑動UIScrollview隱藏或者顯示導航欄的實例
一、好多App都有上下滑動UIScrollview隱藏或者顯示導航欄,在這里我說說我覺得有用的幾種方法:
1.iOS8之后系統(tǒng)有一個屬性hidesBarsOnSwipe
Objective-C代碼如下
self.navigationController.hidesBarsOnSwipe = YES;
swift代碼如下
self.navigationController?.hidesBarsOnSwipe = true
當使用以上代碼時,可以達到效果
2.使用UIScrollViewDelegate一個代理方法
Objective-C代碼如下
- (void)scrollViewDidScroll:(UIScrollView *)scrollView { //scrollView已經有拖拽手勢,直接拿到scrollView的拖拽手勢 UIPanGestureRecognizer *pan = scrollView.panGestureRecognizer; //獲取到拖拽的速度 >0 向下拖動 <0 向上拖動 CGFloat velocity = [pan velocityInView:scrollView].y; if (velocity <- 5) { //向上拖動,隱藏導航欄 [self.navigationController setNavigationBarHidden:YES animated:YES]; }else if (velocity > 5) { //向下拖動,顯示導航欄 [self.navigationController setNavigationBarHidden:NO animated:YES]; }else if(velocity == 0){ //停止拖拽 } }
swift代碼如下
func scrollViewDidScroll(scrollView: UIScrollView) { let pan = scrollView.panGestureRecognizer let velocity = pan.velocityInView(scrollView).y if velocity < -5 { self.navigationController?.setNavigationBarHidden(true, animated: true) } else if velocity > 5 { self.navigationController?.setNavigationBarHidden(false, animated: true) } }
這種效果最好
3.使用UIScrollViewDelegate另一個代理方法
Objective-C代碼如下
- (void)scrollViewWillEndDragging:(UIScrollView *)scrollView withVelocity:(CGPoint)velocity targetContentOffset:(inout CGPoint *)targetContentOffset</span>
{ if (velocity.y > 0.0) { [self.navigationController setNavigationBarHidden:YES animated:YES]; } else if (velocity.y < 0.0){ [self.navigationController setNavigationBarHidden:NO animated:YES]; } }
swift代碼如下
func scrollViewWillEndDragging(scrollView: UIScrollView, withVelocity velocity: CGPoint, targetContentOffset: UnsafeMutablePointer<CGPoint>) { if velocity.y > 0 { self.navigationController?.setNavigationBarHidden(true, animated: true) } else if velocity.y < 0 { self.navigationController?.setNavigationBarHidden(false, animated: true) } }
二、總結:三種方法都可以,我個人覺得第二種方法效果最好,大家可以學習借鑒一下
以上這篇iOS開發(fā)上下滑動UIScrollview隱藏或者顯示導航欄的實例就是小編分享給大家的全部內容了,希望能給大家一個參考,也希望大家多多支持腳本之家。
相關文章
Flutter Widgets粘合劑CustomScrollView NestedScrollVie
這篇文章主要為大家介紹了Flutter Widgets粘合劑CustomScrollView NestedScrollView滾動控件示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪2022-11-11iOS中使用UISearchBar控件限制輸入字數的實現方法
這篇文章主要介紹了iOS中使用UISearchBar控件限制輸入字數的實現方法的相關資料,需要的朋友可以參考下2016-08-08