HTML5 live update

In a separate HTML5 application running in the browser (NOT Unity/UE4), is live update to the Studio supported? I seem to be able to initialize the system to enable liveupdate (the log says everything works fine), but connecting via Studio does not work (gives socketError).

Also, it’s kind of confusing to me how it would work, since HTML5 websockets (which the API probably uses) can’t ‘listen’ for connections on clientside, instead it can only initiate connections.

Do I need to follow any additional steps besides the ones outlined at https://www.fmod.com/resources/documentation-studio?page=editing-during-live-update.html#preparing-your-game-for-connection ?

If it isn’t supported for browser-side, would I get it to work in a NW.JS (which is node.js + DOM) application?

Hi ,
Live connect is not supported in HTML5 runtime of FMOD, as there is no appropriate socket API to allow this to happen that we are aware of (I seem to remember about hearing about web sockets but it wasnt supported on all browsers or something like this).

2 Likes

Thanks for the answer. My project is node.js based, i.e. locally I have access to the C API if need be, but I need to laboriously write writer wrappers to expose that stuff to node.js. Do you think there is any way to leverage the existing emscripten port to make this easier? I.e. only add the missing functionality (live updating, etc.) somehow.

Is this still an accurate statement? If so, could the API docs be updated to mention this? I thought I had a bug somewhere when trying to get this working on my project.

https://www.fmod.com/resources/documentation-api?version=2.1&page=studio-api-system.html#fmod_studio_initflags

We are looking into sockets and thread support required to make our live update system work but at this stage those features aren’t supported. We plan to update our documentation for our next release to make this clear.

It is still accurate now yes. I’m experimenting with it now but the involvement of threads and no dynamic memory growth means a significant change in requirements / setup for the developer.

upon further investigation, standard socket support is not supported on the web. A browser can connect to a ‘websocket’ (usually defined with ‘ws://url’, which is a different concept, so it means html5 cannot by default connect to an arbitrary address/port.

If a websocket server was set up , then html5 code can connect to it. This is what some html5 games would do.
Another way is to run a proxy server that forwards websockets to real ones, there is a package called websockify which could do that, ie https://github.com/novnc/websockify

Thanks for looking into this!

An update for this support.

  1. It needs pthread support enabled. This means SharedArrayBuffer support - https://caniuse.com/#feat=sharedarraybuffer shows that only certain browsers support this.
  2. You need to run a proxy application in the background (ie tools/websocket_to_posix_proxy/ in emscripten) to allow websocket data to be converted to socket data. We can supply this (I have bulit this for windows, not mac or linux, but it is open source). I have only got this to partially work.
  3. It would have to be a special build that is for development purposes only, mainly due to point #1.

If these things are ok we can release a version with this stuff included, though I have not got websocket_to_posix_proxy to work properly yet, it is only sending data in one direction. I am testing different browsers because it may be a browser support problem.

Hi! I still use this tool! Was this feature ever officially added?

What does the “toolchain” mean in your docs?:

“There are alternatives provided by our toolchain”: https://www.fmod.com/docs/2.01/api/platforms-html5.html

Hi,
We havent added this feature yet, while waiting for browsers to catch up. It looks like safari has sharedarraybuffer support now, so threads may at least be an option in the future.

our toolchain just means the FMOD API, but that particular doc should be updated to use consistent terminology so we can fix that.

Hello, are there any updates to this? We’d really like to use Live Updates via HTML5; for us it would be acceptable if it requires a special dev build with SharedArrayBuffer + a proxy running in the background or in a server somewhere, as long as we can make use of Live Updates during development at least.

we went pretty hard on the sharedarraybuffer/simd and pthread support last year, the browsers still weren’t ready (buggy/not supported everywhere). We will have to reevaluate this year at some time but its not high on our priority list.

Okay, thanks for the update, we appreciate it. For what is worth, today caniuse reports 94.92% support for SharedArrayBuffer [0] and 91.87% for SIMD [1], though we are not WebAssembly users so we can’t speak for their reliability. Pthreads support is also “considered stable” according to emscripten dot org [2].

[0] Shared Array Buffer | Can I use... Support tables for HTML5, CSS3, etc + [1] /wasm-simd
[2] Pthreads support — Emscripten 3.1.60-git (dev) documentation

Hello!

I’m looking to implement live updates for my web-based game using FMOD Studio. I can handle the byte stream and set up a proxy to resend data via WebSocket, but I’m unsure about the next steps. Specifically, how do I update the data on the client side of FMOD?

Additionally, is there any documentation available on the message protocol used by FMOD Studio? This feature is crucial for our company’s decision to use FMOD.

Thank you!

Hello,
The socket code on the FMOD Engine client side is stubbed out for HTML5, so i’m not sure having a websocket setup will help unfortunately for FMOD Engine to FMOD Studio Tool live update.