服务器之家

服务器之家 > 正文

iOS开发上下滑动UIScrollview隐藏或者显示导航栏的实例

时间:2021-04-15 15:50     来源/作者:夕阳下的守望者

一、好多App都有上下滑动UIScrollview隐藏或者显示导航栏,在这里我说说我觉得有用的几种方法:

1.iOS8之后系统有一个属性hidesBarsOnSwipe

Objective-C代码如下

?
1
self.navigationController.hidesBarsOnSwipe = YES;

swift代码如下

?
1
self.navigationController?.hidesBarsOnSwipe = true

当使用以上代码时,可以达到效果

2.使用UIScrollViewDelegate一个代理方法

Objective-C代码如下

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
- (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代码如下

?
1
2
3
4
5
6
7
8
9
10
11
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代码如下

?
1
- (void)scrollViewWillEndDragging:(UIScrollView *)scrollView withVelocity:(CGPoint)velocity targetContentOffset:(inout CGPoint *)targetContentOffset</span>
?
1
2
3
4
5
6
7
{
 if (velocity.y > 0.0) {
  [self.navigationController setNavigationBarHidden:YES animated:YES];
 } else if (velocity.y < 0.0){
  [self.navigationController setNavigationBarHidden:NO animated:YES];
 }
}

swift代码如下

?
1
2
3
4
5
6
7
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开发上下滑动UIScrollview隐藏或者显示导航栏的实例就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持服务器之家。

原文链接:http://blog.csdn.net/wgl_happy/article/details/51791937

相关文章

热门资讯

2020微信伤感网名听哭了 让对方看到心疼的伤感网名大全
2020微信伤感网名听哭了 让对方看到心疼的伤感网名大全 2019-12-26
yue是什么意思 网络流行语yue了是什么梗
yue是什么意思 网络流行语yue了是什么梗 2020-10-11
背刺什么意思 网络词语背刺是什么梗
背刺什么意思 网络词语背刺是什么梗 2020-05-22
Intellij idea2020永久破解,亲测可用!!!
Intellij idea2020永久破解,亲测可用!!! 2020-07-29
苹果12mini价格表官网报价 iPhone12mini全版本价格汇总
苹果12mini价格表官网报价 iPhone12mini全版本价格汇总 2020-11-13
返回顶部