論優(yōu)雅的實現(xiàn)描邊

最近使用了一下 IBAnimatable赖阻,這個庫對 IBInspectable 的使用真讓人嘆為觀止啰脚。突然意識到其實 IBInspectable 可以讓我們減少很多不必要的重復(fù)代碼伪阶。對一個 UIView 進行描邊是我們在開發(fā)過程中比較常用的均驶,UI 設(shè)計師們希望通過描邊來增加界面的層次感磺芭。

常見的描邊實現(xiàn)

通過 UIView 實現(xiàn)描一條線

在剛開始做 iOS 開發(fā)時骆撇,我很喜歡使用這樣的方式。但后來發(fā)現(xiàn)這種實現(xiàn)用一下兩個缺點:

  1. 后期如果 UI 需要重新調(diào)整羽德,會變得比較痛苦几莽。
  2. 一般描邊都只需要1個像素的描邊,在使用 XibStoryBoard 的時候需要設(shè)置 0.5 這樣的值宅静。XibStoryBoard 好像支持的不太好章蚣,經(jīng)常會出現(xiàn)在 plus 上描邊的線看起來特別粗。

通過 CALayer 繪制描邊

這個方法實現(xiàn)描邊的效果很不錯坏为。但還是有些缺點:

  1. 有些 UIView 其實在代碼中不需要體現(xiàn)究驴,但因為需要描邊。我必須把它拖到代碼中匀伏。
  2. 代碼中到處出現(xiàn),進行描邊的代碼蝴韭,一定程度影響代碼的美觀和閱讀性(PS: 我有潔癖)够颠。

對這些實現(xiàn)進行封裝的確是一個不錯的選擇。但我也許還有可能有更好的方案榄鉴。

使用 IBInspectable

這里我只描述我的實現(xiàn)思路履磨,不對 IBInspectable 進行介紹。畢竟 IBInspectable2014WWDC 的內(nèi)容了(PS: 比我學(xué)習(xí) iOS 還要早 = =)庆尘,很多大神都有博客對其介紹剃诅。

思路如下:

  1. 可以使用 IBDesignable 將屬性定義到 IB 中驶忌,通過定義屬性矛辕,實現(xiàn)描邊笑跛。
  2. 我們可以統(tǒng)一在 layoutSubviews 中進行描邊處理。
  3. 我不希望為了實現(xiàn)描邊還去繼承一個類聊品,所以我選擇對 UIView 通過 Category 實現(xiàn)描邊的功能飞蹂。
  4. 我需要增加一下新的屬性來定義描邊,所以我需要使用 AssociatedObject 實現(xiàn)翻屈。對于 AssociatedObject 不了解的同學(xué)可以看南峰子的這篇博客 Objective-C Runtime 運行時之二:成員變量與屬性陈哑。
  5. 由于我希望通過 Category 實現(xiàn)描邊,我還需要使用 Method Swizzling 實現(xiàn)伸眶。在每個 UIView 及其子類 在實現(xiàn) layoutSubviews 去執(zhí)行我的描邊代碼惊窖。不了解的同學(xué)可以看南峰子的這篇博客 Objective-C Runtime 運行時之四:Method Swizzling

最終實現(xiàn)效果

如圖厘贼,只需要在 IB 上配置上屬性爬坑,就可以實現(xiàn)描邊的功能。

這樣做還是有缺點的涂臣,IB 上的屬性有點多盾计。。赁遗。

對于代碼感興趣的同學(xué)可以到https://github.com/bay2/IBViewExt署辉,我在這里就不貼代碼了,代碼不多看 UIView+IB.m 文件就可以了岩四。

IBInspectable 的局限

  1. BDesignableIBInspectable 無法在 Cocoa Touch Frameworks 中生效哭尝,詳細看這里,所以使用 Carthage 的時候剖煌,BDesignableIBInspectable 也無法正常工作材鹦, cocoapods 不會有次問題。
  2. BDesignable 無法再 categories/extensions 正常工作耕姊, stackoverflow 上也有提到這個問題
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末桶唐,一起剝皮案震驚了整個濱河市,隨后出現(xiàn)的幾起案子茉兰,更是在濱河造成了極大的恐慌尤泽,老刑警劉巖,帶你破解...
    沈念sama閱讀 212,542評論 6 493
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件规脸,死亡現(xiàn)場離奇詭異坯约,居然都是意外死亡,警方通過查閱死者的電腦和手機莫鸭,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 90,596評論 3 385
  • 文/潘曉璐 我一進店門闹丐,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人被因,你說我怎么就攤上這事卿拴∩缆兀” “怎么了?”我有些...
    開封第一講書人閱讀 158,021評論 0 348
  • 文/不壞的土叔 我叫張陵巍棱,是天一觀的道長惑畴。 經(jīng)常有香客問我,道長航徙,這世上最難降的妖魔是什么如贷? 我笑而不...
    開封第一講書人閱讀 56,682評論 1 284
  • 正文 為了忘掉前任,我火速辦了婚禮到踏,結(jié)果婚禮上杠袱,老公的妹妹穿的比我還像新娘。我一直安慰自己窝稿,他們只是感情好楣富,可當我...
    茶點故事閱讀 65,792評論 6 386
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著伴榔,像睡著了一般纹蝴。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上踪少,一...
    開封第一講書人閱讀 49,985評論 1 291
  • 那天塘安,我揣著相機與錄音,去河邊找鬼援奢。 笑死兼犯,一個胖子當著我的面吹牛,可吹牛的內(nèi)容都是我干的集漾。 我是一名探鬼主播切黔,決...
    沈念sama閱讀 39,107評論 3 410
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼具篇!你這毒婦竟也來了纬霞?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 37,845評論 0 268
  • 序言:老撾萬榮一對情侶失蹤栽连,失蹤者是張志新(化名)和其女友劉穎险领,沒想到半個月后,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體秒紧,經(jīng)...
    沈念sama閱讀 44,299評論 1 303
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 36,612評論 2 327
  • 正文 我和宋清朗相戀三年挨下,在試婚紗的時候發(fā)現(xiàn)自己被綠了熔恢。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 38,747評論 1 341
  • 序言:一個原本活蹦亂跳的男人離奇死亡臭笆,死狀恐怖叙淌,靈堂內(nèi)的尸體忽然破棺而出秤掌,到底是詐尸還是另有隱情,我是刑警寧澤鹰霍,帶...
    沈念sama閱讀 34,441評論 4 333
  • 正文 年R本政府宣布闻鉴,位于F島的核電站,受9級特大地震影響茂洒,放射性物質(zhì)發(fā)生泄漏孟岛。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點故事閱讀 40,072評論 3 317
  • 文/蒙蒙 一督勺、第九天 我趴在偏房一處隱蔽的房頂上張望渠羞。 院中可真熱鬧,春花似錦智哀、人聲如沸次询。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,828評論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽屯吊。三九已至,卻和暖如春摹菠,著一層夾襖步出監(jiān)牢的瞬間盒卸,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 32,069評論 1 267
  • 我被黑心中介騙來泰國打工辨嗽, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留世落,地道東北人。 一個月前我還...
    沈念sama閱讀 46,545評論 2 362
  • 正文 我出身青樓糟需,卻偏偏與公主長得像屉佳,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子洲押,可洞房花燭夜當晚...
    茶點故事閱讀 43,658評論 2 350

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

  • 發(fā)現(xiàn) 關(guān)注 消息 iOS 第三方庫武花、插件、知名博客總結(jié) 作者大灰狼的小綿羊哥哥關(guān)注 2017.06.26 09:4...
    肇東周閱讀 12,066評論 4 62
  • N0.141 7月11日 晴 臺風(fēng)即將過境時,天空露出了水洗般迷人的藍挑童。 抬頭看天累铅,在葉子的縫隙間透著微藍,陽光...
    瑞和她的淺島繁花閱讀 388評論 0 1
  • 當?shù)V山上的灰塵將我掩埋 當下坡的路把我的腸子顛出來 當我的腸子在烈日下暴曬 盤山公路一直繞到大海
    摩柯菠蘿閱讀 209評論 0 3
  • 王曉梅站叼,改變思維最簡單的做法就是改變輸入娃兽。
    沙漏記得閱讀 196評論 0 0
  • 我怕黑。幾乎沒看過恐怖片兒尽楔,偶爾電影中有嚇人的場面投储,我都會堵上耳朵把頭窩起來第练。尤其不敢一個人在家里過夜,一丁點動靜...
    吾小桐閱讀 302評論 6 2