From af89ab94a683dd403c3125f7fda35899b58f2cb3 Mon Sep 17 00:00:00 2001 From: Zyie Date: Wed, 8 Jan 2025 15:03:13 +0000 Subject: [PATCH] Deploy website - based on d1841f21fac19ffe2d0fb4b17c36b72ce7b6ba2b --- 404.html | 2 +- 7.x/branding.html | 2 +- 7.x/examples.html | 2 +- 7.x/examples/advanced/collision-detection.html | 2 +- 7.x/examples/advanced/mouse-trail.html | 2 +- 7.x/examples/advanced/scratch-card.html | 2 +- 7.x/examples/advanced/screen-shot.html | 2 +- 7.x/examples/advanced/slots.html | 2 +- 7.x/examples/advanced/spinners.html | 2 +- 7.x/examples/advanced/star-warp.html | 2 +- 7.x/examples/assets/async.html | 2 +- 7.x/examples/assets/background.html | 2 +- 7.x/examples/assets/bundle.html | 2 +- 7.x/examples/assets/multiple.html | 2 +- 7.x/examples/assets/promise.html | 2 +- 7.x/examples/basic/blend-modes.html | 2 +- 7.x/examples/basic/cache-as-bitmap.html | 2 +- 7.x/examples/basic/container.html | 2 +- 7.x/examples/basic/particle-container.html | 2 +- 7.x/examples/basic/simple-plane.html | 2 +- 7.x/examples/basic/tinting.html | 2 +- 7.x/examples/basic/transparent-background.html | 2 +- 7.x/examples/events/click.html | 2 +- 7.x/examples/events/custom-hitarea.html | 2 +- 7.x/examples/events/custom-mouse-icon.html | 2 +- 7.x/examples/events/dragging.html | 2 +- 7.x/examples/events/interactivity.html | 2 +- 7.x/examples/events/logger.html | 2 +- 7.x/examples/events/nested-boundary-with-projection.html | 2 +- 7.x/examples/events/pointer-tracker.html | 2 +- 7.x/examples/events/slider.html | 2 +- 7.x/examples/filters-advanced/custom.html | 2 +- 7.x/examples/filters-advanced/mouse-blending.html | 2 +- .../filters-advanced/shader-toy-filter-render-texture.html | 2 +- 7.x/examples/filters-basic/blur.html | 2 +- 7.x/examples/filters-basic/color-matrix.html | 2 +- 7.x/examples/filters-basic/displacement-map-crawlies.html | 2 +- 7.x/examples/filters-basic/displacement-map-flag.html | 2 +- 7.x/examples/graphics/advanced.html | 2 +- 7.x/examples/graphics/dynamic.html | 2 +- 7.x/examples/graphics/simple.html | 2 +- 7.x/examples/masks/filter.html | 2 +- 7.x/examples/masks/graphics.html | 2 +- 7.x/examples/masks/sprite.html | 2 +- 7.x/examples/mesh-and-shaders/instanced-geometry.html | 2 +- 7.x/examples/mesh-and-shaders/interleaving-geometry.html | 2 +- 7.x/examples/mesh-and-shaders/merging-geometry.html | 2 +- .../mesh-and-shaders/multi-pass-shader-generated-mesh.html | 2 +- 7.x/examples/mesh-and-shaders/shader-toy-mesh.html | 2 +- 7.x/examples/mesh-and-shaders/shared-shader.html | 2 +- 7.x/examples/mesh-and-shaders/sharing-geometry.html | 2 +- 7.x/examples/mesh-and-shaders/textured-mesh-advanced.html | 2 +- 7.x/examples/mesh-and-shaders/textured-mesh-basic.html | 2 +- 7.x/examples/mesh-and-shaders/triangle-color.html | 2 +- 7.x/examples/mesh-and-shaders/triangle-textured.html | 2 +- 7.x/examples/mesh-and-shaders/triangle.html | 2 +- 7.x/examples/mesh-and-shaders/uniforms.html | 2 +- 7.x/examples/offscreen-canvas/basic.html | 2 +- 7.x/examples/sprite/animated-sprite-animation-speed.html | 2 +- 7.x/examples/sprite/animated-sprite-explosion.html | 2 +- 7.x/examples/sprite/animated-sprite-jet.html | 2 +- 7.x/examples/sprite/basic.html | 2 +- 7.x/examples/sprite/texture-swap.html | 2 +- 7.x/examples/sprite/tiling-sprite.html | 2 +- 7.x/examples/sprite/video.html | 2 +- 7.x/examples/text/bitmap-text.html | 2 +- 7.x/examples/text/from-font.html | 2 +- 7.x/examples/text/pixi-text.html | 2 +- 7.x/examples/text/web-font.html | 2 +- 7.x/examples/textures/gradient-basic.html | 2 +- 7.x/examples/textures/gradient-resource.html | 2 +- 7.x/examples/textures/render-texture-advanced.html | 2 +- 7.x/examples/textures/render-texture-basic.html | 2 +- 7.x/examples/textures/texture-rotate.html | 2 +- 7.x/faq.html | 2 +- 7.x/guides.html | 2 +- 7.x/guides/basics/architecture-overview.html | 2 +- 7.x/guides/basics/getting-started.html | 2 +- 7.x/guides/basics/render-loop.html | 2 +- 7.x/guides/basics/scene-graph.html | 2 +- 7.x/guides/basics/what-pixijs-is-not.html | 2 +- 7.x/guides/basics/what-pixijs-is.html | 2 +- 7.x/guides/components/assets.html | 2 +- 7.x/guides/components/containers.html | 2 +- 7.x/guides/components/display-object.html | 2 +- 7.x/guides/components/graphics.html | 2 +- 7.x/guides/components/interaction.html | 2 +- 7.x/guides/components/sprite-sheets.html | 2 +- 7.x/guides/components/sprites.html | 2 +- 7.x/guides/components/text.html | 2 +- 7.x/guides/components/textures.html | 2 +- 7.x/guides/migrations/upgrading.html | 2 +- 7.x/guides/migrations/v5.html | 2 +- 7.x/guides/migrations/v6.html | 2 +- 7.x/guides/migrations/v7.html | 2 +- 7.x/guides/production/performance-tips.html | 2 +- 7.x/playground.html | 2 +- 7.x/search-index-blog.json | 2 +- 7.x/search-index.json | 2 +- 7.x/tutorials.html | 2 +- 7.x/tutorials/getting-started.html | 2 +- 8.x/branding.html | 2 +- 8.x/examples.html | 2 +- 8.x/examples/advanced/collision-detection.html | 2 +- 8.x/examples/advanced/mouse-trail.html | 2 +- 8.x/examples/advanced/scratch-card.html | 2 +- 8.x/examples/advanced/screen-shot.html | 2 +- 8.x/examples/advanced/slots.html | 2 +- 8.x/examples/advanced/spinners.html | 2 +- 8.x/examples/advanced/star-warp.html | 2 +- 8.x/examples/assets/async.html | 2 +- 8.x/examples/assets/background.html | 2 +- 8.x/examples/assets/bundle.html | 2 +- 8.x/examples/assets/multiple.html | 2 +- 8.x/examples/assets/promise.html | 2 +- 8.x/examples/basic/blend-modes.html | 2 +- 8.x/examples/basic/cache-as-texture.html | 2 +- 8.x/examples/basic/container.html | 2 +- 8.x/examples/basic/mesh-plane.html | 2 +- 8.x/examples/basic/particle-container.html | 2 +- 8.x/examples/basic/render-group.html | 2 +- 8.x/examples/basic/tinting.html | 2 +- 8.x/examples/basic/transparent-background.html | 2 +- 8.x/examples/events/click.html | 2 +- 8.x/examples/events/custom-hitarea.html | 2 +- 8.x/examples/events/custom-mouse-icon.html | 2 +- 8.x/examples/events/dragging.html | 2 +- 8.x/examples/events/interactivity.html | 2 +- 8.x/examples/events/logger.html | 2 +- 8.x/examples/events/pointer-tracker.html | 2 +- 8.x/examples/events/slider.html | 2 +- 8.x/examples/filters-advanced/custom.html | 2 +- 8.x/examples/filters-advanced/mouse-blending.html | 2 +- 8.x/examples/filters-basic/blur.html | 2 +- 8.x/examples/filters-basic/color-matrix.html | 2 +- 8.x/examples/filters-basic/displacement-map-crawlies.html | 2 +- 8.x/examples/filters-basic/displacement-map-flag.html | 2 +- 8.x/examples/graphics/advanced.html | 2 +- 8.x/examples/graphics/dynamic.html | 2 +- 8.x/examples/graphics/fill-gradient.html | 2 +- 8.x/examples/graphics/mesh-from-path.html | 2 +- 8.x/examples/graphics/pixel-line.html | 2 +- 8.x/examples/graphics/simple.html | 2 +- 8.x/examples/graphics/svg-load.html | 2 +- 8.x/examples/graphics/svg.html | 2 +- 8.x/examples/graphics/texture.html | 2 +- 8.x/examples/masks/filter.html | 2 +- 8.x/examples/masks/graphics.html | 2 +- 8.x/examples/masks/inverse-mask.html | 2 +- 8.x/examples/masks/sprite.html | 2 +- 8.x/examples/mesh-and-shaders/instanced-geometry.html | 2 +- 8.x/examples/mesh-and-shaders/multipass-mesh.html | 2 +- 8.x/examples/mesh-and-shaders/perspective-mesh.html | 2 +- 8.x/examples/mesh-and-shaders/shader-toy-mesh.html | 2 +- 8.x/examples/mesh-and-shaders/shared-geometry.html | 2 +- 8.x/examples/mesh-and-shaders/shared-shader.html | 2 +- 8.x/examples/mesh-and-shaders/textured-mesh-advanced.html | 2 +- 8.x/examples/mesh-and-shaders/textured-mesh-basic.html | 2 +- 8.x/examples/mesh-and-shaders/triangle-color.html | 2 +- 8.x/examples/mesh-and-shaders/triangle-textured.html | 2 +- 8.x/examples/mesh-and-shaders/triangle.html | 2 +- 8.x/examples/offscreen-canvas/basic.html | 2 +- 8.x/examples/sprite/animated-sprite-animation-speed.html | 2 +- 8.x/examples/sprite/animated-sprite-explosion.html | 2 +- 8.x/examples/sprite/animated-sprite-jet.html | 2 +- 8.x/examples/sprite/basic.html | 2 +- 8.x/examples/sprite/texture-swap.html | 2 +- 8.x/examples/sprite/tiling-sprite.html | 2 +- 8.x/examples/sprite/video.html | 2 +- 8.x/examples/text/bitmap-text.html | 2 +- 8.x/examples/text/from-font.html | 2 +- 8.x/examples/text/pixi-text.html | 2 +- 8.x/examples/text/web-font.html | 2 +- 8.x/examples/textures/render-texture-advanced.html | 2 +- 8.x/examples/textures/render-texture-basic.html | 2 +- 8.x/examples/textures/texture-rotate.html | 2 +- 8.x/faq.html | 2 +- 8.x/guides.html | 2 +- 8.x/guides/advanced/cache-as-texture.html | 2 +- 8.x/guides/advanced/render-groups.html | 2 +- 8.x/guides/basics/architecture-overview.html | 2 +- 8.x/guides/basics/getting-started.html | 2 +- 8.x/guides/basics/render-loop.html | 2 +- 8.x/guides/basics/scene-graph.html | 2 +- 8.x/guides/basics/what-pixijs-is-not.html | 2 +- 8.x/guides/basics/what-pixijs-is.html | 2 +- 8.x/guides/components/assets.html | 2 +- 8.x/guides/components/containers.html | 2 +- 8.x/guides/components/graphics-pixel-line.html | 2 +- 8.x/guides/components/graphics.html | 2 +- 8.x/guides/components/interaction.html | 2 +- 8.x/guides/components/sprite-sheets.html | 2 +- 8.x/guides/components/sprites.html | 2 +- 8.x/guides/components/text.html | 2 +- 8.x/guides/components/textures.html | 2 +- 8.x/guides/migrations/v5.html | 2 +- 8.x/guides/migrations/v6.html | 2 +- 8.x/guides/migrations/v7.html | 2 +- 8.x/guides/migrations/v8.html | 2 +- 8.x/guides/production/performance-tips.html | 2 +- 8.x/playground.html | 2 +- 8.x/tutorials.html | 2 +- 8.x/tutorials/choo-choo-train.html | 2 +- 8.x/tutorials/fish-pond.html | 2 +- 8.x/tutorials/getting-started.html | 2 +- 8.x/tutorials/spine-boy-adventure.html | 2 +- assets/js/1854.3c77b3d0.js | 1 + assets/js/1854.5b8fe8dd.js | 1 - assets/js/5b9bb158.74f54150.js | 1 - assets/js/5b9bb158.d3ce2bda.js | 1 + assets/js/90d8859c.32d16deb.js | 1 - assets/js/90d8859c.c2949d44.js | 1 + assets/js/f81c1134.1bc34334.js | 1 - assets/js/f81c1134.8cd2f20a.js | 1 + .../js/{runtime~main.1fb4bd8f.js => runtime~main.728870e7.js} | 2 +- blog.html | 4 ++-- blog/archive.html | 2 +- blog/assetpack-1.0.0.html | 2 +- blog/atom.xml | 2 +- blog/authors.html | 2 +- blog/better-docs-v8.html | 2 +- blog/create-cli.html | 4 ++-- blog/particlecontainer-v8.html | 2 +- blog/pixi-js-hearts-spine.html | 2 +- blog/pixi-universe.html | 2 +- blog/pixi-v8-beta.html | 2 +- blog/pixi-v8-launches.html | 2 +- blog/rss.xml | 2 +- blog/tags.html | 2 +- blog/tags/animation.html | 2 +- blog/tags/asset-management.html | 2 +- blog/tags/asset-pack.html | 2 +- blog/tags/cli.html | 4 ++-- blog/tags/games.html | 2 +- blog/tags/improvements.html | 4 ++-- blog/tags/optimisation.html | 2 +- blog/tags/optimization.html | 2 +- blog/tags/particle-container.html | 2 +- blog/tags/performance.html | 2 +- blog/tags/pixi-js-universe.html | 2 +- blog/tags/pixi-js.html | 4 ++-- blog/tags/qo-l.html | 4 ++-- blog/tags/spine.html | 2 +- blog/tags/templates.html | 4 ++-- blog/tags/updates.html | 4 ++-- blog/tags/web-gl.html | 2 +- blog/tags/web-gpu.html | 2 +- blog/tags/web.html | 2 +- index.html | 2 +- search-index-8.x-examples.json | 2 +- search-index-8.x-guides.json | 2 +- search-index-8.x-tutorials.json | 2 +- search-index-blog.json | 2 +- search-index.json | 2 +- search.html | 2 +- team.html | 2 +- versions.html | 2 +- 257 files changed, 261 insertions(+), 261 deletions(-) create mode 100644 assets/js/1854.3c77b3d0.js delete mode 100644 assets/js/1854.5b8fe8dd.js delete mode 100644 assets/js/5b9bb158.74f54150.js create mode 100644 assets/js/5b9bb158.d3ce2bda.js delete mode 100644 assets/js/90d8859c.32d16deb.js create mode 100644 assets/js/90d8859c.c2949d44.js delete mode 100644 assets/js/f81c1134.1bc34334.js create mode 100644 assets/js/f81c1134.8cd2f20a.js rename assets/js/{runtime~main.1fb4bd8f.js => runtime~main.728870e7.js} (97%) diff --git a/404.html b/404.html index 5cb748e97..c93326498 100644 --- a/404.html +++ b/404.html @@ -1 +1 @@ -PixiJS
Skip to main content
\ No newline at end of file +PixiJS
Skip to main content
\ No newline at end of file diff --git a/7.x/branding.html b/7.x/branding.html index d37ea5584..58304a835 100644 --- a/7.x/branding.html +++ b/7.x/branding.html @@ -1,4 +1,4 @@ -Branding | PixiJS
Skip to main content
Version: v7.x

Branding

+Branding | PixiJS
Version: v7.x

Branding

Below are links to assorted PixiJS branding assets usable for including on your site, game, or app. All assets here are free-to-use. If you have any questions or requests, please file an issue.

This is the banner that is displayed at the top of our README.

diff --git a/7.x/examples.html b/7.x/examples.html index de7eca563..e0b3c0b29 100644 --- a/7.x/examples.html +++ b/7.x/examples.html @@ -1,4 +1,4 @@ -Examples | PixiJS
Version: v7.x

Examples

+Examples | PixiJS
Version: v7.x

Examples

Welcome to the PixiJS Examples page! Here you can find a variety of demos and code snippets to help you get started with PixiJS.

Check out some of our featured examples below:

    diff --git a/7.x/examples/advanced/collision-detection.html b/7.x/examples/advanced/collision-detection.html index 9f03f0170..4d30fdea5 100644 --- a/7.x/examples/advanced/collision-detection.html +++ b/7.x/examples/advanced/collision-detection.html @@ -1 +1 @@ -Collision Detection | PixiJS \ No newline at end of file +Collision Detection | PixiJS \ No newline at end of file diff --git a/7.x/examples/advanced/mouse-trail.html b/7.x/examples/advanced/mouse-trail.html index 2e7df1d4b..7648fc8a9 100644 --- a/7.x/examples/advanced/mouse-trail.html +++ b/7.x/examples/advanced/mouse-trail.html @@ -1 +1 @@ -Mouse Trail | PixiJS \ No newline at end of file +Mouse Trail | PixiJS \ No newline at end of file diff --git a/7.x/examples/advanced/scratch-card.html b/7.x/examples/advanced/scratch-card.html index 356333d99..303dad145 100644 --- a/7.x/examples/advanced/scratch-card.html +++ b/7.x/examples/advanced/scratch-card.html @@ -1 +1 @@ -Scratch Card | PixiJS \ No newline at end of file +Scratch Card | PixiJS \ No newline at end of file diff --git a/7.x/examples/advanced/screen-shot.html b/7.x/examples/advanced/screen-shot.html index c36d230a7..24a9ff1eb 100644 --- a/7.x/examples/advanced/screen-shot.html +++ b/7.x/examples/advanced/screen-shot.html @@ -1 +1 @@ -Screen Shot | PixiJS \ No newline at end of file +Screen Shot | PixiJS \ No newline at end of file diff --git a/7.x/examples/advanced/slots.html b/7.x/examples/advanced/slots.html index 09d55fc20..d5d151889 100644 --- a/7.x/examples/advanced/slots.html +++ b/7.x/examples/advanced/slots.html @@ -1 +1 @@ -Slots | PixiJS \ No newline at end of file +Slots | PixiJS \ No newline at end of file diff --git a/7.x/examples/advanced/spinners.html b/7.x/examples/advanced/spinners.html index 85f8376e1..e2877011a 100644 --- a/7.x/examples/advanced/spinners.html +++ b/7.x/examples/advanced/spinners.html @@ -1 +1 @@ -Spinners | PixiJS \ No newline at end of file +Spinners | PixiJS \ No newline at end of file diff --git a/7.x/examples/advanced/star-warp.html b/7.x/examples/advanced/star-warp.html index 3632e8ad0..cbd5b943b 100644 --- a/7.x/examples/advanced/star-warp.html +++ b/7.x/examples/advanced/star-warp.html @@ -1 +1 @@ -Star Warp | PixiJS \ No newline at end of file +Star Warp | PixiJS \ No newline at end of file diff --git a/7.x/examples/assets/async.html b/7.x/examples/assets/async.html index 1766cf320..2afe99101 100644 --- a/7.x/examples/assets/async.html +++ b/7.x/examples/assets/async.html @@ -1 +1 @@ -Async | PixiJS \ No newline at end of file +Async | PixiJS \ No newline at end of file diff --git a/7.x/examples/assets/background.html b/7.x/examples/assets/background.html index cee5b954e..4d78aff2c 100644 --- a/7.x/examples/assets/background.html +++ b/7.x/examples/assets/background.html @@ -1 +1 @@ -Background | PixiJS \ No newline at end of file +Background | PixiJS \ No newline at end of file diff --git a/7.x/examples/assets/bundle.html b/7.x/examples/assets/bundle.html index 1c350a153..6ed72c83f 100644 --- a/7.x/examples/assets/bundle.html +++ b/7.x/examples/assets/bundle.html @@ -1 +1 @@ -Bundle | PixiJS \ No newline at end of file +Bundle | PixiJS \ No newline at end of file diff --git a/7.x/examples/assets/multiple.html b/7.x/examples/assets/multiple.html index af0bbd35d..24745b11c 100644 --- a/7.x/examples/assets/multiple.html +++ b/7.x/examples/assets/multiple.html @@ -1 +1 @@ -Multiple | PixiJS \ No newline at end of file +Multiple | PixiJS \ No newline at end of file diff --git a/7.x/examples/assets/promise.html b/7.x/examples/assets/promise.html index ee504c63f..68e15ad41 100644 --- a/7.x/examples/assets/promise.html +++ b/7.x/examples/assets/promise.html @@ -1 +1 @@ -Promise | PixiJS \ No newline at end of file +Promise | PixiJS \ No newline at end of file diff --git a/7.x/examples/basic/blend-modes.html b/7.x/examples/basic/blend-modes.html index b00161a24..9579596c4 100644 --- a/7.x/examples/basic/blend-modes.html +++ b/7.x/examples/basic/blend-modes.html @@ -1 +1 @@ -Blend Modes | PixiJS \ No newline at end of file +Blend Modes | PixiJS \ No newline at end of file diff --git a/7.x/examples/basic/cache-as-bitmap.html b/7.x/examples/basic/cache-as-bitmap.html index 92c653b9e..43c7215f6 100644 --- a/7.x/examples/basic/cache-as-bitmap.html +++ b/7.x/examples/basic/cache-as-bitmap.html @@ -1 +1 @@ -Cache As Bitmap | PixiJS \ No newline at end of file +Cache As Bitmap | PixiJS \ No newline at end of file diff --git a/7.x/examples/basic/container.html b/7.x/examples/basic/container.html index 200ec90dc..e70e37592 100644 --- a/7.x/examples/basic/container.html +++ b/7.x/examples/basic/container.html @@ -1 +1 @@ -Container | PixiJS \ No newline at end of file +Container | PixiJS \ No newline at end of file diff --git a/7.x/examples/basic/particle-container.html b/7.x/examples/basic/particle-container.html index 3da8d5e8b..f46bb6576 100644 --- a/7.x/examples/basic/particle-container.html +++ b/7.x/examples/basic/particle-container.html @@ -1 +1 @@ -Particle Container | PixiJS \ No newline at end of file +Particle Container | PixiJS \ No newline at end of file diff --git a/7.x/examples/basic/simple-plane.html b/7.x/examples/basic/simple-plane.html index ace58b2e9..2981c1353 100644 --- a/7.x/examples/basic/simple-plane.html +++ b/7.x/examples/basic/simple-plane.html @@ -1 +1 @@ -Simple Plane | PixiJS \ No newline at end of file +Simple Plane | PixiJS \ No newline at end of file diff --git a/7.x/examples/basic/tinting.html b/7.x/examples/basic/tinting.html index 0421c44ff..5553dd2e2 100644 --- a/7.x/examples/basic/tinting.html +++ b/7.x/examples/basic/tinting.html @@ -1 +1 @@ -Tinting | PixiJS \ No newline at end of file +Tinting | PixiJS \ No newline at end of file diff --git a/7.x/examples/basic/transparent-background.html b/7.x/examples/basic/transparent-background.html index d21567b37..f1fda013f 100644 --- a/7.x/examples/basic/transparent-background.html +++ b/7.x/examples/basic/transparent-background.html @@ -1 +1 @@ -Transparent Background | PixiJS \ No newline at end of file +Transparent Background | PixiJS \ No newline at end of file diff --git a/7.x/examples/events/click.html b/7.x/examples/events/click.html index 8d4e1ee19..d244a0021 100644 --- a/7.x/examples/events/click.html +++ b/7.x/examples/events/click.html @@ -1 +1 @@ -Click | PixiJS \ No newline at end of file +Click | PixiJS \ No newline at end of file diff --git a/7.x/examples/events/custom-hitarea.html b/7.x/examples/events/custom-hitarea.html index 1cc33beaf..568050333 100644 --- a/7.x/examples/events/custom-hitarea.html +++ b/7.x/examples/events/custom-hitarea.html @@ -1 +1 @@ -Custom Hitarea | PixiJS \ No newline at end of file +Custom Hitarea | PixiJS \ No newline at end of file diff --git a/7.x/examples/events/custom-mouse-icon.html b/7.x/examples/events/custom-mouse-icon.html index 56d7ff4cb..fbeeabd6e 100644 --- a/7.x/examples/events/custom-mouse-icon.html +++ b/7.x/examples/events/custom-mouse-icon.html @@ -1 +1 @@ -Custom Mouse Icon | PixiJS \ No newline at end of file +Custom Mouse Icon | PixiJS \ No newline at end of file diff --git a/7.x/examples/events/dragging.html b/7.x/examples/events/dragging.html index 9bfb52a35..69168d913 100644 --- a/7.x/examples/events/dragging.html +++ b/7.x/examples/events/dragging.html @@ -1 +1 @@ -Dragging | PixiJS \ No newline at end of file +Dragging | PixiJS \ No newline at end of file diff --git a/7.x/examples/events/interactivity.html b/7.x/examples/events/interactivity.html index e15ac5eec..37d2839c5 100644 --- a/7.x/examples/events/interactivity.html +++ b/7.x/examples/events/interactivity.html @@ -1 +1 @@ -Interactivity | PixiJS \ No newline at end of file +Interactivity | PixiJS \ No newline at end of file diff --git a/7.x/examples/events/logger.html b/7.x/examples/events/logger.html index 1ace7673f..9a36fb4a9 100644 --- a/7.x/examples/events/logger.html +++ b/7.x/examples/events/logger.html @@ -1 +1 @@ -Logger | PixiJS \ No newline at end of file +Logger | PixiJS \ No newline at end of file diff --git a/7.x/examples/events/nested-boundary-with-projection.html b/7.x/examples/events/nested-boundary-with-projection.html index 5a8fe0a07..2bb37bdf6 100644 --- a/7.x/examples/events/nested-boundary-with-projection.html +++ b/7.x/examples/events/nested-boundary-with-projection.html @@ -1 +1 @@ -Nested Boundary With Projection | PixiJS \ No newline at end of file +Nested Boundary With Projection | PixiJS \ No newline at end of file diff --git a/7.x/examples/events/pointer-tracker.html b/7.x/examples/events/pointer-tracker.html index acf5ea203..cea72223e 100644 --- a/7.x/examples/events/pointer-tracker.html +++ b/7.x/examples/events/pointer-tracker.html @@ -1 +1 @@ -Pointer Tracker | PixiJS \ No newline at end of file +Pointer Tracker | PixiJS \ No newline at end of file diff --git a/7.x/examples/events/slider.html b/7.x/examples/events/slider.html index 772585ed7..67151bd24 100644 --- a/7.x/examples/events/slider.html +++ b/7.x/examples/events/slider.html @@ -1 +1 @@ -Slider | PixiJS \ No newline at end of file +Slider | PixiJS \ No newline at end of file diff --git a/7.x/examples/filters-advanced/custom.html b/7.x/examples/filters-advanced/custom.html index f8586f28e..597af39fc 100644 --- a/7.x/examples/filters-advanced/custom.html +++ b/7.x/examples/filters-advanced/custom.html @@ -1 +1 @@ -Custom | PixiJS \ No newline at end of file +Custom | PixiJS \ No newline at end of file diff --git a/7.x/examples/filters-advanced/mouse-blending.html b/7.x/examples/filters-advanced/mouse-blending.html index b7a0097f2..49d5e40b0 100644 --- a/7.x/examples/filters-advanced/mouse-blending.html +++ b/7.x/examples/filters-advanced/mouse-blending.html @@ -1 +1 @@ -Mouse Blending | PixiJS \ No newline at end of file +Mouse Blending | PixiJS \ No newline at end of file diff --git a/7.x/examples/filters-advanced/shader-toy-filter-render-texture.html b/7.x/examples/filters-advanced/shader-toy-filter-render-texture.html index e95053b05..1c154a617 100644 --- a/7.x/examples/filters-advanced/shader-toy-filter-render-texture.html +++ b/7.x/examples/filters-advanced/shader-toy-filter-render-texture.html @@ -1 +1 @@ -Shader Toy Filter Render Texture | PixiJS \ No newline at end of file +Shader Toy Filter Render Texture | PixiJS \ No newline at end of file diff --git a/7.x/examples/filters-basic/blur.html b/7.x/examples/filters-basic/blur.html index 0e872f360..739201b9e 100644 --- a/7.x/examples/filters-basic/blur.html +++ b/7.x/examples/filters-basic/blur.html @@ -1 +1 @@ -Blur | PixiJS \ No newline at end of file +Blur | PixiJS \ No newline at end of file diff --git a/7.x/examples/filters-basic/color-matrix.html b/7.x/examples/filters-basic/color-matrix.html index 5b4b4dc10..2d20fed74 100644 --- a/7.x/examples/filters-basic/color-matrix.html +++ b/7.x/examples/filters-basic/color-matrix.html @@ -1 +1 @@ -Color Matrix | PixiJS \ No newline at end of file +Color Matrix | PixiJS \ No newline at end of file diff --git a/7.x/examples/filters-basic/displacement-map-crawlies.html b/7.x/examples/filters-basic/displacement-map-crawlies.html index fa50fde22..7439ea900 100644 --- a/7.x/examples/filters-basic/displacement-map-crawlies.html +++ b/7.x/examples/filters-basic/displacement-map-crawlies.html @@ -1 +1 @@ -Displacement Map Crawlies | PixiJS \ No newline at end of file +Displacement Map Crawlies | PixiJS \ No newline at end of file diff --git a/7.x/examples/filters-basic/displacement-map-flag.html b/7.x/examples/filters-basic/displacement-map-flag.html index a2cd65cc1..54c08e824 100644 --- a/7.x/examples/filters-basic/displacement-map-flag.html +++ b/7.x/examples/filters-basic/displacement-map-flag.html @@ -1 +1 @@ -Displacement Map Flag | PixiJS \ No newline at end of file +Displacement Map Flag | PixiJS \ No newline at end of file diff --git a/7.x/examples/graphics/advanced.html b/7.x/examples/graphics/advanced.html index ab5b53aa0..3e4cfc9ca 100644 --- a/7.x/examples/graphics/advanced.html +++ b/7.x/examples/graphics/advanced.html @@ -1 +1 @@ -Advanced | PixiJS \ No newline at end of file +Advanced | PixiJS \ No newline at end of file diff --git a/7.x/examples/graphics/dynamic.html b/7.x/examples/graphics/dynamic.html index 5e87e8c92..3afc54e97 100644 --- a/7.x/examples/graphics/dynamic.html +++ b/7.x/examples/graphics/dynamic.html @@ -1 +1 @@ -Dynamic | PixiJS \ No newline at end of file +Dynamic | PixiJS \ No newline at end of file diff --git a/7.x/examples/graphics/simple.html b/7.x/examples/graphics/simple.html index 6690cbfb0..781f2ddbe 100644 --- a/7.x/examples/graphics/simple.html +++ b/7.x/examples/graphics/simple.html @@ -1 +1 @@ -Simple | PixiJS \ No newline at end of file +Simple | PixiJS \ No newline at end of file diff --git a/7.x/examples/masks/filter.html b/7.x/examples/masks/filter.html index bd67046c5..1f565fac6 100644 --- a/7.x/examples/masks/filter.html +++ b/7.x/examples/masks/filter.html @@ -1 +1 @@ -Filter | PixiJS \ No newline at end of file +Filter | PixiJS \ No newline at end of file diff --git a/7.x/examples/masks/graphics.html b/7.x/examples/masks/graphics.html index 919656286..a24b1af9c 100644 --- a/7.x/examples/masks/graphics.html +++ b/7.x/examples/masks/graphics.html @@ -1 +1 @@ -Graphics | PixiJS \ No newline at end of file +Graphics | PixiJS \ No newline at end of file diff --git a/7.x/examples/masks/sprite.html b/7.x/examples/masks/sprite.html index 306bc7d2d..7526da608 100644 --- a/7.x/examples/masks/sprite.html +++ b/7.x/examples/masks/sprite.html @@ -1 +1 @@ -Sprite | PixiJS \ No newline at end of file +Sprite | PixiJS \ No newline at end of file diff --git a/7.x/examples/mesh-and-shaders/instanced-geometry.html b/7.x/examples/mesh-and-shaders/instanced-geometry.html index 8359a69f9..d1529f3e6 100644 --- a/7.x/examples/mesh-and-shaders/instanced-geometry.html +++ b/7.x/examples/mesh-and-shaders/instanced-geometry.html @@ -1 +1 @@ -Instanced Geometry | PixiJS \ No newline at end of file +Instanced Geometry | PixiJS \ No newline at end of file diff --git a/7.x/examples/mesh-and-shaders/interleaving-geometry.html b/7.x/examples/mesh-and-shaders/interleaving-geometry.html index f1a8490ac..58c9a1ed9 100644 --- a/7.x/examples/mesh-and-shaders/interleaving-geometry.html +++ b/7.x/examples/mesh-and-shaders/interleaving-geometry.html @@ -1 +1 @@ -Interleaving Geometry | PixiJS \ No newline at end of file +Interleaving Geometry | PixiJS \ No newline at end of file diff --git a/7.x/examples/mesh-and-shaders/merging-geometry.html b/7.x/examples/mesh-and-shaders/merging-geometry.html index 24109f81e..5f6b5f08d 100644 --- a/7.x/examples/mesh-and-shaders/merging-geometry.html +++ b/7.x/examples/mesh-and-shaders/merging-geometry.html @@ -1 +1 @@ -Merging Geometry | PixiJS \ No newline at end of file +Merging Geometry | PixiJS \ No newline at end of file diff --git a/7.x/examples/mesh-and-shaders/multi-pass-shader-generated-mesh.html b/7.x/examples/mesh-and-shaders/multi-pass-shader-generated-mesh.html index 88d62b73c..3011c2bd6 100644 --- a/7.x/examples/mesh-and-shaders/multi-pass-shader-generated-mesh.html +++ b/7.x/examples/mesh-and-shaders/multi-pass-shader-generated-mesh.html @@ -1 +1 @@ -Multi Pass Shader Generated Mesh | PixiJS \ No newline at end of file +Multi Pass Shader Generated Mesh | PixiJS \ No newline at end of file diff --git a/7.x/examples/mesh-and-shaders/shader-toy-mesh.html b/7.x/examples/mesh-and-shaders/shader-toy-mesh.html index 69747c389..003e2447e 100644 --- a/7.x/examples/mesh-and-shaders/shader-toy-mesh.html +++ b/7.x/examples/mesh-and-shaders/shader-toy-mesh.html @@ -1 +1 @@ -Shader Toy Mesh | PixiJS \ No newline at end of file +Shader Toy Mesh | PixiJS \ No newline at end of file diff --git a/7.x/examples/mesh-and-shaders/shared-shader.html b/7.x/examples/mesh-and-shaders/shared-shader.html index e8d2bd8c2..5c70d33de 100644 --- a/7.x/examples/mesh-and-shaders/shared-shader.html +++ b/7.x/examples/mesh-and-shaders/shared-shader.html @@ -1 +1 @@ -Shared Shader | PixiJS \ No newline at end of file +Shared Shader | PixiJS \ No newline at end of file diff --git a/7.x/examples/mesh-and-shaders/sharing-geometry.html b/7.x/examples/mesh-and-shaders/sharing-geometry.html index 2fbb8b1fc..680851ab7 100644 --- a/7.x/examples/mesh-and-shaders/sharing-geometry.html +++ b/7.x/examples/mesh-and-shaders/sharing-geometry.html @@ -1 +1 @@ -Sharing Geometry | PixiJS \ No newline at end of file +Sharing Geometry | PixiJS \ No newline at end of file diff --git a/7.x/examples/mesh-and-shaders/textured-mesh-advanced.html b/7.x/examples/mesh-and-shaders/textured-mesh-advanced.html index f056d316d..37c0e3952 100644 --- a/7.x/examples/mesh-and-shaders/textured-mesh-advanced.html +++ b/7.x/examples/mesh-and-shaders/textured-mesh-advanced.html @@ -1 +1 @@ -Textured Mesh Advanced | PixiJS \ No newline at end of file +Textured Mesh Advanced | PixiJS \ No newline at end of file diff --git a/7.x/examples/mesh-and-shaders/textured-mesh-basic.html b/7.x/examples/mesh-and-shaders/textured-mesh-basic.html index 7f68c5536..e3633c3db 100644 --- a/7.x/examples/mesh-and-shaders/textured-mesh-basic.html +++ b/7.x/examples/mesh-and-shaders/textured-mesh-basic.html @@ -1 +1 @@ -Textured Mesh Basic | PixiJS \ No newline at end of file +Textured Mesh Basic | PixiJS \ No newline at end of file diff --git a/7.x/examples/mesh-and-shaders/triangle-color.html b/7.x/examples/mesh-and-shaders/triangle-color.html index b515aa2fa..20362fc21 100644 --- a/7.x/examples/mesh-and-shaders/triangle-color.html +++ b/7.x/examples/mesh-and-shaders/triangle-color.html @@ -1 +1 @@ -Triangle Color | PixiJS \ No newline at end of file +Triangle Color | PixiJS \ No newline at end of file diff --git a/7.x/examples/mesh-and-shaders/triangle-textured.html b/7.x/examples/mesh-and-shaders/triangle-textured.html index 45fcd1237..034cf7a28 100644 --- a/7.x/examples/mesh-and-shaders/triangle-textured.html +++ b/7.x/examples/mesh-and-shaders/triangle-textured.html @@ -1 +1 @@ -Triangle Textured | PixiJS \ No newline at end of file +Triangle Textured | PixiJS \ No newline at end of file diff --git a/7.x/examples/mesh-and-shaders/triangle.html b/7.x/examples/mesh-and-shaders/triangle.html index a0fb2068f..7ba4f1df5 100644 --- a/7.x/examples/mesh-and-shaders/triangle.html +++ b/7.x/examples/mesh-and-shaders/triangle.html @@ -1 +1 @@ -Triangle | PixiJS \ No newline at end of file +Triangle | PixiJS \ No newline at end of file diff --git a/7.x/examples/mesh-and-shaders/uniforms.html b/7.x/examples/mesh-and-shaders/uniforms.html index dbf008ff1..2e0696ef6 100644 --- a/7.x/examples/mesh-and-shaders/uniforms.html +++ b/7.x/examples/mesh-and-shaders/uniforms.html @@ -1 +1 @@ -Uniforms | PixiJS \ No newline at end of file +Uniforms | PixiJS \ No newline at end of file diff --git a/7.x/examples/offscreen-canvas/basic.html b/7.x/examples/offscreen-canvas/basic.html index af14133b0..04a107b6a 100644 --- a/7.x/examples/offscreen-canvas/basic.html +++ b/7.x/examples/offscreen-canvas/basic.html @@ -1 +1 @@ -Basic | PixiJS \ No newline at end of file +Basic | PixiJS \ No newline at end of file diff --git a/7.x/examples/sprite/animated-sprite-animation-speed.html b/7.x/examples/sprite/animated-sprite-animation-speed.html index 20a053f47..8d36149f5 100644 --- a/7.x/examples/sprite/animated-sprite-animation-speed.html +++ b/7.x/examples/sprite/animated-sprite-animation-speed.html @@ -1 +1 @@ -Animated Sprite Animation Speed | PixiJS \ No newline at end of file +Animated Sprite Animation Speed | PixiJS \ No newline at end of file diff --git a/7.x/examples/sprite/animated-sprite-explosion.html b/7.x/examples/sprite/animated-sprite-explosion.html index 23ff27b2e..aa8a9b48c 100644 --- a/7.x/examples/sprite/animated-sprite-explosion.html +++ b/7.x/examples/sprite/animated-sprite-explosion.html @@ -1 +1 @@ -Animated Sprite Explosion | PixiJS \ No newline at end of file +Animated Sprite Explosion | PixiJS \ No newline at end of file diff --git a/7.x/examples/sprite/animated-sprite-jet.html b/7.x/examples/sprite/animated-sprite-jet.html index c8499927a..fed66818d 100644 --- a/7.x/examples/sprite/animated-sprite-jet.html +++ b/7.x/examples/sprite/animated-sprite-jet.html @@ -1 +1 @@ -Animated Sprite Jet | PixiJS \ No newline at end of file +Animated Sprite Jet | PixiJS \ No newline at end of file diff --git a/7.x/examples/sprite/basic.html b/7.x/examples/sprite/basic.html index 81e09fd91..10b3d4e7d 100644 --- a/7.x/examples/sprite/basic.html +++ b/7.x/examples/sprite/basic.html @@ -1 +1 @@ -Basic | PixiJS \ No newline at end of file +Basic | PixiJS \ No newline at end of file diff --git a/7.x/examples/sprite/texture-swap.html b/7.x/examples/sprite/texture-swap.html index b1cf5c962..51b8fea4e 100644 --- a/7.x/examples/sprite/texture-swap.html +++ b/7.x/examples/sprite/texture-swap.html @@ -1 +1 @@ -Texture Swap | PixiJS \ No newline at end of file +Texture Swap | PixiJS \ No newline at end of file diff --git a/7.x/examples/sprite/tiling-sprite.html b/7.x/examples/sprite/tiling-sprite.html index 71c49753c..9d0123bc8 100644 --- a/7.x/examples/sprite/tiling-sprite.html +++ b/7.x/examples/sprite/tiling-sprite.html @@ -1 +1 @@ -Tiling Sprite | PixiJS \ No newline at end of file +Tiling Sprite | PixiJS \ No newline at end of file diff --git a/7.x/examples/sprite/video.html b/7.x/examples/sprite/video.html index e17448bf7..864139d61 100644 --- a/7.x/examples/sprite/video.html +++ b/7.x/examples/sprite/video.html @@ -1 +1 @@ -Video | PixiJS \ No newline at end of file +Video | PixiJS \ No newline at end of file diff --git a/7.x/examples/text/bitmap-text.html b/7.x/examples/text/bitmap-text.html index 11e1a43c3..b479b5fbb 100644 --- a/7.x/examples/text/bitmap-text.html +++ b/7.x/examples/text/bitmap-text.html @@ -1 +1 @@ -Bitmap Text | PixiJS \ No newline at end of file +Bitmap Text | PixiJS \ No newline at end of file diff --git a/7.x/examples/text/from-font.html b/7.x/examples/text/from-font.html index a5e66287d..8dff6f36d 100644 --- a/7.x/examples/text/from-font.html +++ b/7.x/examples/text/from-font.html @@ -1 +1 @@ -From Font | PixiJS \ No newline at end of file +From Font | PixiJS \ No newline at end of file diff --git a/7.x/examples/text/pixi-text.html b/7.x/examples/text/pixi-text.html index dc4884149..5317e5d28 100644 --- a/7.x/examples/text/pixi-text.html +++ b/7.x/examples/text/pixi-text.html @@ -1 +1 @@ -Pixi Text | PixiJS \ No newline at end of file +Pixi Text | PixiJS \ No newline at end of file diff --git a/7.x/examples/text/web-font.html b/7.x/examples/text/web-font.html index 6435231c5..7d812c5db 100644 --- a/7.x/examples/text/web-font.html +++ b/7.x/examples/text/web-font.html @@ -1 +1 @@ -Web Font | PixiJS \ No newline at end of file +Web Font | PixiJS \ No newline at end of file diff --git a/7.x/examples/textures/gradient-basic.html b/7.x/examples/textures/gradient-basic.html index 14454bea1..d0e4bb509 100644 --- a/7.x/examples/textures/gradient-basic.html +++ b/7.x/examples/textures/gradient-basic.html @@ -1 +1 @@ -Gradient Basic | PixiJS \ No newline at end of file +Gradient Basic | PixiJS \ No newline at end of file diff --git a/7.x/examples/textures/gradient-resource.html b/7.x/examples/textures/gradient-resource.html index f257f756f..3169f40f3 100644 --- a/7.x/examples/textures/gradient-resource.html +++ b/7.x/examples/textures/gradient-resource.html @@ -1 +1 @@ -Gradient Resource | PixiJS \ No newline at end of file +Gradient Resource | PixiJS \ No newline at end of file diff --git a/7.x/examples/textures/render-texture-advanced.html b/7.x/examples/textures/render-texture-advanced.html index 8e00628fe..6b543234f 100644 --- a/7.x/examples/textures/render-texture-advanced.html +++ b/7.x/examples/textures/render-texture-advanced.html @@ -1 +1 @@ -Render Texture Advanced | PixiJS \ No newline at end of file +Render Texture Advanced | PixiJS \ No newline at end of file diff --git a/7.x/examples/textures/render-texture-basic.html b/7.x/examples/textures/render-texture-basic.html index 4832c60f6..1761f59ff 100644 --- a/7.x/examples/textures/render-texture-basic.html +++ b/7.x/examples/textures/render-texture-basic.html @@ -1 +1 @@ -Render Texture Basic | PixiJS \ No newline at end of file +Render Texture Basic | PixiJS \ No newline at end of file diff --git a/7.x/examples/textures/texture-rotate.html b/7.x/examples/textures/texture-rotate.html index 7ed350caa..22f0fcc9a 100644 --- a/7.x/examples/textures/texture-rotate.html +++ b/7.x/examples/textures/texture-rotate.html @@ -1 +1 @@ -Texture Rotate | PixiJS \ No newline at end of file +Texture Rotate | PixiJS \ No newline at end of file diff --git a/7.x/faq.html b/7.x/faq.html index 78db0df24..2434b71d9 100644 --- a/7.x/faq.html +++ b/7.x/faq.html @@ -1,4 +1,4 @@ -FAQ | PixiJS
    Version: v7.x

    FAQ

    +FAQ | PixiJS
    Version: v7.x

    FAQ

    What is PixiJS for?​

    Everything! Pixi.js is a rendering library that will allow you to create rich, interactive graphic experiences, cross-platform applications, and games without diff --git a/7.x/guides.html b/7.x/guides.html index cea34e418..dabd455aa 100644 --- a/7.x/guides.html +++ b/7.x/guides.html @@ -1,4 +1,4 @@ -Welcome | PixiJS

    Version: v7.x

    Welcome

    +Welcome | PixiJS
    Version: v7.x

    Welcome

    PixiJS is an open source, web-based rendering system that provides blazing fast performance for games, data visualization, and other graphics intensive projects. These guides are designed to be a companion to the API documentation, providing a structured introduction to using the API to solve problems and build projects.

    About The Guides​

    If you're new to PixiJS, we suggest you start with the Basics and read through them in order (a good place to start is Getting Started). While PixiJS has a mature API and solid documentation, the guides go over many common issues and questions that developers new to the system encounter.

    diff --git a/7.x/guides/basics/architecture-overview.html b/7.x/guides/basics/architecture-overview.html index 2fa272000..1cbd688ef 100644 --- a/7.x/guides/basics/architecture-overview.html +++ b/7.x/guides/basics/architecture-overview.html @@ -1,4 +1,4 @@ -Architecture Overview | PixiJS
    Version: v7.x

    Architecture Overview

    +Architecture Overview | PixiJS
    Version: v7.x

    Architecture Overview

    OK, now that you've gotten a feel for how easy it is to build a PixiJS application, let's get into the specifics. For the rest of the Basics section, we're going to work from the high level down to the details. We'll start with an overview of how PixiJS is put together.

    The Code​

    Before we get into how the code is layed out, let's talk about where it lives. PixiJS is an open source product hosted on GitHub. Like any GitHub repo, you can browse and download the raw source files for each PixiJS class, as well as search existing issues & bugs, and even submit your own. PixiJS is written in a JavaScript variant called TypeScript, which enables type-checking in JavaScript via a pre-compile step.

    diff --git a/7.x/guides/basics/getting-started.html b/7.x/guides/basics/getting-started.html index 8072fec8f..c933b12e0 100644 --- a/7.x/guides/basics/getting-started.html +++ b/7.x/guides/basics/getting-started.html @@ -1,4 +1,4 @@ -Getting Started | PixiJS
    Version: v7.x

    Getting Started

    +Getting Started | PixiJS
    Version: v7.x

    Getting Started

    In this section we're going to build the simplest possible PixiJS application. In doing so, we'll walk through the basics of how to build and serve the code.

    Advanced Users​

    A quick note before we start: this guide is aimed at beginning PixiJS developers who have minimal diff --git a/7.x/guides/basics/render-loop.html b/7.x/guides/basics/render-loop.html index 65f8b68ea..3d12de3d7 100644 --- a/7.x/guides/basics/render-loop.html +++ b/7.x/guides/basics/render-loop.html @@ -1,4 +1,4 @@ -Render Loop | PixiJS

    Version: v7.x

    Render Loop

    +Render Loop | PixiJS
    Version: v7.x

    Render Loop

    Now that you understand the major parts of the system, let's look at how these parts work together to get your project onto the screen. Unlike a web page, PixiJS is constantly updating and re-drawing itself, over and over. You update your objects, then PixiJS renders them to the screen, then the process repeats. We call this cycle the render loop.

    The majority of any PixiJS project is contained in this update + render cycle. You code the updates, PixiJS handles the rendering.

    Let's walk through what happens each frame of the render loop. There are three main steps.

    diff --git a/7.x/guides/basics/scene-graph.html b/7.x/guides/basics/scene-graph.html index ffd4f1486..1ddd41508 100644 --- a/7.x/guides/basics/scene-graph.html +++ b/7.x/guides/basics/scene-graph.html @@ -1,4 +1,4 @@ -Scene Graph | PixiJS
    Version: v7.x

    Scene Graph

    +Scene Graph | PixiJS
    Version: v7.x

    Scene Graph

    Every frame, PixiJS is updating and then rendering the scene graph. Let's talk about what's in the scene graph, and how it impacts how you develop your project. If you've built games before, this should all sound very familiar, but if you're coming from HTML and the DOM, it's worth understanding before we get into specific types of objects you can render.

    The Scene Graph Is a Tree​

    The scene graph's root node is a container maintained by the application, and referenced with app.stage. When you add a sprite or other renderable object as a child to the stage, it's added to the scene graph and will be rendered and interactable. Most PixiJS objects can also have children, and so as you build more complex scenes, you will end up with a tree of parent-child relationships, rooted at the app's stage.

    diff --git a/7.x/guides/basics/what-pixijs-is-not.html b/7.x/guides/basics/what-pixijs-is-not.html index ef95fd5c5..53e34e717 100644 --- a/7.x/guides/basics/what-pixijs-is-not.html +++ b/7.x/guides/basics/what-pixijs-is-not.html @@ -1,4 +1,4 @@ -What PixiJS Is Not | PixiJS
    Version: v7.x

    What PixiJS Is Not

    +What PixiJS Is Not | PixiJS
    Version: v7.x

    What PixiJS Is Not

    While PixiJS can do many things, there are things it can't do, or that require additional tools to accomplish. Newcomers to PixiJS often struggle to identify which tasks PixiJS can solve, and which require outside solutions. If you're about to start a project, it can be helpful to know if PixiJS is a good fit for your needs. The following list is obviously incomplete - PixiJS is also not, for example, a duck - but it includes many common tasks or features that you might expect us to support.

    PixiJS Is Not ... A Framework​

    PixiJS is a rendering engine, and it supports additional features such as interaction management that are commonly needed when using a render engine. But it is not a framework like Unity or Phaser. Frameworks are designed to do all the things you'd need to do when building a game - user settings management, music playback, object scripting, art pipeline management... the list goes on. PixiJS is designed to do one thing really well - render graphical content. This lets us focus on keeping up with new technology, and makes downloading PixiJS blazingly fast.

    diff --git a/7.x/guides/basics/what-pixijs-is.html b/7.x/guides/basics/what-pixijs-is.html index 3175b79b7..2aff717ed 100644 --- a/7.x/guides/basics/what-pixijs-is.html +++ b/7.x/guides/basics/what-pixijs-is.html @@ -1,4 +1,4 @@ -What PixiJS Is | PixiJS
    Version: v7.x

    What PixiJS Is

    +What PixiJS Is | PixiJS
    Version: v7.x

    What PixiJS Is

    So what exactly is PixiJS? At its heart, PixiJS is a rendering system that uses WebGL (or optionally Canvas) to display images and other 2D visual content. It provides a full scene graph (a hierarchy of objects to render), and provides interaction support to enable handling click and touch events. It is a natural replacement for Flash in the modern HTML5 world, but provides better performance and pixel-level effects that go beyond what Flash could achieve. It is perfect for online games, educational content, interactive ads, data visualization... any web-based application where complex graphics are important. And coupled with technology such as Cordova and Electron, PixiJS apps can be distributed beyond the browser as mobile and desktop applications.

    Here's what else you get with PixiJS:

    PixiJS Is ... Fast​

    diff --git a/7.x/guides/components/assets.html b/7.x/guides/components/assets.html index e8f3acac5..fcfdf7c9a 100644 --- a/7.x/guides/components/assets.html +++ b/7.x/guides/components/assets.html @@ -1,4 +1,4 @@ -Assets | PixiJS
    Version: v7.x

    Assets

    +Assets | PixiJS
    Version: v7.x

    Assets

    The Assets package​

    The Assets package is a modern replacement for the old PIXI.Loader class. It is a promise-based resource management solution that will download, cache and parse your assets into something you can use. The downloads can be simultaneous and in the background, meaning faster startup times for your app, the cache ensures that you never download the same asset twice and the extensible parser system allows you to easily extend and customize the process to your needs.

    Getting started​

    diff --git a/7.x/guides/components/containers.html b/7.x/guides/components/containers.html index e3e7528d9..878cfb9cb 100644 --- a/7.x/guides/components/containers.html +++ b/7.x/guides/components/containers.html @@ -1,4 +1,4 @@ -Containers | PixiJS
    Version: v7.x

    Containers

    +Containers | PixiJS
    Version: v7.x

    Containers

    The Container class provides a simple display object that does what its name implies - collect a set of child objects together. But beyond grouping objects, containers have a few uses that you should be aware of.

    Containers as Groups​

    Almost every type of display object is also derived from Container - even Sprites! This means that in many cases you can create a parent-child hierarchy with the objects you want to render.

    diff --git a/7.x/guides/components/display-object.html b/7.x/guides/components/display-object.html index 1e7a95578..df64199ac 100644 --- a/7.x/guides/components/display-object.html +++ b/7.x/guides/components/display-object.html @@ -1,4 +1,4 @@ -Display Objects | PixiJS
    Version: v7.x

    Display Objects

    +Display Objects | PixiJS
    Version: v7.x

    Display Objects

    DisplayObject is the core class for anything that can be rendered by the engine. It's the base class for sprites, text, complex graphics, containers, etc., and provides much of the common functionality for those objects. As you're learning PixiJS, it's important to read through the documentation for this class to understand how to move, scale, rotate and compose the visual elements of your project.

    Be aware that you won't use DisplayObject directly - you'll use its functions and attributes in derived classes.

    Commonly Used Attributes​

    diff --git a/7.x/guides/components/graphics.html b/7.x/guides/components/graphics.html index c986ffdbd..6b2b04ace 100644 --- a/7.x/guides/components/graphics.html +++ b/7.x/guides/components/graphics.html @@ -1,4 +1,4 @@ -Graphics | PixiJS
    Version: v7.x

    Graphics

    +Graphics | PixiJS
    Version: v7.x

    Graphics

    Graphics is a complex and much misunderstood tool in the PixiJS toolbox. At first glance, it looks like a tool for drawing shapes. And it is! But it can also be used to generate masks. How does that work?

    In this guide, we're going to de-mystify the Graphics object, starting with how to think about what it does.

    Check out the graphics example code.

    diff --git a/7.x/guides/components/interaction.html b/7.x/guides/components/interaction.html index 5875b785e..87242d619 100644 --- a/7.x/guides/components/interaction.html +++ b/7.x/guides/components/interaction.html @@ -1,4 +1,4 @@ -Interaction | PixiJS
    Version: v7.x

    Interaction

    +Interaction | PixiJS
    Version: v7.x

    Interaction

    PixiJS is primarily a rendering system, but it also includes support for interactivity. Adding support for mouse and touch events to your project is simple and consistent.

    Event Modes​

    The new event-based system that replaced InteractionManager from v6 has expanded the definition of what a DisplayObject means to be interactive. With this we have introduced eventMode which allows you to control how an object responds to interaction events. This is similar to the interactive property in v6 but with more options.

    diff --git a/7.x/guides/components/sprite-sheets.html b/7.x/guides/components/sprite-sheets.html index f1fac9fb9..43df851e7 100644 --- a/7.x/guides/components/sprite-sheets.html +++ b/7.x/guides/components/sprite-sheets.html @@ -1,4 +1,4 @@ -Spritesheets | PixiJS
    Version: v7.x

    Spritesheets

    +Spritesheets | PixiJS
    Version: v7.x

    Spritesheets

    Now that you understand basic sprites, it's time to talk about a better way to create them - the Spritesheet class.

    A Spritesheet is a media format for more efficiently downloading and rendering Sprites. While somewhat more complex to create and use, they are a key tool in optimizing your project.

    Anatomy of a Spritesheet​

    diff --git a/7.x/guides/components/sprites.html b/7.x/guides/components/sprites.html index c5d6b5b4d..6cfb69e92 100644 --- a/7.x/guides/components/sprites.html +++ b/7.x/guides/components/sprites.html @@ -1,4 +1,4 @@ -Sprites | PixiJS
    Version: v7.x

    Sprites

    +Sprites | PixiJS
    Version: v7.x

    Sprites

    Sprites are the simplest and most common renderable object in PixiJS. They represent a single image to be displayed on the screen. Each Sprite contains a Texture to be drawn, along with all the transformation and display state required to function in the scene graph.

    Creating Sprites​

    To create a Sprite, all you need is a Texture (check out the Texture guide). Load a PNG's URL using the PIXI.Loader class, then call PIXI.Sprite.from(url) and you're all set. As a convenience during prototyping, you can pass a non-loaded URL to from() and PixiJS will handle it, but your sprite will "pop in" after it loads if you don't pre-load your textures.

    diff --git a/7.x/guides/components/text.html b/7.x/guides/components/text.html index cb51e039c..8f5729ae6 100644 --- a/7.x/guides/components/text.html +++ b/7.x/guides/components/text.html @@ -1,4 +1,4 @@ -Text | PixiJS
    Version: v7.x

    Text

    +Text | PixiJS
    Version: v7.x

    Text

    Whether it's a high score or a diagram label, text is often the best way to convey information in your projects. Surprisingly, drawing text to the screen with WebGL is a very complex process - there's no built in support for it at all. One of the values PixiJS provides is in hiding this complexity to allow you to draw text in diverse styles, fonts and colors with a few lines of code. In addition, these bits of text are just as much scene objects as sprites - you can tint text, rotate it, alpha-blend it, and otherwise treat it like any other graphical object.

    Let's dig into how this works.

    There Are Two Kinds of Text​

    diff --git a/7.x/guides/components/textures.html b/7.x/guides/components/textures.html index 83fb498ad..5815fb664 100644 --- a/7.x/guides/components/textures.html +++ b/7.x/guides/components/textures.html @@ -1,4 +1,4 @@ -Textures | PixiJS
    Version: v7.x

    Textures

    +Textures | PixiJS
    Version: v7.x

    Textures

    We're slowly working our way down from the high level to the low. We've talked about the scene graph, and in general about display objects that live in it. We're about to get to sprites and other simple display objects. But before we do, we need to talk about textures.

    In PixiJS, textures are one of the core resources used by display objects. A texture, broadly speaking, represents a source of pixels to be used to fill in an area on the screen. The simplest example is a sprite - a rectangle that is completely filled with a single texture. But things can get much more complex.

    Life-cycle of a Texture​

    diff --git a/7.x/guides/migrations/upgrading.html b/7.x/guides/migrations/upgrading.html index b48460403..864d812b0 100644 --- a/7.x/guides/migrations/upgrading.html +++ b/7.x/guides/migrations/upgrading.html @@ -1,4 +1,4 @@ -Upgrading PixiJS | PixiJS
    Version: v7.x

    Upgrading PixiJS

    +Upgrading PixiJS | PixiJS
    Version: v7.x

    Upgrading PixiJS

    PixiJS uses a lot of peerDependencies internally to define the relationship between packages. This has created unpredictable errors because of how npm resolves peers when bumping/upgrading (e.g., #8382, #8268, #8144, #7209).

    When you're upgrading using npm please completely uninstall instead of just changing the version in your package.json:

    npm uninstall pixi.js
    npm install pixi.js
    diff --git a/7.x/guides/migrations/v5.html b/7.x/guides/migrations/v5.html index 9801b67e0..b845c3171 100644 --- a/7.x/guides/migrations/v5.html +++ b/7.x/guides/migrations/v5.html @@ -1,4 +1,4 @@ -v5 Migration Guide | PixiJS
    Version: v7.x

    v5 Migration Guide

    +v5 Migration Guide | PixiJS
    Version: v7.x

    v5 Migration Guide

    This document is useful for developers who are attempting to upgrading from v4 to v5. This includes gotchas and important context for understanding why your v4 code made need some subtle changes. In general, we've try to be as backward-compatible in v5 with the use of deprecation warnings in the console. There are, however, sometimes when changes are too substantial and require some additional help.

    🚧 API Changes​

    Making WebGL First-Class​

    diff --git a/7.x/guides/migrations/v6.html b/7.x/guides/migrations/v6.html index fc5535937..5570a5eb3 100644 --- a/7.x/guides/migrations/v6.html +++ b/7.x/guides/migrations/v6.html @@ -1,4 +1,4 @@ -v6 Migration Guide | PixiJS
    Version: v7.x

    v6 Migration Guide

    +v6 Migration Guide | PixiJS
    Version: v7.x

    v6 Migration Guide

    PixiJS 6 comes with few surface-level breaking changes. This document is not complete.

    Typings​

    If you're using TypeScript, make sure the follow is added to your tsconfig.json:

    diff --git a/7.x/guides/migrations/v7.html b/7.x/guides/migrations/v7.html index 49d2d747b..88ab63bc0 100644 --- a/7.x/guides/migrations/v7.html +++ b/7.x/guides/migrations/v7.html @@ -1,4 +1,4 @@ -v7 Migration Guide | PixiJS
    Version: v7.x

    v7 Migration Guide

    +v7 Migration Guide | PixiJS
    Version: v7.x

    v7 Migration Guide

    First and foremost, PixiJS v7 is a modernization release that reflects changes in the ecosystem since PixiJS was first published over six years ago. Browsers have gotten better, but PixiJS hasn't really taken advantage of some of the new features like fetch, Workers, modern JavaScript language syntax. This release keeps intact much of the high-level DisplayObjects (e.g., Sprite, Graphics, Mesh, etc). Aside from a few things, this release should be medium to low impact for most users.

    πŸ‘‹ Dropping Internet Explorer​

    Microsoft officially ended support for IE, so we decided to follow. It simplified many of our modernizations since IE was an outliner from Safari/Chrome/Firefox/Edge and mobile browsers. If you need support for IE, please consider using Babel or some other trans-piling tool.

    diff --git a/7.x/guides/production/performance-tips.html b/7.x/guides/production/performance-tips.html index cfa3f6fcc..f6bac9c86 100644 --- a/7.x/guides/production/performance-tips.html +++ b/7.x/guides/production/performance-tips.html @@ -1,4 +1,4 @@ -Performance Tips | PixiJS
    Version: v7.x

    Performance Tips

    +Performance Tips | PixiJS
    Version: v7.x

    Performance Tips

    General​

    • Only optimize when you need to! PixiJS can handle a fair amount of content off the bat
    • diff --git a/7.x/playground.html b/7.x/playground.html index 475126462..6c352dd25 100644 --- a/7.x/playground.html +++ b/7.x/playground.html @@ -1 +1 @@ -index | PixiJS \ No newline at end of file +index | PixiJS \ No newline at end of file diff --git a/7.x/search-index-blog.json b/7.x/search-index-blog.json index 6c5337009..b3de8980e 100644 --- a/7.x/search-index-blog.json +++ b/7.x/search-index-blog.json @@ -1 +1 @@ -[{"documents":[{"i":738,"t":"","u":"/blog/archive","b":["Blog"]},{"i":739,"t":"AssetPack 1.0.0 Release!","u":"/blog/assetpack-1.0.0","b":["Blog"]},{"i":756,"t":"PixiJS Update - Survey & v8.6.0","u":"/blog/better-docs-v8","b":["Blog"]},{"i":776,"t":"","u":"/blog/authors","b":["Blog"]},{"i":777,"t":"PixiJS Update - Start building with PixiJS in just one command! πŸš€","u":"/blog/create-cli","b":["Blog"]},{"i":795,"t":"PixiJS Joins the Spine 4.2 Physics Revolution! πŸš€","u":"/blog/pixi-js-hearts-spine","b":["Blog"]},{"i":805,"t":"Introducing the PixiJS Universe!","u":"/blog/pixi-universe","b":["Blog"]},{"i":839,"t":"ParticleContainer - The New Speed Demon in PixiJS v8","u":"/blog/particlecontainer-v8","b":["Blog"]},{"i":855,"t":"PixiJS v8 Beta! πŸŽ‰","u":"/blog/pixi-v8-beta","b":["Blog"]},{"i":869,"t":"PixiJS v8 Launches! πŸŽ‰","u":"/blog/pixi-v8-launches","b":["Blog"]}],"index":{"version":"2.3.9","fields":["t"],"fieldVectors":[["t/738",[]],["t/739",[0,2.219,1,2.219,2,2.219]],["t/756",[3,0.347,4,1.344,5,1.808,6,0.629,7,1.808]],["t/776",[]],["t/777",[3,0.411,4,1.051,6,0.492,8,1.414,9,1.414,10,1.414,11,1.414]],["t/795",[3,0.293,6,0.53,12,1.525,13,1.525,14,1.525,15,1.525,16,1.525]],["t/805",[3,0.427,17,2.219,18,2.219]],["t/839",[3,0.318,19,1.654,20,1.654,21,1.654,22,1.654,23,0.951]],["t/855",[3,0.383,6,0.693,23,1.145,24,1.992]],["t/869",[3,0.383,6,0.693,23,1.145,25,1.992]]],"invertedIndex":[["",{"_index":6,"t":{"756":{"position":[[23,1]]},"777":{"position":[[64,2]]},"795":{"position":[[47,2]]},"855":{"position":[[16,2]]},"869":{"position":[[20,2]]}}}],["1.0.0",{"_index":1,"t":{"739":{"position":[[10,5]]}}}],["4.2",{"_index":14,"t":{"795":{"position":[[23,3]]}}}],["assetpack",{"_index":0,"t":{"739":{"position":[[0,9]]}}}],["beta",{"_index":24,"t":{"855":{"position":[[10,5]]}}}],["building",{"_index":9,"t":{"777":{"position":[[22,8]]}}}],["command",{"_index":11,"t":{"777":{"position":[[55,8]]}}}],["demon",{"_index":22,"t":{"839":{"position":[[34,5]]}}}],["introducing",{"_index":17,"t":{"805":{"position":[[0,11]]}}}],["joins",{"_index":12,"t":{"795":{"position":[[7,5]]}}}],["launches",{"_index":25,"t":{"869":{"position":[[10,9]]}}}],["new",{"_index":20,"t":{"839":{"position":[[24,3]]}}}],["one",{"_index":10,"t":{"777":{"position":[[51,3]]}}}],["particlecontainer",{"_index":19,"t":{"839":{"position":[[0,17]]}}}],["physics",{"_index":15,"t":{"795":{"position":[[27,7]]}}}],["pixijs",{"_index":3,"t":{"756":{"position":[[0,6]]},"777":{"position":[[0,6],[36,6]]},"795":{"position":[[0,6]]},"805":{"position":[[16,6]]},"839":{"position":[[43,6]]},"855":{"position":[[0,6]]},"869":{"position":[[0,6]]}}}],["release",{"_index":2,"t":{"739":{"position":[[16,8]]}}}],["revolution",{"_index":16,"t":{"795":{"position":[[35,11]]}}}],["speed",{"_index":21,"t":{"839":{"position":[[28,5]]}}}],["spine",{"_index":13,"t":{"795":{"position":[[17,5]]}}}],["start",{"_index":8,"t":{"777":{"position":[[16,5]]}}}],["survey",{"_index":5,"t":{"756":{"position":[[16,6]]}}}],["universe",{"_index":18,"t":{"805":{"position":[[23,9]]}}}],["update",{"_index":4,"t":{"756":{"position":[[7,6]]},"777":{"position":[[7,6]]}}}],["v8",{"_index":23,"t":{"839":{"position":[[50,2]]},"855":{"position":[[7,2]]},"869":{"position":[[7,2]]}}}],["v8.6.0",{"_index":7,"t":{"756":{"position":[[25,6]]}}}]],"pipeline":["stemmer"]}},{"documents":[{"i":741,"t":"What is AssetPack?","u":"/blog/assetpack-1.0.0","h":"#what-is-assetpack","p":739},{"i":743,"t":"Key Features of AssetPack","u":"/blog/assetpack-1.0.0","h":"#key-features-of-assetpack","p":739},{"i":745,"t":"How to use AssetPack","u":"/blog/assetpack-1.0.0","h":"#how-to-use-assetpack","p":739},{"i":746,"t":"Installation","u":"/blog/assetpack-1.0.0","h":"#installation","p":739},{"i":748,"t":"Setup","u":"/blog/assetpack-1.0.0","h":"#setup","p":739},{"i":750,"t":"Open Source Games","u":"/blog/assetpack-1.0.0","h":"#open-source-games","p":739},{"i":752,"t":"Conclusion","u":"/blog/assetpack-1.0.0","h":"#conclusion","p":739},{"i":754,"t":"🌐 Stay Connected","u":"/blog/assetpack-1.0.0","h":"#-stay-connected","p":739},{"i":758,"t":"πŸ“– Improving Documentation","u":"/blog/better-docs-v8","h":"#-improving-documentation","p":756},{"i":760,"t":"✨ What’s New?","u":"/blog/better-docs-v8","h":"#-whats-new","p":756},{"i":762,"t":"v8.6.0","u":"/blog/better-docs-v8","h":"#v860","p":756},{"i":764,"t":"v8.5.0","u":"/blog/better-docs-v8","h":"#v850","p":756},{"i":766,"t":"v8.4.0","u":"/blog/better-docs-v8","h":"#v840","p":756},{"i":768,"t":"v8.3.0","u":"/blog/better-docs-v8","h":"#v830","p":756},{"i":770,"t":"v8.2.0","u":"/blog/better-docs-v8","h":"#v820","p":756},{"i":772,"t":"πŸ—£οΈ Looking Ahead","u":"/blog/better-docs-v8","h":"#️-looking-ahead","p":756},{"i":774,"t":"🌐 Stay Connected","u":"/blog/better-docs-v8","h":"#-stay-connected","p":756},{"i":779,"t":"πŸš€ Getting Started","u":"/blog/create-cli","h":"#-getting-started","p":777},{"i":781,"t":"πŸ› οΈ Bundler Templates: Simple and Barebones","u":"/blog/create-cli","h":"#️-bundler-templates-simple-and-barebones","p":777},{"i":783,"t":"What’s Included?","u":"/blog/create-cli","h":"#whats-included","p":777},{"i":785,"t":"🎨 Creation Templates: Feature-Rich Starting Points","u":"/blog/create-cli","h":"#-creation-templates-feature-rich-starting-points","p":777},{"i":787,"t":"What’s Included?","u":"/blog/create-cli","h":"#whats-included-1","p":777},{"i":789,"t":"🌍 Creation Templates for Every Platform","u":"/blog/create-cli","h":"#-creation-templates-for-every-platform","p":777},{"i":791,"t":"Acknowledgements","u":"/blog/create-cli","h":"#acknowledgements","p":777},{"i":793,"t":"🌐 Stay Connected","u":"/blog/create-cli","h":"#-stay-connected","p":777},{"i":797,"t":"πŸ‹οΈβ€β™‚οΈ Physics in Spine","u":"/blog/pixi-js-hearts-spine","h":"#️️-physics-in-spine","p":795},{"i":799,"t":"πŸ“Ž Attachments","u":"/blog/pixi-js-hearts-spine","h":"#-attachments","p":795},{"i":801,"t":"🏎️ v8 Spine Player Beta","u":"/blog/pixi-js-hearts-spine","h":"#️-v8-spine-player-beta","p":795},{"i":803,"t":"πŸ“² Stay Connected","u":"/blog/pixi-js-hearts-spine","h":"#-stay-connected","p":795},{"i":807,"t":"Phase 1​","u":"/blog/pixi-universe","h":"#phase-1","p":805},{"i":809,"t":"PixiJS Website​","u":"/blog/pixi-universe","h":"#pixijs-website","p":805},{"i":811,"t":"PixiJS React​","u":"/blog/pixi-universe","h":"#pixijs-react","p":805},{"i":813,"t":"PixiJS Open Games​","u":"/blog/pixi-universe","h":"#pixijs-open-games","p":805},{"i":815,"t":"PixiJS UI & PixiJS Layout​","u":"/blog/pixi-universe","h":"#pixijs-ui--pixijs-layout","p":805},{"i":817,"t":"AssetPack​","u":"/blog/pixi-universe","h":"#assetpack","p":805},{"i":819,"t":"Phase 2​","u":"/blog/pixi-universe","h":"#phase-2","p":805},{"i":821,"t":"PixiJS JumpStart​","u":"/blog/pixi-universe","h":"#pixijs-jumpstart","p":805},{"i":823,"t":"PixiJS Dev Tools​","u":"/blog/pixi-universe","h":"#pixijs-dev-tools","p":805},{"i":825,"t":"Phase 3​","u":"/blog/pixi-universe","h":"#phase-3","p":805},{"i":827,"t":"Comet​","u":"/blog/pixi-universe","h":"#comet","p":805},{"i":829,"t":"PixiJS v8​","u":"/blog/pixi-universe","h":"#pixijs-v8","p":805},{"i":831,"t":"Phase 4​","u":"/blog/pixi-universe","h":"#phase-4","p":805},{"i":833,"t":"PixiJS 3D​","u":"/blog/pixi-universe","h":"#pixijs-3d","p":805},{"i":835,"t":"PixiJS Game Engine​","u":"/blog/pixi-universe","h":"#pixijs-game-engine","p":805},{"i":837,"t":"Conclusion","u":"/blog/pixi-universe","h":"#conclusion","p":805},{"i":841,"t":"πŸš€ New ParticleContainer Design","u":"/blog/particlecontainer-v8","h":"#-new-particlecontainer-design","p":839},{"i":843,"t":"Speed Secret: Static vs. Dynamic Properties","u":"/blog/particlecontainer-v8","h":"#speed-secret-static-vs-dynamic-properties","p":839},{"i":845,"t":"PixiJS v8 Particle Container Usage","u":"/blog/particlecontainer-v8","h":"#pixijs-v8-particle-container-usage","p":839},{"i":847,"t":"Reasons to Use ParticleContainer","u":"/blog/particlecontainer-v8","h":"#reasons-to-use-particlecontainer","p":839},{"i":849,"t":"Next Steps","u":"/blog/particlecontainer-v8","h":"#next-steps","p":839},{"i":851,"t":"πŸŽ‰ Conclusion","u":"/blog/particlecontainer-v8","h":"#-conclusion","p":839},{"i":853,"t":"🌐 Stay Connected","u":"/blog/particlecontainer-v8","h":"#-stay-connected","p":839},{"i":857,"t":"1. 😍 Embracing WebGPU","u":"/blog/pixi-v8-beta","h":"#1--embracing-webgpu","p":855},{"i":859,"t":"2. πŸš€ Turbocharging Performance","u":"/blog/pixi-v8-beta","h":"#2--turbocharging-performance","p":855},{"i":861,"t":"But Wait, There's More!","u":"/blog/pixi-v8-beta","h":"#but-wait-theres-more","p":855},{"i":863,"t":"Over to you!","u":"/blog/pixi-v8-beta","h":"#over-to-you","p":855},{"i":865,"t":"Steps to install:","u":"/blog/pixi-v8-beta","h":"#steps-to-install","p":855},{"i":867,"t":"Keep in touch!","u":"/blog/pixi-v8-beta","h":"#keep-in-touch","p":855},{"i":871,"t":"πŸš€ Revolutionizing Web Graphics: Welcome to PixiJS v8","u":"/blog/pixi-v8-launches","h":"#-revolutionizing-web-graphics-welcome-to-pixijs-v8","p":869},{"i":873,"t":"πŸ”— Quick links","u":"/blog/pixi-v8-launches","h":"#-quick-links","p":869},{"i":875,"t":"🎁 Whats New?","u":"/blog/pixi-v8-launches","h":"#-whats-new","p":869},{"i":877,"t":"✨ We promise the Renderer will work","u":"/blog/pixi-v8-launches","h":"#-we-promise-the-renderer-will-work","p":869},{"i":879,"t":"🀝 What now? Get involved!","u":"/blog/pixi-v8-launches","h":"#-what-now-get-involved","p":869},{"i":881,"t":"πŸ“² Keep in touch","u":"/blog/pixi-v8-launches","h":"#-keep-in-touch","p":869}],"index":{"version":"2.3.9","fields":["t"],"fieldVectors":[["t/741",[0,3.589]],["t/743",[0,2.543,1,3.589,2,3.589]],["t/745",[0,2.977,3,3.632]],["t/746",[4,5.066]],["t/748",[5,5.066]],["t/750",[6,3.102,7,3.589,8,3.102]],["t/752",[9,3.927]],["t/754",[10,0.854,11,2.352,12,2.352]],["t/758",[10,0.854,13,3.589,14,3.589]],["t/760",[10,0.854,15,2.782,16,2.782]],["t/762",[17,5.066]],["t/764",[18,5.066]],["t/766",[19,5.066]],["t/768",[20,5.066]],["t/770",[21,5.066]],["t/772",[10,0.854,22,3.589,23,3.589]],["t/774",[10,0.854,11,2.352,12,2.352]],["t/779",[10,0.854,24,3.589,25,3.589]],["t/781",[10,0.661,26,2.778,27,2.154,28,2.778,29,2.778]],["t/783",[15,3.257,30,3.632]],["t/785",[10,0.54,27,1.757,31,1.96,32,2.267,33,2.267,34,2.267,35,2.267]],["t/787",[15,3.257,30,3.632]],["t/789",[10,0.746,27,2.428,31,2.708,36,3.132]],["t/791",[37,5.066]],["t/793",[10,0.854,11,2.352,12,2.352]],["t/797",[10,0.854,38,3.589,39,3.102]],["t/799",[10,1,40,4.201]],["t/801",[10,0.661,39,2.402,41,1.969,42,2.778,43,2.778]],["t/803",[10,0.854,11,2.352,12,2.352]],["t/807",[44,2.977,45,3.632]],["t/809",[46,1.931,47,4.201]],["t/811",[46,1.931,48,4.201]],["t/813",[6,3.102,8,3.102,46,1.649]],["t/815",[10,0.661,46,1.913,49,2.778,50,2.778]],["t/817",[0,3.589]],["t/819",[44,2.977,51,3.632]],["t/821",[46,1.931,52,4.201]],["t/823",[46,1.649,53,3.589,54,3.589]],["t/825",[44,2.977,55,4.201]],["t/827",[56,5.066]],["t/829",[41,2.977,46,1.931]],["t/831",[44,2.977,57,4.201]],["t/833",[46,1.931,58,4.201]],["t/835",[46,1.649,59,3.589,60,3.589]],["t/837",[9,3.927]],["t/841",[10,0.746,16,2.428,61,2.708,62,3.132]],["t/843",[63,2.497,64,2.497,65,2.497,66,2.497,67,2.497,68,2.497]],["t/845",[41,1.969,46,1.277,69,2.778,70,2.778,71,2.778]],["t/847",[3,3.102,61,3.102,72,3.589]],["t/849",[73,4.201,74,3.632]],["t/851",[9,3.257,10,1]],["t/853",[10,0.854,11,2.352,12,2.352]],["t/857",[10,0.746,45,2.708,75,3.132,76,3.132]],["t/859",[10,0.746,51,2.708,77,3.132,78,3.132]],["t/861",[79,3.589,80,3.589,81,3.589]],["t/863",[82,5.066]],["t/865",[74,3.632,83,4.201]],["t/867",[84,3.632,85,3.632]],["t/871",[10,0.54,41,1.606,46,1.042,86,2.267,87,2.267,88,2.267,89,2.267]],["t/873",[10,0.854,90,3.589,91,3.589]],["t/875",[10,0.854,16,2.782,92,3.589]],["t/877",[10,0.746,93,3.132,94,3.132,95,3.132]],["t/879",[10,0.854,96,3.589,97,3.589]],["t/881",[10,0.854,84,3.102,85,3.102]]],"invertedIndex":[["",{"_index":10,"t":{"754":{"position":[[0,2]]},"758":{"position":[[0,2]]},"760":{"position":[[0,1]]},"772":{"position":[[0,3]]},"774":{"position":[[0,2]]},"779":{"position":[[0,2]]},"781":{"position":[[0,3]]},"785":{"position":[[0,2]]},"789":{"position":[[0,2]]},"793":{"position":[[0,2]]},"797":{"position":[[0,6]]},"799":{"position":[[0,2]]},"801":{"position":[[0,3]]},"803":{"position":[[0,2]]},"815":{"position":[[10,1]]},"841":{"position":[[0,2]]},"851":{"position":[[0,2]]},"853":{"position":[[0,2]]},"857":{"position":[[3,2]]},"859":{"position":[[3,2]]},"871":{"position":[[0,2]]},"873":{"position":[[0,2]]},"875":{"position":[[0,2]]},"877":{"position":[[0,1]]},"879":{"position":[[0,2]]},"881":{"position":[[0,2]]}}}],["1",{"_index":45,"t":{"807":{"position":[[6,2]]},"857":{"position":[[0,2]]}}}],["2",{"_index":51,"t":{"819":{"position":[[6,2]]},"859":{"position":[[0,2]]}}}],["3",{"_index":55,"t":{"825":{"position":[[6,2]]}}}],["3d",{"_index":58,"t":{"833":{"position":[[7,3]]}}}],["4",{"_index":57,"t":{"831":{"position":[[6,2]]}}}],["acknowledgements",{"_index":37,"t":{"791":{"position":[[0,16]]}}}],["ahead",{"_index":23,"t":{"772":{"position":[[12,5]]}}}],["assetpack",{"_index":0,"t":{"741":{"position":[[8,10]]},"743":{"position":[[16,9]]},"745":{"position":[[11,9]]},"817":{"position":[[0,10]]}}}],["attachments",{"_index":40,"t":{"799":{"position":[[3,11]]}}}],["barebones",{"_index":29,"t":{"781":{"position":[[34,9]]}}}],["beta",{"_index":43,"t":{"801":{"position":[[20,4]]}}}],["bundler",{"_index":26,"t":{"781":{"position":[[4,7]]}}}],["comet",{"_index":56,"t":{"827":{"position":[[0,6]]}}}],["conclusion",{"_index":9,"t":{"752":{"position":[[0,10]]},"837":{"position":[[0,10]]},"851":{"position":[[3,10]]}}}],["connected",{"_index":12,"t":{"754":{"position":[[8,9]]},"774":{"position":[[8,9]]},"793":{"position":[[8,9]]},"803":{"position":[[8,9]]},"853":{"position":[[8,9]]}}}],["container",{"_index":70,"t":{"845":{"position":[[19,9]]}}}],["creation",{"_index":31,"t":{"785":{"position":[[3,8]]},"789":{"position":[[3,8]]}}}],["design",{"_index":62,"t":{"841":{"position":[[25,6]]}}}],["dev",{"_index":53,"t":{"823":{"position":[[7,3]]}}}],["documentation",{"_index":14,"t":{"758":{"position":[[13,13]]}}}],["dynamic",{"_index":67,"t":{"843":{"position":[[25,7]]}}}],["embracing",{"_index":75,"t":{"857":{"position":[[6,9]]}}}],["engine",{"_index":60,"t":{"835":{"position":[[12,7]]}}}],["feature",{"_index":32,"t":{"785":{"position":[[23,7]]}}}],["features",{"_index":2,"t":{"743":{"position":[[4,8]]}}}],["game",{"_index":59,"t":{"835":{"position":[[7,4]]}}}],["games",{"_index":8,"t":{"750":{"position":[[12,5]]},"813":{"position":[[12,6]]}}}],["getting",{"_index":24,"t":{"779":{"position":[[3,7]]}}}],["graphics",{"_index":88,"t":{"871":{"position":[[23,9]]}}}],["improving",{"_index":13,"t":{"758":{"position":[[3,9]]}}}],["included",{"_index":30,"t":{"783":{"position":[[7,9]]},"787":{"position":[[7,9]]}}}],["install",{"_index":83,"t":{"865":{"position":[[9,8]]}}}],["installation",{"_index":4,"t":{"746":{"position":[[0,12]]}}}],["involved",{"_index":97,"t":{"879":{"position":[[17,9]]}}}],["jumpstart",{"_index":52,"t":{"821":{"position":[[7,10]]}}}],["keep",{"_index":84,"t":{"867":{"position":[[0,4]]},"881":{"position":[[3,4]]}}}],["key",{"_index":1,"t":{"743":{"position":[[0,3]]}}}],["layout",{"_index":50,"t":{"815":{"position":[[19,7]]}}}],["links",{"_index":91,"t":{"873":{"position":[[9,5]]}}}],["looking",{"_index":22,"t":{"772":{"position":[[4,7]]}}}],["more",{"_index":81,"t":{"861":{"position":[[18,5]]}}}],["new",{"_index":16,"t":{"760":{"position":[[9,4]]},"841":{"position":[[3,3]]},"875":{"position":[[9,4]]}}}],["next",{"_index":73,"t":{"849":{"position":[[0,4]]}}}],["now",{"_index":96,"t":{"879":{"position":[[8,4]]}}}],["open",{"_index":6,"t":{"750":{"position":[[0,4]]},"813":{"position":[[7,4]]}}}],["over",{"_index":82,"t":{"863":{"position":[[0,4]]}}}],["particle",{"_index":69,"t":{"845":{"position":[[10,8]]}}}],["particlecontainer",{"_index":61,"t":{"841":{"position":[[7,17]]},"847":{"position":[[15,17]]}}}],["performance",{"_index":78,"t":{"859":{"position":[[20,11]]}}}],["phase",{"_index":44,"t":{"807":{"position":[[0,5]]},"819":{"position":[[0,5]]},"825":{"position":[[0,5]]},"831":{"position":[[0,5]]}}}],["physics",{"_index":38,"t":{"797":{"position":[[7,7]]}}}],["pixijs",{"_index":46,"t":{"809":{"position":[[0,6]]},"811":{"position":[[0,6]]},"813":{"position":[[0,6]]},"815":{"position":[[0,6],[12,6]]},"821":{"position":[[0,6]]},"823":{"position":[[0,6]]},"829":{"position":[[0,6]]},"833":{"position":[[0,6]]},"835":{"position":[[0,6]]},"845":{"position":[[0,6]]},"871":{"position":[[44,6]]}}}],["platform",{"_index":36,"t":{"789":{"position":[[32,8]]}}}],["player",{"_index":42,"t":{"801":{"position":[[13,6]]}}}],["points",{"_index":35,"t":{"785":{"position":[[45,6]]}}}],["promise",{"_index":93,"t":{"877":{"position":[[5,7]]}}}],["properties",{"_index":68,"t":{"843":{"position":[[33,10]]}}}],["quick",{"_index":90,"t":{"873":{"position":[[3,5]]}}}],["react",{"_index":48,"t":{"811":{"position":[[7,6]]}}}],["reasons",{"_index":72,"t":{"847":{"position":[[0,7]]}}}],["renderer",{"_index":94,"t":{"877":{"position":[[17,8]]}}}],["revolutionizing",{"_index":86,"t":{"871":{"position":[[3,15]]}}}],["rich",{"_index":33,"t":{"785":{"position":[[31,4]]}}}],["secret",{"_index":64,"t":{"843":{"position":[[6,7]]}}}],["setup",{"_index":5,"t":{"748":{"position":[[0,5]]}}}],["simple",{"_index":28,"t":{"781":{"position":[[23,6]]}}}],["source",{"_index":7,"t":{"750":{"position":[[5,6]]}}}],["speed",{"_index":63,"t":{"843":{"position":[[0,5]]}}}],["spine",{"_index":39,"t":{"797":{"position":[[18,5]]},"801":{"position":[[7,5]]}}}],["started",{"_index":25,"t":{"779":{"position":[[11,7]]}}}],["starting",{"_index":34,"t":{"785":{"position":[[36,8]]}}}],["static",{"_index":65,"t":{"843":{"position":[[14,6]]}}}],["stay",{"_index":11,"t":{"754":{"position":[[3,4]]},"774":{"position":[[3,4]]},"793":{"position":[[3,4]]},"803":{"position":[[3,4]]},"853":{"position":[[3,4]]}}}],["steps",{"_index":74,"t":{"849":{"position":[[5,5]]},"865":{"position":[[0,5]]}}}],["templates",{"_index":27,"t":{"781":{"position":[[12,10]]},"785":{"position":[[12,10]]},"789":{"position":[[12,9]]}}}],["there's",{"_index":80,"t":{"861":{"position":[[10,7]]}}}],["tools",{"_index":54,"t":{"823":{"position":[[11,6]]}}}],["touch",{"_index":85,"t":{"867":{"position":[[8,6]]},"881":{"position":[[11,5]]}}}],["turbocharging",{"_index":77,"t":{"859":{"position":[[6,13]]}}}],["ui",{"_index":49,"t":{"815":{"position":[[7,2]]}}}],["usage",{"_index":71,"t":{"845":{"position":[[29,5]]}}}],["use",{"_index":3,"t":{"745":{"position":[[7,3]]},"847":{"position":[[11,3]]}}}],["v8",{"_index":41,"t":{"801":{"position":[[4,2]]},"829":{"position":[[7,3]]},"845":{"position":[[7,2]]},"871":{"position":[[51,2]]}}}],["v8.2.0",{"_index":21,"t":{"770":{"position":[[0,6]]}}}],["v8.3.0",{"_index":20,"t":{"768":{"position":[[0,6]]}}}],["v8.4.0",{"_index":19,"t":{"766":{"position":[[0,6]]}}}],["v8.5.0",{"_index":18,"t":{"764":{"position":[[0,6]]}}}],["v8.6.0",{"_index":17,"t":{"762":{"position":[[0,6]]}}}],["vs",{"_index":66,"t":{"843":{"position":[[21,3]]}}}],["wait",{"_index":79,"t":{"861":{"position":[[4,5]]}}}],["web",{"_index":87,"t":{"871":{"position":[[19,3]]}}}],["webgpu",{"_index":76,"t":{"857":{"position":[[16,6]]}}}],["website",{"_index":47,"t":{"809":{"position":[[7,8]]}}}],["welcome",{"_index":89,"t":{"871":{"position":[[33,7]]}}}],["whats",{"_index":92,"t":{"875":{"position":[[3,5]]}}}],["what’s",{"_index":15,"t":{"760":{"position":[[2,6]]},"783":{"position":[[0,6]]},"787":{"position":[[0,6]]}}}],["work",{"_index":95,"t":{"877":{"position":[[31,4]]}}}]],"pipeline":["stemmer"]}},{"documents":[{"i":738,"t":"Archive","s":"","u":"/blog/archive","p":738},{"i":739,"t":"AssetPack 1.0.0 is here! πŸŽ‰","s":"AssetPack 1.0.0 Release!","u":"/blog/assetpack-1.0.0","p":739},{"i":756,"t":"A look at the recent updates and improvements in PixiJS.","s":"PixiJS Update - Survey & v8.6.0","u":"/blog/better-docs-v8","p":756},{"i":777,"t":"A look at the new PixiJS Create CLI and Creation Templates for easier project setup.","s":"PixiJS Update - Start building with PixiJS in just one command! πŸš€","u":"/blog/create-cli","p":777},{"i":795,"t":"Elevate your animations with Spine 1.1.0 and the revolutionary physics features of Spine 4.2, now fully integrated with PixiJS v8.","s":"PixiJS Joins the Spine 4.2 Physics Revolution! πŸš€","u":"/blog/pixi-js-hearts-spine","p":795},{"i":805,"t":"PixiJS v2 Website Brief Description","s":"Introducing the PixiJS Universe!","u":"/blog/pixi-universe","p":805},{"i":839,"t":"Introducing the new ParticleContainer in PixiJS v8β€”faster than ever, optimized for rendering millions of particles effortlessly.","s":"ParticleContainer - The New Speed Demon in PixiJS v8","u":"/blog/particlecontainer-v8","p":839},{"i":855,"t":"PixiJS v8 The Future of 2D Web Graphics Is (almost!) Here!","s":"PixiJS v8 Beta! πŸŽ‰","u":"/blog/pixi-v8-beta","p":855},{"i":869,"t":"PixiJS v8 The Future of 2D Web Graphics is Here!","s":"PixiJS v8 Launches! πŸŽ‰","u":"/blog/pixi-v8-launches","p":869}],"index":{"version":"2.3.9","fields":["t"],"fieldVectors":[["t/738",[0,2.922]],["t/739",[1,2.3,2,2.3,3,1.273,4,2.3]],["t/756",[5,1.57,6,2.148,7,2.148,8,2.148,9,0.326]],["t/777",[5,1.179,9,0.245,10,1.179,11,1.614,12,1.614,13,1.614,14,1.614,15,1.614,16,1.614,17,1.614]],["t/795",[9,0.204,18,1.346,19,1.346,20,2.036,21,1.346,22,1.346,23,1.346,24,1.346,25,1.346,26,1.346,27,1.346,28,1.346,29,0.745]],["t/805",[9,0.326,30,2.148,31,2.148,32,2.148,33,2.148]],["t/839",[9,0.245,10,1.179,34,1.614,35,1.614,36,1.614,37,1.614,38,1.614,39,1.614,40,1.614,41,1.614]],["t/855",[3,1.05,9,0.288,29,1.05,42,1.386,43,1.386,44,1.386,45,1.386]],["t/869",[3,1.05,9,0.288,29,1.05,42,1.386,43,1.386,44,1.386,45,1.386]]],"invertedIndex":[["",{"_index":4,"t":{"739":{"position":[[25,2]]}}}],["1.0.0",{"_index":2,"t":{"739":{"position":[[10,5]]}}}],["1.1.0",{"_index":21,"t":{"795":{"position":[[35,5]]}}}],["2d",{"_index":43,"t":{"855":{"position":[[24,2]]},"869":{"position":[[24,2]]}}}],["4.2",{"_index":25,"t":{"795":{"position":[[89,4]]}}}],["animations",{"_index":19,"t":{"795":{"position":[[13,10]]}}}],["archive",{"_index":0,"t":{"738":{"position":[[0,7]]}}}],["assetpack",{"_index":1,"t":{"739":{"position":[[0,9]]}}}],["brief",{"_index":32,"t":{"805":{"position":[[18,5]]}}}],["cli",{"_index":12,"t":{"777":{"position":[[32,3]]}}}],["create",{"_index":11,"t":{"777":{"position":[[25,6]]}}}],["creation",{"_index":13,"t":{"777":{"position":[[40,8]]}}}],["description",{"_index":33,"t":{"805":{"position":[[24,11]]}}}],["easier",{"_index":15,"t":{"777":{"position":[[63,6]]}}}],["effortlessly",{"_index":41,"t":{"839":{"position":[[115,13]]}}}],["elevate",{"_index":18,"t":{"795":{"position":[[0,7]]}}}],["features",{"_index":24,"t":{"795":{"position":[[71,8]]}}}],["fully",{"_index":27,"t":{"795":{"position":[[98,5]]}}}],["future",{"_index":42,"t":{"855":{"position":[[14,6]]},"869":{"position":[[14,6]]}}}],["graphics",{"_index":45,"t":{"855":{"position":[[31,8]]},"869":{"position":[[31,8]]}}}],["here",{"_index":3,"t":{"739":{"position":[[19,5]]},"855":{"position":[[53,5]]},"869":{"position":[[43,5]]}}}],["improvements",{"_index":8,"t":{"756":{"position":[[33,12]]}}}],["integrated",{"_index":28,"t":{"795":{"position":[[104,10]]}}}],["introducing",{"_index":34,"t":{"839":{"position":[[0,11]]}}}],["look",{"_index":5,"t":{"756":{"position":[[2,4]]},"777":{"position":[[2,4]]}}}],["millions",{"_index":39,"t":{"839":{"position":[[93,8]]}}}],["new",{"_index":10,"t":{"777":{"position":[[14,3]]},"839":{"position":[[16,3]]}}}],["now",{"_index":26,"t":{"795":{"position":[[94,3]]}}}],["optimized",{"_index":37,"t":{"839":{"position":[[69,9]]}}}],["particlecontainer",{"_index":35,"t":{"839":{"position":[[20,17]]}}}],["particles",{"_index":40,"t":{"839":{"position":[[105,9]]}}}],["physics",{"_index":23,"t":{"795":{"position":[[63,7]]}}}],["pixijs",{"_index":9,"t":{"756":{"position":[[49,7]]},"777":{"position":[[18,6]]},"795":{"position":[[120,6]]},"805":{"position":[[0,6]]},"839":{"position":[[41,6]]},"855":{"position":[[0,6]]},"869":{"position":[[0,6]]}}}],["project",{"_index":16,"t":{"777":{"position":[[70,7]]}}}],["recent",{"_index":6,"t":{"756":{"position":[[14,6]]}}}],["rendering",{"_index":38,"t":{"839":{"position":[[83,9]]}}}],["revolutionary",{"_index":22,"t":{"795":{"position":[[49,13]]}}}],["setup",{"_index":17,"t":{"777":{"position":[[78,6]]}}}],["spine",{"_index":20,"t":{"795":{"position":[[29,5],[83,5]]}}}],["templates",{"_index":14,"t":{"777":{"position":[[49,9]]}}}],["updates",{"_index":7,"t":{"756":{"position":[[21,7]]}}}],["v2",{"_index":30,"t":{"805":{"position":[[7,2]]}}}],["v8",{"_index":29,"t":{"795":{"position":[[127,3]]},"855":{"position":[[7,2]]},"869":{"position":[[7,2]]}}}],["v8β€”faster",{"_index":36,"t":{"839":{"position":[[48,9]]}}}],["web",{"_index":44,"t":{"855":{"position":[[27,3]]},"869":{"position":[[27,3]]}}}],["website",{"_index":31,"t":{"805":{"position":[[10,7]]}}}]],"pipeline":["stemmer"]}},{"documents":[{"i":739,"t":"PixiJS,Spine,JavaScript,game development,web development,asset management,loading","s":"AssetPack 1.0.0 Release!","u":"/blog/assetpack-1.0.0","p":739},{"i":756,"t":"PixiJS,Updates,Improvements,QoL","s":"PixiJS Update - Survey & v8.6.0","u":"/blog/better-docs-v8","p":756},{"i":777,"t":"PixiJS,Updates,Improvements,QoL,Templates,CLI","s":"PixiJS Update - Start building with PixiJS in just one command! πŸš€","u":"/blog/create-cli","p":777},{"i":795,"t":"PixiJS,Spine,webGL,webGPU,2D animation,JavaScript graphics,game development","s":"PixiJS Joins the Spine 4.2 Physics Revolution! πŸš€","u":"/blog/pixi-js-hearts-spine","p":795},{"i":805,"t":"keyword,for,search,engines","s":"Introducing the PixiJS Universe!","u":"/blog/pixi-universe","p":805},{"i":839,"t":"PixiJS,ParticleContainer,game development,web graphics,optimization,WebGL","s":"ParticleContainer - The New Speed Demon in PixiJS v8","u":"/blog/particlecontainer-v8","p":839},{"i":855,"t":"PixiJS,pixi.js,webGL,webGPU,performance,2d rendering,2d webGL,javascript graphics,game development","s":"PixiJS v8 Beta! πŸŽ‰","u":"/blog/pixi-v8-beta","p":855},{"i":869,"t":"PixiJS,pixi.js,webGL,webGPU,performance,2d rendering,2d webGL,javascript graphics,game development","s":"PixiJS v8 Launches! πŸŽ‰","u":"/blog/pixi-v8-launches","p":869}],"index":{"version":"2.3.9","fields":["t"],"fieldVectors":[["t/739",[0,1.577,1,1.127,2,1.577,3,1.577]],["t/756",[4,2.464]],["t/777",[5,2.464]],["t/795",[6,1.577,7,1.577,8,0.831,9,0.831]],["t/805",[10,2.464]],["t/839",[1,1.281,11,1.792,12,1.792]],["t/855",[8,0.742,9,0.742,13,1.006,14,1.006,15,1.006]],["t/869",[8,0.742,9,0.742,13,1.006,14,1.006,15,1.006]]],"invertedIndex":[["animation,javascript",{"_index":7,"t":{"795":{"position":[[29,20]]}}}],["development",{"_index":9,"t":{"795":{"position":[[64,11]]},"855":{"position":[[87,11]]},"869":{"position":[[87,11]]}}}],["development,asset",{"_index":2,"t":{"739":{"position":[[45,17]]}}}],["development,web",{"_index":1,"t":{"739":{"position":[[29,15]]},"839":{"position":[[30,15]]}}}],["graphics,game",{"_index":8,"t":{"795":{"position":[[50,13]]},"855":{"position":[[73,13]]},"869":{"position":[[73,13]]}}}],["graphics,optimization,webgl",{"_index":12,"t":{"839":{"position":[[46,27]]}}}],["keyword,for,search,engines",{"_index":10,"t":{"805":{"position":[[0,26]]}}}],["management,loading",{"_index":3,"t":{"739":{"position":[[63,18]]}}}],["pixijs,particlecontainer,game",{"_index":11,"t":{"839":{"position":[[0,29]]}}}],["pixijs,pixi.js,webgl,webgpu,performance,2d",{"_index":13,"t":{"855":{"position":[[0,42]]},"869":{"position":[[0,42]]}}}],["pixijs,spine,javascript,game",{"_index":0,"t":{"739":{"position":[[0,28]]}}}],["pixijs,spine,webgl,webgpu,2d",{"_index":6,"t":{"795":{"position":[[0,28]]}}}],["pixijs,updates,improvements,qol",{"_index":4,"t":{"756":{"position":[[0,31]]}}}],["pixijs,updates,improvements,qol,templates,cli",{"_index":5,"t":{"777":{"position":[[0,45]]}}}],["rendering,2d",{"_index":14,"t":{"855":{"position":[[43,12]]},"869":{"position":[[43,12]]}}}],["webgl,javascript",{"_index":15,"t":{"855":{"position":[[56,16]]},"869":{"position":[[56,16]]}}}]],"pipeline":["stemmer"]}},{"documents":[{"i":740,"t":"Today we are very excited to announce AssetPack 1.0, an asset management and optimization tool for web developers. In the world of web development, managing and optimizing assets often demands significant manual effort. Developers need to ensure that their images are compressed, their audio files are optimized, their fonts are loaded efficiently, and more. This process can be time-consuming and error-prone, especially when working on large projects with many assets. To address this challenge, AssetPack provides a configurable asset pipeline that automates many of these tasks, making it easier for developers to manage and deploy assets in their projects.","s":"AssetPack 1.0.0 Release!","u":"/blog/assetpack-1.0.0","h":"","p":739},{"i":742,"t":"AssetPack is a tool designed to streamline the management, optimization, and deployment of assets in web projects. It is framework-agnostic and can be used with any framework you like, such as PixiJS, Three.js, Phaser, and others. AssetPack employs a plugin-based system, allowing you to create your own plugins to customize asset processing according to your needs. AssetPack comes out of the box with the following plugins: Cache Busting: Automatically appends a unique hash to asset URLs to ensure that clients always load the latest version of the asset. Compression: Compresses images using sharp, allowing for the creation of webp/avif images and compressing png/jpg to reduce file sizes. TexturePacker: Automatically generates spritesheets from images. Mipmap: Generates mipmaps for textures to improve rendering performance e.g. 2x, 1x, 0.5x, etc. Spine: Optimizes Spine animations by creating mipmaps for .atlas files. Audio/FFmpeg: Converts audio files to the desired format and bitrate using FFmpeg. JSON: Minifies JSON files to reduce their size. Webfont: Converts all fonts files to WOFF2 format, and plugins for SDF and MSDF font generation Manifest: Generates a manifest file containing all asset URLs for easy loading. This can be used with PixiJS's Assets loader The above plugins are just a few examples of what AssetPack can do. You can create your own plugins to extend AssetPack's functionality further.","s":"What is AssetPack?","u":"/blog/assetpack-1.0.0","h":"#what-is-assetpack","p":739},{"i":744,"t":"Caching & CI​ AssetPack intelligently caches assets, transforming each asset only once. This reduces redundant processing and speeds up build times, ensuring that you always have the latest version of your assets without unnecessary overhead. This is perfect for Continuous Integration (CI) environments, AssetPack allows you to commit raw assets to your repository and transform them as part of your build process. This ensures that your assets are always optimized and up-to-date with minimal manual intervention. See the Github Action example here for more information. Performance​ Designed to handle large quantities of assets, AssetPack utilizes the fastest tools available. This ensures that your asset pipeline can keep up with the demands of modern web development, delivering optimized assets quickly and efficiently. Watch Mode​ With the Watch mode, AssetPack monitors your assets in real-time, updating them as you add or remove files. This live update feature streamlines development, allowing you to see changes immediately without having to manually trigger asset processing. Combined with the caching system, Watch mode ensures that only the necessary assets are transformed, keeping build times to a minimum. Tag System​ AssetPack's tag-powered system makes asset management intuitive and flexible. By simply adding tags to folders or files (e.g., {tps} to create a sprite sheet), you can easily apply specific processing rules. This feature simplifies complex asset workflows and enhances customization.","s":"Key Features of AssetPack","u":"/blog/assetpack-1.0.0","h":"#key-features-of-assetpack","p":739},{"i":747,"t":"To install AssetPack, you need to install the @assetpack/core package. npm install --save-dev @assetpack/core COMPATIBILITY NOTE AssetPack requires Node.js version 20+, please upgrade if your package manager warns about it.","s":"Installation","u":"/blog/assetpack-1.0.0","h":"#installation","p":739},{"i":749,"t":"To set up AssetPack, you need to create a configuration file that defines what assets you want to optimise and how you want to optimise them. First create a .assetpack.js file in the root of your project. This file should export an object with the following properties: // .assetpack.js import { pixiPipes } from '@assetpack/core'; export default { entry: './raw-assets', output: './public/assets', pipes: [ /* If you are using AssetPack with PixiJS, you can use the `pixiPipes` function * to add a pre-configured set of plugins, with an opinionated * set of defaults for PixiJS. */ ...pixiPipes() ], }; To see the full list of configuration options, see the API Reference page. Then to run AssetPack, you can use the CLI, run programmatically, or use a build tool like Vite. CLI Programmatic Vite AssetPack has a number of built-in plugins for you to use, to see the full list of plugins, see the Plugins page.","s":"Setup","u":"/blog/assetpack-1.0.0","h":"#setup","p":739},{"i":751,"t":"AssetPack is already in use in our open source games repo. Check out the games leveraging AssetPack for asset management. These examples showcase the power and flexibility of AssetPack in real-world scenarios.","s":"Open Source Games","u":"/blog/assetpack-1.0.0","h":"#open-source-games","p":739},{"i":753,"t":"AssetPack is a powerful tool that can help you manage and optimize assets in your web projects. By automating many of the tasks involved in asset management, AssetPack can save you time and effort, allowing you to focus on building great web experiences. We hope you find AssetPack useful in your projects, and we look forward to seeing what you create with it! We are committed to continuously improving AssetPack, and your feedback is invaluable to us. If you encounter any issues or have suggestions for new features, please reach out on our discord or open an issue on our GitHub repository.","s":"Conclusion","u":"/blog/assetpack-1.0.0","h":"#conclusion","p":739},{"i":755,"t":"Follow Zyie and PixiJS on social media for the latest updates. Join our vibrant community on Discord for real-time discussions and support.","s":"🌐 Stay Connected","u":"/blog/assetpack-1.0.0","h":"#-stay-connected","p":739},{"i":757,"t":"Thank you to everyone who participated in our survey! One thing came through loud and clear: better documentation is a top priority for the PixiJS community. We’ve taken your feedback to heart, and work is already underway to make significant improvements. This post is part of our commitment to better communication. We’ll share how we’re tackling documentation updates and shine a light on some of the great features and improvements we’ve introduced since PixiJS v8 that might have flown under the radar!","s":"PixiJS Update - Survey & v8.6.0","u":"/blog/better-docs-v8","h":"","p":756},{"i":759,"t":"Documentation is critical for a library like PixiJS, and we recognize there’s room for growth. Below is a list of the changes we’re making to improve the documentation: More Examples: Adding more examples for both beginners and experienced developers to learn from to the website. Add example/guide for each feature we introduce on release, to help you understand how to use it right away. Updated Guides: Overhaul our current set of guides to better reflect the current state of PixiJS. Add more guides to cover the basics of PixiJS Starter Templates: Create a set of starter templates to help you get up and running quickly. These templates will be available through an npm create command. API Doc Improvements: Improve documentation of types. Include inline examples and explanations. Ensure all public API's are written from the perspective of the user, not the developer. Look into providing a toggle for exposing internal API's, with the default being to hide them. This will help reduce the noise in the API docs for most users while stil giving plugin developers access to the internals. Migration Guide: Improving the migration guide to help you upgrade your codebase to the latest version of PixiJS. Explore backporting more deprecations where possible to help you upgrade your codebase more easily. These changes will take time, but they are high on our priority list. If you have any suggestions or feedback, please let us know on Bluesky or Discord.","s":"πŸ“– Improving Documentation","u":"/blog/better-docs-v8","h":"#-improving-documentation","p":756},{"i":761,"t":"We’ve been hard at work delivering new features and improvements, but let’s be honestβ€”we haven’t done the best job announcing them. Here’s a quick rundown of the highlights from our recent releases. NOTE We will be bringing out more detailed guides/examples on all of these features as well, this is just the start!","s":"✨ What’s New?","u":"/blog/better-docs-v8","h":"#-whats-new","p":756},{"i":763,"t":"cacheAsTexture: Containers now have a cacheAsTexture() function. It behaves similarly to cacheAsBitmap from v7 and will render the container to a texture instead of rendering the container itself. This can be great for performance if the container is static, as instead of rendering all the children etc., it will just render a single texture. As well as this the process of caching is also relatively low cost, with the trade-off being memory usage as the use of a texture does increase memory (for the texture itself). Guide We have a full guide on this feature here. index.js Loading... Open browser console EditorPreviewBoth pixelLine: The pixelLine property is a neat feature of the PixiJS Graphics API that allows you to create lines that remain 1 pixel thick, regardless of scaling or zoom level. This feature is especially useful for achieving crisp, pixel-perfect visuals, particularly in retro-style or grid-based games, technical drawing, or UI rendering. Guide We have a full guide on this feature here. index.js Loading... Open browser console EditorPreviewBoth New Global Methods: We have added three new functions to Container to make it easier to work with global transforms / tints / alphas. getGlobalTransform const skipUpdate = false; const outMatrix = new Matrix(); // writes and returns outMatrix; const globalTransform = container.getGlobalTransform(outMatrix, skipUpdate); getGlobalTint const skipUpdate = false; // returns rgb color const globalTint = container.getGlobalTint(skipUpdate); getGlobalAlpha const skipUpdate = false; // returns alpha as number; const globalAlpha = container.getGlobalAlpha(skipUpdate); INFO if skipUpdate is true - it will be faster but may be outdated - uses the last rendered data if skipUpdate is false - it will be 100% accurate but slower - recalculates transform chain","s":"v8.6.0","u":"/blog/better-docs-v8","h":"#v860","p":756},{"i":765,"t":"ParticleContainer: Faster than ever, optimized for rendering a million particles effortlessly. The ParticleContainer shines when you need insane numbers of visual elements on-screen, especially when you want them moving and interacting in real time. Whether you're building particle effects, swarms of characters, or abstract art installations, PixiJS v8 has you covered. The static vs. dynamic property system gives you granular control over performance, allowing you to fine-tune the balance between flexibility and speed. Blog We have a blog post on this feature here. index.js Loading... Open browser console EditorPreviewBoth Inverse Masking: You can now use element.setMask({ mask, inverse: true }) to create an inverse mask effect. This is great for creating cut-out effects or other creative visuals. index.js Loading... Open browser console EditorPreviewBoth","s":"v8.5.0","u":"/blog/better-docs-v8","h":"#v850","p":756},{"i":767,"t":"Multiview: Support for renderering the same context to multiple canvases. Eliminating the need for multiple PixiJS instances and duplicating resources. Simply add await app.init({ multiView: true}) and when rendering, pass in the target canvas to render to. renderer.render({ container, target: canvasOnDom1 }) EXPERIMENTAL This feature is still experimental and currently interaction only works on the first canvas.","s":"v8.4.0","u":"/blog/better-docs-v8","h":"#v840","p":756},{"i":769,"t":"PerspectiveMesh: A new mesh type that allows you to create 3D perspective effect index.js Loading... Open browser console EditorPreviewBoth","s":"v8.3.0","u":"/blog/better-docs-v8","h":"#v830","p":756},{"i":771,"t":"Container Reparenting: You can now reparent a container to another container without it looking visually different with two new methods reparentChild(child) and reparentChildAt(child, 1). Usually when you move a child from one container to another, it will visually jump to the new container. This is because the child's transform is relative to the parent container. With these new methods, the child will keep its position and scale relative to the new parent container. const container1 = new Container(); const container2 = new Container(); const sprite = new Sprite(); container1.scale = 5; container1.addChild(sprite); // visually the sprite will remain in the same position and scale // despite container1 and container2 having different scales. container2.reparentChild(sprite); ### v8.1.0 - **Generic Typing for Container**: You can now specify the type of children that a container can have. e.g. ```typescript const container = new Container(); container.addChild(new Sprite()); container.addChild(new Graphics()); // This will throw a type error DTS Bundles: We now provide a single TypeScript definition file with all pixi exports under the PIXI namespace, similar to the defintion file we generated in v6. This can be useful for users that are using PixiJS in a non-module environment, and need to include the definition file manually. This file can be found on all of our releases on Github in the \"Assets\" section, or through https://pixijs.download/vX.X.X/pixi.d.ts.","s":"v8.2.0","u":"/blog/better-docs-v8","h":"#v820","p":756},{"i":773,"t":"We’re committed to addressing the feedback you’ve shared and continuing to improve PixiJS. In addition to better documentation, you can expect more regular updates to keep you informed about what’s new. Your input is vital to PixiJS’s success, and we encourage you to share your thoughts through Bluesky, Github, and the Discord channel. Thanks for your continued support as we work to make PixiJS better for everyone. The PixiJS Team","s":"πŸ—£οΈ Looking Ahead","u":"/blog/better-docs-v8","h":"#️-looking-ahead","p":756},{"i":775,"t":"Follow Zyie and PixiJS on social media for the latest updates. Join our vibrant community on Discord for real-time discussions and support.","s":"🌐 Stay Connected","u":"/blog/better-docs-v8","h":"#-stay-connected","p":756},{"i":778,"t":"As we mentioned in our previous PixiJS Update post, we are focusing on making PixiJS easier to use and understand. Today we're pushing the project one step closer to that goal and we’re excited to introduce PixiJS Create. An easy to use CLI that provides templates for using PixiJS with your favourite bundler, as well as a new \"Creation Template\" to get you started with PixiJS and its ecosystem.","s":"PixiJS Update - Start building with PixiJS in just one command! πŸš€","u":"/blog/create-cli","h":"","p":777},{"i":780,"t":"PixiJS Create is a new CLI tool that simplifies the process of setting up a PixiJS project. It provides a quick and easy way to create a new PixiJS project with the tools you need to get started with just one command. Whether you prefer using Vite, Webpack, or esbuild, PixiJS Create has you covered. It is as simple as running: NPM: npm create pixi.js@latest Yarn: yarn create pixi.js PNPM: pnpm create pixi.js Bun: bun create pixi.js Then just follow the prompts to select your desired template and you're good to go! When running the tool, you will be presented with an option of either a Bundler Template or a Creation Template. Let's take a closer look at each of these options.","s":"πŸš€ Getting Started","u":"/blog/create-cli","h":"#-getting-started","p":777},{"i":782,"t":"Bundler Templates are stripped-down starting points for setting up PixiJS projects with popular build tools. These templates focus solely on the essentials, giving you a no-frills environment to start your project without any added complexity.","s":"πŸ› οΈ Bundler Templates: Simple and Barebones","u":"/blog/create-cli","h":"#️-bundler-templates-simple-and-barebones","p":777},{"i":784,"t":"Out-of-the-box integration with major bundlers, including: Vite v6 + PixiJS (Recommended) Webpack v5 + PixiJS esbuild + PixiJS PixiJS imported via import maps Bundler Templates are ideal if you want complete control over your project’s setup while skipping the hassle of setting up an entire project. They’re lightweight, efficient, and perfect for custom workflows.","s":"What’s Included?","u":"/blog/create-cli","h":"#whats-included","p":777},{"i":786,"t":"Creation Templates go beyond the basics, offering a fully-featured foundation for building applications with PixiJS. These templates address common challenges developers face when starting a new project, providing tools that simplify screen management, asset handling, audio and more.","s":"🎨 Creation Templates: Feature-Rich Starting Points","u":"/blog/create-cli","h":"#-creation-templates-feature-rich-starting-points","p":777},{"i":788,"t":"Screen Management: Handle transitions and organize application states with ease. Asset Loading: Built-in support for PixiJS AssetPack, making asset management effortless. Audio Playback: Leverage PixiJS Sound for modern WebAudio API features. Responsive Design: Automatic resize handling for various screen sizes. Simple UI: Includes a basic UI library for common UI elements. Animation Tools: Includes preconfigured support for libraries like Spine for skeletal animations and Motion for smooth tweening and transitions. Creation Templates are perfect for developers who want to hit the ground running with a robust foundation, enabling them to focus on building amazing content rather than worrying about setup.","s":"What’s Included?","u":"/blog/create-cli","h":"#whats-included-1","p":777},{"i":790,"t":"For the creation templates we’re starting with support for general web-based applications but are planning to expand the template ecosystem to other platforms soon: Web Template: A general-purpose creation template (available now). Coming Soon: Discord Template: Build multiplayer applications for Discord using their SDK. Facebook Template: Create apps for Facebook Instant Games. YouTube Template: Develop YouTube Playables.","s":"🌍 Creation Templates for Every Platform","u":"/blog/create-cli","h":"#-creation-templates-for-every-platform","p":777},{"i":792,"t":"This project is based on amazing create-vite tool and inspired by the create-game project by Phaser. We are grateful for their work and the inspiration it provided.","s":"Acknowledgements","u":"/blog/create-cli","h":"#acknowledgements","p":777},{"i":794,"t":"Follow Zyie and PixiJS on social media for the latest updates. Join our vibrant community on Discord for real-time discussions and support.","s":"🌐 Stay Connected","u":"/blog/create-cli","h":"#-stay-connected","p":777},{"i":796,"t":"We have exciting news for all animation enthusiasts and game developers! The Spine team has just smashed it out of the park with the release of Spine 4.2, which includes some truly great new features. The best part for us PixiJS users? We can start leveraging these remarkable features today in both v7 and v8! For those unfamiliar, Spine is the standard for creating stunning 2D animations. It offers an intuitive editor and a multitude of runtimes to ensure that your animations can be utilized across various platforms. PixiJS has supported Spine for almost as long as both have existed (around 10 years)! Personally, we have been shipping games with Spine for about that long as well. Initially, we maintained our own player. This worked well, but as Spine evolved and new releases were introduced, we had to invest considerable time and energy to modify our custom player. In the past year, the Esoteric team has been managing the v7 version of the player after PixiJS's elementalcode made the initial implementation on top of their excellent HTML5 runtime. This means that as these incredible updates are released, the PixiJS community can use them almost immediately! Here are a few of the exciting new features:","s":"PixiJS Joins the Spine 4.2 Physics Revolution! πŸš€","u":"/blog/pixi-js-hearts-spine","h":"","p":795},{"i":798,"t":"Spine 4.2 revolutionizes animation with built-in physics, allowing bones to move naturally by simulating real-world physics. This means: Automatic Secondary Motion: Save time and enhance your animations with automated movement for hair, clothing, and more. Dynamic Movement: Enjoy fluid and realistic physics that respond to character movements and animations.","s":"πŸ‹οΈβ€β™‚οΈ Physics in Spine","u":"/blog/pixi-js-hearts-spine","h":"#️️-physics-in-spine","p":795},{"i":800,"t":"You can now attach any PixiJS Container to a slot in your animation with a simple-to-use API. addSlotObject(slotName, object) removeSlotObject(slotName) getSlotObject(slotName)","s":"πŸ“Ž Attachments","u":"/blog/pixi-js-hearts-spine","h":"#-attachments","p":795},{"i":802,"t":"We have not forgotten about v8! Just as we engineered v8 with the goal of being the fastest WebGPU (and WebGL!) renderer available, we applied this same focus to the v8 implementation of Spine. Here are some impressive statistics: 50% Faster: Enjoy significant performance improvements, making it over 50% faster than the previous v7 version. 50% Less Memory: We've optimized memory usage, reducing it by over 50% compared to the current v7 version. We are proud to say that this is one of if not the fastest way to render Spine animations on the web πŸ†. Get ready to create smooth, high-performance animations with ease. We plan on handing this implementation back over to the Spine team once we have dotted all the i's and crossed the t's. The last missing feature is the dark-tint property, which is not currently taken into account when rendering in v8. Other than that, all other features are present. If you are not using dark-tint, then this version will work great on v8; we are already using it in production for our games! We included all the examples in the repo for you to play with here. You can also check out the live v8 examples here","s":"🏎️ v8 Spine Player Beta","u":"/blog/pixi-js-hearts-spine","h":"#️-v8-spine-player-beta","p":795},{"i":804,"t":"Follow Doormat23 and PixiJS on social media for the latest updates. Join our vibrant community on Discord for real-time discussions and support.","s":"πŸ“² Stay Connected","u":"/blog/pixi-js-hearts-spine","h":"#-stay-connected","p":795},{"i":806,"t":"We are excited to announce the launch of the PixiJS Universe, an initiative to further enhance the capabilities of PixiJS and make it even easier for developers to create amazing games and apps. For years, PixiJS has been the most popular 2D renderer for the web, but it was always \"just a rendering engine.\" The community has created many great tools to help developers build games and applications with PixiJS, but we lacked the manpower to maintain and improve these tools, causing fragmentation in the community. To address this, Playco has assembled a dedicated team of developers who will work on PixiJS full-time. Over the next 12 months, we have more than ten projects planned, and in this announcement, we would like to introduce some of them.","s":"Introducing the PixiJS Universe!","u":"/blog/pixi-universe","h":"","p":805},{"i":808,"t":"We have several new projects in the works, and we are releasing them in four phases over the year. We are currently nearing the end of phase 1, which has seen the release of several exciting new tools and libraries for PixiJS:","s":"Phase 1​","u":"/blog/pixi-universe","h":"#phase-1","p":805},{"i":810,"t":"First up we are excited to announce that we will be releasing a beta version of our new website for PixiJS. The current documentation has suffered from long-term organic growth over the years with little structure and as such much of the PixiJS documentation is fragmented across multiple sites. This new website will put everything you need in one place and be easily searchable. We are also planning on improving the documentation and adding more guides and examples, as well as considering translating the documentation into other languages. If you have any ideas on how to improve the site please let us know! Github Repo","s":"PixiJS Website​","u":"/blog/pixi-universe","h":"#pixijs-website","p":805},{"i":812,"t":"Next up is PixiJS React. A library that provides a way to use PixiJS in React applications. PixiJS React is a continuation of the react-pixi library created by Patrick Brouwer, which has been widely used by the PixiJS community in React projects. PixiJS has taken over maintenance of the library and is dedicated to improving the library's performance, documentation, and support for new features. The library provides an easy-to-use interface that makes it easy for developers to create React applications with PixiJS. The library integrates all the core features of PixiJS and allows you to create custom components for 3rd party libraries. Github Repo","s":"PixiJS React​","u":"/blog/pixi-universe","h":"#pixijs-react","p":805},{"i":814,"t":"We have now released a new repository called \"PixiJS Open Games\". This is a collection of open-source games that showcases how to use PixiJS to create games and is released under the MIT license. The purpose of these games is to provide professional examples of how to use PixiJS for game development. The first two games released are a match-3 game and a bubble shooter game. These games not only demonstrate how to use PixiJS for game development but also how to use other libraries such as PixiJS UI and AssetPack. We also have more games planned for release, which will demonstrate how to use PixiJS with other libraries such as PixiJS Layout and PixiJS React. PixiJS Open Games will hopefully be a valuable resource for game developers who want to learn how to use PixiJS for game development and will also be a great source of inspiration for developers looking to create their own games using PixiJS. The project is available on GitHub for anyone who wants to explore the code or contribute to the project. Github Repo Play Puzzling Potions Play Bubbo Bubbo","s":"PixiJS Open Games​","u":"/blog/pixi-universe","h":"#pixijs-open-games","p":805},{"i":816,"t":"PixiJS UI is a new library for developers who want to create beautiful and functional user interfaces with PixiJS. The library includes a range of components such as buttons, checkboxes, sliders, text inputs, scroll views, lists, radio buttons, and progress bars, which can be easily integrated into your game. These components are highly customizable, allowing you to tweak the appearance and behaviour of each element to fit your game's specific needs. PixiJS UI has been used in all of the open-source games, so feel free to check these out for real-world examples. PixiJS UI Github Repo PixiJS Layout is another library that can make your life as a developer easier. This library enables you to create responsive layouts using PixiJS, which means you can design interfaces that adapt to different screen sizes and aspect ratios. PixiJS Layout works well with PixiJS UI, allowing you to combine both libraries to create complex, dynamic interfaces that respond to user input and screen changes. With PixiJS Layout, you have the flexibility to create resizable layouts that can be adjusted to fit any screen size or device. This means that your game's interface can look great on everything from small mobile devices to large desktop displays. PixiJS Layout is still under development but will be ready in the next few weeks PixiJS Layout Github Repo","s":"PixiJS UI & PixiJS Layout​","u":"/blog/pixi-universe","h":"#pixijs-ui--pixijs-layout","p":805},{"i":818,"t":"Finally, for phase 1 we are announcing AssetPack. Asset management is an important part of developing applications, and the new AssetPack library aims to make this process easier. AssetPack is a framework-agnostic library that can be used with any framework, including PixiJS, ThreeJS, and Phaser. It provides a range of features that help developers manage their assets efficiently. The key feature of AssetPack is the ability to automatically generate new assets on the fly. For example, you can provide it with a folder of individual images and it will generate sprite sheets, which can significantly improve the performance of your application. It also provides plugins to generate mipmaps, convert fonts to different formats, convert audio to different formats, compress images, and minify JSON. These features help developers optimize their assets for faster loading times, better performance, and improved user experience. We will soon be releasing a new blog post that provides more details on how to use it. With its many useful features and framework-agnostic design. However, if you want to get stuck in today then check out the GitHub repo Github Repo","s":"AssetPack​","u":"/blog/pixi-universe","h":"#assetpack","p":805},{"i":820,"t":"Phase 2 will begin shortly and aims to make it easier to work with PixiJS applications.","s":"Phase 2​","u":"/blog/pixi-universe","h":"#phase-2","p":805},{"i":822,"t":"Jumpstart is a new CLI tool being developed by the PixiJS team to simplify the process of creating new PixiJS applications. With this tool, developers will no longer need to set up complicated tooling or worry about setting up different bundlers and frameworks. The tool will handle all the setup for you, allowing you to focus on building your application. Jumpstart will be similar to other CLI tools such as Create-React-App or Create-Vue, which have become popular in the front-end development community. The tool will provide templates for different bundlers and frameworks, including webpack, parcel, rollup, and more. This will make it easy for developers to get started with PixiJS regardless of their preferred tools and workflows. With Jumpstart, you'll be able to create a new PixiJS application in just a few minutes and start building right away.","s":"PixiJS JumpStart​","u":"/blog/pixi-universe","h":"#pixijs-jumpstart","p":805},{"i":824,"t":"PixiJS dev tools will be a browser extension that is planned to be released soon to help developers debug their PixiJS applications. This tool aims to make it easier for developers to understand the inner workings of PixiJS, optimize their code, and follow best practices. It is designed to help developers diagnose performance issues and visualize the resources that their applications are consuming. One of the key features of the PixiJS Dev Tools is its ability to help developers understand the complex process of batching in PixiJS. Batching is a technique used to optimize the rendering of multiple objects in the same draw call. This process can be complicated to understand, especially for new developers. PixiJS Dev Tools aims to make it easier to debug and optimize the rendering of objects. Overall, PixiJS Dev Tools will be a powerful tool that will make it easier for developers to build high-performance, visually stunning applications with PixiJS. By providing developers with a deeper understanding of the inner workings of PixiJS, this toolset will help developers optimize their code and create more efficient and engaging applications.","s":"PixiJS Dev Tools​","u":"/blog/pixi-universe","h":"#pixijs-dev-tools","p":805},{"i":826,"t":"Phase 3 is where our long-term projects start to be revealed. These are major changes to the PixiJS ecosystem that we are incredibly excited about","s":"Phase 3​","u":"/blog/pixi-universe","h":"#phase-3","p":805},{"i":828,"t":"Comet will be a new editor that aims to make it easier than ever to design and create games and applications with PixiJS. With its intuitive and user-friendly interface, the editor is designed to appeal to both designers and developers, allowing both groups to collaborate and work more efficiently. One of the standout features of Comet is the visual interface it provides for creating and editing scenes, sprites, animations, and more. This means that designers can create and edit complex scenes without ever having to write a single line of code. The editor provides a range of tools and options for creating sprites, animations, and other game elements, making it easy to get started with creating a game or application. In addition, developers will appreciate the runtime player feature, which allows them to easily recreate scenes in their own applications. This makes it easy to test and iterate on designs, ensuring that the final product is both functional and visually appealing. And with multi-user, real-time collaboration, Comet makes it easy for teams to work together, sharing assets and ideas and creating high-quality games and applications in record time.","s":"Comet​","u":"/blog/pixi-universe","h":"#comet","p":805},{"i":830,"t":"PixiJS v8 will be the next major release that represents a complete rewrite of PixiJS from the ground up. The development team has leveraged their extensive experience over many years to make improvements and optimizations to the core PixiJS engine. The new version of PixiJS is designed to be faster and more efficient, providing a significant improvement in rendering performance compared to v7 (currently sitting at x2) One of the most exciting features of PixiJS v8 is the inclusion of first-class support for WebGPU, which is a new graphics API that is being developed by major browser vendors. This will enable developers to take advantage of advanced GPU capabilities, which can significantly improve the performance of graphics-intensive applications. In addition to WebGPU support, the PixiJS team has also made a significant effort to optimize the engine for the canvas renderer, which will be available as a first-class option for developers looking to reduce bundle size. Overall, PixiJS v8 represents a major leap forward for us, developers can expect a much faster and more efficient engine that is better suited for building complex, graphics-intensive applications.","s":"PixiJS v8​","u":"/blog/pixi-universe","h":"#pixijs-v8","p":805},{"i":832,"t":"Phase 4 represents a leap into new territory for PixiJS as we look to delve deeper into areas outside of strictly 2D rendering.","s":"Phase 4​","u":"/blog/pixi-universe","h":"#phase-4","p":805},{"i":834,"t":"For years, Goodboy (now Playco) has had an internal 3D engine called Odie that was built on top of PixiJS. We are now planning to open-source it, which is exciting for those of you who want to seamlessly mix 2D and 3D content in your games or applications. With PixiJS 3D, you will no longer need to switch between engines or frameworks to incorporate 3D elements in your project. Although this is a long-term project, the team is making progress and plans to share more information later in the year. This release will greatly expand PixiJS's capabilities and give developers even more flexibility when building their applications.","s":"PixiJS 3D​","u":"/blog/pixi-universe","h":"#pixijs-3d","p":805},{"i":836,"t":"Finally, we are thrilled to announce that we will be working on a new library called PixiJS Game Engine. This game engine aims to provide everything you would expect from a 2D/3D game engine and will offer many features and tools to make game development easier and more efficient. Some of the features of PixiJS Game Engine will include support for physics engines, audio, input handling, asset loading and management, state management, animation and tweening, and more.","s":"PixiJS Game Engine​","u":"/blog/pixi-universe","h":"#pixijs-game-engine","p":805},{"i":838,"t":"We've shared a lot of exciting news about new projects and updates coming to the PixiJS community. There's a lot to look forward to in the upcoming months. We want to extend our sincere thanks to the PixiJS community, its contributors, and Playco for making all of this possible. We're excited to see what you'll create with these new tools and resources, and we look forward to continuing to support and grow the PixiJS ecosystem. Be sure to check out the GitHub links mentioned above and stay tuned for more updates on the PixiJS Universe!","s":"Conclusion","u":"/blog/pixi-universe","h":"#conclusion","p":805},{"i":840,"t":"PixiJS v8 has taken speed to the next level with the release of its new ParticleContainer. This new feature brings a jaw-dropping performance boost, capable of rendering 100K+ without breaking a sweat. If you’ve got tons of elements to throw on the screen, you’re in for a treat!","s":"ParticleContainer - The New Speed Demon in PixiJS v8","u":"/blog/particlecontainer-v8","h":"","p":839},{"i":842,"t":"The key difference in PixiJS v8 is that the ParticleContainer doesn’t deal with sprites any more, it works with lightweight particles. While particles share many properties with sprites (like texture, position, anchor, scale, rotation, alpha and color), they cut out unnecessary overhead. The result is speed, pure and simple. How fast, you ask? Well, take a look on my machine (Macbook Pro M3): Sprites + Container: 200,000 at 60fps. Particles + ParticleContainer: 1,000,000 at 60fps! Yes, that’s a million bunnies on-screen, and honestly the main bottleneck at that point wasn’t even rendering but the logic behind the bouncing movement! Give this a spin and see for yourself: The key takeaway is that you can now render huge volumes of elements absurdly fast, making PixiJS v8 a perfect choice for high-performance games or visually intensive projects. And yes this is faster than the v7 particle container by over 3x! Please checkout the migration guide for more information on how to migrate your code to the new particle container.","s":"πŸš€ New ParticleContainer Design","u":"/blog/particlecontainer-v8","h":"#-new-particlecontainer-design","p":839},{"i":844,"t":"To get the most out of this performance beast, it’s essential to understand static vs. dynamic properties. PixiJS gives you full control over which properties update every frame (dynamic) and which don’t need constant updates (static). Here’s how they work: Static properties: Once set, they stay the same unless explicitly changed. By keeping them static, you reduce computational load, meaning faster rendering. This is your responsibility to update :) Dynamic properties: These are recalculated and uploaded to the GPU every frame regardless. By default, only the position is dynamic, but you can configure others if needed. The fewer dynamic properties you have, the faster the rendering will be!","s":"Speed Secret: Static vs. Dynamic Properties","u":"/blog/particlecontainer-v8","h":"#speed-secret-static-vs-dynamic-properties","p":839},{"i":846,"t":"Let’s walk through a simple example of how to get started: import { ParticleContainer, Particle, Texture } from 'pixi.js'; // Create a particle container with default options const container = new ParticleContainer({ // this is the default, but we show it here for clarity dynamicProperties: { position: true, // Allow dynamic position changes (default) scale: false, // Static scale for extra performance rotation: false, // Static rotation color: false // Static color } }); // Add particles const texture = Texture.from('path/to/bunny.png'); for (let i = 0; i < 100000; ++i) { let particle = new Particle({ texture, x: Math.random() * 800, y: Math.random() * 600, }); container.addParticle(particle); } // Add container to the Pixi stage app.stage.addChild(container); In this example, we create a ParticleContainer, set properties to static where possible, and generate a 100k particles. By using a shared texture (hello, sprite sheets!), we ensure that all particles share the same graphical assets, making rendering even more efficient.","s":"PixiJS v8 Particle Container Usage","u":"/blog/particlecontainer-v8","h":"#pixijs-v8-particle-container-usage","p":839},{"i":848,"t":"The ParticleContainer shines when you need insane numbers of visual elements on-screen, especially when you want them moving and interacting in real time. Whether you're building particle effects, swarms of characters, or abstract art installations, PixiJS v8 has you covered. The static vs. dynamic property system gives you granular control over performance, allowing you to fine-tune the balance between flexibility and speed. This is basically the fastest we could make it by still keeping allowing for different textures (via sprite sheets) and still empowering devs to manipulate the particles via JS and not having to move the movement to the GPU (which might be faster, but is more complex and less flexible). So even though we are choosing to call them particles, they are more like something in between a traditional particle and a classic sprite. This is ideal for projects where frame rate and rendering volume matterβ€”such as games, interactive apps, and high-volume data visualization. By controlling the dynamic properties of your particles, you can optimize your application’s performance to fit your needs.","s":"Reasons to Use ParticleContainer","u":"/blog/particlecontainer-v8","h":"#reasons-to-use-particlecontainer","p":839},{"i":850,"t":"The new ParticleContainer is a game-changer, but there are still some areas for improvement! For one, there is room to optimise further the static uploading of properties (you may notice the example above is slower when adding bunnys - but then speeds up once stable). We plan to expose how the particles are batched so that developers can add / remove attributes from the batch to make it even faster or add more flexibility and customization. But for now, this is a great starting point and we hope you enjoy the new ParticleContainer!","s":"Next Steps","u":"/blog/particlecontainer-v8","h":"#next-steps","p":839},{"i":852,"t":"PixiJS v8’s ParticleContainer is a game-changer when it comes to rendering at scale. Its ability to push millions of particles at full speed opens up a world of possibilities for game developers, animators, and creative coders. Get in, experiment with the new API, and see just how fast your visuals can fly! Ready to give it a spin? Try out the new ParticleContainer in PixiJS v8, and push the limits of performance in your projects!","s":"πŸŽ‰ Conclusion","u":"/blog/particlecontainer-v8","h":"#-conclusion","p":839},{"i":854,"t":"Follow Doormat23 and PixiJS on social media for the latest updates. Join our vibrant community on Discord for real-time discussions and support.","s":"🌐 Stay Connected","u":"/blog/particlecontainer-v8","h":"#-stay-connected","p":839},{"i":856,"t":"We're thrilled to offer an exclusive preview of the future of 2D web graphics with the Beta release of PixiJS v8. Although not yet finalized, this Beta iteration is packed with killer performance improvements and features we're eager for you to start playing with! Over the course of a decadeβ€”yes, you read that right, ten years!β€”we've implemented significant changes to the PixiJS engine. But the advancements in this new release are among the most monumental we've ever made! Two driving factors catalysed our approach to re-engineering the codebase and rendering pipeline in v8:","s":"PixiJS v8 Beta! πŸŽ‰","u":"/blog/pixi-v8-beta","h":"","p":855},{"i":858,"t":"The newcomer WebGPU offers a substantial performance improvement over its predecessor, WebGL. It propels web computations and graphics into a new era, providing a more efficient and robust API. Soon, it will be the go-to method for rendering most GPU-powered content on the web. This shift is reminiscent of PixiJS's initial launch. At that time, WebGL was new and only available in a handful of desktop browsers, while Canvas was ubiquitous. PixiJS's standout feature was its ability to first attempt rendering with WebGL and then fall back to Canvas as a Plan B. This approach allowed PixiJS content to immediately benefit as WebGL gained traction. Fast forward to today, and WebGL is now available on 95% of browsers. History is repeating itself with WebGPU, currently supported in only a few desktop browsers and roughly 27% of the market. However, it's only a matter of time before it becomes universally supported. PixiJS aims to execute the same fallback strategy, allowing you to always leverage the best technology available without needing to rewrite your code. This is precisely what version 8 achieves and will future proof everything we make for another ten years :D","s":"1. 😍 Embracing WebGPU","u":"/blog/pixi-v8-beta","h":"#1--embracing-webgpu","p":855},{"i":860,"t":"PixiJS has always been synonymous with speed and high-performance graphics. With v8, we've revisited our architecture to optimize both static and dynamic rendering. While v7 is fast, it operates as a somewhat β€˜naΓ―ve’ renderer. v7 approach:​ Traverse the scene graph and make sure all the transforms are correct Traverse the scene graph a second time and do the following Build batches to render Upload the data to the GPU Draw the batch to the screen. v8 approach​ Update the transform of only things that changed Traverse the scene graph and construct a set of instructions. Upload all scene data to GPU in one go. Execute rendering based on the instructions. There are three key changes to this loop that give us a performance bump. First, we update only the elements that have changed. If nothing has moved, no code is executed, optimizing computational overhead. Second, if the scene graph remains unchanged in subsequent frames, we reuse the existing rendering instructions. This avoids the overhead of reconstructing these instructions for each frame. Third, if no elements in the scene change position, the data upload step (Step 3) is entirely skipped, thereby saving bandwidth and further reducing computational work. The net effect of these improvements? A decent performance leap across varying use-cases: CPU = time spent by the cpu rendering a single frame GPU = time spend by the gpu rendering a single frame Bunny Situation V7 CPU V8 CPU CPU Dif V7 GPU V8 GPU GPU dif 100k sprites all moving ~50ms ~15ms 233% ~9ms ~2ms 350% 100k sprites not moving ~21ms ~0.12ms 17417% ~9ms ~0.5ms 1700% 100k sprites (changing scene structure) ~50ms ~24ms 108% ~9ms ~2ms 350% These benchmark numbers are based on this Bunnymark test that you can try yourself! v7 Bunnymark v8 Bunnymark - WebGPU v8 Bunnymark - WebGL Repo Please have a play, you can fiddle with the parameters in the url to change the number of bunnies. Curious to see what numbers all of you get! Best of all, these improvements apply to WebGPU and the WebGL renderer. As with all of PixiJs’s party tricks, this all happens automatically :D","s":"2. πŸš€ Turbocharging Performance","u":"/blog/pixi-v8-beta","h":"#2--turbocharging-performance","p":855},{"i":862,"t":"While the two key drivers behind this overhaul were performance and usability, we didn't stop there. We've seized this opportunity to enhance the API and introduce a plethora of new features to the engineβ€”far too many to encapsulate in a single post! Stay tuned for upcoming blog posts where we'll delve deeper into these additional improvements and API refinements, empowering you to create even more remarkable projects. For a comprehensive overview of what's new, don't miss the release notes. As a crucial note, PixiJS v8 retains much of the familiar API despite undergoing significant internal updates. Our changes are geared toward making PixiJS more robust and user-friendly. When you encounter modifications, rest assured that the v7 methodology will continue to workβ€”you'll simply see a deprecation warning, guiding you towards optimal practices.","s":"But Wait, There's More!","u":"/blog/pixi-v8-beta","h":"#but-wait-theres-more","p":855},{"i":864,"t":"As we progress toward the release candidate, now is the perfect time for you to dive in and explore v8. Your feedback at this stage is invaluable for fine-tuning our engine. We invite you to share your thoughtsβ€”the good, the bad, and the uglyβ€”report bugs, and even contribute code. Together, we can elevate PixiJS to unprecedented heights. πŸ‘‡ Don't waitβ€”dive right in! Explore the PixiJS v8 Codebase on GitHub","s":"Over to you!","u":"/blog/pixi-v8-beta","h":"#over-to-you","p":855},{"i":866,"t":"via npm you can install the beta version like so: npm install pixi.js@prerelease-v8 then you can create the most appropriate renderer using the new autoDetectRenderer function: import { autoDetectRenderer } from \"pixi.js\"; async function init() { const renderer = await autoDetectRenderer({ // any settings }); // will return a WebGL or WebGPU renderer } Start experimenting with PixiJS v8 Beta today and join us in shaping the future of 2D web graphics! πŸŽ‰","s":"Steps to install:","u":"/blog/pixi-v8-beta","h":"#steps-to-install","p":855},{"i":868,"t":"\"To stay in the loop, we invite you to follow Doormat23 and PixiJS on social media, where we'll be unveiling more exciting updates shortly. Alternatively, you can join our vibrant community on Discord for direct engagement and real-time conversations.","s":"Keep in touch!","u":"/blog/pixi-v8-beta","h":"#keep-in-touch","p":855},{"i":870,"t":"Get ready to push the boundaries of what's possible on the web! PixiJS v8 has landed, and it's a game-changer. Celebrating a decade of driving innovation, we've supercharged PixiJS with the latest technological advancements, making it faster, more robust, and ridiculously powerful. From the seamless integration of WebGPU to leveraging modern JavaScript for smoother development, PixiJS v8 is all about empowering you to create jaw-dropping web experiences with ease. It's not just an update; it's the future of 2D web graphics, today. Dive in and let PixiJS v8 elevate your projects to unseen heights. Let's make the web a more beautiful place, one pixi(el) at a time.","s":"PixiJS v8 Launches! πŸŽ‰","u":"/blog/pixi-v8-launches","h":"","p":869},{"i":872,"t":"It's hard to believe that PixiJS has been part of the open-source community for a whopping ten years. In that time, the digital landscape has evolved tremendously, and so has PixiJS. We've seen significant updates, like the transition to TypeScript, and we've overhauled major parts of the engine, such as asset loading and WebGL integration. Now, we're thrilled to unveil PixiJS v8, arguably our most substantial update ever. This release is not just a reflection on the shortcomings of v7, which has served us well, but an acknowledgment that there's always room for improvement. Over time, we've all encountered aspects of our code we wished we could refine. Often, the best solutions and insights emerge only after we've stepped back from the problem, allowing us to see the bigger picture. With PixiJS v8, our aim was to revisit and enhance the foundation of PixiJS, streamlining its core rather than just adding layers of code. Our vision for v8 was clear: Longevity: We designed v8 to stand the test of time, anticipating it will remain relevant and robust for another decade. Innovation with WebGPU: Embracing the latest in rendering technology, we've seamlessly integrated WebGPU, not as an add-on to our existing WebGL renderer but as a core paradigm, ensuring PixiJS remains at the cutting edge as WebGL phases out. Leveraging Modern JavaScript: The advancements in JavaScript have significantly simplified development. We've utilized features like object destructuring and options to make v8 cleaner and more powerful. Correcting Past Oversights: Every project has its lessons. With v8, we've addressed and rearchitected certain aspects of PixiJS, reducing complexity and enhancing functionality, particularly in areas we felt were overengineered in the past (looking at you, textures!). Boosting Performance: PixiJS is already renowned for its speed. With v8, we've unlocked even greater performance, making it faster across the board compared to v7. We're incredibly proud of PixiJS v8 and eager to share the improvements and new features with you. While there are some breaking API changes, we've provided a migration guide and ensured compatibility with v7 wherever possible. Get ready to experience the next level of 2D rendering with PixiJS v8!","s":"πŸš€ Revolutionizing Web Graphics: Welcome to PixiJS v8","u":"/blog/pixi-v8-launches","h":"#-revolutionizing-web-graphics-welcome-to-pixijs-v8","p":869},{"i":874,"t":"The new Docs for v8 can be found here Migration Examples Open Games","s":"πŸ”— Quick links","u":"/blog/pixi-v8-launches","h":"#-quick-links","p":869},{"i":876,"t":"There are numerous updates to discuss, more than can be covered in a single post! Below are the key highlights. For a more detailed exploration of these changes, be sure to follow the links provided above. πŸ“ˆ New Performance Bar​ The performance of v8 is faster for both renderers. This means by using v8 and the WebGL renderer, all the speed improvements apply! This is mainly as we have taken great care to make a more reactive render loop that only updates what it needs to. Check out the numbers here: CPU = time spent by the CPU rendering a single frame GPU = time spent by the GPU rendering a single frame Bunny Situation V7 CPU V8 CPU CPU Dif V7 GPU V8 GPU GPU dif 100k sprites all moving ~50ms ~15ms 233% ~9ms ~2ms 350% 100k sprites not moving ~21ms ~0.12ms 17417% ~9ms ~0.5ms 1700% 100k sprites (changing scene structure) ~50ms ~24ms 108% ~9ms ~2ms 350% These benchmark numbers are based on the Bunnymark test that you can try yourself. v7 Bunnymark v8 Bunnymark - WebGPU v8 Bunnymark - WebGL Repo πŸ–₯️ WebGPU Renderer​ We've implemented a WebGPU backend for rendering. Whilst this has created a better graphics paradigm under the hood and set us up for the future of rich web content, it's important to note that WebGPU does not automatically guarantee improved performance over WebGL in all scenarios, as PixiJS often encounters more limitations on the CPU side than the GPU. However, for scenes with numerous batch breaks, such as filters, masks, and blend modes, WebGPU may offer better performance due to its more modern to rendering. As WebGPU is relatively new, it's expected to enhance in speed over time, similar to the development of WebGL. It serves as a solid foundation for future advancements. πŸ“¦ New Package Structure​ No more \"lerna.\" PixiJS is now just one package with one import root: import {stuff} from β€˜pixi.js’. This change means we now have much better tree shaking during app compilation, reducing bundle size if not imported. Old: import { Sprite } from \"@pixi/sprite\"; import { Graphic } from \"@pixi/graphics\"; New: import { Sprite, Graphic } from \"pixi.js\";","s":"🎁 Whats New?","u":"/blog/pixi-v8-launches","h":"#-whats-new","p":869},{"i":878,"t":"When initializing a renderer, this process is now asynchronous. This serves two purposes: firstly, identifying and loading the necessary renderer code to minimize what is loaded for your users. We only load the one backend that your user is using. There's no point in loading all the WebGL stuff if they are using WebGPU. Secondly, the initialization of WebGPU itself is an asynchronous process, so we need to have a promise in there somewhere! import { Application, autoDetectRenderer } from \"pixi.js\"; const app = new Application(); (async () => { await app.init({ // application options }); // or const renderer = await autoDetectRenderer({}); // WebGL or WebGPU // do pixi things })(); 🌟 Scene Upgrades​ The concept of render groups has been introduced, enabling containers to utilize GPU for their transformations. This facilitates a true 2D hardware-accelerated camera, ideal for navigating large static worlds through panning and zooming, similar to how a camera moves in a 3D environment rather than moving the world itself. This approach can significantly enhance performance. const container = new Container({ isRenderGroup:true // this containers transform is now handled on the GPU! }) Another cool new change is that now blend modes and tints are inherited, much like transforms and alpha. This means you can now easily tint a container, and all its children will have the tint applied - same for blend modes, its as easy as: // will make all the children tinted red container.tint = 'red' // will make all the children have the add blend mode container.blendMode = 'add' Rendering to a texture with antialiasing has been simplified; you only need to enable the new antialiasing property by setting it to true during the creation of a render texture or when applying a filter, similar to the process used for creating your renderer. const texture = RenderTexture.create({ width:100, height:100, antialias:true // easy as that }) We have also added support for a wide range of Photoshop-like filters, This allows you to take your rendering to the next level! We have including all the classics: ColorBlend, ColorBurnBlend, ColorDodgeBlend, DarkenBlend, DifferenceBlend, DivideBlend, ExclusionBlend, HardLightBlend, HardMixBlend, LightenBlend, LinearBurnBlend, LinearDodgeBlend, LinearLightBlend, LuminosityBlend, NegationBlend, OverlayBlend, PinLightBlend, SaturationBlend, SoftLightBlend, SubtractBlend, VividLightBlend. It's important to mention that these are essentially filters at the core, so it's advisable not to overuse them to avoid potential slowdowns. import `pixi.js/advanced-blend-modes` // make sure to include them in you lib! (or cherry pick one!) myContainer.blendMode = 'color-burn` // easy! 🎨 Graphics Upgrades​ The Graphics API has undergone changes to become more intuitive and user-friendly, closely resembling the HTML Canvas 2D context API. For instance, drawing and filling a rectangle is simplified as follows: graphics .rect(50, 50, 100, 100) .fill('blue'); A GraphicsContext has been introduced, powering all graphics operations. Similar to how one texture can be used across many sprites, a single GraphicsContext can now be utilized by multiple Graphics objects, enhancing efficiency and flexibility. Support for SVG drawing has been added. For example: graphics.svg('M 100 350 q 150 -300 300 0'); Gradient fill support has been introduced, currently limited to linear gradients, allowing for more visually engaging designs. The new GraphicsPath class enables the drawing and sharing of shapes. This feature is particularly useful as it allows for the creation of paths that can then be transformed into Mesh geometry using the buildGeometryFromPath function, opening up new possibilities for intricate and detailed graphic designs. const path = new GraphicsPath() .rect(-50, -50, 100, 100) // create geometry from the path: const geometry = buildGeometryFromPath({ path, }); const mesh = new Mesh({ geometry, texture: Texture.WHITE, }); For more information on these graphics upgrades and guidance on how to adapt to the enhanced Graphics API, please refer to the migration guide, or why not jump in and play with some examples. πŸ“ Text Upgrades​ Text has been upgraded to allow for better performance and usability! We have also integrated HTMLText into v8 as standard. BitmapFonts can now be generated on the fly or installed upfront as you prefer. They dynamically add characters as the font's glyphs are required, saving on memory. The layout of bitmap text is almost identical to the layout of the default text now, making it easier to switch between the two depending on your needs. const myText = new BitmapText({ text: 'hello im a bitmap font!', // font will be dynamically created style:{ fontFamily: 'Outfit', fontSize: 12, fill: 'red', } }) Text fills and strokes now conform to the same fills and strokes as graphics. This means Gradients, textures, and all the fun ways you can fill and stroke graphics can now be applied to Text. const myText = new Text({ text: 'hello im some fancy text', // font will be dynamically created! style:{ fontFamily: 'Outfit', fontSize: 12, fill: { texture, color:'red'} // same as graphics api fills stroke: { width:3, color:'blue' } // same as graphics api strokes } })","s":"✨ We promise the Renderer will work","u":"/blog/pixi-v8-launches","h":"#-we-promise-the-renderer-will-work","p":869},{"i":880,"t":"As PixiJS v8 takes its first steps into the world, we're eager to see it grow with your feedback and contributions. Now we know things won't be perfect, but we're committed to quick responses on GitHub and Discord to any issues that arise, valuing your input to make PixiJS even better. A heartfelt thanks to our early adopters (everyone in here) for testing the limits of v8, to our dedicated contributors and team for their hard work. Your efforts and insights are invaluable to us. We could not have gotten here without you! A final big shout-out to PlayCo for their support in making this release a reality! Let's continue to innovate and push the boundaries of web graphics together. Your engagement is key to PixiJS's evolution, and we're excited to see where we can go with your help.","s":"🀝 What now? Get involved!","u":"/blog/pixi-v8-launches","h":"#-what-now-get-involved","p":869},{"i":882,"t":"To stay in the loop, we invite you to follow Doormat23 and PixiJS on social media, where we'll be unveiling more exciting updates shortly. Alternatively, you can join our vibrant community on Discord for direct engagement and real-time chit-chats.","s":"πŸ“² Keep in touch","u":"/blog/pixi-v8-launches","h":"#-keep-in-touch","p":869}],"index":{"version":"2.3.9","fields":["t"],"fieldVectors":[["t/740",[0,2.456,1,4.204,2,2.456,3,3.011,4,2.8,5,4.204,6,2.8,7,2.2,8,3.65,9,2.321,10,2.434,11,2.319,12,2.456,13,2.091,14,3.65,15,3.65,16,3.321,17,3.65,18,2.456,19,3.65,20,3.284,21,1.818,22,2.793,23,3.284,24,4.204,25,2.612,26,3.284,27,3.011,28,3.284,29,3.65,30,3.011,31,0.933,32,2.321,33,1.216,34,3.65,35,3.65,36,4.204,37,2.793,38,3.65,39,3.011,40,2.33,41,2.945,42,3.284,43,4.204,44,2.612,45,4.204,46,3.284,47,4.204,48,3.65,49,1.668,50,1.992,51,3.284,52,4.204]],["t/742",[4,2.842,6,2.842,7,1.504,8,2.496,9,1.587,10,1.243,16,2.249,22,1.91,23,4.022,25,1.786,26,4.463,28,2.246,40,1.19,53,1.786,54,2.875,55,2.875,56,3.732,57,2.496,58,2.671,59,1.68,60,0.18,61,2.875,62,2.246,63,2.496,64,2.875,65,2.496,66,1.786,67,2.059,68,1.945,69,1.11,70,4.778,71,2.875,72,2.496,73,2.875,74,1.91,75,2.496,76,1.051,77,2.496,78,2.246,79,2.875,80,2.875,81,3.079,82,2.875,83,2.875,84,2.875,85,4.299,86,2.875,87,1.786,88,2.246,89,1.43,90,1.43,91,2.875,92,2.875,93,1.859,94,2.875,95,1.68,96,2.875,97,2.875,98,2.875,99,3.079,100,3.358,101,2.246,102,2.875,103,5.149,104,2.875,105,2.875,106,3.732,107,2.059,108,1.68,109,0.898,110,0.864,111,2.246,112,2.875,113,2.875,114,2.875,115,2.496,116,2.856,117,2.875,118,1.786,119,1.786,120,2.875,121,2.875,122,4.299,123,2.496,124,4.299,125,2.875,126,2.875,127,3.732,128,2.875,129,2.059,130,2.875,131,2.875,132,2.875,133,2.875,134,2.496,135,2.875,136,4.299,137,2.875,138,1.68,139,1.504,140,1.91,141,2.875,142,2.059,143,1.91,144,1.504,145,2.496,146,2.496,147,2.496,148,2.059]],["t/744",[4,2.766,6,2.972,7,1.426,10,1.178,13,2.053,16,3.52,17,2.365,19,2.365,26,3.225,27,2.957,30,1.951,31,0.605,32,1.504,33,0.788,39,1.951,46,2.128,53,1.693,67,3.57,68,1.232,69,0.704,72,4.327,87,2.565,89,1.355,90,1.355,110,0.819,111,2.128,146,2.365,149,3.584,150,0.996,151,4.129,152,2.725,153,2.725,154,2.725,155,1.81,156,1.951,157,2.725,158,2.725,159,2.365,160,2.063,161,2.912,162,3.584,163,2.128,164,2.412,165,2.365,166,2.128,167,1.592,168,2.725,169,1.951,170,2.725,171,1.693,172,2.725,173,2.365,174,2.128,175,1.81,176,1.81,177,4.985,178,2.725,179,2.725,180,2.725,181,2.16,182,1.232,183,2.725,184,1.81,185,1.426,186,1.951,187,2.128,188,2.725,189,2.725,190,2.128,191,1.232,192,1.592,193,2.128,194,1.81,195,2.365,196,2.365,197,4.985,198,4.327,199,2.725,200,1.128,201,2.725,202,1.504,203,2.365,204,2.365,205,1.693,206,1.956,207,2.725,208,1.291,209,2.128,210,1.951,211,2.365,212,2.725,213,2.725,214,2.365,215,2.365,216,2.128,217,2.725,218,4.129,219,2.365,220,2.128,221,1.951,222,2.365,223,2.128,224,1.81,225,2.725,226,2.725,227,2.725,228,1.693,229,2.725,230,1.693,231,2.128,232,2.365,233,2.725,234,2.365,235,1.693,236,2.128,237,2.725,238,2.365]],["t/747",[4,3.297,21,2.347,90,2.699,239,6.214,240,5.755,241,5.755,242,3.887,243,4.24,244,4.711,245,4.711,246,3.887,247,5.427,248,5.427,249,5.427,250,3.171,251,4.711,252,5.427,253,5.427]],["t/749",[4,3.117,9,1.93,16,2.594,21,1.512,60,0.311,69,1.28,70,4.896,78,2.732,93,1.512,100,4.5,150,2.753,160,1.448,161,2.043,173,3.036,181,3.279,202,1.93,240,3.036,254,3.366,255,4.958,256,3.497,257,2.466,258,4.304,259,1.93,260,4.958,261,3.036,262,1.739,263,4.958,264,2.732,265,2.173,266,2.173,267,5.761,268,2.323,269,3.497,270,3.497,271,3.497,272,3.497,273,2.835,274,2.505,275,3.497,276,3.497,277,3.497,278,3.497,279,3.294,280,4.304,281,2.173,282,1.657,283,3.497,284,4.958,285,4.958,286,3.551,287,3.497,288,3.551,289,3.497,290,2.732,291,2.505]],["t/751",[4,3.572,6,2.72,7,2.861,12,3.195,76,1.998,144,2.861,200,2.264,273,2.473,292,3.916,293,2.72,294,3.633,295,2.88,296,2.861,297,3.397,298,3.916,299,5.468,300,5.468,301,3.195,302,4.747]],["t/753",[4,3.443,6,2.206,7,2.32,9,2.448,10,2.522,16,2.32,20,3.464,33,1.283,40,2.415,41,2.32,48,3.85,51,3.464,68,2.006,69,1.145,76,1.621,174,3.464,182,2.006,243,3.464,250,2.591,293,2.206,303,3.176,304,2.755,305,2.755,306,4.435,307,4.435,308,2.947,309,2.448,310,2.102,311,3.85,312,3.85,313,4.435,314,2.947,315,2.591,316,3.176,317,4.435,318,3.464,319,4.435,320,3.176,321,2.755,322,3.464,323,3.85,324,3.464,325,3.85,326,0.778,327,1.76,328,4.435,329,2.006,330,4.435]],["t/755",[33,1.669,60,0.361,89,2.871,200,2.389,329,2.611,331,2.871,332,4.509,333,3.372,334,3.372,335,2.29,336,3.186,337,3.372,338,2.389,339,3.835,340,2.29]],["t/757",[18,2.656,60,0.371,176,3.02,292,3.256,310,2.154,321,2.824,327,1.804,335,1.804,338,1.882,341,4.546,342,3.551,343,4.546,344,4.546,345,1.882,346,4.546,347,4.546,348,2.824,349,4.546,350,3.946,351,3.272,352,3.938,353,3.551,354,3.946,355,5.146,356,3.02,357,4.546,358,2.056,359,4.546,360,1.419,361,2.948,362,2.824,363,4.546,364,4.546,365,4.546,366,2.656,367,3.02,368,4.546,369,4.546,370,4.546,371,3.551,372,1.475,373,4.546,374,3.02,375,4.546]],["t/759",[11,1.576,22,1.918,31,1.359,33,0.835,49,1.145,60,0.359,65,2.506,69,1.113,89,1.436,90,1.436,99,2.068,108,2.519,144,2.7,155,1.918,160,1.195,192,1.687,196,2.506,202,2.38,206,1.368,208,2.043,224,1.918,230,1.793,242,2.068,250,1.687,251,3.743,254,2.519,268,1.918,273,1.306,280,3.743,282,2.043,304,3.806,315,1.687,320,2.068,321,1.793,325,2.506,329,1.306,348,1.793,351,1.593,352,3.429,354,2.506,361,1.436,367,1.918,376,2.887,377,1.793,378,2.887,379,2.887,380,2.255,381,2.506,382,2.506,383,1.793,384,2.887,385,2.887,386,2.506,387,2.506,388,2.887,389,2.068,390,1.306,391,2.068,392,2.068,393,2.506,394,2.887,395,4.48,396,2.506,397,3.368,398,2.887,399,2.506,400,2.887,401,2.506,402,4.312,403,2.849,404,2.255,405,2.506,406,2.887,407,2.887,408,2.068,409,2.887,410,2.887,411,2.887,412,4.312,413,2.887,414,2.506,415,1.793,416,2.506,417,1.918,418,2.887,419,2.887,420,2.255,421,1.918,422,2.887,423,2.887,424,2.506,425,2.068,426,2.887,427,2.506,428,2.887,429,2.887,430,2.865,431,2.865,432,3.368,433,2.255,434,2.887,435,2.887,436,1.918,437,1.918,438,1.687,439,2.255,440,2.506]],["t/761",[31,1.153,76,1.898,195,4.509,246,3.721,326,0.912,327,2.56,355,4.509,358,2.35,361,2.584,441,4.058,442,4.509,443,5.195,444,5.195,445,5.195,446,3.227,447,5.195,448,4.509,449,4.509,450,4.058,451,5.195,452,4.509,453,5.195,454,4.058,455,5.195,456,4.058,457,5.195,458,2.867,459,3.035]],["t/763",[32,1.375,37,1.655,50,1.181,60,0.156,66,1.548,69,0.643,109,1.472,110,0.749,115,2.163,139,2.017,149,2.163,150,2.59,167,1.456,171,1.548,175,1.655,185,2.017,206,2.515,273,1.127,274,1.784,279,2.561,282,1.181,290,1.946,293,1.917,295,1.077,310,1.181,314,1.655,326,0.828,358,1.127,360,0.778,421,1.655,431,3.526,458,1.375,460,3.855,461,2.163,462,0.988,463,2.491,464,2.491,465,2.491,466,1.304,467,2.252,468,3.101,469,3.801,470,3.855,471,3.011,472,1.375,473,1.946,474,1.456,475,2.163,476,2.491,477,2.491,478,2.491,479,3.011,480,2.163,481,2.491,482,3.011,483,2.561,484,3.011,485,3.011,486,3.855,487,1.655,488,2.491,489,1.181,490,2.491,491,1.946,492,1.784,493,3.855,494,2.491,495,1.946,496,2.491,497,2.491,498,1.784,499,2.491,500,2.491,501,1.946,502,1.946,503,2.491,504,2.163,505,2.491,506,2.491,507,2.163,508,1.784,509,3.855,510,2.163,511,1.946,512,2.163,513,2.491,514,1.946,515,2.163,516,2.491,517,2.491,518,4.205,519,6.07,520,4.607,521,3.855,522,2.491,523,2.491,524,4.715,525,2.491,526,2.491,527,2.491,528,2.491,529,1.784,530,2.491,531,2.491,532,2.491,533,1.946,534,2.491,535,2.491,536,2.491,537,1.655,538,1.127,539,2.491,540,2.491,541,2.163,542,2.491,543,1.946,544,2.163,545,2.491,546,2.163,547,2.491,548,2.491]],["t/765",[21,1.581,27,2.618,33,1.057,37,2.429,60,0.229,67,2.618,68,1.653,69,0.944,76,1.336,109,1.141,110,1.098,119,2.271,139,2.676,150,1.336,185,1.912,200,1.513,206,1.732,257,1.818,273,1.653,293,2.544,301,2.136,309,2.017,310,1.732,362,2.271,372,1.186,462,1.45,472,2.017,482,3.996,483,3.398,484,3.996,485,3.996,487,2.429,501,2.855,537,2.429,538,1.653,549,2.989,550,3.173,551,2.271,552,3.655,553,3.173,554,3.173,555,2.618,556,2.855,557,2.017,558,2.017,559,2.429,560,3.173,561,2.855,562,2.855,563,2.618,564,4.44,565,3.173,566,2.855,567,3.173,568,3.173,569,3.173,570,2.618,571,2.855,572,2.136,573,2.855,574,3.173,575,2.618,576,1.45,577,2.855,578,3.173,579,3.173,580,2.618,581,2.017,582,3.996,583,5.901,584,3.655,585,3.655,586,5.115,587,2.855,588,3.173,589,3.173]],["t/767",[21,2.097,60,0.304,109,1.514,150,1.772,202,2.676,206,2.298,223,3.788,259,2.676,340,1.924,467,2.833,468,2.833,537,3.221,590,6.179,591,4.849,592,2.676,593,4.209,594,4.426,595,4.849,596,4.849,597,4.849,598,4.849,599,3.788,600,3.788,601,4.209,602,4.849,603,6.179,604,4.426,605,4.849,606,4.849,607,6.179,608,3.473,609,3.012,610,4.849,611,3.473]],["t/769",[69,1.49,139,3.02,171,3.586,293,2.871,326,1.013,414,5.01,482,4.509,483,3.835,484,4.509,485,4.509,587,4.509,612,5.772,613,5.01,614,5.01,615,4.509]],["t/771",[16,1.522,21,1.258,35,2.526,60,0.182,93,1.258,100,4.49,111,2.273,150,2.563,164,1.7,175,1.933,182,1.316,193,2.273,210,2.084,211,2.526,228,3.571,314,1.933,326,1.204,345,1.205,348,1.808,374,1.933,408,2.084,425,2.084,454,2.273,462,2.057,468,4.287,473,2.273,474,1.7,489,1.379,491,2.273,492,2.084,510,3.765,518,3.819,592,1.606,614,3.765,616,2.91,617,2.91,618,2.882,619,2.084,620,3.445,621,2.882,622,1.933,623,2.91,624,2.91,625,2.91,626,2.273,627,4.338,628,2.526,629,2.91,630,4.338,631,4.338,632,2.882,633,3.107,634,4.338,635,4.338,636,2.91,637,2.91,638,2.91,639,2.526,640,2.91,641,2.91,642,2.91,643,2.91,644,2.91,645,2.91,646,3.765,647,2.91,648,4.338,649,2.526,650,2.91,651,2.91,652,1.933,653,4.338,654,3.107,655,2.91,656,2.91,657,2.084,658,2.91,659,2.526,660,2.526,661,2.91,662,2.91,663,2.273,664,2.526,665,2.91,666,2.91]],["t/773",[31,1.055,60,0.422,108,2.777,182,2.15,193,3.713,318,3.713,321,2.953,326,0.834,329,2.15,335,1.886,340,1.886,342,3.713,348,2.953,351,3.368,352,3.158,358,2.15,360,1.484,366,2.777,367,3.158,440,4.127,667,4.754,668,4.127,669,3.713,670,4.127,671,3.713,672,3.713,673,4.754,674,4.754,675,4.754,676,3.405,677,4.754,678,4.127,679,4.754,680,4.754,681,4.754,682,4.754,683,3.713,684,4.754,685,2.624]],["t/775",[33,1.669,60,0.361,89,2.871,200,2.389,329,2.611,331,2.871,332,4.509,333,3.372,334,3.372,335,2.29,336,3.186,337,3.372,338,2.389,339,3.835,340,2.29]],["t/778",[0,2.814,2,2.814,44,2.992,49,1.911,50,2.282,60,0.462,69,1.244,93,2.083,95,2.814,138,2.814,205,2.992,262,2.396,273,2.783,286,3.45,326,0.845,345,1.994,362,2.992,367,3.2,389,3.45,391,3.45,403,2.658,458,2.658,686,4.181,687,4.181,688,4.817,689,3.2,690,4.817,691,4.181,692,4.181,693,4.181,694,4.817,695,3.45,696,3.762,697,3.2,698,3.45]],["t/780",[9,2.98,21,1.709,32,2.182,44,2.456,60,0.414,69,1.888,93,1.709,95,2.31,123,3.432,138,2.31,155,2.626,160,1.636,191,1.788,234,3.432,242,3.867,262,2.686,281,2.456,286,2.831,288,2.831,315,2.31,326,0.948,331,1.966,345,1.636,404,4.218,405,3.432,437,2.626,450,3.088,561,3.088,562,3.088,570,2.831,692,3.432,695,2.831,696,4.804,697,2.626,699,2.626,700,3.088,701,3.432,702,3.088,703,3.432,704,2.626,705,3.953,706,5.4,707,4.086,708,5.4,709,5.4,710,3.953,711,3.953,712,3.432,713,2.626,714,3.953,715,3.432,716,3.088]],["t/782",[40,2.214,60,0.335,160,2.214,161,3.124,164,3.124,191,2.419,262,2.66,308,3.553,403,3.626,427,4.642,459,3.124,511,4.177,663,4.177,695,3.83,699,3.553,717,5.348,718,5.348,719,3.83,720,5.348,721,4.177,722,5.348,723,5.348,724,5.348,725,4.642]],["t/784",[60,0.443,76,1.715,77,4.073,150,2.447,160,1.943,167,2.742,169,3.361,236,3.665,257,2.334,262,2.334,266,2.915,288,3.361,403,2.59,575,3.361,576,1.862,660,4.073,695,3.361,699,3.118,702,3.665,703,4.073,726,3.361,727,4.073,728,3.361,729,4.693,730,4.693,731,4.073,732,3.665,733,4.693,734,3.665,735,4.073,736,4.693,737,3.665,738,4.693,739,4.693,740,4.693,741,4.693,742,4.073,743,2.915,744,3.665]],["t/786",[6,2.565,7,2.699,11,1.885,25,3.204,31,1.144,42,4.029,60,0.323,95,3.014,191,2.333,262,2.565,309,2.847,326,0.905,401,4.478,403,3.546,417,3.427,558,2.847,713,3.427,719,3.694,745,5.158,746,5.158,747,5.158,748,5.158,749,3.694,750,2.444,751,4.478,752,5.158,753,5.158,754,4.478,755,4.029]],["t/788",[4,1.955,6,2.676,7,2.815,11,1.437,25,2.443,49,1.56,60,0.337,95,2.297,101,3.071,116,2.612,118,2.443,139,2.057,167,2.297,187,3.071,191,1.778,194,2.612,257,1.955,282,1.863,291,2.816,308,2.612,309,2.17,327,1.56,340,2.134,377,2.443,403,2.17,404,3.071,508,4.392,557,2.17,558,2.969,704,2.612,737,3.071,749,2.816,751,3.413,755,3.071,756,5.38,757,3.932,758,2.612,759,3.932,760,3.071,761,3.932,762,3.932,763,3.413,764,3.932,765,3.932,766,3.413,767,2.816,768,3.413,769,3.932,770,3.413,771,4.202,772,3.932,773,2.612,774,3.932,775,2.612,776,3.932,777,3.413,778,3.413,779,3.413,780,3.932,781,3.413,782,2.612,783,3.413,784,3.071,785,2.816,786,3.932]],["t/790",[10,2.606,66,2.896,69,1.204,93,2.016,95,3.521,161,2.724,192,2.724,295,2.016,329,2.726,340,1.85,367,3.098,403,2.573,462,1.85,696,5.847,698,3.339,719,3.339,750,2.855,787,6.026,788,3.642,789,4.047,790,4.047,791,4.316,792,4.047,793,4.047,794,4.662,795,4.662,796,6.026,797,3.642,798,4.662,799,6.026,800,4.662,801,4.662]],["t/792",[9,3.186,62,4.509,66,3.586,69,1.777,262,3.422,288,4.134,358,2.611,784,4.509,802,5.772,803,3.02,804,5.772,805,5.01,806,4.509]],["t/794",[33,1.669,60,0.361,89,2.871,200,2.389,329,2.611,331,2.871,332,4.509,333,3.372,334,3.372,335,2.29,336,3.186,337,3.372,338,2.389,339,3.835,340,2.29]],["t/796",[0,1.914,11,1.197,14,2.844,22,2.177,33,0.948,60,0.348,76,1.197,90,1.63,116,4.468,118,2.94,119,2.036,140,2.177,143,2.177,176,2.177,185,1.714,209,2.56,221,2.347,273,1.482,295,1.417,298,2.347,310,1.553,326,0.975,327,2.204,335,1.3,338,1.356,353,2.56,371,2.56,372,1.063,383,2.94,390,1.482,425,2.347,446,2.036,454,2.56,458,2.612,459,1.914,466,2.476,685,2.612,744,2.56,770,2.844,771,2.56,773,2.177,790,2.844,803,1.714,807,2.765,808,2.844,809,3.277,810,3.277,811,3.277,812,2.844,813,3.277,814,2.844,815,2.844,816,3.277,817,2.844,818,2.844,819,1.714,820,2.844,821,2.844,822,3.277,823,3.277,824,2.56,825,2.844,826,3.39,827,3.277,828,3.277,829,3.277,830,1.914,831,3.277,832,3.277,833,3.277,834,3.277,835,4.822,836,3.277,837,2.844,838,3.277,839,3.277,840,3.277,841,3.277,842,2.844,843,2.56,844,3.277,845,3.277,846,2.56,847,2.844,848,2.844,849,3.277,850,3.277,851,2.844,852,2.036,853,3.277,854,2.56]],["t/798",[12,2.871,31,1.09,33,1.421,68,2.223,116,3.265,118,3.872,200,2.034,243,3.839,291,3.52,572,2.871,626,3.839,768,4.266,773,3.265,777,4.266,812,4.266,852,3.053,855,4.914,856,5.941,857,4.914,858,4.914,859,4.914,860,4.914,861,3.053,862,4.914,863,4.868,864,4.914,865,4.914,866,3.839,867,4.914,868,4.914,869,4.266,870,4.914,871,4.914]],["t/800",[60,0.367,264,4.581,273,2.653,282,2.779,462,2.327,468,3.427,704,3.896,773,3.896,872,5.865,873,5.865,874,5.865,875,5.865,876,5.865]],["t/802",[10,1.423,18,1.923,27,2.357,49,1.306,69,0.85,76,1.203,90,2.77,93,2.053,109,1.028,110,1.427,116,3.7,118,2.95,144,2.484,150,1.203,156,2.357,185,2.914,190,3.709,192,1.923,204,2.857,206,1.56,292,2.357,295,1.423,296,1.722,297,2.045,308,2.187,310,1.56,327,1.306,345,1.363,356,2.187,358,1.489,361,1.637,372,2.186,397,2.571,421,2.187,438,1.923,466,2.484,467,1.923,479,3.709,480,2.857,487,2.187,538,2.148,541,2.857,576,2.21,592,1.817,609,2.045,685,1.817,687,2.857,693,2.857,700,2.571,760,2.571,778,2.857,848,4.122,866,2.571,877,3.292,878,3.292,879,1.722,880,1.923,881,1.817,882,2.857,883,3.292,884,3.292,885,5.293,886,2.857,887,1.817,888,2.357,889,2.571,890,2.857,891,2.187,892,2.571,893,3.292,894,2.571,895,3.292,896,3.292,897,3.292,898,3.292,899,3.292,900,4.748,901,4.122,902,3.292,903,3.292,904,3.292,905,3.292,906,2.357]],["t/804",[33,1.669,60,0.361,89,2.871,200,2.389,329,2.611,331,2.871,333,3.372,334,3.372,335,2.29,336,3.186,337,3.372,338,2.389,339,3.835,340,2.29,907,4.134]],["t/806",[2,2.401,3,2.943,10,1.777,11,2.292,31,0.912,33,1.189,40,1.701,41,2.15,42,3.21,50,1.947,60,0.439,69,1.061,87,2.553,108,2.401,109,1.283,148,2.943,161,2.401,191,2.508,279,2.73,295,2.397,304,2.553,310,1.947,338,2.295,358,1.859,360,1.283,389,2.943,576,1.63,685,2.268,721,3.21,750,1.947,784,3.21,797,3.21,819,2.15,830,2.401,861,2.553,881,2.268,908,3.567,909,3.567,910,4.11,911,3.21,912,2.044,913,2.401,914,2.943,915,4.11,916,4.11,917,4.11,918,4.11,919,4.11,920,2.943,921,4.11,922,3.21,923,2.401,924,3.567,925,3.567,926,2.943,927,3.21,928,4.11]],["t/808",[40,2.264,60,0.342,191,2.473,326,1.169,390,2.473,492,3.916,576,2.169,609,3.397,611,3.916,775,3.633,807,3.195,843,4.271,929,6.66,930,4.271,931,5.468,932,4.747,933,5.468,934,4.747,935,3.633,936,4.747]],["t/810",[2,2.545,3,3.119,21,1.883,31,0.966,59,2.545,60,0.361,90,2.166,108,2.545,144,2.279,160,1.803,182,1.97,224,2.894,230,2.706,250,2.545,259,2.404,296,2.279,320,3.119,326,1.011,345,1.803,352,4.567,381,3.781,387,5.003,395,3.781,397,3.402,439,3.402,458,2.404,576,1.728,594,3.119,788,3.402,826,3.119,830,2.545,930,3.402,937,3.402,938,4.355,939,3.402,940,4.355,941,4.355,942,3.402,943,2.894,944,4.355,945,4.355,946,4.355,947,3.119,948,3.781,949,4.355,950,4.355,951,4.355,952,4.355,953,3.781,954,4.355]],["t/812",[11,1.51,40,1.711,44,3.457,58,2.567,60,0.463,69,1.437,110,1.242,138,3.251,160,1.711,171,2.567,182,1.869,220,3.228,273,2.517,296,2.162,320,2.96,326,0.725,327,2.208,338,1.711,340,1.64,352,2.746,356,2.746,377,4.365,576,1.64,654,2.96,700,3.228,744,3.228,750,2.637,775,2.746,914,2.96,922,3.228,923,2.415,955,5.653,956,4.133,957,4.133,958,4.133,959,4.133,960,4.133,961,4.133,962,3.228,963,4.133,964,2.96,965,3.588,966,4.133,967,3.588]],["t/814",[4,1.683,11,1.77,13,2.813,31,0.751,59,2.83,60,0.469,69,1.25,93,1.463,144,1.77,174,2.643,182,2.19,192,1.977,257,1.683,259,1.867,262,2.409,273,3.075,293,2.813,294,3.218,295,3.151,296,1.77,310,1.603,326,0.594,374,2.248,386,2.937,390,1.53,433,2.643,462,1.342,508,2.423,619,2.423,622,2.248,652,2.248,775,3.218,792,2.937,803,3.557,805,2.937,854,4.418,906,3.469,927,2.643,955,2.643,968,2.643,969,3.383,970,3.383,971,3.383,972,3.383,973,3.383,974,3.383,975,2.643,976,3.383,977,3.383,978,4.843,979,2.643,980,3.383,981,3.383,982,3.383,983,3.383,984,1.77,985,2.937,986,3.383,987,3.383,988,4.843]],["t/816",[11,1.055,12,1.687,13,1.436,39,2.068,50,1.368,58,1.793,59,1.687,60,0.453,68,1.95,69,1.478,74,1.918,76,1.055,93,1.248,101,2.255,129,2.068,143,1.918,144,1.51,155,1.918,182,1.95,200,1.195,208,1.368,230,1.793,232,2.506,235,1.793,257,1.436,293,1.436,294,1.918,295,1.248,296,2.256,297,1.793,301,1.687,310,1.368,315,1.687,326,0.507,360,0.901,374,1.918,377,3.557,383,1.793,415,2.679,416,2.506,458,1.593,508,4.101,558,2.849,572,1.687,608,2.068,611,2.068,618,1.918,621,1.918,676,2.068,766,2.506,767,2.068,771,2.255,775,1.918,803,1.51,852,2.679,869,2.506,891,1.918,923,1.687,947,2.068,962,2.255,965,3.743,979,4.786,989,2.506,990,2.506,991,5.161,992,2.068,993,4.312,994,2.887,995,2.887,996,2.506,997,2.887,998,2.887,999,2.887,1000,2.887,1001,2.887,1002,2.255,1003,2.887,1004,2.255,1005,2.887,1006,2.887,1007,2.887,1008,2.887,1009,2.887,1010,2.887,1011,3.743,1012,4.312,1013,2.887,1014,2.887,1015,2.887,1016,2.506,1017,4.312,1018,2.506,1019,2.887,1020,2.887,1021,2.887,1022,2.887,1023,2.887,1024,2.887,1025,2.887,1026,2.887,1027,2.887,1028,2.506,1029,2.887,1030,2.887]],["t/818",[0,1.923,4,3.032,6,1.637,7,1.722,11,1.735,16,2.914,23,3.709,25,2.045,28,2.571,30,2.357,31,0.73,32,1.817,41,1.722,44,3.46,50,1.56,51,2.571,56,4.835,57,4.122,58,2.045,60,0.206,62,2.571,70,2.571,76,1.203,81,2.357,106,2.857,108,1.923,110,1.427,127,2.857,139,1.722,162,2.857,176,2.187,182,2.148,184,2.187,206,1.56,228,2.045,257,1.637,273,1.489,296,2.484,297,2.045,304,2.95,305,2.045,314,2.187,326,0.977,327,2.21,351,1.817,360,1.028,362,2.045,377,2.95,415,2.045,448,2.857,492,2.357,538,1.489,582,2.571,621,3.155,652,2.187,728,2.357,750,1.56,758,2.187,767,2.357,791,2.357,930,2.571,935,2.187,992,2.357,1031,2.857,1032,2.571,1033,3.292,1034,2.045,1035,3.292,1036,1.923,1037,2.357,1038,4.835,1039,2.571,1040,3.292,1041,3.292,1042,2.571,1043,2.357,1044,4.748,1045,4.748,1046,3.292,1047,3.292,1048,2.857,1049,2.571,1050,3.292,1051,3.292]],["t/820",[50,2.848,60,0.376,358,2.718,360,1.876,750,2.848,935,3.993,1034,3.734,1052,6.01,1053,6.01,1054,4.695]],["t/822",[9,3.567,11,1.902,13,1.865,21,1.621,31,0.832,32,2.069,59,2.191,60,0.405,68,1.696,69,1.544,119,2.329,138,2.191,143,2.491,160,2.155,187,2.929,191,2.355,236,2.929,254,2.191,286,3.729,308,2.491,309,2.874,326,1.05,338,1.552,360,1.171,392,2.685,393,3.255,403,2.069,421,2.491,459,2.191,495,2.929,621,3.459,652,2.491,657,2.685,685,2.069,697,2.491,699,2.491,702,2.929,721,2.929,727,4.52,728,2.685,737,2.929,750,1.777,754,3.255,758,3.459,934,3.255,955,2.929,1055,5.982,1056,3.255,1057,3.255,1058,3.255,1059,3.75,1060,3.75,1061,4.52,1062,2.929,1063,3.75,1064,3.255,1065,3.75,1066,3.75,1067,3.75,1068,3.75,1069,3.255,1070,3.75]],["t/824",[9,2.621,11,2.597,31,0.73,32,2.621,34,2.857,37,2.187,50,2.639,53,2.045,58,2.045,60,0.453,69,0.85,109,1.482,110,1.427,161,1.923,191,2.758,235,2.045,244,5.293,303,2.357,304,3.788,305,3.788,324,2.571,326,0.578,327,1.306,331,1.637,345,1.363,360,1.739,391,3.989,417,2.187,438,1.923,446,2.045,483,2.187,592,1.817,594,2.357,599,2.571,620,2.187,743,2.045,750,2.889,791,2.357,818,2.857,854,2.571,927,2.571,984,2.484,1034,2.95,1036,1.923,1037,2.357,1058,2.857,1071,3.292,1072,4.748,1073,4.748,1074,4.748,1075,2.857,1076,3.292,1077,3.292,1078,4.748,1079,3.292,1080,4.122,1081,2.857,1082,2.857,1083,2.857,1084,2.571,1085,3.292,1086,3.292,1087,2.857]],["t/826",[2,3.427,40,2.428,60,0.367,208,2.779,459,3.427,698,4.2,726,4.2,826,4.2,935,3.896,939,4.581,975,4.581,1088,5.865,1089,5.091]],["t/828",[11,1.718,16,1.699,30,2.326,31,1.043,33,1.36,44,2.921,49,1.288,50,1.539,53,2.017,60,0.203,68,1.469,69,1.214,118,2.921,119,3.764,138,3.229,163,2.537,164,1.897,171,2.017,191,1.469,200,1.344,206,1.539,210,2.326,220,3.673,221,2.326,230,2.017,235,2.017,281,2.017,295,2.033,326,0.57,327,1.288,345,1.344,358,2.127,360,1.014,383,3.434,415,2.921,438,1.897,474,1.897,556,2.537,557,1.792,620,2.158,671,2.537,697,2.158,750,2.619,758,2.158,767,2.326,803,2.46,821,4.798,835,2.819,851,2.819,852,2.017,953,2.819,962,3.673,984,1.699,990,2.819,992,2.326,1034,2.017,1090,5.527,1091,2.537,1092,3.248,1093,4.702,1094,2.819,1095,3.248,1096,2.819,1097,3.248,1098,4.798,1099,3.124,1100,3.248,1101,3.248,1102,3.248,1103,3.248,1104,3.248,1105,2.326,1106,3.248,1107,2.819,1108,2.819,1109,3.248,1110,3.248,1111,3.248,1112,3.248,1113,3.248,1114,2.537,1115,2.819,1116,3.248,1117,3.248]],["t/830",[11,2.009,13,1.601,18,2.73,20,2.514,31,1.037,41,1.684,53,2,60,0.432,90,1.601,99,2.305,108,1.881,109,1.005,110,1.404,129,2.305,160,1.332,192,1.881,235,2,259,2.579,282,1.525,305,2,309,1.777,316,2.305,326,0.82,327,1.277,340,1.853,345,1.332,351,1.777,360,1.005,361,1.601,372,1.785,390,1.456,417,2.139,421,2.139,437,2.139,466,1.684,483,2.139,489,2.606,538,2.113,576,1.277,604,2.305,609,2,619,2.305,671,2.514,672,2.514,685,2.579,715,2.794,726,3.939,735,2.794,743,2.902,750,2.214,781,2.794,807,1.881,830,1.881,846,2.514,879,2.444,881,1.777,889,2.514,911,2.514,913,3.213,923,1.881,943,2.139,964,2.305,1043,2.305,1049,2.514,1056,2.794,1083,2.794,1118,4.055,1119,2.794,1120,3.219,1121,3.219,1122,3.219,1123,2.305,1124,3.219,1125,3.219,1126,3.219,1127,4.055,1128,3.219,1129,2.794,1130,3.219,1131,3.219,1132,1.881,1133,4.055,1134,2.794,1135,2.514,1136,3.219]],["t/832",[60,0.361,109,1.802,315,3.372,326,1.013,819,3.02,935,3.835,1084,4.509,1118,5.01,1135,4.509,1137,5.772,1138,5.772,1139,5.01,1140,4.509,1141,5.772,1142,5.772]],["t/834",[11,1.527,21,1.808,31,1.244,49,1.658,60,0.351,140,2.777,186,2.994,257,2.079,262,2.789,291,2.994,293,2.079,294,2.777,295,1.808,301,2.442,309,2.307,353,3.265,366,2.442,390,1.891,420,3.265,462,2.225,557,2.307,580,2.994,615,5.283,685,2.307,750,2.657,785,2.994,788,3.265,789,3.629,807,2.442,815,3.629,819,2.187,826,2.994,830,2.442,843,3.265,911,3.265,912,2.079,913,2.442,920,2.994,939,3.265,968,3.265,1002,3.265,1057,3.629,1061,3.629,1143,4.18,1144,4.18,1145,3.629,1146,4.18,1147,3.629,1148,3.629,1149,4.18,1150,3.629,1151,4.18,1152,4.18,1153,4.18,1154,2.994]],["t/836",[3,3.276,6,2.275,7,3.114,13,2.275,25,2.842,31,1.321,38,3.971,41,2.393,50,2.168,60,0.373,139,2.393,191,2.069,326,0.803,327,2.361,340,1.815,360,1.428,377,2.842,399,3.971,408,3.276,652,3.039,672,3.573,676,3.276,743,2.842,755,3.573,773,3.039,779,3.971,803,3.801,856,3.971,913,4.094,947,3.276,968,3.573,1031,3.971,1034,2.842,1148,3.971,1155,3.573,1156,4.575,1157,3.573]],["t/838",[2,2.56,31,0.972,40,1.814,49,1.738,60,0.432,69,1.131,76,1.601,142,3.138,145,3.804,181,2.292,182,1.982,191,1.982,257,2.179,297,2.722,315,3.381,316,4.144,326,1.015,335,2.296,338,2.395,340,1.738,436,2.911,599,3.423,669,3.423,670,3.804,683,3.423,686,3.804,689,2.911,698,3.138,793,3.804,807,2.56,808,3.804,887,2.418,909,3.804,920,3.138,925,3.804,1069,3.804,1158,5.786,1159,3.423,1160,3.804,1161,4.382,1162,3.804,1163,3.804,1164,3.138,1165,3.804,1166,2.911,1167,3.804]],["t/840",[60,0.325,109,1.622,110,1.561,164,3.035,206,2.462,326,1.133,356,3.451,372,1.686,390,2.35,498,3.721,549,3.035,557,2.867,558,2.867,581,2.867,649,4.509,668,4.509,923,3.035,1168,5.195,1169,4.509,1170,4.509,1171,5.195,1172,5.195,1173,3.721,1174,4.509,1175,5.195,1176,5.195,1177,5.195,1178,5.195]],["t/842",[31,1.057,40,1.369,41,1.73,49,1.312,60,0.298,76,1.208,109,1.032,110,0.994,150,1.741,165,2.87,166,2.583,167,1.932,181,1.73,186,2.368,250,1.932,265,2.054,295,1.43,315,1.932,326,0.58,366,1.932,372,1.546,430,2.197,431,2.197,437,2.197,438,1.932,458,1.825,462,1.312,466,1.73,467,1.932,468,3.262,469,2.368,529,2.368,533,2.583,538,1.496,549,2.783,550,2.87,551,3.469,557,1.825,558,1.825,563,3.412,576,1.312,581,1.825,588,2.87,611,2.368,620,2.197,632,2.197,633,2.368,704,2.197,742,2.87,863,2.583,912,1.644,984,1.73,1036,2.783,1099,3.71,1133,2.87,1154,2.368,1179,3.307,1180,3.307,1181,3.307,1182,3.307,1183,2.87,1184,3.307,1185,3.307,1186,3.412,1187,3.307,1188,3.307,1189,3.307,1190,3.307,1191,3.307,1192,3.307,1193,4.764,1194,3.307,1195,4.764,1196,3.307,1197,2.87,1198,3.307,1199,3.307,1200,3.307,1201,2.583,1202,3.307,1203,3.307,1204,2.87,1205,3.307,1206,2.87,1207,2.583,1208,3.307,1209,3.307,1210,3.307,1211,3.307,1212,3.307,1213,3.307,1214,3.307,1215,3.307]],["t/844",[21,1.797,60,0.26,63,3.608,76,1.519,88,3.247,99,2.977,109,1.744,110,1.249,150,1.519,156,2.977,205,3.47,216,3.247,254,2.428,265,4.373,268,2.761,279,2.761,335,1.649,358,1.88,391,2.977,449,3.608,472,3.724,495,3.247,538,2.527,571,3.247,572,4.113,573,3.247,575,2.977,576,1.649,592,2.294,632,2.761,1132,2.428,1166,2.761,1216,4.156,1217,4.156,1218,4.156,1219,4.001,1220,4.156,1221,4.156,1222,4.156,1223,4.156,1224,3.608,1225,3.608,1226,4.156,1227,4.156,1228,4.156,1229,4.156,1230,4.156,1231,4.156,1232,4.156]],["t/846",[16,1.655,22,2.101,31,0.702,49,1.255,69,1.191,93,1.368,109,0.987,110,0.95,150,2.899,184,3.065,185,1.655,202,2.546,208,1.499,228,1.965,254,1.848,265,1.965,266,1.965,268,3.617,281,1.965,326,0.809,348,1.965,366,1.848,436,2.101,442,2.746,468,3.181,469,4.286,472,3.303,518,3.065,520,4.726,529,3.304,537,2.101,549,3.181,551,3.382,563,4.286,572,1.848,592,1.746,632,3.065,633,3.304,654,2.265,669,2.471,697,2.101,704,2.101,707,2.101,743,1.965,912,1.573,1038,2.746,1042,2.471,1173,2.265,1183,4.004,1233,3.163,1234,3.163,1235,3.163,1236,3.163,1237,2.746,1238,3.163,1239,3.163,1240,2.746,1241,3.163,1242,3.163,1243,4.613,1244,3.163,1245,3.163,1246,3.163,1247,3.163,1248,2.746,1249,3.163,1250,2.746,1251,3.163]],["t/848",[21,1.45,31,1.067,33,0.97,37,2.227,40,1.388,60,0.21,67,2.401,68,2.176,74,2.227,107,2.401,109,1.047,110,1.445,190,2.619,200,1.388,210,2.401,216,2.619,222,2.91,228,2.989,235,2.083,257,1.667,265,2.083,295,1.45,301,1.959,305,2.083,309,1.85,360,1.047,372,1.088,438,1.959,472,1.85,487,2.227,538,1.516,543,2.619,549,1.959,551,3.496,553,2.91,554,2.91,555,2.401,556,2.619,557,1.85,558,1.85,559,2.227,560,2.91,561,2.619,562,2.619,563,3.446,564,2.91,565,2.91,566,2.619,567,2.91,568,2.91,569,2.91,570,2.401,571,2.619,572,2.811,573,2.619,574,2.91,575,2.401,576,1.33,577,2.619,578,2.91,579,2.91,580,3.446,581,1.85,608,3.446,621,2.227,626,2.619,732,3.758,734,2.619,797,2.619,863,2.619,886,2.91,912,1.667,1011,2.91,1042,2.619,1082,2.91,1132,1.959,1219,2.401,1252,3.352,1253,2.619,1254,3.352,1255,3.352,1256,3.352,1257,3.352,1258,3.352,1259,3.352,1260,3.352,1261,3.352,1262,3.352,1263,4.811,1264,3.352,1265,3.352,1266,3.352,1267,3.352,1268,3.352]],["t/850",[11,1.661,31,1.009,142,3.256,148,3.256,150,1.661,156,3.256,159,3.946,160,1.882,184,3.02,202,3.272,203,3.946,224,3.02,238,3.946,258,3.946,265,2.824,301,2.656,310,2.154,312,3.946,326,1.04,345,1.882,360,1.419,380,3.551,462,1.804,472,2.509,538,2.056,546,3.946,549,3.463,551,2.824,608,3.256,719,3.256,803,2.378,866,3.551,892,3.551,912,2.261,1123,3.256,1140,3.551,1201,3.551,1269,3.551,1270,4.546,1271,4.546,1272,4.546,1273,4.546,1274,4.546,1275,4.546,1276,4.546,1277,3.551]],["t/852",[11,1.726,12,2.759,40,1.955,60,0.381,75,4.1,76,1.726,109,1.475,110,1.419,160,1.955,181,2.471,279,3.138,282,2.238,326,1.066,372,1.533,501,3.689,549,3.55,551,2.934,581,2.607,589,4.1,633,3.383,803,3.179,891,3.138,1037,3.383,1039,3.689,1154,3.383,1186,3.383,1206,4.1,1269,3.689,1278,4.723,1279,4.746,1280,4.723,1281,4.723,1282,4.1,1283,4.723,1284,4.723,1285,4.723,1286,3.689,1287,4.1]],["t/854",[33,1.669,60,0.361,89,2.871,200,2.389,329,2.611,331,2.871,333,3.372,334,3.372,335,2.29,336,3.186,337,3.372,338,2.389,339,3.835,340,2.29,907,4.134]],["t/856",[10,1.895,18,2.56,46,3.423,60,0.362,109,1.368,110,1.317,208,2.076,326,0.769,327,1.738,361,2.179,372,1.878,390,2.617,392,3.138,432,3.423,459,2.56,489,2.076,576,1.738,622,2.911,689,3.844,819,2.292,846,3.423,887,2.418,913,2.56,926,3.138,937,4.52,1150,3.804,1155,3.423,1157,3.423,1288,4.382,1289,4.382,1290,2.911,1291,4.382,1292,4.382,1293,4.382,1294,4.382,1295,3.423,1296,4.382,1297,4.382,1298,4.382,1299,4.382,1300,4.382,1301,3.804,1302,3.138,1303,4.382,1304,3.804,1305,4.382,1306,4.382,1307,3.138,1308,4.382,1309,4.382]],["t/858",[0,1.848,10,1.995,31,0.702,33,1.334,60,0.289,68,1.431,87,1.965,90,1.573,109,1.44,110,0.95,140,3.065,143,2.101,164,1.848,192,3.181,206,1.499,209,2.471,219,2.746,259,1.746,282,1.499,316,2.265,326,0.809,360,0.987,417,2.101,446,1.965,462,1.255,471,2.471,489,1.499,576,1.255,592,1.746,604,3.304,609,1.965,618,2.101,713,2.101,743,1.965,763,2.746,782,2.101,785,3.304,791,2.265,820,2.746,825,4.004,830,1.848,847,2.746,879,2.413,880,3.717,892,2.471,894,2.471,908,2.746,926,2.265,947,2.265,984,1.655,1028,4.004,1034,1.965,1037,2.265,1096,2.746,1119,2.746,1123,2.265,1132,1.848,1186,2.265,1290,2.101,1307,2.265,1310,3.163,1311,2.746,1312,3.163,1313,3.163,1314,3.163,1315,3.163,1316,3.163,1317,3.163,1318,3.163,1319,3.163,1320,5.445,1321,3.163,1322,3.163,1323,3.163,1324,3.163,1325,3.163,1326,3.163,1327,3.163,1328,3.163,1329,3.163,1330,3.163,1331,3.163,1332,3.163,1333,3.163,1334,3.163,1335,2.101,1336,3.163,1337,3.163,1338,3.163,1339,3.163,1340,2.746,1341,3.163,1342,3.163,1343,2.746,1344,3.163,1345,3.163,1346,3.163,1347,3.163,1348,3.163,1349,2.746]],["t/860",[15,1.857,33,1.236,60,0.134,66,2.125,78,1.671,81,1.533,87,1.329,109,1.666,110,1.284,148,1.533,150,1.25,155,1.422,161,1.25,166,2.672,175,1.422,181,1.12,205,2.125,208,1.014,231,1.671,250,1.25,254,1.25,259,1.181,273,0.968,290,1.671,296,1.12,305,1.329,345,0.886,358,0.968,360,0.668,361,1.701,372,1.847,383,1.329,438,1.25,446,1.329,466,2.792,467,1.25,472,1.181,474,1.998,489,1.014,512,1.857,514,1.671,543,3.337,555,2.45,557,1.888,558,1.181,559,2.272,572,1.25,581,1.181,587,1.671,632,1.422,678,1.857,691,2.969,713,1.422,879,1.789,880,1.998,881,1.888,887,1.181,888,1.533,906,1.533,942,1.671,967,1.857,975,1.671,984,1.12,1036,1.25,1081,1.857,1099,2.839,1105,1.533,1132,3.49,1135,1.671,1154,1.533,1164,1.533,1173,3.06,1186,1.533,1197,1.857,1207,1.671,1219,3.06,1224,2.969,1225,2.969,1277,1.671,1286,1.671,1307,2.45,1340,1.857,1349,1.857,1350,2.14,1351,2.14,1352,2.14,1353,2.14,1354,2.14,1355,2.14,1356,4.273,1357,4.666,1358,4.881,1359,2.14,1360,3.42,1361,2.14,1362,4.273,1363,1.671,1364,2.14,1365,4.881,1366,1.533,1367,2.14,1368,2.14,1369,2.14,1370,2.14,1371,1.857,1372,2.14,1373,2.14,1374,2.14,1375,2.14,1376,1.857,1377,2.14,1378,2.14,1379,2.14,1380,2.672,1381,2.14,1382,2.14,1383,2.14,1384,1.857,1385,2.14,1386,2.14,1387,2.14,1388,2.14,1389,2.14,1390,4.632,1391,1.857,1392,2.14,1393,1.857,1394,1.857,1395,2.969,1396,2.969,1397,1.857,1398,1.857,1399,3.709,1400,2.969,1401,2.672,1402,1.857,1403,1.857,1404,1.857,1405,1.857,1406,1.857,1407,1.857,1408,1.857,1409,1.857,1410,1.857,1411,4.237,1412,2.14,1413,2.14,1414,2.14,1415,2.14,1416,2.14,1417,2.14]],["t/862",[18,2.146,31,1.139,40,1.521,41,1.922,49,1.458,60,0.321,69,0.949,110,1.104,181,1.922,208,1.741,223,2.87,246,2.631,282,2.804,323,3.189,326,0.901,327,1.458,335,1.458,361,1.827,362,2.282,372,1.192,389,2.631,390,1.662,396,3.189,415,2.282,420,2.87,466,1.922,474,2.146,582,2.87,622,2.441,639,3.189,782,2.441,814,3.189,861,2.282,887,2.028,912,1.827,943,2.441,1036,2.146,1075,3.189,1084,2.87,1091,2.87,1139,3.189,1160,3.189,1166,2.441,1167,3.189,1204,3.189,1253,2.87,1418,3.674,1419,3.189,1420,3.674,1421,3.674,1422,3.674,1423,3.674,1424,3.674,1425,3.674,1426,3.674,1427,3.674,1428,2.87,1429,3.674,1430,3.674,1431,3.674,1432,3.674,1433,3.189,1434,3.189,1435,3.674,1436,3.674,1437,3.674,1438,3.674,1439,3.674,1440,3.674,1441,3.674,1442,3.189,1443,3.674,1444,3.674,1445,3.674,1446,3.674,1447,3.189,1448,3.674,1449,3.674,1450,3.674,1451,3.674,1452,3.674,1453,3.674]],["t/864",[33,1.393,60,0.385,150,1.76,167,2.814,182,2.179,321,2.992,322,3.762,366,2.814,372,1.997,390,2.179,392,3.45,432,3.762,433,4.807,462,1.911,577,3.762,712,4.181,912,2.396,913,2.814,984,2.52,985,4.181,1002,3.762,1114,3.762,1248,4.181,1434,4.181,1442,4.181,1454,4.817,1455,4.181,1456,4.817,1457,3.762,1458,4.817,1459,4.817,1460,4.817,1461,4.817,1462,4.181,1463,4.817,1464,4.181,1465,4.817]],["t/866",[0,2.607,10,1.93,60,0.279,69,1.152,90,2.219,93,1.93,150,2.826,239,5.083,242,4.194,266,2.772,274,4.194,326,0.783,336,2.463,372,1.9,459,2.607,489,2.114,518,2.965,600,3.486,707,2.965,732,3.486,819,2.335,879,2.335,880,2.607,881,3.608,937,4.574,1290,2.965,1466,4.462,1467,4.462,1468,5.674,1469,3.873,1470,4.462,1471,4.462,1472,4.462,1473,4.462,1474,4.462]],["t/868",[31,1.195,33,1.558,60,0.337,200,2.23,329,2.437,331,2.679,333,3.148,334,3.148,335,2.137,336,2.973,337,3.148,338,2.23,807,3.148,907,3.858,1054,4.208,1166,3.579,1366,3.858,1428,4.208,1457,4.208,1475,4.676,1476,4.676,1477,4.676,1478,4.208,1479,5.387]],["t/870",[0,2.361,10,2.884,13,2.01,31,1.216,33,1.169,40,1.673,49,1.603,60,0.418,69,1.043,89,2.01,169,2.894,194,2.685,205,2.51,298,2.894,303,2.894,311,3.508,345,1.673,360,1.262,372,2.019,436,2.685,489,1.915,538,1.828,716,3.157,760,3.157,782,2.685,803,2.114,819,2.114,879,2.114,887,2.23,891,2.685,948,3.508,989,3.508,1169,3.508,1170,3.508,1253,3.157,1269,3.157,1279,3.157,1290,2.685,1302,2.894,1304,3.508,1335,4.133,1433,3.508,1455,3.508,1462,3.508,1464,3.508,1480,3.508,1481,4.041,1482,4.041,1483,3.508,1484,3.508,1485,4.041,1486,4.041,1487,4.041,1488,4.041,1489,3.508,1490,4.041,1491,4.041,1492,4.041]],["t/872",[6,1.117,13,1.117,18,1.312,31,0.498,33,1.276,49,0.891,53,1.395,59,1.312,60,0.417,68,1.016,76,0.82,87,1.395,89,1.117,107,1.608,109,1.11,110,1.068,139,1.175,147,1.949,163,1.754,169,1.608,176,1.492,181,1.175,194,1.492,202,1.239,205,1.395,208,1.064,224,1.492,245,1.949,262,1.117,264,1.754,281,1.395,282,1.064,292,1.608,293,1.117,294,1.492,298,1.608,303,1.608,326,0.394,327,1.41,335,0.891,338,0.93,350,1.949,360,0.701,361,1.117,366,1.312,372,2.109,380,1.754,390,1.016,430,1.492,431,1.492,436,1.492,441,1.754,446,1.395,458,1.239,462,0.891,466,2.308,491,1.754,498,1.608,502,1.754,538,1.016,576,0.891,581,1.239,618,1.492,619,1.608,646,1.949,689,2.361,725,1.949,726,1.608,749,1.608,782,1.492,806,1.754,819,1.175,824,1.754,830,1.312,837,1.949,842,3.085,861,1.395,879,1.859,880,2.577,881,1.239,887,3.587,888,1.608,889,1.754,890,1.949,891,1.492,894,1.754,912,1.117,913,1.312,923,1.312,926,1.608,932,1.949,936,1.949,964,2.545,984,1.859,1004,1.754,1043,1.608,1049,1.754,1089,1.949,1105,1.608,1123,1.608,1140,1.754,1145,1.949,1155,1.754,1159,1.754,1174,1.949,1295,1.754,1302,1.608,1311,1.949,1335,1.492,1343,1.949,1371,1.949,1376,1.949,1483,1.949,1484,1.949,1489,3.085,1493,2.245,1494,2.245,1495,2.245,1496,2.245,1497,2.245,1498,2.245,1499,2.245,1500,2.245,1501,2.245,1502,2.245,1503,2.245,1504,2.245,1505,2.245,1506,2.245,1507,2.245,1508,3.554,1509,2.245,1510,2.245,1511,2.245,1512,1.949,1513,2.245,1514,2.245,1515,2.245,1516,2.245,1517,2.245,1518,2.245,1519,2.245,1520,2.245,1521,2.245,1522,2.245,1523,2.245,1524,2.245,1525,2.245,1526,2.245,1527,2.245,1528,1.949,1529,2.245,1530,2.245,1531,1.949,1532,2.245,1533,2.245,1534,2.245,1535,2.245,1536,2.245,1537,2.245,1538,2.245,1539,2.245,1540,1.949,1541,2.245,1542,2.245,1543,2.245,1544,2.245,1545,2.245,1546,2.245,1547,2.245,1548,2.245,1549,2.245]],["t/874",[144,3.171,185,3.171,293,3.014,295,2.621,326,1.064,372,1.967,424,5.261,430,4.026,664,5.261]],["t/876",[10,0.879,13,1.011,31,1.234,33,1.194,59,1.187,60,0.205,66,1.262,74,1.35,76,0.743,81,1.456,93,0.879,109,1.479,110,1.423,129,1.456,142,1.456,150,2.412,160,0.841,185,1.063,194,1.35,208,0.963,228,2.039,231,1.587,241,2.848,246,1.456,254,1.187,261,1.764,266,3.23,296,1.063,297,1.262,302,1.764,310,0.963,326,0.831,331,1.011,335,1.302,345,1.358,351,2.278,356,1.35,360,0.634,361,1.011,362,1.262,372,1.804,374,1.35,382,1.764,383,1.262,452,1.764,456,1.587,462,1.302,466,2.159,467,1.187,474,2.411,475,1.764,489,0.963,538,0.919,555,2.35,559,2.18,570,1.456,576,1.302,581,1.811,657,1.456,707,2.18,731,1.764,749,1.456,785,1.456,806,1.587,852,2.039,861,1.262,879,2.909,880,2.768,881,1.811,887,1.122,888,1.456,914,1.456,942,2.563,943,1.35,1032,1.587,1036,1.187,1048,1.764,1062,1.587,1098,1.764,1099,2.742,1105,1.456,1132,3.248,1134,1.764,1157,1.587,1164,1.456,1165,1.764,1173,2.956,1207,1.587,1219,2.35,1277,1.587,1286,1.587,1290,2.18,1301,1.764,1302,1.456,1335,2.18,1357,1.587,1366,1.456,1380,1.587,1390,4.826,1391,2.848,1393,1.764,1394,1.764,1395,2.848,1396,2.848,1397,1.764,1398,1.764,1399,3.583,1400,2.848,1401,2.563,1402,1.764,1403,1.764,1404,1.764,1405,1.764,1406,1.764,1407,1.764,1408,1.764,1409,1.764,1410,1.764,1411,4.112,1528,1.764,1550,3.281,1551,2.032,1552,2.032,1553,2.032,1554,2.032,1555,2.032,1556,2.032,1557,2.032,1558,1.764,1559,2.032,1560,2.032,1561,2.032,1562,2.032,1563,2.032,1564,2.032,1565,2.032,1566,2.032,1567,1.764,1568,2.032,1569,1.764,1570,1.764,1571,2.032,1572,2.032,1573,1.764,1574,2.032,1575,2.032,1576,1.764,1577,2.032,1578,2.032,1579,1.764,1580,2.032,1581,2.032,1582,2.032,1583,2.848,1584,2.032]],["t/878",[12,0.657,21,0.859,29,0.976,31,0.592,32,1.473,39,0.805,41,0.588,49,0.446,50,0.533,58,1.234,68,0.509,69,0.29,74,0.747,88,0.878,93,1.154,95,1.161,107,0.805,109,0.62,110,0.597,119,0.699,134,2.317,138,1.559,139,1.04,144,0.588,150,2.737,160,0.466,171,1.234,175,0.747,184,0.747,186,0.805,198,0.976,202,1.473,206,0.533,208,0.533,214,0.976,215,0.976,221,0.805,230,0.699,250,0.657,266,1.234,268,0.747,274,0.805,281,0.699,282,1.744,301,0.657,314,0.747,326,0.902,340,1.059,345,1.105,348,0.699,351,0.621,360,0.833,371,2.085,372,0.365,408,0.805,415,1.234,425,0.805,430,0.747,431,0.747,437,0.747,456,0.878,461,1.725,462,1.953,467,1.161,468,1.559,469,2.911,471,1.552,472,0.621,473,2.085,474,0.657,479,0.878,487,0.747,489,2.526,498,0.805,502,0.878,504,1.725,507,2.317,511,1.552,514,0.878,515,0.976,518,3.27,529,0.805,533,0.878,537,1.32,544,3.194,559,0.747,566,0.878,580,0.805,592,1.778,593,0.976,594,0.805,600,1.552,601,0.976,604,0.805,609,0.699,613,2.317,615,0.878,618,0.747,620,0.747,622,1.32,628,0.976,654,0.805,657,1.912,659,0.976,663,0.878,699,0.747,701,0.976,707,0.747,728,0.805,734,0.878,758,1.773,783,0.976,817,0.976,819,1.04,824,0.878,852,1.234,861,0.699,879,1.396,880,1.161,881,1.778,882,1.725,885,2.317,901,1.725,906,0.805,914,1.423,923,0.657,924,1.725,943,0.747,964,0.805,979,1.552,984,0.588,992,0.805,996,4.461,1004,0.878,1016,0.976,1018,0.976,1032,0.878,1039,0.878,1043,0.805,1062,0.878,1064,0.976,1080,0.976,1087,0.976,1091,0.878,1094,0.976,1099,0.747,1107,1.725,1115,0.976,1127,0.976,1129,0.976,1132,1.161,1147,0.976,1159,0.878,1164,0.805,1201,0.878,1237,0.976,1240,0.976,1250,1.725,1282,0.976,1307,0.805,1335,1.32,1357,0.878,1363,0.878,1380,0.878,1384,0.976,1401,0.878,1419,0.976,1468,1.725,1469,0.976,1531,1.725,1540,0.976,1558,0.976,1567,1.725,1569,2.797,1570,2.317,1573,0.976,1576,0.976,1579,0.976,1583,0.976,1585,1.125,1586,1.987,1587,1.125,1588,1.125,1589,1.125,1590,1.125,1591,1.125,1592,1.125,1593,1.125,1594,1.125,1595,3.222,1596,1.125,1597,1.125,1598,1.125,1599,1.125,1600,1.125,1601,1.125,1602,1.987,1603,1.125,1604,1.125,1605,1.125,1606,1.125,1607,1.125,1608,1.125,1609,1.125,1610,1.125,1611,1.125,1612,1.125,1613,2.669,1614,1.125,1615,1.125,1616,1.987,1617,1.125,1618,1.125,1619,1.125,1620,1.125,1621,1.125,1622,1.125,1623,1.125,1624,1.125,1625,1.125,1626,1.125,1627,1.125,1628,1.125,1629,1.125,1630,1.125,1631,1.125,1632,1.125,1633,1.125,1634,1.125,1635,1.125,1636,1.125,1637,1.125,1638,1.125,1639,1.125,1640,1.125,1641,1.125,1642,1.125,1643,1.125,1644,1.125,1645,1.125,1646,1.125,1647,1.125,1648,1.125,1649,1.125,1650,1.125,1651,1.125,1652,1.125,1653,1.125,1654,1.125,1655,1.125,1656,1.125,1657,1.125,1658,1.125,1659,1.125,1660,1.125,1661,1.125,1662,1.125,1663,1.125,1664,1.125,1665,1.125,1666,1.125,1667,1.125,1668,1.125,1669,1.125,1670,1.987,1671,1.125,1672,1.125,1673,1.125,1674,1.125,1675,1.125,1676,1.125,1677,1.125,1678,1.987,1679,1.125,1680,3.222,1681,1.125,1682,1.125,1683,1.987,1684,1.987,1685,1.125,1686,1.125,1687,3.222,1688,1.987,1689,1.125,1690,1.125,1691,2.669,1692,1.125,1693,1.125,1694,1.125,1695,1.125,1696,1.125,1697,1.125,1698,1.125,1699,1.125,1700,1.125,1701,1.125,1702,2.669,1703,1.125,1704,1.125,1705,1.125,1706,1.987,1707,1.125,1708,1.125,1709,1.987,1710,1.125,1711,1.987,1712,1.987,1713,1.987,1714,1.987,1715,2.669,1716,2.669,1717,1.125,1718,1.125,1719,1.125,1720,1.987,1721,1.125,1722,1.125,1723,1.125,1724,1.125]],["t/880",[2,2.261,10,1.673,12,2.261,49,1.535,60,0.333,76,1.414,140,2.571,164,2.261,167,2.261,181,2.784,182,1.75,185,2.784,259,2.135,304,2.404,318,3.022,321,2.404,322,3.022,324,3.022,329,1.75,340,1.535,342,3.022,351,2.135,358,1.75,360,1.208,372,1.727,390,1.75,439,3.022,441,3.022,450,3.022,462,1.535,489,1.833,676,2.771,683,3.022,685,2.135,689,4.04,713,2.571,716,3.022,912,1.924,920,2.771,922,3.022,1036,2.261,1108,3.359,1114,3.022,1162,3.359,1163,3.359,1279,3.022,1287,3.359,1295,3.022,1363,3.022,1447,3.359,1478,3.022,1480,3.359,1512,3.359,1725,3.869,1726,3.869,1727,3.869,1728,3.869,1729,3.869,1730,3.869,1731,3.869,1732,3.869,1733,3.869,1734,3.869,1735,3.869,1736,3.869,1737,3.869,1738,3.869,1739,3.869,1740,3.869,1741,3.869,1742,3.869]],["t/882",[31,1.187,33,1.547,60,0.335,200,2.214,329,2.419,331,2.66,333,3.124,334,3.124,335,2.122,336,2.952,337,3.124,338,2.214,807,3.124,907,3.83,1054,4.177,1166,3.553,1366,3.83,1428,4.177,1457,4.177,1475,4.642,1476,4.642,1477,4.642,1478,4.177,1743,5.348,1744,5.348]]],"invertedIndex":[["",{"_index":150,"t":{"744":{"position":[[8,1]]},"749":{"position":[[270,2],[294,1],[306,1],[347,1],[406,1],[408,2],[488,1],[550,1],[580,2],[598,2],[601,2]]},"763":{"position":[[1191,1],[1199,1],[1245,1],[1270,1],[1286,2],[1341,1],[1427,1],[1436,2],[1474,1],[1545,1],[1554,2],[1600,1]]},"765":{"position":[[702,2]]},"767":{"position":[[308,2]]},"771":{"position":[[490,1],[526,1],[558,1],[591,1],[625,2],[691,2],[787,3],[937,1],[1034,2]]},"784":{"position":[[67,1],[101,1],[118,1]]},"802":{"position":[[551,3]]},"842":{"position":[[404,1],[445,1]]},"844":{"position":[[452,2]]},"846":{"position":[[66,1],[105,1],[123,2],[191,1],[217,2],[292,1],[310,2],[368,2],[423,2],[455,2],[471,1],[473,3],[477,2],[508,1],[556,1],[563,1],[578,1],[593,1],[636,1],[660,1],[667,3],[704,1],[706,2]]},"850":{"position":[[344,1]]},"860":{"position":[[1321,1],[1374,1]]},"864":{"position":[[340,2]]},"866":{"position":[[184,1],[205,1],[245,1],[262,1],[291,2],[307,3],[311,2],[353,1],[455,2]]},"876":{"position":[[206,2],[510,1],[563,1],[1007,3],[1716,2],[1972,1],[1981,1],[2011,1],[2021,1],[2058,1],[2076,1]]},"878":{"position":[[452,1],[486,1],[514,1],[542,2],[545,2],[548,1],[567,2],[590,3],[594,2],[615,1],[647,2],[666,2],[684,5],[690,2],[1103,1],[1140,2],[1196,2],[1440,2],[1496,1],[1504,2],[1578,1],[1861,1],[1924,2],[1940,2],[2615,2],[2700,1],[2715,2],[2724,2],[3789,1],[3836,2],[3885,1],[3917,3],[3932,1],[3979,3],[4175,2],[4648,1],[4700,2],[4793,1],[4795,2],[5003,1],[5050,2],[5137,1],[5161,2],[5199,1],[5223,1],[5225,2],[5257,1],[5259,2]]}}}],["0",{"_index":1240,"t":{"846":{"position":[[558,2]]},"878":{"position":[[3338,4]]}}}],["0.12ms",{"_index":1403,"t":{"860":{"position":[[1569,7]]},"876":{"position":[[758,7]]}}}],["0.5ms",{"_index":1405,"t":{"860":{"position":[[1589,6]]},"876":{"position":[[778,6]]}}}],["0.5x",{"_index":114,"t":{"742":{"position":[[845,5]]}}}],["1",{"_index":492,"t":{"763":{"position":[[752,1]]},"771":{"position":[[184,3]]},"808":{"position":[[141,2]]},"818":{"position":[[19,1]]}}}],["1,000,000",{"_index":1194,"t":{"842":{"position":[[466,9]]}}}],["1.0",{"_index":5,"t":{"740":{"position":[[48,4]]}}}],["10",{"_index":829,"t":{"796":{"position":[[598,2]]}}}],["100",{"_index":544,"t":{"763":{"position":[[1773,4]]},"878":{"position":[[2975,4],[2980,4],[3315,3],[3826,4],[3831,4]]}}}],["100000",{"_index":1241,"t":{"846":{"position":[[565,7]]}}}],["100k",{"_index":1173,"t":{"840":{"position":[[170,5]]},"846":{"position":[[876,4]]},"860":{"position":[[1483,4],[1539,4],[1602,4]]},"876":{"position":[[672,4],[728,4],[791,4]]}}}],["108",{"_index":1409,"t":{"860":{"position":[[1654,4]]},"876":{"position":[[843,4]]}}}],["12",{"_index":924,"t":{"806":{"position":[[635,2]]},"878":{"position":[[4776,3],[5127,3]]}}}],["150",{"_index":1677,"t":{"878":{"position":[[3325,3]]}}}],["15ms",{"_index":1397,"t":{"860":{"position":[[1513,5]]},"876":{"position":[[702,5]]}}}],["1700",{"_index":1406,"t":{"860":{"position":[[1596,5]]},"876":{"position":[[785,5]]}}}],["17417",{"_index":1404,"t":{"860":{"position":[[1577,6]]},"876":{"position":[[766,6]]}}}],["1x",{"_index":113,"t":{"742":{"position":[[841,3]]}}}],["2",{"_index":1052,"t":{"820":{"position":[[6,1]]}}}],["20",{"_index":249,"t":{"747":{"position":[[164,4]]}}}],["200,000",{"_index":1192,"t":{"842":{"position":[[417,7]]}}}],["21ms",{"_index":1402,"t":{"860":{"position":[[1563,5]]},"876":{"position":[[752,5]]}}}],["233",{"_index":1398,"t":{"860":{"position":[[1519,4]]},"876":{"position":[[708,4]]}}}],["24ms",{"_index":1408,"t":{"860":{"position":[[1648,5]]},"876":{"position":[[837,5]]}}}],["27",{"_index":1333,"t":{"858":{"position":[[825,3]]}}}],["2d",{"_index":819,"t":{"796":{"position":[[377,2]]},"806":{"position":[[239,2]]},"832":{"position":[[114,2]]},"834":{"position":[[208,2]]},"856":{"position":[[62,2]]},"866":{"position":[[438,2]]},"870":{"position":[[513,2]]},"872":{"position":[[2234,2]]},"878":{"position":[[845,2],[2864,2]]}}}],["2d/3d",{"_index":1156,"t":{"836":{"position":[[173,5]]}}}],["2ms",{"_index":1400,"t":{"860":{"position":[[1529,4],[1664,4]]},"876":{"position":[[718,4],[853,4]]}}}],["2x",{"_index":112,"t":{"742":{"position":[[837,3]]}}}],["3",{"_index":975,"t":{"814":{"position":[[343,1]]},"826":{"position":[[6,1]]},"860":{"position":[[1137,2]]}}}],["300",{"_index":1678,"t":{"878":{"position":[[3330,3],[3334,3]]}}}],["350",{"_index":1401,"t":{"860":{"position":[[1534,4],[1669,4]]},"876":{"position":[[723,4],[858,4]]},"878":{"position":[[3319,3]]}}}],["3d",{"_index":615,"t":{"769":{"position":[[59,2]]},"834":{"position":[[52,2],[215,2],[269,3],[352,2]]},"878":{"position":[[982,2]]}}}],["3rd",{"_index":966,"t":{"812":{"position":[[622,3]]}}}],["3x",{"_index":1213,"t":{"842":{"position":[[918,3]]}}}],["4",{"_index":1137,"t":{"832":{"position":[[6,1]]}}}],["4.2",{"_index":812,"t":{"796":{"position":[[150,4]]},"798":{"position":[[6,3]]}}}],["5",{"_index":637,"t":{"771":{"position":[[593,2]]}}}],["50",{"_index":885,"t":{"802":{"position":[[231,3],[302,3],[343,3],[410,3]]},"878":{"position":[[2971,3],[3817,3],[3822,3]]}}}],["50ms",{"_index":1396,"t":{"860":{"position":[[1507,5],[1642,5]]},"876":{"position":[[696,5],[831,5]]}}}],["600",{"_index":1246,"t":{"846":{"position":[[662,4]]}}}],["60fps",{"_index":1193,"t":{"842":{"position":[[428,6],[479,6]]}}}],["8",{"_index":1346,"t":{"858":{"position":[[1103,1]]}}}],["800",{"_index":1244,"t":{"846":{"position":[[638,4]]}}}],["95",{"_index":1329,"t":{"858":{"position":[[704,3]]}}}],["9ms",{"_index":1399,"t":{"860":{"position":[[1524,4],[1584,4],[1659,4]]},"876":{"position":[[713,4],[773,4],[848,4]]}}}],["ability",{"_index":1037,"t":{"818":{"position":[[420,7]]},"824":{"position":[[457,7]]},"852":{"position":[[89,7]]},"858":{"position":[[477,7]]}}}],["above",{"_index":142,"t":{"742":{"position":[[1284,5]]},"838":{"position":[[480,5]]},"850":{"position":[[199,5]]},"876":{"position":[[199,6]]}}}],["abstract",{"_index":567,"t":{"765":{"position":[[317,8]]},"848":{"position":[[222,8]]}}}],["absurdly",{"_index":1211,"t":{"842":{"position":[[748,8]]}}}],["accelerated",{"_index":1601,"t":{"878":{"position":[[857,11]]}}}],["access",{"_index":428,"t":{"759":{"position":[[1071,6]]}}}],["according",{"_index":73,"t":{"742":{"position":[[342,9]]}}}],["account",{"_index":902,"t":{"802":{"position":[[828,7]]}}}],["accurate",{"_index":545,"t":{"763":{"position":[[1778,8]]}}}],["achieves",{"_index":1347,"t":{"858":{"position":[[1105,8]]}}}],["achieving",{"_index":499,"t":{"763":{"position":[[842,9]]}}}],["acknowledgment",{"_index":1506,"t":{"872":{"position":[[525,14]]}}}],["action",{"_index":183,"t":{"744":{"position":[[531,6]]}}}],["adapt",{"_index":1018,"t":{"816":{"position":[[782,5]]},"878":{"position":[[4054,5]]}}}],["add",{"_index":202,"t":{"744":{"position":[[927,3]]},"749":{"position":[[493,3]]},"759":{"position":[[281,3],[488,3]]},"767":{"position":[[159,3]]},"846":{"position":[[480,3],[709,3]]},"850":{"position":[[340,3],[405,3]]},"872":{"position":[[1200,3]]},"878":{"position":[[1543,3],[1580,5],[4414,3]]}}}],["added",{"_index":511,"t":{"763":{"position":[[1103,5]]},"782":{"position":[[226,5]]},"878":{"position":[[1956,5],[3279,6]]}}}],["adding",{"_index":224,"t":{"744":{"position":[[1326,6]]},"759":{"position":[[184,6]]},"810":{"position":[[437,6]]},"850":{"position":[[220,6]]},"872":{"position":[[911,6]]}}}],["addition",{"_index":671,"t":{"773":{"position":[[94,8]]},"828":{"position":[[729,9]]},"830":{"position":[[763,8]]}}}],["additional",{"_index":1429,"t":{"862":{"position":[[322,10]]}}}],["address",{"_index":42,"t":{"740":{"position":[[474,7]]},"786":{"position":[[133,7]]},"806":{"position":[[520,7]]}}}],["addressed",{"_index":1537,"t":{"872":{"position":[[1605,9]]}}}],["addressing",{"_index":667,"t":{"773":{"position":[[19,10]]}}}],["addslotobject(slotname",{"_index":874,"t":{"800":{"position":[[94,23]]}}}],["adjusted",{"_index":1023,"t":{"816":{"position":[[1083,8]]}}}],["adopters",{"_index":1734,"t":{"880":{"position":[[319,8]]}}}],["advanced",{"_index":1131,"t":{"830":{"position":[[649,8]]}}}],["advancements",{"_index":1302,"t":{"856":{"position":[[398,12]]},"870":{"position":[[211,13]]},"872":{"position":[[1361,12]]},"876":{"position":[[1702,13]]}}}],["advantage",{"_index":1130,"t":{"830":{"position":[[636,9]]}}}],["advisable",{"_index":1649,"t":{"878":{"position":[[2517,9]]}}}],["agnostic",{"_index":57,"t":{"742":{"position":[[131,8]]},"818":{"position":[[205,8],[1061,8]]}}}],["aim",{"_index":1518,"t":{"872":{"position":[[815,3]]}}}],["aims",{"_index":1034,"t":{"818":{"position":[[146,4]]},"820":{"position":[[31,4]]},"824":{"position":[[143,4],[731,4]]},"828":{"position":[[32,4]]},"836":{"position":[[122,4]]},"858":{"position":[[928,4]]}}}],["allow",{"_index":1237,"t":{"846":{"position":[[313,5]]},"878":{"position":[[4219,5]]}}}],["allowed",{"_index":1325,"t":{"858":{"position":[[579,7]]}}}],["allowing",{"_index":68,"t":{"742":{"position":[[272,8],[603,8]]},"744":{"position":[[998,8]]},"753":{"position":[[198,8]]},"765":{"position":[[456,8]]},"798":{"position":[[58,8]]},"816":{"position":[[353,8],[874,8]]},"822":{"position":[[306,8]]},"828":{"position":[[237,8]]},"848":{"position":[[361,8],[494,8]]},"858":{"position":[[972,8]]},"872":{"position":[[756,8]]},"878":{"position":[[3425,8]]}}}],["allows",{"_index":171,"t":{"744":{"position":[[315,6]]},"763":{"position":[[713,6]]},"769":{"position":[[38,6]]},"812":{"position":[[579,6]]},"828":{"position":[[800,6]]},"878":{"position":[[2019,6],[3582,6]]}}}],["alpha",{"_index":533,"t":{"763":{"position":[[1565,5]]},"842":{"position":[[236,5]]},"878":{"position":[[1297,6]]}}}],["alphas",{"_index":516,"t":{"763":{"position":[[1201,7]]}}}],["already",{"_index":292,"t":{"751":{"position":[[13,7]]},"757":{"position":[[206,7]]},"802":{"position":[[987,7]]},"872":{"position":[[1832,7]]}}}],["alternatively",{"_index":1476,"t":{"868":{"position":[[140,14]]},"882":{"position":[[139,14]]}}}],["although",{"_index":1150,"t":{"834":{"position":[[381,8]]},"856":{"position":[[114,8]]}}}],["always",{"_index":87,"t":{"742":{"position":[[514,6]]},"744":{"position":[[167,6],[450,6]]},"806":{"position":[[275,6]]},"858":{"position":[[988,6]]},"860":{"position":[[11,6]]},"872":{"position":[[553,6]]}}}],["amazing",{"_index":784,"t":{"788":{"position":[[664,7]]},"792":{"position":[[25,7]]},"806":{"position":[[171,7]]}}}],["anchor",{"_index":1182,"t":{"842":{"position":[[211,7]]}}}],["animation",{"_index":773,"t":{"788":{"position":[[377,9]]},"796":{"position":[[30,9]]},"798":{"position":[[25,9]]},"800":{"position":[[58,9]]},"836":{"position":[[438,9]]}}}],["animations",{"_index":118,"t":{"742":{"position":[[879,10]]},"788":{"position":[[463,10]]},"796":{"position":[[380,11],[470,10]]},"798":{"position":[[192,10],[349,11]]},"802":{"position":[[529,10],[600,10]]},"828":{"position":[[416,11],[622,11]]}}}],["animators",{"_index":1283,"t":{"852":{"position":[[196,10]]}}}],["announce",{"_index":3,"t":{"740":{"position":[[29,8]]},"806":{"position":[[18,8]]},"810":{"position":[[27,8]]},"836":{"position":[[28,8]]}}}],["announcement",{"_index":928,"t":{"806":{"position":[[698,13]]}}}],["announcing",{"_index":448,"t":{"761":{"position":[[115,10]]},"818":{"position":[[28,10]]}}}],["another",{"_index":618,"t":{"771":{"position":[[59,7],[240,8]]},"816":{"position":[[608,7]]},"858":{"position":[[1159,7]]},"872":{"position":[[1068,7]]},"878":{"position":[[1199,7]]}}}],["antialias:true",{"_index":1622,"t":{"878":{"position":[[1909,14]]}}}],["antialiasing",{"_index":1616,"t":{"878":{"position":[[1614,12],[1680,12]]}}}],["anticipating",{"_index":1525,"t":{"872":{"position":[[1016,12]]}}}],["anyone",{"_index":983,"t":{"814":{"position":[[947,6]]}}}],["api",{"_index":282,"t":{"749":{"position":[[659,3]]},"759":{"position":[[692,3],[1011,3]]},"763":{"position":[[704,3]]},"788":{"position":[[229,3]]},"800":{"position":[[89,4]]},"830":{"position":[[546,3]]},"852":{"position":[[260,4]]},"858":{"position":[[189,4]]},"862":{"position":[[146,3],[350,3],[555,3]]},"872":{"position":[[2093,3]]},"878":{"position":[[2759,3],[2875,4],[4085,4],[5181,3],[5245,3]]}}}],["api's",{"_index":412,"t":{"759":{"position":[[806,5],[928,6]]}}}],["app",{"_index":1062,"t":{"822":{"position":[[424,3]]},"876":{"position":[[1905,3]]},"878":{"position":[[510,3]]}}}],["app.init",{"_index":601,"t":{"767":{"position":[[169,10]]},"878":{"position":[[556,10]]}}}],["app.stage.addchild(container",{"_index":1249,"t":{"846":{"position":[[741,30]]}}}],["appeal",{"_index":1092,"t":{"828":{"position":[[196,6]]}}}],["appealing",{"_index":1110,"t":{"828":{"position":[[980,10]]}}}],["appearance",{"_index":1008,"t":{"816":{"position":[[379,10]]}}}],["appends",{"_index":82,"t":{"742":{"position":[[455,7]]}}}],["application",{"_index":758,"t":{"788":{"position":[[51,11]]},"818":{"position":[[636,12]]},"822":{"position":[[345,12],[795,11]]},"828":{"position":[[713,12]]},"878":{"position":[[454,12],[520,14],[570,11]]}}}],["applications",{"_index":750,"t":{"786":{"position":[[91,12]]},"790":{"position":[[77,12],[281,12]]},"806":{"position":[[387,12]]},"812":{"position":[[78,13],[494,12]]},"818":{"position":[[102,13]]},"820":{"position":[[74,13]]},"822":{"position":[[110,13]]},"824":{"position":[[119,13],[374,12],[937,12],[1141,13]]},"828":{"position":[[96,12],[851,13],[1146,12]]},"830":{"position":[[746,13],[1168,13]]},"834":{"position":[[243,13],[619,13]]}}}],["application’s",{"_index":1268,"t":{"848":{"position":[[1078,13]]}}}],["applied",{"_index":882,"t":{"802":{"position":[[135,7]]},"878":{"position":[[1392,7],[4973,7]]}}}],["apply",{"_index":231,"t":{"744":{"position":[[1413,5]]},"860":{"position":[[1994,5]]},"876":{"position":[[356,6]]}}}],["applying",{"_index":1617,"t":{"878":{"position":[[1772,8]]}}}],["appreciate",{"_index":1103,"t":{"828":{"position":[[755,10]]}}}],["approach",{"_index":1307,"t":{"856":{"position":[[512,8]]},"858":{"position":[[570,8]]},"860":{"position":[[230,10],[455,9]]},"878":{"position":[[1039,8]]}}}],["appropriate",{"_index":1467,"t":{"866":{"position":[[113,11]]}}}],["apps",{"_index":797,"t":{"790":{"position":[[349,4]]},"806":{"position":[[189,5]]},"848":{"position":[[957,5]]}}}],["architecture",{"_index":1352,"t":{"860":{"position":[[105,12]]}}}],["areas",{"_index":1140,"t":{"832":{"position":[[88,5]]},"850":{"position":[[70,5]]},"872":{"position":[[1725,5]]}}}],["arguably",{"_index":1502,"t":{"872":{"position":[[384,8]]}}}],["arise",{"_index":1730,"t":{"880":{"position":[[233,6]]}}}],["around",{"_index":828,"t":{"796":{"position":[[590,7]]}}}],["art",{"_index":568,"t":{"765":{"position":[[326,3]]},"848":{"position":[[231,3]]}}}],["ask",{"_index":1187,"t":{"842":{"position":[[341,4]]}}}],["aspect",{"_index":1019,"t":{"816":{"position":[[818,6]]}}}],["aspects",{"_index":1508,"t":{"872":{"position":[[615,7],[1641,7]]}}}],["assembled",{"_index":921,"t":{"806":{"position":[[545,9]]}}}],["asset",{"_index":6,"t":{"740":{"position":[[56,5],[532,5]]},"742":{"position":[[325,5],[480,5],[552,6],[1206,5]]},"744":{"position":[[71,5],[704,5],[1073,5],[1275,5],[1478,5]]},"751":{"position":[[104,5]]},"753":{"position":[[140,5]]},"786":{"position":[[253,5]]},"788":{"position":[[81,5],[142,5]]},"818":{"position":[[50,5]]},"836":{"position":[[390,5]]},"872":{"position":[[306,5]]}}}],["assetpack",{"_index":4,"t":{"740":{"position":[[38,9],[498,9]]},"742":{"position":[[0,9],[231,9],[367,9],[1330,9]]},"744":{"position":[[14,9],[305,9],[633,9],[861,9]]},"747":{"position":[[11,10],[129,9]]},"749":{"position":[[10,10],[428,9],[691,10],[798,9]]},"751":{"position":[[0,9],[90,9],[175,9]]},"753":{"position":[[0,9],[158,9],[272,9],[405,10]]},"788":{"position":[[124,10]]},"814":{"position":[[507,10]]},"818":{"position":[[39,10],[128,9],[180,9],[403,9]]}}}],["assetpack's",{"_index":146,"t":{"742":{"position":[[1390,11]]},"744":{"position":[[1238,11]]}}}],["assetpack.js",{"_index":260,"t":{"749":{"position":[[157,13],[273,13]]}}}],["assetpack/core",{"_index":240,"t":{"747":{"position":[[46,15],[94,15]]},"749":{"position":[[313,18]]}}}],["assets",{"_index":16,"t":{"740":{"position":[[172,6],[463,7],[636,6]]},"742":{"position":[[91,6],[1266,6]]},"744":{"position":[[45,7],[206,6],[340,6],[439,6],[625,7],[796,6],[885,6],[1168,6]]},"749":{"position":[[79,6],[363,8]]},"753":{"position":[[67,6]]},"771":{"position":[[1421,8]]},"818":{"position":[[364,6],[458,6],[847,6]]},"828":{"position":[[1093,6]]},"846":{"position":[[997,7]]}}}],["assured",{"_index":1445,"t":{"862":{"position":[[722,7]]}}}],["async",{"_index":1469,"t":{"866":{"position":[[223,5]]},"878":{"position":[[535,6]]}}}],["asynchronous",{"_index":1586,"t":{"878":{"position":[[50,13],[374,12]]}}}],["atlas",{"_index":120,"t":{"742":{"position":[[914,6]]}}}],["attach",{"_index":872,"t":{"800":{"position":[[12,6]]}}}],["attempt",{"_index":1322,"t":{"858":{"position":[[494,7]]}}}],["attributes",{"_index":1276,"t":{"850":{"position":[[353,10]]}}}],["audio",{"_index":25,"t":{"740":{"position":[[286,5]]},"742":{"position":[[951,5]]},"786":{"position":[[269,5]]},"788":{"position":[[171,5]]},"818":{"position":[[739,5]]},"836":{"position":[[367,6]]}}}],["audio/ffmpeg",{"_index":121,"t":{"742":{"position":[[928,13]]}}}],["autodetectrenderer",{"_index":1468,"t":{"866":{"position":[[148,18],[186,18],[270,20]]},"878":{"position":[[467,18],[623,23]]}}}],["automated",{"_index":862,"t":{"798":{"position":[[208,9]]}}}],["automates",{"_index":47,"t":{"740":{"position":[[552,9]]}}}],["automatic",{"_index":768,"t":{"788":{"position":[[262,9]]},"798":{"position":[[137,9]]}}}],["automatically",{"_index":81,"t":{"742":{"position":[[441,13],[710,13]]},"818":{"position":[[431,13]]},"860":{"position":[[2089,13]]},"876":{"position":[[1238,13]]}}}],["automating",{"_index":306,"t":{"753":{"position":[[99,10]]}}}],["available",{"_index":192,"t":{"744":{"position":[[670,10]]},"759":{"position":[[651,9]]},"790":{"position":[[215,10]]},"802":{"position":[[121,10]]},"814":{"position":[[923,9]]},"830":{"position":[[904,9]]},"858":{"position":[[370,9],[691,9],[1024,9]]}}}],["avoid",{"_index":1651,"t":{"878":{"position":[[2550,5]]}}}],["avoids",{"_index":1377,"t":{"860":{"position":[[985,6]]}}}],["await",{"_index":600,"t":{"767":{"position":[[163,5]]},"866":{"position":[[264,5]]},"878":{"position":[[550,5],[617,5]]}}}],["away",{"_index":393,"t":{"759":{"position":[[384,5]]},"822":{"position":[[854,5]]}}}],["b",{"_index":1324,"t":{"858":{"position":[[562,2]]}}}],["back",{"_index":894,"t":{"802":{"position":[[661,4]]},"858":{"position":[[537,4]]},"872":{"position":[[733,4]]}}}],["backend",{"_index":1558,"t":{"876":{"position":[[1055,7]]},"878":{"position":[[215,7]]}}}],["backporting",{"_index":434,"t":{"759":{"position":[[1218,11]]}}}],["bad",{"_index":1459,"t":{"864":{"position":[[225,4]]}}}],["balance",{"_index":579,"t":{"765":{"position":[[486,7]]},"848":{"position":[[391,7]]}}}],["bandwidth",{"_index":1385,"t":{"860":{"position":[[1176,9]]}}}],["bar",{"_index":1553,"t":{"876":{"position":[[225,4]]}}}],["bars",{"_index":1003,"t":{"816":{"position":[[258,5]]}}}],["based",{"_index":66,"t":{"742":{"position":[[258,5]]},"763":{"position":[[918,5]]},"790":{"position":[[71,5]]},"792":{"position":[[16,5]]},"860":{"position":[[634,5],[1702,5]]},"876":{"position":[[891,5]]}}}],["basic",{"_index":772,"t":{"788":{"position":[[336,5]]}}}],["basically",{"_index":1252,"t":{"848":{"position":[[438,9]]}}}],["basics",{"_index":401,"t":{"759":{"position":[[517,6]]},"786":{"position":[[33,7]]}}}],["batch",{"_index":1277,"t":{"850":{"position":[[373,5]]},"860":{"position":[[431,5]]},"876":{"position":[[1420,5]]}}}],["batched",{"_index":1275,"t":{"850":{"position":[[309,7]]}}}],["batches",{"_index":1361,"t":{"860":{"position":[[377,7]]}}}],["batching",{"_index":1078,"t":{"824":{"position":[[518,8],[538,8]]}}}],["beast",{"_index":1216,"t":{"844":{"position":[[40,6]]}}}],["beautiful",{"_index":989,"t":{"816":{"position":[[61,9]]},"870":{"position":[[630,9]]}}}],["become",{"_index":1064,"t":{"822":{"position":[[454,6]]},"878":{"position":[[2788,6]]}}}],["becomes",{"_index":1338,"t":{"858":{"position":[[890,7]]}}}],["before",{"_index":1337,"t":{"858":{"position":[[880,6]]}}}],["begin",{"_index":1053,"t":{"820":{"position":[[13,5]]}}}],["beginners",{"_index":384,"t":{"759":{"position":[[214,9]]}}}],["behaves",{"_index":463,"t":{"763":{"position":[[68,7]]}}}],["behaviour",{"_index":1009,"t":{"816":{"position":[[394,9]]}}}],["behind",{"_index":1204,"t":{"842":{"position":[[610,6]]},"862":{"position":[[26,6]]}}}],["being",{"_index":421,"t":{"759":{"position":[[952,5]]},"763":{"position":[[431,5]]},"802":{"position":[[74,5]]},"822":{"position":[[28,5]]},"830":{"position":[[558,5]]}}}],["believe",{"_index":1493,"t":{"872":{"position":[[13,7]]}}}],["below",{"_index":382,"t":{"759":{"position":[[95,5]]},"876":{"position":[[82,5]]}}}],["benchmark",{"_index":1410,"t":{"860":{"position":[[1680,9]]},"876":{"position":[[869,9]]}}}],["benefit",{"_index":1326,"t":{"858":{"position":[[617,7]]}}}],["best",{"_index":446,"t":{"761":{"position":[[106,4]]},"796":{"position":[[205,4]]},"824":{"position":[[257,4]]},"858":{"position":[[1008,4]]},"860":{"position":[[1962,4]]},"872":{"position":[[673,4]]}}}],["beta",{"_index":937,"t":{"810":{"position":[[64,4]]},"856":{"position":[[87,4],[147,4]]},"866":{"position":[[28,4],[390,4]]}}}],["better",{"_index":351,"t":{"757":{"position":[[93,6],[296,6]]},"759":{"position":[[444,6]]},"773":{"position":[[106,6],[398,6]]},"818":{"position":[[880,6]]},"830":{"position":[[1113,6]]},"876":{"position":[[1104,6],[1492,6],[1878,6]]},"878":{"position":[[4229,6]]},"880":{"position":[[279,7]]}}}],["between",{"_index":580,"t":{"765":{"position":[[494,7]]},"834":{"position":[[307,7]]},"848":{"position":[[399,7],[805,7]]},"878":{"position":[[4594,7]]}}}],["beyond",{"_index":745,"t":{"786":{"position":[[22,6]]}}}],["big",{"_index":1738,"t":{"880":{"position":[[536,3]]}}}],["bigger",{"_index":1516,"t":{"872":{"position":[[779,6]]}}}],["bitmap",{"_index":1706,"t":{"878":{"position":[[4496,6],[4685,6]]}}}],["bitmapfonts",{"_index":1699,"t":{"878":{"position":[[4317,11]]}}}],["bitmaptext",{"_index":1710,"t":{"878":{"position":[[4654,12]]}}}],["bitrate",{"_index":125,"t":{"742":{"position":[[989,7]]}}}],["blend",{"_index":1569,"t":{"876":{"position":[[1462,5]]},"878":{"position":[[1235,5],[1411,5],[1547,5],[2602,5]]}}}],["blog",{"_index":582,"t":{"765":{"position":[[525,4],[540,4]]},"818":{"position":[[962,4]]},"862":{"position":[[275,4]]}}}],["bluesky",{"_index":440,"t":{"759":{"position":[[1443,7]]},"773":{"position":[[296,8]]}}}],["board",{"_index":1547,"t":{"872":{"position":[[1942,5]]}}}],["bones",{"_index":857,"t":{"798":{"position":[[67,5]]}}}],["boost",{"_index":1171,"t":{"840":{"position":[[142,6]]}}}],["boosting",{"_index":1543,"t":{"872":{"position":[[1800,8]]}}}],["both",{"_index":383,"t":{"759":{"position":[[209,4]]},"796":{"position":[[295,4],[572,4]]},"816":{"position":[[898,4]]},"828":{"position":[[206,4],[246,4],[951,4]]},"860":{"position":[[130,4]]},"876":{"position":[[266,4]]}}}],["bottleneck",{"_index":1200,"t":{"842":{"position":[[549,10]]}}}],["bouncing",{"_index":1205,"t":{"842":{"position":[[621,8]]}}}],["boundaries",{"_index":1480,"t":{"870":{"position":[[22,10]]},"880":{"position":[[652,10]]}}}],["box",{"_index":77,"t":{"742":{"position":[[394,3]]},"784":{"position":[[11,3]]}}}],["breaking",{"_index":1174,"t":{"840":{"position":[[184,8]]},"872":{"position":[[2084,8]]}}}],["breaks",{"_index":1566,"t":{"876":{"position":[[1426,7]]}}}],["bringing",{"_index":455,"t":{"761":{"position":[[215,8]]}}}],["brings",{"_index":1168,"t":{"840":{"position":[[108,6]]}}}],["brouwer",{"_index":958,"t":{"812":{"position":[[168,8]]}}}],["browser",{"_index":483,"t":{"763":{"position":[[595,7],[1041,7]]},"765":{"position":[[597,7],[834,7]]},"769":{"position":[[106,7]]},"824":{"position":[[27,7]]},"830":{"position":[[583,7]]}}}],["browsers",{"_index":1320,"t":{"858":{"position":[[404,9],[711,9],[804,8]]}}}],["bubble",{"_index":976,"t":{"814":{"position":[[356,6]]}}}],["bubbo",{"_index":988,"t":{"814":{"position":[[1053,5],[1059,5]]}}}],["bugs",{"_index":1461,"t":{"864":{"position":[[250,5]]}}}],["build",{"_index":161,"t":{"744":{"position":[[136,5],[401,5],[1200,5]]},"749":{"position":[[754,5]]},"782":{"position":[[96,5]]},"790":{"position":[[263,5]]},"806":{"position":[[371,5]]},"824":{"position":[[895,5]]},"860":{"position":[[371,5]]}}}],["buildgeometryfrompath",{"_index":1688,"t":{"878":{"position":[[3673,21],[3887,23]]}}}],["building",{"_index":309,"t":{"753":{"position":[[223,8]]},"765":{"position":[[265,8]]},"786":{"position":[[82,8]]},"788":{"position":[[655,8]]},"822":{"position":[[331,8],[839,8]]},"830":{"position":[[1131,8]]},"834":{"position":[[604,8]]},"848":{"position":[[170,8]]}}}],["built",{"_index":291,"t":{"749":{"position":[[824,5]]},"788":{"position":[[96,5]]},"798":{"position":[[40,5]]},"834":{"position":[[83,5]]}}}],["bump",{"_index":1367,"t":{"860":{"position":[[729,5]]}}}],["bun",{"_index":709,"t":{"780":{"position":[[412,4],[417,3]]}}}],["bundle",{"_index":1134,"t":{"830":{"position":[[971,6]]},"876":{"position":[[1931,6]]}}}],["bundler",{"_index":695,"t":{"778":{"position":[[302,8]]},"780":{"position":[[592,7]]},"782":{"position":[[0,7]]},"784":{"position":[[159,7]]}}}],["bundlers",{"_index":727,"t":{"784":{"position":[[38,9]]},"822":{"position":[[237,8],[555,8]]}}}],["bundles",{"_index":651,"t":{"771":{"position":[[1070,8]]}}}],["bunnies",{"_index":1197,"t":{"842":{"position":[[508,7]]},"860":{"position":[[1909,8]]}}}],["bunny",{"_index":1393,"t":{"860":{"position":[[1423,5]]},"876":{"position":[[612,5]]}}}],["bunnymark",{"_index":1411,"t":{"860":{"position":[[1716,9],[1761,9],[1774,9],[1796,9]]},"876":{"position":[[904,9],[949,9],[962,9],[984,9]]}}}],["bunnys",{"_index":1272,"t":{"850":{"position":[[227,6]]}}}],["burn",{"_index":1659,"t":{"878":{"position":[[2709,5]]}}}],["busting",{"_index":80,"t":{"742":{"position":[[432,8]]}}}],["buttons",{"_index":993,"t":{"816":{"position":[[166,8],[236,8]]}}}],["cache",{"_index":79,"t":{"742":{"position":[[426,5]]}}}],["cacheasbitmap",{"_index":465,"t":{"763":{"position":[[89,13]]}}}],["cacheastexture",{"_index":460,"t":{"763":{"position":[[0,15],[38,16]]}}}],["caches",{"_index":153,"t":{"744":{"position":[[38,6]]}}}],["caching",{"_index":149,"t":{"744":{"position":[[0,7],[1109,7]]},"763":{"position":[[375,7]]}}}],["call",{"_index":1082,"t":{"824":{"position":[[630,5]]},"848":{"position":[[752,4]]}}}],["called",{"_index":968,"t":{"814":{"position":[[38,6]]},"834":{"position":[[62,6]]},"836":{"position":[[78,6]]}}}],["came",{"_index":347,"t":{"757":{"position":[[64,4]]}}}],["camera",{"_index":1602,"t":{"878":{"position":[[869,7],[964,6]]}}}],["candidate",{"_index":1454,"t":{"864":{"position":[[34,10]]}}}],["canvas",{"_index":604,"t":{"767":{"position":[[237,6],[409,7]]},"830":{"position":[[873,6]]},"858":{"position":[[420,6],[545,6]]},"878":{"position":[[2857,6]]}}}],["canvases",{"_index":595,"t":{"767":{"position":[[64,9]]}}}],["canvasondom1",{"_index":606,"t":{"767":{"position":[[295,12]]}}}],["capabilities",{"_index":911,"t":{"806":{"position":[[99,12]]},"830":{"position":[[662,13]]},"834":{"position":[[544,12]]}}}],["capable",{"_index":1172,"t":{"840":{"position":[[149,7]]}}}],["care",{"_index":1556,"t":{"876":{"position":[[401,4]]}}}],["cases",{"_index":1389,"t":{"860":{"position":[[1310,6]]}}}],["catalysed",{"_index":1306,"t":{"856":{"position":[[498,9]]}}}],["causing",{"_index":918,"t":{"806":{"position":[[477,7]]}}}],["celebrating",{"_index":1482,"t":{"870":{"position":[[111,11]]}}}],["certain",{"_index":1539,"t":{"872":{"position":[[1633,7]]}}}],["chain",{"_index":548,"t":{"763":{"position":[[1823,5]]}}}],["challenge",{"_index":43,"t":{"740":{"position":[[487,10]]}}}],["challenges",{"_index":752,"t":{"786":{"position":[[148,10]]}}}],["change",{"_index":1380,"t":{"860":{"position":[[1093,6],[1888,6]]},"876":{"position":[[1848,6]]},"878":{"position":[[1216,6]]}}}],["changed",{"_index":1224,"t":{"844":{"position":[[324,8]]},"860":{"position":[[506,7],[780,8]]}}}],["changer",{"_index":1269,"t":{"850":{"position":[[36,8]]},"852":{"position":[[40,7]]},"870":{"position":[[102,8]]}}}],["changes",{"_index":208,"t":{"744":{"position":[[1018,7]]},"759":{"position":[[118,7],[1316,7]]},"816":{"position":[[989,8]]},"826":{"position":[[78,7]]},"846":{"position":[[336,7]]},"856":{"position":[[360,7]]},"860":{"position":[[681,7]]},"862":{"position":[[612,7]]},"872":{"position":[[2097,8]]},"876":{"position":[[153,8]]},"878":{"position":[[2777,7]]}}}],["changing",{"_index":1407,"t":{"860":{"position":[[1615,9]]},"876":{"position":[[804,9]]}}}],["channel",{"_index":682,"t":{"773":{"position":[[329,8]]}}}],["character",{"_index":870,"t":{"798":{"position":[[325,9]]}}}],["characters",{"_index":566,"t":{"765":{"position":[[302,11]]},"848":{"position":[[207,11]]},"878":{"position":[[4418,10]]}}}],["chats",{"_index":1744,"t":{"882":{"position":[[241,6]]}}}],["check",{"_index":297,"t":{"751":{"position":[[59,5]]},"802":{"position":[[1114,5]]},"816":{"position":[[528,5]]},"818":{"position":[[1126,5]]},"838":{"position":[[443,5]]},"876":{"position":[[478,5]]}}}],["checkboxes",{"_index":994,"t":{"816":{"position":[[175,11]]}}}],["checkout",{"_index":1214,"t":{"842":{"position":[[929,8]]}}}],["cherry",{"_index":1656,"t":{"878":{"position":[[2660,6]]}}}],["child",{"_index":627,"t":{"771":{"position":[[212,5],[396,5]]}}}],["child's",{"_index":629,"t":{"771":{"position":[[313,7]]}}}],["children",{"_index":473,"t":{"763":{"position":[[291,8]]},"771":{"position":[[866,8]]},"878":{"position":[[1364,8],[1461,8],[1525,8]]}}}],["chit",{"_index":1743,"t":{"882":{"position":[[236,4]]}}}],["choice",{"_index":1212,"t":{"842":{"position":[[790,6]]}}}],["choosing",{"_index":1258,"t":{"848":{"position":[[740,8]]}}}],["ci",{"_index":151,"t":{"744":{"position":[[10,3],[286,4]]}}}],["clarity",{"_index":1235,"t":{"846":{"position":[[265,7]]}}}],["class",{"_index":1127,"t":{"830":{"position":[[496,5],[925,5]]},"878":{"position":[[3491,5]]}}}],["classic",{"_index":1261,"t":{"848":{"position":[[842,7]]}}}],["classics",{"_index":1625,"t":{"878":{"position":[[2098,9]]}}}],["cleaner",{"_index":1533,"t":{"872":{"position":[[1504,7]]}}}],["clear",{"_index":350,"t":{"757":{"position":[[86,6]]},"872":{"position":[[956,6]]}}}],["cli",{"_index":286,"t":{"749":{"position":[[718,4],[776,3]]},"778":{"position":[[237,3]]},"780":{"position":[[23,3]]},"822":{"position":[[19,3],[393,3]]}}}],["clients",{"_index":86,"t":{"742":{"position":[[506,7]]}}}],["closely",{"_index":1661,"t":{"878":{"position":[[2829,7]]}}}],["closer",{"_index":692,"t":{"778":{"position":[[156,6]]},"780":{"position":[[646,6]]}}}],["clothing",{"_index":865,"t":{"798":{"position":[[237,9]]}}}],["code",{"_index":984,"t":{"814":{"position":[[979,4]]},"824":{"position":[[240,5],[1097,4]]},"828":{"position":[[545,5]]},"842":{"position":[[1002,4]]},"858":{"position":[[1066,5]]},"860":{"position":[[814,4]]},"864":{"position":[[276,5]]},"872":{"position":[[630,4],[928,5]]},"878":{"position":[[146,4]]}}}],["codebase",{"_index":432,"t":{"759":{"position":[[1168,8],[1288,8]]},"856":{"position":[[543,8]]},"864":{"position":[[391,8]]}}}],["coders",{"_index":1284,"t":{"852":{"position":[[220,7]]}}}],["collaborate",{"_index":1095,"t":{"828":{"position":[[261,11]]}}}],["collaboration",{"_index":1112,"t":{"828":{"position":[[1022,14]]}}}],["collection",{"_index":969,"t":{"814":{"position":[[76,10]]}}}],["color",{"_index":529,"t":{"763":{"position":[[1451,5]]},"842":{"position":[[246,7]]},"846":{"position":[[442,6],[465,5]]},"878":{"position":[[2702,6]]}}}],["color:'blue",{"_index":1724,"t":{"878":{"position":[[5210,12]]}}}],["color:'red",{"_index":1722,"t":{"878":{"position":[[5148,12]]}}}],["colorblend",{"_index":1626,"t":{"878":{"position":[[2108,11]]}}}],["colorburnblend",{"_index":1627,"t":{"878":{"position":[[2120,15]]}}}],["colordodgeblend",{"_index":1628,"t":{"878":{"position":[[2136,16]]}}}],["combine",{"_index":1021,"t":{"816":{"position":[[890,7]]}}}],["combined",{"_index":213,"t":{"744":{"position":[[1091,8]]}}}],["comes",{"_index":75,"t":{"742":{"position":[[377,5]]},"852":{"position":[[56,5]]}}}],["comet",{"_index":1090,"t":{"828":{"position":[[0,5],[332,5],[1037,5]]}}}],["coming",{"_index":793,"t":{"790":{"position":[[232,6]]},"838":{"position":[[67,6]]}}}],["command",{"_index":405,"t":{"759":{"position":[[683,8]]},"780":{"position":[[209,8]]}}}],["commit",{"_index":172,"t":{"744":{"position":[[329,6]]}}}],["commitment",{"_index":363,"t":{"757":{"position":[[282,10]]}}}],["committed",{"_index":318,"t":{"753":{"position":[[369,9]]},"773":{"position":[[6,9]]},"880":{"position":[[163,9]]}}}],["common",{"_index":751,"t":{"786":{"position":[[141,6]]},"788":{"position":[[357,6]]}}}],["communication",{"_index":364,"t":{"757":{"position":[[303,14]]}}}],["community",{"_index":338,"t":{"755":{"position":[[80,9]]},"757":{"position":[[147,10]]},"775":{"position":[[80,9]]},"794":{"position":[[80,9]]},"796":{"position":[[1132,9]]},"804":{"position":[[85,9]]},"806":{"position":[[313,9],[506,10]]},"812":{"position":[[218,9]]},"822":{"position":[[498,10]]},"838":{"position":[[88,10],[207,10]]},"854":{"position":[[85,9]]},"868":{"position":[[180,9]]},"872":{"position":[[66,9]]},"882":{"position":[[179,9]]}}}],["compared",{"_index":889,"t":{"802":{"position":[[414,8]]},"830":{"position":[[382,8]]},"872":{"position":[[1948,8]]}}}],["compatibility",{"_index":245,"t":{"747":{"position":[[110,13]]},"872":{"position":[[2151,13]]}}}],["compilation",{"_index":1580,"t":{"876":{"position":[[1909,12]]}}}],["complete",{"_index":735,"t":{"784":{"position":[[199,8]]},"830":{"position":[[59,8]]}}}],["complex",{"_index":235,"t":{"744":{"position":[[1470,7]]},"816":{"position":[[923,8]]},"824":{"position":[[499,7]]},"828":{"position":[[484,7]]},"830":{"position":[[1140,8]]},"848":{"position":[[690,7]]}}}],["complexity",{"_index":725,"t":{"782":{"position":[[232,11]]},"872":{"position":[[1669,10]]}}}],["complicated",{"_index":1058,"t":{"822":{"position":[[181,11]]},"824":{"position":[[656,11]]}}}],["components",{"_index":965,"t":{"812":{"position":[[607,10]]},"816":{"position":[[147,10],[317,10]]}}}],["comprehensive",{"_index":1431,"t":{"862":{"position":[[429,13]]}}}],["compress",{"_index":1046,"t":{"818":{"position":[[767,8]]}}}],["compressed",{"_index":24,"t":{"740":{"position":[[268,11]]}}}],["compresses",{"_index":92,"t":{"742":{"position":[[572,10]]}}}],["compressing",{"_index":97,"t":{"742":{"position":[[653,11]]}}}],["compression",{"_index":91,"t":{"742":{"position":[[559,12]]}}}],["computational",{"_index":1225,"t":{"844":{"position":[[368,13]]},"860":{"position":[[843,13],[1207,13]]}}}],["computations",{"_index":1314,"t":{"858":{"position":[[109,12]]}}}],["concept",{"_index":1596,"t":{"878":{"position":[[713,7]]}}}],["configurable",{"_index":45,"t":{"740":{"position":[[519,12]]}}}],["configuration",{"_index":255,"t":{"749":{"position":[[42,13],[628,13]]}}}],["configure",{"_index":1230,"t":{"844":{"position":[[600,9]]}}}],["configured",{"_index":276,"t":{"749":{"position":[[503,10]]}}}],["conform",{"_index":1717,"t":{"878":{"position":[[4825,7]]}}}],["considerable",{"_index":839,"t":{"796":{"position":[[820,12]]}}}],["considering",{"_index":950,"t":{"810":{"position":[[481,11]]}}}],["console",{"_index":484,"t":{"763":{"position":[[603,7],[1049,7]]},"765":{"position":[[605,7],[842,7]]},"769":{"position":[[114,7]]}}}],["const",{"_index":518,"t":{"763":{"position":[[1228,5],[1254,5],[1319,5],[1410,5],[1457,5],[1528,5],[1582,5]]},"771":{"position":[[473,5],[509,5],[545,5],[921,5]]},"846":{"position":[[175,5],[494,5]]},"866":{"position":[[247,5]]},"878":{"position":[[504,5],[600,5],[1087,5],[1847,5],[3778,5],[3870,5],[3921,5],[4635,5],[4990,5]]}}}],["constant",{"_index":1221,"t":{"844":{"position":[[209,8]]}}}],["construct",{"_index":1364,"t":{"860":{"position":[[543,9]]}}}],["consuming",{"_index":34,"t":{"740":{"position":[[384,9]]},"824":{"position":[[391,10]]}}}],["container",{"_index":468,"t":{"763":{"position":[[131,9],[179,9],[238,9],[1132,9]]},"767":{"position":[[276,10]]},"771":{"position":[[0,9],[46,9],[67,9],[227,9],[282,10],[357,10],[462,10],[496,12],[532,12],[821,12],[882,9],[927,9]]},"800":{"position":[[30,9]]},"842":{"position":[[406,10],[900,9],[1027,10]]},"846":{"position":[[144,9],[181,9],[713,9]]},"878":{"position":[[1093,9],[1109,11],[1341,10]]}}}],["container.addchild(new",{"_index":648,"t":{"771":{"position":[[964,22],[998,22]]}}}],["container.addparticle(particle",{"_index":1247,"t":{"846":{"position":[[671,32]]}}}],["container.blendmode",{"_index":1615,"t":{"878":{"position":[[1558,19]]}}}],["container.getglobalalpha(skipupdate",{"_index":535,"t":{"763":{"position":[[1602,37]]}}}],["container.getglobaltint(skipupdate",{"_index":531,"t":{"763":{"position":[[1476,36]]}}}],["container.getglobaltransform(outmatrix",{"_index":526,"t":{"763":{"position":[[1343,39]]}}}],["container.tint",{"_index":1614,"t":{"878":{"position":[[1481,14]]}}}],["container1",{"_index":634,"t":{"771":{"position":[[479,10],[702,10]]}}}],["container1.addchild(sprite",{"_index":638,"t":{"771":{"position":[[596,28]]}}}],["container1.scale",{"_index":636,"t":{"771":{"position":[[574,16]]}}}],["container2",{"_index":635,"t":{"771":{"position":[[515,10],[717,10]]}}}],["container2.reparentchild(sprite",{"_index":641,"t":{"771":{"position":[[753,33]]}}}],["container(); container.addChild(new Sprite()); container.addChild(new Graphics()); // This will throw a type error DTS Bundles: We now provide a single TypeScript definition file with all pixi exports under the PIXI namespace, similar to the defintion file we generated in v6. This can be useful for users that are using PixiJS in a non-module environment, and need to include the definition file manually. This file can be found on all of our releases on Github in the \"Assets\" section, or through https://pixijs.download/vX.X.X/pixi.d.ts.","s":"v8.2.0","u":"/blog/better-docs-v8","h":"#v820","p":757},{"i":774,"t":"We’re committed to addressing the feedback you’ve shared and continuing to improve PixiJS. In addition to better documentation, you can expect more regular updates to keep you informed about what’s new. Your input is vital to PixiJS’s success, and we encourage you to share your thoughts through Bluesky, Github, and the Discord channel. Thanks for your continued support as we work to make PixiJS better for everyone. The PixiJS Team","s":"πŸ—£οΈ Looking Ahead","u":"/blog/better-docs-v8","h":"#️-looking-ahead","p":757},{"i":776,"t":"Follow Zyie and PixiJS on social media for the latest updates. Join our vibrant community on Discord for real-time discussions and support.","s":"🌐 Stay Connected","u":"/blog/better-docs-v8","h":"#-stay-connected","p":757},{"i":778,"t":"As we mentioned in our previous PixiJS Update post, we are focusing on making PixiJS easier to use and understand. Today we're pushing the project one step closer to that goal and we’re excited to introduce PixiJS Create. An easy to use CLI that provides templates for using PixiJS with your favourite bundler, as well as a new \"Creation Template\" to get you started with PixiJS and its ecosystem.","s":"PixiJS Update - Start building with PixiJS in just one command! πŸš€","u":"/blog/create-cli","h":"","p":777},{"i":780,"t":"PixiJS Create is a new CLI tool that simplifies the process of setting up a PixiJS project. It provides a quick and easy way to create a new PixiJS project with the tools you need to get started with just one command. Whether you prefer using Vite, Webpack, or esbuild, PixiJS Create has you covered. It is as simple as running: NPM: npm create pixi.js@latest Yarn: yarn create pixi.js PNPM: pnpm create pixi.js Bun: bun create pixi.js Then just follow the prompts to select your desired template and you're good to go! When running the tool, you will be presented with an option of either a Bundler Template or a Creation Template. Let's take a closer look at each of these options.","s":"πŸš€ Getting Started","u":"/blog/create-cli","h":"#-getting-started","p":777},{"i":782,"t":"Bundler Templates are stripped-down starting points for setting up PixiJS projects with popular build tools. These templates focus solely on the essentials, giving you a no-frills environment to start your project without any added complexity.","s":"πŸ› οΈ Bundler Templates: Simple and Barebones","u":"/blog/create-cli","h":"#️-bundler-templates-simple-and-barebones","p":777},{"i":784,"t":"Out-of-the-box integration with major bundlers, including: Vite v6 + PixiJS (Recommended) Webpack v5 + PixiJS esbuild + PixiJS PixiJS imported via import maps Bundler Templates are ideal if you want complete control over your project’s setup while skipping the hassle of setting up an entire project. They’re lightweight, efficient, and perfect for custom workflows.","s":"What’s Included?","u":"/blog/create-cli","h":"#whats-included","p":777},{"i":786,"t":"Creation Templates go beyond the basics, offering a fully-featured foundation for building applications with PixiJS. These templates address common challenges developers face when starting a new project, providing tools that simplify screen management, asset handling, audio and more.","s":"🎨 Creation Templates: Feature-Rich Starting Points","u":"/blog/create-cli","h":"#-creation-templates-feature-rich-starting-points","p":777},{"i":788,"t":"Screen Management: Handle transitions and organize application states with ease. Asset Loading: Built-in support for PixiJS AssetPack, making asset management effortless. Audio Playback: Leverage PixiJS Sound for modern WebAudio API features. Responsive Design: Automatic resize handling for various screen sizes. Simple UI: Includes a basic UI library for common UI elements. Animation Tools: Includes preconfigured support for libraries like Spine for skeletal animations and Motion for smooth tweening and transitions. Creation Templates are perfect for developers who want to hit the ground running with a robust foundation, enabling them to focus on building amazing content rather than worrying about setup.","s":"What’s Included?","u":"/blog/create-cli","h":"#whats-included-1","p":777},{"i":790,"t":"For the creation templates we’re starting with support for general web-based applications but are planning to expand the template ecosystem to other platforms soon: Web Template: A general-purpose creation template (available now). Coming Soon: Discord Template: Build multiplayer applications for Discord using their SDK. Facebook Template: Create apps for Facebook Instant Games. YouTube Template: Develop YouTube Playables.","s":"🌍 Creation Templates for Every Platform","u":"/blog/create-cli","h":"#-creation-templates-for-every-platform","p":777},{"i":792,"t":"This project is based on amazing create-vite tool and inspired by the create-game project by Phaser. We are grateful for their work and the inspiration it provided.","s":"Acknowledgements","u":"/blog/create-cli","h":"#acknowledgements","p":777},{"i":794,"t":"Follow Zyie and PixiJS on social media for the latest updates. Join our vibrant community on Discord for real-time discussions and support.","s":"🌐 Stay Connected","u":"/blog/create-cli","h":"#-stay-connected","p":777},{"i":796,"t":"We are excited to announce the launch of the PixiJS Universe, an initiative to further enhance the capabilities of PixiJS and make it even easier for developers to create amazing games and apps. For years, PixiJS has been the most popular 2D renderer for the web, but it was always \"just a rendering engine.\" The community has created many great tools to help developers build games and applications with PixiJS, but we lacked the manpower to maintain and improve these tools, causing fragmentation in the community. To address this, Playco has assembled a dedicated team of developers who will work on PixiJS full-time. Over the next 12 months, we have more than ten projects planned, and in this announcement, we would like to introduce some of them.","s":"Introducing the PixiJS Universe!","u":"/blog/pixi-universe","h":"","p":795},{"i":798,"t":"We have several new projects in the works, and we are releasing them in four phases over the year. We are currently nearing the end of phase 1, which has seen the release of several exciting new tools and libraries for PixiJS:","s":"Phase 1​","u":"/blog/pixi-universe","h":"#phase-1","p":795},{"i":800,"t":"First up we are excited to announce that we will be releasing a beta version of our new website for PixiJS. The current documentation has suffered from long-term organic growth over the years with little structure and as such much of the PixiJS documentation is fragmented across multiple sites. This new website will put everything you need in one place and be easily searchable. We are also planning on improving the documentation and adding more guides and examples, as well as considering translating the documentation into other languages. If you have any ideas on how to improve the site please let us know! Github Repo","s":"PixiJS Website​","u":"/blog/pixi-universe","h":"#pixijs-website","p":795},{"i":802,"t":"Next up is PixiJS React. A library that provides a way to use PixiJS in React applications. PixiJS React is a continuation of the react-pixi library created by Patrick Brouwer, which has been widely used by the PixiJS community in React projects. PixiJS has taken over maintenance of the library and is dedicated to improving the library's performance, documentation, and support for new features. The library provides an easy-to-use interface that makes it easy for developers to create React applications with PixiJS. The library integrates all the core features of PixiJS and allows you to create custom components for 3rd party libraries. Github Repo","s":"PixiJS React​","u":"/blog/pixi-universe","h":"#pixijs-react","p":795},{"i":804,"t":"We have now released a new repository called \"PixiJS Open Games\". This is a collection of open-source games that showcases how to use PixiJS to create games and is released under the MIT license. The purpose of these games is to provide professional examples of how to use PixiJS for game development. The first two games released are a match-3 game and a bubble shooter game. These games not only demonstrate how to use PixiJS for game development but also how to use other libraries such as PixiJS UI and AssetPack. We also have more games planned for release, which will demonstrate how to use PixiJS with other libraries such as PixiJS Layout and PixiJS React. PixiJS Open Games will hopefully be a valuable resource for game developers who want to learn how to use PixiJS for game development and will also be a great source of inspiration for developers looking to create their own games using PixiJS. The project is available on GitHub for anyone who wants to explore the code or contribute to the project. Github Repo Play Puzzling Potions Play Bubbo Bubbo","s":"PixiJS Open Games​","u":"/blog/pixi-universe","h":"#pixijs-open-games","p":795},{"i":806,"t":"PixiJS UI is a new library for developers who want to create beautiful and functional user interfaces with PixiJS. The library includes a range of components such as buttons, checkboxes, sliders, text inputs, scroll views, lists, radio buttons, and progress bars, which can be easily integrated into your game. These components are highly customizable, allowing you to tweak the appearance and behaviour of each element to fit your game's specific needs. PixiJS UI has been used in all of the open-source games, so feel free to check these out for real-world examples. PixiJS UI Github Repo PixiJS Layout is another library that can make your life as a developer easier. This library enables you to create responsive layouts using PixiJS, which means you can design interfaces that adapt to different screen sizes and aspect ratios. PixiJS Layout works well with PixiJS UI, allowing you to combine both libraries to create complex, dynamic interfaces that respond to user input and screen changes. With PixiJS Layout, you have the flexibility to create resizable layouts that can be adjusted to fit any screen size or device. This means that your game's interface can look great on everything from small mobile devices to large desktop displays. PixiJS Layout is still under development but will be ready in the next few weeks PixiJS Layout Github Repo","s":"PixiJS UI & PixiJS Layout​","u":"/blog/pixi-universe","h":"#pixijs-ui--pixijs-layout","p":795},{"i":808,"t":"Finally, for phase 1 we are announcing AssetPack. Asset management is an important part of developing applications, and the new AssetPack library aims to make this process easier. AssetPack is a framework-agnostic library that can be used with any framework, including PixiJS, ThreeJS, and Phaser. It provides a range of features that help developers manage their assets efficiently. The key feature of AssetPack is the ability to automatically generate new assets on the fly. For example, you can provide it with a folder of individual images and it will generate sprite sheets, which can significantly improve the performance of your application. It also provides plugins to generate mipmaps, convert fonts to different formats, convert audio to different formats, compress images, and minify JSON. These features help developers optimize their assets for faster loading times, better performance, and improved user experience. We will soon be releasing a new blog post that provides more details on how to use it. With its many useful features and framework-agnostic design. However, if you want to get stuck in today then check out the GitHub repo Github Repo","s":"AssetPack​","u":"/blog/pixi-universe","h":"#assetpack","p":795},{"i":810,"t":"Phase 2 will begin shortly and aims to make it easier to work with PixiJS applications.","s":"Phase 2​","u":"/blog/pixi-universe","h":"#phase-2","p":795},{"i":812,"t":"Jumpstart is a new CLI tool being developed by the PixiJS team to simplify the process of creating new PixiJS applications. With this tool, developers will no longer need to set up complicated tooling or worry about setting up different bundlers and frameworks. The tool will handle all the setup for you, allowing you to focus on building your application. Jumpstart will be similar to other CLI tools such as Create-React-App or Create-Vue, which have become popular in the front-end development community. The tool will provide templates for different bundlers and frameworks, including webpack, parcel, rollup, and more. This will make it easy for developers to get started with PixiJS regardless of their preferred tools and workflows. With Jumpstart, you'll be able to create a new PixiJS application in just a few minutes and start building right away.","s":"PixiJS JumpStart​","u":"/blog/pixi-universe","h":"#pixijs-jumpstart","p":795},{"i":814,"t":"PixiJS dev tools will be a browser extension that is planned to be released soon to help developers debug their PixiJS applications. This tool aims to make it easier for developers to understand the inner workings of PixiJS, optimize their code, and follow best practices. It is designed to help developers diagnose performance issues and visualize the resources that their applications are consuming. One of the key features of the PixiJS Dev Tools is its ability to help developers understand the complex process of batching in PixiJS. Batching is a technique used to optimize the rendering of multiple objects in the same draw call. This process can be complicated to understand, especially for new developers. PixiJS Dev Tools aims to make it easier to debug and optimize the rendering of objects. Overall, PixiJS Dev Tools will be a powerful tool that will make it easier for developers to build high-performance, visually stunning applications with PixiJS. By providing developers with a deeper understanding of the inner workings of PixiJS, this toolset will help developers optimize their code and create more efficient and engaging applications.","s":"PixiJS Dev Tools​","u":"/blog/pixi-universe","h":"#pixijs-dev-tools","p":795},{"i":816,"t":"Phase 3 is where our long-term projects start to be revealed. These are major changes to the PixiJS ecosystem that we are incredibly excited about","s":"Phase 3​","u":"/blog/pixi-universe","h":"#phase-3","p":795},{"i":818,"t":"Comet will be a new editor that aims to make it easier than ever to design and create games and applications with PixiJS. With its intuitive and user-friendly interface, the editor is designed to appeal to both designers and developers, allowing both groups to collaborate and work more efficiently. One of the standout features of Comet is the visual interface it provides for creating and editing scenes, sprites, animations, and more. This means that designers can create and edit complex scenes without ever having to write a single line of code. The editor provides a range of tools and options for creating sprites, animations, and other game elements, making it easy to get started with creating a game or application. In addition, developers will appreciate the runtime player feature, which allows them to easily recreate scenes in their own applications. This makes it easy to test and iterate on designs, ensuring that the final product is both functional and visually appealing. And with multi-user, real-time collaboration, Comet makes it easy for teams to work together, sharing assets and ideas and creating high-quality games and applications in record time.","s":"Comet​","u":"/blog/pixi-universe","h":"#comet","p":795},{"i":820,"t":"PixiJS v8 will be the next major release that represents a complete rewrite of PixiJS from the ground up. The development team has leveraged their extensive experience over many years to make improvements and optimizations to the core PixiJS engine. The new version of PixiJS is designed to be faster and more efficient, providing a significant improvement in rendering performance compared to v7 (currently sitting at x2) One of the most exciting features of PixiJS v8 is the inclusion of first-class support for WebGPU, which is a new graphics API that is being developed by major browser vendors. This will enable developers to take advantage of advanced GPU capabilities, which can significantly improve the performance of graphics-intensive applications. In addition to WebGPU support, the PixiJS team has also made a significant effort to optimize the engine for the canvas renderer, which will be available as a first-class option for developers looking to reduce bundle size. Overall, PixiJS v8 represents a major leap forward for us, developers can expect a much faster and more efficient engine that is better suited for building complex, graphics-intensive applications.","s":"PixiJS v8​","u":"/blog/pixi-universe","h":"#pixijs-v8","p":795},{"i":822,"t":"Phase 4 represents a leap into new territory for PixiJS as we look to delve deeper into areas outside of strictly 2D rendering.","s":"Phase 4​","u":"/blog/pixi-universe","h":"#phase-4","p":795},{"i":824,"t":"For years, Goodboy (now Playco) has had an internal 3D engine called Odie that was built on top of PixiJS. We are now planning to open-source it, which is exciting for those of you who want to seamlessly mix 2D and 3D content in your games or applications. With PixiJS 3D, you will no longer need to switch between engines or frameworks to incorporate 3D elements in your project. Although this is a long-term project, the team is making progress and plans to share more information later in the year. This release will greatly expand PixiJS's capabilities and give developers even more flexibility when building their applications.","s":"PixiJS 3D​","u":"/blog/pixi-universe","h":"#pixijs-3d","p":795},{"i":826,"t":"Finally, we are thrilled to announce that we will be working on a new library called PixiJS Game Engine. This game engine aims to provide everything you would expect from a 2D/3D game engine and will offer many features and tools to make game development easier and more efficient. Some of the features of PixiJS Game Engine will include support for physics engines, audio, input handling, asset loading and management, state management, animation and tweening, and more.","s":"PixiJS Game Engine​","u":"/blog/pixi-universe","h":"#pixijs-game-engine","p":795},{"i":828,"t":"We've shared a lot of exciting news about new projects and updates coming to the PixiJS community. There's a lot to look forward to in the upcoming months. We want to extend our sincere thanks to the PixiJS community, its contributors, and Playco for making all of this possible. We're excited to see what you'll create with these new tools and resources, and we look forward to continuing to support and grow the PixiJS ecosystem. Be sure to check out the GitHub links mentioned above and stay tuned for more updates on the PixiJS Universe!","s":"Conclusion","u":"/blog/pixi-universe","h":"#conclusion","p":795},{"i":830,"t":"PixiJS v8 has taken speed to the next level with the release of its new ParticleContainer. This new feature brings a jaw-dropping performance boost, capable of rendering 100K+ without breaking a sweat. If you’ve got tons of elements to throw on the screen, you’re in for a treat!","s":"ParticleContainer - The New Speed Demon in PixiJS v8","u":"/blog/particlecontainer-v8","h":"","p":829},{"i":832,"t":"The key difference in PixiJS v8 is that the ParticleContainer doesn’t deal with sprites any more, it works with lightweight particles. While particles share many properties with sprites (like texture, position, anchor, scale, rotation, alpha and color), they cut out unnecessary overhead. The result is speed, pure and simple. How fast, you ask? Well, take a look on my machine (Macbook Pro M3): Sprites + Container: 200,000 at 60fps. Particles + ParticleContainer: 1,000,000 at 60fps! Yes, that’s a million bunnies on-screen, and honestly the main bottleneck at that point wasn’t even rendering but the logic behind the bouncing movement! Give this a spin and see for yourself: The key takeaway is that you can now render huge volumes of elements absurdly fast, making PixiJS v8 a perfect choice for high-performance games or visually intensive projects. And yes this is faster than the v7 particle container by over 3x! Please checkout the migration guide for more information on how to migrate your code to the new particle container.","s":"πŸš€ New ParticleContainer Design","u":"/blog/particlecontainer-v8","h":"#-new-particlecontainer-design","p":829},{"i":834,"t":"To get the most out of this performance beast, it’s essential to understand static vs. dynamic properties. PixiJS gives you full control over which properties update every frame (dynamic) and which don’t need constant updates (static). Here’s how they work: Static properties: Once set, they stay the same unless explicitly changed. By keeping them static, you reduce computational load, meaning faster rendering. This is your responsibility to update :) Dynamic properties: These are recalculated and uploaded to the GPU every frame regardless. By default, only the position is dynamic, but you can configure others if needed. The fewer dynamic properties you have, the faster the rendering will be!","s":"Speed Secret: Static vs. Dynamic Properties","u":"/blog/particlecontainer-v8","h":"#speed-secret-static-vs-dynamic-properties","p":829},{"i":836,"t":"Let’s walk through a simple example of how to get started: import { ParticleContainer, Particle, Texture } from 'pixi.js'; // Create a particle container with default options const container = new ParticleContainer({ // this is the default, but we show it here for clarity dynamicProperties: { position: true, // Allow dynamic position changes (default) scale: false, // Static scale for extra performance rotation: false, // Static rotation color: false // Static color } }); // Add particles const texture = Texture.from('path/to/bunny.png'); for (let i = 0; i < 100000; ++i) { let particle = new Particle({ texture, x: Math.random() * 800, y: Math.random() * 600, }); container.addParticle(particle); } // Add container to the Pixi stage app.stage.addChild(container); In this example, we create a ParticleContainer, set properties to static where possible, and generate a 100k particles. By using a shared texture (hello, sprite sheets!), we ensure that all particles share the same graphical assets, making rendering even more efficient.","s":"PixiJS v8 Particle Container Usage","u":"/blog/particlecontainer-v8","h":"#pixijs-v8-particle-container-usage","p":829},{"i":838,"t":"The ParticleContainer shines when you need insane numbers of visual elements on-screen, especially when you want them moving and interacting in real time. Whether you're building particle effects, swarms of characters, or abstract art installations, PixiJS v8 has you covered. The static vs. dynamic property system gives you granular control over performance, allowing you to fine-tune the balance between flexibility and speed. This is basically the fastest we could make it by still keeping allowing for different textures (via sprite sheets) and still empowering devs to manipulate the particles via JS and not having to move the movement to the GPU (which might be faster, but is more complex and less flexible). So even though we are choosing to call them particles, they are more like something in between a traditional particle and a classic sprite. This is ideal for projects where frame rate and rendering volume matterβ€”such as games, interactive apps, and high-volume data visualization. By controlling the dynamic properties of your particles, you can optimize your application’s performance to fit your needs.","s":"Reasons to Use ParticleContainer","u":"/blog/particlecontainer-v8","h":"#reasons-to-use-particlecontainer","p":829},{"i":840,"t":"The new ParticleContainer is a game-changer, but there are still some areas for improvement! For one, there is room to optimise further the static uploading of properties (you may notice the example above is slower when adding bunnys - but then speeds up once stable). We plan to expose how the particles are batched so that developers can add / remove attributes from the batch to make it even faster or add more flexibility and customization. But for now, this is a great starting point and we hope you enjoy the new ParticleContainer!","s":"Next Steps","u":"/blog/particlecontainer-v8","h":"#next-steps","p":829},{"i":842,"t":"PixiJS v8’s ParticleContainer is a game-changer when it comes to rendering at scale. Its ability to push millions of particles at full speed opens up a world of possibilities for game developers, animators, and creative coders. Get in, experiment with the new API, and see just how fast your visuals can fly! Ready to give it a spin? Try out the new ParticleContainer in PixiJS v8, and push the limits of performance in your projects!","s":"πŸŽ‰ Conclusion","u":"/blog/particlecontainer-v8","h":"#-conclusion","p":829},{"i":844,"t":"Follow Doormat23 and PixiJS on social media for the latest updates. Join our vibrant community on Discord for real-time discussions and support.","s":"🌐 Stay Connected","u":"/blog/particlecontainer-v8","h":"#-stay-connected","p":829},{"i":846,"t":"Get ready to push the boundaries of what's possible on the web! PixiJS v8 has landed, and it's a game-changer. Celebrating a decade of driving innovation, we've supercharged PixiJS with the latest technological advancements, making it faster, more robust, and ridiculously powerful. From the seamless integration of WebGPU to leveraging modern JavaScript for smoother development, PixiJS v8 is all about empowering you to create jaw-dropping web experiences with ease. It's not just an update; it's the future of 2D web graphics, today. Dive in and let PixiJS v8 elevate your projects to unseen heights. Let's make the web a more beautiful place, one pixi(el) at a time.","s":"PixiJS v8 Launches! πŸŽ‰","u":"/blog/pixi-v8-launches","h":"","p":845},{"i":848,"t":"It's hard to believe that PixiJS has been part of the open-source community for a whopping ten years. In that time, the digital landscape has evolved tremendously, and so has PixiJS. We've seen significant updates, like the transition to TypeScript, and we've overhauled major parts of the engine, such as asset loading and WebGL integration. Now, we're thrilled to unveil PixiJS v8, arguably our most substantial update ever. This release is not just a reflection on the shortcomings of v7, which has served us well, but an acknowledgment that there's always room for improvement. Over time, we've all encountered aspects of our code we wished we could refine. Often, the best solutions and insights emerge only after we've stepped back from the problem, allowing us to see the bigger picture. With PixiJS v8, our aim was to revisit and enhance the foundation of PixiJS, streamlining its core rather than just adding layers of code. Our vision for v8 was clear: Longevity: We designed v8 to stand the test of time, anticipating it will remain relevant and robust for another decade. Innovation with WebGPU: Embracing the latest in rendering technology, we've seamlessly integrated WebGPU, not as an add-on to our existing WebGL renderer but as a core paradigm, ensuring PixiJS remains at the cutting edge as WebGL phases out. Leveraging Modern JavaScript: The advancements in JavaScript have significantly simplified development. We've utilized features like object destructuring and options to make v8 cleaner and more powerful. Correcting Past Oversights: Every project has its lessons. With v8, we've addressed and rearchitected certain aspects of PixiJS, reducing complexity and enhancing functionality, particularly in areas we felt were overengineered in the past (looking at you, textures!). Boosting Performance: PixiJS is already renowned for its speed. With v8, we've unlocked even greater performance, making it faster across the board compared to v7. We're incredibly proud of PixiJS v8 and eager to share the improvements and new features with you. While there are some breaking API changes, we've provided a migration guide and ensured compatibility with v7 wherever possible. Get ready to experience the next level of 2D rendering with PixiJS v8!","s":"πŸš€ Revolutionizing Web Graphics: Welcome to PixiJS v8","u":"/blog/pixi-v8-launches","h":"#-revolutionizing-web-graphics-welcome-to-pixijs-v8","p":845},{"i":850,"t":"The new Docs for v8 can be found here Migration Examples Open Games","s":"πŸ”— Quick links","u":"/blog/pixi-v8-launches","h":"#-quick-links","p":845},{"i":852,"t":"There are numerous updates to discuss, more than can be covered in a single post! Below are the key highlights. For a more detailed exploration of these changes, be sure to follow the links provided above. πŸ“ˆ New Performance Bar​ The performance of v8 is faster for both renderers. This means by using v8 and the WebGL renderer, all the speed improvements apply! This is mainly as we have taken great care to make a more reactive render loop that only updates what it needs to. Check out the numbers here: CPU = time spent by the CPU rendering a single frame GPU = time spent by the GPU rendering a single frame Bunny Situation V7 CPU V8 CPU CPU Dif V7 GPU V8 GPU GPU dif 100k sprites all moving ~50ms ~15ms 233% ~9ms ~2ms 350% 100k sprites not moving ~21ms ~0.12ms 17417% ~9ms ~0.5ms 1700% 100k sprites (changing scene structure) ~50ms ~24ms 108% ~9ms ~2ms 350% These benchmark numbers are based on the Bunnymark test that you can try yourself. v7 Bunnymark v8 Bunnymark - WebGPU v8 Bunnymark - WebGL Repo πŸ–₯️ WebGPU Renderer​ We've implemented a WebGPU backend for rendering. Whilst this has created a better graphics paradigm under the hood and set us up for the future of rich web content, it's important to note that WebGPU does not automatically guarantee improved performance over WebGL in all scenarios, as PixiJS often encounters more limitations on the CPU side than the GPU. However, for scenes with numerous batch breaks, such as filters, masks, and blend modes, WebGPU may offer better performance due to its more modern to rendering. As WebGPU is relatively new, it's expected to enhance in speed over time, similar to the development of WebGL. It serves as a solid foundation for future advancements. πŸ“¦ New Package Structure​ No more \"lerna.\" PixiJS is now just one package with one import root: import {stuff} from β€˜pixi.js’. This change means we now have much better tree shaking during app compilation, reducing bundle size if not imported. Old: import { Sprite } from \"@pixi/sprite\"; import { Graphic } from \"@pixi/graphics\"; New: import { Sprite, Graphic } from \"pixi.js\";","s":"🎁 Whats New?","u":"/blog/pixi-v8-launches","h":"#-whats-new","p":845},{"i":854,"t":"When initializing a renderer, this process is now asynchronous. This serves two purposes: firstly, identifying and loading the necessary renderer code to minimize what is loaded for your users. We only load the one backend that your user is using. There's no point in loading all the WebGL stuff if they are using WebGPU. Secondly, the initialization of WebGPU itself is an asynchronous process, so we need to have a promise in there somewhere! import { Application, autoDetectRenderer } from \"pixi.js\"; const app = new Application(); (async () => { await app.init({ // application options }); // or const renderer = await autoDetectRenderer({}); // WebGL or WebGPU // do pixi things })(); 🌟 Scene Upgrades​ The concept of render groups has been introduced, enabling containers to utilize GPU for their transformations. This facilitates a true 2D hardware-accelerated camera, ideal for navigating large static worlds through panning and zooming, similar to how a camera moves in a 3D environment rather than moving the world itself. This approach can significantly enhance performance. const container = new Container({ isRenderGroup:true // this containers transform is now handled on the GPU! }) Another cool new change is that now blend modes and tints are inherited, much like transforms and alpha. This means you can now easily tint a container, and all its children will have the tint applied - same for blend modes, its as easy as: // will make all the children tinted red container.tint = 'red' // will make all the children have the add blend mode container.blendMode = 'add' Rendering to a texture with antialiasing has been simplified; you only need to enable the new antialiasing property by setting it to true during the creation of a render texture or when applying a filter, similar to the process used for creating your renderer. const texture = RenderTexture.create({ width:100, height:100, antialias:true // easy as that }) We have also added support for a wide range of Photoshop-like filters, This allows you to take your rendering to the next level! We have including all the classics: ColorBlend, ColorBurnBlend, ColorDodgeBlend, DarkenBlend, DifferenceBlend, DivideBlend, ExclusionBlend, HardLightBlend, HardMixBlend, LightenBlend, LinearBurnBlend, LinearDodgeBlend, LinearLightBlend, LuminosityBlend, NegationBlend, OverlayBlend, PinLightBlend, SaturationBlend, SoftLightBlend, SubtractBlend, VividLightBlend. It's important to mention that these are essentially filters at the core, so it's advisable not to overuse them to avoid potential slowdowns. import `pixi.js/advanced-blend-modes` // make sure to include them in you lib! (or cherry pick one!) myContainer.blendMode = 'color-burn` // easy! 🎨 Graphics Upgrades​ The Graphics API has undergone changes to become more intuitive and user-friendly, closely resembling the HTML Canvas 2D context API. For instance, drawing and filling a rectangle is simplified as follows: graphics .rect(50, 50, 100, 100) .fill('blue'); A GraphicsContext has been introduced, powering all graphics operations. Similar to how one texture can be used across many sprites, a single GraphicsContext can now be utilized by multiple Graphics objects, enhancing efficiency and flexibility. Support for SVG drawing has been added. For example: graphics.svg('M 100 350 q 150 -300 300 0'); Gradient fill support has been introduced, currently limited to linear gradients, allowing for more visually engaging designs. The new GraphicsPath class enables the drawing and sharing of shapes. This feature is particularly useful as it allows for the creation of paths that can then be transformed into Mesh geometry using the buildGeometryFromPath function, opening up new possibilities for intricate and detailed graphic designs. const path = new GraphicsPath() .rect(-50, -50, 100, 100) // create geometry from the path: const geometry = buildGeometryFromPath({ path, }); const mesh = new Mesh({ geometry, texture: Texture.WHITE, }); For more information on these graphics upgrades and guidance on how to adapt to the enhanced Graphics API, please refer to the migration guide, or why not jump in and play with some examples. πŸ“ Text Upgrades​ Text has been upgraded to allow for better performance and usability! We have also integrated HTMLText into v8 as standard. BitmapFonts can now be generated on the fly or installed upfront as you prefer. They dynamically add characters as the font's glyphs are required, saving on memory. The layout of bitmap text is almost identical to the layout of the default text now, making it easier to switch between the two depending on your needs. const myText = new BitmapText({ text: 'hello im a bitmap font!', // font will be dynamically created style:{ fontFamily: 'Outfit', fontSize: 12, fill: 'red', } }) Text fills and strokes now conform to the same fills and strokes as graphics. This means Gradients, textures, and all the fun ways you can fill and stroke graphics can now be applied to Text. const myText = new Text({ text: 'hello im some fancy text', // font will be dynamically created! style:{ fontFamily: 'Outfit', fontSize: 12, fill: { texture, color:'red'} // same as graphics api fills stroke: { width:3, color:'blue' } // same as graphics api strokes } })","s":"✨ We promise the Renderer will work","u":"/blog/pixi-v8-launches","h":"#-we-promise-the-renderer-will-work","p":845},{"i":856,"t":"As PixiJS v8 takes its first steps into the world, we're eager to see it grow with your feedback and contributions. Now we know things won't be perfect, but we're committed to quick responses on GitHub and Discord to any issues that arise, valuing your input to make PixiJS even better. A heartfelt thanks to our early adopters (everyone in here) for testing the limits of v8, to our dedicated contributors and team for their hard work. Your efforts and insights are invaluable to us. We could not have gotten here without you! A final big shout-out to PlayCo for their support in making this release a reality! Let's continue to innovate and push the boundaries of web graphics together. Your engagement is key to PixiJS's evolution, and we're excited to see where we can go with your help.","s":"🀝 What now? Get involved!","u":"/blog/pixi-v8-launches","h":"#-what-now-get-involved","p":845},{"i":858,"t":"To stay in the loop, we invite you to follow Doormat23 and PixiJS on social media, where we'll be unveiling more exciting updates shortly. Alternatively, you can join our vibrant community on Discord for direct engagement and real-time chit-chats.","s":"πŸ“² Keep in touch","u":"/blog/pixi-v8-launches","h":"#-keep-in-touch","p":845},{"i":860,"t":"We're thrilled to offer an exclusive preview of the future of 2D web graphics with the Beta release of PixiJS v8. Although not yet finalized, this Beta iteration is packed with killer performance improvements and features we're eager for you to start playing with! Over the course of a decadeβ€”yes, you read that right, ten years!β€”we've implemented significant changes to the PixiJS engine. But the advancements in this new release are among the most monumental we've ever made! Two driving factors catalysed our approach to re-engineering the codebase and rendering pipeline in v8:","s":"PixiJS v8 Beta! πŸŽ‰","u":"/blog/pixi-v8-beta","h":"","p":859},{"i":862,"t":"The newcomer WebGPU offers a substantial performance improvement over its predecessor, WebGL. It propels web computations and graphics into a new era, providing a more efficient and robust API. Soon, it will be the go-to method for rendering most GPU-powered content on the web. This shift is reminiscent of PixiJS's initial launch. At that time, WebGL was new and only available in a handful of desktop browsers, while Canvas was ubiquitous. PixiJS's standout feature was its ability to first attempt rendering with WebGL and then fall back to Canvas as a Plan B. This approach allowed PixiJS content to immediately benefit as WebGL gained traction. Fast forward to today, and WebGL is now available on 95% of browsers. History is repeating itself with WebGPU, currently supported in only a few desktop browsers and roughly 27% of the market. However, it's only a matter of time before it becomes universally supported. PixiJS aims to execute the same fallback strategy, allowing you to always leverage the best technology available without needing to rewrite your code. This is precisely what version 8 achieves and will future proof everything we make for another ten years :D","s":"1. 😍 Embracing WebGPU","u":"/blog/pixi-v8-beta","h":"#1--embracing-webgpu","p":859},{"i":864,"t":"PixiJS has always been synonymous with speed and high-performance graphics. With v8, we've revisited our architecture to optimize both static and dynamic rendering. While v7 is fast, it operates as a somewhat β€˜naΓ―ve’ renderer. v7 approach:​ Traverse the scene graph and make sure all the transforms are correct Traverse the scene graph a second time and do the following Build batches to render Upload the data to the GPU Draw the batch to the screen. v8 approach​ Update the transform of only things that changed Traverse the scene graph and construct a set of instructions. Upload all scene data to GPU in one go. Execute rendering based on the instructions. There are three key changes to this loop that give us a performance bump. First, we update only the elements that have changed. If nothing has moved, no code is executed, optimizing computational overhead. Second, if the scene graph remains unchanged in subsequent frames, we reuse the existing rendering instructions. This avoids the overhead of reconstructing these instructions for each frame. Third, if no elements in the scene change position, the data upload step (Step 3) is entirely skipped, thereby saving bandwidth and further reducing computational work. The net effect of these improvements? A decent performance leap across varying use-cases: CPU = time spent by the cpu rendering a single frame GPU = time spend by the gpu rendering a single frame Bunny Situation V7 CPU V8 CPU CPU Dif V7 GPU V8 GPU GPU dif 100k sprites all moving ~50ms ~15ms 233% ~9ms ~2ms 350% 100k sprites not moving ~21ms ~0.12ms 17417% ~9ms ~0.5ms 1700% 100k sprites (changing scene structure) ~50ms ~24ms 108% ~9ms ~2ms 350% These benchmark numbers are based on this Bunnymark test that you can try yourself! v7 Bunnymark v8 Bunnymark - WebGPU v8 Bunnymark - WebGL Repo Please have a play, you can fiddle with the parameters in the url to change the number of bunnies. Curious to see what numbers all of you get! Best of all, these improvements apply to WebGPU and the WebGL renderer. As with all of PixiJs’s party tricks, this all happens automatically :D","s":"2. πŸš€ Turbocharging Performance","u":"/blog/pixi-v8-beta","h":"#2--turbocharging-performance","p":859},{"i":866,"t":"While the two key drivers behind this overhaul were performance and usability, we didn't stop there. We've seized this opportunity to enhance the API and introduce a plethora of new features to the engineβ€”far too many to encapsulate in a single post! Stay tuned for upcoming blog posts where we'll delve deeper into these additional improvements and API refinements, empowering you to create even more remarkable projects. For a comprehensive overview of what's new, don't miss the release notes. As a crucial note, PixiJS v8 retains much of the familiar API despite undergoing significant internal updates. Our changes are geared toward making PixiJS more robust and user-friendly. When you encounter modifications, rest assured that the v7 methodology will continue to workβ€”you'll simply see a deprecation warning, guiding you towards optimal practices.","s":"But Wait, There's More!","u":"/blog/pixi-v8-beta","h":"#but-wait-theres-more","p":859},{"i":868,"t":"As we progress toward the release candidate, now is the perfect time for you to dive in and explore v8. Your feedback at this stage is invaluable for fine-tuning our engine. We invite you to share your thoughtsβ€”the good, the bad, and the uglyβ€”report bugs, and even contribute code. Together, we can elevate PixiJS to unprecedented heights. πŸ‘‡ Don't waitβ€”dive right in! Explore the PixiJS v8 Codebase on GitHub","s":"Over to you!","u":"/blog/pixi-v8-beta","h":"#over-to-you","p":859},{"i":870,"t":"via npm you can install the beta version like so: npm install pixi.js@prerelease-v8 then you can create the most appropriate renderer using the new autoDetectRenderer function: import { autoDetectRenderer } from \"pixi.js\"; async function init() { const renderer = await autoDetectRenderer({ // any settings }); // will return a WebGL or WebGPU renderer } Start experimenting with PixiJS v8 Beta today and join us in shaping the future of 2D web graphics! πŸŽ‰","s":"Steps to install:","u":"/blog/pixi-v8-beta","h":"#steps-to-install","p":859},{"i":872,"t":"\"To stay in the loop, we invite you to follow Doormat23 and PixiJS on social media, where we'll be unveiling more exciting updates shortly. Alternatively, you can join our vibrant community on Discord for direct engagement and real-time conversations.","s":"Keep in touch!","u":"/blog/pixi-v8-beta","h":"#keep-in-touch","p":859},{"i":874,"t":"We have exciting news for all animation enthusiasts and game developers! The Spine team has just smashed it out of the park with the release of Spine 4.2, which includes some truly great new features. The best part for us PixiJS users? We can start leveraging these remarkable features today in both v7 and v8! For those unfamiliar, Spine is the standard for creating stunning 2D animations. It offers an intuitive editor and a multitude of runtimes to ensure that your animations can be utilized across various platforms. PixiJS has supported Spine for almost as long as both have existed (around 10 years)! Personally, we have been shipping games with Spine for about that long as well. Initially, we maintained our own player. This worked well, but as Spine evolved and new releases were introduced, we had to invest considerable time and energy to modify our custom player. In the past year, the Esoteric team has been managing the v7 version of the player after PixiJS's elementalcode made the initial implementation on top of their excellent HTML5 runtime. This means that as these incredible updates are released, the PixiJS community can use them almost immediately! Here are a few of the exciting new features:","s":"PixiJS Joins the Spine 4.2 Physics Revolution! πŸš€","u":"/blog/pixi-js-hearts-spine","h":"","p":873},{"i":876,"t":"Spine 4.2 revolutionizes animation with built-in physics, allowing bones to move naturally by simulating real-world physics. This means: Automatic Secondary Motion: Save time and enhance your animations with automated movement for hair, clothing, and more. Dynamic Movement: Enjoy fluid and realistic physics that respond to character movements and animations.","s":"πŸ‹οΈβ€β™‚οΈ Physics in Spine","u":"/blog/pixi-js-hearts-spine","h":"#️️-physics-in-spine","p":873},{"i":878,"t":"You can now attach any PixiJS Container to a slot in your animation with a simple-to-use API. addSlotObject(slotName, object) removeSlotObject(slotName) getSlotObject(slotName)","s":"πŸ“Ž Attachments","u":"/blog/pixi-js-hearts-spine","h":"#-attachments","p":873},{"i":880,"t":"We have not forgotten about v8! Just as we engineered v8 with the goal of being the fastest WebGPU (and WebGL!) renderer available, we applied this same focus to the v8 implementation of Spine. Here are some impressive statistics: 50% Faster: Enjoy significant performance improvements, making it over 50% faster than the previous v7 version. 50% Less Memory: We've optimized memory usage, reducing it by over 50% compared to the current v7 version. We are proud to say that this is one of if not the fastest way to render Spine animations on the web πŸ†. Get ready to create smooth, high-performance animations with ease. We plan on handing this implementation back over to the Spine team once we have dotted all the i's and crossed the t's. The last missing feature is the dark-tint property, which is not currently taken into account when rendering in v8. Other than that, all other features are present. If you are not using dark-tint, then this version will work great on v8; we are already using it in production for our games! We included all the examples in the repo for you to play with here. You can also check out the live v8 examples here","s":"🏎️ v8 Spine Player Beta","u":"/blog/pixi-js-hearts-spine","h":"#️-v8-spine-player-beta","p":873},{"i":882,"t":"Follow Doormat23 and PixiJS on social media for the latest updates. Join our vibrant community on Discord for real-time discussions and support.","s":"πŸ“² Stay Connected","u":"/blog/pixi-js-hearts-spine","h":"#-stay-connected","p":873}],"index":{"version":"2.3.9","fields":["t"],"fieldVectors":[["t/740",[0,2.456,1,4.204,2,2.456,3,3.011,4,2.8,5,4.204,6,2.8,7,2.2,8,3.65,9,2.321,10,2.434,11,2.319,12,2.456,13,2.091,14,3.65,15,3.65,16,3.321,17,3.65,18,2.456,19,3.65,20,3.284,21,1.818,22,2.793,23,3.284,24,4.204,25,2.612,26,3.284,27,3.011,28,3.284,29,3.65,30,3.011,31,0.933,32,2.321,33,1.216,34,3.65,35,3.65,36,4.204,37,2.793,38,3.65,39,3.011,40,2.33,41,2.945,42,3.284,43,4.204,44,2.612,45,4.204,46,3.284,47,4.204,48,3.65,49,1.668,50,1.992,51,3.284,52,4.204]],["t/742",[4,2.842,6,2.842,7,1.504,8,2.496,9,1.587,10,1.243,16,2.249,22,1.91,23,4.022,25,1.786,26,4.463,28,2.246,40,1.19,53,1.786,54,2.875,55,2.875,56,3.732,57,2.496,58,2.671,59,1.68,60,0.18,61,2.875,62,2.246,63,2.496,64,2.875,65,2.496,66,1.786,67,2.059,68,1.945,69,1.11,70,4.778,71,2.875,72,2.496,73,2.875,74,1.91,75,2.496,76,1.051,77,2.496,78,2.246,79,2.875,80,2.875,81,3.079,82,2.875,83,2.875,84,2.875,85,4.299,86,2.875,87,1.786,88,2.246,89,1.43,90,1.43,91,2.875,92,2.875,93,1.859,94,2.875,95,1.68,96,2.875,97,2.875,98,2.875,99,3.079,100,3.358,101,2.246,102,2.875,103,5.149,104,2.875,105,2.875,106,3.732,107,2.059,108,1.68,109,0.898,110,0.864,111,2.246,112,2.875,113,2.875,114,2.875,115,2.496,116,2.856,117,2.875,118,1.786,119,1.786,120,2.875,121,2.875,122,4.299,123,2.496,124,4.299,125,2.875,126,2.875,127,3.732,128,2.875,129,2.059,130,2.875,131,2.875,132,2.875,133,2.875,134,2.496,135,2.875,136,4.299,137,2.875,138,1.68,139,1.504,140,1.91,141,2.875,142,2.059,143,1.91,144,1.504,145,2.496,146,2.496,147,2.496,148,2.059]],["t/744",[4,2.766,6,2.972,7,1.426,10,1.178,13,2.053,16,3.52,17,2.365,19,2.365,26,3.225,27,2.957,30,1.951,31,0.605,32,1.504,33,0.788,39,1.951,46,2.128,53,1.693,67,3.57,68,1.232,69,0.704,72,4.327,87,2.565,89,1.355,90,1.355,110,0.819,111,2.128,146,2.365,149,3.584,150,0.996,151,4.129,152,2.725,153,2.725,154,2.725,155,1.81,156,1.951,157,2.725,158,2.725,159,2.365,160,2.063,161,2.912,162,3.584,163,2.128,164,2.412,165,2.365,166,2.128,167,1.592,168,2.725,169,1.951,170,2.725,171,1.693,172,2.725,173,2.365,174,2.128,175,1.81,176,1.81,177,4.985,178,2.725,179,2.725,180,2.725,181,2.16,182,1.232,183,2.725,184,1.81,185,1.426,186,1.951,187,2.128,188,2.725,189,2.725,190,2.128,191,1.232,192,1.592,193,2.128,194,1.81,195,2.365,196,2.365,197,4.985,198,4.327,199,2.725,200,1.128,201,2.725,202,1.504,203,2.365,204,2.365,205,1.693,206,1.956,207,2.725,208,1.291,209,2.128,210,1.951,211,2.365,212,2.725,213,2.725,214,2.365,215,2.365,216,2.128,217,2.725,218,4.129,219,2.365,220,2.128,221,1.951,222,2.365,223,2.128,224,1.81,225,2.725,226,2.725,227,2.725,228,1.693,229,2.725,230,1.693,231,2.128,232,2.365,233,2.725,234,2.365,235,1.693,236,2.128,237,2.725,238,2.365]],["t/747",[4,3.297,21,2.347,90,2.699,239,6.214,240,5.755,241,5.755,242,3.887,243,4.24,244,4.711,245,4.711,246,3.887,247,5.427,248,5.427,249,5.427,250,3.171,251,4.711,252,5.427,253,5.427]],["t/749",[4,3.117,9,1.93,16,2.594,21,1.512,60,0.311,69,1.28,70,4.896,78,2.732,93,1.512,100,4.5,150,2.753,160,1.448,161,2.043,173,3.036,181,3.279,202,1.93,240,3.036,254,3.366,255,4.958,256,3.497,257,2.466,258,4.304,259,1.93,260,4.958,261,3.036,262,1.739,263,4.958,264,2.732,265,2.173,266,2.173,267,5.761,268,2.323,269,3.497,270,3.497,271,3.497,272,3.497,273,2.835,274,2.505,275,3.497,276,3.497,277,3.497,278,3.497,279,3.294,280,4.304,281,2.173,282,1.657,283,3.497,284,4.958,285,4.958,286,3.551,287,3.497,288,3.551,289,3.497,290,2.732,291,2.505]],["t/751",[4,3.572,6,2.72,7,2.861,12,3.195,76,1.998,144,2.861,200,2.264,273,2.473,292,3.916,293,2.72,294,3.633,295,2.88,296,2.861,297,3.397,298,3.916,299,5.468,300,5.468,301,3.195,302,4.747]],["t/753",[4,3.443,6,2.206,7,2.32,9,2.448,10,2.522,16,2.32,20,3.464,33,1.283,40,2.415,41,2.32,48,3.85,51,3.464,68,2.006,69,1.145,76,1.621,174,3.464,182,2.006,243,3.464,250,2.591,293,2.206,303,3.176,304,2.755,305,2.755,306,4.435,307,4.435,308,2.947,309,2.448,310,2.102,311,3.85,312,3.85,313,4.435,314,2.947,315,2.591,316,3.176,317,4.435,318,3.464,319,4.435,320,3.176,321,2.755,322,3.464,323,3.85,324,3.464,325,3.85,326,0.778,327,1.76,328,4.435,329,2.006,330,4.435]],["t/755",[33,1.669,60,0.361,89,2.871,200,2.389,329,2.611,331,2.871,332,4.509,333,3.372,334,3.372,335,2.29,336,3.186,337,3.372,338,2.389,339,3.835,340,2.29]],["t/758",[18,2.656,60,0.371,176,3.02,292,3.256,310,2.154,321,2.824,327,1.804,335,1.804,338,1.882,341,4.546,342,3.551,343,4.546,344,4.546,345,1.882,346,4.546,347,4.546,348,2.824,349,4.546,350,3.946,351,3.272,352,3.938,353,3.551,354,3.946,355,5.146,356,3.02,357,4.546,358,2.056,359,4.546,360,1.419,361,2.948,362,2.824,363,4.546,364,4.546,365,4.546,366,2.656,367,3.02,368,4.546,369,4.546,370,4.546,371,3.551,372,1.475,373,4.546,374,3.02,375,4.546]],["t/760",[11,1.576,22,1.918,31,1.359,33,0.835,49,1.145,60,0.359,65,2.506,69,1.113,89,1.436,90,1.436,99,2.068,108,2.519,144,2.7,155,1.918,160,1.195,192,1.687,196,2.506,202,2.38,206,1.368,208,2.043,224,1.918,230,1.793,242,2.068,250,1.687,251,3.743,254,2.519,268,1.918,273,1.306,280,3.743,282,2.043,304,3.806,315,1.687,320,2.068,321,1.793,325,2.506,329,1.306,348,1.793,351,1.593,352,3.429,354,2.506,361,1.436,367,1.918,376,2.887,377,1.793,378,2.887,379,2.887,380,2.255,381,2.506,382,2.506,383,1.793,384,2.887,385,2.887,386,2.506,387,2.506,388,2.887,389,2.068,390,1.306,391,2.068,392,2.068,393,2.506,394,2.887,395,4.48,396,2.506,397,3.368,398,2.887,399,2.506,400,2.887,401,2.506,402,4.312,403,2.849,404,2.255,405,2.506,406,2.887,407,2.887,408,2.068,409,2.887,410,2.887,411,2.887,412,4.312,413,2.887,414,2.506,415,1.793,416,2.506,417,1.918,418,2.887,419,2.887,420,2.255,421,1.918,422,2.887,423,2.887,424,2.506,425,2.068,426,2.887,427,2.506,428,2.887,429,2.887,430,2.865,431,2.865,432,3.368,433,2.255,434,2.887,435,2.887,436,1.918,437,1.918,438,1.687,439,2.255,440,2.506]],["t/762",[31,1.153,76,1.898,195,4.509,246,3.721,326,0.912,327,2.56,355,4.509,358,2.35,361,2.584,441,4.058,442,4.509,443,5.195,444,5.195,445,5.195,446,3.227,447,5.195,448,4.509,449,4.509,450,4.058,451,5.195,452,4.509,453,5.195,454,4.058,455,5.195,456,4.058,457,5.195,458,2.867,459,3.035]],["t/764",[32,1.375,37,1.655,50,1.181,60,0.156,66,1.548,69,0.643,109,1.472,110,0.749,115,2.163,139,2.017,149,2.163,150,2.59,167,1.456,171,1.548,175,1.655,185,2.017,206,2.515,273,1.127,274,1.784,279,2.561,282,1.181,290,1.946,293,1.917,295,1.077,310,1.181,314,1.655,326,0.828,358,1.127,360,0.778,421,1.655,431,3.526,458,1.375,460,3.855,461,2.163,462,0.988,463,2.491,464,2.491,465,2.491,466,1.304,467,2.252,468,3.101,469,3.801,470,3.855,471,3.011,472,1.375,473,1.946,474,1.456,475,2.163,476,2.491,477,2.491,478,2.491,479,3.011,480,2.163,481,2.491,482,3.011,483,2.561,484,3.011,485,3.011,486,3.855,487,1.655,488,2.491,489,1.181,490,2.491,491,1.946,492,1.784,493,3.855,494,2.491,495,1.946,496,2.491,497,2.491,498,1.784,499,2.491,500,2.491,501,1.946,502,1.946,503,2.491,504,2.163,505,2.491,506,2.491,507,2.163,508,1.784,509,3.855,510,2.163,511,1.946,512,2.163,513,2.491,514,1.946,515,2.163,516,2.491,517,2.491,518,4.205,519,6.07,520,4.607,521,3.855,522,2.491,523,2.491,524,4.715,525,2.491,526,2.491,527,2.491,528,2.491,529,1.784,530,2.491,531,2.491,532,2.491,533,1.946,534,2.491,535,2.491,536,2.491,537,1.655,538,1.127,539,2.491,540,2.491,541,2.163,542,2.491,543,1.946,544,2.163,545,2.491,546,2.163,547,2.491,548,2.491]],["t/766",[21,1.581,27,2.618,33,1.057,37,2.429,60,0.229,67,2.618,68,1.653,69,0.944,76,1.336,109,1.141,110,1.098,119,2.271,139,2.676,150,1.336,185,1.912,200,1.513,206,1.732,257,1.818,273,1.653,293,2.544,301,2.136,309,2.017,310,1.732,362,2.271,372,1.186,462,1.45,472,2.017,482,3.996,483,3.398,484,3.996,485,3.996,487,2.429,501,2.855,537,2.429,538,1.653,549,2.989,550,3.173,551,2.271,552,3.655,553,3.173,554,3.173,555,2.618,556,2.855,557,2.017,558,2.017,559,2.429,560,3.173,561,2.855,562,2.855,563,2.618,564,4.44,565,3.173,566,2.855,567,3.173,568,3.173,569,3.173,570,2.618,571,2.855,572,2.136,573,2.855,574,3.173,575,2.618,576,1.45,577,2.855,578,3.173,579,3.173,580,2.618,581,2.017,582,3.996,583,5.901,584,3.655,585,3.655,586,5.115,587,2.855,588,3.173,589,3.173]],["t/768",[21,2.097,60,0.304,109,1.514,150,1.772,202,2.676,206,2.298,223,3.788,259,2.676,340,1.924,467,2.833,468,2.833,537,3.221,590,6.179,591,4.849,592,2.676,593,4.209,594,4.426,595,4.849,596,4.849,597,4.849,598,4.849,599,3.788,600,3.788,601,4.209,602,4.849,603,6.179,604,4.426,605,4.849,606,4.849,607,6.179,608,3.473,609,3.012,610,4.849,611,3.473]],["t/770",[69,1.49,139,3.02,171,3.586,293,2.871,326,1.013,414,5.01,482,4.509,483,3.835,484,4.509,485,4.509,587,4.509,612,5.772,613,5.01,614,5.01,615,4.509]],["t/772",[16,1.522,21,1.258,35,2.526,60,0.182,93,1.258,100,4.49,111,2.273,150,2.563,164,1.7,175,1.933,182,1.316,193,2.273,210,2.084,211,2.526,228,3.571,314,1.933,326,1.204,345,1.205,348,1.808,374,1.933,408,2.084,425,2.084,454,2.273,462,2.057,468,4.287,473,2.273,474,1.7,489,1.379,491,2.273,492,2.084,510,3.765,518,3.819,592,1.606,614,3.765,616,2.91,617,2.91,618,2.882,619,2.084,620,3.445,621,2.882,622,1.933,623,2.91,624,2.91,625,2.91,626,2.273,627,4.338,628,2.526,629,2.91,630,4.338,631,4.338,632,2.882,633,3.107,634,4.338,635,4.338,636,2.91,637,2.91,638,2.91,639,2.526,640,2.91,641,2.91,642,2.91,643,2.91,644,2.91,645,2.91,646,3.765,647,2.91,648,4.338,649,2.526,650,2.91,651,2.91,652,1.933,653,4.338,654,3.107,655,2.91,656,2.91,657,2.084,658,2.91,659,2.526,660,2.526,661,2.91,662,2.91,663,2.273,664,2.526,665,2.91,666,2.91]],["t/774",[31,1.055,60,0.422,108,2.777,182,2.15,193,3.713,318,3.713,321,2.953,326,0.834,329,2.15,335,1.886,340,1.886,342,3.713,348,2.953,351,3.368,352,3.158,358,2.15,360,1.484,366,2.777,367,3.158,440,4.127,667,4.754,668,4.127,669,3.713,670,4.127,671,3.713,672,3.713,673,4.754,674,4.754,675,4.754,676,3.405,677,4.754,678,4.127,679,4.754,680,4.754,681,4.754,682,4.754,683,3.713,684,4.754,685,2.624]],["t/776",[33,1.669,60,0.361,89,2.871,200,2.389,329,2.611,331,2.871,332,4.509,333,3.372,334,3.372,335,2.29,336,3.186,337,3.372,338,2.389,339,3.835,340,2.29]],["t/778",[0,2.814,2,2.814,44,2.992,49,1.911,50,2.282,60,0.462,69,1.244,93,2.083,95,2.814,138,2.814,205,2.992,262,2.396,273,2.783,286,3.45,326,0.845,345,1.994,362,2.992,367,3.2,389,3.45,391,3.45,403,2.658,458,2.658,686,4.181,687,4.181,688,4.817,689,3.2,690,4.817,691,4.181,692,4.181,693,4.181,694,4.817,695,3.45,696,3.762,697,3.2,698,3.45]],["t/780",[9,2.98,21,1.709,32,2.182,44,2.456,60,0.414,69,1.888,93,1.709,95,2.31,123,3.432,138,2.31,155,2.626,160,1.636,191,1.788,234,3.432,242,3.867,262,2.686,281,2.456,286,2.831,288,2.831,315,2.31,326,0.948,331,1.966,345,1.636,404,4.218,405,3.432,437,2.626,450,3.088,561,3.088,562,3.088,570,2.831,692,3.432,695,2.831,696,4.804,697,2.626,699,2.626,700,3.088,701,3.432,702,3.088,703,3.432,704,2.626,705,3.953,706,5.4,707,4.086,708,5.4,709,5.4,710,3.953,711,3.953,712,3.432,713,2.626,714,3.953,715,3.432,716,3.088]],["t/782",[40,2.214,60,0.335,160,2.214,161,3.124,164,3.124,191,2.419,262,2.66,308,3.553,403,3.626,427,4.642,459,3.124,511,4.177,663,4.177,695,3.83,699,3.553,717,5.348,718,5.348,719,3.83,720,5.348,721,4.177,722,5.348,723,5.348,724,5.348,725,4.642]],["t/784",[60,0.443,76,1.715,77,4.073,150,2.447,160,1.943,167,2.742,169,3.361,236,3.665,257,2.334,262,2.334,266,2.915,288,3.361,403,2.59,575,3.361,576,1.862,660,4.073,695,3.361,699,3.118,702,3.665,703,4.073,726,3.361,727,4.073,728,3.361,729,4.693,730,4.693,731,4.073,732,3.665,733,4.693,734,3.665,735,4.073,736,4.693,737,3.665,738,4.693,739,4.693,740,4.693,741,4.693,742,4.073,743,2.915,744,3.665]],["t/786",[6,2.565,7,2.699,11,1.885,25,3.204,31,1.144,42,4.029,60,0.323,95,3.014,191,2.333,262,2.565,309,2.847,326,0.905,401,4.478,403,3.546,417,3.427,558,2.847,713,3.427,719,3.694,745,5.158,746,5.158,747,5.158,748,5.158,749,3.694,750,2.444,751,4.478,752,5.158,753,5.158,754,4.478,755,4.029]],["t/788",[4,1.955,6,2.676,7,2.815,11,1.437,25,2.443,49,1.56,60,0.337,95,2.297,101,3.071,116,2.612,118,2.443,139,2.057,167,2.297,187,3.071,191,1.778,194,2.612,257,1.955,282,1.863,291,2.816,308,2.612,309,2.17,327,1.56,340,2.134,377,2.443,403,2.17,404,3.071,508,4.392,557,2.17,558,2.969,704,2.612,737,3.071,749,2.816,751,3.413,755,3.071,756,5.38,757,3.932,758,2.612,759,3.932,760,3.071,761,3.932,762,3.932,763,3.413,764,3.932,765,3.932,766,3.413,767,2.816,768,3.413,769,3.932,770,3.413,771,4.202,772,3.932,773,2.612,774,3.932,775,2.612,776,3.932,777,3.413,778,3.413,779,3.413,780,3.932,781,3.413,782,2.612,783,3.413,784,3.071,785,2.816,786,3.932]],["t/790",[10,2.606,66,2.896,69,1.204,93,2.016,95,3.521,161,2.724,192,2.724,295,2.016,329,2.726,340,1.85,367,3.098,403,2.573,462,1.85,696,5.847,698,3.339,719,3.339,750,2.855,787,6.026,788,3.642,789,4.047,790,4.047,791,4.316,792,4.047,793,4.047,794,4.662,795,4.662,796,6.026,797,3.642,798,4.662,799,6.026,800,4.662,801,4.662]],["t/792",[9,3.186,62,4.509,66,3.586,69,1.777,262,3.422,288,4.134,358,2.611,784,4.509,802,5.772,803,3.02,804,5.772,805,5.01,806,4.509]],["t/794",[33,1.669,60,0.361,89,2.871,200,2.389,329,2.611,331,2.871,332,4.509,333,3.372,334,3.372,335,2.29,336,3.186,337,3.372,338,2.389,339,3.835,340,2.29]],["t/796",[2,2.401,3,2.943,10,1.777,11,2.292,31,0.912,33,1.189,40,1.701,41,2.15,42,3.21,50,1.947,60,0.439,69,1.061,87,2.553,108,2.401,109,1.283,148,2.943,161,2.401,191,2.508,279,2.73,295,2.397,304,2.553,310,1.947,338,2.295,358,1.859,360,1.283,389,2.943,576,1.63,685,2.268,721,3.21,750,1.947,784,3.21,797,3.21,807,3.567,808,3.567,809,4.11,810,2.553,811,3.21,812,2.044,813,2.401,814,2.15,815,2.268,816,2.401,817,2.943,818,4.11,819,4.11,820,4.11,821,4.11,822,4.11,823,2.943,824,4.11,825,3.21,826,2.401,827,3.567,828,3.567,829,2.943,830,3.21,831,4.11]],["t/798",[40,2.264,60,0.342,191,2.473,326,1.169,390,2.473,492,3.916,576,2.169,609,3.397,611,3.916,775,3.633,832,6.66,833,4.271,834,5.468,835,4.747,836,4.271,837,5.468,838,4.747,839,3.633,840,4.747,841,3.195]],["t/800",[2,2.545,3,3.119,21,1.883,31,0.966,59,2.545,60,0.361,90,2.166,108,2.545,144,2.279,160,1.803,182,1.97,224,2.894,230,2.706,250,2.545,259,2.404,296,2.279,320,3.119,326,1.011,345,1.803,352,4.567,381,3.781,387,5.003,395,3.781,397,3.402,439,3.402,458,2.404,576,1.728,594,3.119,788,3.402,813,2.545,833,3.402,842,3.402,843,4.355,844,3.119,845,3.402,846,4.355,847,4.355,848,3.402,849,2.894,850,4.355,851,4.355,852,4.355,853,3.119,854,3.781,855,4.355,856,4.355,857,4.355,858,4.355,859,3.781,860,4.355]],["t/802",[11,1.51,40,1.711,44,3.457,58,2.567,60,0.463,69,1.437,110,1.242,138,3.251,160,1.711,171,2.567,182,1.869,220,3.228,273,2.517,296,2.162,320,2.96,326,0.725,327,2.208,338,1.711,340,1.64,352,2.746,356,2.746,377,4.365,576,1.64,654,2.96,700,3.228,744,3.228,750,2.637,775,2.746,817,2.96,825,3.228,826,2.415,861,5.653,862,4.133,863,4.133,864,4.133,865,4.133,866,4.133,867,4.133,868,3.228,869,4.133,870,2.96,871,3.588,872,4.133,873,3.588]],["t/804",[4,1.683,11,1.77,13,2.813,31,0.751,59,2.83,60,0.469,69,1.25,93,1.463,144,1.77,174,2.643,182,2.19,192,1.977,257,1.683,259,1.867,262,2.409,273,3.075,293,2.813,294,3.218,295,3.151,296,1.77,310,1.603,326,0.594,374,2.248,386,2.937,390,1.53,433,2.643,462,1.342,508,2.423,619,2.423,622,2.248,652,2.248,775,3.218,792,2.937,803,3.557,805,2.937,830,2.643,861,2.643,874,4.418,875,2.643,876,3.383,877,3.383,878,3.383,879,3.383,880,3.383,881,3.383,882,2.643,883,3.383,884,3.383,885,4.843,886,2.643,887,3.383,888,3.383,889,3.383,890,3.383,891,1.77,892,2.937,893,3.469,894,3.383,895,3.383,896,4.843]],["t/806",[11,1.055,12,1.687,13,1.436,39,2.068,50,1.368,58,1.793,59,1.687,60,0.453,68,1.95,69,1.478,74,1.918,76,1.055,93,1.248,101,2.255,129,2.068,143,1.918,144,1.51,155,1.918,182,1.95,200,1.195,208,1.368,230,1.793,232,2.506,235,1.793,257,1.436,293,1.436,294,1.918,295,1.248,296,2.256,297,1.793,301,1.687,310,1.368,315,1.687,326,0.507,360,0.901,374,1.918,377,3.557,383,1.793,415,2.679,416,2.506,458,1.593,508,4.101,558,2.849,572,1.687,608,2.068,611,2.068,618,1.918,621,1.918,676,2.068,766,2.506,767,2.068,771,2.255,775,1.918,803,1.51,826,1.687,853,2.068,868,2.255,871,3.743,886,4.786,897,2.506,898,2.506,899,5.161,900,2.068,901,4.312,902,2.887,903,2.887,904,2.506,905,2.887,906,2.887,907,2.887,908,2.887,909,2.887,910,2.255,911,2.887,912,2.255,913,2.887,914,2.887,915,2.887,916,2.887,917,2.887,918,2.887,919,3.743,920,4.312,921,2.887,922,2.887,923,2.887,924,2.506,925,4.312,926,2.679,927,2.506,928,2.887,929,2.887,930,2.887,931,2.506,932,2.887,933,2.887,934,2.887,935,2.887,936,2.887,937,2.887,938,2.506,939,2.887,940,1.918,941,2.887]],["t/808",[0,1.923,4,3.032,6,1.637,7,1.722,11,1.735,16,2.914,23,3.709,25,2.045,28,2.571,30,2.357,31,0.73,32,1.817,41,1.722,44,3.46,50,1.56,51,2.571,56,4.835,57,4.122,58,2.045,60,0.206,62,2.571,70,2.571,76,1.203,81,2.357,106,2.857,108,1.923,110,1.427,127,2.857,139,1.722,162,2.857,176,2.187,182,2.148,184,2.187,206,1.56,228,2.045,257,1.637,273,1.489,296,2.484,297,2.045,304,2.95,305,2.045,314,2.187,326,0.977,327,2.21,351,1.817,360,1.028,362,2.045,377,2.95,415,2.045,448,2.857,492,2.357,538,1.489,582,2.571,621,3.155,652,2.187,728,2.357,750,1.56,758,2.187,767,2.357,791,2.357,833,2.571,839,2.187,900,2.357,942,2.857,943,2.571,944,3.292,945,2.045,946,3.292,947,1.923,948,2.357,949,4.835,950,2.571,951,3.292,952,3.292,953,2.571,954,2.357,955,4.748,956,4.748,957,3.292,958,3.292,959,2.857,960,2.571,961,3.292,962,3.292]],["t/810",[50,2.848,60,0.376,358,2.718,360,1.876,750,2.848,839,3.993,945,3.734,963,6.01,964,6.01,965,4.695]],["t/812",[9,3.567,11,1.902,13,1.865,21,1.621,31,0.832,32,2.069,59,2.191,60,0.405,68,1.696,69,1.544,119,2.329,138,2.191,143,2.491,160,2.155,187,2.929,191,2.355,236,2.929,254,2.191,286,3.729,308,2.491,309,2.874,326,1.05,338,1.552,360,1.171,392,2.685,393,3.255,403,2.069,421,2.491,459,2.191,495,2.929,621,3.459,652,2.491,657,2.685,685,2.069,697,2.491,699,2.491,702,2.929,721,2.929,727,4.52,728,2.685,737,2.929,750,1.777,754,3.255,758,3.459,838,3.255,861,2.929,966,5.982,967,3.255,968,3.255,969,3.255,970,3.75,971,3.75,972,4.52,973,2.929,974,3.75,975,3.255,976,3.75,977,3.75,978,3.75,979,3.75,980,3.255,981,3.75]],["t/814",[9,2.621,11,2.597,31,0.73,32,2.621,34,2.857,37,2.187,50,2.639,53,2.045,58,2.045,60,0.453,69,0.85,109,1.482,110,1.427,161,1.923,191,2.758,235,2.045,244,5.293,303,2.357,304,3.788,305,3.788,324,2.571,326,0.578,327,1.306,331,1.637,345,1.363,360,1.739,391,3.989,417,2.187,438,1.923,446,2.045,483,2.187,592,1.817,594,2.357,599,2.571,620,2.187,743,2.045,750,2.889,791,2.357,830,2.571,874,2.571,891,2.484,945,2.95,947,1.923,948,2.357,969,2.857,982,3.292,983,4.748,984,4.748,985,4.748,986,2.857,987,3.292,988,3.292,989,4.748,990,3.292,991,4.122,992,2.857,993,2.857,994,2.857,995,2.857,996,2.571,997,3.292,998,3.292,999,2.857]],["t/816",[2,3.427,40,2.428,60,0.367,208,2.779,459,3.427,698,4.2,726,4.2,839,3.896,844,4.2,845,4.581,882,4.581,1000,5.865,1001,5.091]],["t/818",[11,1.718,16,1.699,30,2.326,31,1.043,33,1.36,44,2.921,49,1.288,50,1.539,53,2.017,60,0.203,68,1.469,69,1.214,118,2.921,119,3.764,138,3.229,163,2.537,164,1.897,171,2.017,191,1.469,200,1.344,206,1.539,210,2.326,220,3.673,221,2.326,230,2.017,235,2.017,281,2.017,295,2.033,326,0.57,327,1.288,345,1.344,358,2.127,360,1.014,383,3.434,415,2.921,438,1.897,474,1.897,556,2.537,557,1.792,620,2.158,671,2.537,697,2.158,750,2.619,758,2.158,767,2.326,803,2.46,859,2.819,868,3.673,891,1.699,898,2.819,900,2.326,926,2.017,945,2.017,1002,5.527,1003,4.798,1004,2.537,1005,3.248,1006,4.702,1007,2.819,1008,3.248,1009,2.819,1010,3.248,1011,4.798,1012,3.124,1013,3.248,1014,3.248,1015,3.248,1016,3.248,1017,2.819,1018,2.819,1019,3.248,1020,2.326,1021,3.248,1022,2.819,1023,2.819,1024,3.248,1025,3.248,1026,3.248,1027,3.248,1028,3.248,1029,2.537,1030,2.819,1031,3.248,1032,3.248]],["t/820",[11,2.009,13,1.601,18,2.73,20,2.514,31,1.037,41,1.684,53,2,60,0.432,90,1.601,99,2.305,108,1.881,109,1.005,110,1.404,129,2.305,160,1.332,192,1.881,235,2,259,2.579,282,1.525,305,2,309,1.777,316,2.305,326,0.82,327,1.277,340,1.853,345,1.332,351,1.777,360,1.005,361,1.601,372,1.785,390,1.456,417,2.139,421,2.139,437,2.139,466,1.684,483,2.139,489,2.606,538,2.113,576,1.277,604,2.305,609,2,619,2.305,671,2.514,672,2.514,685,2.579,715,2.794,726,3.939,735,2.794,743,2.902,750,2.214,781,2.794,811,2.514,813,1.881,815,1.777,816,3.213,826,1.881,841,1.881,849,2.139,870,2.305,954,2.305,960,2.514,967,2.794,994,2.794,1033,4.055,1034,2.794,1035,3.219,1036,3.219,1037,3.219,1038,2.305,1039,2.514,1040,3.219,1041,3.219,1042,3.219,1043,4.055,1044,2.444,1045,3.219,1046,2.794,1047,3.219,1048,3.219,1049,1.881,1050,4.055,1051,2.514,1052,2.794,1053,2.514,1054,3.219]],["t/822",[60,0.361,109,1.802,315,3.372,326,1.013,814,3.02,839,3.835,996,4.509,1033,5.01,1053,4.509,1055,5.772,1056,5.772,1057,5.01,1058,4.509,1059,5.772,1060,5.772]],["t/824",[11,1.527,21,1.808,31,1.244,49,1.658,60,0.351,140,2.777,186,2.994,257,2.079,262,2.789,291,2.994,293,2.079,294,2.777,295,1.808,301,2.442,309,2.307,353,3.265,366,2.442,390,1.891,420,3.265,462,2.225,557,2.307,580,2.994,615,5.283,685,2.307,750,2.657,785,2.994,788,3.265,789,3.629,811,3.265,812,2.079,813,2.442,814,2.187,816,2.442,823,2.994,836,3.265,841,2.442,844,2.994,845,3.265,875,3.265,910,3.265,968,3.629,972,3.629,1061,4.18,1062,4.18,1063,3.629,1064,3.629,1065,4.18,1066,3.629,1067,3.629,1068,4.18,1069,3.629,1070,4.18,1071,4.18,1072,4.18,1073,2.994]],["t/826",[3,3.276,6,2.275,7,3.114,13,2.275,25,2.842,31,1.321,38,3.971,41,2.393,50,2.168,60,0.373,139,2.393,191,2.069,326,0.803,327,2.361,340,1.815,360,1.428,377,2.842,399,3.971,408,3.276,652,3.039,672,3.573,676,3.276,743,2.842,755,3.573,773,3.039,779,3.971,803,3.801,816,4.094,853,3.276,875,3.573,942,3.971,945,2.842,1067,3.971,1074,3.573,1075,4.575,1076,3.573,1077,3.971]],["t/828",[2,2.56,31,0.972,40,1.814,49,1.738,60,0.432,69,1.131,76,1.601,142,3.138,145,3.804,181,2.292,182,1.982,191,1.982,257,2.179,297,2.722,315,3.381,316,4.144,326,1.015,335,2.296,338,2.395,340,1.738,436,2.911,599,3.423,669,3.423,670,3.804,683,3.423,686,3.804,689,2.911,698,3.138,793,3.804,808,3.804,823,3.138,828,3.804,841,2.56,980,3.804,1078,2.418,1079,5.786,1080,3.804,1081,3.423,1082,3.804,1083,4.382,1084,3.804,1085,3.804,1086,3.138,1087,3.804,1088,2.911,1089,3.804]],["t/830",[60,0.325,109,1.622,110,1.561,164,3.035,206,2.462,326,1.133,356,3.451,372,1.686,390,2.35,498,3.721,549,3.035,557,2.867,558,2.867,581,2.867,649,4.509,668,4.509,826,3.035,1090,5.195,1091,4.509,1092,4.509,1093,5.195,1094,5.195,1095,3.721,1096,4.509,1097,5.195,1098,5.195,1099,5.195,1100,5.195]],["t/832",[31,1.057,40,1.369,41,1.73,49,1.312,60,0.298,76,1.208,109,1.032,110,0.994,150,1.741,165,2.87,166,2.583,167,1.932,181,1.73,186,2.368,250,1.932,265,2.054,295,1.43,315,1.932,326,0.58,366,1.932,372,1.546,430,2.197,431,2.197,437,2.197,438,1.932,458,1.825,462,1.312,466,1.73,467,1.932,468,3.262,469,2.368,529,2.368,533,2.583,538,1.496,549,2.783,550,2.87,551,3.469,557,1.825,558,1.825,563,3.412,576,1.312,581,1.825,588,2.87,611,2.368,620,2.197,632,2.197,633,2.368,704,2.197,742,2.87,812,1.644,891,1.73,947,2.783,1012,3.71,1050,2.87,1073,2.368,1101,3.307,1102,3.307,1103,3.307,1104,3.307,1105,2.87,1106,3.307,1107,3.307,1108,3.412,1109,3.307,1110,3.307,1111,3.307,1112,3.307,1113,3.307,1114,3.307,1115,4.764,1116,3.307,1117,4.764,1118,3.307,1119,2.87,1120,3.307,1121,3.307,1122,3.307,1123,2.583,1124,3.307,1125,3.307,1126,2.87,1127,3.307,1128,2.583,1129,2.87,1130,2.583,1131,3.307,1132,3.307,1133,3.307,1134,3.307,1135,3.307,1136,3.307,1137,3.307,1138,3.307]],["t/834",[21,1.797,60,0.26,63,3.608,76,1.519,88,3.247,99,2.977,109,1.744,110,1.249,150,1.519,156,2.977,205,3.47,216,3.247,254,2.428,265,4.373,268,2.761,279,2.761,335,1.649,358,1.88,391,2.977,449,3.608,472,3.724,495,3.247,538,2.527,571,3.247,572,4.113,573,3.247,575,2.977,576,1.649,592,2.294,632,2.761,1049,2.428,1088,2.761,1139,4.156,1140,4.156,1141,4.156,1142,4.001,1143,4.156,1144,4.156,1145,4.156,1146,4.156,1147,3.608,1148,3.608,1149,4.156,1150,4.156,1151,4.156,1152,4.156,1153,4.156,1154,4.156,1155,4.156]],["t/836",[16,1.655,22,2.101,31,0.702,49,1.255,69,1.191,93,1.368,109,0.987,110,0.95,150,2.899,184,3.065,185,1.655,202,2.546,208,1.499,228,1.965,254,1.848,265,1.965,266,1.965,268,3.617,281,1.965,326,0.809,348,1.965,366,1.848,436,2.101,442,2.746,468,3.181,469,4.286,472,3.303,518,3.065,520,4.726,529,3.304,537,2.101,549,3.181,551,3.382,563,4.286,572,1.848,592,1.746,632,3.065,633,3.304,654,2.265,669,2.471,697,2.101,704,2.101,707,2.101,743,1.965,812,1.573,949,2.746,953,2.471,1095,2.265,1105,4.004,1156,3.163,1157,3.163,1158,3.163,1159,3.163,1160,2.746,1161,3.163,1162,3.163,1163,2.746,1164,3.163,1165,3.163,1166,4.613,1167,3.163,1168,3.163,1169,3.163,1170,3.163,1171,2.746,1172,3.163,1173,2.746,1174,3.163]],["t/838",[21,1.45,31,1.067,33,0.97,37,2.227,40,1.388,60,0.21,67,2.401,68,2.176,74,2.227,107,2.401,109,1.047,110,1.445,190,2.619,200,1.388,210,2.401,216,2.619,222,2.91,228,2.989,235,2.083,257,1.667,265,2.083,295,1.45,301,1.959,305,2.083,309,1.85,360,1.047,372,1.088,438,1.959,472,1.85,487,2.227,538,1.516,543,2.619,549,1.959,551,3.496,553,2.91,554,2.91,555,2.401,556,2.619,557,1.85,558,1.85,559,2.227,560,2.91,561,2.619,562,2.619,563,3.446,564,2.91,565,2.91,566,2.619,567,2.91,568,2.91,569,2.91,570,2.401,571,2.619,572,2.811,573,2.619,574,2.91,575,2.401,576,1.33,577,2.619,578,2.91,579,2.91,580,3.446,581,1.85,608,3.446,621,2.227,626,2.619,732,3.758,734,2.619,797,2.619,812,1.667,919,2.91,953,2.619,993,2.91,1049,1.959,1128,2.619,1142,2.401,1175,3.352,1176,2.619,1177,3.352,1178,3.352,1179,3.352,1180,2.91,1181,3.352,1182,3.352,1183,3.352,1184,3.352,1185,3.352,1186,3.352,1187,4.811,1188,3.352,1189,3.352,1190,3.352,1191,3.352,1192,3.352]],["t/840",[11,1.661,31,1.009,142,3.256,148,3.256,150,1.661,156,3.256,159,3.946,160,1.882,184,3.02,202,3.272,203,3.946,224,3.02,238,3.946,258,3.946,265,2.824,301,2.656,310,2.154,312,3.946,326,1.04,345,1.882,360,1.419,380,3.551,462,1.804,472,2.509,538,2.056,546,3.946,549,3.463,551,2.824,608,3.256,719,3.256,803,2.378,812,2.261,1038,3.256,1058,3.551,1123,3.551,1193,3.551,1194,4.546,1195,4.546,1196,4.546,1197,4.546,1198,3.551,1199,4.546,1200,4.546,1201,4.546,1202,3.551,1203,3.551]],["t/842",[11,1.726,12,2.759,40,1.955,60,0.381,75,4.1,76,1.726,109,1.475,110,1.419,160,1.955,181,2.471,279,3.138,282,2.238,326,1.066,372,1.533,501,3.689,549,3.55,551,2.934,581,2.607,589,4.1,633,3.383,803,3.179,940,3.138,948,3.383,950,3.689,1073,3.383,1108,3.383,1129,4.1,1193,3.689,1204,4.723,1205,4.746,1206,4.723,1207,4.723,1208,4.1,1209,4.723,1210,4.723,1211,4.723,1212,3.689,1213,4.1]],["t/844",[33,1.669,60,0.361,89,2.871,200,2.389,329,2.611,331,2.871,333,3.372,334,3.372,335,2.29,336,3.186,337,3.372,338,2.389,339,3.835,340,2.29,1214,4.134]],["t/846",[0,2.361,10,2.884,13,2.01,31,1.216,33,1.169,40,1.673,49,1.603,60,0.418,69,1.043,89,2.01,169,2.894,194,2.685,205,2.51,298,2.894,303,2.894,311,3.508,345,1.673,360,1.262,372,2.019,436,2.685,489,1.915,538,1.828,716,3.157,760,3.157,782,2.685,803,2.114,814,2.114,854,3.508,897,3.508,940,2.685,1044,2.114,1078,2.23,1091,3.508,1092,3.508,1176,3.157,1193,3.157,1205,3.157,1215,3.508,1216,3.508,1217,4.041,1218,4.133,1219,4.041,1220,3.508,1221,3.508,1222,3.508,1223,4.041,1224,4.041,1225,2.894,1226,4.041,1227,4.041,1228,3.508,1229,4.041,1230,2.685,1231,3.508,1232,3.508,1233,4.041,1234,3.508,1235,4.041]],["t/848",[6,1.117,13,1.117,18,1.312,31,0.498,33,1.276,49,0.891,53,1.395,59,1.312,60,0.417,68,1.016,76,0.82,87,1.395,89,1.117,107,1.608,109,1.11,110,1.068,139,1.175,147,1.949,163,1.754,169,1.608,176,1.492,181,1.175,194,1.492,202,1.239,205,1.395,208,1.064,224,1.492,245,1.949,262,1.117,264,1.754,281,1.395,282,1.064,292,1.608,293,1.117,294,1.492,298,1.608,303,1.608,326,0.394,327,1.41,335,0.891,338,0.93,350,1.949,360,0.701,361,1.117,366,1.312,372,2.109,380,1.754,390,1.016,430,1.492,431,1.492,436,1.492,441,1.754,446,1.395,458,1.239,462,0.891,466,2.308,491,1.754,498,1.608,502,1.754,538,1.016,576,0.891,581,1.239,618,1.492,619,1.608,646,1.949,689,2.361,725,1.949,726,1.608,749,1.608,782,1.492,806,1.754,810,1.395,812,1.117,813,1.312,814,1.175,815,1.239,816,1.312,826,1.312,829,1.608,835,1.949,840,1.949,870,2.545,891,1.859,912,1.754,940,1.492,954,1.608,960,1.754,1001,1.949,1020,1.608,1038,1.608,1039,1.754,1044,1.859,1058,1.754,1064,1.949,1074,1.754,1078,3.587,1081,1.754,1096,1.949,1218,1.492,1220,1.949,1222,1.949,1225,1.608,1228,3.085,1236,2.245,1237,2.245,1238,2.245,1239,2.245,1240,1.949,1241,2.245,1242,2.245,1243,2.245,1244,2.245,1245,2.577,1246,2.245,1247,2.245,1248,1.949,1249,2.245,1250,2.245,1251,2.245,1252,2.245,1253,2.245,1254,3.554,1255,2.245,1256,2.245,1257,2.245,1258,1.949,1259,2.245,1260,2.245,1261,1.754,1262,2.245,1263,2.245,1264,2.245,1265,2.245,1266,2.245,1267,2.245,1268,2.245,1269,2.245,1270,2.245,1271,2.245,1272,2.245,1273,2.245,1274,2.245,1275,1.949,1276,1.949,1277,1.949,1278,1.949,1279,2.245,1280,2.245,1281,1.949,1282,1.754,1283,2.245,1284,2.245,1285,2.245,1286,3.085,1287,2.245,1288,2.245,1289,2.245,1290,2.245,1291,2.245,1292,1.608,1293,1.949,1294,2.245,1295,2.245,1296,2.245,1297,2.245,1298,2.245,1299,2.245,1300,2.245,1301,1.949,1302,1.754,1303,2.245,1304,2.245]],["t/850",[144,3.171,185,3.171,293,3.014,295,2.621,326,1.064,372,1.967,424,5.261,430,4.026,664,5.261]],["t/852",[10,0.879,13,1.011,31,1.234,33,1.194,59,1.187,60,0.205,66,1.262,74,1.35,76,0.743,81,1.456,93,0.879,109,1.479,110,1.423,129,1.456,142,1.456,150,2.412,160,0.841,185,1.063,194,1.35,208,0.963,228,2.039,231,1.587,241,2.848,246,1.456,254,1.187,261,1.764,266,3.23,296,1.063,297,1.262,302,1.764,310,0.963,326,0.831,331,1.011,335,1.302,345,1.358,351,2.278,356,1.35,360,0.634,361,1.011,362,1.262,372,1.804,374,1.35,382,1.764,383,1.262,452,1.764,456,1.587,462,1.302,466,2.159,467,1.187,474,2.411,475,1.764,489,0.963,538,0.919,555,2.35,559,2.18,570,1.456,576,1.302,581,1.811,657,1.456,707,2.18,731,1.764,749,1.456,785,1.456,806,1.587,810,1.262,815,1.811,817,1.456,848,2.563,849,1.35,926,2.039,943,1.587,947,1.187,959,1.764,973,1.587,1011,1.764,1012,2.742,1020,1.456,1044,2.909,1049,3.248,1052,1.764,1076,1.587,1078,1.122,1086,1.456,1087,1.764,1095,2.956,1130,1.587,1142,2.35,1202,1.587,1212,1.587,1218,2.18,1225,1.456,1230,2.18,1245,2.768,1277,1.764,1292,1.456,1305,3.281,1306,2.032,1307,2.032,1308,2.032,1309,2.032,1310,2.032,1311,2.032,1312,2.032,1313,1.456,1314,4.826,1315,2.848,1316,1.764,1317,1.764,1318,2.848,1319,2.848,1320,1.764,1321,1.764,1322,3.583,1323,2.848,1324,2.563,1325,1.764,1326,1.764,1327,1.764,1328,1.764,1329,1.764,1330,1.764,1331,1.587,1332,1.764,1333,1.764,1334,1.764,1335,4.112,1336,1.764,1337,1.764,1338,2.032,1339,2.032,1340,2.032,1341,2.032,1342,2.032,1343,2.032,1344,2.032,1345,2.032,1346,1.764,1347,2.032,1348,1.764,1349,1.764,1350,2.032,1351,2.032,1352,1.764,1353,2.032,1354,2.032,1355,1.764,1356,1.587,1357,2.032,1358,2.032,1359,1.764,1360,2.032,1361,2.032,1362,2.032,1363,2.848,1364,2.032]],["t/854",[12,0.657,21,0.859,29,0.976,31,0.592,32,1.473,39,0.805,41,0.588,49,0.446,50,0.533,58,1.234,68,0.509,69,0.29,74,0.747,88,0.878,93,1.154,95,1.161,107,0.805,109,0.62,110,0.597,119,0.699,134,2.317,138,1.559,139,1.04,144,0.588,150,2.737,160,0.466,171,1.234,175,0.747,184,0.747,186,0.805,198,0.976,202,1.473,206,0.533,208,0.533,214,0.976,215,0.976,221,0.805,230,0.699,250,0.657,266,1.234,268,0.747,274,0.805,281,0.699,282,1.744,301,0.657,314,0.747,326,0.902,340,1.059,345,1.105,348,0.699,351,0.621,360,0.833,371,2.085,372,0.365,408,0.805,415,1.234,425,0.805,430,0.747,431,0.747,437,0.747,456,0.878,461,1.725,462,1.953,467,1.161,468,1.559,469,2.911,471,1.552,472,0.621,473,2.085,474,0.657,479,0.878,487,0.747,489,2.526,498,0.805,502,0.878,504,1.725,507,2.317,511,1.552,514,0.878,515,0.976,518,3.27,529,0.805,533,0.878,537,1.32,544,3.194,559,0.747,566,0.878,580,0.805,592,1.778,593,0.976,594,0.805,600,1.552,601,0.976,604,0.805,609,0.699,613,2.317,615,0.878,618,0.747,620,0.747,622,1.32,628,0.976,654,0.805,657,1.912,659,0.976,663,0.878,699,0.747,701,0.976,707,0.747,728,0.805,734,0.878,758,1.773,783,0.976,810,0.699,814,1.04,815,1.778,817,1.423,826,0.657,827,1.725,849,0.747,870,0.805,886,1.552,891,0.588,893,0.805,900,0.805,904,4.461,912,0.878,924,0.976,926,1.234,927,0.976,943,0.878,950,0.878,954,0.805,973,0.878,975,0.976,991,0.976,999,0.976,1004,0.878,1007,0.976,1012,0.747,1022,1.725,1030,0.976,1043,0.976,1044,1.396,1046,0.976,1049,1.161,1066,0.976,1081,0.878,1086,0.805,1123,0.878,1160,0.976,1163,0.976,1173,1.725,1208,0.976,1218,1.32,1245,1.161,1281,1.725,1282,0.878,1293,0.976,1324,0.878,1331,0.878,1337,0.976,1346,1.725,1348,2.797,1349,2.317,1352,0.976,1355,0.976,1356,0.878,1359,0.976,1363,0.976,1365,1.125,1366,1.987,1367,1.125,1368,1.125,1369,1.125,1370,1.125,1371,1.125,1372,1.125,1373,1.125,1374,1.125,1375,1.725,1376,0.976,1377,0.878,1378,3.222,1379,1.125,1380,1.125,1381,1.125,1382,1.125,1383,1.125,1384,1.125,1385,1.987,1386,1.125,1387,1.125,1388,1.125,1389,1.125,1390,1.125,1391,0.805,1392,1.125,1393,1.125,1394,1.125,1395,1.125,1396,1.725,1397,1.725,1398,1.125,1399,2.669,1400,1.125,1401,1.125,1402,1.987,1403,1.125,1404,1.125,1405,1.125,1406,1.125,1407,1.125,1408,1.125,1409,1.125,1410,1.125,1411,1.125,1412,1.125,1413,1.125,1414,1.125,1415,1.125,1416,1.125,1417,1.125,1418,1.125,1419,1.125,1420,1.125,1421,1.125,1422,1.125,1423,1.125,1424,1.125,1425,1.125,1426,1.125,1427,1.125,1428,1.125,1429,1.125,1430,1.125,1431,1.125,1432,1.125,1433,1.125,1434,1.125,1435,1.125,1436,1.125,1437,1.125,1438,1.125,1439,1.125,1440,1.125,1441,1.125,1442,1.125,1443,1.125,1444,1.125,1445,1.125,1446,1.125,1447,1.125,1448,1.125,1449,1.125,1450,1.125,1451,1.125,1452,1.125,1453,1.125,1454,1.125,1455,2.317,1456,1.125,1457,1.987,1458,1.125,1459,1.125,1460,1.125,1461,1.125,1462,1.125,1463,1.125,1464,1.125,1465,1.987,1466,1.125,1467,3.222,1468,1.125,1469,1.125,1470,1.987,1471,1.987,1472,1.125,1473,1.125,1474,3.222,1475,1.987,1476,1.125,1477,1.125,1478,2.669,1479,1.125,1480,1.125,1481,1.125,1482,1.125,1483,1.125,1484,1.125,1485,0.976,1486,1.125,1487,0.976,1488,1.125,1489,1.125,1490,1.125,1491,2.669,1492,1.125,1493,1.125,1494,1.125,1495,0.976,1496,1.987,1497,1.125,1498,1.125,1499,1.987,1500,1.125,1501,1.987,1502,1.987,1503,1.987,1504,1.987,1505,2.669,1506,2.669,1507,1.125,1508,1.125,1509,1.125,1510,1.987,1511,1.125,1512,1.125,1513,1.125,1514,1.125]],["t/856",[2,2.261,10,1.673,12,2.261,49,1.535,60,0.333,76,1.414,140,2.571,164,2.261,167,2.261,181,2.784,182,1.75,185,2.784,259,2.135,304,2.404,318,3.022,321,2.404,322,3.022,324,3.022,329,1.75,340,1.535,342,3.022,351,2.135,358,1.75,360,1.208,372,1.727,390,1.75,439,3.022,441,3.022,450,3.022,462,1.535,489,1.833,676,2.771,683,3.022,685,2.135,689,4.04,713,2.571,716,3.022,812,1.924,823,2.771,825,3.022,947,2.261,1023,3.359,1029,3.022,1084,3.359,1085,3.359,1205,3.022,1213,3.359,1215,3.359,1258,3.359,1302,3.022,1377,3.022,1515,3.869,1516,3.869,1517,3.869,1518,3.869,1519,3.869,1520,3.869,1521,3.869,1522,3.869,1523,3.869,1524,3.869,1525,3.869,1526,3.869,1527,3.869,1528,3.869,1529,3.869,1530,3.869,1531,3.359,1532,3.869,1533,3.022,1534,3.869]],["t/858",[31,1.187,33,1.547,60,0.335,200,2.214,329,2.419,331,2.66,333,3.124,334,3.124,335,2.122,336,2.952,337,3.124,338,2.214,841,3.124,965,4.177,1088,3.553,1214,3.83,1313,3.83,1533,4.177,1535,4.177,1536,4.177,1537,4.642,1538,4.642,1539,4.642,1540,5.348,1541,5.348]],["t/860",[10,1.895,18,2.56,46,3.423,60,0.362,109,1.368,110,1.317,208,2.076,326,0.769,327,1.738,361,2.179,372,1.878,390,2.617,392,3.138,432,3.423,459,2.56,489,2.076,576,1.738,622,2.911,689,3.844,814,2.292,816,2.56,829,3.138,842,4.52,1051,3.423,1069,3.804,1074,3.423,1076,3.423,1078,2.418,1221,3.804,1225,3.138,1230,2.911,1302,3.423,1336,3.804,1391,3.138,1542,4.382,1543,4.382,1544,4.382,1545,4.382,1546,4.382,1547,4.382,1548,4.382,1549,4.382,1550,4.382,1551,4.382,1552,4.382,1553,4.382,1554,4.382,1555,4.382,1556,4.382,1557,4.382]],["t/862",[0,1.848,10,1.995,31,0.702,33,1.334,60,0.289,68,1.431,87,1.965,90,1.573,109,1.44,110,0.95,140,3.065,143,2.101,164,1.848,192,3.181,206,1.499,209,2.471,219,2.746,259,1.746,282,1.499,316,2.265,326,0.809,360,0.987,417,2.101,446,1.965,462,1.255,471,2.471,489,1.499,576,1.255,592,1.746,604,3.304,609,1.965,618,2.101,713,2.101,743,1.965,763,2.746,782,2.101,785,3.304,791,2.265,807,2.746,813,1.848,829,2.265,853,2.265,891,1.655,938,4.004,945,1.965,948,2.265,1009,2.746,1034,2.746,1038,2.265,1044,2.413,1049,1.848,1108,2.265,1198,2.471,1218,2.101,1230,2.101,1245,3.717,1248,2.746,1261,2.471,1275,2.746,1391,2.265,1558,3.163,1559,2.746,1560,3.163,1561,3.163,1562,3.163,1563,3.163,1564,3.163,1565,3.163,1566,3.163,1567,2.746,1568,3.163,1569,5.445,1570,3.163,1571,3.163,1572,3.163,1573,3.163,1574,3.163,1575,3.163,1576,3.163,1577,3.163,1578,3.163,1579,3.163,1580,3.163,1581,4.004,1582,3.163,1583,3.163,1584,3.163,1585,3.163,1586,3.163,1587,3.163,1588,3.163,1589,2.746,1590,3.163,1591,3.163,1592,3.163,1593,3.163,1594,3.163,1595,3.163,1596,3.163,1597,2.746]],["t/864",[15,1.857,33,1.236,60,0.134,66,2.125,78,1.671,81,1.533,87,1.329,109,1.666,110,1.284,148,1.533,150,1.25,155,1.422,161,1.25,166,2.672,175,1.422,181,1.12,205,2.125,208,1.014,231,1.671,250,1.25,254,1.25,259,1.181,273,0.968,290,1.671,296,1.12,305,1.329,345,0.886,358,0.968,360,0.668,361,1.701,372,1.847,383,1.329,438,1.25,446,1.329,466,2.792,467,1.25,472,1.181,474,1.998,489,1.014,512,1.857,514,1.671,543,3.337,555,2.45,557,1.888,558,1.181,559,2.272,572,1.25,581,1.181,587,1.671,632,1.422,678,1.857,691,2.969,713,1.422,815,1.888,848,1.671,873,1.857,882,1.671,891,1.12,893,1.533,947,1.25,992,1.857,1012,2.839,1020,1.533,1044,1.789,1049,3.49,1053,1.671,1073,1.533,1078,1.181,1086,1.533,1095,3.06,1108,1.533,1119,1.857,1130,1.671,1142,3.06,1147,2.969,1148,2.969,1202,1.671,1212,1.671,1245,1.998,1276,1.857,1278,1.857,1292,1.533,1313,1.533,1314,4.632,1315,1.857,1316,1.857,1317,1.857,1318,2.969,1319,2.969,1320,1.857,1321,1.857,1322,3.709,1323,2.969,1324,2.672,1325,1.857,1326,1.857,1327,1.857,1328,1.857,1329,1.857,1330,1.857,1331,4.666,1332,1.857,1333,1.857,1334,1.857,1335,4.237,1356,2.672,1377,1.671,1391,2.45,1495,1.857,1589,1.857,1597,1.857,1598,2.14,1599,2.14,1600,2.14,1601,2.14,1602,2.14,1603,2.14,1604,4.273,1605,4.881,1606,2.14,1607,3.42,1608,2.14,1609,4.273,1610,2.14,1611,4.881,1612,2.14,1613,2.14,1614,2.14,1615,2.14,1616,2.14,1617,2.14,1618,2.14,1619,2.14,1620,2.14,1621,2.14,1622,2.14,1623,2.14,1624,2.14,1625,2.14,1626,2.14,1627,2.14,1628,2.14,1629,2.14,1630,2.14,1631,2.14,1632,2.14,1633,2.14,1634,2.14,1635,2.14,1636,2.14,1637,2.14]],["t/866",[18,2.146,31,1.139,40,1.521,41,1.922,49,1.458,60,0.321,69,0.949,110,1.104,181,1.922,208,1.741,223,2.87,246,2.631,282,2.804,323,3.189,326,0.901,327,1.458,335,1.458,361,1.827,362,2.282,372,1.192,389,2.631,390,1.662,396,3.189,415,2.282,420,2.87,466,1.922,474,2.146,582,2.87,622,2.441,639,3.189,782,2.441,810,2.282,812,1.827,849,2.441,947,2.146,986,3.189,996,2.87,1004,2.87,1057,3.189,1078,2.028,1082,3.189,1088,2.441,1089,3.189,1126,3.189,1176,2.87,1216,3.189,1485,3.189,1531,3.189,1536,2.87,1638,3.674,1639,3.674,1640,3.674,1641,3.674,1642,3.674,1643,3.674,1644,3.674,1645,3.674,1646,3.674,1647,3.674,1648,3.674,1649,3.189,1650,3.674,1651,3.674,1652,3.189,1653,3.674,1654,3.674,1655,3.674,1656,3.674,1657,3.674,1658,3.674,1659,3.674,1660,3.189,1661,3.674,1662,3.674,1663,3.674,1664,3.674,1665,3.674,1666,3.674,1667,3.674,1668,3.674,1669,3.674,1670,3.674]],["t/868",[33,1.393,60,0.385,150,1.76,167,2.814,182,2.179,321,2.992,322,3.762,366,2.814,372,1.997,390,2.179,392,3.45,432,3.762,433,4.807,462,1.911,577,3.762,712,4.181,812,2.396,816,2.814,891,2.52,892,4.181,910,3.762,1029,3.762,1171,4.181,1231,4.181,1232,4.181,1234,4.181,1535,3.762,1652,4.181,1660,4.181,1671,4.817,1672,4.817,1673,4.817,1674,4.817,1675,4.817,1676,4.817,1677,4.817,1678,4.817]],["t/870",[0,2.607,10,1.93,60,0.279,69,1.152,90,2.219,93,1.93,150,2.826,239,5.083,242,4.194,266,2.772,274,4.194,326,0.783,336,2.463,372,1.9,459,2.607,489,2.114,518,2.965,600,3.486,707,2.965,732,3.486,814,2.335,815,3.608,842,4.574,1044,2.335,1230,2.965,1245,2.607,1375,5.674,1376,3.873,1679,4.462,1680,4.462,1681,4.462,1682,4.462,1683,4.462,1684,4.462,1685,4.462]],["t/872",[31,1.195,33,1.558,60,0.337,200,2.23,329,2.437,331,2.679,333,3.148,334,3.148,335,2.137,336,2.973,337,3.148,338,2.23,841,3.148,965,4.208,1088,3.579,1214,3.858,1313,3.858,1533,4.208,1535,4.208,1536,4.208,1537,4.676,1538,4.676,1539,4.676,1686,5.387]],["t/874",[0,1.914,11,1.197,14,2.844,22,2.177,33,0.948,60,0.348,76,1.197,90,1.63,116,4.468,118,2.94,119,2.036,140,2.177,143,2.177,176,2.177,185,1.714,209,2.56,221,2.347,273,1.482,295,1.417,298,2.347,310,1.553,326,0.975,327,2.204,335,1.3,338,1.356,353,2.56,371,2.56,372,1.063,383,2.94,390,1.482,425,2.347,446,2.036,454,2.56,458,2.612,459,1.914,466,2.476,685,2.612,744,2.56,770,2.844,771,2.56,773,2.177,790,2.844,803,1.714,813,1.914,814,1.714,836,2.56,841,2.765,844,3.39,874,2.56,926,2.036,995,2.844,1003,2.844,1017,2.844,1018,4.822,1051,2.56,1063,2.844,1080,2.844,1240,2.844,1282,2.56,1286,2.844,1487,2.844,1559,2.844,1567,2.844,1581,2.844,1649,2.844,1687,3.277,1688,3.277,1689,3.277,1690,2.844,1691,3.277,1692,3.277,1693,3.277,1694,3.277,1695,3.277,1696,3.277,1697,3.277,1698,3.277,1699,3.277,1700,3.277,1701,3.277,1702,3.277,1703,3.277,1704,3.277,1705,3.277,1706,3.277,1707,3.277,1708,3.277,1709,2.844,1710,3.277,1711,3.277,1712,3.277]],["t/876",[12,2.871,31,1.09,33,1.421,68,2.223,116,3.265,118,3.872,200,2.034,243,3.839,291,3.52,572,2.871,626,3.839,768,4.266,773,3.265,777,4.266,810,3.053,926,3.053,931,4.266,1077,5.941,1128,4.868,1203,3.839,1690,4.266,1713,4.914,1714,4.914,1715,4.914,1716,4.914,1717,4.914,1718,4.914,1719,4.914,1720,4.914,1721,4.914,1722,4.914,1723,4.914,1724,4.914]],["t/878",[60,0.367,264,4.581,273,2.653,282,2.779,462,2.327,468,3.427,704,3.896,773,3.896,1725,5.865,1726,5.865,1727,5.865,1728,5.865,1729,5.865]],["t/880",[10,1.423,18,1.923,27,2.357,49,1.306,69,0.85,76,1.203,90,2.77,93,2.053,109,1.028,110,1.427,116,3.7,118,2.95,144,2.484,150,1.203,156,2.357,185,2.914,190,3.709,192,1.923,204,2.857,206,1.56,292,2.357,295,1.423,296,1.722,297,2.045,308,2.187,310,1.56,327,1.306,345,1.363,356,2.187,358,1.489,361,1.637,372,2.186,397,2.571,421,2.187,438,1.923,466,2.484,467,1.923,479,3.709,480,2.857,487,2.187,538,2.148,541,2.857,576,2.21,592,1.817,609,2.045,685,1.817,687,2.857,693,2.857,700,2.571,760,2.571,778,2.857,815,1.817,893,2.357,940,2.187,1039,2.571,1044,1.722,1078,1.817,1180,2.857,1198,2.571,1203,2.571,1245,1.923,1261,2.571,1292,2.357,1301,2.857,1396,4.122,1397,2.857,1455,5.293,1709,4.122,1730,3.292,1731,3.292,1732,3.292,1733,3.292,1734,3.292,1735,3.292,1736,3.292,1737,3.292,1738,3.292,1739,3.292,1740,4.748,1741,3.292,1742,3.292,1743,3.292,1744,3.292]],["t/882",[33,1.669,60,0.361,89,2.871,200,2.389,329,2.611,331,2.871,333,3.372,334,3.372,335,2.29,336,3.186,337,3.372,338,2.389,339,3.835,340,2.29,1214,4.134]]],"invertedIndex":[["",{"_index":150,"t":{"744":{"position":[[8,1]]},"749":{"position":[[270,2],[294,1],[306,1],[347,1],[406,1],[408,2],[488,1],[550,1],[580,2],[598,2],[601,2]]},"764":{"position":[[1191,1],[1199,1],[1245,1],[1270,1],[1286,2],[1341,1],[1427,1],[1436,2],[1474,1],[1545,1],[1554,2],[1600,1]]},"766":{"position":[[702,2]]},"768":{"position":[[308,2]]},"772":{"position":[[490,1],[526,1],[558,1],[591,1],[625,2],[691,2],[787,3],[937,1],[1034,2]]},"784":{"position":[[67,1],[101,1],[118,1]]},"832":{"position":[[404,1],[445,1]]},"834":{"position":[[452,2]]},"836":{"position":[[66,1],[105,1],[123,2],[191,1],[217,2],[292,1],[310,2],[368,2],[423,2],[455,2],[471,1],[473,3],[477,2],[508,1],[556,1],[563,1],[578,1],[593,1],[636,1],[660,1],[667,3],[704,1],[706,2]]},"840":{"position":[[344,1]]},"852":{"position":[[206,2],[510,1],[563,1],[1007,3],[1716,2],[1972,1],[1981,1],[2011,1],[2021,1],[2058,1],[2076,1]]},"854":{"position":[[452,1],[486,1],[514,1],[542,2],[545,2],[548,1],[567,2],[590,3],[594,2],[615,1],[647,2],[666,2],[684,5],[690,2],[1103,1],[1140,2],[1196,2],[1440,2],[1496,1],[1504,2],[1578,1],[1861,1],[1924,2],[1940,2],[2615,2],[2700,1],[2715,2],[2724,2],[3789,1],[3836,2],[3885,1],[3917,3],[3932,1],[3979,3],[4175,2],[4648,1],[4700,2],[4793,1],[4795,2],[5003,1],[5050,2],[5137,1],[5161,2],[5199,1],[5223,1],[5225,2],[5257,1],[5259,2]]},"864":{"position":[[1321,1],[1374,1]]},"868":{"position":[[340,2]]},"870":{"position":[[184,1],[205,1],[245,1],[262,1],[291,2],[307,3],[311,2],[353,1],[455,2]]},"880":{"position":[[551,3]]}}}],["0",{"_index":1163,"t":{"836":{"position":[[558,2]]},"854":{"position":[[3338,4]]}}}],["0.12ms",{"_index":1326,"t":{"852":{"position":[[758,7]]},"864":{"position":[[1569,7]]}}}],["0.5ms",{"_index":1328,"t":{"852":{"position":[[778,6]]},"864":{"position":[[1589,6]]}}}],["0.5x",{"_index":114,"t":{"742":{"position":[[845,5]]}}}],["1",{"_index":492,"t":{"764":{"position":[[752,1]]},"772":{"position":[[184,3]]},"798":{"position":[[141,2]]},"808":{"position":[[19,1]]}}}],["1,000,000",{"_index":1116,"t":{"832":{"position":[[466,9]]}}}],["1.0",{"_index":5,"t":{"740":{"position":[[48,4]]}}}],["10",{"_index":1697,"t":{"874":{"position":[[598,2]]}}}],["100",{"_index":544,"t":{"764":{"position":[[1773,4]]},"854":{"position":[[2975,4],[2980,4],[3315,3],[3826,4],[3831,4]]}}}],["100000",{"_index":1164,"t":{"836":{"position":[[565,7]]}}}],["100k",{"_index":1095,"t":{"830":{"position":[[170,5]]},"836":{"position":[[876,4]]},"852":{"position":[[672,4],[728,4],[791,4]]},"864":{"position":[[1483,4],[1539,4],[1602,4]]}}}],["108",{"_index":1333,"t":{"852":{"position":[[843,4]]},"864":{"position":[[1654,4]]}}}],["12",{"_index":827,"t":{"796":{"position":[[635,2]]},"854":{"position":[[4776,3],[5127,3]]}}}],["150",{"_index":1464,"t":{"854":{"position":[[3325,3]]}}}],["15ms",{"_index":1320,"t":{"852":{"position":[[702,5]]},"864":{"position":[[1513,5]]}}}],["1700",{"_index":1329,"t":{"852":{"position":[[785,5]]},"864":{"position":[[1596,5]]}}}],["17417",{"_index":1327,"t":{"852":{"position":[[766,6]]},"864":{"position":[[1577,6]]}}}],["1x",{"_index":113,"t":{"742":{"position":[[841,3]]}}}],["2",{"_index":963,"t":{"810":{"position":[[6,1]]}}}],["20",{"_index":249,"t":{"747":{"position":[[164,4]]}}}],["200,000",{"_index":1114,"t":{"832":{"position":[[417,7]]}}}],["21ms",{"_index":1325,"t":{"852":{"position":[[752,5]]},"864":{"position":[[1563,5]]}}}],["233",{"_index":1321,"t":{"852":{"position":[[708,4]]},"864":{"position":[[1519,4]]}}}],["24ms",{"_index":1332,"t":{"852":{"position":[[837,5]]},"864":{"position":[[1648,5]]}}}],["27",{"_index":1583,"t":{"862":{"position":[[825,3]]}}}],["2d",{"_index":814,"t":{"796":{"position":[[239,2]]},"822":{"position":[[114,2]]},"824":{"position":[[208,2]]},"846":{"position":[[513,2]]},"848":{"position":[[2234,2]]},"854":{"position":[[845,2],[2864,2]]},"860":{"position":[[62,2]]},"870":{"position":[[438,2]]},"874":{"position":[[377,2]]}}}],["2d/3d",{"_index":1075,"t":{"826":{"position":[[173,5]]}}}],["2ms",{"_index":1323,"t":{"852":{"position":[[718,4],[853,4]]},"864":{"position":[[1529,4],[1664,4]]}}}],["2x",{"_index":112,"t":{"742":{"position":[[837,3]]}}}],["3",{"_index":882,"t":{"804":{"position":[[343,1]]},"816":{"position":[[6,1]]},"864":{"position":[[1137,2]]}}}],["300",{"_index":1465,"t":{"854":{"position":[[3330,3],[3334,3]]}}}],["350",{"_index":1324,"t":{"852":{"position":[[723,4],[858,4]]},"854":{"position":[[3319,3]]},"864":{"position":[[1534,4],[1669,4]]}}}],["3d",{"_index":615,"t":{"770":{"position":[[59,2]]},"824":{"position":[[52,2],[215,2],[269,3],[352,2]]},"854":{"position":[[982,2]]}}}],["3rd",{"_index":872,"t":{"802":{"position":[[622,3]]}}}],["3x",{"_index":1136,"t":{"832":{"position":[[918,3]]}}}],["4",{"_index":1055,"t":{"822":{"position":[[6,1]]}}}],["4.2",{"_index":1690,"t":{"874":{"position":[[150,4]]},"876":{"position":[[6,3]]}}}],["5",{"_index":637,"t":{"772":{"position":[[593,2]]}}}],["50",{"_index":1455,"t":{"854":{"position":[[2971,3],[3817,3],[3822,3]]},"880":{"position":[[231,3],[302,3],[343,3],[410,3]]}}}],["50ms",{"_index":1319,"t":{"852":{"position":[[696,5],[831,5]]},"864":{"position":[[1507,5],[1642,5]]}}}],["600",{"_index":1169,"t":{"836":{"position":[[662,4]]}}}],["60fps",{"_index":1115,"t":{"832":{"position":[[428,6],[479,6]]}}}],["8",{"_index":1594,"t":{"862":{"position":[[1103,1]]}}}],["800",{"_index":1167,"t":{"836":{"position":[[638,4]]}}}],["95",{"_index":1578,"t":{"862":{"position":[[704,3]]}}}],["9ms",{"_index":1322,"t":{"852":{"position":[[713,4],[773,4],[848,4]]},"864":{"position":[[1524,4],[1584,4],[1659,4]]}}}],["ability",{"_index":948,"t":{"808":{"position":[[420,7]]},"814":{"position":[[457,7]]},"842":{"position":[[89,7]]},"862":{"position":[[477,7]]}}}],["above",{"_index":142,"t":{"742":{"position":[[1284,5]]},"828":{"position":[[480,5]]},"840":{"position":[[199,5]]},"852":{"position":[[199,6]]}}}],["abstract",{"_index":567,"t":{"766":{"position":[[317,8]]},"838":{"position":[[222,8]]}}}],["absurdly",{"_index":1134,"t":{"832":{"position":[[748,8]]}}}],["accelerated",{"_index":1384,"t":{"854":{"position":[[857,11]]}}}],["access",{"_index":428,"t":{"760":{"position":[[1071,6]]}}}],["according",{"_index":73,"t":{"742":{"position":[[342,9]]}}}],["account",{"_index":1741,"t":{"880":{"position":[[828,7]]}}}],["accurate",{"_index":545,"t":{"764":{"position":[[1778,8]]}}}],["achieves",{"_index":1595,"t":{"862":{"position":[[1105,8]]}}}],["achieving",{"_index":499,"t":{"764":{"position":[[842,9]]}}}],["acknowledgment",{"_index":1252,"t":{"848":{"position":[[525,14]]}}}],["action",{"_index":183,"t":{"744":{"position":[[531,6]]}}}],["adapt",{"_index":927,"t":{"806":{"position":[[782,5]]},"854":{"position":[[4054,5]]}}}],["add",{"_index":202,"t":{"744":{"position":[[927,3]]},"749":{"position":[[493,3]]},"760":{"position":[[281,3],[488,3]]},"768":{"position":[[159,3]]},"836":{"position":[[480,3],[709,3]]},"840":{"position":[[340,3],[405,3]]},"848":{"position":[[1200,3]]},"854":{"position":[[1543,3],[1580,5],[4414,3]]}}}],["added",{"_index":511,"t":{"764":{"position":[[1103,5]]},"782":{"position":[[226,5]]},"854":{"position":[[1956,5],[3279,6]]}}}],["adding",{"_index":224,"t":{"744":{"position":[[1326,6]]},"760":{"position":[[184,6]]},"800":{"position":[[437,6]]},"840":{"position":[[220,6]]},"848":{"position":[[911,6]]}}}],["addition",{"_index":671,"t":{"774":{"position":[[94,8]]},"818":{"position":[[729,9]]},"820":{"position":[[763,8]]}}}],["additional",{"_index":1647,"t":{"866":{"position":[[322,10]]}}}],["address",{"_index":42,"t":{"740":{"position":[[474,7]]},"786":{"position":[[133,7]]},"796":{"position":[[520,7]]}}}],["addressed",{"_index":1289,"t":{"848":{"position":[[1605,9]]}}}],["addressing",{"_index":667,"t":{"774":{"position":[[19,10]]}}}],["addslotobject(slotname",{"_index":1727,"t":{"878":{"position":[[94,23]]}}}],["adjusted",{"_index":933,"t":{"806":{"position":[[1083,8]]}}}],["adopters",{"_index":1524,"t":{"856":{"position":[[319,8]]}}}],["advanced",{"_index":1048,"t":{"820":{"position":[[649,8]]}}}],["advancements",{"_index":1225,"t":{"846":{"position":[[211,13]]},"848":{"position":[[1361,12]]},"852":{"position":[[1702,13]]},"860":{"position":[[398,12]]}}}],["advantage",{"_index":1047,"t":{"820":{"position":[[636,9]]}}}],["advisable",{"_index":1435,"t":{"854":{"position":[[2517,9]]}}}],["agnostic",{"_index":57,"t":{"742":{"position":[[131,8]]},"808":{"position":[[205,8],[1061,8]]}}}],["aim",{"_index":1265,"t":{"848":{"position":[[815,3]]}}}],["aims",{"_index":945,"t":{"808":{"position":[[146,4]]},"810":{"position":[[31,4]]},"814":{"position":[[143,4],[731,4]]},"818":{"position":[[32,4]]},"826":{"position":[[122,4]]},"862":{"position":[[928,4]]}}}],["allow",{"_index":1160,"t":{"836":{"position":[[313,5]]},"854":{"position":[[4219,5]]}}}],["allowed",{"_index":1574,"t":{"862":{"position":[[579,7]]}}}],["allowing",{"_index":68,"t":{"742":{"position":[[272,8],[603,8]]},"744":{"position":[[998,8]]},"753":{"position":[[198,8]]},"766":{"position":[[456,8]]},"806":{"position":[[353,8],[874,8]]},"812":{"position":[[306,8]]},"818":{"position":[[237,8]]},"838":{"position":[[361,8],[494,8]]},"848":{"position":[[756,8]]},"854":{"position":[[3425,8]]},"862":{"position":[[972,8]]},"876":{"position":[[58,8]]}}}],["allows",{"_index":171,"t":{"744":{"position":[[315,6]]},"764":{"position":[[713,6]]},"770":{"position":[[38,6]]},"802":{"position":[[579,6]]},"818":{"position":[[800,6]]},"854":{"position":[[2019,6],[3582,6]]}}}],["alpha",{"_index":533,"t":{"764":{"position":[[1565,5]]},"832":{"position":[[236,5]]},"854":{"position":[[1297,6]]}}}],["alphas",{"_index":516,"t":{"764":{"position":[[1201,7]]}}}],["already",{"_index":292,"t":{"751":{"position":[[13,7]]},"758":{"position":[[206,7]]},"848":{"position":[[1832,7]]},"880":{"position":[[987,7]]}}}],["alternatively",{"_index":1538,"t":{"858":{"position":[[139,14]]},"872":{"position":[[140,14]]}}}],["although",{"_index":1069,"t":{"824":{"position":[[381,8]]},"860":{"position":[[114,8]]}}}],["always",{"_index":87,"t":{"742":{"position":[[514,6]]},"744":{"position":[[167,6],[450,6]]},"796":{"position":[[275,6]]},"848":{"position":[[553,6]]},"862":{"position":[[988,6]]},"864":{"position":[[11,6]]}}}],["amazing",{"_index":784,"t":{"788":{"position":[[664,7]]},"792":{"position":[[25,7]]},"796":{"position":[[171,7]]}}}],["anchor",{"_index":1104,"t":{"832":{"position":[[211,7]]}}}],["animation",{"_index":773,"t":{"788":{"position":[[377,9]]},"826":{"position":[[438,9]]},"874":{"position":[[30,9]]},"876":{"position":[[25,9]]},"878":{"position":[[58,9]]}}}],["animations",{"_index":118,"t":{"742":{"position":[[879,10]]},"788":{"position":[[463,10]]},"818":{"position":[[416,11],[622,11]]},"874":{"position":[[380,11],[470,10]]},"876":{"position":[[192,10],[349,11]]},"880":{"position":[[529,10],[600,10]]}}}],["animators",{"_index":1209,"t":{"842":{"position":[[196,10]]}}}],["announce",{"_index":3,"t":{"740":{"position":[[29,8]]},"796":{"position":[[18,8]]},"800":{"position":[[27,8]]},"826":{"position":[[28,8]]}}}],["announcement",{"_index":831,"t":{"796":{"position":[[698,13]]}}}],["announcing",{"_index":448,"t":{"762":{"position":[[115,10]]},"808":{"position":[[28,10]]}}}],["another",{"_index":618,"t":{"772":{"position":[[59,7],[240,8]]},"806":{"position":[[608,7]]},"848":{"position":[[1068,7]]},"854":{"position":[[1199,7]]},"862":{"position":[[1159,7]]}}}],["antialias:true",{"_index":1408,"t":{"854":{"position":[[1909,14]]}}}],["antialiasing",{"_index":1402,"t":{"854":{"position":[[1614,12],[1680,12]]}}}],["anticipating",{"_index":1272,"t":{"848":{"position":[[1016,12]]}}}],["anyone",{"_index":890,"t":{"804":{"position":[[947,6]]}}}],["api",{"_index":282,"t":{"749":{"position":[[659,3]]},"760":{"position":[[692,3],[1011,3]]},"764":{"position":[[704,3]]},"788":{"position":[[229,3]]},"820":{"position":[[546,3]]},"842":{"position":[[260,4]]},"848":{"position":[[2093,3]]},"854":{"position":[[2759,3],[2875,4],[4085,4],[5181,3],[5245,3]]},"862":{"position":[[189,4]]},"866":{"position":[[146,3],[350,3],[555,3]]},"878":{"position":[[89,4]]}}}],["api's",{"_index":412,"t":{"760":{"position":[[806,5],[928,6]]}}}],["app",{"_index":973,"t":{"812":{"position":[[424,3]]},"852":{"position":[[1905,3]]},"854":{"position":[[510,3]]}}}],["app.init",{"_index":601,"t":{"768":{"position":[[169,10]]},"854":{"position":[[556,10]]}}}],["app.stage.addchild(container",{"_index":1172,"t":{"836":{"position":[[741,30]]}}}],["appeal",{"_index":1005,"t":{"818":{"position":[[196,6]]}}}],["appealing",{"_index":1025,"t":{"818":{"position":[[980,10]]}}}],["appearance",{"_index":916,"t":{"806":{"position":[[379,10]]}}}],["appends",{"_index":82,"t":{"742":{"position":[[455,7]]}}}],["application",{"_index":758,"t":{"788":{"position":[[51,11]]},"808":{"position":[[636,12]]},"812":{"position":[[345,12],[795,11]]},"818":{"position":[[713,12]]},"854":{"position":[[454,12],[520,14],[570,11]]}}}],["applications",{"_index":750,"t":{"786":{"position":[[91,12]]},"790":{"position":[[77,12],[281,12]]},"796":{"position":[[387,12]]},"802":{"position":[[78,13],[494,12]]},"808":{"position":[[102,13]]},"810":{"position":[[74,13]]},"812":{"position":[[110,13]]},"814":{"position":[[119,13],[374,12],[937,12],[1141,13]]},"818":{"position":[[96,12],[851,13],[1146,12]]},"820":{"position":[[746,13],[1168,13]]},"824":{"position":[[243,13],[619,13]]}}}],["application’s",{"_index":1192,"t":{"838":{"position":[[1078,13]]}}}],["applied",{"_index":1397,"t":{"854":{"position":[[1392,7],[4973,7]]},"880":{"position":[[135,7]]}}}],["apply",{"_index":231,"t":{"744":{"position":[[1413,5]]},"852":{"position":[[356,6]]},"864":{"position":[[1994,5]]}}}],["applying",{"_index":1403,"t":{"854":{"position":[[1772,8]]}}}],["appreciate",{"_index":1016,"t":{"818":{"position":[[755,10]]}}}],["approach",{"_index":1391,"t":{"854":{"position":[[1039,8]]},"860":{"position":[[512,8]]},"862":{"position":[[570,8]]},"864":{"position":[[230,10],[455,9]]}}}],["appropriate",{"_index":1680,"t":{"870":{"position":[[113,11]]}}}],["apps",{"_index":797,"t":{"790":{"position":[[349,4]]},"796":{"position":[[189,5]]},"838":{"position":[[957,5]]}}}],["architecture",{"_index":1600,"t":{"864":{"position":[[105,12]]}}}],["areas",{"_index":1058,"t":{"822":{"position":[[88,5]]},"840":{"position":[[70,5]]},"848":{"position":[[1725,5]]}}}],["arguably",{"_index":1247,"t":{"848":{"position":[[384,8]]}}}],["arise",{"_index":1520,"t":{"856":{"position":[[233,6]]}}}],["around",{"_index":1696,"t":{"874":{"position":[[590,7]]}}}],["art",{"_index":568,"t":{"766":{"position":[[326,3]]},"838":{"position":[[231,3]]}}}],["ask",{"_index":1109,"t":{"832":{"position":[[341,4]]}}}],["aspect",{"_index":928,"t":{"806":{"position":[[818,6]]}}}],["aspects",{"_index":1254,"t":{"848":{"position":[[615,7],[1641,7]]}}}],["assembled",{"_index":824,"t":{"796":{"position":[[545,9]]}}}],["asset",{"_index":6,"t":{"740":{"position":[[56,5],[532,5]]},"742":{"position":[[325,5],[480,5],[552,6],[1206,5]]},"744":{"position":[[71,5],[704,5],[1073,5],[1275,5],[1478,5]]},"751":{"position":[[104,5]]},"753":{"position":[[140,5]]},"786":{"position":[[253,5]]},"788":{"position":[[81,5],[142,5]]},"808":{"position":[[50,5]]},"826":{"position":[[390,5]]},"848":{"position":[[306,5]]}}}],["assetpack",{"_index":4,"t":{"740":{"position":[[38,9],[498,9]]},"742":{"position":[[0,9],[231,9],[367,9],[1330,9]]},"744":{"position":[[14,9],[305,9],[633,9],[861,9]]},"747":{"position":[[11,10],[129,9]]},"749":{"position":[[10,10],[428,9],[691,10],[798,9]]},"751":{"position":[[0,9],[90,9],[175,9]]},"753":{"position":[[0,9],[158,9],[272,9],[405,10]]},"788":{"position":[[124,10]]},"804":{"position":[[507,10]]},"808":{"position":[[39,10],[128,9],[180,9],[403,9]]}}}],["assetpack's",{"_index":146,"t":{"742":{"position":[[1390,11]]},"744":{"position":[[1238,11]]}}}],["assetpack.js",{"_index":260,"t":{"749":{"position":[[157,13],[273,13]]}}}],["assetpack/core",{"_index":240,"t":{"747":{"position":[[46,15],[94,15]]},"749":{"position":[[313,18]]}}}],["assets",{"_index":16,"t":{"740":{"position":[[172,6],[463,7],[636,6]]},"742":{"position":[[91,6],[1266,6]]},"744":{"position":[[45,7],[206,6],[340,6],[439,6],[625,7],[796,6],[885,6],[1168,6]]},"749":{"position":[[79,6],[363,8]]},"753":{"position":[[67,6]]},"772":{"position":[[1421,8]]},"808":{"position":[[364,6],[458,6],[847,6]]},"818":{"position":[[1093,6]]},"836":{"position":[[997,7]]}}}],["assured",{"_index":1663,"t":{"866":{"position":[[722,7]]}}}],["async",{"_index":1376,"t":{"854":{"position":[[535,6]]},"870":{"position":[[223,5]]}}}],["asynchronous",{"_index":1366,"t":{"854":{"position":[[50,13],[374,12]]}}}],["atlas",{"_index":120,"t":{"742":{"position":[[914,6]]}}}],["attach",{"_index":1725,"t":{"878":{"position":[[12,6]]}}}],["attempt",{"_index":1571,"t":{"862":{"position":[[494,7]]}}}],["attributes",{"_index":1201,"t":{"840":{"position":[[353,10]]}}}],["audio",{"_index":25,"t":{"740":{"position":[[286,5]]},"742":{"position":[[951,5]]},"786":{"position":[[269,5]]},"788":{"position":[[171,5]]},"808":{"position":[[739,5]]},"826":{"position":[[367,6]]}}}],["audio/ffmpeg",{"_index":121,"t":{"742":{"position":[[928,13]]}}}],["autodetectrenderer",{"_index":1375,"t":{"854":{"position":[[467,18],[623,23]]},"870":{"position":[[148,18],[186,18],[270,20]]}}}],["automated",{"_index":1718,"t":{"876":{"position":[[208,9]]}}}],["automates",{"_index":47,"t":{"740":{"position":[[552,9]]}}}],["automatic",{"_index":768,"t":{"788":{"position":[[262,9]]},"876":{"position":[[137,9]]}}}],["automatically",{"_index":81,"t":{"742":{"position":[[441,13],[710,13]]},"808":{"position":[[431,13]]},"852":{"position":[[1238,13]]},"864":{"position":[[2089,13]]}}}],["automating",{"_index":306,"t":{"753":{"position":[[99,10]]}}}],["available",{"_index":192,"t":{"744":{"position":[[670,10]]},"760":{"position":[[651,9]]},"790":{"position":[[215,10]]},"804":{"position":[[923,9]]},"820":{"position":[[904,9]]},"862":{"position":[[370,9],[691,9],[1024,9]]},"880":{"position":[[121,10]]}}}],["avoid",{"_index":1437,"t":{"854":{"position":[[2550,5]]}}}],["avoids",{"_index":1620,"t":{"864":{"position":[[985,6]]}}}],["await",{"_index":600,"t":{"768":{"position":[[163,5]]},"854":{"position":[[550,5],[617,5]]},"870":{"position":[[264,5]]}}}],["away",{"_index":393,"t":{"760":{"position":[[384,5]]},"812":{"position":[[854,5]]}}}],["b",{"_index":1573,"t":{"862":{"position":[[562,2]]}}}],["back",{"_index":1261,"t":{"848":{"position":[[733,4]]},"862":{"position":[[537,4]]},"880":{"position":[[661,4]]}}}],["backend",{"_index":1337,"t":{"852":{"position":[[1055,7]]},"854":{"position":[[215,7]]}}}],["backporting",{"_index":434,"t":{"760":{"position":[[1218,11]]}}}],["bad",{"_index":1674,"t":{"868":{"position":[[225,4]]}}}],["balance",{"_index":579,"t":{"766":{"position":[[486,7]]},"838":{"position":[[391,7]]}}}],["bandwidth",{"_index":1626,"t":{"864":{"position":[[1176,9]]}}}],["bar",{"_index":1308,"t":{"852":{"position":[[225,4]]}}}],["bars",{"_index":911,"t":{"806":{"position":[[258,5]]}}}],["based",{"_index":66,"t":{"742":{"position":[[258,5]]},"764":{"position":[[918,5]]},"790":{"position":[[71,5]]},"792":{"position":[[16,5]]},"852":{"position":[[891,5]]},"864":{"position":[[634,5],[1702,5]]}}}],["basic",{"_index":772,"t":{"788":{"position":[[336,5]]}}}],["basically",{"_index":1175,"t":{"838":{"position":[[438,9]]}}}],["basics",{"_index":401,"t":{"760":{"position":[[517,6]]},"786":{"position":[[33,7]]}}}],["batch",{"_index":1202,"t":{"840":{"position":[[373,5]]},"852":{"position":[[1420,5]]},"864":{"position":[[431,5]]}}}],["batched",{"_index":1200,"t":{"840":{"position":[[309,7]]}}}],["batches",{"_index":1608,"t":{"864":{"position":[[377,7]]}}}],["batching",{"_index":989,"t":{"814":{"position":[[518,8],[538,8]]}}}],["beast",{"_index":1139,"t":{"834":{"position":[[40,6]]}}}],["beautiful",{"_index":897,"t":{"806":{"position":[[61,9]]},"846":{"position":[[630,9]]}}}],["become",{"_index":975,"t":{"812":{"position":[[454,6]]},"854":{"position":[[2788,6]]}}}],["becomes",{"_index":1587,"t":{"862":{"position":[[890,7]]}}}],["before",{"_index":1586,"t":{"862":{"position":[[880,6]]}}}],["begin",{"_index":964,"t":{"810":{"position":[[13,5]]}}}],["beginners",{"_index":384,"t":{"760":{"position":[[214,9]]}}}],["behaves",{"_index":463,"t":{"764":{"position":[[68,7]]}}}],["behaviour",{"_index":917,"t":{"806":{"position":[[394,9]]}}}],["behind",{"_index":1126,"t":{"832":{"position":[[610,6]]},"866":{"position":[[26,6]]}}}],["being",{"_index":421,"t":{"760":{"position":[[952,5]]},"764":{"position":[[431,5]]},"812":{"position":[[28,5]]},"820":{"position":[[558,5]]},"880":{"position":[[74,5]]}}}],["believe",{"_index":1236,"t":{"848":{"position":[[13,7]]}}}],["below",{"_index":382,"t":{"760":{"position":[[95,5]]},"852":{"position":[[82,5]]}}}],["benchmark",{"_index":1334,"t":{"852":{"position":[[869,9]]},"864":{"position":[[1680,9]]}}}],["benefit",{"_index":1575,"t":{"862":{"position":[[617,7]]}}}],["best",{"_index":446,"t":{"762":{"position":[[106,4]]},"814":{"position":[[257,4]]},"848":{"position":[[673,4]]},"862":{"position":[[1008,4]]},"864":{"position":[[1962,4]]},"874":{"position":[[205,4]]}}}],["beta",{"_index":842,"t":{"800":{"position":[[64,4]]},"860":{"position":[[87,4],[147,4]]},"870":{"position":[[28,4],[390,4]]}}}],["better",{"_index":351,"t":{"758":{"position":[[93,6],[296,6]]},"760":{"position":[[444,6]]},"774":{"position":[[106,6],[398,6]]},"808":{"position":[[880,6]]},"820":{"position":[[1113,6]]},"852":{"position":[[1104,6],[1492,6],[1878,6]]},"854":{"position":[[4229,6]]},"856":{"position":[[279,7]]}}}],["between",{"_index":580,"t":{"766":{"position":[[494,7]]},"824":{"position":[[307,7]]},"838":{"position":[[399,7],[805,7]]},"854":{"position":[[4594,7]]}}}],["beyond",{"_index":745,"t":{"786":{"position":[[22,6]]}}}],["big",{"_index":1528,"t":{"856":{"position":[[536,3]]}}}],["bigger",{"_index":1263,"t":{"848":{"position":[[779,6]]}}}],["bitmap",{"_index":1496,"t":{"854":{"position":[[4496,6],[4685,6]]}}}],["bitmapfonts",{"_index":1488,"t":{"854":{"position":[[4317,11]]}}}],["bitmaptext",{"_index":1500,"t":{"854":{"position":[[4654,12]]}}}],["bitrate",{"_index":125,"t":{"742":{"position":[[989,7]]}}}],["blend",{"_index":1348,"t":{"852":{"position":[[1462,5]]},"854":{"position":[[1235,5],[1411,5],[1547,5],[2602,5]]}}}],["blog",{"_index":582,"t":{"766":{"position":[[525,4],[540,4]]},"808":{"position":[[962,4]]},"866":{"position":[[275,4]]}}}],["bluesky",{"_index":440,"t":{"760":{"position":[[1443,7]]},"774":{"position":[[296,8]]}}}],["board",{"_index":1300,"t":{"848":{"position":[[1942,5]]}}}],["bones",{"_index":1714,"t":{"876":{"position":[[67,5]]}}}],["boost",{"_index":1093,"t":{"830":{"position":[[142,6]]}}}],["boosting",{"_index":1296,"t":{"848":{"position":[[1800,8]]}}}],["both",{"_index":383,"t":{"760":{"position":[[209,4]]},"806":{"position":[[898,4]]},"818":{"position":[[206,4],[246,4],[951,4]]},"852":{"position":[[266,4]]},"864":{"position":[[130,4]]},"874":{"position":[[295,4],[572,4]]}}}],["bottleneck",{"_index":1122,"t":{"832":{"position":[[549,10]]}}}],["bouncing",{"_index":1127,"t":{"832":{"position":[[621,8]]}}}],["boundaries",{"_index":1215,"t":{"846":{"position":[[22,10]]},"856":{"position":[[652,10]]}}}],["box",{"_index":77,"t":{"742":{"position":[[394,3]]},"784":{"position":[[11,3]]}}}],["breaking",{"_index":1096,"t":{"830":{"position":[[184,8]]},"848":{"position":[[2084,8]]}}}],["breaks",{"_index":1345,"t":{"852":{"position":[[1426,7]]}}}],["bringing",{"_index":455,"t":{"762":{"position":[[215,8]]}}}],["brings",{"_index":1090,"t":{"830":{"position":[[108,6]]}}}],["brouwer",{"_index":864,"t":{"802":{"position":[[168,8]]}}}],["browser",{"_index":483,"t":{"764":{"position":[[595,7],[1041,7]]},"766":{"position":[[597,7],[834,7]]},"770":{"position":[[106,7]]},"814":{"position":[[27,7]]},"820":{"position":[[583,7]]}}}],["browsers",{"_index":1569,"t":{"862":{"position":[[404,9],[711,9],[804,8]]}}}],["bubble",{"_index":883,"t":{"804":{"position":[[356,6]]}}}],["bubbo",{"_index":896,"t":{"804":{"position":[[1053,5],[1059,5]]}}}],["bugs",{"_index":1676,"t":{"868":{"position":[[250,5]]}}}],["build",{"_index":161,"t":{"744":{"position":[[136,5],[401,5],[1200,5]]},"749":{"position":[[754,5]]},"782":{"position":[[96,5]]},"790":{"position":[[263,5]]},"796":{"position":[[371,5]]},"814":{"position":[[895,5]]},"864":{"position":[[371,5]]}}}],["buildgeometryfrompath",{"_index":1475,"t":{"854":{"position":[[3673,21],[3887,23]]}}}],["building",{"_index":309,"t":{"753":{"position":[[223,8]]},"766":{"position":[[265,8]]},"786":{"position":[[82,8]]},"788":{"position":[[655,8]]},"812":{"position":[[331,8],[839,8]]},"820":{"position":[[1131,8]]},"824":{"position":[[604,8]]},"838":{"position":[[170,8]]}}}],["built",{"_index":291,"t":{"749":{"position":[[824,5]]},"788":{"position":[[96,5]]},"824":{"position":[[83,5]]},"876":{"position":[[40,5]]}}}],["bump",{"_index":1612,"t":{"864":{"position":[[729,5]]}}}],["bun",{"_index":709,"t":{"780":{"position":[[412,4],[417,3]]}}}],["bundle",{"_index":1052,"t":{"820":{"position":[[971,6]]},"852":{"position":[[1931,6]]}}}],["bundler",{"_index":695,"t":{"778":{"position":[[302,8]]},"780":{"position":[[592,7]]},"782":{"position":[[0,7]]},"784":{"position":[[159,7]]}}}],["bundlers",{"_index":727,"t":{"784":{"position":[[38,9]]},"812":{"position":[[237,8],[555,8]]}}}],["bundles",{"_index":651,"t":{"772":{"position":[[1070,8]]}}}],["bunnies",{"_index":1119,"t":{"832":{"position":[[508,7]]},"864":{"position":[[1909,8]]}}}],["bunny",{"_index":1316,"t":{"852":{"position":[[612,5]]},"864":{"position":[[1423,5]]}}}],["bunnymark",{"_index":1335,"t":{"852":{"position":[[904,9],[949,9],[962,9],[984,9]]},"864":{"position":[[1716,9],[1761,9],[1774,9],[1796,9]]}}}],["bunnys",{"_index":1196,"t":{"840":{"position":[[227,6]]}}}],["burn",{"_index":1445,"t":{"854":{"position":[[2709,5]]}}}],["busting",{"_index":80,"t":{"742":{"position":[[432,8]]}}}],["buttons",{"_index":901,"t":{"806":{"position":[[166,8],[236,8]]}}}],["cache",{"_index":79,"t":{"742":{"position":[[426,5]]}}}],["cacheasbitmap",{"_index":465,"t":{"764":{"position":[[89,13]]}}}],["cacheastexture",{"_index":460,"t":{"764":{"position":[[0,15],[38,16]]}}}],["caches",{"_index":153,"t":{"744":{"position":[[38,6]]}}}],["caching",{"_index":149,"t":{"744":{"position":[[0,7],[1109,7]]},"764":{"position":[[375,7]]}}}],["call",{"_index":993,"t":{"814":{"position":[[630,5]]},"838":{"position":[[752,4]]}}}],["called",{"_index":875,"t":{"804":{"position":[[38,6]]},"824":{"position":[[62,6]]},"826":{"position":[[78,6]]}}}],["came",{"_index":347,"t":{"758":{"position":[[64,4]]}}}],["camera",{"_index":1385,"t":{"854":{"position":[[869,7],[964,6]]}}}],["candidate",{"_index":1671,"t":{"868":{"position":[[34,10]]}}}],["canvas",{"_index":604,"t":{"768":{"position":[[237,6],[409,7]]},"820":{"position":[[873,6]]},"854":{"position":[[2857,6]]},"862":{"position":[[420,6],[545,6]]}}}],["canvases",{"_index":595,"t":{"768":{"position":[[64,9]]}}}],["canvasondom1",{"_index":606,"t":{"768":{"position":[[295,12]]}}}],["capabilities",{"_index":811,"t":{"796":{"position":[[99,12]]},"820":{"position":[[662,13]]},"824":{"position":[[544,12]]}}}],["capable",{"_index":1094,"t":{"830":{"position":[[149,7]]}}}],["care",{"_index":1311,"t":{"852":{"position":[[401,4]]}}}],["cases",{"_index":1630,"t":{"864":{"position":[[1310,6]]}}}],["catalysed",{"_index":1555,"t":{"860":{"position":[[498,9]]}}}],["causing",{"_index":821,"t":{"796":{"position":[[477,7]]}}}],["celebrating",{"_index":1219,"t":{"846":{"position":[[111,11]]}}}],["certain",{"_index":1291,"t":{"848":{"position":[[1633,7]]}}}],["chain",{"_index":548,"t":{"764":{"position":[[1823,5]]}}}],["challenge",{"_index":43,"t":{"740":{"position":[[487,10]]}}}],["challenges",{"_index":752,"t":{"786":{"position":[[148,10]]}}}],["change",{"_index":1356,"t":{"852":{"position":[[1848,6]]},"854":{"position":[[1216,6]]},"864":{"position":[[1093,6],[1888,6]]}}}],["changed",{"_index":1147,"t":{"834":{"position":[[324,8]]},"864":{"position":[[506,7],[780,8]]}}}],["changer",{"_index":1193,"t":{"840":{"position":[[36,8]]},"842":{"position":[[40,7]]},"846":{"position":[[102,8]]}}}],["changes",{"_index":208,"t":{"744":{"position":[[1018,7]]},"760":{"position":[[118,7],[1316,7]]},"806":{"position":[[989,8]]},"816":{"position":[[78,7]]},"836":{"position":[[336,7]]},"848":{"position":[[2097,8]]},"852":{"position":[[153,8]]},"854":{"position":[[2777,7]]},"860":{"position":[[360,7]]},"864":{"position":[[681,7]]},"866":{"position":[[612,7]]}}}],["changing",{"_index":1330,"t":{"852":{"position":[[804,9]]},"864":{"position":[[1615,9]]}}}],["channel",{"_index":682,"t":{"774":{"position":[[329,8]]}}}],["character",{"_index":1723,"t":{"876":{"position":[[325,9]]}}}],["characters",{"_index":566,"t":{"766":{"position":[[302,11]]},"838":{"position":[[207,11]]},"854":{"position":[[4418,10]]}}}],["chats",{"_index":1541,"t":{"858":{"position":[[241,6]]}}}],["check",{"_index":297,"t":{"751":{"position":[[59,5]]},"806":{"position":[[528,5]]},"808":{"position":[[1126,5]]},"828":{"position":[[443,5]]},"852":{"position":[[478,5]]},"880":{"position":[[1114,5]]}}}],["checkboxes",{"_index":902,"t":{"806":{"position":[[175,11]]}}}],["checkout",{"_index":1137,"t":{"832":{"position":[[929,8]]}}}],["cherry",{"_index":1442,"t":{"854":{"position":[[2660,6]]}}}],["child",{"_index":627,"t":{"772":{"position":[[212,5],[396,5]]}}}],["child's",{"_index":629,"t":{"772":{"position":[[313,7]]}}}],["children",{"_index":473,"t":{"764":{"position":[[291,8]]},"772":{"position":[[866,8]]},"854":{"position":[[1364,8],[1461,8],[1525,8]]}}}],["chit",{"_index":1540,"t":{"858":{"position":[[236,4]]}}}],["choice",{"_index":1135,"t":{"832":{"position":[[790,6]]}}}],["choosing",{"_index":1182,"t":{"838":{"position":[[740,8]]}}}],["ci",{"_index":151,"t":{"744":{"position":[[10,3],[286,4]]}}}],["clarity",{"_index":1158,"t":{"836":{"position":[[265,7]]}}}],["class",{"_index":1043,"t":{"820":{"position":[[496,5],[925,5]]},"854":{"position":[[3491,5]]}}}],["classic",{"_index":1185,"t":{"838":{"position":[[842,7]]}}}],["classics",{"_index":1411,"t":{"854":{"position":[[2098,9]]}}}],["cleaner",{"_index":1284,"t":{"848":{"position":[[1504,7]]}}}],["clear",{"_index":350,"t":{"758":{"position":[[86,6]]},"848":{"position":[[956,6]]}}}],["cli",{"_index":286,"t":{"749":{"position":[[718,4],[776,3]]},"778":{"position":[[237,3]]},"780":{"position":[[23,3]]},"812":{"position":[[19,3],[393,3]]}}}],["clients",{"_index":86,"t":{"742":{"position":[[506,7]]}}}],["closely",{"_index":1447,"t":{"854":{"position":[[2829,7]]}}}],["closer",{"_index":692,"t":{"778":{"position":[[156,6]]},"780":{"position":[[646,6]]}}}],["clothing",{"_index":1720,"t":{"876":{"position":[[237,9]]}}}],["code",{"_index":891,"t":{"804":{"position":[[979,4]]},"814":{"position":[[240,5],[1097,4]]},"818":{"position":[[545,5]]},"832":{"position":[[1002,4]]},"848":{"position":[[630,4],[928,5]]},"854":{"position":[[146,4]]},"862":{"position":[[1066,5]]},"864":{"position":[[814,4]]},"868":{"position":[[276,5]]}}}],["codebase",{"_index":432,"t":{"760":{"position":[[1168,8],[1288,8]]},"860":{"position":[[543,8]]},"868":{"position":[[391,8]]}}}],["coders",{"_index":1210,"t":{"842":{"position":[[220,7]]}}}],["collaborate",{"_index":1008,"t":{"818":{"position":[[261,11]]}}}],["collaboration",{"_index":1027,"t":{"818":{"position":[[1022,14]]}}}],["collection",{"_index":876,"t":{"804":{"position":[[76,10]]}}}],["color",{"_index":529,"t":{"764":{"position":[[1451,5]]},"832":{"position":[[246,7]]},"836":{"position":[[442,6],[465,5]]},"854":{"position":[[2702,6]]}}}],["color:'blue",{"_index":1514,"t":{"854":{"position":[[5210,12]]}}}],["color:'red",{"_index":1512,"t":{"854":{"position":[[5148,12]]}}}],["colorblend",{"_index":1412,"t":{"854":{"position":[[2108,11]]}}}],["colorburnblend",{"_index":1413,"t":{"854":{"position":[[2120,15]]}}}],["colordodgeblend",{"_index":1414,"t":{"854":{"position":[[2136,16]]}}}],["combine",{"_index":930,"t":{"806":{"position":[[890,7]]}}}],["combined",{"_index":213,"t":{"744":{"position":[[1091,8]]}}}],["comes",{"_index":75,"t":{"742":{"position":[[377,5]]},"842":{"position":[[56,5]]}}}],["comet",{"_index":1002,"t":{"818":{"position":[[0,5],[332,5],[1037,5]]}}}],["coming",{"_index":793,"t":{"790":{"position":[[232,6]]},"828":{"position":[[67,6]]}}}],["command",{"_index":405,"t":{"760":{"position":[[683,8]]},"780":{"position":[[209,8]]}}}],["commit",{"_index":172,"t":{"744":{"position":[[329,6]]}}}],["commitment",{"_index":363,"t":{"758":{"position":[[282,10]]}}}],["committed",{"_index":318,"t":{"753":{"position":[[369,9]]},"774":{"position":[[6,9]]},"856":{"position":[[163,9]]}}}],["common",{"_index":751,"t":{"786":{"position":[[141,6]]},"788":{"position":[[357,6]]}}}],["communication",{"_index":364,"t":{"758":{"position":[[303,14]]}}}],["community",{"_index":338,"t":{"755":{"position":[[80,9]]},"758":{"position":[[147,10]]},"776":{"position":[[80,9]]},"794":{"position":[[80,9]]},"796":{"position":[[313,9],[506,10]]},"802":{"position":[[218,9]]},"812":{"position":[[498,10]]},"828":{"position":[[88,10],[207,10]]},"844":{"position":[[85,9]]},"848":{"position":[[66,9]]},"858":{"position":[[179,9]]},"872":{"position":[[180,9]]},"874":{"position":[[1132,9]]},"882":{"position":[[85,9]]}}}],["compared",{"_index":1039,"t":{"820":{"position":[[382,8]]},"848":{"position":[[1948,8]]},"880":{"position":[[414,8]]}}}],["compatibility",{"_index":245,"t":{"747":{"position":[[110,13]]},"848":{"position":[[2151,13]]}}}],["compilation",{"_index":1360,"t":{"852":{"position":[[1909,12]]}}}],["complete",{"_index":735,"t":{"784":{"position":[[199,8]]},"820":{"position":[[59,8]]}}}],["complex",{"_index":235,"t":{"744":{"position":[[1470,7]]},"806":{"position":[[923,8]]},"814":{"position":[[499,7]]},"818":{"position":[[484,7]]},"820":{"position":[[1140,8]]},"838":{"position":[[690,7]]}}}],["complexity",{"_index":725,"t":{"782":{"position":[[232,11]]},"848":{"position":[[1669,10]]}}}],["complicated",{"_index":969,"t":{"812":{"position":[[181,11]]},"814":{"position":[[656,11]]}}}],["components",{"_index":871,"t":{"802":{"position":[[607,10]]},"806":{"position":[[147,10],[317,10]]}}}],["comprehensive",{"_index":1650,"t":{"866":{"position":[[429,13]]}}}],["compress",{"_index":957,"t":{"808":{"position":[[767,8]]}}}],["compressed",{"_index":24,"t":{"740":{"position":[[268,11]]}}}],["compresses",{"_index":92,"t":{"742":{"position":[[572,10]]}}}],["compressing",{"_index":97,"t":{"742":{"position":[[653,11]]}}}],["compression",{"_index":91,"t":{"742":{"position":[[559,12]]}}}],["computational",{"_index":1148,"t":{"834":{"position":[[368,13]]},"864":{"position":[[843,13],[1207,13]]}}}],["computations",{"_index":1562,"t":{"862":{"position":[[109,12]]}}}],["concept",{"_index":1379,"t":{"854":{"position":[[713,7]]}}}],["configurable",{"_index":45,"t":{"740":{"position":[[519,12]]}}}],["configuration",{"_index":255,"t":{"749":{"position":[[42,13],[628,13]]}}}],["configure",{"_index":1153,"t":{"834":{"position":[[600,9]]}}}],["configured",{"_index":276,"t":{"749":{"position":[[503,10]]}}}],["conform",{"_index":1507,"t":{"854":{"position":[[4825,7]]}}}],["considerable",{"_index":1704,"t":{"874":{"position":[[820,12]]}}}],["considering",{"_index":856,"t":{"800":{"position":[[481,11]]}}}],["console",{"_index":484,"t":{"764":{"position":[[603,7],[1049,7]]},"766":{"position":[[605,7],[842,7]]},"770":{"position":[[114,7]]}}}],["const",{"_index":518,"t":{"764":{"position":[[1228,5],[1254,5],[1319,5],[1410,5],[1457,5],[1528,5],[1582,5]]},"772":{"position":[[473,5],[509,5],[545,5],[921,5]]},"836":{"position":[[175,5],[494,5]]},"854":{"position":[[504,5],[600,5],[1087,5],[1847,5],[3778,5],[3870,5],[3921,5],[4635,5],[4990,5]]},"870":{"position":[[247,5]]}}}],["constant",{"_index":1144,"t":{"834":{"position":[[209,8]]}}}],["construct",{"_index":1610,"t":{"864":{"position":[[543,9]]}}}],["consuming",{"_index":34,"t":{"740":{"position":[[384,9]]},"814":{"position":[[391,10]]}}}],["container",{"_index":468,"t":{"764":{"position":[[131,9],[179,9],[238,9],[1132,9]]},"768":{"position":[[276,10]]},"772":{"position":[[0,9],[46,9],[67,9],[227,9],[282,10],[357,10],[462,10],[496,12],[532,12],[821,12],[882,9],[927,9]]},"832":{"position":[[406,10],[900,9],[1027,10]]},"836":{"position":[[144,9],[181,9],[713,9]]},"854":{"position":[[1093,9],[1109,11],[1341,10]]},"878":{"position":[[30,9]]}}}],["container.addchild(new",{"_index":648,"t":{"772":{"position":[[964,22],[998,22]]}}}],["container.addparticle(particle",{"_index":1170,"t":{"836":{"position":[[671,32]]}}}],["container.blendmode",{"_index":1401,"t":{"854":{"position":[[1558,19]]}}}],["container.getglobalalpha(skipupdate",{"_index":535,"t":{"764":{"position":[[1602,37]]}}}],["container.getglobaltint(skipupdate",{"_index":531,"t":{"764":{"position":[[1476,36]]}}}],["container.getglobaltransform(outmatrix",{"_index":526,"t":{"764":{"position":[[1343,39]]}}}],["container.tint",{"_index":1400,"t":{"854":{"position":[[1481,14]]}}}],["container1",{"_index":634,"t":{"772":{"position":[[479,10],[702,10]]}}}],["container1.addchild(sprite",{"_index":638,"t":{"772":{"position":[[596,28]]}}}],["container1.scale",{"_index":636,"t":{"772":{"position":[[574,16]]}}}],["container2",{"_index":635,"t":{"772":{"position":[[515,10],[717,10]]}}}],["container2.reparentchild(sprite",{"_index":641,"t":{"772":{"position":[[753,33]]}}}],["container(); container.addChild(new Sprite()); container.addChild(new Graphics()); // This will throw a type error DTS Bundles: We now provide a single TypeScript definition file with all pixi exports under the PIXI namespace, similar to the defintion file we generated in v6. This can be useful for users that are using PixiJS in a non-module environment, and need to include the definition file manually. This file can be found on all of our releases on Github in the \"Assets\" section, or through https://pixijs.download/vX.X.X/pixi.d.ts.","s":"v8.2.0","u":"/blog/better-docs-v8","h":"#v820","p":756},{"i":773,"t":"We’re committed to addressing the feedback you’ve shared and continuing to improve PixiJS. In addition to better documentation, you can expect more regular updates to keep you informed about what’s new. Your input is vital to PixiJS’s success, and we encourage you to share your thoughts through Bluesky, Github, and the Discord channel. Thanks for your continued support as we work to make PixiJS better for everyone. The PixiJS Team","s":"πŸ—£οΈ Looking Ahead","u":"/blog/better-docs-v8","h":"#️-looking-ahead","p":756},{"i":775,"t":"Follow Zyie and PixiJS on social media for the latest updates. Join our vibrant community on Discord for real-time discussions and support.","s":"🌐 Stay Connected","u":"/blog/better-docs-v8","h":"#-stay-connected","p":756},{"i":778,"t":"As we mentioned in our previous PixiJS Update post, we are focusing on making PixiJS easier to use and understand. Today we're pushing the project one step closer to that goal and we’re excited to introduce PixiJS Create. An easy to use CLI that provides templates for using PixiJS with your favourite bundler, as well as a new \"Creation Template\" to get you started with PixiJS and its ecosystem.","s":"PixiJS Update - Start building with PixiJS in just one command! πŸš€","u":"/blog/create-cli","h":"","p":777},{"i":780,"t":"PixiJS Create is a new CLI tool that simplifies the process of setting up a PixiJS project. It provides a quick and easy way to create a new PixiJS project with the tools you need to get started with just one command. Whether you prefer using Vite, Webpack, or esbuild, PixiJS Create has you covered. It is as simple as running: NPM: npm create pixi.js@latest Yarn: yarn create pixi.js PNPM: pnpm create pixi.js Bun: bun create pixi.js Then just follow the prompts to select your desired template and you're good to go! When running the tool, you will be presented with an option of either a Bundler Template or a Creation Template. Let's take a closer look at each of these options.","s":"πŸš€ Getting Started","u":"/blog/create-cli","h":"#-getting-started","p":777},{"i":782,"t":"Bundler Templates are stripped-down starting points for setting up PixiJS projects with popular build tools. These templates focus solely on the essentials, giving you a no-frills environment to start your project without any added complexity.","s":"πŸ› οΈ Bundler Templates: Simple and Barebones","u":"/blog/create-cli","h":"#️-bundler-templates-simple-and-barebones","p":777},{"i":784,"t":"Out-of-the-box integration with major bundlers, including: Vite v6 + PixiJS (Recommended) Webpack v5 + PixiJS esbuild + PixiJS PixiJS imported via import maps Bundler Templates are ideal if you want complete control over your project’s setup while skipping the hassle of setting up an entire project. They’re lightweight, efficient, and perfect for custom workflows.","s":"What’s Included?","u":"/blog/create-cli","h":"#whats-included","p":777},{"i":786,"t":"Creation Templates go beyond the basics, offering a fully-featured foundation for building applications with PixiJS. These templates address common challenges developers face when starting a new project, providing tools that simplify screen management, asset handling, audio and more.","s":"🎨 Creation Templates: Feature-Rich Starting Points","u":"/blog/create-cli","h":"#-creation-templates-feature-rich-starting-points","p":777},{"i":788,"t":"Screen Management: Handle transitions and organize application states with ease. Asset Loading: Built-in support for PixiJS AssetPack, making asset management effortless. Audio Playback: Leverage PixiJS Sound for modern WebAudio API features. Responsive Design: Automatic resize handling for various screen sizes. Simple UI: Includes a basic UI library for common UI elements. Animation Tools: Includes preconfigured support for libraries like Spine for skeletal animations and Motion for smooth tweening and transitions. Creation Templates are perfect for developers who want to hit the ground running with a robust foundation, enabling them to focus on building amazing content rather than worrying about setup.","s":"What’s Included?","u":"/blog/create-cli","h":"#whats-included-1","p":777},{"i":790,"t":"For the creation templates we’re starting with support for general web-based applications but are planning to expand the template ecosystem to other platforms soon: Web Template: A general-purpose creation template (available now). Coming Soon: Discord Template: Build multiplayer applications for Discord using their SDK. Facebook Template: Create apps for Facebook Instant Games. YouTube Template: Develop YouTube Playables.","s":"🌍 Creation Templates for Every Platform","u":"/blog/create-cli","h":"#-creation-templates-for-every-platform","p":777},{"i":792,"t":"This project is based on amazing create-vite tool and inspired by the create-game project by Phaser. We are grateful for their work and the inspiration it provided.","s":"Acknowledgements","u":"/blog/create-cli","h":"#acknowledgements","p":777},{"i":794,"t":"Follow Zyie and PixiJS on social media for the latest updates. Join our vibrant community on Discord for real-time discussions and support.","s":"🌐 Stay Connected","u":"/blog/create-cli","h":"#-stay-connected","p":777},{"i":796,"t":"We have exciting news for all animation enthusiasts and game developers! The Spine team has just smashed it out of the park with the release of Spine 4.2, which includes some truly great new features. The best part for us PixiJS users? We can start leveraging these remarkable features today in both v7 and v8! For those unfamiliar, Spine is the standard for creating stunning 2D animations. It offers an intuitive editor and a multitude of runtimes to ensure that your animations can be utilized across various platforms. PixiJS has supported Spine for almost as long as both have existed (around 10 years)! Personally, we have been shipping games with Spine for about that long as well. Initially, we maintained our own player. This worked well, but as Spine evolved and new releases were introduced, we had to invest considerable time and energy to modify our custom player. In the past year, the Esoteric team has been managing the v7 version of the player after PixiJS's elementalcode made the initial implementation on top of their excellent HTML5 runtime. This means that as these incredible updates are released, the PixiJS community can use them almost immediately! Here are a few of the exciting new features:","s":"PixiJS Joins the Spine 4.2 Physics Revolution! πŸš€","u":"/blog/pixi-js-hearts-spine","h":"","p":795},{"i":798,"t":"Spine 4.2 revolutionizes animation with built-in physics, allowing bones to move naturally by simulating real-world physics. This means: Automatic Secondary Motion: Save time and enhance your animations with automated movement for hair, clothing, and more. Dynamic Movement: Enjoy fluid and realistic physics that respond to character movements and animations.","s":"πŸ‹οΈβ€β™‚οΈ Physics in Spine","u":"/blog/pixi-js-hearts-spine","h":"#️️-physics-in-spine","p":795},{"i":800,"t":"You can now attach any PixiJS Container to a slot in your animation with a simple-to-use API. addSlotObject(slotName, object) removeSlotObject(slotName) getSlotObject(slotName)","s":"πŸ“Ž Attachments","u":"/blog/pixi-js-hearts-spine","h":"#-attachments","p":795},{"i":802,"t":"We have not forgotten about v8! Just as we engineered v8 with the goal of being the fastest WebGPU (and WebGL!) renderer available, we applied this same focus to the v8 implementation of Spine. Here are some impressive statistics: 50% Faster: Enjoy significant performance improvements, making it over 50% faster than the previous v7 version. 50% Less Memory: We've optimized memory usage, reducing it by over 50% compared to the current v7 version. We are proud to say that this is one of if not the fastest way to render Spine animations on the web πŸ†. Get ready to create smooth, high-performance animations with ease. We plan on handing this implementation back over to the Spine team once we have dotted all the i's and crossed the t's. The last missing feature is the dark-tint property, which is not currently taken into account when rendering in v8. Other than that, all other features are present. If you are not using dark-tint, then this version will work great on v8; we are already using it in production for our games! We included all the examples in the repo for you to play with here. You can also check out the live v8 examples here","s":"🏎️ v8 Spine Player Beta","u":"/blog/pixi-js-hearts-spine","h":"#️-v8-spine-player-beta","p":795},{"i":804,"t":"Follow Doormat23 and PixiJS on social media for the latest updates. Join our vibrant community on Discord for real-time discussions and support.","s":"πŸ“² Stay Connected","u":"/blog/pixi-js-hearts-spine","h":"#-stay-connected","p":795},{"i":806,"t":"We are excited to announce the launch of the PixiJS Universe, an initiative to further enhance the capabilities of PixiJS and make it even easier for developers to create amazing games and apps. For years, PixiJS has been the most popular 2D renderer for the web, but it was always \"just a rendering engine.\" The community has created many great tools to help developers build games and applications with PixiJS, but we lacked the manpower to maintain and improve these tools, causing fragmentation in the community. To address this, Playco has assembled a dedicated team of developers who will work on PixiJS full-time. Over the next 12 months, we have more than ten projects planned, and in this announcement, we would like to introduce some of them.","s":"Introducing the PixiJS Universe!","u":"/blog/pixi-universe","h":"","p":805},{"i":808,"t":"We have several new projects in the works, and we are releasing them in four phases over the year. We are currently nearing the end of phase 1, which has seen the release of several exciting new tools and libraries for PixiJS:","s":"Phase 1​","u":"/blog/pixi-universe","h":"#phase-1","p":805},{"i":810,"t":"First up we are excited to announce that we will be releasing a beta version of our new website for PixiJS. The current documentation has suffered from long-term organic growth over the years with little structure and as such much of the PixiJS documentation is fragmented across multiple sites. This new website will put everything you need in one place and be easily searchable. We are also planning on improving the documentation and adding more guides and examples, as well as considering translating the documentation into other languages. If you have any ideas on how to improve the site please let us know! Github Repo","s":"PixiJS Website​","u":"/blog/pixi-universe","h":"#pixijs-website","p":805},{"i":812,"t":"Next up is PixiJS React. A library that provides a way to use PixiJS in React applications. PixiJS React is a continuation of the react-pixi library created by Patrick Brouwer, which has been widely used by the PixiJS community in React projects. PixiJS has taken over maintenance of the library and is dedicated to improving the library's performance, documentation, and support for new features. The library provides an easy-to-use interface that makes it easy for developers to create React applications with PixiJS. The library integrates all the core features of PixiJS and allows you to create custom components for 3rd party libraries. Github Repo","s":"PixiJS React​","u":"/blog/pixi-universe","h":"#pixijs-react","p":805},{"i":814,"t":"We have now released a new repository called \"PixiJS Open Games\". This is a collection of open-source games that showcases how to use PixiJS to create games and is released under the MIT license. The purpose of these games is to provide professional examples of how to use PixiJS for game development. The first two games released are a match-3 game and a bubble shooter game. These games not only demonstrate how to use PixiJS for game development but also how to use other libraries such as PixiJS UI and AssetPack. We also have more games planned for release, which will demonstrate how to use PixiJS with other libraries such as PixiJS Layout and PixiJS React. PixiJS Open Games will hopefully be a valuable resource for game developers who want to learn how to use PixiJS for game development and will also be a great source of inspiration for developers looking to create their own games using PixiJS. The project is available on GitHub for anyone who wants to explore the code or contribute to the project. Github Repo Play Puzzling Potions Play Bubbo Bubbo","s":"PixiJS Open Games​","u":"/blog/pixi-universe","h":"#pixijs-open-games","p":805},{"i":816,"t":"PixiJS UI is a new library for developers who want to create beautiful and functional user interfaces with PixiJS. The library includes a range of components such as buttons, checkboxes, sliders, text inputs, scroll views, lists, radio buttons, and progress bars, which can be easily integrated into your game. These components are highly customizable, allowing you to tweak the appearance and behaviour of each element to fit your game's specific needs. PixiJS UI has been used in all of the open-source games, so feel free to check these out for real-world examples. PixiJS UI Github Repo PixiJS Layout is another library that can make your life as a developer easier. This library enables you to create responsive layouts using PixiJS, which means you can design interfaces that adapt to different screen sizes and aspect ratios. PixiJS Layout works well with PixiJS UI, allowing you to combine both libraries to create complex, dynamic interfaces that respond to user input and screen changes. With PixiJS Layout, you have the flexibility to create resizable layouts that can be adjusted to fit any screen size or device. This means that your game's interface can look great on everything from small mobile devices to large desktop displays. PixiJS Layout is still under development but will be ready in the next few weeks PixiJS Layout Github Repo","s":"PixiJS UI & PixiJS Layout​","u":"/blog/pixi-universe","h":"#pixijs-ui--pixijs-layout","p":805},{"i":818,"t":"Finally, for phase 1 we are announcing AssetPack. Asset management is an important part of developing applications, and the new AssetPack library aims to make this process easier. AssetPack is a framework-agnostic library that can be used with any framework, including PixiJS, ThreeJS, and Phaser. It provides a range of features that help developers manage their assets efficiently. The key feature of AssetPack is the ability to automatically generate new assets on the fly. For example, you can provide it with a folder of individual images and it will generate sprite sheets, which can significantly improve the performance of your application. It also provides plugins to generate mipmaps, convert fonts to different formats, convert audio to different formats, compress images, and minify JSON. These features help developers optimize their assets for faster loading times, better performance, and improved user experience. We will soon be releasing a new blog post that provides more details on how to use it. With its many useful features and framework-agnostic design. However, if you want to get stuck in today then check out the GitHub repo Github Repo","s":"AssetPack​","u":"/blog/pixi-universe","h":"#assetpack","p":805},{"i":820,"t":"Phase 2 will begin shortly and aims to make it easier to work with PixiJS applications.","s":"Phase 2​","u":"/blog/pixi-universe","h":"#phase-2","p":805},{"i":822,"t":"Jumpstart is a new CLI tool being developed by the PixiJS team to simplify the process of creating new PixiJS applications. With this tool, developers will no longer need to set up complicated tooling or worry about setting up different bundlers and frameworks. The tool will handle all the setup for you, allowing you to focus on building your application. Jumpstart will be similar to other CLI tools such as Create-React-App or Create-Vue, which have become popular in the front-end development community. The tool will provide templates for different bundlers and frameworks, including webpack, parcel, rollup, and more. This will make it easy for developers to get started with PixiJS regardless of their preferred tools and workflows. With Jumpstart, you'll be able to create a new PixiJS application in just a few minutes and start building right away.","s":"PixiJS JumpStart​","u":"/blog/pixi-universe","h":"#pixijs-jumpstart","p":805},{"i":824,"t":"PixiJS dev tools will be a browser extension that is planned to be released soon to help developers debug their PixiJS applications. This tool aims to make it easier for developers to understand the inner workings of PixiJS, optimize their code, and follow best practices. It is designed to help developers diagnose performance issues and visualize the resources that their applications are consuming. One of the key features of the PixiJS Dev Tools is its ability to help developers understand the complex process of batching in PixiJS. Batching is a technique used to optimize the rendering of multiple objects in the same draw call. This process can be complicated to understand, especially for new developers. PixiJS Dev Tools aims to make it easier to debug and optimize the rendering of objects. Overall, PixiJS Dev Tools will be a powerful tool that will make it easier for developers to build high-performance, visually stunning applications with PixiJS. By providing developers with a deeper understanding of the inner workings of PixiJS, this toolset will help developers optimize their code and create more efficient and engaging applications.","s":"PixiJS Dev Tools​","u":"/blog/pixi-universe","h":"#pixijs-dev-tools","p":805},{"i":826,"t":"Phase 3 is where our long-term projects start to be revealed. These are major changes to the PixiJS ecosystem that we are incredibly excited about","s":"Phase 3​","u":"/blog/pixi-universe","h":"#phase-3","p":805},{"i":828,"t":"Comet will be a new editor that aims to make it easier than ever to design and create games and applications with PixiJS. With its intuitive and user-friendly interface, the editor is designed to appeal to both designers and developers, allowing both groups to collaborate and work more efficiently. One of the standout features of Comet is the visual interface it provides for creating and editing scenes, sprites, animations, and more. This means that designers can create and edit complex scenes without ever having to write a single line of code. The editor provides a range of tools and options for creating sprites, animations, and other game elements, making it easy to get started with creating a game or application. In addition, developers will appreciate the runtime player feature, which allows them to easily recreate scenes in their own applications. This makes it easy to test and iterate on designs, ensuring that the final product is both functional and visually appealing. And with multi-user, real-time collaboration, Comet makes it easy for teams to work together, sharing assets and ideas and creating high-quality games and applications in record time.","s":"Comet​","u":"/blog/pixi-universe","h":"#comet","p":805},{"i":830,"t":"PixiJS v8 will be the next major release that represents a complete rewrite of PixiJS from the ground up. The development team has leveraged their extensive experience over many years to make improvements and optimizations to the core PixiJS engine. The new version of PixiJS is designed to be faster and more efficient, providing a significant improvement in rendering performance compared to v7 (currently sitting at x2) One of the most exciting features of PixiJS v8 is the inclusion of first-class support for WebGPU, which is a new graphics API that is being developed by major browser vendors. This will enable developers to take advantage of advanced GPU capabilities, which can significantly improve the performance of graphics-intensive applications. In addition to WebGPU support, the PixiJS team has also made a significant effort to optimize the engine for the canvas renderer, which will be available as a first-class option for developers looking to reduce bundle size. Overall, PixiJS v8 represents a major leap forward for us, developers can expect a much faster and more efficient engine that is better suited for building complex, graphics-intensive applications.","s":"PixiJS v8​","u":"/blog/pixi-universe","h":"#pixijs-v8","p":805},{"i":832,"t":"Phase 4 represents a leap into new territory for PixiJS as we look to delve deeper into areas outside of strictly 2D rendering.","s":"Phase 4​","u":"/blog/pixi-universe","h":"#phase-4","p":805},{"i":834,"t":"For years, Goodboy (now Playco) has had an internal 3D engine called Odie that was built on top of PixiJS. We are now planning to open-source it, which is exciting for those of you who want to seamlessly mix 2D and 3D content in your games or applications. With PixiJS 3D, you will no longer need to switch between engines or frameworks to incorporate 3D elements in your project. Although this is a long-term project, the team is making progress and plans to share more information later in the year. This release will greatly expand PixiJS's capabilities and give developers even more flexibility when building their applications.","s":"PixiJS 3D​","u":"/blog/pixi-universe","h":"#pixijs-3d","p":805},{"i":836,"t":"Finally, we are thrilled to announce that we will be working on a new library called PixiJS Game Engine. This game engine aims to provide everything you would expect from a 2D/3D game engine and will offer many features and tools to make game development easier and more efficient. Some of the features of PixiJS Game Engine will include support for physics engines, audio, input handling, asset loading and management, state management, animation and tweening, and more.","s":"PixiJS Game Engine​","u":"/blog/pixi-universe","h":"#pixijs-game-engine","p":805},{"i":838,"t":"We've shared a lot of exciting news about new projects and updates coming to the PixiJS community. There's a lot to look forward to in the upcoming months. We want to extend our sincere thanks to the PixiJS community, its contributors, and Playco for making all of this possible. We're excited to see what you'll create with these new tools and resources, and we look forward to continuing to support and grow the PixiJS ecosystem. Be sure to check out the GitHub links mentioned above and stay tuned for more updates on the PixiJS Universe!","s":"Conclusion","u":"/blog/pixi-universe","h":"#conclusion","p":805},{"i":840,"t":"PixiJS v8 has taken speed to the next level with the release of its new ParticleContainer. This new feature brings a jaw-dropping performance boost, capable of rendering 100K+ without breaking a sweat. If you’ve got tons of elements to throw on the screen, you’re in for a treat!","s":"ParticleContainer - The New Speed Demon in PixiJS v8","u":"/blog/particlecontainer-v8","h":"","p":839},{"i":842,"t":"The key difference in PixiJS v8 is that the ParticleContainer doesn’t deal with sprites any more, it works with lightweight particles. While particles share many properties with sprites (like texture, position, anchor, scale, rotation, alpha and color), they cut out unnecessary overhead. The result is speed, pure and simple. How fast, you ask? Well, take a look on my machine (Macbook Pro M3): Sprites + Container: 200,000 at 60fps. Particles + ParticleContainer: 1,000,000 at 60fps! Yes, that’s a million bunnies on-screen, and honestly the main bottleneck at that point wasn’t even rendering but the logic behind the bouncing movement! Give this a spin and see for yourself: The key takeaway is that you can now render huge volumes of elements absurdly fast, making PixiJS v8 a perfect choice for high-performance games or visually intensive projects. And yes this is faster than the v7 particle container by over 3x! Please checkout the migration guide for more information on how to migrate your code to the new particle container.","s":"πŸš€ New ParticleContainer Design","u":"/blog/particlecontainer-v8","h":"#-new-particlecontainer-design","p":839},{"i":844,"t":"To get the most out of this performance beast, it’s essential to understand static vs. dynamic properties. PixiJS gives you full control over which properties update every frame (dynamic) and which don’t need constant updates (static). Here’s how they work: Static properties: Once set, they stay the same unless explicitly changed. By keeping them static, you reduce computational load, meaning faster rendering. This is your responsibility to update :) Dynamic properties: These are recalculated and uploaded to the GPU every frame regardless. By default, only the position is dynamic, but you can configure others if needed. The fewer dynamic properties you have, the faster the rendering will be!","s":"Speed Secret: Static vs. Dynamic Properties","u":"/blog/particlecontainer-v8","h":"#speed-secret-static-vs-dynamic-properties","p":839},{"i":846,"t":"Let’s walk through a simple example of how to get started: import { ParticleContainer, Particle, Texture } from 'pixi.js'; // Create a particle container with default options const container = new ParticleContainer({ // this is the default, but we show it here for clarity dynamicProperties: { position: true, // Allow dynamic position changes (default) scale: false, // Static scale for extra performance rotation: false, // Static rotation color: false // Static color } }); // Add particles const texture = Texture.from('path/to/bunny.png'); for (let i = 0; i < 100000; ++i) { let particle = new Particle({ texture, x: Math.random() * 800, y: Math.random() * 600, }); container.addParticle(particle); } // Add container to the Pixi stage app.stage.addChild(container); In this example, we create a ParticleContainer, set properties to static where possible, and generate a 100k particles. By using a shared texture (hello, sprite sheets!), we ensure that all particles share the same graphical assets, making rendering even more efficient.","s":"PixiJS v8 Particle Container Usage","u":"/blog/particlecontainer-v8","h":"#pixijs-v8-particle-container-usage","p":839},{"i":848,"t":"The ParticleContainer shines when you need insane numbers of visual elements on-screen, especially when you want them moving and interacting in real time. Whether you're building particle effects, swarms of characters, or abstract art installations, PixiJS v8 has you covered. The static vs. dynamic property system gives you granular control over performance, allowing you to fine-tune the balance between flexibility and speed. This is basically the fastest we could make it by still keeping allowing for different textures (via sprite sheets) and still empowering devs to manipulate the particles via JS and not having to move the movement to the GPU (which might be faster, but is more complex and less flexible). So even though we are choosing to call them particles, they are more like something in between a traditional particle and a classic sprite. This is ideal for projects where frame rate and rendering volume matterβ€”such as games, interactive apps, and high-volume data visualization. By controlling the dynamic properties of your particles, you can optimize your application’s performance to fit your needs.","s":"Reasons to Use ParticleContainer","u":"/blog/particlecontainer-v8","h":"#reasons-to-use-particlecontainer","p":839},{"i":850,"t":"The new ParticleContainer is a game-changer, but there are still some areas for improvement! For one, there is room to optimise further the static uploading of properties (you may notice the example above is slower when adding bunnys - but then speeds up once stable). We plan to expose how the particles are batched so that developers can add / remove attributes from the batch to make it even faster or add more flexibility and customization. But for now, this is a great starting point and we hope you enjoy the new ParticleContainer!","s":"Next Steps","u":"/blog/particlecontainer-v8","h":"#next-steps","p":839},{"i":852,"t":"PixiJS v8’s ParticleContainer is a game-changer when it comes to rendering at scale. Its ability to push millions of particles at full speed opens up a world of possibilities for game developers, animators, and creative coders. Get in, experiment with the new API, and see just how fast your visuals can fly! Ready to give it a spin? Try out the new ParticleContainer in PixiJS v8, and push the limits of performance in your projects!","s":"πŸŽ‰ Conclusion","u":"/blog/particlecontainer-v8","h":"#-conclusion","p":839},{"i":854,"t":"Follow Doormat23 and PixiJS on social media for the latest updates. Join our vibrant community on Discord for real-time discussions and support.","s":"🌐 Stay Connected","u":"/blog/particlecontainer-v8","h":"#-stay-connected","p":839},{"i":856,"t":"We're thrilled to offer an exclusive preview of the future of 2D web graphics with the Beta release of PixiJS v8. Although not yet finalized, this Beta iteration is packed with killer performance improvements and features we're eager for you to start playing with! Over the course of a decadeβ€”yes, you read that right, ten years!β€”we've implemented significant changes to the PixiJS engine. But the advancements in this new release are among the most monumental we've ever made! Two driving factors catalysed our approach to re-engineering the codebase and rendering pipeline in v8:","s":"PixiJS v8 Beta! πŸŽ‰","u":"/blog/pixi-v8-beta","h":"","p":855},{"i":858,"t":"The newcomer WebGPU offers a substantial performance improvement over its predecessor, WebGL. It propels web computations and graphics into a new era, providing a more efficient and robust API. Soon, it will be the go-to method for rendering most GPU-powered content on the web. This shift is reminiscent of PixiJS's initial launch. At that time, WebGL was new and only available in a handful of desktop browsers, while Canvas was ubiquitous. PixiJS's standout feature was its ability to first attempt rendering with WebGL and then fall back to Canvas as a Plan B. This approach allowed PixiJS content to immediately benefit as WebGL gained traction. Fast forward to today, and WebGL is now available on 95% of browsers. History is repeating itself with WebGPU, currently supported in only a few desktop browsers and roughly 27% of the market. However, it's only a matter of time before it becomes universally supported. PixiJS aims to execute the same fallback strategy, allowing you to always leverage the best technology available without needing to rewrite your code. This is precisely what version 8 achieves and will future proof everything we make for another ten years :D","s":"1. 😍 Embracing WebGPU","u":"/blog/pixi-v8-beta","h":"#1--embracing-webgpu","p":855},{"i":860,"t":"PixiJS has always been synonymous with speed and high-performance graphics. With v8, we've revisited our architecture to optimize both static and dynamic rendering. While v7 is fast, it operates as a somewhat β€˜naΓ―ve’ renderer. v7 approach:​ Traverse the scene graph and make sure all the transforms are correct Traverse the scene graph a second time and do the following Build batches to render Upload the data to the GPU Draw the batch to the screen. v8 approach​ Update the transform of only things that changed Traverse the scene graph and construct a set of instructions. Upload all scene data to GPU in one go. Execute rendering based on the instructions. There are three key changes to this loop that give us a performance bump. First, we update only the elements that have changed. If nothing has moved, no code is executed, optimizing computational overhead. Second, if the scene graph remains unchanged in subsequent frames, we reuse the existing rendering instructions. This avoids the overhead of reconstructing these instructions for each frame. Third, if no elements in the scene change position, the data upload step (Step 3) is entirely skipped, thereby saving bandwidth and further reducing computational work. The net effect of these improvements? A decent performance leap across varying use-cases: CPU = time spent by the cpu rendering a single frame GPU = time spend by the gpu rendering a single frame Bunny Situation V7 CPU V8 CPU CPU Dif V7 GPU V8 GPU GPU dif 100k sprites all moving ~50ms ~15ms 233% ~9ms ~2ms 350% 100k sprites not moving ~21ms ~0.12ms 17417% ~9ms ~0.5ms 1700% 100k sprites (changing scene structure) ~50ms ~24ms 108% ~9ms ~2ms 350% These benchmark numbers are based on this Bunnymark test that you can try yourself! v7 Bunnymark v8 Bunnymark - WebGPU v8 Bunnymark - WebGL Repo Please have a play, you can fiddle with the parameters in the url to change the number of bunnies. Curious to see what numbers all of you get! Best of all, these improvements apply to WebGPU and the WebGL renderer. As with all of PixiJs’s party tricks, this all happens automatically :D","s":"2. πŸš€ Turbocharging Performance","u":"/blog/pixi-v8-beta","h":"#2--turbocharging-performance","p":855},{"i":862,"t":"While the two key drivers behind this overhaul were performance and usability, we didn't stop there. We've seized this opportunity to enhance the API and introduce a plethora of new features to the engineβ€”far too many to encapsulate in a single post! Stay tuned for upcoming blog posts where we'll delve deeper into these additional improvements and API refinements, empowering you to create even more remarkable projects. For a comprehensive overview of what's new, don't miss the release notes. As a crucial note, PixiJS v8 retains much of the familiar API despite undergoing significant internal updates. Our changes are geared toward making PixiJS more robust and user-friendly. When you encounter modifications, rest assured that the v7 methodology will continue to workβ€”you'll simply see a deprecation warning, guiding you towards optimal practices.","s":"But Wait, There's More!","u":"/blog/pixi-v8-beta","h":"#but-wait-theres-more","p":855},{"i":864,"t":"As we progress toward the release candidate, now is the perfect time for you to dive in and explore v8. Your feedback at this stage is invaluable for fine-tuning our engine. We invite you to share your thoughtsβ€”the good, the bad, and the uglyβ€”report bugs, and even contribute code. Together, we can elevate PixiJS to unprecedented heights. πŸ‘‡ Don't waitβ€”dive right in! Explore the PixiJS v8 Codebase on GitHub","s":"Over to you!","u":"/blog/pixi-v8-beta","h":"#over-to-you","p":855},{"i":866,"t":"via npm you can install the beta version like so: npm install pixi.js@prerelease-v8 then you can create the most appropriate renderer using the new autoDetectRenderer function: import { autoDetectRenderer } from \"pixi.js\"; async function init() { const renderer = await autoDetectRenderer({ // any settings }); // will return a WebGL or WebGPU renderer } Start experimenting with PixiJS v8 Beta today and join us in shaping the future of 2D web graphics! πŸŽ‰","s":"Steps to install:","u":"/blog/pixi-v8-beta","h":"#steps-to-install","p":855},{"i":868,"t":"\"To stay in the loop, we invite you to follow Doormat23 and PixiJS on social media, where we'll be unveiling more exciting updates shortly. Alternatively, you can join our vibrant community on Discord for direct engagement and real-time conversations.","s":"Keep in touch!","u":"/blog/pixi-v8-beta","h":"#keep-in-touch","p":855},{"i":870,"t":"Get ready to push the boundaries of what's possible on the web! PixiJS v8 has landed, and it's a game-changer. Celebrating a decade of driving innovation, we've supercharged PixiJS with the latest technological advancements, making it faster, more robust, and ridiculously powerful. From the seamless integration of WebGPU to leveraging modern JavaScript for smoother development, PixiJS v8 is all about empowering you to create jaw-dropping web experiences with ease. It's not just an update; it's the future of 2D web graphics, today. Dive in and let PixiJS v8 elevate your projects to unseen heights. Let's make the web a more beautiful place, one pixi(el) at a time.","s":"PixiJS v8 Launches! πŸŽ‰","u":"/blog/pixi-v8-launches","h":"","p":869},{"i":872,"t":"It's hard to believe that PixiJS has been part of the open-source community for a whopping ten years. In that time, the digital landscape has evolved tremendously, and so has PixiJS. We've seen significant updates, like the transition to TypeScript, and we've overhauled major parts of the engine, such as asset loading and WebGL integration. Now, we're thrilled to unveil PixiJS v8, arguably our most substantial update ever. This release is not just a reflection on the shortcomings of v7, which has served us well, but an acknowledgment that there's always room for improvement. Over time, we've all encountered aspects of our code we wished we could refine. Often, the best solutions and insights emerge only after we've stepped back from the problem, allowing us to see the bigger picture. With PixiJS v8, our aim was to revisit and enhance the foundation of PixiJS, streamlining its core rather than just adding layers of code. Our vision for v8 was clear: Longevity: We designed v8 to stand the test of time, anticipating it will remain relevant and robust for another decade. Innovation with WebGPU: Embracing the latest in rendering technology, we've seamlessly integrated WebGPU, not as an add-on to our existing WebGL renderer but as a core paradigm, ensuring PixiJS remains at the cutting edge as WebGL phases out. Leveraging Modern JavaScript: The advancements in JavaScript have significantly simplified development. We've utilized features like object destructuring and options to make v8 cleaner and more powerful. Correcting Past Oversights: Every project has its lessons. With v8, we've addressed and rearchitected certain aspects of PixiJS, reducing complexity and enhancing functionality, particularly in areas we felt were overengineered in the past (looking at you, textures!). Boosting Performance: PixiJS is already renowned for its speed. With v8, we've unlocked even greater performance, making it faster across the board compared to v7. We're incredibly proud of PixiJS v8 and eager to share the improvements and new features with you. While there are some breaking API changes, we've provided a migration guide and ensured compatibility with v7 wherever possible. Get ready to experience the next level of 2D rendering with PixiJS v8!","s":"πŸš€ Revolutionizing Web Graphics: Welcome to PixiJS v8","u":"/blog/pixi-v8-launches","h":"#-revolutionizing-web-graphics-welcome-to-pixijs-v8","p":869},{"i":874,"t":"The new Docs for v8 can be found here Migration Examples Open Games","s":"πŸ”— Quick links","u":"/blog/pixi-v8-launches","h":"#-quick-links","p":869},{"i":876,"t":"There are numerous updates to discuss, more than can be covered in a single post! Below are the key highlights. For a more detailed exploration of these changes, be sure to follow the links provided above. πŸ“ˆ New Performance Bar​ The performance of v8 is faster for both renderers. This means by using v8 and the WebGL renderer, all the speed improvements apply! This is mainly as we have taken great care to make a more reactive render loop that only updates what it needs to. Check out the numbers here: CPU = time spent by the CPU rendering a single frame GPU = time spent by the GPU rendering a single frame Bunny Situation V7 CPU V8 CPU CPU Dif V7 GPU V8 GPU GPU dif 100k sprites all moving ~50ms ~15ms 233% ~9ms ~2ms 350% 100k sprites not moving ~21ms ~0.12ms 17417% ~9ms ~0.5ms 1700% 100k sprites (changing scene structure) ~50ms ~24ms 108% ~9ms ~2ms 350% These benchmark numbers are based on the Bunnymark test that you can try yourself. v7 Bunnymark v8 Bunnymark - WebGPU v8 Bunnymark - WebGL Repo πŸ–₯️ WebGPU Renderer​ We've implemented a WebGPU backend for rendering. Whilst this has created a better graphics paradigm under the hood and set us up for the future of rich web content, it's important to note that WebGPU does not automatically guarantee improved performance over WebGL in all scenarios, as PixiJS often encounters more limitations on the CPU side than the GPU. However, for scenes with numerous batch breaks, such as filters, masks, and blend modes, WebGPU may offer better performance due to its more modern to rendering. As WebGPU is relatively new, it's expected to enhance in speed over time, similar to the development of WebGL. It serves as a solid foundation for future advancements. πŸ“¦ New Package Structure​ No more \"lerna.\" PixiJS is now just one package with one import root: import {stuff} from β€˜pixi.js’. This change means we now have much better tree shaking during app compilation, reducing bundle size if not imported. Old: import { Sprite } from \"@pixi/sprite\"; import { Graphic } from \"@pixi/graphics\"; New: import { Sprite, Graphic } from \"pixi.js\";","s":"🎁 Whats New?","u":"/blog/pixi-v8-launches","h":"#-whats-new","p":869},{"i":878,"t":"When initializing a renderer, this process is now asynchronous. This serves two purposes: firstly, identifying and loading the necessary renderer code to minimize what is loaded for your users. We only load the one backend that your user is using. There's no point in loading all the WebGL stuff if they are using WebGPU. Secondly, the initialization of WebGPU itself is an asynchronous process, so we need to have a promise in there somewhere! import { Application, autoDetectRenderer } from \"pixi.js\"; const app = new Application(); (async () => { await app.init({ // application options }); // or const renderer = await autoDetectRenderer({}); // WebGL or WebGPU // do pixi things })(); 🌟 Scene Upgrades​ The concept of render groups has been introduced, enabling containers to utilize GPU for their transformations. This facilitates a true 2D hardware-accelerated camera, ideal for navigating large static worlds through panning and zooming, similar to how a camera moves in a 3D environment rather than moving the world itself. This approach can significantly enhance performance. const container = new Container({ isRenderGroup:true // this containers transform is now handled on the GPU! }) Another cool new change is that now blend modes and tints are inherited, much like transforms and alpha. This means you can now easily tint a container, and all its children will have the tint applied - same for blend modes, its as easy as: // will make all the children tinted red container.tint = 'red' // will make all the children have the add blend mode container.blendMode = 'add' Rendering to a texture with antialiasing has been simplified; you only need to enable the new antialiasing property by setting it to true during the creation of a render texture or when applying a filter, similar to the process used for creating your renderer. const texture = RenderTexture.create({ width:100, height:100, antialias:true // easy as that }) We have also added support for a wide range of Photoshop-like filters, This allows you to take your rendering to the next level! We have including all the classics: ColorBlend, ColorBurnBlend, ColorDodgeBlend, DarkenBlend, DifferenceBlend, DivideBlend, ExclusionBlend, HardLightBlend, HardMixBlend, LightenBlend, LinearBurnBlend, LinearDodgeBlend, LinearLightBlend, LuminosityBlend, NegationBlend, OverlayBlend, PinLightBlend, SaturationBlend, SoftLightBlend, SubtractBlend, VividLightBlend. It's important to mention that these are essentially filters at the core, so it's advisable not to overuse them to avoid potential slowdowns. import `pixi.js/advanced-blend-modes` // make sure to include them in you lib! (or cherry pick one!) myContainer.blendMode = 'color-burn` // easy! 🎨 Graphics Upgrades​ The Graphics API has undergone changes to become more intuitive and user-friendly, closely resembling the HTML Canvas 2D context API. For instance, drawing and filling a rectangle is simplified as follows: graphics .rect(50, 50, 100, 100) .fill('blue'); A GraphicsContext has been introduced, powering all graphics operations. Similar to how one texture can be used across many sprites, a single GraphicsContext can now be utilized by multiple Graphics objects, enhancing efficiency and flexibility. Support for SVG drawing has been added. For example: graphics.svg('M 100 350 q 150 -300 300 0'); Gradient fill support has been introduced, currently limited to linear gradients, allowing for more visually engaging designs. The new GraphicsPath class enables the drawing and sharing of shapes. This feature is particularly useful as it allows for the creation of paths that can then be transformed into Mesh geometry using the buildGeometryFromPath function, opening up new possibilities for intricate and detailed graphic designs. const path = new GraphicsPath() .rect(-50, -50, 100, 100) // create geometry from the path: const geometry = buildGeometryFromPath({ path, }); const mesh = new Mesh({ geometry, texture: Texture.WHITE, }); For more information on these graphics upgrades and guidance on how to adapt to the enhanced Graphics API, please refer to the migration guide, or why not jump in and play with some examples. πŸ“ Text Upgrades​ Text has been upgraded to allow for better performance and usability! We have also integrated HTMLText into v8 as standard. BitmapFonts can now be generated on the fly or installed upfront as you prefer. They dynamically add characters as the font's glyphs are required, saving on memory. The layout of bitmap text is almost identical to the layout of the default text now, making it easier to switch between the two depending on your needs. const myText = new BitmapText({ text: 'hello im a bitmap font!', // font will be dynamically created style:{ fontFamily: 'Outfit', fontSize: 12, fill: 'red', } }) Text fills and strokes now conform to the same fills and strokes as graphics. This means Gradients, textures, and all the fun ways you can fill and stroke graphics can now be applied to Text. const myText = new Text({ text: 'hello im some fancy text', // font will be dynamically created! style:{ fontFamily: 'Outfit', fontSize: 12, fill: { texture, color:'red'} // same as graphics api fills stroke: { width:3, color:'blue' } // same as graphics api strokes } })","s":"✨ We promise the Renderer will work","u":"/blog/pixi-v8-launches","h":"#-we-promise-the-renderer-will-work","p":869},{"i":880,"t":"As PixiJS v8 takes its first steps into the world, we're eager to see it grow with your feedback and contributions. Now we know things won't be perfect, but we're committed to quick responses on GitHub and Discord to any issues that arise, valuing your input to make PixiJS even better. A heartfelt thanks to our early adopters (everyone in here) for testing the limits of v8, to our dedicated contributors and team for their hard work. Your efforts and insights are invaluable to us. We could not have gotten here without you! A final big shout-out to PlayCo for their support in making this release a reality! Let's continue to innovate and push the boundaries of web graphics together. Your engagement is key to PixiJS's evolution, and we're excited to see where we can go with your help.","s":"🀝 What now? Get involved!","u":"/blog/pixi-v8-launches","h":"#-what-now-get-involved","p":869},{"i":882,"t":"To stay in the loop, we invite you to follow Doormat23 and PixiJS on social media, where we'll be unveiling more exciting updates shortly. Alternatively, you can join our vibrant community on Discord for direct engagement and real-time chit-chats.","s":"πŸ“² Keep in touch","u":"/blog/pixi-v8-launches","h":"#-keep-in-touch","p":869},{"i":884,"t":"Below are links to assorted PixiJS branding assets usable for including on your site, game, or app. All assets here are free-to-use. If you have any questions or requests, please file an issue.","s":"Branding","u":"/7.x/branding","h":"","p":883},{"i":886,"t":"This is the banner that is displayed at the top of our README.","s":"Banner","u":"/7.x/branding","h":"#banner","p":883},{"i":888,"t":"We recommend using the Logo in places where the audience may not be familiar with PixiJS.","s":"Logo","u":"/7.x/branding","h":"#logo","p":883},{"i":890,"t":"Download: SVG PNG","s":"Logo (Dark)","u":"/7.x/branding","h":"#logo-dark","p":883},{"i":892,"t":"Download: SVG PNG","s":"Logo (Dark, Transparent)","u":"/7.x/branding","h":"#logo-dark-transparent","p":883},{"i":894,"t":"Download: SVG PNG","s":"Logo (Pink)","u":"/7.x/branding","h":"#logo-pink","p":883},{"i":896,"t":"Download: SVG PNG","s":"Logo (Pink, Transparent)","u":"/7.x/branding","h":"#logo-pink-transparent","p":883},{"i":898,"t":"We recommend using the Mark in places where the audience is someone familiar with the ecosystem, such as PixiJS Discord users, plugin authors, social media followers.","s":"Mark","u":"/7.x/branding","h":"#mark","p":883},{"i":900,"t":"512px x 512px Download: SVG PNG","s":"Mark (Pink, Large)","u":"/7.x/branding","h":"#mark-pink-large","p":883},{"i":902,"t":"Download: SVG PNG","s":"Mark (Pink)","u":"/7.x/branding","h":"#mark-pink","p":883},{"i":904,"t":"Download: SVG PNG","s":"Mark (Light)","u":"/7.x/branding","h":"#mark-light","p":883},{"i":906,"t":"Welcome to the PixiJS Examples page! Here you can find a variety of demos and code snippets to help you get started with PixiJS. Check out some of our featured examples below: Basic Container Blend Modes Tiling Sprite Animated Sprite Text Graphics","s":"Examples","u":"/7.x/examples","h":"","p":905},{"i":908,"t":"index.js Loading... Open browser console EditorPreviewBoth","s":"Collision Detection","u":"/7.x/examples/advanced/collision-detection","h":"","p":907},{"i":910,"t":"index.js Loading... Open browser console EditorPreviewBoth","s":"Mouse Trail","u":"/7.x/examples/advanced/mouse-trail","h":"","p":909},{"i":912,"t":"index.js Loading... Open browser console EditorPreviewBoth","s":"Scratch Card","u":"/7.x/examples/advanced/scratch-card","h":"","p":911},{"i":914,"t":"index.js Loading... Open browser console EditorPreviewBoth","s":"Slots","u":"/7.x/examples/advanced/slots","h":"","p":913},{"i":916,"t":"index.js Loading... Open browser console EditorPreviewBoth","s":"Screen Shot","u":"/7.x/examples/advanced/screen-shot","h":"","p":915},{"i":918,"t":"index.js Loading... Open browser console EditorPreviewBoth","s":"Spinners","u":"/7.x/examples/advanced/spinners","h":"","p":917},{"i":920,"t":"index.js Loading... Open browser console EditorPreviewBoth","s":"Async","u":"/7.x/examples/assets/async","h":"","p":919},{"i":922,"t":"index.js Loading... Open browser console EditorPreviewBoth","s":"Star Warp","u":"/7.x/examples/advanced/star-warp","h":"","p":921},{"i":924,"t":"index.js Loading... Open browser console EditorPreviewBoth","s":"Bundle","u":"/7.x/examples/assets/bundle","h":"","p":923},{"i":926,"t":"index.js Loading... Open browser console EditorPreviewBoth","s":"Background","u":"/7.x/examples/assets/background","h":"","p":925},{"i":928,"t":"index.js Loading... Open browser console EditorPreviewBoth","s":"Multiple","u":"/7.x/examples/assets/multiple","h":"","p":927},{"i":930,"t":"index.js Loading... Open browser console EditorPreviewBoth","s":"Promise","u":"/7.x/examples/assets/promise","h":"","p":929},{"i":932,"t":"index.js Loading... Open browser console EditorPreviewBoth","s":"Blend Modes","u":"/7.x/examples/basic/blend-modes","h":"","p":931},{"i":934,"t":"index.js Loading... Open browser console EditorPreviewBoth","s":"Cache As Bitmap","u":"/7.x/examples/basic/cache-as-bitmap","h":"","p":933},{"i":936,"t":"index.js Loading... Open browser console EditorPreviewBoth","s":"Particle Container","u":"/7.x/examples/basic/particle-container","h":"","p":935},{"i":938,"t":"index.js Loading... Open browser console EditorPreviewBoth","s":"Container","u":"/7.x/examples/basic/container","h":"","p":937},{"i":940,"t":"index.js Loading... Open browser console EditorPreviewBoth","s":"Tinting","u":"/7.x/examples/basic/tinting","h":"","p":939},{"i":942,"t":"index.js Loading... Open browser console EditorPreviewBoth","s":"Simple Plane","u":"/7.x/examples/basic/simple-plane","h":"","p":941},{"i":944,"t":"index.js Loading... Open browser console EditorPreviewBoth","s":"Transparent Background","u":"/7.x/examples/basic/transparent-background","h":"","p":943},{"i":946,"t":"index.js Loading... Open browser console EditorPreviewBoth","s":"Click","u":"/7.x/examples/events/click","h":"","p":945},{"i":948,"t":"index.js Loading... Open browser console EditorPreviewBoth","s":"Custom Hitarea","u":"/7.x/examples/events/custom-hitarea","h":"","p":947},{"i":950,"t":"index.js Loading... Open browser console EditorPreviewBoth","s":"Custom Mouse Icon","u":"/7.x/examples/events/custom-mouse-icon","h":"","p":949},{"i":952,"t":"index.js Loading... Open browser console EditorPreviewBoth","s":"Dragging","u":"/7.x/examples/events/dragging","h":"","p":951},{"i":954,"t":"index.js Loading... Open browser console EditorPreviewBoth","s":"Interactivity","u":"/7.x/examples/events/interactivity","h":"","p":953},{"i":956,"t":"index.js Loading... Open browser console EditorPreviewBoth","s":"Nested Boundary With Projection","u":"/7.x/examples/events/nested-boundary-with-projection","h":"","p":955},{"i":958,"t":"index.js Loading... Open browser console EditorPreviewBoth","s":"Pointer Tracker","u":"/7.x/examples/events/pointer-tracker","h":"","p":957},{"i":960,"t":"index.js Loading... Open browser console EditorPreviewBoth","s":"Mouse Blending","u":"/7.x/examples/filters-advanced/mouse-blending","h":"","p":959},{"i":962,"t":"index.js Loading... Open browser console EditorPreviewBoth","s":"Custom","u":"/7.x/examples/filters-advanced/custom","h":"","p":961},{"i":964,"t":"index.js Loading... Open browser console EditorPreviewBoth","s":"Slider","u":"/7.x/examples/events/slider","h":"","p":963},{"i":966,"t":"index.js Loading... Open browser console EditorPreviewBoth","s":"Shader Toy Filter Render Texture","u":"/7.x/examples/filters-advanced/shader-toy-filter-render-texture","h":"","p":965},{"i":968,"t":"index.js Loading... Open browser console EditorPreviewBoth","s":"Blur","u":"/7.x/examples/filters-basic/blur","h":"","p":967},{"i":970,"t":"index.js Loading... Open browser console EditorPreviewBoth","s":"Logger","u":"/7.x/examples/events/logger","h":"","p":969},{"i":972,"t":"index.js Loading... Open browser console EditorPreviewBoth","s":"Color Matrix","u":"/7.x/examples/filters-basic/color-matrix","h":"","p":971},{"i":974,"t":"index.js Loading... Open browser console EditorPreviewBoth","s":"Displacement Map Flag","u":"/7.x/examples/filters-basic/displacement-map-flag","h":"","p":973},{"i":976,"t":"index.js Loading... Open browser console EditorPreviewBoth","s":"Advanced","u":"/7.x/examples/graphics/advanced","h":"","p":975},{"i":978,"t":"index.js Loading... Open browser console EditorPreviewBoth","s":"Displacement Map Crawlies","u":"/7.x/examples/filters-basic/displacement-map-crawlies","h":"","p":977},{"i":980,"t":"index.js Loading... Open browser console EditorPreviewBoth","s":"Dynamic","u":"/7.x/examples/graphics/dynamic","h":"","p":979},{"i":982,"t":"index.js Loading... Open browser console EditorPreviewBoth","s":"Simple","u":"/7.x/examples/graphics/simple","h":"","p":981},{"i":984,"t":"index.js Loading... Open browser console EditorPreviewBoth","s":"Filter","u":"/7.x/examples/masks/filter","h":"","p":983},{"i":986,"t":"index.js Loading... Open browser console EditorPreviewBoth","s":"Graphics","u":"/7.x/examples/masks/graphics","h":"","p":985},{"i":988,"t":"index.js Loading... Open browser console EditorPreviewBoth","s":"Sprite","u":"/7.x/examples/masks/sprite","h":"","p":987},{"i":990,"t":"index.js Loading... Open browser console EditorPreviewBoth","s":"Instanced Geometry","u":"/7.x/examples/mesh-and-shaders/instanced-geometry","h":"","p":989},{"i":992,"t":"index.js Loading... Open browser console EditorPreviewBoth","s":"Merging Geometry","u":"/7.x/examples/mesh-and-shaders/merging-geometry","h":"","p":991},{"i":994,"t":"index.js Loading... Open browser console EditorPreviewBoth","s":"Multi Pass Shader Generated Mesh","u":"/7.x/examples/mesh-and-shaders/multi-pass-shader-generated-mesh","h":"","p":993},{"i":996,"t":"index.js Loading... Open browser console EditorPreviewBoth","s":"Interleaving Geometry","u":"/7.x/examples/mesh-and-shaders/interleaving-geometry","h":"","p":995},{"i":998,"t":"index.js Loading... Open browser console EditorPreviewBoth","s":"Shader Toy Mesh","u":"/7.x/examples/mesh-and-shaders/shader-toy-mesh","h":"","p":997},{"i":1000,"t":"index.js Loading... Open browser console EditorPreviewBoth","s":"Textured Mesh Advanced","u":"/7.x/examples/mesh-and-shaders/textured-mesh-advanced","h":"","p":999},{"i":1002,"t":"index.js Loading... Open browser console EditorPreviewBoth","s":"Shared Shader","u":"/7.x/examples/mesh-and-shaders/shared-shader","h":"","p":1001},{"i":1004,"t":"index.js Loading... Open browser console EditorPreviewBoth","s":"Textured Mesh Basic","u":"/7.x/examples/mesh-and-shaders/textured-mesh-basic","h":"","p":1003},{"i":1006,"t":"index.js Loading... Open browser console EditorPreviewBoth","s":"Sharing Geometry","u":"/7.x/examples/mesh-and-shaders/sharing-geometry","h":"","p":1005},{"i":1008,"t":"index.js Loading... Open browser console EditorPreviewBoth","s":"Triangle Textured","u":"/7.x/examples/mesh-and-shaders/triangle-textured","h":"","p":1007},{"i":1010,"t":"index.js Loading... Open browser console EditorPreviewBoth","s":"Triangle","u":"/7.x/examples/mesh-and-shaders/triangle","h":"","p":1009},{"i":1012,"t":"index.js Loading... Open browser console EditorPreviewBoth","s":"Basic","u":"/7.x/examples/offscreen-canvas/basic","h":"","p":1011},{"i":1014,"t":"index.js Loading... Open browser console EditorPreviewBoth","s":"Uniforms","u":"/7.x/examples/mesh-and-shaders/uniforms","h":"","p":1013},{"i":1016,"t":"index.js Loading... Open browser console EditorPreviewBoth","s":"Animated Sprite Animation Speed","u":"/7.x/examples/sprite/animated-sprite-animation-speed","h":"","p":1015},{"i":1018,"t":"index.js Loading... Open browser console EditorPreviewBoth","s":"Animated Sprite Explosion","u":"/7.x/examples/sprite/animated-sprite-explosion","h":"","p":1017},{"i":1020,"t":"index.js Loading... Open browser console EditorPreviewBoth","s":"Triangle Color","u":"/7.x/examples/mesh-and-shaders/triangle-color","h":"","p":1019},{"i":1022,"t":"index.js Loading... Open browser console EditorPreviewBoth","s":"Basic","u":"/7.x/examples/sprite/basic","h":"","p":1021},{"i":1024,"t":"index.js Loading... Open browser console EditorPreviewBoth","s":"Animated Sprite Jet","u":"/7.x/examples/sprite/animated-sprite-jet","h":"","p":1023},{"i":1026,"t":"index.js Loading... Open browser console EditorPreviewBoth","s":"Texture Swap","u":"/7.x/examples/sprite/texture-swap","h":"","p":1025},{"i":1028,"t":"index.js Loading... Open browser console EditorPreviewBoth","s":"Tiling Sprite","u":"/7.x/examples/sprite/tiling-sprite","h":"","p":1027},{"i":1030,"t":"index.js Loading... Open browser console EditorPreviewBoth","s":"Video","u":"/7.x/examples/sprite/video","h":"","p":1029},{"i":1032,"t":"index.js Loading... Open browser console EditorPreviewBoth","s":"Bitmap Text","u":"/7.x/examples/text/bitmap-text","h":"","p":1031},{"i":1034,"t":"index.js Loading... Open browser console EditorPreviewBoth","s":"Pixi Text","u":"/7.x/examples/text/pixi-text","h":"","p":1033},{"i":1036,"t":"index.js Loading... Open browser console EditorPreviewBoth","s":"From Font","u":"/7.x/examples/text/from-font","h":"","p":1035},{"i":1038,"t":"index.js Loading... Open browser console EditorPreviewBoth","s":"Web Font","u":"/7.x/examples/text/web-font","h":"","p":1037},{"i":1040,"t":"index.js Loading... Open browser console EditorPreviewBoth","s":"Gradient Basic","u":"/7.x/examples/textures/gradient-basic","h":"","p":1039},{"i":1042,"t":"index.js Loading... Open browser console EditorPreviewBoth","s":"Gradient Resource","u":"/7.x/examples/textures/gradient-resource","h":"","p":1041},{"i":1044,"t":"index.js Loading... Open browser console EditorPreviewBoth","s":"Render Texture Advanced","u":"/7.x/examples/textures/render-texture-advanced","h":"","p":1043},{"i":1046,"t":"index.js Loading... Open browser console EditorPreviewBoth","s":"Texture Rotate","u":"/7.x/examples/textures/texture-rotate","h":"","p":1045},{"i":1048,"t":"index.js Loading... Open browser console EditorPreviewBoth","s":"Render Texture Basic","u":"/7.x/examples/textures/render-texture-basic","h":"","p":1047},{"i":1050,"t":"PixiJS is an open source, web-based rendering system that provides blazing fast performance for games, data visualization, and other graphics intensive projects. These guides are designed to be a companion to the API documentation, providing a structured introduction to using the API to solve problems and build projects.","s":"Welcome","u":"/7.x/guides","h":"","p":1049},{"i":1052,"t":"If you're new to PixiJS, we suggest you start with the Basics and read through them in order (a good place to start is Getting Started). While PixiJS has a mature API and solid documentation, the guides go over many common issues and questions that developers new to the system encounter.","s":"About The Guides","u":"/7.x/guides","h":"#about-the-guides","p":1049},{"i":1054,"t":"As you explore the guides, you may find these resources valuable: PixiJS API documentation PixiJS Github repo","s":"Other Resources","u":"/7.x/guides","h":"#other-resources","p":1049},{"i":1057,"t":"Everything! Pixi.js is a rendering library that will allow you to create rich, interactive graphic experiences, cross-platform applications, and games without having to dive into the WebGL API or grapple with the intricacies of browser and device compatibility. Killer performance with a clean API, means not only will your content be better - but also faster to build!","s":"What is PixiJS for?","u":"/7.x/faq","h":"#what-is-pixijs-for","p":1055},{"i":1059,"t":"PixiJS is and always will be free and Open Source. That said, financial contributions are what make it possible to push PixiJS further, faster. Contributions allow us to commission the PixiJS developer community to accelerate feature development and create more in-depth documentation. Support Us by making a contribution via Open Collective. Go on! It will be a massive help AND make you feel good about yourself, win win ;)","s":"Is PixiJS free?","u":"/7.x/faq","h":"#is-pixijs-free","p":1055},{"i":1061,"t":"Visit our GitHub page to download the very latest version of PixiJS. This is the most up-to-date resource for PixiJS and should always be your first port of call to make sure you are using the latest version. Just click the 'Download' link in the navigation.","s":"Where do I get it?","u":"/7.x/faq","h":"#where-do-i-get-it","p":1055},{"i":1063,"t":"Right here! Take a look through the Resources section for a wealth of information including documentation, forums, tutorials and the Goodboy blog.","s":"How do I get started?","u":"/7.x/faq","h":"#how-do-i-get-started","p":1055},{"i":1065,"t":"Because you care about speed. PixiJS' #1 mantra has always been speed. We really do feel the need! We do everything we can to make PixiJS as streamlined, efficient and fast as possible, whilst balancing it with offering as many crucial and valuable features as we can.","s":"Why should I use PixiJS?","u":"/7.x/faq","h":"#why-should-i-use-pixijs","p":1055},{"i":1067,"t":"No. PixiJS is what we've come to think of as a \"creation engine\". Whilst it is extremely good for making games, the core essence of PixiJS is simply moving things around on screens as quickly and efficiently as possible. It does of course happen that it is absolutely brilliant for making games though!","s":"Is PixiJS a game engine?","u":"/7.x/faq","h":"#is-pixijs-a-game-engine","p":1055},{"i":1069,"t":"Outside of the highly active PixiJS community, it is primarily maintained by Mat Groves, Technical Partner of our creative agency Goodboy Digital. One of the huge advantages of creating PixiJS within the framework of a working agency is that it means its features are always driven by genuine industry demands and critically are always trialled \"in anger\" in our cutting-edge games, sites and apps.","s":"Who makes PixiJS?","u":"/7.x/faq","h":"#who-makes-pixijs","p":1055},{"i":1071,"t":"Two things - lets us know via the PixiJS GitHub community and even better yet, if you know how, post a fix! Our Community is stronger in numbers so we're always keen to welcome new contributors into the team to help us shape what PixiJS becomes next.","s":"I found a bug. What should I do?","u":"/7.x/faq","h":"#i-found-a-bug-what-should-i-do","p":1055},{"i":1073,"t":"In this section we're going to build the simplest possible PixiJS application. In doing so, we'll walk through the basics of how to build and serve the code.","s":"Getting Started","u":"/7.x/guides/basics/getting-started","h":"","p":1072},{"i":1075,"t":"A quick note before we start: this guide is aimed at beginning PixiJS developers who have minimal experience developing JavaScript-based applications. If you are a coding veteran, you may find that the level of detail here is not helpful. If that's the case, you may want to skim this guide, then jump into how to work with PixiJS and packers like webpack and npm.","s":"Advanced Users","u":"/7.x/guides/basics/getting-started","h":"#advanced-users","p":1072},{"i":1077,"t":"One final note. The JavaScript universe is currently in transition from old-school JavaScript (ES5) to the newer ES6 flavor: // ES5 var x = 5; setTimeout(function() { alert(x); }, 1000); // ES6 const x = 5; setTimeout(() => alert(x), 1000); ES6 brings a number of major advantages in terms of clearer syntax, better variable scoping, native class support, etc. By now, all major browsers support it. Given this, our examples in these guides will use ES6. This doesn't mean you can't use PixiJS with ES5 programs! Just mentally substitute \"var\" for \"let/const\", expand the shorter function-passing syntax, and everything will run just fine.","s":"A Note About JavaScript","u":"/7.x/guides/basics/getting-started","h":"#a-note-about-javascript","p":1072},{"i":1079,"t":"OK! With those notes out of the way, let's get started. There are only a few steps required to write a PixiJS application: Create an HTML file Serve the file with a web server Load the PixiJS library Create an Application Add the generated view to the DOM Add an image to the stage Write an update loop Let's walk through them together.","s":"Components of a PixiJS Application","u":"/7.x/guides/basics/getting-started","h":"#components-of-a-pixijs-application","p":1072},{"i":1081,"t":"PixiJS is a JavaScript library that runs in a web page. So the first thing we're going to need is some HTML in a file. In a real PixiJS application, you might want to embed your display within a complex existing page, or you might want your display area to fill the whole page. For this demo, we'll build an empty page to start:

      Hello PixiJS

      Create a new folder named pixi-test, then copy and paste this HTML into a new file in the pixi-test folder named index.html.","s":"The HTML File","u":"/7.x/guides/basics/getting-started","h":"#the-html-file","p":1072},{"i":1083,"t":"You will need to run a web server to develop locally with PixiJS. Web browsers prevent loading local files (such as images and audio files) on locally loaded web pages. If you just double-click your new HTML file, you'll get an error when you try to add a sprite to the PixiJS stage. Running a web server sounds complex and difficult, but it turns out there are a number of simple web servers that will serve this purpose. For this guide, we're going to be working with Mongoose, but you could just as easily use XAMPP or the http-server Node.js package to serve your files. To start serving your page with Mongoose, go to the Mongoose download page and download the free server for your operating system. Mongoose defaults to serving the files in the folder it's run in, so copy the downloaded executable into the folder you created in the prior step (pixi-test). Double-click the executable, tell your operating system that you trust the file to run, and you'll have a running web server, serving your new folder. Test that everything is working by opening your browser of choice and entering http://127.0.0.1:8080 in the location bar. (Mongoose by default serves files on port 8080.) You should see \"Hello PixiJS\" and nothing else. If you get an error at this step, it means you didn't name your file index.html or you mis-configured your web server.","s":"Serving the File","u":"/7.x/guides/basics/getting-started","h":"#serving-the-file","p":1072},{"i":1085,"t":"OK, so we have a web page, and we're serving it. But it's empty. The next step is to actually load the PixiJS library. If we were building a real application, we'd want to download a target version of PixiJS from the Pixi Github repo so that our version wouldn't change on us. But for this sample application, we'll just use the CDN version of PixiJS. Add this line to the section of your index.html file: This will include a non-minified version of the latest version of PixiJS when your page loads, ready to be used. We use the non-minified version because we're in development. In production, you'd want to use pixi.min.js instead, which is compressed for faster download and excludes assertions and deprecation warnings that can help when building your project, but take longer to download and run.","s":"Loading PixiJS","u":"/7.x/guides/basics/getting-started","h":"#loading-pixijs","p":1072},{"i":1087,"t":"Loading the library doesn't do much good if we don't use it, so the next step is to start up PixiJS. Start by replacing the line

      Hello PixiJS

      with a script tag like so: What we're doing here is adding a JavaScript code block, and in that block creating a new PIXI.Application instance. Application is a helper class that simplifies working with PixiJS. It creates the renderer, creates the stage, and starts a ticker for updating. In production, you'll almost certainly want to do these steps yourself for added customization and control - we'll cover doing so in a later guide. For now, the Application class is a perfect way to start playing with PixiJS without worrying about the details.","s":"Creating an Application","u":"/7.x/guides/basics/getting-started","h":"#creating-an-application","p":1072},{"i":1089,"t":"When the PIXI.Application class creates the renderer, it builds a Canvas element that it will render to. In order to see what we draw with PixiJS, we need to add this Canvas element to the web page's DOM. Append the following line to your page's script block: document.body.appendChild(app.view); This takes the view created by the application (the Canvas element) and adds it to the body of your page.","s":"Adding the View to the DOM","u":"/7.x/guides/basics/getting-started","h":"#adding-the-view-to-the-dom","p":1072},{"i":1091,"t":"So far all we've been doing is prep work. We haven't actually told PixiJS to draw anything. Let's fix that by adding an image to be displayed. There are a number of ways to draw images in PixiJS, but the simplest is by using a Sprite. We'll get into the details of how the scene graph works in a later guide, but for now all you need to know is that PixiJS renders a hierarchy of DisplayObjects. A Sprite is a type of DisplayObject that wraps a loaded image resource to allow drawing it, scaling it, rotating it, and so forth. Before PixiJS can render an image, it needs to be loaded. Just like in any web page, image loading happens asynchronously. We'll talk a lot more about resource loading in later guides. For now, we can use a helper method on the PIXI.Sprite class to handle the image loading for us: // Magically load the PNG asynchronously let sprite = PIXI.Sprite.from('sample.png'); Download the sample PNG here, and save it into your pixi-test directory next to your index.html.","s":"Creating a Sprite","u":"/7.x/guides/basics/getting-started","h":"#creating-a-sprite","p":1072},{"i":1093,"t":"Finally, we need to add our new sprite to the stage. The stage is simply a Container that is the root of the scene graph. Every child of the stage container will be rendered every frame. By adding our sprite to the stage, we tell PixiJS's renderer we want to draw it. app.stage.addChild(sprite);","s":"Adding the Sprite to the Stage","u":"/7.x/guides/basics/getting-started","h":"#adding-the-sprite-to-the-stage","p":1072},{"i":1095,"t":"While you can use PixiJS for static content, for most projects you'll want to add animation. Our sample app is actually cranking away, rendering the same sprite in the same place multiple times a second. All we have to do to make the image move is to update its attributes once per frame. To do this, we want to hook into the application's ticker. A ticker is a PixiJS object that runs one or more callbacks each frame. Doing so is surprisingly easy. Add the following to the end of your script block: // Add a variable to count up the seconds our demo has been running let elapsed = 0.0; // Tell our application's ticker to run a new callback every frame, passing // in the amount of time that has passed since the last tick app.ticker.add((delta) => { // Add the time to our total elapsed time elapsed += delta; // Update the sprite's X position based on the cosine of our elapsed time. We divide // by 50 to slow the animation down a bit... sprite.x = 100.0 + Math.cos(elapsed/50.0) * 100.0; }); All you need to do is to call app.ticker.add(...), pass it a callback function, and then update your scene in that function. It will get called every frame, and you can move, rotate etc. whatever you'd like to drive your project's animations.","s":"Writing an Update Loop","u":"/7.x/guides/basics/getting-started","h":"#writing-an-update-loop","p":1072},{"i":1097,"t":"That's it! The simplest PixiJS project! Here's the whole thing in one place. Check your file and make sure it matches if you're getting errors. Once you have things working, the next thing to do is to read through the rest of the Basics guides to dig into how all this works in much greater depth.","s":"Putting It All Together","u":"/7.x/guides/basics/getting-started","h":"#putting-it-all-together","p":1072},{"i":1099,"t":"Now that you understand the major parts of the system, let's look at how these parts work together to get your project onto the screen. Unlike a web page, PixiJS is constantly updating and re-drawing itself, over and over. You update your objects, then PixiJS renders them to the screen, then the process repeats. We call this cycle the render loop. The majority of any PixiJS project is contained in this update + render cycle. You code the updates, PixiJS handles the rendering. Let's walk through what happens each frame of the render loop. There are three main steps.","s":"Render Loop","u":"/7.x/guides/basics/render-loop","h":"","p":1098},{"i":1101,"t":"The first step is to calculate how much time has elapsed since the last frame, and then call the Application object's ticker callbacks with that time delta. This allows your project's code to animate and update the sprites, etc. on the stage in preparation for rendering.","s":"Running Ticker Callbacks","u":"/7.x/guides/basics/render-loop","h":"#running-ticker-callbacks","p":1098},{"i":1103,"t":"We'll talk a lot more about what a scene graph is and what it's made of in the next guide, but for now, all you need to know is that it contains the things you're drawing - sprites, text, etc. - and that these objects are in a tree-like hierarchy. After you've updated your game objects by moving, rotating and so forth, PixiJS needs to calculate the new positions and state of every object in the scene, before it can start drawing.","s":"Updating the Scene Graph","u":"/7.x/guides/basics/render-loop","h":"#updating-the-scene-graph","p":1098},{"i":1105,"t":"Now that our game's state has been updated, it's time to draw it to the screen. The rendering system starts with the root of the scene graph (app.stage), and starts rendering each object and its children, until all objects have been drawn. No culling or other cleverness is built into this process. If you have lots of objects outside of the visible portion of the stage, you'll want to investigate disabling them as an optimization.","s":"Rendering the Scene Graph","u":"/7.x/guides/basics/render-loop","h":"#rendering-the-scene-graph","p":1098},{"i":1107,"t":"A note about frame rates. The render loop can't be run infinitely fast - drawing things to the screen takes time. In addition, it's not generally useful to have a frame updated more than once per screen update (commonly 60fps, but newer monitors can support 144fps and up). Finally, PixiJS runs in the context of a web browser like Chrome or Firefox. The browser itself has to balance the needs of various internal operations with servicing any open tabs. All this to say, determining when to draw a frame is a complex issue. In cases where you want to adjust that behavior, you can set the minFPS and maxFPS attributes on a Ticker to give PixiJS hints as to the range of tick speeds you want to support. Just be aware that due to the complex environment, your project cannot guarantee a given FPS. Use the passed delta value in your ticker callbacks to scale any animations to ensure smooth playback.","s":"Frame Rates","u":"/7.x/guides/basics/render-loop","h":"#frame-rates","p":1098},{"i":1109,"t":"What we've just covered is the default render loop provided out of the box by the Application helper class. There are many other ways of creating a render loop that may be helpful for advanced users looking to solve a given problem. While you're prototyping and learning PixiJS, sticking with the Application's provided system is the recommended approach.","s":"Custom Render Loops","u":"/7.x/guides/basics/render-loop","h":"#custom-render-loops","p":1098},{"i":1111,"t":"OK, now that you've gotten a feel for how easy it is to build a PixiJS application, let's get into the specifics. For the rest of the Basics section, we're going to work from the high level down to the details. We'll start with an overview of how PixiJS is put together.","s":"Architecture Overview","u":"/7.x/guides/basics/architecture-overview","h":"","p":1110},{"i":1113,"t":"Before we get into how the code is layed out, let's talk about where it lives. PixiJS is an open source product hosted on GitHub. Like any GitHub repo, you can browse and download the raw source files for each PixiJS class, as well as search existing issues & bugs, and even submit your own. PixiJS is written in a JavaScript variant called TypeScript, which enables type-checking in JavaScript via a pre-compile step.","s":"The Code","u":"/7.x/guides/basics/architecture-overview","h":"#the-code","p":1110},{"i":1115,"t":"PixiJS is a modular rendering engine. Each task required for generating, updating and displaying content is broken out into its own component. Not only does this make the code cleaner, it allows for greater extensibility. Additionally, with the use of the PixiJS Customize tool, it's possible to build a custom PixiJS file containing only the subset of features your project needs, saving download size. Here's a list of the major components that make up PixiJS. Note that this list isn't exhaustive. Additionally, don't worry too much about how each component works. The goal here is to give you a feel for what's under the hood as we start exploring the engine.","s":"The Components","u":"/7.x/guides/basics/architecture-overview","h":"#the-components","p":1110},{"i":1117,"t":"Component Description Renderer @pixi/core The core of the PixiJS system is the renderer, which displays the scene graph and draws it to the screen. The default renderer for PixiJS is based on WebGL under the hood. Container @pixi/display Main display object which creates a scene graph: the tree of renderable objects to be displayed, such as sprites, graphics and text. See Scene Graph for more details. Loader @pixi/loader The loader system provides tools for asynchronously loading resources such as images and audio files. Ticker @pixi/ticker Tickers provide periodic callbacks based on a clock. Your game update logic will generally be run in response to a tick once per frame. You can have multiple tickers in use at one time. Application @pixi/app The Application is a simple helper that wraps a Loader, Ticker and Renderer into a single, convenient easy-to-use object. Great for getting started quickly, prototyping and building simple projects. Interaction @pixi/interaction PixiJS supports both touch and mouse-based interaction - making objects clickable, firing hover events, etc. Accessibility @pixi/accessibility Woven through our display system is a rich set of tools for enabling keyboard and screen-reader accessibility.","s":"Major Components","u":"/7.x/guides/basics/architecture-overview","h":"#major-components","p":1110},{"i":1119,"t":"Every frame, PixiJS is updating and then rendering the scene graph. Let's talk about what's in the scene graph, and how it impacts how you develop your project. If you've built games before, this should all sound very familiar, but if you're coming from HTML and the DOM, it's worth understanding before we get into specific types of objects you can render.","s":"Scene Graph","u":"/7.x/guides/basics/scene-graph","h":"","p":1118},{"i":1121,"t":"The scene graph's root node is a container maintained by the application, and referenced with app.stage. When you add a sprite or other renderable object as a child to the stage, it's added to the scene graph and will be rendered and interactable. Most PixiJS objects can also have children, and so as you build more complex scenes, you will end up with a tree of parent-child relationships, rooted at the app's stage. (A helpful tool for exploring your project is the Pixi.js devtools plugin for Chrome, which allows you to view and manipulate the scene graph in real time as it's running!)","s":"The Scene Graph Is a Tree","u":"/7.x/guides/basics/scene-graph","h":"#the-scene-graph-is-a-tree","p":1118},{"i":1123,"t":"When a parent moves, its children move as well. When a parent is rotated, its children are rotated too. Hide a parent, and the children will also be hidden. If you have a game object that's made up of multiple sprites, you can collect them under a container to treat them as a single object in the world, moving and rotating as one. Each frame, PixiJS runs through the scene graph from the root down through all the children to the leaves to calculate each object's final position, rotation, visibility, transparency, etc. If a parent's alpha is set to 0.5 (making it 50% transparent), all its children will start at 50% transparent as well. If a child is then set to 0.5 alpha, it won't be 50% transparent, it will be 0.5 x 0.5 = 0.25 alpha, or 75% transparent. Similarly, an object's position is relative to its parent, so if a parent is set to an x position of 50 pixels, and the child is set to an x position of 100 pixels, it will be drawn at a screen offset of 150 pixels, or 50 + 100. Here's an example. We'll create three sprites, each a child of the last, and animate their position, rotation, scale and alpha. Even though each sprite's properties are set to the same values, the parent-child chain amplifies each change: // Create the application helper and add its render target to the page const app = new PIXI.Application({ width: 640, height: 360 }); document.body.appendChild(app.view); // Add a container to center our sprite stack on the page const container = new PIXI.Container(); container.x = app.screen.width / 2; container.y = app.screen.height / 2; app.stage.addChild(container); // Create the 3 sprites, each a child of the last const sprites = []; let parent = container; for (let i = 0; i < 3; i++) { let sprite = PIXI.Sprite.from('assets/images/sample.png'); sprite.anchor.set(0.5); parent.addChild(sprite); sprites.push(sprite); parent = sprite; } // Set all sprite's properties to the same value, animated over time let elapsed = 0.0; app.ticker.add((delta) => { elapsed += delta / 60; const amount = Math.sin(elapsed); const scale = 1.0 + 0.25 * amount; const alpha = 0.75 + 0.25 * amount; const angle = 40 * amount; const x = 75 * amount; for (let i = 0; i < sprites.length; i++) { const sprite = sprites[i]; sprite.scale.set(scale); sprite.alpha = alpha; sprite.angle = angle; sprite.x = x; } }); The cumulative translation, rotation, scale and skew of any given node in the scene graph is stored in the object's worldTransform property. Similarly, the cumulative alpha value is stored in the worldAlpha property.","s":"Parents and Children","u":"/7.x/guides/basics/scene-graph","h":"#parents-and-children","p":1118},{"i":1125,"t":"So we have a tree of things to draw. Who gets drawn first? PixiJS renders the tree from the root down. At each level, the current object is rendered, then each child is rendered in order of insertion. So the second child is rendered on top of the first child, and the third over the second. Check out this example, with two parent objects A & D, and two children B & C under A: // Create the application helper and add its render target to the page const app = new PIXI.Application({ width: 640, height: 360 }); document.body.appendChild(app.view); // Label showing scene graph hierarchy const label = new PIXI.Text('Scene Graph:\\n\\napp.stage\\n β”— A\\n β”— B\\n β”— C\\n β”— D', {fill: '#ffffff'}); label.position = {x: 300, y: 100}; app.stage.addChild(label); // Helper function to create a block of color with a letter const letters = []; function addLetter(letter, parent, color, pos) { const bg = new PIXI.Sprite(PIXI.Texture.WHITE); bg.width = 100; bg.height = 100; bg.tint = color; const text = new PIXI.Text(letter, {fill: \"#ffffff\"}); text.anchor.set(0.5); text.position = {x: 50, y: 50}; const container = new PIXI.Container(); container.position = pos; container.visible = false; container.addChild(bg, text); parent.addChild(container); letters.push(container); return container; } // Define 4 letters let a = addLetter('A', app.stage, 0xff0000, {x: 100, y: 100}); let b = addLetter('B', a, 0x00ff00, {x: 20, y: 20}); let c = addLetter('C', a, 0x0000ff, {x: 20, y: 40}); let d = addLetter('D', app.stage, 0xff8800, {x: 140, y: 100}); // Display them over time, in order let elapsed = 0.0; app.ticker.add((delta) => { elapsed += delta / 60.0; if (elapsed >= letters.length) { elapsed = 0.0; } for (let i = 0; i < letters.length; i ++) { letters[i].visible = elapsed >= i; } }); If you'd like to re-order a child object, you can use setChildIndex(). To add a child at a given point in a parent's list, use addChildAt(). Finally, you can enable automatic sorting of an object's children using the sortableChildren option combined with setting the zIndex property on each child.","s":"Render Order","u":"/7.x/guides/basics/scene-graph","h":"#render-order","p":1118},{"i":1127,"t":"If you're building a project where a large proportion of your DisplayObject's are off-screen (say, a side-scrolling game), you will want to cull those objects. Culling is the process of evaluating if an object (or its children!) is on the screen, and if not, turning off rendering for it. If you don't cull off-screen objects, the renderer will still draw them, even though none of their pixels end up on the screen. PixiJS doesn't provide built-in support for viewport culling, but you can find 3rd party plugins that might fit your needs. Alternately, if you'd like to build your own culling system, simply run your objects during each tick and set renderable to false on any object that doesn't need to be drawn.","s":"Culling","u":"/7.x/guides/basics/scene-graph","h":"#culling","p":1118},{"i":1129,"t":"If you add a sprite to the stage, by default it will show up in the top left corner of the screen. That's the origin of the global coordinate space used by PixiJS. If all your objects were children of the stage, that's the only coordinates you'd need to worry about. But once you introduce containers and children, things get more complicated. A child object at [50, 100] is 50 pixels right and 100 pixels down from its parent. We call these two coordinate systems \"global\" and \"local\" coordinates. When you use position.set(x, y) on an object, you're always working in local coordinates, relative to the object's parent. The problem is, there are many times when you want to know the global position of an object. For example, if you want to cull offscreen objects to save render time, you need to know if a given child is outside the view rectangle. To convert from local to global coordinates, you use the toGlobal() function. Here's a sample usage: // Get the global position of an object, relative to the top-left of the screen let globalPos = obj.toGlobal(new PIXI.Point(0,0)); This snippet will set globalPos to be the global coordinates for the child object, relative to [0, 0] in the global coordinate system.","s":"Local vs Global Coordinates","u":"/7.x/guides/basics/scene-graph","h":"#local-vs-global-coordinates","p":1118},{"i":1131,"t":"When your project is working with the host operating system or browser, there is a third coordinate system that comes into play - \"screen\" coordinates (aka \"viewport\" coordinates). Screen coordinates represent position relative to the top-left of the canvas element that PixiJS is rendering into. Things like the DOM and native mouse click events work in screen space. Now, in many cases, screen space is equivalent to world space. This is the case if the size of the canvas is the same as the size of the render view specified when you create you PIXI.Application. By default, this will be the case - you'll create for example an 800x600 application window and add it to your HTML page, and it will stay that size. 100 pixels in world coordinates will equal 100 pixels in screen space. BUT! It is common to stretch the rendered view to have it fill the screen, or to render at a lower resolution and up-scale for speed. In that case, the screen size of the canvas element will change (e.g. via CSS), but the underlying render view will not, resulting in a mis-match between world coordinates and screen coordinates.","s":"Global vs Screen Coordinates","u":"/7.x/guides/basics/scene-graph","h":"#global-vs-screen-coordinates","p":1118},{"i":1133,"t":"So what exactly is PixiJS? At its heart, PixiJS is a rendering system that uses WebGL (or optionally Canvas) to display images and other 2D visual content. It provides a full scene graph (a hierarchy of objects to render), and provides interaction support to enable handling click and touch events. It is a natural replacement for Flash in the modern HTML5 world, but provides better performance and pixel-level effects that go beyond what Flash could achieve. It is perfect for online games, educational content, interactive ads, data visualization... any web-based application where complex graphics are important. And coupled with technology such as Cordova and Electron, PixiJS apps can be distributed beyond the browser as mobile and desktop applications. Here's what else you get with PixiJS:","s":"What PixiJS Is","u":"/7.x/guides/basics/what-pixijs-is","h":"","p":1132},{"i":1135,"t":"One of the major features that distinguishes PixiJS from other web-based rendering solutions is speed. From the ground up, the render pipeline has been built to get the most performance possible out of your users' browsers. Automatic sprite and geometry batching, careful use of WebGL resources, a tight scene graph - no matter your application, speed is valuable, and PixiJS has it to spare.","s":"PixiJS Is ... Fast","u":"/7.x/guides/basics/what-pixijs-is","h":"#pixijs-is--fast","p":1132},{"i":1137,"t":"Drawing images on a page can be handled with HTML5 and the DOM, so why use PixiJS? Beyond performance, the answer is that PixiJS goes well beyond simple images. Draw trails and tracks with SimpleRope. Draw polygons, lines, circles and other primitives with Graphics. Text provides full text rendering support that's just as performant as sprites. And even when drawing simple images, PixiJS natively supports spritesheets for efficient loading and ease of development.","s":"... More Than Just Sprites","u":"/7.x/guides/basics/what-pixijs-is","h":"#-more-than-just-sprites","p":1132},{"i":1139,"t":"WebGL is the JavaScript API for accessing users' GPUs for fast rendering and advanced effects. PixiJS leverages WebGL to display thousands of moving sprites efficiently even on mobile devices. But using WebGL offers more than just speed. By using the Filter class, you can write shader programs (or use pre-built ones!) to achieve displacement maps, blurring, and other advanced visual effects that cannot be accomplished with just the DOM or Canvas APIs.","s":"... WebGL Native","u":"/7.x/guides/basics/what-pixijs-is","h":"#-webgl-native","p":1132},{"i":1141,"t":"Want to understand how the engine works? Trying to track down a bug? Been burned by closed-source projects going dark? With PixiJS, you get a mature project with full source code access. We're MIT licensed for compatibility, and hosted on GitHub for issue tracking and ease of access.","s":"... Open Source","u":"/7.x/guides/basics/what-pixijs-is","h":"#-open-source","p":1132},{"i":1143,"t":"Open source helps. So does being based on JavaScript. But the real reason PixiJS is easy to extend is the clean internal API that underlies every part of the system. After years of development and 5 major releases, PixiJS is ready to make your project a success, no matter what your needs.","s":"... Extensible","u":"/7.x/guides/basics/what-pixijs-is","h":"#-extensible","p":1132},{"i":1145,"t":"Flash required the player. Unity requires an installer or app store. PixiJS requires... a browser. Deploying PixiJS on the web is exactly like deploying a web site. That's all it is - JavaScript + images + audio, like you've done a hundred times. Your users simply visit a URL, and your game or other content is ready to run. But it doesn't stop at the web. If you want to deploy a mobile app, wrap your PixiJS code in Cordova. Want to deploy a standalone desktop program? Build an Electron wrapper, and you're ready to rock.","s":"... Easy to Deploy","u":"/7.x/guides/basics/what-pixijs-is","h":"#-easy-to-deploy","p":1132},{"i":1147,"t":"While PixiJS can do many things, there are things it can't do, or that require additional tools to accomplish. Newcomers to PixiJS often struggle to identify which tasks PixiJS can solve, and which require outside solutions. If you're about to start a project, it can be helpful to know if PixiJS is a good fit for your needs. The following list is obviously incomplete - PixiJS is also not, for example, a duck - but it includes many common tasks or features that you might expect us to support.","s":"What PixiJS Is Not","u":"/7.x/guides/basics/what-pixijs-is-not","h":"","p":1146},{"i":1149,"t":"PixiJS is a rendering engine, and it supports additional features such as interaction management that are commonly needed when using a render engine. But it is not a framework like Unity or Phaser. Frameworks are designed to do all the things you'd need to do when building a game - user settings management, music playback, object scripting, art pipeline management... the list goes on. PixiJS is designed to do one thing really well - render graphical content. This lets us focus on keeping up with new technology, and makes downloading PixiJS blazingly fast.","s":"PixiJS Is Not ... A Framework","u":"/7.x/guides/basics/what-pixijs-is-not","h":"#pixijs-is-not--a-framework","p":1146},{"i":1151,"t":"PixiJS is built for 2D. Platformers, adventure games, interactive ads, custom data visualization... all good. But if you want to render 3D models, you might want to check out babylon.js or three.js.","s":"... A 3D Renderer","u":"/7.x/guides/basics/what-pixijs-is-not","h":"#-a-3d-renderer","p":1146},{"i":1153,"t":"If you're looking to build mobile games, you can do it with PixiJS, but you'll need to use a deployment system like Apache Cordova if you want access to native bindings. We don't provide access to the camera, location services, notifications, etc.","s":"... A Mobile App","u":"/7.x/guides/basics/what-pixijs-is-not","h":"#-a-mobile-app","p":1146},{"i":1155,"t":"Building a truly generic UI system is a huge challenge, as anyone who has worked with Unity's UI tools can attest. We've chosen to avoid the complexity to stay true to our core focus on speed. While you can certainly build your own UI using PixiJS's scene graph and interaction manager, we don't ship with a UI library out of the box.","s":"... A UI Library","u":"/7.x/guides/basics/what-pixijs-is-not","h":"#-a-ui-library","p":1146},{"i":1157,"t":"There are many techniques and technologies that you can use to store settings, scores, and other data. Cookies, Web Storage, server-based storage... there are many solutions, each with advantages and disadvantages. You can use any of them with PixiJS, but we don't provide tools to do so.","s":"... A Data Store","u":"/7.x/guides/basics/what-pixijs-is-not","h":"#-a-data-store","p":1146},{"i":1159,"t":"At least, not out of the box. Again, web audio technology is a constantly evolving challenge, with constantly changing rules and requirements across many browsers. There are a number of dedicated web audio libraries (such as Howler.js that can be used with PixiJS to play sound effects and music. Alternatively, the PixiJS Sound plugin is designed to work well with PixiJS.","s":"... An Audio Library","u":"/7.x/guides/basics/what-pixijs-is-not","h":"#-an-audio-library","p":1146},{"i":1161,"t":"There are a number of tools that are useful for building 2D art and games that you might expect to be a part of PixiJS, but we're a rendering engine, not a development environment. Packing sprite sheets, processing images, building mipmaps or Retina-ready sprites - there are great standalone tools for this type of tooling. Where appropriate throughout the guides, we'll point you to tools that may be useful.","s":"... A Development Environment","u":"/7.x/guides/basics/what-pixijs-is-not","h":"#-a-development-environment","p":1146},{"i":1163,"t":"Only you know! If you're looking for a tightly focused, fast and efficient rendering engine for your next web-based project, PixiJS is likely a great fit. If you need a full game development framework, with native bindings and a rich UI library, you may want to explore other options. Or you may not. It can be faster and easier to build just the subset of a full framework that your project needs than it can be to digest a monolithic API with bells and whistles you don't need. There are hundreds of complex, rich games and visual projects that use PixiJS for rendering, with plugins or custom code to add the UI and sound effects. There are benefits to both approaches. Regardless, we hope you have a better feel for what PixiJS can (and cannot!) offer your project.","s":"So Is PixiJS Right For Me?","u":"/7.x/guides/basics/what-pixijs-is-not","h":"#so-is-pixijs-right-for-me","p":1146},{"i":1166,"t":"The Assets package is a modern replacement for the old PIXI.Loader class. It is a promise-based resource management solution that will download, cache and parse your assets into something you can use. The downloads can be simultaneous and in the background, meaning faster startup times for your app, the cache ensures that you never download the same asset twice and the extensible parser system allows you to easily extend and customize the process to your needs.","s":"The Assets package","u":"/7.x/guides/components/assets","h":"#the-assets-package","p":1164},{"i":1168,"t":"The @pixi/assets package doesn't come bundled with PixiJS in version 6.x and must be added externally, however it will become integrated with version 7. The class that does all the heavy lifting is called AssetsClass but you don't need to create your own instance since you will find one ready to use in PIXI.Assets. This package relies heavily on JavaScript Promises that all modern browsers support, however, if your target browser doesn't support promises you should look into polyfilling them.","s":"Getting started","u":"/7.x/guides/components/assets","h":"#getting-started","p":1164},{"i":1170,"t":"To quickly use the PIXI.Assets instance, you just need to call PIXI.Assets.load and pass in an asset. This will return a promise that when resolved will yield the value you seek. In this example, we will load a texture and then turn it into a sprite. One very important thing to keep in mind while using Assets is that all requests are cached and if the URL is the same, the promise returned will also be the same. To show it in code: promise1 = PIXI.Assets.load('bunny.png') promise2 = PIXI.Assets.load('bunny.png') //promise1 === promise2 Out of the box, the following assets types can be loaded without the need for external plugins: Textures (avif, webp, png, jpg, gif) Sprite sheets (json) Bitmap fonts (xml, fnt, txt) Web fonts (ttf, woff, woff2) Json files (json) Text files (txt) More types can be added fairly easily by creating additional loader parsers.","s":"Making our first Assets Promise","u":"/7.x/guides/components/assets","h":"#making-our-first-assets-promise","p":1164},{"i":1172,"t":"When an asset is downloaded, it is cached as a promise inside the Assets instance and if you try to download it again you will get a reference to the already resolved promise. However promise handlers .then(...)/.catch(...)/.finally(...) are always asynchronous, this means that even if a promise was already resolved the code below the .then(...)/.catch(...)/.finally(...) will execute before the code inside them. See this example: console.log(1); alreadyResolvedPromise.then(() => console.log(2)); console.log(3); // Console output: // 1 // 3 // 2 To learn more about why this happens you will need to learn about Microtasks, however, using async functions should mitigate this problem.","s":"Warning about solved promises","u":"/7.x/guides/components/assets","h":"#warning-about-solved-promises","p":1164},{"i":1174,"t":"There is a way to work with promises that is more intuitive and easier to read: async/await. To use it we first need to create a function/method and mark it as async. async function test() { // ... } This function now wraps the return value in a promise and allows us to use the await keyword before a promise to halt the execution of the code until it is resolved and gives us the value. See this example: The texture variable now is not a promise but the resolved texture that resulted after waiting for this promise to resolve. const texture = await PIXI.Assets.load('examples/assets/bunny.png'); This allows us to write more readable code without falling into callback hell and to better think when our program halts and yields.","s":"Using Async/Await","u":"/7.x/guides/components/assets","h":"#using-asyncawait","p":1164},{"i":1176,"t":"We can add assets to the cache and then load them all simultaneously by using PIXI.Assets.add(...) and then calling PIXI.Assets.load(...) with all the keys you want to have loaded. See the following example: However, if you want to take full advantage of @pixi/Assets you should use bundles. Bundles are just a way to group assets together and can be added manually by calling PIXI.Assets.addBundle(...)/PIXI.Assets.loadBundle(...). PIXI.Assets.addBundle('animals', { bunny: 'bunny.png', chicken: 'chicken.png', thumper: 'thumper.png', }); const assets = await PIXI.Assets.loadBundle('animals'); However, the best way to handle bundles is to use a manifest and call PIXI.Assets.init({manifest}) with said manifest (or even better, an URL pointing to it). Splitting our assets into bundles that correspond to screens or stages of our app will come in handy for loading in the background while the user is using the app instead of locking them in a single monolithic loading screen. { \"bundles\":[ { \"name\":\"load-screen\", \"assets\":[ { \"name\":\"background\", \"srcs\":\"sunset.png\" }, { \"name\":\"bar\", \"srcs\":\"load-bar.{png,webp}\" } ] }, { \"name\":\"game-screen\", \"assets\":[ { \"name\":\"character\", \"srcs\":\"robot.png\" }, { \"name\":\"enemy\", \"srcs\":\"bad-guy.png\" } ] } ] } PIXI.Assets.init({manifest: \"path/manifest.json\"}); Beware that you can only call init once. Remember there is no downside in repeating URLs since they will all be cached, so if you need the same asset in two bundles you can duplicate the request without any extra cost!","s":"Loading multiple assets","u":"/7.x/guides/components/assets","h":"#loading-multiple-assets","p":1164},{"i":1178,"t":"The old approach to loading was to use PIXI.Loader to load all your assets at the beginning of your app, but users are less patient now and want content to be instantly available so the practices are moving towards loading the bare minimum needed to show the user some content and, while they are interacting with that, we keep loading the following content in the background. Luckily, @pixi/assets has us covered with a system that allows us to load everything in the background and in case we need some assets right now, bump them to the top of the queue so we can minimize loading times. To achieve this, we have the methods PIXI.Assets.backgroundLoad(...) and PIXI.Assets.backgroundLoadBundle(...) that will passively begin to load these assets in the background. So when you finally come to loading them you will get a promise that resolves to the loaded assets immediately. When you finally need the assets to show, you call the usual PIXI.Assets.load(...) or PIXI.Assets.loadBundle(...) and you will get the corresponding promise. The best way to do this is using bundles, see the following example: We create one bundle for each screen our game will have and set them all to start downloading at the beginning of our app. If the user progresses slowly enough in our app then they should never get to see a loading screen after the first one!","s":"Background loading","u":"/7.x/guides/components/assets","h":"#background-loading","p":1164},{"i":1180,"t":"DisplayObject is the core class for anything that can be rendered by the engine. It's the base class for sprites, text, complex graphics, containers, etc., and provides much of the common functionality for those objects. As you're learning PixiJS, it's important to read through the documentation for this class to understand how to move, scale, rotate and compose the visual elements of your project. Be aware that you won't use DisplayObject directly - you'll use its functions and attributes in derived classes.","s":"Display Objects","u":"/7.x/guides/components/display-object","h":"","p":1179},{"i":1182,"t":"The most common attributes you'll use when laying out and animating content in PixiJS are provided by the DisplayObject class: Property Description position X- and Y-position are given in pixels and change the position of the object relative to its parent, also available directly as object.x / object.y rotation Rotation is specified in radians, and turns an object clockwise (0.0 - 2 * Math.PI) angle Angle is an alias for rotation that is specified in degrees instead of radians (0.0 - 360.0) pivot Point the object rotates around, in pixels - also sets origin for child objects alpha Opacity from 0.0 (fully transparent) to 1.0 (fully opaque), inherited by children scale Scale is specified as a percent with 1.0 being 100% or actual-size, and can be set independently for the x and y axis skew Skew transforms the object in x and y similar to the CSS skew() function, and is specified in radians visible Whether the object is visible or not, as a boolean value - prevents updating and rendering object and children renderable Whether the object should be rendered - when false, object will still be updated, but won't be rendered, doesn't affect children","s":"Commonly Used Attributes","u":"/7.x/guides/components/display-object","h":"#commonly-used-attributes","p":1179},{"i":1184,"t":"Graphics is a complex and much misunderstood tool in the PixiJS toolbox. At first glance, it looks like a tool for drawing shapes. And it is! But it can also be used to generate masks. How does that work? In this guide, we're going to de-mystify the Graphics object, starting with how to think about what it does. Check out the graphics example code.","s":"Graphics","u":"/7.x/guides/components/graphics","h":"","p":1183},{"i":1186,"t":"First-time users of the PIXI.Graphics class often struggle with how it works. Let's look at an example snippet that creates a Graphics object and draws a rectangle: // Create a Graphics object, set a fill color, draw a rectangle let obj = new PIXI.Graphics(); obj.beginFill(0xff0000); obj.drawRect(0, 0, 200, 100); // Add it to the stage to render app.stage.addChild(obj); That code will work - you'll end up with a red rectangle on the screen. But it's pretty confusing when you start to think about it. Why am I drawing a rectangle when constructing the object? Isn't drawing something a one-time action? How does the rectangle get drawn the second frame? And it gets even weirder when you create a Graphics object with a bunch of drawThis and drawThat calls, and then you use it as a mask. What??? The problem is that the function names are centered around drawing, which is an action that puts pixels on the screen. But in spite of that, the Graphics object is really about building. Let's look a bit deeper at that drawRect() call. When you call drawRect(), PixiJS doesn't actually draw anything. Instead, it stores the rectangle you \"drew\" into a list of geometry for later use. If you then add the Graphics object to the scene, the renderer will come along, and ask the Graphics object to render itself. At that point, your rectangle actually gets drawn - along with any other shapes, lines, etc. that you've added to the geometry list. Once you understand what's going on, things start to make a lot more sense. When you use a Graphics object as a mask, for example, the masking system uses that list of graphics primitives in the geometry list to constrain which pixels make it to the screen. There's no drawing involved. That's why it helps to think of the Graphics class not as a drawing tool, but as a geometry building tool.","s":"Graphics Is About Building - Not Drawing","u":"/7.x/guides/components/graphics","h":"#graphics-is-about-building---not-drawing","p":1183},{"i":1188,"t":"There are a lot of functions in the PIXI.Graphics class, but as a quick orientation, here's the list of basic primitives you can add: Line Rect RoundRect Circle Ellipse Arc Bezier and Quadratic Curve In addition, the Graphics Extras package (@pixi/graphics-extras) optionally includes the following complex primitives: Torus Chamfer Rect Fillet Rect Regular Polygon Star Rounded Polygon","s":"Types of Primitives","u":"/7.x/guides/components/graphics","h":"#types-of-primitives","p":1183},{"i":1190,"t":"Inside every Graphics object is a GraphicsGeometry object. The GraphicsGeometry class manages the list of geometry primitives created by the Graphics parent object. For the most part, you will not work directly with this object. The owning Graphics object creates and manages it. However, there are two related cases where you do work with the list. First, you can re-use geometry from one Graphics object in another. No matter whether you're re-drawing the same shape over and over, or re-using it as a mask over and over, it's more efficient to share identical GraphicsGeometry. You can do this like so: // Create a master graphics object let template = new PIXI.Graphics(); // Add a circle template.drawCircle(100, 100, 50); // Create 5 duplicate objects for (let i = 0; i < 5; i++) { // Initialize the duplicate using our template's pre-built geometry let duplicate = new PIXI.Graphics(template.geometry); } This leads to the second time you need to be aware of the underlying GraphicsGeometry object - avoiding memory leaks. Because Graphics objects can share geometry, you must call destroy() when you no longer need them. Failure to do so will prevent the GraphicsGeometry object it owns from being properly de-referenced, and will lead to memory leaks.","s":"The Geometry List","u":"/7.x/guides/components/graphics","h":"#the-geometry-list","p":1183},{"i":1192,"t":"OK, so now that we've covered how the PIXI.Graphics class works, let's look at how you use it. The most obvious use of a Graphics object is to draw dynamically generated shapes to the screen. Doing so is simple. Create the object, call the various builder functions to add your custom primitives, then add the object to the scene graph. Each frame, the renderer will come along, ask the Graphics object to render itself, and each primitive, with associated line and fill styles, will be drawn to the screen.","s":"Graphics For Display","u":"/7.x/guides/components/graphics","h":"#graphics-for-display","p":1183},{"i":1194,"t":"You can also use a Graphics object as a complex mask. To do so, build your object and primitives as usual. Next create a PIXI.Container object that will contain the masked content, and set its mask property to your Graphics object. The children of the container will now be clipped to only show through inside the geometry you've created. This technique works for both WebGL and Canvas-based rendering. Check out the masking example code.","s":"Graphics as a Mask","u":"/7.x/guides/components/graphics","h":"#graphics-as-a-mask","p":1183},{"i":1196,"t":"The Graphics class is a complex beast, and so there are a number of things to be aware of when using it. Memory Leaks: The first has already been mentioned - call destroy() on any Graphics object you no longer need to avoid memory leaks. Holes: Holes you create have to be completely contained in the shape or else it may not be able to triangulate correctly. Changing Geometry: If you want to change the shape of a Graphics object, you don't need to delete and recreate it. Instead you can use the clear() function to reset the contents of the geometry list, then add new primitives as desired. Be careful of performance when doing this every frame. Performance: Graphics objects are generally quite performant. However, if you build highly complex geometry, you may pass the threshold that permits batching during rendering, which can negatively impact performance. It's better for batching to use many Graphics objects instead of a single Graphics with many shapes. Transparency: Because the Graphics object renders its primitives sequentially, be careful when using blend modes or partial transparency with overlapping geometry. Blend modes like ADD and MULTIPLY will work on each primitive, not on the final composite image. Similarly, partially transparent Graphics objects will show primitives overlapping. To apply transparency or blend modes to a single flattened surface, consider using AlphaFilter or RenderTexture.","s":"Caveats and Gotchas","u":"/7.x/guides/components/graphics","h":"#caveats-and-gotchas","p":1183},{"i":1198,"t":"Now that you understand basic sprites, it's time to talk about a better way to create them - the Spritesheet class. A Spritesheet is a media format for more efficiently downloading and rendering Sprites. While somewhat more complex to create and use, they are a key tool in optimizing your project.","s":"Spritesheets","u":"/7.x/guides/components/sprite-sheets","h":"","p":1197},{"i":1200,"t":"The basic idea of a spritesheet is to pack a series of images together into a single image, track where each source image ends up, and use that combined image as a shared BaseTexture for the resulting Sprites. The first step is to collect the images you want to combine. The sprite packer then collects the images, and creates a new combined image. As this image is being created, the tool building it keeps track of the location of the rectangle where each source image is stored. It then writes out a JSON file with that information. These two files, in combination, can be passed into a SpriteSheet constructor. The SpriteSheet object then parses the JSON, and creates a series of Texture objects, one for each source image, setting the source rectangle for each based on the JSON data. Each texture uses the same shared BaseTexture as its source.","s":"Anatomy of a Spritesheet","u":"/7.x/guides/components/sprite-sheets","h":"#anatomy-of-a-spritesheet","p":1197},{"i":1202,"t":"SpriteSheets help your project in two ways. First, by speeding up the loading process. While downloading a SpriteSheet's texture requires moving the same (or even slightly more!) number of bytes, they're grouped into a single file. This means that the user's browser can request and download far fewer files for the same number of Sprites. The number of files itself is a key driver of download speed, because each request requires a round-trip to the webserver, and browsers are limited to how many files they can download simultaneously. Converting a project from individual source images to shared sprite sheets can cut your download time in half, at no cost in quality. Second, by improving batch rendering. WebGL rendering speed scales roughly with the number of draw calls made. Batching multiple Sprites, etc. into a single draw call is the main secret to how PixiJS can run so blazingly fast. Maximizing batching is a complex topic, but when multiple Sprites all share a common BaseTexture, it makes it more likely that they can be batched together and rendered in a single call.","s":"Doubly Efficient","u":"/7.x/guides/components/sprite-sheets","h":"#doubly-efficient","p":1197},{"i":1204,"t":"You can use a 3rd party tool to assemble your sprite sheet files. Here are two that may fit your needs: ShoeBox: ShoeBox is a free, Adobe AIR-based sprite packing utility that is great for small projects or learning how SpriteSheets work. TexturePacker: TexturePacker is a more polished tool that supports advanced features and workflows. A free version is available which has all the necessary features for packing spritesheets for PixiJS. It's a good fit for larger projects and professional game development, or projects that need more complex tile mapping features. Spritesheet data can also be created manually or programmatically, and supplied to a new AnimatedSprite. This may be an easier option if your sprites are already contained in a single image. // Create object to store sprite sheet data const atlasData = { frames: { enemy1: { frame: { x: 0, y:0, w:32, h:32 }, sourceSize: { w: 32, h: 32 }, spriteSourceSize: { x: 0, y: 0, w: 32, h: 32 } }, enemy2: { frame: { x: 32, y:0, w:32, h:32 }, sourceSize: { w: 32, h: 32 }, spriteSourceSize: { x: 0, y: 0, w: 32, h: 32 } }, }, meta: { image: 'images/spritesheet.png', format: 'RGBA8888', size: { w: 128, h: 32 }, scale: 1 }, animations: { enemy: ['enemy1','enemy2'] //array of frames by name } } // Create the SpriteSheet from data and image const spritesheet = new PIXI.Spritesheet( PIXI.BaseTexture.from(atlasData.meta.image), atlasData ); // Generate all the Textures asynchronously await spritesheet.parse(); // spritesheet is ready to use! const anim = new PIXI.AnimatedSprite(spritesheet.animations.enemy); // set the animation speed anim.animationSpeed = 0.1666; // play the animation on a loop anim.play(); // add it to the stage to render app.stage.addChild(anim);","s":"Creating SpriteSheets","u":"/7.x/guides/components/sprite-sheets","h":"#creating-spritesheets","p":1197},{"i":1206,"t":"The Container class provides a simple display object that does what its name implies - collect a set of child objects together. But beyond grouping objects, containers have a few uses that you should be aware of.","s":"Containers","u":"/7.x/guides/components/containers","h":"","p":1205},{"i":1208,"t":"Almost every type of display object is also derived from Container - even Sprites! This means that in many cases you can create a parent-child hierarchy with the objects you want to render. However, it's a good idea not to do this. Standalone Container objects are very cheap to render, and having a proper hierarchy of Container objects, each containing one or more renderable objects, provides flexibility in rendering order. It also future-proofs your code, as when you need to add an additional object to a branch of the tree, your animation logic doesn't need to change - just drop the new object into the proper Container, and your logic moves the Container with no changes to your code. So that's the primary use for Containers - as groups of renderable objects in a hierarchy. Check out the container example code.","s":"Containers as Groups","u":"/7.x/guides/components/containers","h":"#containers-as-groups","p":1205},{"i":1210,"t":"Another common use for Container objects is as hosts for masked content. \"Masking\" is a technique where parts of your scene graph are only visible within a given area. Think of a pop-up window. It has a frame made of one or more Sprites, then has a scrollable content area that hides content outside the frame. A Container plus a mask makes that scrollable area easy to implement. Add the Container, set its mask property to a Graphics object with a rect, and add the text, image, etc. content you want to display as children of that masked Container. Any content that extends beyond the rectangular mask will simply not be drawn. Move the contents of the Container to scroll as desired. // Create the application helper and add its render target to the page let app = new PIXI.Application({ width: 640, height: 360 }); document.body.appendChild(app.view); // Create window frame let frame = new PIXI.Graphics(); frame.beginFill(0x666666); frame.lineStyle({ color: 0xffffff, width: 4, alignment: 0 }); frame.drawRect(0, 0, 208, 208); frame.position.set(320 - 104, 180 - 104); app.stage.addChild(frame); // Create a graphics object to define our mask let mask = new PIXI.Graphics(); // Add the rectangular area to show mask.beginFill(0xffffff); mask.drawRect(0,0,200,200); mask.endFill(); // Add container that will hold our masked content let maskContainer = new PIXI.Container(); // Set the mask to use our graphics object from above maskContainer.mask = mask; // Add the mask as a child, so that the mask is positioned relative to its parent maskContainer.addChild(mask); // Offset by the window's frame width maskContainer.position.set(4,4); // And add the container to the window! frame.addChild(maskContainer); // Create contents for the masked container let text = new PIXI.Text( 'This text will scroll up and be masked, so you can see how masking works. Lorem ipsum and all that.\\n\\n' + 'You can put anything in the container and it will be masked!', { fontSize: 24, fill: 0x1010ff, wordWrap: true, wordWrapWidth: 180 } ); text.x = 10; maskContainer.addChild(text); // Add a ticker callback to scroll the text up and down let elapsed = 0.0; app.ticker.add((delta) => { // Update the text's y coordinate to scroll it elapsed += delta; text.y = 10 + -100.0 + Math.cos(elapsed/50.0) * 100.0; }); There are two types of masks supported by PixiJS: Use a Graphics object to create a mask with an arbitrary shape - powerful, but doesn't support anti-aliasing Sprite: Use the alpha channel from a Sprite as your mask, providing anti-aliased edging - not supported on the Canvas renderer","s":"Masking","u":"/7.x/guides/components/containers","h":"#masking","p":1205},{"i":1212,"t":"Another common use for Container objects is as hosts for filtered content. Filters are an advanced, WebGL-only feature that allows PixiJS to perform per-pixel effects like blurring and displacements. By setting a filter on a Container, the area of the screen the Container encompasses will be processed by the filter after the Container's contents have been rendered. Below are list of filters available by default in PixiJS. There is, however, a community repository with many more filters. Filter Description AlphaFilter: @pixi/filter-alpha Similar to setting alpha property, but flattens the Container instead of applying to children individually. BlurFilter: @pixi/filter-blur Apply a blur effect ColorMatrixFilter: @pixi/filter-color-matrix A color matrix is a flexible way to apply more complex tints or color transforms (e.g., sepia tone). DisplacementFilter: @pixi/filter-displacement Displacement maps create visual offset pixels, for instance creating a wavy water effect. FXAAFilter: @pixi/filter-fxaa Basic FXAA (Fast Approximate Anti-Aliasing) to create smoothing effect. NoiseFilter: @pixi/filter-noise Create random noise (e.g., grain effect). Important: Filters should be use somewhat sparingly. They can slow performance and increase memory if used too often in a scene.","s":"Filtering","u":"/7.x/guides/components/containers","h":"#filtering","p":1205},{"i":1214,"t":"Whether it's a high score or a diagram label, text is often the best way to convey information in your projects. Surprisingly, drawing text to the screen with WebGL is a very complex process - there's no built in support for it at all. One of the values PixiJS provides is in hiding this complexity to allow you to draw text in diverse styles, fonts and colors with a few lines of code. In addition, these bits of text are just as much scene objects as sprites - you can tint text, rotate it, alpha-blend it, and otherwise treat it like any other graphical object. Let's dig into how this works.","s":"Text","u":"/7.x/guides/components/text","h":"","p":1213},{"i":1216,"t":"Because of the challenges of working with text in WebGL, PixiJS provides two very different solutions. In this guide, we're going to go over both methods in some detail to help you make the right choice for your project's needs. Selecting the wrong text type can have a large negative impact on your project's performance and appearance.","s":"There Are Two Kinds of Text","u":"/7.x/guides/components/text","h":"#there-are-two-kinds-of-text","p":1213},{"i":1218,"t":"In order to draw text to the screen, you use a Text object. Under the hood, this class draws text to an off-screen buffer using the browser's normal text rendering, then uses that offscreen buffer as the source for drawing the text object. Effectively what this means is that whenever you create or change text, PixiJS creates a new rasterized image of that text, and then treats it like a sprite. This approach allows truly rich text display while keeping rendering speed high. So when working with PIXI.Text objects, there are two sets of options - standard display object options like position, rotation, etc that work after the text is rasterized internally, and text style options that are used while rasterizing. Because text once rendered is basically just a sprite, there's no need to review the standard options. Instead, let's focus on how text is styled. Check out the text example code.","s":"The Text Object","u":"/7.x/guides/components/text","h":"#the-text-object","p":1213},{"i":1220,"t":"There are a lot of text style options available (see TextStyle), but they break down into 5 main groups: Font: fontFamily to select the webfont to use, fontSize to specify the size of the text to draw, along with options for font weight, style and variant. Appearance: Set the color with fill or add a stroke outline, including options for gradient fills. Drop-Shadows: Set a drop-shadow with dropShadow, with a host of related options to specify offset, blur, opacity, etc. Layout: Enable with wordWrap and wordWrapWidth, and then customize the lineHeight and align or letterSpacing Utilities: Add padding or trim extra space to deal with funky font families if needed. To interactively test out feature of Text Style, check out this tool.","s":"Text Styles","u":"/7.x/guides/components/text","h":"#text-styles","p":1213},{"i":1222,"t":"In order for PixiJS to build a PIXI.Text object, you'll need to make sure that the font you want to use is loaded by the browser. Unfortunately, at the time of writing, the PIXI.Loader system does not support loading font files, so you'll need to use a 3rd party font loader to ensure that any custom web fonts you want to use are pre-loaded. It's not enough to add an @font-face declaration in your project's CSS because browsers will happily render text using a fallback font while your custom font loads. Any javascript library that can load a web font will work, you just want something that will delay starting your project until the font has been fully loaded by the browser. One such library is FontFaceObserver. Here's a simple example that shows how to use it to ensure the web font \"Short Stack\" is loaded before your app starts. First, we need a font-face declaration in CSS: @font-face { font-family: Short Stack; src: url(short-stack.woff2) format('woff2'), url(short-stack.woff) format('woff'); } Now that the browser knows what our font is and how to find the source files, it's time to use the library to load them: // Create the loader let font = new FontFaceObserver('Short Stack', {}); // Start loading the font font.load().then(() => { // Successful load, start up your PixiJS app as usual let app = new PIXI.Application({ width: 640, height: 360 }); document.body.appendChild(app.view); // ... etc ... }, () => { // Failed load, log the error or display a message to the user alert('Unable to load required font!'); });","s":"Loading and Using Fonts","u":"/7.x/guides/components/text","h":"#loading-and-using-fonts","p":1213},{"i":1224,"t":"While PixiJS does make working with text easy, there are a few things you need to watch out for. First, changing an existing text string requires re-generating the internal render of that text, which is a slow operation that can impact performance if you change many text objects each frame. If your project requires lots of frequently changing text on the screen at once, consider using a PIXI.BitmapText object (explained below) which uses a fixed bitmap font that doesn't require re-generation when text changes. Second, be careful when scaling text. Setting a text object's scale to > 1.0 will result in blurry/pixely display, because the text is not re-rendered at the higher resolution needed to look sharp - it's still the same resolution it was when generated. To deal with this, you can render at a higher initial size and down-scale, instead. This will use more memory, but will allow your text to always look clear and crisp.","s":"Caveats and Gotchas","u":"/7.x/guides/components/text","h":"#caveats-and-gotchas","p":1213},{"i":1226,"t":"In addition to the standard PIXI.Text approach to adding text to your project, PixiJS also supports bitmap fonts. Bitmap fonts are very different from TrueType or other general purpose fonts, in that they consist of a single image containing pre-rendered versions of every letter you want to use. When drawing text with a bitmap font, PixiJS doesn't need to render the font glyphs into a temporary buffer - it can simply copy and stamp out each character of a string from the master font image. The primary advantage of this approach is speed - changing text frequently is much cheaper and rendering each additional piece of text is much faster due to the shared source texture. Check out the bitmap text example code.","s":"BitmapText","u":"/7.x/guides/components/text","h":"#bitmaptext","p":1213},{"i":1228,"t":"3rd party solutions BitmapFont.from auto-generation","s":"BitmapFont","u":"/7.x/guides/components/text","h":"#bitmapfont","p":1213},{"i":1230,"t":"PIXI.Text Static text Small number of text objects High fidelity text rendering (kerning e.g.) Text layout (line & letter spacing) PIXI.BitmapText Dynamic text Large number of text objects Lower memory","s":"Selecting the Right Approach","u":"/7.x/guides/components/text","h":"#selecting-the-right-approach","p":1213},{"i":1232,"t":"Sprites are the simplest and most common renderable object in PixiJS. They represent a single image to be displayed on the screen. Each Sprite contains a Texture to be drawn, along with all the transformation and display state required to function in the scene graph.","s":"Sprites","u":"/7.x/guides/components/sprites","h":"","p":1231},{"i":1234,"t":"To create a Sprite, all you need is a Texture (check out the Texture guide). Load a PNG's URL using the PIXI.Loader class, then call PIXI.Sprite.from(url) and you're all set. As a convenience during prototyping, you can pass a non-loaded URL to from() and PixiJS will handle it, but your sprite will \"pop in\" after it loads if you don't pre-load your textures. Check out the sprite example code.","s":"Creating Sprites","u":"/7.x/guides/components/sprites","h":"#creating-sprites","p":1231},{"i":1236,"t":"In our DisplayObject guide, we learned about the DisplayObject class and the various properties it defines. Since Sprite objects are also display objects, you can move a sprite, rotate it, and update any other display property.","s":"Using Sprites","u":"/7.x/guides/components/sprites","h":"#using-sprites","p":1231},{"i":1238,"t":"Alpha is a standard display object property. You can use it to fade sprites into the scene by animating each sprite's alpha from 0.0 to 1.0 over a period of time. Tinting allows you multiply the color value of every pixel by a single color. For example, if you had a dungeon game, you might show a character's poison status by setting obj.tint = 0x00FF00, which would give a green tint to the character. Blend modes change how pixel colors are added to the screen when rendering. The three main modes are add, which adds each pixel's RGB channels to whatever is under your sprite (useful for glows and lighting), multiply which works like tint, but on a per-pixel basis, and screen, which overlays the pixels, brightening whatever is underneath them.","s":"Alpha, Tint and Blend Modes","u":"/7.x/guides/components/sprites","h":"#alpha-tint-and-blend-modes","p":1231},{"i":1240,"t":"One common area of confusion when working with sprites lies in scaling and dimensions. The PIXI.DisplayObject class allows you to set the x and y scale for any object. Sprites, being DisplayObjects, also support scaling. In addition, however, Sprites support explicit width and height attributes that can be used to achieve the same effect, but are in pixels instead of a percentage. This works because a Sprite object owns a Texture, which has an explicit width and height. When you set a Sprite's width, internally PixiJS converts that width into a percentage of the underlying texture's width and updates the object's x-scale. So width and height are really just convenience methods for changing scale, based on pixel dimensions rather than percentages.","s":"Scale vs Width & Height","u":"/7.x/guides/components/sprites","h":"#scale-vs-width--height","p":1231},{"i":1242,"t":"If you add a sprite to your stage and rotate it, it will by default rotate around the top-left corner of the image. In some cases, this is what you want. In many cases, however, what you want is for the sprite to rotate around the center of the image it contains, or around an arbitrary point. There are two ways to achieve this: pivots and anchors An object's pivot is an offset, expressed in pixels, from the top-left corner of the Sprite. It defaults to (0, 0). If you have a Sprite whose texture is 100px x 50px, and want to set the pivot point to the center of the image, you'd set your pivot to (50, 25) - half the width, and half the height. Note that pivots can be set outside of the image, meaning the pivot may be less than zero or greater than the width/height. This can be useful in setting up complex animation hierarchies, for example. Every DisplayObject has a pivot. An anchor, in contrast, is only available for Sprites. Anchors are specified in percentages, from 0.0 to 1.0, in each dimension. To rotate around the center point of a texture using anchors, you'd set your Sprite's anchor to (0.5, 0.5) - 50% in width and height. While less common, anchors can also be outside the standard 0.0 - 1.0 range. The nice thing about anchors is that they are resolution and dimension agnostic. If you set your Sprite to be anchored in the middle then later change the size of the texture, your object will still rotate correctly. If you had instead set a pivot using pixel-based calculations, changing the texture size would require changing your pivot point. So, generally speaking, you'll want to use anchors when working with Sprites. One final note: unlike CSS, where setting the transform-origin of the image doesn't move it, in PixiJS setting an anchor or pivot will move your object on the screen. In other words, setting an anchor or pivot affects not just the rotation origin, but also the position of the sprite relative to its parent.","s":"Pivot vs Anchor","u":"/7.x/guides/components/sprites","h":"#pivot-vs-anchor","p":1231},{"i":1244,"t":"PixiJS is primarily a rendering system, but it also includes support for interactivity. Adding support for mouse and touch events to your project is simple and consistent.","s":"Interaction","u":"/7.x/guides/components/interaction","h":"","p":1243},{"i":1246,"t":"The new event-based system that replaced InteractionManager from v6 has expanded the definition of what a DisplayObject means to be interactive. With this we have introduced eventMode which allows you to control how an object responds to interaction events. This is similar to the interactive property in v6 but with more options. eventMode Description none Ignores all interaction events, similar to CSS's pointer-events: none, good optimization for non-interactive children passive Does not emit events and ignores hit testing on itself but does allow for events and hit testing only its interactive children. If you want to be compatible with v6, set this as your default eventMode (see options in Renderer, Application, etc) auto Does not emit events and but is hit tested if parent is interactive. Same as interactive = false in v7 static Emit events and is hit tested. Same as interaction = true in v7, useful for objects like buttons that do not move. dynamic Emits events and is hit tested but will also receive mock interaction events fired from a ticker to allow for interaction when the mouse isn't moving. This is useful for elements that independently moving or animating.","s":"Event Modes","u":"/7.x/guides/components/interaction","h":"#event-modes","p":1243},{"i":1248,"t":"PixiJS supports the following event types: Event Type Description pointercancel Fired when a pointer device button is released outside the display object that initially registered a pointerdown. pointerdown Fired when a pointer device button is pressed on the display object. pointerenter Fired when a pointer device enters the display object. pointerleave Fired when a pointer device leaves the display object. pointermove Fired when a pointer device is moved while over the display object. globalpointermove Fired when a pointer device is moved, regardless of hit-testing the current object. pointerout Fired when a pointer device is moved off the display object. pointerover Fired when a pointer device is moved onto the display object. pointertap Fired when a pointer device is tapped on the display object. pointerup Fired when a pointer device button is released over the display object. pointerupoutside Fired when a pointer device button is released outside the display object that initially registered a pointerdown. mousedown Fired when a mouse button is pressed on the display object. mouseenter Fired when the mouse cursor enters the display object. mouseleave Fired when the mouse cursor leaves the display object. mousemove Fired when the mouse cursor is moved while over the display object. globalmousemove Fired when a mouse is moved, regardless of hit-testing the current object. mouseout Fired when the mouse cursor is moved off the display object. mouseover Fired when the mouse cursor is moved onto the display object. mouseup Fired when a mouse button is released over the display object. mouseupoutside Fired when a mouse button is released outside the display object that initially registered a mousedown. click Fired when a mouse button is clicked (pressed and released) over the display object. touchcancel Fired when a touch point is removed outside of the display object that initially registered a touchstart. touchend Fired when a touch point is removed from the display object. touchendoutside Fired when a touch point is removed outside of the display object that initially registered a touchstart. touchmove Fired when a touch point is moved along the display object. globaltouchmove Fired when a touch point is moved, regardless of hit-testing the current object. touchstart Fired when a touch point is placed on the display object. tap Fired when a touch point is tapped on the display object. wheel Fired when a mouse wheel is spun over the display object. rightclick Fired when a right mouse button is clicked (pressed and released) over the display object. rightdown Fired when a right mouse button is pressed on the display object. rightup Fired when a right mouse button is released over the display object. rightupoutside Fired when a right mouse button is released outside the display object that initially registered a rightdown.","s":"Event Types","u":"/7.x/guides/components/interaction","h":"#event-types","p":1243},{"i":1250,"t":"Any DisplayObject-derived object (Sprite, Container, etc.) can become interactive simply by setting its eventMode property to any of the eventModes listed above. Doing so will cause the object to emit interaction events that can be responded to in order to drive your project's behavior. Check out the interaction example code. To respond to clicks and taps, bind to the events fired on the object, like so: let sprite = PIXI.Sprite.from('/some/texture.png'); sprite.on('pointerdown', (event) => { alert('clicked!'); }); sprite.eventMode = 'static'; Check out the DisplayObject for the list of interaction events supported.","s":"Enabling Interaction","u":"/7.x/guides/components/interaction","h":"#enabling-interaction","p":1243},{"i":1252,"t":"You can check if an object is interactive by calling the isInteractive property. This will return true if eventMode is set to static or dynamic. if (sprite.isInteractive()) { // sprite is interactive }","s":"Checking if Object is Interactive","u":"/7.x/guides/components/interaction","h":"#checking-if-object-is-interactive","p":1243},{"i":1254,"t":"PixiJS supports three types of interaction events - mouse, touch and pointer. Mouse events are fired by mouse movement, clicks etc. Touch events are fired for touch-capable devices. And pointer events are fired for both. What this means is that, in many cases, you can write your project to use pointer events and it will just work when used with either mouse or touch input. Given that, the only reason to use non-pointer events is to support different modes of operation based on input type or to support multi-touch interaction. In all other cases, prefer pointer events.","s":"Use Pointer Events","u":"/7.x/guides/components/interaction","h":"#use-pointer-events","p":1243},{"i":1256,"t":"Hit testing requires walking the full object tree, which in complex projects can become an optimization bottleneck. To mitigate this issue, PixiJS Container-derived objects have a property named interactiveChildren. If you have Containers or other objects with complex child trees that you know will never be interactive, you can set this property to false and the hit testing algorithm will skip those children when checking for hover and click events. As an example, if you were building a side-scrolling game, you would probably want to set background.interactiveChildren = false for your background layer with rocks, clouds, flowers, etc. Doing so would speed up hit testing substantially due to the number of unclickable child objects the background layer would contain. The EventSystem can also be customised to be more performant: const app = new PIXI.Application({ /** * by default we use `auto` for backwards compatibility. * However `passive` is more performant and will be used by default in the future, */ eventMode: 'passive', eventFeatures: { move: true, /** disables the global move events which can be very expensive in large scenes */ globalMove: false, click: true, wheel: true, } });","s":"Optimization","u":"/7.x/guides/components/interaction","h":"#optimization","p":1243},{"i":1258,"t":"We're slowly working our way down from the high level to the low. We've talked about the scene graph, and in general about display objects that live in it. We're about to get to sprites and other simple display objects. But before we do, we need to talk about textures. In PixiJS, textures are one of the core resources used by display objects. A texture, broadly speaking, represents a source of pixels to be used to fill in an area on the screen. The simplest example is a sprite - a rectangle that is completely filled with a single texture. But things can get much more complex.","s":"Textures","u":"/7.x/guides/components/textures","h":"","p":1257},{"i":1260,"t":"Let's examine how textures really work, by following the path your image data travels on its way to the screen. Here's the flow we're going to follow: Source Image > Loader > BaseTexture > Texture","s":"Life-cycle of a Texture","u":"/7.x/guides/components/textures","h":"#life-cycle-of-a-texture","p":1257},{"i":1262,"t":"To start with, you have the image you want to display. The first step is to make it available on your server. This may seem obvious, but if you're coming to PixiJS from other game development systems, it's worth remembering that everything has to be loaded over the network. If you're developing locally, please be aware that you must use a webserver to test, or your images won't load due to how browsers treat local file security.","s":"Serving the Image","u":"/7.x/guides/components/textures","h":"#serving-the-image","p":1257},{"i":1264,"t":"To work with the image, the first step is to pull the image file from your webserver into the user's web browser. To do this, we can use PIXI.Texture.from(), which works for quick demos, but in production you'll use the Loader class. A Loader wraps and manages using an element to tell the browser to fetch the image, and then notifies you when that has been completed. This process is asynchronous - you request the load, then time passes, then an event fires to let you know the load is completed. We'll go into the loader in a lot more depth in a later guide.","s":"Loading the Image","u":"/7.x/guides/components/textures","h":"#loading-the-image","p":1257},{"i":1266,"t":"Once the Loader has done its work, the loaded element contains the pixel data we need. But to use it to render something, PixiJS has to take that raw image file and upload it to the GPU. This brings us to the real workhorse of the texture system - the BaseTexture class. Each BaseTexture manages a single pixel source - usually an image, but can also be a Canvas or Video element. BaseTextures allow PixiJS to convert the image to pixels and use those pixels in rendering. In addition, it also contains settings that control how the texture data is rendered, such as the wrap mode (for UV coordinates outside the 0.0-1.0 range) and scale mode (used when scaling a texture). BaseTextures are automatically cached, so that calling PIXI.Texture.from() repeatedly for the same URL returns the same BaseTexture each time. Destroying a BaseTexture frees the image data associated with it.","s":"BaseTextures Own the Data","u":"/7.x/guides/components/textures","h":"#basetextures-own-the-data","p":1257},{"i":1268,"t":"So finally, we get to the PIXI.Texture class itself! At this point, you may be wondering what the Texture object does. After all, the BaseTexture manages the pixels and render settings. And the answer is, it doesn't do very much. Textures are light-weight views on an underlying BaseTexture. Their main attribute is the source rectangle within the BaseTexture from which to pull. If all PixiJS drew were sprites, that would be pretty redundant. But consider SpriteSheets. A SpriteSheet is a single image that contains multiple sprite images arranged within. In a Spritesheet object, a single BaseTexture is referenced by a set of Textures, one for each source image in the original sprite sheet. By sharing a single BaseTexture, the browser only downloads one file, and our batching renderer can blaze through drawing sprites since they all share the same underlying pixel data. The SpriteSheet's Textures pull out just the rectangle of pixels needed by each sprite. That is why we have both Textures and BaseTextures - to allow sprite sheets, animations, button states, etc to be loaded as a single image, while only displaying the part of the master image that is needed.","s":"Textures are a View on BaseTextures","u":"/7.x/guides/components/textures","h":"#textures-are-a-view-on-basetextures","p":1257},{"i":1270,"t":"We will discuss resource loading in a later guide, but one of the most common issues new users face when building a PixiJS project is how best to load their textures. Using PIXI.Texture.from() as we do in our demo snippets will work, but will result in pop-in as each texture is loaded while your objects are already being rendered in the scene graph. Instead, here's a quick cheat sheet of one good solution: Show a loading image Create a Loader Run all texture-based objects, add their textures to the loader Start the loader, and optionally update your loading image based on progress callbacks On loader completion, run all objects and use PIXI.Texture.from() to pull the loaded textures out of the texture cache Prepare your textures (optional - see below) Hide your loading image, start rendering your scene graph Using this workflow ensures that your textures are pre-loaded, to prevent pop-in, and is relatively easy to code. Regarding preparing textures: Even after you've loaded your textures, the images still need to be pushed to the GPU and decoded. Doing this for a large number of source images can be slow and cause lag spikes when your project first loads. To solve this, you can use the Prepare plugin, which allows you to pre-load textures in a final step before displaying your project.","s":"Loading Textures","u":"/7.x/guides/components/textures","h":"#loading-textures","p":1257},{"i":1272,"t":"Once you're done with a Texture, you may wish to free up the memory (both WebGL-managed buffers and browser-based) that it uses. To do so, you should call destroy() on the BaseTexture that owns the data. Remember that Textures don't manage pixel data! This is a particularly good idea for short-lived imagery like cut-scenes that are large and will only be used once. If you want to remove all textures and wipe the slate clean, you can use the PIXI.utils.destroyTextureCache() function.","s":"Unloading Textures","u":"/7.x/guides/components/textures","h":"#unloading-textures","p":1257},{"i":1274,"t":"As we alluded to above, you can make a Texture out of more than just images: Video: Pass an HTML5