精品欧美一区二区三区在线观看 _久久久久国色av免费观看性色_国产精品久久在线观看_亚洲第一综合网站_91精品又粗又猛又爽_小泽玛利亚一区二区免费_91亚洲精品国偷拍自产在线观看 _久久精品视频在线播放_美女精品久久久_欧美日韩国产成人在线

高效圖片輪播,兩個imageView實現

移動開發 iOS
在不少項目中,都會有圖片輪播這個功能,現在網上關于圖片輪播的框架層出不窮,千奇百怪,筆者根據自己的思路,用兩個imageView也實現了圖片輪播,這里說說筆者的主要思路以及大概步驟,具體代碼請看這里,如果覺得好用,請獻上你的star。

該輪播框架的優勢:

  • 文件少,代碼簡潔
  • 不依賴任何其他第三方庫,耦合度低
  • 同時支持本地圖片及網絡圖片
  • 可修改分頁控件位置,顯示或隱藏
  • 自定義分頁控件的圖片,就是這么個性
  • 自帶圖片緩存,一次加載,永久使用
  • 性能好,占用內存少,輪播流暢

實際使用

我們先看demo,代碼如下

運行效果

1429074-dbe48ca8403116a5.gif

輪播實現步驟

接下來,筆者將從各方面逐一分析。

層級結構

最底層是一個UIView,上面有一個UIScrollView以及UIPageControl,scrollView上有兩個UIImageView,imageView寬高 = scrollview寬高 = view寬高

輪播原理

假設輪播控件的寬度為x高度為y,我們設置scrollview的contentSize.width為3x,并讓scrollview的水平偏移量為x,既顯示最中間內容

  1. scrollView.contentSize = CGSizeMake(3x, y);  
  2. scrollView.contentOffset = CGPointMake(x, 0); 

將imageView添加到scrollview內容視圖的中間位置

接下來使用代理方法scrollViewDidScroll來監聽scrollview的滾動,定義一個枚舉變量來記錄滾動的方向

  1. typedef enum{  
  2.   DirecNone,  
  3.   DirecLeft,  
  4.   DirecRight  
  5. } Direction;@property (nonatomic, assign) Direction direction;  
  6.    
  7. - (void)scrollViewDidScroll:(UIScrollView *)scrollView {  self.direction = scrollView.contentOffset.x >x? DirecLeft : DirecRight;  

使用KVO來監聽direction屬性值的改變

  1. [self addObserver:self forKeyPath:@"direction" options:NSKeyValueObservingOptionNew context:nil]; 

判斷滾動的方向,當偏移量大于x,表示左移,則將otherImageView加在右邊,偏移量小于x,表示右移,則將otherImageView加在左邊

  1. - (void)observeValueForKeyPath:(NSString *)keyPath ofObject:(id)object change:(NSDictionary *)change context:(void *)context {   //self.currIndex表示當前顯示圖片的索引,self.nextIndex表示將要顯示圖片的索引  
  2.   //_images為圖片數組  
  3.   if(change[NSKeyValueChangeNewKey] == change[NSKeyValueChangeOldKey]) return;  if ([change[NSKeyValueChangeNewKey] intValue] == DirecRight) {    self.otherImageView.frame = CGRectMake(0, 0, self.width, self.height);    selfself.nextIndex = self.currIndex - 1;    if (self.nextIndex < 0self.nextIndex = _images.count – 1;  
  4.   } else if ([change[NSKeyValueChangeNewKey] intValue] == DirecLeft){    self.otherImageView.frame = CGRectMake(CGRectGetMaxX(_currImageView.frame), 0, self.width, self.height);    self.nextIndex = (self.currIndex + 1) % _images.count;  
  5.   }  selfself.otherImageView.image = self.images[self.nextIndex];  

通過代理方法scrollViewDidEndDecelerating來監聽滾動結束,結束后,會變成以下兩種情況:

此時,scrollview的偏移量為0或者2x,我們通過代碼再次將scrollview的偏移量設置為x,并將currImageView的圖片修改為otherImageView的圖片

  1. - (void)scrollViewDidEndDecelerating:(UIScrollView *)scrollView {  
  2.   [self pauseScroll];  
  3. }  
  4.    
  5. - (void)pauseScroll {  self.direction = DirecNone;//清空滾動方向  
  6.     //判斷最終是滾到了右邊還是左邊  
  7.   int index = self.scrollView.contentOffset.x / x;  if (index == 1) return; //等于1表示最后沒有滾動,返回不做任何操作  
  8.   selfself.currIndex = self.nextIndex;//當前圖片索引改變  
  9.   selfself.pageControl.currentPage = self.currIndex;  self.currImageView.frame = CGRectMake(x, 0, x, y);  selfself.currImageView.image = self.otherImageView.image;  self.scrollView.contentOffset = CGPointMake(x, 0);  

那么我們看到的還是currImageView,只不過展示的是下一張圖片,如圖,又變成了最初的效果

自動滾動

輪播的功能實現了,接下來添加定時器讓它自動滾動,相當簡單

  1. - (void)startTimer {   //如果只有一張圖片,則直接返回,不開啟定時器  
  2.    if (_images.count <= 1) return;   //如果定時器已開啟,先停止再重新開啟  
  3.    if (self.timer) [self stopTimer];   self.timer = [NSTimer timerWithTimeInterval:self.time target:self selector:@selector(nextPage) userInfo:nil repeats:YES];  
  4.    [[NSRunLoop currentRunLoop] addTimer:self.timer forMode:NSRunLoopCommonModes];  
  5. }  
  6.    
  7. - (void)nextPage {    //動畫改變scrollview的偏移量就可以實現自動滾動  
  8.   [self.scrollView setContentOffset:CGPointMake(self.width * 2, 0) animated:YES];  

注意:setContentOffset:animated:方法執行完畢后不會調用scrollview的scrollViewDidEndDecelerating方法,但是會調用scrollViewDidEndScrollingAnimation方法,因此我們要在該方法中調用pauseScroll

  1. - (void)scrollViewDidEndScrollingAnimation:(UIScrollView *)scrollView {  
  2.   [self pauseScroll];  

拖拽時停止自動滾動

當我們手動拖拽圖片時,需要停止自動滾動,此時我們只需要讓定時器失效就行了,當停止拖拽時,重新啟動定時器

  1. - (void)scrollViewWillBeginDragging:(UIScrollView *)scrollView {  
  2.   [self.timer invalidate];  
  3. }  
  4.    
  5. - (void)scrollViewDidEndDragging:(UIScrollView *)scrollView willDecelerate:(BOOL)decelerate{  
  6.   [self startTimer];  

加載圖片

實際開發中,我們很少會輪播本地圖片,大部分都是服務器獲取的,也有可能既有本地圖片,也有網絡圖片,那要如何來加載呢?

定義4個屬性

  • NSArray imageArray:暴露在.h文件中,外界將要加載的圖片或路徑數組賦值給該屬性
  • NSMutableArray images:用來存放圖片的數組
  • NSMutableDictionary imageDic:用來緩存圖片的字典,key為URL
  • NSMutableDictionary operationDic:用來保存下載操作的字典,key為URL

判斷外界傳入的是圖片還是路徑,如果是圖片,直接加入圖片數組中,如果是路徑,先添加一個占位圖片,然后根據路徑去下載圖片

  1. _images = [NSMutableArray array];for (int i = 0; i < imageArray.count; i++) {    if ([imageArray[i] isKindOfClass:[UIImage class]]) {  
  2.       [_images addObject:imageArray[i]];//如果是圖片,直接添加到images中  
  3.     } else if ([imageArray[i] isKindOfClass:[NSString class]]){  
  4.       [_images addObject:[UIImage imageNamed:@"placeholder"]];//如果是路徑,添加一個占位圖片到images中  
  5.       [self downloadImages:i];  //下載網絡圖片  
  6.     }  
  7.   } 

下載圖片,先從緩存中取,如果有,則替換之前的占位圖片,如果沒有,去沙盒中取,如果有,替換占位圖片,并添加到緩存中,如果沒有,開啟異步線程下載

  1. - (void)downloadImages:(int)index {  NSString *key = _imageArray[index];  //從字典緩存中取圖片  
  2.   UIImage *image = [self.imageDic objectForKey:key];  if (image) {  
  3.     _images[index] = image;//如果圖片存在,則直接替換之前的占位圖片  
  4.   }else{    //字典中沒有從沙盒中取圖片  
  5.     NSString *cache = [NSSearchPathForDirectoriesInDomains(NSCachesDirectory, NSUserDomainMask, YES) lastObject];    NSString *path = [cache stringByAppendingPathComponent:[key lastPathComponent]];    NSData *data = [NSData dataWithContentsOfFile:path];    if (data) {             //沙盒中有,替換占位圖片,并加入字典緩存中  
  6.       image = [UIImage imageWithData:data];  
  7.       _images[index] = image;  
  8.       [self.imageDic setObject:image forKey:key];  
  9.     }else{       //字典沙盒都沒有,下載圖片  
  10.       NSBlockOperation *download = [self.operationDic objectForKey:key];//查看下載操作是否存在  
  11.       if (!download) {//不存在  
  12.         //創建一個隊列,默認為并發隊列  
  13.         NSOperationQueue *queue = [[NSOperationQueue alloc] init];        //創建一個下載操作  
  14.         download = [NSBlockOperation blockOperationWithBlock:^{          NSURL *url = [NSURL URLWithString:key];          NSData *data = [NSData dataWithContentsOfURL:url];           if (data) {                        //下載完成后,替換占位圖片,存入字典并寫入沙盒,將下載操作從字典中移除掉  
  15.             UIImage *image = [UIImage imageWithData:data];  
  16.             [self.imageDic setObject:image forKey:key];            self.images[index] = image;                        //如果只有一張圖片,需要在主線程主動去修改currImageView的值  
  17.             if (_images.count == 1) [_currImageView performSelectorOnMainThread:@selector(setImage:) withObject:image waitUntilDone:NO];  
  18.             [data writeToFile:path atomically:YES];  
  19.             [self.operationDic removeObjectForKey:key];   
  20.             }  
  21.         }];  
  22.         [queue addOperation:download];  
  23.         [self.operationDic setObject:download forKey:key];//將下載操作加入字典  
  24.       }  
  25.     }  
  26.   }  

監聽圖片點擊

當圖片被點擊的時候,我們往往需要執行某些操作,因此需要監聽圖片的點擊,思路如下

1.定義一個block屬性暴露給外界void(^imageClickBlock)(NSInteger index)

(不會block的可以用代理,或者看這里)

2.設置currImageView的userInteractionEnabled為YES

3.給currImageView添加一個點擊的手勢

4.在手勢方法里調用block,并傳入圖片索引

結束語

上面是筆者的主要思路以及部分代碼,需要源碼的請前往筆者的github下載:https://github.com/codingZero/XRCarouselView,記得獻上你的星星哦

責任編輯:陳琳 來源: CocoaChina
相關推薦

2010-07-17 00:50:12

batch Telne

2013-05-10 09:31:06

程序員

2021-09-08 09:52:34

語言

2022-06-17 09:46:51

Chrome 102Chrome瀏覽器

2024-03-20 09:40:27

動畫技巧CSS逐幀動畫

2011-09-07 16:43:38

Qt Widget

2010-07-21 11:32:35

SQL Server日

2010-09-13 16:55:27

DIV橫向排列

2009-06-30 09:37:02

對象比較Java

2025-02-25 09:11:08

2010-05-27 09:50:18

MySQL導入sql腳

2020-11-13 07:16:09

線程互斥鎖死循環

2009-07-16 10:39:00

SwingUtilit

2010-09-10 15:26:05

SOAP封裝

2020-10-26 08:19:53

算法隊列

2024-01-11 11:35:46

Python開發

2010-09-17 09:51:37

SIP路由

2010-07-02 12:26:51

LEACH協議

2017-01-15 01:45:37

簡歷簡歷模板數據

2009-07-15 18:29:22

Jython應用
點贊
收藏

51CTO技術棧公眾號

亚洲精品成人精品456| 国产一级特黄毛片| 亚洲图片在线视频| 欧美日韩国产专区| 3atv一区二区三区| 国产亚洲欧美一区二区三区| 受虐m奴xxx在线观看| aaa在线观看| 嫩呦国产一区二区三区av| 亚洲综合不卡| 欧美一区永久视频免费观看| 久久久久久a亚洲欧洲aⅴ| 亚洲AV成人无码精电影在线| 色在线免费观看| 精品一区二区三区欧美| 亚洲欧美一区二区三区情侣bbw| 法国空姐在线观看免费| 一区二区三区在线观看av| 欧美特黄一级大片| 欧美日韩综合视频网址| 国产精品theporn88| 国产97免费视频| 国内精品伊人| 久久久精品天堂| 海角国产乱辈乱精品视频| 超碰成人免费在线| 国内老熟妇对白hdxxxx| 久久免费大视频| 色嗨嗨av一区二区三区| 久久精品magnetxturnbtih| 中文字幕免费播放| 日韩理论电影大全| 在线观看亚洲精品视频| 日本高清一区| 亚洲成人av影片| 亚洲自拍偷拍网| 91精品国模一区二区三区| 国产97在线 | 亚洲| 欧美自拍偷拍一区二区| 韩日成人在线| 亚洲高清一二三区| 久久久久久久久久伊人| 国产又粗又猛又黄视频| 亚洲国产精品嫩草影院久久av| 亚洲影院理伦片| 99在线视频播放| 国产一级淫片a| 精品淫伦v久久水蜜桃| 亚洲一区二区在线播放相泽| 日韩精品无码一区二区三区| 中文字幕制服诱惑| 久久久人人人| 国产丝袜一区视频在线观看| 亚洲熟妇av一区二区三区| 牛牛热在线视频| 日韩成人伦理电影在线观看| 中文字幕综合在线| 九九热99视频| 超碰公开在线| 成人h动漫精品一区二| 国语自产精品视频在线看一大j8 | 成av人电影在线观看| 日韩国产欧美在线观看| 55夜色66夜色国产精品视频| 男人天堂av电影| 日韩精品导航| 欧美唯美清纯偷拍| 亚洲国产一二三精品无码| 欧美69xxxx| 不卡一区二区中文字幕| 国产精品一区二区不卡视频| 国产精品999在线观看| 欧美中文字幕一区二区| 一本大道亚洲视频| 韩国三级与黑人| 日本在线啊啊| 欧美日韩精品中文字幕| 免费在线激情视频| 欧亚一区二区| 亚洲一区二区五区| 日韩国产一级片| 人在线成免费视频| 欧美影院一区二区三区| 午夜国产一区二区三区| 国产婷婷视频在线 | 国产玖玖精品视频| 欧美三级小视频| 国产aⅴ精品一区二区三区久久| 7878成人国产在线观看| 精品人妻一区二区三区免费| 一呦二呦三呦精品国产| 欧洲一区二区三区免费视频| 日日干日日操日日射| 大胆人体一区| 亚洲自拍偷拍欧美| 在线综合视频网站| 欧美孕妇性xxxⅹ精品hd| 国产成人高清视频| 91精品国产综合久久香蕉的用户体验| 制服.丝袜.亚洲.中文.综合懂色| 久久一区视频| 91久久精品国产91性色| 成人免费视频国产免费| 一区二区三区国产在线| 欧美情侣性视频| 一级片黄色录像| 美女精品一区最新中文字幕一区二区三区| 日韩免费一区二区| 亚洲一区二区偷拍| 日韩欧美三区| 欧美性大战久久久久久久蜜臀| 天堂av在线8| 伦理一区二区| 久久精品中文字幕免费mv| 国产精品扒开腿做爽爽| 91精品久久久久久久蜜月| 一区二区福利视频| 精品无码一区二区三区电影桃花| 日韩免费特黄一二三区| 国产做受69高潮| 在线观看国产精品入口男同| 日韩国产欧美在线播放| 999热视频在线观看| av网站免费大全| 337p粉嫩大胆噜噜噜噜噜91av| 国产另类自拍| 欧美成年黄网站色视频| 色综合久久久久综合| 国产极品美女高潮无套久久久| 午夜激情在线播放| 欧美日韩亚洲激情| 少妇性l交大片7724com| 日韩激情免费| 热久久99这里有精品| 无码人妻精品一区二区| 成人免费视频一区| 久久av二区| 国产原厂视频在线观看| 欧美日韩精品高清| 天堂在线精品视频| 欧美军人男男激情gay| 日韩在线视频观看正片免费网站| 麻豆视频免费在线播放| 欧美一级播放| 国产偷久久久精品专区| 日本高清在线观看视频| 午夜久久久久久电影| 免费av观看网址| 日韩精品视频在线看| 亚洲白拍色综合图区| 91丝袜在线观看| 伊人春色精品| 97热精品视频官网| 欧美一区,二区| 亚洲综合一区二区| 国产免费无码一区二区| 天堂资源在线亚洲| 91精品国产91久久久久久不卡| 波多野结衣一区二区三区四区| 91在线观看免费视频| 视频在线99| 最新超碰在线| 岛国av一区二区在线在线观看| 国产麻豆剧传媒精品国产| 欧美区一区二| 庆余年2免费日韩剧观看大牛| 亚洲欧美日韩动漫| 中文字幕视频一区二区三区久| 9191国产视频| **欧美日韩在线观看| 日韩无一区二区| 右手影院亚洲欧美| 99re6这里只有精品| 免费91在线视频| 亚洲 欧美 日韩 综合| 91丨porny丨首页| 一本久道中文无码字幕av| 日韩在线精品强乱中文字幕| 欧美老女人性生活| 少妇一区二区三区四区| 中文字幕一区二区在线播放| 131美女爱做视频| 亚洲精品tv| 九色精品美女在线| 免费观看a视频| 一本久久综合亚洲鲁鲁五月天| 欧美激情亚洲色图| 99视频精品| 日韩中文一区| 日韩精品一级| 热re91久久精品国99热蜜臀| 欧美成人三区| 日韩精品久久久久久久玫瑰园| 高h视频免费观看| 成人av手机在线观看| 麻豆av免费在线| 亚洲人metart人体| 久久青青草综合| 日韩在线电影| 97碰在线观看| 国产91在线视频蝌蚪| 日韩电影中文字幕在线| 在线免费a视频| 亚洲第一成人在线| 一级全黄裸体片| 可以免费看不卡的av网站| 三年中文高清在线观看第6集| 欧美艳星kaydenkross| 久久精品视频中文字幕| 涩爱av在线播放一区二区| 在线播放国产精品二区一二区四区| 日韩xxxxxxxxx| 自拍偷自拍亚洲精品播放| 亚洲国产果冻传媒av在线观看| 亚洲国产导航| 国产乱人伦精品一区二区| 午夜av成人| 国产一区二区三区在线免费观看| 国产色视频在线| 亚洲精品久久久蜜桃| 久操视频免费看| 成人黄色小视频在线观看| 天天操狠狠操夜夜操| 久久国产精品99国产| 天堂а√在线中文在线| 久久精品国产大片免费观看| 久久久久网址| 国产精品调教| 欧美一级大片在线观看| 国产区在线观看| 中文字幕欧美日韩| 欧洲亚洲精品视频| 日韩精品一区二区三区四区| 国产一区二区三区成人| 亚洲免费在线视频一区 二区| 精产国品一二三区| 免费成人av在线播放| 欧美aaa在线观看| 国产一区日韩| 欧美日韩天天操| 久久久久久久性潮| 庆余年2免费日韩剧观看大牛| 2020日本在线视频中文字幕| 亚洲人免费视频| 一级黄在线观看| 欧美色网站导航| 一区二区在线观看免费视频| 成人免费一区二区三区在线观看| 五月婷婷婷婷婷| 国产精品久久综合| 一级黄色免费视频| 日韩在线a电影| 成熟老妇女视频| 免费亚洲婷婷| 日韩一级免费在线观看| 老色鬼久久亚洲一区二区| 日韩毛片在线免费看| 日韩一区欧美二区| 天美星空大象mv在线观看视频| 91精品一区二区三区综合| 一区二区三区的久久的视频| 99精品国产一区二区三区2021| 欧美最顶级丰满的aⅴ艳星| 欧美伦理91| 国产91在线播放精品91| 91福利国产在线观看菠萝蜜| 久久精品中文字幕免费mv| 深夜国产在线播放| 久久久免费观看视频| 精品极品在线| 久久精品国产欧美亚洲人人爽| 欧美激情午夜| 欧美激情视频在线观看| 亚洲三区在线播放| 亚洲精品自产拍| 在线免费观看黄色网址| 久久成人18免费网站| 国产黄色免费在线观看| 亚洲第一视频网站| 亚洲av成人精品毛片| 国产一区二区三区视频在线观看| 国精品人妻无码一区二区三区喝尿 | 制服下的诱惑暮生| 成人精品高清在线| 国产一二三四五区| 成人一级黄色片| 一本色道综合久久欧美日韩精品 | 亚洲国产精品精华液网站| 99热国产在线观看| 亚洲精选一二三| 日本中文字幕网| 欧美亚洲综合久久| jlzzjlzzjlzz亚洲人| 国产视频久久久久| 欧美jizzhd69巨大| 欧美亚洲国产另类| 日韩一级特黄| 麻豆精品视频| 蜜臀av一区| www.一区二区三区| 香蕉久久99| 亚洲高潮无码久久| 免费亚洲视频| 中文字幕18页| 中文av一区二区| 五月天精品在线| 国产网站一区二区| 欧美日韩高清丝袜| 亚洲精品国产无套在线观| 黄色在线观看国产| 欧美日韩国产综合新一区 | 青草视频在线免费直播| 久久久久999| 涩涩涩在线视频| 亚洲影院高清在线| 久久伊人精品| 三区精品视频观看| 一本久道久久久| 韩国三级丰满少妇高潮| 亚洲国产精品成人综合| 国产成人自拍视频在线| 91精品欧美一区二区三区综合在 | 污污网站在线观看视频| 成人av在线观| 成人免费精品动漫网站| 中文字幕av一区二区三区高 | 日本一区二区三区在线免费观看| 91在线一区二区三区| 欧美人与禽zozzo禽性配| 一区二区不卡在线播放| 中文字幕一区二区人妻| 亚洲欧洲在线看| 97蜜桃久久| 电影午夜精品一区二区三区| 91日韩欧美| 奇米影音第四色| 国产亚洲欧洲一区高清在线观看| 日韩成人毛片视频| 911精品国产一区二区在线| 成人h小游戏| 91大神在线播放精品| 国产一级成人av| 日韩欧美猛交xxxxx无码| 国产资源在线一区| youjizz.com日本| 亚洲欧美国产毛片在线| 国产精品一区二区av白丝下载| 欧美刺激午夜性久久久久久久| 理论片午午伦夜理片在线播放| 日韩免费观看高清| 制服丝袜日韩| 国产v亚洲v天堂无码久久久| 久久色在线视频| www深夜成人a√在线| 欧美三级视频在线播放| 国产精品一二三区视频| 国产精品91免费在线| 国产精品一站二站| 国产女人水真多18毛片18精品 | 成人国产精品免费网站| 久久久久成人网站| 亚洲第一区中文字幕| 欧美亚洲日本精品| 青青草成人网| 麻豆一区二区在线| 欧美精品丝袜久久久中文字幕| 久青草免费视频| 精品区一区二区| 国产大学生校花援交在线播放| 日韩美女视频免费在线观看| 精品久久视频| 中文字幕 欧美日韩| 一区二区三区在线观看网站| 国产综合视频在线| 茄子视频成人在线| 成人在线国产| 九九九久久久久久久| 午夜影院久久久| 国产天堂在线| 国产主播欧美精品| 伊人久久亚洲美女图片| 亚洲欧美日韩精品一区| 亚洲免费毛片网站| 高h调教冰块play男男双性文| 8050国产精品久久久久久| 国产不卡一区| 夜夜爽久久精品91| 岛国av午夜精品| 日本暖暖在线视频| 欧美最猛黑人xxxx黑人猛叫黄 | 一本色道久久综合亚洲二区三区| 久久99精品久久久久久国产越南| 私库av在线播放| 亚洲美女久久久| 久久亚洲国产精品尤物| www.好吊操| 国产精品影视天天线| av片在线免费看| 精品少妇一区二区三区免费观看| 欧美7777|