iOS 开发小技巧iOS Developer - JS && WebViewiOS Developer

UIWebView&WKWebView如何截图

2016-09-07  本文已影响1503人  iceMaple

先看效果


ScreenShotDemo.gif

1 什么时候会用到这个?

分享,目前笔者能想到的只有分享,因为要用呀😁。

2 为什么要写这个?

UIWebView的截图功能还是很容易实现的,可是WKWebView的截图,嗯,一片灰色。。。
在笔者逛了Stack Overflow,里面并没有很好的方法,于是,只能自己动手了,so,可能方法并不是很好,但是足矣解决问题,有时间再研究。

3 开工

(1)UIGraphicsBeginImageContext(CGSize size)
(2)UIGraphicsBeginImageContextWithOptions(CGSize size, BOOL opaque, CGFloat scale)

区别:
UIGraphicsBeginImageContext
参数size为新创建的位图上下文的大小。该函数的功能同UIGraphicsBeginImageContextWithOptions的功能相同,相当与UIGraphicsBeginImageContextWithOptions的opaque参数为NO,scale因子为1.0。
UIGraphicsBeginImageContextWithOptions
参数size——同UIGraphicsBeginImageContext
参数opaque—透明开关,如果图形完全不用透明,设置为YES以优化位图的存储。
参数scale—–缩放因子

3.1.2获取上下文

UIGraphicsGetCurrentContext()

UIGraphicsGetCurrentContext 来取得上下文,这个上下文表示当前的view的size大小

3.1.3绘制

   - (void)renderInContext:(CGContextRef)cox;

参数就是获取的上下文,指明绘制的地方

3.1.4完成

   UIGraphicsGetImageFromCurrentImageContext()

得到绘制好的上下文

4 UIWebView的截图

网上的很多方法就是循环遍历子视图,然后组合起来,个人觉得不够简单,我不会承认用网上的方法我失败了才出此下策的。

在UIWebView加载完成的代理方法里面

-(void)webViewDidFinishLoad:(UIWebView \*)webView
{
   [self saveImageToPhotos: [self screenShotWithScrollView:webView.scrollView]];
    webView.delegate = nil;
   [webView removeFromSuperview];
    webView = nil;
}

封装截图方法

   - (UIImage *)screenShotWithScrollView:(UIScrollView *)scrollView
  {
    UIImage* image;

    UIGraphicsBeginImageContextWithOptions(scrollView.contentSize, NO, [UIScreen mainScreen].scale);
   {
    CGPoint savedContentOffset = scrollView.contentOffset;
    CGRect savedFrame = scrollView.frame;
    scrollView.contentOffset = CGPointZero;
    scrollView.frame = CGRectMake(0, 0, scrollView.contentSize.width, scrollView.contentSize.height);
    [scrollView.layer renderInContext: UIGraphicsGetCurrentContext()];
    image = UIGraphicsGetImageFromCurrentImageContext();
    scrollView.contentOffset = savedContentOffset;
    scrollView.frame = savedFrame;
   }
  UIGraphicsEndImageContext();

  if (image != nil)
  {
    return image;
  }
  return nil;
  }

5 WKWebView的截图

同上,嗯,是的,就是用UIWebView请求一遍再截取UIWebView的图就行,在截完图释放就好,看了一下运存,暂时没问题

注:在UIWebView请求完数据的代理方法里面再截图
注:在UIWebView请求完数据的代理方法里面再截图
注:在UIWebView请求完数据的代理方法里面再截图

完结:如有更好的方法请多多指教

20161117日更新-----------------------

封装了截图方法,一句话代码截图

/**
 截屏

 @param url 截屏的url
 @param successBlock 截屏成功的回调
 @param failureBlock 截屏失败的回调
 */
-(void)capturePicShareWitchUrl:(NSString*)url
                       success:(CapSuccessBlock) successBlock
                       failure:(CapFailureBlock) failureBlock;

惯例文末放Demo:https://github.com/yongliangP/WebViewCaptureDemo
码字不容易,路过请喜欢

上一篇 下一篇

猜你喜欢

热点阅读