- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
在 this document ,它使用 URL.createObjectURL
设置视频源。 (这是接听电话的代码)。
var offer = getOfferFromFriend();
navigator.getUserMedia({video: true}, function(stream) {
pc.onaddstream = e => video.src = URL.createObjectURL(e.stream);
pc.addStream(stream);
pc.setRemoteDescription(new RTCSessionDescription(offer), function() {
pc.createAnswer(function(answer) {
pc.setLocalDescription(answer, function() {
// send the answer to a server to be forwarded back to the caller (you)
}, error);
}, error);
}, error);
});
URL.createObjectURL
的值是在应答者一侧生成的,它的事件取决于函数被调用的时间。如何使用它来获取远程视频流?
URL.createObjectURL
的结果看起来像 Blob :
http://some.site.com/xxxx-the-token-xxxx .有了这个字符串,视频组件如何知道在哪里加载远程流?是否有 {url:stream} 的哈希图存储在某处?如果是这样,视频组件如何访问hashmap?
stream.toURL
获得该字符串。 .但与
URL.createObjectURL
的结果不同.
URL.createObjectURL
的值取决于时间。如果你连续调用它两次,你会得到不同的值。
最佳答案
URL.createObjectURL(stream)
是一个黑客。停止使用它。正在努力中remove it .
使用 video.srcObject = stream
直接代替。它是标准的且实现良好。
本地资源的这种分配从一开始就不应该是 URL,并且是理解 WebRTC 如何工作的红鲱鱼。
WebRTC 是一种传输 API,直接将数据从一个对等方发送到另一个对等方。不涉及内容 URL。远程stream
您来自 onaddstream
是本地对象接收方,是传输的直播结果,准备播放。
您阅读的文档已经过时且过时。谢谢指出,我会改正的。它还有其他问题:您应该立即调用 setRemoteDescription,而不是等待接收者共享他们的相机,否则会错过传入的候选人。代替您显示的代码,请执行以下操作:
pc.onaddstream = e => video.srcObject = e.stream;
function getOfferFromFriend(offer) {
return pc.setRemoteDescription(new RTCSessionDescription(offer))
.then(() => navigator.getUserMedia({video: true}))
.then(stream => {
pc.addStream(stream);
return pc.createAnswer();
})
.then(answer => pc.setLocalDescription(answer))
.then(() => {
// send the answer to a server to be forwarded back to the caller (you)
})
.catch(error);
}
srcObject
, 避免了已弃用的回调 API,并且不会导致间歇性 ICE 故障。
关于webrtc - 为什么WebRTC远程视频源是URL.createObjectURL生成的,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/41798731/
从 Firefox 开发者网站,我知道 Firefox 使用 objectURL = window.URL.createObjectURL(file); 获取文件类型的 url,但在 chrome 和
我正在尝试从后端将 PDF 加载为 JavaScript 中的 blob,但收到 Failed to execute 'createObjectURL' on 'URL': Overload reso
我正在使用以下 javascript 创建对象 url,唯一的问题是加载 url blob:http:///mysite.com/randomhash 文件已损坏。 var audioFile = n
我想将 window.URL.createObjectURL(file) 创建的地址传递给 dancer.js 但我得到 GET blob:http%3A//localhost/b847c5cd-aa
我想读取生成的图像并将其发送到服务器。 此代码生成图像。 var xhr = new XMLHttpRequest(); xhr.onreadystatechange = function(){
下面是我的代码的屏幕截图: 最佳答案 我认为这只是外壳,请尝试vendorURL.createObjectURL(stream) URL.createObjectURL() 关于javascript
URL.createObjectURL(event.target.files[0] this makes me able to view the image just uploaded in the
我正在做一些Ajax调用,以从服务器接收一些Blob。我想使用URL.createObjectURL()方法在浏览器上显示它。根据docs,它必须接受一个对象。 我需要帮助,如何在PHP中将其作为对象
我正在尝试使用 URL.createObjectURL 显示图像。但是,它占用的内存非常大,大约是图像大小的 10 倍。这是我的代码: var image = new Image(); image.s
我知道使用 mediaSource 是可行的,但媒体源不支持所有视频格式(例如片段 mp4)。这是一个问题,因为我的应用程序没有可以修复文件的服务器。它只是一个客户端应用程序。 const blob
我的目标是拥有一个表单,该表单将 URL 提交到一个端点,该端点返回一个 PDF 的 base64 编码,该 PDF 显示在屏幕上没有 window.open 弹出窗口. 我想要的示例输出:https
我想弄清楚是我的代码有问题还是当前的 HTML5 文件 API 实现有问题。 下面的代码有效。在已经加载图像一次后重复该过程时会出现该错误。 第二次选择文件时,图像 blob 加载,然后闪烁,图像消失
我只是好奇如何获取包裹在 URL.createObjectURL 中的数据。 所以我写了下面的代码。 function typedArrayToURL(typedArray, mimeType) {
我正在使用 JavaFX 8 嵌入式 WebView。我想从 Blob 图像构建 Blob URL。但是, URL.createObjectURL 给了我未定义的信息。有没有什么方法(垫片或例如)在
我了解 window.URL.createObjectURL 创建的对象的生命周期与文档相关联。有什么方法可以更改目标文档吗? 我正在开发一个 chrome 扩展程序,我面临的问题是创建的 DOMSt
我正在构建一个在线 csv 转换器,允许用户上传 csv 文件并下载处理后的 csv 输出文件。一切正常,除了下载文件的名称看起来像“6fd665aa-74d7-4b4e-96e1-38aea0cca
我有这个加载文件功能,可以在上传后加载图像。我想转换以获取其 URL 路径...但是我收到错误“URL.createObjectURL 不是函数”但是当我控制 e.target .files[0],我
我正在尝试下载并显示 iFrame 内远程文件的内容,并且在除 IE 之外的所有浏览器中均成功(我正在尝试使用 IE 10)。我使用了 XMLHttpRequest、Blob、CreateOBject
我正在尝试在 Javascript 中创建一个 blob 来提供一个文件。但是,window.URL.createObjectURL(blob) 创建的链接会随着时间的推移而失效。我希望能够生成一个链
我正在开发一个网络应用程序,每个人都可以直接在互联网上编辑图像。 在开发网站时,我遇到了打开本地系统文件的大问题。 通常,我们可以使用如下两种已知的方式来做到这一点。 首先,使用FileReader。
我是一名优秀的程序员,十分优秀!