声网 Fastboard SDK 支持在白板中插入和展示多种形式的文件,例如图片、音视频和文档,帮助用户快速分享丰富多元的信息,创造沉浸式的互动体验。
本文介绍如何调用 Fastboard SDK 的 API 插入图片、演示文档和播放音视频。
声网 Fastboard SDK 提供 insertImg
方法,用于在白板主窗口中插入并展示图片。你只需调用该方法,并传入图片的 URL、宽和高,即可在白板上展示指定图片。
开始前,请确保满足以下条件:
下面在加入白板房间的示例项目基础上添加代码,展示如何在白板中插入一张图片。
在 ViewController.swift
文件中,用如下代码替换 fastRoom.joinRoom()
:
fastRoom.joinRoom() {
// 调用 insertImg 并传入图片的 URL 和尺寸
fastRoom.insertImg(URL(string: "https://test.aliyuncs.com/cloud-storage/2022-xx/15/e3xxda.png")!,
imageSize: .init(width: 100, height: 100))
}
运行项目。app 重启后,可以在白板页面看到插入的图片。
声网 Fastboard SDK 集成了内置插件 MediaPlayer,用于播放音视频文件。你只需调用 Fasdboard SDK 的 insertMedia
方法,传入音视频文件的 URL 地址和窗口标题,即可在白板子窗口中播放音视频。
开始前,请确保满足以下条件:
下面在加入白板房间的示例项目基础上添加代码,展示如何在白板中插入并播放音视频文件。
在 ViewController.swift
文件中,用如下代码替换 fastRoom.joinRoom()
:
fastRoom.joinRoom(){
// 调用 insertMedia 并传入音视频文件的 URL 和子窗口标题
fastRoom.insertMedia(URL(string: "https://test.aliyuncs.com/cloud-storage/2022-xx/15/52xxx37.mp4")!,
title: "test1.mp4",
completionHandler: nil)
}
运行项目。app 重启后,可以在白板页面上看到名为 test1.mp4 的子窗口,点击开始按钮,即可播放视频。
声网 Fastboard SDK 集成了内置插件 DocsViewer,用于展示文档。成功使用声网文档转服务完成文档转换后,只需调用 Fasdboard SDK 的 insertPptx
或 insertStaticDocument
方法,并传入转换后的文件信息,即可在白板子窗口中分页演示文档。
开始前,请确保满足以下条件:
具体实现步骤如下:
uuid
,即文档转换任务的 Task UUID。uuid
,为文档转换任务生成一个 Task Token。convertedFileList
参数的值。insertPptx
或 insertStaticDocument
方法,并传入如下参数:pages
:转换后的文件信息。你需要自行将 convertedFileList
转换为 WhitePptPage
数组。title
:窗口标题。completionHandler
:方法调用结果回调。传入 nil
,表示不注册回调。下面在加入白板房间的示例项目基础上添加代码,展示如何插入并展示一个带动画效果的 PPTX 文件。
成功完成了动态文档转换,并调用查询转换任务进度 API 获取了转换后的文件信息。
在 ViewController.swift
文件中添加如下行,导入 Whiteboard SDK:
import UIKit
import Fastboard
// 导入 Whiteboard SDK
import Whiteboard
在 ViewController.swift
文件中,用如下代码替换 fastRoom.joinRoom()
:
fastRoom.joinRoom(){
// 将文档转换结果中 convertedFileList 的值定义为 jsonStr 变量
let jsonStr =
"""
[{
"width": 1280,
"height": 720,
"conversionFileUrl": "pptx://convertcdn.netless.link/dynamicConvert/3ce728e0954f11ec997c6580ac31fd96/1.slide",
"preview": "https://convertcdn.netless.link/dynamicConvert/3ce728e0954f11ec997c6580ac31fd96/preview/1.png"
},
{
"width": 1280,
"height": 720,
"conversionFileUrl": "pptx://convertcdn.netless.link/dynamicConvert/3ce728e0954f11ec997c6580ac31fd96/2.slide",
"preview": "https://convertcdn.netless.link/dynamicConvert/3ce728e0954f11ec997c6580ac31fd96/preview/2.png"
},
{
"width": 1280,
"height": 720,
"conversionFileUrl": "pptx://convertcdn.netless.link/dynamicConvert/3ce728e0954f11ec997c6580ac31fd96/3.slide",
"preview": "https://convertcdn.netless.link/dynamicConvert/3ce728e0954f11ec997c6580ac31fd96/preview/3.png"
}]
"""
// 将 jsonStr 转换为 WhitePptPage 数组
let dic = try! JSONSerialization.jsonObject(with: jsonStr.data(using: .utf8)!) as! [[String: Any]]
let pages = dic.map { item -> WhitePptPage in
let url = item["conversionFileUrl"] as? String
let pre = item["preview"] as? String
let w = item["width"] as? Int
let h = item["height"] as? Int
return WhitePptPage(src: url!, preview: pre!, size: .init(width: w!, height: h!))
}
// 调用 insertPptx 插入文档
fastRoom.insertPptx(pages, title: "演示文档")
return
}
运行项目。app 重启后,可以在白板页面上看到名为演示文档的子窗口,点击切页箭头,即可分页演示文档。