Hooks
PlayCanvas React provides a comprehensive set of React hooks that make it easy to integrate PlayCanvas functionality into your React applications. These hooks handle the complex lifecycle management and provide a clean, React-friendly API.
Available Hooks
Core Hooks
Asset Loading Hooks
- useAsset - Load any type of PlayCanvas asset
- useModel - Load 3D models (GLB/GLTF)
- useTexture - Load texture assets
- useSplat - Load Gaussian splat assets
- useEnvAtlas - Load environment atlas textures
- useFont - Load font assets
Event and Animation Hooks
- useAppEvent - Subscribe to PlayCanvas application events
Material and Physics Hooks
- useMaterial - Create and manage materials
- usePhysics - Access physics context and state
Usage Pattern
Most hooks follow a consistent pattern:
import { useApp, useAsset } from '@playcanvas/react/hooks'
function MyComponent() {
  const app = useApp()
  const { asset, loading, error } = useAsset('model.glb', 'container')
  
  if (loading) return <div>Loading...</div>
  if (error) return <div>Error: {error}</div>
  
  return <Container asset={asset} />
}
Context Requirements
Many hooks require specific React contexts to be available:
- useApp requires an <Application>component in the component tree
- useParent requires an <Entity>component in the component tree
- usePhysics requires physics to be enabled on the Application
TypeScript Support
All hooks are fully typed with TypeScript and provide excellent IntelliSense support. The hooks automatically infer types from the PlayCanvas engine types.
// Fully typed with PlayCanvas types
const app = useApp() // Application
const entity = useParent() // Entity
const { asset } = useAsset('texture.jpg', 'texture') // Asset | null
Best Practices
- Always check loading states when using asset hooks
- Handle errors gracefully for better user experience
- Use the appropriate hook for your specific use case
- Clean up subscriptions are handled automatically by the hooks
- Follow React rules - hooks should only be called at the top level of components