全网整合营销服务商

电脑端+手机端+微信端=数据同步管理

免费咨询热线:400-708-3566

Swift实现可自定义分页宽度的UIScrollView

最近在开发新版的APP时需要一个可自定义分页宽度的图片轮播组件。刚开始自己觉得在这个万能的互联网上早就应该有一个大侠为我们封装好了,我只需要下载、拷贝、粘贴、修改一下代码就可以了。谁知一圈下来,不知道是自己没搜到,还是什么其它原因,根本就找不到。所以,一狠心就自己开干了。

我们先看一下需要的效果,如下图:

总起来说,所需要功能有如下几项:

  • 可自定义分页的宽度,并且在两边可以显示相邻两项的一部分,从而用户知道可以滑动;
  • 可以无限轮播;
  • 可以自动轮播。

对于无限轮播和自动轮播在网上一搜索一大把。这里我就不详细讲了,其原理就是第一页和最后一页对contentOffset做一下特殊处理,其它没有什么玄机。

而对于定义分页的宽度经过一番搜索之后实现的方法也基本上处于同一,原理如下图:

把所能滚动的视图的宽度定为所需要的宽度,并把它放入另外一个View中,同时把clipsToBounds设置为false,这样相邻的两个页面就会显示在ScrollView两边的空白地方,而不是被切除不显示。另外,如果能够让Scroll View的两边的空白地方也可以滑动,那么需要将View Enhancer的点击事件同时作用到Scroll View上。

Ok,既然原理都懂了,那么下手开干就不是问题了。代码我就不在这里贴了,可以去我的github上下载,如果喜欢别忘了star一下哦。

看一下示例是如何使用的:

class ScrollViewPagingDemoViewController: UIViewController

 override func viewDidLoad() {
 super.viewDidLoad()

 self.view.addSubview(scrollPagingView)

 // 添加你的Page view,如:
 let view1 = UIView(frame: CGRectZero)
 view1.backgroundColor = UIColor(red: 0xff/255.0, green: 0x2d/255.0, blue: 0x41/255.0, alpha: 1.0)
 view1.layer.borderColor = UIColor(red: 0xff/255.0, green: 0x2d/255.0, blue: 0x41/255.0, alpha: 1.0).CGColor
 view1.layer.borderWidth = 0.5
 view1.layer.cornerRadius = 5
 scrollPagingView.addPage(view1)

 let view2 = UIView(frame: CGRectZero)
 view2.backgroundColor = UIColor(red: 0x00/255.0, green: 0x7a/255.0, blue: 0xff/255.0, alpha: 1.0)
 view2.layer.borderColor = UIColor(red: 0x00/255.0, green: 0x7a/255.0, blue: 0xff/255.0, alpha: 1.0).CGColor
 view2.layer.borderWidth = 0.5
 view2.layer.cornerRadius = 5
 scrollPagingView.addPage(view2)

 let view3 = UIView(frame: CGRectZero)
 view3.backgroundColor = UIColor(red: 0x4b/255.0, green: 0xd9/255.0, blue: 0x64/255.0, alpha: 1.0)
 view3.layer.borderColor = UIColor(red: 0x4b/255.0, green: 0xd9/255.0, blue: 0x64/255.0, alpha: 1.0).CGColor
 view3.layer.borderWidth = 0.5
 view3.layer.cornerRadius = 5
 scrollPagingView.addPage(view3)

 let view4 = UIView(frame: CGRectZero)
 view4.backgroundColor = UIColor(red: 0xff/255.0, green: 0x96/255.0, blue: 0x00/255.0, alpha: 1.0)
 view4.layer.borderColor = UIColor(red: 0xff/255.0, green: 0x96/255.0, blue: 0x00/255.0, alpha: 1.0).CGColor
 view4.layer.borderWidth = 0.5
 view4.layer.cornerRadius = 5
 scrollPagingView.addPage(view4)

 // 用户点击事件,如果需要的话  
 let tapGesture = UITapGestureRecognizer(target:self, action: #selector(ScrollViewPagingDemoViewController.scrollViewTapAction(_:)))
 scrollPagingView.addGestureRecognizer(tapGesture)
 }

 override func viewWillLayoutSubviews() {
 super.viewWillLayoutSubviews()

 // 设置大小,并初始化setup方法必须调用
 self.scrollPagingView.frame = CGRect(x: 0, y: 100, width: self.view.bounds.width, height: 240)
 self.scrollPagingView.setup() 
 }

 private lazy var scrollPagingView: CDScrollPagingView = {
 let scrollPagingView = CDScrollPagingView()
 // 控制页与页之间的间隔,默认为10
 scrollPagingView.itemSpacing = 10.0
 // 是否显示分页指示器,默认显示
 scrollPagingView.showPageControl = true
 // 自动切换的时间间隔,默认为3s,0表示不自动切换
 scrollPagingView.timeInterval = 3.0
 return scrollPagingView
 }()

 func scrollViewTapAction(sender: CDScrollPagingView){
 if let curPage = scrollPagingView.currentPage() {
  let alertController = UIAlertController(title: "系统提示",
            message: "您点击第\\(curPage)页", preferredStyle: .Alert)
  let okAction = UIAlertAction(title: "Ok", style: .Default, handler: nil)
  alertController.addAction(okAction)
  self.presentViewController(alertController, animated: true, completion: nil)

 }
 }
}

需要说明的有以下几点:

  • 分页的宽度可以通过设置CDScrollPagingView.pageWidth的值大小来控制,默认为0.85即整个宽度的85%
  • 页与页之间的间隔可以通过CDScrollPagingView.itemSpacing来设置,默认值为10.0
  • 分页指示器可以控制是否显示,控制的参数为CDScrollPagingView.showPageControl
  • 自动轮播的时间间隔可以通过scrollPagingView.timeInterval来控制,默认为3s,如果设置为0表示不进行自动轮播

另外,如果想为每个页添加点击事件或者页面中控件需要添加事件处理是非常麻烦的,因为UIScrollView已经对事件做了处理,所以如果直接绑定事件处理的话会没有任何反应,这个也把我折腾了好久。不过,对于这种轮播控件的需求大部分应该是点击了某个页面后进行一些处理,因此CDScrollPagingView提供了一个方法currentPage()来获取当前是第几页,这样就可以根据这个值进行处理了。具体可以看上面的示例代码。

这个控件我也只是开发了最基础的一些功能,不过已经满足了自己APP的需要。后续如果需要可能还会需要增加一些动效。

如果感兴趣,大家可以到github下载。

P.S. 这个分页控件里面最少要有3个页面,否则会崩溃。


# Swift  # 分页  # UIScrollView  # iOS ScrollView实现自动布局的方法(适用Swift 3.0 )  # swift实现自动轮播图效果(UIScrollView+UIPageControl+Timer)  # Swift 如何让ScrollView滚动到具体某个位置  # 可以通过  # 默认为  # 我就  # 自定义  # 设置为  # 所需要  # 如下图  # 就可以  # 我也  # 就会  # 好了  # 在这个  # 我只  # 还会  # 没有任何  # 把我  # 要有  # 把它  # 没有什么 


相关文章: 专业制作网站的公司哪家好,建立一个公司网站的费用.有哪些部分,分别要多少钱?  建站之星Pro快速搭建教程:模板选择与功能配置指南  做企业网站制作流程,企业网站制作基本流程有哪些?  c++ stringstream用法详解_c++字符串与数字转换利器  宝塔建站无法访问?如何排查配置与端口问题?  如何快速搭建支持数据库操作的智能建站平台?  C++中引用和指针有什么区别?(代码说明)  如何用y主机助手快速搭建网站?  如何批量查询域名的建站时间记录?  网站设计制作企业有哪些,抖音官网主页怎么设置?  广东企业建站网站优化与SEO营销核心策略指南  如何快速上传建站程序避免常见错误?  制作网页的网站有哪些,电脑上怎么做网页?  建站之星如何快速更换网站模板?  开封网站制作公司,网络用语开封是什么意思?  建站10G流量真的够用吗?如何应对访问高峰?  建站主机无法访问?如何排查域名与服务器问题  如何选购建站域名与空间?自助平台全解析  小米网站链接制作教程,请问miui新增网页链接调用服务有什么用啊?  历史网站制作软件,华为如何找回被删除的网站?  建站之星手机一键生成:多端自适应+小程序开发快速建站指南  怎么制作网站设计模板图片,有电商商品详情页面的免费模板素材网站推荐吗?  可靠的网站设计制作软件,做网站设计需要什么样的电脑配置?  怎么用手机制作网站链接,dw怎么把手机适应页面变成网页?  香港服务器租用费用高吗?如何避免常见误区?  如何在橙子建站上传落地页?操作指南详解  如何在宝塔面板创建新站点?  北京网站制作费用多少,建立一个公司网站的费用.有哪些部分,分别要多少钱?  网站制作软件有哪些,制图软件有哪些?  如何用手机制作网站和网页,手机移动端的网站能制作成中英双语的吗?  php条件判断怎么写_ifelse和switchcase的使用区别【对比】  宝盒自助建站智能生成技巧:SEO优化与关键词设置指南  零基础网站服务器架设实战:轻量应用与域名解析配置指南  如何通过VPS建站实现广告与增值服务盈利?  上海网站制作网页,上海本地的生活网站有哪些?最好包括生活的各个方面的?  ppt制作免费网站有哪些,ppt模板免费下载网站?  如何高效配置香港服务器实现快速建站?  北京企业网站设计制作公司,北京铁路集团官方网站?  如何通过万网虚拟主机快速搭建网站?  如何快速使用云服务器搭建个人网站?  高性能网站服务器部署指南:稳定运行与安全配置优化方案  北京制作网站的公司,北京铁路集团官方网站?  网站制作专业公司有哪些,如何制作一个企业网站,建设网站的基本步骤有哪些?  ppt在线制作免费网站推荐,有什么下载免费的ppt模板网站?  如何在Tomcat中配置并部署网站项目?  网站制作企业,网站的banner和导航栏是指什么?  已有域名如何免费搭建网站?  如何配置WinSCP新建站点的密钥验证步骤?  在线制作视频网站免费,都有哪些好的动漫网站?  零服务器AI建站解决方案:快速部署与云端平台低成本实践 

您的项目需求

*请认真填写需求信息,我们会在24小时内与您取得联系。