https://github.com/easycodingTop/EALayoutLiteForOC
QQ群:454686295
====================================================
這一節(jié) 講一下控件屬性設(shè)置
{ "class":"UIView" } class 指定view類型,也可以是自定類。 swift里自定義的類需要使用 @objc(類名)導(dǎo)出oc頭文件
**color
各種以 color 為后綴的屬性(或者帶有 set***Color方法的), 不分大小寫, 均會(huì)自動(dòng)解析為 UIColor對(duì)象
color 表示方式: 如 "backgroundColor":"blackColor", "textColor":[100,150,200,0.8]
"#aarrggbb" OR "0xaarrggbb" : 這種 十六進(jìn)制 字符器 分別為 a-透明度 r-紅色 g-綠色 b-藍(lán)色
"blackColor" OR "redColor", 等等 : 這種是通過調(diào)用 [UIColor blackColor] 這種方法實(shí)現(xiàn),所以支持 UIColor 支持的類似所有方法。
[r,g,b] OR [r,g,b,a] : 這種是數(shù)組的方式。 r ,g ,b 分別是 十進(jìn)制 [0,255], a 為透明度 [0.0, 1.0] 。 默認(rèn)a為1.0
如果某個(gè)類的屬性是以 color為后綴結(jié)尾,但是又不是 UIColor對(duì)象類型,需要自己為此類重寫解析,
為該類添加方法 -(void)***Color:(id)value parser:(SkinParser*)parser.
比如: CALayer 中的 borderColor backgroundColor shadowColor 類型均為 CGColor
所以為此類添加對(duì)應(yīng)方法
-(void)borderColor:(id)value parser:(SkinParser*)parser { self.borderColor =toColor(value).CGColor; }
-(void)backgroundColor:(id)value parser:(SkinParser*)parser
-(void)shadowColor:(id)value parser:(SkinParser*)parser
**image
以image為后綴的屬性(或者帶有set***Image), 不分大小寫, 均會(huì)自動(dòng)解析為 UIImage 對(duì)象。
image 表示方式:
"image/myicon.png", 一個(gè)圖片相對(duì)于當(dāng)前 json文件的相對(duì)路徑
"image":{"name":"Images/btn_bg.png","resizeCap":[15,20,20,20],"model":"tile"},
則會(huì)調(diào)用 [image resizableImageWithCapInsets:resizeCap resizingMode:(UIImageResizingModeTile)]
"image":{"name":"Images/btn_bg.png","resizeCap":[15,20,20,20],"model":"stretch"},
會(huì)調(diào)用 [image resizableImageWithCapInsets:resizeCap resizingMode:(UIImageResizingModeStretch)]"image":{"name":"Images/btn_bg.png","resizeCap":[15,20,20,20]},
會(huì)調(diào)用 [image resizableImageWithCapInsets:resizeCap];
**font
表示方式 :
"font":14 , 默認(rèn)為 systemFontOfSize
"font":{"size":14, "name":"bold"}, name 支持 "italic" "system" 以及其它字體名字,還有自定義字體均可
**frame
表示方式:
"frame": [x,y,width,height]
**size
表示方式:
"size":[width,height]
**insets / *inset
表示方式:
"insets/inset":[top,left,bottom,right]
**view
表示方式:
{ "class":"UILabel", xxxxxxx:xxxxxx }
**viewMode
表示方式:
"viewMode": "never" / "whileEditing" / "unlessEditing" / "always"
分別對(duì)應(yīng) UITextFieldViewModeNever,
UITextFieldViewModeWhileEditing,
UITextFieldViewModeUnlessEditing,
UITextFieldViewModeAlways
====================================================
上面這些屬性都是預(yù)設(shè) 支持的解析, 更多可以看下 庫里頭文件里的定義。
后面會(huì)具體講如何 添加解析規(guī)則,自定義屬性解析。
上面沒提到的其它簡單屬性,無需特別的解析方法,可以自動(dòng)設(shè)置
比如 number string bool 這些類型。直接在json里寫上和屬性名一樣的key就可以了
比如 alpha 屬于number類型,所以直接寫上 "alpha":0.5
UILabel的text 是 string類型, 直接寫上 "text":"asdfasdf"
========================================================================================
敬請(qǐng)關(guān)注下一節(jié):
====================================================
https://github.com/easycodingTop/EALayoutLiteForOC
QQ群:454686295
====================================================
新聞熱點(diǎn)
疑難解答
圖片精選
網(wǎng)友關(guān)注