GDevelop / W3C Games Community
data:image/s3,"s3://crabby-images/b817b/b817b1993374754815ce948120267fd8093739ca" alt=""
đź‘‹
data:image/s3,"s3://crabby-images/d3722/d37223dd28b5dce24291ff9037f16e4c7ed8b457" alt=""
data:image/s3,"s3://crabby-images/7d857/7d85790c46a8d098b7c210d3b4a598c7589a89b1" alt=""
Clément
Florian
@FlorianRival
@ClementPasteau
data:image/s3,"s3://crabby-images/b817b/b817b1993374754815ce948120267fd8093739ca" alt=""
GDevelop in a few words
- "No-code" game creation platform
- Open-source engine
- Based on web technologies
- Game engine based on PixiJS
- Interface built with React
- Core logic written in C++, compiled to WebAssembly
data:image/s3,"s3://crabby-images/43da1/43da1d94bb882f2943af652328b6a0c5ed08dbb5" alt=""
data:image/s3,"s3://crabby-images/bdcac/bdcacf302f660902481389f2a947a6bc3604286a" alt=""
data:image/s3,"s3://crabby-images/61588/615887342fbed6dced833e739e47285b306e5400" alt=""
data:image/s3,"s3://crabby-images/8a574/8a5745be83ee8d59162690d70ecb5794bb48fa68" alt=""
data:image/s3,"s3://crabby-images/eb939/eb93960e725f1f2fe154676d378ec6d0a82e63f3" alt=""
data:image/s3,"s3://crabby-images/b817b/b817b1993374754815ce948120267fd8093739ca" alt=""
GDevelop in a few images
data:image/s3,"s3://crabby-images/ea9cb/ea9cbc95a004435459fe601fa769287a76b574ab" alt=""
data:image/s3,"s3://crabby-images/a7cfd/a7cfdcd7b837d0bfae418bb17fec28ac1e4380c1" alt=""
data:image/s3,"s3://crabby-images/b817b/b817b1993374754815ce948120267fd8093739ca" alt=""
React based interface
- The whole app is built on React (with Material-UI as a component library).Â
- Scalable and works well for an app like GDevelop!Â
data:image/s3,"s3://crabby-images/b817b/b817b1993374754815ce948120267fd8093739ca" alt=""
Typing
- We have a mix of TypeScript (game engine) and Flow type (editor).
- Saved our lives more than once!
- Considering migrating everything to TypeScript in the future - as long as we can run type checking separately from the transpilation.
data:image/s3,"s3://crabby-images/b817b/b817b1993374754815ce948120267fd8093739ca" alt=""
WebAssembly usage
- The core logic (how to represent a game, tools to generate code from a game, etc...) is written in C++
- Using Emscripten, we compile it to a WebAssembly library and use it directly.
data:image/s3,"s3://crabby-images/b817b/b817b1993374754815ce948120267fd8093739ca" alt=""
Our usage of PixiJS
- Started with PixiJS as a dual canvas/WebGL renderer (which was useful at the time) and very performant
- Great to see support of WebGL2 (and looking at how WebGPU will rise đź‘€)
- Mostly smooth experience (except for some hiccups on iOS)Â
data:image/s3,"s3://crabby-images/b817b/b817b1993374754815ce948120267fd8093739ca" alt=""
Pain points,
challenges, or things hard to deal with
data:image/s3,"s3://crabby-images/b817b/b817b1993374754815ce948120267fd8093739ca" alt=""
Storing data locally... and keeping it
- There are a few solutions to store data locally: Web Storage API (localStorage), IndexedDB.
- But it's always too easy for the user (or the browser) to just nuke everything without warnings.
- File System Access API seems a good solution... too bad it's not (yet?) usable everywhere (Firefox, Safari)
data:image/s3,"s3://crabby-images/b817b/b817b1993374754815ce948120267fd8093739ca" alt=""
Consistent performance
- Easy to fall out of the “happy path” of JS engine and get deoptimized.
- Some warnings are surfaced in debuggers... but overall we need to be cautious.
- Spector.js, Safari WebGL command inspector: we need more of these tools!
- Impact of garbage collection can vary across devices - no way to easily measure/trigger a GC.
- A "super strict"/"never slow" JavaScript mode would be awesome.
data:image/s3,"s3://crabby-images/b817b/b817b1993374754815ce948120267fd8093739ca" alt=""
iOS and web technologies
- At each new iOS version, something will break.
- We had some large performance regressions. Fixed by the folks at PixiJS (kudos!)
- Heard too many horrors stories to try too many new things (IndexedDB, PWA support) - iOS forces us to stay old school in our approach.
data:image/s3,"s3://crabby-images/b817b/b817b1993374754815ce948120267fd8093739ca" alt=""
Monetisation on the web and on mobile devices
- Is ads the only working solution for now?Â
- Started to look at web monetization
- Not sure if this getting any traction? Promises are a bit unclear to us.
Best solution seems still to package as a native app (Cordova) and publish/sell on app stores.
data:image/s3,"s3://crabby-images/b817b/b817b1993374754815ce948120267fd8093739ca" alt=""
Web games discovery
- Hard to get noticed (though that's true on app stores too)
- Some indie stores (Itch.io) can help.
- But also hard to do "remarketing" as limited push capabilities/no app installed by the user.
- Some companies are promoting HTML5 games (Poki, Google with Gamesnack)
Best solution seems still to package as a native app (Cordova) and publish/sell on app stores.
data:image/s3,"s3://crabby-images/b817b/b817b1993374754815ce948120267fd8093739ca" alt=""
This being said...
being based on web technologies allows us to be:
fast, agile, working (almost) everywhere
Thank you!Â
data:image/s3,"s3://crabby-images/b817b/b817b1993374754815ce948120267fd8093739ca" alt=""
deck
By Florian Rival
deck
- 1,147