iOS开发-QLPreviewController与UIDocumentInteractionController显示文档

iOS开发-QLPreviewController与UIDocumentInteractionController显示文档

在应用中,我们有时想预览文件, 可以使用QLPreviewController与UIDocumentInteractionController

一、QLPreviewController与UIDocumentInteractionController

QLPreviewController是一个 UIViewController ,用于管理预览项的用户体验。

UIDocumentInteractionController

官方文档:UIDocumentInteractionController 一种视图控制器,用于预览、打开或打印应用程序无法直接处理的文件格式的文件。名字叫控制器,但却是继承自 NSObject。

二、实现预览显示文档

使用QLPreviewController与UIDocumentInteractionController预览显示文档

复制代码
#import "INDocumentPreviewViewController.h"
#import <QuickLook/QuickLook.h>

@interface INDocumentPreviewViewController ()<QLPreviewControllerDataSource, UIDocumentInteractionControllerDelegate>

@property (strong, nonatomic) QLPreviewController *previewController;
@property (copy, nonatomic) NSURL *fileURL; //文件路径
@property(nonatomic,strong) UIDocumentInteractionController * documentVC;

@end

@implementation INDocumentPreviewViewController

- (void)viewDidLoad {
    [super viewDidLoad];
    // Do any additional setup after loading the view.
    
    self.view.backgroundColor = [UIColor whiteColor];
    
    UIButton *shareBtn;
    shareBtn = [UIButton buttonWithType:UIButtonTypeCustom];
    shareBtn.frame = CGRectMake(50, 100, 200, 46);
    shareBtn.layer.cornerRadius = 4;
    shareBtn.backgroundColor = [UIColor brownColor];
    [shareBtn setTitle:@"QLPreviewController" forState:UIControlStateNormal];
    [shareBtn addTarget:self action:@selector(showQLPreview) forControlEvents:UIControlEventTouchUpInside];
    [self.view addSubview:shareBtn];
    
    UIButton *shareBtn2;
    shareBtn2 = [UIButton buttonWithType:UIButtonTypeCustom];
    shareBtn2.frame = CGRectMake(50, 200, 200, 46);
    shareBtn2.layer.cornerRadius = 4;
    shareBtn2.backgroundColor = [UIColor brownColor];
    [shareBtn2 setTitle:@"UIDocumentInteraction" forState:UIControlStateNormal];
    [shareBtn2 addTarget:self action:@selector(documentInteraction) forControlEvents:UIControlEventTouchUpInside];
    [self.view addSubview:shareBtn2];
    
    self.previewController  =  [[QLPreviewController alloc]  init];
    self.previewController.dataSource  = self;
}

- (void)showQLPreview {
    self.fileURL = [NSURL fileURLWithPath:[[NSBundle mainBundle]pathForResource:@"七牛实时音视频云白皮书.pdf" ofType:nil]];
    [self presentViewController:self.previewController animated:YES completion:nil];
    //刷新界面,如果不刷新的话,不重新走一遍代理方法,返回的url还是上一次的url
    [self.previewController refreshCurrentPreviewItem];
}


- (void)documentInteraction {
    self.fileURL = [NSURL fileURLWithPath:[[NSBundle mainBundle]pathForResource:@"七牛实时音视频云白皮书.pdf" ofType:nil]];
    NSURL *url = self.fileURL;

    self.documentVC = [UIDocumentInteractionController interactionControllerWithURL:url];
    self.documentVC.delegate = self;

    dispatch_async(dispatch_get_main_queue(), ^{
        BOOL b = [self.documentVC presentPreviewAnimated:YES];
    });
}

#pragma mark - QLPreviewControllerDataSource
-(id<QLPreviewItem>)previewController:(QLPreviewController *)controller previewItemAtIndex:(NSInteger)index {
    return self.fileURL;
}

- (NSInteger)numberOfPreviewItemsInPreviewController:(QLPreviewController *)previewController{
    return 1;
}

#pragma mark 代理方法
//为快速预览指定控制器
- (UIViewController*)documentInteractionControllerViewControllerForPreview:(UIDocumentInteractionController*)controller
{
    NSLog(@"%@",NSStringFromSelector(_cmd));
    return self;
}
 
//为快速预览指定View
- (UIView*)documentInteractionControllerViewForPreview:(UIDocumentInteractionController*)controller
{
    NSLog(@"%@",NSStringFromSelector(_cmd));
    return self.view;
}
 
//为快速预览指定显示范围
- (CGRect)documentInteractionControllerRectForPreview:(UIDocumentInteractionController*)controller
{
    NSLog(@"%@",NSStringFromSelector(_cmd));
    //    return self.view.frame;
    return CGRectMake(0, 0, self.view.frame.size.width, self.view.frame.size.height);
}

@end

三、小结

iOS开发-QLPreviewController与UIDocumentInteractionController显示文档。

学习记录,每天不停进步。

相关推荐
yingdonglan几秒前
Flutter 框架跨平台鸿蒙开发 ——AnimatedBuilder性能优化详解
flutter·性能优化·harmonyos
程序员清洒1 分钟前
Flutter for OpenHarmony:Icon 与 IconButton — 图标系统集成
前端·学习·flutter·华为
时光慢煮2 分钟前
打造跨端驾照学习助手:Flutter × OpenHarmony 实战解析
学习·flutter·华为·开源·openharmony
菜鸟小芯16 分钟前
【开源鸿蒙跨平台开发先锋训练营】DAY8~DAY13 底部选项卡&首页功能实现
flutter·harmonyos
b20772126 分钟前
Flutter for OpenHarmony 身体健康状况记录App实战 - 提醒设置实现
python·flutter·macos·cocoa·harmonyos
踏雪羽翼31 分钟前
android 图表实现
android·折线图·弹窗·图表·自定义图标
2601_949613021 小时前
flutter_for_openharmony家庭药箱管理app实战+药品详情实现
java·前端·flutter
有位神秘人1 小时前
Android中PopupWindow中如何弹出时让背景变暗
android
TheNextByte11 小时前
iPhone 与Android :有什么区别?
android·cocoa·iphone
xingfanjiuge1 小时前
Flutter框架跨平台鸿蒙开发——ListView.builder深度解析
flutter·华为·harmonyos