ios 關于UIPageControl 自定義樣式定制的正確姿勢

版權聲明:本文為博主原創(chuàng)文章推盛,遵循 CC 4.0 BY-SA 版權協(xié)議,轉(zhuǎn)載請附上原文出處鏈接和本聲明古毛。

本文鏈接:https://blog.csdn.net/a416863220/article/details/43407517

近來联贩,項目中需要定制UIPageControl樣式抵赢,目前知道的方式大概如下葫辐,這里簡單概括:

一刨裆、修改顏色聂示,最簡單的方式:

// 設置非選中頁的圓點顏色
_pageControl.pageIndicatorTintColor = [UIColor redColor];
// 設置選中頁的圓點顏色
_pageControl.currentPageIndicatorTintColor = [UIColor blueColor]; 

二告唆、修改靜態(tài)圖標樣式棺弊,可以采用KVO方式,這種弊端是只能靜態(tài)顯示擒悬,無法動態(tài)替換模她,且私有,危險:

[_pageControl setValue:[UIImage imageNamed:@"image1"] forKeyPath:@"_pageImage"]; 
[_pageControl setValue:[UIImage imageNamed:@"image2"] forKeyPath:@"_currentPageImage"];

三懂牧、替換系統(tǒng)默認圖標侈净,自定義樣式:

常規(guī)方式便是創(chuàng)建一個類,繼承于UIPageControl僧凤,重新set方式畜侦,這里寫下核心代碼,也是目前網(wǎng)絡上的方式:

-(void) updateDots {            
     for (int i = 0; i < [self.subviews count]; i++)  
{       
    UIImageView *dot = [self.subviews objectAtIndex:i];       
    if (i == self.currentPage) {
       dot.image = activeImage;     
    }
    else 
       dot.image = inactiveImage;   
     
 }

結果是程序崩潰躯保,歸咎原因:

這種方式及其危險的夏伊,因為[self.subviews objectAtIndex:i] class 為UIView, 而 UIImageView *dot = [self.subviews objectAtIndex:i]; 這句是將一個UIView轉(zhuǎn)換為UIImageView, 故容易crash 掉,特此放棄如上國內(nèi)方式吻氧;

四溺忧、完善上面第三種方式,轉(zhuǎn)為安全的替換方式盯孙,核心代碼如下:

for (UIView *subview in view.subviews) {          
  if ([subview isKindOfClass:[UIImageView class]]) {           
     dot = (UIImageView *)subview;         
      break;       
     }      
  }

采用如上安全方式鲁森,可有效防止崩潰,至此完成項目需求振惰,效果如下:

image

五歌溉、這里把整個代碼放出來,幫助大家少走彎路骑晶,具體代碼如下:

1痛垛、.h文件

#import <UIKit/UIKit.h> 
@interface CustomPageControl : UIPageControl
@property (nonatomic, strong) UIImage *currentImage;
@property (nonatomic, strong) UIImage *inactiveImage; 
@property (nonatomic, assign) CGSize currentImageSize;
@property (nonatomic, assign) CGSize inactiveImageSize;
@end

2、.m文件

#import "CustomPageControl.h" 
@implementation CustomPageControl 
- (instancetype)init{   
 self = [super init];  
  if (self) {      
  self.userInteractionEnabled = NO;   
 }   
 return self;
} 
- (void)setCurrentPage:(NSInteger)currentPage{ 
   [super setCurrentPage:currentPage]; 
    [self updateDots];
} 
 - (void)updateDots{   
 for (int i = 0; i < [self.subviews count]; i++) {    
    UIImageView *dot = [self imageViewForSubview:[self.subviews objectAtIndex:i] currPage:i];      
  if (i == self.currentPage){      
      dot.image = self.currentImage;     
       dot.size = self.currentImageSize;     
  }else{           
 dot.image = self.inactiveImage;        
   dot.size = self.inactiveImageSize;     
   } 
  }
}
- (UIImageView *)imageViewForSubview:(UIView *)view currPage:(int)currPage{    UIImageView *dot = nil;   
 if ([view isKindOfClass:[UIView class]]) {   
     for (UIView *subview in view.subviews) {   
         if ([subview isKindOfClass:[UIImageView class]]) {       
         dot = (UIImageView *)subview;      
          break;     
       }     
   }              
  if (dot == nil) {       
     dot = [[UIImageView alloc] initWithFrame:CGRectMake(0.0f, 0.0f, view.frame.size.width, view.frame.size.height)];              
         [view addSubview:dot];  
      }  
  }else {       
 dot = (UIImageView *)view;   
 }       
 return dot;
}
@end

3桶蛔、使用方式:

CustomPageControl *pageCtrl = [[CustomPageControl alloc] initWithFrame:CGRectMake(0, 10, mScreenWidth, 5)]; 
[pageCtrl.numberOfPages = cardSwitchViewAry.count;
pageCtrl.currentPage = 0; 
pageCtrl.userInteractionEnabled = NO;
pageCtrl.inactiveImage = [UIImage imageNamed:@"ex_page_1"];
pageCtrl.inactiveImageSize = CGSizeMake(5, 5);
pageCtrl.currentImage = [UIImage imageNamed:@"ex_page_2"];
pageCtrl.currentImageSize = CGSizeMake(10, 5);     
 //去掉系統(tǒng)自帶樣式
pageCtrl.currentPageIndicatorTintColor = [UIColor clearColor];
pageCtrl.pageIndicatorTintColor = [UIColor clearColor];    

至此匙头,定制UIPageControl的正確姿勢已了解,希望對大家有用仔雷。

最后編輯于
?著作權歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末蹂析,一起剝皮案震驚了整個濱河市舔示,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌电抚,老刑警劉巖惕稻,帶你破解...
    沈念sama閱讀 206,126評論 6 481
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異蝙叛,居然都是意外死亡俺祠,警方通過查閱死者的電腦和手機,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 88,254評論 2 382
  • 文/潘曉璐 我一進店門借帘,熙熙樓的掌柜王于貴愁眉苦臉地迎上來锻煌,“玉大人,你說我怎么就攤上這事姻蚓。” “怎么了匣沼?”我有些...
    開封第一講書人閱讀 152,445評論 0 341
  • 文/不壞的土叔 我叫張陵狰挡,是天一觀的道長。 經(jīng)常有香客問我释涛,道長加叁,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 55,185評論 1 278
  • 正文 為了忘掉前任唇撬,我火速辦了婚禮它匕,結果婚禮上,老公的妹妹穿的比我還像新娘窖认。我一直安慰自己豫柬,他們只是感情好,可當我...
    茶點故事閱讀 64,178評論 5 371
  • 文/花漫 我一把揭開白布扑浸。 她就那樣靜靜地躺著烧给,像睡著了一般。 火紅的嫁衣襯著肌膚如雪喝噪。 梳的紋絲不亂的頭發(fā)上础嫡,一...
    開封第一講書人閱讀 48,970評論 1 284
  • 那天,我揣著相機與錄音酝惧,去河邊找鬼榴鼎。 笑死,一個胖子當著我的面吹牛晚唇,可吹牛的內(nèi)容都是我干的巫财。 我是一名探鬼主播,決...
    沈念sama閱讀 38,276評論 3 399
  • 文/蒼蘭香墨 我猛地睜開眼哩陕,長吁一口氣:“原來是場噩夢啊……” “哼翁涤!你這毒婦竟也來了桥言?” 一聲冷哼從身側響起,我...
    開封第一講書人閱讀 36,927評論 0 259
  • 序言:老撾萬榮一對情侶失蹤葵礼,失蹤者是張志新(化名)和其女友劉穎号阿,沒想到半個月后,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體鸳粉,經(jīng)...
    沈念sama閱讀 43,400評論 1 300
  • 正文 獨居荒郊野嶺守林人離奇死亡扔涧,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 35,883評論 2 323
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發(fā)現(xiàn)自己被綠了届谈。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片枯夜。...
    茶點故事閱讀 37,997評論 1 333
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖艰山,靈堂內(nèi)的尸體忽然破棺而出湖雹,到底是詐尸還是另有隱情,我是刑警寧澤曙搬,帶...
    沈念sama閱讀 33,646評論 4 322
  • 正文 年R本政府宣布摔吏,位于F島的核電站,受9級特大地震影響纵装,放射性物質(zhì)發(fā)生泄漏征讲。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點故事閱讀 39,213評論 3 307
  • 文/蒙蒙 一橡娄、第九天 我趴在偏房一處隱蔽的房頂上張望诗箍。 院中可真熱鬧,春花似錦挽唉、人聲如沸滤祖。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,204評論 0 19
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽氨距。三九已至,卻和暖如春棘劣,著一層夾襖步出監(jiān)牢的瞬間俏让,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 31,423評論 1 260
  • 我被黑心中介騙來泰國打工茬暇, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留首昔,地道東北人。 一個月前我還...
    沈念sama閱讀 45,423評論 2 352
  • 正文 我出身青樓糙俗,卻偏偏與公主長得像勒奇,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子巧骚,可洞房花燭夜當晚...
    茶點故事閱讀 42,722評論 2 345