<!DOCTYPE html>
<html lang="en">
	<head>
		<meta charset="utf-8">
		<title>three.js / examples</title>
		<meta name="viewport" content="width=device-width, user-scalable=no, minimum-scale=1.0, maximum-scale=1.0">
		<style>

			@font-face {
				font-family: 'inconsolata';
				src: url('files/inconsolata.woff') format('woff');
				font-weight: normal;
				font-style: normal;
			}

			*{
				box-sizing: border-box;
			}

			html {
				height: 100%;
			}

			body {
				background-color: #ffffff;
				margin: 0px;
				height: 100%;
				color: #555;
				font-family: 'inconsolata';
				font-size: 15px;
				line-height: 18px;
				overflow: hidden;
			}

			h1 {
				margin-top: 30px;
				margin-bottom: 40px;
				margin-left: 20px;
				font-size: 25px;
				font-weight: normal;
			}

			h2 {
				font-size: 20px;
				font-weight: normal;
			}

			a {
				color: #2194CE;
				text-decoration: none;
			}

			#panel {
				position: fixed;
				left: 0px;
				width: 310px;
				height: 100%;
				overflow: auto;
				background: #fafafa;
			}

				#panel #content {
					padding: 0px 20px;
				}

				#panel #content .link {
					color: #2194CE;
					text-decoration: none;
					cursor: pointer;
				}

				#panel #content .selected {
					color: #ff0000;
				}

					#panel #content .link:hover {
						text-decoration: underline;
					}

			#viewer {
				position: absolute;
				border: 0px;
				left: 310px;
				width: calc(100% - 310px);
				height: 100%;
				overflow: auto;
			}

			#button {
				position: fixed;
				top: 20px;
				right: 20px;
				padding: 8px;
				color: #fff;
				background-color: #555;
				opacity: 0.7;
			}

				#button:hover {
					cursor: pointer;
					opacity: 1;
				}

			/* mobile */

			#expandButton {
				display: none;
				position: absolute;
				right: 20px;
				top: 12px;
				width: 32px;
				height: 32px;
			}

				#expandButton span {
					height: 2px;
					background-color: #2194CE;
					width: 16px;
					position: absolute;
					left: 8px;
					top: 10px;
				}

				#expandButton span:nth-child(1) {
					top: 16px;
				}

				#expandButton span:nth-child(2) {
					top: 22px;
				}

			@media all and ( max-width: 640px ) {
				h1{
					margin-top: 20px;
					margin-bottom: 20px;
				}
				#panel{
					position: absolute;
					left: 0;
					top: 0;
					height: 480px;
					width: 100%;
					right: 0;
					z-index: 100;
					overflow: hidden;
					border-bottom: 1px solid #dedede;
				}
				#content{
					position: absolute;
					left: 0;
					top: 60px;
					right: 0;
					bottom: 0;
					font-size: 17px;
					line-height: 22px;
					overflow: auto;
				}
				#viewer{
					position: absolute;
					left: 0;
					top: 56px;
					width: 100%;
					height: calc(100% - 56px);
				}
				#expandButton{
					display: block;
				}
				#panel.collapsed{
					height: 56px;
				}
			}

		</style>
	</head>
	<body>

		<div id="panel" class="collapsed">
			<h1><a href="http://threejs.org">three.js</a> / examples</h1>
			<a id="expandButton" href="#">
				<span></span>
				<span></span>
				<span></span>
			</a>
			<div id="content"></div>
		</div>
		<iframe id="viewer" allowfullscreen onmousewheel=""></iframe>

		<script>

		var files = {
			"webgl": [
				"webgl_animation_cloth",
				"webgl_animation_skinning_blending",
				"webgl_animation_skinning_morph",
				"webgl_buffergeometry",
				"webgl_buffergeometry_custom_attributes_particles",
				"webgl_buffergeometry_lines",
				"webgl_buffergeometry_lines_indexed",
				"webgl_buffergeometry_particles",
				"webgl_buffergeometry_drawcalls",
				"webgl_buffergeometry_rawshader",
				"webgl_buffergeometry_uint",
				"webgl_camera",
				"webgl_camera_logarithmicdepthbuffer",
				"webgl_custom_attributes",
				"webgl_custom_attributes_lines",
				"webgl_custom_attributes_particles",
				"webgl_custom_attributes_particles2",
				"webgl_custom_attributes_particles3",
				"webgl_decals",
				"webgl_effects_anaglyph",
				"webgl_effects_parallaxbarrier",
				"webgl_effects_stereo",
				"webgl_geometries",
				"webgl_geometries2",
				"webgl_geometry_colors",
				"webgl_geometry_colors_blender",
				"webgl_geometry_colors_lookuptable",
				"webgl_geometry_convex",
				"webgl_geometry_cube",
				"webgl_geometry_dynamic",
				"webgl_geometry_extrude_shapes",
				"webgl_geometry_extrude_shapes2",
				"webgl_geometry_extrude_splines",
				"webgl_geometry_hierarchy",
				"webgl_geometry_hierarchy2",
				"webgl_geometry_large_mesh",
				"webgl_geometry_minecraft",
				"webgl_geometry_minecraft_ao",
				"webgl_geometry_normals",
				"webgl_geometry_nurbs",
				"webgl_geometry_shapes",
				"webgl_geometry_terrain",
				"webgl_geometry_terrain_fog",
				"webgl_geometry_terrain_raycast",
				"webgl_geometry_text",
				"webgl_geometry_text2",
				"webgl_gpgpu_birds",
				"webgl_hdr",
				"webgl_helpers",
				"webgl_interactive_buffergeometry",
				"webgl_interactive_cubes",
				"webgl_interactive_cubes_gpu",
				"webgl_interactive_cubes_ortho",
				"webgl_interactive_draggablecubes",
				"webgl_interactive_lines",
				"webgl_interactive_particles",
				"webgl_interactive_raycasting_pointcloud",
				"webgl_interactive_voxelpainter",
				"webgl_kinect",
				"webgl_lensflares",
				"webgl_lights_hemisphere",
				"webgl_lights_pointlights",
				"webgl_lights_pointlights2",
				"webgl_lines_colors",
				"webgl_lines_cubes",
				"webgl_lines_dashed",
				"webgl_lines_sphere",
				"webgl_lines_splines",
				"webgl_loader_assimp2json",
				"webgl_loader_awd",
				"webgl_loader_babylon",
				"webgl_loader_collada",
				"webgl_loader_collada_keyframe",
				"webgl_loader_collada_skinning",
				"webgl_loader_collada_kinematics",
				"webgl_loader_ctm",
				"webgl_loader_ctm_materials",
				"webgl_loader_gltf",
				"webgl_loader_json_blender",
				"webgl_loader_json_objconverter",
				"webgl_loader_msgpack",
				"webgl_loader_obj",
				"webgl_loader_obj_mtl",
				"webgl_loader_pdb",
				"webgl_loader_ply",
				"webgl_loader_scene",
				"webgl_loader_stl",
				"webgl_loader_utf8",
				"webgl_loader_vrml",
				"webgl_loader_vtk",
				"webgl_lod",
				"webgl_marchingcubes",
				"webgl_materials",
				"webgl_materials2",
				"webgl_materials_blending",
				"webgl_materials_blending_custom",
				"webgl_materials_bumpmap",
				"webgl_materials_bumpmap_skin",
				"webgl_materials_cars",
				"webgl_materials_cars_camaro",
				"webgl_materials_cubemap",
				"webgl_materials_cubemap_balls_reflection",
				"webgl_materials_cubemap_balls_refraction",
				"webgl_materials_cubemap_dynamic",
				"webgl_materials_cubemap_dynamic2",
				"webgl_materials_cubemap_escher",
				"webgl_materials_cubemap_refraction",
				"webgl_materials_envmaps",
				"webgl_materials_grass",
				"webgl_materials_lightmap",
				"webgl_materials_normalmap",
				"webgl_materials_normaldisplacementmap",
				"webgl_materials_parallaxmap",
				"webgl_materials_shaders_fresnel",
				"webgl_materials_skin",
				"webgl_materials_texture_anisotropy",
				"webgl_materials_texture_compressed",
				"webgl_materials_texture_filters",
				"webgl_materials_texture_manualmipmap",
				"webgl_materials_texture_pvrtc",
				"webgl_materials_texture_tga",
				"webgl_materials_video",
				"webgl_materials_wireframe",
				"webgl_mirror",
				"webgl_modifier_subdivision",
				"webgl_modifier_tessellation",
				"webgl_morphnormals",
				"webgl_morphtargets",
				"webgl_morphtargets_horse",
				"webgl_morphtargets_human",
				"webgl_morphtargets_md2",
				"webgl_morphtargets_md2_control",
				"webgl_multiple_canvases_circle",
				"webgl_multiple_canvases_complex",
				"webgl_multiple_canvases_grid",
				"webgl_multiple_views",
				"webgl_nearestneighbour",
				"webgl_octree",
				"webgl_octree_raycasting",
				"webgl_panorama_equirectangular",
				"webgl_particles_billboards",
				"webgl_particles_billboards_colors",
				"webgl_particles_dynamic",
				"webgl_particles_random",
				"webgl_particles_shapes",
				"webgl_particles_sprites",
				"webgl_performance",
				"webgl_performance_doublesided",
				"webgl_performance_static",
				"webgl_postprocessing",
				"webgl_postprocessing_advanced",
				"webgl_postprocessing_dof",
				"webgl_postprocessing_dof2",
				"webgl_postprocessing_godrays",
				"webgl_postprocessing_crossfade",
				"webgl_postprocessing_glitch",
				"webgl_rtt",
				"webgl_sandbox",
				"webgl_shader",
				"webgl_shader_lava",
				"webgl_shader2",
				"webgl_shaders_ocean",
				"webgl_shading_physical",
				"webgl_shaders_sky",
				"webgl_shaders_tonemapping",
				"webgl_shaders_vector",
				"webgl_shadowmap",
				"webgl_shadowmap_performance",
				"webgl_shadowmap_viewer",
				"webgl_shadowmesh",
				"webgl_sprites",
				"webgl_terrain_dynamic",
				"webgl_test_memory",
				"webgl_test_memory2",
				"webgl_trails",
				"webgl_video_panorama_equirectangular"
			],
			"webgldeferred": [
				"webgldeferred_animation",
				"webgldeferred_arealights",
				"webgldeferred_pointlights"
			],
			"vr": [
				"vr_cubes",
				"vr_video"
			],
			"css3d": [
				"css3d_molecules",
				"css3d_panorama",
				"css3d_periodictable",
				"css3d_sandbox",
				"css3d_sprites",
				"css3d_youtube"
			],
			"css3d stereo": [
				"css3dstereo_periodictable",
			],
			"misc": [
				"misc_animation_keys",
				"misc_controls_deviceorientation",
				"misc_controls_fly",
				"misc_controls_orbit",
				"misc_controls_pointerlock",
				"misc_controls_trackball",
				"misc_controls_transform",
				"misc_lights_test",
				"misc_lookat",
				"misc_fps",
				"misc_sound",
				"misc_ubiquity_test",
				"misc_ubiquity_test2",
				"misc_uv_tests"
			],
			"canvas": [
				"canvas_ascii_effect",
				"canvas_camera_orthographic",
				"canvas_camera_orthographic2",
				"canvas_effects_stereo",
				"canvas_geometry_birds",
				"canvas_geometry_cube",
				"canvas_geometry_earth",
				"canvas_geometry_hierarchy",
				"canvas_geometry_nurbs",
				"canvas_geometry_panorama",
				"canvas_geometry_panorama_fisheye",
				"canvas_geometry_shapes",
				"canvas_geometry_terrain",
				"canvas_geometry_text",
				"canvas_interactive_cubes",
				"canvas_interactive_cubes_tween",
				"canvas_interactive_particles",
				"canvas_interactive_voxelpainter",
				"canvas_lights_pointlights",
				"canvas_lines",
				"canvas_lines_colors",
				"canvas_lines_dashed",
				"canvas_lines_sphere",
				"canvas_materials",
				"canvas_materials_depth",
				"canvas_materials_normal",
				"canvas_materials_reflection",
				"canvas_materials_video",
				"canvas_morphtargets_horse",
				"canvas_particles_floor",
				"canvas_particles_random",
				"canvas_particles_shapes",
				"canvas_particles_sprites",
				"canvas_particles_waves",
				"canvas_performance",
				"canvas_sandbox"
			],
			"raytracing": [
				"raytracing_sandbox"
			],
			"software": [
				"software_geometry_earth",
				"software_sandbox"
			],
			"svg": [
				"svg_sandbox"
			]
		};

		//

		var panel = document.getElementById( 'panel' );
		var content = document.getElementById( 'content' );
		var viewer = document.getElementById( 'viewer' );

		var expandButton = document.getElementById( 'expandButton' );
		expandButton.addEventListener( 'click', function ( event ) {
			panel.classList.toggle( 'collapsed' );
			event.preventDefault();
		} );

		// iOS8 workaround

		if ( /(iPad|iPhone|iPod)/g.test( navigator.userAgent ) ) {

			viewer.addEventListener( 'load', function ( event ) {

				viewer.contentWindow.innerWidth -= 10;
				viewer.contentWindow.innerHeight -= 2;

			} );

		}

		var container = document.createElement( 'div' );
		content.appendChild( container );

		var button = document.createElement( 'div' );
		button.id = 'button';
		button.textContent = 'View source';
		button.addEventListener( 'click', function ( event ) {

			var array = location.href.split( '/' );
			array.pop();

			window.open( 'view-source:' + array.join( '/' ) + '/' + selected + '.html' );

		}, false );
		button.style.display = 'none';
		document.body.appendChild( button );

		var divs = {};
		var selected = null;

		for ( var key in files ) {

			var section = files[ key ];

			var div = document.createElement( 'h2' );
			div.textContent = key;
			container.appendChild( div );

			for ( var i = 0; i < section.length; i ++ ) {

				( function ( file ) {

					var name = file.split( '_' );
					name.shift();
					name = name.join( ' / ' );

					var div = document.createElement( 'div' );
					div.className = 'link';
					div.textContent = name;
					div.addEventListener( 'click', function () {

						panel.classList.toggle( 'collapsed' );
						load( file );

					} );
					container.appendChild( div );

					divs[ file ] = div;

				} )( section[ i ] );

			}

		}

		var load = function ( file ) {

			if ( selected !== null ) divs[ selected ].className = 'link';

			divs[ file ].className = 'link selected';

			window.location.hash = file;
			viewer.src = file + '.html';
			viewer.focus();

			button.style.display = '';

			selected = file;

		};

		if ( window.location.hash !== '' ) {

			load( window.location.hash.substring( 1 ) );

		}

		</script>

	</body>
</html>