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

ios开发 截屏带上状态栏_取整

我们发现。当图片拖动不到一半的时候,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类型是向下取整,即省略小数点后的全部数字。


转载于:


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

ios开发 截屏带上状态栏_取整

我们发现。当图片拖动不到一半的时候,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类型是向下取整,即省略小数点后的全部数字。