@dougsillars
Augmented Reality on the Web:
Building an ARt Gallery
Doug Sillars
July 11, 2019
FullStack London
@dougsillars
Contact Me:
@DougSillars
Doug.Sillars@gmail.com
www.dougsillars.com
Doug Sillars
Freelance Developer Relations
Performance Audits: Web/Native
Workshops:
Performance/Images/Video/AR
http://bit.ly/HighPerformanceAndroidApps
Virtual Reality
Virtual Reality
https://www.flickr.com/photos/68158920@N08/17742136272
Virtual Reality
Virtual Reality
Augmented Reality
Augmented Reality
Augmented Reality
• Wearing fancy occulus with cameras
• Really $$$
Augmented Reality –
Smartphone
https://www.flickr.com/photos/bellemarematt/28124392062
https://www.flickr.com/photos/bagogames/28628142444
Augmented Reality –
Smartphone
https://www.flickr.com/photos/bellemarematt/28124392062
https://www.flickr.com/photos/bagogames/28628142444
AR/VR- in the Browser
• What we can do today
• What is coming tomorrow
AR/VR- in the browser
• What we can do today
• A-Frame
• https://aframe.io
• https://github.com/dougsillars/ARtGallery
AR/VR- in the browser
• What we can do today
• A-Frame
• https://aframe.io
• https://github.com/dougsillars/ARtGallery
VR with A-Frame
https://dougsillars.github.io/ARtGallery/aframeHW.html
VR with A-Frame
https://dougsillars.github.io/ARtGallery/aframeHW.html
VR with A-Frame
https://dougsillars.github.io/ARtGallery/aframeHW.html
VR with A-Frame
https://dougsillars.github.io/ARtGallery/aframeHW.html
VR with A-Frame
https://dougsillars.github.io/ARtGallery/aframeHW.html
Building a Gallery
https://dougsillars.github.io/ARtGallery/aframeroom.html
VR ART
https://dougsillars.github.io/ARtGallery/aframeroomart.html
VR ART
https://dougsillars.github.io/ARtGallery/justart.html
Front Wall
VR ART
https://dougsillars.github.io/ARtGallery/justart.html
Front Wall
2m up
VR ART
https://dougsillars.github.io/ARtGallery/justart.html
VR Art Animation
https://dougsillars.github.io/ARtGallery/justart1.html
VR More Art
https://dougsillars.github.io/ARtGallery/aframeroomart2.html
VR More Art
https://dougsillars.github.io/ARtGallery/aframeroomart2.html
VR More Art
https://dougsillars.github.io/ARtGallery/aframeroomart2.html
Add a Ceiling
https://dougsillars.github.io/ARtGallery/sistine.html
Add a Ceiling
https://dougsillars.github.io/ARtGallery/sistine.html
Add a Ceiling
https://dougsillars.github.io/ARtGallery/sistine.html
<a-cylinder position="0 4 4"
rotation="0 90 90"
radius="4"
height="16"
theta-start="0"
theta-length="180"
src="#sistine"
side="double">
</a-cylinder>
GLTF Models
GLTF Models
VR Models Are Large
We won’t forget optimization!!
AR with A-Frame
We’ll use AR.js to add AR functionality to the page
3D objects are placed with Markers:
AR Markers
http://bit.ly/ARHiro
AR Markers
Create Your Own Markers
https://jeromeetienne.github.io/AR.js/three.js/examples/mark
er-training/examples/generator.html
Creates an image to print and tape to
the wall.
Creates a .patt pattern file for the
browser
AR Markers
Create Your Own Markers
https://jeromeetienne.github.io/AR.js/three.js/examples/mark
er-training/examples/generator.html
Creates an image to print and tape to
the wall.
Creates a .patt pattern file for the
browser
AR Markers
Create Your Own Markers
AR Markers to Create A Scene
https://dougsillars.github.io/ARtGallery/ARt.html
Optimisations for AR/VR
• Images are integral to the view – we want them to load quickly
Optimisations for AR/VR
• Reduce File Size
Optimisations for AR/VR
• Reduce File Size
• Resize images (to power of 2)
https://res.cloudinary.com/dougsillars/image/upload/h_1024/v1552460601/
VanGogh-starry_night_qoohur.jpg
Optimisations for AR/VR
Optimisations for AR/VR
Optimisations for AR/VR
• Optimize Quality
https://res.cloudinary.com/dougsillars/image/upload/h_1024,
q_auto,/v1552460601/VanGogh-starry_night_qoohur.jpg
Optimisations for AR/VR
• Optimize Format
https://res.cloudinary.com/dougsillars/image/upload/h_1024,
q_auto,f_auto/v1552460601/VanGogh-
starry_night_qoohur.jpg
Optimisations for AR/VR
• Optimize Format
https://res.cloudinary.com/dougsillars/image/upload/h_1024,
q_auto,f_auto/v1552460601/VanGogh-
starry_night_qoohur.jpg
Optimisations for AR/VR
• Optimize Format
https://res.cloudinary.com/dougsillars/image/upload/h_1024,
q_auto,f_auto/v1552460601/VanGogh-
starry_night_qoohur.jpg
1.8 MB -> 323 KB
Optimisations for AR/VR
• Optimize Format
https://res.cloudinary.com/dougsillars/image/upload/h_512,
q_auto,f_auto/v1552460601/VanGogh-
starry_night_qoohur.jpg
1.8 MB -> 93 KB
Optimisations for GLTF
Draco Compression optimizes .bin files
AR with WEBXR
AR with WEBXR
• All WebXR Demos require:
• Android 8.0+
• Chrome Canary v70-72 (late 2018)
• Flags enabled:
• WebXR Device API
• WebXR Hit Test
• ARCore installed
Protip:
If using WebXR a lot, prevent Canary
from auto-updating in Play Store
WEBXR Hit Test
https://codelabs.developers.google.com/codelabs/ar-with-webxr/#4
WEBXR Hit Test
https://dougsillars.github.io/ar-with-
webxr/WebXrARt/
Optimisations for WebXR
1024X1024 1024X1025
https://res.cloudinary.com/dougsillars/image
/upload/x_230,y_128,w_512,h_512,c_crop/
w_256/v1552682248/stabilization_yegbkb.gi
f
850 KB -> 174 KB
Optimisations for aGIF
Optimisations for PNG
https://res.cloudinary.com/dougsillars/image/upl
oad/q_auto,w_256/c_crop,w_256,h_256/v15526
82248/Anchor_rzjbco.png
• Optimise quality, shrink to 256
KB wide
• Crop to 256x256
• 36 KB -> 2.2 KB
Loading WEbXR Art Gallery (Optimized)
Conclusions
• AR on the web is available today with A-Frame
• AR with Hit Points is coming
• AR does not have to be processor intensive, nor utilize huge
amounts of data
Setup
• https://github.com/dougsillars/ARtGallery
git clone https://github.com/<username>/ARtGallery
Seeing your Code
GitHub Account No GitHub Account
Details:
https://gist.github.com/jgravois/5e73b56fa7756fd00b89
Seeing your Code
Local Webserver
python -m SimpleHTTPServer 1337
In Browser: Localhost:1337
Let’s build!
• Art Files you can use:
• https://res.cloudinary.com/dougsillars/image/upload/w_1000/v1551634938/scream_qbwybi.jpg
• https://res.cloudinary.com/dougsillars/image/upload/w_1000/v1551634946/monalisa_nlcskz.jpg
• https://res.cloudinary.com/dougsillars/image/upload/w_1000/v1551634942/Mural_del_Gernika_s9ld
ah.jpg
• https://res.cloudinary.com/dougsillars/image/upload/v1552460601/VanGogh-
starry_night_qoohur.jpg
• https://res.cloudinary.com/dougsillars/image/upload/v1553694737/CAPPELLA_SISTINA_Ceiling_oosz
7w.jpg
• https://res.cloudinary.com/dougsillars/image/upload/v1553694758/last_supper_hykuux.jpg
• https://res.cloudinary.com/dougsillars/image/upload/v1553694762/The_Nightwatch_kkzvus.jpg
• Try: Sketchfab.com for 3D Models
Links
Code: https://github.com/dougsillars/ARtGallery
https://github.com/dougsillars/ar-with-webxr
WebXR spec: https://www.w3.org/TR/2019/WD-webxr-20190205/
Cloudinary: https://cloudinary.com
Love Building with Video and Images?
Media Developer Expert
mde-comm@cloudinary.com
Become a

More Related Content

PPTX
A rt gallery webcamp-zg
PPTX
ARt gallery sligo
PPTX
A rt gallery gdgcork
PPTX
A rt gallery gdgkarlsruhle
PPTX
A rt gallery tallinn
PPTX
A rt gallery devfestlondon
PPTX
A rt gallery limerick-galway
PPTX
A rt gallery gdgbelfast
A rt gallery webcamp-zg
ARt gallery sligo
A rt gallery gdgcork
A rt gallery gdgkarlsruhle
A rt gallery tallinn
A rt gallery devfestlondon
A rt gallery limerick-galway
A rt gallery gdgbelfast

What's hot (18)

PPTX
A rt gallery cardiff
PPTX
A rt gallery oredev
PPTX
A rt gallery pyconweb
PPTX
ARt gallery tartu
PPTX
A rt gallery vilnius-gdg
PPTX
A rt gallery gdgmadrid
PPTX
ARt gallery vilniusjs
PPTX
A rt gallery hague-rotterdamfrontend
PPTX
ARt gallery workshop
PPTX
A rt gallery coding-serbia_novisad
PPTX
A rt gallery hub387
PPTX
ARt gallery
PPT
Annie leibovitz
PPTX
Free Microsoft Apps
ZIP
Adaptive Mobile UX Design
PPTX
Responsive web design
PPTX
Socially Responsible Design - Why, What, How
PPTX
The Art + Science Marketing - Gianluca Diegoli - #FMX18
A rt gallery cardiff
A rt gallery oredev
A rt gallery pyconweb
ARt gallery tartu
A rt gallery vilnius-gdg
A rt gallery gdgmadrid
ARt gallery vilniusjs
A rt gallery hague-rotterdamfrontend
ARt gallery workshop
A rt gallery coding-serbia_novisad
A rt gallery hub387
ARt gallery
Annie leibovitz
Free Microsoft Apps
Adaptive Mobile UX Design
Responsive web design
Socially Responsible Design - Why, What, How
The Art + Science Marketing - Gianluca Diegoli - #FMX18
Ad

Similar to A rt gallery london-fullstack (19)

PPTX
A rt gallery pantalks
PDF
SWONtech News for May, 2012
PPTX
OSCAL: Free and Open Source Tools for Image and Video Performance
PPTX
Hackference
PPTX
Don't be a Digital Dinosaur - Design for the Space Between
PPTX
Reading gdg images
PPT
Agile Intro + Learning Game
KEY
Bitrzr - Ignite Portugal Tecnológico
PPTX
PyconUK: Fast and Beautiful Images
PPTX
Oggcamp Fast and Beautiful Images
PPTX
Turin webperf meetup
PPTX
The Future of Design isn't Just the Web - WebVisions 2011 Workshop
PPTX
Don't a Digital Dinosaur - Web 2.0 2011
PPTX
Milano ux
PDF
Maximising the opportunities of the online marketplace (South Australia)
PDF
A Potpourri Of Web Tools
PPTX
Edi react fastandbeautiful
PDF
Developing for Mobile
PPTX
Create Successful Cross Channel Experiences - IA Summit 2011
A rt gallery pantalks
SWONtech News for May, 2012
OSCAL: Free and Open Source Tools for Image and Video Performance
Hackference
Don't be a Digital Dinosaur - Design for the Space Between
Reading gdg images
Agile Intro + Learning Game
Bitrzr - Ignite Portugal Tecnológico
PyconUK: Fast and Beautiful Images
Oggcamp Fast and Beautiful Images
Turin webperf meetup
The Future of Design isn't Just the Web - WebVisions 2011 Workshop
Don't a Digital Dinosaur - Web 2.0 2011
Milano ux
Maximising the opportunities of the online marketplace (South Australia)
A Potpourri Of Web Tools
Edi react fastandbeautiful
Developing for Mobile
Create Successful Cross Channel Experiences - IA Summit 2011
Ad

More from Doug Sillars (20)

PPTX
Fastandbeautiful belfast
PPTX
Fastandbeautiful gdg sacremento
PPTX
Fastandbeautiful gd glittlerock
PPTX
Fastandbeautiful webinale
PPTX
Ai powered images-pythonljubjana
PPTX
Fastandbeautiful zagrebtechsauna
PPTX
Video js zagreb
PDF
Vkmdp cologne
PPTX
Ai powered images-gdgtirana
PPTX
Ai powered images-sarajevo
PPTX
Ai powered images-zurichpydata
PPTX
Fastandbeautiful vienna
PPTX
Ai powered images-opieaivienna
PPTX
Fastandbeautiful devfest london
PPTX
Ai powered images-mobileera
PPTX
Fastandbeautiful oredev
PPTX
Qa fest kiev_when its just too slow
PPTX
Armadajs video
PPTX
Fastandbeautiful novi sad
PPTX
Belgrade when its just too slow
Fastandbeautiful belfast
Fastandbeautiful gdg sacremento
Fastandbeautiful gd glittlerock
Fastandbeautiful webinale
Ai powered images-pythonljubjana
Fastandbeautiful zagrebtechsauna
Video js zagreb
Vkmdp cologne
Ai powered images-gdgtirana
Ai powered images-sarajevo
Ai powered images-zurichpydata
Fastandbeautiful vienna
Ai powered images-opieaivienna
Fastandbeautiful devfest london
Ai powered images-mobileera
Fastandbeautiful oredev
Qa fest kiev_when its just too slow
Armadajs video
Fastandbeautiful novi sad
Belgrade when its just too slow

Recently uploaded (20)

PPTX
Modernising the Digital Integration Hub
PDF
ENT215_Completing-a-large-scale-migration-and-modernization-with-AWS.pdf
PDF
Getting started with AI Agents and Multi-Agent Systems
PPTX
Chapter 5: Probability Theory and Statistics
PDF
sbt 2.0: go big (Scala Days 2025 edition)
PDF
Enhancing emotion recognition model for a student engagement use case through...
PPTX
MicrosoftCybserSecurityReferenceArchitecture-April-2025.pptx
PPTX
Configure Apache Mutual Authentication
PDF
Consumable AI The What, Why & How for Small Teams.pdf
PDF
Taming the Chaos: How to Turn Unstructured Data into Decisions
PDF
Flame analysis and combustion estimation using large language and vision assi...
PDF
TrustArc Webinar - Click, Consent, Trust: Winning the Privacy Game
PDF
NewMind AI Weekly Chronicles – August ’25 Week III
PPT
Geologic Time for studying geology for geologist
PDF
How ambidextrous entrepreneurial leaders react to the artificial intelligence...
PDF
Abstractive summarization using multilingual text-to-text transfer transforme...
PDF
CloudStack 4.21: First Look Webinar slides
PPTX
AI IN MARKETING- PRESENTED BY ANWAR KABIR 1st June 2025.pptx
PDF
Produktkatalog für HOBO Datenlogger, Wetterstationen, Sensoren, Software und ...
PDF
A Late Bloomer's Guide to GenAI: Ethics, Bias, and Effective Prompting - Boha...
Modernising the Digital Integration Hub
ENT215_Completing-a-large-scale-migration-and-modernization-with-AWS.pdf
Getting started with AI Agents and Multi-Agent Systems
Chapter 5: Probability Theory and Statistics
sbt 2.0: go big (Scala Days 2025 edition)
Enhancing emotion recognition model for a student engagement use case through...
MicrosoftCybserSecurityReferenceArchitecture-April-2025.pptx
Configure Apache Mutual Authentication
Consumable AI The What, Why & How for Small Teams.pdf
Taming the Chaos: How to Turn Unstructured Data into Decisions
Flame analysis and combustion estimation using large language and vision assi...
TrustArc Webinar - Click, Consent, Trust: Winning the Privacy Game
NewMind AI Weekly Chronicles – August ’25 Week III
Geologic Time for studying geology for geologist
How ambidextrous entrepreneurial leaders react to the artificial intelligence...
Abstractive summarization using multilingual text-to-text transfer transforme...
CloudStack 4.21: First Look Webinar slides
AI IN MARKETING- PRESENTED BY ANWAR KABIR 1st June 2025.pptx
Produktkatalog für HOBO Datenlogger, Wetterstationen, Sensoren, Software und ...
A Late Bloomer's Guide to GenAI: Ethics, Bias, and Effective Prompting - Boha...

A rt gallery london-fullstack

Editor's Notes

  • #16: https://dougsillars.github.io/ARtGallery/aframeHW.html
  • #17: https://dougsillars.github.io/ARtGallery/aframeHW.html
  • #18: https://dougsillars.github.io/ARtGallery/aframeHW.html
  • #19: https://dougsillars.github.io/ARtGallery/aframeHW.html
  • #20: https://dougsillars.github.io/ARtGallery/aframeHW.html
  • #21: https://dougsillars.github.io/ARtGallery/aframeHW.html
  • #22: https://dougsillars.github.io/ARtGallery/aframeroomart.html
  • #23: https://dougsillars.github.io/ARtGallery/aframeroomart.html
  • #24: https://dougsillars.github.io/ARtGallery/aframeroomart.html
  • #25: https://dougsillars.github.io/ARtGallery/aframeroomart.html
  • #26: https://dougsillars.github.io/ARtGallery/aframeroomart.html
  • #27: https://dougsillars.github.io/ARtGallery/aframeroomart.html
  • #28: https://dougsillars.github.io/ARtGallery/aframeroomart.html
  • #29: https://dougsillars.github.io/ARtGallery/aframeroomart.html
  • #30: https://dougsillars.github.io/ARtGallery/sistine.html
  • #31: https://dougsillars.github.io/ARtGallery/sistine.html
  • #32: https://dougsillars.github.io/ARtGallery/sistine.html
  • #33: https://dougsillars.github.io/ARtGallery/aframeroomart.html
  • #34: https://dougsillars.github.io/ARtGallery/aframeroomart.html
  • #35: https://dougsillars.github.io/ARtGallery/aframeroomart.html