麻豆小视频在线观看_中文黄色一级片_久久久成人精品_成片免费观看视频大全_午夜精品久久久久久久99热浪潮_成人一区二区三区四区

首頁 > 系統 > iOS > 正文

iOS實現UIScrollView的無限輪播功能(原理)詳解

2019-10-21 18:39:37
字體:
來源:轉載
供稿:網友

前言

同學們在寫需求的時候肯定會時常用到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

 

總結

以上就是這篇文章的全部內容了,希望本文的內容對大家的學習或者工作具有一定的參考學習價值,如果有疑問大家可以留言交流,謝謝大家對VEVB武林網的支持。


注:相關教程知識閱讀請移步到IOS開發頻道。
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: h视频在线观看免费 | 日本网站在线看 | 欧美成人免费一区二区三区 | 成人免费视频视频在线观看 免费 | 中国杭州少妇xxxx做受 | 国产精品久久久久久久久久 | 成人在线观看污 | 国产精品免费成人 | 九九热在线视频免费观看 | 国产喷白浆10p | 中文有码一区二区 | 黄色av免费电影 | 国产乱淫av一区二区三区 | 国产美女的小嫩bbb图片 | 成人午夜免费国产 | 精品中文字幕久久久久四十五十骆 | 亚洲嫩草av | av在线浏览| videos韩国 | 最新久久免费视频 | 中文字幕精品一二三四五六七八 | 国产精品视频一区二区三区综合 | 羞羞答答视频 | 日韩一级免费毛片 | 日本娇小videos高潮 | 一级做受大片免费视频 | 日韩黄色免费在线观看 | 欧美高清在线精品一区二区不卡 | 看全色黄大色黄大片女图片 | 国产porn在线 | 欧美一区二区黄 | 国产精品久久久久久久av | 亚洲一区二区三区精品在线观看 | 第四色成人网 | 日日鲁夜夜视频热线播放 | 久色成人 | 男人的天堂视频网站 | 黄色小视频免费在线观看 | 天堂精品久久 | 久久影院在线观看 | 免费一级毛片在线播放视频 |