日常更新知识点


1、添加系统提示音和震动
2、在xib 中使用 UIScrollView,但是问题是.m文件中设置contentsize 无效
3、将数组中的内容分拼接成字符串
4、判断字典是否包含特定Key值
5、过滤emoji表情键盘输入,包含输入哈哈引出的微笑表情
6、dismissViewController到根视图
7、pop返回到指定控制器
8、数据处理 (比较两个数组,并除去相同元素)

1、添加系统提示音和震动

  • 工程下添加AudioToolbox.framework
  • 添加头文件#import <AudioToolbox/AudioToolbox.h>
  • appDelegate的代理方法didReceiveRemoteNotification中添加
    AudioServicesPlaySystemSound(1007);//系统提示音 AudioServicesPlaySystemSound(kSystemSoundID_Vibrate);//震动

2、在xib 中使用 UIScrollView,但是问题是.m文件中设置contentsize 无效

  • 问题分析
    xib 中勾选了autolayout选项,在autolayout下,iOS计算UIScrollView的contentsize的机制是略有不同。在autolayout中,会在viewDidAppear之前根据subview的constraint重新计算UIScrollView的contentsize。 当在viewdidload里手动设置contentsize时,会再重新计算一次,把前面手动设置的值覆盖掉。
  • 解决方法
    1 去除autolayout选项,自己手动设置contentsize
    2 如果要使用autolayout,则需要设置subview的constraint,让系统自动根据constraint计算出contentsize
    3 在viewDidAppear里面自己手动设置contentsize

3、将数组中的内容分拼接成字符串

NSString *string = [array componentsJoinedByString:@","];//用,分割

打印array:(
    1,
    2,
)
打印string:1,2

4、判断字典是否包含特定Key值

if([[dict allKeys] containsObject:@"key"]){
   //有
}else{
   //没有
}

5、过滤emoji表情键盘输入,包含输入哈哈引出的微笑表情

当选择表情键盘输入时return NO

- (BOOL)textView:(UITextView *)textView shouldChangeTextInRange:(NSRange)range replacementText:(NSString *)text
{
   // 不让输入表情
   if ([textView isFirstResponder]) {
       //表情键盘
       if ([[[textView textInputMode] primaryLanguage] isEqualToString:@"emoji"] || ![[textView textInputMode] primaryLanguage]) {
           return NO;
       }else{//
           return ![self stringContainsEmoji:text];
       }
       
   }
   
   return YES;
}
// 过滤所有表情  https://gist.github.com/cihancimen/4146056
- (BOOL)stringContainsEmoji:(NSString *)string {
   __block BOOL returnValue = NO;
   [string enumerateSubstringsInRange:NSMakeRange(0, [string length]) options:NSStringEnumerationByComposedCharacterSequences usingBlock:
    ^(NSString *substring, NSRange substringRange, NSRange enclosingRange, BOOL *stop) {
        
        const unichar hs = [substring characterAtIndex:0];
        // surrogate pair
        if (0xd800 <= hs && hs <= 0xdbff) {
            if (substring.length > 1) {
                const unichar ls = [substring characterAtIndex:1];
                const int uc = ((hs - 0xd800) * 0x400) + (ls - 0xdc00) + 0x10000;
                if (0x1d000 <= uc && uc <= 0x1f77f) {
                    returnValue = YES;
                }
            }
        } else if (substring.length > 1) {
            const unichar ls = [substring characterAtIndex:1];
            if (ls == 0x20e3) {
                returnValue = YES;
            }
            
        } else {
            // non surrogate
//             if (0x2100 <= hs && hs <= 0x27ff) {
//                 returnValue = YES;
//             }
            if (0x2B05 <= hs && hs <= 0x2b07) {
                returnValue = YES;
            } else if (0x2934 <= hs && hs <= 0x2935) {
                returnValue = YES;
            } else if (0x3297 <= hs && hs <= 0x3299) {
                returnValue = YES;
            } else if (hs == 0xa9 || hs == 0xae || hs == 0x303d || hs == 0x3030 || hs == 0x2b55 || hs == 0x2b1c || hs == 0x2b1b || hs == 0x2b50) {
                returnValue = YES;
            }
        }
    }];
   
   return returnValue;
}

6、dismissViewController到根视图

如果是在Controller中 则代码如下

 UIViewController *vc =  self;
 while (vc.presentingViewController) {
     vc = vc.presentingViewController;
 }
 [vc dismissViewControllerAnimated:YES completion:nil];  

如果是在视图(View)中 则代码如下

-(void)backClick{  
     UIViewController *vc =  [self viewController];  
     while (vc.presentingViewController) {  
          vc = vc.presentingViewController;  
     }  
     [vc dismissViewControllerAnimated:YES completion:nil];  
 }  

 /** 获取当前view的controller */  
- (UIViewController *)viewController  
{  
    for (UIView *next = [self superview]; next; next = next.superview) {  
         UIResponder *nextResponser = [next nextResponder];  

         if ([nextResponser isKindOfClass:[UIViewController class]]) {  
              return (UIViewController *)nextResponser;  
         }  
    }  
   return nil;  
}  

该代码可返回到根(通过present过来的)Controller

7、pop返回到指定控制器

方法一

 UIViewController *viewCtl = self.navigationController.viewControllers[1];

[self.navigationController popToViewController:viewCtl animated:YES];

方法二

for (UIViewController *controller in self.navigationController.viewControllers) {
          if ([controller isKindOfClass:[SetupViewController class]]) {
                    SetupViewController *revise =(SetupViewController *)controller;
                    [self.navigationController popToViewController:revise animated:YES];
          }
}

8、数据处理 (比较两个数组,并除去相同元素)

    NSArray * arr1 = @[@1,@2,@3];
    NSArray * arr2 = @[@2,@3,@4,@5];
    
    NSPredicate * filterPredicate = [NSPredicate predicateWithFormat:@"NOT (SELF IN %@)",arr1];
    NSArray * filter = [arr2 filteredArrayUsingPredicate:filterPredicate];
    NSLog(@"%@",filter);

打印:

2018-12-20 10:51:59.792762+0800 demo[2898:47742] (
    4,
    5
)
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 204,293评论 6 478
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 85,604评论 2 381
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 150,958评论 0 337
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,729评论 1 277
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,719评论 5 366
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,630评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 38,000评论 3 397
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,665评论 0 258
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,909评论 1 299
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,646评论 2 321
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,726评论 1 330
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,400评论 4 321
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,986评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,959评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,197评论 1 260
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 44,996评论 2 349
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,481评论 2 342

推荐阅读更多精彩内容