8.编写Home页面 -PageTitleView 和PageC
编写两个自定义控件之间的关联关系
1.监听PageTitleView中的点击
1.1将PageTitleView中点击逻辑进行处理
1.2告知PageContentView滚动到正确的控制器
// MARK:-监听Label的点击
extensionPageTitleView{
@objcfileprivatefunctitleLabelClick(_tapGes :UITapGestureRecognizer) {
// 0.获取当前Label
guardletcurrentLabel = tapGes.viewas?UILabelelse{return}
// 1.如果是重复点击同一个Title,那么直接返回
ifcurrentLabel.tag==currentIndex{return}
// 2.获取之前的Label
letoldLabel =titleLabels[currentIndex]
// 3.切换文字的颜色
currentLabel.textColor=UIColor(r:kSelectColor.0, g:kSelectColor.1, b:kSelectColor.2)
oldLabel.textColor=UIColor(r:kNormalColor.0, g:kNormalColor.1, b:kNormalColor.2)
// 4.保存最新Label的下标值
currentIndex= currentLabel.tag
// 5.滚动条位置发生改变
let scrollLineX =CGFloat(currentIndex) *scrollLine.frame.width
UIView.animate(withDuration:0.15, animations: {
self.scrollLine.frame.origin.x= scrollLineX
})
// 6.通知代理
delegate?.pageTitleView(self, selectedIndex:currentIndex)
}
}
data:image/s3,"s3://crabby-images/20a44/20a441b2c88b896048890c06e9b5e21a279a12ef" alt=""
data:image/s3,"s3://crabby-images/d2bcb/d2bcbc9c7d1dc870c3302526c97e4c8bb18cf942" alt=""
// 0.获取当前Label
guardletcurrentLabel = tagGes.viewas?UILabelelse{return}
// 1.如果是重复点击同一个Title,那么直接返回
ifcurrentLabel.tag==currentIndex{return}
// 2.获取之前的Label
letoldLabel =titleLabels[currentIndex]
// 3.切换文字的颜色
currentLabel.textColor=UIColor(r:kSelectColor.0, g:kSelectColor.1, b:kSelectColor.2)
oldLabel.textColor=UIColor(r:kNormalColor.0, g:kNormalColor.1, b:kNormalColor.2)
// 4.保存最新Label的下标值
currentIndex= currentLabel.tag
// 5.滚动条位置发生改变
letscrollLineX =CGFloat(currentIndex) *scrollLine.frame.width
UIView.animate(withDuration:0.15, animations: {
self.scrollLine.frame.origin.x= scrollLineX
})
data:image/s3,"s3://crabby-images/8ea5a/8ea5a38605ad65a5200a080a11aec6ef745f9782" alt=""
运行效果:点击不同的title ,下标会切换到不同的下标并改变颜色
data:image/s3,"s3://crabby-images/fc8cc/fc8cc7b25da772e4791bc0fefe3800b9fa4f6ddb" alt=""
为了PageTitleView能与下面的PageContentView进行联系,这里先把点击的到label的下标传递给HomeViewController,再由HomeViewController传递给PageContentView
通过代理进行实现这样的通信
// MARK:定义代理,只能被类遵守
protocolPageTitleViewDelegate:class{
funcpageTitleView(_titleView :PageTitleView, selectedIndex index :Int)
}
data:image/s3,"s3://crabby-images/1d0ba/1d0baef7413e48b1ee739acd730204a19ebb9025" alt=""
在类中进行定义代理
data:image/s3,"s3://crabby-images/10558/105582d4b53a0df02f33560c071ccf5059e0af35" alt=""
到HomeViewController 来成为PagetitleView的代理
data:image/s3,"s3://crabby-images/0ff19/0ff190137933d30aec24b9d7b68124583385af2c" alt=""
data:image/s3,"s3://crabby-images/52cc2/52cc2c4a2280da5dd159e607dc2ed0821bbb58dc" alt=""
点击不同的title 来显示点击到的index
data:image/s3,"s3://crabby-images/36333/363330e3dccc3a16783fab978a380cbbd7af92bb" alt=""
data:image/s3,"s3://crabby-images/27d54/27d54a0145fd661744f55b381c4a675b5d0e170e" alt=""
extensionHomeViewController:PageTitleViewDelegate{
func pageTitleView(_titleView:PageTitleView, selectedIndex index:Int) {
pageContentView.setCurrentIndex(index)
}
}
data:image/s3,"s3://crabby-images/3ec01/3ec01835b393adc6d88134315e709f33a50db680" alt=""
来到PageContentView
data:image/s3,"s3://crabby-images/c17f4/c17f44c8bdf1f29dddcc840ed56d9a5796d5b0b8" alt=""
fileprivate var isForbidScrollDelegate :Bool = false
data:image/s3,"s3://crabby-images/35339/353390247423e90f4b731c4b7a37f23dc9594b75" alt=""
运行效果:点击PageTitleView中的title,下面的PageContentViw 滑动到对应的选项
data:image/s3,"s3://crabby-images/cd9d2/cd9d24a1858f36e8e048a8b89bc7b8cb0def2c3a" alt=""
处理PageContentView滚动
data:image/s3,"s3://crabby-images/c92df/c92df64c8f08a3768b657a37106836972fd99948" alt=""
遵循collection Delegate协议
data:image/s3,"s3://crabby-images/f6b83/f6b83cb5f097b1f5bb541c8823b7fb405d43573d" alt=""
//遵循collectionView的Delegate协议
extensionPageContentView:UICollectionViewDelegate{
funcscrollViewWillBeginDragging(_scrollView:UIScrollView) {
print("--")
}
}
测试监听滚动的事件 ,运行,滑动PageContentView 就会打印 --
data:image/s3,"s3://crabby-images/fe9e2/fe9e28e3ffd17f7d7cb449efb79cecf93926c442" alt=""
定义:fileprivatevarisForbidScrollDelegate :Bool=false
data:image/s3,"s3://crabby-images/75fbd/75fbdbb3095f48696513edc788b009744605615a" alt=""
data:image/s3,"s3://crabby-images/399a9/399a9e81908950c36878ff289e8a6253512935d6" alt=""
data:image/s3,"s3://crabby-images/2132d/2132d198f1b0f4745cfc07435a9d7bb4abd68d5b" alt=""