代码之家  ›  专栏  ›  技术社区  ›  zakdances

ThreeJS视频纹理需要CORS头,即使<video>标记不需要它

  •  0
  • zakdances  · 技术社区  · 6 年前

    我有一个本地主机web服务器,它运行一个页面,在 <video> 标签。视频播放正确。好的,太好了。现在我想用这个视频作为一个纹理在一个3JS画布(使用 THREE.VideoTexture ). 但3rejs没有显示视频,而是开始重复打印

    THREE.WebGLState: DOMException: Failed to execute 'texImage2D' on 'WebGLRenderingContext': The video element contains cross-origin data, and may not be loaded.

    无限循环。

    我的视频真的需要CORS头设置只有在一个3ejs画布?如果是,为什么?我该怎么解决?

    1 回复  |  直到 6 年前
        1
  •  1
  •   Quentin    6 年前

    我的视频真的需要CORS头设置只有在一个3ejs画布?

    对。

    如果是,为什么?

    当您希望JavaScript从另一个源读取数据时,CORS是必需的(而不是简单地让浏览器在JavaScript不接触数据的情况下呈现数据)。

    使用它作为纹理时,需要读取视频数据并使用JavaScript进行处理。

    我该怎么解决?

    配置要从中提取视频的服务器,以授予您使用CORS的权限,或移动数据,使其位于同一源。