过滤表情

- (void)textDidChange:(NSNotification *)note{
	
	ComponentAttrTableViewCell *cell = (ComponentAttrTableViewCell*)[self.compAttrTableView cellForRowAtIndexPath:editIndexPath];
	//禁止输入表情
	EditTextField *textField = cell.attrValueTextField;
	if([self isContainsEmoji:[textField text]]){
		[textField setText:[self disable_emoji:[textField text]]];
		
	}
}
/* 过滤表情 */
- (NSString *)disable_emoji:(NSString *)text
{
	NSRegularExpression *regex = [NSRegularExpression regularExpressionWithPattern:@"[^\\u0020-\\u007E\\u00A0-\\u00BE\\u2E80-\\uA4CF\\uF900-\\uFAFF\\uFE30-\\uFE4F\\uFF00-\\uFFEF\\u0080-\\u009F\\u2000-\\u201f\r\n]" options:NSRegularExpressionCaseInsensitive error:nil];
	NSString *modifiedString = [regex stringByReplacingMatchesInString:text
															   options:0
																 range:NSMakeRange(0, [text length])
														  withTemplate:@""];
	return modifiedString;
}
/* 判断是否含有表情 */
- (BOOL)isContainsEmoji:(NSString *)string {
	__block BOOL isEomji = 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) {
					 isEomji = YES;
				 }
			 }
		 } else if (substring.length > 1) {
			 const unichar ls = [substring characterAtIndex:1];
			 if (ls == 0x20e3) {
				 isEomji = YES;
			 }
		 } else {
			 if (0x2100 <= hs && hs <= 0x27ff && hs != 0x263b) {
				 isEomji = YES;
			 } else if (0x2B05 <= hs && hs <= 0x2b07) {
				 isEomji = YES;
			 } else if (0x2934 <= hs && hs <= 0x2935) {
				 isEomji = YES;
			 } else if (0x3297 <= hs && hs <= 0x3299) {
				 isEomji = YES;
			 } else if (hs == 0xa9 || hs == 0xae || hs == 0x303d || hs == 0x3030 || hs == 0x2b55 || hs == 0x2b1c || hs == 0x2b1b || hs == 0x2b50|| hs == 0x231a ) {
				 isEomji = YES;
			 }
		 }
	 }];
	return isEomji;
}

过滤掉 Android 输入框中的表情,你可以在输入框的文本变化监听器中添加逻辑来检测和过滤表情符号。 首先,你需要定义一个正则表达式来匹配表情符号。以下是一个简单的表情符号正则表达式: ``` "[\\uD83C-\\uDBFF\\uDC00-\\uDFFF]+" ``` 这个正则表达式匹配 Unicode 中的所有表情符号。 然后,在文本变化监听器中,你可以使用该正则表达式来检测输入框中是否包含表情符号,并在需要的时候将其移除。以下是一个示例代码: ```java editText.addTextChangedListener(new TextWatcher() { @Override public void beforeTextChanged(CharSequence s, int start, int count, int after) { // do nothing } @Override public void onTextChanged(CharSequence s, int start, int before, int count) { // check if the new text contains emoji if (s.toString().matches("[\\uD83C-\\uDBFF\\uDC00-\\uDFFF]+")) { // remove the emoji from the new text editText.setText(s.toString().replaceAll("[\\uD83C-\\uDBFF\\uDC00-\\uDFFF]+", "")); editText.setSelection(editText.getText().length()); } } @Override public void afterTextChanged(Editable s) { // do nothing } }); ``` 在这个示例中,如果新的文本包含表情符号,就将其移除并更新输入框中的文本。同时,将输入框的光标位置设置为文本末尾,以保持用户的输入体验。 你可以根据自己的需求修改这个逻辑,例如可以在输入框失去焦点时检测并过滤表情符号,或者在提交表单数据之前检查并移除表情符号。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值