iOS如何实现对当前webView进行截屏
这篇文章给大家分享的是有关iOS如何实现对当前webView进行截屏的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。
为东莞等地区用户提供了全套网页设计制作服务,及东莞网站建设行业解决方案。主营业务为网站设计制作、网站建设、东莞网站设计,以传统方式定制建设网站,并提供域名空间备案等一条龙服务,秉承以专业、用心的态度为用户提供真诚的服务。我们深信只要达到每一位用户的要求,就会得到认可,从而选择与我们长期合作。这样,我们也可以走得更远!
UIWebView和WKWebView的截屏有所区别:
UIWebView:
func getImage(context: ServiceExecuteContext) -> UIImage { //创建一个基于位图的图形上下文并指定大小 UIGraphicsBeginImageContextWithOptions(context.fromViewController.webView.bounds.size, true, 0) //renderInContext呈现接受者及其子范围到指定的上下文 context.fromViewController.webView.layer.renderInContext(UIGraphicsGetCurrentContext()!) //返回一个基于当前图形上下文的图片 let image = UIGraphicsGetImageFromCurrentImageContext() //移除栈顶的基于当前位图的图形上下文 UIGraphicsEndImageContext() //let imagRef = CGImageCreateWithImageInRect((image?.CGImage)!, context.fromViewController.webView.bounds) //let newImage = UIImage.init(CGImage: imagRef!) //UIImageWriteToSavedPhotosAlbum(newImage, nil, nil, nil);//保存图片到照片库 return image! }
UIGraphicsBeginImageContext()方法传入唯一参数,是一个CGSize变量,用来指定图形context的大小,所以获取屏幕截图的时候这个size该是屏幕的大小。其实了解了这个过程,就知道这个方法可以获取任意区域的截图,当然是必须当前页面的一部分。你需要截取哪个view的图像,就让这个view的layer调用renderInContext把图形渲染进当前图形context。
WKWebView:
当我尝试去截取WKWebView的图。截图的结果返回给我的就仅仅只是一张背景图, 显然截图失败。通过搜索StackOverflow和Google, 我发现WKWebView并不能简单的使用layer.renderInContext的方法去绘制图形。如果直接调用layer.renderInContext需要获取对应的Context, 但是在WKWebView中执行UIGraphicsGetCurrentContext()的返回结果是nil
StackOverflow提供了一种解决思路是使用UIView的drawViewHierarchyInRect方法去截取屏幕视图。通过直接调用WKWebView的drawViewHierarchyInRect方法(afterScreenUpdates参数必须为true), 可以成功的截取WKWebView的屏幕内容
func getImage(context: ServiceExecuteContext) -> UIImage { UIGraphicsBeginImageContextWithOptions(context.fromViewController.webView.bounds.size, true, 0) for subView: UIView in context.fromViewController.webView.subviews { subView.drawViewHierarchyInRect(subView.bounds, afterScreenUpdates: true) } //UIApplication.sharedApplication().keyWindow?.layer.renderInContext(UIGraphicsGetCurrentContext()!) let image = UIGraphicsGetImageFromCurrentImageContext() UIGraphicsEndImageContext() //let imagRef = CGImageCreateWithImageInRect((image?.CGImage)!, context.fromViewController.webView.bounds) //let newImage = UIImage.init(CGImage: imagRef!) return image! }
感谢各位的阅读!关于“iOS如何实现对当前webView进行截屏”这篇文章就分享到这里了,希望以上内容可以对大家有一定的帮助,让大家可以学到更多知识,如果觉得文章不错,可以把它分享出去让更多的人看到吧!
当前文章:iOS如何实现对当前webView进行截屏
链接分享:http://hbruida.cn/article/gsseji.html