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

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

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

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


当前回答

[firstNameTextField setContentVerticalAlignment:UIControlContentVerticalAlignmentCenter];

其他回答

所有这些答案都针对标题问题,但我想对OP问题主体中提出的问题提出一些解决方案。

文本内容大小

一个快速计算UITextView中文本大小的方法是使用NSLayoutManager:

UITextView *textView;
CGSize textSize = [textView usedRectForTextContainer:textView.textContainer].size;

这给出了总的可滚动内容,它可能比UITextView的帧大。我发现这比textView更准确。contentSize,因为它实际计算文本占用了多少空间。例如,给定一个空的UITextView:

textView.frame.size = (width=246, height=50)
textSize = (width=10, height=16.701999999999998)
textView.contentSize = (width=246, height=33)
textView.textContainerInset = (top=8, left=0, bottom=8, right=0)

行高

UIFont有一个属性,可以让你快速获得给定字体的行高。所以你可以快速找到文本的行高在你的UITextView:

UITextView *textView;
CGFloat lineHeight = textView.font.lineHeight;

计算可见文本大小

确定实际可见的文本数量对于处理“分页”效果很重要。UITextView有一个属性叫textContainerInset它实际上是UITextView。frame和文本本身之间的边距。要计算可视帧的实际高度,可以执行以下计算:

UITextView *textView;
CGFloat textViewHeight = textView.frame.size.height;
UIEdgeInsets textInsets = textView.textContainerInset;
CGFloat textHeight = textViewHeight - textInsets.top - textInsets.bottom;

确定分页大小

最后,现在你已经有了可见文本大小和内容,你可以通过从textSize中减去textHeight来快速确定你的偏移量:

// where n is the page number you want
CGFloat pageOffsetY = textSize - textHeight * (n - 1);
textView.contentOffset = CGPointMake(textView.contentOffset.x, pageOffsetY);

// examples
CGFloat page1Offset = 0;
CGFloat page2Offset = textSize - textHeight
CGFloat page3Offset = textSize - textHeight * 2

使用所有这些方法,我不需要触摸我的嵌入,我可以去插入号或文本中任何我想要的地方。

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

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

如果你想要设置一个HTML字符串并避免底部填充,请确保你没有使用块标记,即div和p。

对我来说,这就是原因。您可以通过替换出现的块标记来轻松测试它,例如,span标记。

我找到了另一种方法。从UITextView的子视图中获取带有文本的视图,并在子类的layoutSubview方法中设置它:

- (void)layoutSubviews {
    [super layoutSubviews];

    const int textViewIndex = 1;
    UIView *textView = [self.subviews objectAtIndex:textViewIndex];
    textView.frame = CGRectMake(
                                 kStatusViewContentOffset,
                                 0.0f,
                                 self.bounds.size.width - (2.0f * kStatusViewContentOffset),
                                 self.bounds.size.height - kStatusViewContentOffset);
}

在iOS 5上UIEdgeInsetsMake(-8,-8,-8,-8);看起来效果不错。