iOS iOS中UITextField和UITextView屏蔽表情符号的输入

起因:云端服务器代码不支持表情符号的输入,所以APP端需要屏蔽掉所有的UITextField和UITextView屏蔽表情符号输入

要判断是否含有Emoji表情,必须先了解什么是Emoji。

Emoji 是一套起源于日本的12x12像素表情符号,由栗田穣崇(Shigetaka Kurit)创作,最早在日本网络及手机用户中流行,自苹果公司发布的iOS 5输入法中加入了emoji后,这种表情符号开始席卷全球,目前emoji已被大多数现代计算机系统所兼容的Unicode编码采纳,普遍应用于各种手机短信和社交网络中。

以上是摘自百度百科里的一段话,Emoji表情最终会被编码成Unicode,因此,只要知道Emoji表情的Unicode编码的范围,就可以判断用户是否输入了Emoji表情。

解决方法:想到两种解决方案,一种是在输入之后过滤掉,网上找了一些过滤的算法,好像都不太好用;另一种屏蔽ios输入表情符输入。(以下解决方法非原创,贴上来是整理记录一下,也给遇到同样问题的人提供一点帮助吧^_^)

(1)以textview为例 加入以下代理方法,就禁止了表情符的输入,[UITextInputMode currentInputMode]这个方法已经在ios7后被启用了,现在在xcode中只是有警告但是可以用,代替它的方法+ (NSArray<NSString *> *)activeInputModes;没有找到怎么用,又会用的留个言哈,非常感谢!

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

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

        return NO;

    }

    return YES;

}


2)为了防止用户输入哈哈,有笑脸提示,从而输入了表情符,在textViewDidEndEditing加入判断是否有表情符输入的方法,如果有弹出alert 提示让用户重新输入。以下是具体代码,我这里写成了NSString的一个分类

采用了http://blog.csdn.net/liujinlongxa/article/details/44207003中的算法,好用有效,防止代码找不到,再贴一遍吧。

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

                                    }

                                }

                            }];

    

    return returnValue;

}



评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值