From 9a5dce433a601975d215cf18ac9f84d152190935 Mon Sep 17 00:00:00 2001 From: Luke Zhao Date: Sun, 26 Jan 2020 20:19:54 -0800 Subject: [PATCH] fix centering logic --- CollectionKit2/Sources/CollectionView.swift | 29 +++++++++++++-------- 1 file changed, 18 insertions(+), 11 deletions(-) diff --git a/CollectionKit2/Sources/CollectionView.swift b/CollectionKit2/Sources/CollectionView.swift index 65801037..85a2fc11 100644 --- a/CollectionKit2/Sources/CollectionView.swift +++ b/CollectionKit2/Sources/CollectionView.swift @@ -45,15 +45,17 @@ open class CollectionView: UIScrollView { public private(set) var lastLoadBounds: CGRect = .zero public private(set) var contentOffsetChange: CGPoint = .zero - - public var contentView: UIView? { - didSet { - oldValue?.removeFromSuperview() - if let contentView = contentView { - addSubview(contentView) - } - } + + public var centerContentViewVertically = false + public var centerContentViewHorizontally = true + public var contentView: UIView? { + didSet { + oldValue?.removeFromSuperview() + if let contentView = contentView { + addSubview(contentView) + } } + } private var visibleIdentifiers: [String] = [] @@ -78,16 +80,21 @@ open class CollectionView: UIScrollView { public func ensureZoomViewIsCentered() { guard let contentView = contentView else { return } - let boundsSize = bounds.inset(by: adjustedContentInset) + let boundsSize: CGRect + if #available(iOS 11.0, *) { + boundsSize = bounds.inset(by: adjustedContentInset) + } else { + boundsSize = bounds.inset(by: contentInset) + } var frameToCenter = contentView.frame - if frameToCenter.size.width < boundsSize.width { + if centerContentViewHorizontally, frameToCenter.size.width < boundsSize.width { frameToCenter.origin.x = (boundsSize.width - frameToCenter.size.width) * 0.5 } else { frameToCenter.origin.x = 0 } - if frameToCenter.size.height < boundsSize.height { + if centerContentViewVertically, frameToCenter.size.height < boundsSize.height { frameToCenter.origin.y = (boundsSize.height - frameToCenter.size.height) * 0.5 } else { frameToCenter.origin.y = 0