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;

}




發佈了34 篇原創文章 · 獲贊 1 · 訪問量 8萬+
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章