IOS 中UIKit-UIPageControl利用delegate定位圓點位置
IOS 中UIKit-UIPageControl利用delegate定位圓點位置
在UIScrollView中會添加UIPageControl作為頁碼標(biāo)識,可以讓用戶清楚的知道當(dāng)前的頁數(shù)。我們需要優(yōu)化的一點是讓pageControl的小圓點精確的跟著scrollView而定位。我們先來看一下效果圖:

我們發(fā)現(xiàn),當(dāng)圖片拖動不到一半的時候,pageControl的圓點定位到前一張圖,圖片拖動超過一半的時候,定位到下一張圖。這里就需要四舍五入的計算了。
我們可以利用協(xié)議 delegate 去做這件事情。
首先,我們要為當(dāng)前我們設(shè)置的這個scrollView添加代理:
scrollView.delegate = self;
這里必須要讓當(dāng)前類去遵守 UIScrollViewDelegate 協(xié)議。
在 UIScrollViewDelegate 中,有這么一個方法,只要scrollView滾動就可以觸發(fā)。我們可以在這個方法中去實現(xiàn)。
- (void)scrollViewDidScroll:(UIScrollView *)scrollView
{
// 用水平移動的距離除以寬度等于頁數(shù),但是并沒有精確
double page = scrollView.contentOffset.x / scrollView.width;
// 采用四舍五入來確定更靠近哪一頁,并設(shè)置(下面是一個四舍五入的小技巧,+ 0.5 再向下取整即可)
self.pageControl.currentPage = (int)(page + 0.5);
}
分析舉例說明:(page = 0 為第一張圖片,page = 1 為第二張圖片,以此類推)
page = 0.95,更接近第二張圖片,page + 0.5 = 1.45,(int)1.45 = 1
page = 1.21,更接近第二張圖片,page + 0.5 = 1.71,(int)1.71 = 1
page = 1.67,更接近第三張圖片,page + 0.5 = 2.17,(int)2.17 = 2
page = 2.11,更接近第三張圖片,page + 0.5 = 2.61,(int)2.61 = 2
另外注意的是,強(qiáng)制轉(zhuǎn)化為int類型是向下取整,即省略小數(shù)點后的所有數(shù)字。
感謝閱讀,希望能幫助到大家,謝謝大家對本站的支持!
相關(guān)文章
ios基于UITableViewController實現(xiàn)列表
這篇文章主要介紹了ios基于UITableViewController實現(xiàn)列表的相關(guān)資料,具有一定的參考價值,感興趣的小伙伴們可以參考一下2017-01-01
iOS中定位(location manager )出現(xiàn)log日志的解決辦法
這篇文章主要給大家介紹了關(guān)于iOS中定位(location manager )出現(xiàn)log日志的解決辦法,文中通過示例代碼將解決的辦法介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面來一起學(xué)習(xí)學(xué)習(xí)吧。2017-10-10
iOS緩存文件大小顯示功能和一鍵清理功能的實現(xiàn)方法
緩存占用了系統(tǒng)的大量空間,如何實時動態(tài)的顯示緩存的大小,使用戶清晰的了解緩存的積累情況,有效的進(jìn)行一鍵清理呢?下面小編通過本文給大家介紹iOS緩存文件大小顯示功能和一鍵清理功能的實現(xiàn)方法,一起看看吧2016-10-10

