You signed in with another tab or window. Reload to refresh your session.You signed out in another tab or window. Reload to refresh your session.You switched accounts on another tab or window. Reload to refresh your session.Dismiss alert
When using Stage with custom width and height props, the app refreshes or crashes on older iPads in both Chrome and Safari, indicating a potential memory leak. The app's memory usage isn't high, so we suspect that, due to some internal handling by React Pixi, the WebGL context isn't being cleaned up properly when custom width and height parameters are provided. iPadOS on these older devices can handle approximately 16 active WebGL contexts, and we experience the crash at the exact same point in our app every time. When no custom width and height props are provided, the Stage uses the default values, and there's no crash. Even if we provide fixed values to the Stage, it still refreshes or crashes the browser. <Stage width={700} height={900}>...</Stage>
The app even crashes when we only have an empty canvas.
The app doesn't crash on newer iPads.
Notes:
Internal Behavior of the Stage Component When width and height Are Specified:
Re-initialization of PixiJS Application:
When you specify width and height, the Stage component might be disposing of the existing PixiJS application and creating a new one to apply the new dimensions.
This can happen even if the values haven't changed because the presence of these props might trigger an internal update mechanism.
Result: Multiple PixiJS applications and WebGL contexts might be created without properly disposing of the previous ones, leading to resource leaks and eventual crashes.
Canvas Resizing and WebGL Context Loss:
Specifying width and height could cause the canvas to resize, which may lead to the WebGL context being lost and a new one being created.
Impact on iOS Devices:
iOS devices like the iPad have strict limits on the number of WebGL contexts (usually around 16).
Exceeding this limit by creating new contexts without disposing of old ones can cause the app to refresh/crash.
Expected Behavior
Browser should not refresh/crash when using width and height on Stage. Pixi JS application WebGL contexts should be cleaned up.
Steps to Reproduce
Create stage with fixed width and height provided <Stage width="700" height="900">...<Stage />
Stage has to be re-rendered a couple of times and the browser will eventually refresh/crash
Environment
@pixi/react version: e.g. 7.1.0
pixi.js version: e.g. 7.2.4
React version: e.g. 18.2.0
ReactDOM version: e.g. 18.2.0
Browser & Version: *e.g. Chrome 127.0.0 * and latest
OS & Version: e.g. iPadOS 17.5.1
**iPad version: iPad Pro. 3rd gen
Possible Solution
No response
Additional Information
No response
The text was updated successfully, but these errors were encountered:
Some remarks after having had similar issues outside of PIXI-React (in a React app using "raw" PIXI via React effects):
Even desktop browsers have hard limits on the number of WebGL contexts (I think it is 16 on Chrome, and it might be only 8 on iOS devices). Unfortunately, it turns out that it is just not possible to explicitly clean up WebGL contexts, it happens during garbage collection whenever the browser feels like it. So the only solution I found is to avoid recreating too many contexts.
So check if your app somehow recreates WebGL contexts in situations where they could be reused. For instance if some component containing a canvas is repeatedly mounted and unmounted, try to find a way to put the canvas in a more stable parent component that won't need to be remounted as often. Or hide the component via CSS rather than unmounting it.
Current Behavior
When using Stage with custom
width
andheight
props, the app refreshes or crashes on older iPads in both Chrome and Safari, indicating a potential memory leak. The app's memory usage isn't high, so we suspect that, due to some internal handling by React Pixi, the WebGL context isn't being cleaned up properly when customwidth
andheight
parameters are provided. iPadOS on these older devices can handle approximately 16 active WebGL contexts, and we experience the crash at the exact same point in our app every time. When no custom width and height props are provided, the Stage uses the default values, and there's no crash. Even if we provide fixed values to the Stage, it still refreshes or crashes the browser.<Stage width={700} height={900}>...</Stage>
The app even crashes when we only have an empty canvas.
The app doesn't crash on newer iPads.
Notes:
Internal Behavior of the Stage Component When width and height Are Specified:
When you specify width and height, the Stage component might be disposing of the existing PixiJS application and creating a new one to apply the new dimensions.
This can happen even if the values haven't changed because the presence of these props might trigger an internal update mechanism.
Result: Multiple PixiJS applications and WebGL contexts might be created without properly disposing of the previous ones, leading to resource leaks and eventual crashes.
Specifying width and height could cause the canvas to resize, which may lead to the WebGL context being lost and a new one being created.
iOS devices like the iPad have strict limits on the number of WebGL contexts (usually around 16).
Exceeding this limit by creating new contexts without disposing of old ones can cause the app to refresh/crash.
Expected Behavior
Browser should not refresh/crash when using
width
andheight
onStage
. Pixi JS application WebGL contexts should be cleaned up.Steps to Reproduce
<Stage width="700" height="900">...<Stage />
Environment
@pixi/react
version: e.g. 7.1.0pixi.js
version: e.g. 7.2.4React
version: e.g. 18.2.0ReactDOM
version: e.g. 18.2.0iPad
version: iPad Pro. 3rd genPossible Solution
No response
Additional Information
No response
The text was updated successfully, but these errors were encountered: