PPMT---ios开发技巧<二>

算是自己平时用的多的,在此收集起来,分享给大家,有些知识也是看了别人的分享才知道的,所以共享之!
由于篇幅问题,每一篇分享10个技巧

【1】UITextField输入限制大全

1.1 只能输入数字

- (BOOL)textField:(UITextField *)textField shouldChangeCharactersInRange:(NSRange)range replacementString:(NSString *)string{
    //  判断输入的是否为数字 (只能输入数字)
    NSString *validRegEx =@"^[0-9]*$";
    NSPredicate *regExPredicate =[NSPredicate predicateWithFormat:@"SELF MATCHES %@", validRegEx];
    BOOL myStringMatchesRegEx = [regExPredicate evaluateWithObject:string];
    if (myStringMatchesRegEx){
        return YES;
}else{
        return NO;
}
}

1.2 *** 限制只能输入一个“.”***比如输入价格的时候3.50

#pragma mark --- 限制只能输入一个“.”
+ (void)LC_LimitedPointOnlyOne:(UITextField *)LC_tf
{
    NSString *newStr = LC_tf.text;
    NSString *temp = nil;
    int commonWordCount = 0;
    for(int i =0; i < [newStr length]; i++)
    {
        temp = [newStr substringWithRange:NSMakeRange(i, 1)];
        if ([temp isEqualToString:@"."]) {
            commonWordCount++;
            NSLog(@"第%d个字是:%@----%d", i, temp,commonWordCount);
            if (commonWordCount >= 2) {
                newStr = [newStr substringToIndex:newStr.length-1];
                LC_tf.text = newStr;
            }
        }
    }
}

如果不让输入“.”,只需要修改上面代码if (commonWordCount >= 2)21.

1.3 【限制输入文字数量】比如限制输入8个字(无论中英还是标点符号以及空格都各算一个),虽然超过了8个,但仍然可以输入,等到输入完后只取前8位的。

1.3_第一步 在初始化textfield时设置

 [[NSNotificationCenter defaultCenter]addObserver:self selector:@selector(textFiledEditChanged:)                                                 name:@"UITextFieldTextDidChangeNotification"
                                                  object:self.detailTf];

1.3_第二步 实现 textFiledEditChanged:方法,并设置通知的dealloc.

-(void)textFiledEditChanged:(NSNotification*)obj{
    UITextField *textField = (UITextField *)obj.object;
    if (textField.tag == 6057) { //只有商品规格有此限制
        NSString *toBeString = textField.text;
        // 键盘输入模式
        NSArray *langs = [UITextInputMode activeInputModes];
        UITextInputMode *inputMode = (UITextInputMode *)[langs firstObject];
        NSString *lang = [inputMode primaryLanguage];
        //FIXME: 输出输入的是汉字还是字母
        // NSLog(@"输出输入的是汉字还是字母--%@",lang);
        if([lang isEqualToString:@"zh-Hans"]) { //简体中文输入,包括简体拼音,简体五笔,简体手写
            UITextRange *selectedRange = [textField markedTextRange];
            //获取高亮部分
            UITextPosition *position = [textField positionFromPosition:selectedRange.start offset:0];
            //没有高亮选择的字,则对已输入的文字进行字数统计和限制
            if(!position) {
                if(toBeString.length > Maximum_tagCount) {
                    textField.text = [toBeString substringToIndex:Maximum_tagCount];
                    [[MessShowView share]showWithMess:@"必须限制在15字以内" login:NO];
                }
            }
            //有高亮选择的字符串,则暂不对文字进行统计和限制
            else{
            }
        }
        //中文输入法以外的直接对其统计限制即可,不考虑其他语种情况
        else{
            if(toBeString.length > Maximum_tagCount) {
                textField.text= [toBeString substringToIndex:Maximum_tagCount];
                [[MessShowView share]showWithMess:@"必须限制在15字以内" login:NO];
            }
        }
    } 
}
-(void)dealloc{
 [[NSNotificationCenter defaultCenter]removeObserver:self                                                name:@"UITextFieldTextDidChangeNotification"
                                                 object:self.detailTf];
}
【2】 字典转json,并处理@"\/" ----》 @"/"的情况
NSError *error;
NSData *jsonData = [NSJSONSerialization
                    dataWithJSONObject:dict options:NSJSONWritingPrettyPrinted error:&error];
if ([jsonData length] > 0 && error == nil){
    //NSData转换为String
    NSString *jsonString = [[NSString alloc] initWithData:jsonData encoding:NSUTF8StringEncoding];
    //处理encoding后字符串的变换情况@"\\/" ----》 @"/" ;
    jsonString = [jsonString stringByReplacingOccurrencesOfString:@"\\/" withString:@"/"];
    jsonData = [jsonString dataUsingEncoding:NSUTF8StringEncoding];
    
}
【3】批量上传图片,并且等待获取到返回的参数后再执行下一步操作
- (void) UploadMyCardPhotos:(NSMutableArray *) photoArray {
    
    [SVProgressHUD showErrorWithStatus:@"正在上传"];

    /*!
     * 队列组可以将很多队列添加到一个组里,这样做的好处是,当这个组里所有的任务都执行完了,队列组会通过一个方法通知我们。
     */
    //创建队列组
    dispatch_group_t uploadGroup = dispatch_group_create();
    
    /*
     __block不管是ARC还是MRC模式下都可以使用,可以修饰对象,还可以修饰基本数据类型。
     __weak只能在ARC模式下使用,也只能修饰对象(NSString),不能修饰基本数据类型(int)。
     __block对象可以在block中被重新赋值,__weak不可以。
     */
    __block NSMutableArray *array = [photoArray mutableCopy];
    
    for (int i= 0; i

更多参考:

  1. AFNetworking 3 批量上传图片的 3 种方法
【4】对象属性字段与系统有可能冲突(如id)的处理

1 系统方法

@implementation PPModel
-(void)setValue:(id)value forUndefinedKey:(NSString *)key{
    if ([key isEqualToString:@"id"]) {
        self.squareId = value;
    }
}
@end

2 ** MJExtension**

#import "User.h"
#import "MJExtension.h"
@implementation User
+(NSDictionary *)replacedKeyFromPropertyName{
return @{@"ID":@"id"};
}
@end

MJ字典转模型框架 遇到的问题?

【5】查询用户是否允许app使用麦克风ios7_later
//第一次调用这个方法的时候,系统会提示用户让他同意你的app获取麦克风的数据 
// 其他时候调用方法的时候,则不会提醒用户 
// 而会传递之前的值来要求用户同意 
[[AVAudioSession sharedInstance] requestRecordPermission:^(BOOL granted) { 
    if (granted) { 
        // 用户同意获取数据 
    } else { 
        // 可以显示一个提示框告诉用户这个app没有得到允许? 
    } 
}]; 
【6】在照片中检测微笑以及眨眼ios7_later

iOS给Core Image增加了两种人脸检测功能:CIDetectorEyeBlink以及CIDetectorSmile。这也就是说你现在可以在照片中检测微笑以及眨眼。

以下是在app中使用它的方法:

UIImage *image = [UIImage imageNamed:@"myImage"]; 
CIDetector *detector = [CIDetector detectorOfType:CIDetectorTypeFace 
                                          context:nil 
                                          options:@{CIDetectorAccuracy: CIDetectorAccuracyHigh}]; 
  
NSDictionary *options = @{ CIDetectorSmile: @YES, CIDetectorEyeBlink: @YES }; 
  
NSArray *features = [detector featuresInImage:image.CIImage options:options]; 
  
for (CIFaceFeature *feature in features) { 
    NSLog(@”Bounds: %@”, NSStringFromCGRect(feature.bounds)); 
  
    if (feature.hasSmile) { 
    NSLog(@”Nice smile!”); 
    } else { 
    NSLog(@”Why so serious?”); 
    } 
    if (feature.leftEyeClosed || feature.rightEyeClosed) { 
    NSLog(@”Open your eyes!”); 
    } 
} 
【7】状态栏文字白色

1在Info.plist中设置UIViewControllerBasedStatusBarAppearance 为NO
2 在需要改变状态栏颜色的ViewController中在ViewDidLoad方法中增加:

 [UIApplication sharedApplication].statusBarStyle = UIStatusBarStyleLightContent;

如果需要在全部View中都变色,可以写在父类的相关方法中,或者写到AppDelegate中。

//-(UIStatusBarStyle)preferredStatusBarStyle
//{
//    return UIStatusBarStyleLightContent;
//}
【8】iOS跳转界面时隐藏tabBar的方法
//1.设置self.tabBarController.tabBar.hidden=YES;
self.tabBarController.tabBar.hidden=YES;
 
//2.如果在push跳转时需要隐藏tabBar,设置self.hidesBottomBarWhenPushed=YES;
    self.hidesBottomBarWhenPushed=YES;
    NextViewController *next=[[NextViewController alloc]init];
    [self.navigationController pushViewController:next animated:YES];
    self.hidesBottomBarWhenPushed=NO;
 
//并在push后设置self.hidesBottomBarWhenPushed=NO;
//这样back回来的时候,tabBar会恢复正常显示。

你可能感兴趣的:(PPMT---ios开发技巧<二>)