- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在尝试使用 FFMPEG.wasm 将 Canvas 动画转换为视频。这个想法是用 canvas.toDataURL()
生成一堆图像。然后将它们发送到节点服务器以生成视频。一切都与我从公共(public)目录中提取以进行测试的预上传图像完美配合,但是当我尝试发送使用 canvas.toDataURL()
创建的一堆(或单个)图像时我收到以下错误:
RuntimeError: abort(Error: ENAMETOOLONG: name too long, open 'data:image/png;base64, ...
我试图替换
canvas.toDataURL()
与
canvas.getContext('2d').getImageData()
,但这也无济于事。以下是我正在使用的剪切代码:
async function fetchData() {
const response = await fetch('/api/record-canvas', {
method: 'POST',
headers: { 'Content-Type': 'application/json' },
body: JSON.stringify({ image: here_goes_the_canvas_data }),
});
}
后端:
await ffmpeg.load();
ffmpeg.FS('writeFile', `001.png`, await fetchFile(image));
await ffmpeg.run('-loop', '1', '-i', '001.png', '-c:v', 'libx264', '-t', '30', '-pix_fmt', 'yuv420p', 'out.mp4');
await fs.promises.writeFile('out.mp4', ffmpeg.FS('readFile', 'out.mp4'));
上面的代码被简化为制作单个图像的视频,循环播放 30 秒。同样,它适用于预上传的图像,但不适用于 Canvas 数据。
最佳答案
对于那些遇到相同问题的人,这是我提出的解决方案:
dataURL
必须是 jpeg
(例如 canvas.toDataURL('image/jpeg')
)。 Buffer.from(image.split(',')[1], 'base64')
函数之前,您需要将其转换为 Buffer 值(例如 fetchFile
。关于javascript - 将 canvas.toDataURL() 传递给 ffmpeg.wasm 问题,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/70324936/
将多个值从 WebAssembly 传递到 Javascript 可能比需要的更难。通常,我发现我必须: 设置 Javascript 和 WebAssembly 之间共享的内存。 执行 WASM 工作
我正在构建一个 Flutter 网络应用程序。一切正常,直到随机进行了热重启,然后我开始收到此错误。 wasm streaming compile failed: TypeError: Could n
我想使用 python-ext-wasm 将 Rust 程序/项目编译为 Wasm,以便在我的 Python 应用程序中使用.现有的教程假定它是针对网络的并建议 wasm-pack .有没有另一种在没
脚步:cargo generate --git https://github.com/rustwasm/wasm-pack-template项目名称:project-name // src/lib.r
我正在处理 Rust WASM tutorial for Conway's game of life . 文件中最简单的函数之一叫做 Universe.render (它用于呈现代表游戏状态的字符串)
我有一个 WASM 函数,我想在我的以 WASM 为目标的 near-sdk Rust 项目中使用。我如何在我的 Rust 代码中调用这个函数? 最佳答案 您的情况还不够详细,无法给出详细的答案。 (
我正在尝试使用 Emscripten 作为学习机会将完整的 C++ 程序编译为 Wasm。以下命令确实生成了完整有效且有效的 HTML+JS+Wasm: emcc main.cpp [...libra
我正在尝试创建一个带有 Wasm 数据库层的 NodeJS 应用程序。我使用 Rust、Diesel 作为数据库驱动程序,使用 wasm-pack 作为 WebAssembly 编译器。 当我尝试使用
我正在尝试关注 Rust WebAssembly book我被困在第 4.2 节的练习中。我按照答案中的描述更改了所有内容,但是给定的 &str (姓名)在greet函数始终为空。 这是我的 gree
我在构建项目(Angular 8)时遇到上述错误。我们如何修复这个错误? 最佳答案 $env:NODE_OPTIONS = "--no-experimental-fetch" 在 Power shel
br_if 是如何工作的。我已经阅读了文档,但我没有找到任何关于 br_if 的结果值的信息。我用 WebAssembly Studio .我有这段代码,但我不明白为什么会这样。 (func $f (
我想创建一个 .wasm编译时仍具有导出的函数名称的文件。 package main import ( "fmt" ) func main() { fmt.Println("Main"
我有一个带有版本 5 程序集的 Blazor WASM 项目,并尝试根据这篇文章激活调试:https://docs.microsoft.com/en-us/aspnet/core/blazor/deb
我正在使用 Blazor WASM 开发简单的在线游戏。最近我发现 Blazor 客户端是单线程的,这对于我的大多数算法来说都是灾难性的。我想实现比权威服务器更好的架构,并能够在客户端运行代码(用于滞
由于 Wasm 是以非人类可读的形式编写的,这是否使黑客几乎不可能查看站点的 Wasm 文件并弄清楚是什么? 我知道在客户端保留敏感数据从来都不是最佳实践,但在代码模糊性方面,Wasm 似乎有点改变游
当我们将一个c源文件编译成wasm时,会有很多import "env"xxxx段。比如这是我的c源文件, char message[] = "hello wasm!"; char* getMessag
我有一个用 C++ 编写的项目,要部署的平台的二进制大小限制为 256KB。 工具链是wasi-sdk-16.0 clang++,我们使用这个编译器将源代码编译成WASM格式的二进制文件。在此步骤中,
已关注 Dynamically set the culture from the Accept-Language header本地化我的 blazor wasm 应用程序。 WebUI.csproj
我正在使用 vscode。我无法调试“独立”(或“托管”)blazor wasm。 有很多这样的问题,但它们是针对 RC、显然已为 .NET 6 修复的错误,或显然已在 SDK 6.0.102 中修复
我是 Rust 的新手,到目前为止我对它的设计感到惊讶。但是我遇到了一些让我害怕在商业项目中使用它的事情。 “Hello world”应用程序的可执行二进制文件大小为 3.2Mb。 -rwxr-xr-
我是一名优秀的程序员,十分优秀!