2010-07-09 53 views
1

我想为PDF文档中的每个PDF页面创建缩略图并将其放置在UISCrollVIew中。我在这方面取得了成功,但当速度太快时,滚动并不像我想要的那么顺利。 我想优化创建PDF页面的拇指图像。 我想在CGContextDrawPDFPage之后创建一个CGContextRef并重置它的内容,因此我不必每次创建一个上下文并执行一些其他计算,这需要大量资源。使用CGContextDrawPDFPage绘制PDF页面后重新设置CGContextRef

重置CGContextDrawPDFPage后的CGContextRef内容是否可能? CGContextRestoreGState和CGContextSaveGState在这种情况下似乎没有帮助。

NSAutoreleasePool *pool = [[NSAutoreleasePool alloc] init]; 
GCPdfSource *pdfSource = [GCPdfSource sharedInstance]; 
for (int i = pageRange.location; i <= pageRange.length; i++) { 

    UIView *thumbPdfView = [scrollView viewWithTag:i+1]; 
    if (thumbPdfView == nil) { 

     CGPDFPageRef pdfPage = [pdfSource pageAt:i + 1]; 
     float xPosition = THUMB_H_PADDING + THUMB_H_PADDING * i + THUMB_WIDTH * i; 

     CGRect frame = CGRectMake(xPosition, THUMB_H_PADDING, THUMB_WIDTH, THUMB_HEIGHT); 
     thumbPdfView = [[UIView alloc] initWithFrame:frame]; 
     thumbPdfView.opaque = YES; 
     thumbPdfView.backgroundColor = [UIColor whiteColor]; 
     [thumbPdfView setTag:i+1]; 

     CGColorSpaceRef colorSpace = CGColorSpaceCreateDeviceRGB(); 
     CGContextRef context = CGBitmapContextCreate(NULL, 
             frame.size.width, 
             frame.size.height, 
             8,      /* bits per component*/ 
             frame.size.width * 4, /* bytes per row */ 
             colorSpace, 
             kCGImageAlphaPremultipliedLast | kCGBitmapByteOrder32Big); 
     CGColorSpaceRelease(colorSpace); 
     CGContextClipToRect(context, CGRectMake(0, 0, frame.size.width,frame.size.height)); 


     CGRect pdfPageRect = CGPDFPageGetBoxRect(pdfPage, kCGPDFMediaBox); 
     CGRect contextRect = CGContextGetClipBoundingBox(context); 
     CGAffineTransform transform = aspectFit(pdfPageRect, contextRect); 

     CGContextConcatCTM(context, transform); 
     CGContextDrawPDFPage(context, pdfPage); 


     CGImageRef image = CGBitmapContextCreateImage(context); 
     CGContextRelease(context); 
     UIImage *uiImage = [[UIImage alloc]initWithCGImage:image]; 
     CGImageRelease(image); 

     UIImageView *imageVIew = [[UIImageView alloc]initWithImage:uiImage]; 
     [uiImage release]; 

     [thumbPdfView addSubview:imageVIew]; 
     [imageVIew release]; 

     [scrollView addSubview:thumbPdfView]; 
     [thumbPdfView release]; 

    } 
} 

[pool release];//release 

和aspectFit功能...

CGAffineTransform aspectFit(CGRect innerRect, CGRect outerRect) { 
CGFloat scaleFactor = MIN(outerRect.size.width/innerRect.size.width, outerRect.size.height/innerRect.size.height); 
CGAffineTransform scale = CGAffineTransformMakeScale(scaleFactor, scaleFactor); 
CGRect scaledInnerRect = CGRectApplyAffineTransform(innerRect, scale); 
CGAffineTransform translation = 
CGAffineTransformMakeTranslation((outerRect.size.width - scaledInnerRect.size.width)/2 - scaledInnerRect.origin.x, 
           (outerRect.size.height - scaledInnerRect.size.height)/2 - scaledInnerRect.origin.y); 
return CGAffineTransformConcat(scale, translation); 

}

回答

0

尝试CGContextClearRect(context, contextBounds)

CGContextSaveGState和CGContextRestoreGState对上下文的内容没有任何影响。他们推动并弹出对上下文状态方面所做的更改,例如当前的填充颜色。

+0

谢谢!它的工作原理,现在我不需要每次绘制pdf页面时创建一个上下文:) CGContextClearRect(context,CGContextGetClipBoundingBox(context)); 它并没有像我期望的那样有帮助(它在滚动速度太快时不太顺利),但无论如何它比以前更好。 – Koteg 2010-07-09 12:27:02