定時器+分頁

定時器+分頁


#import <UIKit/UIKit.h>

@interface XMGPageView : UIView
+ (instancetype)pageView;
/** 圖片名字 */
@property (nonatomic, strong) NSArray *imageNames;
/** 其他圓點(diǎn)顏色 */
@property (nonatomic, strong) UIColor *otherColor;
/** 當(dāng)前圓點(diǎn)顏色 */
@property (nonatomic, strong) UIColor *currentColor;


@end




#import "XMGPageView.h"

@interface XMGPageView() <UIScrollViewDelegate>
@property (weak, nonatomic) IBOutlet UIScrollView *scrollView;
@property (weak, nonatomic) IBOutlet UIPageControl *pageControl;
/**  定時器  */
@property(nonatomic,strong)NSTimer * timer ;
@end

@implementation XMGPageView
/**
 * 當(dāng)控件通過代碼創(chuàng)建時新思,就會調(diào)用這個方法
 * 當(dāng)控件通過代碼創(chuàng)建時纲熏,想做一些初始化操作贺待。應(yīng)該在這個方法中執(zhí)行
 */
- (instancetype)initWithFrame:(CGRect)frame
{
    if (self = [super initWithFrame:frame]) {
        [self setup];
        
        // 添加子控件代碼
    }
    return self;
}

/**
 * 當(dāng)控件從xib\storyboard中創(chuàng)建完畢時,就會調(diào)用這個方法
 * 當(dāng)控件從xib\storyboard中創(chuàng)建完畢后的初始化操作趁耗。應(yīng)該在這個方法中執(zhí)行
 */
- (void)awakeFromNib
{
    [self setup];
}

/**
 * 初始化代碼
 */
- (void)setup
{
    self.scrollView.backgroundColor = [UIColor redColor];
}

/**
 * 當(dāng)控件是通過xib\storyboard創(chuàng)建時,會調(diào)用這個方法來初始化控件
 */
- (id)initWithCoder:(NSCoder *)aDecoder
{
    if (self = [super initWithCoder:aDecoder]) {
    }
    return self;
}

+ (instancetype)pageView
{
    return [[[NSBundle mainBundle] loadNibNamed:NSStringFromClass(self) owner:nil options:nil] lastObject];
}

/**
 * 當(dāng)控件的尺寸發(fā)生改變的時候玛荞,會自動調(diào)用這個方法
 */
- (void)layoutSubviews
{
    [super layoutSubviews];
    
    // 設(shè)置scrollView的frame
    self.scrollView.frame = self.bounds;
    
    // 獲得scrollview的尺寸
    CGFloat scrollW = self.scrollView.frame.size.width;
    CGFloat scrollH = self.scrollView.frame.size.height;
    
    // 設(shè)置pageControl
    CGFloat pageW = 100;
    CGFloat pageH = 20;
    CGFloat pageX = scrollW - pageW;
    CGFloat pageY = scrollH - pageH;
    self.pageControl.frame = CGRectMake(pageX, pageY, pageW, pageH);
    
    // 設(shè)置內(nèi)容大小
    self.scrollView.contentSize = CGSizeMake(self.imageNames.count * scrollW, 0);
    
    // 設(shè)置所有imageView的frame
    for (int i = 0; i<self.scrollView.subviews.count; i++) {
        UIImageView *imageView = self.scrollView.subviews[i];
        imageView.frame = CGRectMake(i * scrollW, 0, scrollW, scrollH);
    }
}

#pragma mark - setter方法的重寫
- (void)setImageNames:(NSArray *)imageNames
{
    _imageNames = imageNames;
    
    // 移除之前的所有imageView
    // 讓subviews數(shù)組中的所有對象都執(zhí)行removeFromSuperview方法
    [self.scrollView.subviews makeObjectsPerformSelector:@selector(removeFromSuperview)];
    
    // 根據(jù)圖片名創(chuàng)建對應(yīng)個數(shù)的imageView
    for (int i = 0; i<imageNames.count; i++) {
        UIImageView *imageView = [[UIImageView alloc] init];
        imageView.image = [UIImage imageNamed:imageNames[i]];
        [self.scrollView addSubview:imageView];
    }
    
    // 設(shè)置總頁數(shù)
    self.pageControl.numberOfPages = imageNames.count;
//    if (imageNames.count <= 1) {
//        self.pageControl.hidden = YES;
//    } else {
//        self.pageControl.hidden = NO;
//    }
//    self.pageControl.hidden = imageNames.count <= 1;
//    self.pageControl.hidesForSinglePage = YES;
}

- (void)setCurrentColor:(UIColor *)currentColor
{
    _currentColor = currentColor;
    
    self.pageControl.currentPageIndicatorTintColor = currentColor;
}

- (void)setOtherColor:(UIColor *)otherColor
{
    _otherColor = otherColor;
    
    self.pageControl.pageIndicatorTintColor = otherColor;
}

#pragma mark - <UIScrollViewDelegate>
- (void)scrollViewDidScroll:(UIScrollView *)scrollView
{
    self.pageControl.currentPage = (int)(scrollView.contentOffset.x / scrollView.frame.size.width + 0.5);
}


#pragma mark -定時器設(shè)置

-(void)scrollViewWillBeginDragging:(UIScrollView *)scrollView
{
   [self stopTimer];
}
-(void)stopTimer
{
    [self.timer invalidate];
    self.timer=nil;
}

-(void)scrollViewDidEndDragging:(UIScrollView *)scrollView willDecelerate:(BOOL)decelerate
{
    [self startTimer];
}

-(void)startTimer
{
    self.timer=[NSTimer scheduledTimerWithTimeInterval:1.5 target:self selector:@selector(nextPage) userInfo:nil repeats:YES];
    [[NSRunLoop mainRunLoop]addTimer:self.timer forMode:NSRunLoopCommonModes];
}
-(void)nextPage
{
   NSInteger page=  self.pageControl.currentPage+1;
    if(page==self.pageControl.numberOfPages)
    {
        page=0;
    }
    
    
    CGPoint offset=self.scrollView.contentOffset;
    offset.x=page*self.scrollView.frame.size.width;
    
    
    [self.scrollView setContentOffset:offset animated:YES];
    NSLog(@"---------nextPage");
}



@end



    
    XMGPageView *pageView = [XMGPageView pageView];
    pageView.frame = CGRectMake(37, 50, 250, 200);
    pageView.imageNames = @[@"img_00", @"img_01", @"img_02"];
    pageView.otherColor = [UIColor grayColor];
    pageView.currentColor = [UIColor orangeColor];
    [self.view addSubview:pageView];
    self.pageView = pageView;




最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末秉沼,一起剝皮案震驚了整個濱河市,隨后出現(xiàn)的幾起案子辕狰,更是在濱河造成了極大的恐慌改备,老刑警劉巖,帶你破解...
    沈念sama閱讀 211,884評論 6 492
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件蔓倍,死亡現(xiàn)場離奇詭異悬钳,居然都是意外死亡,警方通過查閱死者的電腦和手機(jī)偶翅,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 90,347評論 3 385
  • 文/潘曉璐 我一進(jìn)店門默勾,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人聚谁,你說我怎么就攤上這事母剥。” “怎么了形导?”我有些...
    開封第一講書人閱讀 157,435評論 0 348
  • 文/不壞的土叔 我叫張陵环疼,是天一觀的道長。 經(jīng)常有香客問我朵耕,道長炫隶,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 56,509評論 1 284
  • 正文 為了忘掉前任憔披,我火速辦了婚禮等限,結(jié)果婚禮上爸吮,老公的妹妹穿的比我還像新娘。我一直安慰自己望门,他們只是感情好形娇,可當(dāng)我...
    茶點(diǎn)故事閱讀 65,611評論 6 386
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著筹误,像睡著了一般桐早。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上厨剪,一...
    開封第一講書人閱讀 49,837評論 1 290
  • 那天哄酝,我揣著相機(jī)與錄音,去河邊找鬼祷膳。 笑死陶衅,一個胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的直晨。 我是一名探鬼主播搀军,決...
    沈念sama閱讀 38,987評論 3 408
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼勇皇!你這毒婦竟也來了罩句?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 37,730評論 0 267
  • 序言:老撾萬榮一對情侶失蹤敛摘,失蹤者是張志新(化名)和其女友劉穎门烂,沒想到半個月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體兄淫,經(jīng)...
    沈念sama閱讀 44,194評論 1 303
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡屯远,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 36,525評論 2 327
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發(fā)現(xiàn)自己被綠了拖叙。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片氓润。...
    茶點(diǎn)故事閱讀 38,664評論 1 340
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖薯鳍,靈堂內(nèi)的尸體忽然破棺而出咖气,到底是詐尸還是另有隱情,我是刑警寧澤挖滤,帶...
    沈念sama閱讀 34,334評論 4 330
  • 正文 年R本政府宣布崩溪,位于F島的核電站,受9級特大地震影響斩松,放射性物質(zhì)發(fā)生泄漏伶唯。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 39,944評論 3 313
  • 文/蒙蒙 一惧盹、第九天 我趴在偏房一處隱蔽的房頂上張望乳幸。 院中可真熱鬧瞪讼,春花似錦、人聲如沸粹断。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,764評論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽瓶埋。三九已至希柿,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間养筒,已是汗流浹背曾撤。 一陣腳步聲響...
    開封第一講書人閱讀 31,997評論 1 266
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留晕粪,地道東北人挤悉。 一個月前我還...
    沈念sama閱讀 46,389評論 2 360
  • 正文 我出身青樓,卻偏偏與公主長得像兵多,于是被迫代替她去往敵國和親尖啡。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 43,554評論 2 349

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

  • 5-Level Paging and 5-Level EPT white paper原文 修訂版本1.1 2017...
    公子小水閱讀 3,728評論 0 3
  • 一剩膘、MCS-51單片機(jī)的定時器/計數(shù)器概念 單片機(jī)中的定時器和計數(shù)器其實(shí)是同一個物理的電子元件,只不過計數(shù)器記錄的...
    Dorajimmy閱讀 1,348評論 0 1
  • @(嵌入式) [TOC] 簡述 考慮平臺硬件定時器個數(shù)限制的, FreeRTOS 通過一個 Daemon 任務(wù)(啟...
    orientlu閱讀 7,869評論 0 3
  • 原文鏈接 你可以使用的定時器類來創(chuàng)建一個定時器對象盆顾,或者更簡單地說怠褐,定時器。一個定時器在指定的時間到達(dá)后觸發(fā)您宪,并發(fā)...
    dacheng閱讀 1,235評論 0 7
  • 一. NSTimer NSTimer的初始化方法有以下幾種: 會自動啟動, 并加入* MainRunloop*的*...
    codeshow閱讀 500評論 0 0