Skip to content

sawa-zen/three-fiber-webxr-toolbox

Repository files navigation

🥽 three-fiber-webxr-toolbox

three-fiber-webxr-toolbox

This toolset provides useful components for creating xr content with react-three-fiber.

Motivation

When developing WebXR, I strongly wanted to develop in immersive mode while wearing VR goggles. If I could do that, I would be able to change the color and shape of objects in the real world just by rewriting my own code. I feel like a god.

Getting Start

npm install three-fiber-webxr-toolbox

Components

The three-fiber-webxr-toolbox component enables development like the following video.

↓ Click to play video
three-fiber-webxr-toolbox

XRErrorBoundary

This component is used to prevent webgl context from being lost if there is an error in the code. If an error occurs, an error window is displayed in XR space.

Be sure to install directly under the XR component. The context is lost when XRErrorBoundary itself is re-rendered.

import { XrErrorBoundary } from 'three-fiber-webxr-toolbox'

ReactDOM.createRoot(document.getElementById("root") as HTMLElement).render(
  <React.StrictMode>
    <ARButton />
    <Canvas>
      <XR>
        <XrErrorBoundary>
          <App />
        </XrErrorBoundary>
      </XR>
    </Canvas>
  </React.StrictMode>
);

ConsoleProvider

Console logs cannot be viewed when wearing a head-mounted display. This component is designed to be used as an alternative in such cases.

If it is a child element of ConsoleProvider, it can push console messages from useConsole hooks.

import { XrErrorBoundary } from 'three-fiber-webxr-toolbox'

const App = () => {
  return (
    <ConsoleProvider>
      <Child />
    </ConsoleProvider>
  )
}

const Child = () => {
  const { pushMessage } = useConsole()

  useEffect(() => { pushMessage('Hello World!') })

  return (
    <mesh>
      ...
    </mesh>
  )
}

Portal

When developing in XR's immersive mode, it is sometimes inconvenient to see the keyboard, mouse, or coffee mug. In such cases, this component creates a hole to partially view the pass-through image.

<Portal position={[0, 0.6, -0.5]} />

attention Even when VR content is created, it must be made in AR or the pass-through image will not be projected.

RemoteDisplay

comming soon...

This component is used to display a PC display within the content being developed. This component allows for more seamless development in immersive mode.

Code contributions

To develop XR, https is required so that ngrok can access the local PC. Please change the domain part to your own domain.

ngrok http --domain=xxxxx.ngrok-free.app 5173

Start the development server and access the URL published in ngrok from a head-mounted display.

yarn dev

About

This toolset provides useful components for creating xr content with react-three-fiber.

Topics

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published