3

我正在使用这段非常优雅的代码 获取 UIScrollView 的屏幕截图,包括用于捕获要导出到 UIImage 的 UITableView 的全部内容的屏幕外部分。

UIGraphicsBeginImageContextWithOptions(self.controller.tableView.contentSize, YES, 0);
{
    CGPoint savedContentOffset = self.controller.tableView.contentOffset;
    CGRect savedFrame = self.controller.tableView.frame;

    self.controller.tableView.contentOffset = CGPointZero;
    self.controller.tableView.frame = CGRectMake(0, 0, self.controller.tableView.contentSize.width, self.controller.tableView.contentSize.height);

    [self.controller.tableView.layer renderInContext: UIGraphicsGetCurrentContext()];
    image = UIGraphicsGetImageFromCurrentImageContext();

    self.controller.tableView.contentOffset = savedContentOffset;
    self.controller.tableView.frame = savedFrame;
}

UIGraphicsEndImageContext();

它在模拟器中运行得非常好,但是,当我在 iOS 设备(iphone 4s)上运行此代码时,调用此方法时会出现以下错误:

[self.controller.tableView.layer renderInContext: UIGraphicsGetCurrentContext()];

错误:

Error: CGContextTranslateCTM: invalid context 0x2924b0
Error: CGContextDrawImage: invalid context 0x2924b0
Error: CGContextRestoreGState: invalid context 0x2924b0
Error: CGContextSaveGState: invalid context 0x2924b0
Error: CGContextScaleCTM: invalid context 0x2924b0
Error: CGContextClipToRect: invalid context 0x2924b0
etc...

当表格视图内容大小在其范围内时,此代码运行良好,但一旦大于其范围(甚至 1 个像素),它就会进入上述错误的无限循环。但这仅发生在设备上。不是模拟器。

有任何想法吗?

4

1 回答 1

8

事实证明,使用 [UIImage ..] resizableImageWithCapInsets] 方法并将其应用于单元格 backgroundView 并调整框架会导致在实际设备上发生各种时髦的错误,但不会在模拟器上发生。

恢复到已弃用的 [UIImage ..] stretchableImageWithLeftCapWidth: topCapHeight:] 方法解决了它。

于 2012-05-24T08:31:54.383 回答