Security News
cURL Project and Go Security Teams Reject CVSS as Broken
cURL and Go security teams are publicly rejecting CVSS as flawed for assessing vulnerabilities and are calling for more accurate, context-aware approaches.
@pixi/react
Advanced tools
Simply the best way to write PixiJS applications in React
Write PixiJS applications using React declarative style 👌
Pixi React is an open-source, production-ready library to render high performant PixiJS applications in React.
If you want to start a new React project from scratch then we recommend Create React App, but Pixi React should work with any React application (Remix, Next.js, etc). To add to an existing React application, just install the dependencies:
npm install pixi.js@^8.2.1 @pixi/react
import {
Application,
extend,
} from '@pixi/react'
import {
Container,
Graphics,
} from 'pixi.js'
import { useCallback } from 'react'
extend({
Container,
Graphics,
})
const MyComponent = () => {
const drawCallback = useCallback(graphics => {
graphics.clear()
graphics.setFillStyle({ color: 'red' })
graphics.rect(0, 0, 100, 100)
graphics.fill()
}, [])
return (
<Application>
<container x={100} y={100}>
<graphics draw={drawCallback} />
</container>
</Application>
)
}
extend
One of the most important concepts to understand with Pixi React v7 is extend
. Normally, Pixi React would have to import all pf Pixi.js to be able to provide the full library as JSX components. Instead, we use an internal catalogue of components populated by the extend
API. This allows you to define exactly which parts of Pixi.js you want to import, keeping your bundle sizes small.
To allow Pixi React to use a Pixi.js component, pass it to the extend
API:
import { Container } from 'pixi.js'
import { extend } from '@pixi/react'
extend({ Container })
const MyComponent = () => (
<container />
)
[!CAUTION] Attempting to use components that haven't been passed to the
extend
API will result in errors.
<Application>
The <Application>
component is used to wrap your Pixi React app. The <Application>
component can take all props that can be set on PIXI.Application
.
import { Application } from '@pixi/react'
const MyComponent = () => {
return (
<Application
autoStart
sharedTicker />
)
}
defaultTextStyle
defaultTextStyle
is a convenience property. Whatever is passed will automatically be assigned to Pixi.js'sTextStyle.defaultTextStyle
.
[!NOTE] This property is not retroactive. It will only apply to text components created after
defaultTextStyle
is set. Any text components created before settingdefaultTextStyle
will retain the base styles they had beforedefaultTextStyle
was changed.
resizeTo
The <Application>
component supports the resizeTo
property, with some additional functionality: it can accept any HTML element or it can take a React ref
directly.
import { Application } from '@pixi/react'
import { useRef } from 'react'
const MyComponent = () => {
const parentRef = useRef(null)
return (
<div ref={parentRef}>
<Application resizeTo={parentRef} />
</div>
)
}
All other Pixi React components should be included in your IDE's intellisense/autocomplete once you've installed/imported @pixi/react
. If it's exported from Pixi.js, it's supported as a component in Pixi React. The only difference is that Pixi React components will always start with lowercase characters. Here's a selection of commonly used components:
<container />
<graphics />
<sprite />
<animatedSprite />
<text />
<htmlText />
<graphics>
The graphics
component has a special draw
property. draw
takes a callback which receives the Graphics
context, allowing drawing to happen on every tick.
const MyComponent = () => {
return (
<graphics draw={graphics => {
graphics.clear()
graphics.setFillStyle({ color: 'red' })
graphics.rect(0, 0, 100, 100)
graphics.fill()
}} />
)
}
[!IMPORTANT] You may run into some components that conflict with others. For example, the
<text>
component conflicts with the<text>
component that's built-in to React for use in SVGs. To address this issue, all components are available with thepixi
prefix. For example, you can replace the<text>
component with the<pixiText>
component. It will have the same functionality with none of the collisions.
Pixi React supports custom components via the extend
API. For example, you can create a <viewport>
component using the pixi-viewport
library:
import { extend } from '@pixi/react'
import { Viewport } from 'pixi-viewport'
extend({ viewport })
const MyComponent = () => {
<viewport>
<container />
</viewport>
}
If you're using Typescript, this new <viewport>
component will throw type errors. Pixi React exports a PixiReactNode
type that can be used to solve this. You'll need to pass the Viewport
into PixiReactNode
and inject it into JSX:
import type { PixiReactNode } from '@pixi/react'
import type { Viewport } from 'pixi-viewport'
declare global {
namespace JSX {
interface IntrinsicElements {
viewport: PixiReactNode<typeof Viewport>;
}
}
}
useApp
useApp
allows access to the parent PIXI.Application
created by the <Application>
component. This hook will not work outside of an <Application>
component. Additionally, the parent application is passed via React Context. This means useApp
will only work appropriately in child components, and not directly in the component that contains the <Application>
component.
For example, the following example useApp
will not be able to access the parent application:
import {
Application,
useApp,
} from '@pixi/react'
const ParentComponent = () => {
// This will cause an invariant violation.
const app = useApp()
return (
<Application />
)
}
Here's a working example where useApp
will be able to access the parent application:
import {
Application,
useApp,
} from '@pixi/react'
const ChildComponent = () => {
const app = useApp()
console.log(app)
return (
<container />
)
}
const ParentComponent = () => (
<Application>
<ChildComponent />
</Application>
)
useAsset
The useAsset
hook wraps the functionality of Pixi's Asset loader and cache into a convenient React hook. The hook can accept either an UnresolvedAsset
or a url.
import { useAsset } from '@pixi/react'
const MyComponent = () => {
const bunnyTexture = useAsset('https://pixijs.com/assets/bunny.png')
const bunnyTexture2 = useAsset({
alias: 'bunny',
src: 'https://pixijs.com/assets/bunny.png',
})
return (
<container>
<sprite texture={bunnyTexture}>
<sprite texture={bunnyTexture2}>
</container>
)
}
useAsset
can optionally accept a ProgressCallback
as a second argument. This callback will be called by the asset loader as the asset is loaded.
const bunnyTexture = useAsset('https://pixijs.com/assets/bunny.png', progress => {
console.log(`We have achieved ${progress * 100}% bunny.`)
})
[!TIP] The
useAsset
hook also supports React Suspense! If given a suspense boundary, it's possible to prevent components from rendering until they've finished loading their assets:
import { Application, useAsset, } from '@pixi/react' import { Suspense } from 'react'; const BunnySprite = () => { const bunnyTexture = useAsset('https://pixijs.com/assets/bunny.png') return ( <sprite texture={bunnyTexture} /> ) } const LoadingText = () => ( <pixiText text={'Loading...'} /> ) const MyApp = () => ( <Application> <Suspense fallback={<LoadingText />}> <BunnySprite /> </Suspense> </Application> )
useExtend
useExtend
allows the extend
API to be used as a React hook. Additionally, the useExtend
hook is memoised, while the extend
function is not.
import { Container } from 'pixi.js'
import { useExtend } from '@pixi/react'
const MyComponent = () => {
useExtend({ Container })
return (
<container />
)
}
useTick
useTick
allows a callback to be attached to the Ticker
on the parent application.
import { useTick } from '@pixi/react'
const MyComponent = () => {
useTick(() => console.log('This will be logged on every tick'))
}
useTick
optionally takes a boolean as a second argument. Setting this boolean to false
will cause the callback to be disabled until the argument is set to true again.
import { useState } from 'react'
import { useTick } from '@pixi/react'
const MyComponent = () => {
const [isEnabled, setIsEnabled] = useState(false)
useTick(() => console.log('This will be logged on every tick as long as `isEnabled` is `true`'), )
return (
<sprite onClick={setIsEnabled(previousState => !previousState)}>
)
}
FAQs
Write PixiJS applications using React declarative style.
The npm package @pixi/react receives a total of 13,118 weekly downloads. As such, @pixi/react popularity was classified as popular.
We found that @pixi/react demonstrated a healthy version release cadence and project activity because the last version was released less than a year ago. It has 4 open source maintainers collaborating on the project.
Did you know?
Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.
Security News
cURL and Go security teams are publicly rejecting CVSS as flawed for assessing vulnerabilities and are calling for more accurate, context-aware approaches.
Security News
Bun 1.2 enhances its JavaScript runtime with 90% Node.js compatibility, built-in S3 and Postgres support, HTML Imports, and faster, cloud-first performance.
Security News
Biden's executive order pushes for AI-driven cybersecurity, software supply chain transparency, and stronger protections for federal and open source systems.