blob: 3c316c5984400ce70913969000cadc6eda043ef5 [file] [log] [blame]
<!DOCTYPE html>
<html>
<head>
<meta charset='utf-8'>
<meta http-equiv='X-UA-Compatible' content='chrome=1'>
<meta name='viewport' content='width=device-width, initial-scale=1'>
<meta name='mobile-web-app-capable' content='yes'>
<meta name='apple-mobile-web-app-capable' content='yes'>
<meta name='twitter:card' content='summary'>
<meta name='twitter:title' content='WebXR Samples'>
<meta name='twitter:description' content='Sample WebXR pages for testing and reference'>
<link rel='icon' type='image/png' sizes='32x32' href='../favicon-32x32.png'>
<link rel='icon' type='image/png' sizes='96x96' href='../favicon-96x96.png'>
<link rel='stylesheet' href='../css/stylesheet.css'>
<link rel='stylesheet' href='../css/pygment_trac.css'>
<style>
article {
position: relative;
padding: 0.5em;
background-color: rgba(255, 255, 255, 0.90);
margin-bottom: 1em;
border-radius: 3px;
}
hr {
margin-bottom: 1em;
}
article h3 {
font-size: 1.0em;
margin-top: 0px;
margin-bottom: 0px;
}
article h3::before {
display: inline-block;
content: attr(data-index) ' - ';
font-weight: bold;
white-space: nowrap;
margin-right: 0.2em;
}
article h4 {
position: absolute;
right: 0.5em;
top: 0.5em;
margin-top: 0px;
margin-bottom: 0px;
}
article p {
margin: 0.5em;
}
article .links {
margin-left: 0.5em;
margin-right: 0.5em;
}
article a {
display: inline-block;
}
article a:not(:first-child)::before {
display: inline-block;
content: '•';
font-weight: bold;
white-space: nowrap;
margin-left: 0.5em;
margin-right: 0.5em;
}
.github-link {
font-size: 0.8em;
}
.wordmark img {
width: 70%;
}
</style>
<!--[if lt IE 9]>
<script src='https://html5shiv.googlecode.com/svn/trunk/html5.js'></script>
<![endif]-->
<title>WebXR - Layers Samples</title>
</head>
<body>
<div class='container' id='container'>
<header class='header'>
<div id='nav'>
<a href='../'>Samples</a>
<a href='./' class='selected'>Layers Samples</a>
<a href='../proposals/'>Proposals</a>
<a href='../tests/'>Test Pages</a>
<a href='../report/'>Report</a>
</div>
<h1>
<a href='' class='wordmark'>
<img src='../media/logo/webxr-logo.svg' alt='WebXR Logo' />
</a>
</h1>
<h2 class='tagline'>WebXR Layers Samples</h2>
</header>
<main class='main' id='main'>
<p>These pages demonstrate how to use various aspects of the WebXR Layers API.<br/>
<script>
let pages = [
{
title: 'Projection Layer', category: 'Basics',
path: 'proj-layer.html',
description: 'Demonstrates drawing to a projection layer.',
noPolyfill: true
},
{
title: 'Quad Layer', category: 'Basics',
path: 'quad-layer.html',
description: 'Demonstrates drawing to a quad layer.',
noPolyfill: true
},
{
title: 'Cylinder Layer', category: 'Basics',
path: 'cyld-layer.html',
description: 'Demonstrates drawing to a cylinder layer.',
noPolyfill: true
},
{
title: 'Cube Layer', category: 'Basics',
path: 'cube-layer.html',
description: 'Demonstrates drawing to a cube layer.',
noPolyfill: true
},
{
title: 'Equirect Layer', category: 'Basics',
path: 'eqrt-layer.html',
description: 'Demonstrates drawing to an equirect layer.',
noPolyfill: true
},
{
title: 'Media Layer', category: 'Basics',
path: 'media-layer-sample.html',
description: 'Demonstrates using an equirect media layer for video playback.',
noPolyfill: true
},
{
title: 'Equirect Video', category: 'Multi-layer',
path: 'eqrt-video.html',
description: 'Demonstrates immersive video playback with media controls using both equirect and projection layers.',
noPolyfill: true
},
{
title: 'Layer VS Non-Layer', category: 'Multi-layer',
path: 'quad-ab-test.html',
description: 'An A/B test quality comparison of rendering the same square texture using quad layer vs drawing the texture directly into the scene.',
noPolyfill: true
},
{
title: 'Layer Hit Test', category: 'Multi-layer',
path: 'quad-select.html',
description: 'Demonstrates a work-around to implement hit test on layers by placing transparent placeholders for each quad layer in the projection layer.',
noPolyfill: true
},
{
title: 'Projection Layer with Multiview', category: 'Multiview',
path: 'proj-multiview.html',
description: 'Demonstrates a technique to reduce the number of state changes made while rendering.',
noPolyfill: true
},
{
title: 'Projection Layer with occlusion', category: 'Multiview',
path: 'proj-multiview-occlusion.html',
description: 'Demonstrates a technique to occlude the scene with real wold pixels.',
noPolyfill: true
},
];
let mainElement = document.getElementById("main");
// Append an element for every item in the pages list.
let sampleIdx = 0;
for (let page of pages) {
if (page.category == 'divider') {
let divider = document.createElement('hr');
mainElement.appendChild(divider);
continue;
}
sampleIdx += 1;
let article = document.createElement('article');
let title = document.createElement('h3');
title.setAttribute('data-index', sampleIdx);
let titleLink = document.createElement('a');
titleLink.href = page.path;
titleLink.textContent = page.title;
title.appendChild(titleLink);
article.appendChild(title);
let category = document.createElement('h4');
category.textContent = page.category;
article.appendChild(category);
let description = document.createElement('p');
description.textContent = page.description;
article.appendChild(description);
let links = document.createElement('div');
links.classList.add('links');
let sourceLink = document.createElement('a');
sourceLink.href = 'https://github.com/immersive-web/webxr-samples/blob/master/layers-samples/' + page.path;
sourceLink.textContent = 'Source';
links.appendChild(sourceLink);
if (!page.noPolyfill) {
let polyfillLink = document.createElement('a');
polyfillLink.href = page.path + '?usePolyfill=0';
polyfillLink.textContent = 'Run Without Polyfill';
links.appendChild(polyfillLink);
}
article.appendChild(links);
mainElement.appendChild(article);
}
</script>
</main>
<br />
<h3><a class='github-link' href='https://github.com/immersive-web/webxr-samples'>View source on GitHub</a></h3>
<footer class='footer'>
</footer>
</div>
</body>
</html>