-
-
Notifications
You must be signed in to change notification settings - Fork 182
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
Pixi React v8 #493
Comments
Thanks for your work on this @trezy! I wonder how much the pixi/react API night change? I know the Pixi 8 API changes a bit, but I'm wondering if the next version of pixi/react is expected to have its own set of API changes on top of that? |
@Nantris: Yeah, the new API for Pixi React will be subtly different from v7. For example, here's a basic application with v7 vs the same application with v8: // Pixi React v7
import { Container, Sprite, Stage, Text } from '@pixi/react';
export const MyComponent = () => {
return (
<Stage options={{ background: 0xffffff }}>
<Sprite
anchor={{ x: 0.5, y: 0.5 }}
image="https://pixijs.io/pixi-react/img/bunny.png"
x={400}
y={270} />
<Container x={400} y={330}>
<Text
anchor={{ x: 0.5, y: 0.5 }}
text="Hello World" />
</Container>
</Stage>
);
}; // Pixi React v8
import { Container, Sprite, Text } from 'pixi.js'
import { Application, useAsset, useExtend } from '@pixi/react';
export const MyComponent = () => {
useExtend({ Container, Sprite, Text })
const texture = useAsset({ src: 'https://pixijs.com/assets/bunny.png' })
return (
<Application background={0xffffff} >
{texture && (
<sprite
anchor={{ x: 0.5, y: 0.5 }}
texture
x={400}
y={270} />
)}
<container x={400} y={330}>
<text
anchor={{ x: 0.5, y: 0.5 }}
text={'Hello World'} />
</container>
</Application>
);
}; A few important differences to notice:
More additionsOnce released, this syntax will always work. However, I intend to add a couple of other features that will add even more utility to the library:
|
This comment was marked as spam.
This comment was marked as spam.
This comment was marked as spam.
This comment was marked as spam.
Just wanted to drop in and say thank you for the hard work. I've been using the v8 beta and its such a huge improvement. Very excited for the release ❤️ |
+1 to the above. Very excited to see this drop! |
This is exactly the feature I wanted. |
This comment was marked as off-topic.
This comment was marked as off-topic.
@nightgrey Please create a new issue with these details. Leaving it in the comments of another ticket will result in the issue being lost in the clutter. |
@trezy Thank you so much for your work! Would you say this is stable enough to start making hobby projects with it already? I would really love the new v8 performance |
@P3ntest Yup! I've been using it in hobby projects already. 😁 |
This looks super cool! Currently looking at this option as a replacement for our current setup with svg elements and react-spring. Any thoughts on how the new architecture would handle something like the react-spring library for elements that are reactive and dynamic, or if it would still be necessary in the first place? For example, react-three/fiber suggests that for rapidly changing values, you either use something like react-spring or their |
For what it's worth, I've used both pixi-react v7 and v8 in small games with a lot of animations, once with only regular React state, and once with MobX, and it worked just fine. Contrary to popular opinion, React is perfectly capable of handling 60 fps, although you might have to keep an eye on performance and optimize rerenders sometimes. |
amazing work; I personally have lots of small issues; some easy to work around, some less:
but it looks super promising ! thanks |
@trezy Hey! Thanks for your great work! Should I use vanilla Pixi8 with react or better to use pixi v7 but with pixi-react ? |
@bulbazavr1024 Personally I'm using the latest beta with Pixi v8 in my projects already. That said, I'm planning to get a release candidate ready over my winter break. That's going to include dropping support for React 18 and below in favour of supporting React 19. That could be a deal breaker for some folx, so it's probably an important thing to keep in mind. |
@trezy Thanks for your reply! Do you have any estimate time when we can expect stable release version ? Do you plan to make breaking changes that will break beta and release version ? And do you know about performance improvement version 8 vs 7 ? |
Overview
This issue will track progress on version 8 of Pixi React. This new major version is a complete rewrite of the library and will support Pixi.js v8.
Thesis
The v7 codebase of Pixi React has served its purpose, but it has become burdensome to maintain. Especially with the release of Pixi.js v8 and the significant number of breaking changes it introduced, it makes more sense to rebuild this library from scratch than to continue supporting the legacy codebase.
For this complete rewrite, we'll take a new approach to the library's implementation by introducing a custom React Pixi pragma, an
extend
API, and reflecting all Pixi components as React components. This rewrite is heavily influenced by the prior art of@react-three/fiber
, and I've been receiving significant help from @CodyJasonBennett and @krispya.A new pragma
React allows custom reconcilers to tap into its re/rendering logic. React Pixi has been using a custom reconciler for some time, but the library provided custom components that used this reconciler to manage their own rendering lifecycle. These components need to be maintained, and their logic could require changes depending on how the core Pixi.js library changed.
With a new JSX pragma, we can eliminate the need for custom components. Instead, we reflect Pixi.js components directly into the pragma and proxy their JSX props back as Pixi.js component props. This allows us to expose all Pixi.js components now and in the future with no changes to React Pixi.
The
extend
APITo provide all components as a pragma would typically require us to import the entirety of Pixi.js into the Pixi React library, making tree shaking difficult and significantly increasing the build size for anybody trying to use Pixi.js v8. Instead, we're leveraging an
extend
API allowing users to import only the Pixi.js APIs they require, thus cutting down on bundle sizes.The API will be available as both a Vanilla
extend
method and auseExtend
React hook. An example of what this will look like:Exposing all of Pixi.js
Combining the new pragma and the
extend
API, we can use the entirety of Pixi.js via JSX. Any properties that you would normally set directly on a Pixi.js component will be managed via JSX props, while the components will be exposed directly through their refs. This enables lots of creative use cases, e.g. defining Pixi.jsFilter
s in JSX...More intuitive support down the road
The
BlurFilter
implementation above is a great example of something I've already got an eye towards improving. I'd like to create anattach
API similar to that of@react-three/fiber
, allowing non-directly-rendered components (like filters, textures, etc) to be automatically attached to their parent components. I'd also like to add support for creatingText
components with normal JSX text nodes.In short, I'd like to make the library as intuitive as possible. I'll add basic documentation for React Pixi, but the hope is that most APIs will be best served by the core Pixi.js documentation.
Development process
I've been using the
dev
branch as a sort of test bed for this update. Every update that's pushed to thedev
branch of the repo will be deployed to thedev
tag on npm. That said, these builds are not stable. Many of them will be completely broken until we're in a more stable place with the update (hopefully soon!). I do not recommend installing from thedev
tag. You have been warned.Once we're ready for user feedback, I'll post to the Official Pixi.js Discord. Make sure to join and enable notifications if you want to know when new versions are ready for testing. 😁
Tasks
key
typecheck error #494Cannot insert node before itself
on conditional rendering #495<text>
component throws type errors #500vite dev
#506The text was updated successfully, but these errors were encountered: