当前位置: 首页 > wzjs >正文

设计网站推荐视频泰安网络推广培训

设计网站推荐视频,泰安网络推广培训,wordpress如何写个插件,泉州企业制作网站前言 想必大家工作中或多或少会遇到下图样式的UI需求吧 像这种cell长度不固定,并且还能实现的分页效果UI还是很常见的 实现 我们这里实现主要采用collection view,实现的方式是自定义一个UICollectionViewFlowLayout的子类,在这个类里对…

前言

想必大家工作中或多或少会遇到下图样式的UI需求吧
录屏效果

像这种cell长度不固定,并且还能实现的分页效果UI还是很常见的

实现

我们这里实现主要采用collection view,实现的方式是自定义一个UICollectionViewFlowLayout的子类,在这个类里对cell布局进行排列

  • 当出现page size小于collection view的size的时候,可以使用ZLCollectionFreePageLayout一下子就实现分页效果
  • 并且不需要设置属性collectionView.isPagingEnabled = true,只要设置了layout为ZLCollectionFreePageLayout,就可以自动实现这种效果

主要代码如下:

open override func targetContentOffset(forProposedContentOffset proposedContentOffset: CGPoint, withScrollingVelocity velocity: CGPoint) -> CGPoint {guard let collectionView = collectionView else {return super.targetContentOffset(forProposedContentOffset: proposedContentOffset, withScrollingVelocity: velocity)}var pWOrH: CGFloat = 0var contentOffsetXOrY: CGFloat = 0var collectionViewContentWOrH: CGFloat = 0var velocityXOrY: CGFloat = 0if scrollDirection == .horizontal {pWOrH = (pageWOrH == 0 ? collectionView.frame.width : pageWOrH) + minimumLineSpacingcontentOffsetXOrY = collectionView.contentOffset.xcollectionViewContentWOrH = collectionViewContentSize.widthvelocityXOrY = velocity.x} else {pWOrH = (pageWOrH == 0 ? collectionView.frame.height : pageWOrH) + minimumInteritemSpacingcontentOffsetXOrY = collectionView.contentOffset.ycollectionViewContentWOrH = collectionViewContentSize.heightvelocityXOrY = velocity.y}let originalPage = contentOffsetXOrY / pWOrHvar nextPage = (velocityXOrY > 0) ? ceil(originalPage) : floor(originalPage)if (nextPage + 1.0) * pWOrH > collectionViewContentWOrH { nextPage -= 1.0 }let currentPage = (velocityXOrY > 0) ? floor(originalPage) : ceil(originalPage)let pannedLessThanOnePage = abs(1 + currentPage - originalPage) > 0.5let flicked = abs(velocityXOrY) > 0.01var newProposedContentOffset = proposedContentOffsetif !(pannedLessThanOnePage && flicked) {nextPage = round(originalPage)}newProposedContentOffset.x = nextPage * pWOrHreturn newProposedContentOffset}
  • 在使用的时候,只需要将collection.collectionViewLayout的属性设置为我们自定义的layout对象,具体代码如下面的示例代码:
private lazy var collectionView: UICollectionView = {// 实例化一个ZLCollectionLeftLayout对象let defaultLayout = ZLCollectionFreePageLayout()// 自定义page width或者page heightdefaultLayout.pageWOrH = 200.0defaultLayout.minimumLineSpacing = 10.0defaultLayout.minimumInteritemSpacing = 10.0defaultLayout.scrollDirection = .verticaldefaultLayout.sectionInset = UIEdgeInsets(top: 10.0, left: 10.0, bottom: 10.0, right: 10.0)// 设置collection view的layout为ZLCollectionFreePageLayoutlet collectionView = UICollectionView(frame: .zero, collectionViewLayout: defaultLayout)collectionView.showsVerticalScrollIndicator = falsereturn collectionView
}()
  • 然后就会自动实现分页效果

  • 并且不需要设置属性collectionView.isPagingEnabled = true

开源代码地址

代码开源到github上了,可以直接拿来使用

开源代码地址

http://www.dtcms.com/wzjs/429580.html

相关文章:

  • 做网站大概西安seo排名收费
  • 商城网站建设的优点西安百度seo推广
  • 工程咨询公司北京seo优化技术
  • 开县网站建设宝鸡seo培训
  • 金华做网站报价丹东网站seo
  • 影评网站怎么做百度影音在线电影
  • 购物网站静态页面重庆放心seo整站优化
  • 微信网页制作网站建设免费的建站平台
  • 营销型网站的建设方案网站制作方案
  • 网站建设从零开始防控措施持续优化
  • 网站的制作步骤株洲seo优化哪家好
  • 事业单位网站建设费科目各大网址收录查询
  • 新疆建设厅网站查询在线seo诊断
  • 网站被墙怎么做跳转关键词优化是怎么做的
  • 一个app一年可以赚多少优化电池充电什么意思
  • 广州领域设计网络运营有限公司黑帽seo寄生虫
  • 做网站卖产品要注册公司吗郑州seo哪家好
  • lamp网站开发黄金组合头条关键词排名查询
  • 淘宝客做网站多少钱微信软文怎么写
  • 自己建服务器做网站违法app推广软文范文
  • 深圳市制作网站cpc广告接单平台
  • 网站建设 太原十大搜索引擎入口
  • 婚纱摄影行业网站小吃培训去哪里学最好
  • 动态字设计网站如何让自己的网站排名靠前
  • 织梦网站手机版怎么做seo百度站长工具
  • 海外推广代理商技术教程优化搜索引擎整站
  • 网站怎么做排查修复网站如何优化排名
  • 网站建设推广页seo整站优化报价
  • 深圳品牌策划公司排行榜seo排名优化有哪些
  • 网站做平台重庆网站搜索排名