强制PDF页面填充上下文

时间:2016-03-14 09:46:25

标签: ios swift pdf core-graphics

在我的项目中,我需要生成一个使用CoreGraphics生成的PDF页面的图像。

我设法创建了一个上下文,其中包含我想要的图片大小(destinationSize: CGSize),但是当我使用CGPDFPageGetDrawingTransform函数时,它只会调整页面大小,但它赢了“#{1}}。缩放上下文以使页面填充目标矩形。

以下是我现在在项目中提供的代码摘录:

UIGraphicsBeginImageContextWithOptions(destinationSize, true, 0)

defer {
    UIGraphicsEndImageContext()
}

// Invert y axis (CoreGraphics and UIKit axes are differents)
CGContextTranslateCTM( ctx, 0, destinationSize.height);
CGContextScaleCTM(ctx, 1, -1)

let transform = CGPDFPageGetDrawingTransform(pageRef, .CropBox, CGRect(origin: CGPointZero, size: destinationSize), 0, true)
CGContextConcatCTM(ctx, transform)

// TODO We need force the page to fill all the dest rect when it's bigger than the CropBox size

CGContextDrawPDFPage(ctx, pageRef)

我尝试用比例因子缩放我的上下文,替换TODO:

let contextScale: CGFloat = (pageRect.width < expectedWidth) ? expectedWidth / pageRect.width : 1
CGContextScaleCTM(ctx, contextScale, contextScale)

但是它创建了一个不正确的绘图偏移量,而且我在CoreGraphics转换时丢失了。

重新缩放上下文以确保pdf页面绘制以填充上下文大小的正确方法是什么?

1 个答案:

答案 0 :(得分:0)

这是我提出的解决方案。

据我所知,这适用于任何pdf文档页面。 (经过多次旋转测试,裁剪尺寸和起源。

func transformationForPage(_ pageNumber: Int, targetSize: CGSize) -> CGAffineTransform {
    let pageRef = getPage(pageNumber)
    let rotation = getPageRotationInteger(pageNumber)
    let cropbox = cropboxForPage(pageNumber)

    var transform = pageRef!.getDrawingTransform(.cropBox, rect: CGRect(origin: CGPoint.zero, size: targetSize), rotate: 0, preserveAspectRatio: true)

    // We change the context scale to fill completely the destination size
    if cropbox.width < targetSize.width {
        let contextScale = targetSize.width / cropbox.width
        transform = transform.scaledBy(x: contextScale, y: contextScale)

        transform.tx = -(cropbox.origin.x * transform.a + cropbox.origin.y * transform.b)
        transform.ty = -(cropbox.origin.x * transform.c + cropbox.origin.y * transform.d)

        // Rotation handling
        if rotation == 180 || rotation == 270 {
            transform.tx += targetSize.width
        }
        if rotation == 90 || rotation == 180 {
            transform.ty += targetSize.height
        }
    }

    return transform
}