接近完美禁用iOS的emoji表情键盘

支持iOS搜狗输入法和自动关联表情(如输入hehe,出来的表情)

注意:Swift的textView.text != disable_emoji(textView.text)

在OC里面用 ![xxx isEqualString:bbb]

转帖保留(谢谢):http://www.cnblogs.com/Leetvin/p/4384141.html 

@IBOutlet weak var tf: UITextField!

    override func viewDidLoad() {

        super.viewDidLoad()

        // Do any additional setup after loading the view, typically from a nib.

        

        tf.addTarget(self, action: "textFieldDidChange:", forControlEvents: UIControlEvents.EditingChanged)

    }

 

    override func didReceiveMemoryWarning() {

        super.didReceiveMemoryWarning()

        // Dispose of any resources that can be recreated.

    }

 

    func textViewDidChange(textView: UITextView) {

        var textTange = textView.selectedTextRange

        if(textView.text != disable_emoji(textView.text))

        {

            textView.text = disable_emoji(textView.text)

        }

        textView.selectedTextRange = textTange

    }

    

    func textFieldDidChange(textField: UITextField) {

        

        var textTange = textField.selectedTextRange

        if(textField.text != disable_emoji(textField.text))

        {

            textField.text = disable_emoji(textField.text)

        }

        textField.selectedTextRange = textTange

    }

    

    func disable_emoji(text:String)->String

    {

        var regex = NSRegularExpression(pattern: "[^\\u0020-\\u007E\\u00A0-\\u00BE\\u2E80-\\uA4CF\\uF900-\\uFAFF\\uFE30-\\uFE4F\\uFF00-\\uFFEF\\u0080-\\u009F\\u2000-\\u201f\r\n]", options: NSRegularExpressionOptions.CaseInsensitive, error: nil)

        var modifiedString = regex!.stringByReplacingMatchesInString(text, options: NSMatchingOptions(), range: NSMakeRange(0, text.utf16Count), withTemplate: "")

        return modifiedString

    }

转载于:https://www.cnblogs.com/Leetvin/p/4384141.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值