Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

v9 rc #2331

Draft
wants to merge 365 commits into
base: master
Choose a base branch
from
Draft

v9 rc #2331

Show file tree
Hide file tree
Changes from all commits
Commits
Show all changes
365 commits
Select commit Hold shift + click to select a range
111b4a5
chore: export Overwrite (#2721)
krispya Jan 19, 2023
1b602d4
fix(types): loosen Loader type
CodyJasonBennett Jan 19, 2023
ff8dff5
chore: endOfLine auto for crossplatform dev (#2737)
krispya Jan 25, 2023
fd3e92a
Merge branch 'master' into v9
CodyJasonBennett Feb 26, 2023
39b2cfd
fix: offscreencanvas fixes
CodyJasonBennett Feb 26, 2023
7e5d450
fix: progressive color management
CodyJasonBennett Feb 26, 2023
ee510a4
fix: valid sRGB encode
CodyJasonBennett Feb 26, 2023
e67482e
fix: memoize HMR defaults
CodyJasonBennett Feb 26, 2023
b38c18f
fix: portal injects
CodyJasonBennett Feb 26, 2023
e508a79
feat: short cut for shadow type
CodyJasonBennett Feb 26, 2023
6c4e52f
chore: update HMR identity test
CodyJasonBennett Feb 26, 2023
7edff25
fix(types): accept string[][] in useLoader
CodyJasonBennett Feb 27, 2023
8ee196d
Merge branch 'v9' into fix/loosen-loader-type
CodyJasonBennett Feb 27, 2023
b255c2a
fix(types): remove excess useLoader generics
CodyJasonBennett Feb 27, 2023
f750f3a
chore(hooks): cleanup
CodyJasonBennett Feb 27, 2023
0340acd
chore(types): more cleanup, update snapshot
CodyJasonBennett Feb 27, 2023
0fc6afc
refactor(hooks): try to infer useLoader type
CodyJasonBennett Feb 27, 2023
9c5d23a
chore(hooks): prune unused types
CodyJasonBennett Feb 27, 2023
9969c6c
chore: disable ESLint in tests
CodyJasonBennett Feb 27, 2023
f479040
Merge branch 'v9' into fix/loosen-loader-type
CodyJasonBennett Feb 27, 2023
0d53ce9
fix(hooks): Loader#load signature returns any
CodyJasonBennett Feb 27, 2023
2847837
fix(hooks): remove Loader#loadAsync
CodyJasonBennett Feb 27, 2023
c25f990
[v9] fix: forward StrictMode (#2547)
CodyJasonBennett Feb 27, 2023
b22c406
fix: harden hooks tests
CodyJasonBennett Feb 27, 2023
2b3a68f
Merge branch 'v9' into experiment/object-constructor-effects
CodyJasonBennett Feb 28, 2023
d106982
fix(reconciler): handle append as container effect
CodyJasonBennett Feb 28, 2023
06234ad
chore: cleanup instance init
CodyJasonBennett Feb 28, 2023
5d61585
chore(tests): harden suspense lifecycle tests
CodyJasonBennett Feb 28, 2023
dc994ac
chore: cleanup
CodyJasonBennett Feb 28, 2023
090e497
chore: cleanup element mock
CodyJasonBennett Feb 28, 2023
254a715
fix: don't no-op primitive prepare
CodyJasonBennett Feb 28, 2023
cea29e6
chore: harden render tests
CodyJasonBennett Feb 28, 2023
c195d11
fix(reconciler): handle insert on out-of-order reconstruct
CodyJasonBennett Feb 28, 2023
4fb41a0
experiment: don't dispose on swap
CodyJasonBennett Feb 28, 2023
cf9bfc6
chore: revert swap
CodyJasonBennett Feb 28, 2023
5f376ce
fix(reconciler): remove beforeChild on replace
CodyJasonBennett Mar 4, 2023
5883610
Revert "fix(reconciler): remove beforeChild on replace"
CodyJasonBennett Mar 4, 2023
461561e
feat: `scene` render prop for custom THREE.Scene (#2803)
krispya Mar 14, 2023
fad83b2
[fix] Canvas now properly forwards scene
krispya Mar 15, 2023
76276c0
[fix] narrow scene options type
krispya Mar 15, 2023
6a873aa
Merge pull request #2805 from Nicetouchco/feat/scene-prop
krispya May 30, 2023
35333c9
[feat] relax Object3D checks in the reconciler (#2806)
krispya May 30, 2023
a83e06e
Merge branch 'v9' into experiment/object-constructor-effects
krispya Jun 5, 2023
4ae810e
fix: dispose properly binds its object
krispya Jun 5, 2023
ec1d723
fix: call instead of bind
krispya Jun 5, 2023
9e0b2d1
Revert to bind
krispya Jun 5, 2023
cab6d59
Merge pull request #2871 from Nicetouchco/fix/dispose
krispya Jun 10, 2023
02a2740
Merge branch 'master' into v9
CodyJasonBennett Jun 10, 2023
ad37b2a
chore: update tests, upstream fixes
CodyJasonBennett Jun 10, 2023
ba6aa5b
Merge branch 'master' into v9
CodyJasonBennett Jun 12, 2023
44694cc
fix: inline SSR fallbacks
CodyJasonBennett Jun 12, 2023
7088dc5
chore: prefer imperative loops for tracing
CodyJasonBennett Jun 12, 2023
dde49a5
Merge pull request #2723 from pmndrs/fix/loosen-loader-type
krispya Jun 22, 2023
66b7cb3
Merge pull request #2607 from pmndrs/experiment/object-constructor-ef…
krispya Jun 22, 2023
8449aac
fix: scene prop not being used in web canvas
krispya Jun 22, 2023
e8f2ef0
Merge pull request #2901 from Nicetouchco/fix/scene
krispya Jun 22, 2023
2e7d5d6
fix: object3d check in reconciler
krispya Jun 22, 2023
4249c39
Merge pull request #2902 from Nicetouchco/fix/object3d-check
krispya Jun 22, 2023
df2c2fd
Merge branch 'master' into v9
CodyJasonBennett Jul 12, 2023
0e45425
chore: cleanup
CodyJasonBennett Jul 12, 2023
245cd3e
Merge branch 'master' into v9
CodyJasonBennett Jul 26, 2023
bca4137
fix(types): r153 colors overload fix (#2932)
CodyJasonBennett Aug 20, 2023
1477e10
chore: merge
CodyJasonBennett Sep 4, 2023
f681076
chore: resolve conflicts
CodyJasonBennett Sep 4, 2023
795fa93
Merge branch 'master' into v9
CodyJasonBennett Sep 17, 2023
642c0ca
[v9] experiment: extend factory overload (#2785)
CodyJasonBennett Sep 17, 2023
c5694ee
Merge branch 'master' into v9
CodyJasonBennett Sep 28, 2023
4d59d9c
fix: Function formatting destroying syntax highlighting
krispya Oct 2, 2023
1ff2e32
Merge pull request #3031 from Nicetouchco/fix/syntax-highlighting
krispya Oct 5, 2023
fb0174f
Merge branch 'master' into v9
CodyJasonBennett Oct 6, 2023
221ad2d
fix(applyProps): loosen copy identity in dev
CodyJasonBennett Oct 6, 2023
97bad98
Merge branch 'master' into v9
CodyJasonBennett Oct 21, 2023
62dec65
chore: export buildGraph
CodyJasonBennett Oct 21, 2023
b126089
Merge branch 'master' into v9
CodyJasonBennett Oct 21, 2023
b362ea4
Merge branch 'master' into v9
CodyJasonBennett Oct 22, 2023
fccfd06
chore: handle conflicts
CodyJasonBennett Oct 22, 2023
8921435
Merge branch 'master' into v9
CodyJasonBennett Oct 25, 2023
a56b1ab
refactor(reconciler): remove replace
CodyJasonBennett Oct 26, 2023
e5291a0
Merge branch 'master' into v9
CodyJasonBennett Oct 26, 2023
2ec2bbc
[fix] Add missing math types
krispya Oct 29, 2023
42ccaeb
[v9] fix: add missing math types (#3072)
krispya Oct 29, 2023
1dc2b95
chore: update snapshot
CodyJasonBennett Oct 29, 2023
7ea6c52
Merge remote-tracking branch 'upstream/v9' into v9
krispya Nov 20, 2023
fa978ba
[fix] Guard against constructing without params in diffProps
krispya Nov 20, 2023
9a61979
Merge pull request #3098 from Nicetouchco/fix/primitive-diffProps
krispya Dec 4, 2023
6b3e3dc
docs: update introduction for three.js r155+ (#3134)
charliefuller Jan 1, 2024
9d11627
Update readme.md (#3135)
charliefuller Jan 1, 2024
e07fccf
fix: tests were not extending Three
krispya Mar 20, 2024
037b5f9
fix(RTTR): set initial size for NaN in viewport (#3137)
AbsharHassan Jan 2, 2024
c4e248e
chore: add triplex link
itsdouges Jan 2, 2024
bbf8657
chore: update links
itsdouges Jan 2, 2024
ebd4220
chore: center align
itsdouges Jan 2, 2024
40bfbcb
chore: remove div
itsdouges Jan 2, 2024
0b515aa
fix(native): use MSAA for antialias on iOS (#3139)
CodyJasonBennett Jan 2, 2024
ed81989
docs(changeset): fix(native): use MSAA for antialias on iOS
CodyJasonBennett Jan 2, 2024
03d832a
fix: portal events, update examples
drcmda Jan 12, 2024
a30b2e1
new examples
drcmda Jan 22, 2024
f2d8adf
docs(changeset): fix: portal events, update examples
drcmda Jan 12, 2024
db77e16
chore(ci): matrix (#3146)
satelllte Jan 22, 2024
888f213
csb: node 18 (#3157)
satelllte Jan 23, 2024
0d4011c
chore(CI): setup-node v4 (#3144)
satelllte Jan 23, 2024
4fc5cfe
fix: tonemapping config overwrites userland
krispya Mar 21, 2024
bbb3a03
chore(tests): update color management checks
krispya Mar 21, 2024
4689d0e
new sandboxes
drcmda Feb 15, 2024
0b82cdd
fix: correctly pass frames in invalidate (#3185)
krispya Mar 21, 2024
765ae04
Update readme.md
drcmda Mar 4, 2024
78cfbbd
Merge branch 'master' into v9
CodyJasonBennett Mar 27, 2024
0b4b51a
chore: resolve conflicts
CodyJasonBennett Mar 27, 2024
18a5d7b
chore: add lockfile back
CodyJasonBennett Mar 27, 2024
783f377
Merge branch 'master' into v9
CodyJasonBennett Mar 29, 2024
d7a5b31
chore: mirror #3197
CodyJasonBennett Mar 29, 2024
b4f7bbc
fix(useLoader): loosen object3d check
CodyJasonBennett Apr 22, 2024
6d2543b
chore(examples): remove styled-components
CodyJasonBennett Apr 22, 2024
be6cc23
[v9] fix!: upgrade reconciler for React 19 (#3224)
CodyJasonBennett Apr 26, 2024
36a7fc4
Merge branch 'master' into v9
CodyJasonBennett Apr 26, 2024
2c4f448
chore: resolve conflicts
CodyJasonBennett Apr 26, 2024
4c1242c
[v9] chore(tests): add array attach case (#3070)
CodyJasonBennett Apr 26, 2024
85fad8e
feat(useLoader): support loader instances (#3131)
CodyJasonBennett Apr 26, 2024
9e20942
[v9] fix!: don't automatically set texture colorSpace, colorMap fallb…
CodyJasonBennett Apr 26, 2024
f722b5d
chore(examples): use React beta
CodyJasonBennett Apr 26, 2024
d092606
chore: cleanup global access
CodyJasonBennett Apr 26, 2024
15fb1dd
chore(reconciler): cleanup switchInstance
CodyJasonBennett Apr 26, 2024
1e77613
chore: cleanup, re-enable eslint tests
CodyJasonBennett Apr 26, 2024
dd148bd
fix(updateCamera): don't update world matrices
CodyJasonBennett Apr 26, 2024
1cde392
RELEASING: Releasing 2 package(s)
CodyJasonBennett Apr 26, 2024
425b6bd
chore(tests): use names in swap cases
CodyJasonBennett Apr 26, 2024
c3a1189
chore(tests): cleanup
CodyJasonBennett Apr 26, 2024
0af41db
perf(reconciler): inline prepareUpdate
CodyJasonBennett Apr 27, 2024
f2de25c
fix(types): use new createWithEqualityFn signature
CodyJasonBennett Apr 27, 2024
ad0e822
fix(types): shim OffscreenCanvas
CodyJasonBennett Apr 27, 2024
eafb2cc
fix(findInitialRoot): restore traverse, add coverage
CodyJasonBennett Apr 27, 2024
b252c8a
chore(demos): cleanup SVGRenderer
CodyJasonBennett Apr 28, 2024
817335b
chore: cleanup
CodyJasonBennett Apr 28, 2024
b62c807
chore(demos): upgrade deps
CodyJasonBennett Apr 28, 2024
d7eb077
[v9] refactor!: remove viewport, add dpr (#2887)
CodyJasonBennett Apr 28, 2024
538a89a
chore: Use React beta typings
krispya Apr 28, 2024
a4a86c4
Merge branch 'v9' of https://github.com/pmndrs/react-three-fiber into v9
krispya Apr 28, 2024
d7f7ed4
fix: JSX namespacing for v19
krispya Apr 28, 2024
0ffa718
fix(types): use new ref type
CodyJasonBennett Apr 28, 2024
e0f8a3a
fix(types): resolve remaining type issues
CodyJasonBennett Apr 28, 2024
bcc0620
chore: replace ts-ignore with ts-expect-error
krispya Apr 28, 2024
f1a296d
chore(tests): add failing suspense case
CodyJasonBennett Apr 28, 2024
eafe554
fix(reconciler): don't implement (un)hideInstance methods (#3241)
CodyJasonBennett Apr 28, 2024
a17fe45
RELEASING: Releasing 2 package(s)
CodyJasonBennett Apr 28, 2024
0d8d270
chore(hooks): cleanup
CodyJasonBennett Apr 28, 2024
77fd711
Merge branch 'master' into v9
CodyJasonBennett Apr 30, 2024
1141515
chore: resolve conflicts
CodyJasonBennett Apr 30, 2024
5a076d9
fix(reconciler): instances were not being unhidden properly
krispya May 1, 2024
f6e4c46
chore: cleanup
CodyJasonBennett May 1, 2024
6607d4d
chore: re-use (un)hide hooks
CodyJasonBennett May 1, 2024
03c823b
fix: swapped hide/unhide
CodyJasonBennett May 1, 2024
f6325a6
test: suspense visibility
krispya May 1, 2024
cc3080b
chore(tests): fix typo in sorted attach case
CodyJasonBennett May 3, 2024
1183029
[v9] fix: primitive children mounting (#3248)
krispya May 3, 2024
6f8f736
Revert "[v9] refactor!: remove viewport, add dpr (#2887)"
CodyJasonBennett May 4, 2024
f6dea27
chore(tests): move dpr reactivity case
CodyJasonBennett May 4, 2024
7cd62f7
RELEASING: Releasing 2 package(s)
CodyJasonBennett May 4, 2024
ded1acd
Merge branch 'master' into v9
CodyJasonBennett May 8, 2024
37e6499
chore: resolve conflicts
CodyJasonBennett May 8, 2024
50d43c2
chore: lint
CodyJasonBennett May 8, 2024
eed92d8
chore: upgrade React beta
CodyJasonBennett May 8, 2024
564c252
RELEASING: Releasing 2 package(s)
CodyJasonBennett May 8, 2024
2207cec
fix: remove useUpdate
krispya May 10, 2024
684d89e
Update packages/fiber/src/core/loop.ts
krispya May 11, 2024
a196f20
Update packages/fiber/src/core/store.ts
krispya May 11, 2024
687f90e
Update packages/fiber/src/core/store.ts
krispya May 11, 2024
82ec6c7
Merge branch 'master' into v9
CodyJasonBennett May 15, 2024
aa0957e
chore: upgrade to 19-rc
CodyJasonBennett May 15, 2024
2c267dc
fix(types): add shell types for react-reconciler changes (#3242)
CodyJasonBennett May 15, 2024
1db781d
fix: don't set initial frustum for manual camera
CodyJasonBennett May 21, 2024
566c660
fix(createPortal): preserve injected state
CodyJasonBennett May 22, 2024
09637a2
RELEASING: Releasing 2 package(s)
CodyJasonBennett May 22, 2024
c49e02a
Merge branch 'v9' into fix/remove-use-update
CodyJasonBennett May 22, 2024
9ba7697
Merge pull request #3262 from pmndrs/fix/remove-use-update
krispya May 22, 2024
b1b0198
chore: update rc
CodyJasonBennett May 25, 2024
00d4f0f
fix: use new ref signature
CodyJasonBennett May 25, 2024
486ba41
[v9] fix: swap instances in reverse (#3272)
CodyJasonBennett May 26, 2024
b0b2a1f
fix: color types
krispya May 26, 2024
b355536
chore: update snapshot
CodyJasonBennett May 26, 2024
fad0496
chore(types): cleanup
CodyJasonBennett May 26, 2024
5ac7a71
fix: export constraint types
CodyJasonBennett May 26, 2024
c2c6169
fix: restore exports
CodyJasonBennett May 26, 2024
8f7366a
chore: update snapshot
CodyJasonBennett May 26, 2024
4ab5ef0
fix(extend): don't use deprecated forwardRef
CodyJasonBennett May 26, 2024
7da6142
docs: use new CanvasProps
CodyJasonBennett May 26, 2024
8294bdb
fix: restore onUpdate
CodyJasonBennett May 26, 2024
cbebe98
fix: don't write behavior props
CodyJasonBennett May 26, 2024
24a7485
chore(docs): WIP v9 upgrade guide
CodyJasonBennett May 26, 2024
b4adc17
RELEASING: Releasing 2 package(s)
CodyJasonBennett May 26, 2024
973a182
chore: cleanup
CodyJasonBennett May 26, 2024
86a8ff4
feat: args prop requirement matches constructor params
krispya May 27, 2024
4afe441
chore: fix use of bufferAttribute args
CodyJasonBennett May 27, 2024
a5a9553
chore: update snapshot
CodyJasonBennett May 27, 2024
10c2746
fix: harden vector type
CodyJasonBennett May 27, 2024
e6eeac1
chore: upgrade rc
CodyJasonBennett May 30, 2024
a3db926
chore(example): cleanup
CodyJasonBennett May 30, 2024
2c1224b
v9.0.0-beta.0
CodyJasonBennett May 30, 2024
e4419fe
Merge branch 'master' into v9
CodyJasonBennett May 31, 2024
3ee709d
fix(applyProps): use copy method if same implementation
CodyJasonBennett May 31, 2024
3b2620b
Merge branch 'master' into v9
CodyJasonBennett Jun 4, 2024
841338f
chore: resolve conflicts
CodyJasonBennett Jun 4, 2024
6887b2d
chore: upgrade React to rc.0
CodyJasonBennett Jun 13, 2024
79e0247
RELEASING: Releasing 2 package(s)
CodyJasonBennett Jun 13, 2024
8fa636c
chore: cleanup migration guide
CodyJasonBennett Aug 17, 2024
7c1ea70
Merge branch 'master' into v9
CodyJasonBennett Nov 3, 2024
d3af6bd
chore: resolve conflicts
CodyJasonBennett Nov 3, 2024
18505d9
chore(tests): remove warning assertions for text
CodyJasonBennett Nov 3, 2024
451d68d
v9.0.0-rc.0
CodyJasonBennett Nov 3, 2024
fde05ed
v9.0.0-rc.1
CodyJasonBennett Nov 15, 2024
b24f62e
chore: upgrade types
CodyJasonBennett Nov 29, 2024
400b4cd
chore: React 19 released!
krispya Dec 6, 2024
55e57aa
Merge branch 'master' into v9
CodyJasonBennett Dec 9, 2024
49a87a7
chore: resolve conflicts
CodyJasonBennett Dec 9, 2024
94b4e6c
fix(renderer): null check HTMLCanvasElement global
CodyJasonBennett Jan 3, 2025
1fc2f05
fix: harden XR init against Renderer shim
CodyJasonBennett Jan 8, 2025
d9fd22e
Merge branch 'master' into v9
CodyJasonBennett Jan 9, 2025
2f54285
Merge branch 'master' into v9
CodyJasonBennett Jan 9, 2025
19eb534
fix: loosen instanceof checks for CSB issue
CodyJasonBennett Jan 9, 2025
727df3f
chore: upgrade lockfile
CodyJasonBennett Jan 9, 2025
7adecd9
fix!: set minimum three r156
CodyJasonBennett Jan 9, 2025
8f56062
fix(useLoader): use modern Loader interface, infer extensions type
CodyJasonBennett Jan 9, 2025
cea2474
Merge branch 'master' into v9
CodyJasonBennett Jan 9, 2025
074c590
fix: restrict React peer dep
CodyJasonBennett Jan 9, 2025
9abc761
fix: implement HostTransitionContext
CodyJasonBennett Jan 9, 2025
26dbf38
fix: tree-shaking
CodyJasonBennett Jan 9, 2025
f3edadb
v9.0.0-rc.2
CodyJasonBennett Jan 10, 2025
b3e4ee4
[v9] chore: replace forwardRef with props.ref (#3282)
alexandernanberg Jan 10, 2025
331cc9c
[v9] fix: only copy props if same constructor (#3429)
CodyJasonBennett Jan 10, 2025
dc8554c
refactor!: remove old Props alias
CodyJasonBennett Jan 10, 2025
293cfc2
docs: cleanup, add more extend usage
CodyJasonBennett Jan 10, 2025
a0e5376
9.0.0-rc.3
CodyJasonBennett Jan 10, 2025
e267e0d
fix(useLoader): allow mutable upstream input types
CodyJasonBennett Jan 16, 2025
4275fae
fix: bump react-native peer to 0.78
CodyJasonBennett Jan 16, 2025
e029842
9.0.0-rc.4
CodyJasonBennett Jan 16, 2025
241c3ec
feat: allow the gl prop to be async
drcmda Jan 19, 2025
c89e20a
fix: applyProps.copy, only copy own props, do not mutate external props
drcmda Jan 19, 2025
a575e65
fix: tests
drcmda Jan 19, 2025
4e607ca
add test for copy/assign
drcmda Jan 19, 2025
76fca8f
fix: root.render throws if configure isn't called, fix tests
drcmda Jan 19, 2025
e288fd6
webgpu demo
drcmda Jan 19, 2025
7711011
make gl props an object with non-optional canvas
drcmda Jan 20, 2025
009c97d
types for webgpudemo
drcmda Jan 20, 2025
ad83b46
fix: ts issues
drcmda Jan 20, 2025
9d67984
fix: line demo
drcmda Jan 20, 2025
62a0102
rc5
drcmda Jan 22, 2025
a1f6083
is await createRoot().configure(...) the cause?
drcmda Jan 26, 2025
41fd2d7
new rc for test-renderer
drcmda Jan 26, 2025
dd79fae
chore: docs
drcmda Jan 27, 2025
8e3b41e
fix: top/left event offset compute
drcmda Jan 27, 2025
29ed73f
fix: tests
drcmda Jan 27, 2025
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
2 changes: 1 addition & 1 deletion .github/workflows/test.yml
Original file line number Diff line number Diff line change
Expand Up @@ -33,7 +33,7 @@ jobs:
run: yarn run build

- name: Jest run
run: yarn run test
run: yarn run dev && yarn run test

- name: Report Fiber size
run: yarn run analyze-fiber
Expand Down
2 changes: 1 addition & 1 deletion docs/API/additional-exports.mdx
Original file line number Diff line number Diff line change
@@ -1,6 +1,6 @@
---
title: Additional Exports
nav: 9
nav: 8
---

| export | usage |
Expand Down
154 changes: 100 additions & 54 deletions docs/API/canvas.mdx
Original file line number Diff line number Diff line change
@@ -1,6 +1,6 @@
---
title: Canvas
description: 'The Canvas object is your portal into three.js.'
description: The Canvas object is your portal into three.js
nav: 4
---

Expand All @@ -23,27 +23,27 @@ const App = () => (

## Properties

| Prop | Description | Default |
| --------------- | ------------------------------------------------------------------------------------------------------------------------------------------------- | ----------------------------------------------------------------- |
| children | three.js JSX elements or regular components | |
| fallback | optional DOM JSX elements or regular components in case GL is not supported | |
| gl | Props that go into the default renderer, or your own renderer. Also accepts a synchronous callback like `gl={canvas => new Renderer({ canvas })}` | `{}` |
| camera | Props that go into the default camera, or your own `THREE.Camera` | `{ fov: 75, near: 0.1, far: 1000, position: [0, 0, 5] }` |
| scene | Props that go into the default scene, or your own `THREE.Scene` | `{}` |
| shadows | Props that go into `gl.shadowMap`, can be set true for `PCFsoft` or one of the following: 'basic', 'percentage', 'soft', 'variance' | `false` |
| raycaster | Props that go into the default raycaster | `{}` |
| frameloop | Render mode: always, demand, never | `always` |
| resize | Resize config, see react-use-measure's options | `{ scroll: true, debounce: { scroll: 50, resize: 0 } }` |
| orthographic | Creates an orthographic camera | `false` |
| dpr | Pixel-ratio, use `window.devicePixelRatio`, or automatic: [min, max] | `[1, 2]` |
| legacy | Enables THREE.ColorManagement in three r139 or later | `false` |
| linear | Switch off automatic sRGB color space and gamma correction | `false` |
| events | Configuration for the event manager, as a function of state | `import { events } from "@react-three/fiber"` |
| eventSource | The source where events are being subscribed to, HTMLElement | `React.MutableRefObject<HTMLElement>`, `gl.domElement.parentNode` |
| eventPrefix | The event prefix that is cast into canvas pointer x/y events | `offset` |
| flat | Use `THREE.NoToneMapping` instead of `THREE.ACESFilmicToneMapping` | `false` |
| onCreated | Callback after the canvas has rendered (but not yet committed) | `(state) => {}` |
| onPointerMissed | Response for pointer clicks that have missed any target | `(event) => {}` |
| Prop | Description | Default |
| --------------- | ------------------------------------------------------------------------------------------------------------------------------------------------- | ---------------------------------------------------------- |
| children | three.js JSX elements or regular components | |
| fallback | optional DOM JSX elements or regular components in case GL is not supported | |
| gl | Props that go into the default renderer. Accepts sync/async callback with default props `gl={defaults => new Renderer({ ...defaults })}` | `{}` |
| camera | Props that go into the default camera, or your own `THREE.Camera` | `{ fov: 75, near: 0.1, far: 1000, position: [0, 0, 5] }` |
| scene | Props that go into the default scene, or your own `THREE.Scene` | `{}` |
| shadows | Props that go into `gl.shadowMap`, can be set true for `PCFsoft` or one of the following: 'basic', 'percentage', 'soft', 'variance' | `false` |
| raycaster | Props that go into the default raycaster | `{}` |
| frameloop | Render mode: always, demand, never | `always` |
| resize | Resize config, see react-use-measure's options | `{ scroll: true, debounce: { scroll: 50, resize: 0 } }` |
| orthographic | Creates an orthographic camera | `false` |
| dpr | Pixel-ratio, use `window.devicePixelRatio`, or automatic: [min, max] | `[1, 2]` |
| legacy | Enables THREE.ColorManagement in three r139 or later | `false` |
| linear | Switch off automatic sRGB color space and gamma correction | `false` |
| events | Configuration for the event manager, as a function of state | `import { events } from "@react-three/fiber"` |
| eventSource | The source where events are being subscribed to, HTMLElement | `React.RefObject<HTMLElement>`, `gl.domElement.parentNode` |
| eventPrefix | The event prefix that is cast into canvas pointer x/y events | `offset` |
| flat | Use `THREE.NoToneMapping` instead of `THREE.ACESFilmicToneMapping` | `false` |
| onCreated | Callback after the canvas has rendered (but not yet committed) | `(state) => {}` |
| onPointerMissed | Response for pointer clicks that have missed any target | `(event) => {}` |

## Defaults

Expand Down Expand Up @@ -99,6 +99,29 @@ function App() {
> [!NOTE]
> Ideally, and if possible, your fallback is a seamless, visual replacement for what the canvas would have otherwise rendered.

## WebGPU

Recent Three.js now includes a WebGPU renderer. While still a work in progress and not fully backward-compatible with all of Three's features, the renderer requires an async initialization method. R3F streamlines this by allowing the gl prop to return a promise.

```jsx
import * as THREE from 'three/webgpu'
import * as TSL from 'three/tsl'
import { Canvas, extend, useFrame, useThree } from '@react-three/fiber'

export default () => (
<Canvas
gl={(props) => {
extend(THREE)
const renderer = new THREE.WebGPURenderer(props)
return renderer.init().then(() => renderer)
}}>
<mesh>
<meshBasicNodeMaterial />
<boxGeometry />
</mesh>
</Canvas>
```

## Custom Canvas

R3F can render to a root, similar to how `react-dom` and all the other React renderers work. This allows you to shave off `react-dom` (~40kb), `react-use-measure` (~3kb) and, if you don't need them, `pointer-events` (~7kb) (you need to explicitly import `events` and add them to the config otherwise).
Expand All @@ -120,22 +143,27 @@ extend(THREE)
// Create a react root
const root = createRoot(document.querySelector('canvas'))

// Configure the root, inject events optionally, set camera, etc
root.configure({ events, camera: { position: [0, 0, 50] } })
async function app() {
// Configure the root, inject events optionally, set camera, etc
// This *must* be called before render, and it must be awaited
await root.configure({ events, camera: { position: [0, 0, 50] } })

// createRoot by design is not responsive, you have to take care of resize yourself
window.addEventListener('resize', () => {
root.configure({ size: { width: window.innerWidth, height: window.innerHeight } })
})
// createRoot by design is not responsive, you have to take care of resize yourself
window.addEventListener('resize', () => {
root.configure({ size: { width: window.innerWidth, height: window.innerHeight } })
})

// Trigger resize
window.dispatchEvent(new Event('resize'))

// Trigger resize
window.dispatchEvent(new Event('resize'))
// Render entry point
root.render(<App />)

// Render entry point
root.render(<App />)
// Unmount and dispose of memory
// root.unmount()
}

// Unmount and dispose of memory
// root.unmount()
app()
```

## Tree-shaking
Expand All @@ -150,14 +178,20 @@ import { Mesh, BoxGeometry, MeshStandardMaterial } from 'three'

extend({ Mesh, BoxGeometry, MeshStandardMaterial })

createRoot(canvas).render(
<>
<mesh>
<boxGeometry />
<meshStandardMaterial />
</mesh>
</>,
)
async function app() {
const root = createRoot(document.querySelector('canvas'))
await root.configure()
root.render(
<>
<mesh>
<boxGeometry />
<meshStandardMaterial />
</mesh>
</>,
)
}

app()
```

There's an [official babel plugin](https://github.com/pmndrs/react-three-babel) which will do this for you automatically:
Expand All @@ -167,12 +201,18 @@ There's an [official babel plugin](https://github.com/pmndrs/react-three-babel)

import { createRoot } from '@react-three/fiber'

createRoot(canvasNode).render(
<mesh>
<boxGeometry />
<meshStandardMaterial />
</mesh>,
)
async function app() {
const root = createRoot(document.querySelector('canvas'))
await root.configure()
root.render(
<mesh>
<boxGeometry />
<meshStandardMaterial />
</mesh>,
)
}

app()

// Out:

Expand All @@ -185,10 +225,16 @@ extend({
MeshStandardMaterial: _MeshStandardMaterial,
})

createRoot(canvasNode).render(
<mesh>
<boxGeometry />
<meshStandardMaterial />
</mesh>,
)
async function app() {
const root = createRoot(document.querySelector('canvas'))
await root.configure()
root.render(
<mesh>
<boxGeometry />
<meshStandardMaterial />
</mesh>,
)
}

app()
```
2 changes: 1 addition & 1 deletion docs/API/events.mdx
Original file line number Diff line number Diff line change
@@ -1,7 +1,7 @@
---
title: Events
description: All the events you can hook up to
nav: 8
nav: 7
---

`three.js` objects that implement their own `raycast` method (meshes, lines, etc) can be interacted with by declaring events on them. We support pointer events, clicks and wheel-scroll. Events contain the browser event as well as the `three.js` event data (object, point, distance, etc). You may want to [polyfill](https://github.com/jquery/PEP) them, if that's a concern.
Expand Down
Loading
Loading