欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

iOS實現無限循環(huán)輪播圖效果

 更新時間:2018年07月22日 09:39:55   作者:踏莎行hyx  
這篇文章主要為大家詳細介紹了iOS實現無限循環(huán)輪播圖效果,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下

本文實例為大家分享了iOS實現無限循環(huán)輪播圖的具體代碼,供大家參考,具體內容如下

輪播圖基礎控件,左滑右滑都能無限循環(huán)

預覽

思路

(1)在第一張左邊加一張最后一張的圖片,往左滑到邊緣結束后計算偏移量迅速定位成最后一張

#pragma mark - pagecontrol事件
// 這個是點擊小圓點條進行切換,到邊不能循環(huán)
- (void)pageControlTouched
{
 // 點擊的時候停止計時
 [self.kvTimer setFireDate:[NSDate distantFuture]];
 
 // 滑到指定頁面
 NSInteger curPageIdx = _pageControl.currentPage;
 CGFloat offsetX = self.frame.size.width * (curPageIdx + 1);
 [self.scrollView setContentOffset:CGPointMake(offsetX, 0) animated:YES];
 
 // 重新開啟定時器
 [self.kvTimer setFireDate:[NSDate dateWithTimeInterval:kTimerInterval sinceDate:[NSDate date]]];
}
 
#pragma mark - 滾動事件
- (void)scrollViewWillBeginDragging:(UIScrollView *)scrollView
{
// printf("start drag\n");
 // 記錄偏移量
 preOffsetX = scrollView.contentOffset.x;
 // 開始手動滑動時暫停定時器
 [self.kvTimer setFireDate:[NSDate distantFuture]];
}
 
- (void)scrollViewDidEndDecelerating:(UIScrollView *)scrollView
{
// printf("end drag\n");
 // 左右邊界
 CGFloat leftEdgeOffsetX = 0;
 CGFloat rightEdgeOffsetX = self.frame.size.width * (_pageCount + 1);
 
 if (scrollView.contentOffset.x < preOffsetX)
 {
 // 左滑
 if (scrollView.contentOffset.x > leftEdgeOffsetX)
 {
  self.pageControl.currentPage = scrollView.contentOffset.x / self.frame.size.width - 1;
 }
 else if (scrollView.contentOffset.x == leftEdgeOffsetX)
 {
  self.pageControl.currentPage = _pageCount - 1;
 }
 
 if (scrollView.contentOffset.x == leftEdgeOffsetX)
 {
  self.scrollView.contentOffset = CGPointMake(self.frame.size.width * _pageCount, 0);
 }
 }
 else
 {
 // 右滑
 
 // 設置小點
 if (scrollView.contentOffset.x < rightEdgeOffsetX)
 {
  self.pageControl.currentPage = scrollView.contentOffset.x / self.frame.size.width - 1;
 }
 else if (scrollView.contentOffset.x == rightEdgeOffsetX)
 {
  self.pageControl.currentPage = 0;
 }
 
 // 滑動完了之后從最后多余頁趕緊切換到第一頁
 if (scrollView.contentOffset.x == rightEdgeOffsetX)
 {
  self.scrollView.contentOffset = CGPointMake(self.frame.size.width, 0);
 }
 
 }
 // 結束后又開啟定時器
 [self.kvTimer setFireDate:[NSDate dateWithTimeInterval:kTimerInterval sinceDate:[NSDate date]]];
}
 
- (void)scrollViewDidEndScrollingAnimation:(UIScrollView *)scrollView
{
// printf("end scroll\n");
}
 
#pragma mark - 定時器控制的滑動
// 往右邊滑
- (void)changePageRight
{
 // 設置當前需要偏移的量,每次遞增一個page寬度
 CGFloat offsetX = _scrollView.contentOffset.x + CGRectGetWidth(self.frame);
 
 // 根據情況進行偏移
 CGFloat edgeOffsetX = self.frame.size.width * (_pageCount + 1); // 最后一個多余頁面右邊緣偏移量
 
 // 從多余頁往右邊滑,趕緊先設置為第一頁的位置
 if (offsetX > edgeOffsetX)
 {
 // 偏移量,不帶動畫,欺騙視覺
 self.scrollView.contentOffset = CGPointMake(self.frame.size.width, 0);
 // 這里提前改變下一個要滑動到的位置為第二頁
 offsetX = self.frame.size.width * 2;
 }
 
 // 帶動畫滑動到下一頁面
 [self.scrollView setContentOffset:CGPointMake(offsetX, 0) animated:YES];
 if (offsetX < edgeOffsetX)
 {
 self.pageControl.currentPage = offsetX / self.frame.size.width - 1;
 }
 else if (offsetX == edgeOffsetX)
 {
 // 最后的多余那一頁滑過去之后設置小點為第一個
 self.pageControl.currentPage = 0;
 }
}
 
// 往左邊滑
- (void)changePageLeft
{
 // 設置當前需要偏移的量,每次遞減一個page寬度
 CGFloat offsetX = _scrollView.contentOffset.x - CGRectGetWidth(self.frame);
 
 // 根據情況進行偏移
 CGFloat edgeOffsetX = 0; // 最后一個多余頁面左邊緣偏移量
 
 // 從多余頁往左邊滑動,先設置為最后一頁
 if (offsetX < edgeOffsetX)
 {
 self.scrollView.contentOffset = CGPointMake(self.frame.size.width * _pageCount, 0);
 offsetX = self.frame.size.width * (_pageCount - 1);
 }
 
 // 帶動畫滑動到前一頁面
 [self.scrollView setContentOffset:CGPointMake(offsetX, 0) animated:YES];
 if (offsetX > edgeOffsetX)
 {
 self.pageControl.currentPage = offsetX / self.frame.size.width - 1;
 }
 else if (offsetX == edgeOffsetX)
 {
 // 最后的多余那一頁滑過去之后設置小點為最后一個
 self.pageControl.currentPage = _pageCount - 1;
 }
}

(2)總共只有左、中、右三個頁面,每次滑動后重新進行數據跟頁面的關聯

#pragma mark - 定時器回調
- (void)changePageRight
{
 // 往右滑并且設置小圓點,永遠都是滑到第三頁
 [_scrollView setContentOffset:CGPointMake(self.frame.size.width * 2, 0) animated:YES];
 [self resetPageIndex:YES];
}
 
- (void)changePageLeft
{
 // 往左滑,永遠都是滑動到第一頁
 [_scrollView setContentOffset:CGPointMake(0, 0) animated:YES];
 [self resetPageIndex:NO];
}
 
#pragma mark - 重新設置索引和頁面圖片
- (void)resetPageIndex:(BOOL)isRight
{
 if (isRight)
 {
 // 根據之前的page下標來修改
 if (_prePageIndex == _pageCount - 1)
 {
  // 到頭了就回到第一個
  _pageControl.currentPage = 0;
 }
 else
 {
  // 這里用_prePageIndex來算,否則點擊小圓點條會重復計算了
  _pageControl.currentPage = _prePageIndex + 1;
 }
 }
 else
 {
 if (_prePageIndex == 0)
 {
  _pageControl.currentPage = _pageCount - 1;
 }
 else
 {
  _pageControl.currentPage = _prePageIndex - 1;
 }
 }
 _prePageIndex = _pageControl.currentPage;
}
 
- (void)resetPageView
{
 // 每次滑動完了之后又重新設置當前顯示的page時中間的page
 UIImageView *leftPage = [_scrollView viewWithTag:1000];
 UIImageView *middlePage = [_scrollView viewWithTag:1001];
 UIImageView *rightPage = [_scrollView viewWithTag:1002];
 
 if (_pageControl.currentPage == _pageCount - 1)
 {
 // n- 1 -> n -> 0
 leftPage.image = _kvImageArray[_pageControl.currentPage - 1];
 middlePage.image = _kvImageArray[_pageControl.currentPage];
 rightPage.image = _kvImageArray.firstObject;
 
 }
 else if (_pageControl.currentPage == 0)
 {
 // n -> 0 -> 1
 // 到尾部了,改成從頭開始
 leftPage.image = _kvImageArray.lastObject;
 middlePage.image = _kvImageArray.firstObject;
 rightPage.image = _kvImageArray[1];
 }
 else
 {
 // x - 1 -> x -> x + 1
 leftPage.image = _kvImageArray[_pageControl.currentPage - 1];
 middlePage.image = _kvImageArray[_pageControl.currentPage];
 rightPage.image = _kvImageArray[_pageControl.currentPage + 1];
 }
 
 // 重新設置偏移量
 _scrollView.contentOffset = CGPointMake(self.frame.size.width, 0);
}
 
#pragma mark - pagecontrol事件
- (void)pageControlTouched
{
 [self stopTimer];
 
 NSInteger curPageIndex = _pageControl.currentPage;
 if (curPageIndex > _prePageIndex)
 {
 // 右滑
 [self changePageRight];
 }
 else
 {
 // 左滑
 [self changePageLeft];
 }
 
 [self startTimer];
}
 
#pragma mark - scrollview滑動代理
- (void)scrollViewWillBeginDragging:(UIScrollView *)scrollView
{
 // 先停掉定時器
 [self stopTimer];
 
}
 
- (void)scrollViewDidEndDecelerating:(UIScrollView *)scrollView
{
 // 手動拖拽滑動結束后
 if (scrollView.contentOffset.x > self.frame.size.width)
 {
 // 右滑
 [self resetPageIndex:YES];
 }
 else
 {
 // 左滑
 [self resetPageIndex:NO];
 }
 [self resetPageView];
 
 // 開啟定時器
 [self startTimer];
}
 
- (void)scrollViewDidEndScrollingAnimation:(UIScrollView *)scrollView
{
 // 自動滑動結束后重新設置圖片
 [self resetPageView];
}

源代碼下載

csdn:輪播圖
github:輪播圖

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。

相關文章

  • iOS開發(fā)中WebView的基本使用方法簡介

    iOS開發(fā)中WebView的基本使用方法簡介

    這篇文章主要介紹了iOS開發(fā)中WebView的基本使用方法,代碼基于傳統(tǒng)的Objective-C,需要的朋友可以參考下
    2015-11-11
  • IOS 仿支付寶支付屏幕亮度變化機制

    IOS 仿支付寶支付屏幕亮度變化機制

    這篇文章主要介紹了IOS 仿支付寶支付屏幕亮度變化機制的相關資料,非常不錯,具有參考借鑒價值,需要的朋友可以參考下
    2017-01-01
  • iOS中的UISlider滑塊組件用法總結

    iOS中的UISlider滑塊組件用法總結

    不僅是滑動開關,UISlider組件也是常用的進度條制作工具,這里我們就一起來看一下iOS中的UISlider滑塊組件用法總結,需要的朋友可以參考下
    2016-06-06
  • iOS NSURLProtocol的具體使用方法詳解

    iOS NSURLProtocol的具體使用方法詳解

    本篇文章主要介紹了iOS NSURLProtocol的具體使用方法詳解,小編覺得挺不錯的,現在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2017-11-11
  • iOS超出父控件范圍無法點擊問題解決

    iOS超出父控件范圍無法點擊問題解決

    這篇文章主要介紹了iOS超出父控件范圍無法點擊問題解決,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2023-06-06
  • 干貨分享!iOS10 SiriKit QQ適配詳解

    干貨分享!iOS10 SiriKit QQ適配詳解

    干貨分享!主要為大家詳細介紹了!iOS10 SiriKit QQ適配,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2016-10-10
  • IOS實現驗證碼倒計時功能(二)

    IOS實現驗證碼倒計時功能(二)

    這篇文章主要介紹了IOS實現驗證碼倒計時功能,點擊獲取驗證碼,進入時間倒計時,感興趣的小伙伴們可以參考一下
    2016-04-04
  • 更新了Xcode8 及 iOS10遇到的問題小結

    更新了Xcode8 及 iOS10遇到的問題小結

    更新了Xcode8 以及 iOS10,App訪問用戶的相機、相冊、麥克風、通訊錄的權限都需要重新進行相關的配置,不然在Xcode8中打開編譯的話會直接crash.這篇文章主要介紹了更新了Xcode8 及 iOS10遇到的問題小結的相關資料,需要的朋友可以參考下
    2016-09-09
  • iOS功能實現之列表的橫向刷新加載

    iOS功能實現之列表的橫向刷新加載

    現今已有越來越多的APP需要橫向刷新的需求,而橫向刷新加載的控件卻寥寥無幾,即使有也是集成起來非常的麻煩,恰巧最近項目中又用到了這個功能,所以干脆自己來造個輪子,方便大家使用。
    2016-08-08
  • IOS 九宮格布局實現方法

    IOS 九宮格布局實現方法

    這篇文章主要介紹了IOS 九宮格布局實現方法,及實例代碼,需要的朋友可以參考下
    2016-09-09

最新評論