欢迎来到代码驿站!

iOS代码

当前位置:首页 > 移动开发 > iOS代码

IOS 中UIKit-UIPageControl利用delegate定位圆点位置

时间:2021-01-16 12:31:37|栏目:iOS代码|点击:

IOS 中UIKit-UIPageControl利用delegate定位圆点位置

在UIScrollView中会添加UIPageControl作为页码标识,可以让用户清楚的知道当前的页数。我们需要优化的一点是让pageControl的小圆点精确的跟着scrollView而定位。我们先来看一下效果图:

我们发现,当图片拖动不到一半的时候,pageControl的圆点定位到前一张图,图片拖动超过一半的时候,定位到下一张图。这里就需要四舍五入的计算了。

我们可以利用协议 delegate 去做这件事情。

首先,我们要为当前我们设置的这个scrollView添加代理:

scrollView.delegate = self; 

这里必须要让当前类去遵守 UIScrollViewDelegate 协议。

在 UIScrollViewDelegate 中,有这么一个方法,只要scrollView滚动就可以触发。我们可以在这个方法中去实现。

- (void)scrollViewDidScroll:(UIScrollView *)scrollView 
{ 
  // 用水平移动的距离除以宽度等于页数,但是并没有精确 
  double page = scrollView.contentOffset.x / scrollView.width; 
   
  // 采用四舍五入来确定更靠近哪一页,并设置(下面是一个四舍五入的小技巧,+ 0.5 再向下取整即可) 
  self.pageControl.currentPage = (int)(page + 0.5); 
} 

分析举例说明:(page = 0 为第一张图片,page = 1 为第二张图片,以此类推)

page = 0.95,更接近第二张图片,page + 0.5 = 1.45,(int)1.45 = 1
page = 1.21,更接近第二张图片,page + 0.5 = 1.71,(int)1.71 = 1
page = 1.67,更接近第三张图片,page + 0.5 = 2.17,(int)2.17 = 2
page = 2.11,更接近第三张图片,page + 0.5 = 2.61,(int)2.61 = 2

另外注意的是,强制转化为int类型是向下取整,即省略小数点后的所有数字。

感谢阅读,希望能帮助到大家,谢谢大家对本站的支持!

上一篇:IOS 开发之swift中UIView的扩展使用的实例

栏    目:iOS代码

下一篇:iOS通过代理逆向传值的方式详解

本文标题:IOS 中UIKit-UIPageControl利用delegate定位圆点位置

本文地址:http://www.codeinn.net/misctech/46170.html

推荐教程

广告投放 | 联系我们 | 版权申明

重要申明:本站所有的文章、图片、评论等,均由网友发表或上传并维护或收集自网络,属个人行为,与本站立场无关。

如果侵犯了您的权利,请与我们联系,我们将在24小时内进行处理、任何非本站因素导致的法律后果,本站均不负任何责任。

联系QQ:914707363 | 邮箱:codeinn#126.com(#换成@)

Copyright © 2020 代码驿站 版权所有