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

 更新时间:2018年01月11日 10:25:59   作者:夕阳下的守望者  
下面小编就为大家分享一篇iOS开发上下滑动UIScrollview隐藏或者显示导航栏的实例,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧

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

1.iOS8之后系统有一个属性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开发上下滑动UIScrollview隐藏或者显示导航栏的实例就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持脚本之家。

相关文章

  • 详解IOS图片压缩处理

    详解IOS图片压缩处理

    在日常IOS开发中,感觉图片尺寸太大,想压缩成小一点像素的。那么该如何做呢?本文通过“压缩”两个概念及实例来告诉大家如何进行图片压缩处理才是最好的。
    2016-07-07
  • iOS开发商品页中banner中点击查看图片

    iOS开发商品页中banner中点击查看图片

    本文文章给大家列出了关于iOS开发商品页中banner中点击查看图片功能源码,有兴趣的朋友参考下吧。
    2018-02-02
  • iOS给图片添加滤镜&使用openGLES动态渲染图片详解及实例

    iOS给图片添加滤镜&使用openGLES动态渲染图片详解及实例

    这篇文章主要介绍了iOS给图片添加滤镜&使用openGLES动态渲染图片详解及实例的相关资料,需要的朋友可以参考下
    2016-10-10
  • IOS网络请求之NSURLSession使用详解

    IOS网络请求之NSURLSession使用详解

    这篇文章主要介绍了IOS网络请求之NSURLSession使用详解,今天使用NSURLConnection分别实现了get、post、表单提交、文件上传、文件下载,有兴趣的可以了解一下。
    2017-02-02
  • ios实现简易队列

    ios实现简易队列

    这篇文章主要为大家详细介绍了ios实现简易队列,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2020-02-02
  • 解析iOS10中的极光推送消息的适配

    解析iOS10中的极光推送消息的适配

    这篇文章主要介绍了解析iOS10中的极光推送消息的适配的相关资料,我们需要先安装Xcode8.0版本,接下来本文分步骤详细给大家介绍,需要的朋友可以参考下
    2016-09-09
  • IOS实现微信朋友圈相册评论界面的翻转过渡动画

    IOS实现微信朋友圈相册评论界面的翻转过渡动画

    现在很多人几乎每天都离不开微信,大家有没有发现在点开微信相册的时候,想要在相册图片界面跳转查看点赞和评论时,微信会采用界面翻转的过渡动画来跳转到评论界面,点击完成又会翻转回到图片界面,这不同于一般的导航界面滑动动画,于是学着做了一下,有需要一起看看。
    2016-08-08
  • IOS开发Swift 与 OC相互调用详解

    IOS开发Swift 与 OC相互调用详解

    这篇文章主要为大家介绍了IOS开发Swift 与 OC相互调用示例详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2022-08-08
  • iOS中的缓存计算和清除完整实例代码

    iOS中的缓存计算和清除完整实例代码

    iOS设备使用时间长了,一些应用程序的缓存垃圾文件就会越存越多,这些文件堆积多了就会拖慢系统速度。因此,小编整理了iOS中的缓存计算和清除实例
    2017-04-04
  • Objective-C实现身份证验证的方法示例

    Objective-C实现身份证验证的方法示例

    这篇文章主要给大家分享了Objective-C实现身份证验证的方法,文中给出了详细的示例代码,对大家具有一定的参考价值,需要的朋友们下面来一起看看吧。
    2017-03-03

最新评论