使用storyboard设置button边框属性(颜色,宽度,圆角)
2017-05-14 13:40
375 查看
通常使用Category时。仅仅能加入方法,不可加入属性。可是在使用Storyboard时我们可能会使用到keyPath,这里设置的key都须要是所设置视图的属性值。而且类型有所限制。
比如:我如今有一个button。我想设置成圆角。而且是紫色边框。
而且我不想写代码,想通过storyboard直接设置。这样看起来非常帅(事实上就是一个强迫症吧,由于一直在用sb设置整个界面,可是突然出现几个样式,在sb中不能够直接设置。这样的感觉非常烦躁的。
遇到的问题:这里key path 的type类型是固定的。这里我们不能够加入。这里仅仅有一个UIColor类型的color,可是设置边框的颜色,应该是CGColor的,所以类型不匹配,我们须要为CALayer加入一个UIColor的属性。
这里我们使用Category。不用疑问,对,是使用Category为CALayer加入一个UIColor的属性。
CALayer+Addition.h
#import <QuartzCore/QuartzCore.h>
#import <UIKit/UIKit.h>
@interface CALayer (Additions)
@property(nonatomic, strong) UIColor *borderColorFromUIColor;
- (void)setBorderColorFromUIColor:(UIColor *)color;
@end
CALayer+Addition.m
#import "CALayer+Additions.h"
#import <objc/runtime.h>
@implementation CALayer (Additions)
//static const void *borderColorFromUIColorKey = &borderColorFromUIColorKey;
//@dynamic borderColorFromUIColor;
- (UIColor *)borderColorFromUIColor {
return objc_getAssociatedObject(self, @selector(borderColorFromUIColor));
}
-(void)setBorderColorFromUIColor:(UIColor *)color
{
objc_setAssociatedObject(self, @selector(borderColorFromUIColor), color, OBJC_ASSOCIATION_RETAIN_NONATOMIC);
[selfsetBorderColorFromUIborderColorFromUIColor];
}
- (void)setBorderColorFromUI:(UIColor *)color
{
self.borderColor = color.CGColor;
// NSLog(@"%@", color);
}
这样就成功为CALayer加入了borderColorFromUIColor属性,而且在key path里可能成功设置该属性,为button设置边框颜色了。
实现效果
比如:我如今有一个button。我想设置成圆角。而且是紫色边框。
而且我不想写代码,想通过storyboard直接设置。这样看起来非常帅(事实上就是一个强迫症吧,由于一直在用sb设置整个界面,可是突然出现几个样式,在sb中不能够直接设置。这样的感觉非常烦躁的。
遇到的问题:这里key path 的type类型是固定的。这里我们不能够加入。这里仅仅有一个UIColor类型的color,可是设置边框的颜色,应该是CGColor的,所以类型不匹配,我们须要为CALayer加入一个UIColor的属性。
这里我们使用Category。不用疑问,对,是使用Category为CALayer加入一个UIColor的属性。
CALayer+Addition.h
#import <QuartzCore/QuartzCore.h>
#import <UIKit/UIKit.h>
@interface CALayer (Additions)
@property(nonatomic, strong) UIColor *borderColorFromUIColor;
- (void)setBorderColorFromUIColor:(UIColor *)color;
@end
CALayer+Addition.m
#import "CALayer+Additions.h"
#import <objc/runtime.h>
@implementation CALayer (Additions)
//static const void *borderColorFromUIColorKey = &borderColorFromUIColorKey;
//@dynamic borderColorFromUIColor;
- (UIColor *)borderColorFromUIColor {
return objc_getAssociatedObject(self, @selector(borderColorFromUIColor));
}
-(void)setBorderColorFromUIColor:(UIColor *)color
{
objc_setAssociatedObject(self, @selector(borderColorFromUIColor), color, OBJC_ASSOCIATION_RETAIN_NONATOMIC);
[selfsetBorderColorFromUIborderColorFromUIColor];
}
- (void)setBorderColorFromUI:(UIColor *)color
{
self.borderColor = color.CGColor;
// NSLog(@"%@", color);
}
这样就成功为CALayer加入了borderColorFromUIColor属性,而且在key path里可能成功设置该属性,为button设置边框颜色了。
实现效果
相关文章推荐
- 使用storyboard设置按钮边框属性(颜色,宽度,圆角)
- storyboard或者Xib给View设置边框属性(颜色,宽度,圆角)
- 为类目(类别)添加属性,使用storyboard设置边框颜色
- 为类目(类别)添加属性,使用storyboard设置边框颜色(转载)
- 设置UI控件的Layer属性(边框可见,边框颜色,边框宽度,边框圆角)
- 使用Drawble文件实现圆角,填充颜色,边框等属性的设置(Android)
- 为类目(类别)添加属性,使用storyboard设置边框颜色
- Android Button 常用属性设置,圆角,边框,点击事件
- CALayer控件(通过操作这个CALayer对象,可以很方便地调整UIView的一些界面属性,比如:阴影、圆角大小、边框宽度和颜色等)
- 设置视图圆角,边框宽度/颜色
- 代码设置TextView、Button等控件圆角边框背景颜色
- storyboard内设置视图属性(圆角和边框)
- 如何在Xib中设置Button的属性(圆角以及背景颜色)
- 如何在Xib中设置Button的属性(圆角以及背景颜色)
- xib中设置圆角,边框宽度,边框颜色等
- 设置button的边框颜色和宽度
- UIButton边框宽度颜色圆角设置后不显示
- 在Storyboard中或者xib中设置button的圆角属性,和其他不能设置的熟悉
- storyboard 设置圆角与边框颜色
- UIButton设置圆角和边框及边框颜色