這篇文章主要介紹iOS如何實現(xiàn)UIScrollView的無限輪播功能,文中介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們一定要看完!
UIScrollView控件是什么?
(1)移動設(shè)備的屏幕?大?小是極其有限的,因此直接展?示在?用戶眼前的內(nèi)容也相當(dāng)有限
(2)當(dāng)展?示的內(nèi)容較多,超出?一個屏幕時,?用戶可通過滾動?手勢來查看屏幕以外的內(nèi)容
(3)普通的UIView不具備滾動功能,不能顯?示過多的內(nèi)容
(4)UIScrollView是一個能夠滾動的視圖控件,可以?用來展?示?大量的內(nèi)容,并且可以通過滾 動查看所有的內(nèi)容
(5) 舉例:手機上的“設(shè)置”、其他?示例程序
而說到UIScrollView,大家最先想到的肯定就是它上面的無限輪播功能。蘋果在UIScrollView上并沒有提供相應(yīng)的方法讓大家實現(xiàn)輪播,所以就需要通過代碼進行處理來實現(xiàn)。
先上圖
無限輪播效果圖.gif
我先給大家講講其實現(xiàn)的原理:
我們假設(shè)用幾張圖片實現(xiàn)輪播效果。首先,我們需要打開UIScrollView的分頁滑動
/// 分頁滑動 _scrollView.scrollEnabled = YES;
它方便的幫助我們實現(xiàn)了輪播的效果,然后就需要我們來實現(xiàn)“無限的”輪播。接下來,我們就需要擺放圖片了,在擺放圖片時需要注意,我們需要在第一張圖片的位置擺放最后一張圖片(可能有點懵哈,不過不要著急慢慢往下看),然后我們依次擺放圖片(從第一張到最后一張),最后在所有圖片的尾部我們再放上第一張圖片。這樣我們就多放了兩張圖片(分別在首尾多放了一張圖)。我把對應(yīng)的方法寫一下:
/// 將圖片放置在UIScrollView上 -(void)setupImage { /// 在UIScrollView的最前面添加一張圖片 UIImageView *firstImageView = [[UIImageView alloc] initWithFrame:CGRectMake(0, 0, kScreenWidth, self.scrollView.frame.size.height)]; /// 圖片名是最后一張圖片 firstImageView.image = [UIImage imageNamed:self.imageNameList.lastObject]; [self.scrollView addSubview:firstImageView]; /// 添加圖片 for (NSInteger index = 0; index < self.imageNameList.count; index ++) { /// UIScrollView上的每一張圖片 UIImageView *imageView = [[UIImageView alloc] initWithFrame:CGRectMake((index + 1) * kScreenWidth, 0, kScreenWidth, self.scrollView.frame.size.height)]; imageView.image = [UIImage imageNamed:self.imageNameList[index]]; [self.scrollView addSubview:imageView]; self.scrollView.contentSize = CGSizeMake((index + 2) * self.scrollView.bounds.size.width, 0); } /// 在UIScrollView的最后面添加一張圖片 UIImageView *lastImageView = [[UIImageView alloc] initWithFrame:CGRectMake((self.imageNameList.count + 1) * kScreenWidth, 0, kScreenWidth, self.scrollView.frame.size.height)]; /// 圖片名是第一張圖片 lastImageView.image = [UIImage imageNamed:self.imageNameList.firstObject]; [self.scrollView addSubview:lastImageView]; /// 設(shè)置UIScrollView的偏移量 self.scrollView.contentSize = CGSizeMake((self.imageNameList.count + 2) * self.scrollView.bounds.size.width, 0); /// 設(shè)置UIScrollView的起始偏移距離(將第一張圖片跳過) self.scrollView.contentOffset = CGPointMake(kScreenWidth, 0); /// 圖片總數(shù) self.pageControl.numberOfPages = self.imageNameList.count; self.pageControl.currentPage = 0; }
其實,如果大家看到這里,應(yīng)該就會大致明白無線輪播的實現(xiàn)原理了。接下來就是最后一步,在UIScrollView的代理方法里面寫邏輯:判斷UIScrollView的偏移量,當(dāng)其滑動到首位時(顯示的是最后一張圖片),滑動停止,就把偏移量修改最后面圖片的位置上(倒數(shù)第二張)。同理,當(dāng)UIScrollView滑動到最后時(顯示的是第一張圖片),滑動停止,就把偏移量修改到第一張圖片的位置上(正數(shù)第二張)。
#pragma mark - UIScrollViewDelegate -(void)scrollViewDidEndDecelerating:(UIScrollView *)scrollView { /// 當(dāng)UIScrollView滑動到第一位停止時,將UIScrollView的偏移位置改變 if (scrollView.contentOffset.x == 0) { scrollView.contentOffset = CGPointMake(self.imageNameList.count * kScreenWidth, 0); self.pageControl.currentPage = self.imageNameList.count; /// 當(dāng)UIScrollView滑動到最后一位停止時,將UIScrollView的偏移位置改變 } else if (scrollView.contentOffset.x == (self.imageNameList.count + 1)* kScreenWidth) { scrollView.contentOffset = CGPointMake(kScreenWidth, 0); self.pageControl.currentPage = 0; } else { self.pageControl.currentPage = scrollView.contentOffset.x / kScreenWidth - 1; } }
ok,原理其實就是這樣。在首尾多加兩張圖片當(dāng)做占位符,然后當(dāng)UIScrollView滑動到占位符的位置時,改變UIScrollView的偏移量,簡單且方便。下面就是全部代碼:
#import "ViewController.h" #define kScreenWidth [UIScreen mainScreen].bounds.size.width @interface ViewController () <UIScrollViewDelegate> /// 滑動控制器 @property (nonatomic, strong) UIScrollView *scrollView; /// 圖片數(shù)組 @property (nonatomic, strong) NSArray<NSString *> *imageNameList; /// 頁碼控制器 @property (nonatomic, strong) UIPageControl *pageControl; @end @implementation ViewController - (void)viewDidLoad { [super viewDidLoad]; // 設(shè)置圖片名的數(shù)組 self.imageNameList = @[@"image0", @"image1", @"image2", @"image3"]; // 添加圖片 [self setupImage]; } /// 將圖片放置在UIScrollView上 -(void)setupImage { /// 在UIScrollView的最前面添加一張圖片 UIImageView *firstImageView = [[UIImageView alloc] initWithFrame:CGRectMake(0, 0, kScreenWidth, self.scrollView.frame.size.height)]; /// 圖片名是最后一張圖片 firstImageView.image = [UIImage imageNamed:self.imageNameList.lastObject]; [self.scrollView addSubview:firstImageView]; /// 添加圖片 for (NSInteger index = 0; index < self.imageNameList.count; index ++) { /// UIScrollView上的每一張圖片 UIImageView *imageView = [[UIImageView alloc] initWithFrame:CGRectMake((index + 1) * kScreenWidth, 0, kScreenWidth, self.scrollView.frame.size.height)]; imageView.image = [UIImage imageNamed:self.imageNameList[index]]; [self.scrollView addSubview:imageView]; self.scrollView.contentSize = CGSizeMake((index + 2) * self.scrollView.bounds.size.width, 0); } /// 在UIScrollView的最后面添加一張圖片 UIImageView *lastImageView = [[UIImageView alloc] initWithFrame:CGRectMake((self.imageNameList.count + 1) * kScreenWidth, 0, kScreenWidth, self.scrollView.frame.size.height)]; /// 圖片名是第一張圖片 lastImageView.image = [UIImage imageNamed:self.imageNameList.firstObject]; [self.scrollView addSubview:lastImageView]; /// 設(shè)置UIScrollView的偏移量 self.scrollView.contentSize = CGSizeMake((self.imageNameList.count + 2) * self.scrollView.bounds.size.width, 0); /// 設(shè)置UIScrollView的起始偏移距離(將第一張圖片跳過) self.scrollView.contentOffset = CGPointMake(kScreenWidth, 0); /// 圖片總數(shù) self.pageControl.numberOfPages = self.imageNameList.count; self.pageControl.currentPage = 0; } #pragma mark - UIScrollViewDelegate -(void)scrollViewDidEndDecelerating:(UIScrollView *)scrollView { /// 當(dāng)UIScrollView滑動到第一位停止時,將UIScrollView的偏移位置改變 if (scrollView.contentOffset.x == 0) { scrollView.contentOffset = CGPointMake(self.imageNameList.count * kScreenWidth, 0); self.pageControl.currentPage = self.imageNameList.count; /// 當(dāng)UIScrollView滑動到最后一位停止時,將UIScrollView的偏移位置改變 } else if (scrollView.contentOffset.x == (self.imageNameList.count + 1)* kScreenWidth) { scrollView.contentOffset = CGPointMake(kScreenWidth, 0); self.pageControl.currentPage = 0; } else { self.pageControl.currentPage = scrollView.contentOffset.x / kScreenWidth - 1; } } #pragma mark - Get方法 -(UIScrollView *)scrollView { if (!_scrollView) { _scrollView = [[UIScrollView alloc] initWithFrame:CGRectMake(0, 0, kScreenWidth, 200)]; _scrollView.pagingEnabled = YES; _scrollView.clipsToBounds = NO; _scrollView.scrollEnabled = YES; _scrollView.delegate = self; _scrollView.bounces = NO; _scrollView.showsHorizontalScrollIndicator = NO; _scrollView.showsVerticalScrollIndicator = NO; [self.view addSubview:_scrollView]; } return _scrollView; } -(UIPageControl *)pageControl { if (!_pageControl) { _pageControl = [[UIPageControl alloc] initWithFrame:CGRectMake(0, 150, kScreenWidth, 50)]; _pageControl.pageIndicatorTintColor = [UIColor blackColor]; _pageControl.currentPageIndicatorTintColor = [UIColor grayColor]; [self.view addSubview:_pageControl]; } return _pageControl; } @end
以上是“iOS如何實現(xiàn)UIScrollView的無限輪播功能”這篇文章的所有內(nèi)容,感謝各位的閱讀!希望分享的內(nèi)容對大家有幫助,更多相關(guān)知識,歡迎關(guān)注創(chuàng)新互聯(lián)網(wǎng)站建設(shè)公司行業(yè)資訊頻道!
另外有需要云服務(wù)器可以了解下創(chuàng)新互聯(lián)建站chinadenli.net,海內(nèi)外云服務(wù)器15元起步,三天無理由+7*72小時售后在線,公司持有idc許可證,提供“云服務(wù)器、裸金屬服務(wù)器、高防服務(wù)器、香港服務(wù)器、美國服務(wù)器、虛擬主機、免備案服務(wù)器”等云主機租用服務(wù)以及企業(yè)上云的綜合解決方案,具有“安全穩(wěn)定、簡單易用、服務(wù)可用性高、性價比高”等特點與優(yōu)勢,專為企業(yè)上云打造定制,能夠滿足用戶豐富、多元化的應(yīng)用場景需求。
網(wǎng)站標題:iOS如何實現(xiàn)UIScrollView的無限輪播功能-創(chuàng)新互聯(lián)
鏈接分享:http://chinadenli.net/article12/desegc.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供搜索引擎優(yōu)化、Google、ChatGPT、網(wǎng)站內(nèi)鏈、面包屑導(dǎo)航、網(wǎng)站導(dǎo)航
聲明:本網(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)
猜你還喜歡下面的內(nèi)容