iOS疯狂详解之UIScrollerView滚动方向判断
2014-12-10 15:48
555 查看
PushListView.h
@interface PushListView : UIView<UITableViewDelegate,UITableViewDataSource
{
CGFloat contentOffsetY;
CGFloat oldContentOffsetY;
CGFloat newContentOffsetY;
}
...............................
PushListView.m
//开始拖拽视图
- (void)scrollViewWillBeginDragging:(UIScrollView *)scrollView
{
contentOffsetY = scrollView.contentOffset.y;
}
// 滚动时调用此方法(手指离开屏幕后)
- (void)scrollViewDidScroll:(UIScrollView *)scrollView
{
//NSLog(@"scrollView.contentOffset:%f, %f", scrollView.contentOffset.x, scrollView.contentOffset.y);
newContentOffsetY = scrollView.contentOffset.y;
if (newContentOffsetY >
oldContentOffsetY && oldContentOffsetY > contentOffsetY) {
// 向上滚动
NSLog(@"up");
} else if (newContentOffsetY <
oldContentOffsetY && oldContentOffsetY < contentOffsetY) {
// 向下滚动
NSLog(@"down");
} else {
NSLog(@"dragging");
}
if (scrollView.dragging) { // 拖拽
NSLog(@"scrollView.dragging");
NSLog(@"contentOffsetY: %f",
contentOffsetY);
NSLog(@"newContentOffsetY: %f", scrollView.contentOffset.y);
if ((scrollView.contentOffset.y -
contentOffsetY) > 5.0f) { // 向上拖拽
// 隐藏导航栏和选项栏
// [self layoutView];
[_viewController.navigationController
setNavigationBarHidden:YES animated:YES];
//[_viewController.navigationController setToolbarHidden:!hidden animated:YES];
_viewController.tabBarController.tabBar.hidden =
YES;
} else if ((contentOffsetY - scrollView.contentOffset.y) >
5.0f) { // 向下拖拽
// 显示导航栏和选项栏
//[self layoutView];
[_viewController.navigationController
setNavigationBarHidden:NO animated:YES];
//[_viewController.navigationController setToolbarHidden:NO animated:YES];
_viewController.tabBarController.tabBar.hidden =
NO;
} else {
}
}
}
// 完成拖拽(滚动停止时调用此方法,手指离开屏幕前)
- (void)scrollViewDidEndDragging:(UIScrollView *)scrollView willDecelerate:(BOOL)decelerate
{
// NSLog(@"scrollViewDidEndDragging");
oldContentOffsetY = scrollView.contentOffset.y;
}
@interface PushListView : UIView<UITableViewDelegate,UITableViewDataSource
{
CGFloat contentOffsetY;
CGFloat oldContentOffsetY;
CGFloat newContentOffsetY;
}
...............................
PushListView.m
//开始拖拽视图
- (void)scrollViewWillBeginDragging:(UIScrollView *)scrollView
{
contentOffsetY = scrollView.contentOffset.y;
}
// 滚动时调用此方法(手指离开屏幕后)
- (void)scrollViewDidScroll:(UIScrollView *)scrollView
{
//NSLog(@"scrollView.contentOffset:%f, %f", scrollView.contentOffset.x, scrollView.contentOffset.y);
newContentOffsetY = scrollView.contentOffset.y;
if (newContentOffsetY >
oldContentOffsetY && oldContentOffsetY > contentOffsetY) {
// 向上滚动
NSLog(@"up");
} else if (newContentOffsetY <
oldContentOffsetY && oldContentOffsetY < contentOffsetY) {
// 向下滚动
NSLog(@"down");
} else {
NSLog(@"dragging");
}
if (scrollView.dragging) { // 拖拽
NSLog(@"scrollView.dragging");
NSLog(@"contentOffsetY: %f",
contentOffsetY);
NSLog(@"newContentOffsetY: %f", scrollView.contentOffset.y);
if ((scrollView.contentOffset.y -
contentOffsetY) > 5.0f) { // 向上拖拽
// 隐藏导航栏和选项栏
// [self layoutView];
[_viewController.navigationController
setNavigationBarHidden:YES animated:YES];
//[_viewController.navigationController setToolbarHidden:!hidden animated:YES];
_viewController.tabBarController.tabBar.hidden =
YES;
} else if ((contentOffsetY - scrollView.contentOffset.y) >
5.0f) { // 向下拖拽
// 显示导航栏和选项栏
//[self layoutView];
[_viewController.navigationController
setNavigationBarHidden:NO animated:YES];
//[_viewController.navigationController setToolbarHidden:NO animated:YES];
_viewController.tabBarController.tabBar.hidden =
NO;
} else {
}
}
}
// 完成拖拽(滚动停止时调用此方法,手指离开屏幕前)
- (void)scrollViewDidEndDragging:(UIScrollView *)scrollView willDecelerate:(BOOL)decelerate
{
// NSLog(@"scrollViewDidEndDragging");
oldContentOffsetY = scrollView.contentOffset.y;
}
相关文章推荐
- UIScrollerView滚动方向判断
- iOS开发之UITableView , UICollectionView, UIScrollview,根据代理判断页面滚动方向。
- iOS开发之UITableView , UICollectionView, UIScrollview,根据代理判断页面滚动方向。
- IOS中判断UIScrollerView滑动的方向
- 【转载】UIScrollerView滚动方向判断
- UIScrollerView滚动方向判断
- ios之UIScrollerView滚动视图
- ios中怎么判断是否滚动到tableview的最后一行
- iOS疯狂详解之TableView以及TableViewCell背景设置
- iOS开发 - ScrollView滚动时怎么判断滚动停止及滚动的方向
- ios开发之检测UIScrollView的滚动方向
- iOS之判断滚动视图的滚动方向
- [ios]ios开发之检测UIScrollView的滚动方向 【转】
- RecyclerView实现滚动方向判断(上下监听)
- ios之UIScrollerView滚动视图总结
- ios之UIScrollerView滚动视图
- ios中uiscrollerview属性和方法详解
- Android WebView 滚动方向判断同时底部导航栏隐藏或显示(动画效果)
- iOS疯狂详解之视频播放MPMoviePlayerViewController
- iOS疯狂详解之tableview编辑添加删除