简体   繁体   English

在UITextView中检测自动换行

[英]Word wrap detecting in UITextView

I am implementing a customized rich text editor by extending the UITextView. 我通过扩展UITextView来实现自定义的富文本编辑器。 When user selects the text range and apples the 'highlighting' menu, the editor will draw a blue background for the selected text: 当用户选择文本范围并使用“突出显示”菜单时,编辑器将为所选文本绘制蓝色背景:

- (CGRect)getRectAtRangePos:(NSInteger)pos {
    UITextPosition *beginning = self.beginningOfDocument;
    UITextPosition *start = [self positionFromPosition:beginning offset:pos];
    CGRect rect = [self caretRectForPosition:start];
    return [self convertRect:rect fromView:self.textInputView];
}


- (void)drawRange:(NSRange)range {
    CGContextRef context = UIGraphicsGetCurrentContext();
    CGContextSetRGBFillColor(context, 0x16/255.f, 0x38/255.f, 0xfc/255.f, 0.5);
    CGRect startRect = [self getRectAtRangePos:range.location];
    CGRect endRect = [self getRectAtRangePos:range.location + range.length];

    CGFloat padding = 1;
    CGFloat margin = 1;

    if (ABS(endRect.origin.y - startRect.origin.y) < 5) {//They are in the same line
        CGRect wholeRect = CGRectMake(startRect.origin.x, startRect.origin.y + padding, endRect.origin.x - startRect.origin.x, startRect.size.height - 2 * padding);
        CGContextFillRect(context, wholeRect);
    }
    else {//The range occupies at least two lines
        CGRect firstRect = CGRectMake(startRect.origin.x, startRect.origin.y + padding, self.bounds.size.width - startRect.origin.x - margin, startRect.size.height - 2 * padding);
        CGContextFillRect(context, firstRect);
        CGFloat heightDiff = endRect.origin.y - (startRect.origin.y + startRect.size.height);
        if (heightDiff > 5) {//The range occupies more than two lines
            CGRect secondRect = CGRectMake(margin, startRect.origin.y + startRect.size.height + padding, self.bounds.size.width - 2*margin, heightDiff - 2* padding);
            CGContextFillRect(context, secondRect);
        }
        CGRect thirdRect = CGRectMake(margin, endRect.origin.y + padding, endRect.origin.x, endRect.size.height - 2* padding);
        CGContextFillRect(context, thirdRect);
    }
}

When the selected text contains a long word which caused the word wrap, the blue background looks ugly. 当所选文本包含导致自动换行的长词时,蓝色背景看起来很难看。

在此输入图像描述

Is there a way to detect the position where the word wrap? 有没有办法检测自动换行的位置? Thanks! 谢谢!

OK, finally I solved this problem. 好的,最后我解决了这个问题。 To detecting the word wrap or a new line break, it's simple to use following code: 要检测自动换行或换行符,使用以下代码很简单:

#pragma UITextViewDelegate
- (void)textViewDidChange:(UITextView *)textView {
    if ( ABS(lastContentSize_.height - textView.contentSize.height) > 1) {
        NSLog(@"word wrap or line break!");
    }

}

That's all:) 就这样:)

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM