Iphone 将PDF加载到屏幕外的图层

Iphone 将PDF加载到屏幕外的图层,iphone,cocoa-touch,iphone-sdk-3.0,ipad,Iphone,Cocoa Touch,Iphone Sdk 3.0,Ipad,有没有办法将PDF加载到CALayer(或CATiledLayer)屏幕外,然后在需要时显示?该解决方案还应支持按所需分辨率进行缩放 更新 只是澄清一下-我希望pdf保持基于向量。注意:您说过需要将pdf加载到CALayer中。但在这里,我有一个将整个pdf页面加载到图像中的解决方案。一旦图像位于阵列中,您就可以在需要时查看其中的任何图像。如果您有任何疑问,请添加评论。 您只需复制并粘贴以下代码。这几乎对你有用。我已经测试过了 首先,将以下方法置于视图控制器的实现之上 NSMutableAr

有没有办法将PDF加载到CALayer(或CATiledLayer)屏幕外,然后在需要时显示?该解决方案还应支持按所需分辨率进行缩放

更新

只是澄清一下-我希望pdf保持基于向量。

注意:您说过需要将pdf加载到CALayer中。但在这里,我有一个将整个pdf页面加载到图像中的解决方案。一旦图像位于阵列中,您就可以在需要时查看其中的任何图像。如果您有任何疑问,请添加评论。

  • 您只需复制并粘贴以下代码。这几乎对你有用。我已经测试过了
首先,将以下方法置于视图控制器的实现之上

NSMutableArray *aRefImgs; // global variable.
void setRefImgs(NSMutableArray *ref){
    aRefImgs=ref;
}

NSMutableArray* ImgArrRef(){
    return aRefImgs;
}
CGPDFDocumentRef MyGetPDFDocumentRef (const char *filename) {
    CFStringRef path;
    CFURLRef url;
    CGPDFDocumentRef document;
    path = CFStringCreateWithCString (NULL, filename,kCFStringEncodingUTF8);
    url = CFURLCreateWithFileSystemPath (NULL, path, kCFURLPOSIXPathStyle, 0);
    CFRelease (path);
    document = CGPDFDocumentCreateWithURL (url);// 2
    CFRelease(url);
    int count = CGPDFDocumentGetNumberOfPages (document);// 3
    if (count == 0) {
        printf("`%s' needs at least one page!", filename);
        return NULL;
    }
    return document;
}

void MyDisplayPDFPage (CGContextRef myContext,size_t pageNumber,const char *filename, CGPDFOperatorTableRef tblRef, NSMutableString *mainStr) {
    CGPDFDocumentRef document;
    CGPDFPageRef page;
    document = MyGetPDFDocumentRef (filename);// 1
    totalPages=CGPDFDocumentGetNumberOfPages(document);
    page = CGPDFDocumentGetPage (document, pageNumber);// 2
    CGContextDrawPDFPage (myContext, page);// 3
    CGContextTranslateCTM(myContext, 0, 20);
    CGContextScaleCTM(myContext, 1.0, -1.0);
    CGPDFDocumentRelease (document);// 4
}
现在,将以下代码放入viewController.m文件中

-(void)viewDidLoad {
    filePath=[[NSString alloc] initWithString:[[NSBundle mainBundle] pathForResource:@"roadie" ofType:@"pdf"]];

    CGPDFDocumentRef d=MyGetPDFDocumentRef([filePath UTF8String]);

    size_t nos=CGPDFDocumentGetNumberOfPages(d); 
    totalPages=nos;
    arrImgs=[[NSMutableArray alloc] init]; // arrImgs variable declared in viewController.h file.
setRefImgs(arrImgs);
int i;
for(i=0;i<nos;i++){
    UIGraphicsBeginImageContext(CGSizeMake(720, 720));
    MyDisplayPDFPage(UIGraphicsGetCurrentContext(), i+1, [filePath UTF8String],myTable,mainString);
    UIImage *tmp=UIGraphicsGetImageFromCurrentImageContext();
    UIImage *t2=[tmp rotate:UIImageOrientationDownMirrored];
    [arrPDFImgs addObject:t2];
    UIImageView *imgV=[[UIImageView alloc] initWithFrame:CGRectMake(scrPDFImages.frame.size.width * i, 0, scrPDFImages.frame.size.width, scrPDFImages.frame.size.height)];
    [imgV setContentMode:UIViewContentModeScaleToFill];
    [imgV setImage:t2];
    [scrPDFImages addSubview:imgV]; 
            // scrPDFImages is an array that has all images 
            // per page one image from pdf document
    [imgV release];
    UIGraphicsPopContext();
    }
}

如何控制所创建图像的大小/质量?pdf页面基于矢量,放大后看起来非常完美。为了使图像在放大时看起来像样,我需要创建一个分辨率更高的版本。如何做到这一点?请将它添加到您的问题中-您也需要缩放。我还有缩放的解决方案。但它会在我的答案中添加更多的代码。@Spark:MyDisplayPDFPage(UIGraphicsGetCurrentContext(),i+1,[filePath UTF8String],myTable,mainString)中的myTable是什么;请将它添加到您的问题中-您还需要缩放。
@interface UIImage (WBImage)
// rotate UIImage to any angle
-(UIImage*)rotate:(UIImageOrientation)orient;
@end

@implementation UIImage (WBImage)


static inline CGFloat degreesToRadians(CGFloat degrees)
{
    return M_PI * (degrees / 180.0);
}

static inline CGSize swapWidthAndHeight(CGSize size)
{
    CGFloat  swap = size.width;

    size.width  = size.height;
    size.height = swap;

    return size;
}


-(UIImage*)rotate:(UIImageOrientation)orient
{
    CGRect             bnds = CGRectZero;
    UIImage*           copy = nil;
    CGContextRef       ctxt = nil;
    CGRect             rect = CGRectZero;
    CGAffineTransform  tran = CGAffineTransformIdentity;

    bnds.size = self.size;
    rect.size = self.size;

    switch (orient)
    {
        case UIImageOrientationUp:
            return self;

        case UIImageOrientationUpMirrored:
            tran = CGAffineTransformMakeTranslation(rect.size.width, 0.0);
            tran = CGAffineTransformScale(tran, -1.0, 1.0);
            break;

        case UIImageOrientationDown:
            tran = CGAffineTransformMakeTranslation(rect.size.width,
                                                    rect.size.height);
            tran = CGAffineTransformRotate(tran, degreesToRadians(180.0));
            break;

        case UIImageOrientationDownMirrored:
            tran = CGAffineTransformMakeTranslation(0.0, rect.size.height);
            tran = CGAffineTransformScale(tran, 1.0, -1.0);
            break;

        case UIImageOrientationLeft:
            bnds.size = swapWidthAndHeight(bnds.size);
            tran = CGAffineTransformMakeTranslation(0.0, rect.size.width);
            tran = CGAffineTransformRotate(tran, degreesToRadians(-90.0));
            break;

        case UIImageOrientationLeftMirrored:
            bnds.size = swapWidthAndHeight(bnds.size);
            tran = CGAffineTransformMakeTranslation(rect.size.height,
                                                    rect.size.width);
            tran = CGAffineTransformScale(tran, -1.0, 1.0);
            tran = CGAffineTransformRotate(tran, degreesToRadians(-90.0));
            break;

        case UIImageOrientationRight:
            bnds.size = swapWidthAndHeight(bnds.size);
            tran = CGAffineTransformMakeTranslation(rect.size.height, 0.0);
            tran = CGAffineTransformRotate(tran, degreesToRadians(90.0));
            break;

        case UIImageOrientationRightMirrored:
            bnds.size = swapWidthAndHeight(bnds.size);
            tran = CGAffineTransformMakeScale(-1.0, 1.0);
            tran = CGAffineTransformRotate(tran, degreesToRadians(90.0));
            break;

        default:
            // orientation value supplied is invalid
            assert(false);
            return nil;
    }

    UIGraphicsBeginImageContext(bnds.size);
    ctxt = UIGraphicsGetCurrentContext();

    switch (orient)
    {
        case UIImageOrientationLeft:
        case UIImageOrientationLeftMirrored:
        case UIImageOrientationRight:
        case UIImageOrientationRightMirrored:
            CGContextScaleCTM(ctxt, -1.0, 1.0);
            CGContextTranslateCTM(ctxt, -rect.size.height, 0.0);
            break;

        default:
            CGContextScaleCTM(ctxt, 1.0, -1.0);
            CGContextTranslateCTM(ctxt, 0.0, -rect.size.height);
            break;
    }

    CGContextConcatCTM(ctxt, tran);
    CGContextDrawImage(ctxt, rect, self.CGImage);

    copy = UIGraphicsGetImageFromCurrentImageContext();
    UIGraphicsEndImageContext();

    return copy;
}


@end