首页 > 解决方案 > 网络上的 TokBox 订阅者快照

问题描述

我正在尝试在我的 Web 应用程序中捕获订阅者的快照。

我想通过单击按钮捕获快照。

    var imgData = subscriber.getImgData();
    var img = document.createElement("img");
    img.setAttribute("src", "data:image/png;base64," + imgData);

    // Replace with the parent DIV for the img
    document.getElementById("containerId").appendChild(img);

这是他们在开发人员文件中提供的代码。没有任何关于如何实现它的描述。

现在我的问题是,如果我把它放在按钮 onClick 函数中,比如

    function capture(){

    }

它不会做任何事情,因为无法在 capture() 函数上获取订阅者值。

在以下不同功能中加入会话时,订阅者已经启动

    function initializeSession() {
          var session = OT.initSession(apiKey, sessionId);
          session.on('streamCreated', function streamCreated(event) {
                var subscriberOptions = {
                      insertMode: 'append',
                      width: '100%',
                      height: '100%'
                 };
           var subscriber = session.subscribe(event.stream, 'subscribers', subscriberOptions, handleError);

                });

如果有人可以帮助我,我如何在按钮单击时捕获快照。提前致谢。

标签: javascriptwebrtcopentoktokbox

解决方案


OpenTok 开发者倡导者在这里。

您需要修改代码以在initializeSession函数外部定义订阅者对象,如下所示:

var subscriber;
function initializeSession() {
  var session = OT.initSession(apiKey, sessionId);
  session.on('streamCreated', function streamCreated(event) {
    var subscriberOptions = {
      insertMode: 'append',
      width: '100%',
      height: '100%'
    };
    subscriber = session.subscribe(event.stream, 'subscribers', subscriberOptions, handleError);
  });
}

然后您可以像这样访问函数中的subscriber对象capture

function capture(){
  if (subscriber) {
    var imgData = subscriber.getImgData();
    var img = document.createElement("img");
    img.setAttribute("src", "data:image/png;base64," + imgData);

    // Replace with the parent DIV for the img
    document.getElementById("containerId").appendChild(img);
  }
}

推荐阅读