iOS:quartz2D绘图(显示绘制在PDF上的图片)

quart2D既可以用来绘制图像到pdf上,也可以从pdf上读取图像并显示出来。在使用这种方式之前,还有一种方式可以用来读取显示pdf上的图像,即使用UIWebView网页视图控件- (void)loadRequest:(NSURLRequest *)request方法加载绘制到视图上显示,这里我将会将这两种方式都演示一遍。

 

具体的实例如下:

方式一:采用网页视图控件UIWebView的方式显示在pdf上的绘图

1、在故事板视图中拖入两个子控件,分别是网页视图控件webView和显示按钮

 

2、将网页视图控件webView IBOutLet关联到控制器类中,为显示按钮添加显示事件IBAction



 



 

3、写按钮事件代码显示pdf上绘制的图片

#param mark -使用网页视图控件显示PDF内容

复制代码
- (IBAction)showPDF:(UIButton *)sender
{
    //设置pdf文件的路径
    NSArray *documents = NSSearchPathForDirectoriesInDomains(NSDocumentDirectory, NSUserDomainMask, YES);
    
    //文档目录
    NSString *document = [documents lastObject];
    //NSLog(@"%@",document);
    
    //拼接pdf路径
    NSString *PDFpath = [document stringByAppendingPathComponent:@"img.pdf"];
    
    //创建URL
    NSURL *url = [NSURL URLWithString:PDFpath];
    
    //创建request
    NSURLRequest *request = [NSURLRequest requestWithURL:url];
    
    //在网页中显示
    [self.webView loadRequest:request];
}
复制代码
点击按钮后,显示的pdf上的绘图截图为:



 

 

 

方式二:采用quartz2D的方式用其封装好的函数显示在pdf上的绘图

1.在故事板视图中拖入两个按钮控件,分别命名为上一页和下一页,用来翻看前面和后面的绘图。



2、自定义一个视图类PDFView,并将控制器视图关联此类,同时将之前创建保存在沙盒目录下的pdf文件imageBook.pdf拖入文件

  

3、在自定义的PDFView类中为两个按钮添加事件IBAction





4、再就是具体的代码了,如下:

在PDFView类中:

//PDFView.h文件中声明打开pdf文件方法和绘制图片显示方法

复制代码
@interface PDFView : UIView
//打开pdf文件
-(void)openPDF:(NSURL *)url;
//绘制图片显示在视图上
-(void)drawPDFWithPage:(size_t)page andContext:(CGContextRef) context;
@end
复制代码
//PDFView.m文件中说明pdf一些属性

复制代码
@implementation PDFView
{
    //pdf文档
    CGPDFDocumentRef _pdfDoc;
    //当前页
    size_t _currentPageNum;
    //总页数
    size_t _totalPageNums;
}
复制代码
//打开PDF文件

复制代码
-(void)openPDF:(NSURL *)url
{
    //创建pdfDoc
    _pdfDoc = CGPDFDocumentCreateWithURL((__bridge CFURLRef)url);
    
    //总页数
    _totalPageNums = CGPDFDocumentGetNumberOfPages(_pdfDoc);
    
    //第一页
    _currentPageNum = 1;
}
复制代码
//上一页

复制代码
- (IBAction)pagePrev:(UIButton *)sender
{
    if (_currentPageNum >1)
    {
        _currentPageNum--;
        [self setNeedsDisplay];
    }
}
复制代码
//下一页

复制代码
- (IBAction)pageNext:(UIButton *)sender
{
    if (_currentPageNum < _totalPageNums)
    {
        _currentPageNum++;
        [self setNeedsDisplay];
    }
}
复制代码
//显示PDF

复制代码
-(void)drawPDFWithPage:(size_t)page andContext:(CGContextRef) context
{
    //获取页
    CGPDFPageRef pdfPage = CGPDFDocumentGetPage(_pdfDoc, page);
    
    //画pdf页面
    CGContextDrawPDFPage(context, pdfPage);
}
复制代码
//重写drawRect:(CGRect rect)方法绘制从pdf文件获取的图像(由于quartzD坐标系是反的,所以需要旋转坐标系)

复制代码
- (void)drawRect:(CGRect)rect
{
    CGContextRef context = UIGraphicsGetCurrentContext();
    
    //旋转坐标系
    CGContextTranslateCTM(context, 80, self.frame.size.height-60);
    CGContextScaleCTM(context, 1, -1);
    
    [self drawPDFWithPage:_currentPageNum andContext:context];
}
复制代码
 

 

在控制器ViewController类中:

//调用执行

复制代码
- (void)viewDidLoad {
    [super viewDidLoad];
   
    //加载pdf文件
    NSString *pdfFileName = [[NSBundle mainBundle]pathForResource:@"imageBook" ofType:@"pdf"];
    
    NSURL *url = [NSURL fileURLWithPath:pdfFileName];
    
    PDFView *pdfView = (PDFView*)self.view;
    
    [pdfView openPDF:url];
}
复制代码
 

演示结果如下:
  

 

程序猿神奇的手,每时每刻,这双手都在改变着世界的交互方式!


本文转自当天真遇到现实博客园博客,原文链接:http://www.cnblogs.com/XYQ-208910/p/4869576.html,如需转载请自行联系原作者
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值