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

Improve compatibility of three/webgpu with nextjs #29916

Closed
whatisor opened this issue Nov 17, 2024 · 10 comments · Fixed by #29919
Closed

Improve compatibility of three/webgpu with nextjs #29916

whatisor opened this issue Nov 17, 2024 · 10 comments · Fixed by #29919
Labels
Milestone

Comments

@whatisor
Copy link
Contributor

Description

As default, 1 threejs project working on nextjs, which wants to upgrade to WebGPU, needs dynamic import for three/webgpu component.
This has some limitation during development.

Solution

We should be able to avoid all client code style as "self." in global scope.

Alternatives

NA

Additional context

No response

@Mugen87
Copy link
Collaborator

Mugen87 commented Nov 18, 2024

Do you mind explaining in more detail what parts of WebGPURenderer have issues with nextjs? Based on what you have written so far I'm afraid this aspect is not clear yet.

@whatisor
Copy link
Contributor Author

It cannot compile with error that self. is undefined because code is compiled in backend side without dynamic import.
I know threejs is client side code but webglrenderer does not have that issue.
image

@whatisor
Copy link
Contributor Author

I am testing it here:
next-three-webgpu

@Mugen87
Copy link
Collaborator

Mugen87 commented Nov 18, 2024

@RenaudRohlinger This is the line in question:

const GPUShaderStage = self.GPUShaderStage;

Could this section be rewritten like so?

// GPUShaderStage is not defined in browsers not supporting WebGPU
const GPUShaderStage = ( typeof self !== 'undefined' ) ? self.GPUShaderStage : { VERTEX: 1, FRAGMENT: 2, COMPUTE: 4 };

const wrapNames = {
	[ RepeatWrapping ]: 'repeat',
	[ ClampToEdgeWrapping ]: 'clamp',
	[ MirroredRepeatWrapping ]: 'mirror'
};

const gpuShaderStageLib = {
	'vertex': GPUShaderStage.VERTEX,
	'fragment': GPUShaderStage.FRAGMENT,
	'compute': GPUShaderStage.COMPUTE
};

@Mugen87 Mugen87 added the WebGPU label Nov 18, 2024
@RenaudRohlinger
Copy link
Collaborator

I believe so, also I'm surprised nextjs got the issue, I'm using the WebGPURenderer in OffScreen Canvas actively.

@whatisor
Copy link
Contributor Author

whatisor commented Nov 18, 2024

It needs more broadly approaching for all "self." or "navigator." code around code of webgpu parts

@donmccurdy
Copy link
Collaborator

I am testing it here: next-three-webgpu

@whatisor cloning this repo and running yarn dev and yarn build locally, I'm not seeing any errors. Are additional steps needed to reproduce the error described in #29916 (comment) ?

@whatisor
Copy link
Contributor Author

whatisor commented Nov 20, 2024

@donmccurdy using dynamic import in that project is not a good way, just work around to overcome it.
Client code have worse performance and less Lint activity.

@donmccurdy
Copy link
Collaborator

donmccurdy commented Nov 20, 2024

@whatisor WebGPU does not exist in Node.js, and cannot be used for server-side rendering (SSR). three.js renderers cannot operate in a Node.js environment, so I'm not sure a performance comparison is meaningful.

Maybe we can avoid top-level await, and fix issues that would prevent importing three.js in a Node.js environment, but I don't think putting typeof checks in front of every reference to Web APIs in three.js is a good use of time... are you sure that lazy-loading and dynamic import aren't the right choice here? I don't think you want your server to spend time parsing 3D models and textures on each request, for example, only to throw that work away.

@whatisor
Copy link
Contributor Author

whatisor commented Nov 20, 2024

@donmccurdy Server will not handle any 3D resource, it compiles app script at compile time with best Lint support and prerender html only at runtime.
There are many limitation of next dynamic you will get on because of 2 mode of ssr. It is not a good deal for big project.
And you will not want to load big script bundle at client.

I am sure we can do it well as webglrenderer. This is not a big issue, just avoid "global scope" in code.

@Mugen87 Mugen87 added this to the r171 milestone Nov 24, 2024
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
Projects
None yet
Development

Successfully merging a pull request may close this issue.

4 participants