Ios NSLayoutManager BoundingRectfolyPhrange关闭某些点

Ios NSLayoutManager BoundingRectfolyPhrange关闭某些点,ios,objective-c,swift,core-text,textkit,Ios,Objective C,Swift,Core Text,Textkit,我想在UITextView中“突出显示”特定的单词,而不是使用纯色(可以通过NSAttributedString),而是使用渐变和其他一些奇特的效果 因此,我决定有必要手动创建一个视图,并使用给定文本的边界矩形覆盖(或参考底图) 令我惊讶的是,事实证明这非常简单。示例是在UIViewController中,txtView作为UITextView连接为IBOutlet: override func viewDidLayoutSubviews() { super.viewDidLayoutS

我想在UITextView中“突出显示”特定的单词,而不是使用纯色(可以通过
NSAttributedString
),而是使用渐变和其他一些奇特的效果

因此,我决定有必要手动创建一个视图,并使用给定文本的边界矩形覆盖(或参考底图)

令我惊讶的是,事实证明这非常简单。示例是在UIViewController中,
txtView
作为
UITextView
连接为
IBOutlet

override func viewDidLayoutSubviews() {
    super.viewDidLayoutSubviews()

    // Converting to NSString as I need a NSRange for glphyRangeForCharacterRange
    // (a normal String in Swift returns a Range)
    let charRange = (txtView.text as NSString).rangeOfString("dolor sit er elit")
    assert(charRange.location != NSNotFound, "Character Range could not be found.")

    let glyphRange = txtView.layoutManager.glyphRangeForCharacterRange(charRange,
        actualCharacterRange: nil)
    let glyphContainer = txtView.layoutManager.textContainerForGlyphAtIndex(glyphRange.location, effectiveRange: nil)
    let glyphRect = txtView.layoutManager.boundingRectForGlyphRange(glyphRange,
        inTextContainer: glyphContainer!)

    let highlightView = UIView(frame: glyphRect)
    highlightView.alpha = 0.3
    highlightView.backgroundColor = UIColor.redColor()
    txtView.addSubview(highlightView)
}
可悲的是,这导致了重叠视图(在下面的屏幕截图中为红色)偏离了几个点

它似乎总是以同样的数量减少。这意味着我可能会硬编码,但这从来都不是一个好主意。在各种设备的模拟器上以及在iOS 8.1.3的iPhone6上进行了测试

我还尝试了其他变体(通过创建自己的NSTextContainer等),灵感来自和


任何想法(除此之外)?

尝试通过textview的TextContainerSet调整glyph rect:

var glyphRect = txtView.layoutManager.boundingRectForGlyphRange(glyphRange,
        inTextContainer: glyphContainer!)

glyphRect.origin.y += txtView.textContainerInset.top

那就应该成功了

非常感谢!这很有道理,现在我明白了,哈哈。再次感谢!我对多行UILabel也有同样的问题。但是UILabel没有TextContainerSet,有什么想法吗?