一個Swift版簡單實用的自定義PageControl。
github地址:JJPageControl
OC請參考:iOS自定義PageControl
自定義PageControl
我們經(jīng)常會用到PageControl,但是系統(tǒng)的PageControl只有一種樣式,不支持多樣化,這里簡單介紹一個簡單的自定義PageControl.
主要功能:
- 可以自定義兩點之間間隙
- 可以定義左右間隙
- 可以自定義高度
- 可以自定義選中點的寬度
- 可以設(shè)置每個點的圓角大小
- 每個點有點擊事件
- 可以自定義選中和非選中的圖片
- 可以設(shè)置居左、居中奔誓、居右樣式
- 支持長條形狀
- 選中點可以小于非選中點
將項目工程中的JJPageControl拖拽到你的項目中.
//創(chuàng)建pageControl
var pageControl2 = JJPageControl()
pageControl2.frame = CGRect(x: 0, y: 300, width: UIScreen.main.bounds.size.width, height: 30)
//選中點的顏色
pageControl2.currentColor = UIColor.red
//非選中點的顏色
pageControl2.otherColor = UIColor.blue
//設(shè)置圓角大小
pageControl2.pointCornerRadius = 2
//設(shè)置選中點的大新⒕濉(寬度和高度)
pageControl2.currentPointSize = CGSize(width: 6, height: 12)
//設(shè)置非選中點的大姓摇(寬度和高度)
pageControl2.otherPointSize = CGSize(width: 10, height: 6)
//設(shè)置樣式.默認(rèn)居中顯示
pageControl2.pageAliment = .Center
//設(shè)置點的總個數(shù)
pageControl2.numberOfPages = 7
//交互打開
pageControl2.isUserInteractionEnabled = true
//設(shè)置兩點之間的間隙
pageControl2.controlSpacing = 3
//左右間寬,只有在居左居右顯示的時候才有用
pageControl2.leftAndRightSpacing = 10
//是否可以點擊,默認(rèn)不可以點擊
pageControl2.isCanClickPoint = true
//當(dāng)只有一個點的時候是否隱藏,默認(rèn)隱藏
pageControl2.isHidesForSinglePage = YES;
//標(biāo)記
pageControl2.tag = 902
//代理
pageControl2.delegate = self
view.addSubview(pageControl2)
實現(xiàn)代理方法:
extension ViewController:JJPageControlDelegate{
func jj_pageControlClick(pageControl: JJPageControl, index: Int) {
print("帶擊了第\(index)個")
}
}
修改當(dāng)前選中
extension ViewController: UIScrollViewDelegate {
func scrollViewDidScroll(_ scrollView: UIScrollView) {
let currentIndex = Int(scrollView.contentOffset.x / UIScreen.main.bounds.size.width)
let tag = scrollView.tag
switch tag {
case 10002:
pageControl2.currentPage = currentIndex
default:
return
}
}
}