-
Notifications
You must be signed in to change notification settings - Fork 802
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
WebAssembly build #4327
Comments
Hi @birkskyum There is no "hard" blocker. There is an implementation of GDAL in WebAssembly: https://github.com/bugra9/gdal3.js This gdal implementation is disabling curl, so it cannot use grid files. In the release of PROJ 9.6.0 (planned for March) there is an option to include the proj.db file embedded in the library. That would make it even easier. #4265 If you want to do it, please contact me. |
I don't know if it is usable at runtime, but I can say that the default build of proj:wasm32-emscripten succeeds in vcpkg. This is the list of dependencies (host: x64-linux):
|
thanks @dg0yt , that's great news! I think we can get this working, but as you point out it's hard to tell what runtime performance it'll have. It's probably easiest to just try it out and see what it brings. I'm still familiarizing myself a bit with the normal build pipeline ( I do have a build ), running tests ( few tests breaks still ) , running demos so the goal is clear - and then make an attempt at compiling it. |
I've had a version of this knocking around my computer for a year or two, and have gotten it quite close to release, but it's not 100% ready yet. I cleaned it up for initial proof-of-concept. It currently builds using emscripten, and works to allow for using a native version of PROJ on the JVM while falling back to WebAssembly using graalwasm when the native version isn't available for a platform. The framework for getting this to work on node is close, but there's still a few webpack issues I need to work through. I'll probably publish an initial build of this as a .jar to Maven Central for initial usage on the JVM, and aspire to get a first version posted to node soon. Any assistance getting the JS issues resolved would be much appreciated! |
More to the point -- if any want to help me get what I've got as step 3 working, it would be immensely helpful.
|
Your notes above solved the problem — the workaround for now is that I can build the git version, embed the database, and export it as a single file where the WASM is embedded in the js, thus no longer needing webpack. I can successfully load PROJ in js and call its C api, returning accurate results. I’ll get this cleaned up and pushed to my repo, with an npm package that at least provides the initial functions to create transforms from CRS and transform points accordingly. It would still be nice to eventually get this resolved so the WASM can be its own file without base64 expansion, but that is no longer a blocker. Thank you all! |
Additionally, an added benefit of piggybacking off of the native and graal bindings is that I can reuse all the logic for handling the PROJ contexts and pointer array expansions and object lifecycles, making it pretty seamless to abstract away all the C parts of PROJ behind the mechanisms of the JVM and JS VM so it still feels idiomatic here. |
NPM package is now available for testing: https://www.npmjs.com/package/proj-wasm |
Hi, I'm interested in a WebAssembly build of PROJ.
The intention is to mitigate differences across PROJ and proj4js, by simply running PROJ in the browser.
I'm curious if there are known blockers to this.
I've previously managed to make large C++ codebases run online as WebAssembly.
It's sometimes a bit slow still, but there're are all the time small performance gains coming from improved browser support for wasm, and improvements in emscripten to leverage it.
The text was updated successfully, but these errors were encountered: