iOS 修改UIPageControl樣式

注:由于iOS13 系統(tǒng)對(duì)一些私有屬性的限制锉试,以下的方式不能保證正確性。在iOS13 系統(tǒng)下,UISearchBar 中的視圖層級(jí)已經(jīng)更換斤吐,UITextField 已經(jīng)可以外部可用搔涝;UITextField 的 _placeholderLabel 成員變量的類型已經(jīng)不是 UILabel,以往的設(shè)置方法已經(jīng)不能使用和措。類似的更換非常多庄呈,大家還是謹(jǐn)慎使用私有方式進(jìn)行設(shè)置,因此私有 api 具有上架風(fēng)險(xiǎn)派阱,另外就是系統(tǒng)并不會(huì)向下兼容地更新诬留。


由于系統(tǒng)并未提供相應(yīng)的屬性和方法讓我們修改樣式,我們最多只能修改顏色

// 修改顏色
@property(nullable, nonatomic,strong) UIColor *pageIndicatorTintColor;
@property(nullable, nonatomic,strong) UIColor *currentPageIndicatorTintColor;

當(dāng)我們需要更換樣式時(shí)贫母,則顯得很困難文兑,我們只可能通過(guò)KVC間接修改對(duì)應(yīng)的值,前提是系統(tǒng)有相應(yīng)的成員變量腺劣,另外系統(tǒng)可能更換成員變量绿贞,這種方式不是很妥當(dāng)


解決方案

1、尋找成員變量

使用運(yùn)行時(shí)獲取到UIPageControl的成員變量

unsigned int count;
Ivar* ivars = class_copyIvarList([UIPageControl class], &count);
for (int i=0; i<count; i++) {
    Ivar ivar = ivars[i];
    NSString* name = [NSString stringWithUTF8String:ivar_getName(ivar)];    // 名稱
    NSString* type = [NSString stringWithUTF8String:ivar_getTypeEncoding(ivar)];     // 類型
    NSLog(@"成員變量:%@ -> 類型:%@",name,type);
}

結(jié)果:


結(jié)果

我們注意到有兩個(gè)比變量 _currentPageImage 和 _pageImage 橘原,這兩個(gè)就是我們需要更改的樣式籍铁,分別對(duì)應(yīng)選中和未選中的樣式

2、KVC方式修改

KVC可以修改對(duì)象的屬性趾断、成員變量拒名,包括私有成員變量

[self.pageControl setValue:[UIImage imageNamed:@"selected"] forKeyPath:@"_currentPageImage"];
[self.pageControl setValue:[UIImage imageNamed:@"normal"] forKeyPath:@"_pageImage"];

3、結(jié)果


結(jié)果

常見的還是有修改UITextField的_placeholderLabel樣式歼冰,同樣方法靡狞,想了解運(yùn)行時(shí)知識(shí)的小伙伴的點(diǎn)擊這里,運(yùn)行時(shí)的相關(guān)應(yīng)用可以看這里隔嫡,還有這里


除了上述的 間接的甸怕、曲折的修改樣式的方法,如果想實(shí)現(xiàn)更為優(yōu)雅或者更為酷炫的樣式的話腮恩,完全可以自定義控件梢杭,掌控性更好,只是稍微麻煩一點(diǎn)而已


補(bǔ)充:

筆者覺得替換為圖片時(shí)秸滴,兩個(gè)控件的間距太大武契,試圖調(diào)整之間的間距,發(fā)現(xiàn)系統(tǒng)無(wú)法更改其位置和大小荡含,替換的讀者需要注意一下咒唆,或者有改變位置的方法,希望留言

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末释液,一起剝皮案震驚了整個(gè)濱河市全释,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌误债,老刑警劉巖浸船,帶你破解...
    沈念sama閱讀 221,635評(píng)論 6 515
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件妄迁,死亡現(xiàn)場(chǎng)離奇詭異,居然都是意外死亡登淘,警方通過(guò)查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 94,543評(píng)論 3 399
  • 文/潘曉璐 我一進(jìn)店門封字,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái)黔州,“玉大人阔籽,你說(shuō)我怎么就攤上這事》碌ⅲ” “怎么了各薇?”我有些...
    開封第一講書人閱讀 168,083評(píng)論 0 360
  • 文/不壞的土叔 我叫張陵,是天一觀的道長(zhǎng)峭判。 經(jīng)常有香客問我开缎,道長(zhǎng)林螃,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 59,640評(píng)論 1 296
  • 正文 為了忘掉前任疗认,我火速辦了婚禮,結(jié)果婚禮上横漏,老公的妹妹穿的比我還像新娘谨设。我一直安慰自己缎浇,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 68,640評(píng)論 6 397
  • 文/花漫 我一把揭開白布素跺。 她就那樣靜靜地躺著二蓝,像睡著了一般。 火紅的嫁衣襯著肌膚如雪指厌。 梳的紋絲不亂的頭發(fā)上刊愚,一...
    開封第一講書人閱讀 52,262評(píng)論 1 308
  • 那天,我揣著相機(jī)與錄音仑乌,去河邊找鬼百拓。 笑死琴锭,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的衙传。 我是一名探鬼主播决帖,決...
    沈念sama閱讀 40,833評(píng)論 3 421
  • 文/蒼蘭香墨 我猛地睜開眼,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼蓖捶!你這毒婦竟也來(lái)了地回?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 39,736評(píng)論 0 276
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤俊鱼,失蹤者是張志新(化名)和其女友劉穎刻像,沒想到半個(gè)月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體并闲,經(jīng)...
    沈念sama閱讀 46,280評(píng)論 1 319
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡细睡,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 38,369評(píng)論 3 340
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了帝火。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片溜徙。...
    茶點(diǎn)故事閱讀 40,503評(píng)論 1 352
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖犀填,靈堂內(nèi)的尸體忽然破棺而出蠢壹,到底是詐尸還是另有隱情,我是刑警寧澤九巡,帶...
    沈念sama閱讀 36,185評(píng)論 5 350
  • 正文 年R本政府宣布图贸,位于F島的核電站,受9級(jí)特大地震影響冕广,放射性物質(zhì)發(fā)生泄漏疏日。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,870評(píng)論 3 333
  • 文/蒙蒙 一佳窑、第九天 我趴在偏房一處隱蔽的房頂上張望制恍。 院中可真熱鬧,春花似錦神凑、人聲如沸净神。這莊子的主人今日做“春日...
    開封第一講書人閱讀 32,340評(píng)論 0 24
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)鹃唯。三九已至,卻和暖如春瓣喊,著一層夾襖步出監(jiān)牢的瞬間坡慌,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 33,460評(píng)論 1 272
  • 我被黑心中介騙來(lái)泰國(guó)打工藻三, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留洪橘,地道東北人跪者。 一個(gè)月前我還...
    沈念sama閱讀 48,909評(píng)論 3 376
  • 正文 我出身青樓,卻偏偏與公主長(zhǎng)得像熄求,于是被迫代替她去往敵國(guó)和親渣玲。 傳聞我的和親對(duì)象是個(gè)殘疾皇子弟晚,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 45,512評(píng)論 2 359

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