在UICollectionView中使用三張圖實現(xiàn)輪播


原理很簡單驹尼,就是在UICollectionViewCell上面放一個UIScrollView填抬,在UIScrollView放上三個UIImageView实檀,默認(rèn)的展示的是中間的UIImageView读规,當(dāng)用戶劃到下一張圖片的臨界點時候,偷偷的切換回中間的UIImageView展示杉允,但是UIImage卻全部換掉了邑贴,也就是說用戶永遠(yuǎn)看到的是中間的UIImageView限府,只是內(nèi)容不同而已。

步驟一

xib創(chuàng)建UIScrollView

  • 在xib文件中拖入一個UIScrollView痢缎,設(shè)置pageEnable為YES,添加top,leading,bottom,trailing四個約束世澜。這一步是為了確定scrollView的frame独旷。

  • 我們再拉一個UIView到scrollView上(注意:這個view很重要,她是用于確定scrollView的contentSize的),并對其上下左右進行約束,約束完你會發(fā)現(xiàn),約束報錯,scrollView的contentSize并不能確定!


    添加控制view
  • 約束完發(fā)現(xiàn)出錯了,不要著急寥裂,接著我們需要確定一下嵌洼, 我們是需要水平方向的滾動還是豎直方向的滾動,或者水平方向和豎直方向都需要滾動封恰。
    1.水平方向和豎直方向都需要滾動的話麻养, 不用添加
    2.水平方向滾動或者豎直方向滾動需要添加一個約束:


    設(shè)置滾動方向
  • 我們這里需要水平方向滾動:


    水平滾動約束.
  • 然后再添加一個寬度,設(shè)置contentsize诺舔,將這個寬度設(shè)置為屬性鳖昌,在代碼中設(shè)置其大小。


    設(shè)置寬度contentSize
步驟二

在view2上面添加三個UIImageView低飒,設(shè)置其寬度许昨,給中間的UIImageView添加手勢,響應(yīng)點擊事件

步驟三

代碼控制滾動褥赊,設(shè)置計時器

  • 設(shè)置數(shù)據(jù)源
    - (void)setDataArray:(NSArray *)dataArray
    {
    _dataArray = dataArray;
    if ([dataArray count] == 0) {
    NSLog(@"cycleImageViewConfig:images is empty!");
    return;
    }
    if (dataArray.count == 1) {
    self.scrollView.scrollEnabled = NO;
    }

        [self changeImageViewWithIndex:self.curIndex];
    
        self.pageControl.numberOfPages = dataArray.count;
    
        [self timeSetter];
    }
    
  • 設(shè)置定時器
    - (void)timeSetter
    {
    //將定時器放入主進程的RunLoop中
    if (!self.timer) {
    self.timer = [NSTimer scheduledTimerWithTimeInterval:CH_DEFAULT_DURATION_TIME target:self selector:@selector(timerAction) userInfo:nil repeats:YES];
    [[NSRunLoop currentRunLoop] addTimer:self.timer forMode:NSRunLoopCommonModes];
    }
    }

    - (void)timerAction{
          if (self.dataArray.count <= 1) {
             return ;
         }
          [self.scrollView setContentOffset:CGPointMake(kScreenWidth*2, 0) animated:YES];
          [self performSelector:@selector(reloadImage) withObject:nil afterDelay:.35];
    }
    
    - (void)reloadImage
    {
          if (self.dataArray.count == 0) {
             return;
          }
          CGPoint offset = [_scrollView contentOffset];
    
          if (offset.x > kScreenWidth) { //  向右滑動
               self.curIndex = CH_CYCLEINDEX_CALCULATE(self.curIndex+1, self.dataArray.count);
          } else if(offset.x < self.frame.size.width) {
            //  向左滑動
            self.curIndex = CH_CYCLEINDEX_CALCULATE(self.curIndex-1, self.dataArray.count);
          }
    
          [self changeImageViewWithIndex:self.curIndex];
    
          [self.scrollView setContentOffset:CGPointMake(kScreenWidth, 0) animated:NO];
          self.pageControl.currentPage = self.curIndex;
    }
    
  • 改變輪播的圖片
    - (void)changeImageViewWithIndex:(NSInteger)index
    {
    NSString *midString = self.dataArray[CH_CYCLEINDEX_CALCULATE(index, self.dataArray.count)];
    NSString *leftString = self.dataArray[CH_CYCLEINDEX_CALCULATE(index-1, self.dataArray.count)];
    NSString *rightString = self.dataArray[CH_CYCLEINDEX_CALCULATE(index+1, self.dataArray.count)];

        [self.leftImageView sd_setImageWithURL:[NSURL URLWithString:leftString] placeholderImage:[UIImage imageNamed:@"place_2"]];
        [self.midImageVIew sd_setImageWithURL:[NSURL URLWithString:midString] placeholderImage:[UIImage imageNamed:@"place_2"]];
        [self.rightImageView sd_setImageWithURL:[NSURL URLWithString:rightString] placeholderImage:[UIImage imageNamed:@"place_2"]];
    }
    
  • ScrollView Delegate
    //當(dāng)用戶手動個輪播時 關(guān)閉定時器
    - (void)scrollViewWillBeginDragging:(UIScrollView *)scrollView
    {
    [self.timer invalidate];
    self.timer = nil;
    }

    //當(dāng)用戶手指停止滑動圖片時 啟動定時器
    - (void)scrollViewDidEndDragging:(UIScrollView *)scrollView willDecelerate:(BOOL)decelerate
    {
    [self timeSetter];
    }

    - (void)scrollViewDidEndDecelerating:(UIScrollView *)scrollView
    {
        [self reloadImage];
    }
    

(具體看demo

demo 傳送門

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末糕档,一起剝皮案震驚了整個濱河市,隨后出現(xiàn)的幾起案子拌喉,更是在濱河造成了極大的恐慌速那,老刑警劉巖,帶你破解...
    沈念sama閱讀 216,402評論 6 499
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件尿背,死亡現(xiàn)場離奇詭異端仰,居然都是意外死亡,警方通過查閱死者的電腦和手機残家,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,377評論 3 392
  • 文/潘曉璐 我一進店門榆俺,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人坞淮,你說我怎么就攤上這事茴晋。” “怎么了回窘?”我有些...
    開封第一講書人閱讀 162,483評論 0 353
  • 文/不壞的土叔 我叫張陵诺擅,是天一觀的道長。 經(jīng)常有香客問我啡直,道長烁涌,這世上最難降的妖魔是什么苍碟? 我笑而不...
    開封第一講書人閱讀 58,165評論 1 292
  • 正文 為了忘掉前任,我火速辦了婚禮撮执,結(jié)果婚禮上微峰,老公的妹妹穿的比我還像新娘。我一直安慰自己抒钱,他們只是感情好蜓肆,可當(dāng)我...
    茶點故事閱讀 67,176評論 6 388
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著谋币,像睡著了一般仗扬。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上蕾额,一...
    開封第一講書人閱讀 51,146評論 1 297
  • 那天早芭,我揣著相機與錄音,去河邊找鬼诅蝶。 笑死退个,一個胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的秤涩。 我是一名探鬼主播帜乞,決...
    沈念sama閱讀 40,032評論 3 417
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼筐眷!你這毒婦竟也來了黎烈?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 38,896評論 0 274
  • 序言:老撾萬榮一對情侶失蹤匀谣,失蹤者是張志新(化名)和其女友劉穎照棋,沒想到半個月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體武翎,經(jīng)...
    沈念sama閱讀 45,311評論 1 310
  • 正文 獨居荒郊野嶺守林人離奇死亡烈炭,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 37,536評論 2 332
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發(fā)現(xiàn)自己被綠了宝恶。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片符隙。...
    茶點故事閱讀 39,696評論 1 348
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖垫毙,靈堂內(nèi)的尸體忽然破棺而出霹疫,到底是詐尸還是另有隱情,我是刑警寧澤综芥,帶...
    沈念sama閱讀 35,413評論 5 343
  • 正文 年R本政府宣布丽蝎,位于F島的核電站,受9級特大地震影響膀藐,放射性物質(zhì)發(fā)生泄漏屠阻。R本人自食惡果不足惜红省,卻給世界環(huán)境...
    茶點故事閱讀 41,008評論 3 325
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望国觉。 院中可真熱鬧吧恃,春花似錦、人聲如沸麻诀。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,659評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽针饥。三九已至,卻和暖如春需频,著一層夾襖步出監(jiān)牢的瞬間丁眼,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 32,815評論 1 269
  • 我被黑心中介騙來泰國打工昭殉, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留苞七,地道東北人。 一個月前我還...
    沈念sama閱讀 47,698評論 2 368
  • 正文 我出身青樓挪丢,卻偏偏與公主長得像蹂风,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子乾蓬,可洞房花燭夜當(dāng)晚...
    茶點故事閱讀 44,592評論 2 353

推薦閱讀更多精彩內(nèi)容