iOS开发CoreGraphics核心图形框架之九——PDF文件的渲染与创建(一)

简介: iOS开发CoreGraphics核心图形框架之九——PDF文件的渲染与创建

一、渲染已有的PDF文档


   在CoreGraphics框架中,有两个类型与PDF文档的渲染有关,分别为CGPDFDocumentRef与CGPDFPageRef。其中,CGPDFDocumentRef对应整个PDF文档,里面封装了许多文档相关的信息,CGPDFPageRef对应PDF文档中某一页的内容,通过它开发者可以将PDF内容通过CGContext上下文渲染到指定目标上。


   如下代码演示了在自定义View的drawRect:方法中进行PDF文档的绘制:


-(void)drawRect:(CGRect)rect{

   //由于坐标系不同,需要进行翻转

   CGContextRef contextRef = UIGraphicsGetCurrentContext();

   //进行坐标系的翻转

   CGContextTranslateCTM(contextRef, 0, rect.size.height);

   CGContextScaleCTM(contextRef, 1.0, -1.0);

   //获取pdf文件的路径

   NSString * path = [[NSBundle mainBundle] pathForResource:@"MyText" ofType:@"pdf"];

   CFStringRef pathString = CFStringCreateWithCString(NULL, [path cStringUsingEncoding:NSUTF8StringEncoding], kCFStringEncodingUTF8);

   //创建url

   CFURLRef url = CFURLCreateWithFileSystemPath(NULL, pathString, kCFURLPOSIXPathStyle, 0);

   CFRelease(pathString);

   //进行CGPDFDocumentRef引用的创建

   CGPDFDocumentRef document = CGPDFDocumentCreateWithURL(url);

   CFRelease(url);

   //获取文档的第1页

   CGPDFPageRef page1 = CGPDFDocumentGetPage(document, 1);

   //进行绘制

   CGContextDrawPDFPage(contextRef, page1);

   CGPDFPageRelease(page1);

   CGPDFDocumentRelease(document);

}

效果如下:

image.png



CGPDFDocument中提供的方法解析如下:


//通过数据提供者类来创建PDF文档对象

CGPDFDocumentRef  CGPDFDocumentCreateWithProvider(CGDataProviderRef cg_nullable provider);

//通过url来创建PDF文档

CGPDFDocumentRef  CGPDFDocumentCreateWithURL(CFURLRef cg_nullable url);

//进行引用计数+1

CGPDFDocumentRef  CGPDFDocumentRetain(CGPDFDocumentRef cg_nullable document);

//进行引用计数-1,需要注意,其作用和CFRelease()相似,不同的是如果document为NULL,不是发生crash

void CGPDFDocumentRelease(CGPDFDocumentRef cg_nullable document);

//获取PDF文档的版本

void CGPDFDocumentGetVersion(CGPDFDocumentRef cg_nullable document, int *  majorVersion, int *  minorVersion);

//判断文档是否是加密的

bool CGPDFDocumentIsEncrypted(CGPDFDocumentRef cg_nullable document);

//使用密码对PDF文档进行解密 返回值为1表示解密成功

bool CGPDFDocumentUnlockWithPassword(CGPDFDocumentRef cg_nullable document, const char *  password);

//判断PDF文档是否已经解锁

bool CGPDFDocumentIsUnlocked(CGPDFDocumentRef cg_nullable document);

//获取此PDF文档是否允许绘制

bool CGPDFDocumentAllowsPrinting(CGPDFDocumentRef cg_nullable document);

//获取此文档是否允许拷贝

bool CGPDFDocumentAllowsCopying(CGPDFDocumentRef cg_nullable document);

//获取PDF文档的总页数

size_t CGPDFDocumentGetNumberOfPages(CGPDFDocumentRef cg_nullable document);

//获取文档中某页数据

CGPDFPageRef __nullable CGPDFDocumentGetPage(CGPDFDocumentRef cg_nullable document, size_t pageNumber);

//获取文档的目录信息

CGPDFDictionaryRef __nullable CGPDFDocumentGetCatalog(CGPDFDocumentRef cg_nullable document);

//获取文档详情信息

CGPDFDictionaryRef __nullable CGPDFDocumentGetInfo(CGPDFDocumentRef cg_nullable document);

//获取文档id

CGPDFArrayRef __nullable CGPDFDocumentGetID(CGPDFDocumentRef cg_nullable document);

//获取CGPDFDocument类在CoreGraphics框架中的id

CFTypeID CGPDFDocumentGetTypeID(void);


CGPDFDocument中还有一些已经弃用的方法,这些方法现在封装在CGPDFPage中,弃用的方法如下:


CGRect CGPDFDocumentGetMediaBox(CGPDFDocumentRef cg_nullable document,int page);

CGRect CGPDFDocumentGetCropBox(CGPDFDocumentRef cg_nullable document, int page);

CGRect CGPDFDocumentGetBleedBox(CGPDFDocumentRef cg_nullable document, int page);

CGRect CGPDFDocumentGetTrimBox(CGPDFDocumentRef cg_nullable document, int page);

CGRect CGPDFDocumentGetArtBox(CGPDFDocumentRef cg_nullable document, int page);

int CGPDFDocumentGetRotationAngle(CGPDFDocumentRef cg_nullable document, int page);

CGPDFPage中的主要方法列举如下:


//进行引用计数+1

CGPDFPageRef CGPDFPageRetain(CGPDFPageRef cg_nullable page);

//进行引用计数-1

void CGPDFPageRelease(CGPDFPageRef cg_nullable page);

//获取对应的PDF文档对象

CGPDFDocumentRef __nullable CGPDFPageGetDocument(CGPDFPageRef cg_nullable page);

//获取当前页是文档中的第几页

size_t CGPDFPageGetPageNumber(CGPDFPageRef cg_nullable page);

//获取与文档此页相关联的媒体区域

/*

typedef CF_ENUM (int32_t, CGPDFBox) {

 kCGPDFMediaBox = 0,

 kCGPDFCropBox = 1,

 kCGPDFBleedBox = 2,

 kCGPDFTrimBox = 3,

 kCGPDFArtBox = 4

};

*/

CGRect CGPDFPageGetBoxRect(CGPDFPageRef cg_nullable page, CGPDFBox box);

//获取此页的旋转角度

int CGPDFPageGetRotationAngle(CGPDFPageRef cg_nullable page);

//transform变换

CGAffineTransform CGPDFPageGetDrawingTransform(CGPDFPageRef cg_nullable page, CGPDFBox box, CGRect rect, int rotate, bool preserveAspectRatio);


目录
相关文章
|
10月前
|
存储 JSON API
如何将 Swagger 文档导出为 PDF 文件
你会发现自己可能需要将 Swagger 文档导出为 PDF 或文件,以便于共享和存档。在这篇博文中,我们将指导你完成将 Swagger 文档导出为 PDF 格式的过程。
|
移动开发 网络协议 小程序
基于开源IM即时通讯框架MobileIMSDK:RainbowChat-iOS端v10.0版已发布
RainbowChat是一套基于开源IM即时通讯聊天框架 MobileIMSDK 的产品级移动端IM系统。RainbowChat源于真实运营的产品,解决了大量的屏幕适配、细节优化、机器兼容问题。RainbowChat可能是市面上提供im即时通讯聊天源码的,唯一一款同时支持TCP、UDP两种通信协议的IM产品。与姊妹产品RainbowTalk和RainbowChat-Web 技术同源,历经考验。
403 0
基于开源IM即时通讯框架MobileIMSDK:RainbowChat-iOS端v10.0版已发布
|
7月前
|
C#
【PDF提取内容改名】批量提取PDF指定区域内容重命名PDF文件,PDF自动提取内容命名的方案和详细步骤
本工具可批量提取PDF中的合同编号、日期、发票号等关键信息,支持PDF自定义区域提取并自动重命名文件,适用于合同管理、发票处理、文档归档和数据录入场景。基于iTextSharp库实现,提供完整代码示例与百度、腾讯网盘下载链接,助力高效处理PDF文档。
937 40
|
7月前
|
编译器 Python
如何利用Python批量重命名PDF文件
本文介绍了如何使用Python提取PDF内容并用于文件重命名。通过安装Python环境、PyCharm编译器及Jupyter Notebook,结合tabula库实现PDF数据读取与处理,并提供代码示例与参考文献。
|
9月前
|
人工智能 算法 安全
使用CodeBuddy实现批量转换PPT、Excel、Word为PDF文件工具
通过 CodeBuddy 实现本地批量转换工具,让复杂的文档处理需求转化为 “需求描述→代码生成→一键运行” 的极简流程,真正实现 “技术为效率服务” 的目标。感兴趣的快来体验下把
513 10
|
8月前
|
数据采集 存储 API
Python爬虫结合API接口批量获取PDF文件
Python爬虫结合API接口批量获取PDF文件
|
12月前
|
文字识别 Serverless 开发工具
【全自动改PDF名】批量OCR识别提取PDF自定义指定区域内容保存到 Excel 以及根据PDF文件内容的标题来批量重命名
学校和教育机构常需处理成绩单、报名表等PDF文件。通过OCR技术,可自动提取学生信息并录入Excel,便于统计分析和存档管理。本文介绍使用阿里云服务实现批量OCR识别、内容提取、重命名及导出表格的完整步骤,包括开通相关服务、编写代码、部署函数计算和设置自动化触发器等。提供Python示例代码和详细操作指南,帮助用户高效处理PDF文件。 链接: - 百度网盘:[链接](https://pan.baidu.com/s/1mWsg7mDZq2pZ8xdKzdn5Hg?pwd=8866) - 腾讯网盘:[链接](https://share.weiyun.com/a77jklXK)
1858 5
|
人工智能 编解码 文字识别
OCRmyPDF:16.5K Star!快速将 PDF 文件转换为可搜索、可复制的文档的命令行工具
OCRmyPDF 是一款开源命令行工具,专为将扫描的 PDF 文件转换为可搜索、可复制的文档。支持多语言、图像优化和多核处理。
1282 17
OCRmyPDF:16.5K Star!快速将 PDF 文件转换为可搜索、可复制的文档的命令行工具
|
机器学习/深度学习 人工智能 文字识别
Zerox:AI驱动的万能OCR工具,精准识别复杂布局并输出Markdown格式,支持PDF、DOCX、图片等多种文件格式
Zerox 是一款开源的本地化高精度OCR工具,基于GPT-4o-mini模型,支持PDF、DOCX、图片等多种格式文件,能够零样本识别复杂布局文档,输出Markdown格式结果。
1364 4
Zerox:AI驱动的万能OCR工具,精准识别复杂布局并输出Markdown格式,支持PDF、DOCX、图片等多种文件格式
|
人工智能 文字识别 数据挖掘
MarkItDown:微软开源的多格式转Markdown工具,支持将PDF、Word、图像和音频等文件转换为Markdown格式
MarkItDown 是微软开源的多功能文档转换工具,支持将 PDF、PPT、Word、Excel、图像、音频等多种格式的文件转换为 Markdown 格式,具备 OCR 文字识别、语音转文字和元数据提取等功能。
3338 9
MarkItDown:微软开源的多格式转Markdown工具,支持将PDF、Word、图像和音频等文件转换为Markdown格式