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