近期需求提出需要对手机表情进行处理,对于手机表情处理,有三种方案可供选择:
1. 禁止用户使用表情键盘:
- (BOOL)textField:(UITextField*)textField shouldChangeCharactersInRange:(NSRange)range replacementString:(NSString *)string {
if (textField.tag ==300) {
if ([[textFieldtextInputMode] primaryLanguage]==nil||[[[textFieldtextInputMode] primaryLanguage]isEqualToString:@"emoji"]) {
return NO;
}
}
return YES;
}
2. 后台升级数据库,使其支持emoji表情符:此解决需后台处理,也可自行百度进行了解
3. 后台不做操作,前端对表情进行编码:
思路: 此种方法可解决表情上传服务器失败问题,但存入数据库中的表情无法查看,因表情都已被编码;在输入内容提交的时候, 对输入内容进行遍历,因emoji表情长度为2,文字和标点长度为1,所以遍历的时候需要注意,如果是表情进行编码, 不是的话直接进行进行拼接,在解码时,根据编码规则进行解码。。。
+ (NSString *)encodeEmoji:(NSString *)encodeStr {
NSMutableString *s = [NSMutableString stringWithCapacity:0];
NSAttributedString *att = [[NSAttributedString alloc] initWithString:encodeStr];
NSRange range;
for(int i=0; i<att.length; i+=range.length){
range = [att.string rangeOfComposedCharacterSequenceAtIndex:i];
NSAttributedString *attS =[att attributedSubstringFromRange:range];
if ([CommonTool judgeEmoji:attS.string]) {
for (int i = 0; i < attS.string.length; i++) {
[s appendFormat:@"\\"];
[s appendFormat:@"u%x",[attS.string characterAtIndex:i]];
}
}else{
[s appendFormat:@"%@",attS.string];
}
}
return s;
}
// 解码
+ (NSString *)decodeEmoji:(NSString *)tepStr1{
NSString *decodeStr = tepStr1;
if ([decodeStr containsString:@"\\\\u"]) {
decodeStr=[decodeStr stringByReplacingOccurrencesOfString:@"\\\\u"withString:@"\\U"];
}else if([decodeStr containsString:@"\\u"]){
decodeStr = [decodeStr stringByReplacingOccurrencesOfString:@"\\u"withString:@"\\U"];
NSString *tepStr2 = [decodeStr stringByReplacingOccurrencesOfString:@"\""withString:@"\\\""];
NSString *tepStr3 = [[@"\"" stringByAppendingString:tepStr2]stringByAppendingString:@"\""];
NSData *tepData = [tepStr3 dataUsingEncoding:NSUTF8StringEncoding];
NSString *axiba = [NSPropertyListSerialization propertyListWithData:tepData options:NSPropertyListMutableContainers format:NULL error:NULL];
return [axiba stringByReplacingOccurrencesOfString:@"\\r\\n"withString:@"\n"];
}
return tepStr1;
}
// 编码时判断是否是表情
+ (BOOL)judgeEmoji:(NSString *)text
{
__block BOOL returnValue = NO;
[text enumerateSubstringsInRange:NSMakeRange(0, [text length])
options:NSStringEnumerationByComposedCharacterSequences
usingBlock:^(NSString *substring, NSRange substringRange, NSRange enclosingRange, BOOL *stop) {
const unichar high = [substring characterAtIndex: 0]; // Surrogate pair (U+1D000-1F9FF)
if (0xD800 <= high && high <= 0xDBFF) {
const unichar low = [substring characterAtIndex: 1];
const int codepoint = ((high - 0xD800) * 0x400) + (low - 0xDC00) + 0x10000;
if (0x1D000 <= codepoint && codepoint <= 0x1F9FF){
returnValue = YES;
} // Not surrogate pair (U+2100-27BF)
} else {
if (0x2100 <= high && high <= 0x27BF){
returnValue = YES;
}
}
}];
return returnValue;
}