scrollView实现基础中心点缩放及与UIPageControl结合使用
来自: http://www.cnblogs.com/xueyao/p/5185794.html
一般来说scrollView与UIPageControl都是结合使用,因为在使用滚动视图的时候 ,使用UIPageControl,用户可以 清楚 的明白显示的内容有多少页,如果 没有的话,总不能让用户一个个的去数。用户体验效果不理想。
一般来说,在滑动scrollView的时候,UIPageControl的选中点的位置也会有相应的变化。当然,反之来说,改变选中点的位置,相应的scrollView显示的内容也会产生变化 。
因为我这边需要实现的效果是:最后一张向后滑动之后,会自动跳到第一张显示的内容。如果想解决这个,只需要在第一张之前添加一个最后一张的图片。具体代码就不展示了。关于改变scrollView,来改变UIPageControl当前的值。
具体的代码实现。
//在滚动视图停止滚动时,改变pageControl上面点的位置 - (void)scrollViewDidEndDecelerating:(UIScrollView *)scrollView{ //获取滚动视图当前的偏移量 CGPoint offset = scrollView.contentOffset; //计算偏移量与屏幕宽度的关系,也就是偏移了多少倍 NSInteger page = offset.x / kWidth; self.pageControl.currentPage = page - 1 < 0 ? 9 : page - 1; }
那如果改变UIPageControl当前的值,来达到改变scrollView的内容呢。通过对所添加的UIPageControll来设置触发方法为click
具体代码展示。
//通过点圆点的位置来改变视图的变化 - (void)click:(UIPageControl *)pageControl{ self.scrollView.contentOffset = CGPointMake(kWidth * (pageControl.currentPage + 1), 0); }
而对于scrollView来说,如果只设置了一个scrollView的话,我们所达到的效果是不理想的,因为在缩放的同时,也会改变本身的contentSize,所以所达到的效果是不会理想的,也会有很严重的恶劣感。当然,想解决这个,也非常的容易 ,只需要在scrollView上添加一个子视图,一个等大的scrollView,就称呼为小scrollView,小scrollView用来进行缩放处理,而大scrollView来进行滚动。这样一来 ,就不会改变大scrollView整体的contentSize.
小scrollView缩放的具体代码展示。
//必须设置缩放比例以及设置代理对象 smallScroll.delegate = self; smallScroll.minimumZoomScale = 0.5; smallScroll.maximumZoomScale = 2.0;
//指定缩放的视图 - (UIView *)viewForZoomingInScrollView:(UIScrollView *)scrollView{ //return [scrollView.subviews firstObject]; return [scrollView.subviews objectAtIndex:0]; } //中心点缩放 - (void)scrollViewDidZoom:(UIScrollView *)scrollView{ UIImageView *imageV = [scrollView.subviews firstObject]; if (scrollView.zoomScale <= 1.0) { imageV.center = CGPointMake(kWidth / 2, kHeight / 2); } }
因为是对小scrollView进行缩放,所以 在进行缩放前,必须要指定进行缩放的视图是哪一个。 所以 大srcollView的第一个子视图就是我想要进行缩放的视图。
当然,到了这个地步 ,又发现了一个新的问题,滑动到下一页后,再返回刚刚缩放过的地方,发现还是改变后的图片,并没有恢复成原样。发现问题就应该合理的解决好问题。
//减速结束,也就是停止滚动 - (void)scrollViewDidEndDecelerating:(UIScrollView *)scrollView{ NSLog(@"结束滚动"); // 先从负责滚动的⼤scrollView找到他的⼦子视图 for (UIScrollView *sView in scrollView.subviews){ // 在根据⼦子类的对象类型进⾏行判断 if ([sView isKindOfClass:[UIScrollView class]]){ // 把视图的尺⼨寸恢复到原有尺⼨寸 sView.zoomScale = 1.0; } } }
当然,使用这些方法的前提就是设置好代理.Delegate。
做到这个地方,基础的都做完了。不管怎么说。合理的利用方法。发现问题并解决好问题,才是一个新手应该注意的地方。一个方法的使用,并不是单纯的只有一个使用方法,多种思路就可能会有不同的解决方式 。scrollView是滚动视图,使用还是比较简单,日常使用还是挺频繁的,而基于scrollView的 UITableView才是日后使用的重点。 api文档是可以很好的帮助解决了个个方法的介绍。虽然全英文,可能会看不懂。当不看,你永远不懂,所以要慢慢的,尝试了解一点。会一点是一点。