iOS输入框禁止输入emoji表情

 

调用方法:

在输入框的代理方法中使用

- (void)textViewDidChange:(UITextView *)textView{

    

    NSLog(@"text:%@",textView.text);

    

    if (textView.text.length <= TEXT_MAXLENGTH) {

        label2.text = [NSString stringWithFormat:@"您还可以输入%lu个文字",TEXT_MAXLENGTH-[textView.text length]];

    }

    //该判断用于联想输入

    if (textView.text.length > TEXT_MAXLENGTH){

        textView.text = [textView.text substringToIndex:TEXT_MAXLENGTH];

    }

    

}


- (BOOL)textView:(UITextView *)textView shouldChangeTextInRange:(NSRange)range replacementText:(NSString *)text{

    

    //判断加上输入的字符,是否超过界限

    NSString *string = [NSString stringWithFormat:@"%@%@", textView.text, text];

    if (string.length > TEXT_MAXLENGTH){

        return NO;

    }

    //   限制苹果系统输入法  禁止输入表情

    if ([[[UITextInputMode currentInputMode]primaryLanguage] isEqualToString:@"emoji"]) {

        return NO;

    }

    //禁止输入emoji表情

    if ([LGToolMethods stringContainsEmoji:text]) {

        return NO;

    }

    

    return YES;

}


//判断是否输入了emoji 表情

+ (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];

                                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 {

                                    if (0x2100 <= hs && hs <= 0x27ff) {

                                        returnValue = YES;

                                    } else 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;

                                    }else if (hs == 0x200d){

                                        returnValue = YES;

                                    }

                                }

                            }];

    

    return returnValue;

}




  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值