-
Notifications
You must be signed in to change notification settings - Fork 289
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
[DISCUSSION] What are some ways to run xeokit apps offline? #958
Comments
We did a bit of offline at BIMData. If we're in an environment allowing to run a local webserver (eg: Electron), running a web server serving files is easy. We don't know well iOS and Android, there are probably many other (and better) possibilities. |
i don't think, that its a good idea to define use cases or solutions depending on the used medium (chrome, pwa, etc). i think xeokit-sdk as a package should be take in considiration that it can be used in any framework/library (that uses js/ts). |
In our company, we consume xeokit-sdk in different ways: from a React Native app, from a Xamarin app, and from a React app. The "classic approach" when consuming xeokit-sdk from native mobile apps (RN, Xamarin, whatever...) is to consume it from inside a WebView (how else would you run JS code from an Android or iOS project?), then mechanisms like what you @Amoki mention are the the way to go: you just intercept requests done by the JS side and serve them locally, even foward the requests to some other API. As you tell @assaad97, xeokit-sdk is a component that can just be consumed in different ways, and you seem to suggest to have a "catalog" of best-practices when consuming it. The use case that starts this thread refers to the fact that JS doesn't provide a "user defined storage", either for models or viewpoints. And this is just what depends heavily on the consuming side: xeokit-sdk provides the 3D viewing stuff, whereas the consuming part has control on how to serve and models and provide the persistent state used by xeokit-sdk 🙂 With all this, maybe a collection of sample projects using xeokit-sdk could be a good starting point, such as:
|
Hi @tmarti, |
Hello @lindenthal! The experience is good so far. Some problems in the past with the VRAM usage but recent optimizations in xeokit made it much better. Our apps are on the stores but you need some user account in Interaxo (a SaaS product line from Tribia AS company, where I work), so not “publicly usable”. The considerations in the mobile are the ones described in this thread: stick to a webview and intercept certain custom-protocol URL’s for data passing between the native app code and the webview. |
What are some ways to run xeokit apps offline?
How to build a xeokit app for mobile devices, that can load models and save BCF viewpoints etc, at locations where a network is not available?
This is an open issue, where we might discuss techniques for building offline apps on xeokit.
Use Case
AFAIK I don't think we can use browser storage for (2) because the models will be too big. (3) could be done by running the JS in a container that provides file I/O hooks, or by serving HTTP pages locally and maybe feeding them data through a socket from a local file server process of some sort. Some thoughts below...
Limit of xeokit scope
Loading models with HTTP GETs is the only network activity that the xeokit SDK does. All other network
activity (eg. loading and saving BCF viewpoints) is the responsibility of the application layer, which is
outside the scope of xeokit. in other words, xeokit is a viewer SDK only, that only uses the network for loading models, using HTTP by default.
Accordingly, xeokit's BCFViewpointsPlugin, which captures and restores Viewer state to and from BCF JSON viewpoints, does not manage the actual persistence or transmission of those JSON viewpoints - it just transfers them in and out of the Viewer component.
The snippet below shows how we can inject custom data access objects into xeokit's loader plugins, which might be used to make a xeokit application load models off the file system and meet (2), if file system hooks were somehow available to the DAOs to use.
Run an example of custom loader DAOs here.
That doesn't solve saving and loading BCF of course.
Some Possibilities
Electron
While Electron itself does not natively support iOS development, it can be used to create applications for macOS, Windows, and Linux. I'm not sure, but perhaps it could load XKT files from the iOS file system?
Chrome+Node Running Locally
We could run an app locally on the device using nodejs. The app would:
Chrome Embedded Framework
CEF allows us to embed a xeokit viewer in an app built in (at least) Java, python, .Net and Go. Essentially it provides a Javascript execution container with most standard browser APIs, that runs inside the Java/python/Net/Go environment, with hooks into that environment for things like file I/O. The app layer would manage the I/O as mentioned earlier, while possibly configuring the xeokit loader plugins with a custom DAO that hooks into the container's I/O.
Perhaps just build a CEF container in python that provides the I/O hooks for loading the models and saving/loading BCF?
Resources
The text was updated successfully, but these errors were encountered: