我试图在我的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);

                });


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

最佳答案

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);
  }
}

关于javascript - Web上的TokBox订户快照,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/61107988/

10-11 03:27