Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/ahmedalmasri/sncollectionviewlayout
Collection View Layouts is a set of custom flow layouts for iOS which imitate general data grid approaches for mobile apps.
https://github.com/ahmedalmasri/sncollectionviewlayout
collectionview collectionviewlayout grid-layout ios ios-swift swift swift-library swift4 uicollectionview uicollectionviewflowlayout xcode
Last synced: 3 months ago
JSON representation
Collection View Layouts is a set of custom flow layouts for iOS which imitate general data grid approaches for mobile apps.
- Host: GitHub
- URL: https://github.com/ahmedalmasri/sncollectionviewlayout
- Owner: ahmedAlmasri
- License: mit
- Created: 2018-12-01T10:06:31.000Z (about 6 years ago)
- Default Branch: master
- Last Pushed: 2021-05-09T23:27:46.000Z (almost 4 years ago)
- Last Synced: 2024-10-28T21:52:51.102Z (4 months ago)
- Topics: collectionview, collectionviewlayout, grid-layout, ios, ios-swift, swift, swift-library, swift4, uicollectionview, uicollectionviewflowlayout, xcode
- Language: Swift
- Homepage:
- Size: 176 KB
- Stars: 107
- Watchers: 8
- Forks: 11
- Open Issues: 1
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
# SNCollectionViewLayout
[data:image/s3,"s3://crabby-images/9c6a1/9c6a123384dc8729a4f0ee7b55f0c0e8dc7eab2c" alt="CI Status"](https://travis-ci.org/ahmedAlmasri/SNCollectionViewLayout)
[data:image/s3,"s3://crabby-images/85e3e/85e3e185b97c99dcc4d2166e63687c056db32218" alt="Version"](https://cocoapods.org/pods/SNCollectionViewLayout)
[data:image/s3,"s3://crabby-images/1855e/1855e91ef230dc18f3d3c457d01005f42aa8eecb" alt="License"](https://cocoapods.org/pods/SNCollectionViewLayout)
[data:image/s3,"s3://crabby-images/5dae5/5dae5feed40fc11bfdf9cbf3757e99d8a81855ba" alt="Platform"](https://cocoapods.org/pods/SNCollectionViewLayout)ScreenShots
## Example
To run the example project, clone the repo, and run `pod install` from the Example directory first.
## Using1- Create instance
```swift
let snCollectionViewLayout = SNCollectionViewLayout()
snCollectionViewLayout.fixedDivisionCount = 4 // Columns for .vertical, rows for .horizontal
snCollectionViewLayout.delegate = self
myCollectionView.collectionViewLayout = snCollectionViewLayout
```2- Delegate
```swift
// scale for items based number of columns
func scaleForItem(inCollectionView collectionView: UICollectionView, withLayout layout: UICollectionViewLayout, atIndexPath indexPath: IndexPath) -> UInt {
if indexPath.row == 0 || indexPath.row == 3 || indexPath.row == 10 || indexPath.row == 70 {
return 2
}
return 1
}
// height for item if set fixedDimension height equal width
func itemFlexibleDimension(inCollectionView collectionView: UICollectionView, withLayout layout: UICollectionViewLayout, fixedDimension: CGFloat) -> CGFloat {
return fixedDimension
}
// header height
func headerFlexibleDimension(inCollectionView collectionView: UICollectionView, withLayout layout: UICollectionViewLayout, fixedDimension: CGFloat) -> CGFloat {
return 0
}
```## Requirements
* Swift 4.2+
* Xcode 10.0+
* iOS 11.0+## Installation
SNCollectionViewLayout is available through [CocoaPods](https://cocoapods.org). To install
it, simply add the following line to your Podfile:```ruby
pod 'SNCollectionViewLayout'
```## Author
ahmedAlmasri, [email protected]
## License
SNCollectionViewLayout is available under the MIT license. See the LICENSE file for more info.