zoukankan      html  css  js  c++  java
  • 【iOS开发每日小笔记(七)】UITextView UITextField 检测并过滤Emoji表情符号

    这篇文章是我的【iOS开发每日小笔记】系列中的一片,记录的是今天在开发工作中遇到的,可以用很短的文章或很小的demo演示解释出来的小心得小技巧。它们可能会给用户体验、代码效率得到一些提升,或是之前自己没有接触过的技术,很开心的学到了,放在这里得瑟一下。90%的作用是帮助自己回顾、记忆、复习。

    最近的项目里遇到一个需求,为了防止学生在主观题答题过程中,输入表情符号,需要对学生输入的内容做检测和过滤,将苹果键盘的Emoji表情符号过滤掉。

    通过研究和测试,得到以下比较完美的解决方案,思路两条:

    1,当用户切换键盘为Emoji表情时,输入的表情不响应(即表情符号不显示到UITextView或UITextField)。这里可以通过UITextView或UITextField的回调和是否为emoji键盘:

    1 [[[textView textInputMode] primaryLanguage] isEqualToString:@"emoji"]

    来判断;

    2,当用户通过中文键盘输入中文“哈哈”后出现可选文字中选中的Emoji笑脸,最后统一通过检查最终字符串textField.text的内容,通过Emoji筛unicode编码来判断是否存在Emoji表情,如果存在则提醒用户做修改。

    主要的代码如下:

     1 - (BOOL)textView:(UITextView *)textView shouldChangeTextInRange:(NSRange)range replacementText:(NSString *)text
     2 {
     3     // 不让输入表情
     4     if ([textView isFirstResponder]) {
     5         if ([[[textView textInputMode] primaryLanguage] isEqualToString:@"emoji"] || ![[textView textInputMode] primaryLanguage]) {
     6             return NO;
     7         }
     8     }
     9     
    10     return YES;
    11 }
    12 
    13 // 过滤所有表情  https://gist.github.com/cihancimen/4146056
    14 - (BOOL)stringContainsEmoji:(NSString *)string {
    15     __block BOOL returnValue = NO;
    16     [string enumerateSubstringsInRange:NSMakeRange(0, [string length]) options:NSStringEnumerationByComposedCharacterSequences usingBlock:
    17      ^(NSString *substring, NSRange substringRange, NSRange enclosingRange, BOOL *stop) {
    18          
    19          const unichar hs = [substring characterAtIndex:0];
    20          // surrogate pair
    21          if (0xd800 <= hs && hs <= 0xdbff) {
    22              if (substring.length > 1) {
    23                  const unichar ls = [substring characterAtIndex:1];
    24                  const int uc = ((hs - 0xd800) * 0x400) + (ls - 0xdc00) + 0x10000;
    25                  if (0x1d000 <= uc && uc <= 0x1f77f) {
    26                      returnValue = YES;
    27                  }
    28              }
    29          } else if (substring.length > 1) {
    30              const unichar ls = [substring characterAtIndex:1];
    31              if (ls == 0x20e3) {
    32                  returnValue = YES;
    33              }
    34              
    35          } else {
    36              // non surrogate
    37              if (0x2100 <= hs && hs <= 0x27ff) {
    38                  returnValue = YES;
    39              } else if (0x2B05 <= hs && hs <= 0x2b07) {
    40                  returnValue = YES;
    41              } else if (0x2934 <= hs && hs <= 0x2935) {
    42                  returnValue = YES;
    43              } else if (0x3297 <= hs && hs <= 0x3299) {
    44                  returnValue = YES;
    45              } else if (hs == 0xa9 || hs == 0xae || hs == 0x303d || hs == 0x3030 || hs == 0x2b55 || hs == 0x2b1c || hs == 0x2b1b || hs == 0x2b50) {
    46                  returnValue = YES;
    47              }
    48          }
    49      }];
    50     
    51     return returnValue;
    52 }

    解决方案参考了:

    https://gist.github.com/cihancimen/4146056

    为此我做了一个demo放在gitHub上,有兴趣的可以下载试试效果:https://github.com/pigpigdaddy/ForbidEmojiDemo

  • 相关阅读:
    poi隐藏列
    凯西太太的果园
    java中不可变对象深入理解
    excel添加空白行的快捷键
    如何在多个页面中,引入一个公共组件
    对后端返回的数据进行适配
    我与时间管理的故事
    在前端团队的那些日子(初见)
    我是这样做时间管理的(下)
    我是这样做时间管理的(上)
  • 原文地址:https://www.cnblogs.com/pigpigDD/p/3952496.html
Copyright © 2011-2022 走看看