pageControl頁碼實時更新的實現(xiàn)-創(chuàng)新互聯(lián)

    iOS開發(fā)過程中會經(jīng)常遇到scrollView與pageControl混合使用的情況。scrollView與pageControl的配合邏輯代碼一般是寫在以下代理函數(shù)中的:

創(chuàng)新互聯(lián)公司成立于2013年,是專業(yè)互聯(lián)網(wǎng)技術(shù)服務(wù)公司,擁有項目成都網(wǎng)站設(shè)計、做網(wǎng)站網(wǎng)站策劃,項目實施與項目整合能力。我們以讓每一個夢想脫穎而出為使命,1280元東興做網(wǎng)站,已為上家服務(wù),為東興各地企業(yè)和個人服務(wù),聯(lián)系電話:18982081108
-(void)scrollViewDidEndDecelerating:(UIScrollView *)scrollView

即在scrollView滾動結(jié)束時pageControl才會更新代碼,這樣可以防止pageControl頁碼的邏輯混亂。但這同樣會出現(xiàn)一個問題,那就是在用戶快速滑動scrollView的時候,pageControl的頁碼無法更新,在用戶看來就是scrollVIew在滑動,而頁碼無變化。其實解決的方法很簡單,原理就是將pageControl的頁碼更新放到以下代理函數(shù)中即可:

- (void)scrollViewDidScroll:(UIScrollView *)scrollView

這個函數(shù)會在scrollView滑動過程中不斷被調(diào)用,將pageControl的頁碼更新操作放在這個函數(shù)里執(zhí)行即可獲得頁碼實時更新的效果。代碼如下:

//scrollView滑動結(jié)束時調(diào)用
-(void)scrollViewDidEndDecelerating:(UIScrollView *)scrollView{
    if(_p_w_picpathScrollView.contentOffset.x >= (totalPage-1.5)*_p_w_picpathScrollView.width){
        [_p_w_picpathScrollView setContentOffset:CGPointMake(_p_w_picpathScrollView.width, 0) animated:NO];
    }else if(_p_w_picpathScrollView.contentOffset.x<0.5*_p_w_picpathScrollView.width){
        [_p_w_picpathScrollView setContentOffset:CGPointMake((totalPage-2)*_p_w_picpathScrollView.width, 0) animated:NO];
    }
    NSInteger currentPage = roundf((_p_w_picpathScrollView.contentOffset.x-_p_w_picpathScrollView.width) / [self getWidth]);
    _pageControl.currentPage = currentPage;
}


//scrollView滑動過程中多次調(diào)用
- (void)scrollViewDidScroll:(UIScrollView *)scrollView{
    NSInteger currentPage;
    if(_p_w_picpathScrollView.contentOffset.x >= (totalPage-1.5)*_p_w_picpathScrollView.width) {
        currentPage = roundf((_p_w_picpathScrollView.contentOffset.x-_p_w_picpathScrollView.width) / [self getWidth]) - (totalPage-2);
    }else if(_p_w_picpathScrollView.contentOffset.x<0.5*_p_w_picpathScrollView.width){
        // 設(shè)置當前頁
        currentPage = roundf((_p_w_picpathScrollView.contentOffset.x-_p_w_picpathScrollView.width) / [self getWidth]) + (totalPage-2);
    }else{
        currentPage = roundf((_p_w_picpathScrollView.contentOffset.x -_p_w_picpathScrollView.width) / [self getWidth]);
    }
    _pageControl.currentPage = currentPage;
}

需要說明的幾點:

1、這個scrollView是根據(jù)需求“banner需要能夠循環(huán)滑動”而設(shè)置的,原理如下:

(1)有三個主要的數(shù)據(jù)view,分別為view1,view2,view3,這三個是真正要顯示的數(shù)據(jù)view。為了實現(xiàn)“循環(huán)效果”,另外定義了兩個輔助view(view1_fz和view3_fz),在scrollView中的排列順序如下圖所示:

pageControl頁碼實時更新的實現(xiàn)

(2)在右滑至View1_fz的位置時,通過setContentOffset將_p_w_picpathScrollView移到View1的位置,并關(guān)閉動畫效果。在左滑至View3_fz的位置時,通過setContentOffset將_p_w_picpathScrollView移到View3的位置,并關(guān)閉動畫效果。

這樣就實現(xiàn)了循環(huán)的效果。

2、這里的totalPage指的是所有的view個數(shù),包括輔助的view,即totalPage=5。

3、通過contentOffset的值計算當前頁碼currentPage。

4、這里的“翻頁”是以view的一半寬度為標準的,即scrollView翻頁超過了下一頁的一半時currentPage顯示為下一頁。

5、為了實現(xiàn)pageControl的實時更新效果,在scrollViewDidScroll中對currentPage實時進行計算。

6、為了防止頁碼的錯誤,在scrollViewDidEndDecelerating函數(shù)中依然保留一次對currentPage的最終計算。

另外有需要云服務(wù)器可以了解下創(chuàng)新互聯(lián)scvps.cn,海內(nèi)外云服務(wù)器15元起步,三天無理由+7*72小時售后在線,公司持有idc許可證,提供“云服務(wù)器、裸金屬服務(wù)器、高防服務(wù)器、香港服務(wù)器、美國服務(wù)器、虛擬主機、免備案服務(wù)器”等云主機租用服務(wù)以及企業(yè)上云的綜合解決方案,具有“安全穩(wěn)定、簡單易用、服務(wù)可用性高、性價比高”等特點與優(yōu)勢,專為企業(yè)上云打造定制,能夠滿足用戶豐富、多元化的應(yīng)用場景需求。

文章標題:pageControl頁碼實時更新的實現(xiàn)-創(chuàng)新互聯(lián)
分享URL:http://bm7419.com/article4/hceoe.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供品牌網(wǎng)站制作網(wǎng)頁設(shè)計公司、網(wǎng)站建設(shè)、網(wǎng)站改版做網(wǎng)站、用戶體驗

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)

網(wǎng)站建設(shè)網(wǎng)站維護公司