
self.view.layer.shadowColor = [UIColor blackColor].CGColor; //阴影颜色 self.view.layer.shadowOffset = CGSizeMake(10, 10); //阴影偏移 四周阴影则设置为CGSizeZero self.view.layer.shadowOpacity = 1; //阴影透明度,默认为0,不显示 self.view.layer.shadowRadius = 10; //阴影半径 默认为3
1、mas_equalTo是equal to的宏定义,equalTo后面的参数只能是常用数值类型,mas_equalTo后面还可以跟CGsize类型的参数。如下,只能用mas_equalTo
make.size.mas_equalTo(CGSizeMake(img.size.width, img.size.height));
2、下面这句中参数为self.buttonLogin.mas_right,不能写成self.buttonLogin.right
make.right.mas_equalTo(self.buttonLogin.mas_right);
3、
只要添加了这个宏,就不用带mas_前缀 #define MAS_SHORTHAND
只要添加了这个宏,equalTo就等价于mas_equalTo #define MAS_SHORTHAND_GLOBALS
头文件#import "Masonry.h"一定要放在上面两个宏的后面
只有断行模式为NSLineBreakByWordWrapping和NSLineBreakByCharWrapping的段落才能正常获取到文本高度。
NSMutableParagraphStyle *paragraphStyle = [[NSMutableParagraphStyle alloc]init];
paragraphStyle.lineSpacing = 2;
paragraphStyle.lineBreakMode = NSLineBreakByCharWrapping;
NSDictionary *dic = @{NSFontAttributeName:[UIFont systemFontOfSize:14.0f],NSParagraphStyleAttributeName:paragraphStyle};
CGFloat hegiht = [string boundingRectWithSize:CGSizeMake(300, MAXFLOAT) options:NSStringDrawingUsesLineFragmentOrigin attributes:dic context:nil].size.height;
extern是变量扩展的关键字,用其声明的变量也称为全局变量,通过它可以跨文件使用同一个变量。使用方法是:
在一个类的.m文件中申明全局变量。例:
NSString *externString = @"haha";
在另一个文件中使用(可以修改):
extern NSString *externString;
注意:假如申明放在一个类的.h文件中,在使用extern NSString *externString;的类中就不能导入申明类的.h头文件,会报duplicate(重复)错误。
1、storyboard中可以设置点击某个button直接push到下一个视图。如果button所在视图控制器重写了
- (void)PRepareForSegue:(UIStoryboardSegue *)segue sender:(id)sender;
通过 segue.destinationViewController 可以获取目标目标视图控制器,这样可以在push前对目标视图控制器相关参数进行设置。也可以将button所在的视图控制器push关联到目标视图控制器,并设置storyboard segue的identifier,通过
[self performSegueWithIdentifier:@"PushToTest" sender:nil];
push到目标视图控制器,sender为需要传递到方法-(void)prepareForSegue:(UIStoryboardSegue *)segue sender:(id)sender的数据对象。
2、加载故事版(storyboard)中的视图控制器:
UIStoryboard *sb = [UIStoryboard storyboardWithName:@"Test" bundle:nil]; //name不用加.storyboard后缀 UIViewController *viewController = [sb instantiateViewControllerWithIdentifier:@"TestViewController"]; //@“TestViewController”为storyboard的标识符,UIViewController为故事板中视图控制器对应的类
instantiateInitialViewController和instantiateViewControllerWithIdentifier:的区别:
前者得到的是storyBoard中初始化的那个界面(入口界面),后者则根据identifier参数得到整个storyboard中任意的界面(由identifier决定)。
当我们在一个UIViewController中同时创建2个tableView的时候,如果把它们的frame中的Y坐标设置为一样,你可能会发现它们的位置并没有达到你想要的结果.比如第一tableView个frame(0,0,320,568),另一个也frame(0,0,320,568),结果会发现第二个tableView的第一行数据被导航栏遮挡了,以至于我们不得已把第二个frame改成(0,64,320,568-64).因此当我们一个界面有多个tableView之类的,要将视图控制器的automaticallyAdjustsScrollViewInsets设置为NO,完全由自己手动来布局,就不会错乱了。
NSString *string2 = [string1 stringByReplacingOccurrencesOfString:@"b" withString:@"y"];
用@"y"替换string1中所有的@"b",得到替换后的字符串string2;
NSString *string3 = [string1 stringByReplacingOccurrencesOfString:@"b" withString:@"y" options:NSCaseInsensitiveSearch range:NSMakeRange(0, 4)];
用@"y"替换string1中0·4索引范围内的@"b",比较方式为NSCaseInsensitiveSearch,得到替换后的字符串string3。
关于比较方式枚举:
enum{
NSCaseInsensitiveSearch = 1,//不区分大小写比较
NSLiteralSearch = 2,//区分大小写比较
NSBackwardsSearch = 4,//从字符串末尾开始搜索
NSAnchoredSearch = 8,//搜索限制范围的字符串
NSNumbericSearch = 64//按照字符串里的数字为依据,算出顺序。例如 Foo2.txt < Foo7.txt < Foo25.txt
NSDiacriticInsensitiveSearch = 128,//忽略 "-" 符号的比较
NSWidthInsensitiveSearch = 256,//忽略字符串的长度,比较出结果
NSForcedOrderingSearch = 512//忽略不区分大小写比较的选项,并强制返回 NSOrderedAscending 或者NSOrderedDescending
NSRegularExpressionSearch = 1024//只能应用于 rangeOfString:…, stringByReplacingOccurrencesOfString:...和 replaceOccurrencesOfString:… 方法。使用通用兼容的比较方法,如果设置此项,可以去掉 NSCaseInsensitiveSearch 和 NSAnchoredSearch
}
//获取当前屏幕显示的viewcontroller
- (UIViewController *)currentViewController{
UIWindow *keyWindow = [UIapplication sharedApplication].keyWindow;
// modal展现方式的底层视图不同
// 取到第一层时,取到的是UITransitionView,通过这个view拿不到控制器,因此针对这个特例取到第二层避免
UIView *firstLayoutContainerView = [keyWindow.subviews firstObject];
UIView *secondLayoutContainerView = [firstLayoutContainerView.subviews firstObject];
UIViewController *vc = [self parentControllerForView:secondLayoutContainerView];
if (vc) {
if ([vc isKindOfClass:[UITabBarController class]]) {
//容器为UITabBarController
UITabBarController *tab = (UITabBarController *)vc;
if ([tab.selectedViewController isKindOfClass:[UINavigationController class]]) {
UINavigationController *nav = (UINavigationController *)tab.selectedViewController;
return [nav.viewControllers lastObject];
} else {
return tab.selectedViewController;
}
} else if ([vc isKindOfClass:[UINavigationController class]]) {
//容器为UINavigationController
UINavigationController *nav = (UINavigationController *)vc;
return [nav.viewControllers lastObject];
}
}else{
//无容器
return [self parentControllerForView:firstLayoutContainerView];
}
return nil;
}
//通过响应者链条获取view所在的控制器
- (UIViewController *)parentControllerForView:(UIView *)view{
UIResponder *responder = [view nextResponder];
while (responder) {
if ([responder isKindOfClass:[UIViewController class]]) {
return (UIViewController *)responder;
}
responder = [responder nextResponder];
}
return nil;
}