先給年夜家說下成績描寫
辦事器端不支撐Emoji臉色,是以客戶端在上傳用戶輸出時,不克不及包括Emoji臉色。
處理計劃
在客戶端發送要求前,斷定用戶輸出中能否含有臉色,假如含有臉色,則提醒用戶從新輸出。這個進程症結是若何斷定字符串中能否含有Emoji臉色。要斷定能否含有Emoji臉色,必需先懂得甚麼是Emoji。
Emoji 是一套來源於日本的12x12像素臉色符號,由栗田穣崇(Shigetaka Kurit)創作,最早在日本收集及手機用戶中風行,自蘋果公司宣布的IOS 5輸出法中參加了emoji後,這類臉色符號開端囊括全球,今朝emoji已被年夜多半古代盤算機體系所兼容的Unicode編碼采用,廣泛運用於各類手機短信和社交收集中。
以上是摘自百度百科裡的一段話,Emoji臉色終究會被編碼成Unicode,是以,只需曉得Emoji臉色的Unicode編碼的規模,便可以斷定用戶能否輸出了Emoji臉色。以下是詳細代碼,我這裡寫成了NSString的一個分類
@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臉色成績,願望對年夜家有所贊助,假如年夜家有任何疑問請給我留言,小編會實時答復年夜家的。在此也異常感激年夜家對本站網站的支撐!
【iOS中斷定Emoji臉色成績】的相關資料介紹到這裡,希望對您有所幫助! 提示:不會對讀者因本文所帶來的任何損失負責。如果您支持就請把本站添加至收藏夾哦!