18.创建推荐分类View
2017-09-05 本文已影响19人
whong736
新建View文件
data:image/s3,"s3://crabby-images/a3397/a339764ff132bc94a1dc36b78f7522923a3a1bda" alt=""
继承UICollectionView
data:image/s3,"s3://crabby-images/704c7/704c78ef0ee220c78ea074e6ba13981576be97b8" alt=""
0.为类新建相应测View文件
data:image/s3,"s3://crabby-images/93b5e/93b5ecab702c1be6e2c79263ae4f4630ee778c69" alt=""
data:image/s3,"s3://crabby-images/6096c/6096c78dc7e2997494ebc02cd7cfb5a27e2bb864" alt=""
关联控制器和View
data:image/s3,"s3://crabby-images/5b87b/5b87b136f0861cb2557a6a104036ec747e078d75" alt=""
size设置为Freeform 可以自由调整大小
data:image/s3,"s3://crabby-images/918b9/918b9ab994155432739b5c3a9dd73c771adc0dbd" alt=""
设置高度为90
data:image/s3,"s3://crabby-images/a7cff/a7cffd4f1ec101817c6da94cab8c52d0da53ac3e" alt=""
为了能看到这个view,给view设置一个背景颜色
data:image/s3,"s3://crabby-images/88ea5/88ea5916cff2b82c7a62980ba68d6eb21572bd3d" alt=""
1.快速创建类方法 && 设置不跟随父控件的拉伸而拉伸
import UIKit
class RecommentGroupView: UIView {
override func awakeFromNib() {
super.awakeFromNib()
// 让控件不随着父控件的拉伸而拉伸
autoresizingMask = UIViewAutoresizing()
}
}
extension RecommentGroupView{
//提供快速创建类方法
class func recommentGroupView() -> RecommentGroupView{
return Bundle.main.loadNibNamed("RecommentGroupView", owner: nil, options: nil)?.first as! RecommentGroupView
}
}
data:image/s3,"s3://crabby-images/59a70/59a700e7b7f81214abcd639d06db5e18905bb5c7" alt=""
2.到对应的控制器中,通过闭包懒加载之前定义的这个View
//懒加载需要创建的View,通过闭包的方式
lazy var groupView:RecommentGroupView = {
//MARK:通过类方法来创建View
let groupView = RecommentGroupView.recommentGroupView()
// groupView.frame =
return groupView
}()
data:image/s3,"s3://crabby-images/fd0b0/fd0b083fd0392866418635df010568d9199d741a" alt=""
3.到设置UI方法中将groupView添加到collectionView中
修改前
data:image/s3,"s3://crabby-images/22978/229783a1e9c00b6fbf8071bf82a34e90cff77394" alt=""
修改后
data:image/s3,"s3://crabby-images/93261/93261291c7fbabfc9ffaf0344a3a8a82bf191550" alt=""
4.先定义一个groupView 的高度。
在collectionView 添加的groupView后还不能显示,因为还没有设置frame以及调整之前的cycleView 的Y值
//定义 RecommentGroupView的高度
private let kGroupViewH : CGFloat = 90
data:image/s3,"s3://crabby-images/01ee8/01ee8a9487317dd5838e8c228a2c3cc21ebd5665" alt=""
5.调整之前轮播的frame的Y值,Y变为 两个容器的高度之和
由原来的
cycleView.frame = CGRect(x: 0, y: - kCycleViewH , width: kScreenW , height: kCycleViewH)
改为:
cycleView.frame = CGRect(x: 0, y: -(kCycleViewH + kGroupViewH), width: kScreenW , height: kCycleViewH)
data:image/s3,"s3://crabby-images/1b293/1b2930703afc7353027dd9819346514b028bfb5a" alt=""
6.设置collectionViewron容器偏移量的时候,加上groupView的高度
由原来的:
//4.设置collectionView的内边距
collectionView.contentInset = UIEdgeInsets(top: kCycleViewH , left: 0, bottom: 0, right: 0)
变为:
//4.设置collectionView的内边距
collectionView.contentInset = UIEdgeInsets(top: kCycleViewH + kGroupViewH, left: 0, bottom: 0, right: 0)
data:image/s3,"s3://crabby-images/f9011/f90119219de7e0b0ff938b12e0d1122fc221e798" alt=""
7.设置groupView的Frame
groupView.frame = CGRect(x: 0, y: -kGroupViewH, width: kScreenW, height: kGroupViewH)
运行查看效果:
data:image/s3,"s3://crabby-images/17cf2/17cf260e14a772d8ba8e95de11c386b5deb4c7d5" alt=""
8. 给添加好的View 拖入CollectionView控件进行布局
data:image/s3,"s3://crabby-images/365ed/365edf9b26411d70f9625dccf61b9e844b0961e8" alt=""
给推入的CollectionView设置约束
data:image/s3,"s3://crabby-images/65540/655406d3eeec41096a5d016955415567eec6c2ae" alt=""
9.设置collectionView的数据源为自己
data:image/s3,"s3://crabby-images/21bed/21bed41d0f799802d8d8095976374a77347f4cbb" alt=""
设置后为:
data:image/s3,"s3://crabby-images/84534/845344597a6dc069600f81f0e866c30d77d72312" alt=""
10.将XIB中的collectionView定义一个collectionView属性
data:image/s3,"s3://crabby-images/0fd66/0fd6649faa8ad4d46b0d5157fe9c0746b2ba2367" alt=""
11.注册Cell
声明一个常量
private let kGroupCellID = "kGroupCellID"
注册Cell
//注册cell
collectionView.register(UICollectionViewCell.self, forCellWithReuseIdentifier: kGroupCellID)
12.代码遵守数据源协议
// MARK 遵守Collection数据源协议
extension RecommentGroupView:UICollectionViewDataSource{
func collectionView(_ collectionView: UICollectionView, numberOfItemsInSection section: Int) -> Int {
return 8
}
func collectionView(_ collectionView: UICollectionView, cellForItemAt indexPath: IndexPath) -> UICollectionViewCell {
let cell = collectionView.dequeueReusableCell(withReuseIdentifier: kGroupCellID, for: indexPath)
// MARK :为了能显示Cell,如果是奇数显示蓝色,偶数显示红色
cell.backgroundColor = indexPath.item % 2 == 0 ? UIColor.red : UIColor.blue
return cell
}
}
data:image/s3,"s3://crabby-images/ed7d1/ed7d1ffa9bfe4cbd5e8032aebbc6e21915d09284" alt=""
运行查看效果:
滚动方向和cell大小不对
data:image/s3,"s3://crabby-images/759bb/759bb9602c2c510dd60ff6a303d867eaa0ba8b3d" alt=""
13.设置cell的滚动方式,从上下滚动改为左右滚动
data:image/s3,"s3://crabby-images/61e7b/61e7b48081d57414bf60478d9c6c6fb4121f3229" alt=""
设置间距为0
data:image/s3,"s3://crabby-images/0ad93/0ad933793bd8135add4fb2f3e9986a1bd422a171" alt=""
data:image/s3,"s3://crabby-images/40332/403329813acdc1afb454cfd9c2b88964aaaee5ab" alt=""
继续调整:高度和宽度
data:image/s3,"s3://crabby-images/b717d/b717d4dfbfa3a805dc25e861c0bfc6e837bdc2f4" alt=""
隐藏滚动条
data:image/s3,"s3://crabby-images/12f2a/12f2a40a8c22650e50f9edc51167bc9e447e76dc" alt=""
运行查看效果:
data:image/s3,"s3://crabby-images/7299b/7299b0638f5fcb062ba3e301de3089a85f954bdd" alt=""
马哥27
14.将之前分组的数据展示到cell中
var groups : [GoodGroupModel]?
data:image/s3,"s3://crabby-images/145b6/145b61f4eec6969c021e07286a9c26d6b96e4277" alt=""
15.回到对应的Controller中将之前请求到的数据传递给groupView
//加载数据源
extension RecommendViewController {
fileprivate func loadData(){
//1.请求推荐数据
recommendVM.requestData {
self.collectionView.reloadData()
}
//2.将数据传递给groupView
self.groupView.groups = self.recommendVM.goodGroup
//2.请求轮播数据
recommendVM.requestCycleData {
self.cycleView.cycleModels = self.recommendVM.cycleModels
}
}
}
data:image/s3,"s3://crabby-images/6e54f/6e54f67eeec873589eff2c67b363a808b7faed10" alt=""
按住Command + self.groupView.groups 中的groups 看是否能跳转到14的定义
16.回到14步的定义,修改为监听数据的改变让collectionView进行重新加载数据
修改前
var groups : [GoodGroupModel]?
修改后
var groups : [GoodGroupModel]? {
didSet{
collectionView.reloadData()
}
data:image/s3,"s3://crabby-images/f90a3/f90a35f0c428d45a4814995887abc3bdc85c5ae8" alt=""
17 ,修改返回值,和动态cell内容
修改前
// MARK 遵守Collection数据源协议
extension RecommentGroupView : UICollectionViewDataSource {
func collectionView(_ collectionView: UICollectionView, numberOfItemsInSection section: Int) -> Int {
return 6
}
func collectionView(_ collectionView: UICollectionView, cellForItemAt indexPath: IndexPath) -> UICollectionViewCell {
let cell = collectionView.dequeueReusableCell(withReuseIdentifier: kGroupCellID, for: indexPath)
cell.backgroundColor = indexPath.item % 2 == 0 ? UIColor.blue : UIColor.red
return cell
}
}
修改后
// MARK 遵守Collection数据源协议
extension RecommentGroupView : UICollectionViewDataSource {
func collectionView(_ collectionView: UICollectionView, numberOfItemsInSection section: Int) -> Int {
return groups?.count ?? 0
}
func collectionView(_ collectionView: UICollectionView, cellForItemAt indexPath: IndexPath) -> UICollectionViewCell {
let cell = collectionView.dequeueReusableCell(withReuseIdentifier: kGroupCellID, for: indexPath)
let group = groups![indexPath.item]
cell.backgroundColor = indexPath.item % 2 == 0 ? UIColor.blue : UIColor.red
return cell
}
}
data:image/s3,"s3://crabby-images/2e115/2e1159cc73df28107a008bda1ea120496cc4d8dd" alt=""
这时候请求的值已经存储在group中,下一步就是要解析这里值,并进行展现
18 自定义view来展现请求的值,新建View
选择view
data:image/s3,"s3://crabby-images/c9bdc/c9bdc3f599e91466aa13cedb1c618c70ef73d151" alt=""
继承之UICollectionCell 并勾选创建XIB文件
data:image/s3,"s3://crabby-images/1931c/1931c0332f54525172710d72f8e659bd8aa3c409" alt=""
19 修改第12步通过XIB来注册
修改前
collectionView.register(UICollectionViewCell.self, forCellWithReuseIdentifier: kGroupCellID)
修改后
//注册cell,修改位XIB注册
collectionView.register(UINib(nibName: "CollectionGroupCell", bundle: nil), forCellWithReuseIdentifier: kGroupCellID)
data:image/s3,"s3://crabby-images/81063/8106320354d4f19f855852200cf9ea305429ed7b" alt=""
20. 对第12步,对之前的cell 进行强转
data:image/s3,"s3://crabby-images/bc074/bc0745a2f1cc7651f8abeef8cbe8a164be3191e6" alt=""
21.到自定义View中,定义模型属性
data:image/s3,"s3://crabby-images/42d9d/42d9d5ed6a41071a3f70646c218f94556d774033" alt=""
修改前:
let group = groups![indexPath.item]
修改cell的赋值,修改后
cell.group = groups![indexPath.item]
data:image/s3,"s3://crabby-images/c4939/c49390ed493dfbd0291ba10780694355395df117" alt=""
22 修改XIB自定义view来显示请求到的数值
设置之前cell 定义的高宽
data:image/s3,"s3://crabby-images/a1447/a1447d6744a9eeb4f2e3322e2352cf13960054b6" alt=""
拖入一个lable进行颜色和约束定位
data:image/s3,"s3://crabby-images/22ae7/22ae73e9c17a04a6de6db296115dda6c006d69c9" alt=""
给文字设置约束1
data:image/s3,"s3://crabby-images/da0ac/da0ac876e306410d4ca76412a921065dac6b2940" alt=""
设置约束2
data:image/s3,"s3://crabby-images/0291f/0291fd2979de92c64e1eb05be14470973f9b58c6" alt=""