SlideShare a Scribd company logo
Pietro Grandi
@PietroGrandi3D
Demystifying the 3D Web
1 / 44
Pietro Grandi
Frontend dev at BetssonGroup
Working with WebGL since 2012
Born as 3D Artist
Hi!
2 / 44
Community
Khronos Chapter Milano
OTS WebGL workshop
NodeSchool WebGL workshop
Pietro Grandi
3 / 44
Why the web?
4 / 44
Web is everywhere
Desktop
Mobile
Wearable
Why the web?
5 / 44
Browser as environment for
applications
Fast JS interpreter
Standards
One stack, more platforms
Why the web?
6 / 44
Why WebGL?
7 / 44
WebGL
Native API
Porting of OpenGL ES 2.0
GPU access
Maintained by Khronos Group
Why WebGL?
8 / 44
Native API
Access through JavaScript
No plugin required
Context from canvas
Why WebGL?
9 / 44
OpenGL
Industry standard
Shader based pipeline
Khronos Group
Why WebGL?
10 / 44
The Khronos Group
Founded in January 2000
Including ATI, Intel, NVIDIA...
Creating open standard APIs for
rich media
Why WebGL?
11 / 44
Shaders
Define rules for visualization
Vertex shader for geometry
Fragment shader for pixels
Why WebGL?
12 / 44
Shaders
Take parameters
Compiled
Use GLSL 1.0
Why WebGL?
13 / 44
Shader pipeline
Link shaders
Load geometry data
Draw data
Why WebGL?
14 / 44
Immediate mode API
Scene is redrawn each time
No scene caching
Scene is managed by the
application
Why WebGL?
15 / 44
Support
All product names, logos, and brands are property of their respective owners.
Why WebGL?
16 / 44
Yet another JS
framework???
17 / 44
WebGL API offers
primitives
Points and connections
Triangles and connections
Colors
Textures
Why frameworks?
18 / 44
World is bigger
Polygons
Solids
Fluids
Materials
Why frameworks?
19 / 44
A trivial example
A red square in 52 lines
A red square in 21 lines
Why frameworks?
20 / 44
So, is there a killer
framework?
21 / 44
The biggest
ThreeJS
BabylonJS
OSGJS
SceneJS
Which framework?
22 / 44
ThreeJS
Developed for Flash
Community driven development
Game engine
MIT License
Which framework?
23 / 44
BabylonJS
Developed for Silverlight
Supported by Microsoft
Game engine
Apache license 2.0
Which framework?
24 / 44
OSGJS
Based on OpenSceneGraph
Used by Sketchfab
Rendering engine
MIT License
Which framework?
25 / 44
SceneJS
Rendering engine
Declarative approach
Used by BioDigital Human
Custom OSS License
Which framework?
26 / 44
What about 2D?
Shaders for 2D effects
GPU powered rendering
Filters
Texture blending
Not just 3D
27 / 44
PixiJS
Fast rendering engine
Support animations
WebGL blend and filters
Not just 3D
28 / 44
Cool.
Is someone REALLY using
it?
29 / 44
Google maps
Big data visualization
Draw vectors instead of tiles
Boost performances
Case study
30 / 44
Autodesk
A360 Viewer
Revit WebGL Publisher
Using ThreeJS
Formerly using Flash
Case study
31 / 44
Autodesk
API for developer
Convert models
Display 3D
Case study
32 / 44
Unity
WebGL target as of 5.3
Compiles to JS with Emscripten
Custom framework
Case study
33 / 44
Big companies spend
money.
Have you ever used it in
production?
34 / 44
Yes, I did it!
UI to navigate environments
Data visualization
Online 3D viewer
Me
35 / 44
Have you read Microsoft's
security report?
36 / 44
Graphics is weak
Real time calls for performances
Less checks
Buffer overflow, illegal memory
access, DOS
Security
37 / 44
Untrusted code
Web applications are not
installed
Giving hardware access can be
harmful
No control
Security
38 / 44
WebGL is not OpenGL
New allocated memory is zeored
Pixels outside framebuffer are
set to (0,0,0,0)
Array buffers have fixed size
Security
39 / 44
Unknown sources
Cross origin assets are forbidden
Only CORS validated resources
can be loaded
Security
40 / 44
Denial of service
OS can reset the GPU
GL_ARB_robustness has been
introduced
WebGL implementation could
detect GPU reset
Security
41 / 44
@PietroGrandi3D
pietrograndi.com
Thank you!
42 / 44
WebGL programming guide, Kouichi Matsuda
WebGL security, Khronos Group
WebGL considered harmful, Microsoft 2011
Unity WebGL updates, Jonas Echterhoff 2015
Step inside the map with Google MapsGL, Brian McLendon
2011
WWDC 2014, Apple
Announcing an updated version of Internet Explorer 11,
Microsoft 2014
References
43 / 44
Betsson Group
http://www.betssongroup.com/Jobs
We are hiring!
44 / 44

More Related Content

PDF
SQL o NoSQL? Progettare applicazioni 'Big Data-ready' attraverso l'utilizzo d...
PDF
NoSQL on the move
PPTX
Siligong.Data - May 2021 - Transforming your analytics workflow with dbt
PPTX
Why does Microsoft care about NoSQL, SQL and Polyglot Persistence?
PDF
Adobe Behance Scales to Millions of Users at Lower TCO with Neo4j
PDF
[WSO2Con EU 2018] Architecting for a Container Native Environment
PPTX
Closing Keynote
PPTX
Delivering Rich Content Applications at Scale with Nuxeo & MongoDB Atlas
SQL o NoSQL? Progettare applicazioni 'Big Data-ready' attraverso l'utilizzo d...
NoSQL on the move
Siligong.Data - May 2021 - Transforming your analytics workflow with dbt
Why does Microsoft care about NoSQL, SQL and Polyglot Persistence?
Adobe Behance Scales to Millions of Users at Lower TCO with Neo4j
[WSO2Con EU 2018] Architecting for a Container Native Environment
Closing Keynote
Delivering Rich Content Applications at Scale with Nuxeo & MongoDB Atlas

What's hot (20)

PDF
Nuxeo & React Native
PDF
Offline-First Mobile Web Apps with PouchDB, IBM Cloudant, and IBM Bluemix
 
PPTX
Dirigible powered by Orion for Cloud Development (EclipseCon EU 2015)
PDF
UI Dev in Big data world using open source
PPTX
Towards Digital Twin standards following an open source approach
PPTX
The building blocks for a reusable front end - #imaodbc2015
PPT
Genie Db
PDF
Using React.js to extend your CMS
PDF
Resume
PDF
Cloud-Native .Net des applications containerisées .Net sur Linux, Windows e...
PDF
H2O World 2017 Keynote - Jim McHugh, VP & GM of Data Center, NVIDIA
PDF
How Crosser Built a Modern Industrial Data Historian with InfluxDB and Grafana
PPTX
Quantifying Genuine User Experience in Virtual Desktop Ecosystems
PPT
Whitehorses Oracle OpenWorld 2010: Douwe Pieter van den Bos
PDF
CD in Machine Learning Systems
PDF
Documenting serverless architectures could we do it better - o'reily sa con...
PPTX
GraphDay Paris - Intro & Découverte de l'outil de visualisation Neo4j Bloom
PDF
(20.05.2009) Cumuy Presenta - Más tecnologías interesantes para conocer - PPT 2
PDF
Building Reactive Real-time Data Pipeline
PDF
GraphDay Paris - CAST IMAGING - Un IRM pour les systèmes IT complexes
Nuxeo & React Native
Offline-First Mobile Web Apps with PouchDB, IBM Cloudant, and IBM Bluemix
 
Dirigible powered by Orion for Cloud Development (EclipseCon EU 2015)
UI Dev in Big data world using open source
Towards Digital Twin standards following an open source approach
The building blocks for a reusable front end - #imaodbc2015
Genie Db
Using React.js to extend your CMS
Resume
Cloud-Native .Net des applications containerisées .Net sur Linux, Windows e...
H2O World 2017 Keynote - Jim McHugh, VP & GM of Data Center, NVIDIA
How Crosser Built a Modern Industrial Data Historian with InfluxDB and Grafana
Quantifying Genuine User Experience in Virtual Desktop Ecosystems
Whitehorses Oracle OpenWorld 2010: Douwe Pieter van den Bos
CD in Machine Learning Systems
Documenting serverless architectures could we do it better - o'reily sa con...
GraphDay Paris - Intro & Découverte de l'outil de visualisation Neo4j Bloom
(20.05.2009) Cumuy Presenta - Más tecnologías interesantes para conocer - PPT 2
Building Reactive Real-time Data Pipeline
GraphDay Paris - CAST IMAGING - Un IRM pour les systèmes IT complexes
Ad

Viewers also liked (20)

PDF
Distributed Companies: A WordPress.com Team Perspective - Davide Casali - Cod...
PDF
The rise and fall and rise of Virtual Reality - Adriaan Rijkens - Codemotion...
PPTX
React Native - Unleash the power of React in your device - Eduard Tomàs - Cod...
PDF
Living on the Edge (Service) - Mark Heckler - Codemotion Amsterdam 2016
PDF
Microsoft <3 Open Source: Un anno dopo!
PDF
Customize and control connected devices
PDF
Knowledge is Power: Getting out of trouble by understanding Git - Steve Smith...
PDF
Engage and retain users in the mobile world
PPTX
Welcome to Mordor - Daniel Kahn - Codemotion Amsterdam 2016
PDF
Software environmentalism - Tudor Girba - Codemotion Amsterdam 2016
PDF
Angular2 and Redux - up & running - Nir Kaufman - Codemotion Amsterdam 2016
PDF
OrientDB - the 2nd generation of (MultiModel) NoSQL - Luigi Dell Aquila - Cod...
PPTX
Sinfonier: How I turned my grandmother into a data analyst - Fran J. Gomez - ...
PDF
Maker Experience: user centered toolkit for makers
PDF
Death to Icon Fonts - Seren Davies - Codemotion Amsterdam 2016
PDF
F# for the curly brace developer - Michael Newton - Codemotion Amsterdam 2016
PDF
Boxcars and Cabooses: When one more XHR is too much - Peter Chittum - Codemot...
ODP
If security is hard, you are doing it wrong - Fabio Locati - Codemotion Amste...
PDF
Everything you always wanted to know about highly available distributed datab...
PDF
Microservices, the lean way - Bruno Bossola - Codemotion Amsterdam 2016
Distributed Companies: A WordPress.com Team Perspective - Davide Casali - Cod...
The rise and fall and rise of Virtual Reality - Adriaan Rijkens - Codemotion...
React Native - Unleash the power of React in your device - Eduard Tomàs - Cod...
Living on the Edge (Service) - Mark Heckler - Codemotion Amsterdam 2016
Microsoft <3 Open Source: Un anno dopo!
Customize and control connected devices
Knowledge is Power: Getting out of trouble by understanding Git - Steve Smith...
Engage and retain users in the mobile world
Welcome to Mordor - Daniel Kahn - Codemotion Amsterdam 2016
Software environmentalism - Tudor Girba - Codemotion Amsterdam 2016
Angular2 and Redux - up & running - Nir Kaufman - Codemotion Amsterdam 2016
OrientDB - the 2nd generation of (MultiModel) NoSQL - Luigi Dell Aquila - Cod...
Sinfonier: How I turned my grandmother into a data analyst - Fran J. Gomez - ...
Maker Experience: user centered toolkit for makers
Death to Icon Fonts - Seren Davies - Codemotion Amsterdam 2016
F# for the curly brace developer - Michael Newton - Codemotion Amsterdam 2016
Boxcars and Cabooses: When one more XHR is too much - Peter Chittum - Codemot...
If security is hard, you are doing it wrong - Fabio Locati - Codemotion Amste...
Everything you always wanted to know about highly available distributed datab...
Microservices, the lean way - Bruno Bossola - Codemotion Amsterdam 2016
Ad

Similar to Demistifying the 3D Web (20)

PPTX
Open Source and Windows Azure; A Match Made in Heaven
PDF
VR Workshop #1
PDF
Modern e2e-testing-for-complex-web-applications-with-cypressio
DOCX
summer file - Copy
PPTX
Android Web app
PPTX
Staying connected: An Overview of Announcements from Microsoft’s Connect();
PDF
JUNIPER: Towards Modeling Approach Enabling Efficient Platform for Heterogene...
PDF
GDSC NIET ORIENTATION ).pdf
PPTX
PittsburgJUG_Cloud-Native Dev Tools: Bringing the cloud back to earth
PDF
Containers & CaaS
PDF
Tampere Docker meetup - Happy 5th Birthday Docker
PDF
Agile Chennai 2023 | AI-Powered Agile : Transforming How We Deliver Extraordi...
ODP
OSGeo Live Lightening Overview
PPTX
Webinar by ZNetLive & Plesk- Winning the Game for WebOps and DevOps
PPTX
Jfokus_Bringing the cloud back down to earth.pptx
PPTX
Bahrain ch9 introduction to docker 5th birthday
PDF
Profiling Android Applications
PPTX
Docker Bday #5, SF Edition: Introduction to Docker
PPTX
Turku2017 recentdevelopments
PDF
What is WebRTC? What can I do with it?
Open Source and Windows Azure; A Match Made in Heaven
VR Workshop #1
Modern e2e-testing-for-complex-web-applications-with-cypressio
summer file - Copy
Android Web app
Staying connected: An Overview of Announcements from Microsoft’s Connect();
JUNIPER: Towards Modeling Approach Enabling Efficient Platform for Heterogene...
GDSC NIET ORIENTATION ).pdf
PittsburgJUG_Cloud-Native Dev Tools: Bringing the cloud back to earth
Containers & CaaS
Tampere Docker meetup - Happy 5th Birthday Docker
Agile Chennai 2023 | AI-Powered Agile : Transforming How We Deliver Extraordi...
OSGeo Live Lightening Overview
Webinar by ZNetLive & Plesk- Winning the Game for WebOps and DevOps
Jfokus_Bringing the cloud back down to earth.pptx
Bahrain ch9 introduction to docker 5th birthday
Profiling Android Applications
Docker Bday #5, SF Edition: Introduction to Docker
Turku2017 recentdevelopments
What is WebRTC? What can I do with it?

More from Codemotion (20)

PDF
Fuzz-testing: A hacker's approach to making your code more secure | Pascal Ze...
PDF
Pompili - From hero to_zero: The FatalNoise neverending story
PPTX
Pastore - Commodore 65 - La storia
PPTX
Pennisi - Essere Richard Altwasser
PPTX
Michel Schudel - Let's build a blockchain... in 40 minutes! - Codemotion Amst...
PPTX
Richard Süselbeck - Building your own ride share app - Codemotion Amsterdam 2019
PPTX
Eward Driehuis - What we learned from 20.000 attacks - Codemotion Amsterdam 2019
PPTX
Francesco Baldassarri - Deliver Data at Scale - Codemotion Amsterdam 2019 -
PDF
Martin Förtsch, Thomas Endres - Stereoscopic Style Transfer AI - Codemotion A...
PDF
Melanie Rieback, Klaus Kursawe - Blockchain Security: Melting the "Silver Bul...
PDF
Angelo van der Sijpt - How well do you know your network stack? - Codemotion ...
PDF
Lars Wolff - Performance Testing for DevOps in the Cloud - Codemotion Amsterd...
PDF
Sascha Wolter - Conversational AI Demystified - Codemotion Amsterdam 2019
PDF
Michele Tonutti - Scaling is caring - Codemotion Amsterdam 2019
PPTX
Pat Hermens - From 100 to 1,000+ deployments a day - Codemotion Amsterdam 2019
PPTX
James Birnie - Using Many Worlds of Compute Power with Quantum - Codemotion A...
PDF
Don Goodman-Wilson - Chinese food, motor scooters, and open source developmen...
PDF
Pieter Omvlee - The story behind Sketch - Codemotion Amsterdam 2019
PDF
Dave Farley - Taking Back “Software Engineering” - Codemotion Amsterdam 2019
PDF
Joshua Hoffman - Should the CTO be Coding? - Codemotion Amsterdam 2019
Fuzz-testing: A hacker's approach to making your code more secure | Pascal Ze...
Pompili - From hero to_zero: The FatalNoise neverending story
Pastore - Commodore 65 - La storia
Pennisi - Essere Richard Altwasser
Michel Schudel - Let's build a blockchain... in 40 minutes! - Codemotion Amst...
Richard Süselbeck - Building your own ride share app - Codemotion Amsterdam 2019
Eward Driehuis - What we learned from 20.000 attacks - Codemotion Amsterdam 2019
Francesco Baldassarri - Deliver Data at Scale - Codemotion Amsterdam 2019 -
Martin Förtsch, Thomas Endres - Stereoscopic Style Transfer AI - Codemotion A...
Melanie Rieback, Klaus Kursawe - Blockchain Security: Melting the "Silver Bul...
Angelo van der Sijpt - How well do you know your network stack? - Codemotion ...
Lars Wolff - Performance Testing for DevOps in the Cloud - Codemotion Amsterd...
Sascha Wolter - Conversational AI Demystified - Codemotion Amsterdam 2019
Michele Tonutti - Scaling is caring - Codemotion Amsterdam 2019
Pat Hermens - From 100 to 1,000+ deployments a day - Codemotion Amsterdam 2019
James Birnie - Using Many Worlds of Compute Power with Quantum - Codemotion A...
Don Goodman-Wilson - Chinese food, motor scooters, and open source developmen...
Pieter Omvlee - The story behind Sketch - Codemotion Amsterdam 2019
Dave Farley - Taking Back “Software Engineering” - Codemotion Amsterdam 2019
Joshua Hoffman - Should the CTO be Coding? - Codemotion Amsterdam 2019

Recently uploaded (20)

PDF
iTop VPN Free 5.6.0.5262 Crack latest version 2025
PDF
Internet Downloader Manager (IDM) Crack 6.42 Build 42 Updates Latest 2025
PDF
Autodesk AutoCAD Crack Free Download 2025
PPTX
Weekly report ppt - harsh dattuprasad patel.pptx
PDF
Designing Intelligence for the Shop Floor.pdf
PPTX
AMADEUS TRAVEL AGENT SOFTWARE | AMADEUS TICKETING SYSTEM
PDF
How to Make Money in the Metaverse_ Top Strategies for Beginners.pdf
PDF
AutoCAD Professional Crack 2025 With License Key
PPTX
Operating system designcfffgfgggggggvggggggggg
PPTX
Computer Software and OS of computer science of grade 11.pptx
PPTX
CHAPTER 2 - PM Management and IT Context
PDF
Internet Downloader Manager (IDM) Crack 6.42 Build 41
PDF
Salesforce Agentforce AI Implementation.pdf
PDF
Navsoft: AI-Powered Business Solutions & Custom Software Development
PDF
iTop VPN 6.5.0 Crack + License Key 2025 (Premium Version)
PDF
Complete Guide to Website Development in Malaysia for SMEs
PDF
Design an Analysis of Algorithms II-SECS-1021-03
PDF
iTop VPN Crack Latest Version Full Key 2025
PPTX
Agentic AI Use Case- Contract Lifecycle Management (CLM).pptx
PDF
Nekopoi APK 2025 free lastest update
iTop VPN Free 5.6.0.5262 Crack latest version 2025
Internet Downloader Manager (IDM) Crack 6.42 Build 42 Updates Latest 2025
Autodesk AutoCAD Crack Free Download 2025
Weekly report ppt - harsh dattuprasad patel.pptx
Designing Intelligence for the Shop Floor.pdf
AMADEUS TRAVEL AGENT SOFTWARE | AMADEUS TICKETING SYSTEM
How to Make Money in the Metaverse_ Top Strategies for Beginners.pdf
AutoCAD Professional Crack 2025 With License Key
Operating system designcfffgfgggggggvggggggggg
Computer Software and OS of computer science of grade 11.pptx
CHAPTER 2 - PM Management and IT Context
Internet Downloader Manager (IDM) Crack 6.42 Build 41
Salesforce Agentforce AI Implementation.pdf
Navsoft: AI-Powered Business Solutions & Custom Software Development
iTop VPN 6.5.0 Crack + License Key 2025 (Premium Version)
Complete Guide to Website Development in Malaysia for SMEs
Design an Analysis of Algorithms II-SECS-1021-03
iTop VPN Crack Latest Version Full Key 2025
Agentic AI Use Case- Contract Lifecycle Management (CLM).pptx
Nekopoi APK 2025 free lastest update

Demistifying the 3D Web