15.自定义无限轮播View Cell
Collection来实现一个无线轮播的View
1.新建自定义的 View - Cell ,
data:image/s3,"s3://crabby-images/9acf7/9acf700ddd6f692cd9e68ecf422daaa39057df58" alt=""
继承自 UIView
data:image/s3,"s3://crabby-images/80dc2/80dc2bd1750f617839bbbee38b0079af6637943b" alt=""
2.继续创建针对Cell View 创建XIB文件,新建,选择View下一步
data:image/s3,"s3://crabby-images/e9026/e9026ced137af123d08e51e2516b33603114d194" alt=""
选择我们需要创建的Cell View 点击确定,即创建了针对该Cell View的XIB文件
data:image/s3,"s3://crabby-images/349ab/349ab9c75c93f107f4dbfae05657e87c94ba1dfc" alt=""
2.2将Cell View 与 XIB文件进行关联
data:image/s3,"s3://crabby-images/06b0d/06b0daed336f1c8331ffbf56d19d720a1b6a71aa" alt=""
2.3修改XIB的Size改为Freeform,
data:image/s3,"s3://crabby-images/576e4/576e416e5c2f632e21b86039cf5fbb654c574883" alt=""
2.4修改XIB的显示大小:
data:image/s3,"s3://crabby-images/3e03a/3e03ad0c160ff6a4429c2a025c77a072a431b476" alt=""
2.5先将这个View 注册到页面进行展示。
data:image/s3,"s3://crabby-images/89216/892161c612f9815edecff1622a8508fc42afbdd1" alt=""
2.6 提供一个快速创建View 的类方法
// MARK:提供一个快速创建View的类方法
extension RecommenCycleView{
//声明XIB
classfuncRecommenCycleView() ->RecommenCycleView{
return Bundle.main.loadNibNamed("RecommenCycleView", owner:nil, options:nil)?.first as! RecommenCycleView
}
}
data:image/s3,"s3://crabby-images/570c3/570c32d27d2fa7b960f5bf13ec260a03db0f169c" alt=""
2.7 设置View 不跟随父控件的拉伸而拉伸
class RecommenCycleView:UIView{
override func awakeFromNib() {
super.awakeFromNib()
//MARK :设置该控件不随父控件的拉伸而拉伸
autoresizingMask=UIViewAutoresizing()
}
}
data:image/s3,"s3://crabby-images/02148/0214835133163aecf54ba66e1149370b45983222" alt=""
3.回到Controller ,懒加载定义一个 CycleView,为了能使cycleView能跟随页面滑动,需要注册到collectionView中
3.1定义cycleView控件的高度常量
data:image/s3,"s3://crabby-images/7a4aa/7a4aa0c1b53262e5ec14f8d57d6ec12407fa4c4e" alt=""
3.2懒加载闭包创建cycleView,并定义Frame
data:image/s3,"s3://crabby-images/81c34/81c34e22e1636caf3f10dd7cae7ffaee7b73f1a6" alt=""
3.3 为了让Cycleview能跟随页面滑动,需要将cycleView添加到collectionView中
data:image/s3,"s3://crabby-images/cd3e8/cd3e840098e2507e49cfe191e2fc5a91780803a4" alt=""
3.4 设置collectionView的内边距
data:image/s3,"s3://crabby-images/12196/1219676e82a82ed59d21f2427b7c0f35ea06c883" alt=""
运行效果:
data:image/s3,"s3://crabby-images/76758/7675854850b549d9edd8397b95aa523b2f92fef8" alt=""
4.继续给CycleView增加collectionView来进展展示轮播
4.1在CycleView中拖入 collectionView 控件
data:image/s3,"s3://crabby-images/68138/68138f422cd6b7b072b561cc18325be03615b6cc" alt=""
4.2给拖入的collectionView进行约束
data:image/s3,"s3://crabby-images/c9f19/c9f19631120f7e0f4ab8b82593b1c4441181d61e" alt=""
设置约束后
data:image/s3,"s3://crabby-images/2459e/2459e29aa9a5fd9f3e1f6f877a985dcd86b43051" alt=""
4.3 拖入一个pageController 到CollectionView上
data:image/s3,"s3://crabby-images/c8b57/c8b573e3d90eec3d8da2682422c933ca4420c281" alt=""
4.4 修改pageController选中颜色和默认颜色
data:image/s3,"s3://crabby-images/a4790/a4790b2ee143ecbc32a2ccf3f1a0b2f25cce2544" alt=""
4.5设置约束
data:image/s3,"s3://crabby-images/3092e/3092e575176a817a3abb2b1fd7f4ebffd7c45473" alt=""
4.6运行查看效果
collectionview默认背景为白色
data:image/s3,"s3://crabby-images/a4246/a42463189ab12eaeb0f0179a710a0c6445a99028" alt=""
4.7 给collectionView设置数据源
选中collectionView 右键,连接数据源
data:image/s3,"s3://crabby-images/999f5/999f5bb82be3e2b3c0db02154481e8c3b2281d0e" alt=""
4.8声明XIB控件属性
data:image/s3,"s3://crabby-images/69037/690372313e3613599590484679dd9aa4fd644caa" alt=""
4.9 注册collectionView
定义一个Cell ID 常量
privatelet kCycleCellID ="kCycleCellID"
注册cell
// MARK:2.注册Cell,修改为使用XIB进行注册
collectionView.register(UICollectionViewCell.self, forCellWithReuseIdentifier:kCycleCellID)
data:image/s3,"s3://crabby-images/954c2/954c2ccb123da7764e8b567a88d5d49462a91507" alt=""
5.0 遵循CollectionView 的数据源协议
随机设置了一个返回6组数据
//MARK:遵循collectionView的数据源协议
extension RecommenCycleView: UICollectionViewDataSource{
func collectionView(_ collectionView: UICollectionView, numberOfItemsInSection section: Int) -> Int {
return 6
}
func collectionView(_ collectionView: UICollectionView, cellForItemAt indexPath: IndexPath) -> UICollectionViewCell {
let cell = collectionView.dequeueReusableCell(withReuseIdentifier: kCycleCellID, for: indexPath)
return cell
}
}
data:image/s3,"s3://crabby-images/d652e/d652e3f341bc06840723c20acb982c7cc2a44067" alt=""
5.1为了能看到不同的效果,需要对CollectionView 的背景颜色进行一下设置。
data:image/s3,"s3://crabby-images/519e7/519e7adf2f0318180fa05355e98b27ab50022c3e" alt=""
5.2 运行查看效果:需要调整一下大小和间隔
data:image/s3,"s3://crabby-images/d9db6/d9db681f70dfa0326cd2c7dbfe03c332a5d2b210" alt=""
5.3 设置collection布局
override func layoutSubviews() {
super.layoutSubviews()
// MARK: 设置collectionView 的layput布局
let layout = collectionView.collectionViewLayout as! UICollectionViewFlowLayout
layout.itemSize = collectionView.bounds.size
}
data:image/s3,"s3://crabby-images/9f1cb/9f1cbe7d26a18624e238b1e80225e9fad0347259" alt=""
5.3 在XIB中设置其他的布局属性
5.3.1选中Collection View Flow layout 设置item之间的间距为0
data:image/s3,"s3://crabby-images/e664d/e664d2c942b1c69183a2904a6e789f752bb588c4" alt=""
5.3.2选中Collection View Flow layout设置滚动方向:水平滚动
data:image/s3,"s3://crabby-images/417d6/417d65c3f9cbb5c344b04a6c9df984535f2431e8" alt=""
5.3.3 选中Collection View 取消滚动条显示,勾选允许分页
data:image/s3,"s3://crabby-images/89285/8928536b84d277fd010ce894fa4ca2a23c2018c9" alt=""
运行查看效果:
data:image/s3,"s3://crabby-images/9bd13/9bd1324a22b6457ee4b3d238da42eaef1fdb24b9" alt=""
小马哥23