欧美一区二区三区老妇人-欧美做爰猛烈大尺度电-99久久夜色精品国产亚洲a-亚洲福利视频一区二区

iOS如何實(shí)現(xiàn)UIScrollView的無(wú)限輪播功能-創(chuàng)新互聯(lián)

這篇文章主要介紹iOS如何實(shí)現(xiàn)UIScrollView的無(wú)限輪播功能,文中介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們一定要看完!

德清網(wǎng)站制作公司哪家好,找創(chuàng)新互聯(lián)公司!從網(wǎng)頁(yè)設(shè)計(jì)、網(wǎng)站建設(shè)、微信開(kāi)發(fā)、APP開(kāi)發(fā)、響應(yīng)式網(wǎng)站等網(wǎng)站項(xiàng)目制作,到程序開(kāi)發(fā),運(yùn)營(yíng)維護(hù)。創(chuàng)新互聯(lián)公司自2013年創(chuàng)立以來(lái)到現(xiàn)在10年的時(shí)間,我們擁有了豐富的建站經(jīng)驗(yàn)和運(yùn)維經(jīng)驗(yàn),來(lái)保證我們的工作的順利進(jìn)行。專注于網(wǎng)站建設(shè)就選創(chuàng)新互聯(lián)公司

UIScrollView控件是什么?

(1)移動(dòng)設(shè)備的屏幕?大?小是極其有限的,因此直接展?示在?用戶眼前的內(nèi)容也相當(dāng)有限

(2)當(dāng)展?示的內(nèi)容較多,超出?一個(gè)屏幕時(shí),?用戶可通過(guò)滾動(dòng)?手勢(shì)來(lái)查看屏幕以外的內(nèi)容

(3)普通的UIView不具備滾動(dòng)功能,不能顯?示過(guò)多的內(nèi)容

(4)UIScrollView是一個(gè)能夠滾動(dòng)的視圖控件,可以?用來(lái)展?示?大量的內(nèi)容,并且可以通過(guò)滾 動(dòng)查看所有的內(nèi)容

(5) 舉例:手機(jī)上的“設(shè)置”、其他?示例程序

而說(shuō)到UIScrollView,大家最先想到的肯定就是它上面的無(wú)限輪播功能。蘋果在UIScrollView上并沒(méi)有提供相應(yīng)的方法讓大家實(shí)現(xiàn)輪播,所以就需要通過(guò)代碼進(jìn)行處理來(lái)實(shí)現(xiàn)。

先上圖

iOS如何實(shí)現(xiàn)UIScrollView的無(wú)限輪播功能
無(wú)限輪播效果圖.gif

我先給大家講講其實(shí)現(xiàn)的原理:

我們假設(shè)用幾張圖片實(shí)現(xiàn)輪播效果。首先,我們需要打開(kāi)UIScrollView的分頁(yè)滑動(dòng)

/// 分頁(yè)滑動(dòng)
_scrollView.scrollEnabled = YES;

它方便的幫助我們實(shí)現(xiàn)了輪播的效果,然后就需要我們來(lái)實(shí)現(xiàn)“無(wú)限的”輪播。接下來(lái),我們就需要擺放圖片了,在擺放圖片時(shí)需要注意,我們需要在第一張圖片的位置擺放最后一張圖片(可能有點(diǎn)懵哈,不過(guò)不要著急慢慢往下看),然后我們依次擺放圖片(從第一張到最后一張),最后在所有圖片的尾部我們?cè)俜派系谝粡垐D片。這樣我們就多放了兩張圖片(分別在首尾多放了一張圖)。我把對(duì)應(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的起始偏移距離(將第一張圖片跳過(guò))
 self.scrollView.contentOffset = CGPointMake(kScreenWidth, 0);
 
 /// 圖片總數(shù)
 self.pageControl.numberOfPages = self.imageNameList.count;
 self.pageControl.currentPage = 0;
}

其實(shí),如果大家看到這里,應(yīng)該就會(huì)大致明白無(wú)線輪播的實(shí)現(xiàn)原理了。接下來(lái)就是最后一步,在UIScrollView的代理方法里面寫邏輯:判斷UIScrollView的偏移量,當(dāng)其滑動(dòng)到首位時(shí)(顯示的是最后一張圖片),滑動(dòng)停止,就把偏移量修改最后面圖片的位置上(倒數(shù)第二張)。同理,當(dāng)UIScrollView滑動(dòng)到最后時(shí)(顯示的是第一張圖片),滑動(dòng)停止,就把偏移量修改到第一張圖片的位置上(正數(shù)第二張)。

#pragma mark - UIScrollViewDelegate
-(void)scrollViewDidEndDecelerating:(UIScrollView *)scrollView {
 /// 當(dāng)UIScrollView滑動(dòng)到第一位停止時(shí),將UIScrollView的偏移位置改變
 if (scrollView.contentOffset.x == 0) {
 scrollView.contentOffset = CGPointMake(self.imageNameList.count * kScreenWidth, 0);
 self.pageControl.currentPage = self.imageNameList.count;
 /// 當(dāng)UIScrollView滑動(dòng)到最后一位停止時(shí),將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,原理其實(shí)就是這樣。在首尾多加兩張圖片當(dāng)做占位符,然后當(dāng)UIScrollView滑動(dòng)到占位符的位置時(shí),改變UIScrollView的偏移量,簡(jiǎn)單且方便。下面就是全部代碼:

#import "ViewController.h"

#define kScreenWidth [UIScreen mainScreen].bounds.size.width

@interface ViewController () <UIScrollViewDelegate>

/// 滑動(dòng)控制器
@property (nonatomic, strong) UIScrollView *scrollView;
/// 圖片數(shù)組
@property (nonatomic, strong) NSArray<NSString *> *imageNameList;
/// 頁(yè)碼控制器
@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的起始偏移距離(將第一張圖片跳過(guò))
 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滑動(dòng)到第一位停止時(shí),將UIScrollView的偏移位置改變
 if (scrollView.contentOffset.x == 0) {
 scrollView.contentOffset = CGPointMake(self.imageNameList.count * kScreenWidth, 0);
 self.pageControl.currentPage = self.imageNameList.count;
 /// 當(dāng)UIScrollView滑動(dòng)到最后一位停止時(shí),將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如何實(shí)現(xiàn)UIScrollView的無(wú)限輪播功能”這篇文章的所有內(nèi)容,感謝各位的閱讀!希望分享的內(nèi)容對(duì)大家有幫助,更多相關(guān)知識(shí),歡迎關(guān)注創(chuàng)新互聯(lián)網(wǎng)站建設(shè)公司行業(yè)資訊頻道!

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

網(wǎng)站標(biāo)題:iOS如何實(shí)現(xiàn)UIScrollView的無(wú)限輪播功能-創(chuàng)新互聯(lián)
鏈接分享:http://www.chinadenli.net/article12/desegc.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供搜索引擎優(yōu)化GoogleChatGPT網(wǎng)站內(nèi)鏈面包屑導(dǎo)航網(wǎng)站導(dǎo)航

廣告

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

營(yíng)銷型網(wǎng)站建設(shè)