Lindsay Kay
OSArch Community Meetup, July 3, 2021
xeokit
Open Source
an
data:image/s3,"s3://crabby-images/e0f92/e0f928e5fc6c90be1a4f77b0458f30ee5a3654c0" alt=""
for
Graphics
&
BIM
AEC
data:image/s3,"s3://crabby-images/74563/7456372f003b8b1a45e98652e88288cde8968b49" alt=""
data:image/s3,"s3://crabby-images/1a5c5/1a5c52998c843cc3b1afcb3c3b614ff86faa058b" alt=""
data:image/s3,"s3://crabby-images/48823/488231c068fae08722d6c7cf50ef456462b7528b" alt=""
data:image/s3,"s3://crabby-images/347e6/347e68bba9f7967ab491307567bcb14a7e60d123" alt=""
Web Programming Toolkit
Viewing BIM in the browser is tricky!
data:image/s3,"s3://crabby-images/768f3/768f3d6d078e3fdc21061990d0afc5040974b3ca" alt=""
- Loading models quickly over the Web
- Control of tools and data
- Fitting them in browser memory
- Drawing them interactively
- Accurately viewing double-precision geometry on single-precision HW
Some challenges:
data:image/s3,"s3://crabby-images/51baa/51baa3ddd8a36c0dd2af0bdc37a2f4cf984848fa" alt=""
Introducing xeokit
Background Info
Tech Overview
Loading Big Models Fast
xeokit Background Info
- AGPL3 dual-licensed JavaScript SDK for developing browser-based 3D AEC model viewers
- Based on lessons learned from xeogl, SceneJS and various client projects since 2009
- Created in Feb 2019 by xeolabs
- Mission: code AEC viewers easily, load big models quickly, navigate them smoothly, host own code and data
- Creoox AG becomes xeokit's business partner in 2020: creoox.com
data:image/s3,"s3://crabby-images/1a5c5/1a5c52998c843cc3b1afcb3c3b614ff86faa058b" alt=""
data:image/s3,"s3://crabby-images/74563/7456372f003b8b1a45e98652e88288cde8968b49" alt=""
Introducing xeokit
data:image/s3,"s3://crabby-images/53459/53459e7f6dc62f856887e4baf07e1a2a35543296" alt=""
xeokit Tech Overview
- Views complex models at full-precision
- Loads models quickly from native XKT format
- Code, tools and models in your hands
const viewer = new Viewer({
canvasId: "myCanvas"
});
viewer.camera.eye = [0,0,100];
viewer.camera.look = [0,0,0];
viewer.camera.up = [-0, 1, 0];
const xktLoader =
new XKTLoaderPlugin(viewer);
const model = xktLoader.load({
src: "HolterTower.xkt"
});
- Custom WebGL 3D graphics engine with AEC-friendly programming API
- JavaScript viewer with plugins library
- Converters for IFC, CityJSON, 3DXML, LAZ glTF, DAE, STL, PCL ...
data:image/s3,"s3://crabby-images/51baa/51baa3ddd8a36c0dd2af0bdc37a2f4cf984848fa" alt=""
Introducing xeokit
Loading Big Models Fast
- XKT - xeokit's native, compact binary model format
- Quantized, tiled RTC vertex coordinates - double precision for 48 bits per vertex!
- Embedded metadata (eg. IFC structure)
- Convert your models to XKT using open source tools
- Compresses bulky source formats (eg. IFC) for quick transport and efficient loading
data:image/s3,"s3://crabby-images/51baa/51baa3ddd8a36c0dd2af0bdc37a2f4cf984848fa" alt=""
Introducing xeokit
Using xeokit
data:image/s3,"s3://crabby-images/b668b/b668b882218eb9a5d371d0c034312f3092b5a31e" alt=""
Converting a Model to XKT
Viewing an XKT Model with xeokit
Converting a Model to XKT
- More info: https://bit.ly/2ThmyCf
data:image/s3,"s3://crabby-images/b668b/b668b882218eb9a5d371d0c034312f3092b5a31e" alt=""
Use open source tools in a chain:
-
IfcConvert
-
COLLADA2GLTF
-
xeokit-metadata
-
gltf2xkt
Using xeokit
-
A fast, closed-source IFC converter is also available from Creoox: creoox.com
Converting a Model to XKT (2)
- More info: https://bit.ly/2ThmyCf
./IfcConvert -y --use-element-guids Duplex.ifc Duplex.dae
./COLLADA2GLTF-bin --materialsCommon -v -i Duplex.dae -o Duplex.gltf
./xeokit-metadata Duplex.ifc Duplex.json
./gltf2xkt -s Duplex.gltf -m Duplex.json -o Duplex.xkt
Using the open source CLI tools in Linux:
Using xeokit
Viewing an XKT model with xeokit
import {Viewer, XKTLoaderPlugin}
from "xeokit-sdk.es.js";
const viewer = new Viewer({
canvasId: "myCanvas"
});
viewer.camera.eye = [1842022, 10, -5173301];
viewer.camera.look = [1842022, 10, -5173401];
viewer.camera.up = [-0.0, 1.0, 0.0];
const xktLoader = new XKTLoaderPlugin(viewer);
const model = xktLoader.load({
src: "Schependomlaan.xkt"
});
data:image/s3,"s3://crabby-images/e482b/e482bd7c5dc68677f387de03258ce2fd1fb6ce6a" alt=""
IFC = 49.3 MB, XKT = 1.6M, loaded in 0.7 secs, 60 FPS
Using xeokit
data:image/s3,"s3://crabby-images/89146/89146322be8d6718d178c9118c9c429ffd4d06f6" alt=""
A Look Inside xeokit
Minimizing Memory Footprint
Drawing Many Objects Interactively
Rounding Jitter on WebGL
Eliminating Rounding Jitter
Navigating Precisely
Minimizing Memory Footprint
- Store geometry on GPU, not in browser
- Quantized RTC vertex positions, oct-encoded (optional) normals
- 48 bits per double-precision position, 16 bits per normal
A large plumbing model at BIMData.io
data:image/s3,"s3://crabby-images/1915e/1915e7ea8e6205281787e2b364f755993afe25a0" alt=""
Inside xeokit
Drawing Many Objects Interactively
data:image/s3,"s3://crabby-images/f702d/f702d06a49cd5febdfcbfe5209084dd700ce9576" alt=""
1. ANGLE_instanced_arrays
Two rendering techniques on WebGL:
2. Batched Geometry Arrays:
- Combine single-use geometries into a single set of VBOs
- Add an array of per-vertex flags, to hold object states
- Vertex shader "discards" vertex when visible flag false
- Update all vertex flags for an object to set its visibility
Inside xeokit
A Technical Hurdle - Rounding Jitter on WebGL
data:image/s3,"s3://crabby-images/ed8b5/ed8b5b73593e71260d2655bcd60f17cd8a054b69" alt=""
- GPUs are usually only single-precision, however
- Many BIM models use double-precision coordinates
-
Need to emulate double-precision rendering to eliminate rounding jitter
Model centered at (1842022, 10, -5173301), provided by BIMData.io
Inside xeokit
Solution - How we Eliminate Rounding Jitter
- Coords are 32-bit offsets from their 64-bit tile centers, rendered using modified view matrix
- Tiled, relative-to-center (RTC) coordinates
Read about RTC coordinates in virtualglobebook.com
data:image/s3,"s3://crabby-images/e246b/e246b4e06019ff46a419083cd6a40373dba7476b" alt=""
- Memory bonus: full-precision without the cost of storing double-precision values
Inside xeokit
data:image/s3,"s3://crabby-images/c882b/c882bc1ab1cf9d885f1192591796adcbbf4f2f90" alt=""
How we Navigate Precisely
- Distance-proportional rate of forward/backward movement
-
Ray-cast every n frames to find distance to nearest object, scale dolly and zoom rates accordingly
- Move fast in open spaces, move slow in tighter spaces
Inside xeokit
Who's using xeokit?
data:image/s3,"s3://crabby-images/77103/7710362f08bac71c7d5ee3fdabdd152dc88903f2" alt=""
data:image/s3,"s3://crabby-images/b442b/b442bbf36413a5f699272962188216be7de0a97b" alt=""
data:image/s3,"s3://crabby-images/44b62/44b629011cda543a3eaf6778b087627b3dd05f99" alt=""
data:image/s3,"s3://crabby-images/62131/62131d869008b7589027c32ad723bc32ad973d66" alt=""
data:image/s3,"s3://crabby-images/9f784/9f7847fc4f6087ad0e0a7c642d585fdbd497f92f" alt=""
data:image/s3,"s3://crabby-images/186e6/186e6dd84c572d1b4f7aa3fa8732abc4b4273961" alt=""
data:image/s3,"s3://crabby-images/1a5c5/1a5c52998c843cc3b1afcb3c3b614ff86faa058b" alt=""
data:image/s3,"s3://crabby-images/53ef1/53ef1d2336bfe5864c3852088c8f1cff177c858b" alt=""
data:image/s3,"s3://crabby-images/c43f4/c43f4a8b6eefefba82bb868aee0ec96e0e171cff" alt=""
data:image/s3,"s3://crabby-images/02cb0/02cb00b7e346c35877cade5ce4d3dd4defe9dbb3" alt=""
data:image/s3,"s3://crabby-images/fcb2e/fcb2e30d1ed462d99d1439d34a09d0a356b3ff6b" alt=""
data:image/s3,"s3://crabby-images/c50c0/c50c06c6687cfe85715aad099bcf387db630471c" alt=""
data:image/s3,"s3://crabby-images/951ab/951abdc8175642bfd31e0edbe23567cdd66f6fe4" alt=""
data:image/s3,"s3://crabby-images/cad03/cad03c278cc9de860252c04d85189123a18f2c46" alt=""
data:image/s3,"s3://crabby-images/e6d5c/e6d5c18041c10601a1d8267f6e8dcf11680fb20e" alt=""
data:image/s3,"s3://crabby-images/8ebad/8ebad6cb37d791efa7939e4059185a038cc76817" alt=""
data:image/s3,"s3://crabby-images/e5bcf/e5bcfd4840453a551a84e26d271bf17efb479056" alt=""
data:image/s3,"s3://crabby-images/505eb/505eb5ef2a68022b69064c0ef7312b3eb6227b0b" alt=""
data:image/s3,"s3://crabby-images/0a80e/0a80e5f290c23651e74461ce86aa4fa152fbade4" alt=""
data:image/s3,"s3://crabby-images/1acab/1acab5aa43dc875b98a7740b41560a4338c599b9" alt=""
data:image/s3,"s3://crabby-images/e4ad1/e4ad10e733fb1845b1845966911fa2584cdacd43" alt=""
data:image/s3,"s3://crabby-images/0b974/0b974f9523b15e632ed13f9b9b9da745bc5c1681" alt=""
- View multiple models
- Share issues via BCF
- Slice, highlight, X-ray
- Plan views
data:image/s3,"s3://crabby-images/62131/62131d869008b7589027c32ad723bc32ad973d66" alt=""
data:image/s3,"s3://crabby-images/44b62/44b629011cda543a3eaf6778b087627b3dd05f99" alt=""
Who's using xeokit?
- Great OSS community supporters - sponsors of many public xeokit features
- xeolabs clients since 2019
Who's using xeokit?
- Sponsors of several valuable open source xeokit features
Text
D-Studio
- Can't show apps yet - still under development!
data:image/s3,"s3://crabby-images/cb6a2/cb6a26d14e2256e82f44317e1918022ceb2bf1a4" alt=""
data:image/s3,"s3://crabby-images/417b9/417b956b985a4b08dfdf7e5cbce615ce013d623c" alt=""
- xeolabs client since 2019
-
Centralized BIM Data
-
Requirements Management
-
BIM Model Viewer
-
Rule-Based Quality Checks
-
Clash Detection
-
KPI Dashboard
-
Coordination & Reports
Who's using xeokit?
data:image/s3,"s3://crabby-images/8ebad/8ebad6cb37d791efa7939e4059185a038cc76817" alt=""
data:image/s3,"s3://crabby-images/ca363/ca363f8d602567cb8b2f92778c73a18736ac7d1d" alt=""
Text
-
Contributed IFC metadata tool and React integration boilerplate
- xeolabs client since 2017
- Originally used xeogl
- Moved to xeokit in 2019
Who's using xeokit?
data:image/s3,"s3://crabby-images/4c9f3/4c9f332dbc81519c5124cfff4ec336df090309b1" alt=""
- Supports xeokit with feature planning, bug fixes, and datasets for demos and testing
- Upload IFC models
- View in 3D
- Slice, highlight, X-ray
- Plan views
- Share BCF
- Model checker
- etc
Who's using xeokit?
data:image/s3,"s3://crabby-images/0a80e/0a80e5f290c23651e74461ce86aa4fa152fbade4" alt=""
- Using xeokit as the 3D front end for their Singular Qualifier IFC model checker tool
Who's using xeokit?
data:image/s3,"s3://crabby-images/e6d5c/e6d5c18041c10601a1d8267f6e8dcf11680fb20e" alt=""
data:image/s3,"s3://crabby-images/fd65c/fd65c16ae8df3ca70408d0479a867453756f3c7c" alt=""
Who's using xeokit?
data:image/s3,"s3://crabby-images/fcb2e/fcb2e30d1ed462d99d1439d34a09d0a356b3ff6b" alt=""
data:image/s3,"s3://crabby-images/fdebb/fdebbdce49bc1020b9d41b6b2d0895d840e8160d" alt=""
xeokit in Research: UMass Boston
-
3D Visualization of a Building
-
A semi-automatic pipeline to transform 2D floorplans to 3D models
-
Honors Senior Thesis Project
data:image/s3,"s3://crabby-images/48e14/48e14e4bea113b0bae61b2d5be75d6c2b05e7ddf" alt=""
data:image/s3,"s3://crabby-images/77103/7710362f08bac71c7d5ee3fdabdd152dc88903f2" alt=""
Who's using xeokit?
What's in the works for xeokit 2.0
- convert2xkt - Single-step multi-format XKT converter
- xeokit-bim-viewer-demo - BIM viewer boilerplate with batch model import, element property sets, BCF etc.
- Point clouds, CityJSON, object attributes, localization and more
- Performance test suite - measure conversion times, XKT sizes and load/render performance in all browsers
- WebGPU!
Big thanks to our supporters:
data:image/s3,"s3://crabby-images/61c14/61c14525421c79a1300d8cf6226b9ba77af871b1" alt=""
data:image/s3,"s3://crabby-images/cb6a2/cb6a26d14e2256e82f44317e1918022ceb2bf1a4" alt=""
D-Studio
data:image/s3,"s3://crabby-images/44b62/44b629011cda543a3eaf6778b087627b3dd05f99" alt=""
data:image/s3,"s3://crabby-images/4c9f3/4c9f332dbc81519c5124cfff4ec336df090309b1" alt=""
data:image/s3,"s3://crabby-images/8ebad/8ebad6cb37d791efa7939e4059185a038cc76817" alt=""
data:image/s3,"s3://crabby-images/0b974/0b974f9523b15e632ed13f9b9b9da745bc5c1681" alt=""
Sponsor of many public xeokit features, including xeokit-bim-viewer
Sponsor of various public xeokit features
Help with feature design, QA and data sets for demos
Contributed MIT-licensed IFC metadata extractor tool and a React boilerplate
Collaborated on the XKT model format
data:image/s3,"s3://crabby-images/1a5c5/1a5c52998c843cc3b1afcb3c3b614ff86faa058b" alt=""
xeokit's exclusive business partner
Thanks!
data:image/s3,"s3://crabby-images/1a5c5/1a5c52998c843cc3b1afcb3c3b614ff86faa058b" alt=""
data:image/s3,"s3://crabby-images/74563/7456372f003b8b1a45e98652e88288cde8968b49" alt=""
lindsay.kay@xeolabs.com
Copy of xeokit: A Web Programming Toolkit for BIM & Engineering Graphics
By xeolabs
Copy of xeokit: A Web Programming Toolkit for BIM & Engineering Graphics
A presentation for OSArch Meetup July 2021.
- 1,911