声网 Fastboard SDK 是声网为帮助开发人员快速构建白板应用推出的新一代白板 SDK。Fastboard SDK 在互动白板 SDK 的基础上增加了 UI 实现,只需几行代码即可加入房间,并立即使用各种丰富的编辑工具体验实时互动协作;Fastboard SDK 还集成了窗口管理器 window-manager,方便开发者快速添加插件,轻松扩展白板应用的功能,丰富用户的协作体验。
本文介绍如何建立一个简单的项目,使用声网 Fastboard SDK 加入房间并即刻体验互动白板的功能。
下图展示了加入声网互动白板房间的基本流程:
当你的 app 客户端请求加入互动白板房间时:
createFastRoom
和 joinRoom
方法加入白板房间。在 app 客户端加入互动白板房间前,你需要在 app 服务端调用声网互动白板提供的 RESTful API 创建房间、获取 room UUID 和生成 room Token,并将 room UUID 和 room Token 传给 app 客户端。
调用互动白板服务端 RESTful API 创建一个房间。详见创建房间(POST)。
请求示例
你可以使用以下 Node.js 脚本发送请求:
request
模块。你可以运行 npm install request
安装。var request = require("request");
var options = {
"method": "POST",
"url": "https://api.netless.link/v5/rooms",
"headers": {
"token": "你的 SDK Token",
"Content-Type": "application/json",
"region": "cn-hz"
}
};
request(options, function (error, response) {
if (error) throw new Error(error);
console.log(response.body);
});
如果方法调用成功,声网互动白板服务端将返回新建房间的信息,其中的 uuid
是房间的唯一标识,app 客户端加入房间时需要传入该参数。
响应示例
{
"uuid": "4a50xxxxxx796b", // 房间的 UUID
"teamUUID": "RMmLxxxxxx15aw",
"appUUID": "i54xxxxxx1AQ",
"isRecord": true,
"isBan": false,
"createdAt": "2021-01-18T06:56:29.432Z",
"limit": 0
}
创建房间并获取新建房间的 uuid
后,你需要在 app 服务端生成 Room Token 并下发给 app 客户端。当 app 客户端加入房间时,声网互动白板服务端会使用该 Token 对其鉴权。
你可以通过以下方式在 app 服务端生成 Room Token:
下面以调用 RESTful API 的方式为例介绍如何生成 Room Token。
请求示例
你可以使用以下 Node.js 脚本发送请求:
request
模块。你可以运行 npm install request
安装。var request = require('request');
var options = {
"method": "POST",
// 将 <房间的 UUID> 替换成你的房间 UUID
"url": "https://api.netless.link/v5/tokens/rooms/<房间的 UUID>",
"headers": {
"token": "你的 SDK Token",
"Content-Type": "application/json",
"region": "cn-hz"
},
body: JSON.stringify({"lifespan":3600000,"role":"admin"})
};
request(options, function (error, response) {
if (error) throw new Error(error);
console.log(response.body);
});
如果方法调用成功,声网互动白板服务端将返回生成的 Room Token。
响应示例
"NETLESSROOM_YWs9XXXXXXXXXXXZWNhNjk" // Room Token
参照如下步骤获取最新版的 Fastboard iOS SDK:
在终端里进入项目根目录,并运行以下命令,在项目文件夹下创建一个 Podfile
文件:
pod init
打开 Podfile
文件,添加如下内容:
platform :ios, '10.0'
use_frameworks!
target 'ExampleFastboard' do
pod 'Fastboard'
end
在终端里运行以下命令安装 SDK:
pod install
安装成功后,项目文件夹下会生成一个 xcworkspace
文件,你可以打开该文件,对项目进行后续编辑。
使用 Fastboard SDK 加入白板房间的步骤如下:
Fastboard
类的 createFastRoom
创建 FastRoom
实例。FastRoom
实例的 view 添加到 viewController
并设置布局。FastRoomView
提供白板界面,并带有常用功能的 UI。FastRoom
类的 joinRoom
加入白板房间。调用 createFastRoom
创建 FastRoom
实例,需要通过 config
参数传入以下白板房间配置信息:
appIdentifier
:String。互动白板项目的 App Identifier。详见获取互动白板项目的安全密钥。roomUUID
:String。房间的 UUID,详见创建房间。toomToken
:String。用于鉴权的 Room Token。生成该 Room Token 使用的房间 UUID 必须和上面的房间 UUID 一致。详见生成 Room Token。region
:数据中心,必须和创建房间时设置的数据中心一致。userUID
:String。用户 UID,即用户的唯一标识符,字符串格式,长度不能超过 1024 字节。将 ViewController.swift
文件中的内容替换成如下代码:
import UIKit
// 导入 Fastboard SDK
import Fastboard
class ViewController: UIViewController {
// 定义 fastRoom 变量
var fastRoom: FastRoom!
override func viewDidLoad() {
super.viewDidLoad()
// 设置白板房间的参数
let config = FastRoomConfiguration(appIdentifier: "互动白板项目的 App Identifier",
roomUUID: "房间的 UUID",
roomToken: "房间的 Token",
region: .CN,
userUID: "用户 UID")
// 创建 FastRoom 实例
let fastRoom = Fastboard.createFastRoom(withFastRoomConfig: config)
// 添加 FastRoomView
view.addSubview(fastRoom.view)
// 加入房间
fastRoom.joinRoom()
self.fastRoom = fastRoom
}
// 设置 FastRoomView 的布局
override func viewDidLayoutSubviews() {
super.viewDidLayoutSubviews()
fastRoom.view.frame = view.bounds
}
}
在 Xcode 中编译并在模拟器或真机上运行项目。app 成功安装并启动后,你可以看到如下界面:
你可以选择左侧工具栏上的铅笔、文字或形状工具,在白板上写写画画;当前页面写满时,可以点击下方的 图标,新增页面,并使用箭头切换页面。
体验完带 UI 的白板功能后,你可以调用 Fastboard SDK 的 API 并自定义 UI,以实现插入图片、播放音视频、演示文档等功能。详见展示文件。