Emscripten:提供下载/保存生成的 MEMFS 文件

标签 emscripten

我玩 emscripten 是为了好玩,并编译了我的一个旧模拟器程序以在浏览器中运行。

该程序将输出保存为数据文件,由于我没有做任何特别的事情,它应该驻留在 MEMFS(内存文件系统)上。

如何允许用户从 MEMFS 下载生成的文件?我可以触发浏览器的常规保存文件对话框吗?

最佳答案

知道了:

  • 在编译期间将 FS 添加到 EXTRA_EXPORTED_RUNTIME_METHODS。
  • $ emcc --bind -std=c++11 \
           -s EXTRA_EXPORTED_RUNTIME_METHODS=FS \
           -o main.js *.cpp 
    
  • 将下面的函数添加到 .html 或 .js 文件中。
  • function offerFileAsDownload(filename, mime) {
      mime = mime || "application/octet-stream";
    
      let content = Module.FS.readFile(filename);
      console.log(`Offering download of "${filename}", with ${content.length} bytes...`);
    
      var a = document.createElement('a');
      a.download = filename;
      a.href = URL.createObjectURL(new Blob([content], {type: mime}));
      a.style.display = 'none';
    
      document.body.appendChild(a);
      a.click();
      setTimeout(() => {
        document.body.removeChild(a);
        URL.revokeObjectURL(a.href);
      }, 2000);
    }
    
  • 在 postRun 上调用函数(选项 1):
  • <script>
    // This must go BEFORE sourcing main.js:
    var Module = {
      onRuntimeInitialized: () => {
        Module.postRun.push(() => offerFileAsDownload("filename.ext", "mime/type"));
      }
    };
    </script>
    <script src="main.js"></script>
    
  • 在 C++ 代码末尾调用函数(选项 2):
  • int main() {
      // ...
      emscripten::val::global("window").call<void>(
        "offerFileAsDownload",
        string("filename.ext"),
        string("mime/type")
      );
      // ...
    }
    

    关于Emscripten:提供下载/保存生成的 MEMFS 文件,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/54466870/

    相关文章:

    node.js - 试图让Emscripten在 Electron 中工作

    javascript - 使用 webpack 将 Wasm + JS 文件捆绑为一个

    c++ - 使用 emscripten 编译时,我该怎么做才能包含 <X11/Xlocale.h>?

    javascript - 未解析的符号 : llvm_trap from Emscripten

    javascript - 如何通过 emscripten 在 C++ 和 javascript 之间传递字符串

    javascript - 是否可以使用 emscripten 从 C++ 和 Javascript 打印字符串?

    javascript - 我怎样才能拥有类型的功能(arr : T[]) => T in C++ that compile to WebAssembly?

    c - 如何在 emscripten 编译库中读取用户指定的文件?

    html - 从 EMSCRIPTEN 访问 DOM

    c++ - 删除 "-s ONLY_MY_CODE=1"编译参数会导致 WebAssembly 程序中断