3D software developer at Creoox AG
Lindsay Kay
AEC Hackathon, Wroclaw, 5 October, 2024
Evolution
3D Visualization
of
data:image/s3,"s3://crabby-images/e0f92/e0f928e5fc6c90be1a4f77b0458f30ee5a3654c0" alt=""
in
Tracing the Path of the xeokit SDK
AEC
data:image/s3,"s3://crabby-images/48823/488231c068fae08722d6c7cf50ef456462b7528b" alt=""
data:image/s3,"s3://crabby-images/ed16d/ed16dadaca191bd02f88a073cb74c0682cc2f886" alt=""
data:image/s3,"s3://crabby-images/52bc7/52bc7a7f743237e15ed28cbc6abe1fd6a89af791" alt=""
JavaScript in the 90s / 2000s
xeokit.io
- JavaScript was fairly slow
data:image/s3,"s3://crabby-images/a1887/a1887612fab61ab20afc387099d63f1879816a98" alt=""
- Best for things like AJAX
- App logic in JS not considered a best practice
data:image/s3,"s3://crabby-images/46a91/46a91bed36ea2e37f6b36571bb2c4df3456f764a" alt=""
2000s: Learning Graphics Programming
- While learning graphics programming, perverse fun implementing algorithms in JavaScript and watching them struggle
- A fine example, in Oliver's JavaScript Raytracer: https://nerget.com/rayjs/rayjs.html
data:image/s3,"s3://crabby-images/ce153/ce153e95de088e1c042ee5882d460f4da102da97" alt=""
- However, notice the upgrades to Oliver's RayTracer over the past decade - Workers etc.
xeokit.io
data:image/s3,"s3://crabby-images/46a91/46a91bed36ea2e37f6b36571bb2c4df3456f764a" alt=""
2006: Created SceneJS
- My hobby JS engine: https://github.com/xeolabs/scenejs
- Working as a Java/JavaScript developer
SceneJS drew 3D wire frames using DIVs
data:image/s3,"s3://crabby-images/63b61/63b610be8292923493ecdcea9149288992b2fe01" alt=""
var scene = SceneJS.createScene({
nodes:[{
type:"material",
color: { r: 1, g: 1, b: 1 },
nodes:[{
type: "rotate",
id: "myRotate",
y: 1.0, angle: 0,
nodes: [{
type:"geometry/box"
}]
}]
}]
});
data:image/s3,"s3://crabby-images/46a91/46a91bed36ea2e37f6b36571bb2c4df3456f764a" alt=""
2006: SceneJS
var scene = SceneJS.createScene({
nodes:[{
type:"material",
color: { r: .3, g: .3, b: 1 },
nodes:[{
type: "rotate",
id: "myRotate",
y: 1.0,
angle: 0,
nodes: [{
type:"geometry/teapot"
}]
}]
}]
});
scene.getNode("myRotate",
function(myRotate) {
var angle = 0;
scene.on("tick",
function() {
myRotate.setAngle
(angle += .5);
});
});
SceneJS had a declarative scene graph definition inspired by VRML and other Human-readible formats
data:image/s3,"s3://crabby-images/46a91/46a91bed36ea2e37f6b36571bb2c4df3456f764a" alt=""
2006: Mozilla's Canvas 3D Experiments
- 2006: Vladimir Vukićević presents Canvas 3D experiment at Mozilla - a JS API on OpenGL ES
- 2007: I converted SceneJS to use Canvas 3D
data:image/s3,"s3://crabby-images/eed3e/eed3ea27eff61820c1fca471f3905411c30917d4" alt=""
- SceneJS is then rendering Gouraud shaded triangle meshes
- Pretty basic, but eye-catching to see in FireFox back then
xeokit.io
data:image/s3,"s3://crabby-images/46a91/46a91bed36ea2e37f6b36571bb2c4df3456f764a" alt=""
2007: "Is that actually running in the browser?"
- Hackers' first experiments on Canvas 3D made an impression
- Desktop graphics programmers surprised
- Graphics software companies start considering their Web 3D strategy (CAD, MedViz, gaming..)
- Graphics gurus explore WebGL and sharing on social media
- Classic algorithms adapted to WebGL appearing
xeokit.io
data:image/s3,"s3://crabby-images/46a91/46a91bed36ea2e37f6b36571bb2c4df3456f764a" alt=""
2009: We need to move our product into the browser
- CTOs: But which WebGL JavaScript library to use?
- In 2009, only a handful of WebGL libraries and developers exist
- Three.js not released until 2010
- A Web graphics programmer shortage
- Quit my Java / JavaScript job to develop SceneJS
- Bought a bunch of graphics textbooks and a decent GPU.
data:image/s3,"s3://crabby-images/46a91/46a91bed36ea2e37f6b36571bb2c4df3456f764a" alt=""
2010: BioDigital Human Migrates to SceneJS
- https://www.biodigital.com/
- A virtual Human body built on OpenSceneGraph / C++
- Our mission: rebuild on SceneJS, run everywhere
data:image/s3,"s3://crabby-images/b984e/b984e0fb7b40554b613f2cc3174ab445e4f49f5c" alt=""
data:image/s3,"s3://crabby-images/46a91/46a91bed36ea2e37f6b36571bb2c4df3456f764a" alt=""
2010: BioDigital Human Built on SceneJS
- Promising PoC - Skeleton at 15 FPS in FireFox, loaded from COLLADA
- WebGL still glitchy in some browsers
- Many learnings from using SceneJS in production - consequences of design
- Forked SceneJS for BioDigital Human - public and private forks
data:image/s3,"s3://crabby-images/a4379/a43791bf238cd07b8f3955f550256164a50d4dea" alt=""
data:image/s3,"s3://crabby-images/46a91/46a91bed36ea2e37f6b36571bb2c4df3456f764a" alt=""
2010: BioDigital Requirement #1 - Load Models Quickly
- SceneJS COLLADA loader too slow
- Instead, load JSON scene outlines, materials, quantized geometries etc. from an asset server
- Great resource - Zygote Body,originally created by Won Chun at Google: https://www.zygotebody.com/
xeokit.io
data:image/s3,"s3://crabby-images/46a91/46a91bed36ea2e37f6b36571bb2c4df3456f764a" alt=""
2010: BioDigital Requirement #2 - Navigate Models Fluidly
- How to draw thousands of objects at 30-60FPS?
- Minimize GL state changes, like OpenSceneGraph
- Scene graph -> display list compilation
- VBO geometry batching
- Inspirations from OSGJS: https://github.com/cedricpinson/osgjs
data:image/s3,"s3://crabby-images/55d3c/55d3c7aa240c3c7f4f44bbc06dfb1b22d3f25457" alt=""
- Minimize JS garbage collection
data:image/s3,"s3://crabby-images/46a91/46a91bed36ea2e37f6b36571bb2c4df3456f764a" alt=""
2010: More BioDigital SceneJS Requirements
- Physically-based materials
- Slicing Planes
- 3D picking
- Attaching 3D labels
- Highlighting, X-Ray
- VFX - Blur, video textures, animations, morphing etc.
data:image/s3,"s3://crabby-images/82490/8249051cc871f1752798150f78ae3eaa1a175134" alt=""
data:image/s3,"s3://crabby-images/fe17b/fe17bca1702ad166110c34042bfe61bf001833ea" alt=""
data:image/s3,"s3://crabby-images/46a91/46a91bed36ea2e37f6b36571bb2c4df3456f764a" alt=""
2011: MicroSoft Difficulties
- "WebGL Considered Harmful"
- https://msrc.microsoft.com/blog/2011/06/webgl-considered-harmful/
- A report on security vulnerabilities
- A tactic to buy time to catch up?
- Things got better when IE discontinued
- Edge is now the new weak link
xeokit.io
data:image/s3,"s3://crabby-images/46a91/46a91bed36ea2e37f6b36571bb2c4df3456f764a" alt=""
2015: SceneJS in BIMSurfer
data:image/s3,"s3://crabby-images/de52a/de52af84d06419245dbd0a2583275ea5feb755ac" alt=""
- SceneJS used in BIMSurfer V1
- BIMServer converts and stores IFC
- BIMSurfer loads model via binary stream
data:image/s3,"s3://crabby-images/46a91/46a91bed36ea2e37f6b36571bb2c4df3456f764a" alt=""
2015: SceneJS Learnings
- Defaults & training wheels were great to get started, but became redundant
- Wraps WebGL in a declarative and logically-oriented API
- Graphics students enjoyed it - used in some classrooms
- Engine has many layers, much complexity
- Not easy to extend and maintain
- Doesn't scale well to 10000+ objects
- For engineering viewers, needs a layer of classes on top
However:
xeokit.io
data:image/s3,"s3://crabby-images/46a91/46a91bed36ea2e37f6b36571bb2c4df3456f764a" alt=""
2015: Created xeogl
- Built on lessons learned from SceneJS
- Component architecture - "game objects"
var mesh = new xeogl.Mesh({
geometry: new xeogl.TeapotGeometry(),
material: new xeogl.MetallicMaterial({
baseColor: [1.0, 1.0, 1.0]
})
});
- https://xeogl.org/
data:image/s3,"s3://crabby-images/e29ed/e29ed8d5c8ce0da750c8e2ed8274a2b341a4cbaa" alt=""
- MIT License
data:image/s3,"s3://crabby-images/46a91/46a91bed36ea2e37f6b36571bb2c4df3456f764a" alt=""
2017: Built BIMData Viewer V1 on xeogl
- Bigger models, no streaming, loaded up-front
- glTF models with 300,000+ objects - pushing the limits of xeogl
data:image/s3,"s3://crabby-images/1915e/1915e7ea8e6205281787e2b364f755993afe25a0" alt=""
data:image/s3,"s3://crabby-images/46a91/46a91bed36ea2e37f6b36571bb2c4df3456f764a" alt=""
2019: Created xeokit
- Built on lessons learned from SceneJS and xeogl
- Objectives:
- Faster rendering
- Easier to extend (code smell refactoring)
- Use less memory
- Support double-precision geometry
- AGPL3 license
- Commercially sustainable
data:image/s3,"s3://crabby-images/d6397/d6397664536b7610ca0850cbb98b052c6dad0b64" alt=""
data:image/s3,"s3://crabby-images/46a91/46a91bed36ea2e37f6b36571bb2c4df3456f764a" alt=""
2024: xeokit SDK
- Partnered with Creoox in 2020
- Development sustained through custom enterprise licenses
- Still one of the only libraries to support double-precision
- Still among the fastest and most precise viewers
xeokit.io
data:image/s3,"s3://crabby-images/46a91/46a91bed36ea2e37f6b36571bb2c4df3456f764a" alt=""
2024: xeokit Differentiators (1)
data:image/s3,"s3://crabby-images/7385b/7385b6def822849fd6808520abff2c3f1c7f4ce1" alt=""
data:image/s3,"s3://crabby-images/10b41/10b4153d34b6215fe4477bab87c2709d3fb549c9" alt=""
xeokit
Others (AutoDesk etc)
- View real-world coordinates without rounding error ("jitter")
Real world 3D coordinate system
data:image/s3,"s3://crabby-images/46a91/46a91bed36ea2e37f6b36571bb2c4df3456f764a" alt=""
2024: xeokit Differentiators (2)
XKT: native compressed binary format
data:image/s3,"s3://crabby-images/d6397/d6397664536b7610ca0850cbb98b052c6dad0b64" alt=""
- CLI IFC->XKT model conversion tools
- Compress geometry
- Split models = smoother loading
- Quantized, tiled RTC vertex positions & oct-encoded normals
- 48 bits per position, 16 bits per normal
data:image/s3,"s3://crabby-images/46a91/46a91bed36ea2e37f6b36571bb2c4df3456f764a" alt=""
2024: xeokit Differentiators (3)
Cursor snap-to-primitive
- Devised by Toni Marti at Triba AG
data:image/s3,"s3://crabby-images/740a3/740a31f771b72b913c76da5c5547c222c6a46e8c" alt=""
- Makes accurate measurements possible / viable
data:image/s3,"s3://crabby-images/46a91/46a91bed36ea2e37f6b36571bb2c4df3456f764a" alt=""
2024: xeokit Differentiators (4)
Integrated semantic data model
- Loads IFC semantics into Viewer
data:image/s3,"s3://crabby-images/83008/8300813f31eb8b7fe5fc9710b41980815d624c9b" alt=""
- Classifies objects, useful for building explorer trees
data:image/s3,"s3://crabby-images/46a91/46a91bed36ea2e37f6b36571bb2c4df3456f764a" alt=""
2024: xeokit Differentiators (5)
View federated models
data:image/s3,"s3://crabby-images/d6397/d6397664536b7610ca0850cbb98b052c6dad0b64" alt=""
- Load multiple models
- Merge models into same explorer tree
- Merge split models
data:image/s3,"s3://crabby-images/46a91/46a91bed36ea2e37f6b36571bb2c4df3456f764a" alt=""
Thanks!
data:image/s3,"s3://crabby-images/46a91/46a91bed36ea2e37f6b36571bb2c4df3456f764a" alt=""
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 WebGL Meeting 2020, looking at how xeokit deals with some of the technical challenges involved with viewing large 3D BIM models in the browser.
- 89