Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/sawa-zen/three-fiber-webxr-toolbox
This toolset provides useful components for creating xr content with react-three-fiber.
https://github.com/sawa-zen/three-fiber-webxr-toolbox
react-three-fiber threejs webxr
Last synced: 3 months ago
JSON representation
This toolset provides useful components for creating xr content with react-three-fiber.
- Host: GitHub
- URL: https://github.com/sawa-zen/three-fiber-webxr-toolbox
- Owner: sawa-zen
- License: mit
- Created: 2023-12-03T10:01:54.000Z (about 1 year ago)
- Default Branch: main
- Last Pushed: 2024-08-25T07:44:19.000Z (4 months ago)
- Last Synced: 2024-09-27T12:03:11.645Z (3 months ago)
- Topics: react-three-fiber, threejs, webxr
- Language: TypeScript
- Homepage:
- Size: 602 KB
- Stars: 22
- Watchers: 1
- Forks: 2
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
# 🥽 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](http://img.youtube.com/vi/jAYIertq6jA/0.jpg)](https://www.youtube.com/watch?v=jAYIertq6jA)### 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.
```tsx
import { XrErrorBoundary } from 'three-fiber-webxr-toolbox'ReactDOM.createRoot(document.getElementById("root") as HTMLElement).render(
);
```### 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.
```tsx
import { XrErrorBoundary } from 'three-fiber-webxr-toolbox'const App = () => {
return (
)
}const Child = () => {
const { pushMessage } = useConsole()useEffect(() => { pushMessage('Hello World!') })
return (
...
)
}
```### 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](http://img.youtube.com/vi/rM7_0A17NJ4/0.jpg)](https://www.youtube.com/watch?v=rM7_0A17NJ4)
```tsx
```
**attention**
Even when VR content is created, it must be made in AR or the pass-through image will not be projected.### RemoteDisplay
This component is used to display a PC display within the content being developed. This component allows for more seamless development in immersive mode.
[![RemoteDisplay](http://img.youtube.com/vi/c8S02jZ2Hs0/0.jpg)](https://www.youtube.com/watch?v=c8S02jZ2Hs0)
English: Currently, you need to use a Vite plugin. We are preparing tools for use outside of Vite, so please wait a little longer.
1. Add remoteDisplayServer plugin to vite.config.ts
```TypeScript
import { remoteDisplayServer } from 'three-fiber-webxr-toolbox'export default defineConfig(({ command }) => {
if (command === 'serve') {
return {
root: 'examples',
plugins: [
remoteDisplayServer(),
],
}
}
...
}
```1. Access /remote_display for screen sharing.
![](./assets/remote_display/image01.png)
1. Pass local IP to RemoteDisplay.
```tsx
import { RemoteDisplay } from 'three-fiber-webxr-toolbox'ReactDOM.createRoot(document.getElementById("root") as HTMLElement).render(
```1. Accessing the development server from the HMD and clicking on the screen with the controller.
![](./assets/remote_display/image02.png)
## Code contributions
To develop XR, https is required. You can create a local certificate and key using `mkcert`.
First, install `mkcert` if you haven't already
```
brew install mkcert
```Then, create a local certificate and key for `localhost`
```
mkcert localhost
```Then, create .env.local and put the local IP of the development PC in the VITE_SOCKET_SERVER_URL environment variable.
```
echo "VITE_SOCKET_SERVER_URL=192.168.xx.xx:3001" > .env.local
```This will generate two files: `localhost.pem`, the local certificate, and `localhost-key.pem`, the private key.
Start the development server and access the URL from a head-mounted display.
```
yarn dev
```