iOS开发经验总结(三)

1、设置UILabel行间距

1
2
3
4
5
NSMutableAttributedString* attrString = [[NSMutableAttributedString  alloc] initWithString:label.text];
     NSMutableParagraphStyle *style = [[NSMutableParagraphStyle alloc] init];
     [style setLineSpacing:20];
     [attrString addAttribute:NSParagraphStyleAttributeName value:style range:NSMakeRange(0, label.text.length)];
     label.attributedText = attrString;

// 或者使用xib,看下gif图

1432270-736756a6216a6753.gif

Untitled.gif


58、比较两个UIImage是否相等

1
2
3
4
5
6
7
- (BOOL)image:(UIImage *)image1 isEqualTo:(UIImage *)image2
{
     NSData *data1 = UIImagePNGRepresentation(image1);
     NSData *data2 = UIImagePNGRepresentation(image2);
 
     return  [data1 isEqual:data2];
}

59、解决当UIScrollView上有UIButton的时候,触摸到button滑动不了的问题

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
// 子类化UIScrollView,并重写以下方法
- (instancetype)initWithFrame:(CGRect)frame {
     if  (self = [ super  initWithFrame:frame]) {
         self.delaysContentTouches = NO;
     }
 
     return  self;
}
 
- (BOOL)touchesShouldCancelInContentView:(UIView *)view {
     if  ([view isKindOfClass:UIButton.class]) {
         return  YES;
     }
 
     return  [ super  touchesShouldCancelInContentView:view];
}

60、UITextView中的文字添加阴影效果

1
2
3
4
5
6
7
8
- (void)setTextLayer:(UITextView *)textView color:(UIColor *)color
{
     CALayer *textLayer = ((CALayer *)[textView.layer.sublayers objectAtIndex:0]);
     textLayer.shadowColor = color.CGColor;
     textLayer.shadowOffset = CGSizeMake(0.0f, 1.0f);
     textLayer.shadowOpacity = 1.0f;
     textLayer.shadowRadius = 1.0f;
}

61、MD5加密

1
2
3
4
5
6
7
8
9
10
11
+ (NSString *)md5:(NSString *)str
{
     const char *concat_str = [str UTF8String];
     unsigned char result[CC_MD5_DIGEST_LENGTH];
     CC_MD5(concat_str, (unsigned int)strlen(concat_str), result);
     NSMutableString *hash = [NSMutableString string];
     for  (int i =0; i<16; i++){
         [hash appendFormat:@ "X" , result[i]];
     }
     return  [hash uppercaseString];
}

62、base64加密

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
@interface NSData (Base64)
/**
  *  @brief  字符串base64后转data
  */
+ (NSData *)dataWithBase64EncodedString:(NSString *)string
{
     if  (![string length])  return  nil;
     NSData *decoded = nil;
#if __MAC_OS_X_VERSION_MIN_REQUIRED < __MAC_10_9 || __IPHONE_OS_VERSION_MIN_REQUIRED < __IPHONE_7_0
     if  (![NSData instancesRespondToSelector:@selector(initWithBase64EncodedString:options:)])
     {
#pragma clang diagnostic push
#pragma clang diagnostic ignored "-Wdeprecated-declarations"
         decoded = [[self alloc] initWithBase64Encoding:[string stringByReplacingOccurrencesOfString:@ "[^A-Za-z0-9+/=]"  withString:@ ""  options:NSRegularExpressionSearch range:NSMakeRange(0, [string length])]];
#pragma clang diagnostic pop
     }
     else
#endif
     {
         decoded = [[self alloc] initWithBase64EncodedString:string options:NSDataBase64DecodingIgnoreUnknownCharacters];
     }
     return  [decoded length]? decoded: nil;
}
/**
  *  @brief  NSData转string
  *  @param wrapWidth 换行长度  76  64
  */
- (NSString *)base64EncodedStringWithWrapWidth:(NSUInteger)wrapWidth
{
     if  (![self length])  return  nil;
     NSString *encoded = nil;
#if __MAC_OS_X_VERSION_MIN_REQUIRED < __MAC_10_9 || __IPHONE_OS_VERSION_MIN_REQUIRED < __IPHONE_7_0
     if  (![NSData instancesRespondToSelector:@selector(base64EncodedStringWithOptions:)])
     {
#pragma clang diagnostic push
#pragma clang diagnostic ignored "-Wdeprecated-declarations"
         encoded = [self base64Encoding];
#pragma clang diagnostic pop
 
     }
     else
#endif
     {
         switch  (wrapWidth)
         {
             case  64:
             {
                 return  [self base64EncodedStringWithOptions:NSDataBase64Encoding64CharacterLineLength];
             }
             case  76:
             {
                 return  [self base64EncodedStringWithOptions:NSDataBase64Encoding76CharacterLineLength];
             }
             default :
             {
                 encoded = [self base64EncodedStringWithOptions:(NSDataBase64EncodingOptions)0];
             }
         }
     }
     if  (!wrapWidth || wrapWidth >= [encoded length])
     {
         return  encoded;
     }
     wrapWidth = (wrapWidth / 4) * 4;
     NSMutableString *result = [NSMutableString string];
     for  (NSUInteger i = 0; i < [encoded length]; i+= wrapWidth)
     {
         if  (i + wrapWidth >= [encoded length])
         {
             [result appendString:[encoded substringFromIndex:i]];
             break ;
         }
         [result appendString:[encoded substringWithRange:NSMakeRange(i, wrapWidth)]];
         [result appendString:@ "\r\n" ];
     }
     return  result;
}
/**
  *  @brief  NSData转string 换行长度默认64
  */
- (NSString *)base64EncodedString
{
     return  [self base64EncodedStringWithWrapWidth:0];
}

63、AES加密

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
#import
@interface NSData (AES)
/**
  *  利用AES加密数据
  */
- (NSData*)encryptedWithAESUsingKey:(NSString*)key andIV:(NSData*)iv {
 
     NSData *keyData = [key dataUsingEncoding:NSUTF8StringEncoding];
 
     size_t dataMoved;
     NSMutableData *encryptedData = [NSMutableData dataWithLength:self.length + kCCBlockSizeAES128];
 
     CCCryptorStatus status = CCCrypt(kCCEncrypt,kCCAlgorithmAES128,kCCOptionPKCS7Padding,keyData.bytes,keyData.length,iv.bytes,self.bytes,self.length,encryptedData.mutableBytes, encryptedData.length,&dataMoved);
 
     if  (status == kCCSuccess) {
         encryptedData.length = dataMoved;
         return  encryptedData;
     }
 
     return  nil;
}
 
/**
  *  @brief  利用AES解密据
  */
- (NSData*)decryptedWithAESUsingKey:(NSString*)key andIV:(NSData*)iv {
 
     NSData *keyData = [key dataUsingEncoding:NSUTF8StringEncoding];
 
     size_t dataMoved;
     NSMutableData *decryptedData = [NSMutableData dataWithLength:self.length + kCCBlockSizeAES128];
 
     CCCryptorStatus result = CCCrypt(kCCDecrypt,kCCAlgorithmAES128,kCCOptionPKCS7Padding,keyData.bytes,keyData.length,iv.bytes,self.bytes,self.length,decryptedData.mutableBytes, decryptedData.length,&dataMoved);
 
     if  (result == kCCSuccess) {
         decryptedData.length = dataMoved;
         return  decryptedData;
     }
 
     return  nil;
 
}

64、3DES加密

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
#import
@interface NSData (3DES)
/**
  *  利用3DES加密数据
  */
- (NSData*)encryptedWith3DESUsingKey:(NSString*)key andIV:(NSData*)iv {
 
     NSData *keyData = [key dataUsingEncoding:NSUTF8StringEncoding];
 
     size_t dataMoved;
     NSMutableData *encryptedData = [NSMutableData dataWithLength:self.length + kCCBlockSize3DES];
 
     CCCryptorStatus result = CCCrypt(kCCEncrypt,kCCAlgorithm3DES,kCCOptionPKCS7Padding,keyData.bytes,keyData.length,iv.bytes,self.bytes,self.length,encryptedData.mutableBytes,encryptedData.length,&dataMoved);
 
     if  (result == kCCSuccess) {
         encryptedData.length = dataMoved;
         return  encryptedData;
     }
 
     return  nil;
 
}
/**
  *  @brief   利用3DES解密数据
  */
- (NSData*)decryptedWith3DESUsingKey:(NSString*)key andIV:(NSData*)iv {
 
     NSData *keyData = [key dataUsingEncoding:NSUTF8StringEncoding];
 
     size_t dataMoved;
     NSMutableData *decryptedData = [NSMutableData dataWithLength:self.length + kCCBlockSize3DES];
 
     CCCryptorStatus result = CCCrypt(kCCDecrypt,kCCAlgorithm3DES,kCCOptionPKCS7Padding,keyData.bytes,keyData.length,iv.bytes,self.bytes,self.length,decryptedData.mutableBytes,decryptedData.length,&dataMoved);
 
     if  (result == kCCSuccess) {
         decryptedData.length = dataMoved;
         return  decryptedData;
     }
 
     return  nil;
 
}

65、单个页面多个网络请求的情况,需要监听所有网络请求结束后刷新UI

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
dispatch_group_t group = dispatch_group_create();
     dispatch_queue_t serialQueue = dispatch_queue_create( "com.wzb.test.www" , DISPATCH_QUEUE_SERIAL);
     dispatch_group_enter(group);
     dispatch_group_async(group, serialQueue, ^{
         // 网络请求一
         [WebClick getDataSuccess:^(ResponseModel *model) {
             dispatch_group_leave(group);
         } failure:^(NSString *err) {
             dispatch_group_leave(group);
         }];
     });
     dispatch_group_enter(group);
     dispatch_group_async(group, serialQueue, ^{
         // 网络请求二
         [WebClick getDataSuccess:getBigTypeRM onSuccess:^(ResponseModel *model) {
             dispatch_group_leave(group);
         }                                  failure:^(NSString *errorString) {
             dispatch_group_leave(group);
         }];
     });
     dispatch_group_enter(group);
     dispatch_group_async(group, serialQueue, ^{
         // 网络请求三
         [WebClick getDataSuccess:^{
             dispatch_group_leave(group);
         } failure:^(NSString *errorString) {
             dispatch_group_leave(group);
         }];
     });
 
     // 所有网络请求结束后会来到这个方法
     dispatch_group_notify(group, serialQueue, ^{
         dispatch_async(dispatch_get_global_queue(0, 0), ^{
             dispatch_async(dispatch_get_main_queue(), ^{
                 // 刷新UI
             });
         });
     });

66、解决openUrl延时问题

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
// 方法一
dispatch_async(dispatch_get_main_queue(), ^{
 
     UIApplication *application = [UIApplication sharedApplication];
     if  ([application respondsToSelector:@selector(openURL:options:completionHandler:)]) {
         [application openURL:URL options:@{}
            completionHandler:nil];
     else  {
         [application openURL:URL];
     }
     });
// 方法二
[self performSelector:@selector(redirectToURL:) withObject:url afterDelay:0.1];
 
- (void) redirectToURL
{
UIApplication *application = [UIApplication sharedApplication];
     if  ([application respondsToSelector:@selector(openURL:options:completionHandler:)]) {
         [application openURL:URL options:@{}
            completionHandler:nil];
     else  {
         [application openURL:URL];
     }
}

67、页面跳转实现翻转动画

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
// modal方式
     TestViewController *vc = [[TestViewController alloc] init];
     vc.view.backgroundColor = [UIColor redColor];
     vc.modalTransitionStyle = UIModalTransitionStyleCoverVertical;
     [self presentViewController:vc animated:YES completion:nil];
 
// push方式
     TestViewController *vc = [[TestViewController alloc] init];
     vc.view.backgroundColor = [UIColor redColor];
     [UIView beginAnimations:@ "View Flip"  context:nil];
     [UIView setAnimationDuration:0.80];
     [UIView setAnimationCurve:UIViewAnimationCurveEaseInOut];
     [UIView setAnimationTransition:UIViewAnimationTransitionFlipFromRight forView:self.navigationController.view cache:NO];
     [self.navigationController pushViewController:vc animated:YES];
     [UIView commitAnimations];

68、tableView实现无限滚动

1
2
3
4
5
6
7
8
9
- (void)scrollViewDidScroll:(UIScrollView *)scrollView
{
     CGFloat actualPosition = scrollView.contentOffset.y;
     CGFloat contentHeight = scrollView.contentSize.height - scrollView.frame.size.height;
     if  (actualPosition >= contentHeight) {
         [self.dataArr addObjectsFromArray:self.dataArr];
         [self.tableView reloadData];
     }
}

69、代码方式调整屏幕亮度

1
2
// brightness属性值在0-1之间,0代表最小亮度,1代表最大亮度
[[UIScreen mainScreen] setBrightness:0.5];

70、获取当前应用CUP用量

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
float cpu_usage()
{
     kern_return_t kr;
     task_info_data_t tinfo;
     mach_msg_type_number_t task_info_count;
 
     task_info_count = TASK_INFO_MAX;
     kr = task_info(mach_task_self(), TASK_BASIC_INFO, (task_info_t)tinfo, &task_info_count);
     if  (kr != KERN_SUCCESS) {
         return  -1;
     }
 
     task_basic_info_t      basic_info;
     thread_array_t         thread_list;
     mach_msg_type_number_t thread_count;
 
     thread_info_data_t     thinfo;
     mach_msg_type_number_t thread_info_count;
 
     thread_basic_info_t basic_info_th;
     uint32_t stat_thread = 0;  // Mach threads
 
     basic_info = (task_basic_info_t)tinfo;
 
     // get threads in the task
     kr = task_threads(mach_task_self(), &thread_list, &thread_count);
     if  (kr != KERN_SUCCESS) {
         return  -1;
     }
     if  (thread_count > 0)
         stat_thread += thread_count;
 
     long tot_sec = 0;
     long tot_usec = 0;
     float tot_cpu = 0;
     int j;
 
     for  (j = 0; j < (int)thread_count; j++)
     {
         thread_info_count = THREAD_INFO_MAX;
         kr = thread_info(thread_list[j], THREAD_BASIC_INFO,
                          (thread_info_t)thinfo, &thread_info_count);
         if  (kr != KERN_SUCCESS) {
             return  -1;
         }
 
         basic_info_th = (thread_basic_info_t)thinfo;
 
         if  (!(basic_info_th->flags & TH_FLAGS_IDLE)) {
             tot_sec = tot_sec + basic_info_th->user_time.seconds + basic_info_th->system_time.seconds;
             tot_usec = tot_usec + basic_info_th->user_time.microseconds + basic_info_th->system_time.microseconds;
             tot_cpu = tot_cpu + basic_info_th->cpu_usage / (float)TH_USAGE_SCALE * 100.0;
         }
 
     // for each thread
 
     kr = vm_deallocate(mach_task_self(), (vm_offset_t)thread_list, thread_count * sizeof(thread_t));
     assert(kr == KERN_SUCCESS);
 
     return  tot_cpu;
}

71、float数据取整四舍五入

1
2
3
4
5
     CGFloat f = 4.65;
     NSLog(@ "%d" , (int)f);     // 打印结果4
 
     CGFloat f = 4.65;
     NSLog(@ "%d" , (int)round(f));     // 打印结果5

72、删除UISearchBar系统默认边框

1
2
3
4
5
6
7
8
     // 方法一
     searchBar.searchBarStyle = UISearchBarStyleMinimal;
 
     // 方法二
     [searchBar setBackgroundImage:[[UIImage alloc]init]];
 
     // 方法三
     searchBar.barTintColor = [UIColor whiteColor];

73、为UICollectionViewCell设置圆角和阴影

1
2
3
4
5
6
7
8
9
10
11
cell.contentView.layer.cornerRadius = 2.0f;
cell.contentView.layer.borderWidth = 1.0f;
cell.contentView.layer.borderColor = [UIColor clearColor].CGColor;
cell.contentView.layer.masksToBounds = YES;
 
cell.layer.shadowColor = [UIColor lightGrayColor].CGColor;
cell.layer.shadowOffset = CGSizeMake(0, 2.0f);
cell.layer.shadowRadius = 2.0f;
cell.layer.shadowOpacity = 1.0f;
cell.layer.masksToBounds = NO;
cell.layer.shadowPath = [UIBezierPath bezierPathWithRoundedRect:cell.bounds cornerRadius:cell.contentView.layer.cornerRadius].CGPath;

74、让正在滑动的scrollView停止滚动(不是禁止,而是暂时停止滚动)

1
[scrollView setContentOffset:scrollView.contentOffset animated:NO];

75、使用xib设置UIView的边框、圆角

圆角和边框看下图即可设置

1432270-92361b4d420ac296.png

xib设置圆角边框.png

但是增加layer.borderColor的keyPath设置边框颜色并不能起作用,后来查了资料,这里应该用layer.borderUIColor,但是这里设置的颜色不起作用,无论设置什么颜色显示出来的都是黑色的。后来又去查了下,有种解决方案是给CALayer添加一个分类,提供一个 - (void)setBorderUIColor:(UIColor *)color;方法就可以解决了,实现如下:

1432270-1fc7e7ca02eca962.png

xib设置边框颜色.png

1
2
3
4
5
6
7
8
#import "CALayer+BorderColor.h"
 
@implementation CALayer (BorderColor)
 
- (void)setBorderUIColor:(UIColor *)color
{
     self.borderColor = color.CGColor;
}

76、根据经纬度获取城市等信息

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
// 创建经纬度
     CLLocation *location = [[CLLocation alloc] initWithLatitude:latitude longitude:longitude];
     //创建一个译码器
     CLGeocoder *cLGeocoder = [[CLGeocoder alloc] init];
     [cLGeocoder reverseGeocodeLocation:userLocation completionHandler:^(NSArray *placemarks, NSError *error) {
         CLPlacemark *place = [placemarks objectAtIndex:0];
         // 位置名
       NSLog(@ "name,%@" ,place.name);
        // 街道
       NSLog(@ "thoroughfare,%@" ,place.thoroughfare);
        // 子街道
       NSLog(@ "subThoroughfare,%@" ,place.subThoroughfare);
        // 市
       NSLog(@ "locality,%@" ,place.locality);
        // 区
       NSLog(@ "subLocality,%@" ,place.subLocality); 
        // 国家
       NSLog(@ "country,%@" ,place.country);
         }
     }];
 
/*  CLPlacemark中属性含义
name                    地名
 
thoroughfare            街道
 
subThoroughfare        街道相关信息,例如门牌等
locality                城市
 
subLocality            城市相关信息,例如标志性建筑
 
administrativeArea      直辖市
 
subAdministrativeArea  其他行政区域信息(自治区等)
 
postalCode              邮编
 
ISOcountryCode          国家编码
 
country                国家
 
inlandWater            水源,湖泊
 
ocean                  海洋
 
areasOfInterest        关联的或利益相关的地标
*/

77、如何防止添加多个NSNotification观察者?

1
2
3
// 解决方案就是添加观察者之前先移除下这个观察者
[[NSNotificationCenter defaultCenter] removeObserver:observer name:name object:object];
         [[NSNotificationCenter defaultCenter] addObserver:observer selector:selector name:name object:object];

78、将一个xib添加到另外一个xib上

1
2
3
4
5
6
7
// 假设你的自定义view名字为CustomView,你需要在CustomView.m中重写 `- (instancetype)initWithCoder:(NSCoder *)aDecoder` 方法,代码如下:
- (instancetype)initWithCoder:(NSCoder *)aDecoder {
     if  ((self = [ super  initWithCoder:aDecoder])) {
         [self addSubview:[[[NSBundle mainBundle] loadNibNamed:@ "CustomView"  owner:self options:nil] objectAtIndex:0]];
     }
     return  self;
}

1432270-1baa2a4dd2e2d08f.png

将一个xib添加到另外一个xib上.png

79、处理字符串,使其首字母大写

1
2
3
4
5
6
     NSString *str = @ "abcdefghijklmn" ;
     NSString *resultStr;
     if  (str && str.length > 0) {
         resultStr = [str stringByReplacingCharactersInRange:NSMakeRange(0,1) withString:[[str substringToIndex:1] capitalizedString]];
     }
     NSLog(@ "%@" , resultStr);

80、判断一个UIAlertView/UIAlertController是否显示

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
// UIAlertView自带属性
if  (alert.visible)
{
       NSLog(@ "显示了" );
else  {
       NSLog(@ "未显示" );
}
 
// UIAlertController没有visible属性,需要自己判断,添加一个全局变量 BOOL visible
UIAlertController *alertController = [UIAlertController alertControllerWithTitle:@ "Title"  message:@ "message"  preferredStyle:UIAlertControllerStyleAlert];
     UIAlertAction *alertAction = [UIAlertAction actionWithTitle:@ "ActionTitle"  style:UIAlertActionStyleDefault handler:^(UIAlertAction * _Nonnull action) {
         self.visible = NO;
     }];
     UIAlertAction *calcelAction = [UIAlertAction actionWithTitle:@ "calcelTitle"  style:UIAlertActionStyleCancel handler:^(UIAlertAction * _Nonnull action) {
         self.visible = NO;
     }];
     [alertController addAction:alertAction];
     [alertController addAction:calcelAction];
     [self presentViewController:alertController animated:YES completion:^{
         self.visible = YES;
     }];

81、获取字符串中的数字

1
2
3
4
5
6
7
- (NSString *)getNumberFromStr:(NSString *)str
{
     NSCharacterSet *nonDigitCharacterSet = [[NSCharacterSet decimalDigitCharacterSet] invertedSet];
     return  [[str componentsSeparatedByCharactersInSet:nonDigitCharacterSet] componentsJoinedByString:@ "" ];
}
6
     NSLog(@ "%@" , [self getNumberFromStr:@ "a0b0c1d2e3f4fda8fa8fad9fsad23" ]);  // 00123488923

82、为UIView的某个方向添加边框

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
// 添加UIView分类
 
// UIView+WZB.h
#import
 
 
/**
  边框方向
 
  - WZBBorderDirectionTop: 顶部
  - WZBBorderDirectionLeft: 左边
  - WZBBorderDirectionBottom: 底部
  - WZBBorderDirectionRight: 右边
  */
typedef NS_ENUM(NSInteger, WZBBorderDirectionType) {
     WZBBorderDirectionTop = 0,
     WZBBorderDirectionLeft,
     WZBBorderDirectionBottom,
     WZBBorderDirectionRight
};
 
@interface UIView (WZB)
 
 
/**
  为UIView的某个方向添加边框
 
  @param direction 边框方向
  @param color 边框颜色
  @param width 边框宽度
  */
- (void)wzb_addBorder:(WZBBorderDirectionType)direction color:(UIColor *)color width:(CGFloat)width;
 
@end
 
// UIView+WZB.m
#import "UIView+WZB.h"
 
@implementation UIView (WZB)
 
- (void)wzb_addBorder:(WZBBorderDirectionType)direction color:(UIColor *)color width:(CGFloat)width
{
     CALayer *border = [CALayer layer];
     border.backgroundColor = color.CGColor;
     switch  (direction) {
         case  WZBBorderDirectionTop:
         {
             border.frame = CGRectMake(0.0f, 0.0f, self.bounds.size.width, width);
         }
             break ;
         case  WZBBorderDirectionLeft:
         {
             border.frame = CGRectMake(0.0f, 0.0f, width, self.bounds.size.height);
         }
             break ;
         case  WZBBorderDirectionBottom:
         {
             border.frame = CGRectMake(0.0f, self.bounds.size.height - width, self.bounds.size.width, width);
         }
             break ;
         case  WZBBorderDirectionRight:
         {
             border.frame = CGRectMake(self.bounds.size.width - width, 0, width, self.bounds.size.height);
         }
             break ;
         default :
             break ;
     }
     [self.layer addSublayer:border];
}

83、通过属性设置UISwitch、UIProgressView等控件的宽高

1
2
3
mySwitch.transform = CGAffineTransformMakeScale(5.0f, 5.0f);
 
progressView.transform = CGAffineTransformMakeScale(5.0f, 5.0f);

84、自动搜索功能,用户连续输入的时候不搜索,用户停止输入的时候自动搜索(我这里设置的是0.5s,可根据需求更改)

1
2
3
4
5
6
7
// 输入框文字改变的时候调用
-(void)searchBar:(UISearchBar *)searchBar textDidChange:(NSString *)searchText{
     // 先取消调用搜索方法
     [NSObject cancelPreviousPerformRequestsWithTarget:self selector:@selector(searchNewResult) object:nil];
     // 0.5秒后调用搜索方法
     [self performSelector:@selector(searchNewResult) withObject:nil afterDelay:0.5];
}

85、修改UISearchBar的占位文字颜色

1
2
3
4
5
6
7
8
9
10
11
     // 方法一(推荐使用)
     UITextField *searchField = [searchBar valueForKey:@ "_searchField" ];
     [searchField setValue:[UIColor blueColor] forKeyPath:@ "_placeholderLabel.textColor" ];
 
     // 方法二(已过期)
     [[UILabel appearanceWhenContainedIn:[UISearchBar class], nil] setTextColor:[UIColor redColor]];
 
     // 方法三(已过期)
     NSDictionary *placeholderAttributes = @{NSForegroundColorAttributeName : [UIColor redColor], NSFontAttributeName : [UIFont fontWithName:@ "HelveticaNeue"  size:15],};
     NSAttributedString *attributedPlaceholder = [[NSAttributedString alloc] initWithString:searchBar.placeholder attributes:placeholderAttributes];
     [[UITextField appearanceWhenContainedIn:[UISearchBar class], nil] setAttributedPlaceholder:attributedPlaceholder];

86、某个界面多个事件同时响应引起的问题(比如,两个button同时按push到新界面,两个都会响应,可能导致push重叠)

1
2
3
4
5
6
7
8
// UIView有个属性叫做exclusiveTouch,设置为YES后,其响应事件会和其他view互斥(有其他view事件响应的时候点击它不起作用)
view.exclusiveTouch = YES;
 
// 一个一个设置太麻烦了,可以全局设置
[[UIView appearance] setExclusiveTouch:YES];
 
// 或者只设置button
[[UIButton appearance] setExclusiveTouch:YES];

87、修改tabBar的frame

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
// 子类化UITabBarViewController,我这里以修改tabBar高度为例,重写viewWillLayoutSubviews方法
#import "WZBTabBarViewController.h"
 
@interface WZBTabBarViewController ()
 
@end
 
@implementation WZBTabBarViewController
- (void)viewWillLayoutSubviews {
 
     CGRect tabFrame = self.tabBar.frame;
     tabFrame.size.height = 100;
     tabFrame.origin.y = self.view.frame.size.height - 100;
     self.tabBar.frame = tabFrame;
}
@end

88、修改键盘背景颜色

1
2
3
4
5
// 设置某个键盘颜色
     textField.keyboardAppearance = UIKeyboardAppearanceAlert;
 
// 设置工程中所有键盘颜色
[[UITextField appearance] setKeyboardAppearance:UIKeyboardAppearanceAlert];

89、修改image颜色

1
2
3
4
5
6
7
8
9
10
11
12
13
UIImage *image = [UIImage imageNamed:@ "test" ];
     imageView.image = [image imageWithRenderingMode:UIImageRenderingModeAlwaysTemplate];
     CGRect rect = CGRectMake(0, 0, image.size.width, image.size.height);
     UIGraphicsBeginImageContext(rect.size);
     CGContextRef context = UIGraphicsGetCurrentContext();
     CGContextClipToMask(context, rect, image.CGImage);
     CGContextSetFillColorWithColor(context, [[UIColor redColor] CGColor]);
     CGContextFillRect(context, rect);
     UIImage *img = UIGraphicsGetImageFromCurrentImageContext();
     UIGraphicsEndImageContext();
 
     UIImage *flippedImage = [UIImage imageWithCGImage:img.CGImage scale:1.0 orientation: UIImageOrientationDownMirrored];
     imageView.image = flippedImage;

90、动画执行removeFromSuperview

1
2
3
4
5
6
     [UIView animateWithDuration:0.2
                      animations:^{
                          view.alpha = 0.0f;
                      } completion:^(BOOL finished){
                          [view removeFromSuperview];
                      }];

91、设置UIButton高亮背景颜色

1
2
3
4
5
6
     [UIView animateWithDuration:0.2
                      animations:^{
                          view.alpha = 0.0f;
                      } completion:^(BOOL finished){
                          [view removeFromSuperview];
                      }];

92、设置UIButton高亮时的背景颜色

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
// 方法一、子类化UIButton,重写setHighlighted:方法,代码如下
#import "WZBButton.h"
 
@implementation WZBButton
 
- (void)setHighlighted:(BOOL)highlighted {
     [ super  setHighlighted:highlighted];
 
     UIColor *normalColor = [UIColor greenColor];
     UIColor *highlightedColor = [UIColor redColor];
     self.backgroundColor = highlighted ? highlightedColor : normalColor;
 
}
 
// 方法二、利用setBackgroundImage:forState:方法
[button setBackgroundImage:[self imageWithColor:[UIColor blueColor]] forState:UIControlStateHighlighted];
 
- (UIImage *)imageWithColor:(UIColor *)color {
     CGRect rect = CGRectMake(0.0f, 0.0f, 1.0f, 1.0f);
     UIGraphicsBeginImageContext(rect.size);
     CGContextRef context = UIGraphicsGetCurrentContext();
 
     CGContextSetFillColorWithColor(context, [color CGColor]);
     CGContextFillRect(context, rect);
 
     UIImage *image = UIGraphicsGetImageFromCurrentImageContext();
     UIGraphicsEndImageContext();
 
     return  image;
}

93、关于图片拉伸

推荐看这个博客,讲的很详细:http://blog.csdn.net/q199109106q/article/details/8615661

94、利用runtime获取一个类所有属性

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
- (NSArray *)allPropertyNames:(Class)aClass
{
     unsigned count;
     objc_property_t *properties = class_copyPropertyList(aClass, &count);
 
     NSMutableArray *rv = [NSMutableArray array];
 
     unsigned i;
     for  (i = 0; i < count; i++)
     {
         objc_property_t property = properties[i];
         NSString *name = [NSString stringWithUTF8String:property_getName(property)];
         [rv addObject:name];
     }
 
     free(properties);
 
     return  rv;
}

95、设置textView的某段文字变成其他颜色

1
2
3
4
5
- (void)setupTextView:(UITextView *)textView text:(NSString *)text color:(UIColor *)color {
     NSMutableAttributedString *string = [[NSMutableAttributedString alloc]initWithString:textView.text];
     [string addAttribute:NSForegroundColorAttributeName value:color range:[textView.text rangeOfString:text]];
     [textView setAttributedText:string];
}

96、让push跳转动画像modal跳转动画那样效果(从下往上推上来)

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
- (void)push
{
TestViewController *vc = [[TestViewController alloc] init];
     vc.view.backgroundColor = [UIColor redColor];
     CATransition* transition = [CATransition animation];
     transition.duration = 0.4f;
     transition.type = kCATransitionMoveIn;
     transition.subtype = kCATransitionFromTop;
     [self.navigationController.view.layer addAnimation:transition forKey:kCATransition];
     [self.navigationController pushViewController:vc animated:NO];
}
 
- (void)pop
{
CATransition* transition = [CATransition animation];
     transition.duration = 0.4f;
     transition.type = kCATransitionReveal;
     transition.subtype = kCATransitionFromBottom;
     [self.navigationController.view.layer addAnimation:transition forKey:kCATransition];
     [self.navigationController popViewControllerAnimated:NO];
}

97、上传图片太大,压缩图片

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
-(UIImage *)resizeImage:(UIImage *)image
{
     float actualHeight = image.size.height;
     float actualWidth = image.size.width;
     float maxHeight = 300.0;
     float maxWidth = 400.0;
     float imgRatio = actualWidth/actualHeight;
     float maxRatio = maxWidth/maxHeight;
     float compressionQuality = 0.5; //50 percent compression
 
     if  (actualHeight > maxHeight || actualWidth > maxWidth)
     {
         if (imgRatio < maxRatio)
         {
             //adjust width according to maxHeight
             imgRatio = maxHeight / actualHeight;
             actualWidth = imgRatio * actualWidth;
             actualHeight = maxHeight;
         }
         else  if (imgRatio > maxRatio)
         {
             //adjust height according to maxWidth
             imgRatio = maxWidth / actualWidth;
             actualHeight = imgRatio * actualHeight;
             actualWidth = maxWidth;
         }
         else
         {
             actualHeight = maxHeight;
             actualWidth = maxWidth;
         }
     }
 
     CGRect rect = CGRectMake(0.0, 0.0, actualWidth, actualHeight);
     UIGraphicsBeginImageContext(rect.size);
     [image drawInRect:rect];
     UIImage *img = UIGraphicsGetImageFromCurrentImageContext();
     NSData *imageData = UIImageJPEGRepresentation(img, compressionQuality);
     UIGraphicsEndImageContext();
 
     return  [UIImage imageWithData:imageData];
 
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值