首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >如何截取UIScrollView可见区域的截图?

如何截取UIScrollView可见区域的截图?
EN

Stack Overflow用户
提问于 2012-06-11 16:42:06
回答 6查看 7.2K关注 0票数 13

如何拍摄UIScrollView可见区域的1:1截图?内容可能比UIScrollView边界更大或更小,也可能是半隐藏的(我为较小的内容实现了自定义滚动,所以它不在左上角)。我在模拟器上达到了预期的效果,但不是在设备本身上:

代码语言:javascript
复制
-(UIImage *)imageFromCombinedContext:(UIView *)background {
      UIImage *image;
      CGRect vis = background.bounds;
      CGSize size = vis.size;
      UIGraphicsBeginImageContext(size);
      [background.layer affineTransform];
      [background.layer renderInontext:UIGraphicsGetCurrentContext()];
      image = UIGraphicsGetImageFromCurrentImageContext();
      UIGraphicsEndImageContext();
      CGImageRef imref = CGImageCreateWithImageInRect([image CGImage], vis);
      image = [UIImage imageWithCGImage:imref];
      CGImageRelease(imref);
      return image;
}
EN

回答 6

Stack Overflow用户

回答已采纳

发布于 2012-06-11 17:23:57

我自己找到了一个解决方案-我截取了整个视图的屏幕截图,然后将其裁剪成UIScrollView框架的大小和位置。

代码语言:javascript
复制
-(UIImage *)imageFromCombinedContext:(UIView *)background 
{
      UIImage *image;
      CGSize size = self.view.frame.size;
      UIGraphicsBeginImageContext(size);
      [background.layer affineTransform];
      [self.view.layer.layer renderInContext:UIGraphicsGetCurrentContext()];
      image = UIGraphicsGetImageFromCurrentImageContext();
      UIGraphicsEndImageContext();
      CGImageRef imgRef = CGImageCreateWithImageInRect([image CGImage],background.frame);
      image = [UIImage imageWithCGImage:imref];
      CGImageRelease(imref);
      return image;
}
票数 4
EN

Stack Overflow用户

发布于 2018-03-29 20:00:53

Abduliam Rehmanius的Swift 4版本回答为UIScrollView extension,翻译,没有缓慢的裁剪

代码语言:javascript
复制
extension UIScrollView {

    var snapshotVisibleArea: UIImage? {
        UIGraphicsBeginImageContext(bounds.size)
        UIGraphicsGetCurrentContext()?.translateBy(x: -contentOffset.x, y: -contentOffset.y)
        layer.render(in: UIGraphicsGetCurrentContext()!)
        let image = UIGraphicsGetImageFromCurrentImageContext()
        UIGraphicsEndImageContext()
        return image
    }
}
票数 4
EN

Stack Overflow用户

发布于 2015-03-10 05:53:56

杰弗里·孙给出了正确的答案。只需将滚动视图放入另一个视图中即可。获取容器视图以在上下文中呈现。好了。

在下面的代码中,cropView包含要捕获的滚动视图。解决方案就是这么简单。

因为我理解了这个问题,以及为什么我找到了这个页面,滚动视图的整个内容都不需要--只需要可见的部分。

代码语言:javascript
复制
func captureCrop() -> UIImage {
    UIGraphicsBeginImageContextWithOptions(self.cropView.frame.size, true, 0.0)
    self.cropView.layer.renderInContext(UIGraphicsGetCurrentContext())
    let image = UIGraphicsGetImageFromCurrentImageContext()
    UIGraphicsEndImageContext()
    return image;
}
票数 3
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/10976816

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档