我在我的iOS应用程序中有一个UITextView,它显示大量的文本。

然后,我通过使用UITextView的offset margin参数来分页此文本。

我的问题是UITextView的填充使我的计算感到困惑,因为它似乎是不同的,取决于我使用的字体大小和字体。

是否有可能移除UITextView内容周围的填充?


当前回答

对于 SwiftUI

如果你正在使用UIViewRepresentable制作自己的TextView并想要控制填充,在你的makeUIView函数中,简单地做:

uiTextView。textContainerInset = UIEdgeInsets(上:10,左:18,下:0,右:18)

或者随便你。

其他回答

使用用户定义运行时属性的故事板或接口构建器解决方案:

iOS 7.1和iOS 6.1的截图内容为contentInset ={{-10, -5},{0,0}}。

对于iOS 7.0,我发现contentInset技巧不再有效。这是我在iOS 7中用来去除边距/填充的代码。

这将把文本的左边缘带到容器的左边缘:

textView.textContainer.lineFragmentPadding = 0

这将导致文本的顶部与容器的顶部对齐:

textView.textContainerInset = .zero

这两行都需要完全删除空白/填充。

做插入解决方案,我仍然有填充在右侧和底部。文本对齐也会导致问题。我找到的唯一可靠的方法是将文本视图放在另一个被剪切到边界的视图中。

以下是胖子非常有用的答案的更新版本。 它增加了两行重要的行,帮助我在iOS 10和11上(可能在较低的版本上也是如此)让布局正常运行:

@IBDesignable class UITextViewFixed: UITextView {
    override func layoutSubviews() {
        super.layoutSubviews()
        setup()
    }
    func setup() {
        translatesAutoresizingMaskIntoConstraints = true
        textContainerInset = UIEdgeInsets.zero
        textContainer.lineFragmentPadding = 0
        translatesAutoresizingMaskIntoConstraints = false
    }
}

重要的几行是两个translatesAutoresizingMaskIntoConstraints = <true/false>语句!

这令人惊讶地删除了我所有环境中的所有边缘!

虽然textView不是第一个响应器,但可能会发生一些奇怪的底边距无法使用接受的答案中提到的sizeThatFits方法解决的情况。

当敲入textView,突然奇怪的底部边缘消失了,一切看起来像它应该,但只要textView有firstResponder。

所以我在Stack Overflow上读到,启用和禁用translatesAutoresizingMaskIntoConstraints在调用之间手动设置帧/边界时确实有帮助。

幸运的是,这不仅适用于框架设置,而且还适用于夹在两个translatesAutoresizingMaskIntoConstraints调用之间的两行setup() !

例如,当在UIView上使用systemlayoutsizefiting计算视图的帧时,这是非常有用的。它会返回正确的大小(以前它没有)!

如原文所述:

不要忘记在检查器中关闭scrollEnabled !这个解决方案在故事板和运行时都能正常工作。

就是这样,现在你真的完成了!

我肯定会避免任何涉及硬编码值的答案,因为实际边距可能会随着用户字体大小设置等而改变。

下面是user1687195的答案,没有修改textContainer。lineFragmentPadding(因为文档声明这不是预期的用法)。

这适用于iOS 7和更高版本。

self.textView.textContainerInset = UIEdgeInsetsMake(
                                      0,
                                      -self.textView.textContainer.lineFragmentPadding,
                                      0,
                                      -self.textView.textContainer.lineFragmentPadding);

这实际上是相同的结果,只是稍微干净一点,因为它没有滥用lineFragmentPadding属性。