iOS 替換鍵盤聯(lián)想提示的emoji表情

最近在做項目遇到一個問題,用戶在輸入信息是時候脚祟,帶有表情的話绍在,服務器那邊會出現(xiàn)亂碼感帅,后來決定禁止用戶輸入表情,在網(wǎng)上搜了下面的方法:

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

}

但是后來發(fā)現(xiàn)這個方法沒法監(jiān)聽到鍵盤聯(lián)想提示的emoji表情地淀,很可惱失球,最后只能監(jiān)聽textView文本變化,然后判斷里面是否有emoji表情帮毁,再把它替換了 下面是實現(xiàn)代碼:

+ (NSString *)disableEmoji:(NSString *)text

{

NSRegularExpression *regular = [[NSRegularExpression alloc] initWithPattern:@"[^\\u0020-\\u007E\\u00A0-\\u00BE\\u2E80-\\uA4CF\\uF900-\\uFAFF\\uFE30-\\uFE4F\\uFF00-\\uFFEF\\u0080-\\u009F\\u2000-\\u201f\r\n]" options:NSRegularExpressionCaseInsensitive error:nil];

NSString *modifiedString = [regular stringByReplacingMatchesInString:text options:NSMatchingReportProgress range:NSMakeRange(0, [text length]) withTemplate:@""];

return modifiedString;

}

調(diào)用:

#pragma mark - UITextViewDelegate

- (void)textViewDidChange:(UITextView *)textView {

UITextRange *textTange = textView.selectedTextRange;

if (![textView.text isEqualToString:[NSString disableEmoji:textView.text]]) {

textView.text = [NSString disableEmoji:textView.text];

}

textView.selectedTextRange = textTange;

}

這樣就能比較完美的替換鍵盤輸入的emoji表情了实苞,另外我很想知道簡書是怎么樣排版代碼的!烈疚?

文章參考:http://www.cnblogs.com/Leetvin/p/4384141.html

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末黔牵,一起剝皮案震驚了整個濱河市,隨后出現(xiàn)的幾起案子爷肝,更是在濱河造成了極大的恐慌猾浦,老刑警劉巖陆错,帶你破解...
    沈念sama閱讀 211,042評論 6 490
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異金赦,居然都是意外死亡音瓷,警方通過查閱死者的電腦和手機,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 89,996評論 2 384
  • 文/潘曉璐 我一進店門夹抗,熙熙樓的掌柜王于貴愁眉苦臉地迎上來绳慎,“玉大人,你說我怎么就攤上這事漠烧⌒臃撸” “怎么了?”我有些...
    開封第一講書人閱讀 156,674評論 0 345
  • 文/不壞的土叔 我叫張陵已脓,是天一觀的道長珊楼。 經(jīng)常有香客問我,道長摆舟,這世上最難降的妖魔是什么亥曹? 我笑而不...
    開封第一講書人閱讀 56,340評論 1 283
  • 正文 為了忘掉前任,我火速辦了婚禮媳瞪,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘照宝。我一直安慰自己蛇受,他們只是感情好厕鹃,可當我...
    茶點故事閱讀 65,404評論 5 384
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著剂碴,像睡著了一般把将。 火紅的嫁衣襯著肌膚如雪忆矛。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 49,749評論 1 289
  • 那天催训,我揣著相機與錄音洽议,去河邊找鬼漫拭。 笑死,一個胖子當著我的面吹牛采驻,可吹牛的內(nèi)容都是我干的审胚。 我是一名探鬼主播匈勋,決...
    沈念sama閱讀 38,902評論 3 405
  • 文/蒼蘭香墨 我猛地睜開眼颓影,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了懒鉴?” 一聲冷哼從身側(cè)響起诡挂,我...
    開封第一講書人閱讀 37,662評論 0 266
  • 序言:老撾萬榮一對情侶失蹤临谱,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后悉默,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體城豁,經(jīng)...
    沈念sama閱讀 44,110評論 1 303
  • 正文 獨居荒郊野嶺守林人離奇死亡抄课,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 36,451評論 2 325
  • 正文 我和宋清朗相戀三年唱星,在試婚紗的時候發(fā)現(xiàn)自己被綠了。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片跟磨。...
    茶點故事閱讀 38,577評論 1 340
  • 序言:一個原本活蹦亂跳的男人離奇死亡间聊,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出抵拘,到底是詐尸還是另有隱情哎榴,我是刑警寧澤,帶...
    沈念sama閱讀 34,258評論 4 328
  • 正文 年R本政府宣布僵蛛,位于F島的核電站尚蝌,受9級特大地震影響,放射性物質(zhì)發(fā)生泄漏充尉。R本人自食惡果不足惜飘言,卻給世界環(huán)境...
    茶點故事閱讀 39,848評論 3 312
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望驼侠。 院中可真熱鬧热凹,春花似錦、人聲如沸泪电。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,726評論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽相速。三九已至,卻和暖如春鲜锚,著一層夾襖步出監(jiān)牢的瞬間突诬,已是汗流浹背苫拍。 一陣腳步聲響...
    開封第一講書人閱讀 31,952評論 1 264
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留旺隙,地道東北人绒极。 一個月前我還...
    沈念sama閱讀 46,271評論 2 360
  • 正文 我出身青樓,卻偏偏與公主長得像蔬捷,于是被迫代替她去往敵國和親垄提。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當晚...
    茶點故事閱讀 43,452評論 2 348

推薦閱讀更多精彩內(nèi)容

  • Android 自定義View的各種姿勢1 Activity的顯示之ViewRootImpl詳解 Activity...
    passiontim閱讀 171,737評論 25 707
  • 對于限制UITextView輸入的字符數(shù)周拐。相信大家在網(wǎng)上見得最多的是實現(xiàn)UITextViewDelegate [o...
    Treey_Ahao閱讀 1,876評論 2 2
  • 九月花開 可待一切安好铡俐。 九月一日。 陽光絢爛妥粟,樹影斑駁审丘。迎面走出宿舍,剛剛拓寬的道路上又擠滿了人勾给,偶有的宣傳欄亦...
    雨魚水閱讀 367評論 0 1
  • 天地蒼茫滩报,宇宙洪荒。大河上下播急,淘濤頓失脓钾。 人生天地間,腳踩四方路旅择,頭頂九天日惭笑,心思九州景,腦想宇宙致生真。古來人多言少...
    隱刺青閱讀 217評論 0 2
  • 文|初之 1 “她將是我一生的伴兒” 你會說這只不過是普通的朋友圈曬證嘛柱蟀,誰沒見過川蒙,有什么大驚小怪的。曬證是很常見...
    初之閱讀 294評論 0 2