91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

iOS如何實現UIScrollView的無限輪播功能

發布時間:2021-05-24 12:01:48 來源:億速云 閱讀:262 作者:小新 欄目:移動開發

這篇文章主要介紹iOS如何實現UIScrollView的無限輪播功能,文中介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們一定要看完!

UIScrollView控件是什么?

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

(2)當展?示的內容較多,超出?一個屏幕時,?用戶可通過滾動?手勢來查看屏幕以外的內容

(3)普通的UIView不具備滾動功能,不能顯?示過多的內容

(4)UIScrollView是一個能夠滾動的視圖控件,可以?用來展?示?大量的內容,并且可以通過滾 動查看所有的內容

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

而說到UIScrollView,大家最先想到的肯定就是它上面的無限輪播功能。蘋果在UIScrollView上并沒有提供相應的方法讓大家實現輪播,所以就需要通過代碼進行處理來實現。

先上圖

iOS如何實現UIScrollView的無限輪播功能
無限輪播效果圖.gif

我先給大家講講其實現的原理:

我們假設用幾張圖片實現輪播效果。首先,我們需要打開UIScrollView的分頁滑動

/// 分頁滑動
_scrollView.scrollEnabled = YES;

它方便的幫助我們實現了輪播的效果,然后就需要我們來實現“無限的”輪播。接下來,我們就需要擺放圖片了,在擺放圖片時需要注意,我們需要在第一張圖片的位置擺放最后一張圖片(可能有點懵哈,不過不要著急慢慢往下看),然后我們依次擺放圖片(從第一張到最后一張),最后在所有圖片的尾部我們再放上第一張圖片。這樣我們就多放了兩張圖片(分別在首尾多放了一張圖)。我把對應的方法寫一下:

/// 將圖片放置在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];
 
 /// 設置UIScrollView的偏移量
 self.scrollView.contentSize = CGSizeMake((self.imageNameList.count + 2) * self.scrollView.bounds.size.width, 0);
 
 /// 設置UIScrollView的起始偏移距離(將第一張圖片跳過)
 self.scrollView.contentOffset = CGPointMake(kScreenWidth, 0);
 
 /// 圖片總數
 self.pageControl.numberOfPages = self.imageNameList.count;
 self.pageControl.currentPage = 0;
}

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

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

#import "ViewController.h"

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

@interface ViewController () <UIScrollViewDelegate>

/// 滑動控制器
@property (nonatomic, strong) UIScrollView *scrollView;
/// 圖片數組
@property (nonatomic, strong) NSArray<NSString *> *imageNameList;
/// 頁碼控制器
@property (nonatomic, strong) UIPageControl *pageControl;

@end

@implementation ViewController

- (void)viewDidLoad {
 [super viewDidLoad];
 
 // 設置圖片名的數組
 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];
 
 /// 設置UIScrollView的偏移量
 self.scrollView.contentSize = CGSizeMake((self.imageNameList.count + 2) * self.scrollView.bounds.size.width, 0);
 
 /// 設置UIScrollView的起始偏移距離(將第一張圖片跳過)
 self.scrollView.contentOffset = CGPointMake(kScreenWidth, 0);
 
 /// 圖片總數
 self.pageControl.numberOfPages = self.imageNameList.count;
 self.pageControl.currentPage = 0;
}

#pragma mark - UIScrollViewDelegate
-(void)scrollViewDidEndDecelerating:(UIScrollView *)scrollView {
 /// 當UIScrollView滑動到第一位停止時,將UIScrollView的偏移位置改變
 if (scrollView.contentOffset.x == 0) {
 scrollView.contentOffset = CGPointMake(self.imageNameList.count * kScreenWidth, 0);
 self.pageControl.currentPage = self.imageNameList.count;
 /// 當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如何實現UIScrollView的無限輪播功能”這篇文章的所有內容,感謝各位的閱讀!希望分享的內容對大家有幫助,更多相關知識,歡迎關注億速云行業資訊頻道!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

霍山县| 德清县| 布拖县| 乃东县| 文登市| 特克斯县| 兴国县| 远安县| 申扎县| 区。| 黔东| 屏东县| 高州市| 绩溪县| 长丰县| 新晃| 扶风县| 平原县| 左云县| 陇南市| 陇西县| 乐山市| 奈曼旗| 张家港市| 阜康市| 临夏市| 台南县| 定兴县| 峡江县| 巩义市| 南昌市| 伊金霍洛旗| 中方县| 福鼎市| 乌拉特前旗| 鹤岗市| 满城县| 衡山县| 澳门| 德格县| 英德市|