美文网首页Dear iOS, fuck you
在xib storyboard中设置view边框颜色,layer

在xib storyboard中设置view边框颜色,layer

作者: 搞得赢 | 来源:发表于2018-01-22 15:52 被阅读1382次

实现步骤(问题复现)

1、在xib中  identity inspector   —> User Defined Runtime Attributes  —> 添加Key Path以及Value。

设置圆角:layer.cornerRadius 对应ValueType为Number或者String。如果Value值为正方形width的一半,则为圆形。

设置边框宽度:layer.borderWidth  对应ValueType为Number或者String。

设置边框颜色:layer.borderColor   对应ValueType为Color。

出现问题

这样设置后,圆角,宽度都生效了,可是边框的颜色是黑色,也就是设置边框颜色没有生效。

问题原因

到QuartzCore.framework中找到CALayer.h这个头文件,搜索borderColor这个属性 @property(nullable) CGColorRef borderColor;  到这里 我们就可以找到原因了。在User Defined Runtime Attributes 中设置layer.borderColor的ValueType为Color,这里的Color对应的是UIColor,而设置layer.borderColor需要是CGColor类型,因此没有生效。关于 UIColor CGColor CIColor的区别联系

问题解决

建立一个CALayer的分类Category,在该分类中添加一个属性,在该属性的setter方法中将该UIColor转化成CGColor赋值给borderColor,然后在xib中添加该属性的key path。

e.g.

// CALayer+XibBorderColor.h

@interface CALayer (XibBorderColor)

@property (nonatomic, strong) UIColor *borderColorWithUIColor;

@end

// CALayer+XibBorderColor.m

#import "CALayer+XibBorderColor.h"

@implementation CALayer (XibBorderColor)

- (void)setBorderColorWithUIColor:(UIColor *)borderColorWithUIColor {

    self.borderColor = borderColorWithUIColor.CGColor;

}

@end

喜欢请点赞👍

相关文章

网友评论

    本文标题:在xib storyboard中设置view边框颜色,layer

    本文链接:https://www.haomeiwen.com/subject/ejjlaxtx.html