123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206 |
- #import "XLTextCalculateHelper.h"
- @implementation XLTextCalculateHelper
- + (BOOL)textField:(UITextField *)textField shouldChangeCharactersInRange:(NSRange)range replacementString:(NSString *)string textLimit:(NSUInteger)textLimit
- {
- UITextRange *selectedRange = [textField markedTextRange];
-
- UITextPosition *pos = [textField positionFromPosition:selectedRange.start offset:0];
-
-
-
-
- if (selectedRange && pos) {
- NSInteger startOffset = [textField offsetFromPosition:textField.beginningOfDocument toPosition:selectedRange.start];
- NSInteger endOffset = [textField offsetFromPosition:textField.beginningOfDocument toPosition:selectedRange.end];
- NSRange offsetRange = NSMakeRange(startOffset, endOffset - startOffset);
-
- if (offsetRange.location < textLimit) {
- return YES;
- }
- else
- {
- return NO;
- }
- }
-
-
- NSString *comcatstr = [textField.text stringByReplacingCharactersInRange:range withString:string];
-
- NSInteger caninputlen = textLimit - comcatstr.length;
-
- if (caninputlen >= 0)
- {
- return YES;
- }
- else
- {
- NSInteger len = string.length + caninputlen;
-
- NSRange rg = {0,MAX(len,0)};
-
- if (rg.length > 0)
- {
- NSString *s = @"";
-
- BOOL asc = [string canBeConvertedToEncoding:NSASCIIStringEncoding];
- if (asc) {
- s = [string substringWithRange:rg];
- }
- else
- {
- __block NSInteger idx = 0;
- __block NSString *trimString = @"";
-
- [string enumerateSubstringsInRange:NSMakeRange(0, [string length])
- options:NSStringEnumerationByComposedCharacterSequences
- usingBlock: ^(NSString* substring, NSRange substringRange, NSRange enclosingRange, BOOL* stop) {
-
- if (idx >= rg.length) {
- *stop = YES;
- return ;
- }
- trimString = [trimString stringByAppendingString:substring];
- idx++;
- }];
- s = trimString;
- }
-
- [textField setText:[textField.text stringByReplacingCharactersInRange:range withString:s]];
- }
- return NO;
- }
- }
- + (BOOL)textView:(UITextView *)textView shouldChangeTextInRange:(NSRange)range replacementText:(NSString *)text textLimit:(NSUInteger)textLimit
- {
- UITextRange *selectedRange = [textView markedTextRange];
-
- UITextPosition *pos = [textView positionFromPosition:selectedRange.start offset:0];
-
-
-
-
- if (selectedRange && pos) {
- NSInteger startOffset = [textView offsetFromPosition:textView.beginningOfDocument toPosition:selectedRange.start];
- NSInteger endOffset = [textView offsetFromPosition:textView.beginningOfDocument toPosition:selectedRange.end];
- NSRange offsetRange = NSMakeRange(startOffset, endOffset - startOffset);
-
- if (offsetRange.location < textLimit) {
- return YES;
- }
- else
- {
- return NO;
- }
- }
-
-
- NSString *comcatstr = [textView.text stringByReplacingCharactersInRange:range withString:text];
-
- NSInteger caninputlen = textLimit - comcatstr.length;
-
- if (caninputlen >= 0)
- {
- return YES;
- }
- else
- {
- NSInteger len = text.length + caninputlen;
-
- NSRange rg = {0,MAX(len,0)};
-
- if (rg.length > 0)
- {
- NSString *s = @"";
-
- BOOL asc = [text canBeConvertedToEncoding:NSASCIIStringEncoding];
- if (asc) {
- s = [text substringWithRange:rg];
- }
- else
- {
- __block NSInteger idx = 0;
- __block NSString *trimString = @"";
-
- [text enumerateSubstringsInRange:NSMakeRange(0, [text length])
- options:NSStringEnumerationByComposedCharacterSequences
- usingBlock: ^(NSString* substring, NSRange substringRange, NSRange enclosingRange, BOOL* stop) {
-
- if (idx >= rg.length) {
- *stop = YES;
- return ;
- }
- trimString = [trimString stringByAppendingString:substring];
- idx++;
- }];
- s = trimString;
- }
-
- [textView setText:[textView.text stringByReplacingCharactersInRange:range withString:s]];
- }
- return NO;
- }
- }
- + (BOOL)textFieldDidChangeWillContinue:(UITextField *)textField textLimit:(NSUInteger)textLimit
- {
- UITextRange *selectedRange = [textField markedTextRange];
-
- UITextPosition *pos = [textField positionFromPosition:selectedRange.start offset:0];
-
-
- if (selectedRange && pos) {
- return NO;
- }
-
- NSString *nsTextContent = textField.text;
- NSInteger existTextNum = nsTextContent.length;
-
- if (existTextNum > textLimit)
- {
-
- NSString *s = [nsTextContent substringToIndex:textLimit];
- [textField setText:s];
- }
- return YES;
- }
- + (BOOL)textViewDidChangeWillContinue:(UITextView *)textView textLimit:(NSUInteger)textLimit
- {
- UITextRange *selectedRange = [textView markedTextRange];
-
- UITextPosition *pos = [textView positionFromPosition:selectedRange.start offset:0];
-
-
- if (selectedRange && pos) {
- return NO;
- }
-
- NSString *nsTextContent = textView.text;
- NSInteger existTextNum = nsTextContent.length;
-
- if (existTextNum > textLimit)
- {
-
- NSString *s = [nsTextContent substringToIndex:textLimit];
- [textView setText:s];
- }
- return YES;
- }
- @end
|