THREE.SixDOF
🌐 Plugin for rendering 6DOF equirectangular 360 images and videos with depthmaps
Install / Use
/learn @juniorxsound/THREE.SixDOFREADME
Getting started
To quickly get started include the latest three-6dof.js after including three.js in your project. Next create your 6DoF viewer like
// Create the loader
var loadingManager = new THREE.LoadingManager();
var textureLoader = new THREE.TextureLoader(loadingManager);
// Load the textures
var colorTexture, depthTexture;
textureLoader.load('360_color_image.jpg', texture => { colorTexture = texture });
textureLoader.load('360_depth_image.jpg', texture => { depthTexture = texture });
// On finish loading create the viewer with the textures
loadingManager.onLoad = () => {
sixDofViewer = new SixDOF.Viewer(colorTexture, depthTexture);
scene.add(sixDofViewer);
}
Using with ES6
If you are using yarn with ES6 you can also
yarn add https://github.com/juniorxsound/THREE.SixDOF
You can import the plugin by simply
import {
Viewer,
TextureType,
MeshDensity,
Style
} from 'three-6dof'
Examples
API
When creating a viewer you pass the following parameters
const instance = new Viewer(
colorTexture, // Or top bottom texture
depthTexture, // Optionally
{
'type': TextureType.SEPERATE, // For seperate depth and texture (for single top bottom use TextureType.TOP_BOTTOM)
'style': Style.WIRE, // Chooses the rendering style (defaults to Style.MESH)
'density': MeshDensity.EXTRA_HIGH // Chooses geometry tesselation level
'displacement': 4.0, // Defaults to 4.0
'radius' : 6 // Defaults to 6
}
)
For a full list of options see the constants.ts file.
-
instance.texture- get theTHREE.Texture -
instance.depth- get theTHREE.Texturedepth map (nullif none) -
instance.displacement- get or set the displacement amount -
instance.pointSize- get or set the point size when rendering points -
instance.opacity- get or set the material's opacity -
instance.config- returns the current config object -
instance.toggleDepthDebug(state)- toggle color and depth rendering (useful for debugging)
Thanks
To krpano and Kandao for the depth panoramas.
Related Skills
docs-writer
98.9k`docs-writer` skill instructions As an expert technical writer and editor for the Gemini CLI project, you produce accurate, clear, and consistent documentation. When asked to write, edit, or revie
model-usage
334.1kUse CodexBar CLI local cost usage to summarize per-model usage for Codex or Claude, including the current (most recent) model or a full model breakdown. Trigger when asked for model-level usage/cost data from codexbar, or when you need a scriptable per-model summary from codexbar cost JSON.
arscontexta
2.8kClaude Code plugin that generates individualized knowledge systems from conversation. You describe how you think and work, have a conversation and get a complete second brain as markdown files you own.
docs
High-performance, modular RAG backend and "Knowledge Engine" Built with Go & Gin, featuring Git-Ops knowledge sync, pgvector semantic search, and OpenAI-compatible model support.
