pdf转图片 swift

2018-11-23 15:47:00 chongyin1864 阅读数 76

PDF文档,是一种与操作系统和电脑硬件等无关的方式进行文件交换的文件格式,并且PDF文件格式可以将文字、字型、格式、颜色及独立于设备和分辨率的图形图像等封装在一个文件中,这些特性使得PDF文档成为我们工作中会经常用到的一种文件格式。但是有时在文字、图片处理时,由于工作需要,会要求将PDF转换成图片。下面我们就来讲讲怎么将PDF转换成图片:

 

1. 前往在线PDF转换平台:pdf365.cn;

把PDF转换成图片,大家都这么做

2、点击“PDF转图片”图标,进入PDF文档上传页面,将需要转换的PDF文档添加到转换窗口中;

把PDF转换成图片,大家都这么做

3、点击“开始转换”按钮,即可完成在线PDF转换成图片;

把PDF转换成图片,大家都这么做

4、转换成功后,点击“下载”按钮,即可获取转换后的文档;

把PDF转换成图片,大家都这么做

 

你可能会用到:

在线图片转PDFhttps://www.pdf365.cn/jpg-to-pdf

在线PDF转PPThttps://www.pdf365.cn/pdf-to-ppt

在线PDF合并https://www.pdf365.cn/pdf-merge

转载于:https://my.oschina.net/NoEggEgg/blog/2934135

2014-02-26 09:10:50 wanggsx20080817 阅读数 1829

图片转PDF的实现方法

Quartz 2D概述

Quartz 2D是Core Grapgics下的2D绘图引擎,适用于iOS和Mac OS X。 它具有强大的绘图功能,提供视角效果渲染,反锯齿渲染,颜色管理,绘制PDF等等。
开发者无需考虑不同设备不同分辨率的显示效果,因为这一切适配操作Quartz 全都自己包了。
具体Quartz可以做些什么,下图给出了最佳答案:


图片转PDF的工具类

利用Quartz 2D将图片数据转换成图片不失真的PDF,方法我已经封装好:

(PDF部分属性未列出,如果有额外需要,需要另行提出赋值)

  1. //  
  2. //  WQPDFManager.h  
  3. //  wqphototopdf  
  4. //  
  5. //  Created by Wu Qian on 12-10-22.  
  6. //  
  7. //  
  8.   
  9. #import <Foundation/Foundation.h>  
  10.   
  11. @interface WQPDFManager : NSObject  
  12.   
  13. /** 
  14.  *  @brief  创建PDF文件 
  15.  * 
  16.  *  @param  imgData         NSData型   照片数据 
  17.  *  @param  destFileName    NSString型 生成的PDF文件名 
  18.  *  @param  pw              NSString型 要设定的密码 
  19.  */  
  20. + (void)WQCreatePDFFileWithSrc:(NSData *)imgData  
  21.                     toDestFile:(NSString *)destFileName  
  22.                   withPassword:(NSString *)pw;  
  23.   
  24.   
  25. /** 
  26.  *  @brief  抛出pdf文件存放地址 
  27.  * 
  28.  *  @param  filename    NSString型 文件名 
  29.  * 
  30.  *  @return NSString型 地址 
  31.  */  
  32. + (NSString *)pdfDestPath:(NSString *)filename;  
  33.   
  34. @end  

  1. //  
  2. //  WQPDFManager.m  
  3. //  wqphototopdf  
  4. //  
  5. //  Created by Wu Qian on 12-10-22.  
  6. //  
  7. //  
  8.   
  9. #import "WQPDFManager.h"  
  10. #import "WQPathUtilities.h"  
  11.   
  12. @implementation WQPDFManager  
  13.   
  14. void WQDrawContent(CGContextRef myContext,  
  15.                    CFDataRef data,  
  16.                    CGRect rect)  
  17. {  
  18.     CGDataProviderRef dataProvider = CGDataProviderCreateWithCFData(data);  
  19.     CGImageRef image = CGImageCreateWithJPEGDataProvider(dataProvider,  
  20.                                                          NULL,  
  21.                                                          NO,  
  22.                                                          kCGRenderingIntentDefault);  
  23.     CGContextDrawImage(myContext, rect, image);  
  24.       
  25.     CGDataProviderRelease(dataProvider);  
  26.     CGImageRelease(image);  
  27. }  
  28.   
  29. void MyCreatePDFFile (CFDataRef data,  
  30.                       CGRect pageRect,  
  31.                       const char *filepath,  
  32.                       CFStringRef password)  
  33. {  
  34.     CGContextRef pdfContext;  
  35.     CFStringRef path;  
  36.     CFURLRef url;  
  37.     CFDataRef boxData = NULL;  
  38.     CFMutableDictionaryRef myDictionary = NULL;  
  39.     CFMutableDictionaryRef pageDictionary = NULL;  
  40.       
  41.     path = CFStringCreateWithCString (NULL, filepath,  
  42.                                       kCFStringEncodingUTF8);  
  43.     url = CFURLCreateWithFileSystemPath (NULL, path,  
  44.                                          kCFURLPOSIXPathStyle, 0);  
  45.     CFRelease (path);  
  46.     myDictionary = CFDictionaryCreateMutable(NULL,  
  47.                                              0,  
  48.                                              &kCFTypeDictionaryKeyCallBacks,  
  49.                                              &kCFTypeDictionaryValueCallBacks);  
  50.     CFDictionarySetValue(myDictionary,  
  51.                          kCGPDFContextTitle,  
  52.                          CFSTR("Photo from iPrivate Album"));  
  53.     CFDictionarySetValue(myDictionary,  
  54.                          kCGPDFContextCreator,  
  55.                          CFSTR("iPrivate Album"));  
  56.     if (password) {  
  57.         CFDictionarySetValue(myDictionary, kCGPDFContextUserPassword, password);  
  58.         CFDictionarySetValue(myDictionary, kCGPDFContextOwnerPassword, password);  
  59.     }  
  60.   
  61.     pdfContext = CGPDFContextCreateWithURL (url, &pageRect, myDictionary);  
  62.     CFRelease(myDictionary);  
  63.     CFRelease(url);  
  64.     pageDictionary = CFDictionaryCreateMutable(NULL,  
  65.                                                0,  
  66.                                                &kCFTypeDictionaryKeyCallBacks,  
  67.                                                &kCFTypeDictionaryValueCallBacks);  
  68.     boxData = CFDataCreate(NULL,(const UInt8 *)&pageRect, sizeof (CGRect));  
  69.     CFDictionarySetValue(pageDictionary, kCGPDFContextMediaBox, boxData);  
  70.     CGPDFContextBeginPage (pdfContext, pageDictionary);  
  71.     WQDrawContent(pdfContext,data,pageRect);  
  72.     CGPDFContextEndPage (pdfContext);  
  73.       
  74.     CGContextRelease (pdfContext);  
  75.     CFRelease(pageDictionary);  
  76.     CFRelease(boxData);  
  77. }  
  78.   
  79. + (NSString *)pdfDestPath:(NSString *)filename  
  80. {  
  81.     return [[WQPathUtilities tmpDirectory]stringByAppendingPathComponent:filename];  
  82. }  
  83.   
  84. + (void)WQCreatePDFFileWithSrc:(NSData *)imgData  
  85.                     toDestFile:(NSString *)destFileName  
  86.                   withPassword:(NSString *)pw  
  87. {  
  88.     NSString *fileFullPath = [self pdfDestPath:destFileName];  
  89.     const char *path = [fileFullPath UTF8String];  
  90.     CFDataRef data = (__bridge CFDataRef)imgData;  
  91.     UIImage *image = [UIImage imageWithData:imgData];  
  92.     CGRect rect = CGRectMake(0, 0, image.size.width, image.size.height);  
  93.     CFStringRef password = (__bridge CFStringRef)pw;  
  94.       
  95.     MyCreatePDFFile(data,rect, path, password);  
  96. }  
  97. @end  


调用方法

  1. NSData *data = [NSData dataWithContentsOfFile:your_image_path];  
  2. NSString *pdfname = @"photoToPDF.pdf";  
  3. [WQPDFManager WQCreatePDFFileWithSrc:data toDestFile:pdfname withPassword:nil];  

如果需要创建带密码保护的PDF,第三个参数传入密码即可。


效果图

以 【私人相册】 中的截图示意一下...
将照片转换为密码保护的PDF,并发送EMail ,接收者需键入密码才可查看照片:




2018-09-21 14:35:57 loovelj 阅读数 1352

PDF转图片方法

最近在研究使用python转PDF转图片的方法,有调用github上的包,有调用jar包的,但是有的安装麻烦,有的缺少依赖的jar包,调用magicimage还内存溢出。最后我使用了Ghostscript,通过shell调用执行,很方便,也很快。

对了,windows下要下载Ghostscript,同时要在把bin文件添加到环境变量中,例如:

C:\Program Files\gs\gs9.23\bin 

然后重启电脑就可以了。


import os
import platform
def pdf2img(pdf_path,save_image_path):
 
    if platform.system()=="Windows":
        cmd="gswin64c.exe -dBATCH -dNOPAUSE -sDEVICE=png16m -dGraphicsAlphaBits=4 -dTextAlphaBits=4 -r600 -sOutputFile="+ save_image_path+"page_%d.jpg "+pdf_path
        os.system(cmd)
    else:
        cmd="gs -dBATCH -dNOPAUSE -sDEVICE=png16m -dGraphicsAlphaBits=4 -dTextAlphaBits=4 -r600 -sOutputFile="+ save_image_path+"page_%d.jpg "+pdf_path
        os.system(cmd)
    
pdf2img("cjcl.pdf","./aaa/")

2018-09-29 20:40:55 qq_27633421 阅读数 3357

最近做项目遇到了这个需求,百度了一下发现还是12年的文章,使用了一下不好用,转为PDF后是空白的,开始Google查文件,现成功实现,效果如下图

1.是我本地的viewcontroller上面的一个view。显示一些请求的结果。可以用手势签名,等等巴拉巴拉的一堆

 

下面这个是转的时候

 

然后是打开模拟器的文件夹的PDF文件,看看效果图:

图片可能有点大 对付看吧。

可能看着有点模糊,是因为图片的原因,一会说下在哪里处理就行了。

准备工作:获取要转的image,图1是一个view,首先我是给他转成了一个图片,转成图片有两种方法,一个是view高度不超过屏幕的,一个是超过了屏幕的,我先都写上吧:

+ (UIImage *) snapshotWithScrollView:(UIScrollView *)scrollView{
        UIImage* image = nil;
        UIGraphicsBeginImageContext(scrollView.contentSize);
        {
                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;
}

+ (UIImage *)snapshotWithView:(UIView *)view
{
        CGSize size = view.bounds.size;
        UIGraphicsBeginImageContextWithOptions(size, YES, 0);
        [view drawViewHierarchyInRect:view.bounds afterScreenUpdates:YES];
        UIImage *image = UIGraphicsGetImageFromCurrentImageContext();
        UIGraphicsEndImageContext();
        return image;
}

 

在得到了image之后,要开始干活了,首先,生成一个图片,我要保存到本地,然后拿到他的URL,使用alassets这个框架

#import <AssetsLibrary/AssetsLibrary.h>

ProStrong ALAssetsLibrary *library;//将它定义为属性,原因下面写了

#define kPadding 20

.
.
.
//上面一堆初始化各种方法的代码不贴了

- (void)saveImage:(UIImage *)image{
    //ALAssetsLibrary如果是临时对象。执行完毕就会释放 保存的aseturl就会失效,找不到目标图片了,所以要声明成属性
    self.library = [[ALAssetsLibrary alloc] init];
    [self.library writeImageToSavedPhotosAlbum:image.CGImage metadata:nil completionBlock:^(NSURL *assetURL, NSError *error) {
        NSLog(@"assetURL = %@, error = %@", assetURL, error);
        self.saveImagePath = assetURL;
        [self turnSelfViewToPDF];
    }];
}

保存完图片后在回调内拿到存储的URL。就是self.library这个对象将这个图片存储的地址,不能让library是否,否则地址会失效

 

第二步:

-(void)turnSelfViewToPDF{
    ALAssetsLibrary *assetslibrary = [[ALAssetsLibrary alloc] init];
    [assetslibrary assetForURL:self.saveImagePath
                   resultBlock:^(ALAsset *asset){
                       //根据URL取到图片
                       ALAssetRepresentation *rep = [asset defaultRepresentation];
                       CGImageRef iref = [rep fullScreenImage];
                       if (iref) {
                           UIImage *image = [UIImage imageWithCGImage:iref];
                           [self setupPDFDocumentNamed:self.recordId width:screenWidth height:self.bgScrollView.contentSize.height];
                           [self addImage:image
                                                     atPoint:CGPointMake((_pageSize.width/2)-(image.size.width/2), kPadding)];
                           
                           NSFileManager *manager = [NSFileManager defaultManager];
                           NSArray *paths = NSSearchPathForDirectoriesInDomains(NSLibraryDirectory, NSUserDomainMask, YES);
                           NSString *path = [paths lastObject];
                           NSString * path1 = [path stringByAppendingPathComponent:[NSString stringWithFormat:@"%@.pdf",self.recordId]];
                           if ([manager fileExistsAtPath:path1]) {
                               [SVProgressHUD showMessage:@"生成PDF文件成功"];
                           }else{
                               [SVProgressHUD showMessage:@"生成PDF文件失败"];
                           }
                       }
                   }
                  failureBlock:^(NSError *error) {
                      NSLog(@"从图库获取图片失败: %@",error);
                  }];
}

- (void)setupPDFDocumentNamed:(NSString*)name width:(float)width height:(float)height {
    //设置存储的PDFframe,默认我传的屏幕宽高,根据你的情况改变
    _pageSize = CGSizeMake(width, height);
    //根据传进来的文件名字  创建文件夹,在内部存储PDF文件
    NSString *newPDFName = [NSString stringWithFormat:@"%@.pdf",name];
    NSArray *paths = NSSearchPathForDirectoriesInDomains(NSLibraryDirectory, NSUserDomainMask, YES);
    NSString *documentsDirectory = [paths objectAtIndex:0];
    NSString *pdfPath = [documentsDirectory stringByAppendingPathComponent:newPDFName];
    //开始绘制PDF
    UIGraphicsBeginPDFContextToFile(pdfPath, CGRectZero, nil);
    UIGraphicsBeginPDFPageWithInfo(CGRectMake(0, 0, _pageSize.width, _pageSize.height), nil);
}

- (void)addImage:(UIImage*)image atPoint:(CGPoint)point {
    //向PDF内添加图片
    CGRect imageFrame = CGRectMake(point.x, point.y, image.size.width, image.size.height);
    [image drawInRect:imageFrame];
    UIGraphicsEndPDFContext();
}

 

以上就是基本的图片转PDF的方法,亲测可用,效果杠杠的

其他:你的领导可能让你在转PDF的时候要给PDF润色啦,加个title啦,加个题记,巴拉巴拉的,所以先写一个在PDF文件最上方加title和一个红色细线的方法,心急的朋友可略过此步骤:

- (CGRect)addText:(NSString*)text withFrame:(CGRect)frame fontSize:(float)fontSize {
    UIFont *font = [UIFont systemFontOfSize:fontSize];
    NSMutableParagraphStyle *style1 = [NSMutableParagraphStyle new];
    style1.lineBreakMode = NSLineBreakByWordWrapping;
    CGSize stringSize = [text boundingRectWithSize:_pageSize options:NSStringDrawingUsesLineFragmentOrigin | NSStringDrawingUsesFontLeading attributes:@{NSParagraphStyleAttributeName:style1} context:nil].size;
    
    float textWidth = frame.size.width;
    
    if (textWidth < stringSize.width)
        textWidth = stringSize.width;
    if (textWidth > _pageSize.width)
        textWidth = _pageSize.width - frame.origin.x;
    CGRect renderingRect = CGRectMake(frame.origin.x, frame.origin.y, textWidth, stringSize.height);
    NSMutableParagraphStyle *style = [NSMutableParagraphStyle new];
    style.lineBreakMode = NSLineBreakByWordWrapping;
    style.alignment = NSTextAlignmentLeft;
    [text drawInRect:renderingRect withAttributes:@{NSFontAttributeName:font,NSParagraphStyleAttributeName:style}];
    frame = CGRectMake(frame.origin.x, frame.origin.y, textWidth, stringSize.height);
    return frame;
}

然后在这行文字下面加个醒目的线条:

-  (CGRect)addLineWithFrame:(CGRect)frame withColor:(UIColor*)color {
    CGContextRef currentContext = UIGraphicsGetCurrentContext();
    CGContextSetStrokeColorWithColor(currentContext, color.CGColor);
    CGContextSetLineWidth(currentContext, frame.size.height);
    CGPoint startPoint = frame.origin;
    CGPoint endPoint = CGPointMake(frame.origin.x + frame.size.width, frame.origin.y);
    CGContextBeginPath(currentContext);
    CGContextMoveToPoint(currentContext, startPoint.x, startPoint.y);
    CGContextAddLineToPoint(currentContext, endPoint.x, endPoint.y);
    CGContextClosePath(currentContext);
    CGContextDrawPath(currentContext, kCGPathFillStroke);
    return frame;
}

然后调用生成PDF的方法就会是这样:

-(void)turnSelfViewToPDF{
    ALAssetsLibrary *assetslibrary = [[ALAssetsLibrary alloc] init];
    [assetslibrary assetForURL:self.saveImagePath
                   resultBlock:^(ALAsset *asset){
                       ALAssetRepresentation *rep = [asset defaultRepresentation];
                       CGImageRef iref = [rep fullScreenImage];
                       if (iref) {
                           UIImage *image = [UIImage imageWithCGImage:iref];
                           [self setupPDFDocumentNamed:self.recordId width:screenWidth height:self.bgScrollView.contentSize.height];
                           //顶部添加title
                           CGRect textRect = [self addText:@"这里是标题,呵呵呵呵呵呵" withFrame:CGRectMake(kPadding, kPadding, 400, 200) fontSize:48.0f];
                           //在title下面画线
                           CGRect blueLineRect = [self addLineWithFrame:CGRectMake(kPadding, textRect.origin.y + textRect.size.height + kPadding, _pageSize.width - kPadding*2, 4) withColor:[UIColor blueColor]];
                           //在线下面添加图片
                           [self addImage:anImage
                                                     atPoint:CGPointMake((_pageSize.width/2)-(anImage.size.width/2), blueLineRect.origin.y + blueLineRect.size.height + kPadding)]
                           
                           NSFileManager *manager = [NSFileManager defaultManager];
                           NSArray *paths = NSSearchPathForDirectoriesInDomains(NSLibraryDirectory, NSUserDomainMask, YES);
                           NSString *path = [paths lastObject];
                           NSString * path1 = [path stringByAppendingPathComponent:[NSString stringWithFormat:@"%@.pdf",self.recordId]];
                           if ([manager fileExistsAtPath:path1]) {
                               [SVProgressHUD showMessage:@"生成PDF文件成功"];
                           }else{
                               [SVProgressHUD showMessage:@"生成PDF文件失败"];
                           }
                       }
                   }
                  failureBlock:^(NSError *error) {
                      NSLog(@"从图库获取图片失败: %@",error);
                  }];
}

最底部还可以调用addline的方法来添加线。不过要获得image的y,可以改变addimage的方法的返回值让他返回imageframe,然后把UIGraphicsEndPDFContext()拿到这里来结束PDF生成即可。有不懂的留言问吧

demo正在做,做好了会更新文章放到github上。

2019-04-27 16:13:16 XLawsZero 阅读数 2614

- (void)footButtonAction

{

    if ([self.downloadUrl isEqualToString:@""] || self.downloadUrl == nil || [self.downloadUrl isEqual:nil] || !self.downloadUrl) {

       return;

    }

    NSURL * url = [[NSURL alloc] initWithString:self.downloadUrl];

    CFURLRef ref = (__bridge CFURLRef)url;

    CGPDFDocumentRef pdf = CGPDFDocumentCreateWithURL(ref);

    CFRelease(ref);

 

    CGImageRef imageRef = PDFPageToCGImage(1,pdf);

    UIImage *amg = [UIImage imageWithCGImage:imageRef];

    CGImageRelease(imageRef);

 

   //保存图片到相册

    UIImageWriteToSavedPhotosAlbum(amg, self, @selector(image:didFinishSavingWithError:contextInfo:), nil);

}

CGImageRef PDFPageToCGImage(size_t pageNumber, CGPDFDocumentRef document)

{

    CGPDFPageRef page = CGPDFDocumentGetPage (document, pageNumber);

    if(page)

    {

        CGRect pageSize =CGPDFPageGetBoxRect(page,kCGPDFMediaBox);

        CGContextRef outContext= CreateARGBBitmapContext (pageSize.size.width, pageSize.size.height);

        if(outContext)

        {

            CGContextDrawPDFPage(outContext, page);

            CGImageRef ThePDFImage= CGBitmapContextCreateImage(outContext);

            CFRelease(outContext);

            return ThePDFImage;

        }

    }

    return NULL;

}

CGContextRef CreateARGBBitmapContext (size_t pixelsWide, size_t pixelsHigh)

{

    CGContextRef    context = NULL;

    CGColorSpaceRef colorSpace;

    void *          bitmapData;

    unsigned long   bitmapByteCount;

    unsigned long   bitmapBytesPerRow;

    // Get image width, height. We’ll use the entire image.

    //  size_t pixelsWide = CGImageGetWidth(inImage);

    //  size_t pixelsHigh = CGImageGetHeight(inImage);

    // Declare the number of bytes per row. Each pixel in the bitmap in this

    // example is represented by 4 bytes; 8 bits each of red, green, blue, and

    // alpha.

    bitmapBytesPerRow   = (pixelsWide * 4);

    bitmapByteCount     = (bitmapBytesPerRow * pixelsHigh);

    // Use the generic RGB color space.

    colorSpace =CGColorSpaceCreateWithName(kCGColorSpaceGenericRGB);

    if (colorSpace == NULL)

    {

        fprintf(stderr, "Error allocating color space\n");

        return NULL;

    }

    // Allocate memory for image data. This is the destination in memory

    // where any drawing to the bitmap context will be rendered.

    bitmapData = malloc( bitmapByteCount );

    if (bitmapData == NULL)

    {

        fprintf (stderr, "Memory not allocated!");

        CGColorSpaceRelease( colorSpace );

        return NULL;

    }

    // Create the bitmap context. We want pre-multiplied ARGB, 8-bits

    // per component. Regardless of what the source image format is

    // (CMYK, Grayscale, and so on) it will be converted over to the format

    // specified here by CGBitmapContextCreate.

    context = CGBitmapContextCreate (bitmapData,

                                     pixelsWide,

                                     pixelsHigh,

                                     8,      // bits per component

                                     bitmapBytesPerRow,

                                     colorSpace,

                                     kCGImageAlphaPremultipliedFirst);

    if (context == NULL)

    {

        free (bitmapData);

        fprintf (stderr, "Context not created!");

    }

    // Make sure and release colorspace before returning

    CGColorSpaceRelease( colorSpace );

    return context;

}

 

// 功能:显示图片保存结果

- (void)image:(UIImage *)image didFinishSavingWithError:(NSError*)error contextInfo:(void*)contextInfo

{

    if (error){

        hud.label.text = @"保存图片失败!";

    }else {

        

        hud.label.text = @"保存图片成功!";

    }

}

用Swift开发Mac App(1)

阅读数 14339