项目开发中,我们可能会遇到如下的应用场景:将一篇文章,进行截屏(需要全屏截取,包括滚动部分)后,分享到新浪微博、邮箱等等。前段时间,我在应用开发中实现了该功能,代码也是从网上找到的,自己整理了一下。主要实现截屏的方法如下所示:

 // 实现页面的截图(包含滚动部分)
- (NSData *)getImageFromView:(UIView *)view
{
NSData *pngImg;
CGFloat max, scale = 1.0;
CGSize viewSize = [view bounds].size; // 获取全屏的Size,包含可见部分和不可见部分(滚动部分)
CGSize size = [view sizeThatFits:CGSizeZero]; max = (viewSize.width > viewSize.height) ? viewSize.width : viewSize.height;
if( max > )
{
scale = /max;
} UIGraphicsBeginImageContextWithOptions(size,YES,scale); // 设置view成全部展开效果
[view setFrame: CGRectMake(, , size.width, size.height)]; CGContextRef context = UIGraphicsGetCurrentContext();
[view.layer renderInContext:context];
pngImg = UIImagePNGRepresentation( UIGraphicsGetImageFromCurrentImageContext() ); UIGraphicsEndImageContext();
return pngImg;
}

  使用的时候,我们可以用下面的代码:

 // webView是页面的一个UIWebView控件,这里是实现webView的全屏截图,其他控件各位可以自行试验
NSData *imageData = [self getImageFromView:webView];
[imageData writeToFile:[[NSHomeDirectory() stringByAppendingPathComponent:@"Documents"] stringByAppendingPathComponent:@"new.png"] atomically:YES];

  【说明】:实现截图功能,需要引入QuartzCore.framework框架,并且添加如下头文件:

  #include <QuartzCore/QuartzCore.h>

05-26 09:28