iOS自定义UIScrollView的滚动条实例代码

2020-01-18 21:43:56于海丽

UIScrollView有自己默认的ios/197699.html">滚动条,可设置隐藏和显示,但是有时候这个默认的滚动条没办法满足我们的需求,那这时候只能通过自定义来实现了。 实现自定义滚动条需要解决的主要问题是:

在scrollview滚动的过程中如何改变滚动条的位置,进而确保滚动条和scrollView在相同时间内走完自己的位移,只要把这个问题解决好了,那我们就可以优雅的自定义滚动条了。

那如何解决这个滚动条的当前滚动位移呢?我们知道,UIScrollView有一个滚动范围,滚动条也有一个滚动范围,也就是说两者的最大的滚动位移是固定的,那要想两者在相同时间内走完自己的位移,只需要确保两者的当前滚动位移和总位移之比一致就行。也就是说:

scrollView的当前位移/scrollView的总位移=滚动条的当前位移/滚动条的总位移

得到这个关系后,想要知道滚动条的当前位移,就不是什么难事了。我们可以通过UIScrollView的代理方法获取scrollview的当前滚动位移,scrollview的总位移和滚动条的总位移是固定的,那显然我们可以方便的得出滚动条的当前位移,这样,得到了滚动条的当前位移,我们就可以通过改变滚动条的frame,进而实现让滚动条跟随scrollview滚动。

但是这里需要注意一点,因为这个位移是相对位移,所以在修改滚动条的frame时,要记得加上滚动条距离相对的参考系的左边距离,这样才是其真正的位移。比如现在滚动条的x是从屏幕左边15开始的,滚动条的滚动范围是屏幕宽度减去30,那么当你以屏幕宽度减去30这个数值作为滚动条的滚动总位移,进而算出滚动条的当前位移时,需要加上距离左边的15才是滚动条真正的位移。

接下来看一下代码的具体实现吧:

一、创建scrollview:(记得签代理UIScrollViewDelegate)


-(UIScrollView *)scrollView{
  if (!_scrollView) {
    _scrollView = [[UIScrollView alloc] initWithFrame:CGRectMake(0, 164, self.view.frame.size.width, 233)];
    _scrollView.delegate = self;
    _scrollView.scrollEnabled = YES;
    _scrollView.bounces = NO;
    _scrollView.showsHorizontalScrollIndicator=NO;
    _scrollView.layer.shadowColor = [UIColor redColor].CGColor;//shadowColor阴影颜色
    _scrollView.layer.shadowOffset = CGSizeMake(0,0);//shadowOffset阴影偏移,x向右偏移,y向下偏移
    _scrollView.layer.shadowOpacity = 0.5;//阴影透明度,默认0
    _scrollView.layer.shadowRadius = 3;//阴影半径,默认3

  }
  return _scrollView;
}

二、创建自定义的滚动条以及在scrollview上加点内容:


-(void)loadView{
  [super loadView];
  [self.view addSubview:self.scrollView];

  slideBackView=[[UIView alloc] initWithFrame:CGRectMake(15, _scrollView.frame.origin.y+_scrollView.frame.size.height+20, self.view.frame.size.width-30, 8)];
  [self.view addSubview:slideBackView];
  slideBackView.backgroundColor = [UIColor colorWithRed:0.91 green:0.91 blue:0.91 alpha:1.00];
  slideBackView.layer.cornerRadius = 4;


  sliderView = [[UIView alloc] init];
  [self.view addSubview:sliderView];
  sliderView.frame=CGRectMake(slideBackView.frame.origin.x, slideBackView.frame.origin.y+(slideBackView.frame.size.height-7 )/2, 40 , 7 );
  sliderView.backgroundColor =[UIColor colorWithRed:0.12 green:0.72 blue:0.88 alpha:1.00];
  sliderView.layer.cornerRadius = 3.5;

 NSArray *textDesArr=@[@"• 产品战略规划:市场目标、用户目标、关键成功要素分析、管理和运用自己的资源来达成目标n• 产品战略实施:有损原则、平衡原则、聚焦原则n• 产品需求文档:实例讲解,牛逼的需求文档是怎么诞生的n• 主动:战略思考、资源争取n• 推动:项目立项、迭代跟踪n• 沟通:上传下达、思想一统n• 平衡:各方协调、跨部沟通n• 把控:管理得法、取舍有道",
          @"• 用户思维:具体案例解析n• 运营思维:具体案例解析n• 数据思维:具体案例解析n• 产品经理的用研能力模型n• 用户研究基本概念解析n• 用研基础搭建及建设n• 用研人员分工及工作职责细分"
          @"• 常用用户研究方法详解n• 桌面研究、定性研究、定量研究三种方法举例讲解及详细步骤解析n• 卡诺模型n• 战略级的市场及用户研究n• 以科学的方法在产品整个生命周期中进行“研究”",
          @"• 品生命周期用户研究侧重点以及研究方法解读n• 产品用研规划建立n• 在产品不同生命周期,侧重不同用研方法,更准确进行产品迭代",
          @"• 格局:大格局思维,聚焦做实事n• 决策:让琐碎的运营变有趣,“舍得”之道n• owner精神:有狼性n• 敏锐:“细节”出真知n• 商业素养",
          @"• 高情商:做个让人感觉“舒适”的资深运营n• 凝聚力:1+1>2,善用团队用人所长,没有完美的个人,只有优秀的团队n• 影响力:在互联网领域成为运营专家,沉淀