Storyboard一些特性及操作技巧整理

Xcode6之后苹果就一直极力倡导使用storyboard,特别随着Xcode6 的Size ClassIBDesignableIBInspectable;Xcode7 的Storyboard Reference推出之后,越来越多的开发者开始使用Storyboard。作为一个Storyboard的重度使用者,在这里对使用Storyboard的一些特性和技巧做一些整理。

Storyboard Reference

作为xib和storyboard的重度使用者(特别是Xcode6以后),以前storyboard一直被大家吐槽,特别是多人开发Merge的时候,一大堆warning、error扑面而来,弄得头都大。而Xcode7之后出现的Storyboard Reference,让我为之一喜。

Storyboard Reference的目的是把一个个模块分离,既避免了Main.storyboard的庞大不可把控,又??榛疷I让分工变得简单,而且可以快速准确地找到分工的各部分。

使用Storyboard Reference,最后你看到你的storyboard应该是这样的:

Storyboard Reference

这样是不是简洁明了,可控性好很多,不用再为多人开发整合而烦恼了~ ~

操作:

只需在Main.storyboard中选中要分离的UIViewController,然后点击菜单:Editor->Refactor to Storyboard 创建一个新的分离出来的storyboard就好了。

Size Class

Xcode6之后出现的Size Class,下面显示了iOS设备及其对应的Size Class:

更直观的iOS设备对应的Size Class:

至于size class在各设备上的相对应的使用就不赘述了,接下来介绍size classAttributes Inspector上的使用:

Attributes Inspector中左边带+的都可以使用size class.

IBDesignable&IBInspectable

IBDesignable&IBInspectable的介绍在nshipster中很早之前就有了,这里也只是我之前使用过的一些整理。

比如,在Storyboard中给按钮加圆角、边框什么的,User Defined Runtime Attributes可能是这个样子的:

上图是用户自定义的运行时属性的使用,而IBInspectable属性提供了一种新的方式。

创建一个自定义的UIButton:

.h文件

#import <UIKit/UIKit.h>

IB_DESIGNABLE
@interface MyDrawButton : UIButton

@property (nonatomic) IBInspectable UIColor *fillColor;           //填充颜色
@property (nonatomic) IBInspectable NSInteger lineWidth;          //线的宽度
@property (nonatomic) IBInspectable NSInteger cornerRadius;       //圆角弧度
@property (nonatomic) IBInspectable NSInteger borderWidth;        //边框宽度

@end

.m文件

#import "MyDrawButton.h"
#import <pop/POP.h>

@implementation MyDrawButton

- (void)drawRect:(CGRect)rect {
    CGContextRef context=UIGraphicsGetCurrentContext();
    CGRect myFrame=self.bounds;
    CGContextSetLineWidth(context, _lineWidth);
    CGRectInset(myFrame, 5, 5);
    [_fillColor set];
    UIRectFrame(myFrame);
    
    self.layer.cornerRadius=_cornerRadius;
    self.layer.borderWidth=_borderWidth;
    self.layer.borderColor=_fillColor.CGColor;
    
    [self addTarget:self action:@selector(scaleToSmall)
   forControlEvents:UIControlEventTouchDown | UIControlEventTouchDragEnter];
    [self addTarget:self action:@selector(scaleAnimation)
   forControlEvents:UIControlEventTouchUpInside];
    [self addTarget:self action:@selector(scaleToDefault)
   forControlEvents:UIControlEventTouchDragExit];
    
}
- (void)scaleToSmall
{
    POPBasicAnimation *scaleAnimation = [POPBasicAnimation animationWithPropertyNamed:kPOPLayerScaleXY];
    scaleAnimation.toValue = [NSValue valueWithCGSize:CGSizeMake(0.95f, 0.95f)];
    [self.layer pop_addAnimation:scaleAnimation forKey:@"layerScaleSmallAnimation"];
}
- (void)scaleAnimation
{
    POPSpringAnimation *scaleAnimation = [POPSpringAnimation animationWithPropertyNamed:kPOPLayerScaleXY];
    scaleAnimation.velocity = [NSValue valueWithCGSize:CGSizeMake(2.f, 2.f)];
    scaleAnimation.toValue = [NSValue valueWithCGSize:CGSizeMake(1.f, 1.f)];
    scaleAnimation.springBounciness = 25.0f;
    [self.layer pop_addAnimation:scaleAnimation forKey:@"layerScaleSpringAnimation"];
    
}
- (void)scaleToDefault
{
    POPBasicAnimation *scaleAnimation = [POPBasicAnimation animationWithPropertyNamed:kPOPLayerScaleXY];
    scaleAnimation.toValue = [NSValue valueWithCGSize:CGSizeMake(1.f, 1.f)];
    [self.layer pop_addAnimation:scaleAnimation forKey:@"layerScaleDefaultAnimation"];
}
@end

storyboard中的UIButton只需继承自它,然后就可以在Attributes Inspector中看到这些属性:

给相应的属性设值就有效果了。而上面给自定义按钮添加了点击动画,只要继承自这个自定义按钮都会有点击动画,其效果是这样的:

User Defined Runtime Attributes

上面图中最后两个是自定义关联的运行时属性,
比如layer.colorFromUIColor,只需新建一个CALayerCategory

.h文件

@interface CALayer (Addition)

@property(nonatomic,strong) UIColor *colorFromUIColor;

-(void)setColorFromUIColor:(UIColor *)color;

@end

.m文件

#import "CALayer+Addition.h"
#import <objc/runtime.h>

@implementation CALayer (Addition)
@dynamic colorFromUIColor;

-(UIColor *)colorFromUIColor
{
    return objc_getAssociatedObject(self, @selector(colorFromUIColor));
}
-(void)setColorFromUIColor:(UIColor *)color
{
    objc_setAssociatedObject(self, @selector(colorFromUIColor), color, OBJC_ASSOCIATION_RETAIN_NONATOMIC);
    [self setColorFromUI:self.colorFromUIColor];
}
-(void)setColorFromUI:(UIColor *)color
{
    self.borderColor=color.CGColor;
}
@end

这样设置就ok了,然后在User Defined Runtime Attributes中就可以设置colorFromUIColor这个属性了。

而自定义runtime属性bindingAnimationType来自FastAnimationWithPOP,配置相关属性运行可以直接得到如下效果:

配置
导入pop、FastAnimationWithPOP:

pod 'pop', '~> 1.0.9'
pod 'FastAnimationWithPOP', '~> 0.0.2'

然后在Identity Inspector中配置控件的用户自定义运行时属性

控制好animationTypedelay就得到了上面的效果,自己不需要写一句代码!有没有很nice! 反正我最开始用的时候兴奋极了 ~ ~

UIStackView

iOS9之后出来的UIStackView比较特别,对于自动布局这块非常方便,它可以快速地在垂直或水平排布多个subview,最有用的就是它会自动为每个subview创建和添加Auto Layout constraints。当然你可以控制subview的大小和位置??梢酝ü∠钆渲胹ubview的大小、排布以及彼此间的间距。具体细节见iOS 9: UIStackView入门,以下是我自己实战操作。

UIStackView
UIStackView

至于兼容iOS9之前版本,推荐使用FDStackView,兼容UIStackView iOS9之前版本,同样的,也可以使用storyboard,非常好!
FDStackView Part1、FDStackView Part2、FDStackView Part3这三篇文章是作者分析FDStackView的设计实现过程,有兴趣可以看一下。

提高Interface Builder高效工作的8个技巧

  • 使view的Size与view中的Content相适应
  • 按住option键—观察所选中view与另外view边缘之间的距离
  • Editor -> Embed In View, Unembed:
  • 在不影响subview的位置时给view自由的添加padding
  • 对不在最前端的view进行移动
  • IBOutletCollection排序
  • 使用自定义属性
  • MoarFonts——字体定制:所见即所得

具体细节查看原文:提高Interface Builder高效工作的8个技巧

总结:

我现在一直在使用storyboard,至今感觉良好!特别有了这些技巧和特性之后,效率那是杠杠的.。这里把以前用过的写在这里分享?出来,也方便我自己总结和回顾。

这篇文章主要内容:

  • Storyboard Reference:Storyboard分离
  • Size Class:多设备自动布局
  • IBDesignable&IBInspectable:配置自定义控件
  • User Defined Runtime Attributes:用户自定义运行时属性
  • UIStackView:方便垂直或水平排布多个subview
  • 提高Interface Builder高效工作的8个技巧:Interface Builder的操作技巧
最后编辑于
?著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 214,100评论 6 493
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,308评论 3 388
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 159,718评论 0 349
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,275评论 1 287
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,376评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,454评论 1 292
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,464评论 3 412
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,248评论 0 269
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,686评论 1 306
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,974评论 2 328
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,150评论 1 342
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,817评论 4 337
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,484评论 3 322
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,140评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,374评论 1 267
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,012评论 2 365
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,041评论 2 351

推荐阅读更多精彩内容

  • 发现 关注 消息 iOS 第三方库、插件、知名博客总结 作者大灰狼的小绵羊哥哥关注 2017.06.26 09:4...
    肇东周阅读 12,079评论 4 62
  • Spring Cloud为开发人员提供了快速构建分布式系统中一些常见模式的工具(例如配置管理,服务发现,断路器,智...
    卡卡罗2017阅读 134,644评论 18 139
  • 我希望有一个如你一般的人,不是已经属于别人,而是属于我或者被我无所顾及的追随。你金灿灿的或者个人照头像都让我欢心,...
    tristeolive阅读 497评论 0 0
  • 文|没有春 我想你了 酸酸的 像刚喝了一碗醋 酸烈激灵过后 有种想哭的感觉 我想你了 晕晕的 像刚喝完一口烈酒 走...
    没有春阅读 489评论 22 13
  • 文/刘彩霞 第二天一早,雪在空中飘着。奇异的是太阳出来了,只才一会儿。阳光清丽,把雪花映衬得晶晶闪闪,雪花打着...
    彩霞漫天阅读 335评论 0 0