先给大家说下问题描述
服务器端不支持Emoji表情,因此客户端在上传用户输入时,不能包含Emoji表情。
解决方案
在客户端发送请求前,判断用户输入中是否含有表情,如果含有表情,则提示用户重新输入。这个过程关键是如何判断字符串中是否含有Emoji表情。要判断是否含有Emoji表情,必须先了解什么是Emoji。
Emoji 是一套起源于日本的12x12像素表情符号,由栗田穣崇(Shigetaka Kurit)创作,最早在日本网络及手机用户中流行,自苹果公司发布的iOS 5输入法中加入了emoji后,这种表情符号开始席卷全球,目前emoji已被大多数现代计算机系统所兼容的Unicode编码采纳,普遍应用于各种手机短信和社交网络中。
以上是摘自百度百科里的一段话,Emoji表情最终会被编码成Unicode,因此,只要知道Emoji表情的Unicode编码的范围,就可以判断用户是否输入了Emoji表情。以下是具体代码,我这里写成了NSString的一个分类
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
|
@implementation NSString (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;
}
}
}];
return returnValue;
}
|
本段代码亲测管用,欢迎大家参考。
以上所述是小编给大家介绍的iOS中判断Emoji表情问题,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对服务器之家网站的支持!