iOS开发之UIScrollView控件详解

2020-01-18 15:59:01于丽

缩放相关


// 当缩放比例更改时调用
- (void)scrollViewDidZoom:(UIScrollView *)scrollView;

// 参与缩放的子视图
- (UIView *)viewForZoomingInScrollView:(UIScrollView *)scrollView;

// 将要开始缩放时调用
- (void)scrollViewWillBeginZooming:(UIScrollView *)scrollView withView:(UIView *)view;

// 已经结束缩放时调用
- (void)scrollViewDidEndZooming:(UIScrollView *)scrollView withView:(UIView *)view atScale:(CGFloat)scale;

常见需求原理解析

导航栏半透明效果

ios,uiscrollview详解,uiscrollview,ios开发uiscrollview

原理解析:

默认情况下,在有UINavigationBar存在时,系统为了防止UIScrollView被遮挡,其contentInset和scrollIndicatorInsets属性都会被设置为UIEdgeInsetsMake(64, 0, 0, 0);在有UITabBar存在时,系统为了防止UIScrollView被遮挡,其contentInset和scrollIndicatorInsets属性都会被设置为UIEdgeInsetsMake(0, 0, 49, 0)

因此,为了使用此种半透明效果,可以直接将UIScrollView的frame设置为整个屏幕的大小

    注1: 系统只在UIScrollView是控制器视图的第0个子视图时才会自动修改contentInset和scrollIndicatorInsets属性

    注2: 如果不想让系统自动修改contentInset和scrollIndicatorInsets属性,可以设置self.automaticallyAdjustsScrollViewInsets = NO;

控件悬停

ios,uiscrollview详解,uiscrollview,ios开发uiscrollview

原理解析:

    方式一: 在悬停位置放置一个与待悬停控件相同的控件,通过-scrollViewDidScroll:代理方法跟踪contentOffset的的变化,当不满足悬停条件时,将该控件hidden属性设置为YES;当满足悬停条件时,将该控件hidden属性设置为NO

    方式二: 通过-scrollViewDidScroll:代理方法跟踪contentOffset的的变化,当不满足悬停条件时,待悬停控件属于UIScrollView的子视图,当满足悬停条件时,待悬停控件属于UIScrollView的父视图的子视图


// 以"方式二"为例
- (void)scrollViewDidScroll:(UIScrollView *)scrollView
{
 if (scrollView.contentOffset.y >= 100)
 {
  CGRect rect = label.frame;
  rect.origin.y = 0;
  label.frame = rect;

  [self.view addSubview:label];
 }
 else
 {
  CGRect rect = label.frame;
  rect.origin.y = 100;
  label.frame = rect;

  [scrollView addSubview:label];
 }
}

下拉头部图片放大

ios,uiscrollview详解,uiscrollview,ios开发uiscrollview