共享文件管理包含上传文件和缓存文件两个部分。
当用户需要创建文件白板时,用户需要先将文件上传至 ZEGO 文件云服务,获得该文件的 fileID(将被永久保存并适用于所有房间)。
这个 file ID 将会在创建文件白板时使用,详情请参考 创建超级白板 - 创建白板。
建议您将文件的名称和 fileID 一一对应,以便快速访问。
ZEGO 超级白板支持客户端 API 和服务端 API 两种方式上传文件。
对于 ZEGO 超级白板 SDK 而言,文件可分为普通文件和 H5 文件。因此,当上传不同类型的文件时,需要调用不同的上传接口。
普通文件包含:
上传的文件必须满足相应的规范:
全部规范请参考 文件规范。
调用 uploadFile 方法上传普通文件。
//filePath 待上传文件的绝对路径,可以使用 iOS 系统API获得。
NSString *filePath = [[NSBundle mainBundle] pathForResource:@"test" ofType:@"pdf"];
//上传文件后转码后渲染模式类型,默认为ZegoDocsViewRenderTypeVector格式,如果用户涉及到 iOS、Web、Windows、Mac、小程序各端的业务,推荐使用 ZegoDocsViewRenderTypeVectorAndIMG 模式。
ZegoSuperBoardRenderType renderType = ZegoSuperBoardRenderTypeVectorAndIMG;
[[ZegoSuperBoardManager sharedInstance] uploadFile:filePath renderType:renderType completionBlock:^(ZegoSuperBoardUploadFileState state, ZegoSuperBoardError errorCode, NSDictionary * _Nonnull infoDictionary) {
if (errorCode == ZegoSuperBoardSuccess) {
if (state == ZegoSuperBoardUploadFileStateUpload) {
// 上传中...
NSNumber * upload_percent = infoDictionary[SUPER_BOARD_UPLOAD_PERCENT];
if (upload_percent.integerValue == 1){
/** 正在转码... */
}
} else if (state == ZegoSuperBoardUploadFileStateConvert){
/** 转换成功 */
NSString *fileID = infoDictionary[SUPER_BOARD_UPLOAD_FILEID];
}
} else {
/** 上传失败 */
}
}];
通过 ZegoUploadCustomH5Config 设置上传 H5 文件的配置参数,并调用 uploadH5File 方法上传 H5 文件。
//filePath 待上传文件的绝对路径,可以使用 iOS 系统API获得。
NSString *filePath = [[NSBundle mainBundle] pathForResource:@"test" ofType:@"zip"];
ZegoUploadCustomH5Config * config = [ZegoUploadCustomH5Config new];
config.pageCount = 2; // 页数
config.width = 960; // 页面的宽
config.height = 540; // 页面的高
config.thumbnailList = nil; //如果需要缩略图传入缩略图网址数组,如@[@"http://url1.jpg",@"http://url2.jpg"]
[[ZegoSuperBoardManager sharedInstance] uploadH5File:filePath config:config completionBlock:^(ZegoSuperBoardUploadFileState state, ZegoSuperBoardError errorCode, NSDictionary * _Nonnull infoDictionary) {
if (errorCode == ZegoSuperBoardSuccess) {
if (state == ZegoSuperBoardUploadFileStateUpload) {
// 上传中...
NSNumber * upload_percent = infoDictionary[SUPER_BOARD_UPLOAD_PERCENT];
if (upload_percent.integerValue == 1){
/** 正在转码... */
}
} else if (state == ZegoSuperBoardUploadFileStateConvert){
/** 转换成功 */
NSString *fileID = infoDictionary[SUPER_BOARD_UPLOAD_FILEID];
}
} else {
/** 上传失败 */
}
}];
调用客户端 API 接口上传文件的过程包含上传(ZegoSuperBoardUploadFileState.Upload)和格式转换 (ZegoSuperBoardUploadFileState.Convert)两个阶段。
{"upload_percent":0.50}
;当前上传 100%,则 "infoMap" 内容为 {"upload_percent":1.00}
。{"upload_fileid":"ekxxxxxxxxv"}
。服务端 API 仅支持上传普通文件,详情请参考服务端接口文档 请求文件转码。
当用户上传文件并获取文件的 fileID 之后,如需提高文件加载速度,可以在调用 ZegoSuperBoardManager 的 createFileView 接口创建文件白板之前,提前缓存该文件。
调用 cacheFileWithFileID 方法将文件缓存到本地。
//需要先定义记录缓存的 seq,取消缓存的时候会使用到
@property (nonatomic,assign) unsigned int cacheSeq;
//缓存指定文件
NSString * fileID = @"";//上传文件后获取的文件 ID
self.cacheSeq = [[ZegoSuperBoardManager sharedInstance] cacheFileWithFileID:fileID completionBlock:^(ZegoSuperBoardCacheState state, ZegoSuperBoardError errorCode, NSDictionary * _Nonnull infoDictionary) {
if (errorCode == ZegoSuperBoardSuccess) {
if (state == ZegoSuperBoardCacheStateCaching) {
NSNumber * download_percent = infoDictionary[SUPER_BOARD_CACHE_PERCENT];
// 缓存中..
} else if (state == ZegoSuperBoardCacheStateCached){
// 缓存成功
}
} else {
// 缓存失败
}
}];
调用 cancelCacheFileWithSeq 方法取消掉正在缓存的文件。
// 保存从调用 cacheFileWithFileID 接口返回的 seq值 self.cacheSeq
// 在取消缓存参数中用到
[[ZegoSuperBoardManager sharedInstance] cancelCacheFileWithSeq:self.cacheSeq completionBlock:^(ZegoSuperBoardError errorCode) {
NSString *msg;
if (errorCode == ZegoSuperBoardSuccess) {
//取消成功
} else {
//取消失败
}
}];
调用 queryFileCachedWithFileID 方法查询文件缓存是否存在。
// 通过 fileID 查询指定文件是否已缓存
[[ZegoSuperBoardManager sharedInstance] queryFileCachedWithFileID:fileID completionBlock:^(ZegoSuperBoardError errorCode, BOOL fileCached) {
if (errorCode == ZegoSuperBoardSuccess) {
// 查询成功
// fileCached 为YES 表示已缓存
// fileCached 为NO 表示为未缓存
}else{
//查询失败
}
}];
联系我们
文档反馈