UIScrollView實(shí)現(xiàn)圖片輪播器

在很多應(yīng)用中我們都可以看到圖片輪播器送漠,類似于下面的網(wǎng)易新聞顽照,頭部圖片區(qū)域就是一個(gè)圖片輪播器


網(wǎng)易新聞

這一次我們自己來實(shí)現(xiàn)一個(gè)簡單的圖片輪播器

  • 新建一個(gè)工程,storyboard中拖入U(xiǎn)IScrollView和一個(gè)UIPageControl,給她們設(shè)置合適大小和位置
  • 準(zhǔn)備5張圖片闽寡,按數(shù)字順序命名代兵,拖入到工程
  • 兩個(gè)控件分別脫線到控制器
@property (weak, nonatomic) IBOutlet UIScrollView *scrollView;
@property (weak, nonatomic) IBOutlet UIPageControl *pageControl;
/** 定時(shí)器 */
@property (nonatomic, weak) NSTimer *timer;

設(shè)置控制器為scrollView的代理并遵守協(xié)議<UIScrollViewDelegate>

  • viewDidLoad方法中:
- (void)viewDidLoad {
    [super viewDidLoad];
    // 1.添加圖片
    CGFloat scrollViewW = self.scrollView.frame.size.width;
    CGFloat scrollViewH = self.scrollView.frame.size.height;
    int count = 5;
    for (int i = 0; i < count; i ++) {
        UIImageView *imageView = [[UIImageView alloc] init];
        NSString *name = [NSString stringWithFormat:@"img_0%d",i + 1];
        imageView.image = [UIImage imageNamed:name];
        imageView.frame = CGRectMake(i * scrollViewW, 0, scrollViewW, scrollViewH);
        [self.scrollView addSubview:imageView];
    }
    // 2.設(shè)置contentSize
    // 這個(gè)0表示豎直方向不可以滾動(dòng)
    self.scrollView.contentSize = CGSizeMake(count * scrollViewW, 0);
    // 3.開啟分頁功能
    // 標(biāo)準(zhǔn):以scrollView的尺寸為一頁
    self.scrollView.pagingEnabled = YES;
    // 4.設(shè)置總頁數(shù)
    self.pageControl.numberOfPages = count;
    // 5.單頁的時(shí)候是否隱藏pageControl
    self.pageControl.hidesForSinglePage = YES;
   // 7.開啟定時(shí)器
    [self startTimer];
}
  • 實(shí)現(xiàn)scrollView的幾個(gè)代理方法:
#pragma mark - UIScrollViewDelegate
- (void)scrollViewDidScroll:(UIScrollView *)scrollView
{
    // 1.計(jì)算頁碼
    int page = (int)(scrollView.contentOffset.x / scrollView.frame.size.width + 0.5);
   // 2.設(shè)置頁碼
    self.pageControl.currentPage = page;
}
/**
 *  用戶即將開始拖拽scrollView時(shí),停止定時(shí)器
 */
- (void)scrollViewWillBeginDragging:(UIScrollView *)scrollView
{
    [self stopTimer];
}
/**
 *  用戶已經(jīng)停止拖拽scrollView時(shí),開啟定時(shí)器
 */
- (void)scrollViewDidEndDragging:(UIScrollView *)scrollView willDecelerate:(BOOL)decelerate
{
    [self startTimer];
}
  • 定時(shí)器相關(guān)代碼:
#pragma mark - 定時(shí)器相關(guān)的代碼
- (void)startTimer
{
    // 返回一個(gè)自動(dòng)執(zhí)行的定時(shí)器對象
    self.timer = [NSTimer scheduledTimerWithTimeInterval:2.0 target:self selector:@selector(nextPage:) userInfo:@"123" repeats:YES];
    // NSDefaultRunLoopMode(默認(rèn)): 同一時(shí)間只能執(zhí)行一個(gè)任務(wù)
    // NSRunLoopCommonModes(公用): 可以分配一定的時(shí)間執(zhí)行其他任務(wù)
    // 作用:修改timer在runLoop中的模式為NSRunLoopCommonModes
    // 目的:不管主線程在做什么操作,都會(huì)分配一定的時(shí)間處理定時(shí)器
    [[NSRunLoop mainRunLoop] addTimer:self.timer forMode:NSRunLoopCommonModes];
}

- (void)stopTimer
{
    [self.timer invalidate];
}
/**
 *  滾動(dòng)到下一頁
 */
- (void)nextPage:(NSTimer *)timer
{
    // 1.計(jì)算下一頁的頁碼
    NSInteger page = self.pageControl.currentPage + 1;
    // 2.超過了最后一頁
    if ( page == 5) {
        page = 0;
    }
    // 3.滾動(dòng)到下一頁
    [self.scrollView setContentOffset:CGPointMake(page * self.scrollView.frame.size.width, 0) animated:YES];
}

這里還有一些storyboard里面的設(shè)置:

  • scrollview默認(rèn)是自帶拖動(dòng)條的,垂直和水平方向都有下隧,選中scrollview奢人,在storyboard中把Scroll Indicators的勾選去掉
  • 在storyboard還可以設(shè)置pageControl的Tint Color和current page(當(dāng)前頁顏色)

運(yùn)行得到一個(gè)簡單的圖片輪播器:
能夠自動(dòng)輪播谓媒,2秒翻下一頁淆院,手動(dòng)拖動(dòng)的時(shí)候,自動(dòng)輪播停止句惯,手指松開土辩,2秒后自動(dòng)翻頁。

簡單圖片輪播器
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末抢野,一起剝皮案震驚了整個(gè)濱河市拷淘,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌指孤,老刑警劉巖启涯,帶你破解...
    沈念sama閱讀 211,194評論 6 490
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異恃轩,居然都是意外死亡结洼,警方通過查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 90,058評論 2 385
  • 文/潘曉璐 我一進(jìn)店門叉跛,熙熙樓的掌柜王于貴愁眉苦臉地迎上來松忍,“玉大人,你說我怎么就攤上這事筷厘∶停” “怎么了宏所?”我有些...
    開封第一講書人閱讀 156,780評論 0 346
  • 文/不壞的土叔 我叫張陵,是天一觀的道長摊溶。 經(jīng)常有香客問我爬骤,道長,這世上最難降的妖魔是什么莫换? 我笑而不...
    開封第一講書人閱讀 56,388評論 1 283
  • 正文 為了忘掉前任盖腕,我火速辦了婚禮,結(jié)果婚禮上浓镜,老公的妹妹穿的比我還像新娘溃列。我一直安慰自己,他們只是感情好膛薛,可當(dāng)我...
    茶點(diǎn)故事閱讀 65,430評論 5 384
  • 文/花漫 我一把揭開白布听隐。 她就那樣靜靜地躺著,像睡著了一般哄啄。 火紅的嫁衣襯著肌膚如雪雅任。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 49,764評論 1 290
  • 那天咨跌,我揣著相機(jī)與錄音沪么,去河邊找鬼。 笑死锌半,一個(gè)胖子當(dāng)著我的面吹牛禽车,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播刊殉,決...
    沈念sama閱讀 38,907評論 3 406
  • 文/蒼蘭香墨 我猛地睜開眼殉摔,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了记焊?” 一聲冷哼從身側(cè)響起逸月,我...
    開封第一講書人閱讀 37,679評論 0 266
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎遍膜,沒想到半個(gè)月后碗硬,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 44,122評論 1 303
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡瓢颅,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 36,459評論 2 325
  • 正文 我和宋清朗相戀三年恩尾,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片惜索。...
    茶點(diǎn)故事閱讀 38,605評論 1 340
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡特笋,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情猎物,我是刑警寧澤虎囚,帶...
    沈念sama閱讀 34,270評論 4 329
  • 正文 年R本政府宣布,位于F島的核電站蔫磨,受9級特大地震影響淘讥,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜堤如,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 39,867評論 3 312
  • 文/蒙蒙 一蒲列、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧搀罢,春花似錦蝗岖、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,734評論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至唧取,卻和暖如春铅鲤,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背枫弟。 一陣腳步聲響...
    開封第一講書人閱讀 31,961評論 1 265
  • 我被黑心中介騙來泰國打工邢享, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人淡诗。 一個(gè)月前我還...
    沈念sama閱讀 46,297評論 2 360
  • 正文 我出身青樓骇塘,卻偏偏與公主長得像,于是被迫代替她去往敵國和親袜漩。 傳聞我的和親對象是個(gè)殘疾皇子绪爸,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 43,472評論 2 348

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