IOS实现上滑隐藏NvaigtionBar而下拉则显示效果
2016-09-01 14:42
316 查看
先看看原APP的效果
实现过程
主要是给
view中的滚动视图添加一个
KVO来监视它的滑动,再根据它的
offset来做一下操作,下面是代码
[myTableView addObserver:self forKeyPath:@"contentOffset" options:NSKeyValueObservingOptionOld|NSKeyValueObservingOptionNew context:nil];
获取
tableView的
contentOffset之后再根据具体需求来实现逻辑判断
-(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]; } }
完成效果图
总结
其实这个效果实现起来确实没有什么难度,写这个主要是给大家看一下我的实现过程与思路,希望可以帮到大家。如果有疑问可以留言交流,谢谢大家对脚本之家的支持。
您可能感兴趣的文章:
相关文章推荐
- iOS---实现简书和知乎的上滑隐藏导航栏下拉显示导航栏效果
- iOS---实现简书和知乎的上滑隐藏导航栏下拉显示导航栏效果
- Winform中如何实现下拉树效果(类似于ComboBox下拉时显示的是树状结构)
- iOS 类似QQ空间表视图下拉头部视图放大效果实现
- iOS 仿 UC 浏览器个人中心 (下拉实现果冻效果)
- iosselect:一个js picker项目,在H5中实现IOS的select下拉框效果
- jqm配合iscroll实现的上拉显示更多下拉刷新效果
- 《React-Native系列》23、 js实现下拉刷新效果(Android和iOS通用)
- 《React-Native系列》23、 js实现下拉刷新效果(Android和iOS通用)
- iOS下拉tableView实现上面的图片放大效果
- 实现监听下拉具体达到显示和隐藏效果的js的核心代码
- [IOS]对UITableView的简单封装,实现了下拉放大头部图片的效果
- 仿IOS通讯录效果,实现获取手机通讯录、字母排序显示、搜索联系人、拨打电话
- iosselect:一个js picker项目,在H5中实现IOS的下拉效果
- 实现下拉刷新效果 IOS所有版本均可使用
- 137在搜索框中实现下拉列表效果(扩展知识:表格视图数据源为空数据时显示提示信息)
- iOS 相似QQ空间表视图下拉头部视图放大效果实现
- 实现ListView的弹性效果,下拉隐藏ToolBar(ActionBar),上拉显示ToolBar
- Android 仿IOS版QQ实现下拉刷新水滴的效果
- iosselect:一个js picker项目,在H5中实现IOS的select下拉框效果