From 5d7f5719a01cf5d633a22f5088303a295aab751f Mon Sep 17 00:00:00 2001 From: Zyie Date: Mon, 8 Jan 2024 15:10:26 +0000 Subject: [PATCH] Deploy website - based on dd1634a7842c0061089bb3d98a669c20b6f4a178 --- 404.html | 4 ++-- assets/js/{0ce74438.19f07c55.js => 0ce74438.4d0f230d.js} | 2 +- assets/js/{17896441.1bc15e92.js => 17896441.571f2a6a.js} | 2 +- assets/js/{6875c492.d8b2e0db.js => 6875c492.2f7515a1.js} | 2 +- assets/js/{a6aa9e1f.feb610be.js => a6aa9e1f.0cf460eb.js} | 2 +- assets/js/{a8389ef7.6c4d4dc7.js => a8389ef7.7b0f68a2.js} | 2 +- assets/js/{ccc49370.2c9f06fb.js => ccc49370.5be4e36b.js} | 2 +- assets/js/{fa17a3e5.987acf52.js => fa17a3e5.384a96ee.js} | 2 +- .../{runtime~main.0fac85c4.js => runtime~main.1b62926b.js} | 2 +- blog.html | 4 ++-- blog/archive.html | 4 ++-- blog/pixi-universe.html | 4 ++-- blog/pixi-v8-beta.html | 4 ++-- blog/tags.html | 4 ++-- blog/tags/pixi-js-universe.html | 4 ++-- blog/tags/pixi-js.html | 4 ++-- blog/tags/web-gl.html | 4 ++-- blog/tags/web-gpu.html | 4 ++-- branding.html | 4 ++-- examples.html | 4 ++-- examples/advanced/collision-detection.html | 4 ++-- examples/advanced/mouse-trail.html | 4 ++-- examples/advanced/scratch-card.html | 4 ++-- examples/advanced/screen-shot.html | 4 ++-- examples/advanced/slots.html | 4 ++-- examples/advanced/spinners.html | 4 ++-- examples/advanced/star-warp.html | 4 ++-- examples/assets/async.html | 4 ++-- examples/assets/background.html | 4 ++-- examples/assets/bundle.html | 4 ++-- examples/assets/multiple.html | 4 ++-- examples/assets/promise.html | 4 ++-- examples/basic/blend-modes.html | 4 ++-- examples/basic/cache-as-bitmap.html | 4 ++-- examples/basic/container.html | 4 ++-- examples/basic/particle-container.html | 4 ++-- examples/basic/simple-plane.html | 4 ++-- examples/basic/tinting.html | 4 ++-- examples/basic/transparent-background.html | 4 ++-- examples/events/click.html | 4 ++-- examples/events/custom-hitarea.html | 4 ++-- examples/events/custom-mouse-icon.html | 4 ++-- examples/events/dragging.html | 4 ++-- examples/events/interactivity.html | 4 ++-- examples/events/logger.html | 4 ++-- examples/events/nested-boundary-with-projection.html | 4 ++-- examples/events/pointer-tracker.html | 4 ++-- examples/events/slider.html | 4 ++-- examples/filters-advanced/custom.html | 4 ++-- examples/filters-advanced/mouse-blending.html | 4 ++-- .../filters-advanced/shader-toy-filter-render-texture.html | 4 ++-- examples/filters-basic/blur.html | 4 ++-- examples/filters-basic/color-matrix.html | 4 ++-- examples/filters-basic/displacement-map-crawlies.html | 4 ++-- examples/filters-basic/displacement-map-flag.html | 4 ++-- examples/graphics/advanced.html | 4 ++-- examples/graphics/dynamic.html | 4 ++-- examples/graphics/simple.html | 4 ++-- examples/masks/filter.html | 4 ++-- examples/masks/graphics.html | 4 ++-- examples/masks/sprite.html | 4 ++-- examples/mesh-and-shaders/instanced-geometry.html | 4 ++-- examples/mesh-and-shaders/interleaving-geometry.html | 4 ++-- examples/mesh-and-shaders/merging-geometry.html | 4 ++-- .../mesh-and-shaders/multi-pass-shader-generated-mesh.html | 4 ++-- examples/mesh-and-shaders/shader-toy-mesh.html | 4 ++-- examples/mesh-and-shaders/shared-shader.html | 4 ++-- examples/mesh-and-shaders/sharing-geometry.html | 4 ++-- examples/mesh-and-shaders/textured-mesh-advanced.html | 4 ++-- examples/mesh-and-shaders/textured-mesh-basic.html | 4 ++-- examples/mesh-and-shaders/triangle-color.html | 4 ++-- examples/mesh-and-shaders/triangle-textured.html | 4 ++-- examples/mesh-and-shaders/triangle.html | 4 ++-- examples/mesh-and-shaders/uniforms.html | 4 ++-- examples/offscreen-canvas/basic.html | 4 ++-- examples/sprite/animated-sprite-animation-speed.html | 4 ++-- examples/sprite/animated-sprite-explosion.html | 4 ++-- examples/sprite/animated-sprite-jet.html | 4 ++-- examples/sprite/basic.html | 4 ++-- examples/sprite/texture-swap.html | 4 ++-- examples/sprite/tiling-sprite.html | 4 ++-- examples/sprite/video.html | 4 ++-- examples/text/bitmap-text.html | 4 ++-- examples/text/from-font.html | 4 ++-- examples/text/pixi-text.html | 4 ++-- examples/text/web-font.html | 4 ++-- examples/textures/gradient-basic.html | 4 ++-- examples/textures/gradient-resource.html | 4 ++-- examples/textures/render-texture-advanced.html | 4 ++-- examples/textures/render-texture-basic.html | 4 ++-- examples/textures/texture-rotate.html | 4 ++-- faq.html | 4 ++-- guides.html | 4 ++-- guides/basics/architecture-overview.html | 4 ++-- guides/basics/getting-started.html | 4 ++-- guides/basics/render-loop.html | 4 ++-- guides/basics/scene-graph.html | 4 ++-- guides/basics/what-pixijs-is-not.html | 4 ++-- guides/basics/what-pixijs-is.html | 4 ++-- guides/components/assets.html | 4 ++-- guides/components/containers.html | 4 ++-- guides/components/display-object.html | 4 ++-- guides/components/graphics.html | 4 ++-- guides/components/interaction.html | 4 ++-- guides/components/sprite-sheets.html | 4 ++-- guides/components/sprites.html | 4 ++-- guides/components/text.html | 4 ++-- guides/components/textures.html | 4 ++-- guides/migrations/upgrading.html | 4 ++-- guides/migrations/v5.html | 4 ++-- guides/migrations/v6.html | 4 ++-- guides/migrations/v7.html | 4 ++-- guides/production/performance-tips.html | 4 ++-- index.html | 4 ++-- playground.html | 4 ++-- search-index-blog.json | 2 +- search-index-examples.json | 2 +- search-index-guides.json | 2 +- search-index.json | 2 +- search.html | 4 ++-- team.html | 4 ++-- tutorial.html | 4 ++-- versions.html | 6 +++--- 123 files changed, 235 insertions(+), 235 deletions(-) rename assets/js/{0ce74438.19f07c55.js => 0ce74438.4d0f230d.js} (99%) rename assets/js/{17896441.1bc15e92.js => 17896441.571f2a6a.js} (98%) rename assets/js/{6875c492.d8b2e0db.js => 6875c492.2f7515a1.js} (97%) rename assets/js/{a6aa9e1f.feb610be.js => a6aa9e1f.0cf460eb.js} (96%) rename assets/js/{a8389ef7.6c4d4dc7.js => a8389ef7.7b0f68a2.js} (98%) rename assets/js/{ccc49370.2c9f06fb.js => ccc49370.5be4e36b.js} (98%) rename assets/js/{fa17a3e5.987acf52.js => fa17a3e5.384a96ee.js} (96%) rename assets/js/{runtime~main.0fac85c4.js => runtime~main.1b62926b.js} (96%) diff --git a/404.html b/404.html index 14f255258..43fd8eee9 100644 --- a/404.html +++ b/404.html @@ -9,13 +9,13 @@ - +
Skip to main content

Page Not Found

We could not find what you were looking for.

Please contact the owner of the site that linked you to the original URL and let them know their link is broken.

- + \ No newline at end of file diff --git a/assets/js/0ce74438.19f07c55.js b/assets/js/0ce74438.4d0f230d.js similarity index 99% rename from assets/js/0ce74438.19f07c55.js rename to assets/js/0ce74438.4d0f230d.js index c0c82b4f1..5de208ebd 100644 --- a/assets/js/0ce74438.19f07c55.js +++ b/assets/js/0ce74438.4d0f230d.js @@ -1 +1 @@ -"use strict";(self.webpackChunkpixi_docusaurus=self.webpackChunkpixi_docusaurus||[]).push([[6342],{7754:(n,e,t)=>{t.d(e,{Z:()=>g});var i=t(2949),a=t(7294),o=t(4184),r=t.n(o),s=t(2695);var d=t(2215),p=t(9604),c=t(5893);function l(n){let{code:e,onChange:t}=n;const o=(0,a.useRef)(null),r=(0,a.useCallback)((n=>{o.current=n}),[]);(0,a.useEffect)((()=>{const n=()=>{null!==o.current&&o.current.layout({})};return window.addEventListener("resize",n),()=>{window.removeEventListener("resize",n)}}),[]);const{colorMode:s}=(0,i.I)();return(0,c.jsx)(p.ZP,{defaultLanguage:"javascript",value:e,defaultPath:"inmemory://model//src/index.ts",onChange:t,options:{lineNumbers:"off",padding:{top:24},minimap:{enabled:!1},fontSize:14,scrollBeyondLastLine:!1,scrollbar:{alwaysConsumeMouseWheel:!1}},onMount:r,theme:"dark"===s?"vs-dark":"light"})}const h=n=>{let{code:e,isPixiWebWorkerVersion:t,isPixiDevVersion:i,pixiVersion:o}=n;const r=(n=>(0,a.useMemo)((()=>({".babelrc":{code:JSON.stringify({presets:[["@babel/preset-env",{useBuiltIns:"entry",corejs:"3.29",targets:"last 2 chrome versions"}]]},null,2)},"src/styles.css":"body { margin: 0; overflow: hidden; }","src/index.js":n,"index.html":'\n\n \n \n PixiJS Playground\n \n \n\n\n - +
Skip to main content

Β· 6 min read
GoodBoyDigital

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!

- + \ No newline at end of file diff --git a/blog/archive.html b/blog/archive.html index 8fb2d923a..ad6992b07 100644 --- a/blog/archive.html +++ b/blog/archive.html @@ -9,13 +9,13 @@ - +
Skip to main content
- + \ No newline at end of file diff --git a/blog/pixi-universe.html b/blog/pixi-universe.html index a14a50555..86eeef345 100644 --- a/blog/pixi-universe.html +++ b/blog/pixi-universe.html @@ -9,7 +9,7 @@ - + @@ -17,7 +17,7 @@
Skip to main content

Introducing the PixiJS Universe!

Β· 11 min read
Zyie

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.

Phase 1​​

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:

PixiJS Website​​

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!

PixiJS React​​

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.

PixiJS Open Games​​

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.

PixiJS UI & PixiJS Layout​​

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 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

AssetPack​​

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

Phase 2​​

Phase 2 will begin shortly and aims to make it easier to work with PixiJS applications.

PixiJS JumpStart​​

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.

PixiJS Dev Tools​​

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.

Phase 3​​

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

Comet​​

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.

PixiJS v8​​

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.

Phase 4​​

Phase 4 represents a leap into new territory for PixiJS as we look to delve deeper into areas outside of strictly 2D rendering.

PixiJS 3D​​

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.

PixiJS Game Engine​​

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.

Conclusion​

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!

- + \ No newline at end of file diff --git a/blog/pixi-v8-beta.html b/blog/pixi-v8-beta.html index 86067a483..dd39f29c4 100644 --- a/blog/pixi-v8-beta.html +++ b/blog/pixi-v8-beta.html @@ -9,7 +9,7 @@ - + @@ -17,7 +17,7 @@
Skip to main content

PixiJS v8 Beta! πŸŽ‰

Β· 6 min read
GoodBoyDigital

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:

1. 😍 Embracing WebGPU​

PixiJS + webGPU = love

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

2. πŸš€ Turbocharging Performance​

bunnies

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:​

  1. Traverse the scene graph and make sure all the transforms are correct
  2. 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​

  1. Update the transform of only things that changed
  2. Traverse the scene graph and construct a set of instructions.
  3. Upload all scene data to GPU in one go.
  4. 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 SituationV7 CPUV8 CPUCPU DifV7 GPUV8 GPUGPU 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!

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

But Wait, There's More!​

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.

Over to you!​

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

Steps to install:​

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! πŸŽ‰

Keep in touch!​

"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.

- + \ No newline at end of file diff --git a/blog/tags.html b/blog/tags.html index e4679558f..bf41aa289 100644 --- a/blog/tags.html +++ b/blog/tags.html @@ -9,13 +9,13 @@ - +
Skip to main content
- + \ No newline at end of file diff --git a/blog/tags/pixi-js-universe.html b/blog/tags/pixi-js-universe.html index 17736e358..20ee216f2 100644 --- a/blog/tags/pixi-js-universe.html +++ b/blog/tags/pixi-js-universe.html @@ -9,13 +9,13 @@ - +
Skip to main content

One post tagged with "PixiJS Universe"

View All Tags
- + \ No newline at end of file diff --git a/blog/tags/pixi-js.html b/blog/tags/pixi-js.html index 8f54f6f90..55614d342 100644 --- a/blog/tags/pixi-js.html +++ b/blog/tags/pixi-js.html @@ -9,13 +9,13 @@ - +
Skip to main content

2 posts tagged with "PixiJS"

View All Tags

Β· 6 min read
GoodBoyDigital

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!

- + \ No newline at end of file diff --git a/blog/tags/web-gl.html b/blog/tags/web-gl.html index 042ca9aeb..789ff8511 100644 --- a/blog/tags/web-gl.html +++ b/blog/tags/web-gl.html @@ -9,13 +9,13 @@ - +
Skip to main content

One post tagged with "WebGL"

View All Tags

Β· 6 min read
GoodBoyDigital

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!

- + \ No newline at end of file diff --git a/blog/tags/web-gpu.html b/blog/tags/web-gpu.html index 15e8da1c2..7ebee06d0 100644 --- a/blog/tags/web-gpu.html +++ b/blog/tags/web-gpu.html @@ -9,13 +9,13 @@ - +
Skip to main content

One post tagged with "WebGPU"

View All Tags

Β· 6 min read
GoodBoyDigital

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!

- + \ No newline at end of file diff --git a/branding.html b/branding.html index 566e38403..88182b565 100644 --- a/branding.html +++ b/branding.html @@ -9,7 +9,7 @@ - + @@ -22,7 +22,7 @@ PNG

PixiJS Logo Full Dark

Mark (Pink)​

Download: SVG PNG

PixiJS Logo Mark Dark

Mark (Light)​

Download: SVG PNG

PixiJS Logo Mark Light

- + \ No newline at end of file diff --git a/examples.html b/examples.html index 0652a1387..af49a56af 100644 --- a/examples.html +++ b/examples.html @@ -9,13 +9,13 @@ - +
Skip to main content
- + \ No newline at end of file diff --git a/examples/advanced/collision-detection.html b/examples/advanced/collision-detection.html index d537ca547..056f7a486 100644 --- a/examples/advanced/collision-detection.html +++ b/examples/advanced/collision-detection.html @@ -9,13 +9,13 @@ - +
Skip to main content

Collision Detection

import * as PIXI from 'pixi.js';

// Based somewhat on this article by Spicy Yoghurt
// URL for further reading: https://spicyyoghurt.com/tutorials/html5-javascript-game-development/collision-detection-physics
const app = new PIXI.Application({ background: '#111', resizeTo: window });

document.body.appendChild(app.view);

// Options for how objects interact
// How fast the red square moves
const movementSpeed = 0.05;

// Strength of the impulse push between two objects
const impulsePower = 5;

// Test For Hit
// A basic AABB check between two different squares
function testForAABB(object1, object2)
{
const bounds1 = object1.getBounds();
const bounds2 = object2.getBounds();

return bounds1.x < bounds2.x + bounds2.width
&& bounds1.x + bounds1.width > bounds2.x
&& bounds1.y < bounds2.y + bounds2.height
&& bounds1.y + bounds1.height > bounds2.y;
}

// Calculates the results of a collision, allowing us to give an impulse that
// shoves objects apart
function collisionResponse(object1, object2)
{
if (!object1 || !object2)
{
return new PIXI.Point(0);
}

const vCollision = new PIXI.Point(
object2.x - object1.x,
object2.y - object1.y,
);

const distance = Math.sqrt(
(object2.x - object1.x) * (object2.x - object1.x)
+ (object2.y - object1.y) * (object2.y - object1.y),
);

const vCollisionNorm = new PIXI.Point(
vCollision.x / distance,
vCollision.y / distance,
);

const vRelativeVelocity = new PIXI.Point(
object1.acceleration.x - object2.acceleration.x,
object1.acceleration.y - object2.acceleration.y,
);

const speed = vRelativeVelocity.x * vCollisionNorm.x
+ vRelativeVelocity.y * vCollisionNorm.y;

const impulse = impulsePower * speed / (object1.mass + object2.mass);

return new PIXI.Point(
impulse * vCollisionNorm.x,
impulse * vCollisionNorm.y,
);
}

// Calculate the distance between two given points
function distanceBetweenTwoPoints(p1, p2)
{
const a = p1.x - p2.x;
const b = p1.y - p2.y;

return Math.hypot(a, b);
}

// The green square we will knock about
const greenSquare = new PIXI.Sprite(PIXI.Texture.WHITE);

greenSquare.position.set((app.screen.width - 100) / 2, (app.screen.height - 100) / 2);
greenSquare.width = 100;
greenSquare.height = 100;
greenSquare.tint = 0x00FF00;
greenSquare.acceleration = new PIXI.Point(0);
greenSquare.mass = 3;

// The square you move around
const redSquare = new PIXI.Sprite(PIXI.Texture.WHITE);

redSquare.position.set(0, 0);
redSquare.width = 100;
redSquare.height = 100;
redSquare.tint = 0xFF0000;
redSquare.acceleration = new PIXI.Point(0);
redSquare.mass = 1;

const mouseCoords = { x: 0, y: 0 };

app.stage.eventMode = 'static';
app.stage.hitArea = app.screen;
app.stage.on('mousemove', (event) =>
{
mouseCoords.x = event.global.x;
mouseCoords.y = event.global.y;
});

// Listen for animate update
app.ticker.add((delta) =>
{
// Applied deacceleration for both squares, done by reducing the
// acceleration by 0.01% of the acceleration every loop
redSquare.acceleration.set(redSquare.acceleration.x * 0.99, redSquare.acceleration.y * 0.99);
greenSquare.acceleration.set(greenSquare.acceleration.x * 0.99, greenSquare.acceleration.y * 0.99);

// Check whether the green square ever moves off the screen
// If so, reverse acceleration in that direction
if (greenSquare.x < 0 || greenSquare.x > (app.screen.width - 100))
{
greenSquare.acceleration.x = -greenSquare.acceleration.x;
}

if (greenSquare.y < 0 || greenSquare.y > (app.screen.height - 100))
{
greenSquare.acceleration.y = -greenSquare.acceleration.y;
}

// If the green square pops out of the cordon, it pops back into the
// middle
if ((greenSquare.x < -30 || greenSquare.x > (app.screen.width + 30))
|| greenSquare.y < -30 || greenSquare.y > (app.screen.height + 30))
{
greenSquare.position.set((app.screen.width - 100) / 2, (app.screen.height - 100) / 2);
}

// If the mouse is off screen, then don't update any further
if (app.screen.width > mouseCoords.x || mouseCoords.x > 0
|| app.screen.height > mouseCoords.y || mouseCoords.y > 0)
{
// Get the red square's center point
const redSquareCenterPosition = new PIXI.Point(
redSquare.x + (redSquare.width * 0.5),
redSquare.y + (redSquare.height * 0.5),
);

// Calculate the direction vector between the mouse pointer and
// the red square
const toMouseDirection = new PIXI.Point(
mouseCoords.x - redSquareCenterPosition.x,
mouseCoords.y - redSquareCenterPosition.y,
);

// Use the above to figure out the angle that direction has
const angleToMouse = Math.atan2(
toMouseDirection.y,
toMouseDirection.x,
);

// Figure out the speed the square should be travelling by, as a
// function of how far away from the mouse pointer the red square is
const distMouseRedSquare = distanceBetweenTwoPoints(
mouseCoords,
redSquareCenterPosition,
);
const redSpeed = distMouseRedSquare * movementSpeed;

// Calculate the acceleration of the red square
redSquare.acceleration.set(
Math.cos(angleToMouse) * redSpeed,
Math.sin(angleToMouse) * redSpeed,
);
}

// If the two squares are colliding
if (testForAABB(greenSquare, redSquare))
{
// Calculate the changes in acceleration that should be made between
// each square as a result of the collision
const collisionPush = collisionResponse(greenSquare, redSquare);
// Set the changes in acceleration for both squares

redSquare.acceleration.set(
(collisionPush.x * greenSquare.mass),
(collisionPush.y * greenSquare.mass),
);
greenSquare.acceleration.set(
-(collisionPush.x * redSquare.mass),
-(collisionPush.y * redSquare.mass),
);
}

greenSquare.x += greenSquare.acceleration.x * delta;
greenSquare.y += greenSquare.acceleration.y * delta;

redSquare.x += redSquare.acceleration.x * delta;
redSquare.y += redSquare.acceleration.y * delta;
});

// Add to stage
app.stage.addChild(redSquare, greenSquare);
- + \ No newline at end of file diff --git a/examples/advanced/mouse-trail.html b/examples/advanced/mouse-trail.html index 56c159dd9..ec58e8b35 100644 --- a/examples/advanced/mouse-trail.html +++ b/examples/advanced/mouse-trail.html @@ -9,13 +9,13 @@ - +
Skip to main content

Mouse Trail

import * as PIXI from 'pixi.js';

const app = new PIXI.Application({ background: '#1099bb', resizeTo: window });

document.body.appendChild(app.view);

// Get the texture for rope.
const trailTexture = PIXI.Texture.from('https://pixijs.com/assets/trail.png');
const historyX = [];
const historyY = [];
// historySize determines how long the trail will be.
const historySize = 20;
// ropeSize determines how smooth the trail will be.
const ropeSize = 100;
const points = [];

// Create history array.
for (let i = 0; i < historySize; i++)
{
historyX.push(0);
historyY.push(0);
}
// Create rope points.
for (let i = 0; i < ropeSize; i++)
{
points.push(new PIXI.Point(0, 0));
}

// Create the rope
const rope = new PIXI.SimpleRope(trailTexture, points);

// Set the blendmode
rope.blendmode = PIXI.BLEND_MODES.ADD;

app.stage.addChild(rope);

let mouseposition = null;

app.stage.eventMode = 'static';
app.stage.hitArea = app.screen;
app.stage.on('mousemove', (event) =>
{
mouseposition = mouseposition || { x: 0, y: 0 };
mouseposition.x = event.global.x;
mouseposition.y = event.global.y;
});

// Listen for animate update
app.ticker.add(() =>
{
if (!mouseposition) return;

// Update the mouse values to history
historyX.pop();
historyX.unshift(mouseposition.x);
historyY.pop();
historyY.unshift(mouseposition.y);
// Update the points to correspond with history.
for (let i = 0; i < ropeSize; i++)
{
const p = points[i];

// Smooth the curve with cubic interpolation to prevent sharp edges.
const ix = cubicInterpolation(historyX, i / ropeSize * historySize);
const iy = cubicInterpolation(historyY, i / ropeSize * historySize);

p.x = ix;
p.y = iy;
}
});

/**
* Cubic interpolation based on https://github.com/osuushi/Smooth.js
*/
function clipInput(k, arr)
{
if (k < 0) k = 0;
if (k > arr.length - 1) k = arr.length - 1;

return arr[k];
}

function getTangent(k, factor, array)
{
return factor * (clipInput(k + 1, array) - clipInput(k - 1, array)) / 2;
}

function cubicInterpolation(array, t, tangentFactor)
{
if (tangentFactor === null) tangentFactor = 1;

const k = Math.floor(t);
const m = [getTangent(k, tangentFactor, array), getTangent(k + 1, tangentFactor, array)];
const p = [clipInput(k, array), clipInput(k + 1, array)];

t -= k;
const t2 = t * t;
const t3 = t * t2;

return (2 * t3 - 3 * t2 + 1) * p[0] + (t3 - 2 * t2 + t) * m[0] + (-2 * t3 + 3 * t2) * p[1] + (t3 - t2) * m[1];
}
- + \ No newline at end of file diff --git a/examples/advanced/scratch-card.html b/examples/advanced/scratch-card.html index 3184546d9..19e98b79c 100644 --- a/examples/advanced/scratch-card.html +++ b/examples/advanced/scratch-card.html @@ -9,13 +9,13 @@ - +
Skip to main content

Scratch Card

import * as PIXI from 'pixi.js';

const app = new PIXI.Application({ resizeTo: window });

document.body.appendChild(app.view);

// prepare circle texture, that will be our brush
const brush = new PIXI.Graphics()
.beginFill(0xffffff)
.drawCircle(0, 0, 50);

// Create a line that will interpolate the drawn points
const line = new PIXI.Graphics();

PIXI.Assets.add('t1', 'https://pixijs.com/assets/bg_grass.jpg');
PIXI.Assets.add('t2', 'https://pixijs.com/assets/bg_rotate.jpg');
PIXI.Assets.load(['t1', 't2']).then(setup);

function setup()
{
const { width, height } = app.screen;
const stageSize = { width, height };

const background = Object.assign(PIXI.Sprite.from('t1'), stageSize);
const imageToReveal = Object.assign(PIXI.Sprite.from('t2'), stageSize);
const renderTexture = PIXI.RenderTexture.create(stageSize);
const renderTextureSprite = new PIXI.Sprite(renderTexture);

imageToReveal.mask = renderTextureSprite;

app.stage.addChild(
background,
imageToReveal,
renderTextureSprite,
);

app.stage.eventMode = 'static';
app.stage.hitArea = app.screen;
app.stage
.on('pointerdown', pointerDown)
.on('pointerup', pointerUp)
.on('pointerupoutside', pointerUp)
.on('pointermove', pointerMove);

let dragging = false;
let lastDrawnPoint = null;

function pointerMove({ global: { x, y } })
{
if (dragging)
{
brush.position.set(x, y);
app.renderer.render(brush, {
renderTexture,
clear: false,
skipUpdateTransform: false,
});
// Smooth out the drawing a little bit to make it look nicer
// this connects the previous drawn point to the current one
// using a line
if (lastDrawnPoint)
{
line
.clear()
.lineStyle({ width: 100, color: 0xffffff })
.moveTo(lastDrawnPoint.x, lastDrawnPoint.y)
.lineTo(x, y);
app.renderer.render(line, {
renderTexture,
clear: false,
skipUpdateTransform: false,
});
}
lastDrawnPoint = lastDrawnPoint || new PIXI.Point();
lastDrawnPoint.set(x, y);
}
}

function pointerDown(event)
{
dragging = true;
pointerMove(event);
}

function pointerUp(event)
{
dragging = false;
lastDrawnPoint = null;
}
}
- + \ No newline at end of file diff --git a/examples/advanced/screen-shot.html b/examples/advanced/screen-shot.html index 157c398a6..522511a43 100644 --- a/examples/advanced/screen-shot.html +++ b/examples/advanced/screen-shot.html @@ -9,13 +9,13 @@ - +
Skip to main content

Screen Shot

import * as PIXI from 'pixi.js';

const app = new PIXI.Application({ backgroundColor: '#111', resizeTo: window });

document.body.appendChild(app.view);

const texture = PIXI.Texture.from('https://pixijs.com/assets/bunny.png');
const bunnyContainer = new PIXI.Container();

async function takeScreenshot()
{
app.stop();
const url = await app.renderer.extract.base64(bunnyContainer);
const a = document.createElement('a');

document.body.append(a);
a.download = 'screenshot';
a.href = url;
a.click();
a.remove();
app.start();
}

app.stage.eventMode = 'static';
app.stage.hitArea = app.screen;
app.stage.on('pointerdown', takeScreenshot);

for (let i = 0; i < 25; i++)
{
const bunny = new PIXI.Sprite(texture);

bunny.anchor.set(0.5);
bunny.x = (i % 5) * 40;
bunny.y = Math.floor(i / 5) * 40;
bunnyContainer.addChild(bunny);
}

bunnyContainer.x = 400;
bunnyContainer.y = 300;
bunnyContainer.pivot.x = bunnyContainer.width / 2;
bunnyContainer.pivot.y = bunnyContainer.height / 2;

app.ticker.add((delta) =>
{
bunnyContainer.rotation += 0.01 * delta;
});

const style = new PIXI.TextStyle({
fontFamily: 'Roboto',
fill: '#999',
});

const screenshotText = new PIXI.Text('Click To Take Screenshot', style);

screenshotText.x = Math.round((app.screen.width - screenshotText.width) / 2);
screenshotText.y = Math.round(screenshotText.height / 2);

app.stage.addChild(screenshotText, bunnyContainer);
- + \ No newline at end of file diff --git a/examples/advanced/slots.html b/examples/advanced/slots.html index 703baf750..f99a8602c 100644 --- a/examples/advanced/slots.html +++ b/examples/advanced/slots.html @@ -9,13 +9,13 @@ - +
Skip to main content

Slots

import * as PIXI from 'pixi.js';

const app = new PIXI.Application({ background: '#1099bb', resizeTo: window });

document.body.appendChild(app.view);

PIXI.Assets.load([
'https://pixijs.com/assets/eggHead.png',
'https://pixijs.com/assets/flowerTop.png',
'https://pixijs.com/assets/helmlok.png',
'https://pixijs.com/assets/skully.png',
]).then(onAssetsLoaded);

const REEL_WIDTH = 160;
const SYMBOL_SIZE = 150;

// onAssetsLoaded handler builds the example.
function onAssetsLoaded()
{
// Create different slot symbols.
const slotTextures = [
PIXI.Texture.from('https://pixijs.com/assets/eggHead.png'),
PIXI.Texture.from('https://pixijs.com/assets/flowerTop.png'),
PIXI.Texture.from('https://pixijs.com/assets/helmlok.png'),
PIXI.Texture.from('https://pixijs.com/assets/skully.png'),
];

// Build the reels
const reels = [];
const reelContainer = new PIXI.Container();

for (let i = 0; i < 5; i++)
{
const rc = new PIXI.Container();

rc.x = i * REEL_WIDTH;
reelContainer.addChild(rc);

const reel = {
container: rc,
symbols: [],
position: 0,
previousPosition: 0,
blur: new PIXI.filters.BlurFilter(),
};

reel.blur.blurX = 0;
reel.blur.blurY = 0;
rc.filters = [reel.blur];

// Build the symbols
for (let j = 0; j < 4; j++)
{
const symbol = new PIXI.Sprite(slotTextures[Math.floor(Math.random() * slotTextures.length)]);
// Scale the symbol to fit symbol area.

symbol.y = j * SYMBOL_SIZE;
symbol.scale.x = symbol.scale.y = Math.min(SYMBOL_SIZE / symbol.width, SYMBOL_SIZE / symbol.height);
symbol.x = Math.round((SYMBOL_SIZE - symbol.width) / 2);
reel.symbols.push(symbol);
rc.addChild(symbol);
}
reels.push(reel);
}
app.stage.addChild(reelContainer);

// Build top & bottom covers and position reelContainer
const margin = (app.screen.height - SYMBOL_SIZE * 3) / 2;

reelContainer.y = margin;
reelContainer.x = Math.round(app.screen.width - REEL_WIDTH * 5);
const top = new PIXI.Graphics();

top.beginFill(0, 1);
top.drawRect(0, 0, app.screen.width, margin);
const bottom = new PIXI.Graphics();

bottom.beginFill(0, 1);
bottom.drawRect(0, SYMBOL_SIZE * 3 + margin, app.screen.width, margin);

// Add play text
const style = new PIXI.TextStyle({
fontFamily: 'Arial',
fontSize: 36,
fontStyle: 'italic',
fontWeight: 'bold',
fill: ['#ffffff', '#00ff99'], // gradient
stroke: '#4a1850',
strokeThickness: 5,
dropShadow: true,
dropShadowColor: '#000000',
dropShadowBlur: 4,
dropShadowAngle: Math.PI / 6,
dropShadowDistance: 6,
wordWrap: true,
wordWrapWidth: 440,
});

const playText = new PIXI.Text('Spin the wheels!', style);

playText.x = Math.round((bottom.width - playText.width) / 2);
playText.y = app.screen.height - margin + Math.round((margin - playText.height) / 2);
bottom.addChild(playText);

// Add header text
const headerText = new PIXI.Text('PIXI MONSTER SLOTS!', style);

headerText.x = Math.round((top.width - headerText.width) / 2);
headerText.y = Math.round((margin - headerText.height) / 2);
top.addChild(headerText);

app.stage.addChild(top);
app.stage.addChild(bottom);

// Set the interactivity.
bottom.eventMode = 'static';
bottom.cursor = 'pointer';
bottom.addListener('pointerdown', () =>
{
startPlay();
});

let running = false;

// Function to start playing.
function startPlay()
{
if (running) return;
running = true;

for (let i = 0; i < reels.length; i++)
{
const r = reels[i];
const extra = Math.floor(Math.random() * 3);
const target = r.position + 10 + i * 5 + extra;
const time = 2500 + i * 600 + extra * 600;

tweenTo(r, 'position', target, time, backout(0.5), null, i === reels.length - 1 ? reelsComplete : null);
}
}

// Reels done handler.
function reelsComplete()
{
running = false;
}

// Listen for animate update.
app.ticker.add((delta) =>
{
// Update the slots.
for (let i = 0; i < reels.length; i++)
{
const r = reels[i];
// Update blur filter y amount based on speed.
// This would be better if calculated with time in mind also. Now blur depends on frame rate.

r.blur.blurY = (r.position - r.previousPosition) * 8;
r.previousPosition = r.position;

// Update symbol positions on reel.
for (let j = 0; j < r.symbols.length; j++)
{
const s = r.symbols[j];
const prevy = s.y;

s.y = ((r.position + j) % r.symbols.length) * SYMBOL_SIZE - SYMBOL_SIZE;
if (s.y < 0 && prevy > SYMBOL_SIZE)
{
// Detect going over and swap a texture.
// This should in proper product be determined from some logical reel.
s.texture = slotTextures[Math.floor(Math.random() * slotTextures.length)];
s.scale.x = s.scale.y = Math.min(SYMBOL_SIZE / s.texture.width, SYMBOL_SIZE / s.texture.height);
s.x = Math.round((SYMBOL_SIZE - s.width) / 2);
}
}
}
});
}

// Very simple tweening utility function. This should be replaced with a proper tweening library in a real product.
const tweening = [];

function tweenTo(object, property, target, time, easing, onchange, oncomplete)
{
const tween = {
object,
property,
propertyBeginValue: object[property],
target,
easing,
time,
change: onchange,
complete: oncomplete,
start: Date.now(),
};

tweening.push(tween);

return tween;
}
// Listen for animate update.
app.ticker.add((delta) =>
{
const now = Date.now();
const remove = [];

for (let i = 0; i < tweening.length; i++)
{
const t = tweening[i];
const phase = Math.min(1, (now - t.start) / t.time);

t.object[t.property] = lerp(t.propertyBeginValue, t.target, t.easing(phase));
if (t.change) t.change(t);
if (phase === 1)
{
t.object[t.property] = t.target;
if (t.complete) t.complete(t);
remove.push(t);
}
}
for (let i = 0; i < remove.length; i++)
{
tweening.splice(tweening.indexOf(remove[i]), 1);
}
});

// Basic lerp funtion.
function lerp(a1, a2, t)
{
return a1 * (1 - t) + a2 * t;
}

// Backout function from tweenjs.
// https://github.com/CreateJS/TweenJS/blob/master/src/tweenjs/Ease.js
function backout(amount)
{
return (t) => (--t * t * ((amount + 1) * t + amount) + 1);
}
- + \ No newline at end of file diff --git a/examples/advanced/spinners.html b/examples/advanced/spinners.html index ffae4ae07..fdcd63802 100644 --- a/examples/advanced/spinners.html +++ b/examples/advanced/spinners.html @@ -9,13 +9,13 @@ - +
Skip to main content

Spinners

import * as PIXI from 'pixi.js';

const app = new PIXI.Application({ background: '#1099bb', resizeTo: window });

document.body.appendChild(app.view);

/* ---------------------------------------
Spinner 1. Square with radial completion.
-------------------------------------- */
const generateSpinner1 = (position) =>
{
const container = new PIXI.Container();

container.position = position;
app.stage.addChild(container);

const base = PIXI.Sprite.from('https://pixijs.com/assets/bg_scene_rotate.jpg');
const size = 100;

base.width = size;
base.height = size;

const bottom = PIXI.Sprite.from('https://pixijs.com/assets/bg_rotate.jpg');

bottom.width = size;
bottom.height = size;

const mask = new PIXI.Graphics();

mask.position.set(size / 2, size / 2);
base.mask = mask;
window.mask = mask;

container.addChild(bottom);
container.addChild(base);
container.addChild(mask);

let phase = 0;

return (delta) =>
{
// Update phase
phase += delta / 60;
phase %= (Math.PI * 2);

// Calculate target point.
const x = Math.cos(phase - Math.PI / 2) * size;
const y = Math.sin(phase - Math.PI / 2) * size;

const segments = [
[-size / 2, -size / 2, size / 2, -size / 2], // top segment
[size / 2, -size / 2, size / 2, size / 2], // right
[-size / 2, size / 2, size / 2, size / 2], // bottom
[-size / 2, -size / 2, -size / 2, size / 2], // left
];

// Find the intersecting segment.
let intersection = null;
let winding = 0;

for (let i = 0; i < segments.length; i++)
{
const segment = segments[i];
const hit = intersect(0, 0, x, y, segment[0], segment[1], segment[2], segment[3]);

if (hit)
{
intersection = hit;
if (i === 0) winding = hit.x > 0 ? 0 : 4;
else winding = i;
break;
}
}

const corners = [
size / 2, -size / 2, // Top right
size / 2, size / 2, // Bottom right
-size / 2, size / 2, // Bottom left
-size / 2, -size / 2, // Top left,
0, -size / 2, // End point
];

// Redraw mask
mask.clear();
mask.lineStyle(2, 0xff0000, 1);
mask.beginFill(0xff0000, 1);
mask.moveTo(0, -size / 2);
mask.lineTo(0, 0);

mask.lineTo(intersection.x, intersection.y);

// fill the corners
for (let i = winding; i < corners.length / 2; i++)
{
mask.lineTo(corners[i * 2], corners[i * 2 + 1]);
}
mask.endFill();
};
};

/* -----------------------
Spinner 2. Scaling balls.
---------------------- */
const generateSpinner2 = (position) =>
{
const container = new PIXI.Container();

container.position = position;
app.stage.addChild(container);

const size = 100;
const ballAmount = 7;
const balls = [];

for (let i = 0; i < ballAmount; i++)
{
const ball = PIXI.Sprite.from('https://pixijs.com/assets/circle.png');

ball.anchor.set(0.5);
container.addChild(ball);
ball.position.set(
size / 2 + Math.cos(i / ballAmount * Math.PI * 2) * size / 3,
size / 2 + Math.sin(i / ballAmount * Math.PI * 2) * size / 3,
);
balls.push(ball);
}

let phase = 0;

return (delta) =>
{
// Update phase
phase += delta / 60;
phase %= (Math.PI * 2);

// Update ball scales
balls.forEach((b, i) =>
{
const sin = Math.sin(i / ballAmount * Math.PI - phase);
// Multiply sin with itself to get more steeper edge.

b.scale.set(Math.abs(sin * sin * sin * 0.5) + 0.5);
});
};
};

/* ---------------------
Spinner 3. Radial mask.
-------------------- */
const generateSpinner3 = (position) =>
{
const container = new PIXI.Container();

container.position = position;
app.stage.addChild(container);

const base = PIXI.Sprite.from('https://pixijs.com/assets/bg_scene_rotate.jpg');
const size = 100;

base.width = size;
base.height = size;

const mask = new PIXI.Graphics();

mask.position.set(size / 2, size / 2);
base.mask = mask;
window.mask = mask;

container.addChild(base);
container.addChild(mask);

let phase = 0;

return (delta) =>
{
// Update phase
phase += delta / 60;
phase %= (Math.PI * 2);

const angleStart = 0 - Math.PI / 2;
const angle = phase + angleStart;
const radius = 50;

const x1 = Math.cos(angleStart) * radius;
const y1 = Math.sin(angleStart) * radius;

// Redraw mask
mask.clear();
mask.lineStyle(2, 0xff0000, 1);
mask.beginFill(0xff0000, 1);
mask.moveTo(0, 0);
mask.lineTo(x1, y1);
mask.arc(0, 0, radius, angleStart, angle, false);
mask.lineTo(0, 0);
mask.endFill();
};
};

/* ---------------------------------
Spinner 4. Rounded rectangle edges.
------------------------------- */
const generateSpinner4 = (position) =>
{
const container = new PIXI.Container();

container.position = position;
app.stage.addChild(container);

const size = 100;
const arcRadius = 15;

const base = PIXI.Sprite.from('https://pixijs.com/assets/bg_scene_rotate.jpg');

base.width = size;
base.height = size;

// For better performance having assets prerounded would be better than masking.
const roundingMask = new PIXI.Graphics();

roundingMask.beginFill(0, 1);
roundingMask.lineStyle(1, 0xff0000, 1);
roundingMask.drawRoundedRect(0, 0, size, size, arcRadius);
roundingMask.endFill();
base.mask = roundingMask;

// The edge could be replaced with image as well.
const lineSize = 5;
const edge = new PIXI.Graphics();

edge.lineStyle(lineSize, 0xff0000, 1);
edge.drawRoundedRect(0, 0, size, size, arcRadius);
edge.endFill();

// Mask in this example works basically the same way as in example 1.
// Except it is reversed and calculates the mask in straight lines in edges.
const mask = new PIXI.Graphics();

mask.position.set(size / 2, size / 2);
edge.mask = mask;

container.addChild(base);
container.addChild(roundingMask);
container.addChild(edge);
container.addChild(mask);

let phase = 0;

return (delta) =>
{
// Update phase
phase += delta / 160;
phase %= (Math.PI * 2);

// Calculate target point.
const x = Math.cos(phase - Math.PI / 2) * size;
const y = Math.sin(phase - Math.PI / 2) * size;
// Line segments
const segments = [
[-size / 2 + lineSize, -size / 2 + lineSize, size / 2 - lineSize, -size / 2 + lineSize], // top segment
[size / 2 - lineSize, -size / 2 + lineSize, size / 2 - lineSize, size / 2 - lineSize], // right
[-size / 2 + lineSize, size / 2 - lineSize, size / 2 - lineSize, size / 2 - lineSize], // bottom
[-size / 2 + lineSize, -size / 2 + lineSize, -size / 2 + lineSize, size / 2 - lineSize], // left
];
// To which dir should mask continue at each segment
let outDir = [
[0, -1],
[1, 0],
[0, 1],
[-1, 0],
];

// Find the intersecting segment.
let intersection = null;
let winding = 0;
// What direction should the line continue after hit has been found before hitting the line size

for (let i = 0; i < segments.length; i++)
{
const segment = segments[i];
const hit = intersect(0, 0, x, y, segment[0], segment[1], segment[2], segment[3]);

if (hit)
{
intersection = hit;
if (i === 0) winding = hit.x < 0 ? 0 : 4;
else winding = 4 - i;
outDir = outDir[i];
break;
}
}

const corners = [
-size / 2 - lineSize, -size / 2 - lineSize, // Top left,
-size / 2 - lineSize, size / 2 + lineSize, // Bottom left
size / 2 + lineSize, size / 2 + lineSize, // Bottom right
size / 2 + lineSize, -size / 2 - lineSize, // Top right
];

// Redraw mask
mask.clear();
mask.lineStyle(2, 0x00ff00, 1);
mask.beginFill(0xff0000, 1);

mask.moveTo(0, 0);
mask.moveTo(0, -size / 2 - lineSize);

// fill the corners
for (let i = 0; i < winding; i++)
{
mask.lineTo(corners[i * 2], corners[i * 2 + 1]);
}

mask.lineTo(intersection.x + outDir[0] * lineSize * 2, intersection.y + outDir[1] * lineSize * 2);
mask.lineTo(intersection.x, intersection.y);
mask.lineTo(0, 0);

mask.endFill();
};
};

/* ---------------------
Spinner 5. Rounded rectangle fixed length spinner by jonlepage
-------------------- */
const generateSpinner5 = (position) =>
{
const container = new PIXI.Container();

container.position = position;
app.stage.addChild(container);

const halfCircle = new PIXI.Graphics();

halfCircle.beginFill(0xff0000);
halfCircle.lineStyle(2, 0xffffff);
halfCircle.arc(0, 0, 100, 0, Math.PI);
halfCircle.endFill();
halfCircle.position.set(50, 50);

const rectangle = new PIXI.Graphics();

rectangle.lineStyle(2, 0xffffff, 1);
rectangle.drawRoundedRect(0, 0, 100, 100, 16);
rectangle.endFill();
rectangle.mask = halfCircle;

container.addChild(rectangle);
container.addChild(halfCircle);

let phase = 0;

return (delta) =>
{
// Update phase
phase += delta / 6;
phase %= (Math.PI * 2);

halfCircle.rotation = phase;
};
};

const onTick = [
generateSpinner1(new PIXI.Point(50, 50)),
generateSpinner2(new PIXI.Point(160, 50)),
generateSpinner3(new PIXI.Point(270, 50)),
generateSpinner4(new PIXI.Point(380, 50)),
generateSpinner5(new PIXI.Point(490, 50)),
];

// Listen for animate update
app.ticker.add((delta) =>
{
// Call tick handling for each spinner.
onTick.forEach((cb) =>
{
cb(delta);
});
});

/**
* Helper functions

line intercept math by Paul Bourke http://paulbourke.net/geometry/pointlineplane/
Determine the intersection point of two line segments
Return FALSE if the lines don't intersect

Code modified from original to match pixi examples linting rules.
*/
function intersect(x1, y1, x2, y2, x3, y3, x4, y4)
{
// Check if none of the lines are of length 0
if ((x1 === x2 && y1 === y2) || (x3 === x4 && y3 === y4))
{
return false;
}

const denominator = ((y4 - y3) * (x2 - x1) - (x4 - x3) * (y2 - y1));

// Lines are parallel
if (denominator === 0)
{
return false;
}

const ua = ((x4 - x3) * (y1 - y3) - (y4 - y3) * (x1 - x3)) / denominator;
const ub = ((x2 - x1) * (y1 - y3) - (y2 - y1) * (x1 - x3)) / denominator;

// is the intersection along the segments
if (ua < 0 || ua > 1 || ub < 0 || ub > 1)
{
return false;
}

// Return a object with the x and y coordinates of the intersection
const x = x1 + ua * (x2 - x1);
const y = y1 + ua * (y2 - y1);

return { x, y };
}
- + \ No newline at end of file diff --git a/examples/advanced/star-warp.html b/examples/advanced/star-warp.html index 769e4e0b1..7bcd4622b 100644 --- a/examples/advanced/star-warp.html +++ b/examples/advanced/star-warp.html @@ -9,13 +9,13 @@ - +
Skip to main content

Star Warp

import * as PIXI from 'pixi.js';

const app = new PIXI.Application({ resizeTo: window });

document.body.appendChild(app.view);

// Get the texture for star.
const starTexture = PIXI.Texture.from('https://pixijs.com/assets/star.png');

const starAmount = 1000;
let cameraZ = 0;
const fov = 20;
const baseSpeed = 0.025;
let speed = 0;
let warpSpeed = 0;
const starStretch = 5;
const starBaseSize = 0.05;

// Create the stars
const stars = [];

for (let i = 0; i < starAmount; i++)
{
const star = {
sprite: new PIXI.Sprite(starTexture),
z: 0,
x: 0,
y: 0,
};

star.sprite.anchor.x = 0.5;
star.sprite.anchor.y = 0.7;
randomizeStar(star, true);
app.stage.addChild(star.sprite);
stars.push(star);
}

function randomizeStar(star, initial)
{
star.z = initial ? Math.random() * 2000 : cameraZ + Math.random() * 1000 + 2000;

// Calculate star positions with radial random coordinate so no star hits the camera.
const deg = Math.random() * Math.PI * 2;
const distance = Math.random() * 50 + 1;

star.x = Math.cos(deg) * distance;
star.y = Math.sin(deg) * distance;
}

// Change flight speed every 5 seconds
setInterval(() =>
{
warpSpeed = warpSpeed > 0 ? 0 : 1;
}, 5000);

// Listen for animate update
app.ticker.add((delta) =>
{
// Simple easing. This should be changed to proper easing function when used for real.
speed += (warpSpeed - speed) / 20;
cameraZ += delta * 10 * (speed + baseSpeed);
for (let i = 0; i < starAmount; i++)
{
const star = stars[i];

if (star.z < cameraZ) randomizeStar(star);

// Map star 3d position to 2d with really simple projection
const z = star.z - cameraZ;

star.sprite.x = star.x * (fov / z) * app.renderer.screen.width + app.renderer.screen.width / 2;
star.sprite.y = star.y * (fov / z) * app.renderer.screen.width + app.renderer.screen.height / 2;

// Calculate star scale & rotation.
const dxCenter = star.sprite.x - app.renderer.screen.width / 2;
const dyCenter = star.sprite.y - app.renderer.screen.height / 2;
const distanceCenter = Math.sqrt(dxCenter * dxCenter + dyCenter * dyCenter);
const distanceScale = Math.max(0, (2000 - z) / 2000);

star.sprite.scale.x = distanceScale * starBaseSize;
// Star is looking towards center so that y axis is towards center.
// Scale the star depending on how fast we are moving, what the stretchfactor is
// and depending on how far away it is from the center.
star.sprite.scale.y = distanceScale * starBaseSize
+ distanceScale * speed * starStretch * distanceCenter / app.renderer.screen.width;
star.sprite.rotation = Math.atan2(dyCenter, dxCenter) + Math.PI / 2;
}
});
- + \ No newline at end of file diff --git a/examples/assets/async.html b/examples/assets/async.html index c278dc9bc..b66a9a82e 100644 --- a/examples/assets/async.html +++ b/examples/assets/async.html @@ -9,13 +9,13 @@ - +
Skip to main content

Async

import * as PIXI from 'pixi.js';

const app = new PIXI.Application({ background: '#1099bb', resizeTo: window });

document.body.appendChild(app.view);

// await can only be used inside an async function
async function init()
{
const texture = await PIXI.Assets.load('https://pixijs.com/assets/bunny.png');

// create a new Sprite from the awaited loaded Texture
const bunny = PIXI.Sprite.from(texture);

// center the sprite's anchor point
bunny.anchor.set(0.5);

// move the sprite to the center of the screen
bunny.x = app.screen.width / 2;
bunny.y = app.screen.height / 2;

app.stage.addChild(bunny);
}

// Call that async function
init();
- + \ No newline at end of file diff --git a/examples/assets/background.html b/examples/assets/background.html index a58292fc8..58b600a8b 100644 --- a/examples/assets/background.html +++ b/examples/assets/background.html @@ -9,13 +9,13 @@ - +
Skip to main content

Background

import * as PIXI from 'pixi.js';

const app = new PIXI.Application({ background: '#1099bb', resizeTo: window });

document.body.appendChild(app.view);

// Add the assets to load
PIXI.Assets.add('flowerTop', 'https://pixijs.com/assets/flowerTop.png');
PIXI.Assets.add('eggHead', 'https://pixijs.com/assets/eggHead.png');

// Allow the assets to load in the background
PIXI.Assets.backgroundLoad(['flowerTop', 'eggHead']);

// If the background load hasn't loaded this asset yet, calling load forces this asset to load now.
PIXI.Assets.load('eggHead').then((texture) =>
{
// auxiliar flag for toggling the texture
let isEggHead = true;

// create a new Sprite from the resolved loaded texture
const character = new PIXI.Sprite(texture);

character.anchor.set(0.5);
character.x = app.screen.width / 2;
character.y = app.screen.height / 2;
character.eventMode = 'static';
character.cursor = 'pointer';

app.stage.addChild(character);

character.on('pointertap', async () =>
{
isEggHead = !isEggHead;
// These promise are already resolved in the cache.
character.texture = await PIXI.Assets.load(isEggHead ? 'eggHead' : 'flowerTop');
});
});
- + \ No newline at end of file diff --git a/examples/assets/bundle.html b/examples/assets/bundle.html index 281dd118d..7b5fd57f2 100644 --- a/examples/assets/bundle.html +++ b/examples/assets/bundle.html @@ -9,13 +9,13 @@ - +
Skip to main content

Bundle

import * as PIXI from 'pixi.js';

const app = new PIXI.Application({ background: '#1099bb', resizeTo: window });

document.body.appendChild(app.view);

async function init()
{
// manifest example
const manifestExample = {
bundles: [{
name: 'load-screen',
assets: [
{
name: 'flowerTop',
srcs: 'https://pixijs.com/assets/flowerTop.png',
},
],
},
{
name: 'game-screen',
assets: [
{
name: 'eggHead',
srcs: 'https://pixijs.com/assets/eggHead.png',
},
],
}],
};

await PIXI.Assets.init({ manifest: manifestExample });

// bundles can be loaded in the background too!
PIXI.Assets.backgroundLoadBundle(['load-screen', 'game-screen']);

makeLoadScreen();
}

async function makeLoadScreen()
{
// get the assets from the load screen bundle.
// If the bundle was already downloaded the promise resolves instantly!
const loadScreenAssets = await PIXI.Assets.loadBundle('load-screen');

// create a new Sprite from the resolved loaded texture
const goNext = new PIXI.Sprite(loadScreenAssets.flowerTop);

goNext.anchor.set(0.5);
goNext.x = app.screen.width / 2;
goNext.y = app.screen.height / 2;
app.stage.addChild(goNext);

goNext.eventMode = 'static';
goNext.cursor = 'pointer';

goNext.on('pointertap', async () =>
{
goNext.destroy();
makeGameScreen();
});
}

async function makeGameScreen()
{
// Wait here until you get the assets
// If the user spends enough time in the load screen by the time they reach the game screen
// the assets are completely loaded and the promise resolves instantly!
const loadScreenAssets = await PIXI.Assets.loadBundle('game-screen');

// create a new Sprite from the resolved loaded texture
const goBack = new PIXI.Sprite(loadScreenAssets.eggHead);

goBack.anchor.set(0.5);
goBack.x = app.screen.width / 2;
goBack.y = app.screen.height / 2;
app.stage.addChild(goBack);

goBack.eventMode = 'static';
goBack.cursor = 'pointer';

goBack.on('pointertap', async () =>
{
goBack.destroy();
// The user can go back and the files are already downloaded
makeLoadScreen();
});
}

init();
- + \ No newline at end of file diff --git a/examples/assets/multiple.html b/examples/assets/multiple.html index 24c92f0b0..400795b08 100644 --- a/examples/assets/multiple.html +++ b/examples/assets/multiple.html @@ -9,13 +9,13 @@ - +
Skip to main content

Multiple

import * as PIXI from 'pixi.js';

const app = new PIXI.Application({ background: '#1099bb', resizeTo: window });

document.body.appendChild(app.view);

// Add the assets to load
PIXI.Assets.add('flowerTop', 'https://pixijs.com/assets/flowerTop.png');
PIXI.Assets.add('eggHead', 'https://pixijs.com/assets/eggHead.png');

// Load the assets and get a resolved promise once both are loaded
const texturesPromise = PIXI.Assets.load(['flowerTop', 'eggHead']); // => Promise<{flowerTop: Texture, eggHead: Texture}>

// When the promise resolves, we have the texture!
texturesPromise.then((textures) =>
{
// create a new Sprite from the resolved loaded Textures

const flower = PIXI.Sprite.from(textures.flowerTop);

flower.anchor.set(0.5);
flower.x = app.screen.width * 0.25;
flower.y = app.screen.height / 2;
app.stage.addChild(flower);

const egg = PIXI.Sprite.from(textures.eggHead);

egg.anchor.set(0.5);
egg.x = app.screen.width * 0.75;
egg.y = app.screen.height / 2;
app.stage.addChild(egg);
});
- + \ No newline at end of file diff --git a/examples/assets/promise.html b/examples/assets/promise.html index 7c57e8c62..56c35dbdd 100644 --- a/examples/assets/promise.html +++ b/examples/assets/promise.html @@ -9,13 +9,13 @@ - +
Skip to main content

Promise

import * as PIXI from 'pixi.js';

const app = new PIXI.Application({ background: '#1099bb', resizeTo: window });

document.body.appendChild(app.view);

// Start loading right away and create a promise
const texturePromise = PIXI.Assets.load('https://pixijs.com/assets/bunny.png');

// When the promise resolves, we have the texture!
texturePromise.then((resolvedTexture) =>
{
// create a new Sprite from the resolved loaded Texture
const bunny = PIXI.Sprite.from(resolvedTexture);

// center the sprite's anchor point
bunny.anchor.set(0.5);

// move the sprite to the center of the screen
bunny.x = app.screen.width / 2;
bunny.y = app.screen.height / 2;

app.stage.addChild(bunny);
});
- + \ No newline at end of file diff --git a/examples/basic/blend-modes.html b/examples/basic/blend-modes.html index 7868ef60d..9c8795c09 100644 --- a/examples/basic/blend-modes.html +++ b/examples/basic/blend-modes.html @@ -9,13 +9,13 @@ - +
Skip to main content

Blend Modes

import * as PIXI from 'pixi.js';

const app = new PIXI.Application({ resizeTo: window });

document.body.appendChild(app.view);

// create a new background sprite
const background = PIXI.Sprite.from('https://pixijs.com/assets/bg_rotate.jpg');

background.width = app.screen.width;
background.height = app.screen.height;
app.stage.addChild(background);

// create an array to store a reference to the dudes
const dudeArray = [];

const totaldudes = 20;

for (let i = 0; i < totaldudes; i++)
{
// create a new Sprite that uses the image name that we just generated as its source
const dude = PIXI.Sprite.from('https://pixijs.com/assets/flowerTop.png');

dude.anchor.set(0.5);

// set a random scale for the dude
dude.scale.set(0.8 + Math.random() * 0.3);

// finally let's set the dude to be at a random position...
dude.x = Math.floor(Math.random() * app.screen.width);
dude.y = Math.floor(Math.random() * app.screen.height);

// The important bit of this example, this is how you change the default blend mode of the sprite
dude.blendMode = PIXI.BLEND_MODES.ADD;

// create some extra properties that will control movement
dude.direction = Math.random() * Math.PI * 2;

// this number will be used to modify the direction of the dude over time
dude.turningSpeed = Math.random() - 0.8;

// create a random speed for the dude between 0 - 2
dude.speed = 2 + Math.random() * 2;

// finally we push the dude into the dudeArray so it it can be easily accessed later
dudeArray.push(dude);

app.stage.addChild(dude);
}

// create a bounding box for the little dudes
const dudeBoundsPadding = 100;

const dudeBounds = new PIXI.Rectangle(
-dudeBoundsPadding,
-dudeBoundsPadding,
app.screen.width + dudeBoundsPadding * 2,
app.screen.height + dudeBoundsPadding * 2,
);

app.ticker.add(() =>
{
// iterate through the dudes and update the positions
for (let i = 0; i < dudeArray.length; i++)
{
const dude = dudeArray[i];

dude.direction += dude.turningSpeed * 0.01;
dude.x += Math.sin(dude.direction) * dude.speed;
dude.y += Math.cos(dude.direction) * dude.speed;
dude.rotation = -dude.direction - Math.PI / 2;

// wrap the dudes by testing their bounds...
if (dude.x < dudeBounds.x)
{
dude.x += dudeBounds.width;
}
else if (dude.x > dudeBounds.x + dudeBounds.width)
{
dude.x -= dudeBounds.width;
}

if (dude.y < dudeBounds.y)
{
dude.y += dudeBounds.height;
}
else if (dude.y > dudeBounds.y + dudeBounds.height)
{
dude.y -= dudeBounds.height;
}
}
});
- + \ No newline at end of file diff --git a/examples/basic/cache-as-bitmap.html b/examples/basic/cache-as-bitmap.html index f00a7726b..21cdfc825 100644 --- a/examples/basic/cache-as-bitmap.html +++ b/examples/basic/cache-as-bitmap.html @@ -9,13 +9,13 @@ - +
Skip to main content

Cache As Bitmap

import * as PIXI from 'pixi.js';

const app = new PIXI.Application({ resizeTo: window });

document.body.appendChild(app.view);

app.stop();

// load resources
PIXI.Assets.load('https://pixijs.com/assets/spritesheet/monsters.json')
.then(onAssetsLoaded);

// holder to store aliens
const aliens = [];
const alienFrames = [
'eggHead.png',
'flowerTop.png',
'helmlok.png',
'skully.png',
];

let count = 0;

// create an empty container
const alienContainer = new PIXI.Container();

alienContainer.x = 400;
alienContainer.y = 300;

// make the stage interactive
app.stage.eventMode = 'static';
app.stage.addChild(alienContainer);

function onAssetsLoaded()
{
// add a bunch of aliens with textures from image paths
for (let i = 0; i < 100; i++)
{
const frameName = alienFrames[i % 4];

// create an alien using the frame name..
const alien = PIXI.Sprite.from(frameName);

alien.tint = Math.random() * 0xFFFFFF;

alien.x = Math.random() * 800 - 400;
alien.y = Math.random() * 600 - 300;
alien.anchor.x = 0.5;
alien.anchor.y = 0.5;
aliens.push(alien);
alienContainer.addChild(alien);
}
app.start();
}

// Combines both mouse click + touch tap
app.stage.on('pointertap', onClick);

function onClick()
{
alienContainer.cacheAsBitmap = !alienContainer.cacheAsBitmap;
}

app.ticker.add(() =>
{
// let's rotate the aliens a little bit
for (let i = 0; i < 100; i++)
{
const alien = aliens[i];

alien.rotation += 0.1;
}

count += 0.01;

alienContainer.scale.x = Math.sin(count);
alienContainer.scale.y = Math.sin(count);
alienContainer.rotation += 0.01;
});
- + \ No newline at end of file diff --git a/examples/basic/container.html b/examples/basic/container.html index f94c6e6f4..d73af6706 100644 --- a/examples/basic/container.html +++ b/examples/basic/container.html @@ -9,13 +9,13 @@ - +
Skip to main content

Container

import * as PIXI from 'pixi.js';

const app = new PIXI.Application({ background: '#1099bb', resizeTo: window });

document.body.appendChild(app.view);

const container = new PIXI.Container();

app.stage.addChild(container);

// Create a new texture
const texture = PIXI.Texture.from('https://pixijs.com/assets/bunny.png');

// Create a 5x5 grid of bunnies
for (let i = 0; i < 25; i++)
{
const bunny = new PIXI.Sprite(texture);

bunny.anchor.set(0.5);
bunny.x = (i % 5) * 40;
bunny.y = Math.floor(i / 5) * 40;
container.addChild(bunny);
}

// Move container to the center
container.x = app.screen.width / 2;
container.y = app.screen.height / 2;

// Center bunny sprite in local container coordinates
container.pivot.x = container.width / 2;
container.pivot.y = container.height / 2;

// Listen for animate update
app.ticker.add((delta) =>
{
// rotate the container!
// use delta to create frame-independent transform
container.rotation -= 0.01 * delta;
});
- + \ No newline at end of file diff --git a/examples/basic/particle-container.html b/examples/basic/particle-container.html index 4de1da899..86c6fbacf 100644 --- a/examples/basic/particle-container.html +++ b/examples/basic/particle-container.html @@ -9,13 +9,13 @@ - +
Skip to main content

Particle Container

import * as PIXI from 'pixi.js';

const app = new PIXI.Application({ resizeTo: window });

document.body.appendChild(app.view);

const sprites = new PIXI.ParticleContainer(10000, {
scale: true,
position: true,
rotation: true,
uvs: true,
alpha: true,
});

app.stage.addChild(sprites);

// create an array to store all the sprites
const maggots = [];

const totalSprites = app.renderer instanceof PIXI.Renderer ? 10000 : 100;

for (let i = 0; i < totalSprites; i++)
{
// create a new Sprite
const dude = PIXI.Sprite.from('https://pixijs.com/assets/maggot_tiny.png');

// set the anchor point so the texture is centerd on the sprite
dude.anchor.set(0.5);

// different maggots, different sizes
dude.scale.set(0.8 + Math.random() * 0.3);

// scatter them all
dude.x = Math.random() * app.screen.width;
dude.y = Math.random() * app.screen.height;

dude.tint = Math.random() * 0x808080;

// create a random direction in radians
dude.direction = Math.random() * Math.PI * 2;

// this number will be used to modify the direction of the sprite over time
dude.turningSpeed = Math.random() - 0.8;

// create a random speed between 0 - 2, and these maggots are slooww
dude.speed = (2 + Math.random() * 2) * 0.2;

dude.offset = Math.random() * 100;

// finally we push the dude into the maggots array so it it can be easily accessed later
maggots.push(dude);

sprites.addChild(dude);
}

// create a bounding box box for the little maggots
const dudeBoundsPadding = 100;
const dudeBounds = new PIXI.Rectangle(
-dudeBoundsPadding,
-dudeBoundsPadding,
app.screen.width + dudeBoundsPadding * 2,
app.screen.height + dudeBoundsPadding * 2,
);

let tick = 0;

app.ticker.add(() =>
{
// iterate through the sprites and update their position
for (let i = 0; i < maggots.length; i++)
{
const dude = maggots[i];

dude.scale.y = 0.95 + Math.sin(tick + dude.offset) * 0.05;
dude.direction += dude.turningSpeed * 0.01;
dude.x += Math.sin(dude.direction) * (dude.speed * dude.scale.y);
dude.y += Math.cos(dude.direction) * (dude.speed * dude.scale.y);
dude.rotation = -dude.direction + Math.PI;

// wrap the maggots
if (dude.x < dudeBounds.x)
{
dude.x += dudeBounds.width;
}
else if (dude.x > dudeBounds.x + dudeBounds.width)
{
dude.x -= dudeBounds.width;
}

if (dude.y < dudeBounds.y)
{
dude.y += dudeBounds.height;
}
else if (dude.y > dudeBounds.y + dudeBounds.height)
{
dude.y -= dudeBounds.height;
}
}

// increment the ticker
tick += 0.1;
});
- + \ No newline at end of file diff --git a/examples/basic/simple-plane.html b/examples/basic/simple-plane.html index e1ced818c..7047d0f06 100644 --- a/examples/basic/simple-plane.html +++ b/examples/basic/simple-plane.html @@ -9,13 +9,13 @@ - +
Skip to main content

Simple Plane

import * as PIXI from 'pixi.js';

const app = new PIXI.Application({ background: '#1099bb', resizeTo: window });

document.body.appendChild(app.view);

PIXI.Assets.load('https://pixijs.com/assets/bg_grass.jpg').then((texture) =>
{
const plane = new PIXI.SimplePlane(texture, 10, 10);

plane.x = 100;
plane.y = 100;

app.stage.addChild(plane);

// Get the buffer for vertice positions.
const buffer = plane.geometry.getBuffer('aVertexPosition');

// Listen for animate update
let timer = 0;

app.ticker.add(() =>
{
// Randomize the vertice positions a bit to create movement.
for (let i = 0; i < buffer.data.length; i++)
{
buffer.data[i] += Math.sin((timer / 10) + i) * 0.5;
}
buffer.update();
timer++;
});
});
- + \ No newline at end of file diff --git a/examples/basic/tinting.html b/examples/basic/tinting.html index eb87f88f8..b83dac37c 100644 --- a/examples/basic/tinting.html +++ b/examples/basic/tinting.html @@ -9,13 +9,13 @@ - +
Skip to main content

Tinting

import * as PIXI from 'pixi.js';

const app = new PIXI.Application({ resizeTo: window });

document.body.appendChild(app.view);

// holder to store the aliens
const aliens = [];

const totalDudes = 20;

for (let i = 0; i < totalDudes; i++)
{
// create a new Sprite that uses the image name that we just generated as its source
const dude = PIXI.Sprite.from('https://pixijs.com/assets/eggHead.png');

// set the anchor point so the texture is centered on the sprite
dude.anchor.set(0.5);

// set a random scale for the dude - no point them all being the same size!
dude.scale.set(0.8 + Math.random() * 0.3);

// finally lets set the dude to be at a random position..
dude.x = Math.random() * app.screen.width;
dude.y = Math.random() * app.screen.height;

dude.tint = Math.random() * 0xFFFFFF;

// create some extra properties that will control movement :
// create a random direction in radians. This is a number between 0 and PI*2 which is the equivalent of 0 - 360 degrees
dude.direction = Math.random() * Math.PI * 2;

// this number will be used to modify the direction of the dude over time
dude.turningSpeed = Math.random() - 0.8;

// create a random speed for the dude between 2 - 4
dude.speed = 2 + Math.random() * 2;

// finally we push the dude into the aliens array so it it can be easily accessed later
aliens.push(dude);

app.stage.addChild(dude);
}

// create a bounding box for the little dudes
const dudeBoundsPadding = 100;
const dudeBounds = new PIXI.Rectangle(-dudeBoundsPadding,
-dudeBoundsPadding,
app.screen.width + dudeBoundsPadding * 2,
app.screen.height + dudeBoundsPadding * 2);

app.ticker.add(() =>
{
// iterate through the dudes and update their position
for (let i = 0; i < aliens.length; i++)
{
const dude = aliens[i];

dude.direction += dude.turningSpeed * 0.01;
dude.x += Math.sin(dude.direction) * dude.speed;
dude.y += Math.cos(dude.direction) * dude.speed;
dude.rotation = -dude.direction - Math.PI / 2;

// wrap the dudes by testing their bounds...
if (dude.x < dudeBounds.x)
{
dude.x += dudeBounds.width;
}
else if (dude.x > dudeBounds.x + dudeBounds.width)
{
dude.x -= dudeBounds.width;
}

if (dude.y < dudeBounds.y)
{
dude.y += dudeBounds.height;
}
else if (dude.y > dudeBounds.y + dudeBounds.height)
{
dude.y -= dudeBounds.height;
}
}
});
- + \ No newline at end of file diff --git a/examples/basic/transparent-background.html b/examples/basic/transparent-background.html index cb231fdfa..9c054db99 100644 --- a/examples/basic/transparent-background.html +++ b/examples/basic/transparent-background.html @@ -9,13 +9,13 @@ - +
Skip to main content

Transparent Background

import * as PIXI from 'pixi.js';

const app = new PIXI.Application({ backgroundAlpha: 0, resizeTo: window });

document.body.appendChild(app.view);

// create a new Sprite from an image path.
const bunny = PIXI.Sprite.from('https://pixijs.com/assets/bunny.png');

// center the sprite's anchor point
bunny.anchor.set(0.5);

// move the sprite to the center of the screen
bunny.x = app.screen.width / 2;
bunny.y = app.screen.height / 2;

app.stage.addChild(bunny);

app.ticker.add(() =>
{
// just for fun, let's rotate mr rabbit a little
bunny.rotation += 0.1;
});
- + \ No newline at end of file diff --git a/examples/events/click.html b/examples/events/click.html index d97967e34..020d112e4 100644 --- a/examples/events/click.html +++ b/examples/events/click.html @@ -9,13 +9,13 @@ - +
Skip to main content

Click

import * as PIXI from 'pixi.js';

const app = new PIXI.Application({ background: '#1099bb', resizeTo: window });

document.body.appendChild(app.view);

// Scale mode for all textures, will retain pixelation
PIXI.settings.SCALE_MODE = PIXI.SCALE_MODES.NEAREST;

const sprite = PIXI.Sprite.from('https://pixijs.com/assets/bunny.png');

// Set the initial position
sprite.anchor.set(0.5);
sprite.x = app.screen.width / 2;
sprite.y = app.screen.height / 2;

// Opt-in to interactivity
sprite.eventMode = 'static';

// Shows hand cursor
sprite.cursor = 'pointer';

// Pointers normalize touch and mouse (good for mobile and desktop)
sprite.on('pointerdown', onClick);

// Alternatively, use the mouse & touch events:
// sprite.on('click', onClick); // mouse-only
// sprite.on('tap', onClick); // touch-only

app.stage.addChild(sprite);

function onClick()
{
sprite.scale.x *= 1.25;
sprite.scale.y *= 1.25;
}
- + \ No newline at end of file diff --git a/examples/events/custom-hitarea.html b/examples/events/custom-hitarea.html index 1aeac302b..8426ba7a4 100644 --- a/examples/events/custom-hitarea.html +++ b/examples/events/custom-hitarea.html @@ -9,13 +9,13 @@ - +
Skip to main content

Custom Hitarea

import * as PIXI from 'pixi.js';

const app = new PIXI.Application(800, 600, { background: '#1099bb' });

document.body.appendChild(app.view);

const yellowStar = PIXI.Texture.from('https://pixijs.com/assets/yellowstar.png');

// Standard Sprite Button
const starButton1 = new PIXI.Sprite(yellowStar);

starButton1.position.set(50, 200);
starButton1.cursor = 'pointer';
starButton1.eventMode = 'static';

starButton1
.on('pointerdown', onClick, starButton1)
.on('pointerover', onPointerOver, starButton1)
.on('pointerout', onPointerOut, starButton1);

// Custom Hitarea Button
const starButton2 = new PIXI.Sprite(yellowStar);

starButton2.position.set(250, 200);

// Create a hitarea that matches the sprite, which will be used for point
// intersection
starButton2.hitArea = new PIXI.Polygon([
80, 0,
100, 50,
160, 55,
115, 95,
130, 150,
80, 120,
30, 150,
45, 95,
0, 55,
60, 50,
]);
starButton2.cursor = 'pointer';
starButton2.eventMode = 'static';

starButton2
.on('pointerdown', onClick, starButton2)
.on('pointerover', onPointerOver, starButton2)
.on('pointerout', onPointerOut, starButton2);

// With Mask, No Hit Area
const starButton3 = new PIXI.Sprite(yellowStar);

starButton3.position.set(450, 200);
starButton3.cursor = 'pointer';
starButton3.eventMode = 'static';

const squareMask = new PIXI.Graphics()
.beginFill(0xFFFFFF)
.drawRect(starButton3.x, starButton3.y, 75, 200)
.endFill();

starButton3.mask = squareMask;

starButton3
.on('pointerdown', onClick, starButton3)
.on('pointerover', onPointerOver, starButton3)
.on('pointerout', onPointerOut, starButton3);

// With a Mask and Hit Area
// Hitareas ignore masks. You can still click on a button made in this way,
// even from areas covered by a mask
const starButton4 = new PIXI.Sprite(yellowStar);

starButton4.position.set(600, 200);

const squareMask2 = new PIXI.Graphics()
.beginFill(0xFFFFFF)
.drawRect(starButton4.x, starButton4.y, 75, 200)
.endFill();

starButton4.mask = squareMask2;

// Again, hitarea for intersection checks
starButton4.hitArea = new PIXI.Polygon([
80, 0,
100, 50,
160, 55,
115, 95,
130, 150,
80, 120,
30, 150,
45, 95,
0, 55,
60, 50,
]);
starButton4.cursor = 'pointer';
starButton4.eventMode = 'static';

starButton4
.on('pointerdown', onClick, starButton4)
.on('pointerover', onPointerOver, starButton4)
.on('pointerout', onPointerOut, starButton4);

const style = new PIXI.TextStyle({ fill: '#ffffff' });

const text1 = new PIXI.Text('Standard', style);

text1.x = starButton1.x + 25;
text1.y = starButton1.y + 170;

const text2 = new PIXI.Text('Hit Area', style);

text2.x = starButton2.x + 35;
text2.y = starButton2.y + 170;

const text3 = new PIXI.Text('Mask', style);

text3.x = starButton3.x + 10;
text3.y = starButton3.y + 170;

const text4 = new PIXI.Text('Mask + Hit Area', style);

text4.x = starButton4.x - 10;
text4.y = starButton4.y + 170;

// Add to stage
app.stage.addChild(
starButton2,
starButton1,
starButton3,
starButton4,
squareMask,
squareMask2,
text1,
text2,
text3,
text4,
);

function onClick()
{
this.tint = 0x333333;
}

function onPointerOver()
{
this.tint = 0x666666;
}

function onPointerOut()
{
this.tint = 0xFFFFFF;
}
- + \ No newline at end of file diff --git a/examples/events/custom-mouse-icon.html b/examples/events/custom-mouse-icon.html index 0457682e9..51ab82455 100644 --- a/examples/events/custom-mouse-icon.html +++ b/examples/events/custom-mouse-icon.html @@ -9,13 +9,13 @@ - +
Skip to main content

Custom Mouse Icon

import * as PIXI from 'pixi.js';

const app = new PIXI.Application({ background: '#1099bb', resizeTo: window });

document.body.appendChild(app.view);

// Css style for icons
const defaultIcon = 'url(\'https://pixijs.com/assets/bunny.png\'),auto';
const hoverIcon = 'url(\'https://pixijs.com/assets/bunny_saturated.png\'),auto';

// Add custom cursor styles
app.renderer.events.cursorStyles.default = defaultIcon;
app.renderer.events.cursorStyles.hover = hoverIcon;

// create a background...
const background = PIXI.Sprite.from('https://pixijs.com/assets/bg_button.jpg');

background.width = app.screen.width;
background.height = app.screen.height;
// add background to stage...
app.stage.addChild(background);

// create some textures from an image path
const textureButton = PIXI.Texture.from('https://pixijs.com/assets/button.png');
const textureButtonDown = PIXI.Texture.from('https://pixijs.com/assets/button_down.png');
const textureButtonOver = PIXI.Texture.from('https://pixijs.com/assets/button_over.png');

const buttons = [];

const buttonPositions = [
175, 75,
655, 75,
410, 325,
150, 465,
685, 445,
];

for (let i = 0; i < 5; i++)
{
const button = new PIXI.Sprite(textureButton);

button.cursor = 'hover';

button.anchor.set(0.5);
button.x = buttonPositions[i * 2];
button.y = buttonPositions[i * 2 + 1];

// make the button interactive...
button.eventMode = 'static';

button
.on('pointerdown', onButtonDown)
.on('pointerup', onButtonUp)
.on('pointerupoutside', onButtonUp)
.on('pointerover', onButtonOver)
.on('pointerout', onButtonOut);

// add it to the stage
app.stage.addChild(button);

// add button to array
buttons.push(button);
}

// set some silly values...
buttons[0].scale.set(1.2);
buttons[2].rotation = Math.PI / 10;
buttons[3].scale.set(0.8);
buttons[4].scale.set(0.8, 1.2);
buttons[4].rotation = Math.PI;

function onButtonDown()
{
this.isdown = true;
this.texture = textureButtonDown;
this.alpha = 1;
}

function onButtonUp()
{
this.isdown = false;
if (this.isOver)
{
this.texture = textureButtonOver;
}
else
{
this.texture = textureButton;
}
}

function onButtonOver()
{
this.isOver = true;
if (this.isdown)
{
return;
}
this.texture = textureButtonOver;
}

function onButtonOut()
{
this.isOver = false;
if (this.isdown)
{
return;
}
this.texture = textureButton;
}
- + \ No newline at end of file diff --git a/examples/events/dragging.html b/examples/events/dragging.html index 307c1fe1f..a3f7c9b23 100644 --- a/examples/events/dragging.html +++ b/examples/events/dragging.html @@ -9,13 +9,13 @@ - +
Skip to main content

Dragging

import * as PIXI from 'pixi.js';

const app = new PIXI.Application({ background: '#1099bb', resizeTo: window });

document.body.appendChild(app.view);

// create a texture from an image path
const texture = PIXI.Texture.from('https://pixijs.com/assets/bunny.png');

// Scale mode for pixelation
texture.baseTexture.scaleMode = PIXI.SCALE_MODES.NEAREST;

for (let i = 0; i < 10; i++)
{
createBunny(
Math.floor(Math.random() * app.screen.width),
Math.floor(Math.random() * app.screen.height),
);
}

function createBunny(x, y)
{
// create our little bunny friend..
const bunny = new PIXI.Sprite(texture);

// enable the bunny to be interactive... this will allow it to respond to mouse and touch events
bunny.eventMode = 'static';

// this button mode will mean the hand cursor appears when you roll over the bunny with your mouse
bunny.cursor = 'pointer';

// center the bunny's anchor point
bunny.anchor.set(0.5);

// make it a bit bigger, so it's easier to grab
bunny.scale.set(3);

// setup events for mouse + touch using
// the pointer events
bunny.on('pointerdown', onDragStart, bunny);

// move the sprite to its designated position
bunny.x = x;
bunny.y = y;

// add it to the stage
app.stage.addChild(bunny);
}

let dragTarget = null;

app.stage.eventMode = 'static';
app.stage.hitArea = app.screen;
app.stage.on('pointerup', onDragEnd);
app.stage.on('pointerupoutside', onDragEnd);

function onDragMove(event)
{
if (dragTarget)
{
dragTarget.parent.toLocal(event.global, null, dragTarget.position);
}
}

function onDragStart()
{
// store a reference to the data
// the reason for this is because of multitouch
// we want to track the movement of this particular touch
// this.data = event.data;
this.alpha = 0.5;
dragTarget = this;
app.stage.on('pointermove', onDragMove);
}

function onDragEnd()
{
if (dragTarget)
{
app.stage.off('pointermove', onDragMove);
dragTarget.alpha = 1;
dragTarget = null;
}
}
- + \ No newline at end of file diff --git a/examples/events/interactivity.html b/examples/events/interactivity.html index caf5cebc6..7f7e63ada 100644 --- a/examples/events/interactivity.html +++ b/examples/events/interactivity.html @@ -9,13 +9,13 @@ - +
Skip to main content

Interactivity

import * as PIXI from 'pixi.js';

const app = new PIXI.Application({ resizeTo: window });

document.body.appendChild(app.view);

// create a background...
const background = PIXI.Sprite.from('https://pixijs.com/assets/bg_button.jpg');

background.width = app.screen.width;
background.height = app.screen.height;

// add background to stage...
app.stage.addChild(background);

// create some textures from an image path
const textureButton = PIXI.Texture.from('https://pixijs.com/assets/button.png');
const textureButtonDown = PIXI.Texture.from('https://pixijs.com/assets/button_down.png');
const textureButtonOver = PIXI.Texture.from('https://pixijs.com/assets/button_over.png');

const buttons = [];

const buttonPositions = [
175, 75,
655, 75,
410, 325,
150, 465,
685, 445,
];

for (let i = 0; i < 5; i++)
{
const button = new PIXI.Sprite(textureButton);

button.anchor.set(0.5);
button.x = buttonPositions[i * 2];
button.y = buttonPositions[i * 2 + 1];

// make the button interactive...
button.eventMode = 'static';
button.cursor = 'pointer';

button
// Mouse & touch events are normalized into
// the pointer* events for handling different
// button events.
.on('pointerdown', onButtonDown)
.on('pointerup', onButtonUp)
.on('pointerupoutside', onButtonUp)
.on('pointerover', onButtonOver)
.on('pointerout', onButtonOut);

// Use mouse-only events
// .on('mousedown', onButtonDown)
// .on('mouseup', onButtonUp)
// .on('mouseupoutside', onButtonUp)
// .on('mouseover', onButtonOver)
// .on('mouseout', onButtonOut)

// Use touch-only events
// .on('touchstart', onButtonDown)
// .on('touchend', onButtonUp)
// .on('touchendoutside', onButtonUp)

// add it to the stage
app.stage.addChild(button);

// add button to array
buttons.push(button);
}

// set some silly values...
buttons[0].scale.set(1.2);
buttons[2].rotation = Math.PI / 10;
buttons[3].scale.set(0.8);
buttons[4].scale.set(0.8, 1.2);
buttons[4].rotation = Math.PI;

function onButtonDown()
{
this.isdown = true;
this.texture = textureButtonDown;
this.alpha = 1;
}

function onButtonUp()
{
this.isdown = false;
if (this.isOver)
{
this.texture = textureButtonOver;
}
else
{
this.texture = textureButton;
}
}

function onButtonOver()
{
this.isOver = true;
if (this.isdown)
{
return;
}
this.texture = textureButtonOver;
}

function onButtonOut()
{
this.isOver = false;
if (this.isdown)
{
return;
}
this.texture = textureButton;
}
- + \ No newline at end of file diff --git a/examples/events/logger.html b/examples/events/logger.html index dd6123139..5b22f6f1e 100644 --- a/examples/events/logger.html +++ b/examples/events/logger.html @@ -9,13 +9,13 @@ - +
Skip to main content

Logger

import * as PIXI from 'pixi.js';

// This example logs the order of events hover-related events in the scene.
const app = new PIXI.Application({
antialias: true,
background: '#1099bb',
});

document.body.appendChild(app.view);

const title = app.stage.addChild(new PIXI.Text(
`Move your mouse slowly over the boxes to
see the order of pointerenter, pointerleave,
pointerover, pointerout events on each target!`, {
fontSize: 16,
},
));

title.x = 2;

const logs = [];
const logText = app.stage.addChild(new PIXI.Text('', {
fontSize: 14,
}));

logText.y = 80;
logText.x = 2;

app.stage.name = 'stage';

// Mount outer black box
const blackBox = app.stage.addChild(new PIXI.Graphics()
.beginFill(0)
.drawRect(0, 0, 400, 400)
.endFill());

blackBox.name = 'black box';
blackBox.x = 400;

// Mount white box inside the white one
const whiteBox = blackBox.addChild(new PIXI.Graphics()
.beginFill(0xffffff)
.drawRect(100, 100, 200, 200)
.endFill());

whiteBox.name = 'white box';

// Enable interactivity everywhere!
app.stage.eventMode = 'static';
app.stage.hitArea = app.screen;
whiteBox.eventMode = 'static';
blackBox.eventMode = 'static';

function onEvent(e)
{
const type = e.type;
const targetName = e.target.name;
const currentTargetName = e.currentTarget.name;

// Add event to top of logs
logs.push(`${currentTargetName} received ${type} event (target is ${targetName})`);

if (currentTargetName === 'stage'
|| type === 'pointerenter'
|| type === 'pointerleave')
{
logs.push('-----------------------------------------', '');
}

// Prevent logs from growing too long
if (logs.length > 30)
{
while (logs.length > 30)
{
logs.shift();
}
}

// Update logText
logText.text = logs.join('\n');
}

[app.stage, whiteBox, blackBox].forEach((object) =>
{
object.addEventListener('pointerenter', onEvent);
object.addEventListener('pointerleave', onEvent);
object.addEventListener('pointerover', onEvent);
object.addEventListener('pointerout', onEvent);
});
- + \ No newline at end of file diff --git a/examples/events/nested-boundary-with-projection.html b/examples/events/nested-boundary-with-projection.html index 7874b09db..ed4bfb693 100644 --- a/examples/events/nested-boundary-with-projection.html +++ b/examples/events/nested-boundary-with-projection.html @@ -9,13 +9,13 @@ - +
Skip to main content

Nested Boundary With Projection

import * as PIXI from 'pixi.js';
import '@pixi/graphics-extras';

// This example shows how you can setup a nested boundary to propagate events
// into a disjoint scene graph. Here, a camera is used to project an different
// world onto the canvas.

const app = new PIXI.Application({
antialias: true,
background: '#1099bb',
});

document.body.appendChild(app.view);

// A projector renders it's content using projection. The transforms in
// the contents scene graph don't change if you move the camera. To achieve
// this, the content is not added as a "child" to the projector; however, this
// means events won't propagate into the content by default.
//
// To solve this, we nest our own EventBoundary, and connect it using
// addEventListener!
class Projector extends PIXI.DisplayObject
{
constructor()
{
super();

// The content root to be rendered by this camera.
this.content = new PIXI.Container();

// Temporary matrix to store the original projection transform.
this.originalTransform = new PIXI.Matrix();

// The event boundary that'll map events downstream into the content
// scene.
this.boundary = new PIXI.EventBoundary(this.content);

// Override copyMouseData to apply inverse worldTransform on
// global coords
this.boundary.copyMouseData = (from, to) =>
{
// Apply default implementation first
PIXI.EventBoundary.prototype.copyMouseData.call(this.boundary, from, to);

// Then bring global coords into content's world
this.worldTransform.applyInverse(to.global, to.global);
// TODO: Remove after https://github.com/pixijs/pixi.js/pull/7381
// is merged!
to.target = this.boundary.hitTest(to.global.x, to.global.y);
};

// Propagate these events down into the content's scene graph!
[
'pointerdown',
'pointerup',
'pointermove',
'pointerover',
'pointerout',
'wheel',
].forEach((event) =>
{
this.addEventListener(event, (e) => this.boundary.mapEvent(e));
});

this.eventMode = 'static';
}

// Pass through cursor
get cursor()
{
return this.boundary.cursor;
}

// eslint-disable-next-line class-methods-use-this
set cursor(value)
{
throw new Error('The camera\'s cursor is derived from its content!');
}

// Pass through calculateBounds
calculateBounds()
{
const contentBounds = this.content.getBounds();

this._bounds.addFrameMatrix(
this.worldTransform,
contentBounds.x,
contentBounds.y,
contentBounds.width,
contentBounds.height,
);
}

// Pass through containsPoint
containsPoint(point)
{
return !!this.boundary.hitTest(point.x, point.y);
}

// Render content with projection
render(renderer)
{
renderer.batch.flush();

const projectionSystem = renderer.projection;
const renderTextureSystem = renderer.renderTexture;

projectionSystem.transform = projectionSystem.transform
|| new PIXI.Matrix();
projectionSystem.transform.copyTo(this.originalTransform);
projectionSystem.transform.append(this.worldTransform);
projectionSystem.update(null, null, 1, !renderTextureSystem.current);

this.content.render(renderer);

renderer.batch.flush();

projectionSystem.transform.copyFrom(this.originalTransform);
projectionSystem.update(null, null, 1, !renderTextureSystem.current);
}

// updateTransform also updates content's transform
updateTransform()
{
super.updateTransform();

this.content.enableTempParent();
this.content.updateTransform();
this.content.disableTempParent(null);
}
}

// The projector
const projector = app.stage.addChild(new Projector());

// Add coordinate axes!
projector.content.addChild(
new PIXI.Graphics()
.lineStyle({ color: 0, alpha: 0.2, width: 2 })
.moveTo(0, -300)
.lineTo(0, 600)
.moveTo(-100, 0)
.lineTo(700, 0),
);

// Construct the star Graphics
const stars = [1, 2, 3].map((i) => new PIXI.Graphics()
.beginFill(0xffffff, 0.75)
.drawStar(0, 0, 18 / i, 100 * i / 2));

// Place the stars
stars[0].x = 0;
stars[1].x = 200;
stars[2].x = 500;

// Add stars to the projector
projector.content.addChild(...stars);

// Make projection x+100, y+300
projector.x = 100;
projector.y = 300;
projector.content.hitArea = new PIXI.Rectangle(-100, -300, app.screen.width, app.screen.height);
// Make hit-area cover the whole screen so we can capture
// pointermove everywhere!
projector.hitArea = projector.content.hitArea;
projector.content.eventMode = 'static';

// Make stars interactive & add wheel handlers
stars.forEach((star) =>
{
// Make star interactive
star.eventMode = 'static';

// Set initial cursor
star.cursor = 'zoom-in';

// Add wheel rotation feedback
star.addEventListener('wheel', (e) =>
{
const scroll = Math.sign(e.deltaY) * Math.min(15, Math.abs(e.deltaY));

star.rotation += scroll / 100;
});

// Add click zoom-in/zoom-out handler
star.addEventListener('click', (e) =>
{
if (star.scale.x === 1)
{
star.scale.set(1.33);
star.cursor = 'zoom-out';
}
else
{
star.scale.set(1);
star.cursor = 'zoom-in';
}
});
});

PIXI.BitmapFont.from('coordinates', {
fontFamily: 'Roboto',
fontSize: 16,
fill: '#272d37',
}, { chars: ['Global:() Screen-.,', ['0', '9']] });

const coordinates = new PIXI.BitmapText('Global: (0, 0)\nScreen: (0, 0)', {
fontName: 'coordinates',
});

coordinates.x = 110;
coordinates.y = 550;

app.stage.addChild(coordinates);

projector.content.addEventListener('pointermove', (e) =>
{
const global = `(${e.global.x | 0}, ${e.global.y | 0})`;
const screen = `(${e.screen.x | 0}, ${e.screen.y | 0})`;

coordinates.text = `Global: ${global}\nScreen: ${screen}`;
});

const description = new PIXI.Text(
'The (0, 0) world coordinates for the content is located at the center of the first star!'
+ '\n * Mouse wheel over stars to rotate them'
+ '\n * Click to zoom in or out', {
fontSize: 16,
fontFamily: 'Roboto',
fill: '#272d37',
},
);

description.position.set(110, 12);

app.stage.addChild(description);
- + \ No newline at end of file diff --git a/examples/events/pointer-tracker.html b/examples/events/pointer-tracker.html index f25f38f38..cab8bd20f 100644 --- a/examples/events/pointer-tracker.html +++ b/examples/events/pointer-tracker.html @@ -9,13 +9,13 @@ - +
Skip to main content

Pointer Tracker

import * as PIXI from 'pixi.js';

// In this a example, a circle will follow the pointer wherever it
// moves over the canvas.

const app = new PIXI.Application({
antialias: true,
background: '#1099bb',
});

document.body.appendChild(app.view);

// Create the circle
const circle = app.stage.addChild(new PIXI.Graphics()
.beginFill(0xffffff)
.lineStyle({ color: 0x111111, alpha: 0.87, width: 1 })
.drawCircle(0, 0, 8)
.endFill());

circle.position.set(app.screen.width / 2, app.screen.height / 2);

// Enable interactivity!
app.stage.eventMode = 'static';

// Make sure the whole canvas area is interactive, not just the circle.
app.stage.hitArea = app.screen;

// Follow the pointer
app.stage.addEventListener('pointermove', (e) =>
{
circle.position.copyFrom(e.global);
});
- + \ No newline at end of file diff --git a/examples/events/slider.html b/examples/events/slider.html index 6b8972a0e..178d7348b 100644 --- a/examples/events/slider.html +++ b/examples/events/slider.html @@ -9,13 +9,13 @@ - +
Skip to main content

Slider

import * as PIXI from 'pixi.js';

const app = new PIXI.Application({
antialias: true,
background: '#1099bb',
});

document.body.appendChild(app.view);

const stageHeight = app.screen.height;
const stageWidth = app.screen.width;

// Make sure stage covers the whole scene
app.stage.hitArea = app.screen;

// Make the slider
const sliderWidth = 320;
const slider = new PIXI.Graphics()
.beginFill(0x272d37)
.drawRect(0, 0, sliderWidth, 4);

slider.x = (stageWidth - sliderWidth) / 2;
slider.y = stageHeight * 0.75;

// Draw the handle
const handle = new PIXI.Graphics()
.beginFill(0xffffff)
.drawCircle(0, 0, 8);

handle.y = slider.height / 2;
handle.x = sliderWidth / 2;
handle.eventMode = 'static';
handle.cursor = 'pointer';

handle
.on('pointerdown', onDragStart)
.on('pointerup', onDragEnd)
.on('pointerupoutside', onDragEnd);

app.stage.addChild(slider);
slider.addChild(handle);

// Add bunny whose scale can be changed by user using slider
const bunny = app.stage.addChild(PIXI.Sprite.from('https://pixijs.com/assets/bunny.png'));

bunny.texture.baseTexture.scaleMode = PIXI.SCALE_MODES.NEAREST;
bunny.scale.set(3);
bunny.anchor.set(0.5);
bunny.x = stageWidth / 2;
bunny.y = stageHeight / 2;

// Add title
const title = new PIXI.Text('Drag the handle to change the scale of bunny.', {
fill: '#272d37',
fontFamily: 'Roboto',
fontSize: 20,
align: 'center',
});

title.roundPixels = true;
title.x = stageWidth / 2;
title.y = 40;
title.anchor.set(0.5, 0);
app.stage.addChild(title);

// Listen to pointermove on stage once handle is pressed.
function onDragStart()
{
app.stage.eventMode = 'static';
app.stage.addEventListener('pointermove', onDrag);
}

// Stop dragging feedback once the handle is released.
function onDragEnd(e)
{
app.stage.eventMode = 'auto';
app.stage.removeEventListener('pointermove', onDrag);
}

// Update the handle's position & bunny's scale when the handle is moved.
function onDrag(e)
{
const halfHandleWidth = handle.width / 2;
// Set handle y-position to match pointer, clamped to (4, screen.height - 4).

handle.x = Math.max(halfHandleWidth, Math.min(
slider.toLocal(e.global).x,
sliderWidth - halfHandleWidth,
));
// Normalize handle position between -1 and 1.
const t = 2 * ((handle.x / sliderWidth) - 0.5);

bunny.scale.set(3 * (1.1 + t));
}
- + \ No newline at end of file diff --git a/examples/filters-advanced/custom.html b/examples/filters-advanced/custom.html index dd92c03e3..75ec9a5a9 100644 --- a/examples/filters-advanced/custom.html +++ b/examples/filters-advanced/custom.html @@ -9,13 +9,13 @@ - +
Skip to main content

Custom

import * as PIXI from 'pixi.js';

const app = new PIXI.Application({ resizeTo: window });

document.body.appendChild(app.view);

// Create background image
const background = PIXI.Sprite.from('https://pixijs.com/assets/bg_grass.jpg');

background.width = app.screen.width;
background.height = app.screen.height;
app.stage.addChild(background);

// Stop application wait for load to finish
app.stop();

fetch('https://pixijs.com/assets/pixi-filters/shader.frag')
.then((res) => res.text())
.then(onLoaded);

let filter;

// Handle the load completed
function onLoaded(data)
{
// Create the new filter, arguments: (vertexShader, framentSource)
filter = new PIXI.Filter(null, data, {
customUniform: 0.0,
});

// === WARNING ===
// specify uniforms in filter constructor
// or set them BEFORE first use
// filter.uniforms.customUniform = 0.0

// Add the filter
background.filters = [filter];

// Resume application update
app.start();
}

// Animate the filter
app.ticker.add((delta) =>
{
filter.uniforms.customUniform += 0.04 * delta;
});
- + \ No newline at end of file diff --git a/examples/filters-advanced/mouse-blending.html b/examples/filters-advanced/mouse-blending.html index 2a7a47d76..d22af10f3 100644 --- a/examples/filters-advanced/mouse-blending.html +++ b/examples/filters-advanced/mouse-blending.html @@ -9,13 +9,13 @@ - +
Skip to main content

Mouse Blending

import * as PIXI from 'pixi.js';

/**
* https://github.com/pixijs/pixi.js/wiki/v5-Creating-Filters
*/

const app = new PIXI.Application({ resizeTo: window });

document.body.appendChild(app.view);

// Create background image
const background = PIXI.Sprite.from('https://pixijs.com/assets/bg_grass.jpg');

background.width = app.screen.width;
background.height = app.screen.height;
app.stage.addChild(background);

// NOTE: this shader wont work on old devices where mediump precision is forced in fragment shader
// because v5 default vertex shader uses `inputSize` in it. Same uniform in fragment and vertex shader
// cant have different precision :(

const shaderFrag = `
precision highp float;

varying vec2 vTextureCoord;

uniform vec2 mouse;
uniform vec4 inputSize;
uniform vec4 outputFrame;
uniform float time;

void main() {
vec2 screenPos = vTextureCoord * inputSize.xy + outputFrame.xy;
if (length(mouse - screenPos) < 25.0) {
gl_FragColor = vec4(1.0, 1.0, 0.0, 1.0) * 0.7; //yellow circle, alpha=0.7
} else {
// blend with underlying image, alpha=0.5
gl_FragColor = vec4( sin(time), (mouse.xy - outputFrame.xy) / outputFrame.zw, 1.0) * 0.5;
}
}
`;

const container = new PIXI.Container();

container.filterArea = new PIXI.Rectangle(100, 100, app.screen.width - 200, app.screen.height - 200);
app.stage.addChild(container);
const filter = new PIXI.Filter(null, shaderFrag, {
mouse: new PIXI.Point(),
});

container.filters = [filter];

app.stage.hitArea = app.screen;
app.stage.eventMode = 'static';
app.stage.on('pointermove', (event) =>
{
filter.uniforms.mouse.copyFrom(event.global);
});
- + \ No newline at end of file diff --git a/examples/filters-advanced/shader-toy-filter-render-texture.html b/examples/filters-advanced/shader-toy-filter-render-texture.html index 2ff68571d..7201dd676 100644 --- a/examples/filters-advanced/shader-toy-filter-render-texture.html +++ b/examples/filters-advanced/shader-toy-filter-render-texture.html @@ -9,13 +9,13 @@ - +
Skip to main content

Shader Toy Filter Render Texture

import * as PIXI from 'pixi.js';

/**
* Please note that this is not the most optimal way of doing pure shader generated rendering and should be used when the
* scene is wanted as input texture. Check the mesh version of example for more performant version if you need only shader
* generated content.
**/
const app = new PIXI.Application({ background: '#1099bb', resizeTo: window });

document.body.appendChild(app.view);

PIXI.Assets.load('https://pixijs.com/assets/perlin.jpg').then(onAssetsLoaded);

let filter = null;

const text = new PIXI.Text('PixiJS', { fill: 0xFFFFFF, fontSize: 80 });

text.anchor.set(0.5, 0.5);
text.position.set(app.renderer.screen.width / 2, app.renderer.screen.height / 2);

app.stage.addChild(text);

let totalTime = 0;

// Fragment shader, in real use this would be much cleaner when loaded from a file
// or embedded into the application as data resource.
const fragment = `//Based on this: https://www.shadertoy.com/view/wtlSWX

varying vec2 vTextureCoord;
uniform sampler2D uSampler;
uniform sampler2D noise;
uniform float time;
// Distance function. Just calculates the height (z) from x,y plane with really simple length check.
// Its not exact as there could be shorter distances.
vec2 dist(vec3 p)
{
float id = floor(p.x)+floor(p.y);
id = mod(id, 2.);
float h = texture2D(noise, vec2(p.x, p.y)*0.04).r*5.1;
float h2 = texture2D(uSampler, vTextureCoord).r;
return vec2(h+h2-p.z,id);
}
//Light calculation.
vec3 calclight(vec3 p, vec3 rd)
{
vec2 eps = vec2( 0., 0.001);
vec3 n = normalize( vec3(
dist(p+eps.yxx).x - dist(p-eps.yxx).x,
dist(p+eps.xyx).x - dist(p-eps.xyx).x,
dist(p+eps.xxy).x - dist(p-eps.xxy).x
));

vec3 d = vec3( max( 0., dot( -rd ,n)));

return d;
}

void main()
{
vec2 uv = vec2(vTextureCoord.x, 1.-vTextureCoord.y);
uv *=2.;
uv-=1.;

vec3 cam = vec3(0.,time -2., -3.);
vec3 target = vec3(sin(time)*0.1, time+cos(time)+2., 0. );
float fov = 2.2;
vec3 forward = normalize( target - cam);
vec3 up = normalize(cross( forward, vec3(0., 1.,0.)));
vec3 right = normalize( cross( up, forward));
vec3 raydir = normalize(vec3( uv.x *up + uv.y * right + fov*forward));

//Do the raymarch
vec3 col = vec3(0.);
float t = 0.;
for( int i = 0; i < 100; i++)
{
vec3 p = t * raydir + cam;
vec2 d = dist(p);
t+=d.x*0.5;//Jump only half of the distance as height function used is not really the best for heightmaps.
if(d.x < 0.001)
{
vec3 bc = d.y < 0.5 ? vec3(1.0, .8, 0.) :
vec3(0.8,0.0, 1.0);
col = vec3( 1.) * calclight(p, raydir) * (1. - t/150.) *bc;
break;
}
if(t > 1000.)
{
break;
}
}
gl_FragColor = vec4(col, 1.);
}
`;

function onAssetsLoaded(perlin)
{
// Add perlin noise for filter, make sure it's wrapping and does not have mipmap.
perlin.baseTexture.wrapMode = PIXI.WRAP_MODES.REPEAT;
perlin.baseTexture.mipmap = false;

// Build the filter
filter = new PIXI.Filter(null, fragment, {
time: 0.0,
noise: perlin,
});
app.stage.filterArea = app.renderer.screen;
app.stage.filters = [filter];

// Listen for animate update.
app.ticker.add((delta) =>
{
filter.uniforms.time = totalTime;
totalTime += delta / 60;
});
}
- + \ No newline at end of file diff --git a/examples/filters-basic/blur.html b/examples/filters-basic/blur.html index ef55c8bbb..926a68ad6 100644 --- a/examples/filters-basic/blur.html +++ b/examples/filters-basic/blur.html @@ -9,13 +9,13 @@ - +
Skip to main content

Blur

import * as PIXI from 'pixi.js';

const app = new PIXI.Application({ resizeTo: window });

document.body.appendChild(app.view);

const bg = PIXI.Sprite.from('https://pixijs.com/assets/pixi-filters/bg_depth_blur.jpg');

bg.width = app.screen.width;
bg.height = app.screen.height;
app.stage.addChild(bg);

const littleDudes = PIXI.Sprite.from('https://pixijs.com/assets/pixi-filters/depth_blur_dudes.jpg');

littleDudes.x = (app.screen.width / 2) - 315;
littleDudes.y = 200;
app.stage.addChild(littleDudes);

const littleRobot = PIXI.Sprite.from('https://pixijs.com/assets/pixi-filters/depth_blur_moby.jpg');

littleRobot.x = (app.screen.width / 2) - 200;
littleRobot.y = 100;
app.stage.addChild(littleRobot);

const blurFilter1 = new PIXI.filters.BlurFilter();
const blurFilter2 = new PIXI.filters.BlurFilter();

littleDudes.filters = [blurFilter1];
littleRobot.filters = [blurFilter2];

let count = 0;

app.ticker.add(() =>
{
count += 0.005;

const blurAmount = Math.cos(count);
const blurAmount2 = Math.sin(count);

blurFilter1.blur = 20 * (blurAmount);
blurFilter2.blur = 20 * (blurAmount2);
});
- + \ No newline at end of file diff --git a/examples/filters-basic/color-matrix.html b/examples/filters-basic/color-matrix.html index 1cb9bcbc1..f63b72714 100644 --- a/examples/filters-basic/color-matrix.html +++ b/examples/filters-basic/color-matrix.html @@ -9,13 +9,13 @@ - +
Skip to main content

Color Matrix

import * as PIXI from 'pixi.js';

const app = new PIXI.Application({ resizeTo: window });

document.body.appendChild(app.view);

app.stage.eventMode = 'static';

const bg = PIXI.Sprite.from('https://pixijs.com/assets/bg_rotate.jpg');

bg.anchor.set(0.5);

bg.x = app.screen.width / 2;
bg.y = app.screen.height / 2;

const filter = new PIXI.filters.ColorMatrixFilter();

const container = new PIXI.Container();

container.x = app.screen.width / 2;
container.y = app.screen.height / 2;

const bgFront = PIXI.Sprite.from('https://pixijs.com/assets/bg_scene_rotate.jpg');

bgFront.anchor.set(0.5);

container.addChild(bgFront);

const light2 = PIXI.Sprite.from('https://pixijs.com/assets/light_rotate_2.png');

light2.anchor.set(0.5);
container.addChild(light2);

const light1 = PIXI.Sprite.from('https://pixijs.com/assets/light_rotate_1.png');

light1.anchor.set(0.5);
container.addChild(light1);

const panda = PIXI.Sprite.from('https://pixijs.com/assets/panda.png');

panda.anchor.set(0.5);

container.addChild(panda);

app.stage.addChild(container);

app.stage.filters = [filter];

let count = 0;
let enabled = true;

app.stage.on('pointertap', () =>
{
enabled = !enabled;
app.stage.filters = enabled ? [filter] : null;
});

const help = new PIXI.Text('Click or tap to turn filters on / off.', {
fontFamily: 'Arial',
fontSize: 12,
fontWeight: 'bold',
fill: 'white',
});

help.y = app.screen.height - 25;
help.x = 10;

app.stage.addChild(help);

app.ticker.add((delta) =>
{
bg.rotation += 0.01;
bgFront.rotation -= 0.01;
light1.rotation += 0.02;
light2.rotation += 0.01;

panda.scale.x = 1 + Math.sin(count) * 0.04;
panda.scale.y = 1 + Math.cos(count) * 0.04;

count += 0.1;

const { matrix } = filter;

matrix[1] = Math.sin(count) * 3;
matrix[2] = Math.cos(count);
matrix[3] = Math.cos(count) * 1.5;
matrix[4] = Math.sin(count / 3) * 2;
matrix[5] = Math.sin(count / 2);
matrix[6] = Math.sin(count / 4);
});
- + \ No newline at end of file diff --git a/examples/filters-basic/displacement-map-crawlies.html b/examples/filters-basic/displacement-map-crawlies.html index 9ef75e1b9..275728ae2 100644 --- a/examples/filters-basic/displacement-map-crawlies.html +++ b/examples/filters-basic/displacement-map-crawlies.html @@ -9,13 +9,13 @@ - +
Skip to main content

Displacement Map Crawlies

import * as PIXI from 'pixi.js';

const app = new PIXI.Application({ resizeTo: window });

document.body.appendChild(app.view);

app.stage.eventMode = 'static';

const container = new PIXI.Container();

app.stage.addChild(container);

const padding = 100;
const bounds = new PIXI.Rectangle(
-padding,
-padding,
app.screen.width + padding * 2,
app.screen.height + padding * 2,
);
const maggots = [];

for (let i = 0; i < 20; i++)
{
const maggot = PIXI.Sprite.from('https://pixijs.com/assets/maggot.png');

maggot.anchor.set(0.5);
container.addChild(maggot);

maggot.direction = Math.random() * Math.PI * 2;
maggot.speed = 1;
maggot.turnSpeed = Math.random() - 0.8;

maggot.x = Math.random() * bounds.width;
maggot.y = Math.random() * bounds.height;

maggot.scale.set(1 + Math.random() * 0.3);
maggot.original = new PIXI.Point();
maggot.original.copyFrom(maggot.scale);
maggots.push(maggot);
}

const displacementSprite = PIXI.Sprite.from('https://pixijs.com/assets/pixi-filters/displace.png');
const displacementFilter = new PIXI.filters.DisplacementFilter(displacementSprite);

app.stage.addChild(displacementSprite);

container.filters = [displacementFilter];

displacementFilter.scale.x = 110;
displacementFilter.scale.y = 110;
displacementSprite.anchor.set(0.5);

const ring = PIXI.Sprite.from('https://pixijs.com/assets/pixi-filters/ring.png');

ring.anchor.set(0.5);

ring.visible = false;

app.stage.addChild(ring);

const bg = PIXI.Sprite.from('https://pixijs.com/assets/bg_grass.jpg');

bg.width = app.screen.width;
bg.height = app.screen.height;

bg.alpha = 0.4;

container.addChild(bg);

app.stage
.on('mousemove', onPointerMove)
.on('touchmove', onPointerMove);

function onPointerMove(eventData)
{
ring.visible = true;

displacementSprite.position.set(eventData.data.global.x - 25, eventData.data.global.y);
ring.position.copyFrom(displacementSprite.position);
}

let count = 0;

app.ticker.add(() =>
{
count += 0.05;

for (let i = 0; i < maggots.length; i++)
{
const maggot = maggots[i];

maggot.direction += maggot.turnSpeed * 0.01;
maggot.x += Math.sin(maggot.direction) * maggot.speed;
maggot.y += Math.cos(maggot.direction) * maggot.speed;

maggot.rotation = -maggot.direction - Math.PI / 2;
maggot.scale.x = maggot.original.x + Math.sin(count) * 0.2;

// wrap the maggots around as the crawl
if (maggot.x < bounds.x)
{
maggot.x += bounds.width;
}
else if (maggot.x > bounds.x + bounds.width)
{
maggot.x -= bounds.width;
}

if (maggot.y < bounds.y)
{
maggot.y += bounds.height;
}
else if (maggot.y > bounds.y + bounds.height)
{
maggot.y -= bounds.height;
}
}
});
- + \ No newline at end of file diff --git a/examples/filters-basic/displacement-map-flag.html b/examples/filters-basic/displacement-map-flag.html index f17cac7c8..b04fd19e4 100644 --- a/examples/filters-basic/displacement-map-flag.html +++ b/examples/filters-basic/displacement-map-flag.html @@ -9,13 +9,13 @@ - +
Skip to main content

Displacement Map Flag

import * as PIXI from 'pixi.js';

const app = new PIXI.Application({ resizeTo: window });

document.body.appendChild(app.view);

app.stage.eventMode = 'static';

const container = new PIXI.Container();

app.stage.addChild(container);

const flag = PIXI.Sprite.from('https://pixijs.com/assets/pixi-filters/flag.png');

container.addChild(flag);
flag.x = 100;
flag.y = 100;

const displacementSprite = PIXI.Sprite.from('https://pixijs.com/assets/pixi-filters/displacement_map_repeat.jpg');
// Make sure the sprite is wrapping.

displacementSprite.texture.baseTexture.wrapMode = PIXI.WRAP_MODES.REPEAT;
const displacementFilter = new PIXI.filters.DisplacementFilter(displacementSprite);

displacementFilter.padding = 10;

displacementSprite.position = flag.position;

app.stage.addChild(displacementSprite);

flag.filters = [displacementFilter];

displacementFilter.scale.x = 30;
displacementFilter.scale.y = 60;

app.ticker.add(() =>
{
// Offset the sprite position to make vFilterCoord update to larger value.
// Repeat wrapping makes sure there's still pixels on the coordinates.
displacementSprite.x++;
// Reset x to 0 when it's over width to keep values from going to very huge numbers.
if (displacementSprite.x > displacementSprite.width) { displacementSprite.x = 0; }
});
- + \ No newline at end of file diff --git a/examples/graphics/advanced.html b/examples/graphics/advanced.html index 7216494ea..da0e11637 100644 --- a/examples/graphics/advanced.html +++ b/examples/graphics/advanced.html @@ -9,13 +9,13 @@ - +
Skip to main content

Advanced

import * as PIXI from 'pixi.js';

const app = new PIXI.Application({ antialias: true, resizeTo: window });

document.body.appendChild(app.view);

const sprite = PIXI.Sprite.from('https://pixijs.com/assets/bg_rotate.jpg');

// // BEZIER CURVE ////
// information: https://en.wikipedia.org/wiki/BΓ©zier_curve

const realPath = new PIXI.Graphics();

realPath.lineStyle(2, 0xFFFFFF, 1);
realPath.moveTo(0, 0);
realPath.lineTo(100, 200);
realPath.lineTo(200, 200);
realPath.lineTo(240, 100);

realPath.position.x = 50;
realPath.position.y = 50;

app.stage.addChild(realPath);

const bezier = new PIXI.Graphics();

bezier.lineStyle(5, 0xAA0000, 1);
bezier.bezierCurveTo(100, 200, 200, 200, 240, 100);

bezier.position.x = 50;
bezier.position.y = 50;

app.stage.addChild(bezier);

// // BEZIER CURVE 2 ////
const realPath2 = new PIXI.Graphics();

realPath2.lineStyle(2, 0xFFFFFF, 1);
realPath2.moveTo(0, 0);
realPath2.lineTo(0, -100);
realPath2.lineTo(150, 150);
realPath2.lineTo(240, 100);

realPath2.position.x = 320;
realPath2.position.y = 150;

app.stage.addChild(realPath2);

const bezier2 = new PIXI.Graphics();

bezier2.lineTextureStyle({ width: 10, texture: sprite.texture });
bezier2.bezierCurveTo(0, -100, 150, 150, 240, 100);

bezier2.position.x = 320;
bezier2.position.y = 150;

app.stage.addChild(bezier2);

// // ARC ////
const arc = new PIXI.Graphics();

arc.lineStyle(5, 0xAA00BB, 1);
arc.arc(600, 100, 50, Math.PI, 2 * Math.PI);

app.stage.addChild(arc);

// // ARC 2 ////
const arc2 = new PIXI.Graphics();

arc2.lineStyle(6, 0x3333DD, 1);
arc2.arc(650, 270, 60, 2 * Math.PI, 3 * Math.PI / 2);

app.stage.addChild(arc2);

// // ARC 3 ////
const arc3 = new PIXI.Graphics();

arc3.lineTextureStyle({ width: 20, texture: sprite.texture });
arc3.arc(650, 420, 60, 2 * Math.PI, 2.5 * Math.PI / 2);

app.stage.addChild(arc3);

// / Hole ////
const rectAndHole = new PIXI.Graphics();

rectAndHole.beginFill(0x00FF00);
rectAndHole.drawRect(350, 350, 150, 150);
rectAndHole.beginHole();
rectAndHole.drawCircle(375, 375, 25);
rectAndHole.drawCircle(425, 425, 25);
rectAndHole.drawCircle(475, 475, 25);
rectAndHole.endHole();
rectAndHole.endFill();

app.stage.addChild(rectAndHole);

// // Line Texture Style ////
const beatifulRect = new PIXI.Graphics();

beatifulRect.lineTextureStyle({ width: 20, texture: sprite.texture });
beatifulRect.beginFill(0xFF0000);
beatifulRect.drawRect(80, 350, 150, 150);
beatifulRect.endFill();

app.stage.addChild(beatifulRect);
- + \ No newline at end of file diff --git a/examples/graphics/dynamic.html b/examples/graphics/dynamic.html index 654ebdb6d..329c1f81d 100644 --- a/examples/graphics/dynamic.html +++ b/examples/graphics/dynamic.html @@ -9,13 +9,13 @@ - +
Skip to main content

Dynamic

import * as PIXI from 'pixi.js';

const app = new PIXI.Application({ antialias: true, resizeTo: window });

document.body.appendChild(app.view);

app.stage.eventMode = 'static';
app.stage.hitArea = app.screen;

const graphics = new PIXI.Graphics();

// set a fill and line style
graphics.beginFill(0xFF3300);
graphics.lineStyle(10, 0xffd900, 1);

// draw a shape
graphics.moveTo(50, 50);
graphics.lineTo(250, 50);
graphics.lineTo(100, 100);
graphics.lineTo(250, 220);
graphics.lineTo(50, 220);
graphics.lineTo(50, 50);
graphics.closePath();
graphics.endFill();

// set a fill and line style again
graphics.lineStyle(10, 0xFF0000, 0.8);
graphics.beginFill(0xFF700B, 1);

// draw a second shape
graphics.moveTo(210, 300);
graphics.lineTo(450, 320);
graphics.lineTo(570, 350);
graphics.quadraticCurveTo(600, 0, 480, 100);
graphics.lineTo(330, 120);
graphics.lineTo(410, 200);
graphics.lineTo(210, 300);
graphics.closePath();
graphics.endFill();

// draw a rectangle
graphics.lineStyle(2, 0x0000FF, 1);
graphics.drawRect(50, 250, 100, 100);

// draw a circle
graphics.lineStyle(0);
graphics.beginFill(0xFFFF0B, 0.5);
graphics.drawCircle(470, 200, 100);
graphics.endFill();

graphics.lineStyle(20, 0x33FF00);
graphics.moveTo(30, 30);
graphics.lineTo(600, 300);

app.stage.addChild(graphics);

// let's create a moving shape
const thing = new PIXI.Graphics();

app.stage.addChild(thing);
thing.x = 800 / 2;
thing.y = 600 / 2;

let count = 0;

// Just click on the stage to draw random lines
window.app = app;
app.stage.on('pointerdown', () =>
{
graphics.lineStyle(Math.random() * 30, Math.random() * 0xFFFFFF, 1);
graphics.moveTo(Math.random() * 800, Math.random() * 600);
graphics.bezierCurveTo(
Math.random() * 800, Math.random() * 600,
Math.random() * 800, Math.random() * 600,
Math.random() * 800, Math.random() * 600,
);
});

app.ticker.add(() =>
{
count += 0.1;

thing.clear();
thing.lineStyle(10, 0xff0000, 1);
thing.beginFill(0xffFF00, 0.5);

thing.moveTo(-120 + Math.sin(count) * 20, -100 + Math.cos(count) * 20);
thing.lineTo(120 + Math.cos(count) * 20, -100 + Math.sin(count) * 20);
thing.lineTo(120 + Math.sin(count) * 20, 100 + Math.cos(count) * 20);
thing.lineTo(-120 + Math.cos(count) * 20, 100 + Math.sin(count) * 20);
thing.lineTo(-120 + Math.sin(count) * 20, -100 + Math.cos(count) * 20);
thing.closePath();

thing.rotation = count * 0.1;
});
- + \ No newline at end of file diff --git a/examples/graphics/simple.html b/examples/graphics/simple.html index fa1cf4a5c..686b930b7 100644 --- a/examples/graphics/simple.html +++ b/examples/graphics/simple.html @@ -9,13 +9,13 @@ - +
Skip to main content

Simple

import * as PIXI from 'pixi.js';
import '@pixi/graphics-extras';

const app = new PIXI.Application({ antialias: true, resizeTo: window });

document.body.appendChild(app.view);

const graphics = new PIXI.Graphics();

// Rectangle
graphics.beginFill(0xDE3249);
graphics.drawRect(50, 50, 100, 100);
graphics.endFill();

// Rectangle + line style 1
graphics.lineStyle(2, 0xFEEB77, 1);
graphics.beginFill(0x650A5A);
graphics.drawRect(200, 50, 100, 100);
graphics.endFill();

// Rectangle + line style 2
graphics.lineStyle(10, 0xFFBD01, 1);
graphics.beginFill(0xC34288);
graphics.drawRect(350, 50, 100, 100);
graphics.endFill();

// Rectangle 2
graphics.lineStyle(2, 0xFFFFFF, 1);
graphics.beginFill(0xAA4F08);
graphics.drawRect(530, 50, 140, 100);
graphics.endFill();

// Circle
graphics.lineStyle(0); // draw a circle, set the lineStyle to zero so the circle doesn't have an outline
graphics.beginFill(0xDE3249, 1);
graphics.drawCircle(100, 250, 50);
graphics.endFill();

// Circle + line style 1
graphics.lineStyle(2, 0xFEEB77, 1);
graphics.beginFill(0x650A5A, 1);
graphics.drawCircle(250, 250, 50);
graphics.endFill();

// Circle + line style 2
graphics.lineStyle(10, 0xFFBD01, 1);
graphics.beginFill(0xC34288, 1);
graphics.drawCircle(400, 250, 50);
graphics.endFill();

// Ellipse + line style 2
graphics.lineStyle(2, 0xFFFFFF, 1);
graphics.beginFill(0xAA4F08, 1);
graphics.drawEllipse(600, 250, 80, 50);
graphics.endFill();

// draw a shape
graphics.beginFill(0xFF3300);
graphics.lineStyle(4, 0xffd900, 1);
graphics.moveTo(50, 350);
graphics.lineTo(250, 350);
graphics.lineTo(100, 400);
graphics.lineTo(50, 350);
graphics.closePath();
graphics.endFill();

// draw a rounded rectangle
graphics.lineStyle(2, 0xFF00FF, 1);
graphics.beginFill(0x650A5A, 0.25);
graphics.drawRoundedRect(50, 440, 100, 100, 16);
graphics.endFill();

// draw star
graphics.lineStyle(2, 0xFFFFFF);
graphics.beginFill(0x35CC5A, 1);
graphics.drawStar(360, 370, 5, 50);
graphics.endFill();

// draw star 2
graphics.lineStyle(2, 0xFFFFFF);
graphics.beginFill(0xFFCC5A, 1);
graphics.drawStar(280, 510, 7, 50);
graphics.endFill();

// draw star 3
graphics.lineStyle(4, 0xFFFFFF);
graphics.beginFill(0x55335A, 1);
graphics.drawStar(470, 450, 4, 50);
graphics.endFill();

// draw polygon
const path = [600, 370, 700, 460, 780, 420, 730, 570, 590, 520];

graphics.lineStyle(0);
graphics.beginFill(0x3500FA, 1);
graphics.drawPolygon(path);
graphics.endFill();

app.stage.addChild(graphics);
- + \ No newline at end of file diff --git a/examples/masks/filter.html b/examples/masks/filter.html index 47ebe1863..698b1f74a 100644 --- a/examples/masks/filter.html +++ b/examples/masks/filter.html @@ -9,13 +9,13 @@ - +
Skip to main content

Filter

import * as PIXI from 'pixi.js';

const app = new PIXI.Application({ resizeTo: window });

document.body.appendChild(app.view);

// Inner radius of the circle
const radius = 100;

// The blur amount
const blurSize = 32;

PIXI.Assets.load('https://pixijs.com/assets/bg_grass.jpg').then((grassTexture) =>
{
const background = new PIXI.Sprite(grassTexture);

app.stage.addChild(background);
background.width = app.screen.width;
background.height = app.screen.height;

const circle = new PIXI.Graphics()
.beginFill(0xFF0000)
.drawCircle(radius + blurSize, radius + blurSize, radius)
.endFill();

circle.filters = [new PIXI.filters.BlurFilter(blurSize)];

const bounds = new PIXI.Rectangle(0, 0, (radius + blurSize) * 2, (radius + blurSize) * 2);
const texture = app.renderer.generateTexture(circle, PIXI.SCALE_MODES.NEAREST, 1, bounds);
const focus = new PIXI.Sprite(texture);

app.stage.addChild(focus);
background.mask = focus;

app.stage.eventMode = 'static';
app.stage.hitArea = app.screen;
app.stage.on('pointermove', (event) =>
{
focus.position.x = event.global.x - focus.width / 2;
focus.position.y = event.global.y - focus.height / 2;
});
});
- + \ No newline at end of file diff --git a/examples/masks/graphics.html b/examples/masks/graphics.html index f69566f12..3c1e57ecf 100644 --- a/examples/masks/graphics.html +++ b/examples/masks/graphics.html @@ -9,13 +9,13 @@ - +
Skip to main content

Graphics

import * as PIXI from 'pixi.js';

const app = new PIXI.Application({ antialias: true, resizeTo: window });

document.body.appendChild(app.view);

app.stage.eventMode = 'static';

const bg = PIXI.Sprite.from('https://pixijs.com/assets/bg_rotate.jpg');

bg.anchor.set(0.5);

bg.x = app.screen.width / 2;
bg.y = app.screen.height / 2;

app.stage.addChild(bg);

const container = new PIXI.Container();

container.x = app.screen.width / 2;
container.y = app.screen.height / 2;

// add a bunch of sprites
const bgFront = PIXI.Sprite.from('https://pixijs.com/assets/bg_scene_rotate.jpg');

bgFront.anchor.set(0.5);

const light2 = PIXI.Sprite.from('https://pixijs.com/assets/light_rotate_2.png');

light2.anchor.set(0.5);

const light1 = PIXI.Sprite.from('https://pixijs.com/assets/light_rotate_1.png');

light1.anchor.set(0.5);

const panda = PIXI.Sprite.from('https://pixijs.com/assets/panda.png');

panda.anchor.set(0.5);

container.addChild(bgFront, light2, light1, panda);

app.stage.addChild(container);

// let's create a moving shape
const thing = new PIXI.Graphics();

app.stage.addChild(thing);
thing.x = app.screen.width / 2;
thing.y = app.screen.height / 2;
thing.lineStyle(0);

container.mask = thing;

let count = 0;

app.stage.on('pointertap', () =>
{
if (!container.mask)
{
container.mask = thing;
}
else
{
container.mask = null;
}
});

const help = new PIXI.Text('Click or tap to turn masking on / off.', {
fontFamily: 'Arial',
fontSize: 12,
fontWeight: 'bold',
fill: 'white',
});

help.y = app.screen.height - 26;
help.x = 10;
app.stage.addChild(help);

app.ticker.add(() =>
{
bg.rotation += 0.01;
bgFront.rotation -= 0.01;

light1.rotation += 0.02;
light2.rotation += 0.01;

panda.scale.x = 1 + Math.sin(count) * 0.04;
panda.scale.y = 1 + Math.cos(count) * 0.04;

count += 0.1;

thing.clear();

thing.beginFill(0x8bc5ff, 0.4);
thing.moveTo(-120 + Math.sin(count) * 20, -100 + Math.cos(count) * 20);
thing.lineTo(120 + Math.cos(count) * 20, -100 + Math.sin(count) * 20);
thing.lineTo(120 + Math.sin(count) * 20, 100 + Math.cos(count) * 20);
thing.lineTo(-120 + Math.cos(count) * 20, 100 + Math.sin(count) * 20);
thing.rotation = count * 0.1;
});
- + \ No newline at end of file diff --git a/examples/masks/sprite.html b/examples/masks/sprite.html index 53e17cea4..8939ff256 100644 --- a/examples/masks/sprite.html +++ b/examples/masks/sprite.html @@ -9,13 +9,13 @@ - +
Skip to main content

Sprite

import * as PIXI from 'pixi.js';

const app = new PIXI.Application({ resizeTo: window });

document.body.appendChild(app.view);

app.stage.eventMode = 'static';

const bg = PIXI.Sprite.from('https://pixijs.com/assets/bg_plane.jpg');

app.stage.addChild(bg);

const cells = PIXI.Sprite.from('https://pixijs.com/assets/cells.png');

cells.scale.set(1.5);

const mask = PIXI.Sprite.from('https://pixijs.com/assets/flowerTop.png');

mask.anchor.set(0.5);
mask.x = 310;
mask.y = 190;

cells.mask = mask;

app.stage.addChild(mask, cells);

const target = new PIXI.Point();

reset();

function reset()
{
target.x = Math.floor(Math.random() * 550);
target.y = Math.floor(Math.random() * 300);
}

app.ticker.add(() =>
{
mask.x += (target.x - mask.x) * 0.1;
mask.y += (target.y - mask.y) * 0.1;

if (Math.abs(mask.x - target.x) < 1)
{
reset();
}
});
- + \ No newline at end of file diff --git a/examples/mesh-and-shaders/instanced-geometry.html b/examples/mesh-and-shaders/instanced-geometry.html index 94b993f17..619b4d46f 100644 --- a/examples/mesh-and-shaders/instanced-geometry.html +++ b/examples/mesh-and-shaders/instanced-geometry.html @@ -9,13 +9,13 @@ - +
Skip to main content

Instanced Geometry

import * as PIXI from 'pixi.js';

const app = new PIXI.Application({ resizeTo: window });

document.body.appendChild(app.view);

const geometry = new PIXI.Geometry()
.addAttribute('aVPos', [-100, 0, 100, 0, 0, -150]);

geometry.instanced = true;
geometry.instanceCount = 5;

const positionSize = 2;
const colorSize = 3;
const buffer = new PIXI.Buffer(new Float32Array(geometry.instanceCount * (positionSize + colorSize)));

geometry.addAttribute(
'aIPos',
buffer,
positionSize,
false,
PIXI.TYPES.FLOAT,
4 * (positionSize + colorSize),
0,
true
);
geometry.addAttribute(
'aICol',
buffer,
colorSize,
false,
PIXI.TYPES.FLOAT,
4 * (positionSize + colorSize),
4 * positionSize, true
);

for (let i = 0; i < geometry.instanceCount; i++)
{
const instanceOffset = i * (positionSize + colorSize);

buffer.data[instanceOffset + 0] = i * 80;
buffer.data[instanceOffset + 2] = Math.random();
buffer.data[instanceOffset + 3] = Math.random();
buffer.data[instanceOffset + 4] = Math.random();
}

const shader = PIXI.Shader.from(`
precision mediump float;
attribute vec2 aVPos;
attribute vec2 aIPos;
attribute vec3 aICol;

uniform mat3 translationMatrix;
uniform mat3 projectionMatrix;

varying vec3 vCol;

void main() {
vCol = aICol;

gl_Position = vec4((projectionMatrix * translationMatrix * vec3(aVPos + aIPos, 1.0)).xy, 0.0, 1.0);
}`,

`precision mediump float;

varying vec3 vCol;

void main() {
gl_FragColor = vec4(vCol, 1.0);
}

`);

const triangles = new PIXI.Mesh(geometry, shader);

triangles.position.set(400, 300);

app.stage.addChild(triangles);

app.ticker.add((delta) =>
{
triangles.rotation += 0.01;
});
- + \ No newline at end of file diff --git a/examples/mesh-and-shaders/interleaving-geometry.html b/examples/mesh-and-shaders/interleaving-geometry.html index 3f663bf3e..02ae1b4c0 100644 --- a/examples/mesh-and-shaders/interleaving-geometry.html +++ b/examples/mesh-and-shaders/interleaving-geometry.html @@ -9,13 +9,13 @@ - +
Skip to main content

Interleaving Geometry

import * as PIXI from 'pixi.js';

const app = new PIXI.Application({ resizeTo: window });

document.body.appendChild(app.view);

const geometry = new PIXI.Geometry()
.addAttribute('aVertexPosition', // the attribute name
[-100, -100, // x, y
100, -100, // x, y
100, 100,
-100, 100], // x, y
2) // the size of the attribute
.addAttribute('aUvs', // the attribute name
[0, 0, // u, v
1, 0, // u, v
1, 1,
0, 1], // u, v
2) // the size of the attribute
.addIndex([0, 1, 2, 0, 2, 3])
.interleave();

const shader = PIXI.Shader.from(`

precision mediump float;

attribute vec2 aVertexPosition;
attribute vec2 aUvs;

uniform mat3 translationMatrix;
uniform mat3 projectionMatrix;

varying vec2 vUvs;

void main() {

vUvs = aUvs;
gl_Position = vec4((projectionMatrix * translationMatrix * vec3(aVertexPosition, 1.0)).xy, 0.0, 1.0);

}`,

`precision mediump float;

varying vec2 vUvs;

uniform sampler2D uSampler2;

void main() {

gl_FragColor = texture2D(uSampler2, vUvs );
}

`,
{
uSampler2: PIXI.Texture.from('https://pixijs.com/assets/bg_scene_rotate.jpg'),
});

const quad = new PIXI.Mesh(geometry, shader);

quad.position.set(400, 300);
quad.scale.set(2);

app.stage.addChild(quad);

app.ticker.add((delta) =>
{
quad.rotation += 0.01;
});
- + \ No newline at end of file diff --git a/examples/mesh-and-shaders/merging-geometry.html b/examples/mesh-and-shaders/merging-geometry.html index c05f87345..59c51a4b2 100644 --- a/examples/mesh-and-shaders/merging-geometry.html +++ b/examples/mesh-and-shaders/merging-geometry.html @@ -9,13 +9,13 @@ - +
Skip to main content

Merging Geometry

import * as PIXI from 'pixi.js';

const app = new PIXI.Application({ resizeTo: window });

document.body.appendChild(app.view);

const geometry = new PIXI.Geometry()
.addAttribute('aVertexPosition', // the attribute name
[-100, -100, // x, y
100, -100, // x, y
100, 100,
-100, 100], // x, y
2) // the size of the attribute
.addAttribute('aUvs', // the attribute name
[0, 0, // u, v
1, 0, // u, v
1, 1,
0, 1], // u, v
2) // the size of the attribute
.addIndex([0, 1, 2, 0, 2, 3]);

const geometry2 = new PIXI.Geometry()
.addAttribute('aVertexPosition', // the attribute name
[-100 + 100, -100, // x, y
100 + 100, -100, // x, y
100 + 100, 100], // x, y
2) // the size of the attribute
.addAttribute('aUvs', // the attribute name
[0, 0, // u, v
1, 0, // u, v
1, 1], // u, v
2) // the size of the attribute
.addIndex([0, 1, 2]);

const geometry3 = PIXI.Geometry.merge([geometry, geometry2]);

const shader = PIXI.Shader.from(`

precision mediump float;

attribute vec2 aVertexPosition;
attribute vec2 aUvs;

uniform mat3 translationMatrix;
uniform mat3 projectionMatrix;

varying vec2 vUvs;

void main() {

vUvs = aUvs;
gl_Position = vec4((projectionMatrix * translationMatrix * vec3(aVertexPosition, 1.0)).xy, 0.0, 1.0);

}`,

`precision mediump float;

varying vec2 vUvs;

uniform sampler2D uSampler2;

void main() {

gl_FragColor = texture2D(uSampler2, vUvs );
}

`,
{
uSampler2: PIXI.Texture.from('https://pixijs.com/assets/bg_scene_rotate.jpg'),
});

const quad = new PIXI.Mesh(geometry3, shader);

quad.position.set(400, 300);
quad.scale.set(2);

app.stage.addChild(quad);

app.ticker.add((delta) =>
{
quad.rotation += 0.01;
});
- + \ No newline at end of file diff --git a/examples/mesh-and-shaders/multi-pass-shader-generated-mesh.html b/examples/mesh-and-shaders/multi-pass-shader-generated-mesh.html index e922df617..ccb91a45f 100644 --- a/examples/mesh-and-shaders/multi-pass-shader-generated-mesh.html +++ b/examples/mesh-and-shaders/multi-pass-shader-generated-mesh.html @@ -9,13 +9,13 @@ - +
Skip to main content

Multi Pass Shader Generated Mesh

import * as PIXI from 'pixi.js';

const app = new PIXI.Application({ height: 640, resizeTo: window });

document.body.appendChild(app.view);

// Build geometry.
const geometry = new PIXI.Geometry()
.addAttribute('aVertexPosition', // the attribute name
[0, 0, // x, y
200, 0, // x, y
200, 200,
0, 200], // x, y
2) // the size of the attribute
.addAttribute('aUvs', // the attribute name
[0, 0, // u, v
1, 0, // u, v
1, 1,
0, 1], // u, v
2) // the size of the attribute
.addIndex([0, 1, 2, 0, 2, 3]);

// Vertex shader. Use same shader for all passes.
const vertexSrc = `

precision mediump float;

attribute vec2 aVertexPosition;
attribute vec2 aUvs;

uniform mat3 translationMatrix;
uniform mat3 projectionMatrix;

varying vec2 vUvs;

void main() {

vUvs = aUvs;
gl_Position = vec4((projectionMatrix * translationMatrix * vec3(aVertexPosition, 1.0)).xy, 0.0, 1.0);

}`;

// Load a perlinnoise texture for one of the shaders.
const perlinTexture = PIXI.Texture.from('https://pixijs.com/assets/perlin.jpg');

// First pass, generates a grid.
const fragmentGridSrc = `
precision mediump float;
varying vec2 vUvs;
uniform float zoom;

void main()
{
//Generate a simple grid.
//Offset uv so that center is 0,0 and edges are -1,1
vec2 uv = (vUvs-vec2(0.5))*2.0;
vec2 gUv = floor(uv*zoom);
vec4 color1 = vec4(0.8, 0.8, 0.8, 1.0);
vec4 color2 = vec4(0.4, 0.4, 0.4, 1.0);
vec4 outColor = mod(gUv.x + gUv.y, 2.) < 0.5 ? color1 : color2;
gl_FragColor = outColor;

}`;

const gridUniforms = {
zoom: 10,
};
const gridShader = PIXI.Shader.from(vertexSrc, fragmentGridSrc, gridUniforms);
// Sharing textures and meshes is possible.
// But for simplicity each pass has its own output texture and mesh in this example.
const gridTexture = PIXI.RenderTexture.create({ width: 200, height: 200 });
const gridQuad = new PIXI.Mesh(geometry, gridShader);
const gridContainer = new PIXI.Container();

gridContainer.addChild(gridQuad);

// Second pass. Takes grid as input and makes it ripple.
const fragmentRippleSrc = `
precision mediump float;
varying vec2 vUvs;
uniform float amount;
uniform float phase;
uniform sampler2D texIn;

void main()
{
//Generate a simple grid.
vec2 uv = vUvs;
//Calculate distance from center
float distance = length( uv - vec2(0.5));
vec4 color = texture2D(texIn, uv);
color.rgb *= sin(distance*25.0+phase) * amount+1.;
gl_FragColor = color;
}`;
const rippleUniforms = {
amount: 0.5,
phase: 0,
texIn: gridTexture,
};
const rippleShader = PIXI.Shader.from(vertexSrc, fragmentRippleSrc, rippleUniforms);
const rippleTexture = PIXI.RenderTexture.create({ width: 200, height: 200 });
const rippleQuad = new PIXI.Mesh(geometry, rippleShader);
const rippleContainer = new PIXI.Container();

rippleContainer.addChild(rippleQuad);

// Second effect. Generates a filtered noise.
const fragmentNoiseSrc = `
precision mediump float;
varying vec2 vUvs;
uniform float limit;
uniform sampler2D noise;

void main()
{
float color = texture2D(noise, vUvs).r;
color = step(limit, color);
gl_FragColor = vec4(color);
}`;
const noiseUniforms = {
limit: 0.5,
noise: perlinTexture,
};
const noiseShader = PIXI.Shader.from(vertexSrc, fragmentNoiseSrc, noiseUniforms);
const noiseTexture = PIXI.RenderTexture.create({ width: 200, height: 200 });
const noiseQuad = new PIXI.Mesh(geometry, noiseShader);
const noiseContainer = new PIXI.Container();

noiseContainer.addChild(noiseQuad);

// Third effect
const fragmentWaveSrc = `
precision mediump float;
varying vec2 vUvs;
uniform float amplitude;
uniform float time;

void main()
{
//Offset uv so that center is 0,0 and edges are -1,1
vec2 uv = (vUvs-vec2(0.5))*2.0;

vec3 outColor = vec3(0.);

//Simple wavefunctions inversed and with small offsets.
outColor += 5./length(uv.y*200. - 50.0*sin( uv.x*0.25+ time*0.25)*amplitude);
outColor += 4./length(uv.y*300. - 100.0*sin(uv.x*0.5+time*0.5)*amplitude*1.2);
outColor += 3./length(uv.y*400. - 150.0*sin(uv.x*0.75+time*0.75)*amplitude*1.4);
outColor += 2./length(uv.y*500. - 200.0*sin(uv.x+time)*amplitude*1.6);

gl_FragColor = vec4(outColor,1.0);
}`;
const waveUniforms = {
amplitude: 0.75,
time: 0,
};
const waveShader = PIXI.Shader.from(vertexSrc, fragmentWaveSrc, waveUniforms);
const waveTexture = PIXI.RenderTexture.create({ width: 200, height: 200 });
const waveQuad = new PIXI.Mesh(geometry, waveShader);
const waveContainer = new PIXI.Container();

waveContainer.addChild(waveQuad);

// Final combination pass
const fragmentCombineSrc = `
precision mediump float;
varying vec2 vUvs;

uniform sampler2D texRipple;
uniform sampler2D texNoise;
uniform sampler2D texWave;

void main()
{
//Read color from all
vec4 ripple = texture2D(texRipple, vUvs);
vec4 noise = texture2D(texNoise, vUvs);
vec4 wave = texture2D(texWave, vUvs);

gl_FragColor = mix(ripple, wave,noise.r);
}`;
const combineUniforms = {
texRipple: rippleTexture,
texNoise: noiseTexture,
texWave: waveTexture,
};
const combineShader = PIXI.Shader.from(vertexSrc, fragmentCombineSrc, combineUniforms);
const combineQuad = new PIXI.Mesh(geometry, combineShader);

gridContainer.position.set(10, 10);
rippleContainer.position.set(220, 10);
noiseContainer.position.set(10, 220);
waveContainer.position.set(10, 430);
combineQuad.position.set(430, 220);

// Add all phases to stage so all the phases can be seen separately.
app.stage.addChild(gridContainer);
app.stage.addChild(rippleContainer);
app.stage.addChild(noiseContainer);
app.stage.addChild(waveContainer);
app.stage.addChild(combineQuad);

// start the animation..
let time = 0;

app.ticker.add((delta) =>
{
time += 1 / 60;
// gridQuad.shader.uniforms.zoom = Math.sin(time)*5+10;
rippleQuad.shader.uniforms.phase = -time;
waveQuad.shader.uniforms.time = time;
noiseQuad.shader.uniforms.limit = Math.sin(time * 0.5) * 0.35 + 0.5;

// Render the passes to get textures.
app.renderer.render(gridQuad, { renderTexture: gridTexture });
app.renderer.render(rippleQuad, { renderTexture: rippleTexture });
app.renderer.render(noiseQuad, { renderTexture: noiseTexture });
app.renderer.render(waveQuad, { renderTexture: waveTexture });
});
- + \ No newline at end of file diff --git a/examples/mesh-and-shaders/shader-toy-mesh.html b/examples/mesh-and-shaders/shader-toy-mesh.html index 518f36c1c..d842dd779 100644 --- a/examples/mesh-and-shaders/shader-toy-mesh.html +++ b/examples/mesh-and-shaders/shader-toy-mesh.html @@ -9,13 +9,13 @@ - +
Skip to main content

Shader Toy Mesh

import * as PIXI from 'pixi.js';

const app = new PIXI.Application({ resizeTo: window });

document.body.appendChild(app.view);

// Build geometry.
const geometry = new PIXI.Geometry()
.addAttribute('aVertexPosition', // the attribute name
[-100, -100, // x, y
100, -100, // x, y
100, 100,
-100, 100], // x, y
2) // the size of the attribute
.addAttribute('aUvs', // the attribute name
[0, 0, // u, v
1, 0, // u, v
1, 1,
0, 1], // u, v
2) // the size of the attribute
.addIndex([0, 1, 2, 0, 2, 3]);

const vertexSrc = `

precision mediump float;

attribute vec2 aVertexPosition;
attribute vec2 aUvs;

uniform mat3 translationMatrix;
uniform mat3 projectionMatrix;

varying vec2 vUvs;

void main() {

vUvs = aUvs;
gl_Position = vec4((projectionMatrix * translationMatrix * vec3(aVertexPosition, 1.0)).xy, 0.0, 1.0);

}`;

const fragmentSrc = `
//Based on this: https://www.shadertoy.com/view/wtlSWX
precision mediump float;

varying vec2 vUvs;

uniform sampler2D noise;
uniform float time;

// Distance function. Just calculates the height (z) from x,y plane with really simple length check.
// Its not exact as there could be shorter distances.
vec2 dist(vec3 p)
{
float id = floor(p.x)+floor(p.y);
id = mod(id, 2.);
float h = texture2D(noise, vec2(p.x, p.y)*0.04).r*5.1;
return vec2(h-p.z,id);
}

//Light calculation.
vec3 calclight(vec3 p, vec3 rd)
{
vec2 eps = vec2( 0., 0.001);
vec3 n = normalize( vec3(
dist(p+eps.yxx).x - dist(p-eps.yxx).x,
dist(p+eps.xyx).x - dist(p-eps.xyx).x,
dist(p+eps.xxy).x - dist(p-eps.xxy).x
));

vec3 d = vec3( max( 0., dot( -rd ,n)));

return d;
}

void main()
{
vec2 uv = vec2(vUvs.x,1.-vUvs.y);
uv *=2.;
uv-=1.;

vec3 cam = vec3(0.,time -2., -3.);
vec3 target = vec3(sin(time)*0.1, time+cos(time)+2., 0. );
float fov = 2.2;
vec3 forward = normalize( target - cam);
vec3 up = normalize(cross( forward, vec3(0., 1.,0.)));
vec3 right = normalize( cross( up, forward));
vec3 raydir = normalize(vec3( uv.x *up + uv.y * right + fov*forward));

//Do the raymarch
vec3 col = vec3(0.);
float t = 0.;
for( int i = 0; i < 100; i++)
{
vec3 p = t * raydir + cam;
vec2 d = dist(p);
t+=d.x*0.5;//Jump only half of the distance as height function used is not really the best for heightmaps.
if(d.x < 0.001)
{
vec3 bc = d.y < 0.5 ? vec3(1.0, .8, 0.) :
vec3(0.8,0.0, 1.0);
col = vec3( 1.) * calclight(p, raydir) * (1. - t/150.) *bc;
break;
}
if(t > 1000.)
{
break;
}
}
gl_FragColor = vec4(col, 1.);
}`;

const uniforms = {
noise: PIXI.Texture.from('https://pixijs.com/assets/perlin.jpg'),
time: 0,
};
// Make sure repeat wrap is used and no mipmapping.

uniforms.noise.baseTexture.wrapMode = PIXI.WRAP_MODES.REPEAT;
uniforms.noise.baseTexture.mipmap = false;

// Build the shader and the quad.
const shader = PIXI.Shader.from(vertexSrc, fragmentSrc, uniforms);
const quad = new PIXI.Mesh(geometry, shader);

quad.position.set(400, 300);
quad.scale.set(2);

app.stage.addChild(quad);

// start the animation..
let time = 0;

app.ticker.add((delta) =>
{
time += 1 / 60;
quad.shader.uniforms.time = time;
quad.scale.set(Number(Math.cos(time)) + 2, Number(Math.sin(time * 0.7)) + 2);
});
- + \ No newline at end of file diff --git a/examples/mesh-and-shaders/shared-shader.html b/examples/mesh-and-shaders/shared-shader.html index 30314f94f..7f5085ad1 100644 --- a/examples/mesh-and-shaders/shared-shader.html +++ b/examples/mesh-and-shaders/shared-shader.html @@ -9,13 +9,13 @@ - +
Skip to main content

Shared Shader

import * as PIXI from 'pixi.js';

const app = new PIXI.Application({ resizeTo: window });

document.body.appendChild(app.view);

const geometry = new PIXI.Geometry()
.addAttribute('aVertexPosition', // the attribute name
[-100, -100, // x, y
100, -100, // x, y
100, 100]) // x, y

.addAttribute('aUvs', // the attribute name
[0, 0, // u, v
1, 0, // u, v
1, 1]); // u, v

const shader = PIXI.Shader.from(`

precision mediump float;

attribute vec2 aVertexPosition;
attribute vec2 aUvs;

uniform mat3 translationMatrix;
uniform mat3 projectionMatrix;

varying vec2 vUvs;

void main() {

vUvs = aUvs;
gl_Position = vec4((projectionMatrix * translationMatrix * vec3(aVertexPosition, 1.0)).xy, 0.0, 1.0);

}`,

`precision mediump float;

varying vec2 vUvs;

uniform sampler2D uSampler2;

void main() {

gl_FragColor = texture2D(uSampler2, vUvs);
}

`,
{
uSampler2: PIXI.Texture.from('https://pixijs.com/assets/bg_scene_rotate.jpg'),
});

const shader2 = PIXI.Shader.from(`

precision mediump float;

attribute vec2 aVertexPosition;
attribute vec2 aUvs;

uniform mat3 translationMatrix;
uniform mat3 projectionMatrix;

varying vec2 vUvs;

void main() {

vUvs = aUvs;
gl_Position = vec4((projectionMatrix * translationMatrix * vec3(aVertexPosition, 1.0)).xy, 0.0, 1.0);

}`,

`precision mediump float;

varying vec2 vUvs;

uniform sampler2D uSampler2;

void main() {

gl_FragColor = texture2D(uSampler2, vUvs);
gl_FragColor.r += (abs(sin(gl_FragCoord.x * 0.06)) * 0.5) * 2.;
gl_FragColor.g += (abs(cos(gl_FragCoord.y * 0.06)) * 0.5) * 2.;
}

`,
{
uSampler2: PIXI.Texture.from('https://pixijs.com/assets/bg_scene_rotate.jpg'),
});

const triangle = new PIXI.Mesh(geometry, shader);

const triangle2 = new PIXI.Mesh(geometry, shader2);

triangle.position.set(400, 300);
triangle.scale.set(2);

triangle2.position.set(500, 400);
triangle2.scale.set(3);

app.stage.addChild(triangle2, triangle);

app.ticker.add((delta) =>
{
triangle.rotation += 0.01;
triangle2.rotation -= 0.005;
});
- + \ No newline at end of file diff --git a/examples/mesh-and-shaders/sharing-geometry.html b/examples/mesh-and-shaders/sharing-geometry.html index 9dafb8f90..1afb4e202 100644 --- a/examples/mesh-and-shaders/sharing-geometry.html +++ b/examples/mesh-and-shaders/sharing-geometry.html @@ -9,13 +9,13 @@ - +
Skip to main content

Sharing Geometry

import * as PIXI from 'pixi.js';

const app = new PIXI.Application({ resizeTo: window });

document.body.appendChild(app.view);

const geometry = new PIXI.Geometry()
.addAttribute('aVertexPosition', // the attribute name
[-100, -100, // x, y
100, -100, // x, y
100, 100], // x, y
2) // the size of the attribute

.addAttribute('aUvs', // the attribute name
[0, 0, // u, v
1, 0, // u, v
1, 1], // u, v
2); // the size of the attribute

const program = PIXI.Program.from(`

precision mediump float;

attribute vec2 aVertexPosition;
attribute vec2 aUvs;

uniform mat3 translationMatrix;
uniform mat3 projectionMatrix;

varying vec2 vUvs;

void main() {

vUvs = aUvs;
gl_Position = vec4((projectionMatrix * translationMatrix * vec3(aVertexPosition, 1.0)).xy, 0.0, 1.0);

}`,

`precision mediump float;

varying vec2 vUvs;

uniform sampler2D uSamplerTexture;

void main() {

gl_FragColor = texture2D(uSamplerTexture, vUvs);
}

`);

const triangle = new PIXI.Mesh(geometry, new PIXI.Shader(program, {
uSamplerTexture: PIXI.Texture.from('https://pixijs.com/assets/bg_scene_rotate.jpg'),
}));

const triangle2 = new PIXI.Mesh(geometry, new PIXI.Shader(program, {
uSamplerTexture: PIXI.Texture.from('https://pixijs.com/assets/bg_rotate.jpg'),
}));

const triangle3 = new PIXI.Mesh(geometry, new PIXI.Shader(program, {
uSamplerTexture: PIXI.Texture.from('https://pixijs.com/assets/bg_displacement.jpg'),
}));

triangle.position.set(400, 300);
triangle.scale.set(2);

triangle2.position.set(200, 100);

triangle3.position.set(500, 400);
triangle3.scale.set(3);

app.stage.addChild(triangle3, triangle2, triangle);

app.ticker.add((delta) =>
{
triangle.rotation += 0.01;
triangle2.rotation -= 0.01;
triangle3.rotation -= 0.005;
});
- + \ No newline at end of file diff --git a/examples/mesh-and-shaders/textured-mesh-advanced.html b/examples/mesh-and-shaders/textured-mesh-advanced.html index acaded403..ded3f43e1 100644 --- a/examples/mesh-and-shaders/textured-mesh-advanced.html +++ b/examples/mesh-and-shaders/textured-mesh-advanced.html @@ -9,13 +9,13 @@ - +
Skip to main content

Textured Mesh Advanced

import * as PIXI from 'pixi.js';

const app = new PIXI.Application({ resizeTo: window });

document.body.appendChild(app.view);

let count = 0;

// build a rope!
const ropeLength = 45;

const points = [];

for (let i = 0; i < 25; i++)
{
points.push(new PIXI.Point(i * ropeLength, 0));
}

const strip = new PIXI.SimpleRope(PIXI.Texture.from('https://pixijs.com/assets/snake.png'), points);

strip.x = -40;
strip.y = 300;

app.stage.addChild(strip);

const g = new PIXI.Graphics();

g.x = strip.x;
g.y = strip.y;
app.stage.addChild(g);

// start animating
app.ticker.add(() =>
{
count += 0.1;

// make the snake
for (let i = 0; i < points.length; i++)
{
points[i].y = Math.sin((i * 0.5) + count) * 30;
points[i].x = i * ropeLength + Math.cos((i * 0.3) + count) * 20;
}
renderPoints();
});

function renderPoints()
{
g.clear();

g.lineStyle(2, 0xffc2c2);
g.moveTo(points[0].x, points[0].y);

for (let i = 1; i < points.length; i++)
{
g.lineTo(points[i].x, points[i].y);
}

for (let i = 1; i < points.length; i++)
{
g.beginFill(0xff0022);
g.drawCircle(points[i].x, points[i].y, 10);
g.endFill();
}
}
- + \ No newline at end of file diff --git a/examples/mesh-and-shaders/textured-mesh-basic.html b/examples/mesh-and-shaders/textured-mesh-basic.html index f97640cbe..42da6f23a 100644 --- a/examples/mesh-and-shaders/textured-mesh-basic.html +++ b/examples/mesh-and-shaders/textured-mesh-basic.html @@ -9,13 +9,13 @@ - +
Skip to main content

Textured Mesh Basic

import * as PIXI from 'pixi.js';

const app = new PIXI.Application({ resizeTo: window });

document.body.appendChild(app.view);

let count = 0;

// build a rope!
const ropeLength = 918 / 20;

const points = [];

for (let i = 0; i < 20; i++)
{
points.push(new PIXI.Point(i * ropeLength, 0));
}

const strip = new PIXI.SimpleRope(PIXI.Texture.from('https://pixijs.com/assets/snake.png'), points);

strip.x = -459;

const snakeContainer = new PIXI.Container();

snakeContainer.x = 400;
snakeContainer.y = 300;

snakeContainer.scale.set(800 / 1100);
app.stage.addChild(snakeContainer);

snakeContainer.addChild(strip);

app.ticker.add(() =>
{
count += 0.1;

// make the snake
for (let i = 0; i < points.length; i++)
{
points[i].y = Math.sin((i * 0.5) + count) * 30;
points[i].x = i * ropeLength + Math.cos((i * 0.3) + count) * 20;
}
});
- + \ No newline at end of file diff --git a/examples/mesh-and-shaders/triangle-color.html b/examples/mesh-and-shaders/triangle-color.html index 3cd7699be..64241ecb6 100644 --- a/examples/mesh-and-shaders/triangle-color.html +++ b/examples/mesh-and-shaders/triangle-color.html @@ -9,13 +9,13 @@ - +
Skip to main content

Triangle Color

import * as PIXI from 'pixi.js';

const app = new PIXI.Application({ resizeTo: window });

document.body.appendChild(app.view);

const geometry = new PIXI.Geometry()
.addAttribute('aVertexPosition', // the attribute name
[-100, -50, // x, y
100, -50, // x, y
0.0, 100.0], // x, y
2) // the size of the attribute

.addAttribute('aColor', // the attribute name
[1, 0, 0, // r, g, b
0, 1, 0, // r, g, b
0, 0, 1], // r, g, b
3); // the size of the attribute

const shader = PIXI.Shader.from(`

precision mediump float;
attribute vec2 aVertexPosition;
attribute vec3 aColor;

uniform mat3 translationMatrix;
uniform mat3 projectionMatrix;

varying vec3 vColor;

void main() {

vColor = aColor;
gl_Position = vec4((projectionMatrix * translationMatrix * vec3(aVertexPosition, 1.0)).xy, 0.0, 1.0);

}`,

`precision mediump float;

varying vec3 vColor;

void main() {
gl_FragColor = vec4(vColor, 1.0);
}

`);

const triangle = new PIXI.Mesh(geometry, shader);

triangle.position.set(400, 300);
triangle.scale.set(2);

app.stage.addChild(triangle);

app.ticker.add((delta) =>
{
triangle.rotation += 0.01;
});
- + \ No newline at end of file diff --git a/examples/mesh-and-shaders/triangle-textured.html b/examples/mesh-and-shaders/triangle-textured.html index d974735a3..685f6bcc2 100644 --- a/examples/mesh-and-shaders/triangle-textured.html +++ b/examples/mesh-and-shaders/triangle-textured.html @@ -9,13 +9,13 @@ - +
Skip to main content

Triangle Textured

import * as PIXI from 'pixi.js';

const app = new PIXI.Application({ resizeTo: window });

document.body.appendChild(app.view);

const geometry = new PIXI.Geometry()
.addAttribute('aVertexPosition', // the attribute name
[-100, -100, // x, y
100, -100, // x, y
100, 100], // x, y
2) // the size of the attribute

.addAttribute('aColor', // the attribute name
[1, 0, 0, // r, g, b
0, 1, 0, // r, g, b
0, 0, 1], // r, g, b
3) // the size of the attribute

.addAttribute('aUvs', // the attribute name
[0, 0, // u, v
1, 0, // u, v
1, 1], // u, v
2); // the size of the attribute

const vertexSrc = `

precision mediump float;

attribute vec2 aVertexPosition;
attribute vec3 aColor;
attribute vec2 aUvs;

uniform mat3 translationMatrix;
uniform mat3 projectionMatrix;

varying vec2 vUvs;
varying vec3 vColor;

void main() {

vUvs = aUvs;
vColor = aColor;
gl_Position = vec4((projectionMatrix * translationMatrix * vec3(aVertexPosition, 1.0)).xy, 0.0, 1.0);

}`;

const fragmentSrc = `

precision mediump float;

varying vec3 vColor;
varying vec2 vUvs;

uniform sampler2D uSampler2;

void main() {

gl_FragColor = texture2D(uSampler2, vUvs) * vec4(vColor, 1.0);
}`;

const uniforms = { uSampler2: PIXI.Texture.from('https://pixijs.com/assets/bg_scene_rotate.jpg') };

const shader = PIXI.Shader.from(vertexSrc, fragmentSrc, uniforms);

const triangle = new PIXI.Mesh(geometry, shader);

triangle.position.set(400, 300);
triangle.scale.set(2);

app.stage.addChild(triangle);

app.ticker.add((delta) =>
{
triangle.rotation += 0.01;
});
- + \ No newline at end of file diff --git a/examples/mesh-and-shaders/triangle.html b/examples/mesh-and-shaders/triangle.html index 12edfc254..46127e982 100644 --- a/examples/mesh-and-shaders/triangle.html +++ b/examples/mesh-and-shaders/triangle.html @@ -9,13 +9,13 @@ - +
Skip to main content

Triangle

import * as PIXI from 'pixi.js';

const app = new PIXI.Application({ resizeTo: window });

document.body.appendChild(app.view);

const geometry = new PIXI.Geometry()
.addAttribute('aVertexPosition', [-100, -50, 100, -50, 0, 100]);

const shader = PIXI.Shader.from(`

precision mediump float;
attribute vec2 aVertexPosition;

uniform mat3 translationMatrix;
uniform mat3 projectionMatrix;

void main() {
gl_Position = vec4((projectionMatrix * translationMatrix * vec3(aVertexPosition, 1.0)).xy, 0.0, 1.0);
}`,

`precision mediump float;

void main() {
gl_FragColor = vec4(1.0, 0.0, 0.0, 1.0);
}

`);

const triangle = new PIXI.Mesh(geometry, shader);

triangle.position.set(400, 300);

app.stage.addChild(triangle);

app.ticker.add((delta) =>
{
triangle.rotation += 0.01;
});
- + \ No newline at end of file diff --git a/examples/mesh-and-shaders/uniforms.html b/examples/mesh-and-shaders/uniforms.html index 171b44e76..650b57fd9 100644 --- a/examples/mesh-and-shaders/uniforms.html +++ b/examples/mesh-and-shaders/uniforms.html @@ -9,13 +9,13 @@ - +
Skip to main content

Uniforms

import * as PIXI from 'pixi.js';

const app = new PIXI.Application({ resizeTo: window });

document.body.appendChild(app.view);

const geometry = new PIXI.Geometry()
.addAttribute('aVertexPosition', // the attribute name
[-100, -100, // x, y
100, -100, // x, y
100, 100,
-100, 100], // x, y
2) // the size of the attribute
.addAttribute('aUvs', // the attribute name
[0, 0, // u, v
1, 0, // u, v
1, 1,
0, 1], // u, v
2) // the size of the attribute
.addIndex([0, 1, 2, 0, 2, 3]);

const vertexSrc = `

precision mediump float;

attribute vec2 aVertexPosition;
attribute vec2 aUvs;

uniform mat3 translationMatrix;
uniform mat3 projectionMatrix;

varying vec2 vUvs;

void main() {

vUvs = aUvs;
gl_Position = vec4((projectionMatrix * translationMatrix * vec3(aVertexPosition, 1.0)).xy, 0.0, 1.0);

}`;

const fragmentSrc = `

precision mediump float;

varying vec2 vUvs;

uniform sampler2D uSampler2;
uniform float time;

void main() {

gl_FragColor = texture2D(uSampler2, vUvs + sin( (time + (vUvs.x) * 14.) ) * 0.1 );
}`;

const uniforms = {
uSampler2: PIXI.Texture.from('https://pixijs.com/assets/bg_scene_rotate.jpg'),
time: 0,
};

const shader = PIXI.Shader.from(vertexSrc, fragmentSrc, uniforms);

const quad = new PIXI.Mesh(geometry, shader);

quad.position.set(400, 300);
quad.scale.set(2);

app.stage.addChild(quad);

// start the animation..
// requestAnimationFrame(animate);

app.ticker.add((delta) =>
{
quad.rotation += 0.01;
quad.shader.uniforms.time += 0.1;
});
- + \ No newline at end of file diff --git a/examples/offscreen-canvas/basic.html b/examples/offscreen-canvas/basic.html index 540dc7e58..33a451676 100644 --- a/examples/offscreen-canvas/basic.html +++ b/examples/offscreen-canvas/basic.html @@ -9,13 +9,13 @@ - +
Skip to main content

Basic

import * as PIXI from 'pixi.js';

// This example is the based on basic/container, but using OffscreenCanvas.

const canvas = document.createElement('canvas');
const view = canvas.transferControlToOffscreen();

const app = new PIXI.Application({ view, background: 0x1099bb, resizeTo: window });

document.body.appendChild(canvas);

const container = new PIXI.Container();

app.stage.addChild(container);

// Create a new texture
const texture = PIXI.Texture.from('https://pixijs.com/assets/bunny.png');

// Create a 5x5 grid of bunnies
for (let i = 0; i < 25; i++)
{
const bunny = new PIXI.Sprite(texture);

bunny.anchor.set(0.5);
bunny.x = (i % 5) * 40;
bunny.y = Math.floor(i / 5) * 40;
container.addChild(bunny);
}

// Move container to the center
container.x = app.screen.width / 2;
container.y = app.screen.height / 2;

// Center bunny sprite in local container coordinates
container.pivot.x = container.width / 2;
container.pivot.y = container.height / 2;

// Listen for animate update
app.ticker.add((delta) =>
{
// rotate the container!
// use delta to create frame-independent transform
container.rotation -= 0.01 * delta;
});
- + \ No newline at end of file diff --git a/examples/sprite/animated-sprite-animation-speed.html b/examples/sprite/animated-sprite-animation-speed.html index 1b6646550..9185e647f 100644 --- a/examples/sprite/animated-sprite-animation-speed.html +++ b/examples/sprite/animated-sprite-animation-speed.html @@ -9,13 +9,13 @@ - +
Skip to main content

Animated Sprite Animation Speed

import * as PIXI from 'pixi.js';

const app = new PIXI.Application({ autoStart: false, resizeTo: window });

document.body.appendChild(app.view);

PIXI.Assets.load('https://pixijs.com/assets/spritesheet/0123456789.json').then((spritesheet) =>
{
// create an array to store the textures
const textures = [];
let i;

for (i = 0; i < 10; i++)
{
const framekey = `0123456789 ${i}.ase`;
const texture = PIXI.Texture.from(framekey);
const time = spritesheet.data.frames[framekey].duration;

textures.push({ texture, time });
}

const scaling = 4;

// create a slow AnimatedSprite
const slow = new PIXI.AnimatedSprite(textures);

slow.anchor.set(0.5);
slow.scale.set(scaling);
slow.animationSpeed = 0.5;
slow.x = (app.screen.width - slow.width) / 2;
slow.y = app.screen.height / 2;
slow.play();
app.stage.addChild(slow);

// create a fast AnimatedSprite
const fast = new PIXI.AnimatedSprite(textures);

fast.anchor.set(0.5);
fast.scale.set(scaling);
fast.x = (app.screen.width + fast.width) / 2;
fast.y = app.screen.height / 2;
fast.play();
app.stage.addChild(fast);

// start animating
app.start();
});
- + \ No newline at end of file diff --git a/examples/sprite/animated-sprite-explosion.html b/examples/sprite/animated-sprite-explosion.html index 05d75b6ba..7f77b8a42 100644 --- a/examples/sprite/animated-sprite-explosion.html +++ b/examples/sprite/animated-sprite-explosion.html @@ -9,13 +9,13 @@ - +
Skip to main content

Animated Sprite Explosion

import * as PIXI from 'pixi.js';

const app = new PIXI.Application({ autoStart: false, resizeTo: window });

document.body.appendChild(app.view);

PIXI.Assets.load('https://pixijs.com/assets/spritesheet/mc.json').then(() =>
{
// create an array to store the textures
const explosionTextures = [];
let i;

for (i = 0; i < 26; i++)
{
const texture = PIXI.Texture.from(`Explosion_Sequence_A ${i + 1}.png`);

explosionTextures.push(texture);
}

for (i = 0; i < 50; i++)
{
// create an explosion AnimatedSprite
const explosion = new PIXI.AnimatedSprite(explosionTextures);

explosion.x = Math.random() * app.screen.width;
explosion.y = Math.random() * app.screen.height;
explosion.anchor.set(0.5);
explosion.rotation = Math.random() * Math.PI;
explosion.scale.set(0.75 + Math.random() * 0.5);
explosion.gotoAndPlay(Math.random() * 26 | 0);
app.stage.addChild(explosion);
}

// start animating
app.start();
});
- + \ No newline at end of file diff --git a/examples/sprite/animated-sprite-jet.html b/examples/sprite/animated-sprite-jet.html index 51b76d273..991ccf712 100644 --- a/examples/sprite/animated-sprite-jet.html +++ b/examples/sprite/animated-sprite-jet.html @@ -9,13 +9,13 @@ - +
Skip to main content

Animated Sprite Jet

import * as PIXI from 'pixi.js';

const app = new PIXI.Application({ background: '#1099bb', resizeTo: window });

document.body.appendChild(app.view);

PIXI.Assets.load('https://pixijs.com/assets/spritesheet/fighter.json').then(() =>
{
// create an array of textures from an image path
const frames = [];

for (let i = 0; i < 30; i++)
{
const val = i < 10 ? `0${i}` : i;

// magically works since the spritesheet was loaded with the pixi loader
frames.push(PIXI.Texture.from(`rollSequence00${val}.png`));
}

// create an AnimatedSprite (brings back memories from the days of Flash, right ?)
const anim = new PIXI.AnimatedSprite(frames);

/*
* An AnimatedSprite inherits all the properties of a PIXI sprite
* so you can change its position, its anchor, mask it, etc
*/
anim.x = app.screen.width / 2;
anim.y = app.screen.height / 2;
anim.anchor.set(0.5);
anim.animationSpeed = 0.5;
anim.play();

app.stage.addChild(anim);

// Animate the rotation
app.ticker.add(() =>
{
anim.rotation += 0.01;
});
});
- + \ No newline at end of file diff --git a/examples/sprite/basic.html b/examples/sprite/basic.html index bdf265d83..0e86f5389 100644 --- a/examples/sprite/basic.html +++ b/examples/sprite/basic.html @@ -9,13 +9,13 @@ - +
Skip to main content

Basic

import * as PIXI from 'pixi.js';

const app = new PIXI.Application({ background: '#1099bb', resizeTo: window });

document.body.appendChild(app.view);

// create a new Sprite from an image path
const bunny = PIXI.Sprite.from('https://pixijs.com/assets/bunny.png');

// center the sprite's anchor point
bunny.anchor.set(0.5);

// move the sprite to the center of the screen
bunny.x = app.screen.width / 2;
bunny.y = app.screen.height / 2;

app.stage.addChild(bunny);

// Listen for animate update
app.ticker.add((delta) =>
{
// just for fun, let's rotate mr rabbit a little
// delta is 1 if running at 100% performance
// creates frame-independent transformation
bunny.rotation += 0.1 * delta;
});
- + \ No newline at end of file diff --git a/examples/sprite/texture-swap.html b/examples/sprite/texture-swap.html index 4299d61a4..4b2ab011d 100644 --- a/examples/sprite/texture-swap.html +++ b/examples/sprite/texture-swap.html @@ -9,13 +9,13 @@ - +
Skip to main content

Texture Swap

import * as PIXI from 'pixi.js';

const app = new PIXI.Application({ background: '#1099bb', resizeTo: window });

document.body.appendChild(app.view);

let isFlower = true;

const texture = PIXI.Texture.from('https://pixijs.com/assets/flowerTop.png');
const secondTexture = PIXI.Texture.from('https://pixijs.com/assets/eggHead.png');

// create a new Sprite using the texture
const character = new PIXI.Sprite(texture);

// center the sprites anchor point
character.anchor.set(0.5);

// move the sprite to the center of the screen
character.x = app.screen.width / 2;
character.y = app.screen.height / 2;

app.stage.addChild(character);

// make the sprite interactive
character.eventMode = 'static';
character.cursor = 'pointer';

character.on('pointertap', () =>
{
isFlower = !isFlower;
// Dynamically swap the texture
character.texture = isFlower ? texture : secondTexture;
});

app.ticker.add(() =>
{
character.rotation += 0.02;
});
- + \ No newline at end of file diff --git a/examples/sprite/tiling-sprite.html b/examples/sprite/tiling-sprite.html index 3cd295a13..1a639e77d 100644 --- a/examples/sprite/tiling-sprite.html +++ b/examples/sprite/tiling-sprite.html @@ -9,13 +9,13 @@ - +
Skip to main content

Tiling Sprite

import * as PIXI from 'pixi.js';

const app = new PIXI.Application({ resizeTo: window });

document.body.appendChild(app.view);

// create a texture from an image path
const texture = PIXI.Texture.from('https://pixijs.com/assets/p2.jpeg');

/* create a tiling sprite ...
* requires a texture, a width and a height
* in WebGL the image size should preferably be a power of two
*/
const tilingSprite = new PIXI.TilingSprite(
texture,
app.screen.width,
app.screen.height,
);

app.stage.addChild(tilingSprite);

let count = 0;

app.ticker.add(() =>
{
count += 0.005;

tilingSprite.tileScale.x = 2 + Math.sin(count);
tilingSprite.tileScale.y = 2 + Math.cos(count);

tilingSprite.tilePosition.x += 1;
tilingSprite.tilePosition.y += 1;
});
- + \ No newline at end of file diff --git a/examples/sprite/video.html b/examples/sprite/video.html index 9d61ddc46..f3cac8533 100644 --- a/examples/sprite/video.html +++ b/examples/sprite/video.html @@ -9,13 +9,13 @@ - +
Skip to main content

Video

import * as PIXI from 'pixi.js';

const app = new PIXI.Application({ backgroundAlpha: 0, resizeTo: window });

document.body.appendChild(app.view);

// Create play button that can be used to trigger the video
const button = new PIXI.Graphics()
.beginFill(0x0, 0.5)
.drawRoundedRect(0, 0, 100, 100, 10)
.endFill()
.beginFill(0xffffff)
.moveTo(36, 30)
.lineTo(36, 70)
.lineTo(70, 50);

// Position the button
button.x = (app.screen.width - button.width) / 2;
button.y = (app.screen.height - button.height) / 2;

// Enable interactivity on the button
button.eventMode = 'static';
button.cursor = 'pointer';

// Add to the stage
app.stage.addChild(button);

// Listen for a click/tap event to start playing the video
// this is useful for some mobile platforms. For example:
// ios9 and under cannot render videos in PIXI without a
// polyfill - https://github.com/bfred-it/iphone-inline-video
// ios10 and above require a click/tap event to render videos
// that contain audio in PIXI. Videos with no audio track do
// not have this requirement
button.on('pointertap', onPlayVideo);

function onPlayVideo()
{
// Don't need the button anymore
button.destroy();

// create a video texture from a path
const texture = PIXI.Texture.from('https://pixijs.com/assets/video.mp4');

// create a new Sprite using the video texture (yes it's that easy)
const videoSprite = new PIXI.Sprite(texture);

// Stetch the fullscreen
videoSprite.width = app.screen.width;
videoSprite.height = app.screen.height;

app.stage.addChild(videoSprite);
}
- + \ No newline at end of file diff --git a/examples/text/bitmap-text.html b/examples/text/bitmap-text.html index b142c3d25..279a242c3 100644 --- a/examples/text/bitmap-text.html +++ b/examples/text/bitmap-text.html @@ -9,13 +9,13 @@ - +
Skip to main content

Bitmap Text

import * as PIXI from 'pixi.js';

const app = new PIXI.Application({ background: '#1099bb', resizeTo: window });

document.body.appendChild(app.view);

PIXI.Assets.load('https://pixijs.com/assets/bitmap-font/desyrel.xml').then(() =>
{
const bitmapFontText = new PIXI.BitmapText(
'bitmap fonts are supported!\nWoo yay!', {
fontName: 'Desyrel',
fontSize: 55,
align: 'left',
},
);

bitmapFontText.x = 50;
bitmapFontText.y = 200;

app.stage.addChild(bitmapFontText);
});
- + \ No newline at end of file diff --git a/examples/text/from-font.html b/examples/text/from-font.html index 59e45fbac..571efdc1f 100644 --- a/examples/text/from-font.html +++ b/examples/text/from-font.html @@ -9,13 +9,13 @@ - +
Skip to main content

From Font

import * as PIXI from 'pixi.js';

const app = new PIXI.Application({ background: '#1099bb', resizeTo: window });

document.body.appendChild(app.view);

// Load from any font file!
PIXI.Assets.addBundle('fonts', {
ChaChicle: 'https://pixijs.com/assets/webfont-loader/ChaChicle.ttf',
Lineal: 'https://pixijs.com/assets/webfont-loader/Lineal.otf',
'Dotrice Regular': 'https://pixijs.com/assets/webfont-loader/Dotrice-Regular.woff',
Crosterian: 'https://pixijs.com/assets/webfont-loader/Crosterian.woff2',
});
PIXI.Assets.loadBundle('fonts').then(() =>
{
const text1 = new PIXI.Text('ChaChicle.ttf', new PIXI.TextStyle({ fontFamily: 'ChaChicle', fontSize: 50 }));
const text2 = new PIXI.Text('Lineal.otf', new PIXI.TextStyle({ fontFamily: 'Lineal', fontSize: 50 }));
const text3 = new PIXI.Text('Dotrice Regular.woff', new PIXI.TextStyle({ fontFamily: 'Dotrice Regular', fontSize: 50 }));
const text4 = new PIXI.Text('Crosterian.woff2', new PIXI.TextStyle({ fontFamily: 'Crosterian', fontSize: 50 }));

text2.y = 150;
text3.y = 300;
text4.y = 450;

app.stage.addChild(text1);
app.stage.addChild(text2);
app.stage.addChild(text3);
app.stage.addChild(text4);
});
- + \ No newline at end of file diff --git a/examples/text/pixi-text.html b/examples/text/pixi-text.html index f33d40a9b..5e1404f76 100644 --- a/examples/text/pixi-text.html +++ b/examples/text/pixi-text.html @@ -9,13 +9,13 @@ - +
Skip to main content

Pixi Text

import * as PIXI from 'pixi.js';

const app = new PIXI.Application({ background: '#1099bb', resizeTo: window });

document.body.appendChild(app.view);

const basicText = new PIXI.Text('Basic text in pixi');

basicText.x = 50;
basicText.y = 100;

app.stage.addChild(basicText);

const style = new PIXI.TextStyle({
fontFamily: 'Arial',
fontSize: 36,
fontStyle: 'italic',
fontWeight: 'bold',
fill: ['#ffffff', '#00ff99'], // gradient
stroke: '#4a1850',
strokeThickness: 5,
dropShadow: true,
dropShadowColor: '#000000',
dropShadowBlur: 4,
dropShadowAngle: Math.PI / 6,
dropShadowDistance: 6,
wordWrap: true,
wordWrapWidth: 440,
lineJoin: 'round',
});

const richText = new PIXI.Text('Rich text with a lot of options and across multiple lines', style);

richText.x = 50;
richText.y = 220;

app.stage.addChild(richText);

const skewStyle = new PIXI.TextStyle({
fontFamily: 'Arial',
dropShadow: true,
dropShadowAlpha: 0.8,
dropShadowAngle: 2.1,
dropShadowBlur: 4,
dropShadowColor: '0x111111',
dropShadowDistance: 10,
fill: ['#ffffff'],
stroke: '#004620',
fontSize: 60,
fontWeight: 'lighter',
lineJoin: 'round',
strokeThickness: 12,
});

const skewText = new PIXI.Text('SKEW IS COOL', skewStyle);

skewText.skew.set(0.65, -0.3);
skewText.anchor.set(0.5, 0.5);
skewText.x = 300;
skewText.y = 480;

app.stage.addChild(skewText);
- + \ No newline at end of file diff --git a/examples/text/web-font.html b/examples/text/web-font.html index b9f8cd69b..521d8437d 100644 --- a/examples/text/web-font.html +++ b/examples/text/web-font.html @@ -9,13 +9,13 @@ - +
Skip to main content

Web Font

import * as PIXI from 'pixi.js';

const app = new PIXI.Application({ background: '#1099bb', resizeTo: window });

document.body.appendChild(app.view);

// Load them google fonts before starting...
window.WebFontConfig = {
google: {
families: ['Snippet'],
},
active()
{
init();
},
};

/* eslint-disable */
// include the web-font loader script
(function() {
const wf = document.createElement('script');
wf.src = `${document.location.protocol === 'https:' ? 'https' : 'http'
}://ajax.googleapis.com/ajax/libs/webfont/1/webfont.js`;
wf.type = 'text/javascript';
wf.async = 'true';
const s = document.getElementsByTagName('script')[0];
s.parentNode.insertBefore(wf, s);
}());
/* eslint-enabled */

function init() {
// create some white text using the Snippet webfont
const textSample = new PIXI.Text(
'PixiJS text using the\ncustom "Snippet" Webfont', {
fontFamily: 'Snippet',
fontSize: 50,
fill: 'white',
align: 'left',
}
);
textSample.position.set(50, 200);
app.stage.addChild(textSample);
}
- + \ No newline at end of file diff --git a/examples/textures/gradient-basic.html b/examples/textures/gradient-basic.html index 0e3906037..47f7ac624 100644 --- a/examples/textures/gradient-basic.html +++ b/examples/textures/gradient-basic.html @@ -9,13 +9,13 @@ - +
Skip to main content

Gradient Basic

import * as PIXI from 'pixi.js';

// This demo uses canvas2d gradient API
// https://developer.mozilla.org/en-US/docs/Web/API/CanvasRenderingContext2D/createLinearGradient

const app = new PIXI.Application({ antialias: true, resizeTo: window });

document.body.appendChild(app.view);

function createGradTexture()
{
// adjust it if somehow you need better quality for very very big images
const quality = 256;
const canvas = document.createElement('canvas');

canvas.width = quality;
canvas.height = 1;

const ctx = canvas.getContext('2d');

// use canvas2d API to create gradient
const grd = ctx.createLinearGradient(0, 0, quality, 0);

grd.addColorStop(0, 'rgba(255, 255, 255, 0.0)');
grd.addColorStop(0.3, 'cyan');
grd.addColorStop(0.7, 'red');
grd.addColorStop(1, 'green');

ctx.fillStyle = grd;
ctx.fillRect(0, 0, quality, 1);

return PIXI.Texture.from(canvas);
}

const gradTexture = createGradTexture();

const sprite = new PIXI.Sprite(gradTexture);

sprite.position.set(100, 100);
sprite.rotation = Math.PI / 8;
sprite.width = 500;
sprite.height = 50;
app.stage.addChild(sprite);
- + \ No newline at end of file diff --git a/examples/textures/gradient-resource.html b/examples/textures/gradient-resource.html index ff7873a6d..bf4b74b06 100644 --- a/examples/textures/gradient-resource.html +++ b/examples/textures/gradient-resource.html @@ -9,13 +9,13 @@ - +
Skip to main content

Gradient Resource

import * as PIXI from 'pixi.js';

// PixiJS V5 Texture-Resource API + canvas2d gradient API + WebGL texImage2D
// Look here for advanced upload function:
// https://github.com/pixijs/pixi.js/blob/dev/packages/core/src/textures/resources/BaseImageResource.js#L54

class GradientResource extends PIXI.Resource
{
constructor()
{
// pass width and height. (0,0) if we dont know yet
// gradient needs only 1 pixel height
super(256, 1);
}

upload(renderer, baseTexture, glTexture)
{
const { width } = this; // default size or from baseTexture?
const { height } = this; // your choice.

// temporary canvas, we dont need it after texture is uploaded to GPU
const canvas = document.createElement('canvas');

canvas.width = width;
canvas.height = height;

const ctx = canvas.getContext('2d');

const grd = ctx.createLinearGradient(0, 0, width, 0);

grd.addColorStop(0, 'rgba(255, 255, 255, 0.0)');
grd.addColorStop(0.3, 'cyan');
grd.addColorStop(0.7, 'red');
grd.addColorStop(1, 'green');

ctx.fillStyle = grd;
ctx.fillRect(0, 0, width, height);

// This info ios usseful if upload happens second time
// Some people use that to track used memory
glTexture.width = width;
glTexture.height = height;

// PURE WEBGL CALLS - that's what its all about.
// PixiJS cant wrap all that API, we give you acceess to it!
const { gl } = renderer;

gl.pixelStorei(gl.UNPACK_PREMULTIPLY_ALPHA_WEBGL, baseTexture.premultiplyAlpha);
gl.texImage2D(baseTexture.target, 0, baseTexture.format, baseTexture.format, baseTexture.type, canvas);

return true;
}
}

const app = new PIXI.Application({ antialias: true, resizeTo: window });

document.body.appendChild(app.view);

const gradBaseTexture = new PIXI.BaseTexture(new GradientResource());
// Here you can fake baseTexture size to avoid resizing all sprites
// There can be multiple baseTextures per gradient, but be careful:
// resource will spawn more glTextures!

gradBaseTexture.setSize(500, 50);

const gradTexture = new PIXI.Texture(gradBaseTexture);

const sprite = new PIXI.Sprite(gradTexture);

sprite.position.set(100, 100);
sprite.rotation = Math.PI / 8;
app.stage.addChild(sprite);
- + \ No newline at end of file diff --git a/examples/textures/render-texture-advanced.html b/examples/textures/render-texture-advanced.html index 6ef771ac0..a79c4da62 100644 --- a/examples/textures/render-texture-advanced.html +++ b/examples/textures/render-texture-advanced.html @@ -9,13 +9,13 @@ - +
Skip to main content

Render Texture Advanced

import * as PIXI from 'pixi.js';

const app = new PIXI.Application({ resizeTo: window });

document.body.appendChild(app.view);

const stageSize = {
width: app.screen.width,
height: app.screen.height,
};

// create two render textures... these dynamic textures will be used to draw the scene into itself
let renderTexture = PIXI.RenderTexture.create(stageSize);
let renderTexture2 = PIXI.RenderTexture.create(stageSize);
const currentTexture = renderTexture;

// create a new sprite that uses the render texture we created above
const outputSprite = new PIXI.Sprite(currentTexture);

// align the sprite
outputSprite.x = 400;
outputSprite.y = 300;
outputSprite.anchor.set(0.5);

// add to stage
app.stage.addChild(outputSprite);

const stuffContainer = new PIXI.Container();

stuffContainer.x = 400;
stuffContainer.y = 300;

app.stage.addChild(stuffContainer);

// create an array of image ids..
const fruits = [
'https://pixijs.com/assets/rt_object_01.png',
'https://pixijs.com/assets/rt_object_02.png',
'https://pixijs.com/assets/rt_object_03.png',
'https://pixijs.com/assets/rt_object_04.png',
'https://pixijs.com/assets/rt_object_05.png',
'https://pixijs.com/assets/rt_object_06.png',
'https://pixijs.com/assets/rt_object_07.png',
'https://pixijs.com/assets/rt_object_08.png',
];

// create an array of items
const items = [];

// now create some items and randomly position them in the stuff container
for (let i = 0; i < 20; i++)
{
const item = PIXI.Sprite.from(fruits[i % fruits.length]);

item.x = Math.random() * 400 - 200;
item.y = Math.random() * 400 - 200;
item.anchor.set(0.5);
stuffContainer.addChild(item);
items.push(item);
}

// used for spinning!
let count = 0;

app.ticker.add(() =>
{
for (let i = 0; i < items.length; i++)
{
// rotate each item
const item = items[i];

item.rotation += 0.1;
}

count += 0.01;

// swap the buffers ...
const temp = renderTexture;

renderTexture = renderTexture2;
renderTexture2 = temp;

// set the new texture
outputSprite.texture = renderTexture;

// twist this up!
stuffContainer.rotation -= 0.01;
outputSprite.scale.set(1 + Math.sin(count) * 0.2);

// render the stage to the texture
// the 'true' clears the texture before the content is rendered
app.renderer.render(app.stage, {
renderTexture: renderTexture2,
clear: false,
});
});
- + \ No newline at end of file diff --git a/examples/textures/render-texture-basic.html b/examples/textures/render-texture-basic.html index bcb9cc0e8..cf35be28b 100644 --- a/examples/textures/render-texture-basic.html +++ b/examples/textures/render-texture-basic.html @@ -9,13 +9,13 @@ - +
Skip to main content

Render Texture Basic

import * as PIXI from 'pixi.js';

const app = new PIXI.Application({ background: '#1099bb', resizeTo: window });

document.body.appendChild(app.view);

const container = new PIXI.Container();

app.stage.addChild(container);

const texture = PIXI.Texture.from('https://pixijs.com/assets/bunny.png');

for (let i = 0; i < 25; i++)
{
const bunny = new PIXI.Sprite(texture);

bunny.x = (i % 5) * 30;
bunny.y = Math.floor(i / 5) * 30;
bunny.rotation = Math.random() * (Math.PI * 2);
container.addChild(bunny);
}

const rt = PIXI.RenderTexture.create({
width: 300,
height: 300,
scaleMode: PIXI.SCALE_MODES.LINEAR,
resolution: 1,
});

const sprite = new PIXI.Sprite(rt);

sprite.x = 450;
sprite.y = 60;
app.stage.addChild(sprite);

/*
* All the bunnies are added to the container with the addChild method
* when you do this, all the bunnies become children of the container, and when a container moves,
* so do all its children.
* This gives you a lot of flexibility and makes it easier to position elements on the screen
*/
container.x = 100;
container.y = 60;

app.ticker.add(() =>
{
app.renderer.render(container, { renderTexture: rt });
});
- + \ No newline at end of file diff --git a/examples/textures/texture-rotate.html b/examples/textures/texture-rotate.html index 07e2da4ba..eeb7d5004 100644 --- a/examples/textures/texture-rotate.html +++ b/examples/textures/texture-rotate.html @@ -9,13 +9,13 @@ - +
Skip to main content

Texture Rotate

import * as PIXI from 'pixi.js';

const app = new PIXI.Application({ resizeTo: window });

document.body.appendChild(app.view);

PIXI.Assets.load('https://pixijs.com/assets/flowerTop.png').then((texture) =>
{
// create rotated textures
const textures = [texture];
const D8 = PIXI.groupD8;

for (let rotate = 1; rotate < 16; rotate++)
{
const h = D8.isVertical(rotate) ? texture.frame.width : texture.frame.height;
const w = D8.isVertical(rotate) ? texture.frame.height : texture.frame.width;

const { frame } = texture;
const crop = new PIXI.Rectangle(texture.frame.x, texture.frame.y, w, h);
const trim = crop;
let rotatedTexture;

if (rotate % 2 === 0)
{
rotatedTexture = new PIXI.Texture(texture.baseTexture, frame, crop, trim, rotate);
}
else
{
// HACK to avoid exception
// PIXI doesnt like diamond-shaped UVs, because they are different in canvas and webgl
rotatedTexture = new PIXI.Texture(texture.baseTexture, frame, crop, trim, rotate - 1);
rotatedTexture.rotate++;
}
textures.push(rotatedTexture);
}

const offsetX = app.screen.width / 16 | 0;
const offsetY = app.screen.height / 8 | 0;
const gridW = app.screen.width / 4 | 0;
const gridH = app.screen.height / 5 | 0;

// normal rotations and mirrors
for (let i = 0; i < 16; i++)
{
// create a new Sprite using rotated texture
const dude = new PIXI.Sprite(textures[i < 8 ? i * 2 : (i - 8) * 2 + 1]);

dude.scale.x = 0.5;
dude.scale.y = 0.5;
// show it in grid
dude.x = offsetX + gridW * (i % 4);
dude.y = offsetY + gridH * (i / 4 | 0);
app.stage.addChild(dude);
const text = new PIXI.Text(`rotate = ${dude.texture.rotate}`, {
fontFamily: 'Courier New', fontSize: '12px', fill: 'white', align: 'left',
});

text.x = dude.x;
text.y = dude.y - 20;
app.stage.addChild(text);
}
});
- + \ No newline at end of file diff --git a/faq.html b/faq.html index be89dab6d..7b6ffb9ed 100644 --- a/faq.html +++ b/faq.html @@ -9,7 +9,7 @@ - + @@ -22,7 +22,7 @@ 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 ;)

Where do I get it?​

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.

How do I get started?​

Right here! Take a look through the Resources section for a wealth of information including documentation, forums, tutorials and the Goodboy blog.

Why should I use PixiJS?​

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.

Is PixiJS a game engine?​

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!

Who makes PixiJS?​

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.

I found a bug. What should I do?​

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.

- + \ No newline at end of file diff --git a/guides.html b/guides.html index 8eb5c9fcd..0d63998e2 100644 --- a/guides.html +++ b/guides.html @@ -9,13 +9,13 @@ - +
Skip to main content

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.

Other Resources​

As you explore the guides, you may find these resources valuable:

- + \ No newline at end of file diff --git a/guides/basics/architecture-overview.html b/guides/basics/architecture-overview.html index 265ad67bc..8e687b50f 100644 --- a/guides/basics/architecture-overview.html +++ b/guides/basics/architecture-overview.html @@ -9,13 +9,13 @@ - +
Skip to main content

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.

The Components​

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.

Major Components​

ComponentDescription
Renderer @pixi/coreThe 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/displayMain 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/loaderThe loader system provides tools for asynchronously loading resources such as images and audio files.
Ticker @pixi/tickerTickers 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/appThe 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/interactionPixiJS supports both touch and mouse-based interaction - making objects clickable, firing hover events, etc.
Accessibility @pixi/accessibilityWoven through our display system is a rich set of tools for enabling keyboard and screen-reader accessibility.
- + \ No newline at end of file diff --git a/guides/basics/getting-started.html b/guides/basics/getting-started.html index 43998f5fd..af20f568b 100644 --- a/guides/basics/getting-started.html +++ b/guides/basics/getting-started.html @@ -9,7 +9,7 @@ - + @@ -18,7 +18,7 @@ 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.

A Note About JavaScript​

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.

Components of a PixiJS Application​

OK! With those notes out of the way, let's get started. There are only a few steps required to write a PixiJS application:

Let's walk through them together.

The HTML File​

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:

<!doctype html>
<html>
<head>
</head>
<body>
<h1>Hello PixiJS</h1>
</body>
</html>

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.

Serving the File​

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.

Loading PixiJS​

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 <head> section of your index.html file:

<script src="https://pixijs.download/release/pixi.js"></script>

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.

Creating an Application​

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 <h1>Hello PixiJS</h1> with a script tag like so:

<script>
let app = new PIXI.Application({ width: 640, height: 360 });
</script>

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.

Adding the View to the DOM​

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.

Creating a Sprite​

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.

Adding the Sprite to the Stage​

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);

Writing an Update Loop​

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.

Putting It All Together​

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.

<!doctype html>
<html>
<head>
<script src="https://pixijs.download/release/pixi.min.js"></script>
</head>
<body>
<script>
// 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 the sprite and add it to the stage
let sprite = PIXI.Sprite.from('sample.png');
app.stage.addChild(sprite);

// Add a ticker callback to move the sprite back and forth
let elapsed = 0.0;
app.ticker.add((delta) => {
elapsed += delta;
sprite.x = 100.0 + Math.cos(elapsed/50.0) * 100.0;
});
</script>
</body>
</html>

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.

- + \ No newline at end of file diff --git a/guides/basics/render-loop.html b/guides/basics/render-loop.html index 08dcc8c65..c0163bf67 100644 --- a/guides/basics/render-loop.html +++ b/guides/basics/render-loop.html @@ -9,13 +9,13 @@ - +
Skip to main content

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.

Running Ticker Callbacks​

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.

Updating the Scene Graph​

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.

Rendering the Scene Graph​

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.

Frame Rates​

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.

Custom Render Loops​

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.

- + \ No newline at end of file diff --git a/guides/basics/scene-graph.html b/guides/basics/scene-graph.html index f1ec0a235..e08732a5c 100644 --- a/guides/basics/scene-graph.html +++ b/guides/basics/scene-graph.html @@ -9,13 +9,13 @@ - +
Skip to main content

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.

(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!)

Parents and Children​

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.

Render Order​

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.

Culling​

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.

Local vs Global Coordinates​

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.

Global vs Screen Coordinates​

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.

- + \ No newline at end of file diff --git a/guides/basics/what-pixijs-is-not.html b/guides/basics/what-pixijs-is-not.html index 453f93322..8b7f91788 100644 --- a/guides/basics/what-pixijs-is-not.html +++ b/guides/basics/what-pixijs-is-not.html @@ -9,13 +9,13 @@ - +
Skip to main content

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.

... A 3D Renderer​

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.

... A Mobile App​

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.

... A UI Library​

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.

... A Data Store​

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.

... An Audio Library​

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.

... A Development Environment​

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.

So Is PixiJS Right For Me?​

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.

- + \ No newline at end of file diff --git a/guides/basics/what-pixijs-is.html b/guides/basics/what-pixijs-is.html index 47bbfaeb9..2499054c1 100644 --- a/guides/basics/what-pixijs-is.html +++ b/guides/basics/what-pixijs-is.html @@ -9,13 +9,13 @@ - +
Skip to main content

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​

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.

... More Than Just Sprites​

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.

... WebGL Native​

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.

... Open Source​

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.

... Extensible​

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.

... Easy to Deploy​

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.

- + \ No newline at end of file diff --git a/guides/components/assets.html b/guides/components/assets.html index 9d14e8a2e..1ab54147b 100644 --- a/guides/components/assets.html +++ b/guides/components/assets.html @@ -9,7 +9,7 @@ - + @@ -23,7 +23,7 @@ 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!

Background loading​

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!

- + \ No newline at end of file diff --git a/guides/components/containers.html b/guides/components/containers.html index b17b060c4..ab08040f0 100644 --- a/guides/components/containers.html +++ b/guides/components/containers.html @@ -9,13 +9,13 @@ - +
Skip to main content

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.

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.

Masking​

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

Filtering​

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.

FilterDescription
AlphaFilter: @pixi/filter-alphaSimilar to setting alpha property, but flattens the Container instead of applying to children individually.
BlurFilter: @pixi/filter-blurApply a blur effect
ColorMatrixFilter: @pixi/filter-color-matrixA color matrix is a flexible way to apply more complex tints or color transforms (e.g., sepia tone).
DisplacementFilter: @pixi/filter-displacementDisplacement maps create visual offset pixels, for instance creating a wavy water effect.
FXAAFilter: @pixi/filter-fxaaBasic FXAA (Fast Approximate Anti-Aliasing) to create smoothing effect.
NoiseFilter: @pixi/filter-noiseCreate 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.

- + \ No newline at end of file diff --git a/guides/components/display-object.html b/guides/components/display-object.html index ee9253cba..f82cdffd6 100644 --- a/guides/components/display-object.html +++ b/guides/components/display-object.html @@ -9,13 +9,13 @@ - +
Skip to main content

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​

The most common attributes you'll use when laying out and animating content in PixiJS are provided by the DisplayObject class:

PropertyDescription
positionX- 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
rotationRotation is specified in radians, and turns an object clockwise (0.0 - 2 * Math.PI)
angleAngle is an alias for rotation that is specified in degrees instead of radians (0.0 - 360.0)
pivotPoint the object rotates around, in pixels - also sets origin for child objects
alphaOpacity from 0.0 (fully transparent) to 1.0 (fully opaque), inherited by children
scaleScale is specified as a percent with 1.0 being 100% or actual-size, and can be set independently for the x and y axis
skewSkew transforms the object in x and y similar to the CSS skew() function, and is specified in radians
visibleWhether the object is visible or not, as a boolean value - prevents updating and rendering object and children
renderableWhether the object should be rendered - when false, object will still be updated, but won't be rendered, doesn't affect children
- + \ No newline at end of file diff --git a/guides/components/graphics.html b/guides/components/graphics.html index 7854cf17d..d8b13d61d 100644 --- a/guides/components/graphics.html +++ b/guides/components/graphics.html @@ -9,13 +9,13 @@ - +
Skip to main content

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.

Graphics Is About Building - Not Drawing​

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.

Types of Primitives​

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

The Geometry List​

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.

Graphics For Display​

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.

Graphics as a Mask​

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.

Caveats and Gotchas​

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.

- + \ No newline at end of file diff --git a/guides/components/interaction.html b/guides/components/interaction.html index b5a985808..39a2c5297 100644 --- a/guides/components/interaction.html +++ b/guides/components/interaction.html @@ -9,13 +9,13 @@ - +
Skip to main content

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.

eventModeDescription
noneIgnores all interaction events, similar to CSS's pointer-events: none, good optimization for non-interactive children
passiveDoes 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)
autoDoes not emit events and but is hit tested if parent is interactive. Same as interactive = false in v7
staticEmit events and is hit tested. Same as interaction = true in v7, useful for objects like buttons that do not move.
dynamicEmits 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.

Event Types​

PixiJS supports the following event types:

Event TypeDescription
pointercancelFired when a pointer device button is released outside the display object that initially registered a pointerdown.
pointerdownFired when a pointer device button is pressed on the display object.
pointerenterFired when a pointer device enters the display object.
pointerleaveFired when a pointer device leaves the display object.
pointermoveFired when a pointer device is moved while over the display object.
globalpointermoveFired when a pointer device is moved, regardless of hit-testing the current object.
pointeroutFired when a pointer device is moved off the display object.
pointeroverFired when a pointer device is moved onto the display object.
pointertapFired when a pointer device is tapped twice on the display object.
pointerupFired when a pointer device button is released over the display object.
pointerupoutsideFired 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.
mouseenterFired when the mouse cursor enters the display object.
mouseleaveFired when the mouse cursor leaves the display object.
mousemove Fired when the mouse cursor is moved while over the display object.
globalmousemoveFired 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.
globaltouchmoveFired 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 twice 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.

Enabling Interaction​

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.

Checking if Object is Interactive​

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
}

Use Pointer Events​

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.

Optimization​

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,
}
});
- + \ No newline at end of file diff --git a/guides/components/sprite-sheets.html b/guides/components/sprite-sheets.html index 934b94796..826aae1dd 100644 --- a/guides/components/sprite-sheets.html +++ b/guides/components/sprite-sheets.html @@ -9,13 +9,13 @@ - +
Skip to main content

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​

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.

Doubly Efficient​

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.

Creating SpriteSheets​

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);
- + \ No newline at end of file diff --git a/guides/components/sprites.html b/guides/components/sprites.html index b9daff029..4e6c2721e 100644 --- a/guides/components/sprites.html +++ b/guides/components/sprites.html @@ -9,13 +9,13 @@ - +
Skip to main content

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.

Check out the sprite example code.

Using Sprites​

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.

Alpha, Tint and Blend Modes​

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.

Scale vs Width & Height​

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.

Pivot vs Anchor​

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.

- + \ No newline at end of file diff --git a/guides/components/text.html b/guides/components/text.html index 430885eb2..ce30a5005 100644 --- a/guides/components/text.html +++ b/guides/components/text.html @@ -9,13 +9,13 @@ - +
Skip to main content

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​

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.

The Text Object​

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.

Text Styles​

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.

Loading and Using Fonts​

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!');
});

Caveats and Gotchas​

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.

BitmapText​

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.

BitmapFont​

  • 3rd party solutions
  • BitmapFont.from auto-generation

Selecting the Right Approach​

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
- + \ No newline at end of file diff --git a/guides/components/textures.html b/guides/components/textures.html index 85406be2d..f5ffb6c07 100644 --- a/guides/components/textures.html +++ b/guides/components/textures.html @@ -9,13 +9,13 @@ - +
Skip to main content

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​

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

Serving the Image​

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.

Loading the Image​

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 <IMG> 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.

BaseTextures Own the Data​

Once the Loader has done its work, the loaded <IMG> 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.

Textures are a View on BaseTextures​

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.

Loading Textures​

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:

  1. Show a loading image
  2. Create a Loader
  3. Run all texture-based objects, add their textures to the loader
  4. Start the loader, and optionally update your loading image based on progress callbacks
  5. On loader completion, run all objects and use PIXI.Texture.from() to pull the loaded textures out of the texture cache
  6. Prepare your textures (optional - see below)
  7. 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.

Unloading Textures​

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.

Beyond Images​

As we alluded to above, you can make a Texture out of more than just images:

Video: Pass an HTML5 <VIDEO> element to PIXI.BaseTexture.from() to allow you to display video in your project. Since it's a texture, you can tint it, add filters, or even apply it to custom geometry.

Canvas: Similarly, you can wrap an HTML5 <CANVAS> element in a BaseTexture to let you use canvas's drawing methods to dynamically create a texture.

SVG: Pass in an <SVG> element or load a .svg URL, and PixiJS will attempt to rasterize it. For highly network-constrained projects, this can allow for beautiful graphics with minimal network load times.

RenderTexture: A more advanced (but very powerful!) feature is to build a Texture from a RenderTexture. This can allow for building complex geometry using a Geometry object, then baking that geometry down to a simple texture.

Each of these texture sources has caveats and nuances that we can't cover in this guide, but they should give you a feeling for the power of PixiJS's texture system.

Check out the render texture example code.

- + \ No newline at end of file diff --git a/guides/migrations/upgrading.html b/guides/migrations/upgrading.html index 2d2c5b174..643d9f4c2 100644 --- a/guides/migrations/upgrading.html +++ b/guides/migrations/upgrading.html @@ -9,13 +9,13 @@ - +
Skip to main content

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

If you are using any PixiJS community plugins, please make sure to uninstall those too:

npm uninstall pixi.js @pixi/particle-emitter @pixi/sound
npm install pixi.js @pixi/particle-emitter @pixi/sound
- + \ No newline at end of file diff --git a/guides/migrations/v5.html b/guides/migrations/v5.html index 1a04c2731..b17131069 100644 --- a/guides/migrations/v5.html +++ b/guides/migrations/v5.html @@ -9,13 +9,13 @@ - +
Skip to main content

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​

PixiJS v5 has made WebGL the first-class renderer and made CanvasRenderer to be second-class. Functionally, there's not much that changed from v4, but there are a bunch of subtle internal naming changes which could trip-up some developers upgrading to v5. For instance:

  • WebGLRenderer becomes Renderer
  • renderWebGL becomes render (in DisplayObject, Sprite, Container, etc)
  • _renderWebGL becomes _render (in DisplayObject, Container, etc)

If you created a plugin or project that previously used render on a Container (see #5510), this will probably cause your project to not render correctly. Please consider renaming your user-defined render to something else. In most other cases, you'll get a deprecation warning trying to invoke WebGL-related classes or methods, e.g., new PIXI.WebGLRenderer().

Renderer Parameters​

Specifying options as a third parameter in Renderer constructor is officially dropped (same with PIXI.Application, PIXI.autoDetectRenderer & PIXI.CanvasRenderer). In v4 we supported two function signatures, but in v5 we dropped width, height, options signature. Please add width and height to options.

const renderer = new PIXI.Renderer(800, 600, { transparent: true }); // bad
const renderer = new PIXI.Renderer({ width: 800, height: 600, transparent: true }); // good
  • Note: Adding transparent: true in Renderer or Application constructor options might help with strange artifacts on some devices, but it might reduce FPS. It's much better than preserveDrawingBuffer: true.

  • If you need the v4 default behavior of resizing the canvas using css pixels, add autoDensity: true to the options.

Not everything went to params. To enable WebGL1 even if WebGL2 is available, use

PIXI.settings.PREFER_ENV = PIXI.ENV.WEBGL;

Mesh, Plane, Rope​

PixiJS v5 introduces a new class called PIXI.Mesh. This allows overriding the default shader and the ability to add more attributes to geometry. For example, you can add colors to vertices.

The old v4 Mesh class has moved from PIXI.mesh.Mesh to PIXI.SimpleMesh, it extends PIXI.Mesh.

PIXI.mesh.Rope, PIXI.mesh.Plane, PIXI.mesh.NineSlicePlane have moved to PIXI.SimpleRope, PIXI.SimplePlane and PIXI.NineSlicePlane respectively.

If you used custom shaders or generated meshes in v4, you might be impacted by these changes in v5.

PIXI.SimpleMesh fields vertices, uvs, indices are wrapped inside mesh.geometry attribute buffers. For example, this is how access to buffers provided through mesh.uvBuffer property:

get uvBuffer()
{
return this.geometry.buffers[1];
}

The indices property shortcut is also missing, but you can access the data inside mesh.geometry.indexBuffer.

You can override buffer data, and notify it that data was changed, in this case buffer will be uploaded to GPU lazily. Previously in v4 mesh had several flags that indicated which attributes have to be updated and their names confused people.

Graphics Holes​

Drawing holes in Graphics was very limited in v4. This only supported non-Shape drawing, like using lineTo, bezierCurveTo, etc. In v5, we improved the hole API by supporting shapes. Unfortunately, there's no deprecation strategy to support the v4 API. For instance, in v4:

const graphic = new PIXI.Graphics()
.beginFill(0xff0000)
.moveTo(0, 0)
.lineTo(100, 0)
.lineTo(100, 100)
.lineTo(0, 100)
.moveTo(10, 10)
.lineTo(90, 10)
.lineTo(90, 90)
.lineTo(10, 90)
.addHole();

Live example in v4.x

In v5, Graphics has simplified and the API changed from addHole to beginHole and endHole.

const graphic = new PIXI.Graphics()
.beginFill(0xff0000)
.drawRect(0, 0, 100, 100)
.beginHole()
.drawCircle(50, 50, 30)
.endHole();

Live example in dev

Filter Padding​

In v4 filters had a default padding of 4 and in v5 this has been changed to a default of 0. This can cause some filters to look broken when used. To fix this issue simply add some padding to the filters you create.

// Glow filter from https://github.com/pixijs/pixi-filters
const filter = new PIXI.filters.GlowFilter();
filter.padding = 4;

Some filters, like BlurFilter, automatically calculate the padding so changes may not be necessary.

Filter Default Vertex Shader​

We reorganized all uniforms dedicated to coordinate system transforms, and renamed them. If your filter doesn't work anymore, check if you use default vertex shader. In that case, you can use old v4 vertex shader code.

All changes are explained in [[Creating Filters|v5-Creating-filters]]

Enable Mipmapping for RenderTexture​

Previously, you may have ended up with code like this in v4 (specifically if you saw Ivan's comment/JSFiddle):

const renderer = PIXI.autoDetectRenderer();
renderer.bindTexture(baseRenderTex, false, 0);
const glTex = baseRenderTex._glTextures[renderer.CONTEXT_UID];
glTex.enableMipmap(); // this is what actually generates mipmaps in WebGL
glTex.enableLinearScaling(); // this is what tells WebGL to USE those mipmaps

In v5, this code is no longer needed.

BaseTexture Resources​

One of the newest features in v5 is that we decoupled all the asset-specific functionality from BaseTexture. We created a new system called "resources" and each BaseTexture now has a resource that wraps some specific asset type. For instance: VideoResource, SVGResource, ImageResource, CanvasResource. In the future, we hope to be able to add other resource types. If there were asset-specific methods or properties being called before, these will probably be on baseTexture.resource.

Also, we removed all of the from* methods from BaseTexture, so you just can call BaseTexture.from and pass in whatever resource. Please see docs for more information about from.

const canvas = document.createElement('canvas');
const baseTexture = PIXI.BaseTexture.from(canvas);

That API also allows to use pure WebGL and 2d context calls, see the gradient example.

BaseTexture.source​

Has been moved to baseTexture.resource.source, moved into resource corresponding to the baseTexture. baseTexture.resource does not exist for RenderTexture, and source does not exist for resources that dont have source.

Graphics Interaction​

If you use transparent interactive graphics trick, make sure that you use specify alpha=0 for all element, not for its parts. How PixiJS deals with shapes that have alpha=0 is considered undefined behaviour. We might change it back, but we have no guarantees about it.

graphics.beginFill(0xffffff, 0.0); //bad
graphics.alpha = 0; //good

πŸ“¦ Publishing Changes​

Canvas Becomes Legacy​

Since WebGL and WebGL2 are now first-class, we have removed the canvas-based fallback from the default pixi.js package. If you need CanvasRenderer, you should switch to use pixi.js-legacy instead.

import * as PIXI from "pixi.js";
// Will NOT return CanvasRenderer because canvas-based
// functionality was removed from "pixi.js"
const renderer = PIXI.autoDetectRenderer(); // return PIXI.Renderer or throws error

Instead, use the legacy bundle to have access to the canvas rendering.

import * as PIXI from "pixi.js-legacy";
const renderer = PIXI.autoDetectRenderer(); // returns PIXI.Renderer or PIXI.CanvasRenderer

Bundling Changes​

If you're using Rollup, Parcel or another bundler to add PixiJS into your project there are a few subtle changes when moving to v5. Namely, the global PIXI object is no longer created automatically. This was removed from bundling for two purpose: 1) to improve tree-shaking for bundlers, and 2) for security purpose by protecting PIXI.

This is no longer a valid way to import:

import "pixi.js";
const renderer = PIXI.autoDetectRenderer(); // INVALID! No more global.PIXI!

Instead, you should import as a namespace or individual elements:

import * as PIXI from "pixi.js";
const renderer = PIXI.autoDetectRenderer();

// or even better:
import { autoDetectRenderer } from "pixi.js";
const renderer = autoDetectRenderer();

Lastly, some 3rd-party plugins maybe expecting window.PIXI, so you might have to explicitly expose the global like this, however this is not recommended.

import * as PIXI from 'pixi.js';
window.PIXI = PIXI; // some bundlers might prefer "global" instead of "window"

Webpack​

When Webpack and 3rd-party plugins, like pixi-spine, you might have difficulties building the global PIXI object resulting in a runtime error ReferenceError: PIXI is not defined. Usually this can be resolved by using Webpack shimming globals.

For instance, here's your import code:

import * as PIXI from 'pixi.js';
import 'pixi-spine'; // or other plugins that need global 'PIXI' to be defined first

Add a plugins section to your webpack.config.js to let know Webpack that the global PIXI variable make reference to pixi.js module. For instance:

const webpack = require('webpack');

module.exports = {
entry: '...',
output: {
...
},
plugins: [
new webpack.ProvidePlugin({
PIXI: 'pixi.js'
})
]
}
- + \ No newline at end of file diff --git a/guides/migrations/v6.html b/guides/migrations/v6.html index 644b4cfa6..985b21914 100644 --- a/guides/migrations/v6.html +++ b/guides/migrations/v6.html @@ -9,13 +9,13 @@ - +
Skip to main content

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:

{
"compilerOptions": {
"moduleResolution": "node",
// Required for importing 3rd-party dependencies like EventEmitter3
"esModuleInterop": true
}
}

Mesh Internals​

If you ever overrode Mesh._renderDefault to take into account more uniforms like this: v5 Reference

if (shader.program.uniformData.translationMatrix)
{
shader.uniforms.translationMatrix = this.transform.worldTransform.toArray(true);
}

Remove the if, leave the contents, otherwise you might not get correct sync uniform for translationMatrix, or even worse - get null pointer. v6 Reference.

shader.uniforms.translationMatrix = this.transform.worldTransform.toArray(true);
- + \ No newline at end of file diff --git a/guides/migrations/v7.html b/guides/migrations/v7.html index f4db067f2..2a9b4c96a 100644 --- a/guides/migrations/v7.html +++ b/guides/migrations/v7.html @@ -9,7 +9,7 @@ - + @@ -17,7 +17,7 @@
Skip to main content

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.

πŸ—‘οΈ Remove Polyfills​

We removed the bundled polyfills such as requestAnimationFrame and Promise. These things are widely available in browsers now. If projects require them, developers should include the polyfills they need for backward-compatibility. Please check out polyfill.io.

πŸ’¬ Output ES2020 (modules) and ES2017 (browser)​

PixiJS historically only published ES5 (no classes!). A new output standard allows us to use ES2017 features that previously we couldn't use (e.g., String.prototype.startsWith, Array.prototype.contains, etc). Not only does it make the code more readable, but the output looks nicer as well. For modules we are outputting ES2020, which contains syntax like nullish coalescing (??). If your project needs to have backward compatibility, you can use Babel to transpile or polyfill.

🐭 Replaces InteractionManager with EventSystem​

InteractionManager was getting complex and difficult to maintain. Few core team members understood the code. We decided to move to FederatedEvents, which is concise, better aligned with the DOM, and supports things like bubbling. The good news, is you shouldn't have to change code, as it is largely a drop-in replacement. We added addEventListener and removeEventListener APIs to DisplayObject which have the same DOM signature and can be used instead of on and off.

πŸ“¦ Replaces Loader with Assets​

Similarly, we've been wanting to remove the Loader because of its legacy approach (e.g., XMLHttpRequest). This was forked from resource-loader that has been with PixiJS for a long time. The original design inspiration for Loader was driven largely by Flash/AS3, which now seem dated. There were a few things we wanted out of a new iteration: static loading, loading with Workers, background loading, Promise-based, fewer layers of caching. Here's a quick example of how this will change:

import { Loader, Sprite } from 'pixi.js';

const loader = new Loader();
loader.add('background', 'path/to/assets/background.jpg');
loader.load((loader, resources) => {
const image = Sprite.from(resources.background.texture);
});

Now becomes:

import { Assets, Sprite } from 'pixi.js';

const texture = await Assets.load('path/to/assets/background.jpg');
const image = Sprite.from(texture);

🀝 Abandon the use of peerDependencies​

PixiJS heavily uses peerDependencies in the package.json within each package. This design choice has plagued Pixi with many issues. It's a breaking change to remove, so now was a good time. We have decided to completely remove peerDependencies, instead opting for nothing. This should make installing and upgrading pixi.js much easier. We are working on updating our tooling for composing a custom version with packages. Edit: As of 7.2.0, we have reverted this change to keep compatibility with some module-based CDNs.

πŸ‘‚ Other Changes​

  • Browser builds have been removed for all packages, with the exception of pixi.js and pixi.js-legacy.
  • Removes Graphics.nextRoundedRectBehavior this is now the default behavior
  • Removes Text.nextLineHeightBehavior this is now the default behavior
  • AbstractBatchRenderer and BatchPluginFactory has been removed. Either extends BatchRenderer or use setShaderGenerator on the default BatchRenderer, (e.g., renderer.plugins.batch)
  • BatchRenderer is installed by default in @pixi/core, no need to Renderer.registerPlugin('batch', BatchRenderer) anymore

Exports from @pixi/core​

The @pixi/core package now depends and re-exports the following packages.

  • @pixi/math
  • @pixi/contants
  • @pixi/utils
  • @pixi/runner
  • @pixi/settings
  • @pixi/ticker

While some packages will still work when installed directly, others will not, since by installing them alongside @pixi/core you will be effectively importing two copies of the same code.Β  This will lead to errors where changing settings from @pixi/settings doesn't do anything since @pixi/core has its own version of that package. It is recommended that you uninstall these from your project and use @pixi/core instead.

import { Rectangle } from '@pixi/math';
import { settings } from '@pixi/settings';
import { ALPHA_MODES } from '@pixi/constants';
import { string2hex } from '@pixi/utils';

Now becomes:

import { Rectangle, settings, ALPHA_MODES, utils } from '@pixi/core';

const { string2hex } = utils;

Extract and Prepare Systems​

Extract and prepare plugins have been converted to Renderer "systems".

renderer.plugins.extract
renderer.plugins.prepare

Now becomes:

renderer.extract
renderer.prepare

Extensions Self-Install​

Extensions now install themselves, so you should only need to import the class in order to use. For example, in v6:

import { AccessibilityManager } from '@pixi/accessibility';
import { extensions } from '@pixi/core';
extensions.add(AccessibilityManager);

Now becomes:

import '@pixi/accessibility';

Using hitTest with Events​

With the new events system, one of the common APIs that changed is `hitTest.

import {Application} from 'pixi.js';

const app = new Application();
app.renderer.plugins.interaction.hitTest({x, y});

Now becomes:

import {Application, EventBoundary} from 'pixi.js';

const app = new Application();
const boundary = new EventBoundary(app.stage);
boundary.hitTest(x, y);

New Async Extract Methods​

The following methods are now async and return a Promise.

  • CanvasExtract.base64()
  • CanvasExtract.image()
  • Extract.base64()
  • Extract.image()
import {Application, EventBoundary} from 'pixi.js';

const app = new Application();
const dataUri = app.renderer.extract.base64();

Now becomes:

import {Application, EventBoundary} from 'pixi.js';

const app = new Application();
const dataUri = await app.renderer.extract.base64();

Interactive Move Events​

Interaction events in PixiJS now behave like the DOM in v7. This was intentional to align around behavior that would be familiar with developers, but obviously impacts the behavior with pointermove, mousemove, and touchmove.

Like the DOM, move events are now local. This means that if you are outside the bounds of the object, you will not receive a move event. Generally, you should consider adding move events to the stage or parent instead of the DisplayObject itself.

Working example: https://jsfiddle.net/bigtimebuddy/spnv4wm6/

Interactive Property Handlers are Removed​

Property-based handlers were removed from events. This was a feature of the old InteractionManager. For instance:

sprite.pointertap = () => {
// handler the pointertap
};

Now becomes:

sprite.on('pointertap', () => {
// handler the pointertap
});

Property buttonMode has been removed​

The property buttonMode was a convenience for toggling the cursor property between pointer and null. It has now been removed.

sprite.buttonMode = true;

Now becomes:

sprite.cursor = 'pointer';

If you would like to re-add this functionality, you can patch DisplayObject's prototype:

import { DisplayObject } from 'pixi.js';

Object.defineProperty(DisplayObject.prototype, 'buttonMode', {
get() { return this.cursor === 'pointer'; },
set(value) { this.cursor = value ? 'pointer' : null; },
});

☝️ Suggestions for Upgrading​

If you're planning on transitioning your code from v6, it would be helpful to implement some of the more dramatic changes in v6 first before upgrading to v7:

import { InteractionManager, extensions, Application } from 'pixi.js';
import { EventSystem } from '@pixi/events';

// Uninstall interaction
extensions.remove(InteractionManager);

// Create the renderer or application
const app = new Application();

// Install events
app.renderer.addSystem(EventSystem, 'events');
  • Switch to the Assets package by installing @pixi/assets and swapping for Loader. For more information on implementing Assets, see this guide.
  • Set Graphics.nextRoundedRectBehavior = true, this uses arcs for corner radius instead of bezier curves.
  • Set Text.nextLineHeightBehavior = true, this defaults to the DOM-like behavior for line height.

πŸ—οΈ Plugin Supported​

PluginCompatiblePlugin Version Supported
PixiJS Soundβœ…v5.0.0+
PixiJS HTMLTextβœ…v3.0.0+
PixiJS Filtersβœ…v5.0.0+
PixiJS GIFβœ…v2.0.0+
PixiJS Spineβœ…v4.0.0+
PixiJS Particle Emitterβœ…v5.0.8+
PixiJS Animate❌
PixiJS Layersβœ…v2.0.0+
PixiJS Lightsβœ…v4.0.0+
PixiJS Graphics Smoothβœ…v1.0.0+
PixiJS Tilemap❌
- + \ No newline at end of file diff --git a/guides/production/performance-tips.html b/guides/production/performance-tips.html index 1c5507269..5362416c1 100644 --- a/guides/production/performance-tips.html +++ b/guides/production/performance-tips.html @@ -9,13 +9,13 @@ - +
Skip to main content

Performance Tips

General​

  • Only optimize when you need to! PixiJS can handle a fair amount of content off the bat
  • Be mindful of the complexity of your scene. The more objects you add the slower things will end up
  • Order can help, for example sprite / graphic / sprite / graphic is slower than sprite / sprite / graphic / graphic
  • Some older mobile devices run things a little slower. Passing in the option useContextAlpha: false and antialias: false to the Renderer or Application can help with performance
  • Culling is disabled by default as it's often better to do this at an application level or set objects to be cullable = true. If you are GPU-bound it will improve performance; if you are CPU-bound it will degrade performance

Sprites​

  • Use Spritesheets where possible to minimize total textures
  • Sprites can be batched with up to 16 different textures (dependent on hardware)
  • This is the fastest way to render content
  • On older devices use smaller low resolution textures
  • Add the extention @0.5x.png to the 50% scale-down spritesheet so PixiJS will visually-double them automatically
  • Draw order can be important

Graphics​

  • Graphics objects are fastest when they are not modified constantly (not including the transform, alpha or tint!)
  • Graphics objects are batched when under a certain size (100 points or smaller)
  • Small Graphics objects are as fast as Sprites (rectangles, triangles)
  • Using 100s of graphics complex objects can be slow, in this instance use sprites (you can create a texture)

Texture​

  • Textures are automatically managed by a Texture Garbage Collector
  • You can also manage them yourself by using texture.destroy()
  • If you plan to destroy more than one at once add a random delay to their destruction to remove freezing
  • Delay texture destroy if you plan to delete a lot of textures yourself

Text​

  • Avoid changing it on every frame as this can be expensive (each time it draws to a canvas and then uploads to GPU)
  • Bitmap Text gives much better performance for dynamically changing text
  • Text resolution matches the renderer resolution, decrease resolution yourself by setting the resolution property, which can consume less memory

Masks​

  • Masks can be expensive if too many are used: e.g., 100s of masks will really slow things down
  • Axis-aligned Rectangle masks are the fastest (as the use scissor rect)
  • Graphics masks are second fastest (as they use the stencil buffer)
  • Sprite masks are the third fastest (they uses filters). They are really expensive. Do not use too many in your scene!

Filters​

  • Release memory: displayObject.filters = null
  • If you know the size of them: displayObject.filterArea = new PIXI.Rectangle(x,y,w,h). This can speed things up as it means the object does not need to be measured
  • Filters are expensive, using too many will start to slow things down!

BlendModes​

  • Different blend modes will cause batches to break (de-optimize)
  • SceenSprite / NormalSprite / SceenSprite / NormalSprite would be 4 draw calls
  • SceenSprite / SceenSprite / NormalSprite / NormalSprite would be 2 draw calls

CacheAsBitmap​

  • Setting to true turns an object into a Sprite by caching it as a Texture
  • It has a one time cost when it is activated as it draws the object to a Texture
  • Avoid changing this on elements frequently
  • If you have a complicated item that has lots of sprites / filters AND does not move then this will speed up rendering!
  • Do not need apply to sprites as they are already Textures
  • Do not use if the object where its children are constantly changing as this will slow things down

Events​

  • If an object has no interactive children use interactiveChildren = false. The event system will then be able to avoid crawling through the object
  • Setting hitArea = new PIXI.Rectangle(x,y,w,h) as above should stop the event system from crawling through the object
- + \ No newline at end of file diff --git a/index.html b/index.html index 1ff44f504..6c28c093c 100644 --- a/index.html +++ b/index.html @@ -9,13 +9,13 @@ - +
Skip to main content

The HTML5 Creation Engine

Create beautiful digital content with the fastest, most flexible 2D WebGL renderer.

A mature solution for hundreds of global brands

- + \ No newline at end of file diff --git a/playground.html b/playground.html index b0bf40e4d..b8abf3b89 100644 --- a/playground.html +++ b/playground.html @@ -9,13 +9,13 @@ - +
Skip to main content
- + \ No newline at end of file diff --git a/search-index-blog.json b/search-index-blog.json index 1e9203638..c82032749 100644 --- a/search-index-blog.json +++ b/search-index-blog.json @@ -1 +1 @@ -[{"documents":[{"i":1,"t":"","u":"/blog/archive","b":["Blog"]},{"i":2,"t":"Introducing the PixiJS Universe!","u":"/blog/pixi-universe","b":["Blog"]},{"i":58,"t":"PixiJS v8 Beta! πŸŽ‰","u":"/blog/pixi-v8-beta","b":["Blog"]}],"index":{"version":"2.3.9","fields":["t"],"fieldVectors":[["t/1",[]],["t/2",[0,0.878,1,0.421,2,0.878]],["t/58",[1,0.364,3,0.759,4,0.759,5,0.759]]],"invertedIndex":[["",{"_index":5,"t":{"58":{"position":[[16,2]]}}}],["beta",{"_index":4,"t":{"58":{"position":[[10,5]]}}}],["introducing",{"_index":0,"t":{"2":{"position":[[0,11]]}}}],["pixijs",{"_index":1,"t":{"2":{"position":[[16,6]]},"58":{"position":[[0,6]]}}}],["universe",{"_index":2,"t":{"2":{"position":[[23,9]]}}}],["v8",{"_index":3,"t":{"58":{"position":[[7,2]]}}}]],"pipeline":["stemmer"]}},{"documents":[{"i":4,"t":"Phase 1​","u":"/blog/pixi-universe","h":"#phase-1","p":2},{"i":6,"t":"PixiJS Website​","u":"/blog/pixi-universe","h":"#pixijs-website","p":2},{"i":8,"t":"PixiJS React​","u":"/blog/pixi-universe","h":"#pixijs-react","p":2},{"i":10,"t":"PixiJS Open Games​","u":"/blog/pixi-universe","h":"#pixijs-open-games","p":2},{"i":12,"t":"PixiJS UI & PixiJS Layout​","u":"/blog/pixi-universe","h":"#pixijs-ui--pixijs-layout","p":2},{"i":14,"t":"AssetPack​","u":"/blog/pixi-universe","h":"#assetpack","p":2},{"i":16,"t":"Phase 2​","u":"/blog/pixi-universe","h":"#phase-2","p":2},{"i":18,"t":"PixiJS JumpStart​","u":"/blog/pixi-universe","h":"#pixijs-jumpstart","p":2},{"i":20,"t":"PixiJS Dev Tools​","u":"/blog/pixi-universe","h":"#pixijs-dev-tools","p":2},{"i":22,"t":"Phase 3​","u":"/blog/pixi-universe","h":"#phase-3","p":2},{"i":24,"t":"Comet​","u":"/blog/pixi-universe","h":"#comet","p":2},{"i":26,"t":"PixiJS v8​","u":"/blog/pixi-universe","h":"#pixijs-v8","p":2},{"i":28,"t":"Phase 4​","u":"/blog/pixi-universe","h":"#phase-4","p":2},{"i":30,"t":"PixiJS 3D​","u":"/blog/pixi-universe","h":"#pixijs-3d","p":2},{"i":32,"t":"PixiJS Game Engine​","u":"/blog/pixi-universe","h":"#pixijs-game-engine","p":2},{"i":34,"t":"Conclusion","u":"/blog/pixi-universe","h":"#conclusion","p":2},{"i":60,"t":"1. 😍 Embracing WebGPU","u":"/blog/pixi-v8-beta","h":"#1--embracing-webgpu","p":58},{"i":62,"t":"2. πŸš€ Turbocharging Performance","u":"/blog/pixi-v8-beta","h":"#2--turbocharging-performance","p":58},{"i":64,"t":"But Wait, There's More!","u":"/blog/pixi-v8-beta","h":"#but-wait-theres-more","p":58},{"i":66,"t":"Over to you!","u":"/blog/pixi-v8-beta","h":"#over-to-you","p":58},{"i":68,"t":"Steps to install:","u":"/blog/pixi-v8-beta","h":"#steps-to-install","p":58},{"i":70,"t":"Keep in touch!","u":"/blog/pixi-v8-beta","h":"#keep-in-touch","p":58}],"index":{"version":"2.3.9","fields":["t"],"fieldVectors":[["t/4",[0,1.728,1,2.351]],["t/6",[2,0.937,3,2.892]],["t/8",[2,0.937,4,2.892]],["t/10",[2,0.789,5,2.437,6,2.437]],["t/12",[2,0.917,7,1.853,8,1.278,9,1.853]],["t/14",[10,3.558]],["t/16",[0,1.728,11,2.351]],["t/18",[2,0.937,12,2.892]],["t/20",[2,0.789,13,2.437,14,2.437]],["t/22",[0,1.728,15,2.892]],["t/24",[16,3.558]],["t/26",[2,0.937,17,2.892]],["t/28",[0,1.728,18,2.892]],["t/30",[2,0.937,19,2.892]],["t/32",[2,0.789,20,2.437,21,2.437]],["t/34",[22,3.558]],["t/60",[1,1.711,8,1.452,23,2.105,24,2.105]],["t/62",[8,1.452,11,1.711,25,2.105,26,2.105]],["t/64",[27,2.437,28,2.437,29,2.437]],["t/66",[30,3.558]],["t/68",[31,2.892,32,2.892]],["t/70",[33,2.892,34,2.892]]],"invertedIndex":[["",{"_index":8,"t":{"12":{"position":[[10,1]]},"60":{"position":[[3,2]]},"62":{"position":[[3,2]]}}}],["1",{"_index":1,"t":{"4":{"position":[[6,2]]},"60":{"position":[[0,2]]}}}],["2",{"_index":11,"t":{"16":{"position":[[6,2]]},"62":{"position":[[0,2]]}}}],["3",{"_index":15,"t":{"22":{"position":[[6,2]]}}}],["3d",{"_index":19,"t":{"30":{"position":[[7,3]]}}}],["4",{"_index":18,"t":{"28":{"position":[[6,2]]}}}],["assetpack",{"_index":10,"t":{"14":{"position":[[0,10]]}}}],["comet",{"_index":16,"t":{"24":{"position":[[0,6]]}}}],["conclusion",{"_index":22,"t":{"34":{"position":[[0,10]]}}}],["dev",{"_index":13,"t":{"20":{"position":[[7,3]]}}}],["embracing",{"_index":23,"t":{"60":{"position":[[6,9]]}}}],["engine",{"_index":21,"t":{"32":{"position":[[12,7]]}}}],["game",{"_index":20,"t":{"32":{"position":[[7,4]]}}}],["games",{"_index":6,"t":{"10":{"position":[[12,6]]}}}],["install",{"_index":32,"t":{"68":{"position":[[9,8]]}}}],["jumpstart",{"_index":12,"t":{"18":{"position":[[7,10]]}}}],["keep",{"_index":33,"t":{"70":{"position":[[0,4]]}}}],["layout",{"_index":9,"t":{"12":{"position":[[19,7]]}}}],["more",{"_index":29,"t":{"64":{"position":[[18,5]]}}}],["open",{"_index":5,"t":{"10":{"position":[[7,4]]}}}],["over",{"_index":30,"t":{"66":{"position":[[0,4]]}}}],["performance",{"_index":26,"t":{"62":{"position":[[20,11]]}}}],["phase",{"_index":0,"t":{"4":{"position":[[0,5]]},"16":{"position":[[0,5]]},"22":{"position":[[0,5]]},"28":{"position":[[0,5]]}}}],["pixijs",{"_index":2,"t":{"6":{"position":[[0,6]]},"8":{"position":[[0,6]]},"10":{"position":[[0,6]]},"12":{"position":[[0,6],[12,6]]},"18":{"position":[[0,6]]},"20":{"position":[[0,6]]},"26":{"position":[[0,6]]},"30":{"position":[[0,6]]},"32":{"position":[[0,6]]}}}],["react",{"_index":4,"t":{"8":{"position":[[7,6]]}}}],["steps",{"_index":31,"t":{"68":{"position":[[0,5]]}}}],["there's",{"_index":28,"t":{"64":{"position":[[10,7]]}}}],["tools",{"_index":14,"t":{"20":{"position":[[11,6]]}}}],["touch",{"_index":34,"t":{"70":{"position":[[8,6]]}}}],["turbocharging",{"_index":25,"t":{"62":{"position":[[6,13]]}}}],["ui",{"_index":7,"t":{"12":{"position":[[7,2]]}}}],["v8",{"_index":17,"t":{"26":{"position":[[7,3]]}}}],["wait",{"_index":27,"t":{"64":{"position":[[4,5]]}}}],["webgpu",{"_index":24,"t":{"60":{"position":[[16,6]]}}}],["website",{"_index":3,"t":{"6":{"position":[[7,8]]}}}]],"pipeline":["stemmer"]}},{"documents":[{"i":3,"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":2},{"i":5,"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":2},{"i":7,"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":2},{"i":9,"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":2},{"i":11,"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":2},{"i":13,"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":2},{"i":15,"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":2},{"i":17,"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":2},{"i":19,"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":2},{"i":21,"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":2},{"i":23,"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":2},{"i":25,"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":2},{"i":27,"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":2},{"i":29,"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":2},{"i":31,"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":2},{"i":33,"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":2},{"i":35,"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":2},{"i":59,"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":58},{"i":61,"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":58},{"i":63,"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 Bunnmark - WebGPU v8 Bunnmark - 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":58},{"i":65,"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":58},{"i":67,"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":58},{"i":69,"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":58},{"i":71,"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":58}],"index":{"version":"2.3.9","fields":["t"],"fieldVectors":[["t/3",[0,1.801,1,2.065,2,2.419,3,0.036,4,2.419,5,2.956,6,2.419,7,2.419,8,2.065,9,0.816,10,1.801,11,1.265,12,1.398,13,0.911,14,2.956,15,2.153,16,2.956,17,1.591,18,2.419,19,1.591,20,1.801,21,1.801,22,2.065,23,1.265,24,1.415,25,2.153,26,2.419,27,1.591,28,2.065,29,1.712,30,2.065,31,2.065,32,1.016,33,2.956,34,2.956,35,2.956,36,1.801,37,2.956,38,2.956,39,2.956,40,2.065,41,2.956,42,2.419,43,1.801,44,1.801,45,2.956,46,1.415,47,1.265,48,1.801,49,2.956,50,2.419,51,0.572,52,2.065,53,1.415,54,2.065,55,2.956,56,2.419]],["t/5",[3,0.028,29,1.693,47,1.693,53,1.894,57,4.827,58,0.612,59,3.237,60,2.764,61,3.956,62,3.956,63,3.237,64,2.764,65,3.956,66,3.237,67,2.129,68,3.237,69,3.956,70,1.693,71,2.129,72,2.411]],["t/7",[0,1.911,1,2.191,3,0.03,17,1.688,36,1.911,47,1.342,51,0.607,58,0.528,60,2.191,73,1.688,74,1.911,75,2.191,76,1.911,77,4.163,78,3.136,79,4.074,80,3.136,81,2.191,82,2.191,83,3.136,84,3.136,85,3.136,86,2.566,87,1.911,88,2.191,89,3.136,90,2.566,91,3.136,92,3.136,93,1.911,94,2.191,95,1.688,96,3.136,97,2.191,98,3.136,99,2.566,100,2.566,101,3.136,102,3.136,103,2.191,104,2.566,105,3.136,106,3.136,107,3.136,108,2.566,109,3.136,110,2.566,111,3.136,112,1.342,113,1.501]],["t/9",[3,0.038,12,0.917,13,1.238,25,1.6,26,2.433,32,1.381,42,2.433,47,1.272,48,1.812,53,1.423,58,0.377,72,1.812,74,1.812,79,2.433,100,2.433,112,1.272,113,1.423,114,3.665,115,3.101,116,2.807,117,2.973,118,2.448,119,2.973,120,2.973,121,2.973,122,2.973,123,2.973,124,1.812,125,2.973,126,2.973,127,2.973,128,1.14,129,1.812,130,1.54,131,2.807,132,2.077,133,2.433,134,2.973,135,2.433,136,2.433,137,2.973,138,2.433,139,2.973,140,2.433]],["t/11",[3,0.039,12,1.075,13,1.075,15,2.841,28,1.695,51,0.47,54,1.695,58,0.308,70,1.038,72,2.125,73,1.306,87,2.125,103,1.695,112,1.492,113,1.162,114,1.695,118,2.997,141,1.479,142,3.339,143,2.426,144,1.695,145,2.851,146,2.426,147,2.436,148,2.426,149,1.985,150,2.426,151,2.426,152,2.426,153,1.479,154,2.426,155,2.997,156,2.196,157,1.695,158,2.426,159,1.695,160,2.426,161,2.426,162,3.486,163,1.985,164,1.985,165,1.985,166,2.426,167,2.426,168,2.426,169,1.306,170,2.426,171,2.426,172,1.985,173,1.695,174,2.853,175,1.695,176,2.426,177,1.985,178,1.162,179,1.985,180,2.853,181,2.426,182,2.426,183,3.486]],["t/13",[3,0.038,9,0.57,11,0.884,12,0.637,13,1.273,15,1.112,28,1.443,48,1.259,58,0.262,59,1.69,72,1.259,87,1.259,93,1.259,97,1.443,103,1.443,104,1.69,112,1.325,113,1.483,115,2.516,124,1.259,132,1.443,138,2.535,145,1.443,147,1.443,149,1.69,155,1.259,156,1.112,163,3.379,165,3.62,169,1.112,173,1.443,184,2.065,185,1.69,186,1.888,187,3.716,188,2.065,189,1.443,190,3.097,191,2.065,192,2.065,193,2.065,194,2.065,195,2.065,196,2.065,197,2.065,198,2.065,199,1.443,200,2.065,201,2.065,202,2.065,203,2.065,204,1.888,205,2.065,206,2.065,207,2.065,208,1.69,209,2.065,210,3.097,211,3.097,212,2.065,213,2.065,214,2.065,215,2.065,216,1.443,217,1.443,218,1.443,219,2.065,220,1.69,221,2.065,222,2.065,223,2.065,224,2.065,225,3.097,226,2.535,227,1.443,228,2.065,229,1.443,230,3.041,231,2.065,232,2.065,233,2.065,234,2.065,235,1.443,236,1.259,237,1.69,238,2.065,239,1.69,240,1.112,241,1.69,242,2.065,243,2.065,244,1.69,245,2.065,246,1.443,247,2.065,248,2.065,249,2.065,250,2.065,251,1.69,252,2.065,253,2.065,254,2.065,255,1.443,256,2.065]],["t/15",[3,0.017,9,0.651,11,1.01,12,1.053,27,1.27,30,2.387,32,0.811,36,1.438,51,0.457,58,0.509,60,1.649,67,1.27,68,1.931,112,1.462,113,1.636,115,2.082,116,2.806,118,1.438,124,1.438,128,1.31,130,1.54,153,1.438,164,3.603,169,1.27,186,1.438,189,1.649,216,1.649,217,1.649,227,1.649,229,2.387,257,1.931,258,2.359,259,1.931,260,1.931,261,2.359,262,2.359,263,2.359,264,1.13,265,1.649,266,4.016,267,3.416,268,1.931,269,2.359,270,2.359,271,2.359,272,3.287,273,1.931,274,1.438,275,1.649,276,1.649,277,1.931,278,4.016,279,2.359,280,2.359,281,2.359,282,2.359,283,3.416,284,2.359,285,2.359,286,1.931,287,1.649,288,2.359,289,2.359,290,3.416,291,2.359,292,3.416,293,1.931,294,2.359,295,2.359,296,2.359,297,1.438,298,1.931,299,1.931,300,2.359,301,1.931,302,2.359,303,1.931,304,1.649,305,1.931,306,1.931,307,2.359,308,2.359,309,2.359,310,1.649]],["t/17",[3,0.031,9,1.203,11,1.865,32,1.499,44,2.656,67,2.345,264,2.087,311,4.358,312,4.358,313,3.567]],["t/19",[3,0.034,9,0.743,12,1.157,13,1.332,18,2.204,25,1.449,29,1.606,32,0.926,43,1.641,51,0.521,58,0.548,66,2.204,74,2.287,87,1.641,94,1.882,114,1.882,131,1.882,153,1.641,156,1.449,204,1.641,229,2.622,255,1.882,265,1.882,268,2.204,287,2.622,314,4.319,315,3.753,316,3.824,317,2.204,318,2.204,319,2.693,320,2.204,321,2.204,322,2.204,323,2.204,324,2.693,325,2.693,326,2.693,327,3.753,328,3.071,329,2.693,330,2.693,331,2.693,332,2.622,333,2.693,334,2.693,335,2.693,336,2.693,337,2.693,338,2.693,339,2.693,340,2.693,341,2.693,342,2.204,343,2.693,344,2.693,345,2.693,346,2.204,347,2.693,348,1.641,349,1.882,350,2.693]],["t/21",[3,0.038,9,1.108,11,1.719,12,1.587,13,0.727,23,1.462,29,1.884,30,3.077,31,1.649,32,1.514,51,0.457,54,1.649,58,0.299,90,1.931,95,1.27,124,1.438,128,1.31,130,0.905,142,1.931,178,1.636,236,1.438,264,1.636,265,2.387,274,1.438,276,1.649,297,2.683,304,1.649,316,2.796,323,1.931,351,4.402,352,1.931,353,2.359,354,3.416,355,4.016,356,3.416,357,3.416,358,1.931,359,1.649,360,1.931,361,1.649,362,2.359,363,2.359,364,2.359,365,1.931,366,2.359,367,3.416,368,2.359,369,3.416,370,1.931,371,1.931,372,2.359,373,2.359,374,1.931,375,2.359,376,1.649,377,1.931,378,2.359,379,1.649,380,1.649,381,2.359,382,2.359,383,1.438,384,2.359]],["t/23",[0,2.59,3,0.031,53,2.035,67,2.287,81,2.97,82,2.97,159,2.97,240,2.287,348,2.59,385,4.25,386,3.478,387,3.478,388,4.25]],["t/25",[3,0.017,9,0.642,11,0.996,12,1.043,13,1.043,15,1.82,29,0.996,32,1.37,44,2.062,46,1.62,51,0.655,58,0.295,95,1.252,97,1.626,108,1.905,116,2.364,130,0.892,131,2.785,132,2.364,133,2.768,136,1.905,155,2.062,178,1.114,185,1.905,186,2.062,189,1.626,204,1.418,218,1.626,226,1.905,227,1.626,235,2.785,236,1.418,264,1.114,272,1.905,273,1.905,275,1.626,287,1.626,320,3.58,342,1.905,361,1.626,376,1.626,377,1.905,389,3.985,390,3.985,391,2.327,392,1.905,393,2.327,394,3.382,395,2.327,396,2.327,397,1.905,398,2.327,399,2.327,400,3.985,401,2.768,402,3.382,403,2.327,404,1.905,405,2.327,406,2.327,407,1.626,408,2.327,409,2.327,410,1.626,411,1.418,412,1.905,413,2.327,414,2.327,415,2.327,416,2.327,417,1.905,418,2.327,419,2.327,420,2.327,421,2.327,422,2.327,423,2.327,424,2.327,425,2.327,426,2.327,427,1.905,428,2.327,429,2.327,430,2.327]],["t/27",[3,0.036,8,1.612,9,0.637,12,1.222,17,1.241,20,1.406,23,0.987,24,1.898,27,1.241,32,1.156,36,1.406,43,2.048,47,0.987,48,1.406,51,0.651,58,0.426,64,1.612,70,0.987,71,1.241,73,1.808,74,1.406,76,1.406,88,1.612,95,1.241,128,1.289,129,2.048,130,0.884,135,1.887,156,1.241,172,1.887,175,1.612,236,1.406,244,1.887,286,1.887,297,1.406,298,2.75,301,1.887,303,1.887,317,1.887,318,1.887,332,1.612,352,1.887,361,1.612,374,1.887,379,1.612,383,2.048,386,3.245,412,1.887,431,1.898,432,2.75,433,2.306,434,1.887,435,2.306,436,2.306,437,2.306,438,1.406,439,2.306,440,2.348,441,1.887,442,2.306,443,1.612,444,2.306,445,2.306,446,2.306,447,3.36,448,2.048,449,2.134,450,1.612,451,2.306,452,2.306,453,2.306,454,2.306,455,2.306,456,1.612,457,3.36,458,1.887,459,2.306,460,1.887,461,2.306,462,2.306,463,2.306,464,1.612,465,1.612,466,1.887,467,2.306]],["t/29",[3,0.03,19,2.25,23,1.789,58,0.53,67,2.25,246,2.922,380,2.922,432,3.422,464,2.922,468,4.181,469,4.181,470,3.422,471,4.181,472,4.181,473,4.181]],["t/31",[3,0.029,8,2.102,10,1.833,12,0.927,15,1.619,17,1.619,19,1.619,24,1.44,32,1.392,40,2.102,43,1.833,51,0.784,63,2.461,70,1.287,71,1.619,81,2.102,82,2.102,94,2.102,99,2.461,141,2.467,144,2.102,145,2.102,147,2.102,169,1.619,174,3.313,199,2.102,241,2.461,321,2.461,328,2.461,332,2.102,410,2.102,411,1.833,474,3.007,475,2.461,476,4.895,477,3.007,478,3.007,479,3.007,480,3.007,481,3.007,482,3.007,483,2.461,484,3.007,485,3.007,486,2.461,487,3.007,488,2.461,489,3.007,490,2.461,491,3.007,492,3.007,493,3.007,494,3.007,495,2.461,496,2.461]],["t/33",[1,2.304,3,0.031,9,0.91,11,1.411,24,2.43,27,1.774,29,1.411,51,0.833,58,0.418,93,2.009,115,2.009,129,2.009,130,1.65,144,2.304,153,2.009,155,3.209,156,1.774,239,2.698,257,2.698,259,2.698,260,3.521,264,1.578,293,2.698,299,2.698,383,2.009,466,2.698,486,2.698,497,2.698,498,3.296,499,3.296,500,2.698,501,3.296,502,3.296,503,3.296,504,3.296,505,3.296,506,3.296]],["t/35",[0,1.923,3,0.036,4,2.582,13,0.973,25,2.249,29,1.35,40,2.205,50,2.582,51,0.611,53,1.511,58,0.53,71,1.698,112,1.35,129,1.923,169,1.698,216,2.205,217,2.205,246,2.921,346,2.582,365,2.582,387,2.582,411,1.923,465,2.921,507,1.923,508,3.155,509,4.18,510,3.155,511,2.921,512,3.155,513,3.155,514,2.582,515,3.155,516,3.155,517,3.155,518,3.155,519,3.155,520,2.582,521,2.205,522,3.155,523,3.155,524,2.582,525,3.155,526,3.155,527,3.155,528,2.205,529,2.582]],["t/59",[3,0.03,19,1.698,21,1.923,23,1.35,24,1.511,47,1.35,52,2.205,58,0.4,70,1.789,75,2.921,128,1.21,130,1.21,157,2.205,240,1.698,348,1.923,349,2.205,431,2.001,438,1.923,440,2.205,449,1.698,458,2.582,488,2.582,497,2.582,500,2.582,507,1.923,520,3.421,530,3.155,531,3.155,532,2.205,533,3.155,534,3.155,535,3.155,536,3.155,537,3.155,538,3.155,539,3.155,540,3.155,541,3.155,542,3.155,543,3.155,544,3.155,545,3.155,546,3.155,547,3.155,548,3.155,549,2.205,550,3.155,551,3.155,552,2.582,553,3.155]],["t/61",[2,1.854,3,0.024,9,0.625,17,1.219,21,2.022,22,1.583,23,1.419,46,1.588,47,0.97,51,0.439,52,1.583,58,0.421,64,1.583,73,1.219,76,1.381,93,1.381,128,0.869,141,1.381,175,2.742,178,1.085,204,1.381,220,1.854,251,2.715,255,1.583,264,1.085,275,1.583,276,1.583,304,1.583,310,1.583,359,1.583,370,1.854,379,1.583,383,1.381,397,1.854,404,1.854,434,1.854,441,1.854,448,2.022,449,1.219,450,1.583,456,1.583,460,2.715,465,1.583,483,2.715,495,2.715,532,1.583,549,1.583,554,2.266,555,2.266,556,2.266,557,2.266,558,3.213,559,2.266,560,2.266,561,2.266,562,1.854,563,1.854,564,2.266,565,2.266,566,2.266,567,2.266,568,2.266,569,2.266,570,3.924,571,2.266,572,2.266,573,2.266,574,2.266,575,2.266,576,2.266,577,2.266,578,2.266,579,2.266,580,2.266,581,2.266,582,1.854,583,2.266,584,2.266,585,2.266,586,2.266,587,3.317,588,2.266,589,2.266,590,2.266,591,2.266,592,2.266,593,2.266,594,2.266,595,2.266,596,1.854,597,2.266,598,2.266,599,2.266,600,2.266,601,2.266,602,2.266,603,2.266,604,2.266,605,2.266,606,1.854]],["t/63",[3,0.011,6,1.249,9,0.421,20,1.492,22,1.067,23,1.644,31,1.067,44,0.93,46,1.468,73,0.821,86,1.249,95,0.821,110,1.249,113,0.731,118,0.93,128,1.176,140,1.249,159,1.067,178,0.731,180,1.249,208,1.249,230,1.249,235,1.067,237,1.249,240,0.821,274,0.93,277,1.249,297,0.93,322,1.249,359,1.067,371,1.249,376,1.067,401,2.51,407,1.711,410,1.711,417,1.249,431,1.964,438,1.492,443,2.685,448,1.492,449,0.821,456,3.011,464,1.067,496,1.249,507,0.93,521,1.067,524,1.249,549,1.711,558,1.711,563,1.249,582,1.249,596,1.249,606,1.249,607,1.526,608,1.526,609,1.526,610,1.526,611,1.526,612,1.526,613,1.526,614,1.526,615,3.066,616,4.309,617,3.509,618,1.526,619,1.526,620,2.449,621,1.526,622,1.526,623,1.526,624,3.066,625,3.066,626,1.526,627,2.449,628,1.526,629,1.526,630,2.449,631,1.526,632,3.509,633,2.449,634,1.526,635,1.249,636,1.526,637,1.526,638,1.526,639,1.526,640,1.526,641,2.449,642,2.449,643,1.526,644,1.526,645,1.526,646,1.526,647,1.526,648,1.526,649,1.526,650,1.526,651,3.066,652,1.526,653,2.449,654,1.526,655,2.449,656,1.526,657,1.526,658,1.526,659,1.526,660,1.526,661,1.526,662,1.526,663,1.526,664,1.526,665,1.526,666,1.526,667,3.842,668,1.711,669,1.526,670,1.526,671,1.526,672,1.526,673,2.449,674,3.066,675,2.449,676,2.449,677,1.526,678,1.526,679,3.066,680,2.449,681,2.449,682,1.526,683,1.526,684,1.526,685,1.526,686,1.526,687,1.526,688,1.526,689,1.526,690,1.526,691,2.449,692,2.449,693,1.526,694,1.526,695,2.449,696,1.526,697,1.526,698,1.526,699,1.526,700,1.526,701,1.526,702,1.526,703,1.526,704,1.526,705,1.526]],["t/65",[3,0.027,7,2.158,10,1.607,13,0.813,27,1.419,51,0.716,53,1.263,56,2.158,58,0.469,70,1.129,88,1.843,128,1.011,130,1.011,157,1.843,186,1.607,240,1.419,274,1.607,305,2.158,306,2.158,360,2.158,380,1.843,392,2.158,407,1.843,411,1.607,431,1.263,438,1.607,440,1.843,443,1.843,450,2.985,470,2.158,475,2.158,507,1.607,511,1.843,514,2.158,521,1.843,528,1.843,529,2.158,562,2.158,706,2.637,707,2.637,708,2.637,709,2.637,710,2.637,711,2.637,712,2.637,713,2.637,714,2.637,715,2.637,716,2.637,717,2.637,718,2.158,719,2.637,720,2.637,721,2.637,722,2.637,723,2.637,724,2.637,725,2.637,726,2.158,727,2.637,728,2.637,729,2.637,730,2.637,731,2.637,732,2.637,733,2.637,734,2.637,735,2.637,736,2.158,737,2.637,738,2.637,739,2.637,740,2.637,741,2.637,742,2.637,743,2.637,744,2.637,745,2.637,746,2.637,747,2.637,748,2.637,749,2.637]],["t/67",[3,0.032,10,2.118,24,1.664,46,1.664,70,1.487,112,1.487,141,2.118,177,3.643,178,1.664,179,2.844,199,2.428,349,2.428,427,2.844,431,2.131,490,2.844,552,2.844,668,2.428,726,2.844,736,2.844,750,3.475,751,3.475,752,3.475,753,3.475,754,3.475,755,3.475,756,3.475,757,3.475,758,2.844,759,3.475,760,3.475,761,3.475,762,3.475,763,3.475,764,3.475,765,3.475,766,3.475,767,3.475]],["t/69",[3,0.023,13,0.991,19,1.73,20,2.883,21,1.959,58,0.407,75,2.957,76,1.959,173,2.246,310,2.246,348,1.959,431,2.026,448,1.959,449,1.73,532,2.246,558,2.246,668,3.922,768,3.214,769,4.231,770,4.231,771,3.214,772,3.214,773,4.73,774,4.231,775,3.214,776,3.214,777,3.214,778,3.214,779,3.214,780,3.214,781,3.214,782,3.214,783,3.214,784,2.631,785,3.214]],["t/71",[3,0.028,25,2.097,46,1.865,51,0.754,71,2.097,218,2.722,313,3.188,358,3.188,511,2.722,528,2.722,635,3.188,718,3.188,758,3.188,784,3.188,786,3.896,787,3.896,788,3.896,789,3.896,790,3.896,791,3.896,792,3.896,793,3.896,794,3.896,795,3.896]]],"invertedIndex":[["",{"_index":668,"t":{"63":{"position":[[1321,1],[1374,1]]},"67":{"position":[[340,2]]},"69":{"position":[[184,1],[205,1],[245,1],[262,1],[291,2],[307,3],[311,2],[353,1],[455,2]]}}}],["0.12ms",{"_index":683,"t":{"63":{"position":[[1569,7]]}}}],["0.5ms",{"_index":685,"t":{"63":{"position":[[1589,6]]}}}],["1",{"_index":68,"t":{"5":{"position":[[141,2]]},"15":{"position":[[19,1]]}}}],["100k",{"_index":674,"t":{"63":{"position":[[1483,4],[1539,4],[1602,4]]}}}],["108",{"_index":689,"t":{"63":{"position":[[1654,4]]}}}],["12",{"_index":49,"t":{"3":{"position":[[635,2]]}}}],["15ms",{"_index":677,"t":{"63":{"position":[[1513,5]]}}}],["1700",{"_index":686,"t":{"63":{"position":[[1596,5]]}}}],["17417",{"_index":684,"t":{"63":{"position":[[1577,6]]}}}],["2",{"_index":311,"t":{"17":{"position":[[6,1]]}}}],["21ms",{"_index":682,"t":{"63":{"position":[[1563,5]]}}}],["233",{"_index":678,"t":{"63":{"position":[[1519,4]]}}}],["24ms",{"_index":688,"t":{"63":{"position":[[1648,5]]}}}],["27",{"_index":589,"t":{"61":{"position":[[825,3]]}}}],["2d",{"_index":19,"t":{"3":{"position":[[239,2]]},"29":{"position":[[114,2]]},"31":{"position":[[208,2]]},"59":{"position":[[62,2]]},"69":{"position":[[438,2]]}}}],["2d/3d",{"_index":499,"t":{"33":{"position":[[173,5]]}}}],["2ms",{"_index":680,"t":{"63":{"position":[[1529,4],[1664,4]]}}}],["3",{"_index":159,"t":{"11":{"position":[[343,1]]},"23":{"position":[[6,1]]},"63":{"position":[[1137,2]]}}}],["350",{"_index":681,"t":{"63":{"position":[[1534,4],[1669,4]]}}}],["3d",{"_index":476,"t":{"31":{"position":[[52,2],[215,2],[269,3],[352,2]]}}}],["3rd",{"_index":139,"t":{"9":{"position":[[622,3]]}}}],["4",{"_index":468,"t":{"29":{"position":[[6,1]]}}}],["50ms",{"_index":676,"t":{"63":{"position":[[1507,5],[1642,5]]}}}],["8",{"_index":603,"t":{"61":{"position":[[1103,1]]}}}],["95",{"_index":583,"t":{"61":{"position":[[704,3]]}}}],["9ms",{"_index":679,"t":{"63":{"position":[[1524,4],[1584,4],[1659,4]]}}}],["ability",{"_index":276,"t":{"15":{"position":[[420,7]]},"21":{"position":[[457,7]]},"61":{"position":[[477,7]]}}}],["above",{"_index":527,"t":{"35":{"position":[[480,5]]}}}],["achieves",{"_index":604,"t":{"61":{"position":[[1105,8]]}}}],["adapt",{"_index":228,"t":{"13":{"position":[[782,5]]}}}],["adding",{"_index":101,"t":{"7":{"position":[[437,6]]}}}],["addition",{"_index":412,"t":{"25":{"position":[[729,9]]},"27":{"position":[[763,8]]}}}],["additional",{"_index":719,"t":{"65":{"position":[[322,10]]}}}],["address",{"_index":39,"t":{"3":{"position":[[520,7]]}}}],["adjusted",{"_index":243,"t":{"13":{"position":[[1083,8]]}}}],["advanced",{"_index":455,"t":{"27":{"position":[[649,8]]}}}],["advancements",{"_index":544,"t":{"59":{"position":[[398,12]]}}}],["advantage",{"_index":454,"t":{"27":{"position":[[636,9]]}}}],["agnostic",{"_index":267,"t":{"15":{"position":[[205,8],[1061,8]]}}}],["aims",{"_index":264,"t":{"15":{"position":[[146,4]]},"17":{"position":[[31,4]]},"21":{"position":[[143,4],[731,4]]},"25":{"position":[[32,4]]},"33":{"position":[[122,4]]},"61":{"position":[[928,4]]}}}],["allowed",{"_index":577,"t":{"61":{"position":[[579,7]]}}}],["allowing",{"_index":204,"t":{"13":{"position":[[353,8],[874,8]]},"19":{"position":[[306,8]]},"25":{"position":[[237,8]]},"61":{"position":[[972,8]]}}}],["allows",{"_index":136,"t":{"9":{"position":[[579,6]]},"25":{"position":[[800,6]]}}}],["alternatively",{"_index":790,"t":{"71":{"position":[[140,14]]}}}],["although",{"_index":488,"t":{"31":{"position":[[381,8]]},"59":{"position":[[114,8]]}}}],["always",{"_index":22,"t":{"3":{"position":[[275,6]]},"61":{"position":[[988,6]]},"63":{"position":[[11,6]]}}}],["amazing",{"_index":14,"t":{"3":{"position":[[171,7]]}}}],["animation",{"_index":505,"t":{"33":{"position":[[438,9]]}}}],["animations",{"_index":402,"t":{"25":{"position":[[416,11],[622,11]]}}}],["announce",{"_index":1,"t":{"3":{"position":[[18,8]]},"7":{"position":[[27,8]]},"33":{"position":[[28,8]]}}}],["announcement",{"_index":55,"t":{"3":{"position":[[698,13]]}}}],["announcing",{"_index":258,"t":{"15":{"position":[[28,10]]}}}],["another",{"_index":220,"t":{"13":{"position":[[608,7]]},"61":{"position":[[1159,7]]}}}],["anyone",{"_index":176,"t":{"11":{"position":[[947,6]]}}}],["api",{"_index":450,"t":{"27":{"position":[[546,3]]},"61":{"position":[[189,4]]},"65":{"position":[[146,3],[350,3],[555,3]]}}}],["app",{"_index":334,"t":{"19":{"position":[[424,3]]}}}],["appeal",{"_index":393,"t":{"25":{"position":[[196,6]]}}}],["appealing",{"_index":423,"t":{"25":{"position":[[980,10]]}}}],["appearance",{"_index":206,"t":{"13":{"position":[[379,10]]}}}],["application",{"_index":287,"t":{"15":{"position":[[636,12]]},"19":{"position":[[345,12],[795,11]]},"25":{"position":[[713,12]]}}}],["applications",{"_index":32,"t":{"3":{"position":[[387,12]]},"9":{"position":[[78,13],[494,12]]},"15":{"position":[[102,13]]},"17":{"position":[[74,13]]},"19":{"position":[[110,13]]},"21":{"position":[[119,13],[374,12],[937,12],[1141,13]]},"25":{"position":[[96,12],[851,13],[1146,12]]},"27":{"position":[[746,13],[1168,13]]},"31":{"position":[[243,13],[619,13]]}}}],["apply",{"_index":702,"t":{"63":{"position":[[1992,5]]}}}],["appreciate",{"_index":413,"t":{"25":{"position":[[755,10]]}}}],["approach",{"_index":549,"t":{"59":{"position":[[512,8]]},"61":{"position":[[570,8]]},"63":{"position":[[230,10],[455,9]]}}}],["appropriate",{"_index":772,"t":{"69":{"position":[[113,11]]}}}],["apps",{"_index":16,"t":{"3":{"position":[[189,5]]}}}],["architecture",{"_index":610,"t":{"63":{"position":[[105,12]]}}}],["areas",{"_index":471,"t":{"29":{"position":[[88,5]]}}}],["aspect",{"_index":232,"t":{"13":{"position":[[818,6]]}}}],["assembled",{"_index":41,"t":{"3":{"position":[[545,9]]}}}],["asset",{"_index":259,"t":{"15":{"position":[[50,5]]},"33":{"position":[[390,5]]}}}],["assetpack",{"_index":164,"t":{"11":{"position":[[507,10]]},"15":{"position":[[39,10],[128,9],[180,9],[403,9]]}}}],["assets",{"_index":272,"t":{"15":{"position":[[364,6],[458,6],[847,6]]},"25":{"position":[[1093,6]]}}}],["assured",{"_index":740,"t":{"65":{"position":[[722,7]]}}}],["async",{"_index":777,"t":{"69":{"position":[[223,5]]}}}],["attempt",{"_index":572,"t":{"61":{"position":[[494,7]]}}}],["audio",{"_index":293,"t":{"15":{"position":[[739,5]]},"33":{"position":[[367,6]]}}}],["autodetectrenderer",{"_index":773,"t":{"69":{"position":[[148,18],[186,18],[270,20]]}}}],["automatically",{"_index":277,"t":{"15":{"position":[[431,13]]},"63":{"position":[[2087,13]]}}}],["available",{"_index":175,"t":{"11":{"position":[[923,9]]},"27":{"position":[[904,9]]},"61":{"position":[[370,9],[691,9],[1024,9]]}}}],["avoids",{"_index":649,"t":{"63":{"position":[[985,6]]}}}],["await",{"_index":780,"t":{"69":{"position":[[264,5]]}}}],["away",{"_index":350,"t":{"19":{"position":[[854,5]]}}}],["b",{"_index":576,"t":{"61":{"position":[[562,2]]}}}],["back",{"_index":574,"t":{"61":{"position":[[537,4]]}}}],["bad",{"_index":761,"t":{"67":{"position":[[225,4]]}}}],["bandwidth",{"_index":660,"t":{"63":{"position":[[1176,9]]}}}],["bars",{"_index":200,"t":{"13":{"position":[[258,5]]}}}],["based",{"_index":633,"t":{"63":{"position":[[634,5],[1702,5]]}}}],["batch",{"_index":626,"t":{"63":{"position":[[431,5]]}}}],["batches",{"_index":622,"t":{"63":{"position":[[377,7]]}}}],["batching",{"_index":367,"t":{"21":{"position":[[518,8],[538,8]]}}}],["beautiful",{"_index":184,"t":{"13":{"position":[[61,9]]}}}],["become",{"_index":336,"t":{"19":{"position":[[454,6]]}}}],["becomes",{"_index":594,"t":{"61":{"position":[[890,7]]}}}],["before",{"_index":593,"t":{"61":{"position":[[880,6]]}}}],["begin",{"_index":312,"t":{"17":{"position":[[13,5]]}}}],["behaviour",{"_index":207,"t":{"13":{"position":[[394,9]]}}}],["behind",{"_index":707,"t":{"65":{"position":[[26,6]]}}}],["being",{"_index":317,"t":{"19":{"position":[[28,5]]},"27":{"position":[[558,5]]}}}],["benchmark",{"_index":690,"t":{"63":{"position":[[1680,9]]}}}],["benefit",{"_index":579,"t":{"61":{"position":[[617,7]]}}}],["best",{"_index":359,"t":{"21":{"position":[[257,4]]},"61":{"position":[[1008,4]]},"63":{"position":[[1960,4]]}}}],["beta",{"_index":75,"t":{"7":{"position":[[64,4]]},"59":{"position":[[87,4],[147,4]]},"69":{"position":[[28,4],[390,4]]}}}],["better",{"_index":301,"t":{"15":{"position":[[880,6]]},"27":{"position":[[1113,6]]}}}],["between",{"_index":485,"t":{"31":{"position":[[307,7]]}}}],["blog",{"_index":305,"t":{"15":{"position":[[962,4]]},"65":{"position":[[275,4]]}}}],["both",{"_index":235,"t":{"13":{"position":[[898,4]]},"25":{"position":[[206,4],[246,4],[951,4]]},"63":{"position":[[130,4]]}}}],["brouwer",{"_index":122,"t":{"9":{"position":[[168,8]]}}}],["browser",{"_index":352,"t":{"21":{"position":[[27,7]]},"27":{"position":[[583,7]]}}}],["browsers",{"_index":570,"t":{"61":{"position":[[404,9],[711,9],[804,8]]}}}],["bubble",{"_index":160,"t":{"11":{"position":[[356,6]]}}}],["bubbo",{"_index":183,"t":{"11":{"position":[[1053,5],[1059,5]]}}}],["bugs",{"_index":763,"t":{"67":{"position":[[250,5]]}}}],["build",{"_index":31,"t":{"3":{"position":[[371,5]]},"21":{"position":[[895,5]]},"63":{"position":[[371,5]]}}}],["building",{"_index":332,"t":{"19":{"position":[[331,8],[839,8]]},"27":{"position":[[1131,8]]},"31":{"position":[[604,8]]}}}],["built",{"_index":478,"t":{"31":{"position":[[83,5]]}}}],["bump",{"_index":636,"t":{"63":{"position":[[729,5]]}}}],["bundle",{"_index":463,"t":{"27":{"position":[[971,6]]}}}],["bundlers",{"_index":327,"t":{"19":{"position":[[237,8],[555,8]]}}}],["bunnies",{"_index":700,"t":{"63":{"position":[[1907,8]]}}}],["bunnmark",{"_index":695,"t":{"63":{"position":[[1774,8],[1795,8]]}}}],["bunny",{"_index":671,"t":{"63":{"position":[[1423,5]]}}}],["bunnymark",{"_index":692,"t":{"63":{"position":[[1716,9],[1761,9]]}}}],["buttons",{"_index":190,"t":{"13":{"position":[[166,8],[236,8]]}}}],["call",{"_index":372,"t":{"21":{"position":[[630,5]]}}}],["called",{"_index":144,"t":{"11":{"position":[[38,6]]},"31":{"position":[[62,6]]},"33":{"position":[[78,6]]}}}],["candidate",{"_index":750,"t":{"67":{"position":[[34,10]]}}}],["canvas",{"_index":460,"t":{"27":{"position":[[873,6]]},"61":{"position":[[420,6],[545,6]]}}}],["capabilities",{"_index":8,"t":{"3":{"position":[[99,12]]},"27":{"position":[[662,13]]},"31":{"position":[[544,12]]}}}],["cases",{"_index":666,"t":{"63":{"position":[[1310,6]]}}}],["catalysed",{"_index":548,"t":{"59":{"position":[[498,9]]}}}],["causing",{"_index":37,"t":{"3":{"position":[[477,7]]}}}],["change",{"_index":653,"t":{"63":{"position":[[1093,6],[1886,6]]}}}],["changed",{"_index":630,"t":{"63":{"position":[[506,7],[780,8]]}}}],["changes",{"_index":240,"t":{"13":{"position":[[989,8]]},"23":{"position":[[78,7]]},"59":{"position":[[360,7]]},"63":{"position":[[681,7]]},"65":{"position":[[612,7]]}}}],["changing",{"_index":687,"t":{"63":{"position":[[1615,9]]}}}],["check",{"_index":216,"t":{"13":{"position":[[528,5]]},"15":{"position":[[1126,5]]},"35":{"position":[[443,5]]}}}],["checkboxes",{"_index":191,"t":{"13":{"position":[[175,11]]}}}],["class",{"_index":447,"t":{"27":{"position":[[496,5],[925,5]]}}}],["cli",{"_index":315,"t":{"19":{"position":[[19,3],[393,3]]}}}],["code",{"_index":178,"t":{"11":{"position":[[979,4]]},"21":{"position":[[240,5],[1097,4]]},"25":{"position":[[545,5]]},"61":{"position":[[1066,5]]},"63":{"position":[[814,4]]},"67":{"position":[[276,5]]}}}],["codebase",{"_index":552,"t":{"59":{"position":[[543,8]]},"67":{"position":[[391,8]]}}}],["collaborate",{"_index":396,"t":{"25":{"position":[[261,11]]}}}],["collaboration",{"_index":425,"t":{"25":{"position":[[1022,14]]}}}],["collection",{"_index":146,"t":{"11":{"position":[[76,10]]}}}],["combine",{"_index":234,"t":{"13":{"position":[[890,7]]}}}],["comet",{"_index":389,"t":{"25":{"position":[[0,5],[332,5],[1037,5]]}}}],["coming",{"_index":512,"t":{"35":{"position":[[67,6]]}}}],["community",{"_index":25,"t":{"3":{"position":[[313,9],[506,10]]},"9":{"position":[[218,9]]},"19":{"position":[[498,10]]},"35":{"position":[[88,10],[207,10]]},"71":{"position":[[180,9]]}}}],["compared",{"_index":442,"t":{"27":{"position":[[382,8]]}}}],["complete",{"_index":433,"t":{"27":{"position":[[59,8]]}}}],["complex",{"_index":236,"t":{"13":{"position":[[923,8]]},"21":{"position":[[499,7]]},"25":{"position":[[484,7]]},"27":{"position":[[1140,8]]}}}],["complicated",{"_index":323,"t":{"19":{"position":[[181,11]]},"21":{"position":[[656,11]]}}}],["components",{"_index":138,"t":{"9":{"position":[[607,10]]},"13":{"position":[[147,10],[317,10]]}}}],["comprehensive",{"_index":723,"t":{"65":{"position":[[429,13]]}}}],["compress",{"_index":294,"t":{"15":{"position":[[767,8]]}}}],["computational",{"_index":641,"t":{"63":{"position":[[843,13],[1207,13]]}}}],["computations",{"_index":560,"t":{"61":{"position":[[109,12]]}}}],["considering",{"_index":105,"t":{"7":{"position":[[481,11]]}}}],["const",{"_index":779,"t":{"69":{"position":[[247,5]]}}}],["construct",{"_index":631,"t":{"63":{"position":[[543,9]]}}}],["consuming",{"_index":366,"t":{"21":{"position":[[391,10]]}}}],["content",{"_index":483,"t":{"31":{"position":[[218,7]]},"61":{"position":[[259,7],[594,7]]}}}],["continuation",{"_index":119,"t":{"9":{"position":[[110,12]]}}}],["continue",{"_index":742,"t":{"65":{"position":[[759,8]]}}}],["continuing",{"_index":522,"t":{"35":{"position":[[379,10]]}}}],["contribute",{"_index":179,"t":{"11":{"position":[[987,10]]},"67":{"position":[[265,10]]}}}],["contributors",{"_index":518,"t":{"35":{"position":[[222,13]]}}}],["conversations",{"_index":795,"t":{"71":{"position":[[237,14]]}}}],["convert",{"_index":290,"t":{"15":{"position":[[695,7],[731,7]]}}}],["core",{"_index":135,"t":{"9":{"position":[[551,4]]},"27":{"position":[[230,4]]}}}],["correct",{"_index":619,"t":{"63":{"position":[[303,7]]}}}],["course",{"_index":539,"t":{"59":{"position":[[274,6]]}}}],["cpu",{"_index":667,"t":{"63":{"position":[[1317,3],[1341,3],[1442,3],[1449,3],[1453,3]]}}}],["create",{"_index":13,"t":{"3":{"position":[[164,6]]},"9":{"position":[[481,6],[593,6]]},"11":{"position":[[144,6],[871,6]]},"13":{"position":[[54,6],[699,6],[916,6],[1046,6]]},"19":{"position":[[411,6],[431,6],[775,6]]},"21":{"position":[[1106,6]]},"25":{"position":[[79,6],[468,6]]},"35":{"position":[[313,6]]},"65":{"position":[[385,6]]},"69":{"position":[[97,6]]}}}],["created",{"_index":26,"t":{"3":{"position":[[327,7]]},"9":{"position":[[149,7]]}}}],["creating",{"_index":320,"t":{"19":{"position":[[90,8]]},"25":{"position":[[378,8],[604,8],[694,8],[1114,8]]}}}],["crucial",{"_index":729,"t":{"65":{"position":[[502,7]]}}}],["curious",{"_index":701,"t":{"63":{"position":[[1916,7]]}}}],["current",{"_index":78,"t":{"7":{"position":[[112,7]]}}}],["currently",{"_index":64,"t":{"5":{"position":[[106,9]]},"27":{"position":[[397,10]]},"61":{"position":[[762,9]]}}}],["custom",{"_index":137,"t":{"9":{"position":[[600,6]]}}}],["customizable",{"_index":203,"t":{"13":{"position":[[339,13]]}}}],["d",{"_index":606,"t":{"61":{"position":[[1177,2]]},"63":{"position":[[2101,2]]}}}],["data",{"_index":625,"t":{"63":{"position":[[406,4],[593,4],[1114,4]]}}}],["debug",{"_index":354,"t":{"21":{"position":[[100,5],[757,5]]}}}],["decadeβ€”yes",{"_index":540,"t":{"59":{"position":[[286,11]]}}}],["decent",{"_index":664,"t":{"63":{"position":[[1267,6]]}}}],["dedicated",{"_index":42,"t":{"3":{"position":[[557,9]]},"9":{"position":[[303,9]]}}}],["deeper",{"_index":380,"t":{"21":{"position":[[994,6]]},"29":{"position":[[76,6]]},"65":{"position":[[304,6]]}}}],["delve",{"_index":470,"t":{"29":{"position":[[70,5]]},"65":{"position":[[298,5]]}}}],["demonstrate",{"_index":162,"t":{"11":{"position":[[398,11],[574,11]]}}}],["deprecation",{"_index":745,"t":{"65":{"position":[[796,11]]}}}],["design",{"_index":227,"t":{"13":{"position":[[759,6]]},"15":{"position":[[1070,7]]},"25":{"position":[[68,6]]}}}],["designed",{"_index":361,"t":{"21":{"position":[[279,8]]},"25":{"position":[[184,8]]},"27":{"position":[[279,8]]}}}],["designers",{"_index":394,"t":{"25":{"position":[[211,9],[454,9]]}}}],["designs",{"_index":419,"t":{"25":{"position":[[907,8]]}}}],["desktop",{"_index":251,"t":{"13":{"position":[[1228,7]]},"61":{"position":[[396,7],[796,7]]}}}],["despite",{"_index":733,"t":{"65":{"position":[[559,7]]}}}],["details",{"_index":307,"t":{"15":{"position":[[991,7]]}}}],["dev",{"_index":351,"t":{"21":{"position":[[7,3],[440,3],[721,3],[818,3]]}}}],["developed",{"_index":318,"t":{"19":{"position":[[34,9]]},"27":{"position":[[564,9]]}}}],["developer",{"_index":222,"t":{"13":{"position":[[653,9]]}}}],["developers",{"_index":12,"t":{"3":{"position":[[150,10],[360,10],[575,10]]},"9":{"position":[[467,10]]},"11":{"position":[[730,10],[849,10]]},"13":{"position":[[31,10]]},"15":{"position":[[340,10],[821,10]]},"19":{"position":[[140,10],[652,10]]},"21":{"position":[[89,10],[170,10],[296,10],[473,10],[702,11],[881,10],[976,10],[1071,10]]},"25":{"position":[[225,11],[739,10]]},"27":{"position":[[617,10],[942,10],[1043,10]]},"31":{"position":[[566,10]]}}}],["developing",{"_index":263,"t":{"15":{"position":[[91,10]]}}}],["development",{"_index":156,"t":{"11":{"position":[[289,12],[437,11],[786,11]]},"13":{"position":[[1275,11]]},"19":{"position":[[486,11]]},"27":{"position":[[110,11]]},"33":{"position":[[243,11]]}}}],["device",{"_index":245,"t":{"13":{"position":[[1118,7]]}}}],["devices",{"_index":249,"t":{"13":{"position":[[1211,7]]}}}],["diagnose",{"_index":362,"t":{"21":{"position":[[307,8]]}}}],["didn't",{"_index":710,"t":{"65":{"position":[[82,6]]}}}],["dif",{"_index":673,"t":{"63":{"position":[[1457,3],[1479,3]]}}}],["different",{"_index":229,"t":{"13":{"position":[[791,9]]},"15":{"position":[[712,9],[748,9]]},"19":{"position":[[227,9],[545,9]]}}}],["direct",{"_index":793,"t":{"71":{"position":[[205,6]]}}}],["discord",{"_index":792,"t":{"71":{"position":[[193,7]]}}}],["displays",{"_index":252,"t":{"13":{"position":[[1236,9]]}}}],["dive",{"_index":752,"t":{"67":{"position":[[80,4]]}}}],["documentation",{"_index":79,"t":{"7":{"position":[[120,13],[245,13],[419,13],[509,13]]},"9":{"position":[[353,14]]}}}],["don't",{"_index":726,"t":{"65":{"position":[[467,5]]},"67":{"position":[[343,5]]}}}],["doormat23",{"_index":786,"t":{"71":{"position":[[46,9]]}}}],["draw",{"_index":371,"t":{"21":{"position":[[625,4]]},"63":{"position":[[422,4]]}}}],["drivers",{"_index":706,"t":{"65":{"position":[[18,7]]}}}],["driving",{"_index":546,"t":{"59":{"position":[[482,7]]}}}],["dynamic",{"_index":237,"t":{"13":{"position":[[932,7]]},"63":{"position":[[146,7]]}}}],["each",{"_index":208,"t":{"13":{"position":[[407,4]]},"63":{"position":[[1046,4]]}}}],["eager",{"_index":537,"t":{"59":{"position":[[228,5]]}}}],["easier",{"_index":11,"t":{"3":{"position":[[139,6]]},"13":{"position":[[663,7]]},"15":{"position":[[172,7]]},"17":{"position":[[47,6]]},"21":{"position":[[159,6],[747,6],[870,6]]},"25":{"position":[[48,6]]},"33":{"position":[[255,6]]}}}],["easily",{"_index":97,"t":{"7":{"position":[[362,6]]},"13":{"position":[[277,6]]},"25":{"position":[[815,6]]}}}],["easy",{"_index":131,"t":{"9":{"position":[[422,4],[458,4]]},"19":{"position":[[643,4]]},"25":{"position":[[669,4],[879,4],[1052,4]]}}}],["ecosystem",{"_index":387,"t":{"23":{"position":[[100,9]]},"35":{"position":[[421,10]]}}}],["edit",{"_index":403,"t":{"25":{"position":[[479,4]]}}}],["editing",{"_index":399,"t":{"25":{"position":[[391,7]]}}}],["editor",{"_index":390,"t":{"25":{"position":[[20,6],[174,6],[555,6]]}}}],["effect",{"_index":663,"t":{"63":{"position":[[1235,6]]}}}],["efficient",{"_index":383,"t":{"21":{"position":[[1118,9]]},"27":{"position":[[310,10],[1088,9]]},"33":{"position":[[271,10]]},"61":{"position":[[168,9]]}}}],["efficiently",{"_index":273,"t":{"15":{"position":[[371,12]]},"25":{"position":[[287,12]]}}}],["effort",{"_index":459,"t":{"27":{"position":[[835,6]]}}}],["element",{"_index":209,"t":{"13":{"position":[[412,7]]}}}],["elements",{"_index":410,"t":{"25":{"position":[[649,9]]},"31":{"position":[[355,8]]},"63":{"position":[[761,8],[1071,8]]}}}],["elevate",{"_index":764,"t":{"67":{"position":[[299,7]]}}}],["empowering",{"_index":721,"t":{"65":{"position":[[367,10]]}}}],["enable",{"_index":452,"t":{"27":{"position":[[610,6]]}}}],["enables",{"_index":223,"t":{"13":{"position":[[684,7]]}}}],["encapsulate",{"_index":716,"t":{"65":{"position":[[221,11]]}}}],["encounter",{"_index":737,"t":{"65":{"position":[[692,9]]}}}],["end",{"_index":66,"t":{"5":{"position":[[128,3]]},"19":{"position":[[482,3]]}}}],["engagement",{"_index":794,"t":{"71":{"position":[[212,10]]}}}],["engaging",{"_index":384,"t":{"21":{"position":[[1132,8]]}}}],["engine",{"_index":24,"t":{"3":{"position":[[300,8]]},"27":{"position":[[242,7],[858,6],[1098,6]]},"31":{"position":[[55,6]]},"33":{"position":[[97,7],[115,6],[184,6],[318,6]]},"59":{"position":[[382,7]]},"67":{"position":[[166,7]]}}}],["engineering",{"_index":551,"t":{"59":{"position":[[527,11]]}}}],["engines",{"_index":486,"t":{"31":{"position":[[315,7]]},"33":{"position":[[358,8]]}}}],["engineβ€”far",{"_index":715,"t":{"65":{"position":[[198,10]]}}}],["enhance",{"_index":7,"t":{"3":{"position":[[87,7]]},"65":{"position":[[134,7]]}}}],["ensuring",{"_index":420,"t":{"25":{"position":[[916,8]]}}}],["entirely",{"_index":656,"t":{"63":{"position":[[1143,8]]}}}],["era",{"_index":561,"t":{"61":{"position":[[146,4]]}}}],["especially",{"_index":373,"t":{"21":{"position":[[683,10]]}}}],["even",{"_index":10,"t":{"3":{"position":[[134,4]]},"31":{"position":[[577,4]]},"65":{"position":[[392,4]]},"67":{"position":[[260,4]]}}}],["everything",{"_index":93,"t":{"7":{"position":[[322,10]]},"13":{"position":[[1182,10]]},"33":{"position":[[138,10]]},"61":{"position":[[1136,10]]}}}],["example",{"_index":280,"t":{"15":{"position":[[481,8]]}}}],["examples",{"_index":103,"t":{"7":{"position":[[460,9]]},"11":{"position":[[250,8]]},"13":{"position":[[559,9]]}}}],["excited",{"_index":0,"t":{"3":{"position":[[7,7]]},"7":{"position":[[16,7]]},"23":{"position":[[133,7]]},"35":{"position":[[286,7]]}}}],["exciting",{"_index":71,"t":{"5":{"position":[[182,8]]},"27":{"position":[[439,8]]},"31":{"position":[[155,8]]},"35":{"position":[[22,8]]},"71":{"position":[[114,8]]}}}],["exclusive",{"_index":530,"t":{"59":{"position":[[27,9]]}}}],["execute",{"_index":596,"t":{"61":{"position":[[936,7]]},"63":{"position":[[616,7]]}}}],["executed",{"_index":639,"t":{"63":{"position":[[822,9]]}}}],["existing",{"_index":648,"t":{"63":{"position":[[947,8]]}}}],["expand",{"_index":494,"t":{"31":{"position":[[528,6]]}}}],["expect",{"_index":466,"t":{"27":{"position":[[1058,6]]},"33":{"position":[[159,6]]}}}],["experience",{"_index":303,"t":{"15":{"position":[[918,11]]},"27":{"position":[[157,10]]}}}],["experimenting",{"_index":783,"t":{"69":{"position":[[361,13]]}}}],["explore",{"_index":177,"t":{"11":{"position":[[967,7]]},"67":{"position":[[92,7],[369,7]]}}}],["extend",{"_index":515,"t":{"35":{"position":[[167,6]]}}}],["extension",{"_index":353,"t":{"21":{"position":[[35,9]]}}}],["extensive",{"_index":437,"t":{"27":{"position":[[147,9]]}}}],["factors",{"_index":547,"t":{"59":{"position":[[490,7]]}}}],["fall",{"_index":573,"t":{"61":{"position":[[532,4]]}}}],["fallback",{"_index":597,"t":{"61":{"position":[[953,8]]}}}],["familiar",{"_index":732,"t":{"65":{"position":[[546,8]]}}}],["fast",{"_index":582,"t":{"61":{"position":[[651,4]]},"63":{"position":[[177,5]]}}}],["faster",{"_index":298,"t":{"15":{"position":[[858,6]]},"27":{"position":[[294,6],[1072,6]]}}}],["feature",{"_index":275,"t":{"15":{"position":[[392,7]]},"25":{"position":[[785,8]]},"61":{"position":[[461,7]]}}}],["features",{"_index":130,"t":{"9":{"position":[[388,9],[556,8]]},"15":{"position":[[321,8],[807,8],[1038,8]]},"21":{"position":[[417,8]]},"25":{"position":[[320,8]]},"27":{"position":[[448,8]]},"33":{"position":[[211,8],[294,8]]},"59":{"position":[[213,8]]},"65":{"position":[[182,8]]}}}],["feedback",{"_index":753,"t":{"67":{"position":[[109,8]]}}}],["feel",{"_index":214,"t":{"13":{"position":[[515,4]]}}}],["few",{"_index":255,"t":{"13":{"position":[[1317,3]]},"19":{"position":[[817,3]]},"61":{"position":[[792,3]]}}}],["fiddle",{"_index":696,"t":{"63":{"position":[[1845,6]]}}}],["final",{"_index":421,"t":{"25":{"position":[[934,5]]}}}],["finalized",{"_index":533,"t":{"59":{"position":[[131,10]]}}}],["finally",{"_index":257,"t":{"15":{"position":[[0,8]]},"33":{"position":[[0,8]]}}}],["fine",{"_index":756,"t":{"67":{"position":[[150,4]]}}}],["first",{"_index":73,"t":{"7":{"position":[[0,5]]},"11":{"position":[[306,5]]},"27":{"position":[[490,5],[919,5]]},"61":{"position":[[488,5]]},"63":{"position":[[735,6]]}}}],["fit",{"_index":210,"t":{"13":{"position":[[423,3],[1095,3]]}}}],["flexibility",{"_index":241,"t":{"13":{"position":[[1031,11]]},"31":{"position":[[587,11]]}}}],["fly",{"_index":279,"t":{"15":{"position":[[472,4]]}}}],["focus",{"_index":331,"t":{"19":{"position":[[322,5]]}}}],["folder",{"_index":281,"t":{"15":{"position":[[516,6]]}}}],["follow",{"_index":358,"t":{"21":{"position":[[250,6]]},"71":{"position":[[39,6]]}}}],["following",{"_index":621,"t":{"63":{"position":[[361,9]]}}}],["fonts",{"_index":291,"t":{"15":{"position":[[703,5]]}}}],["formats",{"_index":292,"t":{"15":{"position":[[722,8],[758,8]]}}}],["forward",{"_index":465,"t":{"27":{"position":[[1027,7]]},"35":{"position":[[121,7],[368,7]]},"61":{"position":[[656,7]]}}}],["four",{"_index":61,"t":{"5":{"position":[[72,4]]}}}],["fragmentation",{"_index":38,"t":{"3":{"position":[[485,13]]}}}],["fragmented",{"_index":89,"t":{"7":{"position":[[262,10]]}}}],["frame",{"_index":651,"t":{"63":{"position":[[1051,6],[1364,5],[1417,5]]}}}],["frames",{"_index":646,"t":{"63":{"position":[[926,7]]}}}],["framework",{"_index":266,"t":{"15":{"position":[[195,9],[248,10],[1051,9]]}}}],["frameworks",{"_index":328,"t":{"19":{"position":[[250,11],[568,11]]},"31":{"position":[[326,10]]}}}],["free",{"_index":215,"t":{"13":{"position":[[520,4]]}}}],["friendly",{"_index":392,"t":{"25":{"position":[[150,8]]},"65":{"position":[[673,9]]}}}],["front",{"_index":337,"t":{"19":{"position":[[476,5]]}}}],["full",{"_index":45,"t":{"3":{"position":[[610,4]]}}}],["function",{"_index":774,"t":{"69":{"position":[[167,9],[229,8]]}}}],["functional",{"_index":185,"t":{"13":{"position":[[75,10]]},"25":{"position":[[956,10]]}}}],["further",{"_index":6,"t":{"3":{"position":[[79,7]]},"63":{"position":[[1190,7]]}}}],["future",{"_index":532,"t":{"59":{"position":[[52,6]]},"61":{"position":[[1123,6]]},"69":{"position":[[428,6]]}}}],["gained",{"_index":580,"t":{"61":{"position":[[634,6]]}}}],["game",{"_index":155,"t":{"11":{"position":[[284,4],[345,4],[371,5],[432,4],[725,4],[781,4]]},"13":{"position":[[305,5]]},"25":{"position":[[644,4],[705,4]]},"33":{"position":[[92,4],[110,4],[179,4],[238,4],[313,4]]}}}],["game's",{"_index":211,"t":{"13":{"position":[[432,6],[1147,6]]}}}],["games",{"_index":15,"t":{"3":{"position":[[179,5],[377,5]]},"11":{"position":[[58,7],[102,5],[151,5],[217,5],[316,5],[383,5],[536,5],[677,5],[888,5]]},"13":{"position":[[505,6]]},"25":{"position":[[86,5],[1136,5]]},"31":{"position":[[234,5]]}}}],["geared",{"_index":735,"t":{"65":{"position":[[624,6]]}}}],["generate",{"_index":278,"t":{"15":{"position":[[445,8],[556,8],[677,8]]}}}],["github",{"_index":112,"t":{"7":{"position":[[614,6]]},"9":{"position":[[643,6]]},"11":{"position":[[936,6],[1014,6]]},"13":{"position":[[579,6],[1341,6]]},"15":{"position":[[1140,6],[1152,6]]},"35":{"position":[[457,6]]},"67":{"position":[[403,6]]}}}],["give",{"_index":496,"t":{"31":{"position":[[561,4]]},"63":{"position":[[707,4]]}}}],["go",{"_index":563,"t":{"61":{"position":[[215,2]]},"63":{"position":[[612,3]]}}}],["good",{"_index":760,"t":{"67":{"position":[[215,5]]}}}],["goodboy",{"_index":474,"t":{"31":{"position":[[11,7]]}}}],["gpu",{"_index":456,"t":{"27":{"position":[[658,3]]},"61":{"position":[[247,3]]},"63":{"position":[[418,3],[601,3],[1370,3],[1394,3],[1464,3],[1471,3],[1475,3]]}}}],["graph",{"_index":617,"t":{"63":{"position":[[260,5],[330,5],[533,5],[888,5]]}}}],["graphics",{"_index":449,"t":{"27":{"position":[[537,8],[727,8],[1149,8]]},"59":{"position":[[69,8]]},"61":{"position":[[126,8]]},"63":{"position":[[66,9]]},"69":{"position":[[445,9]]}}}],["great",{"_index":28,"t":{"3":{"position":[[340,5]]},"11":{"position":[[817,5]]},"13":{"position":[[1173,5]]}}}],["greatly",{"_index":493,"t":{"31":{"position":[[520,7]]}}}],["ground",{"_index":435,"t":{"27":{"position":[[95,6]]}}}],["groups",{"_index":395,"t":{"25":{"position":[[251,6]]}}}],["grow",{"_index":523,"t":{"35":{"position":[[405,4]]}}}],["growth",{"_index":84,"t":{"7":{"position":[[170,6]]}}}],["guides",{"_index":102,"t":{"7":{"position":[[449,6]]}}}],["guiding",{"_index":747,"t":{"65":{"position":[[817,7]]}}}],["handful",{"_index":569,"t":{"61":{"position":[[385,7]]}}}],["handle",{"_index":329,"t":{"19":{"position":[[276,6]]}}}],["handling",{"_index":503,"t":{"33":{"position":[[380,9]]}}}],["happens",{"_index":705,"t":{"63":{"position":[[2079,7]]}}}],["having",{"_index":405,"t":{"25":{"position":[[512,6]]}}}],["heights",{"_index":766,"t":{"67":{"position":[[331,8]]}}}],["help",{"_index":30,"t":{"3":{"position":[[355,4]]},"15":{"position":[[335,4],[816,4]]},"21":{"position":[[84,4],[291,4],[468,4],[1066,4]]}}}],["high",{"_index":376,"t":{"21":{"position":[[901,4]]},"25":{"position":[[1123,4]]},"63":{"position":[[49,4]]}}}],["highly",{"_index":202,"t":{"13":{"position":[[332,6]]}}}],["history",{"_index":584,"t":{"61":{"position":[[721,7]]}}}],["hopefully",{"_index":166,"t":{"11":{"position":[[688,9]]}}}],["ideas",{"_index":108,"t":{"7":{"position":[[561,5]]},"25":{"position":[[1104,5]]}}}],["images",{"_index":283,"t":{"15":{"position":[[537,6],[776,7]]}}}],["immediately",{"_index":578,"t":{"61":{"position":[[605,11]]}}}],["implemented",{"_index":543,"t":{"59":{"position":[[336,11]]}}}],["import",{"_index":775,"t":{"69":{"position":[[177,6]]}}}],["important",{"_index":261,"t":{"15":{"position":[[73,9]]}}}],["improve",{"_index":36,"t":{"3":{"position":[[456,7]]},"7":{"position":[[577,7]]},"15":{"position":[[604,7]]},"27":{"position":[[700,7]]}}}],["improved",{"_index":302,"t":{"15":{"position":[[904,8]]}}}],["improvement",{"_index":441,"t":{"27":{"position":[[345,11]]},"61":{"position":[[53,11]]}}}],["improvements",{"_index":438,"t":{"27":{"position":[[192,12]]},"59":{"position":[[196,12]]},"63":{"position":[[1251,13],[1979,12]]},"65":{"position":[[333,12]]}}}],["improving",{"_index":100,"t":{"7":{"position":[[405,9]]},"9":{"position":[[316,9]]}}}],["include",{"_index":501,"t":{"33":{"position":[[330,7]]}}}],["includes",{"_index":188,"t":{"13":{"position":[[127,8]]}}}],["including",{"_index":268,"t":{"15":{"position":[[259,9]]},"19":{"position":[[580,9]]}}}],["inclusion",{"_index":446,"t":{"27":{"position":[[477,9]]}}}],["incorporate",{"_index":487,"t":{"31":{"position":[[340,11]]}}}],["incredibly",{"_index":388,"t":{"23":{"position":[[122,10]]}}}],["individual",{"_index":282,"t":{"15":{"position":[[526,10]]}}}],["information",{"_index":491,"t":{"31":{"position":[[471,11]]}}}],["init",{"_index":778,"t":{"69":{"position":[[238,6]]}}}],["initial",{"_index":568,"t":{"61":{"position":[[317,7]]}}}],["initiative",{"_index":5,"t":{"3":{"position":[[65,10]]}}}],["inner",{"_index":356,"t":{"21":{"position":[[199,5],[1022,5]]}}}],["input",{"_index":239,"t":{"13":{"position":[[972,5]]},"33":{"position":[[374,5]]}}}],["inputs",{"_index":194,"t":{"13":{"position":[[201,7]]}}}],["inspiration",{"_index":171,"t":{"11":{"position":[[833,11]]}}}],["install",{"_index":770,"t":{"69":{"position":[[16,7],[54,7]]}}}],["instructions",{"_index":632,"t":{"63":{"position":[[562,13],[647,13],[966,13],[1029,12]]}}}],["integrated",{"_index":201,"t":{"13":{"position":[[284,10]]}}}],["integrates",{"_index":134,"t":{"9":{"position":[[532,10]]}}}],["intensive",{"_index":457,"t":{"27":{"position":[[736,9],[1158,9]]}}}],["interface",{"_index":132,"t":{"9":{"position":[[434,9]]},"13":{"position":[[1154,9]]},"25":{"position":[[159,10],[352,9]]}}}],["interfaces",{"_index":187,"t":{"13":{"position":[[91,10],[766,10],[940,10]]}}}],["internal",{"_index":475,"t":{"31":{"position":[[43,8]]},"65":{"position":[[590,8]]}}}],["introduce",{"_index":56,"t":{"3":{"position":[[729,9]]},"65":{"position":[[154,9]]}}}],["intuitive",{"_index":391,"t":{"25":{"position":[[131,9]]}}}],["invaluable",{"_index":755,"t":{"67":{"position":[[135,10]]}}}],["invite",{"_index":758,"t":{"67":{"position":[[177,6]]},"71":{"position":[[25,6]]}}}],["issues",{"_index":363,"t":{"21":{"position":[[328,6]]}}}],["it's",{"_index":591,"t":{"61":{"position":[[853,4]]}}}],["iterate",{"_index":418,"t":{"25":{"position":[[896,7]]}}}],["iteration",{"_index":534,"t":{"59":{"position":[[152,9]]}}}],["itself",{"_index":586,"t":{"61":{"position":[[742,6]]}}}],["join",{"_index":784,"t":{"69":{"position":[[405,4]]},"71":{"position":[[163,4]]}}}],["json",{"_index":296,"t":{"15":{"position":[[795,5]]}}}],["jumpstart",{"_index":314,"t":{"19":{"position":[[0,9],[358,9],[746,10]]}}}],["key",{"_index":274,"t":{"15":{"position":[[388,3]]},"21":{"position":[[413,3]]},"63":{"position":[[677,3]]},"65":{"position":[[14,3]]}}}],["killer",{"_index":536,"t":{"59":{"position":[[177,6]]}}}],["know",{"_index":111,"t":{"7":{"position":[[608,5]]}}}],["lacked",{"_index":33,"t":{"3":{"position":[[420,6]]}}}],["languages",{"_index":107,"t":{"7":{"position":[[534,10]]}}}],["large",{"_index":250,"t":{"13":{"position":[[1222,5]]}}}],["later",{"_index":492,"t":{"31":{"position":[[483,5]]}}}],["launch",{"_index":2,"t":{"3":{"position":[[31,6]]},"61":{"position":[[325,7]]}}}],["layout",{"_index":165,"t":{"11":{"position":[[640,6]]},"13":{"position":[[598,6],[840,6],[1010,7],[1253,6],[1334,6]]}}}],["layouts",{"_index":225,"t":{"13":{"position":[[717,7],[1063,7]]}}}],["leap",{"_index":464,"t":{"27":{"position":[[1022,4]]},"29":{"position":[[21,4]]},"63":{"position":[[1286,4]]}}}],["learn",{"_index":170,"t":{"11":{"position":[[753,5]]}}}],["leverage",{"_index":599,"t":{"61":{"position":[[995,8]]}}}],["leveraged",{"_index":436,"t":{"27":{"position":[[131,9]]}}}],["libraries",{"_index":72,"t":{"5":{"position":[[205,9]]},"9":{"position":[[632,10]]},"11":{"position":[[475,9],[615,9]]},"13":{"position":[[903,9]]}}}],["library",{"_index":115,"t":{"9":{"position":[[27,7],[141,7],[288,7],[402,7],[524,7]]},"13":{"position":[[19,7],[119,7],[616,7],[676,7]]},"15":{"position":[[138,7],[214,7]]},"33":{"position":[[70,7]]}}}],["library's",{"_index":127,"t":{"9":{"position":[[330,9]]}}}],["license",{"_index":151,"t":{"11":{"position":[[187,8]]}}}],["life",{"_index":221,"t":{"13":{"position":[[643,4]]}}}],["line",{"_index":408,"t":{"25":{"position":[[537,4]]}}}],["links",{"_index":525,"t":{"35":{"position":[[464,5]]}}}],["lists",{"_index":197,"t":{"13":{"position":[[223,6]]}}}],["little",{"_index":85,"t":{"7":{"position":[[197,6]]}}}],["loading",{"_index":299,"t":{"15":{"position":[[865,7]]},"33":{"position":[[396,7]]}}}],["long",{"_index":81,"t":{"7":{"position":[[152,4]]},"23":{"position":[[21,4]]},"31":{"position":[[400,4]]}}}],["longer",{"_index":321,"t":{"19":{"position":[[159,6]]},"31":{"position":[[285,6]]}}}],["look",{"_index":246,"t":{"13":{"position":[[1168,4]]},"29":{"position":[[62,4]]},"35":{"position":[[116,4],[363,4]]}}}],["looking",{"_index":172,"t":{"11":{"position":[[860,7]]},"27":{"position":[[953,7]]}}}],["loop",{"_index":635,"t":{"63":{"position":[[697,4]]},"71":{"position":[[16,5]]}}}],["lot",{"_index":509,"t":{"35":{"position":[[15,3],[109,3]]}}}],["made",{"_index":458,"t":{"27":{"position":[[816,4]]},"59":{"position":[[472,5]]}}}],["maintain",{"_index":35,"t":{"3":{"position":[[443,8]]}}}],["maintenance",{"_index":126,"t":{"9":{"position":[[269,11]]}}}],["major",{"_index":386,"t":{"23":{"position":[[72,5]]},"27":{"position":[[27,5],[577,5],[1016,5]]}}}],["make",{"_index":9,"t":{"3":{"position":[[126,4]]},"13":{"position":[[633,4]]},"15":{"position":[[154,4]]},"17":{"position":[[39,4]]},"19":{"position":[[635,4]]},"21":{"position":[[151,4],[739,4],[862,4]]},"25":{"position":[[40,4]]},"27":{"position":[[187,4]]},"33":{"position":[[233,4]]},"61":{"position":[[1150,4]]},"63":{"position":[[270,4]]}}}],["makes",{"_index":133,"t":{"9":{"position":[[449,5]]},"25":{"position":[[870,5],[1043,5]]}}}],["making",{"_index":411,"t":{"25":{"position":[[659,6]]},"31":{"position":[[431,6]]},"35":{"position":[[251,6]]},"65":{"position":[[638,6]]}}}],["manage",{"_index":271,"t":{"15":{"position":[[351,6]]}}}],["management",{"_index":260,"t":{"15":{"position":[[56,10]]},"33":{"position":[[408,11],[426,11]]}}}],["manpower",{"_index":34,"t":{"3":{"position":[[431,8]]}}}],["many",{"_index":27,"t":{"3":{"position":[[335,4]]},"15":{"position":[[1026,4]]},"27":{"position":[[173,4]]},"33":{"position":[[206,4]]},"65":{"position":[[213,4]]}}}],["market",{"_index":590,"t":{"61":{"position":[[836,7]]}}}],["match",{"_index":158,"t":{"11":{"position":[[337,5]]}}}],["matter",{"_index":592,"t":{"61":{"position":[[865,6]]}}}],["means",{"_index":226,"t":{"13":{"position":[[745,5],[1131,5]]},"25":{"position":[[443,5]]}}}],["media",{"_index":788,"t":{"71":{"position":[[77,6]]}}}],["mentioned",{"_index":526,"t":{"35":{"position":[[470,9]]}}}],["method",{"_index":564,"t":{"61":{"position":[[221,6]]}}}],["methodology",{"_index":741,"t":{"65":{"position":[[742,11]]}}}],["minify",{"_index":295,"t":{"15":{"position":[[788,6]]}}}],["minutes",{"_index":347,"t":{"19":{"position":[[821,7]]}}}],["mipmaps",{"_index":289,"t":{"15":{"position":[[686,8]]}}}],["miss",{"_index":727,"t":{"65":{"position":[[473,4]]}}}],["mit",{"_index":150,"t":{"11":{"position":[[183,3]]}}}],["mix",{"_index":482,"t":{"31":{"position":[[204,3]]}}}],["mobile",{"_index":248,"t":{"13":{"position":[[1204,6]]}}}],["modifications",{"_index":738,"t":{"65":{"position":[[702,14]]}}}],["months",{"_index":50,"t":{"3":{"position":[[638,7]]},"35":{"position":[[148,7]]}}}],["monumental",{"_index":545,"t":{"59":{"position":[[450,10]]}}}],["more",{"_index":51,"t":{"3":{"position":[[654,4]]},"7":{"position":[[444,4]]},"11":{"position":[[531,4]]},"15":{"position":[[986,4]]},"19":{"position":[[619,5]]},"21":{"position":[[1113,4]]},"25":{"position":[[282,4],[432,5]]},"27":{"position":[[305,4],[1083,4]]},"31":{"position":[[466,4],[582,4]]},"33":{"position":[[266,4],[466,5]]},"35":{"position":[[505,4]]},"61":{"position":[[163,4]]},"65":{"position":[[397,4],[652,4]]},"71":{"position":[[109,4]]}}}],["moved",{"_index":638,"t":{"63":{"position":[[804,6]]}}}],["moving",{"_index":675,"t":{"63":{"position":[[1500,6],[1556,6]]}}}],["much",{"_index":88,"t":{"7":{"position":[[226,4]]},"27":{"position":[[1067,4]]},"65":{"position":[[534,4]]}}}],["multi",{"_index":424,"t":{"25":{"position":[[1000,5]]}}}],["multiple",{"_index":90,"t":{"7":{"position":[[280,8]]},"21":{"position":[[596,8]]}}}],["naΓ―ve",{"_index":614,"t":{"63":{"position":[[209,7]]}}}],["nearing",{"_index":65,"t":{"5":{"position":[[116,7]]}}}],["need",{"_index":94,"t":{"7":{"position":[[337,4]]},"19":{"position":[[166,4]]},"31":{"position":[[292,4]]}}}],["needing",{"_index":601,"t":{"61":{"position":[[1042,7]]}}}],["needs",{"_index":213,"t":{"13":{"position":[[448,6]]}}}],["net",{"_index":662,"t":{"63":{"position":[[1231,3]]}}}],["new",{"_index":58,"t":{"5":{"position":[[16,3],[191,3]]},"7":{"position":[[84,3],[301,3]]},"9":{"position":[[384,3]]},"11":{"position":[[23,3]]},"13":{"position":[[15,3]]},"15":{"position":[[124,3],[454,3],[958,3]]},"19":{"position":[[15,3],[99,3],[784,3]]},"21":{"position":[[698,3]]},"25":{"position":[[16,3]]},"27":{"position":[[254,3],[533,3]]},"29":{"position":[[31,3]]},"33":{"position":[[66,3]]},"35":{"position":[[42,3],[331,3]]},"59":{"position":[[419,3]]},"61":{"position":[[142,3],[357,3]]},"65":{"position":[[178,3],[462,4]]},"69":{"position":[[144,3]]}}}],["newcomer",{"_index":554,"t":{"61":{"position":[[4,8]]}}}],["news",{"_index":510,"t":{"35":{"position":[[31,4]]}}}],["next",{"_index":48,"t":{"3":{"position":[[630,4]]},"9":{"position":[[0,4]]},"13":{"position":[[1312,4]]},"27":{"position":[[22,4]]}}}],["note",{"_index":730,"t":{"65":{"position":[[510,5]]}}}],["notes",{"_index":728,"t":{"65":{"position":[[490,6]]}}}],["nothing",{"_index":637,"t":{"63":{"position":[[792,7]]}}}],["now",{"_index":141,"t":{"11":{"position":[[8,3]]},"31":{"position":[[19,4],[114,3]]},"61":{"position":[[687,3]]},"67":{"position":[[45,3]]}}}],["npm",{"_index":769,"t":{"69":{"position":[[4,3],[50,3]]}}}],["number",{"_index":699,"t":{"63":{"position":[[1897,6]]}}}],["numbers",{"_index":691,"t":{"63":{"position":[[1690,7],[1936,7]]}}}],["objects",{"_index":369,"t":{"21":{"position":[[605,7],[793,8]]}}}],["odie",{"_index":477,"t":{"31":{"position":[[69,4]]}}}],["offer",{"_index":500,"t":{"33":{"position":[[200,5]]},"59":{"position":[[18,5]]}}}],["offers",{"_index":555,"t":{"61":{"position":[[20,6]]}}}],["one",{"_index":95,"t":{"7":{"position":[[345,3]]},"21":{"position":[[402,3]]},"25":{"position":[[300,3]]},"27":{"position":[[423,3]]},"63":{"position":[[608,3]]}}}],["open",{"_index":145,"t":{"11":{"position":[[53,4],[90,4],[672,4]]},"13":{"position":[[493,4]]},"31":{"position":[[130,4]]}}}],["operates",{"_index":612,"t":{"63":{"position":[[186,8]]}}}],["opportunity",{"_index":713,"t":{"65":{"position":[[119,11]]}}}],["optimal",{"_index":749,"t":{"65":{"position":[[837,7]]}}}],["optimizations",{"_index":439,"t":{"27":{"position":[[209,13]]}}}],["optimize",{"_index":297,"t":{"15":{"position":[[832,8]]},"21":{"position":[[225,8],[570,8],[767,8],[1082,8]]},"27":{"position":[[845,8]]},"63":{"position":[[121,8]]}}}],["optimizing",{"_index":640,"t":{"63":{"position":[[832,10]]}}}],["option",{"_index":461,"t":{"27":{"position":[[931,6]]}}}],["options",{"_index":409,"t":{"25":{"position":[[592,7]]}}}],["organic",{"_index":83,"t":{"7":{"position":[[162,7]]}}}],["out",{"_index":217,"t":{"13":{"position":[[540,3]]},"15":{"position":[[1132,3]]},"35":{"position":[[449,3]]}}}],["outside",{"_index":472,"t":{"29":{"position":[[94,7]]}}}],["over",{"_index":47,"t":{"3":{"position":[[621,4]]},"5":{"position":[[84,4]]},"7":{"position":[[177,4]]},"9":{"position":[[264,4]]},"27":{"position":[[168,4]]},"59":{"position":[[265,4]]},"61":{"position":[[65,4]]}}}],["overall",{"_index":374,"t":{"21":{"position":[[802,8]]},"27":{"position":[[984,8]]}}}],["overhaul",{"_index":708,"t":{"65":{"position":[[38,8]]}}}],["overhead",{"_index":642,"t":{"63":{"position":[[857,9],[996,8]]}}}],["overview",{"_index":724,"t":{"65":{"position":[[443,8]]}}}],["packed",{"_index":535,"t":{"59":{"position":[[165,6]]}}}],["parameters",{"_index":697,"t":{"63":{"position":[[1861,10]]}}}],["parcel",{"_index":340,"t":{"19":{"position":[[599,7]]}}}],["part",{"_index":262,"t":{"15":{"position":[[83,4]]}}}],["party",{"_index":140,"t":{"9":{"position":[[626,5]]},"63":{"position":[[2056,5]]}}}],["patrick",{"_index":121,"t":{"9":{"position":[[160,7]]}}}],["perfect",{"_index":751,"t":{"67":{"position":[[56,7]]}}}],["performance",{"_index":128,"t":{"9":{"position":[[340,12]]},"15":{"position":[[616,11],[887,12]]},"21":{"position":[[316,11],[906,12]]},"27":{"position":[[370,11],[712,11]]},"59":{"position":[[184,11]]},"61":{"position":[[41,11]]},"63":{"position":[[54,11],[717,11],[1274,11]]},"65":{"position":[[52,11]]}}}],["phase",{"_index":67,"t":{"5":{"position":[[135,5]]},"15":{"position":[[13,5]]},"17":{"position":[[0,5]]},"23":{"position":[[0,5]]},"29":{"position":[[0,5]]}}}],["phaser",{"_index":270,"t":{"15":{"position":[[290,7]]}}}],["phases",{"_index":62,"t":{"5":{"position":[[77,6]]}}}],["physics",{"_index":502,"t":{"33":{"position":[[350,7]]}}}],["pipeline",{"_index":553,"t":{"59":{"position":[[566,8]]}}}],["pixi",{"_index":120,"t":{"9":{"position":[[136,4]]}}}],["pixi.js",{"_index":776,"t":{"69":{"position":[[212,10]]}}}],["pixi.js@prerelease",{"_index":771,"t":{"69":{"position":[[62,18]]}}}],["pixijs",{"_index":3,"t":{"3":{"position":[[45,6],[115,6],[206,6],[405,7],[603,6]]},"5":{"position":[[219,7]]},"7":{"position":[[100,7],[238,6]]},"9":{"position":[[11,6],[62,6],[92,6],[211,6],[247,6],[512,7],[568,6]]},"11":{"position":[[45,7],[134,6],[273,6],[421,6],[493,6],[597,6],[633,6],[651,6],[665,6],[770,6],[900,7]]},"13":{"position":[[0,6],[107,7],[455,6],[569,6],[591,6],[731,7],[833,6],[863,6],[1003,6],[1246,6],[1327,6]]},"15":{"position":[[269,7]]},"17":{"position":[[67,6]]},"19":{"position":[[51,6],[103,6],[683,6],[788,6]]},"21":{"position":[[0,6],[112,6],[217,7],[433,6],[530,7],[714,6],[811,6],[955,7],[1040,7]]},"23":{"position":[[93,6]]},"25":{"position":[[114,7]]},"27":{"position":[[0,6],[79,6],[235,6],[269,6],[460,6],[795,6],[993,6]]},"29":{"position":[[49,6]]},"31":{"position":[[99,7],[262,6]]},"33":{"position":[[85,6],[306,6]]},"35":{"position":[[81,6],[200,6],[414,6],[525,6]]},"59":{"position":[[103,6],[375,6]]},"61":{"position":[[587,6],[921,6]]},"63":{"position":[[0,6]]},"65":{"position":[[516,6],[645,6]]},"67":{"position":[[307,6],[381,6]]},"69":{"position":[[380,6]]},"71":{"position":[[60,6]]}}}],["pixijs's",{"_index":495,"t":{"31":{"position":[[535,8]]},"61":{"position":[[308,8],[443,8]]}}}],["pixijs’s",{"_index":703,"t":{"63":{"position":[[2047,8]]}}}],["place",{"_index":96,"t":{"7":{"position":[[349,5]]}}}],["plan",{"_index":575,"t":{"61":{"position":[[557,4]]}}}],["planned",{"_index":54,"t":{"3":{"position":[[677,8]]},"11":{"position":[[542,7]]},"21":{"position":[[53,7]]}}}],["planning",{"_index":99,"t":{"7":{"position":[[393,8]]},"31":{"position":[[118,8]]}}}],["plans",{"_index":489,"t":{"31":{"position":[[451,5]]}}}],["play",{"_index":180,"t":{"11":{"position":[[1026,4],[1048,4]]},"63":{"position":[[1831,5]]}}}],["playco",{"_index":40,"t":{"3":{"position":[[534,6]]},"31":{"position":[[24,7]]},"35":{"position":[[240,6]]}}}],["player",{"_index":415,"t":{"25":{"position":[[778,6]]}}}],["playing",{"_index":538,"t":{"59":{"position":[[251,7]]}}}],["please",{"_index":110,"t":{"7":{"position":[[594,6]]},"63":{"position":[[1817,6]]}}}],["plethora",{"_index":714,"t":{"65":{"position":[[166,8]]}}}],["plugins",{"_index":288,"t":{"15":{"position":[[666,7]]}}}],["popular",{"_index":18,"t":{"3":{"position":[[231,7]]},"19":{"position":[[461,7]]}}}],["position",{"_index":654,"t":{"63":{"position":[[1100,9]]}}}],["possible",{"_index":519,"t":{"35":{"position":[[270,9]]}}}],["post",{"_index":306,"t":{"15":{"position":[[967,4]]},"65":{"position":[[245,5]]}}}],["posts",{"_index":717,"t":{"65":{"position":[[280,5]]}}}],["potions",{"_index":182,"t":{"11":{"position":[[1040,7]]}}}],["powered",{"_index":565,"t":{"61":{"position":[[251,7]]}}}],["powerful",{"_index":375,"t":{"21":{"position":[[838,8]]}}}],["practices",{"_index":360,"t":{"21":{"position":[[262,10]]},"65":{"position":[[845,10]]}}}],["precisely",{"_index":602,"t":{"61":{"position":[[1080,9]]}}}],["predecessor",{"_index":557,"t":{"61":{"position":[[74,12]]}}}],["preferred",{"_index":344,"t":{"19":{"position":[[710,9]]}}}],["preview",{"_index":531,"t":{"59":{"position":[[37,7]]}}}],["process",{"_index":265,"t":{"15":{"position":[[164,7]]},"19":{"position":[[79,7]]},"21":{"position":[[507,7],[641,7]]}}}],["product",{"_index":422,"t":{"25":{"position":[[940,7]]}}}],["professional",{"_index":154,"t":{"11":{"position":[[237,12]]}}}],["progress",{"_index":199,"t":{"13":{"position":[[249,8]]},"31":{"position":[[438,8]]},"67":{"position":[[6,8]]}}}],["project",{"_index":174,"t":{"11":{"position":[[912,7],[1005,8]]},"31":{"position":[[372,8],[410,8]]}}}],["projects",{"_index":53,"t":{"3":{"position":[[668,8]]},"5":{"position":[[20,8]]},"9":{"position":[[237,9]]},"23":{"position":[[31,8]]},"35":{"position":[[46,8]]},"65":{"position":[[413,9]]}}}],["proof",{"_index":605,"t":{"61":{"position":[[1130,5]]}}}],["propels",{"_index":559,"t":{"61":{"position":[[97,7]]}}}],["provide",{"_index":153,"t":{"11":{"position":[[229,7]]},"15":{"position":[[498,7]]},"19":{"position":[[523,7]]},"33":{"position":[[130,7]]}}}],["provides",{"_index":116,"t":{"9":{"position":[[40,8],[410,8]]},"15":{"position":[[301,8],[657,8],[977,8]]},"25":{"position":[[365,8],[562,8]]}}}],["providing",{"_index":379,"t":{"21":{"position":[[966,9]]},"27":{"position":[[321,9]]},"61":{"position":[[151,9]]}}}],["purpose",{"_index":152,"t":{"11":{"position":[[200,7]]}}}],["put",{"_index":92,"t":{"7":{"position":[[318,3]]}}}],["puzzling",{"_index":181,"t":{"11":{"position":[[1031,8]]}}}],["quality",{"_index":429,"t":{"25":{"position":[[1128,7]]}}}],["radio",{"_index":198,"t":{"13":{"position":[[230,5]]}}}],["range",{"_index":189,"t":{"13":{"position":[[138,5]]},"15":{"position":[[312,5]]},"25":{"position":[[573,5]]}}}],["ratios",{"_index":233,"t":{"13":{"position":[[825,7]]}}}],["re",{"_index":550,"t":{"59":{"position":[[524,2]]}}}],["react",{"_index":114,"t":{"9":{"position":[[18,6],[72,5],[99,5],[130,5],[231,5],[488,5]]},"11":{"position":[[658,6]]},"19":{"position":[[418,5]]}}}],["read",{"_index":541,"t":{"59":{"position":[[302,4]]}}}],["ready",{"_index":254,"t":{"13":{"position":[[1299,5]]}}}],["real",{"_index":218,"t":{"13":{"position":[[548,4]]},"25":{"position":[[1012,4]]},"71":{"position":[[227,4]]}}}],["reconstructing",{"_index":650,"t":{"63":{"position":[[1008,14]]}}}],["record",{"_index":430,"t":{"25":{"position":[[1162,6]]}}}],["recreate",{"_index":416,"t":{"25":{"position":[[822,8]]}}}],["reduce",{"_index":462,"t":{"27":{"position":[[964,6]]}}}],["reducing",{"_index":661,"t":{"63":{"position":[[1198,8]]}}}],["refinements",{"_index":720,"t":{"65":{"position":[[354,12]]}}}],["regardless",{"_index":343,"t":{"19":{"position":[[690,10]]}}}],["release",{"_index":70,"t":{"5":{"position":[[163,7]]},"11":{"position":[[554,8]]},"27":{"position":[[33,7]]},"31":{"position":[[507,7]]},"59":{"position":[[92,7],[423,7]]},"65":{"position":[[482,7]]},"67":{"position":[[26,7]]}}}],["released",{"_index":142,"t":{"11":{"position":[[12,8],[164,8],[322,8]]},"21":{"position":[[67,8]]}}}],["releasing",{"_index":60,"t":{"5":{"position":[[54,9]]},"7":{"position":[[52,9]]},"15":{"position":[[946,9]]}}}],["remains",{"_index":643,"t":{"63":{"position":[[894,7]]}}}],["remarkable",{"_index":722,"t":{"65":{"position":[[402,10]]}}}],["reminiscent",{"_index":567,"t":{"61":{"position":[[293,11]]}}}],["render",{"_index":623,"t":{"63":{"position":[[388,6]]}}}],["renderer",{"_index":20,"t":{"3":{"position":[[242,8]]},"27":{"position":[[880,9]]},"63":{"position":[[217,9],[2022,9]]},"69":{"position":[[125,8],[253,8],[344,8]]}}}],["rendering",{"_index":23,"t":{"3":{"position":[[290,9]]},"21":{"position":[[583,9],[780,9]]},"27":{"position":[[360,9]]},"29":{"position":[[117,10]]},"59":{"position":[[556,9]]},"61":{"position":[[232,9],[502,9]]},"63":{"position":[[154,10],[624,9],[956,9],[1345,9],[1398,9]]}}}],["repeating",{"_index":585,"t":{"61":{"position":[[732,9]]}}}],["repo",{"_index":113,"t":{"7":{"position":[[621,4]]},"9":{"position":[[650,4]]},"11":{"position":[[1021,4]]},"13":{"position":[[586,4],[1348,4]]},"15":{"position":[[1147,4],[1159,4]]},"63":{"position":[[1812,4]]}}}],["repository",{"_index":143,"t":{"11":{"position":[[27,10]]}}}],["represents",{"_index":432,"t":{"27":{"position":[[46,10],[1003,10]]},"29":{"position":[[8,10]]}}}],["resizable",{"_index":242,"t":{"13":{"position":[[1053,9]]}}}],["resource",{"_index":168,"t":{"11":{"position":[[712,8]]}}}],["resources",{"_index":365,"t":{"21":{"position":[[353,9]]},"35":{"position":[[345,10]]}}}],["respond",{"_index":238,"t":{"13":{"position":[[956,7]]}}}],["responsive",{"_index":224,"t":{"13":{"position":[[706,10]]}}}],["rest",{"_index":739,"t":{"65":{"position":[[717,4]]}}}],["retains",{"_index":731,"t":{"65":{"position":[[526,7]]}}}],["return",{"_index":782,"t":{"69":{"position":[[319,6]]}}}],["reuse",{"_index":647,"t":{"63":{"position":[[937,5]]}}}],["revealed",{"_index":385,"t":{"23":{"position":[[52,9]]}}}],["revisited",{"_index":609,"t":{"63":{"position":[[91,9]]}}}],["rewrite",{"_index":434,"t":{"27":{"position":[[68,7]]},"61":{"position":[[1053,7]]}}}],["right",{"_index":349,"t":{"19":{"position":[[848,5]]},"59":{"position":[[312,6]]},"67":{"position":[[359,5]]}}}],["robust",{"_index":562,"t":{"61":{"position":[[182,6]]},"65":{"position":[[657,6]]}}}],["rollup",{"_index":341,"t":{"19":{"position":[[607,7]]}}}],["roughly",{"_index":588,"t":{"61":{"position":[[817,7]]}}}],["runtime",{"_index":414,"t":{"25":{"position":[[770,7]]}}}],["same",{"_index":370,"t":{"21":{"position":[[620,4]]},"61":{"position":[[948,4]]}}}],["saving",{"_index":659,"t":{"63":{"position":[[1169,6]]}}}],["scene",{"_index":616,"t":{"63":{"position":[[254,5],[324,5],[527,5],[587,5],[882,5],[1087,5],[1625,5]]}}}],["scenes",{"_index":400,"t":{"25":{"position":[[399,7],[492,6],[831,6]]}}}],["screen",{"_index":230,"t":{"13":{"position":[[801,6],[982,6],[1103,6]]},"63":{"position":[[444,7]]}}}],["scroll",{"_index":195,"t":{"13":{"position":[[209,6]]}}}],["seamlessly",{"_index":481,"t":{"31":{"position":[[193,10]]}}}],["searchable",{"_index":98,"t":{"7":{"position":[[369,11]]}}}],["second",{"_index":620,"t":{"63":{"position":[[338,6],[867,7]]}}}],["see",{"_index":521,"t":{"35":{"position":[[297,3]]},"63":{"position":[[1927,3]]},"65":{"position":[[790,3]]}}}],["seen",{"_index":69,"t":{"5":{"position":[[154,4]]}}}],["seized",{"_index":712,"t":{"65":{"position":[[107,6]]}}}],["set",{"_index":322,"t":{"19":{"position":[[174,3]]},"63":{"position":[[555,3]]}}}],["setting",{"_index":326,"t":{"19":{"position":[[216,7]]}}}],["settings",{"_index":781,"t":{"69":{"position":[[298,8]]}}}],["setup",{"_index":330,"t":{"19":{"position":[[291,5]]}}}],["several",{"_index":57,"t":{"5":{"position":[[8,7],[174,7]]}}}],["shaping",{"_index":785,"t":{"69":{"position":[[416,7]]}}}],["share",{"_index":490,"t":{"31":{"position":[[460,5]]},"67":{"position":[[191,5]]}}}],["shared",{"_index":508,"t":{"35":{"position":[[6,6]]}}}],["sharing",{"_index":428,"t":{"25":{"position":[[1085,7]]}}}],["sheets",{"_index":285,"t":{"15":{"position":[[572,7]]}}}],["shift",{"_index":566,"t":{"61":{"position":[[284,5]]}}}],["shooter",{"_index":161,"t":{"11":{"position":[[363,7]]}}}],["shortly",{"_index":313,"t":{"17":{"position":[[19,7]]},"71":{"position":[[131,8]]}}}],["showcases",{"_index":148,"t":{"11":{"position":[[113,9]]}}}],["significant",{"_index":440,"t":{"27":{"position":[[333,11],[823,11]]},"59":{"position":[[348,11]]},"65":{"position":[[578,11]]}}}],["significantly",{"_index":286,"t":{"15":{"position":[[590,13]]},"27":{"position":[[686,13]]}}}],["similar",{"_index":333,"t":{"19":{"position":[[376,7]]}}}],["simplify",{"_index":319,"t":{"19":{"position":[[66,8]]}}}],["simply",{"_index":744,"t":{"65":{"position":[[783,6]]}}}],["sincere",{"_index":516,"t":{"35":{"position":[[178,7]]}}}],["single",{"_index":407,"t":{"25":{"position":[[530,6]]},"63":{"position":[[1357,6],[1410,6]]},"65":{"position":[[238,6]]}}}],["site",{"_index":109,"t":{"7":{"position":[[589,4]]}}}],["sites",{"_index":91,"t":{"7":{"position":[[289,6]]}}}],["sitting",{"_index":444,"t":{"27":{"position":[[408,7]]}}}],["situation",{"_index":672,"t":{"63":{"position":[[1429,9]]}}}],["size",{"_index":244,"t":{"13":{"position":[[1110,4]]},"27":{"position":[[978,5]]}}}],["sizes",{"_index":231,"t":{"13":{"position":[[808,5]]}}}],["skipped",{"_index":657,"t":{"63":{"position":[[1152,8]]}}}],["sliders",{"_index":192,"t":{"13":{"position":[[187,8]]}}}],["small",{"_index":247,"t":{"13":{"position":[[1198,5]]}}}],["social",{"_index":787,"t":{"71":{"position":[[70,6]]}}}],["somewhat",{"_index":613,"t":{"63":{"position":[[200,8]]}}}],["soon",{"_index":304,"t":{"15":{"position":[[938,4]]},"21":{"position":[[76,4]]},"61":{"position":[[194,5]]}}}],["source",{"_index":147,"t":{"11":{"position":[[95,6],[823,6]]},"13":{"position":[[498,6]]},"31":{"position":[[135,6]]}}}],["specific",{"_index":212,"t":{"13":{"position":[[439,8]]}}}],["speed",{"_index":608,"t":{"63":{"position":[[39,5]]}}}],["spend",{"_index":670,"t":{"63":{"position":[[1381,5]]}}}],["spent",{"_index":669,"t":{"63":{"position":[[1328,5]]}}}],["sprite",{"_index":284,"t":{"15":{"position":[[565,6]]}}}],["sprites",{"_index":401,"t":{"25":{"position":[[407,8],[613,8]]},"63":{"position":[[1488,7],[1544,7],[1607,7]]}}}],["stage",{"_index":754,"t":{"67":{"position":[[126,5]]}}}],["standout",{"_index":397,"t":{"25":{"position":[[311,8]]},"61":{"position":[[452,8]]}}}],["start",{"_index":348,"t":{"19":{"position":[[833,5]]},"23":{"position":[[40,5]]},"59":{"position":[[245,5]]},"69":{"position":[[355,5]]}}}],["started",{"_index":342,"t":{"19":{"position":[[670,7]]},"25":{"position":[[681,7]]}}}],["state",{"_index":504,"t":{"33":{"position":[[420,5]]}}}],["static",{"_index":611,"t":{"63":{"position":[[135,6]]}}}],["stay",{"_index":528,"t":{"35":{"position":[[490,4]]},"65":{"position":[[251,4]]},"71":{"position":[[4,4]]}}}],["step",{"_index":655,"t":{"63":{"position":[[1126,4],[1131,5]]}}}],["still",{"_index":253,"t":{"13":{"position":[[1263,5]]}}}],["stop",{"_index":711,"t":{"65":{"position":[[89,4]]}}}],["strategy",{"_index":598,"t":{"61":{"position":[[962,9]]}}}],["strictly",{"_index":473,"t":{"29":{"position":[[105,8]]}}}],["structure",{"_index":86,"t":{"7":{"position":[[204,9]]},"63":{"position":[[1631,10]]}}}],["stuck",{"_index":309,"t":{"15":{"position":[[1106,5]]}}}],["stunning",{"_index":378,"t":{"21":{"position":[[928,8]]}}}],["subsequent",{"_index":645,"t":{"63":{"position":[[915,10]]}}}],["substantial",{"_index":556,"t":{"61":{"position":[[29,11]]}}}],["such",{"_index":87,"t":{"7":{"position":[[221,4]]},"11":{"position":[[485,4],[625,4]]},"13":{"position":[[158,4]]},"19":{"position":[[403,4]]}}}],["suffered",{"_index":80,"t":{"7":{"position":[[138,8]]}}}],["suited",{"_index":467,"t":{"27":{"position":[[1120,6]]}}}],["support",{"_index":129,"t":{"9":{"position":[[372,7]]},"27":{"position":[[502,7],[782,8]]},"33":{"position":[[338,7]]},"35":{"position":[[393,7]]}}}],["supported",{"_index":587,"t":{"61":{"position":[[772,9],[910,10]]}}}],["sure",{"_index":524,"t":{"35":{"position":[[435,4]]},"63":{"position":[[275,4]]}}}],["switch",{"_index":484,"t":{"31":{"position":[[300,6]]}}}],["synonymous",{"_index":607,"t":{"63":{"position":[[23,10]]}}}],["take",{"_index":453,"t":{"27":{"position":[[631,4]]}}}],["taken",{"_index":125,"t":{"9":{"position":[[258,5]]}}}],["team",{"_index":43,"t":{"3":{"position":[[567,4]]},"19":{"position":[[58,4]]},"27":{"position":[[122,4],[802,4]]},"31":{"position":[[423,4]]}}}],["teams",{"_index":426,"t":{"25":{"position":[[1061,5]]}}}],["technique",{"_index":368,"t":{"21":{"position":[[552,9]]}}}],["technology",{"_index":600,"t":{"61":{"position":[[1013,10]]}}}],["templates",{"_index":338,"t":{"19":{"position":[[531,9]]}}}],["ten",{"_index":52,"t":{"3":{"position":[[664,3]]},"59":{"position":[[319,3]]},"61":{"position":[[1167,3]]}}}],["term",{"_index":82,"t":{"7":{"position":[[157,4]]},"23":{"position":[[26,4]]},"31":{"position":[[405,4]]}}}],["territory",{"_index":469,"t":{"29":{"position":[[35,9]]}}}],["test",{"_index":417,"t":{"25":{"position":[[887,4]]},"63":{"position":[[1726,4]]}}}],["text",{"_index":193,"t":{"13":{"position":[[196,4]]}}}],["thanks",{"_index":517,"t":{"35":{"position":[[186,6]]}}}],["there's",{"_index":513,"t":{"35":{"position":[[99,7]]}}}],["thereby",{"_index":658,"t":{"63":{"position":[[1161,7]]}}}],["things",{"_index":629,"t":{"63":{"position":[[494,6]]}}}],["third",{"_index":652,"t":{"63":{"position":[[1058,6]]}}}],["those",{"_index":480,"t":{"31":{"position":[[168,5]]}}}],["thoughtsβ€”the",{"_index":759,"t":{"67":{"position":[[202,12]]}}}],["three",{"_index":634,"t":{"63":{"position":[[671,5]]}}}],["threejs",{"_index":269,"t":{"15":{"position":[[277,8]]}}}],["thrilled",{"_index":497,"t":{"33":{"position":[[16,8]]},"59":{"position":[[6,8]]}}}],["time",{"_index":46,"t":{"3":{"position":[[615,5]]},"25":{"position":[[1017,4],[1169,5]]},"61":{"position":[[341,5],[875,4]]},"63":{"position":[[345,4],[1323,4],[1376,4]]},"67":{"position":[[64,4]]},"71":{"position":[[232,4]]}}}],["times",{"_index":300,"t":{"15":{"position":[[873,6]]}}}],["today",{"_index":310,"t":{"15":{"position":[[1115,5]]},"61":{"position":[[667,6]]},"69":{"position":[[395,5]]}}}],["together",{"_index":427,"t":{"25":{"position":[[1075,9]]},"67":{"position":[[282,9]]}}}],["tool",{"_index":316,"t":{"19":{"position":[[23,4],[134,5],[266,4],[513,4]]},"21":{"position":[[138,4],[847,4]]}}}],["tooling",{"_index":324,"t":{"19":{"position":[[193,7]]}}}],["tools",{"_index":29,"t":{"3":{"position":[[346,5],[470,6]]},"5":{"position":[[195,5]]},"19":{"position":[[397,5],[720,5]]},"21":{"position":[[11,5],[444,5],[725,5],[822,5]]},"25":{"position":[[582,5]]},"33":{"position":[[224,5]]},"35":{"position":[[335,5]]}}}],["toolset",{"_index":382,"t":{"21":{"position":[[1053,7]]}}}],["top",{"_index":479,"t":{"31":{"position":[[92,3]]}}}],["toward",{"_index":736,"t":{"65":{"position":[[631,6]]},"67":{"position":[[15,6]]}}}],["towards",{"_index":748,"t":{"65":{"position":[[829,7]]}}}],["traction",{"_index":581,"t":{"61":{"position":[[641,9]]}}}],["transform",{"_index":628,"t":{"63":{"position":[[476,9]]}}}],["transforms",{"_index":618,"t":{"63":{"position":[[288,10]]}}}],["translating",{"_index":106,"t":{"7":{"position":[[493,11]]}}}],["traverse",{"_index":615,"t":{"63":{"position":[[241,8],[311,8],[514,8]]}}}],["tricks",{"_index":704,"t":{"63":{"position":[[2062,7]]}}}],["try",{"_index":693,"t":{"63":{"position":[[1744,3]]}}}],["tuned",{"_index":529,"t":{"35":{"position":[[495,5]]},"65":{"position":[[256,5]]}}}],["tuning",{"_index":757,"t":{"67":{"position":[[155,6]]}}}],["tweak",{"_index":205,"t":{"13":{"position":[[369,5]]}}}],["tweening",{"_index":506,"t":{"33":{"position":[[452,9]]}}}],["two",{"_index":157,"t":{"11":{"position":[[312,3]]},"59":{"position":[[478,3]]},"65":{"position":[[10,3]]}}}],["ubiquitous",{"_index":571,"t":{"61":{"position":[[431,11]]}}}],["uglyβ€”report",{"_index":762,"t":{"67":{"position":[[238,11]]}}}],["ui",{"_index":163,"t":{"11":{"position":[[500,2]]},"13":{"position":[[7,2],[462,2],[576,2],[870,3]]}}}],["unchanged",{"_index":644,"t":{"63":{"position":[[902,9]]}}}],["under",{"_index":149,"t":{"11":{"position":[[173,5]]},"13":{"position":[[1269,5]]}}}],["undergoing",{"_index":734,"t":{"65":{"position":[[567,10]]}}}],["understand",{"_index":355,"t":{"21":{"position":[[184,10],[484,10],[671,11]]}}}],["understanding",{"_index":381,"t":{"21":{"position":[[1001,13]]}}}],["universally",{"_index":595,"t":{"61":{"position":[[898,11]]}}}],["universe",{"_index":4,"t":{"3":{"position":[[52,9]]},"35":{"position":[[532,9]]}}}],["unprecedented",{"_index":765,"t":{"67":{"position":[[317,13]]}}}],["unveiling",{"_index":789,"t":{"71":{"position":[[99,9]]}}}],["up",{"_index":74,"t":{"7":{"position":[[6,2]]},"9":{"position":[[5,2]]},"19":{"position":[[178,2],[224,2]]},"27":{"position":[[102,3]]}}}],["upcoming",{"_index":514,"t":{"35":{"position":[[139,8]]},"65":{"position":[[266,8]]}}}],["update",{"_index":627,"t":{"63":{"position":[[465,6],[745,6]]}}}],["updates",{"_index":511,"t":{"35":{"position":[[59,7],[510,7]]},"65":{"position":[[599,8]]},"71":{"position":[[123,7]]}}}],["upload",{"_index":624,"t":{"63":{"position":[[395,6],[576,6],[1119,6]]}}}],["url",{"_index":698,"t":{"63":{"position":[[1879,3]]}}}],["usability",{"_index":709,"t":{"65":{"position":[[68,10]]}}}],["use",{"_index":118,"t":{"9":{"position":[[58,3],[430,3]]},"11":{"position":[[130,3],[269,3],[417,3],[465,3],[593,3],[766,3]]},"15":{"position":[[1009,3]]},"63":{"position":[[1306,3]]}}}],["used",{"_index":124,"t":{"9":{"position":[[199,4]]},"13":{"position":[[474,4]]},"15":{"position":[[234,4]]},"21":{"position":[[562,4]]}}}],["useful",{"_index":308,"t":{"15":{"position":[[1031,6]]}}}],["user",{"_index":186,"t":{"13":{"position":[[86,4],[967,4]]},"15":{"position":[[913,4]]},"25":{"position":[[145,4],[1006,5]]},"65":{"position":[[668,4]]}}}],["using",{"_index":173,"t":{"11":{"position":[[894,5]]},"13":{"position":[[725,5]]},"69":{"position":[[134,5]]}}}],["v7",{"_index":443,"t":{"27":{"position":[[394,2]]},"63":{"position":[[171,2],[227,2],[1439,2],[1461,2],[1758,2]]},"65":{"position":[[739,2]]}}}],["v8",{"_index":431,"t":{"27":{"position":[[7,2],[467,2],[1000,2]]},"59":{"position":[[110,3],[578,3]]},"63":{"position":[[81,3],[452,2],[1446,2],[1468,2],[1771,2],[1792,2]]},"65":{"position":[[523,2]]},"67":{"position":[[100,3],[388,2]]},"69":{"position":[[81,2],[387,2]]}}}],["valuable",{"_index":167,"t":{"11":{"position":[[703,8]]}}}],["varying",{"_index":665,"t":{"63":{"position":[[1298,7]]}}}],["vendors",{"_index":451,"t":{"27":{"position":[[591,8]]}}}],["version",{"_index":76,"t":{"7":{"position":[[69,7]]},"27":{"position":[[258,7]]},"61":{"position":[[1095,7]]},"69":{"position":[[33,7]]}}}],["via",{"_index":768,"t":{"69":{"position":[[0,3]]}}}],["vibrant",{"_index":791,"t":{"71":{"position":[[172,7]]}}}],["views",{"_index":196,"t":{"13":{"position":[[216,6]]}}}],["visual",{"_index":398,"t":{"25":{"position":[[345,6]]}}}],["visualize",{"_index":364,"t":{"21":{"position":[[339,9]]}}}],["visually",{"_index":377,"t":{"21":{"position":[[919,8]]},"25":{"position":[[971,8]]}}}],["vue",{"_index":335,"t":{"19":{"position":[[438,4]]}}}],["waitβ€”dive",{"_index":767,"t":{"67":{"position":[[349,9]]}}}],["want",{"_index":169,"t":{"11":{"position":[[745,4]]},"13":{"position":[[46,4]]},"15":{"position":[[1094,4]]},"31":{"position":[[185,4]]},"35":{"position":[[159,4]]}}}],["warning",{"_index":746,"t":{"65":{"position":[[808,8]]}}}],["way",{"_index":117,"t":{"9":{"position":[[51,3]]}}}],["we'll",{"_index":718,"t":{"65":{"position":[[292,5]]},"71":{"position":[[90,5]]}}}],["we're",{"_index":520,"t":{"35":{"position":[[280,5]]},"59":{"position":[[0,5],[222,5]]}}}],["we've",{"_index":507,"t":{"35":{"position":[[0,5]]},"59":{"position":[[461,5]]},"63":{"position":[[85,5]]},"65":{"position":[[101,5]]}}}],["web",{"_index":21,"t":{"3":{"position":[[259,4]]},"59":{"position":[[65,3]]},"61":{"position":[[105,3],[274,4]]},"69":{"position":[[441,3]]}}}],["webgl",{"_index":558,"t":{"61":{"position":[[87,6],[347,5],[517,5],[628,5],[678,5]]},"63":{"position":[[1806,5],[2016,5]]},"69":{"position":[[328,5]]}}}],["webgpu",{"_index":448,"t":{"27":{"position":[[514,7],[775,6]]},"61":{"position":[[13,6],[754,7]]},"63":{"position":[[1785,6],[2001,6]]},"69":{"position":[[337,6]]}}}],["webpack",{"_index":339,"t":{"19":{"position":[[590,8]]}}}],["website",{"_index":77,"t":{"7":{"position":[[88,7],[305,7]]}}}],["weeks",{"_index":256,"t":{"13":{"position":[[1321,5]]}}}],["well",{"_index":104,"t":{"7":{"position":[[473,4]]},"13":{"position":[[853,4]]}}}],["what's",{"_index":725,"t":{"65":{"position":[[455,6]]}}}],["widely",{"_index":123,"t":{"9":{"position":[[192,6]]}}}],["without",{"_index":404,"t":{"25":{"position":[[499,7]]},"61":{"position":[[1034,7]]}}}],["work",{"_index":44,"t":{"3":{"position":[[595,4]]},"17":{"position":[[57,4]]},"25":{"position":[[277,4],[1070,4]]},"63":{"position":[[1221,5]]}}}],["workflows",{"_index":345,"t":{"19":{"position":[[730,10]]}}}],["working",{"_index":498,"t":{"33":{"position":[[53,7]]}}}],["workings",{"_index":357,"t":{"21":{"position":[[205,8],[1028,8]]}}}],["works",{"_index":59,"t":{"5":{"position":[[36,6]]},"13":{"position":[[847,5]]}}}],["workβ€”you'll",{"_index":743,"t":{"65":{"position":[[771,11]]}}}],["world",{"_index":219,"t":{"13":{"position":[[553,5]]}}}],["worry",{"_index":325,"t":{"19":{"position":[[204,5]]}}}],["write",{"_index":406,"t":{"25":{"position":[[522,5]]}}}],["x2",{"_index":445,"t":{"27":{"position":[[419,3]]}}}],["year",{"_index":63,"t":{"5":{"position":[[93,5]]},"31":{"position":[[496,5]]}}}],["years",{"_index":17,"t":{"3":{"position":[[199,6]]},"7":{"position":[[186,5]]},"27":{"position":[[178,5]]},"31":{"position":[[4,6]]},"61":{"position":[[1171,5]]}}}],["years!β€”we've",{"_index":542,"t":{"59":{"position":[[323,12]]}}}],["you'll",{"_index":346,"t":{"19":{"position":[[757,6]]},"35":{"position":[[306,6]]}}}],["yourself",{"_index":694,"t":{"63":{"position":[[1748,9]]}}}]],"pipeline":["stemmer"]}}] \ No newline at end of file +[{"documents":[{"i":1,"t":"","u":"/blog/archive","b":["Blog"]},{"i":2,"t":"PixiJS v8 Beta! πŸŽ‰","u":"/blog/pixi-v8-beta","b":["Blog"]},{"i":112,"t":"Introducing the PixiJS Universe!","u":"/blog/pixi-universe","b":["Blog"]}],"index":{"version":"2.3.9","fields":["t"],"fieldVectors":[["t/1",[]],["t/2",[0,0.364,1,0.759,2,0.759,3,0.759]],["t/112",[0,0.421,4,0.878,5,0.878]]],"invertedIndex":[["",{"_index":3,"t":{"2":{"position":[[16,2]]}}}],["beta",{"_index":2,"t":{"2":{"position":[[10,5]]}}}],["introducing",{"_index":4,"t":{"112":{"position":[[0,11]]}}}],["pixijs",{"_index":0,"t":{"2":{"position":[[0,6]]},"112":{"position":[[16,6]]}}}],["universe",{"_index":5,"t":{"112":{"position":[[23,9]]}}}],["v8",{"_index":1,"t":{"2":{"position":[[7,2]]}}}]],"pipeline":["stemmer"]}},{"documents":[{"i":4,"t":"1. 😍 Embracing WebGPU","u":"/blog/pixi-v8-beta","h":"#1--embracing-webgpu","p":2},{"i":6,"t":"2. πŸš€ Turbocharging Performance","u":"/blog/pixi-v8-beta","h":"#2--turbocharging-performance","p":2},{"i":8,"t":"But Wait, There's More!","u":"/blog/pixi-v8-beta","h":"#but-wait-theres-more","p":2},{"i":10,"t":"Over to you!","u":"/blog/pixi-v8-beta","h":"#over-to-you","p":2},{"i":12,"t":"Steps to install:","u":"/blog/pixi-v8-beta","h":"#steps-to-install","p":2},{"i":14,"t":"Keep in touch!","u":"/blog/pixi-v8-beta","h":"#keep-in-touch","p":2},{"i":114,"t":"Phase 1​","u":"/blog/pixi-universe","h":"#phase-1","p":112},{"i":116,"t":"PixiJS Website​","u":"/blog/pixi-universe","h":"#pixijs-website","p":112},{"i":118,"t":"PixiJS React​","u":"/blog/pixi-universe","h":"#pixijs-react","p":112},{"i":120,"t":"PixiJS Open Games​","u":"/blog/pixi-universe","h":"#pixijs-open-games","p":112},{"i":122,"t":"PixiJS UI & PixiJS Layout​","u":"/blog/pixi-universe","h":"#pixijs-ui--pixijs-layout","p":112},{"i":124,"t":"AssetPack​","u":"/blog/pixi-universe","h":"#assetpack","p":112},{"i":126,"t":"Phase 2​","u":"/blog/pixi-universe","h":"#phase-2","p":112},{"i":128,"t":"PixiJS JumpStart​","u":"/blog/pixi-universe","h":"#pixijs-jumpstart","p":112},{"i":130,"t":"PixiJS Dev Tools​","u":"/blog/pixi-universe","h":"#pixijs-dev-tools","p":112},{"i":132,"t":"Phase 3​","u":"/blog/pixi-universe","h":"#phase-3","p":112},{"i":134,"t":"Comet​","u":"/blog/pixi-universe","h":"#comet","p":112},{"i":136,"t":"PixiJS v8​","u":"/blog/pixi-universe","h":"#pixijs-v8","p":112},{"i":138,"t":"Phase 4​","u":"/blog/pixi-universe","h":"#phase-4","p":112},{"i":140,"t":"PixiJS 3D​","u":"/blog/pixi-universe","h":"#pixijs-3d","p":112},{"i":142,"t":"PixiJS Game Engine​","u":"/blog/pixi-universe","h":"#pixijs-game-engine","p":112},{"i":144,"t":"Conclusion","u":"/blog/pixi-universe","h":"#conclusion","p":112}],"index":{"version":"2.3.9","fields":["t"],"fieldVectors":[["t/4",[0,1.711,1,1.452,2,2.105,3,2.105]],["t/6",[1,1.452,4,1.711,5,2.105,6,2.105]],["t/8",[7,2.437,8,2.437,9,2.437]],["t/10",[10,3.558]],["t/12",[11,2.892,12,2.892]],["t/14",[13,2.892,14,2.892]],["t/114",[0,2.351,15,1.728]],["t/116",[16,0.937,17,2.892]],["t/118",[16,0.937,18,2.892]],["t/120",[16,0.789,19,2.437,20,2.437]],["t/122",[1,1.278,16,0.917,21,1.853,22,1.853]],["t/124",[23,3.558]],["t/126",[4,2.351,15,1.728]],["t/128",[16,0.937,24,2.892]],["t/130",[16,0.789,25,2.437,26,2.437]],["t/132",[15,1.728,27,2.892]],["t/134",[28,3.558]],["t/136",[16,0.937,29,2.892]],["t/138",[15,1.728,30,2.892]],["t/140",[16,0.937,31,2.892]],["t/142",[16,0.789,32,2.437,33,2.437]],["t/144",[34,3.558]]],"invertedIndex":[["",{"_index":1,"t":{"4":{"position":[[3,2]]},"6":{"position":[[3,2]]},"122":{"position":[[10,1]]}}}],["1",{"_index":0,"t":{"4":{"position":[[0,2]]},"114":{"position":[[6,2]]}}}],["2",{"_index":4,"t":{"6":{"position":[[0,2]]},"126":{"position":[[6,2]]}}}],["3",{"_index":27,"t":{"132":{"position":[[6,2]]}}}],["3d",{"_index":31,"t":{"140":{"position":[[7,3]]}}}],["4",{"_index":30,"t":{"138":{"position":[[6,2]]}}}],["assetpack",{"_index":23,"t":{"124":{"position":[[0,10]]}}}],["comet",{"_index":28,"t":{"134":{"position":[[0,6]]}}}],["conclusion",{"_index":34,"t":{"144":{"position":[[0,10]]}}}],["dev",{"_index":25,"t":{"130":{"position":[[7,3]]}}}],["embracing",{"_index":2,"t":{"4":{"position":[[6,9]]}}}],["engine",{"_index":33,"t":{"142":{"position":[[12,7]]}}}],["game",{"_index":32,"t":{"142":{"position":[[7,4]]}}}],["games",{"_index":20,"t":{"120":{"position":[[12,6]]}}}],["install",{"_index":12,"t":{"12":{"position":[[9,8]]}}}],["jumpstart",{"_index":24,"t":{"128":{"position":[[7,10]]}}}],["keep",{"_index":13,"t":{"14":{"position":[[0,4]]}}}],["layout",{"_index":22,"t":{"122":{"position":[[19,7]]}}}],["more",{"_index":9,"t":{"8":{"position":[[18,5]]}}}],["open",{"_index":19,"t":{"120":{"position":[[7,4]]}}}],["over",{"_index":10,"t":{"10":{"position":[[0,4]]}}}],["performance",{"_index":6,"t":{"6":{"position":[[20,11]]}}}],["phase",{"_index":15,"t":{"114":{"position":[[0,5]]},"126":{"position":[[0,5]]},"132":{"position":[[0,5]]},"138":{"position":[[0,5]]}}}],["pixijs",{"_index":16,"t":{"116":{"position":[[0,6]]},"118":{"position":[[0,6]]},"120":{"position":[[0,6]]},"122":{"position":[[0,6],[12,6]]},"128":{"position":[[0,6]]},"130":{"position":[[0,6]]},"136":{"position":[[0,6]]},"140":{"position":[[0,6]]},"142":{"position":[[0,6]]}}}],["react",{"_index":18,"t":{"118":{"position":[[7,6]]}}}],["steps",{"_index":11,"t":{"12":{"position":[[0,5]]}}}],["there's",{"_index":8,"t":{"8":{"position":[[10,7]]}}}],["tools",{"_index":26,"t":{"130":{"position":[[11,6]]}}}],["touch",{"_index":14,"t":{"14":{"position":[[8,6]]}}}],["turbocharging",{"_index":5,"t":{"6":{"position":[[6,13]]}}}],["ui",{"_index":21,"t":{"122":{"position":[[7,2]]}}}],["v8",{"_index":29,"t":{"136":{"position":[[7,3]]}}}],["wait",{"_index":7,"t":{"8":{"position":[[4,5]]}}}],["webgpu",{"_index":3,"t":{"4":{"position":[[16,6]]}}}],["website",{"_index":17,"t":{"116":{"position":[[7,8]]}}}]],"pipeline":["stemmer"]}},{"documents":[{"i":3,"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":2},{"i":5,"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":2},{"i":7,"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 Bunnmark - WebGPU v8 Bunnmark - 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":2},{"i":9,"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":2},{"i":11,"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":2},{"i":13,"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":2},{"i":15,"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":2},{"i":113,"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":112},{"i":115,"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":112},{"i":117,"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":112},{"i":119,"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":112},{"i":121,"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":112},{"i":123,"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":112},{"i":125,"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":112},{"i":127,"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":112},{"i":129,"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":112},{"i":131,"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":112},{"i":133,"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":112},{"i":135,"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":112},{"i":137,"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":112},{"i":139,"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":112},{"i":141,"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":112},{"i":143,"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":112},{"i":145,"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":112}],"index":{"version":"2.3.9","fields":["t"],"fieldVectors":[["t/3",[0,3.421,1,2.582,2,2.582,3,3.155,4,3.155,5,2.205,6,1.698,7,1.923,8,1.698,9,2.921,10,1.789,11,0.03,12,2.001,13,2.582,14,3.155,15,3.155,16,3.155,17,3.155,18,1.21,19,1.923,20,1.21,21,3.155,22,1.923,23,3.155,24,1.35,25,3.155,26,3.155,27,3.155,28,2.205,29,2.205,30,3.155,31,3.155,32,2.205,33,1.698,34,1.511,35,3.155,36,0.4,37,3.155,38,1.923,39,2.582,40,2.205,41,3.155,42,3.155,43,3.155,44,2.205,45,3.155,46,3.155,47,2.582,48,1.35,49,3.155]],["t/5",[5,1.583,7,2.022,8,1.219,11,0.024,18,0.869,24,0.97,29,1.583,36,0.421,44,1.583,48,1.419,50,2.266,51,2.022,52,2.266,53,2.266,54,1.854,55,2.266,56,3.213,57,2.266,58,2.266,59,2.266,60,1.583,61,0.439,62,1.381,63,1.854,64,1.583,65,1.583,66,1.854,67,2.266,68,1.583,69,2.266,70,2.715,71,2.266,72,2.266,73,2.715,74,2.266,75,1.854,76,1.588,77,2.742,78,2.266,79,2.715,80,3.924,81,2.715,82,2.266,83,1.854,84,1.583,85,1.583,86,1.219,87,2.266,88,2.266,89,2.266,90,2.266,91,2.266,92,2.266,93,2.266,94,2.266,95,2.266,96,2.266,97,1.854,98,1.583,99,1.583,100,1.381,101,2.266,102,2.266,103,2.266,104,2.266,105,1.583,106,3.317,107,1.583,108,2.266,109,2.266,110,2.266,111,2.266,112,2.266,113,2.266,114,2.266,115,2.266,116,1.085,117,1.854,118,1.854,119,2.266,120,2.266,121,1.381,122,1.583,123,2.266,124,1.583,125,2.266,126,1.854,127,2.266,128,1.854,129,1.085,130,2.266,131,1.381,132,2.266,133,2.266,134,2.266,135,1.381,136,0.625,137,1.854,138,1.219,139,1.854]],["t/7",[8,0.821,11,0.011,12,1.964,18,1.176,19,1.492,33,0.821,38,0.93,44,1.711,48,1.644,51,1.492,56,1.711,66,1.249,68,3.011,76,1.468,86,0.821,97,1.249,117,1.249,122,1.067,124,1.067,129,0.731,136,0.421,139,1.249,140,1.526,141,1.526,142,1.067,143,1.526,144,1.526,145,0.93,146,1.067,147,1.526,148,1.249,149,2.685,150,1.526,151,1.526,152,1.526,153,1.492,154,3.066,155,4.309,156,3.509,157,1.249,158,1.526,159,1.526,160,2.449,161,1.526,162,1.067,163,1.526,164,1.526,165,3.066,166,3.066,167,1.249,168,1.526,169,1.249,170,2.449,171,1.526,172,1.526,173,2.449,174,1.526,175,1.249,176,3.509,177,0.821,178,2.449,179,1.526,180,0.93,181,1.249,182,1.249,183,1.526,184,1.711,185,1.526,186,1.526,187,1.526,188,1.526,189,2.449,190,2.449,191,1.526,192,1.526,193,1.526,194,1.526,195,1.526,196,1.526,197,1.526,198,1.526,199,1.249,200,3.066,201,1.526,202,2.449,203,1.526,204,2.449,205,1.067,206,1.526,207,1.526,208,1.526,209,1.526,210,1.526,211,1.249,212,1.526,213,0.93,214,1.526,215,1.526,216,1.526,217,1.067,218,1.526,219,0.93,220,1.526,221,3.842,222,1.711,223,1.526,224,1.711,225,1.526,226,1.526,227,1.526,228,2.449,229,3.066,230,2.51,231,2.449,232,2.449,233,1.526,234,1.526,235,3.066,236,2.449,237,2.449,238,1.526,239,1.526,240,1.526,241,1.526,242,1.526,243,1.526,244,1.249,245,1.526,246,1.526,247,1.526,248,2.449,249,2.449,250,1.249,251,1.526,252,1.526,253,2.449,254,0.731,255,1.249,256,1.249,257,1.526,258,1.526,259,1.526,260,1.526,261,1.526,262,1.526,263,1.067,264,1.526,265,1.526,266,1.249,267,1.526,268,1.526,269,1.249]],["t/9",[10,1.129,11,0.027,12,1.263,18,1.011,19,1.607,20,1.011,32,1.843,33,1.419,36,0.469,38,1.607,40,1.843,61,0.716,63,2.158,64,2.985,149,1.843,180,1.607,224,1.843,263,1.843,270,2.637,271,2.637,272,2.637,273,2.637,274,2.637,275,2.637,276,2.637,277,2.637,278,2.158,279,2.158,280,2.637,281,2.637,282,1.419,283,2.637,284,2.158,285,1.843,286,2.158,287,2.158,288,2.158,289,2.637,290,2.158,291,2.158,292,1.843,293,2.637,294,2.637,295,2.637,296,0.813,297,1.607,298,2.637,299,1.263,300,2.637,301,2.637,302,2.637,303,2.158,304,2.637,305,2.637,306,2.637,307,2.637,308,2.637,309,1.843,310,2.637,311,2.637,312,2.637,313,2.158,314,1.843,315,2.637,316,2.158,317,1.607,318,1.607,319,2.158,320,2.637,321,2.637,322,2.637,323,2.637,324,2.637,325,2.637,326,2.637,327,2.637,328,2.637,329,2.637,330,2.637,331,2.637,332,2.637,333,2.158]],["t/11",[10,1.487,11,0.032,12,2.131,28,2.428,34,1.664,47,2.844,76,1.664,100,2.118,129,1.664,222,2.428,297,2.118,303,2.844,316,2.844,334,2.428,335,3.475,336,3.475,337,3.475,338,3.643,339,3.475,340,3.475,341,3.475,342,3.475,343,3.475,344,2.844,345,2.844,346,3.475,347,3.475,348,3.475,349,3.475,350,3.475,351,2.844,352,2.844,353,3.475,354,3.475,355,3.475,356,3.475,357,1.487]],["t/13",[5,2.246,6,1.73,7,1.959,8,1.73,9,2.957,11,0.023,12,2.026,22,1.959,36,0.407,51,1.959,56,2.246,99,2.246,131,1.959,153,2.883,222,3.922,296,0.991,358,3.214,359,4.231,360,4.231,361,3.214,362,3.214,363,2.246,364,4.73,365,4.231,366,3.214,367,3.214,368,3.214,369,3.214,370,3.214,371,3.214,372,3.214,373,3.214,374,3.214,375,2.631,376,3.214]],["t/15",[11,0.028,61,0.754,76,1.865,181,3.188,285,2.722,290,3.188,314,2.722,344,3.188,375,3.188,377,3.188,378,3.896,379,3.896,380,3.896,381,3.896,382,2.097,383,3.188,384,3.896,385,3.896,386,2.097,387,3.896,388,3.896,389,3.896,390,2.722,391,3.896]],["t/113",[6,1.591,7,1.801,11,0.036,24,1.265,29,2.065,34,1.415,48,1.265,61,0.572,75,2.419,76,1.415,122,2.065,136,0.816,138,1.591,153,1.801,162,2.065,211,2.419,213,1.801,278,2.419,279,2.419,282,1.591,296,0.911,297,1.801,299,1.415,386,2.153,392,1.801,393,2.065,394,2.419,395,2.956,396,2.065,397,1.265,398,1.398,399,2.956,400,2.153,401,2.956,402,2.419,403,2.419,404,2.065,405,1.712,406,2.065,407,1.016,408,2.956,409,2.956,410,2.956,411,1.801,412,2.956,413,2.956,414,2.956,415,2.065,416,2.956,417,2.419,418,1.801,419,2.956,420,1.801,421,2.956,422,2.419,423,2.065,424,2.956]],["t/115",[10,1.693,11,0.028,24,1.693,36,0.612,105,2.764,299,1.894,382,2.129,405,1.693,425,4.827,426,3.237,427,2.764,428,3.956,429,3.956,430,3.237,431,3.956,432,3.237,433,2.129,434,3.237,435,3.956,436,2.411]],["t/117",[9,2.191,11,0.03,24,1.342,36,0.528,61,0.607,86,1.688,131,1.911,135,1.911,138,1.688,177,1.688,244,2.566,254,1.501,255,2.566,309,2.191,357,1.342,392,1.911,393,2.191,411,1.911,427,2.191,437,1.911,438,4.163,439,3.136,440,4.074,441,3.136,442,2.191,443,2.191,444,3.136,445,3.136,446,3.136,447,1.911,448,3.136,449,2.566,450,3.136,451,3.136,452,2.191,453,3.136,454,2.191,455,3.136,456,2.566,457,2.566,458,3.136,459,3.136,460,2.191,461,2.566,462,3.136,463,3.136,464,3.136,465,2.566,466,3.136,467,3.136]],["t/119",[11,0.038,18,1.14,20,1.54,24,1.272,36,0.377,219,2.448,254,1.423,266,2.433,296,1.238,299,1.423,357,1.272,386,1.6,398,0.917,403,2.433,407,1.381,417,2.433,420,1.812,436,1.812,437,1.812,440,2.433,457,2.433,468,3.665,469,3.101,470,2.807,471,2.973,472,2.973,473,2.973,474,2.973,475,2.973,476,2.973,477,1.812,478,2.973,479,2.973,480,2.973,481,1.812,482,2.807,483,2.077,484,2.433,485,2.973,486,2.433,487,2.433,488,2.973,489,2.433,490,2.973]],["t/121",[10,1.038,11,0.039,36,0.308,40,1.695,61,0.47,77,1.695,86,1.306,100,1.479,129,1.162,205,1.695,219,2.997,254,1.162,256,2.853,296,1.075,338,1.985,351,1.985,357,1.492,363,1.695,398,1.075,400,2.841,404,1.695,423,1.695,436,2.125,447,2.125,460,1.695,468,1.695,491,3.339,492,2.426,493,1.695,494,2.851,495,2.426,496,2.436,497,2.426,498,1.985,499,2.426,500,2.426,501,2.426,502,1.479,503,2.426,504,2.997,505,2.196,506,2.426,507,2.426,508,2.426,509,3.486,510,1.985,511,1.985,512,1.985,513,2.426,514,2.426,515,2.426,516,1.306,517,2.426,518,2.426,519,1.985,520,2.853,521,2.426,522,2.426,523,2.426,524,3.486]],["t/123",[11,0.038,33,1.112,36,0.262,79,1.69,107,1.443,121,1.888,135,1.259,136,0.57,137,1.69,146,1.443,148,1.69,169,3.041,199,1.69,254,1.483,296,1.273,318,1.888,334,1.443,357,1.325,363,1.443,390,1.443,397,0.884,398,0.637,400,1.112,404,1.443,420,1.259,426,1.69,436,1.259,447,1.259,454,1.443,460,1.443,461,1.69,469,2.516,477,1.259,483,1.443,489,2.535,494,1.443,496,1.443,498,1.69,504,1.259,505,1.112,510,3.379,512,3.62,516,1.112,525,2.065,526,1.69,527,3.716,528,2.065,529,1.443,530,3.097,531,2.065,532,2.065,533,2.065,534,2.065,535,2.065,536,2.065,537,2.065,538,2.065,539,2.065,540,2.065,541,2.065,542,2.065,543,2.065,544,2.065,545,2.065,546,2.065,547,3.097,548,3.097,549,2.065,550,2.065,551,2.065,552,2.065,553,1.443,554,1.443,555,2.065,556,2.065,557,2.065,558,2.065,559,2.065,560,3.097,561,2.535,562,1.443,563,2.065,564,1.443,565,2.065,566,2.065,567,2.065,568,2.065,569,1.259,570,2.065,571,1.69,572,1.69,573,2.065,574,2.065,575,1.69,576,2.065,577,1.443,578,2.065,579,2.065,580,2.065,581,2.065,582,2.065,583,2.065,584,2.065,585,2.065]],["t/125",[11,0.017,18,1.31,20,1.54,36,0.509,61,0.457,65,1.649,84,1.649,85,1.649,99,1.649,116,1.13,136,0.651,145,1.438,180,1.438,219,1.438,254,1.636,269,1.931,282,1.27,284,1.931,288,1.931,318,1.438,357,1.462,397,1.01,398,1.053,406,2.387,407,0.811,411,1.438,427,1.649,433,1.27,434,1.931,469,2.082,470,2.806,477,1.438,502,1.438,511,3.603,516,1.27,529,1.649,553,1.649,554,1.649,562,1.649,564,2.387,586,1.931,587,2.359,588,1.931,589,1.931,590,2.359,591,2.359,592,2.359,593,1.649,594,4.016,595,3.416,596,1.931,597,2.359,598,2.359,599,2.359,600,3.287,601,1.931,602,4.016,603,2.359,604,2.359,605,2.359,606,2.359,607,3.416,608,2.359,609,2.359,610,1.931,611,1.649,612,2.359,613,2.359,614,3.416,615,2.359,616,3.416,617,1.931,618,2.359,619,2.359,620,2.359,621,1.931,622,1.931,623,2.359,624,1.931,625,2.359,626,1.931,627,2.359,628,2.359,629,2.359]],["t/127",[11,0.031,116,2.087,136,1.203,213,2.656,383,3.567,397,1.865,407,1.499,433,2.345,630,4.358,631,4.358]],["t/129",[11,0.034,22,1.641,28,1.882,36,0.548,61,0.521,107,1.882,121,1.641,136,0.743,175,2.204,296,1.332,386,1.449,398,1.157,402,2.204,405,1.606,407,0.926,418,1.641,432,2.204,437,2.287,447,1.641,452,1.882,468,1.882,482,1.882,502,1.641,505,1.449,564,2.622,593,1.882,596,2.204,611,2.622,632,4.319,633,3.753,634,3.824,635,2.204,636,2.204,637,2.693,638,2.204,639,2.204,640,2.204,641,2.693,642,2.693,643,2.693,644,3.753,645,3.071,646,2.693,647,2.693,648,2.693,649,2.622,650,2.693,651,2.693,652,2.693,653,2.693,654,2.693,655,2.693,656,2.693,657,2.693,658,2.693,659,2.204,660,2.693,661,2.693,662,2.693,663,2.204,664,2.693,665,2.693]],["t/131",[11,0.038,18,1.31,20,0.905,36,0.299,48,1.462,60,1.649,61,0.457,62,1.438,65,1.649,85,1.649,116,1.636,118,1.931,124,1.649,129,1.636,136,1.108,142,1.649,145,2.683,162,1.649,167,1.931,177,1.27,180,1.438,292,1.649,296,0.727,333,1.931,377,1.931,397,1.719,398,1.587,405,1.884,406,3.077,407,1.514,423,1.649,449,1.931,477,1.438,491,1.931,569,1.438,593,2.387,634,2.796,640,1.931,666,4.402,667,1.931,668,2.359,669,3.416,670,4.016,671,3.416,672,3.416,673,1.649,674,2.359,675,2.359,676,2.359,677,1.931,678,2.359,679,3.416,680,2.359,681,3.416,682,2.359,683,2.359,684,1.931,685,2.359,686,1.931,687,2.359,688,2.359,689,2.359,690,2.359]],["t/133",[11,0.031,22,2.59,33,2.287,205,2.97,299,2.035,392,2.59,433,2.287,442,2.97,443,2.97,691,4.25,692,3.478,693,3.478,694,4.25]],["t/135",[11,0.017,20,0.892,36,0.295,61,0.655,76,1.62,83,1.905,84,1.626,116,1.114,121,1.418,126,1.905,129,1.114,136,0.642,142,1.626,146,2.785,177,1.252,184,1.626,213,2.062,224,1.626,230,2.768,250,1.905,296,1.043,317,1.418,318,2.062,319,1.905,352,1.905,390,1.626,397,0.996,398,1.043,400,1.82,405,0.996,407,1.37,454,1.626,465,1.905,470,2.364,482,2.785,483,2.364,484,2.768,487,1.905,504,2.062,526,1.905,529,1.626,561,1.905,562,1.626,569,1.418,600,1.905,601,1.905,611,1.626,638,3.58,659,1.905,673,1.626,686,1.905,695,3.985,696,3.985,697,2.327,698,2.327,699,3.382,700,2.327,701,2.327,702,2.327,703,2.327,704,3.985,705,3.382,706,2.327,707,2.327,708,2.327,709,2.327,710,2.327,711,1.905,712,2.327,713,2.327,714,2.327,715,2.327,716,2.327,717,2.327,718,2.327,719,2.327,720,2.327,721,2.327,722,2.327,723,2.327,724,2.327,725,2.327,726,2.327,727,2.327]],["t/137",[8,2.134,10,0.987,11,0.036,12,1.898,18,1.289,19,1.406,20,0.884,24,0.987,32,2.348,34,1.898,36,0.426,39,1.887,48,0.987,51,2.048,54,1.887,60,1.612,61,0.651,62,2.048,64,1.612,68,1.612,77,1.612,81,1.887,86,1.808,98,1.612,105,1.612,128,1.887,131,1.406,136,0.637,138,1.241,145,1.406,149,1.612,153,1.406,177,1.241,217,1.612,282,1.241,309,1.612,382,1.241,396,1.612,398,1.222,407,1.156,411,1.406,418,2.048,420,1.406,437,1.406,481,2.048,486,1.887,505,1.241,519,1.887,569,1.406,575,1.887,610,1.887,621,2.75,624,1.887,626,1.887,635,1.887,636,1.887,649,1.612,667,1.887,673,1.612,684,1.887,692,3.245,711,1.887,728,2.75,729,2.306,730,2.306,731,2.306,732,2.306,733,2.306,734,2.306,735,2.306,736,2.306,737,2.306,738,3.36,739,2.306,740,2.306,741,2.306,742,2.306,743,2.306,744,3.36,745,2.306,746,2.306,747,2.306,748,2.306,749,1.887,750,2.306]],["t/139",[6,2.25,11,0.03,36,0.53,48,1.789,217,2.922,291,3.422,292,2.922,433,2.25,577,2.922,728,3.422,751,4.181,752,4.181,753,4.181,754,4.181,755,4.181]],["t/141",[6,1.619,10,1.287,11,0.029,13,2.461,34,1.44,61,0.784,70,2.461,73,2.461,100,2.467,138,1.619,182,2.461,184,2.102,297,1.833,313,2.461,317,1.833,334,2.102,345,2.461,382,1.619,396,2.102,398,0.927,400,1.619,407,1.392,415,2.102,418,1.833,430,2.461,442,2.102,443,2.102,452,2.102,456,2.461,493,2.102,494,2.102,496,2.102,516,1.619,520,3.313,572,2.461,639,2.461,645,2.461,649,2.102,756,3.007,757,4.895,758,3.007,759,3.007,760,3.007,761,3.007,762,3.007,763,3.007,764,3.007,765,3.007,766,2.461,767,3.007,768,3.007,769,3.007,770,3.007,771,3.007,772,3.007]],["t/143",[1,2.698,2,2.698,11,0.031,20,1.65,34,2.43,36,0.418,61,0.833,62,2.009,116,1.578,135,2.009,136,0.91,282,1.774,393,2.304,397,1.411,405,1.411,469,2.009,481,2.009,493,2.304,502,2.009,504,3.209,505,1.774,571,2.698,586,2.698,588,2.698,589,3.521,617,2.698,622,2.698,749,2.698,766,2.698,773,3.296,774,3.296,775,3.296,776,3.296,777,3.296,778,3.296,779,3.296,780,3.296]],["t/145",[0,2.582,11,0.036,36,0.53,38,1.923,61,0.611,98,2.921,157,2.582,263,2.205,285,2.205,286,2.582,287,2.582,296,0.973,299,1.511,314,2.921,317,1.923,357,1.35,382,1.698,386,2.249,392,1.923,394,2.582,405,1.35,415,2.205,422,2.582,481,1.923,516,1.698,553,2.205,554,2.205,577,2.921,663,2.582,677,2.582,693,2.582,781,3.155,782,4.18,783,3.155,784,3.155,785,3.155,786,3.155,787,3.155,788,3.155,789,3.155,790,3.155,791,3.155,792,3.155,793,3.155,794,3.155,795,3.155]]],"invertedIndex":[["",{"_index":222,"t":{"7":{"position":[[1321,1],[1374,1]]},"11":{"position":[[340,2]]},"13":{"position":[[184,1],[205,1],[245,1],[262,1],[291,2],[307,3],[311,2],[353,1],[455,2]]}}}],["0.12ms",{"_index":239,"t":{"7":{"position":[[1569,7]]}}}],["0.5ms",{"_index":241,"t":{"7":{"position":[[1589,6]]}}}],["1",{"_index":434,"t":{"115":{"position":[[141,2]]},"125":{"position":[[19,1]]}}}],["100k",{"_index":229,"t":{"7":{"position":[[1483,4],[1539,4],[1602,4]]}}}],["108",{"_index":246,"t":{"7":{"position":[[1654,4]]}}}],["12",{"_index":421,"t":{"113":{"position":[[635,2]]}}}],["15ms",{"_index":233,"t":{"7":{"position":[[1513,5]]}}}],["1700",{"_index":242,"t":{"7":{"position":[[1596,5]]}}}],["17417",{"_index":240,"t":{"7":{"position":[[1577,6]]}}}],["2",{"_index":630,"t":{"127":{"position":[[6,1]]}}}],["21ms",{"_index":238,"t":{"7":{"position":[[1563,5]]}}}],["233",{"_index":234,"t":{"7":{"position":[[1519,4]]}}}],["24ms",{"_index":245,"t":{"7":{"position":[[1648,5]]}}}],["27",{"_index":109,"t":{"5":{"position":[[825,3]]}}}],["2d",{"_index":6,"t":{"3":{"position":[[62,2]]},"13":{"position":[[438,2]]},"113":{"position":[[239,2]]},"139":{"position":[[114,2]]},"141":{"position":[[208,2]]}}}],["2d/3d",{"_index":774,"t":{"143":{"position":[[173,5]]}}}],["2ms",{"_index":236,"t":{"7":{"position":[[1529,4],[1664,4]]}}}],["3",{"_index":205,"t":{"7":{"position":[[1137,2]]},"121":{"position":[[343,1]]},"133":{"position":[[6,1]]}}}],["350",{"_index":237,"t":{"7":{"position":[[1534,4],[1669,4]]}}}],["3d",{"_index":757,"t":{"141":{"position":[[52,2],[215,2],[269,3],[352,2]]}}}],["3rd",{"_index":490,"t":{"119":{"position":[[622,3]]}}}],["4",{"_index":751,"t":{"139":{"position":[[6,1]]}}}],["50ms",{"_index":232,"t":{"7":{"position":[[1507,5],[1642,5]]}}}],["8",{"_index":132,"t":{"5":{"position":[[1103,1]]}}}],["95",{"_index":101,"t":{"5":{"position":[[704,3]]}}}],["9ms",{"_index":235,"t":{"7":{"position":[[1524,4],[1584,4],[1659,4]]}}}],["ability",{"_index":85,"t":{"5":{"position":[[477,7]]},"125":{"position":[[420,7]]},"131":{"position":[[457,7]]}}}],["above",{"_index":795,"t":{"145":{"position":[[480,5]]}}}],["achieves",{"_index":133,"t":{"5":{"position":[[1105,8]]}}}],["adapt",{"_index":563,"t":{"123":{"position":[[782,5]]}}}],["adding",{"_index":458,"t":{"117":{"position":[[437,6]]}}}],["addition",{"_index":711,"t":{"135":{"position":[[729,9]]},"137":{"position":[[763,8]]}}}],["additional",{"_index":293,"t":{"9":{"position":[[322,10]]}}}],["address",{"_index":414,"t":{"113":{"position":[[520,7]]}}}],["adjusted",{"_index":574,"t":{"123":{"position":[[1083,8]]}}}],["advanced",{"_index":743,"t":{"137":{"position":[[649,8]]}}}],["advancements",{"_index":35,"t":{"3":{"position":[[398,12]]}}}],["advantage",{"_index":742,"t":{"137":{"position":[[636,9]]}}}],["agnostic",{"_index":595,"t":{"125":{"position":[[205,8],[1061,8]]}}}],["aims",{"_index":116,"t":{"5":{"position":[[928,4]]},"125":{"position":[[146,4]]},"127":{"position":[[31,4]]},"131":{"position":[[143,4],[731,4]]},"135":{"position":[[32,4]]},"143":{"position":[[122,4]]}}}],["allowed",{"_index":92,"t":{"5":{"position":[[579,7]]}}}],["allowing",{"_index":121,"t":{"5":{"position":[[972,8]]},"123":{"position":[[353,8],[874,8]]},"129":{"position":[[306,8]]},"135":{"position":[[237,8]]}}}],["allows",{"_index":487,"t":{"119":{"position":[[579,6]]},"135":{"position":[[800,6]]}}}],["alternatively",{"_index":384,"t":{"15":{"position":[[140,14]]}}}],["although",{"_index":13,"t":{"3":{"position":[[114,8]]},"141":{"position":[[381,8]]}}}],["always",{"_index":122,"t":{"5":{"position":[[988,6]]},"7":{"position":[[11,6]]},"113":{"position":[[275,6]]}}}],["amazing",{"_index":399,"t":{"113":{"position":[[171,7]]}}}],["animation",{"_index":779,"t":{"143":{"position":[[438,9]]}}}],["animations",{"_index":705,"t":{"135":{"position":[[416,11],[622,11]]}}}],["announce",{"_index":393,"t":{"113":{"position":[[18,8]]},"117":{"position":[[27,8]]},"143":{"position":[[28,8]]}}}],["announcement",{"_index":424,"t":{"113":{"position":[[698,13]]}}}],["announcing",{"_index":587,"t":{"125":{"position":[[28,10]]}}}],["another",{"_index":137,"t":{"5":{"position":[[1159,7]]},"123":{"position":[[608,7]]}}}],["anyone",{"_index":521,"t":{"121":{"position":[[947,6]]}}}],["api",{"_index":64,"t":{"5":{"position":[[189,4]]},"9":{"position":[[146,3],[350,3],[555,3]]},"137":{"position":[[546,3]]}}}],["app",{"_index":651,"t":{"129":{"position":[[424,3]]}}}],["appeal",{"_index":698,"t":{"135":{"position":[[196,6]]}}}],["appealing",{"_index":721,"t":{"135":{"position":[[980,10]]}}}],["appearance",{"_index":544,"t":{"123":{"position":[[379,10]]}}}],["application",{"_index":611,"t":{"125":{"position":[[636,12]]},"129":{"position":[[345,12],[795,11]]},"135":{"position":[[713,12]]}}}],["applications",{"_index":407,"t":{"113":{"position":[[387,12]]},"119":{"position":[[78,13],[494,12]]},"125":{"position":[[102,13]]},"127":{"position":[[74,13]]},"129":{"position":[[110,13]]},"131":{"position":[[119,13],[374,12],[937,12],[1141,13]]},"135":{"position":[[96,12],[851,13],[1146,12]]},"137":{"position":[[746,13],[1168,13]]},"141":{"position":[[243,13],[619,13]]}}}],["apply",{"_index":264,"t":{"7":{"position":[[1992,5]]}}}],["appreciate",{"_index":712,"t":{"135":{"position":[[755,10]]}}}],["approach",{"_index":44,"t":{"3":{"position":[[512,8]]},"5":{"position":[[570,8]]},"7":{"position":[[230,10],[455,9]]}}}],["appropriate",{"_index":362,"t":{"13":{"position":[[113,11]]}}}],["apps",{"_index":401,"t":{"113":{"position":[[189,5]]}}}],["architecture",{"_index":144,"t":{"7":{"position":[[105,12]]}}}],["areas",{"_index":753,"t":{"139":{"position":[[88,5]]}}}],["aspect",{"_index":566,"t":{"123":{"position":[[818,6]]}}}],["assembled",{"_index":416,"t":{"113":{"position":[[545,9]]}}}],["asset",{"_index":588,"t":{"125":{"position":[[50,5]]},"143":{"position":[[390,5]]}}}],["assetpack",{"_index":511,"t":{"121":{"position":[[507,10]]},"125":{"position":[[39,10],[128,9],[180,9],[403,9]]}}}],["assets",{"_index":600,"t":{"125":{"position":[[364,6],[458,6],[847,6]]},"135":{"position":[[1093,6]]}}}],["assured",{"_index":323,"t":{"9":{"position":[[722,7]]}}}],["async",{"_index":368,"t":{"13":{"position":[[223,5]]}}}],["attempt",{"_index":87,"t":{"5":{"position":[[494,7]]}}}],["audio",{"_index":617,"t":{"125":{"position":[[739,5]]},"143":{"position":[[367,6]]}}}],["autodetectrenderer",{"_index":364,"t":{"13":{"position":[[148,18],[186,18],[270,20]]}}}],["automatically",{"_index":269,"t":{"7":{"position":[[2087,13]]},"125":{"position":[[431,13]]}}}],["available",{"_index":77,"t":{"5":{"position":[[370,9],[691,9],[1024,9]]},"121":{"position":[[923,9]]},"137":{"position":[[904,9]]}}}],["avoids",{"_index":197,"t":{"7":{"position":[[985,6]]}}}],["await",{"_index":371,"t":{"13":{"position":[[264,5]]}}}],["away",{"_index":665,"t":{"129":{"position":[[854,5]]}}}],["b",{"_index":91,"t":{"5":{"position":[[562,2]]}}}],["back",{"_index":89,"t":{"5":{"position":[[537,4]]}}}],["bad",{"_index":348,"t":{"11":{"position":[[225,4]]}}}],["bandwidth",{"_index":210,"t":{"7":{"position":[[1176,9]]}}}],["bars",{"_index":539,"t":{"123":{"position":[[258,5]]}}}],["based",{"_index":178,"t":{"7":{"position":[[634,5],[1702,5]]}}}],["batch",{"_index":168,"t":{"7":{"position":[[431,5]]}}}],["batches",{"_index":163,"t":{"7":{"position":[[377,7]]}}}],["batching",{"_index":679,"t":{"131":{"position":[[518,8],[538,8]]}}}],["beautiful",{"_index":525,"t":{"123":{"position":[[61,9]]}}}],["become",{"_index":653,"t":{"129":{"position":[[454,6]]}}}],["becomes",{"_index":114,"t":{"5":{"position":[[890,7]]}}}],["before",{"_index":113,"t":{"5":{"position":[[880,6]]}}}],["begin",{"_index":631,"t":{"127":{"position":[[13,5]]}}}],["behaviour",{"_index":545,"t":{"123":{"position":[[394,9]]}}}],["behind",{"_index":271,"t":{"9":{"position":[[26,6]]}}}],["being",{"_index":635,"t":{"129":{"position":[[28,5]]},"137":{"position":[[558,5]]}}}],["benchmark",{"_index":247,"t":{"7":{"position":[[1680,9]]}}}],["benefit",{"_index":94,"t":{"5":{"position":[[617,7]]}}}],["best",{"_index":124,"t":{"5":{"position":[[1008,4]]},"7":{"position":[[1960,4]]},"131":{"position":[[257,4]]}}}],["beta",{"_index":9,"t":{"3":{"position":[[87,4],[147,4]]},"13":{"position":[[28,4],[390,4]]},"117":{"position":[[64,4]]}}}],["better",{"_index":624,"t":{"125":{"position":[[880,6]]},"137":{"position":[[1113,6]]}}}],["between",{"_index":765,"t":{"141":{"position":[[307,7]]}}}],["blog",{"_index":288,"t":{"9":{"position":[[275,4]]},"125":{"position":[[962,4]]}}}],["both",{"_index":146,"t":{"7":{"position":[[130,4]]},"123":{"position":[[898,4]]},"135":{"position":[[206,4],[246,4],[951,4]]}}}],["brouwer",{"_index":475,"t":{"119":{"position":[[168,8]]}}}],["browser",{"_index":667,"t":{"131":{"position":[[27,7]]},"137":{"position":[[583,7]]}}}],["browsers",{"_index":80,"t":{"5":{"position":[[404,9],[711,9],[804,8]]}}}],["bubble",{"_index":507,"t":{"121":{"position":[[356,6]]}}}],["bubbo",{"_index":524,"t":{"121":{"position":[[1053,5],[1059,5]]}}}],["bugs",{"_index":350,"t":{"11":{"position":[[250,5]]}}}],["build",{"_index":162,"t":{"7":{"position":[[371,5]]},"113":{"position":[[371,5]]},"131":{"position":[[895,5]]}}}],["building",{"_index":649,"t":{"129":{"position":[[331,8],[839,8]]},"137":{"position":[[1131,8]]},"141":{"position":[[604,8]]}}}],["built",{"_index":759,"t":{"141":{"position":[[83,5]]}}}],["bump",{"_index":183,"t":{"7":{"position":[[729,5]]}}}],["bundle",{"_index":748,"t":{"137":{"position":[[971,6]]}}}],["bundlers",{"_index":644,"t":{"129":{"position":[[237,8],[555,8]]}}}],["bunnies",{"_index":261,"t":{"7":{"position":[[1907,8]]}}}],["bunnmark",{"_index":253,"t":{"7":{"position":[[1774,8],[1795,8]]}}}],["bunny",{"_index":226,"t":{"7":{"position":[[1423,5]]}}}],["bunnymark",{"_index":249,"t":{"7":{"position":[[1716,9],[1761,9]]}}}],["buttons",{"_index":530,"t":{"123":{"position":[[166,8],[236,8]]}}}],["call",{"_index":682,"t":{"131":{"position":[[630,5]]}}}],["called",{"_index":493,"t":{"121":{"position":[[38,6]]},"141":{"position":[[62,6]]},"143":{"position":[[78,6]]}}}],["candidate",{"_index":335,"t":{"11":{"position":[[34,10]]}}}],["canvas",{"_index":81,"t":{"5":{"position":[[420,6],[545,6]]},"137":{"position":[[873,6]]}}}],["capabilities",{"_index":396,"t":{"113":{"position":[[99,12]]},"137":{"position":[[662,13]]},"141":{"position":[[544,12]]}}}],["cases",{"_index":220,"t":{"7":{"position":[[1310,6]]}}}],["catalysed",{"_index":43,"t":{"3":{"position":[[498,9]]}}}],["causing",{"_index":412,"t":{"113":{"position":[[477,7]]}}}],["change",{"_index":202,"t":{"7":{"position":[[1093,6],[1886,6]]}}}],["changed",{"_index":173,"t":{"7":{"position":[[506,7],[780,8]]}}}],["changes",{"_index":33,"t":{"3":{"position":[[360,7]]},"7":{"position":[[681,7]]},"9":{"position":[[612,7]]},"123":{"position":[[989,8]]},"133":{"position":[[78,7]]}}}],["changing",{"_index":243,"t":{"7":{"position":[[1615,9]]}}}],["check",{"_index":553,"t":{"123":{"position":[[528,5]]},"125":{"position":[[1126,5]]},"145":{"position":[[443,5]]}}}],["checkboxes",{"_index":531,"t":{"123":{"position":[[175,11]]}}}],["class",{"_index":738,"t":{"137":{"position":[[496,5],[925,5]]}}}],["cli",{"_index":633,"t":{"129":{"position":[[19,3],[393,3]]}}}],["code",{"_index":129,"t":{"5":{"position":[[1066,5]]},"7":{"position":[[814,4]]},"11":{"position":[[276,5]]},"121":{"position":[[979,4]]},"131":{"position":[[240,5],[1097,4]]},"135":{"position":[[545,5]]}}}],["codebase",{"_index":47,"t":{"3":{"position":[[543,8]]},"11":{"position":[[391,8]]}}}],["collaborate",{"_index":701,"t":{"135":{"position":[[261,11]]}}}],["collaboration",{"_index":723,"t":{"135":{"position":[[1022,14]]}}}],["collection",{"_index":495,"t":{"121":{"position":[[76,10]]}}}],["combine",{"_index":568,"t":{"123":{"position":[[890,7]]}}}],["comet",{"_index":695,"t":{"135":{"position":[[0,5],[332,5],[1037,5]]}}}],["coming",{"_index":784,"t":{"145":{"position":[[67,6]]}}}],["community",{"_index":386,"t":{"15":{"position":[[180,9]]},"113":{"position":[[313,9],[506,10]]},"119":{"position":[[218,9]]},"129":{"position":[[498,10]]},"145":{"position":[[88,10],[207,10]]}}}],["compared",{"_index":734,"t":{"137":{"position":[[382,8]]}}}],["complete",{"_index":729,"t":{"137":{"position":[[59,8]]}}}],["complex",{"_index":569,"t":{"123":{"position":[[923,8]]},"131":{"position":[[499,7]]},"135":{"position":[[484,7]]},"137":{"position":[[1140,8]]}}}],["complicated",{"_index":640,"t":{"129":{"position":[[181,11]]},"131":{"position":[[656,11]]}}}],["components",{"_index":489,"t":{"119":{"position":[[607,10]]},"123":{"position":[[147,10],[317,10]]}}}],["comprehensive",{"_index":300,"t":{"9":{"position":[[429,13]]}}}],["compress",{"_index":618,"t":{"125":{"position":[[767,8]]}}}],["computational",{"_index":189,"t":{"7":{"position":[[843,13],[1207,13]]}}}],["computations",{"_index":58,"t":{"5":{"position":[[109,12]]}}}],["considering",{"_index":462,"t":{"117":{"position":[[481,11]]}}}],["const",{"_index":370,"t":{"13":{"position":[[247,5]]}}}],["construct",{"_index":174,"t":{"7":{"position":[[543,9]]}}}],["consuming",{"_index":678,"t":{"131":{"position":[[391,10]]}}}],["content",{"_index":70,"t":{"5":{"position":[[259,7],[594,7]]},"141":{"position":[[218,7]]}}}],["continuation",{"_index":472,"t":{"119":{"position":[[110,12]]}}}],["continue",{"_index":325,"t":{"9":{"position":[[759,8]]}}}],["continuing",{"_index":791,"t":{"145":{"position":[[379,10]]}}}],["contribute",{"_index":351,"t":{"11":{"position":[[265,10]]},"121":{"position":[[987,10]]}}}],["contributors",{"_index":789,"t":{"145":{"position":[[222,13]]}}}],["conversations",{"_index":391,"t":{"15":{"position":[[237,14]]}}}],["convert",{"_index":614,"t":{"125":{"position":[[695,7],[731,7]]}}}],["core",{"_index":486,"t":{"119":{"position":[[551,4]]},"137":{"position":[[230,4]]}}}],["correct",{"_index":159,"t":{"7":{"position":[[303,7]]}}}],["course",{"_index":25,"t":{"3":{"position":[[274,6]]}}}],["cpu",{"_index":221,"t":{"7":{"position":[[1317,3],[1341,3],[1442,3],[1449,3],[1453,3]]}}}],["create",{"_index":296,"t":{"9":{"position":[[385,6]]},"13":{"position":[[97,6]]},"113":{"position":[[164,6]]},"119":{"position":[[481,6],[593,6]]},"121":{"position":[[144,6],[871,6]]},"123":{"position":[[54,6],[699,6],[916,6],[1046,6]]},"129":{"position":[[411,6],[431,6],[775,6]]},"131":{"position":[[1106,6]]},"135":{"position":[[79,6],[468,6]]},"145":{"position":[[313,6]]}}}],["created",{"_index":403,"t":{"113":{"position":[[327,7]]},"119":{"position":[[149,7]]}}}],["creating",{"_index":638,"t":{"129":{"position":[[90,8]]},"135":{"position":[[378,8],[604,8],[694,8],[1114,8]]}}}],["crucial",{"_index":306,"t":{"9":{"position":[[502,7]]}}}],["curious",{"_index":262,"t":{"7":{"position":[[1916,7]]}}}],["current",{"_index":439,"t":{"117":{"position":[[112,7]]}}}],["currently",{"_index":105,"t":{"5":{"position":[[762,9]]},"115":{"position":[[106,9]]},"137":{"position":[[397,10]]}}}],["custom",{"_index":488,"t":{"119":{"position":[[600,6]]}}}],["customizable",{"_index":542,"t":{"123":{"position":[[339,13]]}}}],["d",{"_index":139,"t":{"5":{"position":[[1177,2]]},"7":{"position":[[2101,2]]}}}],["data",{"_index":166,"t":{"7":{"position":[[406,4],[593,4],[1114,4]]}}}],["debug",{"_index":669,"t":{"131":{"position":[[100,5],[757,5]]}}}],["decadeβ€”yes",{"_index":26,"t":{"3":{"position":[[286,11]]}}}],["decent",{"_index":216,"t":{"7":{"position":[[1267,6]]}}}],["dedicated",{"_index":417,"t":{"113":{"position":[[557,9]]},"119":{"position":[[303,9]]}}}],["deeper",{"_index":292,"t":{"9":{"position":[[304,6]]},"131":{"position":[[994,6]]},"139":{"position":[[76,6]]}}}],["delve",{"_index":291,"t":{"9":{"position":[[298,5]]},"139":{"position":[[70,5]]}}}],["demonstrate",{"_index":509,"t":{"121":{"position":[[398,11],[574,11]]}}}],["deprecation",{"_index":328,"t":{"9":{"position":[[796,11]]}}}],["design",{"_index":562,"t":{"123":{"position":[[759,6]]},"125":{"position":[[1070,7]]},"135":{"position":[[68,6]]}}}],["designed",{"_index":673,"t":{"131":{"position":[[279,8]]},"135":{"position":[[184,8]]},"137":{"position":[[279,8]]}}}],["designers",{"_index":699,"t":{"135":{"position":[[211,9],[454,9]]}}}],["designs",{"_index":717,"t":{"135":{"position":[[907,8]]}}}],["desktop",{"_index":79,"t":{"5":{"position":[[396,7],[796,7]]},"123":{"position":[[1228,7]]}}}],["despite",{"_index":311,"t":{"9":{"position":[[559,7]]}}}],["details",{"_index":627,"t":{"125":{"position":[[991,7]]}}}],["dev",{"_index":666,"t":{"131":{"position":[[7,3],[440,3],[721,3],[818,3]]}}}],["developed",{"_index":636,"t":{"129":{"position":[[34,9]]},"137":{"position":[[564,9]]}}}],["developer",{"_index":557,"t":{"123":{"position":[[653,9]]}}}],["developers",{"_index":398,"t":{"113":{"position":[[150,10],[360,10],[575,10]]},"119":{"position":[[467,10]]},"121":{"position":[[730,10],[849,10]]},"123":{"position":[[31,10]]},"125":{"position":[[340,10],[821,10]]},"129":{"position":[[140,10],[652,10]]},"131":{"position":[[89,10],[170,10],[296,10],[473,10],[702,11],[881,10],[976,10],[1071,10]]},"135":{"position":[[225,11],[739,10]]},"137":{"position":[[617,10],[942,10],[1043,10]]},"141":{"position":[[566,10]]}}}],["developing",{"_index":592,"t":{"125":{"position":[[91,10]]}}}],["development",{"_index":505,"t":{"121":{"position":[[289,12],[437,11],[786,11]]},"123":{"position":[[1275,11]]},"129":{"position":[[486,11]]},"137":{"position":[[110,11]]},"143":{"position":[[243,11]]}}}],["device",{"_index":576,"t":{"123":{"position":[[1118,7]]}}}],["devices",{"_index":580,"t":{"123":{"position":[[1211,7]]}}}],["diagnose",{"_index":674,"t":{"131":{"position":[[307,8]]}}}],["didn't",{"_index":274,"t":{"9":{"position":[[82,6]]}}}],["dif",{"_index":228,"t":{"7":{"position":[[1457,3],[1479,3]]}}}],["different",{"_index":564,"t":{"123":{"position":[[791,9]]},"125":{"position":[[712,9],[748,9]]},"129":{"position":[[227,9],[545,9]]}}}],["direct",{"_index":388,"t":{"15":{"position":[[205,6]]}}}],["discord",{"_index":387,"t":{"15":{"position":[[193,7]]}}}],["displays",{"_index":582,"t":{"123":{"position":[[1236,9]]}}}],["dive",{"_index":337,"t":{"11":{"position":[[80,4]]}}}],["documentation",{"_index":440,"t":{"117":{"position":[[120,13],[245,13],[419,13],[509,13]]},"119":{"position":[[353,14]]}}}],["don't",{"_index":303,"t":{"9":{"position":[[467,5]]},"11":{"position":[[343,5]]}}}],["doormat23",{"_index":378,"t":{"15":{"position":[[46,9]]}}}],["draw",{"_index":167,"t":{"7":{"position":[[422,4]]},"131":{"position":[[625,4]]}}}],["drivers",{"_index":270,"t":{"9":{"position":[[18,7]]}}}],["driving",{"_index":41,"t":{"3":{"position":[[482,7]]}}}],["dynamic",{"_index":148,"t":{"7":{"position":[[146,7]]},"123":{"position":[[932,7]]}}}],["each",{"_index":199,"t":{"7":{"position":[[1046,4]]},"123":{"position":[[407,4]]}}}],["eager",{"_index":21,"t":{"3":{"position":[[228,5]]}}}],["easier",{"_index":397,"t":{"113":{"position":[[139,6]]},"123":{"position":[[663,7]]},"125":{"position":[[172,7]]},"127":{"position":[[47,6]]},"131":{"position":[[159,6],[747,6],[870,6]]},"135":{"position":[[48,6]]},"143":{"position":[[255,6]]}}}],["easily",{"_index":454,"t":{"117":{"position":[[362,6]]},"123":{"position":[[277,6]]},"135":{"position":[[815,6]]}}}],["easy",{"_index":482,"t":{"119":{"position":[[422,4],[458,4]]},"129":{"position":[[643,4]]},"135":{"position":[[669,4],[879,4],[1052,4]]}}}],["ecosystem",{"_index":693,"t":{"133":{"position":[[100,9]]},"145":{"position":[[421,10]]}}}],["edit",{"_index":706,"t":{"135":{"position":[[479,4]]}}}],["editing",{"_index":703,"t":{"135":{"position":[[391,7]]}}}],["editor",{"_index":696,"t":{"135":{"position":[[20,6],[174,6],[555,6]]}}}],["effect",{"_index":215,"t":{"7":{"position":[[1235,6]]}}}],["efficient",{"_index":62,"t":{"5":{"position":[[168,9]]},"131":{"position":[[1118,9]]},"137":{"position":[[310,10],[1088,9]]},"143":{"position":[[271,10]]}}}],["efficiently",{"_index":601,"t":{"125":{"position":[[371,12]]},"135":{"position":[[287,12]]}}}],["effort",{"_index":745,"t":{"137":{"position":[[835,6]]}}}],["element",{"_index":546,"t":{"123":{"position":[[412,7]]}}}],["elements",{"_index":184,"t":{"7":{"position":[[761,8],[1071,8]]},"135":{"position":[[649,9]]},"141":{"position":[[355,8]]}}}],["elevate",{"_index":353,"t":{"11":{"position":[[299,7]]}}}],["empowering",{"_index":295,"t":{"9":{"position":[[367,10]]}}}],["enable",{"_index":740,"t":{"137":{"position":[[610,6]]}}}],["enables",{"_index":558,"t":{"123":{"position":[[684,7]]}}}],["encapsulate",{"_index":283,"t":{"9":{"position":[[221,11]]}}}],["encounter",{"_index":320,"t":{"9":{"position":[[692,9]]}}}],["end",{"_index":432,"t":{"115":{"position":[[128,3]]},"129":{"position":[[482,3]]}}}],["engagement",{"_index":389,"t":{"15":{"position":[[212,10]]}}}],["engaging",{"_index":690,"t":{"131":{"position":[[1132,8]]}}}],["engine",{"_index":34,"t":{"3":{"position":[[382,7]]},"11":{"position":[[166,7]]},"113":{"position":[[300,8]]},"137":{"position":[[242,7],[858,6],[1098,6]]},"141":{"position":[[55,6]]},"143":{"position":[[97,7],[115,6],[184,6],[318,6]]}}}],["engineering",{"_index":46,"t":{"3":{"position":[[527,11]]}}}],["engines",{"_index":766,"t":{"141":{"position":[[315,7]]},"143":{"position":[[358,8]]}}}],["engineβ€”far",{"_index":281,"t":{"9":{"position":[[198,10]]}}}],["enhance",{"_index":278,"t":{"9":{"position":[[134,7]]},"113":{"position":[[87,7]]}}}],["ensuring",{"_index":718,"t":{"135":{"position":[[916,8]]}}}],["entirely",{"_index":206,"t":{"7":{"position":[[1143,8]]}}}],["era",{"_index":59,"t":{"5":{"position":[[146,4]]}}}],["especially",{"_index":683,"t":{"131":{"position":[[683,10]]}}}],["even",{"_index":297,"t":{"9":{"position":[[392,4]]},"11":{"position":[[260,4]]},"113":{"position":[[134,4]]},"141":{"position":[[577,4]]}}}],["everything",{"_index":135,"t":{"5":{"position":[[1136,10]]},"117":{"position":[[322,10]]},"123":{"position":[[1182,10]]},"143":{"position":[[138,10]]}}}],["example",{"_index":604,"t":{"125":{"position":[[481,8]]}}}],["examples",{"_index":460,"t":{"117":{"position":[[460,9]]},"121":{"position":[[250,8]]},"123":{"position":[[559,9]]}}}],["excited",{"_index":392,"t":{"113":{"position":[[7,7]]},"117":{"position":[[16,7]]},"133":{"position":[[133,7]]},"145":{"position":[[286,7]]}}}],["exciting",{"_index":382,"t":{"15":{"position":[[114,8]]},"115":{"position":[[182,8]]},"137":{"position":[[439,8]]},"141":{"position":[[155,8]]},"145":{"position":[[22,8]]}}}],["exclusive",{"_index":3,"t":{"3":{"position":[[27,9]]}}}],["execute",{"_index":117,"t":{"5":{"position":[[936,7]]},"7":{"position":[[616,7]]}}}],["executed",{"_index":187,"t":{"7":{"position":[[822,9]]}}}],["existing",{"_index":196,"t":{"7":{"position":[[947,8]]}}}],["expand",{"_index":772,"t":{"141":{"position":[[528,6]]}}}],["expect",{"_index":749,"t":{"137":{"position":[[1058,6]]},"143":{"position":[[159,6]]}}}],["experience",{"_index":626,"t":{"125":{"position":[[918,11]]},"137":{"position":[[157,10]]}}}],["experimenting",{"_index":374,"t":{"13":{"position":[[361,13]]}}}],["explore",{"_index":338,"t":{"11":{"position":[[92,7],[369,7]]},"121":{"position":[[967,7]]}}}],["extend",{"_index":786,"t":{"145":{"position":[[167,6]]}}}],["extension",{"_index":668,"t":{"131":{"position":[[35,9]]}}}],["extensive",{"_index":732,"t":{"137":{"position":[[147,9]]}}}],["factors",{"_index":42,"t":{"3":{"position":[[490,7]]}}}],["fall",{"_index":88,"t":{"5":{"position":[[532,4]]}}}],["fallback",{"_index":119,"t":{"5":{"position":[[953,8]]}}}],["familiar",{"_index":310,"t":{"9":{"position":[[546,8]]}}}],["fast",{"_index":97,"t":{"5":{"position":[[651,4]]},"7":{"position":[[177,5]]}}}],["faster",{"_index":621,"t":{"125":{"position":[[858,6]]},"137":{"position":[[294,6],[1072,6]]}}}],["feature",{"_index":84,"t":{"5":{"position":[[461,7]]},"125":{"position":[[392,7]]},"135":{"position":[[785,8]]}}}],["features",{"_index":20,"t":{"3":{"position":[[213,8]]},"9":{"position":[[182,8]]},"119":{"position":[[388,9],[556,8]]},"125":{"position":[[321,8],[807,8],[1038,8]]},"131":{"position":[[417,8]]},"135":{"position":[[320,8]]},"137":{"position":[[448,8]]},"143":{"position":[[211,8],[294,8]]}}}],["feedback",{"_index":339,"t":{"11":{"position":[[109,8]]}}}],["feel",{"_index":551,"t":{"123":{"position":[[515,4]]}}}],["few",{"_index":107,"t":{"5":{"position":[[792,3]]},"123":{"position":[[1317,3]]},"129":{"position":[[817,3]]}}}],["fiddle",{"_index":257,"t":{"7":{"position":[[1845,6]]}}}],["final",{"_index":719,"t":{"135":{"position":[[934,5]]}}}],["finalized",{"_index":14,"t":{"3":{"position":[[131,10]]}}}],["finally",{"_index":586,"t":{"125":{"position":[[0,8]]},"143":{"position":[[0,8]]}}}],["fine",{"_index":342,"t":{"11":{"position":[[150,4]]}}}],["first",{"_index":86,"t":{"5":{"position":[[488,5]]},"7":{"position":[[735,6]]},"117":{"position":[[0,5]]},"121":{"position":[[306,5]]},"137":{"position":[[490,5],[919,5]]}}}],["fit",{"_index":547,"t":{"123":{"position":[[423,3],[1095,3]]}}}],["flexibility",{"_index":572,"t":{"123":{"position":[[1031,11]]},"141":{"position":[[587,11]]}}}],["fly",{"_index":603,"t":{"125":{"position":[[472,4]]}}}],["focus",{"_index":648,"t":{"129":{"position":[[322,5]]}}}],["folder",{"_index":605,"t":{"125":{"position":[[516,6]]}}}],["follow",{"_index":377,"t":{"15":{"position":[[39,6]]},"131":{"position":[[250,6]]}}}],["following",{"_index":161,"t":{"7":{"position":[[361,9]]}}}],["fonts",{"_index":615,"t":{"125":{"position":[[703,5]]}}}],["formats",{"_index":616,"t":{"125":{"position":[[722,8],[758,8]]}}}],["forward",{"_index":98,"t":{"5":{"position":[[656,7]]},"137":{"position":[[1027,7]]},"145":{"position":[[121,7],[368,7]]}}}],["four",{"_index":428,"t":{"115":{"position":[[72,4]]}}}],["fragmentation",{"_index":413,"t":{"113":{"position":[[485,13]]}}}],["fragmented",{"_index":448,"t":{"117":{"position":[[262,10]]}}}],["frame",{"_index":200,"t":{"7":{"position":[[1051,6],[1364,5],[1417,5]]}}}],["frames",{"_index":194,"t":{"7":{"position":[[926,7]]}}}],["framework",{"_index":594,"t":{"125":{"position":[[195,9],[248,10],[1051,9]]}}}],["frameworks",{"_index":645,"t":{"129":{"position":[[250,11],[568,11]]},"141":{"position":[[326,10]]}}}],["free",{"_index":552,"t":{"123":{"position":[[520,4]]}}}],["friendly",{"_index":319,"t":{"9":{"position":[[673,9]]},"135":{"position":[[150,8]]}}}],["front",{"_index":654,"t":{"129":{"position":[[476,5]]}}}],["full",{"_index":419,"t":{"113":{"position":[[610,4]]}}}],["function",{"_index":365,"t":{"13":{"position":[[167,9],[229,8]]}}}],["functional",{"_index":526,"t":{"123":{"position":[[75,10]]},"135":{"position":[[956,10]]}}}],["further",{"_index":211,"t":{"7":{"position":[[1190,7]]},"113":{"position":[[79,7]]}}}],["future",{"_index":5,"t":{"3":{"position":[[52,6]]},"5":{"position":[[1123,6]]},"13":{"position":[[428,6]]}}}],["gained",{"_index":95,"t":{"5":{"position":[[634,6]]}}}],["game",{"_index":504,"t":{"121":{"position":[[284,4],[345,4],[371,5],[432,4],[725,4],[781,4]]},"123":{"position":[[305,5]]},"135":{"position":[[644,4],[705,4]]},"143":{"position":[[92,4],[110,4],[179,4],[238,4],[313,4]]}}}],["game's",{"_index":548,"t":{"123":{"position":[[432,6],[1147,6]]}}}],["games",{"_index":400,"t":{"113":{"position":[[179,5],[377,5]]},"121":{"position":[[58,7],[102,5],[151,5],[217,5],[316,5],[383,5],[536,5],[677,5],[888,5]]},"123":{"position":[[505,6]]},"135":{"position":[[86,5],[1136,5]]},"141":{"position":[[234,5]]}}}],["geared",{"_index":315,"t":{"9":{"position":[[624,6]]}}}],["generate",{"_index":602,"t":{"125":{"position":[[445,8],[556,8],[677,8]]}}}],["github",{"_index":357,"t":{"11":{"position":[[403,6]]},"117":{"position":[[614,6]]},"119":{"position":[[643,6]]},"121":{"position":[[936,6],[1014,6]]},"123":{"position":[[579,6],[1341,6]]},"125":{"position":[[1140,6],[1152,6]]},"145":{"position":[[457,6]]}}}],["give",{"_index":182,"t":{"7":{"position":[[707,4]]},"141":{"position":[[561,4]]}}}],["go",{"_index":66,"t":{"5":{"position":[[215,2]]},"7":{"position":[[612,3]]}}}],["good",{"_index":347,"t":{"11":{"position":[[215,5]]}}}],["goodboy",{"_index":756,"t":{"141":{"position":[[11,7]]}}}],["gpu",{"_index":68,"t":{"5":{"position":[[247,3]]},"7":{"position":[[418,3],[601,3],[1370,3],[1394,3],[1464,3],[1471,3],[1475,3]]},"137":{"position":[[658,3]]}}}],["graph",{"_index":156,"t":{"7":{"position":[[260,5],[330,5],[533,5],[888,5]]}}}],["graphics",{"_index":8,"t":{"3":{"position":[[69,8]]},"5":{"position":[[126,8]]},"7":{"position":[[66,9]]},"13":{"position":[[445,9]]},"137":{"position":[[537,8],[727,8],[1149,8]]}}}],["great",{"_index":404,"t":{"113":{"position":[[340,5]]},"121":{"position":[[817,5]]},"123":{"position":[[1173,5]]}}}],["greatly",{"_index":771,"t":{"141":{"position":[[520,7]]}}}],["ground",{"_index":730,"t":{"137":{"position":[[95,6]]}}}],["groups",{"_index":700,"t":{"135":{"position":[[251,6]]}}}],["grow",{"_index":792,"t":{"145":{"position":[[405,4]]}}}],["growth",{"_index":445,"t":{"117":{"position":[[170,6]]}}}],["guides",{"_index":459,"t":{"117":{"position":[[449,6]]}}}],["guiding",{"_index":330,"t":{"9":{"position":[[817,7]]}}}],["handful",{"_index":78,"t":{"5":{"position":[[385,7]]}}}],["handle",{"_index":646,"t":{"129":{"position":[[276,6]]}}}],["handling",{"_index":777,"t":{"143":{"position":[[380,9]]}}}],["happens",{"_index":268,"t":{"7":{"position":[[2079,7]]}}}],["having",{"_index":707,"t":{"135":{"position":[[512,6]]}}}],["heights",{"_index":355,"t":{"11":{"position":[[331,8]]}}}],["help",{"_index":406,"t":{"113":{"position":[[355,4]]},"125":{"position":[[335,4],[816,4]]},"131":{"position":[[84,4],[291,4],[468,4],[1066,4]]}}}],["high",{"_index":142,"t":{"7":{"position":[[49,4]]},"131":{"position":[[901,4]]},"135":{"position":[[1123,4]]}}}],["highly",{"_index":541,"t":{"123":{"position":[[332,6]]}}}],["history",{"_index":102,"t":{"5":{"position":[[721,7]]}}}],["hopefully",{"_index":513,"t":{"121":{"position":[[688,9]]}}}],["ideas",{"_index":465,"t":{"117":{"position":[[561,5]]},"135":{"position":[[1104,5]]}}}],["images",{"_index":607,"t":{"125":{"position":[[537,6],[776,7]]}}}],["immediately",{"_index":93,"t":{"5":{"position":[[605,11]]}}}],["implemented",{"_index":31,"t":{"3":{"position":[[336,11]]}}}],["import",{"_index":366,"t":{"13":{"position":[[177,6]]}}}],["important",{"_index":590,"t":{"125":{"position":[[73,9]]}}}],["improve",{"_index":411,"t":{"113":{"position":[[456,7]]},"117":{"position":[[577,7]]},"125":{"position":[[604,7]]},"137":{"position":[[700,7]]}}}],["improved",{"_index":625,"t":{"125":{"position":[[904,8]]}}}],["improvement",{"_index":54,"t":{"5":{"position":[[53,11]]},"137":{"position":[[345,11]]}}}],["improvements",{"_index":19,"t":{"3":{"position":[[196,12]]},"7":{"position":[[1251,13],[1979,12]]},"9":{"position":[[333,12]]},"137":{"position":[[192,12]]}}}],["improving",{"_index":457,"t":{"117":{"position":[[405,9]]},"119":{"position":[[316,9]]}}}],["include",{"_index":775,"t":{"143":{"position":[[330,7]]}}}],["includes",{"_index":528,"t":{"123":{"position":[[127,8]]}}}],["including",{"_index":596,"t":{"125":{"position":[[259,9]]},"129":{"position":[[580,9]]}}}],["inclusion",{"_index":737,"t":{"137":{"position":[[477,9]]}}}],["incorporate",{"_index":767,"t":{"141":{"position":[[340,11]]}}}],["incredibly",{"_index":694,"t":{"133":{"position":[[122,10]]}}}],["individual",{"_index":606,"t":{"125":{"position":[[526,10]]}}}],["information",{"_index":769,"t":{"141":{"position":[[471,11]]}}}],["init",{"_index":369,"t":{"13":{"position":[[238,6]]}}}],["initial",{"_index":74,"t":{"5":{"position":[[317,7]]}}}],["initiative",{"_index":395,"t":{"113":{"position":[[65,10]]}}}],["inner",{"_index":671,"t":{"131":{"position":[[199,5],[1022,5]]}}}],["input",{"_index":571,"t":{"123":{"position":[[972,5]]},"143":{"position":[[374,5]]}}}],["inputs",{"_index":534,"t":{"123":{"position":[[201,7]]}}}],["inspiration",{"_index":518,"t":{"121":{"position":[[833,11]]}}}],["install",{"_index":360,"t":{"13":{"position":[[16,7],[54,7]]}}}],["instructions",{"_index":176,"t":{"7":{"position":[[562,13],[647,13],[966,13],[1029,12]]}}}],["integrated",{"_index":540,"t":{"123":{"position":[[284,10]]}}}],["integrates",{"_index":485,"t":{"119":{"position":[[532,10]]}}}],["intensive",{"_index":744,"t":{"137":{"position":[[736,9],[1158,9]]}}}],["interface",{"_index":483,"t":{"119":{"position":[[434,9]]},"123":{"position":[[1154,9]]},"135":{"position":[[159,10],[352,9]]}}}],["interfaces",{"_index":527,"t":{"123":{"position":[[91,10],[766,10],[940,10]]}}}],["internal",{"_index":313,"t":{"9":{"position":[[590,8]]},"141":{"position":[[43,8]]}}}],["introduce",{"_index":279,"t":{"9":{"position":[[154,9]]},"113":{"position":[[729,9]]}}}],["intuitive",{"_index":697,"t":{"135":{"position":[[131,9]]}}}],["invaluable",{"_index":341,"t":{"11":{"position":[[135,10]]}}}],["invite",{"_index":344,"t":{"11":{"position":[[177,6]]},"15":{"position":[[25,6]]}}}],["issues",{"_index":675,"t":{"131":{"position":[[328,6]]}}}],["it's",{"_index":111,"t":{"5":{"position":[[853,4]]}}}],["iterate",{"_index":716,"t":{"135":{"position":[[896,7]]}}}],["iteration",{"_index":15,"t":{"3":{"position":[[152,9]]}}}],["itself",{"_index":104,"t":{"5":{"position":[[742,6]]}}}],["join",{"_index":375,"t":{"13":{"position":[[405,4]]},"15":{"position":[[163,4]]}}}],["json",{"_index":620,"t":{"125":{"position":[[795,5]]}}}],["jumpstart",{"_index":632,"t":{"129":{"position":[[0,9],[358,9],[746,10]]}}}],["key",{"_index":180,"t":{"7":{"position":[[677,3]]},"9":{"position":[[14,3]]},"125":{"position":[[388,3]]},"131":{"position":[[413,3]]}}}],["killer",{"_index":17,"t":{"3":{"position":[[177,6]]}}}],["know",{"_index":467,"t":{"117":{"position":[[608,5]]}}}],["lacked",{"_index":408,"t":{"113":{"position":[[420,6]]}}}],["languages",{"_index":464,"t":{"117":{"position":[[534,10]]}}}],["large",{"_index":581,"t":{"123":{"position":[[1222,5]]}}}],["later",{"_index":770,"t":{"141":{"position":[[483,5]]}}}],["launch",{"_index":75,"t":{"5":{"position":[[325,7]]},"113":{"position":[[31,6]]}}}],["layout",{"_index":512,"t":{"121":{"position":[[640,6]]},"123":{"position":[[598,6],[840,6],[1010,7],[1253,6],[1334,6]]}}}],["layouts",{"_index":560,"t":{"123":{"position":[[717,7],[1063,7]]}}}],["leap",{"_index":217,"t":{"7":{"position":[[1286,4]]},"137":{"position":[[1022,4]]},"139":{"position":[[21,4]]}}}],["learn",{"_index":517,"t":{"121":{"position":[[753,5]]}}}],["leverage",{"_index":123,"t":{"5":{"position":[[995,8]]}}}],["leveraged",{"_index":731,"t":{"137":{"position":[[131,9]]}}}],["libraries",{"_index":436,"t":{"115":{"position":[[205,9]]},"119":{"position":[[632,10]]},"121":{"position":[[475,9],[615,9]]},"123":{"position":[[903,9]]}}}],["library",{"_index":469,"t":{"119":{"position":[[27,7],[141,7],[288,7],[402,7],[524,7]]},"123":{"position":[[19,7],[119,7],[616,7],[676,7]]},"125":{"position":[[138,7],[214,7]]},"143":{"position":[[70,7]]}}}],["library's",{"_index":480,"t":{"119":{"position":[[330,9]]}}}],["license",{"_index":500,"t":{"121":{"position":[[187,8]]}}}],["life",{"_index":556,"t":{"123":{"position":[[643,4]]}}}],["line",{"_index":709,"t":{"135":{"position":[[537,4]]}}}],["links",{"_index":793,"t":{"145":{"position":[[464,5]]}}}],["lists",{"_index":537,"t":{"123":{"position":[[223,6]]}}}],["little",{"_index":446,"t":{"117":{"position":[[197,6]]}}}],["loading",{"_index":622,"t":{"125":{"position":[[865,7]]},"143":{"position":[[396,7]]}}}],["long",{"_index":442,"t":{"117":{"position":[[152,4]]},"133":{"position":[[21,4]]},"141":{"position":[[400,4]]}}}],["longer",{"_index":639,"t":{"129":{"position":[[159,6]]},"141":{"position":[[285,6]]}}}],["look",{"_index":577,"t":{"123":{"position":[[1168,4]]},"139":{"position":[[62,4]]},"145":{"position":[[116,4],[363,4]]}}}],["looking",{"_index":519,"t":{"121":{"position":[[860,7]]},"137":{"position":[[953,7]]}}}],["loop",{"_index":181,"t":{"7":{"position":[[697,4]]},"15":{"position":[[16,5]]}}}],["lot",{"_index":782,"t":{"145":{"position":[[15,3],[109,3]]}}}],["made",{"_index":39,"t":{"3":{"position":[[472,5]]},"137":{"position":[[816,4]]}}}],["maintain",{"_index":410,"t":{"113":{"position":[[443,8]]}}}],["maintenance",{"_index":479,"t":{"119":{"position":[[269,11]]}}}],["major",{"_index":692,"t":{"133":{"position":[[72,5]]},"137":{"position":[[27,5],[577,5],[1016,5]]}}}],["make",{"_index":136,"t":{"5":{"position":[[1150,4]]},"7":{"position":[[270,4]]},"113":{"position":[[126,4]]},"123":{"position":[[633,4]]},"125":{"position":[[154,4]]},"127":{"position":[[39,4]]},"129":{"position":[[635,4]]},"131":{"position":[[151,4],[739,4],[862,4]]},"135":{"position":[[40,4]]},"137":{"position":[[187,4]]},"143":{"position":[[233,4]]}}}],["makes",{"_index":484,"t":{"119":{"position":[[449,5]]},"135":{"position":[[870,5],[1043,5]]}}}],["making",{"_index":317,"t":{"9":{"position":[[638,6]]},"135":{"position":[[659,6]]},"141":{"position":[[431,6]]},"145":{"position":[[251,6]]}}}],["manage",{"_index":599,"t":{"125":{"position":[[351,6]]}}}],["management",{"_index":589,"t":{"125":{"position":[[56,10]]},"143":{"position":[[408,11],[426,11]]}}}],["manpower",{"_index":409,"t":{"113":{"position":[[431,8]]}}}],["many",{"_index":282,"t":{"9":{"position":[[213,4]]},"113":{"position":[[335,4]]},"125":{"position":[[1026,4]]},"137":{"position":[[173,4]]},"143":{"position":[[206,4]]}}}],["market",{"_index":110,"t":{"5":{"position":[[836,7]]}}}],["match",{"_index":506,"t":{"121":{"position":[[337,5]]}}}],["matter",{"_index":112,"t":{"5":{"position":[[865,6]]}}}],["means",{"_index":561,"t":{"123":{"position":[[745,5],[1131,5]]},"135":{"position":[[443,5]]}}}],["media",{"_index":380,"t":{"15":{"position":[[77,6]]}}}],["mentioned",{"_index":794,"t":{"145":{"position":[[470,9]]}}}],["method",{"_index":67,"t":{"5":{"position":[[221,6]]}}}],["methodology",{"_index":324,"t":{"9":{"position":[[742,11]]}}}],["minify",{"_index":619,"t":{"125":{"position":[[788,6]]}}}],["minutes",{"_index":664,"t":{"129":{"position":[[821,7]]}}}],["mipmaps",{"_index":613,"t":{"125":{"position":[[686,8]]}}}],["miss",{"_index":304,"t":{"9":{"position":[[473,4]]}}}],["mit",{"_index":499,"t":{"121":{"position":[[183,3]]}}}],["mix",{"_index":763,"t":{"141":{"position":[[204,3]]}}}],["mobile",{"_index":579,"t":{"123":{"position":[[1204,6]]}}}],["modifications",{"_index":321,"t":{"9":{"position":[[702,14]]}}}],["months",{"_index":422,"t":{"113":{"position":[[638,7]]},"145":{"position":[[148,7]]}}}],["monumental",{"_index":37,"t":{"3":{"position":[[450,10]]}}}],["more",{"_index":61,"t":{"5":{"position":[[163,4]]},"9":{"position":[[397,4],[652,4]]},"15":{"position":[[109,4]]},"113":{"position":[[654,4]]},"117":{"position":[[444,4]]},"121":{"position":[[531,4]]},"125":{"position":[[986,4]]},"129":{"position":[[619,5]]},"131":{"position":[[1113,4]]},"135":{"position":[[282,4],[432,5]]},"137":{"position":[[305,4],[1083,4]]},"141":{"position":[[466,4],[582,4]]},"143":{"position":[[266,4],[466,5]]},"145":{"position":[[505,4]]}}}],["moved",{"_index":186,"t":{"7":{"position":[[804,6]]}}}],["moving",{"_index":231,"t":{"7":{"position":[[1500,6],[1556,6]]}}}],["much",{"_index":309,"t":{"9":{"position":[[534,4]]},"117":{"position":[[226,4]]},"137":{"position":[[1067,4]]}}}],["multi",{"_index":722,"t":{"135":{"position":[[1000,5]]}}}],["multiple",{"_index":449,"t":{"117":{"position":[[280,8]]},"131":{"position":[[596,8]]}}}],["naΓ―ve",{"_index":152,"t":{"7":{"position":[[209,7]]}}}],["nearing",{"_index":431,"t":{"115":{"position":[[116,7]]}}}],["need",{"_index":452,"t":{"117":{"position":[[337,4]]},"129":{"position":[[166,4]]},"141":{"position":[[292,4]]}}}],["needing",{"_index":127,"t":{"5":{"position":[[1042,7]]}}}],["needs",{"_index":550,"t":{"123":{"position":[[448,6]]}}}],["net",{"_index":214,"t":{"7":{"position":[[1231,3]]}}}],["new",{"_index":36,"t":{"3":{"position":[[419,3]]},"5":{"position":[[142,3],[357,3]]},"9":{"position":[[178,3],[462,4]]},"13":{"position":[[144,3]]},"115":{"position":[[16,3],[191,3]]},"117":{"position":[[84,3],[301,3]]},"119":{"position":[[384,3]]},"121":{"position":[[23,3]]},"123":{"position":[[15,3]]},"125":{"position":[[124,3],[454,3],[958,3]]},"129":{"position":[[15,3],[99,3],[784,3]]},"131":{"position":[[698,3]]},"135":{"position":[[16,3]]},"137":{"position":[[254,3],[533,3]]},"139":{"position":[[31,3]]},"143":{"position":[[66,3]]},"145":{"position":[[42,3],[331,3]]}}}],["newcomer",{"_index":50,"t":{"5":{"position":[[4,8]]}}}],["news",{"_index":783,"t":{"145":{"position":[[31,4]]}}}],["next",{"_index":420,"t":{"113":{"position":[[630,4]]},"119":{"position":[[0,4]]},"123":{"position":[[1312,4]]},"137":{"position":[[22,4]]}}}],["note",{"_index":307,"t":{"9":{"position":[[510,5]]}}}],["notes",{"_index":305,"t":{"9":{"position":[[490,6]]}}}],["nothing",{"_index":185,"t":{"7":{"position":[[792,7]]}}}],["now",{"_index":100,"t":{"5":{"position":[[687,3]]},"11":{"position":[[45,3]]},"121":{"position":[[8,3]]},"141":{"position":[[19,4],[114,3]]}}}],["npm",{"_index":359,"t":{"13":{"position":[[4,3],[50,3]]}}}],["number",{"_index":260,"t":{"7":{"position":[[1897,6]]}}}],["numbers",{"_index":248,"t":{"7":{"position":[[1690,7],[1936,7]]}}}],["objects",{"_index":681,"t":{"131":{"position":[[605,7],[793,8]]}}}],["odie",{"_index":758,"t":{"141":{"position":[[69,4]]}}}],["offer",{"_index":2,"t":{"3":{"position":[[18,5]]},"143":{"position":[[200,5]]}}}],["offers",{"_index":52,"t":{"5":{"position":[[20,6]]}}}],["one",{"_index":177,"t":{"7":{"position":[[608,3]]},"117":{"position":[[345,3]]},"131":{"position":[[402,3]]},"135":{"position":[[300,3]]},"137":{"position":[[423,3]]}}}],["open",{"_index":494,"t":{"121":{"position":[[53,4],[90,4],[672,4]]},"123":{"position":[[493,4]]},"141":{"position":[[130,4]]}}}],["operates",{"_index":150,"t":{"7":{"position":[[186,8]]}}}],["opportunity",{"_index":277,"t":{"9":{"position":[[119,11]]}}}],["optimal",{"_index":332,"t":{"9":{"position":[[837,7]]}}}],["optimizations",{"_index":733,"t":{"137":{"position":[[209,13]]}}}],["optimize",{"_index":145,"t":{"7":{"position":[[121,8]]},"125":{"position":[[832,8]]},"131":{"position":[[225,8],[570,8],[767,8],[1082,8]]},"137":{"position":[[845,8]]}}}],["optimizing",{"_index":188,"t":{"7":{"position":[[832,10]]}}}],["option",{"_index":746,"t":{"137":{"position":[[931,6]]}}}],["options",{"_index":710,"t":{"135":{"position":[[592,7]]}}}],["organic",{"_index":444,"t":{"117":{"position":[[162,7]]}}}],["out",{"_index":554,"t":{"123":{"position":[[540,3]]},"125":{"position":[[1132,3]]},"145":{"position":[[449,3]]}}}],["outside",{"_index":754,"t":{"139":{"position":[[94,7]]}}}],["over",{"_index":24,"t":{"3":{"position":[[265,4]]},"5":{"position":[[65,4]]},"113":{"position":[[621,4]]},"115":{"position":[[84,4]]},"117":{"position":[[177,4]]},"119":{"position":[[264,4]]},"137":{"position":[[168,4]]}}}],["overall",{"_index":684,"t":{"131":{"position":[[802,8]]},"137":{"position":[[984,8]]}}}],["overhaul",{"_index":272,"t":{"9":{"position":[[38,8]]}}}],["overhead",{"_index":190,"t":{"7":{"position":[[857,9],[996,8]]}}}],["overview",{"_index":301,"t":{"9":{"position":[[443,8]]}}}],["packed",{"_index":16,"t":{"3":{"position":[[165,6]]}}}],["parameters",{"_index":258,"t":{"7":{"position":[[1861,10]]}}}],["parcel",{"_index":657,"t":{"129":{"position":[[599,7]]}}}],["part",{"_index":591,"t":{"125":{"position":[[83,4]]}}}],["party",{"_index":266,"t":{"7":{"position":[[2056,5]]},"119":{"position":[[626,5]]}}}],["patrick",{"_index":474,"t":{"119":{"position":[[160,7]]}}}],["perfect",{"_index":336,"t":{"11":{"position":[[56,7]]}}}],["performance",{"_index":18,"t":{"3":{"position":[[184,11]]},"5":{"position":[[41,11]]},"7":{"position":[[54,11],[717,11],[1274,11]]},"9":{"position":[[52,11]]},"119":{"position":[[340,12]]},"125":{"position":[[616,11],[887,12]]},"131":{"position":[[316,11],[906,12]]},"137":{"position":[[370,11],[712,11]]}}}],["phase",{"_index":433,"t":{"115":{"position":[[135,5]]},"125":{"position":[[13,5]]},"127":{"position":[[0,5]]},"133":{"position":[[0,5]]},"139":{"position":[[0,5]]}}}],["phaser",{"_index":598,"t":{"125":{"position":[[290,7]]}}}],["phases",{"_index":429,"t":{"115":{"position":[[77,6]]}}}],["physics",{"_index":776,"t":{"143":{"position":[[350,7]]}}}],["pipeline",{"_index":49,"t":{"3":{"position":[[566,8]]}}}],["pixi",{"_index":473,"t":{"119":{"position":[[136,4]]}}}],["pixi.js",{"_index":367,"t":{"13":{"position":[[212,10]]}}}],["pixi.js@prerelease",{"_index":361,"t":{"13":{"position":[[62,18]]}}}],["pixijs",{"_index":11,"t":{"3":{"position":[[103,6],[375,6]]},"5":{"position":[[587,6],[921,6]]},"7":{"position":[[0,6]]},"9":{"position":[[516,6],[645,6]]},"11":{"position":[[307,6],[381,6]]},"13":{"position":[[380,6]]},"15":{"position":[[60,6]]},"113":{"position":[[45,6],[115,6],[206,6],[405,7],[603,6]]},"115":{"position":[[219,7]]},"117":{"position":[[100,7],[238,6]]},"119":{"position":[[11,6],[62,6],[92,6],[211,6],[247,6],[512,7],[568,6]]},"121":{"position":[[45,7],[134,6],[273,6],[421,6],[493,6],[597,6],[633,6],[651,6],[665,6],[770,6],[900,7]]},"123":{"position":[[0,6],[107,7],[455,6],[569,6],[591,6],[731,7],[833,6],[863,6],[1003,6],[1246,6],[1327,6]]},"125":{"position":[[269,7]]},"127":{"position":[[67,6]]},"129":{"position":[[51,6],[103,6],[683,6],[788,6]]},"131":{"position":[[0,6],[112,6],[217,7],[433,6],[530,7],[714,6],[811,6],[955,7],[1040,7]]},"133":{"position":[[93,6]]},"135":{"position":[[114,7]]},"137":{"position":[[0,6],[79,6],[235,6],[269,6],[460,6],[795,6],[993,6]]},"139":{"position":[[49,6]]},"141":{"position":[[99,7],[262,6]]},"143":{"position":[[85,6],[306,6]]},"145":{"position":[[81,6],[200,6],[414,6],[525,6]]}}}],["pixijs's",{"_index":73,"t":{"5":{"position":[[308,8],[443,8]]},"141":{"position":[[535,8]]}}}],["pixijs’s",{"_index":265,"t":{"7":{"position":[[2047,8]]}}}],["place",{"_index":453,"t":{"117":{"position":[[349,5]]}}}],["plan",{"_index":90,"t":{"5":{"position":[[557,4]]}}}],["planned",{"_index":423,"t":{"113":{"position":[[677,8]]},"121":{"position":[[542,7]]},"131":{"position":[[53,7]]}}}],["planning",{"_index":456,"t":{"117":{"position":[[393,8]]},"141":{"position":[[118,8]]}}}],["plans",{"_index":768,"t":{"141":{"position":[[451,5]]}}}],["play",{"_index":256,"t":{"7":{"position":[[1831,5]]},"121":{"position":[[1026,4],[1048,4]]}}}],["playco",{"_index":415,"t":{"113":{"position":[[534,6]]},"141":{"position":[[24,7]]},"145":{"position":[[240,6]]}}}],["player",{"_index":714,"t":{"135":{"position":[[778,6]]}}}],["playing",{"_index":23,"t":{"3":{"position":[[251,7]]}}}],["please",{"_index":255,"t":{"7":{"position":[[1817,6]]},"117":{"position":[[594,6]]}}}],["plethora",{"_index":280,"t":{"9":{"position":[[166,8]]}}}],["plugins",{"_index":612,"t":{"125":{"position":[[666,7]]}}}],["popular",{"_index":402,"t":{"113":{"position":[[231,7]]},"129":{"position":[[461,7]]}}}],["position",{"_index":203,"t":{"7":{"position":[[1100,9]]}}}],["possible",{"_index":790,"t":{"145":{"position":[[270,9]]}}}],["post",{"_index":284,"t":{"9":{"position":[[245,5]]},"125":{"position":[[967,4]]}}}],["posts",{"_index":289,"t":{"9":{"position":[[280,5]]}}}],["potions",{"_index":523,"t":{"121":{"position":[[1040,7]]}}}],["powered",{"_index":69,"t":{"5":{"position":[[251,7]]}}}],["powerful",{"_index":685,"t":{"131":{"position":[[838,8]]}}}],["practices",{"_index":333,"t":{"9":{"position":[[845,10]]},"131":{"position":[[262,10]]}}}],["precisely",{"_index":130,"t":{"5":{"position":[[1080,9]]}}}],["predecessor",{"_index":55,"t":{"5":{"position":[[74,12]]}}}],["preferred",{"_index":661,"t":{"129":{"position":[[710,9]]}}}],["preview",{"_index":4,"t":{"3":{"position":[[37,7]]}}}],["process",{"_index":593,"t":{"125":{"position":[[164,7]]},"129":{"position":[[79,7]]},"131":{"position":[[507,7],[641,7]]}}}],["product",{"_index":720,"t":{"135":{"position":[[940,7]]}}}],["professional",{"_index":503,"t":{"121":{"position":[[237,12]]}}}],["progress",{"_index":334,"t":{"11":{"position":[[6,8]]},"123":{"position":[[249,8]]},"141":{"position":[[438,8]]}}}],["project",{"_index":520,"t":{"121":{"position":[[912,7],[1005,8]]},"141":{"position":[[372,8],[410,8]]}}}],["projects",{"_index":299,"t":{"9":{"position":[[413,9]]},"113":{"position":[[668,8]]},"115":{"position":[[20,8]]},"119":{"position":[[237,9]]},"133":{"position":[[31,8]]},"145":{"position":[[46,8]]}}}],["proof",{"_index":134,"t":{"5":{"position":[[1130,5]]}}}],["propels",{"_index":57,"t":{"5":{"position":[[97,7]]}}}],["provide",{"_index":502,"t":{"121":{"position":[[229,7]]},"125":{"position":[[498,7]]},"129":{"position":[[523,7]]},"143":{"position":[[130,7]]}}}],["provides",{"_index":470,"t":{"119":{"position":[[40,8],[410,8]]},"125":{"position":[[301,8],[657,8],[977,8]]},"135":{"position":[[365,8],[562,8]]}}}],["providing",{"_index":60,"t":{"5":{"position":[[151,9]]},"131":{"position":[[966,9]]},"137":{"position":[[321,9]]}}}],["purpose",{"_index":501,"t":{"121":{"position":[[200,7]]}}}],["put",{"_index":451,"t":{"117":{"position":[[318,3]]}}}],["puzzling",{"_index":522,"t":{"121":{"position":[[1031,8]]}}}],["quality",{"_index":726,"t":{"135":{"position":[[1128,7]]}}}],["radio",{"_index":538,"t":{"123":{"position":[[230,5]]}}}],["range",{"_index":529,"t":{"123":{"position":[[138,5]]},"125":{"position":[[312,5]]},"135":{"position":[[573,5]]}}}],["ratios",{"_index":567,"t":{"123":{"position":[[825,7]]}}}],["re",{"_index":45,"t":{"3":{"position":[[524,2]]}}}],["react",{"_index":468,"t":{"119":{"position":[[18,6],[72,5],[99,5],[130,5],[231,5],[488,5]]},"121":{"position":[[658,6]]},"129":{"position":[[418,5]]}}}],["read",{"_index":27,"t":{"3":{"position":[[302,4]]}}}],["ready",{"_index":584,"t":{"123":{"position":[[1299,5]]}}}],["real",{"_index":390,"t":{"15":{"position":[[227,4]]},"123":{"position":[[548,4]]},"135":{"position":[[1012,4]]}}}],["reconstructing",{"_index":198,"t":{"7":{"position":[[1008,14]]}}}],["record",{"_index":727,"t":{"135":{"position":[[1162,6]]}}}],["recreate",{"_index":715,"t":{"135":{"position":[[822,8]]}}}],["reduce",{"_index":747,"t":{"137":{"position":[[964,6]]}}}],["reducing",{"_index":212,"t":{"7":{"position":[[1198,8]]}}}],["refinements",{"_index":294,"t":{"9":{"position":[[354,12]]}}}],["regardless",{"_index":660,"t":{"129":{"position":[[690,10]]}}}],["release",{"_index":10,"t":{"3":{"position":[[92,7],[423,7]]},"9":{"position":[[482,7]]},"11":{"position":[[26,7]]},"115":{"position":[[163,7]]},"121":{"position":[[554,8]]},"137":{"position":[[33,7]]},"141":{"position":[[507,7]]}}}],["released",{"_index":491,"t":{"121":{"position":[[12,8],[164,8],[322,8]]},"131":{"position":[[67,8]]}}}],["releasing",{"_index":427,"t":{"115":{"position":[[54,9]]},"117":{"position":[[52,9]]},"125":{"position":[[946,9]]}}}],["remains",{"_index":191,"t":{"7":{"position":[[894,7]]}}}],["remarkable",{"_index":298,"t":{"9":{"position":[[402,10]]}}}],["reminiscent",{"_index":72,"t":{"5":{"position":[[293,11]]}}}],["render",{"_index":164,"t":{"7":{"position":[[388,6]]}}}],["renderer",{"_index":153,"t":{"7":{"position":[[217,9],[2022,9]]},"13":{"position":[[125,8],[253,8],[344,8]]},"113":{"position":[[242,8]]},"137":{"position":[[880,9]]}}}],["rendering",{"_index":48,"t":{"3":{"position":[[556,9]]},"5":{"position":[[232,9],[502,9]]},"7":{"position":[[154,10],[624,9],[956,9],[1345,9],[1398,9]]},"113":{"position":[[290,9]]},"131":{"position":[[583,9],[780,9]]},"137":{"position":[[360,9]]},"139":{"position":[[117,10]]}}}],["repeating",{"_index":103,"t":{"5":{"position":[[732,9]]}}}],["repo",{"_index":254,"t":{"7":{"position":[[1812,4]]},"117":{"position":[[621,4]]},"119":{"position":[[650,4]]},"121":{"position":[[1021,4]]},"123":{"position":[[586,4],[1348,4]]},"125":{"position":[[1147,4],[1159,4]]}}}],["repository",{"_index":492,"t":{"121":{"position":[[27,10]]}}}],["represents",{"_index":728,"t":{"137":{"position":[[46,10],[1003,10]]},"139":{"position":[[8,10]]}}}],["resizable",{"_index":573,"t":{"123":{"position":[[1053,9]]}}}],["resource",{"_index":515,"t":{"121":{"position":[[712,8]]}}}],["resources",{"_index":677,"t":{"131":{"position":[[353,9]]},"145":{"position":[[345,10]]}}}],["respond",{"_index":570,"t":{"123":{"position":[[956,7]]}}}],["responsive",{"_index":559,"t":{"123":{"position":[[706,10]]}}}],["rest",{"_index":322,"t":{"9":{"position":[[717,4]]}}}],["retains",{"_index":308,"t":{"9":{"position":[[526,7]]}}}],["return",{"_index":373,"t":{"13":{"position":[[319,6]]}}}],["reuse",{"_index":195,"t":{"7":{"position":[[937,5]]}}}],["revealed",{"_index":691,"t":{"133":{"position":[[52,9]]}}}],["revisited",{"_index":143,"t":{"7":{"position":[[91,9]]}}}],["rewrite",{"_index":128,"t":{"5":{"position":[[1053,7]]},"137":{"position":[[68,7]]}}}],["right",{"_index":28,"t":{"3":{"position":[[312,6]]},"11":{"position":[[359,5]]},"129":{"position":[[848,5]]}}}],["robust",{"_index":63,"t":{"5":{"position":[[182,6]]},"9":{"position":[[657,6]]}}}],["rollup",{"_index":658,"t":{"129":{"position":[[607,7]]}}}],["roughly",{"_index":108,"t":{"5":{"position":[[817,7]]}}}],["runtime",{"_index":713,"t":{"135":{"position":[[770,7]]}}}],["same",{"_index":118,"t":{"5":{"position":[[948,4]]},"131":{"position":[[620,4]]}}}],["saving",{"_index":209,"t":{"7":{"position":[[1169,6]]}}}],["scene",{"_index":155,"t":{"7":{"position":[[254,5],[324,5],[527,5],[587,5],[882,5],[1087,5],[1625,5]]}}}],["scenes",{"_index":704,"t":{"135":{"position":[[399,7],[492,6],[831,6]]}}}],["screen",{"_index":169,"t":{"7":{"position":[[444,7]]},"123":{"position":[[801,6],[982,6],[1103,6]]}}}],["scroll",{"_index":535,"t":{"123":{"position":[[209,6]]}}}],["seamlessly",{"_index":762,"t":{"141":{"position":[[193,10]]}}}],["searchable",{"_index":455,"t":{"117":{"position":[[369,11]]}}}],["second",{"_index":160,"t":{"7":{"position":[[338,6],[867,7]]}}}],["see",{"_index":263,"t":{"7":{"position":[[1927,3]]},"9":{"position":[[790,3]]},"145":{"position":[[297,3]]}}}],["seen",{"_index":435,"t":{"115":{"position":[[154,4]]}}}],["seized",{"_index":276,"t":{"9":{"position":[[107,6]]}}}],["set",{"_index":175,"t":{"7":{"position":[[555,3]]},"129":{"position":[[174,3]]}}}],["setting",{"_index":643,"t":{"129":{"position":[[216,7]]}}}],["settings",{"_index":372,"t":{"13":{"position":[[298,8]]}}}],["setup",{"_index":647,"t":{"129":{"position":[[291,5]]}}}],["several",{"_index":425,"t":{"115":{"position":[[8,7],[174,7]]}}}],["shaping",{"_index":376,"t":{"13":{"position":[[416,7]]}}}],["share",{"_index":345,"t":{"11":{"position":[[191,5]]},"141":{"position":[[460,5]]}}}],["shared",{"_index":781,"t":{"145":{"position":[[6,6]]}}}],["sharing",{"_index":725,"t":{"135":{"position":[[1085,7]]}}}],["sheets",{"_index":609,"t":{"125":{"position":[[572,7]]}}}],["shift",{"_index":71,"t":{"5":{"position":[[284,5]]}}}],["shooter",{"_index":508,"t":{"121":{"position":[[363,7]]}}}],["shortly",{"_index":383,"t":{"15":{"position":[[131,8]]},"127":{"position":[[19,7]]}}}],["showcases",{"_index":497,"t":{"121":{"position":[[113,9]]}}}],["significant",{"_index":32,"t":{"3":{"position":[[348,11]]},"9":{"position":[[578,11]]},"137":{"position":[[333,11],[823,11]]}}}],["significantly",{"_index":610,"t":{"125":{"position":[[590,13]]},"137":{"position":[[686,13]]}}}],["similar",{"_index":650,"t":{"129":{"position":[[376,7]]}}}],["simplify",{"_index":637,"t":{"129":{"position":[[66,8]]}}}],["simply",{"_index":327,"t":{"9":{"position":[[783,6]]}}}],["sincere",{"_index":787,"t":{"145":{"position":[[178,7]]}}}],["single",{"_index":224,"t":{"7":{"position":[[1357,6],[1410,6]]},"9":{"position":[[238,6]]},"135":{"position":[[530,6]]}}}],["site",{"_index":466,"t":{"117":{"position":[[589,4]]}}}],["sites",{"_index":450,"t":{"117":{"position":[[289,6]]}}}],["sitting",{"_index":735,"t":{"137":{"position":[[408,7]]}}}],["situation",{"_index":227,"t":{"7":{"position":[[1429,9]]}}}],["size",{"_index":575,"t":{"123":{"position":[[1110,4]]},"137":{"position":[[978,5]]}}}],["sizes",{"_index":565,"t":{"123":{"position":[[808,5]]}}}],["skipped",{"_index":207,"t":{"7":{"position":[[1152,8]]}}}],["sliders",{"_index":532,"t":{"123":{"position":[[187,8]]}}}],["small",{"_index":578,"t":{"123":{"position":[[1198,5]]}}}],["social",{"_index":379,"t":{"15":{"position":[[70,6]]}}}],["somewhat",{"_index":151,"t":{"7":{"position":[[200,8]]}}}],["soon",{"_index":65,"t":{"5":{"position":[[194,5]]},"125":{"position":[[938,4]]},"131":{"position":[[76,4]]}}}],["source",{"_index":496,"t":{"121":{"position":[[95,6],[823,6]]},"123":{"position":[[498,6]]},"141":{"position":[[135,6]]}}}],["specific",{"_index":549,"t":{"123":{"position":[[439,8]]}}}],["speed",{"_index":141,"t":{"7":{"position":[[39,5]]}}}],["spend",{"_index":225,"t":{"7":{"position":[[1381,5]]}}}],["spent",{"_index":223,"t":{"7":{"position":[[1328,5]]}}}],["sprite",{"_index":608,"t":{"125":{"position":[[565,6]]}}}],["sprites",{"_index":230,"t":{"7":{"position":[[1488,7],[1544,7],[1607,7]]},"135":{"position":[[407,8],[613,8]]}}}],["stage",{"_index":340,"t":{"11":{"position":[[126,5]]}}}],["standout",{"_index":83,"t":{"5":{"position":[[452,8]]},"135":{"position":[[311,8]]}}}],["start",{"_index":22,"t":{"3":{"position":[[245,5]]},"13":{"position":[[355,5]]},"129":{"position":[[833,5]]},"133":{"position":[[40,5]]}}}],["started",{"_index":659,"t":{"129":{"position":[[670,7]]},"135":{"position":[[681,7]]}}}],["state",{"_index":778,"t":{"143":{"position":[[420,5]]}}}],["static",{"_index":147,"t":{"7":{"position":[[135,6]]}}}],["stay",{"_index":285,"t":{"9":{"position":[[251,4]]},"15":{"position":[[4,4]]},"145":{"position":[[490,4]]}}}],["step",{"_index":204,"t":{"7":{"position":[[1126,4],[1131,5]]}}}],["still",{"_index":583,"t":{"123":{"position":[[1263,5]]}}}],["stop",{"_index":275,"t":{"9":{"position":[[89,4]]}}}],["strategy",{"_index":120,"t":{"5":{"position":[[962,9]]}}}],["strictly",{"_index":755,"t":{"139":{"position":[[105,8]]}}}],["structure",{"_index":244,"t":{"7":{"position":[[1631,10]]},"117":{"position":[[204,9]]}}}],["stuck",{"_index":629,"t":{"125":{"position":[[1106,5]]}}}],["stunning",{"_index":687,"t":{"131":{"position":[[928,8]]}}}],["subsequent",{"_index":193,"t":{"7":{"position":[[915,10]]}}}],["substantial",{"_index":53,"t":{"5":{"position":[[29,11]]}}}],["such",{"_index":447,"t":{"117":{"position":[[221,4]]},"121":{"position":[[485,4],[625,4]]},"123":{"position":[[158,4]]},"129":{"position":[[403,4]]}}}],["suffered",{"_index":441,"t":{"117":{"position":[[138,8]]}}}],["suited",{"_index":750,"t":{"137":{"position":[[1120,6]]}}}],["support",{"_index":481,"t":{"119":{"position":[[372,7]]},"137":{"position":[[502,7],[782,8]]},"143":{"position":[[338,7]]},"145":{"position":[[393,7]]}}}],["supported",{"_index":106,"t":{"5":{"position":[[772,9],[910,10]]}}}],["sure",{"_index":157,"t":{"7":{"position":[[275,4]]},"145":{"position":[[435,4]]}}}],["switch",{"_index":764,"t":{"141":{"position":[[300,6]]}}}],["synonymous",{"_index":140,"t":{"7":{"position":[[23,10]]}}}],["take",{"_index":741,"t":{"137":{"position":[[631,4]]}}}],["taken",{"_index":478,"t":{"119":{"position":[[258,5]]}}}],["team",{"_index":418,"t":{"113":{"position":[[567,4]]},"129":{"position":[[58,4]]},"137":{"position":[[122,4],[802,4]]},"141":{"position":[[423,4]]}}}],["teams",{"_index":724,"t":{"135":{"position":[[1061,5]]}}}],["technique",{"_index":680,"t":{"131":{"position":[[552,9]]}}}],["technology",{"_index":125,"t":{"5":{"position":[[1013,10]]}}}],["templates",{"_index":655,"t":{"129":{"position":[[531,9]]}}}],["ten",{"_index":29,"t":{"3":{"position":[[319,3]]},"5":{"position":[[1167,3]]},"113":{"position":[[664,3]]}}}],["term",{"_index":443,"t":{"117":{"position":[[157,4]]},"133":{"position":[[26,4]]},"141":{"position":[[405,4]]}}}],["territory",{"_index":752,"t":{"139":{"position":[[35,9]]}}}],["test",{"_index":250,"t":{"7":{"position":[[1726,4]]},"135":{"position":[[887,4]]}}}],["text",{"_index":533,"t":{"123":{"position":[[196,4]]}}}],["thanks",{"_index":788,"t":{"145":{"position":[[186,6]]}}}],["there's",{"_index":785,"t":{"145":{"position":[[99,7]]}}}],["thereby",{"_index":208,"t":{"7":{"position":[[1161,7]]}}}],["things",{"_index":172,"t":{"7":{"position":[[494,6]]}}}],["third",{"_index":201,"t":{"7":{"position":[[1058,6]]}}}],["those",{"_index":761,"t":{"141":{"position":[[168,5]]}}}],["thoughtsβ€”the",{"_index":346,"t":{"11":{"position":[[202,12]]}}}],["three",{"_index":179,"t":{"7":{"position":[[671,5]]}}}],["threejs",{"_index":597,"t":{"125":{"position":[[277,8]]}}}],["thrilled",{"_index":1,"t":{"3":{"position":[[6,8]]},"143":{"position":[[16,8]]}}}],["time",{"_index":76,"t":{"5":{"position":[[341,5],[875,4]]},"7":{"position":[[345,4],[1323,4],[1376,4]]},"11":{"position":[[64,4]]},"15":{"position":[[232,4]]},"113":{"position":[[615,5]]},"135":{"position":[[1017,4],[1169,5]]}}}],["times",{"_index":623,"t":{"125":{"position":[[873,6]]}}}],["today",{"_index":99,"t":{"5":{"position":[[667,6]]},"13":{"position":[[395,5]]},"125":{"position":[[1115,5]]}}}],["together",{"_index":352,"t":{"11":{"position":[[282,9]]},"135":{"position":[[1075,9]]}}}],["tool",{"_index":634,"t":{"129":{"position":[[23,4],[134,5],[266,4],[513,4]]},"131":{"position":[[138,4],[847,4]]}}}],["tooling",{"_index":641,"t":{"129":{"position":[[193,7]]}}}],["tools",{"_index":405,"t":{"113":{"position":[[346,5],[470,6]]},"115":{"position":[[195,5]]},"129":{"position":[[397,5],[720,5]]},"131":{"position":[[11,5],[444,5],[725,5],[822,5]]},"135":{"position":[[582,5]]},"143":{"position":[[224,5]]},"145":{"position":[[335,5]]}}}],["toolset",{"_index":689,"t":{"131":{"position":[[1053,7]]}}}],["top",{"_index":760,"t":{"141":{"position":[[92,3]]}}}],["toward",{"_index":316,"t":{"9":{"position":[[631,6]]},"11":{"position":[[15,6]]}}}],["towards",{"_index":331,"t":{"9":{"position":[[829,7]]}}}],["traction",{"_index":96,"t":{"5":{"position":[[641,9]]}}}],["transform",{"_index":171,"t":{"7":{"position":[[476,9]]}}}],["transforms",{"_index":158,"t":{"7":{"position":[[288,10]]}}}],["translating",{"_index":463,"t":{"117":{"position":[[493,11]]}}}],["traverse",{"_index":154,"t":{"7":{"position":[[241,8],[311,8],[514,8]]}}}],["tricks",{"_index":267,"t":{"7":{"position":[[2062,7]]}}}],["try",{"_index":251,"t":{"7":{"position":[[1744,3]]}}}],["tuned",{"_index":286,"t":{"9":{"position":[[256,5]]},"145":{"position":[[495,5]]}}}],["tuning",{"_index":343,"t":{"11":{"position":[[155,6]]}}}],["tweak",{"_index":543,"t":{"123":{"position":[[369,5]]}}}],["tweening",{"_index":780,"t":{"143":{"position":[[452,9]]}}}],["two",{"_index":40,"t":{"3":{"position":[[478,3]]},"9":{"position":[[10,3]]},"121":{"position":[[312,3]]}}}],["ubiquitous",{"_index":82,"t":{"5":{"position":[[431,11]]}}}],["uglyβ€”report",{"_index":349,"t":{"11":{"position":[[238,11]]}}}],["ui",{"_index":510,"t":{"121":{"position":[[500,2]]},"123":{"position":[[7,2],[462,2],[576,2],[870,3]]}}}],["unchanged",{"_index":192,"t":{"7":{"position":[[902,9]]}}}],["under",{"_index":498,"t":{"121":{"position":[[173,5]]},"123":{"position":[[1269,5]]}}}],["undergoing",{"_index":312,"t":{"9":{"position":[[567,10]]}}}],["understand",{"_index":670,"t":{"131":{"position":[[184,10],[484,10],[671,11]]}}}],["understanding",{"_index":688,"t":{"131":{"position":[[1001,13]]}}}],["universally",{"_index":115,"t":{"5":{"position":[[898,11]]}}}],["universe",{"_index":394,"t":{"113":{"position":[[52,9]]},"145":{"position":[[532,9]]}}}],["unprecedented",{"_index":354,"t":{"11":{"position":[[317,13]]}}}],["unveiling",{"_index":381,"t":{"15":{"position":[[99,9]]}}}],["up",{"_index":437,"t":{"117":{"position":[[6,2]]},"119":{"position":[[5,2]]},"129":{"position":[[178,2],[224,2]]},"137":{"position":[[102,3]]}}}],["upcoming",{"_index":287,"t":{"9":{"position":[[266,8]]},"145":{"position":[[139,8]]}}}],["update",{"_index":170,"t":{"7":{"position":[[465,6],[745,6]]}}}],["updates",{"_index":314,"t":{"9":{"position":[[599,8]]},"15":{"position":[[123,7]]},"145":{"position":[[59,7],[510,7]]}}}],["upload",{"_index":165,"t":{"7":{"position":[[395,6],[576,6],[1119,6]]}}}],["url",{"_index":259,"t":{"7":{"position":[[1879,3]]}}}],["usability",{"_index":273,"t":{"9":{"position":[[68,10]]}}}],["use",{"_index":219,"t":{"7":{"position":[[1306,3]]},"119":{"position":[[58,3],[430,3]]},"121":{"position":[[130,3],[269,3],[417,3],[465,3],[593,3],[766,3]]},"125":{"position":[[1009,3]]}}}],["used",{"_index":477,"t":{"119":{"position":[[199,4]]},"123":{"position":[[474,4]]},"125":{"position":[[234,4]]},"131":{"position":[[562,4]]}}}],["useful",{"_index":628,"t":{"125":{"position":[[1031,6]]}}}],["user",{"_index":318,"t":{"9":{"position":[[668,4]]},"123":{"position":[[86,4],[967,4]]},"125":{"position":[[913,4]]},"135":{"position":[[145,4],[1006,5]]}}}],["using",{"_index":363,"t":{"13":{"position":[[134,5]]},"121":{"position":[[894,5]]},"123":{"position":[[725,5]]}}}],["v7",{"_index":149,"t":{"7":{"position":[[171,2],[227,2],[1439,2],[1461,2],[1758,2]]},"9":{"position":[[739,2]]},"137":{"position":[[394,2]]}}}],["v8",{"_index":12,"t":{"3":{"position":[[110,3],[578,3]]},"7":{"position":[[81,3],[452,2],[1446,2],[1468,2],[1771,2],[1792,2]]},"9":{"position":[[523,2]]},"11":{"position":[[100,3],[388,2]]},"13":{"position":[[81,2],[387,2]]},"137":{"position":[[7,2],[467,2],[1000,2]]}}}],["valuable",{"_index":514,"t":{"121":{"position":[[703,8]]}}}],["varying",{"_index":218,"t":{"7":{"position":[[1298,7]]}}}],["vendors",{"_index":739,"t":{"137":{"position":[[591,8]]}}}],["version",{"_index":131,"t":{"5":{"position":[[1095,7]]},"13":{"position":[[33,7]]},"117":{"position":[[69,7]]},"137":{"position":[[258,7]]}}}],["via",{"_index":358,"t":{"13":{"position":[[0,3]]}}}],["vibrant",{"_index":385,"t":{"15":{"position":[[172,7]]}}}],["views",{"_index":536,"t":{"123":{"position":[[216,6]]}}}],["visual",{"_index":702,"t":{"135":{"position":[[345,6]]}}}],["visualize",{"_index":676,"t":{"131":{"position":[[339,9]]}}}],["visually",{"_index":686,"t":{"131":{"position":[[919,8]]},"135":{"position":[[971,8]]}}}],["vue",{"_index":652,"t":{"129":{"position":[[438,4]]}}}],["waitβ€”dive",{"_index":356,"t":{"11":{"position":[[349,9]]}}}],["want",{"_index":516,"t":{"121":{"position":[[745,4]]},"123":{"position":[[46,4]]},"125":{"position":[[1094,4]]},"141":{"position":[[185,4]]},"145":{"position":[[159,4]]}}}],["warning",{"_index":329,"t":{"9":{"position":[[808,8]]}}}],["way",{"_index":471,"t":{"119":{"position":[[51,3]]}}}],["we'll",{"_index":290,"t":{"9":{"position":[[292,5]]},"15":{"position":[[90,5]]}}}],["we're",{"_index":0,"t":{"3":{"position":[[0,5],[222,5]]},"145":{"position":[[280,5]]}}}],["we've",{"_index":38,"t":{"3":{"position":[[461,5]]},"7":{"position":[[85,5]]},"9":{"position":[[101,5]]},"145":{"position":[[0,5]]}}}],["web",{"_index":7,"t":{"3":{"position":[[65,3]]},"5":{"position":[[105,3],[274,4]]},"13":{"position":[[441,3]]},"113":{"position":[[259,4]]}}}],["webgl",{"_index":56,"t":{"5":{"position":[[87,6],[347,5],[517,5],[628,5],[678,5]]},"7":{"position":[[1806,5],[2016,5]]},"13":{"position":[[328,5]]}}}],["webgpu",{"_index":51,"t":{"5":{"position":[[13,6],[754,7]]},"7":{"position":[[1785,6],[2001,6]]},"13":{"position":[[337,6]]},"137":{"position":[[514,7],[775,6]]}}}],["webpack",{"_index":656,"t":{"129":{"position":[[590,8]]}}}],["website",{"_index":438,"t":{"117":{"position":[[88,7],[305,7]]}}}],["weeks",{"_index":585,"t":{"123":{"position":[[1321,5]]}}}],["well",{"_index":461,"t":{"117":{"position":[[473,4]]},"123":{"position":[[853,4]]}}}],["what's",{"_index":302,"t":{"9":{"position":[[455,6]]}}}],["widely",{"_index":476,"t":{"119":{"position":[[192,6]]}}}],["without",{"_index":126,"t":{"5":{"position":[[1034,7]]},"135":{"position":[[499,7]]}}}],["work",{"_index":213,"t":{"7":{"position":[[1221,5]]},"113":{"position":[[595,4]]},"127":{"position":[[57,4]]},"135":{"position":[[277,4],[1070,4]]}}}],["workflows",{"_index":662,"t":{"129":{"position":[[730,10]]}}}],["working",{"_index":773,"t":{"143":{"position":[[53,7]]}}}],["workings",{"_index":672,"t":{"131":{"position":[[205,8],[1028,8]]}}}],["works",{"_index":426,"t":{"115":{"position":[[36,6]]},"123":{"position":[[847,5]]}}}],["workβ€”you'll",{"_index":326,"t":{"9":{"position":[[771,11]]}}}],["world",{"_index":555,"t":{"123":{"position":[[553,5]]}}}],["worry",{"_index":642,"t":{"129":{"position":[[204,5]]}}}],["write",{"_index":708,"t":{"135":{"position":[[522,5]]}}}],["x2",{"_index":736,"t":{"137":{"position":[[419,3]]}}}],["year",{"_index":430,"t":{"115":{"position":[[93,5]]},"141":{"position":[[496,5]]}}}],["years",{"_index":138,"t":{"5":{"position":[[1171,5]]},"113":{"position":[[199,6]]},"117":{"position":[[186,5]]},"137":{"position":[[178,5]]},"141":{"position":[[4,6]]}}}],["years!β€”we've",{"_index":30,"t":{"3":{"position":[[323,12]]}}}],["you'll",{"_index":663,"t":{"129":{"position":[[757,6]]},"145":{"position":[[306,6]]}}}],["yourself",{"_index":252,"t":{"7":{"position":[[1748,9]]}}}]],"pipeline":["stemmer"]}}] \ No newline at end of file diff --git a/search-index-examples.json b/search-index-examples.json index c0994a499..5f30d8b93 100644 --- a/search-index-examples.json +++ b/search-index-examples.json @@ -1 +1 @@ -[{"documents":[{"i":72,"t":"Examples","u":"/examples","b":[]},{"i":74,"t":"Collision Detection","u":"/examples/advanced/collision-detection","b":["Advanced"]},{"i":76,"t":"Scratch Card","u":"/examples/advanced/scratch-card","b":["Advanced"]},{"i":78,"t":"Screen Shot","u":"/examples/advanced/screen-shot","b":["Advanced"]},{"i":80,"t":"Mouse Trail","u":"/examples/advanced/mouse-trail","b":["Advanced"]},{"i":82,"t":"Star Warp","u":"/examples/advanced/star-warp","b":["Advanced"]},{"i":84,"t":"Slots","u":"/examples/advanced/slots","b":["Advanced"]},{"i":86,"t":"Bundle","u":"/examples/assets/bundle","b":["Assets"]},{"i":88,"t":"Multiple","u":"/examples/assets/multiple","b":["Assets"]},{"i":90,"t":"Promise","u":"/examples/assets/promise","b":["Assets"]},{"i":92,"t":"Background","u":"/examples/assets/background","b":["Assets"]},{"i":94,"t":"Spinners","u":"/examples/advanced/spinners","b":["Advanced"]},{"i":96,"t":"Blend Modes","u":"/examples/basic/blend-modes","b":["Basic"]},{"i":98,"t":"Container","u":"/examples/basic/container","b":["Basic"]},{"i":100,"t":"Async","u":"/examples/assets/async","b":["Assets"]},{"i":102,"t":"Simple Plane","u":"/examples/basic/simple-plane","b":["Basic"]},{"i":104,"t":"Tinting","u":"/examples/basic/tinting","b":["Basic"]},{"i":106,"t":"Cache As Bitmap","u":"/examples/basic/cache-as-bitmap","b":["Basic"]},{"i":108,"t":"Transparent Background","u":"/examples/basic/transparent-background","b":["Basic"]},{"i":110,"t":"Click","u":"/examples/events/click","b":["Events"]},{"i":112,"t":"Particle Container","u":"/examples/basic/particle-container","b":["Basic"]},{"i":114,"t":"Custom Mouse Icon","u":"/examples/events/custom-mouse-icon","b":["Events"]},{"i":116,"t":"Dragging","u":"/examples/events/dragging","b":["Events"]},{"i":118,"t":"Logger","u":"/examples/events/logger","b":["Events"]},{"i":120,"t":"Interactivity","u":"/examples/events/interactivity","b":["Events"]},{"i":122,"t":"Custom Hitarea","u":"/examples/events/custom-hitarea","b":["Events"]},{"i":124,"t":"Pointer Tracker","u":"/examples/events/pointer-tracker","b":["Events"]},{"i":126,"t":"Slider","u":"/examples/events/slider","b":["Events"]},{"i":128,"t":"Custom","u":"/examples/filters-advanced/custom","b":["Filters Advanced"]},{"i":130,"t":"Shader Toy Filter Render Texture","u":"/examples/filters-advanced/shader-toy-filter-render-texture","b":["Filters Advanced"]},{"i":132,"t":"Mouse Blending","u":"/examples/filters-advanced/mouse-blending","b":["Filters Advanced"]},{"i":134,"t":"Blur","u":"/examples/filters-basic/blur","b":["Filters Basic"]},{"i":136,"t":"Displacement Map Crawlies","u":"/examples/filters-basic/displacement-map-crawlies","b":["Filters Basic"]},{"i":138,"t":"Nested Boundary With Projection","u":"/examples/events/nested-boundary-with-projection","b":["Events"]},{"i":140,"t":"Color Matrix","u":"/examples/filters-basic/color-matrix","b":["Filters Basic"]},{"i":142,"t":"Advanced","u":"/examples/graphics/advanced","b":["Graphics"]},{"i":144,"t":"Dynamic","u":"/examples/graphics/dynamic","b":["Graphics"]},{"i":146,"t":"Displacement Map Flag","u":"/examples/filters-basic/displacement-map-flag","b":["Filters Basic"]},{"i":148,"t":"Filter","u":"/examples/masks/filter","b":["Masks"]},{"i":150,"t":"Simple","u":"/examples/graphics/simple","b":["Graphics"]},{"i":152,"t":"Graphics","u":"/examples/masks/graphics","b":["Masks"]},{"i":154,"t":"Sprite","u":"/examples/masks/sprite","b":["Masks"]},{"i":156,"t":"Interleaving Geometry","u":"/examples/mesh-and-shaders/interleaving-geometry","b":["Mesh And Shaders"]},{"i":158,"t":"Instanced Geometry","u":"/examples/mesh-and-shaders/instanced-geometry","b":["Mesh And Shaders"]},{"i":160,"t":"Merging Geometry","u":"/examples/mesh-and-shaders/merging-geometry","b":["Mesh And Shaders"]},{"i":162,"t":"Multi Pass Shader Generated Mesh","u":"/examples/mesh-and-shaders/multi-pass-shader-generated-mesh","b":["Mesh And Shaders"]},{"i":164,"t":"Shader Toy Mesh","u":"/examples/mesh-and-shaders/shader-toy-mesh","b":["Mesh And Shaders"]},{"i":166,"t":"Sharing Geometry","u":"/examples/mesh-and-shaders/sharing-geometry","b":["Mesh And Shaders"]},{"i":168,"t":"Shared Shader","u":"/examples/mesh-and-shaders/shared-shader","b":["Mesh And Shaders"]},{"i":170,"t":"Textured Mesh Advanced","u":"/examples/mesh-and-shaders/textured-mesh-advanced","b":["Mesh And Shaders"]},{"i":172,"t":"Textured Mesh Basic","u":"/examples/mesh-and-shaders/textured-mesh-basic","b":["Mesh And Shaders"]},{"i":174,"t":"Triangle","u":"/examples/mesh-and-shaders/triangle","b":["Mesh And Shaders"]},{"i":176,"t":"Triangle Color","u":"/examples/mesh-and-shaders/triangle-color","b":["Mesh And Shaders"]},{"i":178,"t":"Triangle Textured","u":"/examples/mesh-and-shaders/triangle-textured","b":["Mesh And Shaders"]},{"i":180,"t":"Uniforms","u":"/examples/mesh-and-shaders/uniforms","b":["Mesh And Shaders"]},{"i":182,"t":"Animated Sprite Animation Speed","u":"/examples/sprite/animated-sprite-animation-speed","b":["Sprite"]},{"i":184,"t":"Animated Sprite Explosion","u":"/examples/sprite/animated-sprite-explosion","b":["Sprite"]},{"i":186,"t":"Animated Sprite Jet","u":"/examples/sprite/animated-sprite-jet","b":["Sprite"]},{"i":188,"t":"Basic","u":"/examples/sprite/basic","b":["Sprite"]},{"i":190,"t":"Texture Swap","u":"/examples/sprite/texture-swap","b":["Sprite"]},{"i":192,"t":"Basic","u":"/examples/offscreen-canvas/basic","b":["Offscreen Canvas"]},{"i":194,"t":"Tiling Sprite","u":"/examples/sprite/tiling-sprite","b":["Sprite"]},{"i":196,"t":"Bitmap Text","u":"/examples/text/bitmap-text","b":["Text"]},{"i":198,"t":"Video","u":"/examples/sprite/video","b":["Sprite"]},{"i":200,"t":"From Font","u":"/examples/text/from-font","b":["Text"]},{"i":202,"t":"Web Font","u":"/examples/text/web-font","b":["Text"]},{"i":204,"t":"Pixi Text","u":"/examples/text/pixi-text","b":["Text"]},{"i":206,"t":"Gradient Resource","u":"/examples/textures/gradient-resource","b":["Textures"]},{"i":208,"t":"Gradient Basic","u":"/examples/textures/gradient-basic","b":["Textures"]},{"i":210,"t":"Render Texture Advanced","u":"/examples/textures/render-texture-advanced","b":["Textures"]},{"i":212,"t":"Render Texture Basic","u":"/examples/textures/render-texture-basic","b":["Textures"]},{"i":237,"t":"Texture Rotate","u":"/examples/textures/texture-rotate","b":["Textures"]}],"index":{"version":"2.3.9","fields":["t"],"fieldVectors":[["t/72",[0,4.792]],["t/74",[1,3.77,2,3.77]],["t/76",[3,3.77,4,3.77]],["t/78",[5,3.77,6,3.77]],["t/80",[7,2.948,8,3.77]],["t/82",[9,3.77,10,3.77]],["t/84",[11,4.792]],["t/86",[12,4.792]],["t/88",[13,4.792]],["t/90",[14,4.792]],["t/92",[15,4.162]],["t/94",[16,4.792]],["t/96",[17,3.77,18,3.77]],["t/98",[19,4.162]],["t/100",[20,4.792]],["t/102",[21,3.274,22,3.77]],["t/104",[23,4.792]],["t/106",[24,3.77,25,3.274]],["t/108",[15,3.274,26,3.77]],["t/110",[27,4.792]],["t/112",[19,3.274,28,3.77]],["t/114",[7,2.429,29,2.429,30,3.107]],["t/116",[31,4.792]],["t/118",[32,4.792]],["t/120",[33,4.792]],["t/122",[29,2.948,34,3.77]],["t/124",[35,3.77,36,3.77]],["t/126",[37,4.792]],["t/128",[29,3.747]],["t/130",[38,1.649,39,1.997,40,1.997,41,1.797,42,1.53]],["t/132",[7,2.948,43,3.77]],["t/134",[44,4.792]],["t/136",[45,2.699,46,2.699,47,3.107]],["t/138",[48,3.107,49,3.107,50,3.107]],["t/140",[51,3.274,52,3.77]],["t/142",[53,3.747]],["t/144",[54,4.792]],["t/146",[45,2.699,46,2.699,55,3.107]],["t/148",[40,4.162]],["t/150",[21,4.162]],["t/152",[56,4.792]],["t/154",[57,3.189]],["t/156",[58,3.77,59,2.704]],["t/158",[59,2.704,60,3.77]],["t/160",[59,2.704,61,3.77]],["t/162",[38,1.649,62,2.299,63,2.299,64,2.299,65,1.649]],["t/164",[38,2.229,39,2.699,65,2.229]],["t/166",[59,2.704,66,3.77]],["t/168",[38,2.704,67,3.77]],["t/170",[53,2.429,65,2.229,68,2.429]],["t/172",[65,2.229,68,2.429,69,2.068]],["t/174",[70,3.747]],["t/176",[51,3.274,70,2.948]],["t/178",[68,2.948,70,2.948]],["t/180",[71,4.792]],["t/182",[57,1.759,72,2.066,73,2.643,74,2.643]],["t/184",[57,2.068,72,2.429,75,3.107]],["t/186",[57,2.068,72,2.429,76,3.107]],["t/188",[69,3.189]],["t/190",[42,2.509,77,3.77]],["t/192",[69,3.189]],["t/194",[57,2.509,78,3.77]],["t/196",[25,3.274,79,3.274]],["t/198",[80,4.792]],["t/200",[81,4.162]],["t/202",[81,3.274,82,3.77]],["t/204",[79,3.274,83,3.77]],["t/206",[84,3.274,85,3.77]],["t/208",[69,2.509,84,3.274]],["t/210",[41,2.429,42,2.068,53,2.429]],["t/212",[41,2.429,42,2.068,69,2.068]],["t/237",[42,2.509,86,3.77]]],"invertedIndex":[["advanced",{"_index":53,"t":{"142":{"position":[[0,8]]},"170":{"position":[[14,8]]},"210":{"position":[[15,8]]}}}],["animated",{"_index":72,"t":{"182":{"position":[[0,8]]},"184":{"position":[[0,8]]},"186":{"position":[[0,8]]}}}],["animation",{"_index":73,"t":{"182":{"position":[[16,9]]}}}],["async",{"_index":20,"t":{"100":{"position":[[0,5]]}}}],["background",{"_index":15,"t":{"92":{"position":[[0,10]]},"108":{"position":[[12,10]]}}}],["basic",{"_index":69,"t":{"172":{"position":[[14,5]]},"188":{"position":[[0,5]]},"192":{"position":[[0,5]]},"208":{"position":[[9,5]]},"212":{"position":[[15,5]]}}}],["bitmap",{"_index":25,"t":{"106":{"position":[[9,6]]},"196":{"position":[[0,6]]}}}],["blend",{"_index":17,"t":{"96":{"position":[[0,5]]}}}],["blending",{"_index":43,"t":{"132":{"position":[[6,8]]}}}],["blur",{"_index":44,"t":{"134":{"position":[[0,4]]}}}],["boundary",{"_index":49,"t":{"138":{"position":[[7,8]]}}}],["bundle",{"_index":12,"t":{"86":{"position":[[0,6]]}}}],["cache",{"_index":24,"t":{"106":{"position":[[0,5]]}}}],["card",{"_index":4,"t":{"76":{"position":[[8,4]]}}}],["click",{"_index":27,"t":{"110":{"position":[[0,5]]}}}],["collision",{"_index":1,"t":{"74":{"position":[[0,9]]}}}],["color",{"_index":51,"t":{"140":{"position":[[0,5]]},"176":{"position":[[9,5]]}}}],["container",{"_index":19,"t":{"98":{"position":[[0,9]]},"112":{"position":[[9,9]]}}}],["crawlies",{"_index":47,"t":{"136":{"position":[[17,8]]}}}],["custom",{"_index":29,"t":{"114":{"position":[[0,6]]},"122":{"position":[[0,6]]},"128":{"position":[[0,6]]}}}],["detection",{"_index":2,"t":{"74":{"position":[[10,9]]}}}],["displacement",{"_index":45,"t":{"136":{"position":[[0,12]]},"146":{"position":[[0,12]]}}}],["dragging",{"_index":31,"t":{"116":{"position":[[0,8]]}}}],["dynamic",{"_index":54,"t":{"144":{"position":[[0,7]]}}}],["examples",{"_index":0,"t":{"72":{"position":[[0,8]]}}}],["explosion",{"_index":75,"t":{"184":{"position":[[16,9]]}}}],["filter",{"_index":40,"t":{"130":{"position":[[11,6]]},"148":{"position":[[0,6]]}}}],["flag",{"_index":55,"t":{"146":{"position":[[17,4]]}}}],["font",{"_index":81,"t":{"200":{"position":[[5,4]]},"202":{"position":[[4,4]]}}}],["generated",{"_index":64,"t":{"162":{"position":[[18,9]]}}}],["geometry",{"_index":59,"t":{"156":{"position":[[13,8]]},"158":{"position":[[10,8]]},"160":{"position":[[8,8]]},"166":{"position":[[8,8]]}}}],["gradient",{"_index":84,"t":{"206":{"position":[[0,8]]},"208":{"position":[[0,8]]}}}],["graphics",{"_index":56,"t":{"152":{"position":[[0,8]]}}}],["hitarea",{"_index":34,"t":{"122":{"position":[[7,7]]}}}],["icon",{"_index":30,"t":{"114":{"position":[[13,4]]}}}],["instanced",{"_index":60,"t":{"158":{"position":[[0,9]]}}}],["interactivity",{"_index":33,"t":{"120":{"position":[[0,13]]}}}],["interleaving",{"_index":58,"t":{"156":{"position":[[0,12]]}}}],["jet",{"_index":76,"t":{"186":{"position":[[16,3]]}}}],["logger",{"_index":32,"t":{"118":{"position":[[0,6]]}}}],["map",{"_index":46,"t":{"136":{"position":[[13,3]]},"146":{"position":[[13,3]]}}}],["matrix",{"_index":52,"t":{"140":{"position":[[6,6]]}}}],["merging",{"_index":61,"t":{"160":{"position":[[0,7]]}}}],["mesh",{"_index":65,"t":{"162":{"position":[[28,4]]},"164":{"position":[[11,4]]},"170":{"position":[[9,4]]},"172":{"position":[[9,4]]}}}],["modes",{"_index":18,"t":{"96":{"position":[[6,5]]}}}],["mouse",{"_index":7,"t":{"80":{"position":[[0,5]]},"114":{"position":[[7,5]]},"132":{"position":[[0,5]]}}}],["multi",{"_index":62,"t":{"162":{"position":[[0,5]]}}}],["multiple",{"_index":13,"t":{"88":{"position":[[0,8]]}}}],["nested",{"_index":48,"t":{"138":{"position":[[0,6]]}}}],["particle",{"_index":28,"t":{"112":{"position":[[0,8]]}}}],["pass",{"_index":63,"t":{"162":{"position":[[6,4]]}}}],["pixi",{"_index":83,"t":{"204":{"position":[[0,4]]}}}],["plane",{"_index":22,"t":{"102":{"position":[[7,5]]}}}],["pointer",{"_index":35,"t":{"124":{"position":[[0,7]]}}}],["projection",{"_index":50,"t":{"138":{"position":[[21,10]]}}}],["promise",{"_index":14,"t":{"90":{"position":[[0,7]]}}}],["render",{"_index":41,"t":{"130":{"position":[[18,6]]},"210":{"position":[[0,6]]},"212":{"position":[[0,6]]}}}],["resource",{"_index":85,"t":{"206":{"position":[[9,8]]}}}],["rotate",{"_index":86,"t":{"237":{"position":[[8,6]]}}}],["scratch",{"_index":3,"t":{"76":{"position":[[0,7]]}}}],["screen",{"_index":5,"t":{"78":{"position":[[0,6]]}}}],["shader",{"_index":38,"t":{"130":{"position":[[0,6]]},"162":{"position":[[11,6]]},"164":{"position":[[0,6]]},"168":{"position":[[7,6]]}}}],["shared",{"_index":67,"t":{"168":{"position":[[0,6]]}}}],["sharing",{"_index":66,"t":{"166":{"position":[[0,7]]}}}],["shot",{"_index":6,"t":{"78":{"position":[[7,4]]}}}],["simple",{"_index":21,"t":{"102":{"position":[[0,6]]},"150":{"position":[[0,6]]}}}],["slider",{"_index":37,"t":{"126":{"position":[[0,6]]}}}],["slots",{"_index":11,"t":{"84":{"position":[[0,5]]}}}],["speed",{"_index":74,"t":{"182":{"position":[[26,5]]}}}],["spinners",{"_index":16,"t":{"94":{"position":[[0,8]]}}}],["sprite",{"_index":57,"t":{"154":{"position":[[0,6]]},"182":{"position":[[9,6]]},"184":{"position":[[9,6]]},"186":{"position":[[9,6]]},"194":{"position":[[7,6]]}}}],["star",{"_index":9,"t":{"82":{"position":[[0,4]]}}}],["swap",{"_index":77,"t":{"190":{"position":[[8,4]]}}}],["text",{"_index":79,"t":{"196":{"position":[[7,4]]},"204":{"position":[[5,4]]}}}],["texture",{"_index":42,"t":{"130":{"position":[[25,7]]},"190":{"position":[[0,7]]},"210":{"position":[[7,7]]},"212":{"position":[[7,7]]},"237":{"position":[[0,7]]}}}],["textured",{"_index":68,"t":{"170":{"position":[[0,8]]},"172":{"position":[[0,8]]},"178":{"position":[[9,8]]}}}],["tiling",{"_index":78,"t":{"194":{"position":[[0,6]]}}}],["tinting",{"_index":23,"t":{"104":{"position":[[0,7]]}}}],["toy",{"_index":39,"t":{"130":{"position":[[7,3]]},"164":{"position":[[7,3]]}}}],["tracker",{"_index":36,"t":{"124":{"position":[[8,7]]}}}],["trail",{"_index":8,"t":{"80":{"position":[[6,5]]}}}],["transparent",{"_index":26,"t":{"108":{"position":[[0,11]]}}}],["triangle",{"_index":70,"t":{"174":{"position":[[0,8]]},"176":{"position":[[0,8]]},"178":{"position":[[0,8]]}}}],["uniforms",{"_index":71,"t":{"180":{"position":[[0,8]]}}}],["video",{"_index":80,"t":{"198":{"position":[[0,5]]}}}],["warp",{"_index":10,"t":{"82":{"position":[[5,4]]}}}],["web",{"_index":82,"t":{"202":{"position":[[0,3]]}}}]],"pipeline":["stemmer"]}},{"documents":[{"i":73,"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":"/examples","h":"","p":72},{"i":75,"t":"import * as PIXI from 'pixi.js'; // Based somewhat on this article by Spicy Yoghurt // URL for further reading: https://spicyyoghurt.com/tutorials/html5-javascript-game-development/collision-detection-physics const app = new PIXI.Application({ background: '#111', resizeTo: window }); document.body.appendChild(app.view); // Options for how objects interact // How fast the red square moves const movementSpeed = 0.05; // Strength of the impulse push between two objects const impulsePower = 5; // Test For Hit // A basic AABB check between two different squares function testForAABB(object1, object2) { const bounds1 = object1.getBounds(); const bounds2 = object2.getBounds(); return bounds1.x < bounds2.x + bounds2.width && bounds1.x + bounds1.width > bounds2.x && bounds1.y < bounds2.y + bounds2.height && bounds1.y + bounds1.height > bounds2.y; } // Calculates the results of a collision, allowing us to give an impulse that // shoves objects apart function collisionResponse(object1, object2) { if (!object1 || !object2) { return new PIXI.Point(0); } const vCollision = new PIXI.Point( object2.x - object1.x, object2.y - object1.y, ); const distance = Math.sqrt( (object2.x - object1.x) * (object2.x - object1.x) + (object2.y - object1.y) * (object2.y - object1.y), ); const vCollisionNorm = new PIXI.Point( vCollision.x / distance, vCollision.y / distance, ); const vRelativeVelocity = new PIXI.Point( object1.acceleration.x - object2.acceleration.x, object1.acceleration.y - object2.acceleration.y, ); const speed = vRelativeVelocity.x * vCollisionNorm.x + vRelativeVelocity.y * vCollisionNorm.y; const impulse = impulsePower * speed / (object1.mass + object2.mass); return new PIXI.Point( impulse * vCollisionNorm.x, impulse * vCollisionNorm.y, ); } // Calculate the distance between two given points function distanceBetweenTwoPoints(p1, p2) { const a = p1.x - p2.x; const b = p1.y - p2.y; return Math.hypot(a, b); } // The green square we will knock about const greenSquare = new PIXI.Sprite(PIXI.Texture.WHITE); greenSquare.position.set((app.screen.width - 100) / 2, (app.screen.height - 100) / 2); greenSquare.width = 100; greenSquare.height = 100; greenSquare.tint = 0x00FF00; greenSquare.acceleration = new PIXI.Point(0); greenSquare.mass = 3; // The square you move around const redSquare = new PIXI.Sprite(PIXI.Texture.WHITE); redSquare.position.set(0, 0); redSquare.width = 100; redSquare.height = 100; redSquare.tint = 0xFF0000; redSquare.acceleration = new PIXI.Point(0); redSquare.mass = 1; const mouseCoords = { x: 0, y: 0 }; app.stage.eventMode = 'static'; app.stage.hitArea = app.screen; app.stage.on('mousemove', (event) => { mouseCoords.x = event.global.x; mouseCoords.y = event.global.y; }); // Listen for animate update app.ticker.add((delta) => { // Applied deacceleration for both squares, done by reducing the // acceleration by 0.01% of the acceleration every loop redSquare.acceleration.set(redSquare.acceleration.x * 0.99, redSquare.acceleration.y * 0.99); greenSquare.acceleration.set(greenSquare.acceleration.x * 0.99, greenSquare.acceleration.y * 0.99); // Check whether the green square ever moves off the screen // If so, reverse acceleration in that direction if (greenSquare.x < 0 || greenSquare.x > (app.screen.width - 100)) { greenSquare.acceleration.x = -greenSquare.acceleration.x; } if (greenSquare.y < 0 || greenSquare.y > (app.screen.height - 100)) { greenSquare.acceleration.y = -greenSquare.acceleration.y; } // If the green square pops out of the cordon, it pops back into the // middle if ((greenSquare.x < -30 || greenSquare.x > (app.screen.width + 30)) || greenSquare.y < -30 || greenSquare.y > (app.screen.height + 30)) { greenSquare.position.set((app.screen.width - 100) / 2, (app.screen.height - 100) / 2); } // If the mouse is off screen, then don't update any further if (app.screen.width > mouseCoords.x || mouseCoords.x > 0 || app.screen.height > mouseCoords.y || mouseCoords.y > 0) { // Get the red square's center point const redSquareCenterPosition = new PIXI.Point( redSquare.x + (redSquare.width * 0.5), redSquare.y + (redSquare.height * 0.5), ); // Calculate the direction vector between the mouse pointer and // the red square const toMouseDirection = new PIXI.Point( mouseCoords.x - redSquareCenterPosition.x, mouseCoords.y - redSquareCenterPosition.y, ); // Use the above to figure out the angle that direction has const angleToMouse = Math.atan2( toMouseDirection.y, toMouseDirection.x, ); // Figure out the speed the square should be travelling by, as a // function of how far away from the mouse pointer the red square is const distMouseRedSquare = distanceBetweenTwoPoints( mouseCoords, redSquareCenterPosition, ); const redSpeed = distMouseRedSquare * movementSpeed; // Calculate the acceleration of the red square redSquare.acceleration.set( Math.cos(angleToMouse) * redSpeed, Math.sin(angleToMouse) * redSpeed, ); } // If the two squares are colliding if (testForAABB(greenSquare, redSquare)) { // Calculate the changes in acceleration that should be made between // each square as a result of the collision const collisionPush = collisionResponse(greenSquare, redSquare); // Set the changes in acceleration for both squares redSquare.acceleration.set( (collisionPush.x * greenSquare.mass), (collisionPush.y * greenSquare.mass), ); greenSquare.acceleration.set( -(collisionPush.x * redSquare.mass), -(collisionPush.y * redSquare.mass), ); } greenSquare.x += greenSquare.acceleration.x * delta; greenSquare.y += greenSquare.acceleration.y * delta; redSquare.x += redSquare.acceleration.x * delta; redSquare.y += redSquare.acceleration.y * delta; }); // Add to stage app.stage.addChild(redSquare, greenSquare);","s":"Collision Detection","u":"/examples/advanced/collision-detection","h":"","p":74},{"i":77,"t":"import * as PIXI from 'pixi.js'; const app = new PIXI.Application({ resizeTo: window }); document.body.appendChild(app.view); // prepare circle texture, that will be our brush const brush = new PIXI.Graphics() .beginFill(0xffffff) .drawCircle(0, 0, 50); // Create a line that will interpolate the drawn points const line = new PIXI.Graphics(); PIXI.Assets.add('t1', 'https://pixijs.com/assets/bg_grass.jpg'); PIXI.Assets.add('t2', 'https://pixijs.com/assets/bg_rotate.jpg'); PIXI.Assets.load(['t1', 't2']).then(setup); function setup() { const { width, height } = app.screen; const stageSize = { width, height }; const background = Object.assign(PIXI.Sprite.from('t1'), stageSize); const imageToReveal = Object.assign(PIXI.Sprite.from('t2'), stageSize); const renderTexture = PIXI.RenderTexture.create(stageSize); const renderTextureSprite = new PIXI.Sprite(renderTexture); imageToReveal.mask = renderTextureSprite; app.stage.addChild( background, imageToReveal, renderTextureSprite, ); app.stage.eventMode = 'static'; app.stage.hitArea = app.screen; app.stage .on('pointerdown', pointerDown) .on('pointerup', pointerUp) .on('pointerupoutside', pointerUp) .on('pointermove', pointerMove); let dragging = false; let lastDrawnPoint = null; function pointerMove({ global: { x, y } }) { if (dragging) { brush.position.set(x, y); app.renderer.render(brush, { renderTexture, clear: false, skipUpdateTransform: false, }); // Smooth out the drawing a little bit to make it look nicer // this connects the previous drawn point to the current one // using a line if (lastDrawnPoint) { line .clear() .lineStyle({ width: 100, color: 0xffffff }) .moveTo(lastDrawnPoint.x, lastDrawnPoint.y) .lineTo(x, y); app.renderer.render(line, { renderTexture, clear: false, skipUpdateTransform: false, }); } lastDrawnPoint = lastDrawnPoint || new PIXI.Point(); lastDrawnPoint.set(x, y); } } function pointerDown(event) { dragging = true; pointerMove(event); } function pointerUp(event) { dragging = false; lastDrawnPoint = null; } }","s":"Scratch Card","u":"/examples/advanced/scratch-card","h":"","p":76},{"i":79,"t":"import * as PIXI from 'pixi.js'; const app = new PIXI.Application({ backgroundColor: '#111', resizeTo: window }); document.body.appendChild(app.view); const texture = PIXI.Texture.from('https://pixijs.com/assets/bunny.png'); const bunnyContainer = new PIXI.Container(); async function takeScreenshot() { app.stop(); const url = await app.renderer.extract.base64(bunnyContainer); const a = document.createElement('a'); document.body.append(a); a.download = 'screenshot'; a.href = url; a.click(); a.remove(); app.start(); } app.stage.eventMode = 'static'; app.stage.hitArea = app.screen; app.stage.on('pointerdown', takeScreenshot); for (let i = 0; i < 25; i++) { const bunny = new PIXI.Sprite(texture); bunny.anchor.set(0.5); bunny.x = (i % 5) * 40; bunny.y = Math.floor(i / 5) * 40; bunnyContainer.addChild(bunny); } bunnyContainer.x = 400; bunnyContainer.y = 300; bunnyContainer.pivot.x = bunnyContainer.width / 2; bunnyContainer.pivot.y = bunnyContainer.height / 2; app.ticker.add((delta) => { bunnyContainer.rotation += 0.01 * delta; }); const style = new PIXI.TextStyle({ fontFamily: 'Roboto', fill: '#999', }); const screenshotText = new PIXI.Text('Click To Take Screenshot', style); screenshotText.x = Math.round((app.screen.width - screenshotText.width) / 2); screenshotText.y = Math.round(screenshotText.height / 2); app.stage.addChild(screenshotText, bunnyContainer);","s":"Screen Shot","u":"/examples/advanced/screen-shot","h":"","p":78},{"i":81,"t":"import * as PIXI from 'pixi.js'; const app = new PIXI.Application({ background: '#1099bb', resizeTo: window }); document.body.appendChild(app.view); // Get the texture for rope. const trailTexture = PIXI.Texture.from('https://pixijs.com/assets/trail.png'); const historyX = []; const historyY = []; // historySize determines how long the trail will be. const historySize = 20; // ropeSize determines how smooth the trail will be. const ropeSize = 100; const points = []; // Create history array. for (let i = 0; i < historySize; i++) { historyX.push(0); historyY.push(0); } // Create rope points. for (let i = 0; i < ropeSize; i++) { points.push(new PIXI.Point(0, 0)); } // Create the rope const rope = new PIXI.SimpleRope(trailTexture, points); // Set the blendmode rope.blendmode = PIXI.BLEND_MODES.ADD; app.stage.addChild(rope); let mouseposition = null; app.stage.eventMode = 'static'; app.stage.hitArea = app.screen; app.stage.on('mousemove', (event) => { mouseposition = mouseposition || { x: 0, y: 0 }; mouseposition.x = event.global.x; mouseposition.y = event.global.y; }); // Listen for animate update app.ticker.add(() => { if (!mouseposition) return; // Update the mouse values to history historyX.pop(); historyX.unshift(mouseposition.x); historyY.pop(); historyY.unshift(mouseposition.y); // Update the points to correspond with history. for (let i = 0; i < ropeSize; i++) { const p = points[i]; // Smooth the curve with cubic interpolation to prevent sharp edges. const ix = cubicInterpolation(historyX, i / ropeSize * historySize); const iy = cubicInterpolation(historyY, i / ropeSize * historySize); p.x = ix; p.y = iy; } }); /** * Cubic interpolation based on https://github.com/osuushi/Smooth.js */ function clipInput(k, arr) { if (k < 0) k = 0; if (k > arr.length - 1) k = arr.length - 1; return arr[k]; } function getTangent(k, factor, array) { return factor * (clipInput(k + 1, array) - clipInput(k - 1, array)) / 2; } function cubicInterpolation(array, t, tangentFactor) { if (tangentFactor === null) tangentFactor = 1; const k = Math.floor(t); const m = [getTangent(k, tangentFactor, array), getTangent(k + 1, tangentFactor, array)]; const p = [clipInput(k, array), clipInput(k + 1, array)]; t -= k; const t2 = t * t; const t3 = t * t2; return (2 * t3 - 3 * t2 + 1) * p[0] + (t3 - 2 * t2 + t) * m[0] + (-2 * t3 + 3 * t2) * p[1] + (t3 - t2) * m[1]; }","s":"Mouse Trail","u":"/examples/advanced/mouse-trail","h":"","p":80},{"i":83,"t":"import * as PIXI from 'pixi.js'; const app = new PIXI.Application({ resizeTo: window }); document.body.appendChild(app.view); // Get the texture for star. const starTexture = PIXI.Texture.from('https://pixijs.com/assets/star.png'); const starAmount = 1000; let cameraZ = 0; const fov = 20; const baseSpeed = 0.025; let speed = 0; let warpSpeed = 0; const starStretch = 5; const starBaseSize = 0.05; // Create the stars const stars = []; for (let i = 0; i < starAmount; i++) { const star = { sprite: new PIXI.Sprite(starTexture), z: 0, x: 0, y: 0, }; star.sprite.anchor.x = 0.5; star.sprite.anchor.y = 0.7; randomizeStar(star, true); app.stage.addChild(star.sprite); stars.push(star); } function randomizeStar(star, initial) { star.z = initial ? Math.random() * 2000 : cameraZ + Math.random() * 1000 + 2000; // Calculate star positions with radial random coordinate so no star hits the camera. const deg = Math.random() * Math.PI * 2; const distance = Math.random() * 50 + 1; star.x = Math.cos(deg) * distance; star.y = Math.sin(deg) * distance; } // Change flight speed every 5 seconds setInterval(() => { warpSpeed = warpSpeed > 0 ? 0 : 1; }, 5000); // Listen for animate update app.ticker.add((delta) => { // Simple easing. This should be changed to proper easing function when used for real. speed += (warpSpeed - speed) / 20; cameraZ += delta * 10 * (speed + baseSpeed); for (let i = 0; i < starAmount; i++) { const star = stars[i]; if (star.z < cameraZ) randomizeStar(star); // Map star 3d position to 2d with really simple projection const z = star.z - cameraZ; star.sprite.x = star.x * (fov / z) * app.renderer.screen.width + app.renderer.screen.width / 2; star.sprite.y = star.y * (fov / z) * app.renderer.screen.width + app.renderer.screen.height / 2; // Calculate star scale & rotation. const dxCenter = star.sprite.x - app.renderer.screen.width / 2; const dyCenter = star.sprite.y - app.renderer.screen.height / 2; const distanceCenter = Math.sqrt(dxCenter * dxCenter + dyCenter * dyCenter); const distanceScale = Math.max(0, (2000 - z) / 2000); star.sprite.scale.x = distanceScale * starBaseSize; // Star is looking towards center so that y axis is towards center. // Scale the star depending on how fast we are moving, what the stretchfactor is // and depending on how far away it is from the center. star.sprite.scale.y = distanceScale * starBaseSize + distanceScale * speed * starStretch * distanceCenter / app.renderer.screen.width; star.sprite.rotation = Math.atan2(dyCenter, dxCenter) + Math.PI / 2; } });","s":"Star Warp","u":"/examples/advanced/star-warp","h":"","p":82},{"i":85,"t":"import * as PIXI from 'pixi.js'; const app = new PIXI.Application({ background: '#1099bb', resizeTo: window }); document.body.appendChild(app.view); PIXI.Assets.load([ 'https://pixijs.com/assets/eggHead.png', 'https://pixijs.com/assets/flowerTop.png', 'https://pixijs.com/assets/helmlok.png', 'https://pixijs.com/assets/skully.png', ]).then(onAssetsLoaded); const REEL_WIDTH = 160; const SYMBOL_SIZE = 150; // onAssetsLoaded handler builds the example. function onAssetsLoaded() { // Create different slot symbols. const slotTextures = [ PIXI.Texture.from('https://pixijs.com/assets/eggHead.png'), PIXI.Texture.from('https://pixijs.com/assets/flowerTop.png'), PIXI.Texture.from('https://pixijs.com/assets/helmlok.png'), PIXI.Texture.from('https://pixijs.com/assets/skully.png'), ]; // Build the reels const reels = []; const reelContainer = new PIXI.Container(); for (let i = 0; i < 5; i++) { const rc = new PIXI.Container(); rc.x = i * REEL_WIDTH; reelContainer.addChild(rc); const reel = { container: rc, symbols: [], position: 0, previousPosition: 0, blur: new PIXI.filters.BlurFilter(), }; reel.blur.blurX = 0; reel.blur.blurY = 0; rc.filters = [reel.blur]; // Build the symbols for (let j = 0; j < 4; j++) { const symbol = new PIXI.Sprite(slotTextures[Math.floor(Math.random() * slotTextures.length)]); // Scale the symbol to fit symbol area. symbol.y = j * SYMBOL_SIZE; symbol.scale.x = symbol.scale.y = Math.min(SYMBOL_SIZE / symbol.width, SYMBOL_SIZE / symbol.height); symbol.x = Math.round((SYMBOL_SIZE - symbol.width) / 2); reel.symbols.push(symbol); rc.addChild(symbol); } reels.push(reel); } app.stage.addChild(reelContainer); // Build top & bottom covers and position reelContainer const margin = (app.screen.height - SYMBOL_SIZE * 3) / 2; reelContainer.y = margin; reelContainer.x = Math.round(app.screen.width - REEL_WIDTH * 5); const top = new PIXI.Graphics(); top.beginFill(0, 1); top.drawRect(0, 0, app.screen.width, margin); const bottom = new PIXI.Graphics(); bottom.beginFill(0, 1); bottom.drawRect(0, SYMBOL_SIZE * 3 + margin, app.screen.width, margin); // Add play text const style = new PIXI.TextStyle({ fontFamily: 'Arial', fontSize: 36, fontStyle: 'italic', fontWeight: 'bold', fill: ['#ffffff', '#00ff99'], // gradient stroke: '#4a1850', strokeThickness: 5, dropShadow: true, dropShadowColor: '#000000', dropShadowBlur: 4, dropShadowAngle: Math.PI / 6, dropShadowDistance: 6, wordWrap: true, wordWrapWidth: 440, }); const playText = new PIXI.Text('Spin the wheels!', style); playText.x = Math.round((bottom.width - playText.width) / 2); playText.y = app.screen.height - margin + Math.round((margin - playText.height) / 2); bottom.addChild(playText); // Add header text const headerText = new PIXI.Text('PIXI MONSTER SLOTS!', style); headerText.x = Math.round((top.width - headerText.width) / 2); headerText.y = Math.round((margin - headerText.height) / 2); top.addChild(headerText); app.stage.addChild(top); app.stage.addChild(bottom); // Set the interactivity. bottom.eventMode = 'static'; bottom.cursor = 'pointer'; bottom.addListener('pointerdown', () => { startPlay(); }); let running = false; // Function to start playing. function startPlay() { if (running) return; running = true; for (let i = 0; i < reels.length; i++) { const r = reels[i]; const extra = Math.floor(Math.random() * 3); const target = r.position + 10 + i * 5 + extra; const time = 2500 + i * 600 + extra * 600; tweenTo(r, 'position', target, time, backout(0.5), null, i === reels.length - 1 ? reelsComplete : null); } } // Reels done handler. function reelsComplete() { running = false; } // Listen for animate update. app.ticker.add((delta) => { // Update the slots. for (let i = 0; i < reels.length; i++) { const r = reels[i]; // Update blur filter y amount based on speed. // This would be better if calculated with time in mind also. Now blur depends on frame rate. r.blur.blurY = (r.position - r.previousPosition) * 8; r.previousPosition = r.position; // Update symbol positions on reel. for (let j = 0; j < r.symbols.length; j++) { const s = r.symbols[j]; const prevy = s.y; s.y = ((r.position + j) % r.symbols.length) * SYMBOL_SIZE - SYMBOL_SIZE; if (s.y < 0 && prevy > SYMBOL_SIZE) { // Detect going over and swap a texture. // This should in proper product be determined from some logical reel. s.texture = slotTextures[Math.floor(Math.random() * slotTextures.length)]; s.scale.x = s.scale.y = Math.min(SYMBOL_SIZE / s.texture.width, SYMBOL_SIZE / s.texture.height); s.x = Math.round((SYMBOL_SIZE - s.width) / 2); } } } }); } // Very simple tweening utility function. This should be replaced with a proper tweening library in a real product. const tweening = []; function tweenTo(object, property, target, time, easing, onchange, oncomplete) { const tween = { object, property, propertyBeginValue: object[property], target, easing, time, change: onchange, complete: oncomplete, start: Date.now(), }; tweening.push(tween); return tween; } // Listen for animate update. app.ticker.add((delta) => { const now = Date.now(); const remove = []; for (let i = 0; i < tweening.length; i++) { const t = tweening[i]; const phase = Math.min(1, (now - t.start) / t.time); t.object[t.property] = lerp(t.propertyBeginValue, t.target, t.easing(phase)); if (t.change) t.change(t); if (phase === 1) { t.object[t.property] = t.target; if (t.complete) t.complete(t); remove.push(t); } } for (let i = 0; i < remove.length; i++) { tweening.splice(tweening.indexOf(remove[i]), 1); } }); // Basic lerp funtion. function lerp(a1, a2, t) { return a1 * (1 - t) + a2 * t; } // Backout function from tweenjs. // https://github.com/CreateJS/TweenJS/blob/master/src/tweenjs/Ease.js function backout(amount) { return (t) => (--t * t * ((amount + 1) * t + amount) + 1); }","s":"Slots","u":"/examples/advanced/slots","h":"","p":84},{"i":87,"t":"import * as PIXI from 'pixi.js'; const app = new PIXI.Application({ background: '#1099bb', resizeTo: window }); document.body.appendChild(app.view); async function init() { // manifest example const manifestExample = { bundles: [{ name: 'load-screen', assets: [ { name: 'flowerTop', srcs: 'https://pixijs.com/assets/flowerTop.png', }, ], }, { name: 'game-screen', assets: [ { name: 'eggHead', srcs: 'https://pixijs.com/assets/eggHead.png', }, ], }], }; await PIXI.Assets.init({ manifest: manifestExample }); // bundles can be loaded in the background too! PIXI.Assets.backgroundLoadBundle(['load-screen', 'game-screen']); makeLoadScreen(); } async function makeLoadScreen() { // get the assets from the load screen bundle. // If the bundle was already downloaded the promise resolves instantly! const loadScreenAssets = await PIXI.Assets.loadBundle('load-screen'); // create a new Sprite from the resolved loaded texture const goNext = new PIXI.Sprite(loadScreenAssets.flowerTop); goNext.anchor.set(0.5); goNext.x = app.screen.width / 2; goNext.y = app.screen.height / 2; app.stage.addChild(goNext); goNext.eventMode = 'static'; goNext.cursor = 'pointer'; goNext.on('pointertap', async () => { goNext.destroy(); makeGameScreen(); }); } async function makeGameScreen() { // Wait here until you get the assets // If the user spends enough time in the load screen by the time they reach the game screen // the assets are completely loaded and the promise resolves instantly! const loadScreenAssets = await PIXI.Assets.loadBundle('game-screen'); // create a new Sprite from the resolved loaded texture const goBack = new PIXI.Sprite(loadScreenAssets.eggHead); goBack.anchor.set(0.5); goBack.x = app.screen.width / 2; goBack.y = app.screen.height / 2; app.stage.addChild(goBack); goBack.eventMode = 'static'; goBack.cursor = 'pointer'; goBack.on('pointertap', async () => { goBack.destroy(); // The user can go back and the files are already downloaded makeLoadScreen(); }); } init();","s":"Bundle","u":"/examples/assets/bundle","h":"","p":86},{"i":89,"t":"import * as PIXI from 'pixi.js'; const app = new PIXI.Application({ background: '#1099bb', resizeTo: window }); document.body.appendChild(app.view); // Add the assets to load PIXI.Assets.add('flowerTop', 'https://pixijs.com/assets/flowerTop.png'); PIXI.Assets.add('eggHead', 'https://pixijs.com/assets/eggHead.png'); // Load the assets and get a resolved promise once both are loaded const texturesPromise = PIXI.Assets.load(['flowerTop', 'eggHead']); // => Promise<{flowerTop: Texture, eggHead: Texture}> // When the promise resolves, we have the texture! texturesPromise.then((textures) => { // create a new Sprite from the resolved loaded Textures const flower = PIXI.Sprite.from(textures.flowerTop); flower.anchor.set(0.5); flower.x = app.screen.width * 0.25; flower.y = app.screen.height / 2; app.stage.addChild(flower); const egg = PIXI.Sprite.from(textures.eggHead); egg.anchor.set(0.5); egg.x = app.screen.width * 0.75; egg.y = app.screen.height / 2; app.stage.addChild(egg); });","s":"Multiple","u":"/examples/assets/multiple","h":"","p":88},{"i":91,"t":"import * as PIXI from 'pixi.js'; const app = new PIXI.Application({ background: '#1099bb', resizeTo: window }); document.body.appendChild(app.view); // Start loading right away and create a promise const texturePromise = PIXI.Assets.load('https://pixijs.com/assets/bunny.png'); // When the promise resolves, we have the texture! texturePromise.then((resolvedTexture) => { // create a new Sprite from the resolved loaded Texture const bunny = PIXI.Sprite.from(resolvedTexture); // center the sprite's anchor point bunny.anchor.set(0.5); // move the sprite to the center of the screen bunny.x = app.screen.width / 2; bunny.y = app.screen.height / 2; app.stage.addChild(bunny); });","s":"Promise","u":"/examples/assets/promise","h":"","p":90},{"i":93,"t":"import * as PIXI from 'pixi.js'; const app = new PIXI.Application({ background: '#1099bb', resizeTo: window }); document.body.appendChild(app.view); // Add the assets to load PIXI.Assets.add('flowerTop', 'https://pixijs.com/assets/flowerTop.png'); PIXI.Assets.add('eggHead', 'https://pixijs.com/assets/eggHead.png'); // Allow the assets to load in the background PIXI.Assets.backgroundLoad(['flowerTop', 'eggHead']); // If the background load hasn't loaded this asset yet, calling load forces this asset to load now. PIXI.Assets.load('eggHead').then((texture) => { // auxiliar flag for toggling the texture let isEggHead = true; // create a new Sprite from the resolved loaded texture const character = new PIXI.Sprite(texture); character.anchor.set(0.5); character.x = app.screen.width / 2; character.y = app.screen.height / 2; character.eventMode = 'static'; character.cursor = 'pointer'; app.stage.addChild(character); character.on('pointertap', async () => { isEggHead = !isEggHead; // These promise are already resolved in the cache. character.texture = await PIXI.Assets.load(isEggHead ? 'eggHead' : 'flowerTop'); }); });","s":"Background","u":"/examples/assets/background","h":"","p":92},{"i":95,"t":"import * as PIXI from 'pixi.js'; const app = new PIXI.Application({ background: '#1099bb', resizeTo: window }); document.body.appendChild(app.view); /* --------------------------------------- Spinner 1. Square with radial completion. -------------------------------------- */ const generateSpinner1 = (position) => { const container = new PIXI.Container(); container.position = position; app.stage.addChild(container); const base = PIXI.Sprite.from('https://pixijs.com/assets/bg_scene_rotate.jpg'); const size = 100; base.width = size; base.height = size; const bottom = PIXI.Sprite.from('https://pixijs.com/assets/bg_rotate.jpg'); bottom.width = size; bottom.height = size; const mask = new PIXI.Graphics(); mask.position.set(size / 2, size / 2); base.mask = mask; window.mask = mask; container.addChild(bottom); container.addChild(base); container.addChild(mask); let phase = 0; return (delta) => { // Update phase phase += delta / 60; phase %= (Math.PI * 2); // Calculate target point. const x = Math.cos(phase - Math.PI / 2) * size; const y = Math.sin(phase - Math.PI / 2) * size; const segments = [ [-size / 2, -size / 2, size / 2, -size / 2], // top segment [size / 2, -size / 2, size / 2, size / 2], // right [-size / 2, size / 2, size / 2, size / 2], // bottom [-size / 2, -size / 2, -size / 2, size / 2], // left ]; // Find the intersecting segment. let intersection = null; let winding = 0; for (let i = 0; i < segments.length; i++) { const segment = segments[i]; const hit = intersect(0, 0, x, y, segment[0], segment[1], segment[2], segment[3]); if (hit) { intersection = hit; if (i === 0) winding = hit.x > 0 ? 0 : 4; else winding = i; break; } } const corners = [ size / 2, -size / 2, // Top right size / 2, size / 2, // Bottom right -size / 2, size / 2, // Bottom left -size / 2, -size / 2, // Top left, 0, -size / 2, // End point ]; // Redraw mask mask.clear(); mask.lineStyle(2, 0xff0000, 1); mask.beginFill(0xff0000, 1); mask.moveTo(0, -size / 2); mask.lineTo(0, 0); mask.lineTo(intersection.x, intersection.y); // fill the corners for (let i = winding; i < corners.length / 2; i++) { mask.lineTo(corners[i * 2], corners[i * 2 + 1]); } mask.endFill(); }; }; /* ----------------------- Spinner 2. Scaling balls. ---------------------- */ const generateSpinner2 = (position) => { const container = new PIXI.Container(); container.position = position; app.stage.addChild(container); const size = 100; const ballAmount = 7; const balls = []; for (let i = 0; i < ballAmount; i++) { const ball = PIXI.Sprite.from('https://pixijs.com/assets/circle.png'); ball.anchor.set(0.5); container.addChild(ball); ball.position.set( size / 2 + Math.cos(i / ballAmount * Math.PI * 2) * size / 3, size / 2 + Math.sin(i / ballAmount * Math.PI * 2) * size / 3, ); balls.push(ball); } let phase = 0; return (delta) => { // Update phase phase += delta / 60; phase %= (Math.PI * 2); // Update ball scales balls.forEach((b, i) => { const sin = Math.sin(i / ballAmount * Math.PI - phase); // Multiply sin with itself to get more steeper edge. b.scale.set(Math.abs(sin * sin * sin * 0.5) + 0.5); }); }; }; /* --------------------- Spinner 3. Radial mask. -------------------- */ const generateSpinner3 = (position) => { const container = new PIXI.Container(); container.position = position; app.stage.addChild(container); const base = PIXI.Sprite.from('https://pixijs.com/assets/bg_scene_rotate.jpg'); const size = 100; base.width = size; base.height = size; const mask = new PIXI.Graphics(); mask.position.set(size / 2, size / 2); base.mask = mask; window.mask = mask; container.addChild(base); container.addChild(mask); let phase = 0; return (delta) => { // Update phase phase += delta / 60; phase %= (Math.PI * 2); const angleStart = 0 - Math.PI / 2; const angle = phase + angleStart; const radius = 50; const x1 = Math.cos(angleStart) * radius; const y1 = Math.sin(angleStart) * radius; // Redraw mask mask.clear(); mask.lineStyle(2, 0xff0000, 1); mask.beginFill(0xff0000, 1); mask.moveTo(0, 0); mask.lineTo(x1, y1); mask.arc(0, 0, radius, angleStart, angle, false); mask.lineTo(0, 0); mask.endFill(); }; }; /* --------------------------------- Spinner 4. Rounded rectangle edges. ------------------------------- */ const generateSpinner4 = (position) => { const container = new PIXI.Container(); container.position = position; app.stage.addChild(container); const size = 100; const arcRadius = 15; const base = PIXI.Sprite.from('https://pixijs.com/assets/bg_scene_rotate.jpg'); base.width = size; base.height = size; // For better performance having assets prerounded would be better than masking. const roundingMask = new PIXI.Graphics(); roundingMask.beginFill(0, 1); roundingMask.lineStyle(1, 0xff0000, 1); roundingMask.drawRoundedRect(0, 0, size, size, arcRadius); roundingMask.endFill(); base.mask = roundingMask; // The edge could be replaced with image as well. const lineSize = 5; const edge = new PIXI.Graphics(); edge.lineStyle(lineSize, 0xff0000, 1); edge.drawRoundedRect(0, 0, size, size, arcRadius); edge.endFill(); // Mask in this example works basically the same way as in example 1. // Except it is reversed and calculates the mask in straight lines in edges. const mask = new PIXI.Graphics(); mask.position.set(size / 2, size / 2); edge.mask = mask; container.addChild(base); container.addChild(roundingMask); container.addChild(edge); container.addChild(mask); let phase = 0; return (delta) => { // Update phase phase += delta / 160; phase %= (Math.PI * 2); // Calculate target point. const x = Math.cos(phase - Math.PI / 2) * size; const y = Math.sin(phase - Math.PI / 2) * size; // Line segments const segments = [ [-size / 2 + lineSize, -size / 2 + lineSize, size / 2 - lineSize, -size / 2 + lineSize], // top segment [size / 2 - lineSize, -size / 2 + lineSize, size / 2 - lineSize, size / 2 - lineSize], // right [-size / 2 + lineSize, size / 2 - lineSize, size / 2 - lineSize, size / 2 - lineSize], // bottom [-size / 2 + lineSize, -size / 2 + lineSize, -size / 2 + lineSize, size / 2 - lineSize], // left ]; // To which dir should mask continue at each segment let outDir = [ [0, -1], [1, 0], [0, 1], [-1, 0], ]; // Find the intersecting segment. let intersection = null; let winding = 0; // What direction should the line continue after hit has been found before hitting the line size for (let i = 0; i < segments.length; i++) { const segment = segments[i]; const hit = intersect(0, 0, x, y, segment[0], segment[1], segment[2], segment[3]); if (hit) { intersection = hit; if (i === 0) winding = hit.x < 0 ? 0 : 4; else winding = 4 - i; outDir = outDir[i]; break; } } const corners = [ -size / 2 - lineSize, -size / 2 - lineSize, // Top left, -size / 2 - lineSize, size / 2 + lineSize, // Bottom left size / 2 + lineSize, size / 2 + lineSize, // Bottom right size / 2 + lineSize, -size / 2 - lineSize, // Top right ]; // Redraw mask mask.clear(); mask.lineStyle(2, 0x00ff00, 1); mask.beginFill(0xff0000, 1); mask.moveTo(0, 0); mask.moveTo(0, -size / 2 - lineSize); // fill the corners for (let i = 0; i < winding; i++) { mask.lineTo(corners[i * 2], corners[i * 2 + 1]); } mask.lineTo(intersection.x + outDir[0] * lineSize * 2, intersection.y + outDir[1] * lineSize * 2); mask.lineTo(intersection.x, intersection.y); mask.lineTo(0, 0); mask.endFill(); }; }; /* --------------------- Spinner 5. Rounded rectangle fixed length spinner by jonlepage -------------------- */ const generateSpinner5 = (position) => { const container = new PIXI.Container(); container.position = position; app.stage.addChild(container); const halfCircle = new PIXI.Graphics(); halfCircle.beginFill(0xff0000); halfCircle.lineStyle(2, 0xffffff); halfCircle.arc(0, 0, 100, 0, Math.PI); halfCircle.endFill(); halfCircle.position.set(50, 50); const rectangle = new PIXI.Graphics(); rectangle.lineStyle(2, 0xffffff, 1); rectangle.drawRoundedRect(0, 0, 100, 100, 16); rectangle.endFill(); rectangle.mask = halfCircle; container.addChild(rectangle); container.addChild(halfCircle); let phase = 0; return (delta) => { // Update phase phase += delta / 6; phase %= (Math.PI * 2); halfCircle.rotation = phase; }; }; const onTick = [ generateSpinner1(new PIXI.Point(50, 50)), generateSpinner2(new PIXI.Point(160, 50)), generateSpinner3(new PIXI.Point(270, 50)), generateSpinner4(new PIXI.Point(380, 50)), generateSpinner5(new PIXI.Point(490, 50)), ]; // Listen for animate update app.ticker.add((delta) => { // Call tick handling for each spinner. onTick.forEach((cb) => { cb(delta); }); }); /** * Helper functions line intercept math by Paul Bourke http://paulbourke.net/geometry/pointlineplane/ Determine the intersection point of two line segments Return FALSE if the lines don't intersect Code modified from original to match pixi examples linting rules. */ function intersect(x1, y1, x2, y2, x3, y3, x4, y4) { // Check if none of the lines are of length 0 if ((x1 === x2 && y1 === y2) || (x3 === x4 && y3 === y4)) { return false; } const denominator = ((y4 - y3) * (x2 - x1) - (x4 - x3) * (y2 - y1)); // Lines are parallel if (denominator === 0) { return false; } const ua = ((x4 - x3) * (y1 - y3) - (y4 - y3) * (x1 - x3)) / denominator; const ub = ((x2 - x1) * (y1 - y3) - (y2 - y1) * (x1 - x3)) / denominator; // is the intersection along the segments if (ua < 0 || ua > 1 || ub < 0 || ub > 1) { return false; } // Return a object with the x and y coordinates of the intersection const x = x1 + ua * (x2 - x1); const y = y1 + ua * (y2 - y1); return { x, y }; }","s":"Spinners","u":"/examples/advanced/spinners","h":"","p":94},{"i":97,"t":"import * as PIXI from 'pixi.js'; const app = new PIXI.Application({ resizeTo: window }); document.body.appendChild(app.view); // create a new background sprite const background = PIXI.Sprite.from('https://pixijs.com/assets/bg_rotate.jpg'); background.width = app.screen.width; background.height = app.screen.height; app.stage.addChild(background); // create an array to store a reference to the dudes const dudeArray = []; const totaldudes = 20; for (let i = 0; i < totaldudes; i++) { // create a new Sprite that uses the image name that we just generated as its source const dude = PIXI.Sprite.from('https://pixijs.com/assets/flowerTop.png'); dude.anchor.set(0.5); // set a random scale for the dude dude.scale.set(0.8 + Math.random() * 0.3); // finally let's set the dude to be at a random position... dude.x = Math.floor(Math.random() * app.screen.width); dude.y = Math.floor(Math.random() * app.screen.height); // The important bit of this example, this is how you change the default blend mode of the sprite dude.blendMode = PIXI.BLEND_MODES.ADD; // create some extra properties that will control movement dude.direction = Math.random() * Math.PI * 2; // this number will be used to modify the direction of the dude over time dude.turningSpeed = Math.random() - 0.8; // create a random speed for the dude between 0 - 2 dude.speed = 2 + Math.random() * 2; // finally we push the dude into the dudeArray so it it can be easily accessed later dudeArray.push(dude); app.stage.addChild(dude); } // create a bounding box for the little dudes const dudeBoundsPadding = 100; const dudeBounds = new PIXI.Rectangle( -dudeBoundsPadding, -dudeBoundsPadding, app.screen.width + dudeBoundsPadding * 2, app.screen.height + dudeBoundsPadding * 2, ); app.ticker.add(() => { // iterate through the dudes and update the positions for (let i = 0; i < dudeArray.length; i++) { const dude = dudeArray[i]; dude.direction += dude.turningSpeed * 0.01; dude.x += Math.sin(dude.direction) * dude.speed; dude.y += Math.cos(dude.direction) * dude.speed; dude.rotation = -dude.direction - Math.PI / 2; // wrap the dudes by testing their bounds... if (dude.x < dudeBounds.x) { dude.x += dudeBounds.width; } else if (dude.x > dudeBounds.x + dudeBounds.width) { dude.x -= dudeBounds.width; } if (dude.y < dudeBounds.y) { dude.y += dudeBounds.height; } else if (dude.y > dudeBounds.y + dudeBounds.height) { dude.y -= dudeBounds.height; } } });","s":"Blend Modes","u":"/examples/basic/blend-modes","h":"","p":96},{"i":99,"t":"import * as PIXI from 'pixi.js'; const app = new PIXI.Application({ background: '#1099bb', resizeTo: window }); document.body.appendChild(app.view); const container = new PIXI.Container(); app.stage.addChild(container); // Create a new texture const texture = PIXI.Texture.from('https://pixijs.com/assets/bunny.png'); // Create a 5x5 grid of bunnies for (let i = 0; i < 25; i++) { const bunny = new PIXI.Sprite(texture); bunny.anchor.set(0.5); bunny.x = (i % 5) * 40; bunny.y = Math.floor(i / 5) * 40; container.addChild(bunny); } // Move container to the center container.x = app.screen.width / 2; container.y = app.screen.height / 2; // Center bunny sprite in local container coordinates container.pivot.x = container.width / 2; container.pivot.y = container.height / 2; // Listen for animate update app.ticker.add((delta) => { // rotate the container! // use delta to create frame-independent transform container.rotation -= 0.01 * delta; });","s":"Container","u":"/examples/basic/container","h":"","p":98},{"i":101,"t":"import * as PIXI from 'pixi.js'; const app = new PIXI.Application({ background: '#1099bb', resizeTo: window }); document.body.appendChild(app.view); // await can only be used inside an async function async function init() { const texture = await PIXI.Assets.load('https://pixijs.com/assets/bunny.png'); // create a new Sprite from the awaited loaded Texture const bunny = PIXI.Sprite.from(texture); // center the sprite's anchor point bunny.anchor.set(0.5); // move the sprite to the center of the screen bunny.x = app.screen.width / 2; bunny.y = app.screen.height / 2; app.stage.addChild(bunny); } // Call that async function init();","s":"Async","u":"/examples/assets/async","h":"","p":100},{"i":103,"t":"import * as PIXI from 'pixi.js'; const app = new PIXI.Application({ background: '#1099bb', resizeTo: window }); document.body.appendChild(app.view); PIXI.Assets.load('https://pixijs.com/assets/bg_grass.jpg').then((texture) => { const plane = new PIXI.SimplePlane(texture, 10, 10); plane.x = 100; plane.y = 100; app.stage.addChild(plane); // Get the buffer for vertice positions. const buffer = plane.geometry.getBuffer('aVertexPosition'); // Listen for animate update let timer = 0; app.ticker.add(() => { // Randomize the vertice positions a bit to create movement. for (let i = 0; i < buffer.data.length; i++) { buffer.data[i] += Math.sin((timer / 10) + i) * 0.5; } buffer.update(); timer++; }); });","s":"Simple Plane","u":"/examples/basic/simple-plane","h":"","p":102},{"i":105,"t":"import * as PIXI from 'pixi.js'; const app = new PIXI.Application({ resizeTo: window }); document.body.appendChild(app.view); // holder to store the aliens const aliens = []; const totalDudes = 20; for (let i = 0; i < totalDudes; i++) { // create a new Sprite that uses the image name that we just generated as its source const dude = PIXI.Sprite.from('https://pixijs.com/assets/eggHead.png'); // set the anchor point so the texture is centered on the sprite dude.anchor.set(0.5); // set a random scale for the dude - no point them all being the same size! dude.scale.set(0.8 + Math.random() * 0.3); // finally lets set the dude to be at a random position.. dude.x = Math.random() * app.screen.width; dude.y = Math.random() * app.screen.height; dude.tint = Math.random() * 0xFFFFFF; // create some extra properties that will control movement : // create a random direction in radians. This is a number between 0 and PI*2 which is the equivalent of 0 - 360 degrees dude.direction = Math.random() * Math.PI * 2; // this number will be used to modify the direction of the dude over time dude.turningSpeed = Math.random() - 0.8; // create a random speed for the dude between 2 - 4 dude.speed = 2 + Math.random() * 2; // finally we push the dude into the aliens array so it it can be easily accessed later aliens.push(dude); app.stage.addChild(dude); } // create a bounding box for the little dudes const dudeBoundsPadding = 100; const dudeBounds = new PIXI.Rectangle(-dudeBoundsPadding, -dudeBoundsPadding, app.screen.width + dudeBoundsPadding * 2, app.screen.height + dudeBoundsPadding * 2); app.ticker.add(() => { // iterate through the dudes and update their position for (let i = 0; i < aliens.length; i++) { const dude = aliens[i]; dude.direction += dude.turningSpeed * 0.01; dude.x += Math.sin(dude.direction) * dude.speed; dude.y += Math.cos(dude.direction) * dude.speed; dude.rotation = -dude.direction - Math.PI / 2; // wrap the dudes by testing their bounds... if (dude.x < dudeBounds.x) { dude.x += dudeBounds.width; } else if (dude.x > dudeBounds.x + dudeBounds.width) { dude.x -= dudeBounds.width; } if (dude.y < dudeBounds.y) { dude.y += dudeBounds.height; } else if (dude.y > dudeBounds.y + dudeBounds.height) { dude.y -= dudeBounds.height; } } });","s":"Tinting","u":"/examples/basic/tinting","h":"","p":104},{"i":107,"t":"import * as PIXI from 'pixi.js'; const app = new PIXI.Application({ resizeTo: window }); document.body.appendChild(app.view); app.stop(); // load resources PIXI.Assets.load('https://pixijs.com/assets/spritesheet/monsters.json') .then(onAssetsLoaded); // holder to store aliens const aliens = []; const alienFrames = [ 'eggHead.png', 'flowerTop.png', 'helmlok.png', 'skully.png', ]; let count = 0; // create an empty container const alienContainer = new PIXI.Container(); alienContainer.x = 400; alienContainer.y = 300; // make the stage interactive app.stage.eventMode = 'static'; app.stage.addChild(alienContainer); function onAssetsLoaded() { // add a bunch of aliens with textures from image paths for (let i = 0; i < 100; i++) { const frameName = alienFrames[i % 4]; // create an alien using the frame name.. const alien = PIXI.Sprite.from(frameName); alien.tint = Math.random() * 0xFFFFFF; alien.x = Math.random() * 800 - 400; alien.y = Math.random() * 600 - 300; alien.anchor.x = 0.5; alien.anchor.y = 0.5; aliens.push(alien); alienContainer.addChild(alien); } app.start(); } // Combines both mouse click + touch tap app.stage.on('pointertap', onClick); function onClick() { alienContainer.cacheAsBitmap = !alienContainer.cacheAsBitmap; } app.ticker.add(() => { // let's rotate the aliens a little bit for (let i = 0; i < 100; i++) { const alien = aliens[i]; alien.rotation += 0.1; } count += 0.01; alienContainer.scale.x = Math.sin(count); alienContainer.scale.y = Math.sin(count); alienContainer.rotation += 0.01; });","s":"Cache As Bitmap","u":"/examples/basic/cache-as-bitmap","h":"","p":106},{"i":109,"t":"import * as PIXI from 'pixi.js'; const app = new PIXI.Application({ backgroundAlpha: 0, resizeTo: window }); document.body.appendChild(app.view); // create a new Sprite from an image path. const bunny = PIXI.Sprite.from('https://pixijs.com/assets/bunny.png'); // center the sprite's anchor point bunny.anchor.set(0.5); // move the sprite to the center of the screen bunny.x = app.screen.width / 2; bunny.y = app.screen.height / 2; app.stage.addChild(bunny); app.ticker.add(() => { // just for fun, let's rotate mr rabbit a little bunny.rotation += 0.1; });","s":"Transparent Background","u":"/examples/basic/transparent-background","h":"","p":108},{"i":111,"t":"import * as PIXI from 'pixi.js'; const app = new PIXI.Application({ background: '#1099bb', resizeTo: window }); document.body.appendChild(app.view); // Scale mode for all textures, will retain pixelation PIXI.settings.SCALE_MODE = PIXI.SCALE_MODES.NEAREST; const sprite = PIXI.Sprite.from('https://pixijs.com/assets/bunny.png'); // Set the initial position sprite.anchor.set(0.5); sprite.x = app.screen.width / 2; sprite.y = app.screen.height / 2; // Opt-in to interactivity sprite.eventMode = 'static'; // Shows hand cursor sprite.cursor = 'pointer'; // Pointers normalize touch and mouse (good for mobile and desktop) sprite.on('pointerdown', onClick); // Alternatively, use the mouse & touch events: // sprite.on('click', onClick); // mouse-only // sprite.on('tap', onClick); // touch-only app.stage.addChild(sprite); function onClick() { sprite.scale.x *= 1.25; sprite.scale.y *= 1.25; }","s":"Click","u":"/examples/events/click","h":"","p":110},{"i":113,"t":"import * as PIXI from 'pixi.js'; const app = new PIXI.Application({ resizeTo: window }); document.body.appendChild(app.view); const sprites = new PIXI.ParticleContainer(10000, { scale: true, position: true, rotation: true, uvs: true, alpha: true, }); app.stage.addChild(sprites); // create an array to store all the sprites const maggots = []; const totalSprites = app.renderer instanceof PIXI.Renderer ? 10000 : 100; for (let i = 0; i < totalSprites; i++) { // create a new Sprite const dude = PIXI.Sprite.from('https://pixijs.com/assets/maggot_tiny.png'); // set the anchor point so the texture is centerd on the sprite dude.anchor.set(0.5); // different maggots, different sizes dude.scale.set(0.8 + Math.random() * 0.3); // scatter them all dude.x = Math.random() * app.screen.width; dude.y = Math.random() * app.screen.height; dude.tint = Math.random() * 0x808080; // create a random direction in radians dude.direction = Math.random() * Math.PI * 2; // this number will be used to modify the direction of the sprite over time dude.turningSpeed = Math.random() - 0.8; // create a random speed between 0 - 2, and these maggots are slooww dude.speed = (2 + Math.random() * 2) * 0.2; dude.offset = Math.random() * 100; // finally we push the dude into the maggots array so it it can be easily accessed later maggots.push(dude); sprites.addChild(dude); } // create a bounding box box for the little maggots const dudeBoundsPadding = 100; const dudeBounds = new PIXI.Rectangle( -dudeBoundsPadding, -dudeBoundsPadding, app.screen.width + dudeBoundsPadding * 2, app.screen.height + dudeBoundsPadding * 2, ); let tick = 0; app.ticker.add(() => { // iterate through the sprites and update their position for (let i = 0; i < maggots.length; i++) { const dude = maggots[i]; dude.scale.y = 0.95 + Math.sin(tick + dude.offset) * 0.05; dude.direction += dude.turningSpeed * 0.01; dude.x += Math.sin(dude.direction) * (dude.speed * dude.scale.y); dude.y += Math.cos(dude.direction) * (dude.speed * dude.scale.y); dude.rotation = -dude.direction + Math.PI; // wrap the maggots if (dude.x < dudeBounds.x) { dude.x += dudeBounds.width; } else if (dude.x > dudeBounds.x + dudeBounds.width) { dude.x -= dudeBounds.width; } if (dude.y < dudeBounds.y) { dude.y += dudeBounds.height; } else if (dude.y > dudeBounds.y + dudeBounds.height) { dude.y -= dudeBounds.height; } } // increment the ticker tick += 0.1; });","s":"Particle Container","u":"/examples/basic/particle-container","h":"","p":112},{"i":115,"t":"import * as PIXI from 'pixi.js'; const app = new PIXI.Application({ background: '#1099bb', resizeTo: window }); document.body.appendChild(app.view); // Css style for icons const defaultIcon = 'url(\\'https://pixijs.com/assets/bunny.png\\'),auto'; const hoverIcon = 'url(\\'https://pixijs.com/assets/bunny_saturated.png\\'),auto'; // Add custom cursor styles app.renderer.events.cursorStyles.default = defaultIcon; app.renderer.events.cursorStyles.hover = hoverIcon; // create a background... const background = PIXI.Sprite.from('https://pixijs.com/assets/bg_button.jpg'); background.width = app.screen.width; background.height = app.screen.height; // add background to stage... app.stage.addChild(background); // create some textures from an image path const textureButton = PIXI.Texture.from('https://pixijs.com/assets/button.png'); const textureButtonDown = PIXI.Texture.from('https://pixijs.com/assets/button_down.png'); const textureButtonOver = PIXI.Texture.from('https://pixijs.com/assets/button_over.png'); const buttons = []; const buttonPositions = [ 175, 75, 655, 75, 410, 325, 150, 465, 685, 445, ]; for (let i = 0; i < 5; i++) { const button = new PIXI.Sprite(textureButton); button.cursor = 'hover'; button.anchor.set(0.5); button.x = buttonPositions[i * 2]; button.y = buttonPositions[i * 2 + 1]; // make the button interactive... button.eventMode = 'static'; button .on('pointerdown', onButtonDown) .on('pointerup', onButtonUp) .on('pointerupoutside', onButtonUp) .on('pointerover', onButtonOver) .on('pointerout', onButtonOut); // add it to the stage app.stage.addChild(button); // add button to array buttons.push(button); } // set some silly values... buttons[0].scale.set(1.2); buttons[2].rotation = Math.PI / 10; buttons[3].scale.set(0.8); buttons[4].scale.set(0.8, 1.2); buttons[4].rotation = Math.PI; function onButtonDown() { this.isdown = true; this.texture = textureButtonDown; this.alpha = 1; } function onButtonUp() { this.isdown = false; if (this.isOver) { this.texture = textureButtonOver; } else { this.texture = textureButton; } } function onButtonOver() { this.isOver = true; if (this.isdown) { return; } this.texture = textureButtonOver; } function onButtonOut() { this.isOver = false; if (this.isdown) { return; } this.texture = textureButton; }","s":"Custom Mouse Icon","u":"/examples/events/custom-mouse-icon","h":"","p":114},{"i":117,"t":"import * as PIXI from 'pixi.js'; const app = new PIXI.Application({ background: '#1099bb', resizeTo: window }); document.body.appendChild(app.view); // create a texture from an image path const texture = PIXI.Texture.from('https://pixijs.com/assets/bunny.png'); // Scale mode for pixelation texture.baseTexture.scaleMode = PIXI.SCALE_MODES.NEAREST; for (let i = 0; i < 10; i++) { createBunny( Math.floor(Math.random() * app.screen.width), Math.floor(Math.random() * app.screen.height), ); } function createBunny(x, y) { // create our little bunny friend.. const bunny = new PIXI.Sprite(texture); // enable the bunny to be interactive... this will allow it to respond to mouse and touch events bunny.eventMode = 'static'; // this button mode will mean the hand cursor appears when you roll over the bunny with your mouse bunny.cursor = 'pointer'; // center the bunny's anchor point bunny.anchor.set(0.5); // make it a bit bigger, so it's easier to grab bunny.scale.set(3); // setup events for mouse + touch using // the pointer events bunny.on('pointerdown', onDragStart, bunny); // move the sprite to its designated position bunny.x = x; bunny.y = y; // add it to the stage app.stage.addChild(bunny); } let dragTarget = null; app.stage.eventMode = 'static'; app.stage.hitArea = app.screen; app.stage.on('pointerup', onDragEnd); app.stage.on('pointerupoutside', onDragEnd); function onDragMove(event) { if (dragTarget) { dragTarget.parent.toLocal(event.global, null, dragTarget.position); } } function onDragStart() { // store a reference to the data // the reason for this is because of multitouch // we want to track the movement of this particular touch // this.data = event.data; this.alpha = 0.5; dragTarget = this; app.stage.on('pointermove', onDragMove); } function onDragEnd() { if (dragTarget) { app.stage.off('pointermove', onDragMove); dragTarget.alpha = 1; dragTarget = null; } }","s":"Dragging","u":"/examples/events/dragging","h":"","p":116},{"i":119,"t":"import * as PIXI from 'pixi.js'; // This example logs the order of events hover-related events in the scene. const app = new PIXI.Application({ antialias: true, background: '#1099bb', }); document.body.appendChild(app.view); const title = app.stage.addChild(new PIXI.Text( `Move your mouse slowly over the boxes to see the order of pointerenter, pointerleave, pointerover, pointerout events on each target!`, { fontSize: 16, }, )); title.x = 2; const logs = []; const logText = app.stage.addChild(new PIXI.Text('', { fontSize: 14, })); logText.y = 80; logText.x = 2; app.stage.name = 'stage'; // Mount outer black box const blackBox = app.stage.addChild(new PIXI.Graphics() .beginFill(0) .drawRect(0, 0, 400, 400) .endFill()); blackBox.name = 'black box'; blackBox.x = 400; // Mount white box inside the white one const whiteBox = blackBox.addChild(new PIXI.Graphics() .beginFill(0xffffff) .drawRect(100, 100, 200, 200) .endFill()); whiteBox.name = 'white box'; // Enable interactivity everywhere! app.stage.eventMode = 'static'; app.stage.hitArea = app.screen; whiteBox.eventMode = 'static'; blackBox.eventMode = 'static'; function onEvent(e) { const type = e.type; const targetName = e.target.name; const currentTargetName = e.currentTarget.name; // Add event to top of logs logs.push(`${currentTargetName} received ${type} event (target is ${targetName})`); if (currentTargetName === 'stage' || type === 'pointerenter' || type === 'pointerleave') { logs.push('-----------------------------------------', ''); } // Prevent logs from growing too long if (logs.length > 30) { while (logs.length > 30) { logs.shift(); } } // Update logText logText.text = logs.join('\\n'); } [app.stage, whiteBox, blackBox].forEach((object) => { object.addEventListener('pointerenter', onEvent); object.addEventListener('pointerleave', onEvent); object.addEventListener('pointerover', onEvent); object.addEventListener('pointerout', onEvent); });","s":"Logger","u":"/examples/events/logger","h":"","p":118},{"i":121,"t":"import * as PIXI from 'pixi.js'; const app = new PIXI.Application({ resizeTo: window }); document.body.appendChild(app.view); // create a background... const background = PIXI.Sprite.from('https://pixijs.com/assets/bg_button.jpg'); background.width = app.screen.width; background.height = app.screen.height; // add background to stage... app.stage.addChild(background); // create some textures from an image path const textureButton = PIXI.Texture.from('https://pixijs.com/assets/button.png'); const textureButtonDown = PIXI.Texture.from('https://pixijs.com/assets/button_down.png'); const textureButtonOver = PIXI.Texture.from('https://pixijs.com/assets/button_over.png'); const buttons = []; const buttonPositions = [ 175, 75, 655, 75, 410, 325, 150, 465, 685, 445, ]; for (let i = 0; i < 5; i++) { const button = new PIXI.Sprite(textureButton); button.anchor.set(0.5); button.x = buttonPositions[i * 2]; button.y = buttonPositions[i * 2 + 1]; // make the button interactive... button.eventMode = 'static'; button.cursor = 'pointer'; button // Mouse & touch events are normalized into // the pointer* events for handling different // button events. .on('pointerdown', onButtonDown) .on('pointerup', onButtonUp) .on('pointerupoutside', onButtonUp) .on('pointerover', onButtonOver) .on('pointerout', onButtonOut); // Use mouse-only events // .on('mousedown', onButtonDown) // .on('mouseup', onButtonUp) // .on('mouseupoutside', onButtonUp) // .on('mouseover', onButtonOver) // .on('mouseout', onButtonOut) // Use touch-only events // .on('touchstart', onButtonDown) // .on('touchend', onButtonUp) // .on('touchendoutside', onButtonUp) // add it to the stage app.stage.addChild(button); // add button to array buttons.push(button); } // set some silly values... buttons[0].scale.set(1.2); buttons[2].rotation = Math.PI / 10; buttons[3].scale.set(0.8); buttons[4].scale.set(0.8, 1.2); buttons[4].rotation = Math.PI; function onButtonDown() { this.isdown = true; this.texture = textureButtonDown; this.alpha = 1; } function onButtonUp() { this.isdown = false; if (this.isOver) { this.texture = textureButtonOver; } else { this.texture = textureButton; } } function onButtonOver() { this.isOver = true; if (this.isdown) { return; } this.texture = textureButtonOver; } function onButtonOut() { this.isOver = false; if (this.isdown) { return; } this.texture = textureButton; }","s":"Interactivity","u":"/examples/events/interactivity","h":"","p":120},{"i":123,"t":"import * as PIXI from 'pixi.js'; const app = new PIXI.Application(800, 600, { background: '#1099bb' }); document.body.appendChild(app.view); const yellowStar = PIXI.Texture.from('https://pixijs.com/assets/yellowstar.png'); // Standard Sprite Button const starButton1 = new PIXI.Sprite(yellowStar); starButton1.position.set(50, 200); starButton1.cursor = 'pointer'; starButton1.eventMode = 'static'; starButton1 .on('pointerdown', onClick, starButton1) .on('pointerover', onPointerOver, starButton1) .on('pointerout', onPointerOut, starButton1); // Custom Hitarea Button const starButton2 = new PIXI.Sprite(yellowStar); starButton2.position.set(250, 200); // Create a hitarea that matches the sprite, which will be used for point // intersection starButton2.hitArea = new PIXI.Polygon([ 80, 0, 100, 50, 160, 55, 115, 95, 130, 150, 80, 120, 30, 150, 45, 95, 0, 55, 60, 50, ]); starButton2.cursor = 'pointer'; starButton2.eventMode = 'static'; starButton2 .on('pointerdown', onClick, starButton2) .on('pointerover', onPointerOver, starButton2) .on('pointerout', onPointerOut, starButton2); // With Mask, No Hit Area const starButton3 = new PIXI.Sprite(yellowStar); starButton3.position.set(450, 200); starButton3.cursor = 'pointer'; starButton3.eventMode = 'static'; const squareMask = new PIXI.Graphics() .beginFill(0xFFFFFF) .drawRect(starButton3.x, starButton3.y, 75, 200) .endFill(); starButton3.mask = squareMask; starButton3 .on('pointerdown', onClick, starButton3) .on('pointerover', onPointerOver, starButton3) .on('pointerout', onPointerOut, starButton3); // With a Mask and Hit Area // Hitareas ignore masks. You can still click on a button made in this way, // even from areas covered by a mask const starButton4 = new PIXI.Sprite(yellowStar); starButton4.position.set(600, 200); const squareMask2 = new PIXI.Graphics() .beginFill(0xFFFFFF) .drawRect(starButton4.x, starButton4.y, 75, 200) .endFill(); starButton4.mask = squareMask2; // Again, hitarea for intersection checks starButton4.hitArea = new PIXI.Polygon([ 80, 0, 100, 50, 160, 55, 115, 95, 130, 150, 80, 120, 30, 150, 45, 95, 0, 55, 60, 50, ]); starButton4.cursor = 'pointer'; starButton4.eventMode = 'static'; starButton4 .on('pointerdown', onClick, starButton4) .on('pointerover', onPointerOver, starButton4) .on('pointerout', onPointerOut, starButton4); const style = new PIXI.TextStyle({ fill: '#ffffff' }); const text1 = new PIXI.Text('Standard', style); text1.x = starButton1.x + 25; text1.y = starButton1.y + 170; const text2 = new PIXI.Text('Hit Area', style); text2.x = starButton2.x + 35; text2.y = starButton2.y + 170; const text3 = new PIXI.Text('Mask', style); text3.x = starButton3.x + 10; text3.y = starButton3.y + 170; const text4 = new PIXI.Text('Mask + Hit Area', style); text4.x = starButton4.x - 10; text4.y = starButton4.y + 170; // Add to stage app.stage.addChild( starButton2, starButton1, starButton3, starButton4, squareMask, squareMask2, text1, text2, text3, text4, ); function onClick() { this.tint = 0x333333; } function onPointerOver() { this.tint = 0x666666; } function onPointerOut() { this.tint = 0xFFFFFF; }","s":"Custom Hitarea","u":"/examples/events/custom-hitarea","h":"","p":122},{"i":125,"t":"import * as PIXI from 'pixi.js'; // In this a example, a circle will follow the pointer wherever it // moves over the canvas. const app = new PIXI.Application({ antialias: true, background: '#1099bb', }); document.body.appendChild(app.view); // Create the circle const circle = app.stage.addChild(new PIXI.Graphics() .beginFill(0xffffff) .lineStyle({ color: 0x111111, alpha: 0.87, width: 1 }) .drawCircle(0, 0, 8) .endFill()); circle.position.set(app.screen.width / 2, app.screen.height / 2); // Enable interactivity! app.stage.eventMode = 'static'; // Make sure the whole canvas area is interactive, not just the circle. app.stage.hitArea = app.screen; // Follow the pointer app.stage.addEventListener('pointermove', (e) => { circle.position.copyFrom(e.global); });","s":"Pointer Tracker","u":"/examples/events/pointer-tracker","h":"","p":124},{"i":127,"t":"import * as PIXI from 'pixi.js'; const app = new PIXI.Application({ antialias: true, background: '#1099bb', }); document.body.appendChild(app.view); const stageHeight = app.screen.height; const stageWidth = app.screen.width; // Make sure stage covers the whole scene app.stage.hitArea = app.screen; // Make the slider const sliderWidth = 320; const slider = new PIXI.Graphics() .beginFill(0x272d37) .drawRect(0, 0, sliderWidth, 4); slider.x = (stageWidth - sliderWidth) / 2; slider.y = stageHeight * 0.75; // Draw the handle const handle = new PIXI.Graphics() .beginFill(0xffffff) .drawCircle(0, 0, 8); handle.y = slider.height / 2; handle.x = sliderWidth / 2; handle.eventMode = 'static'; handle.cursor = 'pointer'; handle .on('pointerdown', onDragStart) .on('pointerup', onDragEnd) .on('pointerupoutside', onDragEnd); app.stage.addChild(slider); slider.addChild(handle); // Add bunny whose scale can be changed by user using slider const bunny = app.stage.addChild(PIXI.Sprite.from('https://pixijs.com/assets/bunny.png')); bunny.texture.baseTexture.scaleMode = PIXI.SCALE_MODES.NEAREST; bunny.scale.set(3); bunny.anchor.set(0.5); bunny.x = stageWidth / 2; bunny.y = stageHeight / 2; // Add title const title = new PIXI.Text('Drag the handle to change the scale of bunny.', { fill: '#272d37', fontFamily: 'Roboto', fontSize: 20, align: 'center', }); title.roundPixels = true; title.x = stageWidth / 2; title.y = 40; title.anchor.set(0.5, 0); app.stage.addChild(title); // Listen to pointermove on stage once handle is pressed. function onDragStart() { app.stage.eventMode = 'static'; app.stage.addEventListener('pointermove', onDrag); } // Stop dragging feedback once the handle is released. function onDragEnd(e) { app.stage.eventMode = 'auto'; app.stage.removeEventListener('pointermove', onDrag); } // Update the handle's position & bunny's scale when the handle is moved. function onDrag(e) { const halfHandleWidth = handle.width / 2; // Set handle y-position to match pointer, clamped to (4, screen.height - 4). handle.x = Math.max(halfHandleWidth, Math.min( slider.toLocal(e.global).x, sliderWidth - halfHandleWidth, )); // Normalize handle position between -1 and 1. const t = 2 * ((handle.x / sliderWidth) - 0.5); bunny.scale.set(3 * (1.1 + t)); }","s":"Slider","u":"/examples/events/slider","h":"","p":126},{"i":129,"t":"import * as PIXI from 'pixi.js'; const app = new PIXI.Application({ resizeTo: window }); document.body.appendChild(app.view); // Create background image const background = PIXI.Sprite.from('https://pixijs.com/assets/bg_grass.jpg'); background.width = app.screen.width; background.height = app.screen.height; app.stage.addChild(background); // Stop application wait for load to finish app.stop(); fetch('https://pixijs.com/assets/pixi-filters/shader.frag') .then((res) => res.text()) .then(onLoaded); let filter; // Handle the load completed function onLoaded(data) { // Create the new filter, arguments: (vertexShader, framentSource) filter = new PIXI.Filter(null, data, { customUniform: 0.0, }); // === WARNING === // specify uniforms in filter constructor // or set them BEFORE first use // filter.uniforms.customUniform = 0.0 // Add the filter background.filters = [filter]; // Resume application update app.start(); } // Animate the filter app.ticker.add((delta) => { filter.uniforms.customUniform += 0.04 * delta; });","s":"Custom","u":"/examples/filters-advanced/custom","h":"","p":128},{"i":131,"t":"import * as PIXI from 'pixi.js'; /** * Please note that this is not the most optimal way of doing pure shader generated rendering and should be used when the * scene is wanted as input texture. Check the mesh version of example for more performant version if you need only shader * generated content. **/ const app = new PIXI.Application({ background: '#1099bb', resizeTo: window }); document.body.appendChild(app.view); PIXI.Assets.load('https://pixijs.com/assets/perlin.jpg').then(onAssetsLoaded); let filter = null; const text = new PIXI.Text('PixiJS', { fill: 0xFFFFFF, fontSize: 80 }); text.anchor.set(0.5, 0.5); text.position.set(app.renderer.screen.width / 2, app.renderer.screen.height / 2); app.stage.addChild(text); let totalTime = 0; // Fragment shader, in real use this would be much cleaner when loaded from a file // or embedded into the application as data resource. const fragment = `//Based on this: https://www.shadertoy.com/view/wtlSWX varying vec2 vTextureCoord; uniform sampler2D uSampler; uniform sampler2D noise; uniform float time; // Distance function. Just calculates the height (z) from x,y plane with really simple length check. // Its not exact as there could be shorter distances. vec2 dist(vec3 p) { float id = floor(p.x)+floor(p.y); id = mod(id, 2.); float h = texture2D(noise, vec2(p.x, p.y)*0.04).r*5.1; float h2 = texture2D(uSampler, vTextureCoord).r; return vec2(h+h2-p.z,id); } //Light calculation. vec3 calclight(vec3 p, vec3 rd) { vec2 eps = vec2( 0., 0.001); vec3 n = normalize( vec3( dist(p+eps.yxx).x - dist(p-eps.yxx).x, dist(p+eps.xyx).x - dist(p-eps.xyx).x, dist(p+eps.xxy).x - dist(p-eps.xxy).x )); vec3 d = vec3( max( 0., dot( -rd ,n))); return d; } void main() { vec2 uv = vec2(vTextureCoord.x, 1.-vTextureCoord.y); uv *=2.; uv-=1.; vec3 cam = vec3(0.,time -2., -3.); vec3 target = vec3(sin(time)*0.1, time+cos(time)+2., 0. ); float fov = 2.2; vec3 forward = normalize( target - cam); vec3 up = normalize(cross( forward, vec3(0., 1.,0.))); vec3 right = normalize( cross( up, forward)); vec3 raydir = normalize(vec3( uv.x *up + uv.y * right + fov*forward)); //Do the raymarch vec3 col = vec3(0.); float t = 0.; for( int i = 0; i < 100; i++) { vec3 p = t * raydir + cam; vec2 d = dist(p); t+=d.x*0.5;//Jump only half of the distance as height function used is not really the best for heightmaps. if(d.x < 0.001) { vec3 bc = d.y < 0.5 ? vec3(1.0, .8, 0.) : vec3(0.8,0.0, 1.0); col = vec3( 1.) * calclight(p, raydir) * (1. - t/150.) *bc; break; } if(t > 1000.) { break; } } gl_FragColor = vec4(col, 1.); } `; function onAssetsLoaded(perlin) { // Add perlin noise for filter, make sure it's wrapping and does not have mipmap. perlin.baseTexture.wrapMode = PIXI.WRAP_MODES.REPEAT; perlin.baseTexture.mipmap = false; // Build the filter filter = new PIXI.Filter(null, fragment, { time: 0.0, noise: perlin, }); app.stage.filterArea = app.renderer.screen; app.stage.filters = [filter]; // Listen for animate update. app.ticker.add((delta) => { filter.uniforms.time = totalTime; totalTime += delta / 60; }); }","s":"Shader Toy Filter Render Texture","u":"/examples/filters-advanced/shader-toy-filter-render-texture","h":"","p":130},{"i":133,"t":"import * as PIXI from 'pixi.js'; /** * https://github.com/pixijs/pixi.js/wiki/v5-Creating-Filters */ const app = new PIXI.Application({ resizeTo: window }); document.body.appendChild(app.view); // Create background image const background = PIXI.Sprite.from('https://pixijs.com/assets/bg_grass.jpg'); background.width = app.screen.width; background.height = app.screen.height; app.stage.addChild(background); // NOTE: this shader wont work on old devices where mediump precision is forced in fragment shader // because v5 default vertex shader uses `inputSize` in it. Same uniform in fragment and vertex shader // cant have different precision :( const shaderFrag = ` precision highp float; varying vec2 vTextureCoord; uniform vec2 mouse; uniform vec4 inputSize; uniform vec4 outputFrame; uniform float time; void main() { vec2 screenPos = vTextureCoord * inputSize.xy + outputFrame.xy; if (length(mouse - screenPos) < 25.0) { gl_FragColor = vec4(1.0, 1.0, 0.0, 1.0) * 0.7; //yellow circle, alpha=0.7 } else { // blend with underlying image, alpha=0.5 gl_FragColor = vec4( sin(time), (mouse.xy - outputFrame.xy) / outputFrame.zw, 1.0) * 0.5; } } `; const container = new PIXI.Container(); container.filterArea = new PIXI.Rectangle(100, 100, app.screen.width - 200, app.screen.height - 200); app.stage.addChild(container); const filter = new PIXI.Filter(null, shaderFrag, { mouse: new PIXI.Point(), }); container.filters = [filter]; app.stage.hitArea = app.screen; app.stage.eventMode = 'static'; app.stage.on('pointermove', (event) => { filter.uniforms.mouse.copyFrom(event.global); });","s":"Mouse Blending","u":"/examples/filters-advanced/mouse-blending","h":"","p":132},{"i":135,"t":"import * as PIXI from 'pixi.js'; const app = new PIXI.Application({ resizeTo: window }); document.body.appendChild(app.view); const bg = PIXI.Sprite.from('https://pixijs.com/assets/pixi-filters/bg_depth_blur.jpg'); bg.width = app.screen.width; bg.height = app.screen.height; app.stage.addChild(bg); const littleDudes = PIXI.Sprite.from('https://pixijs.com/assets/pixi-filters/depth_blur_dudes.jpg'); littleDudes.x = (app.screen.width / 2) - 315; littleDudes.y = 200; app.stage.addChild(littleDudes); const littleRobot = PIXI.Sprite.from('https://pixijs.com/assets/pixi-filters/depth_blur_moby.jpg'); littleRobot.x = (app.screen.width / 2) - 200; littleRobot.y = 100; app.stage.addChild(littleRobot); const blurFilter1 = new PIXI.filters.BlurFilter(); const blurFilter2 = new PIXI.filters.BlurFilter(); littleDudes.filters = [blurFilter1]; littleRobot.filters = [blurFilter2]; let count = 0; app.ticker.add(() => { count += 0.005; const blurAmount = Math.cos(count); const blurAmount2 = Math.sin(count); blurFilter1.blur = 20 * (blurAmount); blurFilter2.blur = 20 * (blurAmount2); });","s":"Blur","u":"/examples/filters-basic/blur","h":"","p":134},{"i":137,"t":"import * as PIXI from 'pixi.js'; const app = new PIXI.Application({ resizeTo: window }); document.body.appendChild(app.view); app.stage.eventMode = 'static'; const container = new PIXI.Container(); app.stage.addChild(container); const padding = 100; const bounds = new PIXI.Rectangle( -padding, -padding, app.screen.width + padding * 2, app.screen.height + padding * 2, ); const maggots = []; for (let i = 0; i < 20; i++) { const maggot = PIXI.Sprite.from('https://pixijs.com/assets/maggot.png'); maggot.anchor.set(0.5); container.addChild(maggot); maggot.direction = Math.random() * Math.PI * 2; maggot.speed = 1; maggot.turnSpeed = Math.random() - 0.8; maggot.x = Math.random() * bounds.width; maggot.y = Math.random() * bounds.height; maggot.scale.set(1 + Math.random() * 0.3); maggot.original = new PIXI.Point(); maggot.original.copyFrom(maggot.scale); maggots.push(maggot); } const displacementSprite = PIXI.Sprite.from('https://pixijs.com/assets/pixi-filters/displace.png'); const displacementFilter = new PIXI.filters.DisplacementFilter(displacementSprite); app.stage.addChild(displacementSprite); container.filters = [displacementFilter]; displacementFilter.scale.x = 110; displacementFilter.scale.y = 110; displacementSprite.anchor.set(0.5); const ring = PIXI.Sprite.from('https://pixijs.com/assets/pixi-filters/ring.png'); ring.anchor.set(0.5); ring.visible = false; app.stage.addChild(ring); const bg = PIXI.Sprite.from('https://pixijs.com/assets/bg_grass.jpg'); bg.width = app.screen.width; bg.height = app.screen.height; bg.alpha = 0.4; container.addChild(bg); app.stage .on('mousemove', onPointerMove) .on('touchmove', onPointerMove); function onPointerMove(eventData) { ring.visible = true; displacementSprite.position.set(eventData.data.global.x - 25, eventData.data.global.y); ring.position.copyFrom(displacementSprite.position); } let count = 0; app.ticker.add(() => { count += 0.05; for (let i = 0; i < maggots.length; i++) { const maggot = maggots[i]; maggot.direction += maggot.turnSpeed * 0.01; maggot.x += Math.sin(maggot.direction) * maggot.speed; maggot.y += Math.cos(maggot.direction) * maggot.speed; maggot.rotation = -maggot.direction - Math.PI / 2; maggot.scale.x = maggot.original.x + Math.sin(count) * 0.2; // wrap the maggots around as the crawl if (maggot.x < bounds.x) { maggot.x += bounds.width; } else if (maggot.x > bounds.x + bounds.width) { maggot.x -= bounds.width; } if (maggot.y < bounds.y) { maggot.y += bounds.height; } else if (maggot.y > bounds.y + bounds.height) { maggot.y -= bounds.height; } } });","s":"Displacement Map Crawlies","u":"/examples/filters-basic/displacement-map-crawlies","h":"","p":136},{"i":139,"t":"import * as PIXI from 'pixi.js'; import '@pixi/graphics-extras'; // This example shows how you can setup a nested boundary to propagate events // into a disjoint scene graph. Here, a camera is used to project an different // world onto the canvas. const app = new PIXI.Application({ antialias: true, background: '#1099bb', }); document.body.appendChild(app.view); // A projector renders it's content using projection. The transforms in // the contents scene graph don't change if you move the camera. To achieve // this, the content is not added as a \"child\" to the projector; however, this // means events won't propagate into the content by default. // // To solve this, we nest our own EventBoundary, and connect it using // addEventListener! class Projector extends PIXI.DisplayObject { constructor() { super(); // The content root to be rendered by this camera. this.content = new PIXI.Container(); // Temporary matrix to store the original projection transform. this.originalTransform = new PIXI.Matrix(); // The event boundary that'll map events downstream into the content // scene. this.boundary = new PIXI.EventBoundary(this.content); // Override copyMouseData to apply inverse worldTransform on // global coords this.boundary.copyMouseData = (from, to) => { // Apply default implementation first PIXI.EventBoundary.prototype.copyMouseData.call(this.boundary, from, to); // Then bring global coords into content's world this.worldTransform.applyInverse(to.global, to.global); // TODO: Remove after https://github.com/pixijs/pixi.js/pull/7381 // is merged! to.target = this.boundary.hitTest(to.global.x, to.global.y); }; // Propagate these events down into the content's scene graph! [ 'pointerdown', 'pointerup', 'pointermove', 'pointerover', 'pointerout', 'wheel', ].forEach((event) => { this.addEventListener(event, (e) => this.boundary.mapEvent(e)); }); this.eventMode = 'static'; } // Pass through cursor get cursor() { return this.boundary.cursor; } // eslint-disable-next-line class-methods-use-this set cursor(value) { throw new Error('The camera\\'s cursor is derived from its content!'); } // Pass through calculateBounds calculateBounds() { const contentBounds = this.content.getBounds(); this._bounds.addFrameMatrix( this.worldTransform, contentBounds.x, contentBounds.y, contentBounds.width, contentBounds.height, ); } // Pass through containsPoint containsPoint(point) { return !!this.boundary.hitTest(point.x, point.y); } // Render content with projection render(renderer) { renderer.batch.flush(); const projectionSystem = renderer.projection; const renderTextureSystem = renderer.renderTexture; projectionSystem.transform = projectionSystem.transform || new PIXI.Matrix(); projectionSystem.transform.copyTo(this.originalTransform); projectionSystem.transform.append(this.worldTransform); projectionSystem.update(null, null, 1, !renderTextureSystem.current); this.content.render(renderer); renderer.batch.flush(); projectionSystem.transform.copyFrom(this.originalTransform); projectionSystem.update(null, null, 1, !renderTextureSystem.current); } // updateTransform also updates content's transform updateTransform() { super.updateTransform(); this.content.enableTempParent(); this.content.updateTransform(); this.content.disableTempParent(null); } } // The projector const projector = app.stage.addChild(new Projector()); // Add coordinate axes! projector.content.addChild( new PIXI.Graphics() .lineStyle({ color: 0, alpha: 0.2, width: 2 }) .moveTo(0, -300) .lineTo(0, 600) .moveTo(-100, 0) .lineTo(700, 0), ); // Construct the star Graphics const stars = [1, 2, 3].map((i) => new PIXI.Graphics() .beginFill(0xffffff, 0.75) .drawStar(0, 0, 18 / i, 100 * i / 2)); // Place the stars stars[0].x = 0; stars[1].x = 200; stars[2].x = 500; // Add stars to the projector projector.content.addChild(...stars); // Make projection x+100, y+300 projector.x = 100; projector.y = 300; projector.content.hitArea = new PIXI.Rectangle(-100, -300, app.screen.width, app.screen.height); // Make hit-area cover the whole screen so we can capture // pointermove everywhere! projector.hitArea = projector.content.hitArea; projector.content.eventMode = 'static'; // Make stars interactive & add wheel handlers stars.forEach((star) => { // Make star interactive star.eventMode = 'static'; // Set initial cursor star.cursor = 'zoom-in'; // Add wheel rotation feedback star.addEventListener('wheel', (e) => { const scroll = Math.sign(e.deltaY) * Math.min(15, Math.abs(e.deltaY)); star.rotation += scroll / 100; }); // Add click zoom-in/zoom-out handler star.addEventListener('click', (e) => { if (star.scale.x === 1) { star.scale.set(1.33); star.cursor = 'zoom-out'; } else { star.scale.set(1); star.cursor = 'zoom-in'; } }); }); PIXI.BitmapFont.from('coordinates', { fontFamily: 'Roboto', fontSize: 16, fill: '#272d37', }, { chars: ['Global:() Screen-.,', ['0', '9']] }); const coordinates = new PIXI.BitmapText('Global: (0, 0)\\nScreen: (0, 0)', { fontName: 'coordinates', }); coordinates.x = 110; coordinates.y = 550; app.stage.addChild(coordinates); projector.content.addEventListener('pointermove', (e) => { const global = `(${e.global.x | 0}, ${e.global.y | 0})`; const screen = `(${e.screen.x | 0}, ${e.screen.y | 0})`; coordinates.text = `Global: ${global}\\nScreen: ${screen}`; }); const description = new PIXI.Text( 'The (0, 0) world coordinates for the content is located at the center of the first star!' + '\\n * Mouse wheel over stars to rotate them' + '\\n * Click to zoom in or out', { fontSize: 16, fontFamily: 'Roboto', fill: '#272d37', }, ); description.position.set(110, 12); app.stage.addChild(description);","s":"Nested Boundary With Projection","u":"/examples/events/nested-boundary-with-projection","h":"","p":138},{"i":141,"t":"import * as PIXI from 'pixi.js'; const app = new PIXI.Application({ resizeTo: window }); document.body.appendChild(app.view); app.stage.eventMode = 'static'; const bg = PIXI.Sprite.from('https://pixijs.com/assets/bg_rotate.jpg'); bg.anchor.set(0.5); bg.x = app.screen.width / 2; bg.y = app.screen.height / 2; const filter = new PIXI.filters.ColorMatrixFilter(); const container = new PIXI.Container(); container.x = app.screen.width / 2; container.y = app.screen.height / 2; const bgFront = PIXI.Sprite.from('https://pixijs.com/assets/bg_scene_rotate.jpg'); bgFront.anchor.set(0.5); container.addChild(bgFront); const light2 = PIXI.Sprite.from('https://pixijs.com/assets/light_rotate_2.png'); light2.anchor.set(0.5); container.addChild(light2); const light1 = PIXI.Sprite.from('https://pixijs.com/assets/light_rotate_1.png'); light1.anchor.set(0.5); container.addChild(light1); const panda = PIXI.Sprite.from('https://pixijs.com/assets/panda.png'); panda.anchor.set(0.5); container.addChild(panda); app.stage.addChild(container); app.stage.filters = [filter]; let count = 0; let enabled = true; app.stage.on('pointertap', () => { enabled = !enabled; app.stage.filters = enabled ? [filter] : null; }); const help = new PIXI.Text('Click or tap to turn filters on / off.', { fontFamily: 'Arial', fontSize: 12, fontWeight: 'bold', fill: 'white', }); help.y = app.screen.height - 25; help.x = 10; app.stage.addChild(help); app.ticker.add((delta) => { bg.rotation += 0.01; bgFront.rotation -= 0.01; light1.rotation += 0.02; light2.rotation += 0.01; panda.scale.x = 1 + Math.sin(count) * 0.04; panda.scale.y = 1 + Math.cos(count) * 0.04; count += 0.1; const { matrix } = filter; matrix[1] = Math.sin(count) * 3; matrix[2] = Math.cos(count); matrix[3] = Math.cos(count) * 1.5; matrix[4] = Math.sin(count / 3) * 2; matrix[5] = Math.sin(count / 2); matrix[6] = Math.sin(count / 4); });","s":"Color Matrix","u":"/examples/filters-basic/color-matrix","h":"","p":140},{"i":143,"t":"import * as PIXI from 'pixi.js'; const app = new PIXI.Application({ antialias: true, resizeTo: window }); document.body.appendChild(app.view); const sprite = PIXI.Sprite.from('https://pixijs.com/assets/bg_rotate.jpg'); // // BEZIER CURVE //// // information: https://en.wikipedia.org/wiki/BΓ©zier_curve const realPath = new PIXI.Graphics(); realPath.lineStyle(2, 0xFFFFFF, 1); realPath.moveTo(0, 0); realPath.lineTo(100, 200); realPath.lineTo(200, 200); realPath.lineTo(240, 100); realPath.position.x = 50; realPath.position.y = 50; app.stage.addChild(realPath); const bezier = new PIXI.Graphics(); bezier.lineStyle(5, 0xAA0000, 1); bezier.bezierCurveTo(100, 200, 200, 200, 240, 100); bezier.position.x = 50; bezier.position.y = 50; app.stage.addChild(bezier); // // BEZIER CURVE 2 //// const realPath2 = new PIXI.Graphics(); realPath2.lineStyle(2, 0xFFFFFF, 1); realPath2.moveTo(0, 0); realPath2.lineTo(0, -100); realPath2.lineTo(150, 150); realPath2.lineTo(240, 100); realPath2.position.x = 320; realPath2.position.y = 150; app.stage.addChild(realPath2); const bezier2 = new PIXI.Graphics(); bezier2.lineTextureStyle({ width: 10, texture: sprite.texture }); bezier2.bezierCurveTo(0, -100, 150, 150, 240, 100); bezier2.position.x = 320; bezier2.position.y = 150; app.stage.addChild(bezier2); // // ARC //// const arc = new PIXI.Graphics(); arc.lineStyle(5, 0xAA00BB, 1); arc.arc(600, 100, 50, Math.PI, 2 * Math.PI); app.stage.addChild(arc); // // ARC 2 //// const arc2 = new PIXI.Graphics(); arc2.lineStyle(6, 0x3333DD, 1); arc2.arc(650, 270, 60, 2 * Math.PI, 3 * Math.PI / 2); app.stage.addChild(arc2); // // ARC 3 //// const arc3 = new PIXI.Graphics(); arc3.lineTextureStyle({ width: 20, texture: sprite.texture }); arc3.arc(650, 420, 60, 2 * Math.PI, 2.5 * Math.PI / 2); app.stage.addChild(arc3); // / Hole //// const rectAndHole = new PIXI.Graphics(); rectAndHole.beginFill(0x00FF00); rectAndHole.drawRect(350, 350, 150, 150); rectAndHole.beginHole(); rectAndHole.drawCircle(375, 375, 25); rectAndHole.drawCircle(425, 425, 25); rectAndHole.drawCircle(475, 475, 25); rectAndHole.endHole(); rectAndHole.endFill(); app.stage.addChild(rectAndHole); // // Line Texture Style //// const beatifulRect = new PIXI.Graphics(); beatifulRect.lineTextureStyle({ width: 20, texture: sprite.texture }); beatifulRect.beginFill(0xFF0000); beatifulRect.drawRect(80, 350, 150, 150); beatifulRect.endFill(); app.stage.addChild(beatifulRect);","s":"Advanced","u":"/examples/graphics/advanced","h":"","p":142},{"i":145,"t":"import * as PIXI from 'pixi.js'; const app = new PIXI.Application({ antialias: true, resizeTo: window }); document.body.appendChild(app.view); app.stage.eventMode = 'static'; app.stage.hitArea = app.screen; const graphics = new PIXI.Graphics(); // set a fill and line style graphics.beginFill(0xFF3300); graphics.lineStyle(10, 0xffd900, 1); // draw a shape graphics.moveTo(50, 50); graphics.lineTo(250, 50); graphics.lineTo(100, 100); graphics.lineTo(250, 220); graphics.lineTo(50, 220); graphics.lineTo(50, 50); graphics.closePath(); graphics.endFill(); // set a fill and line style again graphics.lineStyle(10, 0xFF0000, 0.8); graphics.beginFill(0xFF700B, 1); // draw a second shape graphics.moveTo(210, 300); graphics.lineTo(450, 320); graphics.lineTo(570, 350); graphics.quadraticCurveTo(600, 0, 480, 100); graphics.lineTo(330, 120); graphics.lineTo(410, 200); graphics.lineTo(210, 300); graphics.closePath(); graphics.endFill(); // draw a rectangle graphics.lineStyle(2, 0x0000FF, 1); graphics.drawRect(50, 250, 100, 100); // draw a circle graphics.lineStyle(0); graphics.beginFill(0xFFFF0B, 0.5); graphics.drawCircle(470, 200, 100); graphics.endFill(); graphics.lineStyle(20, 0x33FF00); graphics.moveTo(30, 30); graphics.lineTo(600, 300); app.stage.addChild(graphics); // let's create a moving shape const thing = new PIXI.Graphics(); app.stage.addChild(thing); thing.x = 800 / 2; thing.y = 600 / 2; let count = 0; // Just click on the stage to draw random lines window.app = app; app.stage.on('pointerdown', () => { graphics.lineStyle(Math.random() * 30, Math.random() * 0xFFFFFF, 1); graphics.moveTo(Math.random() * 800, Math.random() * 600); graphics.bezierCurveTo( Math.random() * 800, Math.random() * 600, Math.random() * 800, Math.random() * 600, Math.random() * 800, Math.random() * 600, ); }); app.ticker.add(() => { count += 0.1; thing.clear(); thing.lineStyle(10, 0xff0000, 1); thing.beginFill(0xffFF00, 0.5); thing.moveTo(-120 + Math.sin(count) * 20, -100 + Math.cos(count) * 20); thing.lineTo(120 + Math.cos(count) * 20, -100 + Math.sin(count) * 20); thing.lineTo(120 + Math.sin(count) * 20, 100 + Math.cos(count) * 20); thing.lineTo(-120 + Math.cos(count) * 20, 100 + Math.sin(count) * 20); thing.lineTo(-120 + Math.sin(count) * 20, -100 + Math.cos(count) * 20); thing.closePath(); thing.rotation = count * 0.1; });","s":"Dynamic","u":"/examples/graphics/dynamic","h":"","p":144},{"i":147,"t":"import * as PIXI from 'pixi.js'; const app = new PIXI.Application({ resizeTo: window }); document.body.appendChild(app.view); app.stage.eventMode = 'static'; const container = new PIXI.Container(); app.stage.addChild(container); const flag = PIXI.Sprite.from('https://pixijs.com/assets/pixi-filters/flag.png'); container.addChild(flag); flag.x = 100; flag.y = 100; const displacementSprite = PIXI.Sprite.from('https://pixijs.com/assets/pixi-filters/displacement_map_repeat.jpg'); // Make sure the sprite is wrapping. displacementSprite.texture.baseTexture.wrapMode = PIXI.WRAP_MODES.REPEAT; const displacementFilter = new PIXI.filters.DisplacementFilter(displacementSprite); displacementFilter.padding = 10; displacementSprite.position = flag.position; app.stage.addChild(displacementSprite); flag.filters = [displacementFilter]; displacementFilter.scale.x = 30; displacementFilter.scale.y = 60; app.ticker.add(() => { // Offset the sprite position to make vFilterCoord update to larger value. // Repeat wrapping makes sure there's still pixels on the coordinates. displacementSprite.x++; // Reset x to 0 when it's over width to keep values from going to very huge numbers. if (displacementSprite.x > displacementSprite.width) { displacementSprite.x = 0; } });","s":"Displacement Map Flag","u":"/examples/filters-basic/displacement-map-flag","h":"","p":146},{"i":149,"t":"import * as PIXI from 'pixi.js'; const app = new PIXI.Application({ resizeTo: window }); document.body.appendChild(app.view); // Inner radius of the circle const radius = 100; // The blur amount const blurSize = 32; PIXI.Assets.load('https://pixijs.com/assets/bg_grass.jpg').then((grassTexture) => { const background = new PIXI.Sprite(grassTexture); app.stage.addChild(background); background.width = app.screen.width; background.height = app.screen.height; const circle = new PIXI.Graphics() .beginFill(0xFF0000) .drawCircle(radius + blurSize, radius + blurSize, radius) .endFill(); circle.filters = [new PIXI.filters.BlurFilter(blurSize)]; const bounds = new PIXI.Rectangle(0, 0, (radius + blurSize) * 2, (radius + blurSize) * 2); const texture = app.renderer.generateTexture(circle, PIXI.SCALE_MODES.NEAREST, 1, bounds); const focus = new PIXI.Sprite(texture); app.stage.addChild(focus); background.mask = focus; app.stage.eventMode = 'static'; app.stage.hitArea = app.screen; app.stage.on('pointermove', (event) => { focus.position.x = event.global.x - focus.width / 2; focus.position.y = event.global.y - focus.height / 2; }); });","s":"Filter","u":"/examples/masks/filter","h":"","p":148},{"i":151,"t":"import * as PIXI from 'pixi.js'; import '@pixi/graphics-extras'; const app = new PIXI.Application({ antialias: true, resizeTo: window }); document.body.appendChild(app.view); const graphics = new PIXI.Graphics(); // Rectangle graphics.beginFill(0xDE3249); graphics.drawRect(50, 50, 100, 100); graphics.endFill(); // Rectangle + line style 1 graphics.lineStyle(2, 0xFEEB77, 1); graphics.beginFill(0x650A5A); graphics.drawRect(200, 50, 100, 100); graphics.endFill(); // Rectangle + line style 2 graphics.lineStyle(10, 0xFFBD01, 1); graphics.beginFill(0xC34288); graphics.drawRect(350, 50, 100, 100); graphics.endFill(); // Rectangle 2 graphics.lineStyle(2, 0xFFFFFF, 1); graphics.beginFill(0xAA4F08); graphics.drawRect(530, 50, 140, 100); graphics.endFill(); // Circle graphics.lineStyle(0); // draw a circle, set the lineStyle to zero so the circle doesn't have an outline graphics.beginFill(0xDE3249, 1); graphics.drawCircle(100, 250, 50); graphics.endFill(); // Circle + line style 1 graphics.lineStyle(2, 0xFEEB77, 1); graphics.beginFill(0x650A5A, 1); graphics.drawCircle(250, 250, 50); graphics.endFill(); // Circle + line style 2 graphics.lineStyle(10, 0xFFBD01, 1); graphics.beginFill(0xC34288, 1); graphics.drawCircle(400, 250, 50); graphics.endFill(); // Ellipse + line style 2 graphics.lineStyle(2, 0xFFFFFF, 1); graphics.beginFill(0xAA4F08, 1); graphics.drawEllipse(600, 250, 80, 50); graphics.endFill(); // draw a shape graphics.beginFill(0xFF3300); graphics.lineStyle(4, 0xffd900, 1); graphics.moveTo(50, 350); graphics.lineTo(250, 350); graphics.lineTo(100, 400); graphics.lineTo(50, 350); graphics.closePath(); graphics.endFill(); // draw a rounded rectangle graphics.lineStyle(2, 0xFF00FF, 1); graphics.beginFill(0x650A5A, 0.25); graphics.drawRoundedRect(50, 440, 100, 100, 16); graphics.endFill(); // draw star graphics.lineStyle(2, 0xFFFFFF); graphics.beginFill(0x35CC5A, 1); graphics.drawStar(360, 370, 5, 50); graphics.endFill(); // draw star 2 graphics.lineStyle(2, 0xFFFFFF); graphics.beginFill(0xFFCC5A, 1); graphics.drawStar(280, 510, 7, 50); graphics.endFill(); // draw star 3 graphics.lineStyle(4, 0xFFFFFF); graphics.beginFill(0x55335A, 1); graphics.drawStar(470, 450, 4, 50); graphics.endFill(); // draw polygon const path = [600, 370, 700, 460, 780, 420, 730, 570, 590, 520]; graphics.lineStyle(0); graphics.beginFill(0x3500FA, 1); graphics.drawPolygon(path); graphics.endFill(); app.stage.addChild(graphics);","s":"Simple","u":"/examples/graphics/simple","h":"","p":150},{"i":153,"t":"import * as PIXI from 'pixi.js'; const app = new PIXI.Application({ antialias: true, resizeTo: window }); document.body.appendChild(app.view); app.stage.eventMode = 'static'; const bg = PIXI.Sprite.from('https://pixijs.com/assets/bg_rotate.jpg'); bg.anchor.set(0.5); bg.x = app.screen.width / 2; bg.y = app.screen.height / 2; app.stage.addChild(bg); const container = new PIXI.Container(); container.x = app.screen.width / 2; container.y = app.screen.height / 2; // add a bunch of sprites const bgFront = PIXI.Sprite.from('https://pixijs.com/assets/bg_scene_rotate.jpg'); bgFront.anchor.set(0.5); const light2 = PIXI.Sprite.from('https://pixijs.com/assets/light_rotate_2.png'); light2.anchor.set(0.5); const light1 = PIXI.Sprite.from('https://pixijs.com/assets/light_rotate_1.png'); light1.anchor.set(0.5); const panda = PIXI.Sprite.from('https://pixijs.com/assets/panda.png'); panda.anchor.set(0.5); container.addChild(bgFront, light2, light1, panda); app.stage.addChild(container); // let's create a moving shape const thing = new PIXI.Graphics(); app.stage.addChild(thing); thing.x = app.screen.width / 2; thing.y = app.screen.height / 2; thing.lineStyle(0); container.mask = thing; let count = 0; app.stage.on('pointertap', () => { if (!container.mask) { container.mask = thing; } else { container.mask = null; } }); const help = new PIXI.Text('Click or tap to turn masking on / off.', { fontFamily: 'Arial', fontSize: 12, fontWeight: 'bold', fill: 'white', }); help.y = app.screen.height - 26; help.x = 10; app.stage.addChild(help); app.ticker.add(() => { bg.rotation += 0.01; bgFront.rotation -= 0.01; light1.rotation += 0.02; light2.rotation += 0.01; panda.scale.x = 1 + Math.sin(count) * 0.04; panda.scale.y = 1 + Math.cos(count) * 0.04; count += 0.1; thing.clear(); thing.beginFill(0x8bc5ff, 0.4); thing.moveTo(-120 + Math.sin(count) * 20, -100 + Math.cos(count) * 20); thing.lineTo(120 + Math.cos(count) * 20, -100 + Math.sin(count) * 20); thing.lineTo(120 + Math.sin(count) * 20, 100 + Math.cos(count) * 20); thing.lineTo(-120 + Math.cos(count) * 20, 100 + Math.sin(count) * 20); thing.rotation = count * 0.1; });","s":"Graphics","u":"/examples/masks/graphics","h":"","p":152},{"i":155,"t":"import * as PIXI from 'pixi.js'; const app = new PIXI.Application({ resizeTo: window }); document.body.appendChild(app.view); app.stage.eventMode = 'static'; const bg = PIXI.Sprite.from('https://pixijs.com/assets/bg_plane.jpg'); app.stage.addChild(bg); const cells = PIXI.Sprite.from('https://pixijs.com/assets/cells.png'); cells.scale.set(1.5); const mask = PIXI.Sprite.from('https://pixijs.com/assets/flowerTop.png'); mask.anchor.set(0.5); mask.x = 310; mask.y = 190; cells.mask = mask; app.stage.addChild(mask, cells); const target = new PIXI.Point(); reset(); function reset() { target.x = Math.floor(Math.random() * 550); target.y = Math.floor(Math.random() * 300); } app.ticker.add(() => { mask.x += (target.x - mask.x) * 0.1; mask.y += (target.y - mask.y) * 0.1; if (Math.abs(mask.x - target.x) < 1) { reset(); } });","s":"Sprite","u":"/examples/masks/sprite","h":"","p":154},{"i":157,"t":"import * as PIXI from 'pixi.js'; const app = new PIXI.Application({ resizeTo: window }); document.body.appendChild(app.view); const geometry = new PIXI.Geometry() .addAttribute('aVertexPosition', // the attribute name [-100, -100, // x, y 100, -100, // x, y 100, 100, -100, 100], // x, y 2) // the size of the attribute .addAttribute('aUvs', // the attribute name [0, 0, // u, v 1, 0, // u, v 1, 1, 0, 1], // u, v 2) // the size of the attribute .addIndex([0, 1, 2, 0, 2, 3]) .interleave(); const shader = PIXI.Shader.from(` precision mediump float; attribute vec2 aVertexPosition; attribute vec2 aUvs; uniform mat3 translationMatrix; uniform mat3 projectionMatrix; varying vec2 vUvs; void main() { vUvs = aUvs; gl_Position = vec4((projectionMatrix * translationMatrix * vec3(aVertexPosition, 1.0)).xy, 0.0, 1.0); }`, `precision mediump float; varying vec2 vUvs; uniform sampler2D uSampler2; void main() { gl_FragColor = texture2D(uSampler2, vUvs ); } `, { uSampler2: PIXI.Texture.from('https://pixijs.com/assets/bg_scene_rotate.jpg'), }); const quad = new PIXI.Mesh(geometry, shader); quad.position.set(400, 300); quad.scale.set(2); app.stage.addChild(quad); app.ticker.add((delta) => { quad.rotation += 0.01; });","s":"Interleaving Geometry","u":"/examples/mesh-and-shaders/interleaving-geometry","h":"","p":156},{"i":159,"t":"import * as PIXI from 'pixi.js'; const app = new PIXI.Application({ resizeTo: window }); document.body.appendChild(app.view); const geometry = new PIXI.Geometry() .addAttribute('aVPos', [-100, 0, 100, 0, 0, -150]); geometry.instanced = true; geometry.instanceCount = 5; const positionSize = 2; const colorSize = 3; const buffer = new PIXI.Buffer(new Float32Array(geometry.instanceCount * (positionSize + colorSize))); geometry.addAttribute( 'aIPos', buffer, positionSize, false, PIXI.TYPES.FLOAT, 4 * (positionSize + colorSize), 0, true ); geometry.addAttribute( 'aICol', buffer, colorSize, false, PIXI.TYPES.FLOAT, 4 * (positionSize + colorSize), 4 * positionSize, true ); for (let i = 0; i < geometry.instanceCount; i++) { const instanceOffset = i * (positionSize + colorSize); buffer.data[instanceOffset + 0] = i * 80; buffer.data[instanceOffset + 2] = Math.random(); buffer.data[instanceOffset + 3] = Math.random(); buffer.data[instanceOffset + 4] = Math.random(); } const shader = PIXI.Shader.from(` precision mediump float; attribute vec2 aVPos; attribute vec2 aIPos; attribute vec3 aICol; uniform mat3 translationMatrix; uniform mat3 projectionMatrix; varying vec3 vCol; void main() { vCol = aICol; gl_Position = vec4((projectionMatrix * translationMatrix * vec3(aVPos + aIPos, 1.0)).xy, 0.0, 1.0); }`, `precision mediump float; varying vec3 vCol; void main() { gl_FragColor = vec4(vCol, 1.0); } `); const triangles = new PIXI.Mesh(geometry, shader); triangles.position.set(400, 300); app.stage.addChild(triangles); app.ticker.add((delta) => { triangles.rotation += 0.01; });","s":"Instanced Geometry","u":"/examples/mesh-and-shaders/instanced-geometry","h":"","p":158},{"i":161,"t":"import * as PIXI from 'pixi.js'; const app = new PIXI.Application({ resizeTo: window }); document.body.appendChild(app.view); const geometry = new PIXI.Geometry() .addAttribute('aVertexPosition', // the attribute name [-100, -100, // x, y 100, -100, // x, y 100, 100, -100, 100], // x, y 2) // the size of the attribute .addAttribute('aUvs', // the attribute name [0, 0, // u, v 1, 0, // u, v 1, 1, 0, 1], // u, v 2) // the size of the attribute .addIndex([0, 1, 2, 0, 2, 3]); const geometry2 = new PIXI.Geometry() .addAttribute('aVertexPosition', // the attribute name [-100 + 100, -100, // x, y 100 + 100, -100, // x, y 100 + 100, 100], // x, y 2) // the size of the attribute .addAttribute('aUvs', // the attribute name [0, 0, // u, v 1, 0, // u, v 1, 1], // u, v 2) // the size of the attribute .addIndex([0, 1, 2]); const geometry3 = PIXI.Geometry.merge([geometry, geometry2]); const shader = PIXI.Shader.from(` precision mediump float; attribute vec2 aVertexPosition; attribute vec2 aUvs; uniform mat3 translationMatrix; uniform mat3 projectionMatrix; varying vec2 vUvs; void main() { vUvs = aUvs; gl_Position = vec4((projectionMatrix * translationMatrix * vec3(aVertexPosition, 1.0)).xy, 0.0, 1.0); }`, `precision mediump float; varying vec2 vUvs; uniform sampler2D uSampler2; void main() { gl_FragColor = texture2D(uSampler2, vUvs ); } `, { uSampler2: PIXI.Texture.from('https://pixijs.com/assets/bg_scene_rotate.jpg'), }); const quad = new PIXI.Mesh(geometry3, shader); quad.position.set(400, 300); quad.scale.set(2); app.stage.addChild(quad); app.ticker.add((delta) => { quad.rotation += 0.01; });","s":"Merging Geometry","u":"/examples/mesh-and-shaders/merging-geometry","h":"","p":160},{"i":163,"t":"import * as PIXI from 'pixi.js'; const app = new PIXI.Application({ height: 640, resizeTo: window }); document.body.appendChild(app.view); // Build geometry. const geometry = new PIXI.Geometry() .addAttribute('aVertexPosition', // the attribute name [0, 0, // x, y 200, 0, // x, y 200, 200, 0, 200], // x, y 2) // the size of the attribute .addAttribute('aUvs', // the attribute name [0, 0, // u, v 1, 0, // u, v 1, 1, 0, 1], // u, v 2) // the size of the attribute .addIndex([0, 1, 2, 0, 2, 3]); // Vertex shader. Use same shader for all passes. const vertexSrc = ` precision mediump float; attribute vec2 aVertexPosition; attribute vec2 aUvs; uniform mat3 translationMatrix; uniform mat3 projectionMatrix; varying vec2 vUvs; void main() { vUvs = aUvs; gl_Position = vec4((projectionMatrix * translationMatrix * vec3(aVertexPosition, 1.0)).xy, 0.0, 1.0); }`; // Load a perlinnoise texture for one of the shaders. const perlinTexture = PIXI.Texture.from('https://pixijs.com/assets/perlin.jpg'); // First pass, generates a grid. const fragmentGridSrc = ` precision mediump float; varying vec2 vUvs; uniform float zoom; void main() { //Generate a simple grid. //Offset uv so that center is 0,0 and edges are -1,1 vec2 uv = (vUvs-vec2(0.5))*2.0; vec2 gUv = floor(uv*zoom); vec4 color1 = vec4(0.8, 0.8, 0.8, 1.0); vec4 color2 = vec4(0.4, 0.4, 0.4, 1.0); vec4 outColor = mod(gUv.x + gUv.y, 2.) < 0.5 ? color1 : color2; gl_FragColor = outColor; }`; const gridUniforms = { zoom: 10, }; const gridShader = PIXI.Shader.from(vertexSrc, fragmentGridSrc, gridUniforms); // Sharing textures and meshes is possible. // But for simplicity each pass has its own output texture and mesh in this example. const gridTexture = PIXI.RenderTexture.create({ width: 200, height: 200 }); const gridQuad = new PIXI.Mesh(geometry, gridShader); const gridContainer = new PIXI.Container(); gridContainer.addChild(gridQuad); // Second pass. Takes grid as input and makes it ripple. const fragmentRippleSrc = ` precision mediump float; varying vec2 vUvs; uniform float amount; uniform float phase; uniform sampler2D texIn; void main() { //Generate a simple grid. vec2 uv = vUvs; //Calculate distance from center float distance = length( uv - vec2(0.5)); vec4 color = texture2D(texIn, uv); color.rgb *= sin(distance*25.0+phase) * amount+1.; gl_FragColor = color; }`; const rippleUniforms = { amount: 0.5, phase: 0, texIn: gridTexture, }; const rippleShader = PIXI.Shader.from(vertexSrc, fragmentRippleSrc, rippleUniforms); const rippleTexture = PIXI.RenderTexture.create({ width: 200, height: 200 }); const rippleQuad = new PIXI.Mesh(geometry, rippleShader); const rippleContainer = new PIXI.Container(); rippleContainer.addChild(rippleQuad); // Second effect. Generates a filtered noise. const fragmentNoiseSrc = ` precision mediump float; varying vec2 vUvs; uniform float limit; uniform sampler2D noise; void main() { float color = texture2D(noise, vUvs).r; color = step(limit, color); gl_FragColor = vec4(color); }`; const noiseUniforms = { limit: 0.5, noise: perlinTexture, }; const noiseShader = PIXI.Shader.from(vertexSrc, fragmentNoiseSrc, noiseUniforms); const noiseTexture = PIXI.RenderTexture.create({ width: 200, height: 200 }); const noiseQuad = new PIXI.Mesh(geometry, noiseShader); const noiseContainer = new PIXI.Container(); noiseContainer.addChild(noiseQuad); // Third effect const fragmentWaveSrc = ` precision mediump float; varying vec2 vUvs; uniform float amplitude; uniform float time; void main() { //Offset uv so that center is 0,0 and edges are -1,1 vec2 uv = (vUvs-vec2(0.5))*2.0; vec3 outColor = vec3(0.); //Simple wavefunctions inversed and with small offsets. outColor += 5./length(uv.y*200. - 50.0*sin( uv.x*0.25+ time*0.25)*amplitude); outColor += 4./length(uv.y*300. - 100.0*sin(uv.x*0.5+time*0.5)*amplitude*1.2); outColor += 3./length(uv.y*400. - 150.0*sin(uv.x*0.75+time*0.75)*amplitude*1.4); outColor += 2./length(uv.y*500. - 200.0*sin(uv.x+time)*amplitude*1.6); gl_FragColor = vec4(outColor,1.0); }`; const waveUniforms = { amplitude: 0.75, time: 0, }; const waveShader = PIXI.Shader.from(vertexSrc, fragmentWaveSrc, waveUniforms); const waveTexture = PIXI.RenderTexture.create({ width: 200, height: 200 }); const waveQuad = new PIXI.Mesh(geometry, waveShader); const waveContainer = new PIXI.Container(); waveContainer.addChild(waveQuad); // Final combination pass const fragmentCombineSrc = ` precision mediump float; varying vec2 vUvs; uniform sampler2D texRipple; uniform sampler2D texNoise; uniform sampler2D texWave; void main() { //Read color from all vec4 ripple = texture2D(texRipple, vUvs); vec4 noise = texture2D(texNoise, vUvs); vec4 wave = texture2D(texWave, vUvs); gl_FragColor = mix(ripple, wave,noise.r); }`; const combineUniforms = { texRipple: rippleTexture, texNoise: noiseTexture, texWave: waveTexture, }; const combineShader = PIXI.Shader.from(vertexSrc, fragmentCombineSrc, combineUniforms); const combineQuad = new PIXI.Mesh(geometry, combineShader); gridContainer.position.set(10, 10); rippleContainer.position.set(220, 10); noiseContainer.position.set(10, 220); waveContainer.position.set(10, 430); combineQuad.position.set(430, 220); // Add all phases to stage so all the phases can be seen separately. app.stage.addChild(gridContainer); app.stage.addChild(rippleContainer); app.stage.addChild(noiseContainer); app.stage.addChild(waveContainer); app.stage.addChild(combineQuad); // start the animation.. let time = 0; app.ticker.add((delta) => { time += 1 / 60; // gridQuad.shader.uniforms.zoom = Math.sin(time)*5+10; rippleQuad.shader.uniforms.phase = -time; waveQuad.shader.uniforms.time = time; noiseQuad.shader.uniforms.limit = Math.sin(time * 0.5) * 0.35 + 0.5; // Render the passes to get textures. app.renderer.render(gridQuad, { renderTexture: gridTexture }); app.renderer.render(rippleQuad, { renderTexture: rippleTexture }); app.renderer.render(noiseQuad, { renderTexture: noiseTexture }); app.renderer.render(waveQuad, { renderTexture: waveTexture }); });","s":"Multi Pass Shader Generated Mesh","u":"/examples/mesh-and-shaders/multi-pass-shader-generated-mesh","h":"","p":162},{"i":165,"t":"import * as PIXI from 'pixi.js'; const app = new PIXI.Application({ resizeTo: window }); document.body.appendChild(app.view); // Build geometry. const geometry = new PIXI.Geometry() .addAttribute('aVertexPosition', // the attribute name [-100, -100, // x, y 100, -100, // x, y 100, 100, -100, 100], // x, y 2) // the size of the attribute .addAttribute('aUvs', // the attribute name [0, 0, // u, v 1, 0, // u, v 1, 1, 0, 1], // u, v 2) // the size of the attribute .addIndex([0, 1, 2, 0, 2, 3]); const vertexSrc = ` precision mediump float; attribute vec2 aVertexPosition; attribute vec2 aUvs; uniform mat3 translationMatrix; uniform mat3 projectionMatrix; varying vec2 vUvs; void main() { vUvs = aUvs; gl_Position = vec4((projectionMatrix * translationMatrix * vec3(aVertexPosition, 1.0)).xy, 0.0, 1.0); }`; const fragmentSrc = ` //Based on this: https://www.shadertoy.com/view/wtlSWX precision mediump float; varying vec2 vUvs; uniform sampler2D noise; uniform float time; // Distance function. Just calculates the height (z) from x,y plane with really simple length check. // Its not exact as there could be shorter distances. vec2 dist(vec3 p) { float id = floor(p.x)+floor(p.y); id = mod(id, 2.); float h = texture2D(noise, vec2(p.x, p.y)*0.04).r*5.1; return vec2(h-p.z,id); } //Light calculation. vec3 calclight(vec3 p, vec3 rd) { vec2 eps = vec2( 0., 0.001); vec3 n = normalize( vec3( dist(p+eps.yxx).x - dist(p-eps.yxx).x, dist(p+eps.xyx).x - dist(p-eps.xyx).x, dist(p+eps.xxy).x - dist(p-eps.xxy).x )); vec3 d = vec3( max( 0., dot( -rd ,n))); return d; } void main() { vec2 uv = vec2(vUvs.x,1.-vUvs.y); uv *=2.; uv-=1.; vec3 cam = vec3(0.,time -2., -3.); vec3 target = vec3(sin(time)*0.1, time+cos(time)+2., 0. ); float fov = 2.2; vec3 forward = normalize( target - cam); vec3 up = normalize(cross( forward, vec3(0., 1.,0.))); vec3 right = normalize( cross( up, forward)); vec3 raydir = normalize(vec3( uv.x *up + uv.y * right + fov*forward)); //Do the raymarch vec3 col = vec3(0.); float t = 0.; for( int i = 0; i < 100; i++) { vec3 p = t * raydir + cam; vec2 d = dist(p); t+=d.x*0.5;//Jump only half of the distance as height function used is not really the best for heightmaps. if(d.x < 0.001) { vec3 bc = d.y < 0.5 ? vec3(1.0, .8, 0.) : vec3(0.8,0.0, 1.0); col = vec3( 1.) * calclight(p, raydir) * (1. - t/150.) *bc; break; } if(t > 1000.) { break; } } gl_FragColor = vec4(col, 1.); }`; const uniforms = { noise: PIXI.Texture.from('https://pixijs.com/assets/perlin.jpg'), time: 0, }; // Make sure repeat wrap is used and no mipmapping. uniforms.noise.baseTexture.wrapMode = PIXI.WRAP_MODES.REPEAT; uniforms.noise.baseTexture.mipmap = false; // Build the shader and the quad. const shader = PIXI.Shader.from(vertexSrc, fragmentSrc, uniforms); const quad = new PIXI.Mesh(geometry, shader); quad.position.set(400, 300); quad.scale.set(2); app.stage.addChild(quad); // start the animation.. let time = 0; app.ticker.add((delta) => { time += 1 / 60; quad.shader.uniforms.time = time; quad.scale.set(Number(Math.cos(time)) + 2, Number(Math.sin(time * 0.7)) + 2); });","s":"Shader Toy Mesh","u":"/examples/mesh-and-shaders/shader-toy-mesh","h":"","p":164},{"i":167,"t":"import * as PIXI from 'pixi.js'; const app = new PIXI.Application({ resizeTo: window }); document.body.appendChild(app.view); const geometry = new PIXI.Geometry() .addAttribute('aVertexPosition', // the attribute name [-100, -100, // x, y 100, -100, // x, y 100, 100], // x, y 2) // the size of the attribute .addAttribute('aUvs', // the attribute name [0, 0, // u, v 1, 0, // u, v 1, 1], // u, v 2); // the size of the attribute const program = PIXI.Program.from(` precision mediump float; attribute vec2 aVertexPosition; attribute vec2 aUvs; uniform mat3 translationMatrix; uniform mat3 projectionMatrix; varying vec2 vUvs; void main() { vUvs = aUvs; gl_Position = vec4((projectionMatrix * translationMatrix * vec3(aVertexPosition, 1.0)).xy, 0.0, 1.0); }`, `precision mediump float; varying vec2 vUvs; uniform sampler2D uSamplerTexture; void main() { gl_FragColor = texture2D(uSamplerTexture, vUvs); } `); const triangle = new PIXI.Mesh(geometry, new PIXI.Shader(program, { uSamplerTexture: PIXI.Texture.from('https://pixijs.com/assets/bg_scene_rotate.jpg'), })); const triangle2 = new PIXI.Mesh(geometry, new PIXI.Shader(program, { uSamplerTexture: PIXI.Texture.from('https://pixijs.com/assets/bg_rotate.jpg'), })); const triangle3 = new PIXI.Mesh(geometry, new PIXI.Shader(program, { uSamplerTexture: PIXI.Texture.from('https://pixijs.com/assets/bg_displacement.jpg'), })); triangle.position.set(400, 300); triangle.scale.set(2); triangle2.position.set(200, 100); triangle3.position.set(500, 400); triangle3.scale.set(3); app.stage.addChild(triangle3, triangle2, triangle); app.ticker.add((delta) => { triangle.rotation += 0.01; triangle2.rotation -= 0.01; triangle3.rotation -= 0.005; });","s":"Sharing Geometry","u":"/examples/mesh-and-shaders/sharing-geometry","h":"","p":166},{"i":169,"t":"import * as PIXI from 'pixi.js'; const app = new PIXI.Application({ resizeTo: window }); document.body.appendChild(app.view); const geometry = new PIXI.Geometry() .addAttribute('aVertexPosition', // the attribute name [-100, -100, // x, y 100, -100, // x, y 100, 100]) // x, y .addAttribute('aUvs', // the attribute name [0, 0, // u, v 1, 0, // u, v 1, 1]); // u, v const shader = PIXI.Shader.from(` precision mediump float; attribute vec2 aVertexPosition; attribute vec2 aUvs; uniform mat3 translationMatrix; uniform mat3 projectionMatrix; varying vec2 vUvs; void main() { vUvs = aUvs; gl_Position = vec4((projectionMatrix * translationMatrix * vec3(aVertexPosition, 1.0)).xy, 0.0, 1.0); }`, `precision mediump float; varying vec2 vUvs; uniform sampler2D uSampler2; void main() { gl_FragColor = texture2D(uSampler2, vUvs); } `, { uSampler2: PIXI.Texture.from('https://pixijs.com/assets/bg_scene_rotate.jpg'), }); const shader2 = PIXI.Shader.from(` precision mediump float; attribute vec2 aVertexPosition; attribute vec2 aUvs; uniform mat3 translationMatrix; uniform mat3 projectionMatrix; varying vec2 vUvs; void main() { vUvs = aUvs; gl_Position = vec4((projectionMatrix * translationMatrix * vec3(aVertexPosition, 1.0)).xy, 0.0, 1.0); }`, `precision mediump float; varying vec2 vUvs; uniform sampler2D uSampler2; void main() { gl_FragColor = texture2D(uSampler2, vUvs); gl_FragColor.r += (abs(sin(gl_FragCoord.x * 0.06)) * 0.5) * 2.; gl_FragColor.g += (abs(cos(gl_FragCoord.y * 0.06)) * 0.5) * 2.; } `, { uSampler2: PIXI.Texture.from('https://pixijs.com/assets/bg_scene_rotate.jpg'), }); const triangle = new PIXI.Mesh(geometry, shader); const triangle2 = new PIXI.Mesh(geometry, shader2); triangle.position.set(400, 300); triangle.scale.set(2); triangle2.position.set(500, 400); triangle2.scale.set(3); app.stage.addChild(triangle2, triangle); app.ticker.add((delta) => { triangle.rotation += 0.01; triangle2.rotation -= 0.005; });","s":"Shared Shader","u":"/examples/mesh-and-shaders/shared-shader","h":"","p":168},{"i":171,"t":"import * as PIXI from 'pixi.js'; const app = new PIXI.Application({ resizeTo: window }); document.body.appendChild(app.view); let count = 0; // build a rope! const ropeLength = 45; const points = []; for (let i = 0; i < 25; i++) { points.push(new PIXI.Point(i * ropeLength, 0)); } const strip = new PIXI.SimpleRope(PIXI.Texture.from('https://pixijs.com/assets/snake.png'), points); strip.x = -40; strip.y = 300; app.stage.addChild(strip); const g = new PIXI.Graphics(); g.x = strip.x; g.y = strip.y; app.stage.addChild(g); // start animating app.ticker.add(() => { count += 0.1; // make the snake for (let i = 0; i < points.length; i++) { points[i].y = Math.sin((i * 0.5) + count) * 30; points[i].x = i * ropeLength + Math.cos((i * 0.3) + count) * 20; } renderPoints(); }); function renderPoints() { g.clear(); g.lineStyle(2, 0xffc2c2); g.moveTo(points[0].x, points[0].y); for (let i = 1; i < points.length; i++) { g.lineTo(points[i].x, points[i].y); } for (let i = 1; i < points.length; i++) { g.beginFill(0xff0022); g.drawCircle(points[i].x, points[i].y, 10); g.endFill(); } }","s":"Textured Mesh Advanced","u":"/examples/mesh-and-shaders/textured-mesh-advanced","h":"","p":170},{"i":173,"t":"import * as PIXI from 'pixi.js'; const app = new PIXI.Application({ resizeTo: window }); document.body.appendChild(app.view); let count = 0; // build a rope! const ropeLength = 918 / 20; const points = []; for (let i = 0; i < 20; i++) { points.push(new PIXI.Point(i * ropeLength, 0)); } const strip = new PIXI.SimpleRope(PIXI.Texture.from('https://pixijs.com/assets/snake.png'), points); strip.x = -459; const snakeContainer = new PIXI.Container(); snakeContainer.x = 400; snakeContainer.y = 300; snakeContainer.scale.set(800 / 1100); app.stage.addChild(snakeContainer); snakeContainer.addChild(strip); app.ticker.add(() => { count += 0.1; // make the snake for (let i = 0; i < points.length; i++) { points[i].y = Math.sin((i * 0.5) + count) * 30; points[i].x = i * ropeLength + Math.cos((i * 0.3) + count) * 20; } });","s":"Textured Mesh Basic","u":"/examples/mesh-and-shaders/textured-mesh-basic","h":"","p":172},{"i":175,"t":"import * as PIXI from 'pixi.js'; const app = new PIXI.Application({ resizeTo: window }); document.body.appendChild(app.view); const geometry = new PIXI.Geometry() .addAttribute('aVertexPosition', [-100, -50, 100, -50, 0, 100]); const shader = PIXI.Shader.from(` precision mediump float; attribute vec2 aVertexPosition; uniform mat3 translationMatrix; uniform mat3 projectionMatrix; void main() { gl_Position = vec4((projectionMatrix * translationMatrix * vec3(aVertexPosition, 1.0)).xy, 0.0, 1.0); }`, `precision mediump float; void main() { gl_FragColor = vec4(1.0, 0.0, 0.0, 1.0); } `); const triangle = new PIXI.Mesh(geometry, shader); triangle.position.set(400, 300); app.stage.addChild(triangle); app.ticker.add((delta) => { triangle.rotation += 0.01; });","s":"Triangle","u":"/examples/mesh-and-shaders/triangle","h":"","p":174},{"i":177,"t":"import * as PIXI from 'pixi.js'; const app = new PIXI.Application({ resizeTo: window }); document.body.appendChild(app.view); const geometry = new PIXI.Geometry() .addAttribute('aVertexPosition', // the attribute name [-100, -50, // x, y 100, -50, // x, y 0.0, 100.0], // x, y 2) // the size of the attribute .addAttribute('aColor', // the attribute name [1, 0, 0, // r, g, b 0, 1, 0, // r, g, b 0, 0, 1], // r, g, b 3); // the size of the attribute const shader = PIXI.Shader.from(` precision mediump float; attribute vec2 aVertexPosition; attribute vec3 aColor; uniform mat3 translationMatrix; uniform mat3 projectionMatrix; varying vec3 vColor; void main() { vColor = aColor; gl_Position = vec4((projectionMatrix * translationMatrix * vec3(aVertexPosition, 1.0)).xy, 0.0, 1.0); }`, `precision mediump float; varying vec3 vColor; void main() { gl_FragColor = vec4(vColor, 1.0); } `); const triangle = new PIXI.Mesh(geometry, shader); triangle.position.set(400, 300); triangle.scale.set(2); app.stage.addChild(triangle); app.ticker.add((delta) => { triangle.rotation += 0.01; });","s":"Triangle Color","u":"/examples/mesh-and-shaders/triangle-color","h":"","p":176},{"i":179,"t":"import * as PIXI from 'pixi.js'; const app = new PIXI.Application({ resizeTo: window }); document.body.appendChild(app.view); const geometry = new PIXI.Geometry() .addAttribute('aVertexPosition', // the attribute name [-100, -100, // x, y 100, -100, // x, y 100, 100], // x, y 2) // the size of the attribute .addAttribute('aColor', // the attribute name [1, 0, 0, // r, g, b 0, 1, 0, // r, g, b 0, 0, 1], // r, g, b 3) // the size of the attribute .addAttribute('aUvs', // the attribute name [0, 0, // u, v 1, 0, // u, v 1, 1], // u, v 2); // the size of the attribute const vertexSrc = ` precision mediump float; attribute vec2 aVertexPosition; attribute vec3 aColor; attribute vec2 aUvs; uniform mat3 translationMatrix; uniform mat3 projectionMatrix; varying vec2 vUvs; varying vec3 vColor; void main() { vUvs = aUvs; vColor = aColor; gl_Position = vec4((projectionMatrix * translationMatrix * vec3(aVertexPosition, 1.0)).xy, 0.0, 1.0); }`; const fragmentSrc = ` precision mediump float; varying vec3 vColor; varying vec2 vUvs; uniform sampler2D uSampler2; void main() { gl_FragColor = texture2D(uSampler2, vUvs) * vec4(vColor, 1.0); }`; const uniforms = { uSampler2: PIXI.Texture.from('https://pixijs.com/assets/bg_scene_rotate.jpg') }; const shader = PIXI.Shader.from(vertexSrc, fragmentSrc, uniforms); const triangle = new PIXI.Mesh(geometry, shader); triangle.position.set(400, 300); triangle.scale.set(2); app.stage.addChild(triangle); app.ticker.add((delta) => { triangle.rotation += 0.01; });","s":"Triangle Textured","u":"/examples/mesh-and-shaders/triangle-textured","h":"","p":178},{"i":181,"t":"import * as PIXI from 'pixi.js'; const app = new PIXI.Application({ resizeTo: window }); document.body.appendChild(app.view); const geometry = new PIXI.Geometry() .addAttribute('aVertexPosition', // the attribute name [-100, -100, // x, y 100, -100, // x, y 100, 100, -100, 100], // x, y 2) // the size of the attribute .addAttribute('aUvs', // the attribute name [0, 0, // u, v 1, 0, // u, v 1, 1, 0, 1], // u, v 2) // the size of the attribute .addIndex([0, 1, 2, 0, 2, 3]); const vertexSrc = ` precision mediump float; attribute vec2 aVertexPosition; attribute vec2 aUvs; uniform mat3 translationMatrix; uniform mat3 projectionMatrix; varying vec2 vUvs; void main() { vUvs = aUvs; gl_Position = vec4((projectionMatrix * translationMatrix * vec3(aVertexPosition, 1.0)).xy, 0.0, 1.0); }`; const fragmentSrc = ` precision mediump float; varying vec2 vUvs; uniform sampler2D uSampler2; uniform float time; void main() { gl_FragColor = texture2D(uSampler2, vUvs + sin( (time + (vUvs.x) * 14.) ) * 0.1 ); }`; const uniforms = { uSampler2: PIXI.Texture.from('https://pixijs.com/assets/bg_scene_rotate.jpg'), time: 0, }; const shader = PIXI.Shader.from(vertexSrc, fragmentSrc, uniforms); const quad = new PIXI.Mesh(geometry, shader); quad.position.set(400, 300); quad.scale.set(2); app.stage.addChild(quad); // start the animation.. // requestAnimationFrame(animate); app.ticker.add((delta) => { quad.rotation += 0.01; quad.shader.uniforms.time += 0.1; });","s":"Uniforms","u":"/examples/mesh-and-shaders/uniforms","h":"","p":180},{"i":183,"t":"import * as PIXI from 'pixi.js'; const app = new PIXI.Application({ autoStart: false, resizeTo: window }); document.body.appendChild(app.view); PIXI.Assets.load('https://pixijs.com/assets/spritesheet/0123456789.json').then((spritesheet) => { // create an array to store the textures const textures = []; let i; for (i = 0; i < 10; i++) { const framekey = `0123456789 ${i}.ase`; const texture = PIXI.Texture.from(framekey); const time = spritesheet.data.frames[framekey].duration; textures.push({ texture, time }); } const scaling = 4; // create a slow AnimatedSprite const slow = new PIXI.AnimatedSprite(textures); slow.anchor.set(0.5); slow.scale.set(scaling); slow.animationSpeed = 0.5; slow.x = (app.screen.width - slow.width) / 2; slow.y = app.screen.height / 2; slow.play(); app.stage.addChild(slow); // create a fast AnimatedSprite const fast = new PIXI.AnimatedSprite(textures); fast.anchor.set(0.5); fast.scale.set(scaling); fast.x = (app.screen.width + fast.width) / 2; fast.y = app.screen.height / 2; fast.play(); app.stage.addChild(fast); // start animating app.start(); });","s":"Animated Sprite Animation Speed","u":"/examples/sprite/animated-sprite-animation-speed","h":"","p":182},{"i":185,"t":"import * as PIXI from 'pixi.js'; const app = new PIXI.Application({ autoStart: false, resizeTo: window }); document.body.appendChild(app.view); PIXI.Assets.load('https://pixijs.com/assets/spritesheet/mc.json').then(() => { // create an array to store the textures const explosionTextures = []; let i; for (i = 0; i < 26; i++) { const texture = PIXI.Texture.from(`Explosion_Sequence_A ${i + 1}.png`); explosionTextures.push(texture); } for (i = 0; i < 50; i++) { // create an explosion AnimatedSprite const explosion = new PIXI.AnimatedSprite(explosionTextures); explosion.x = Math.random() * app.screen.width; explosion.y = Math.random() * app.screen.height; explosion.anchor.set(0.5); explosion.rotation = Math.random() * Math.PI; explosion.scale.set(0.75 + Math.random() * 0.5); explosion.gotoAndPlay(Math.random() * 26 | 0); app.stage.addChild(explosion); } // start animating app.start(); });","s":"Animated Sprite Explosion","u":"/examples/sprite/animated-sprite-explosion","h":"","p":184},{"i":187,"t":"import * as PIXI from 'pixi.js'; const app = new PIXI.Application({ background: '#1099bb', resizeTo: window }); document.body.appendChild(app.view); PIXI.Assets.load('https://pixijs.com/assets/spritesheet/fighter.json').then(() => { // create an array of textures from an image path const frames = []; for (let i = 0; i < 30; i++) { const val = i < 10 ? `0${i}` : i; // magically works since the spritesheet was loaded with the pixi loader frames.push(PIXI.Texture.from(`rollSequence00${val}.png`)); } // create an AnimatedSprite (brings back memories from the days of Flash, right ?) const anim = new PIXI.AnimatedSprite(frames); /* * An AnimatedSprite inherits all the properties of a PIXI sprite * so you can change its position, its anchor, mask it, etc */ anim.x = app.screen.width / 2; anim.y = app.screen.height / 2; anim.anchor.set(0.5); anim.animationSpeed = 0.5; anim.play(); app.stage.addChild(anim); // Animate the rotation app.ticker.add(() => { anim.rotation += 0.01; }); });","s":"Animated Sprite Jet","u":"/examples/sprite/animated-sprite-jet","h":"","p":186},{"i":189,"t":"import * as PIXI from 'pixi.js'; const app = new PIXI.Application({ background: '#1099bb', resizeTo: window }); document.body.appendChild(app.view); // create a new Sprite from an image path const bunny = PIXI.Sprite.from('https://pixijs.com/assets/bunny.png'); // center the sprite's anchor point bunny.anchor.set(0.5); // move the sprite to the center of the screen bunny.x = app.screen.width / 2; bunny.y = app.screen.height / 2; app.stage.addChild(bunny); // Listen for animate update app.ticker.add((delta) => { // just for fun, let's rotate mr rabbit a little // delta is 1 if running at 100% performance // creates frame-independent transformation bunny.rotation += 0.1 * delta; });","s":"Basic","u":"/examples/sprite/basic","h":"","p":188},{"i":191,"t":"import * as PIXI from 'pixi.js'; const app = new PIXI.Application({ background: '#1099bb', resizeTo: window }); document.body.appendChild(app.view); let isFlower = true; const texture = PIXI.Texture.from('https://pixijs.com/assets/flowerTop.png'); const secondTexture = PIXI.Texture.from('https://pixijs.com/assets/eggHead.png'); // create a new Sprite using the texture const character = new PIXI.Sprite(texture); // center the sprites anchor point character.anchor.set(0.5); // move the sprite to the center of the screen character.x = app.screen.width / 2; character.y = app.screen.height / 2; app.stage.addChild(character); // make the sprite interactive character.eventMode = 'static'; character.cursor = 'pointer'; character.on('pointertap', () => { isFlower = !isFlower; // Dynamically swap the texture character.texture = isFlower ? texture : secondTexture; }); app.ticker.add(() => { character.rotation += 0.02; });","s":"Texture Swap","u":"/examples/sprite/texture-swap","h":"","p":190},{"i":193,"t":"import * as PIXI from 'pixi.js'; // This example is the based on basic/container, but using OffscreenCanvas. const canvas = document.createElement('canvas'); const view = canvas.transferControlToOffscreen(); const app = new PIXI.Application({ view, background: 0x1099bb, resizeTo: window }); document.body.appendChild(canvas); const container = new PIXI.Container(); app.stage.addChild(container); // Create a new texture const texture = PIXI.Texture.from('https://pixijs.com/assets/bunny.png'); // Create a 5x5 grid of bunnies for (let i = 0; i < 25; i++) { const bunny = new PIXI.Sprite(texture); bunny.anchor.set(0.5); bunny.x = (i % 5) * 40; bunny.y = Math.floor(i / 5) * 40; container.addChild(bunny); } // Move container to the center container.x = app.screen.width / 2; container.y = app.screen.height / 2; // Center bunny sprite in local container coordinates container.pivot.x = container.width / 2; container.pivot.y = container.height / 2; // Listen for animate update app.ticker.add((delta) => { // rotate the container! // use delta to create frame-independent transform container.rotation -= 0.01 * delta; });","s":"Basic","u":"/examples/offscreen-canvas/basic","h":"","p":192},{"i":195,"t":"import * as PIXI from 'pixi.js'; const app = new PIXI.Application({ resizeTo: window }); document.body.appendChild(app.view); // create a texture from an image path const texture = PIXI.Texture.from('https://pixijs.com/assets/p2.jpeg'); /* create a tiling sprite ... * requires a texture, a width and a height * in WebGL the image size should preferably be a power of two */ const tilingSprite = new PIXI.TilingSprite( texture, app.screen.width, app.screen.height, ); app.stage.addChild(tilingSprite); let count = 0; app.ticker.add(() => { count += 0.005; tilingSprite.tileScale.x = 2 + Math.sin(count); tilingSprite.tileScale.y = 2 + Math.cos(count); tilingSprite.tilePosition.x += 1; tilingSprite.tilePosition.y += 1; });","s":"Tiling Sprite","u":"/examples/sprite/tiling-sprite","h":"","p":194},{"i":197,"t":"import * as PIXI from 'pixi.js'; const app = new PIXI.Application({ background: '#1099bb', resizeTo: window }); document.body.appendChild(app.view); PIXI.Assets.load('https://pixijs.com/assets/bitmap-font/desyrel.xml').then(() => { const bitmapFontText = new PIXI.BitmapText( 'bitmap fonts are supported!\\nWoo yay!', { fontName: 'Desyrel', fontSize: 55, align: 'left', }, ); bitmapFontText.x = 50; bitmapFontText.y = 200; app.stage.addChild(bitmapFontText); });","s":"Bitmap Text","u":"/examples/text/bitmap-text","h":"","p":196},{"i":199,"t":"import * as PIXI from 'pixi.js'; const app = new PIXI.Application({ backgroundAlpha: 0, resizeTo: window }); document.body.appendChild(app.view); // Create play button that can be used to trigger the video const button = new PIXI.Graphics() .beginFill(0x0, 0.5) .drawRoundedRect(0, 0, 100, 100, 10) .endFill() .beginFill(0xffffff) .moveTo(36, 30) .lineTo(36, 70) .lineTo(70, 50); // Position the button button.x = (app.screen.width - button.width) / 2; button.y = (app.screen.height - button.height) / 2; // Enable interactivity on the button button.eventMode = 'static'; button.cursor = 'pointer'; // Add to the stage app.stage.addChild(button); // Listen for a click/tap event to start playing the video // this is useful for some mobile platforms. For example: // ios9 and under cannot render videos in PIXI without a // polyfill - https://github.com/bfred-it/iphone-inline-video // ios10 and above require a click/tap event to render videos // that contain audio in PIXI. Videos with no audio track do // not have this requirement button.on('pointertap', onPlayVideo); function onPlayVideo() { // Don't need the button anymore button.destroy(); // create a video texture from a path const texture = PIXI.Texture.from('https://pixijs.com/assets/video.mp4'); // create a new Sprite using the video texture (yes it's that easy) const videoSprite = new PIXI.Sprite(texture); // Stetch the fullscreen videoSprite.width = app.screen.width; videoSprite.height = app.screen.height; app.stage.addChild(videoSprite); }","s":"Video","u":"/examples/sprite/video","h":"","p":198},{"i":201,"t":"import * as PIXI from 'pixi.js'; const app = new PIXI.Application({ background: '#1099bb', resizeTo: window }); document.body.appendChild(app.view); // Load from any font file! PIXI.Assets.addBundle('fonts', { ChaChicle: 'https://pixijs.com/assets/webfont-loader/ChaChicle.ttf', Lineal: 'https://pixijs.com/assets/webfont-loader/Lineal.otf', 'Dotrice Regular': 'https://pixijs.com/assets/webfont-loader/Dotrice-Regular.woff', Crosterian: 'https://pixijs.com/assets/webfont-loader/Crosterian.woff2', }); PIXI.Assets.loadBundle('fonts').then(() => { const text1 = new PIXI.Text('ChaChicle.ttf', new PIXI.TextStyle({ fontFamily: 'ChaChicle', fontSize: 50 })); const text2 = new PIXI.Text('Lineal.otf', new PIXI.TextStyle({ fontFamily: 'Lineal', fontSize: 50 })); const text3 = new PIXI.Text('Dotrice Regular.woff', new PIXI.TextStyle({ fontFamily: 'Dotrice Regular', fontSize: 50 })); const text4 = new PIXI.Text('Crosterian.woff2', new PIXI.TextStyle({ fontFamily: 'Crosterian', fontSize: 50 })); text2.y = 150; text3.y = 300; text4.y = 450; app.stage.addChild(text1); app.stage.addChild(text2); app.stage.addChild(text3); app.stage.addChild(text4); });","s":"From Font","u":"/examples/text/from-font","h":"","p":200},{"i":203,"t":"import * as PIXI from 'pixi.js'; const app = new PIXI.Application({ background: '#1099bb', resizeTo: window }); document.body.appendChild(app.view); // Load them google fonts before starting... window.WebFontConfig = { google: { families: ['Snippet'], }, active() { init(); }, }; /* eslint-disable */ // include the web-font loader script (function() { const wf = document.createElement('script'); wf.src = `${document.location.protocol === 'https:' ? 'https' : 'http' }://ajax.googleapis.com/ajax/libs/webfont/1/webfont.js`; wf.type = 'text/javascript'; wf.async = 'true'; const s = document.getElementsByTagName('script')[0]; s.parentNode.insertBefore(wf, s); }()); /* eslint-enabled */ function init() { // create some white text using the Snippet webfont const textSample = new PIXI.Text( 'PixiJS text using the\\ncustom \"Snippet\" Webfont', { fontFamily: 'Snippet', fontSize: 50, fill: 'white', align: 'left', } ); textSample.position.set(50, 200); app.stage.addChild(textSample); }","s":"Web Font","u":"/examples/text/web-font","h":"","p":202},{"i":205,"t":"import * as PIXI from 'pixi.js'; const app = new PIXI.Application({ background: '#1099bb', resizeTo: window }); document.body.appendChild(app.view); const basicText = new PIXI.Text('Basic text in pixi'); basicText.x = 50; basicText.y = 100; app.stage.addChild(basicText); const style = new PIXI.TextStyle({ fontFamily: 'Arial', fontSize: 36, fontStyle: 'italic', fontWeight: 'bold', fill: ['#ffffff', '#00ff99'], // gradient stroke: '#4a1850', strokeThickness: 5, dropShadow: true, dropShadowColor: '#000000', dropShadowBlur: 4, dropShadowAngle: Math.PI / 6, dropShadowDistance: 6, wordWrap: true, wordWrapWidth: 440, lineJoin: 'round', }); const richText = new PIXI.Text('Rich text with a lot of options and across multiple lines', style); richText.x = 50; richText.y = 220; app.stage.addChild(richText); const skewStyle = new PIXI.TextStyle({ fontFamily: 'Arial', dropShadow: true, dropShadowAlpha: 0.8, dropShadowAngle: 2.1, dropShadowBlur: 4, dropShadowColor: '0x111111', dropShadowDistance: 10, fill: ['#ffffff'], stroke: '#004620', fontSize: 60, fontWeight: 'lighter', lineJoin: 'round', strokeThickness: 12, }); const skewText = new PIXI.Text('SKEW IS COOL', skewStyle); skewText.skew.set(0.65, -0.3); skewText.anchor.set(0.5, 0.5); skewText.x = 300; skewText.y = 480; app.stage.addChild(skewText);","s":"Pixi Text","u":"/examples/text/pixi-text","h":"","p":204},{"i":207,"t":"import * as PIXI from 'pixi.js'; // PixiJS V5 Texture-Resource API + canvas2d gradient API + WebGL texImage2D // Look here for advanced upload function: // https://github.com/pixijs/pixi.js/blob/dev/packages/core/src/textures/resources/BaseImageResource.js#L54 class GradientResource extends PIXI.Resource { constructor() { // pass width and height. (0,0) if we dont know yet // gradient needs only 1 pixel height super(256, 1); } upload(renderer, baseTexture, glTexture) { const { width } = this; // default size or from baseTexture? const { height } = this; // your choice. // temporary canvas, we dont need it after texture is uploaded to GPU const canvas = document.createElement('canvas'); canvas.width = width; canvas.height = height; const ctx = canvas.getContext('2d'); const grd = ctx.createLinearGradient(0, 0, width, 0); grd.addColorStop(0, 'rgba(255, 255, 255, 0.0)'); grd.addColorStop(0.3, 'cyan'); grd.addColorStop(0.7, 'red'); grd.addColorStop(1, 'green'); ctx.fillStyle = grd; ctx.fillRect(0, 0, width, height); // This info ios usseful if upload happens second time // Some people use that to track used memory glTexture.width = width; glTexture.height = height; // PURE WEBGL CALLS - that's what its all about. // PixiJS cant wrap all that API, we give you acceess to it! const { gl } = renderer; gl.pixelStorei(gl.UNPACK_PREMULTIPLY_ALPHA_WEBGL, baseTexture.premultiplyAlpha); gl.texImage2D(baseTexture.target, 0, baseTexture.format, baseTexture.format, baseTexture.type, canvas); return true; } } const app = new PIXI.Application({ antialias: true, resizeTo: window }); document.body.appendChild(app.view); const gradBaseTexture = new PIXI.BaseTexture(new GradientResource()); // Here you can fake baseTexture size to avoid resizing all sprites // There can be multiple baseTextures per gradient, but be careful: // resource will spawn more glTextures! gradBaseTexture.setSize(500, 50); const gradTexture = new PIXI.Texture(gradBaseTexture); const sprite = new PIXI.Sprite(gradTexture); sprite.position.set(100, 100); sprite.rotation = Math.PI / 8; app.stage.addChild(sprite);","s":"Gradient Resource","u":"/examples/textures/gradient-resource","h":"","p":206},{"i":209,"t":"import * as PIXI from 'pixi.js'; // This demo uses canvas2d gradient API // https://developer.mozilla.org/en-US/docs/Web/API/CanvasRenderingContext2D/createLinearGradient const app = new PIXI.Application({ antialias: true, resizeTo: window }); document.body.appendChild(app.view); function createGradTexture() { // adjust it if somehow you need better quality for very very big images const quality = 256; const canvas = document.createElement('canvas'); canvas.width = quality; canvas.height = 1; const ctx = canvas.getContext('2d'); // use canvas2d API to create gradient const grd = ctx.createLinearGradient(0, 0, quality, 0); grd.addColorStop(0, 'rgba(255, 255, 255, 0.0)'); grd.addColorStop(0.3, 'cyan'); grd.addColorStop(0.7, 'red'); grd.addColorStop(1, 'green'); ctx.fillStyle = grd; ctx.fillRect(0, 0, quality, 1); return PIXI.Texture.from(canvas); } const gradTexture = createGradTexture(); const sprite = new PIXI.Sprite(gradTexture); sprite.position.set(100, 100); sprite.rotation = Math.PI / 8; sprite.width = 500; sprite.height = 50; app.stage.addChild(sprite);","s":"Gradient Basic","u":"/examples/textures/gradient-basic","h":"","p":208},{"i":211,"t":"import * as PIXI from 'pixi.js'; const app = new PIXI.Application({ resizeTo: window }); document.body.appendChild(app.view); const stageSize = { width: app.screen.width, height: app.screen.height, }; // create two render textures... these dynamic textures will be used to draw the scene into itself let renderTexture = PIXI.RenderTexture.create(stageSize); let renderTexture2 = PIXI.RenderTexture.create(stageSize); const currentTexture = renderTexture; // create a new sprite that uses the render texture we created above const outputSprite = new PIXI.Sprite(currentTexture); // align the sprite outputSprite.x = 400; outputSprite.y = 300; outputSprite.anchor.set(0.5); // add to stage app.stage.addChild(outputSprite); const stuffContainer = new PIXI.Container(); stuffContainer.x = 400; stuffContainer.y = 300; app.stage.addChild(stuffContainer); // create an array of image ids.. const fruits = [ 'https://pixijs.com/assets/rt_object_01.png', 'https://pixijs.com/assets/rt_object_02.png', 'https://pixijs.com/assets/rt_object_03.png', 'https://pixijs.com/assets/rt_object_04.png', 'https://pixijs.com/assets/rt_object_05.png', 'https://pixijs.com/assets/rt_object_06.png', 'https://pixijs.com/assets/rt_object_07.png', 'https://pixijs.com/assets/rt_object_08.png', ]; // create an array of items const items = []; // now create some items and randomly position them in the stuff container for (let i = 0; i < 20; i++) { const item = PIXI.Sprite.from(fruits[i % fruits.length]); item.x = Math.random() * 400 - 200; item.y = Math.random() * 400 - 200; item.anchor.set(0.5); stuffContainer.addChild(item); items.push(item); } // used for spinning! let count = 0; app.ticker.add(() => { for (let i = 0; i < items.length; i++) { // rotate each item const item = items[i]; item.rotation += 0.1; } count += 0.01; // swap the buffers ... const temp = renderTexture; renderTexture = renderTexture2; renderTexture2 = temp; // set the new texture outputSprite.texture = renderTexture; // twist this up! stuffContainer.rotation -= 0.01; outputSprite.scale.set(1 + Math.sin(count) * 0.2); // render the stage to the texture // the 'true' clears the texture before the content is rendered app.renderer.render(app.stage, { renderTexture: renderTexture2, clear: false, }); });","s":"Render Texture Advanced","u":"/examples/textures/render-texture-advanced","h":"","p":210},{"i":213,"t":"import * as PIXI from 'pixi.js'; const app = new PIXI.Application({ background: '#1099bb', resizeTo: window }); document.body.appendChild(app.view); const container = new PIXI.Container(); app.stage.addChild(container); const texture = PIXI.Texture.from('https://pixijs.com/assets/bunny.png'); for (let i = 0; i < 25; i++) { const bunny = new PIXI.Sprite(texture); bunny.x = (i % 5) * 30; bunny.y = Math.floor(i / 5) * 30; bunny.rotation = Math.random() * (Math.PI * 2); container.addChild(bunny); } const rt = PIXI.RenderTexture.create({ width: 300, height: 300, scaleMode: PIXI.SCALE_MODES.LINEAR, resolution: 1, }); const sprite = new PIXI.Sprite(rt); sprite.x = 450; sprite.y = 60; app.stage.addChild(sprite); /* * All the bunnies are added to the container with the addChild method * when you do this, all the bunnies become children of the container, and when a container moves, * so do all its children. * This gives you a lot of flexibility and makes it easier to position elements on the screen */ container.x = 100; container.y = 60; app.ticker.add(() => { app.renderer.render(container, { renderTexture: rt }); });","s":"Render Texture Basic","u":"/examples/textures/render-texture-basic","h":"","p":212},{"i":238,"t":"import * as PIXI from 'pixi.js'; const app = new PIXI.Application({ resizeTo: window }); document.body.appendChild(app.view); PIXI.Assets.load('https://pixijs.com/assets/flowerTop.png').then((texture) => { // create rotated textures const textures = [texture]; const D8 = PIXI.groupD8; for (let rotate = 1; rotate < 16; rotate++) { const h = D8.isVertical(rotate) ? texture.frame.width : texture.frame.height; const w = D8.isVertical(rotate) ? texture.frame.height : texture.frame.width; const { frame } = texture; const crop = new PIXI.Rectangle(texture.frame.x, texture.frame.y, w, h); const trim = crop; let rotatedTexture; if (rotate % 2 === 0) { rotatedTexture = new PIXI.Texture(texture.baseTexture, frame, crop, trim, rotate); } else { // HACK to avoid exception // PIXI doesnt like diamond-shaped UVs, because they are different in canvas and webgl rotatedTexture = new PIXI.Texture(texture.baseTexture, frame, crop, trim, rotate - 1); rotatedTexture.rotate++; } textures.push(rotatedTexture); } const offsetX = app.screen.width / 16 | 0; const offsetY = app.screen.height / 8 | 0; const gridW = app.screen.width / 4 | 0; const gridH = app.screen.height / 5 | 0; // normal rotations and mirrors for (let i = 0; i < 16; i++) { // create a new Sprite using rotated texture const dude = new PIXI.Sprite(textures[i < 8 ? i * 2 : (i - 8) * 2 + 1]); dude.scale.x = 0.5; dude.scale.y = 0.5; // show it in grid dude.x = offsetX + gridW * (i % 4); dude.y = offsetY + gridH * (i / 4 | 0); app.stage.addChild(dude); const text = new PIXI.Text(`rotate = ${dude.texture.rotate}`, { fontFamily: 'Courier New', fontSize: '12px', fill: 'white', align: 'left', }); text.x = dude.x; text.y = dude.y - 20; app.stage.addChild(text); } });","s":"Texture Rotate","u":"/examples/textures/texture-rotate","h":"","p":237}],"index":{"version":"2.3.9","fields":["t"],"fieldVectors":[["t/73",[0,6.021,1,5.524,2,6.136,3,6.021,4,4.318,5,5.229,6,6.021,7,6.021,8,5.229,9,6.021,10,4.708,11,6.021,12,4.007,13,4.318,14,6.021,15,6.021,16,4.708,17,2.616,18,4.708,19,6.021,20,5.229,21,1.71,22,6.021,23,3.748,24,4.318]],["t/75",[12,2.316,13,3.11,16,1.708,25,0.012,26,0.045,27,0.012,28,0.012,29,1.36,30,2.184,31,2.184,32,2.184,33,2.184,34,1.897,35,3.479,36,2.184,37,2.184,38,2.184,39,1.897,40,2.184,41,2.184,42,2.184,43,0.04,44,0.012,45,0.037,46,0.02,47,0.405,48,1.897,49,0.052,50,0.052,51,0.02,52,1.897,53,4.336,54,2.184,55,1.708,56,4.223,57,5.749,58,2.721,59,3.479,60,1.567,61,2.184,62,5.401,63,1.567,64,3.595,65,3.547,66,3.479,67,0.909,68,2.184,69,1.567,70,2.184,71,1.279,72,4.946,73,1.243,74,2.184,75,4.336,76,2.184,77,2.184,78,2.184,79,2.184,80,2.353,81,3.479,82,3.479,83,2.184,84,2.184,85,3.479,86,3.479,87,2.184,88,2.184,89,1.567,90,2.184,91,3.479,92,2.184,93,1.897,94,2.184,95,2.184,96,2.184,97,2.184,98,3.766,99,2.184,100,3.829,101,4.336,102,4.336,103,4.336,104,4.336,105,3.292,106,2.184,107,2.184,108,2.184,109,2.184,110,2.184,111,2.184,112,2.184,113,2.184,114,2.184,115,2.7,116,2.184,117,3.479,118,2.184,119,3.479,120,2.184,121,2.184,122,3.547,123,2.184,124,1.454,125,2.184,126,2.184,127,2.184,128,2.184,129,2.721,130,2.184,131,2.184,132,2.184,133,3.391,134,2.184,135,3.479,136,3.479,137,3.479,138,1.09,139,0.444,140,0.964,141,2.184,142,2.184,143,2.184,144,1.897,145,2.184,146,4.336,147,0.836,148,1.039,149,1.897,150,4.336,151,2.184,152,0.426,153,3.479,154,3.479,155,2.184,156,1.708,157,2.184,158,4.336,159,0.39,160,3.479,161,0.836,162,0.803,163,0.803,164,0.549,165,1.039,166,1.039,167,1.897,168,1.279,169,4.946,170,1.708,171,4.946,172,1.708,173,0.992,174,0.992,175,1.279,176,0.662,177,2.184,178,2.184,179,2.721,180,1.897,181,2.184,182,5.754,183,0.662,184,2.184,185,2.184,186,4.946,187,3.479,188,2.184,189,4.946,190,2.184,191,1.826,192,2.184,193,2.886,194,5.401,195,0.805,196,4.336,197,5.401,198,3.479,199,2.184,200,1.708,201,2.184,202,2.468,203,2.276,204,1.567,205,2.184,206,0.949,207,0.992,208,3.479,209,3.479,210,1.095,211,3.479,212,2.184,213,1.581,214,2.184,215,2.184,216,2.184,217,1.039,218,1.708,219,3.479,220,1.897,221,2.184,222,2.184,223,2.184,224,2.184,225,2.184,226,1.897,227,1.708,228,3.479,229,2.184,230,4.336,231,3.479,232,2.184,233,2.184,234,2.184,235,2.184,236,3.479,237,1.897,238,1.454,239,2.184,240,2.184,241,2.184,242,0.871,243,3.479,244,3.479,245,2.184,246,2.596,247,2.184,248,0.772,249,0.992,250,2.184]],["t/77",[13,2.84,25,0.021,26,0.045,27,0.021,28,0.021,43,0.04,44,0.021,45,0.037,46,0.036,47,1.004,49,0.095,50,0.095,51,0.036,73,1.666,100,2.636,124,2.636,138,0.652,152,0.279,161,1.516,162,2.437,163,1.456,164,0.995,165,1.884,166,2.575,207,1.799,251,3.96,252,2.466,253,0.959,254,5.413,255,2.159,256,2.32,257,3.097,258,1.456,259,0.679,260,4.126,261,3.96,262,5.413,263,3.96,264,3.96,265,3.96,266,3.96,267,3.96,268,3.96,269,3.097,270,3.078,271,2.996,272,5.356,273,3.96,274,5.413,275,3.96,276,4.423,277,3.44,278,6.166,279,3.96,280,3.96,281,3.44,282,3.097,283,2.636,284,3.44,285,2.84,286,4.701,287,2.84,288,3.96,289,4.232,290,5.756,291,3.254,292,6.94,293,2.841,294,3.44,295,3.96,296,3.96,297,5.356,298,5.413,299,3.44,300,3.96,301,2.192,302,2.636,303,1.648,304,3.44,305,3.96,306,3.96,307,3.96,308,3.96,309,3.097,310,1.977,311,2.84,312,2.84,313,2.079,314,3.96,315,3.96,316,3.96,317,3.96,318,3.96,319,3.96,320,1.113,321,3.96,322,3.96]],["t/79",[25,0.024,26,0.045,27,0.024,28,0.024,34,5.139,43,0.041,44,0.024,45,0.039,46,0.041,48,3.929,49,0.109,50,0.109,51,0.041,67,2.462,73,1.137,139,0.628,152,0.319,163,1.663,164,1.137,165,2.152,166,2.152,176,1.371,183,1.371,246,2.375,253,1.095,323,4.524,324,3.011,325,5.917,326,1.732,327,3.245,328,5.917,329,3.537,330,3.245,331,4.524,332,4.524,333,4.524,334,4.524,335,5.917,336,4.524,337,4.524,338,4.524,339,3.011,340,3.929,341,2.375,342,2.258,343,2.375,344,2.375,345,2.258,346,3.938,347,2.258,348,3.245,349,4.524,350,4.524,351,2.504,352,4.524,353,1.424,354,4.524,355,4.524,356,4.524,357,4.524,358,4.524,359,3.275,360,3.011,361,2.258,362,3.537,363,1.965,364,4.524,365,4.524,366,3.537,367,4.524,368,4.524,369,4.524,370,4.524,371,4.524,372,4.524,373,4.524]],["t/81",[25,0.017,26,0.045,27,0.017,28,0.017,29,1.996,43,0.041,44,0.017,45,0.025,46,0.029,47,0.595,49,0.077,50,0.077,51,0.029,73,1.381,80,2.87,98,2.784,124,4.016,138,0.528,139,0.542,147,1.785,152,0.499,159,1.262,161,1.227,162,1.179,163,1.179,164,0.806,165,1.525,166,1.525,167,2.784,168,1.878,170,2.507,172,2.507,173,1.456,174,1.456,175,2.02,203,1.683,242,1.279,253,0.776,259,0.942,293,2.447,299,4.05,374,0.806,375,4.718,376,3.206,377,3.206,378,3.206,379,3.206,380,6.411,381,4.663,382,2.784,383,4.663,384,1.334,385,6.689,386,5.495,387,3.531,388,3.206,389,3.206,390,2.507,391,3.206,392,3.206,393,3.206,394,2.784,395,3.206,396,6.034,397,3.206,398,3.206,399,1.048,400,2.299,401,3.206,402,3.206,403,3.206,404,3.206,405,3.206,406,3.646,407,3.206,408,2.784,409,4.663,410,4.663,411,2.784,412,3.206,413,2.507,414,4.663,415,3.206,416,4.663,417,3.206,418,3.206,419,3.206,420,3.206,421,6.411,422,3.206,423,6.689,424,4.663,425,3.206,426,5.495,427,4.663,428,3.206,429,4.452,430,6.411,431,3.206,432,3.206,433,6.689,434,6.411,435,3.206,436,3.206,437,3.206,438,3.206]],["t/83",[21,0.758,25,0.017,26,0.045,27,0.017,28,0.017,43,0.041,44,0.017,45,0.024,46,0.028,49,0.075,50,0.075,51,0.028,55,2.448,60,2.245,67,1.907,73,1.152,105,3.608,115,4.13,122,3.287,139,0.596,152,0.514,159,0.818,161,1.198,162,1.685,173,1.422,174,1.422,175,1.151,176,0.948,206,2.355,210,0.985,226,2.719,227,2.448,246,1.643,253,0.758,258,1.151,259,0.537,320,0.88,384,1.907,439,5.605,440,3.131,441,3.131,442,5.421,443,3.583,444,6.35,445,4.238,446,4.583,447,3.131,448,5.966,449,4.583,450,5.421,451,3.98,452,3.131,453,4.965,454,3.131,455,3.131,456,2.448,457,5.421,458,3.131,459,3.131,460,3.583,461,5.421,462,2.838,463,5.966,464,2.245,465,2.719,466,2.084,467,2.719,468,3.131,469,2.719,470,3.131,471,1.828,472,4.583,473,3.131,474,4.583,475,3.131,476,1.949,477,3.131,478,3.131,479,3.131,480,3.131,481,3.05,482,3.98,483,2.719,484,2.719,485,1.422,486,2.448,487,1.151,488,3.131,489,2.719,490,3.131,491,1.302,492,3.131,493,2.448,494,2.719,495,4.583,496,6.35,497,4.583,498,3.98,499,2.537,500,2.245,501,5.421,502,5.421,503,4.583,504,3.131,505,5.966,506,3.131,507,3.131,508,3.131,509,4.583,510,3.131,511,4.583,512,2.448,513,3.131,514,3.131,515,3.131,516,3.131]],["t/85",[16,1.61,17,0.894,23,2.066,25,0.011,26,0.045,27,0.011,28,0.011,29,1.282,43,0.041,44,0.011,45,0.035,46,0.018,47,0.382,49,0.049,50,0.049,51,0.018,67,1.989,71,1.206,73,1.591,80,2.274,115,1.282,139,0.529,140,0.592,147,1.595,152,0.485,159,1.094,162,0.757,164,0.517,173,1.507,174,1.507,175,1.927,176,1.005,180,1.788,195,0.616,213,0.935,242,0.821,248,1.172,253,0.498,255,1.323,259,0.353,291,1.507,293,1.742,320,1.171,326,1.27,359,2.307,360,1.37,361,1.027,363,0.894,374,0.517,429,4.081,464,1.476,471,0.821,476,1.282,481,1.37,482,2.882,484,2.882,486,1.61,487,0.757,491,1.734,499,1.139,517,2.059,518,1.476,519,1.476,520,2.059,521,2.059,522,1.788,523,4.168,524,1.61,525,6.33,526,1.206,527,2.882,528,2.882,529,2.059,530,0.979,531,2.059,532,4.168,533,2.059,534,1.788,535,1.788,536,2.059,537,2.059,538,2.595,539,4.168,540,3.318,541,3.318,542,2.059,543,2.059,544,4.168,545,2.059,546,3.62,547,1.788,548,2.059,549,2.059,550,2.059,551,2.059,552,6.131,553,1.578,554,4.78,555,2.059,556,3.318,557,2.059,558,1.476,559,2.059,560,2.059,561,2.059,562,3.318,563,3.318,564,2.059,565,2.059,566,3.318,567,2.059,568,2.059,569,2.059,570,2.059,571,2.594,572,2.882,573,1.788,574,5.603,575,2.059,576,2.059,577,2.059,578,2.059,579,2.059,580,2.059,581,2.059,582,1.788,583,1.476,584,0.935,585,1.788,586,1.788,587,1.788,588,1.476,589,1.476,590,1.61,591,1.788,592,1.476,593,1.788,594,1.788,595,1.788,596,1.788,597,1.788,598,1.788,599,1.788,600,1.788,601,2.594,602,1.788,603,1.788,604,1.788,605,1.61,606,2.059,607,2.059,608,2.059,609,2.059,610,2.059,611,2.059,612,2.059,613,3.318,614,2.059,615,2.059,616,2.059,617,2.059,618,2.059,619,2.059,620,3.318,621,2.059,622,2.059,623,2.059,624,2.059,625,2.059,626,2.059,627,2.059,628,2.059,629,1.37,630,2.059,631,2.059,632,2.059,633,3.318,634,4.152,635,1.742,636,1.788,637,4.168,638,2.594,639,3.318,640,3.259,641,1.476,642,2.976,643,4.78,644,2.381,645,2.059,646,2.066,647,2.059,648,2.059,649,3.318,650,1.37,651,3.259,652,1.61,653,2.059,654,2.059,655,3.259,656,2.059,657,1.282,658,2.059,659,2.059,660,3.318,661,1.139,662,3.318,663,1.788,664,2.059,665,3.318,666,4.168,667,2.059,668,1.788,669,1.081,670,1.61,671,3.318,672,2.059,673,2.059,674,2.059,675,2.059,676,2.059,677,2.059,678,2.059,679,2.059,680,2.059,681,2.059,682,1.61,683,4.168,684,2.059,685,1.788,686,2.059,687,2.059,688,3.318,689,3.318,690,3.318,691,3.318,692,1.788,693,2.059,694,2.059,695,2.059,696,3.318,697,2.059,698,1.788,699,2.059,700,2.059,701,2.594,702,2.059,703,2.059,704,2.059,705,3.318,706,2.059,707,3.318,708,2.059,709,2.059,710,2.059,711,2.059,712,2.059,713,2.059,714,2.059,715,2.059,716,2.059,717,2.059,718,2.059,719,3.318,720,2.059,721,2.059,722,2.059,723,2.059,724,2.059]],["t/87",[4,2.78,21,1.291,25,0.021,26,0.045,27,0.021,28,0.021,39,5.296,43,0.038,44,0.021,45,0.037,46,0.035,47,0.99,49,0.093,50,0.093,51,0.035,73,1.532,139,0.59,140,0.952,164,1.34,191,3.956,195,0.99,200,3.031,213,2.423,253,1.291,259,0.914,327,4.94,330,4.373,374,0.974,518,2.78,519,2.78,530,1.844,644,2.423,725,4.17,726,5.333,727,5.333,728,5.333,729,2.853,730,3.375,731,4.94,732,3.366,733,5.333,734,3.031,735,3.876,736,3.847,737,3.876,738,6.098,739,5.333,740,4.632,741,5.333,742,3.825,743,4.17,744,5.333,745,5.333,746,3.876,747,3.825,748,3.876,749,3.876,750,3.876,751,3.876,752,3.876,753,3.876,754,3.876,755,3.876,756,3.876,757,3.876,758,5.333,759,3.366,760,3.876,761,4.632,762,3.876,763,3.876,764,3.876,765,3.876,766,3.876,767,3.876,768,3.876,769,3.876,770,3.876,771,3.876,772,3.876,773,3.876,774,3.876,775,3.876,776,3.876,777,3.876,778,3.876]],["t/89",[21,1.232,25,0.027,26,0.044,27,0.027,28,0.027,43,0.039,44,0.027,45,0.034,46,0.046,47,0.944,49,0.122,50,0.122,51,0.046,139,0.573,140,1.138,179,3.978,195,1.184,248,1.798,253,1.687,259,0.872,374,1.278,518,3.649,519,3.649,730,3.531,731,4.575,734,4.987,736,3.736,742,4.575,743,3.978,747,4.575,779,4.419,780,4.419,781,4.419,782,5.088,783,5.088,784,5.088,785,5.088,786,2.42,787,5.088,788,5.088,789,5.088,790,5.088,791,4.419,792,5.088,793,5.088,794,5.088,795,5.088,796,5.088,797,5.088,798,3.649,799,5.088,800,5.088]],["t/91",[21,1.6,25,0.029,26,0.044,27,0.029,28,0.029,43,0.038,44,0.029,45,0.035,46,0.048,47,1,49,0.129,50,0.129,51,0.048,139,0.594,140,0.961,148,2.564,191,2.829,195,1,206,2.872,207,2.448,227,4.214,253,1.6,259,1.133,342,2.69,344,2.829,345,2.69,347,2.69,374,1.354,635,2.829,736,3.156,742,4.741,743,4.214,747,3.865,801,5.389,802,3.587,803,5.389,804,4.68,805,5.389,806,5.389,807,3.865,808,2.829,809,3.587]],["t/93",[21,1.181,25,0.026,26,0.044,27,0.026,28,0.026,43,0.033,44,0.026,45,0.037,46,0.044,47,1.268,49,0.117,50,0.117,51,0.044,139,0.558,140,0.87,164,1.226,195,0.905,213,2.215,248,1.723,253,1.503,259,0.836,320,1.371,327,3.498,330,3.498,343,2.56,374,1.226,518,3.498,519,3.498,655,3.813,730,4.112,731,4.454,732,4.236,734,4.856,736,3.638,740,4.236,742,3.498,747,4.454,779,4.236,780,4.236,810,4.236,811,4.877,812,4.877,813,6.21,814,4.877,815,4.877,816,4.877,817,4.877,818,4.236,819,4.877,820,6.833,821,4.236,822,4.236,823,4.236,824,4.236,825,4.236,826,4.236,827,4.236,828,4.236,829,4.877,830,4.236,831,4.877]],["t/95",[2,1.062,5,1.859,8,1.062,12,0.814,17,1.69,25,0.007,26,0.045,27,0.011,28,0.007,43,0.041,44,0.007,45,0.031,46,0.011,47,0.227,49,0.029,50,0.029,51,0.011,57,1.062,65,0.877,67,0.89,69,3.304,73,0.307,80,2.633,89,0.877,122,1.535,138,0.759,139,0.713,144,1.062,147,1.092,152,0.524,156,2.677,159,1.174,161,1.763,162,1.694,173,0.556,174,0.556,175,1.694,176,0.371,193,0.814,204,0.877,207,1.555,210,0.673,220,1.859,238,1.424,246,2.806,255,1.838,258,1.694,260,2.422,291,1.767,293,1.123,313,1.123,326,1.489,363,0.93,374,0.307,413,1.674,465,1.859,471,2.388,491,2.224,524,0.957,530,1.018,553,1.628,571,3.345,572,4.001,601,0.957,642,1.332,652,1.674,685,1.062,692,1.062,701,5.303,731,0.877,802,2.847,832,4.607,833,1.223,834,1.223,835,3.89,836,2.042,837,2.853,838,2.231,839,3.609,840,2.853,841,2.853,842,0.814,843,1.223,844,1.223,845,4.381,846,2.853,847,2.853,848,2.14,849,1.223,850,2.853,851,2.853,852,1.498,853,2.14,854,2.14,855,3.89,856,4.607,857,3.068,858,2.14,859,4.001,860,4.889,861,2.14,862,2.14,863,2.14,864,2.14,865,2.14,866,2.14,867,2.14,868,2.14,869,1.674,870,3.423,871,1.223,872,2.853,873,2.853,874,2.853,875,2.853,876,3.423,877,2.853,878,2.853,879,2.853,880,1.223,881,2.14,882,2.14,883,2.853,884,1.062,885,2.14,886,1.223,887,3.89,888,1.062,889,2.14,890,1.223,891,1.223,892,1.223,893,1.223,894,1.223,895,2.14,896,1.223,897,1.223,898,1.223,899,2.973,900,1.223,901,1.062,902,0.957,903,1.223,904,2.853,905,1.223,906,1.223,907,2.853,908,2.973,909,4.889,910,1.223,911,5.346,912,1.223,913,1.223,914,1.223,915,1.859,916,2.231,917,1.223,918,2.853,919,1.223,920,1.062,921,1.223,922,1.223,923,1.062,924,2.14,925,1.223,926,1.223,927,1.223,928,1.223,929,0.509,930,1.223,931,7.041,932,1.223,933,1.223,934,1.223,935,1.062,936,1.223,937,0.877,938,0.957,939,1.223,940,1.223,941,1.223,942,2.677,943,1.223,944,1.223,945,1.223,946,1.223,947,2.14,948,2.14,949,1.223,950,0.877,951,1.223,952,1.223,953,1.223,954,1.223,955,1.223,956,1.535,957,1.223,958,1.223,959,2.14,960,1.223,961,1.223,962,1.223,963,1.223,964,1.223,965,1.223,966,1.223,967,0.814,968,1.223,969,1.223,970,1.223,971,1.223,972,1.223,973,1.223,974,1.223,975,1.223,976,1.223,977,1.223,978,1.223,979,1.223,980,1.223,981,1.223,982,1.223,983,1.223,984,1.062,985,1.062,986,1.062,987,1.223,988,1.223,989,1.223,990,1.223,991,1.223,992,1.223,993,1.223,994,1.223,995,1.223,996,1.223,997,1.223,998,1.223,999,1.062,1000,1.062,1001,1.223,1002,1.223,1003,1.223,1004,3.89,1005,3.89,1006,4.278,1007,4.278,1008,3.423,1009,3.423,1010,1.223,1011,3.423,1012,1.223,1013,3.89,1014,2.853,1015,1.223,1016,0.814]],["t/97",[18,2.763,21,1.405,25,0.019,26,0.045,27,0.019,28,0.019,43,0.039,44,0.019,45,0.034,46,0.032,47,0.928,49,0.085,50,0.085,51,0.032,63,2.535,64,2.352,115,2.2,138,0.582,139,0.638,140,1.035,152,0.409,175,1.299,183,1.071,193,2.352,195,1.077,242,1.994,259,1.185,301,1.956,302,2.352,384,1.47,387,1.764,394,3.069,399,1.155,462,3.001,464,2.535,466,3.862,471,1.994,476,2.2,485,1.605,491,1.47,499,1.956,530,1.681,640,2.763,641,3.586,644,1.605,669,1.855,729,1.535,842,2.352,929,1.47,1017,2.2,1018,2.2,1019,2.2,1020,1.956,1021,3.069,1022,5.48,1023,5,1024,4.343,1025,2.352,1026,2.763,1027,3.069,1028,5.097,1029,3.069,1030,2.763,1031,2.763,1032,2.07,1033,3.91,1034,2.2,1035,4.958,1036,4.958,1037,3.534,1038,2.535,1039,2.763,1040,3.534,1041,2.763,1042,3.069,1043,2.535,1044,4.537,1045,2.763,1046,2.763,1047,3.91,1048,2.07,1049,4.537,1050,2.763,1051,2.763,1052,2.763,1053,3.534,1054,2.763,1055,2.763,1056,2.535,1057,5.206,1058,2.763,1059,2.352,1060,2.763,1061,2.535,1062,3.534,1063,3.534,1064,2.763,1065,2.763,1066,2.763,1067,2.2,1068,3.069,1069,2.535,1070,3.91,1071,4.537,1072,3.91,1073,4.537]],["t/99",[17,3.103,21,1.158,25,0.026,26,0.045,27,0.026,28,0.026,43,0.038,44,0.026,45,0.038,46,0.043,47,0.888,49,0.115,50,0.115,51,0.043,67,2.552,139,0.641,140,0.853,148,2.276,152,0.337,173,2.173,174,2.173,175,1.759,176,1.449,183,1.449,195,0.888,206,2.665,217,2.276,246,3.22,253,1.485,259,1.161,324,3.184,326,1.831,341,2.511,342,3.062,343,2.511,344,2.511,345,2.388,346,4.083,347,2.388,348,3.431,374,1.202,657,2.978,836,2.511,1016,3.184,1074,4.155,1075,3.431,1076,3.74,1077,3.74,1078,3.184,1079,3.184,1080,4.155,1081,4.155,1082,4.155,1083,4.155,1084,4.155,1085,2.648,1086,3.74,1087,3.74,1088,4.155]],["t/101",[21,1.595,25,0.029,26,0.044,27,0.029,28,0.029,43,0.038,44,0.029,45,0.035,46,0.048,47,0.995,49,0.129,50,0.129,51,0.048,73,1.793,139,0.592,140,0.956,148,2.55,191,2.813,195,0.995,206,2.862,207,2.435,253,1.595,259,0.919,327,5.116,330,4.725,342,2.675,344,2.813,345,2.675,347,2.675,374,1.347,485,2.435,725,5.151,736,3.14,804,4.655,807,3.844,808,2.813,809,3.567,984,4.655,1089,4.655,1090,5.36,1091,5.36]],["t/103",[25,0.028,26,0.045,27,0.028,28,0.028,43,0.038,44,0.028,45,0.035,46,0.047,47,0.979,49,0.127,50,0.127,51,0.047,138,1.074,152,0.46,173,2.396,174,2.396,175,1.939,210,1.66,259,0.904,302,3.511,374,1.326,399,1.725,464,4.679,487,2.604,1043,3.784,1092,5.275,1093,4.125,1094,5.275,1095,5.275,1096,5.275,1097,5.275,1098,5.666,1099,6.524,1100,5.275,1101,6.524,1102,5.275,1103,5.275,1104,5.275,1105,5.275,1106,5.275]],["t/105",[21,1.211,25,0.019,26,0.045,27,0.019,28,0.019,43,0.038,44,0.019,45,0.031,46,0.032,49,0.085,50,0.085,51,0.032,63,2.535,64,3.328,115,2.2,138,0.582,139,0.638,140,0.892,152,0.445,175,1.299,183,1.071,193,3.328,195,0.928,207,2.271,242,2.315,253,0.856,259,1.142,301,1.956,313,1.855,384,1.47,387,1.764,399,1.155,462,3.381,466,4.199,471,1.994,485,1.605,491,2.08,499,1.956,553,1.681,640,2.763,644,1.605,669,1.855,729,1.535,808,1.855,839,1.605,929,1.47,937,2.535,1020,1.956,1022,5.04,1024,4.343,1025,2.352,1026,2.763,1027,3.069,1028,5.097,1030,2.763,1031,2.763,1032,2.07,1033,3.91,1035,4.958,1036,4.958,1041,2.763,1042,3.069,1043,2.535,1044,4.537,1045,3.91,1046,2.763,1047,3.91,1048,2.07,1049,4.537,1050,2.763,1051,2.763,1052,2.763,1054,2.763,1055,2.763,1056,2.535,1057,5.206,1058,2.763,1059,2.352,1060,2.763,1061,2.535,1064,2.763,1065,2.763,1066,2.763,1067,2.2,1068,3.069,1069,2.535,1070,3.91,1071,4.537,1072,3.91,1073,4.537,1107,3.069,1108,5.04,1109,3.534,1110,3.534,1111,3.534,1112,3.534,1113,3.069,1114,3.069,1115,3.534,1116,3.534,1117,3.534,1118,3.534,1119,3.534,1120,3.534,1121,3.069]],["t/107",[17,1.821,25,0.022,26,0.045,27,0.022,28,0.022,43,0.04,44,0.022,45,0.03,46,0.038,49,0.101,50,0.101,51,0.038,73,1.414,138,0.926,152,0.448,163,1.541,164,1.054,179,3.278,183,1.704,203,2.201,210,1.77,248,1.481,249,1.904,259,0.965,301,2.321,302,2.79,303,1.744,310,2.093,313,2.201,326,1.605,329,3.278,339,2.79,351,3.114,353,1.77,399,1.371,462,3.02,522,3.641,527,3.641,553,1.994,646,2.61,657,2.61,729,1.821,730,2.321,786,1.994,929,1.744,1020,2.321,1034,2.61,1085,2.321,1107,3.641,1108,5.893,1121,3.641,1122,4.193,1123,4.193,1124,4.193,1125,4.193,1126,4.193,1127,4.193,1128,4.193,1129,2.808,1130,4.193,1131,4.193,1132,4.193,1133,4.193,1134,2.456,1135,4.193,1136,3.641,1137,4.193,1138,4.193,1139,4.193,1140,6.349,1141,4.193,1142,4.193,1143,4.193,1144,3.641,1145,4.193,1146,4.193,1147,4.193,1148,4.193,1149,4.193,1150,4.193,1151,3.007,1152,3.007,1153,3.278,1154,3.278,1155,4.399,1156,5.626,1157,4.193,1158,1.904,1159,4.193,1160,3.114,1161,4.193,1162,4.193]],["t/109",[21,1.616,25,0.029,26,0.044,27,0.029,28,0.029,43,0.036,44,0.029,45,0.036,46,0.049,49,0.131,50,0.131,51,0.049,139,0.6,140,0.977,148,2.606,152,0.386,191,2.875,195,1.016,206,2.9,207,2.488,259,0.939,301,3.032,342,2.734,344,2.875,345,2.734,347,2.734,399,1.791,807,3.928,808,2.875,809,3.646,929,2.279,1034,3.41,1085,3.032,1158,2.488,1163,4.757,1164,2.875,1165,4.283,1166,4.757,1167,4.757,1168,4.757,1169,4.283]],["t/111",[21,1.216,25,0.027,26,0.044,27,0.027,28,0.027,43,0.034,44,0.027,45,0.027,46,0.045,47,0.932,49,0.121,50,0.121,51,0.045,73,1.262,139,0.568,140,0.896,164,1.262,195,0.932,203,3.636,213,2.282,217,2.39,242,2.004,374,1.262,460,3.928,491,2.09,499,2.781,629,3.344,786,2.39,1039,3.928,1152,4.969,1155,5.686,1165,3.928,1170,5.024,1171,4.363,1172,5.024,1173,3.603,1174,5.024,1175,4.363,1176,4.363,1177,5.024,1178,5.024,1179,4.363,1180,4.363,1181,3.603,1182,5.024,1183,5.024,1184,3.603,1185,5.024,1186,4.363,1187,5.024,1188,5.024,1189,5.024,1190,3.344,1191,5.024,1192,5.024,1193,3.603,1194,5.024,1195,6.328,1196,5.024]],["t/113",[21,1.372,25,0.018,26,0.045,27,0.018,28,0.018,43,0.038,44,0.018,45,0.033,46,0.03,49,0.081,50,0.081,51,0.03,60,2.427,63,2.427,64,2.253,71,2.84,115,2.107,138,0.933,139,0.612,140,0.865,152,0.437,175,1.244,183,1.025,193,3.227,195,0.9,207,1.537,242,1.35,253,0.819,259,1.123,301,1.873,320,1.84,387,2.42,399,1.106,462,3.415,466,3.227,471,1.934,485,1.537,491,2.017,499,1.873,500,2.427,644,1.537,669,1.776,808,1.776,985,4.211,1020,1.873,1028,4.064,1030,2.646,1031,2.646,1032,1.982,1033,2.646,1035,4.888,1036,4.888,1044,4.43,1045,2.646,1046,2.646,1047,3.791,1048,1.982,1049,4.43,1050,2.646,1051,2.646,1052,2.646,1055,2.646,1056,3.478,1057,5.121,1058,2.646,1059,2.253,1060,2.646,1061,2.427,1064,2.646,1065,2.646,1066,2.646,1067,2.107,1070,3.791,1071,4.43,1072,3.791,1073,4.43,1113,2.94,1114,2.94,1158,1.537,1197,4.064,1198,3.385,1199,2.94,1200,2.646,1201,3.385,1202,5.919,1203,4.849,1204,3.385,1205,3.385,1206,3.385,1207,3.385,1208,3.385,1209,3.385,1210,3.385,1211,3.385,1212,3.385,1213,3.385,1214,2.427,1215,4.849,1216,3.385,1217,3.385,1218,2.94,1219,2.94,1220,4.921,1221,3.385,1222,3.385,1223,3.385,1224,3.385]],["t/115",[25,0.02,26,0.045,27,0.02,28,0.02,43,0.041,44,0.02,45,0.028,46,0.034,47,1.21,49,0.091,50,0.091,51,0.034,67,1.585,73,1.638,80,2.507,139,0.473,140,0.68,152,0.269,159,0.94,164,0.957,195,0.707,242,1.52,248,2.304,249,2.394,259,0.904,283,2.536,285,2.732,287,2.732,291,2.394,303,1.585,320,1.481,359,2.109,374,0.957,387,1.901,400,2.732,471,2.102,487,1.401,526,2.231,786,1.812,929,1.585,1017,2.372,1018,2.372,1019,2.372,1134,2.231,1164,2,1181,2.732,1225,3.81,1226,3.81,1227,5.27,1228,3.81,1229,5.27,1230,3.81,1231,3.309,1232,3.81,1233,3.81,1234,3.81,1235,3.309,1236,5.248,1237,3.309,1238,4.577,1239,3.309,1240,5.248,1241,3.309,1242,3.309,1243,3.309,1244,3.309,1245,4.121,1246,3.309,1247,3.309,1248,3.309,1249,3.309,1250,3.309,1251,3.309,1252,4.339,1253,3.309,1254,2.979,1255,3.309,1256,3.309,1257,2.979,1258,4.577,1259,2.979,1260,2.979,1261,4.577,1262,5.248,1263,2.979,1264,4.577,1265,2.979,1266,4.577,1267,2.979,1268,3.309,1269,3.309,1270,3.309,1271,3.309,1272,3.309,1273,3.309,1274,3.309,1275,3.309,1276,5.663,1277,5.945,1278,2.979,1279,5.248]],["t/117",[21,0.972,25,0.021,26,0.045,27,0.021,28,0.021,43,0.033,44,0.021,45,0.029,46,0.036,47,0.745,49,0.096,50,0.096,51,0.036,73,1.675,140,0.717,148,1.91,152,0.283,159,0.717,161,1.537,162,2.009,163,1.476,164,1.373,165,1.91,166,1.91,195,0.745,203,3.26,206,1.745,207,1.824,210,1.264,213,2.482,248,1.419,249,1.824,253,1.323,259,0.937,269,3.14,293,3.26,301,2.223,302,2.673,303,1.671,310,2.004,324,2.673,342,3.481,343,2.108,344,2.108,345,2.004,347,2.004,374,1.009,487,1.476,491,1.671,499,2.223,641,3.919,669,2.108,808,2.108,809,2.673,810,3.488,929,1.671,1020,2.223,1021,3.488,1039,4.273,1043,2.88,1134,2.352,1152,4.455,1164,2.108,1171,3.488,1173,2.88,1180,3.488,1181,2.88,1190,4.134,1252,2.673,1278,3.14,1280,4.016,1281,4.016,1282,4.016,1283,4.016,1284,2.88,1285,4.016,1286,4.016,1287,4.016,1288,4.016,1289,4.016,1290,4.016,1291,3.488,1292,4.016,1293,2.673,1294,3.488,1295,4.016,1296,3.488,1297,4.016,1298,4.746,1299,4.016,1300,6.973,1301,4.016,1302,5.394,1303,4.016,1304,4.016,1305,4.016,1306,4.016,1307,3.14,1308,4.016,1309,4.016,1310,4.016,1311,3.14,1312,4.016,1313,4.016,1314,4.016,1315,3.14,1316,5.464,1317,4.016,1318,4.016]],["t/119",[25,0.021,26,0.045,27,0.021,28,0.021,43,0.04,44,0.021,45,0.021,46,0.035,47,0.718,51,0.035,73,0.972,138,0.637,139,0.478,148,1.84,152,0.273,163,1.422,164,1.531,165,1.84,166,1.84,168,3.12,175,1.422,202,2.658,203,2.031,238,2.575,248,1.367,249,2.419,255,2.125,256,2.266,282,3.025,309,3.025,320,1.087,351,3.372,374,0.972,382,3.36,411,3.36,530,1.84,571,3.025,584,2.419,629,2.575,642,3.316,669,2.031,967,2.575,1056,4.707,1089,3.36,1190,4.054,1255,3.36,1284,2.775,1319,6.563,1320,5.326,1321,3.869,1322,2.575,1323,1.931,1324,3.36,1325,4.763,1326,4.165,1327,3.869,1328,3.869,1329,3.869,1330,5.326,1331,5.326,1332,3.36,1333,3.36,1334,3.36,1335,5.326,1336,3.36,1337,3.869,1338,2.575,1339,3.869,1340,3.869,1341,5.326,1342,3.869,1343,5.326,1344,3.869,1345,3.869,1346,3.36,1347,3.545,1348,3.869,1349,3.869,1350,4.054,1351,5.326,1352,3.869,1353,3.869,1354,2.534,1355,3.869,1356,3.36,1357,3.869,1358,3.869,1359,3.869,1360,6.563,1361,3.869,1362,5.326,1363,3.869,1364,5.326,1365,3.869,1366,3.869,1367,3.869,1368,3.869,1369,3.869,1370,5.326,1371,3.869,1372,3.869,1373,3.869,1374,3.869,1375,3.869,1376,6.563,1377,3.869,1378,3.869,1379,3.869]],["t/121",[25,0.02,26,0.045,27,0.02,28,0.02,43,0.039,44,0.02,45,0.027,46,0.033,47,1.098,49,0.088,50,0.088,51,0.033,67,1.524,71,2.146,73,1.611,80,2.44,139,0.461,140,0.654,152,0.258,159,0.915,164,0.921,195,0.68,203,2.692,213,2.33,217,2.44,242,1.461,248,2.091,249,2.33,259,0.879,283,2.438,285,2.627,287,2.627,291,2.33,303,1.524,320,1.441,387,1.828,400,2.627,471,2.046,487,1.347,526,2.146,786,1.743,929,1.524,986,3.182,1017,2.281,1018,2.281,1019,2.281,1134,2.146,1152,3.678,1164,1.923,1190,4.491,1235,3.182,1236,5.139,1237,3.182,1238,4.454,1239,3.182,1240,5.139,1241,3.182,1242,3.182,1243,3.182,1244,3.182,1245,4.01,1246,3.182,1247,3.182,1248,3.182,1249,3.182,1250,3.182,1251,3.182,1252,4.491,1253,3.182,1254,2.864,1256,3.182,1257,2.864,1258,4.454,1259,2.864,1260,2.864,1261,5.568,1262,6.236,1263,2.864,1264,5.139,1265,2.864,1266,5.139,1267,2.864,1268,3.182,1269,3.182,1270,3.182,1271,3.182,1272,3.182,1273,3.182,1274,3.182,1275,3.182,1276,5.568,1277,5.861,1278,2.864,1279,5.139,1380,3.663,1381,3.663,1382,3.663,1383,3.663,1384,3.663,1385,3.663,1386,3.663,1387,3.663,1388,3.663]],["t/123",[21,1.098,25,0.016,26,0.045,27,0.016,28,0.016,43,0.04,44,0.016,45,0.041,47,0.573,51,0.028,69,3.856,73,1.351,138,0.747,152,0.418,164,1.489,202,2.264,207,1.402,213,2.692,237,2.681,248,1.091,249,1.402,255,1.809,256,2.657,258,2.179,259,0.529,281,2.681,283,3.944,313,1.62,341,1.62,359,3.495,360,2.055,363,1.341,374,0.776,485,1.402,487,1.668,524,3.547,526,3.471,558,4.251,590,2.414,646,1.922,845,3.856,852,2.381,859,3.939,938,2.414,1151,2.214,1155,4.937,1231,2.681,1245,3.547,1252,3.579,1263,4.634,1265,4.634,1338,3.944,1347,3.019,1354,3.14,1389,3.087,1390,3.087,1391,3.087,1392,3.087,1393,6.601,1394,5.927,1395,3.087,1396,3.087,1397,3.087,1398,6.314,1399,6.314,1400,5.377,1401,6.601,1402,3.087,1403,3.087,1404,3.087,1405,4.536,1406,5.147,1407,4.536,1408,5.927,1409,4.536,1410,3.547,1411,3.939,1412,3.087,1413,3.087,1414,6.601,1415,3.087,1416,3.087,1417,3.087,1418,5.377,1419,3.087,1420,4.536,1421,3.087,1422,3.087,1423,3.087,1424,3.087,1425,2.681,1426,3.087,1427,3.087,1428,3.087,1429,6.601,1430,3.087,1431,5.377,1432,3.087,1433,4.536,1434,3.087,1435,2.681,1436,3.087,1437,3.087,1438,3.087,1439,3.087,1440,3.939,1441,3.087,1442,3.087,1443,3.087,1444,3.087,1445,3.087,1446,5.927,1447,3.939,1448,3.087,1449,3.087,1450,3.087,1451,3.087,1452,2.681,1453,3.087,1454,3.939,1455,4.536,1456,3.087,1457,3.087,1458,2.681,1459,3.939,1460,3.087,1461,3.087,1462,2.681,1463,5.377,1464,3.087,1465,3.087]],["t/125",[25,0.028,26,0.044,27,0.028,28,0.028,43,0.035,44,0.028,45,0.028,46,0.047,47,0.971,51,0.047,58,4.092,139,0.583,140,0.934,152,0.369,159,0.934,163,1.924,164,1.315,165,2.49,166,2.49,213,2.949,252,4.594,255,2.088,256,3.066,257,4.092,259,0.897,270,2.612,303,2.178,311,3.754,312,3.754,320,1.471,374,1.315,530,2.49,558,3.754,629,3.483,661,2.897,669,2.747,1134,3.066,1200,4.092,1284,3.754,1323,2.612,1325,4.092,1347,3.483,1466,6.492,1467,5.234,1468,4.042,1469,4.546,1470,5.234,1471,5.234,1472,3.483,1473,4.092,1474,4.546,1475,4.546,1476,5.234]],["t/127",[25,0.019,26,0.045,27,0.019,28,0.019,43,0.04,44,0.019,45,0.034,46,0.032,47,0.666,51,0.032,64,2.39,73,1.471,139,0.655,140,0.641,152,0.413,159,0.902,162,1.32,163,1.859,164,1.271,165,1.708,166,1.708,173,1.631,175,1.32,195,0.666,206,1.56,210,1.13,213,2.297,242,1.432,248,1.787,249,2.297,255,2.017,256,2.103,257,2.808,283,2.39,285,2.575,287,2.575,289,2.808,290,3.119,303,2.104,310,1.792,320,1.421,342,2.922,344,1.885,345,1.792,346,2.39,347,1.792,361,1.792,362,2.808,363,1.56,374,0.902,384,1.494,429,3.366,476,2.236,483,3.119,491,2.435,499,3.24,553,2.785,573,3.119,584,1.631,661,1.988,761,3.119,781,4.392,798,2.575,1000,3.119,1173,2.575,1184,2.575,1291,3.119,1296,4.392,1298,4.392,1302,4.392,1322,2.39,1323,1.792,1324,4.392,1334,3.119,1346,3.119,1472,2.39,1473,2.808,1474,3.119,1477,5.854,1478,6.354,1479,5.854,1480,6.949,1481,2.808,1482,3.591,1483,3.591,1484,3.591,1485,2.575,1486,6.436,1487,3.591,1488,3.591,1489,5.854,1490,3.591,1491,3.591,1492,3.591,1493,3.591,1494,3.591,1495,3.591,1496,3.591,1497,3.591,1498,3.119,1499,2.39,1500,3.591,1501,3.591,1502,3.591,1503,3.591,1504,3.591,1505,5.057,1506,3.119,1507,3.119,1508,3.591,1509,3.591,1510,3.591,1511,3.591,1512,3.591,1513,3.591,1514,3.591,1515,5.057,1516,3.591,1517,3.591,1518,3.591,1519,3.591,1520,3.591,1521,3.591,1522,3.591]],["t/129",[25,0.026,26,0.045,27,0.026,28,0.026,43,0.033,44,0.026,45,0.036,46,0.044,47,1.151,49,0.117,50,0.117,51,0.044,73,1.223,140,0.868,174,2.21,175,1.789,176,1.474,195,0.903,217,2.314,242,1.941,246,2.554,248,1.719,259,1.063,329,3.804,339,3.238,650,5.134,730,3.432,759,4.225,929,2.024,950,3.489,1017,3.029,1018,3.029,1019,3.029,1307,3.804,1486,4.225,1506,4.225,1523,3.804,1524,5.385,1525,4.865,1526,4.865,1527,4.865,1528,4.865,1529,4.865,1530,4.865,1531,4.865,1532,4.865,1533,4.865,1534,4.865,1535,4.865,1536,3.804,1537,4.865,1538,2.373,1539,4.865,1540,4.865,1541,3.489,1542,3.804,1543,3.804,1544,6.201,1545,4.865,1546,4.865,1547,3.804]],["t/131",[12,2.888,23,1.81,25,0.016,26,0.045,27,0.016,28,0.016,29,1.81,43,0.028,44,0.016,45,0.028,46,0.026,47,0.54,49,0.07,50,0.07,51,0.026,73,1.304,80,2.064,89,2.085,105,2.888,138,0.479,139,0.553,147,1.113,152,0.472,159,1.099,173,1.321,174,1.321,175,1.069,176,0.881,210,1.365,217,1.383,246,1.526,248,1.027,253,0.704,271,2.402,291,1.321,293,1.526,303,1.21,313,1.526,363,1.263,374,0.731,406,4.059,429,2.888,443,2.274,445,2.274,453,2.274,481,1.935,485,1.971,486,2.274,493,3.393,498,2.525,530,1.383,538,1.81,584,1.321,642,2.701,644,1.971,650,4.099,661,1.609,736,1.703,802,2.888,852,1.526,869,3.393,902,2.274,938,2.274,956,2.085,1026,3.393,1093,2.274,1184,3.723,1293,1.935,1307,2.274,1322,1.935,1338,1.935,1472,1.935,1524,2.525,1536,2.274,1538,1.113,1548,2.908,1549,2.525,1550,2.908,1551,2.908,1552,2.525,1553,2.358,1554,2.908,1555,2.908,1556,2.525,1557,2.525,1558,4.339,1559,2.908,1560,2.085,1561,2.274,1562,2.908,1563,2.908,1564,2.908,1565,2.908,1566,2.525,1567,5.191,1568,4.509,1569,2.908,1570,2.908,1571,2.525,1572,2.908,1573,2.525,1574,2.525,1575,1.321,1576,2.806,1577,2.525,1578,2.255,1579,2.278,1580,2.908,1581,4.059,1582,2.806,1583,2.525,1584,2.525,1585,2.525,1586,2.525,1587,2.525,1588,3.769,1589,2.525,1590,2.525,1591,2.274,1592,2.274,1593,2.525,1594,2.525,1595,2.908,1596,2.908,1597,2.908,1598,2.908,1599,2.525,1600,2.525,1601,2.525,1602,4.746,1603,2.525,1604,3.769,1605,2.525,1606,3.769,1607,3.393,1608,2.525,1609,4.999,1610,2.525,1611,2.525,1612,2.525,1613,2.525,1614,2.525,1615,4.509,1616,2.525,1617,2.525,1618,1.263,1619,1.263,1620,4.059,1621,2.908,1622,2.908,1623,4.509,1624,2.525,1625,2.525,1626,2.525,1627,2.525,1628,4.509,1629,4.059,1630,2.525,1631,3.393,1632,2.525,1633,2.525,1634,4.509,1635,2.525,1636,2.525,1637,2.525,1638,2.525,1639,2.525,1640,3.769,1641,2.525,1642,2.525,1643,2.525,1644,2.525,1645,2.525,1646,2.525,1647,3.769,1648,2.525,1649,2.525,1650,2.525,1651,1.263,1652,2.525,1653,2.525,1654,2.525,1655,1.263,1656,2.525,1657,2.908,1658,4.339,1659,2.525,1660,2.908,1661,2.908,1662,2.274,1663,2.908,1664,2.908,1665,2.908,1666,2.525,1667,2.908]],["t/133",[17,1.818,18,3.271,25,0.022,26,0.045,27,0.022,28,0.022,43,0.038,44,0.022,45,0.038,46,0.038,47,1.042,49,0.1,50,0.1,51,0.038,71,2.451,100,2.785,138,0.689,140,1.002,163,1.538,164,1.051,165,1.99,166,1.99,168,2.451,195,1.042,203,2.949,210,1.316,252,2.605,259,0.717,326,1.601,456,3.271,644,1.9,650,3.739,836,2.196,929,2.337,937,3.001,1017,2.605,1018,2.605,1019,2.605,1025,2.785,1038,3.001,1315,3.271,1354,2.672,1523,3.271,1536,3.271,1538,1.601,1549,3.634,1553,3.08,1568,4.879,1575,1.9,1576,2.755,1577,4.879,1578,3.072,1582,2.441,1618,1.818,1619,1.818,1651,2.755,1655,2.441,1668,4.184,1669,4.184,1670,3.634,1671,4.184,1672,4.184,1673,4.184,1674,4.184,1675,1.9,1676,2.881,1677,4.184,1678,3.634,1679,4.879,1680,5.618,1681,3.634,1682,5.618,1683,4.184,1684,5.508,1685,4.184,1686,5.618,1687,4.184,1688,5.618,1689,4.184,1690,4.184,1691,3.634,1692,4.184,1693,4.184,1694,4.184,1695,4.184,1696,4.184,1697,4.184,1698,4.184,1699,4.184,1700,4.184,1701,3.634,1702,4.184]],["t/135",[25,0.027,26,0.045,27,0.027,28,0.027,43,0.042,44,0.027,45,0.037,46,0.045,49,0.119,50,0.119,51,0.045,138,0.817,139,0.564,140,0.885,152,0.35,195,1.278,384,2.612,399,1.622,547,5.453,1129,3.134,1160,2.746,1354,2.987,1703,3.302,1704,5.386,1705,4.961,1706,4.309,1707,4.309,1708,3.879,1709,4.961,1710,4.961,1711,4.961,1712,4.961,1713,4.961,1714,4.961,1715,4.961,1716,4.961,1717,4.961,1718,4.961,1719,4.961,1720,6.278,1721,6.278,1722,4.961,1723,4.961,1724,3.558,1725,6.278,1726,3.302,1727,6.278,1728,4.961,1729,4.961]],["t/137",[17,1.583,25,0.019,26,0.045,27,0.019,28,0.019,43,0.041,44,0.019,45,0.036,46,0.033,49,0.087,50,0.087,51,0.033,60,2.613,73,0.916,100,2.425,138,0.6,139,0.574,140,0.911,149,3.164,152,0.416,159,0.65,163,1.339,164,0.916,183,1.104,195,0.948,282,2.849,291,1.655,320,1.024,326,1.395,341,1.912,384,1.516,399,1.191,462,3.203,471,2.038,836,1.912,1032,2.134,1048,2.134,1059,2.425,1067,2.268,1069,2.613,1129,2.55,1160,2.017,1202,4.437,1214,2.613,1218,3.164,1219,3.164,1523,2.849,1701,3.164,1703,2.425,1704,3.995,1706,3.164,1707,3.164,1730,6.734,1731,5.109,1732,3.643,1733,3.643,1734,3.643,1735,5.9,1736,5.9,1737,5.109,1738,6.981,1739,6.395,1740,6.981,1741,6.395,1742,3.643,1743,3.643,1744,3.643,1745,3.643,1746,3.164,1747,3.643,1748,4.437,1749,3.164,1750,3.164,1751,3.164,1752,4.437,1753,3.164,1754,3.643,1755,3.643,1756,3.643,1757,3.643,1758,5.109,1759,3.643,1760,3.643,1761,2.849,1762,3.643,1763,3.643,1764,5.109,1765,3.643,1766,3.643,1767,3.643,1768,3.643,1769,3.643,1770,3.643,1771,3.643,1772,3.643,1773,3.643,1774,3.643,1775,3.643,1776,5.109,1777,5.109]],["t/139",[4,1.631,13,3.193,24,1.631,25,0.019,26,0.045,27,0.012,28,0.012,43,0.037,44,0.012,45,0.037,46,0.02,47,0.422,51,0.02,69,1.631,71,1.332,80,1.709,138,0.907,139,0.4,140,0.406,148,1.082,152,0.509,159,0.902,164,1.119,168,1.332,191,2.655,195,0.422,203,1.193,204,1.631,206,0.988,217,1.082,242,1.433,248,1.946,255,1.433,256,1.332,260,1.415,269,1.778,270,1.135,284,1.975,286,1.975,289,2.808,293,1.885,294,4.784,303,2.104,310,1.793,311,1.631,312,1.631,320,0.639,326,0.87,353,1.401,361,1.793,362,2.808,363,1.56,374,0.571,439,3.481,451,4.784,460,1.778,467,1.975,469,3.867,476,1.415,485,1.033,489,1.975,494,4.393,500,1.631,528,1.975,530,1.082,558,1.631,584,1.632,646,1.415,669,1.193,698,1.975,798,1.631,967,2.391,999,1.975,1016,2.963,1020,1.258,1038,2.576,1059,1.513,1061,3.193,1085,1.258,1087,2.808,1134,2.104,1151,2.576,1179,1.975,1181,3.628,1190,3.366,1200,1.778,1214,1.631,1293,1.513,1322,3.366,1323,1.135,1325,1.778,1326,1.778,1332,1.975,1333,1.975,1354,1.082,1356,1.975,1468,1.415,1473,1.778,1475,4.393,1498,3.12,1507,1.975,1542,1.778,1543,2.808,1561,4.969,1607,2.808,1752,1.975,1778,1.975,1779,1.975,1780,2.274,1781,3.592,1782,4.452,1783,2.274,1784,4.452,1785,2.274,1786,4.452,1787,2.274,1788,6.131,1789,2.274,1790,2.274,1791,2.274,1792,2.274,1793,1.975,1794,2.274,1795,2.274,1796,2.274,1797,2.274,1798,2.274,1799,2.274,1800,2.274,1801,2.274,1802,3.12,1803,1.975,1804,2.274,1805,2.274,1806,2.274,1807,1.975,1808,2.274,1809,1.975,1810,1.975,1811,2.274,1812,3.592,1813,2.274,1814,2.274,1815,2.274,1816,2.274,1817,2.274,1818,2.274,1819,3.592,1820,2.274,1821,2.274,1822,3.592,1823,2.274,1824,2.274,1825,2.274,1826,2.274,1827,4.452,1828,2.274,1829,2.274,1830,2.274,1831,2.274,1832,2.274,1833,2.274,1834,2.274,1835,2.274,1836,2.274,1837,5.058,1838,2.274,1839,2.274,1840,2.274,1841,2.274,1842,3.481,1843,2.274,1844,1.975,1845,1.975,1846,2.274,1847,2.274,1848,2.274,1849,2.274,1850,2.274,1851,2.274,1852,2.274,1853,3.592,1854,2.274,1855,2.274,1856,2.274,1857,2.274,1858,2.274,1859,2.274,1860,2.274,1861,2.274,1862,2.274,1863,2.274,1864,2.274,1865,2.274,1866,1.631,1867,2.274,1868,3.592,1869,2.274,1870,2.274,1871,2.274,1872,2.274,1873,3.592,1874,2.274,1875,2.274,1876,3.592,1877,3.592,1878,2.274,1879,2.274,1880,3.592,1881,2.274,1882,2.274,1883,2.274,1884,2.274,1885,2.274,1886,2.274,1887,2.274,1888,2.274,1889,2.274,1890,2.274,1891,2.274,1892,2.274,1893,2.274,1894,2.274,1895,2.274,1896,2.274,1897,2.274,1898,2.274,1899,2.274,1900,1.975,1901,2.274,1902,2.274,1903,2.274,1904,2.274,1905,2.274,1906,3.592,1907,2.274,1908,2.274,1909,2.274,1910,2.274,1911,2.274,1912,2.274,1913,2.274,1914,4.452,1915,4.784,1916,2.274,1917,3.592,1918,2.274,1919,2.274,1920,2.274,1921,2.274,1922,2.274,1923,2.274,1924,2.274,1925,2.274,1926,2.274,1927,2.274,1928,2.274,1929,2.274,1930,2.274,1931,2.274,1932,1.975,1933,2.274,1934,2.274,1935,1.975,1936,2.274,1937,2.274,1938,2.274,1939,2.274,1940,2.274,1941,2.274,1942,2.274,1943,2.274,1944,2.274,1945,2.274,1946,2.274,1947,1.631,1948,2.274]],["t/141",[10,3.128,17,1.738,25,0.021,26,0.045,27,0.021,28,0.021,43,0.041,44,0.021,45,0.036,46,0.036,49,0.096,50,0.096,51,0.036,139,0.645,140,1.106,147,2.086,152,0.282,159,0.972,163,1.471,164,1.005,176,1.212,183,1.878,195,1.011,293,2.099,320,1.124,326,1.531,341,2.099,361,1.996,363,1.738,366,3.128,487,1.471,553,1.903,583,2.869,584,1.817,588,2.869,589,2.869,650,4.43,836,2.099,838,3.128,842,2.662,1078,2.662,1079,2.662,1129,2.72,1153,3.128,1154,3.128,1158,1.817,1160,3.855,1350,2.662,1547,4.261,1666,4.733,1670,3.474,1703,2.662,1726,4.125,1810,3.474,1947,2.869,1949,3.474,1950,3.474,1951,3.474,1952,4,1953,3.474,1954,3.474,1955,3.474,1956,3.474,1957,3.474,1958,3.474,1959,4,1960,3.474,1961,3.474,1962,3.474,1963,4,1964,3.474,1965,3.474,1966,3.474,1967,4,1968,5.78,1969,3.474,1970,3.474,1971,3.474,1972,3.474,1973,3.474,1974,3.474,1975,3.474,1976,3.128,1977,3.474,1978,3.474,1979,3.474,1980,4,1981,4,1982,4,1983,4,1984,4,1985,4,1986,4]],["t/143",[21,0.877,25,0.019,26,0.045,27,0.019,28,0.019,43,0.041,44,0.019,45,0.04,46,0.033,49,0.087,50,0.087,51,0.033,138,1.179,139,0.643,147,1.948,152,0.359,159,1.199,253,1.545,255,2.962,258,2.471,260,2.256,270,2.936,313,2.671,320,1.018,341,3.088,359,2.006,384,2.117,408,4.42,471,2.78,487,1.332,526,4.35,842,2.412,852,2.671,1323,1.809,1354,3.197,1481,3.979,1987,5.883,1988,3.623,1989,3.623,1990,3.623,1991,3.623,1992,3.623,1993,3.623,1994,3.623,1995,3.623,1996,3.623,1997,3.623,1998,3.623,1999,3.623,2000,3.623,2001,3.623,2002,5.089,2003,3.623,2004,3.623,2005,3.623,2006,3.623,2007,3.623,2008,3.623,2009,3.623,2010,3.623,2011,3.623,2012,3.623,2013,3.623,2014,3.623,2015,3.623,2016,3.623,2017,5.883,2018,3.623,2019,3.623,2020,3.623,2021,3.623,2022,6.38,2023,3.623,2024,3.623,2025,3.623,2026,3.623,2027,3.623,2028,3.623,2029,3.623,2030,3.623,2031,3.623,2032,3.623,2033,3.623,2034,3.623,2035,3.623,2036,3.147,2037,3.623,2038,3.623,2039,3.623,2040,3.623,2041,3.623,2042,3.623,2043,3.979,2044,3.623,2045,3.623,2046,3.623,2047,3.623,2048,3.623,2049,3.623,2050,3.623,2051,3.623,2052,3.623,2053,3.623,2054,3.623,2055,3.623,2056,3.623,2057,3.623,2058,3.623,2059,3.623]],["t/145",[24,2.566,25,0.019,26,0.045,27,0.019,28,0.019,43,0.031,44,0.027,45,0.031,46,0.032,49,0.086,50,0.086,51,0.032,138,1.236,139,0.453,152,0.356,156,3.944,159,1.193,163,1.315,164,0.899,165,1.702,166,1.702,202,2.518,210,1.587,242,2.012,249,1.625,252,2.228,255,2.012,258,2.148,259,0.614,260,3.14,313,1.878,320,1.006,340,3.108,353,1.838,359,2.792,363,2.191,384,3.122,399,1.17,462,3.464,466,2.381,512,2.798,646,4.164,916,2.798,942,2.798,1034,2.228,1048,2.096,1129,2.916,1144,5.81,1151,2.566,1158,2.291,1160,3.703,1323,1.786,1354,2.4,1410,4.961,1435,3.108,1481,2.798,1485,4.798,1726,4.452,2043,2.798,2060,3.108,2061,4.381,2062,3.108,2063,4.568,2064,3.108,2065,4.381,2066,3.108,2067,3.944,2068,4.381,2069,4.381,2070,5.074,2071,3.578,2072,2.798,2073,3.578,2074,3.578,2075,3.578,2076,3.578,2077,3.108,2078,3.578,2079,3.578,2080,3.578,2081,3.108,2082,3.578,2083,3.108,2084,3.108,2085,3.108,2086,3.578,2087,3.578,2088,3.578,2089,3.578,2090,3.578,2091,3.578,2092,3.108,2093,3.108,2094,3.108,2095,3.108,2096,3.108,2097,3.578,2098,3.578,2099,3.578,2100,3.578,2101,3.108,2102,3.578,2103,3.578,2104,3.108,2105,4.381,2106,4.381,2107,3.578,2108,3.108]],["t/147",[17,2.088,21,1.49,25,0.026,26,0.044,27,0.026,28,0.026,43,0.04,44,0.026,45,0.036,46,0.043,49,0.115,50,0.115,51,0.043,138,1.013,152,0.434,161,1.84,163,1.767,164,1.208,175,1.767,202,2.399,270,2.399,303,2.56,326,1.84,399,1.571,400,3.447,487,1.767,491,2,668,4.175,669,2.523,682,3.758,818,4.175,836,2.523,852,2.523,1016,3.199,1293,3.199,1425,4.175,1472,4.095,1659,5.344,1662,3.758,1704,4.811,1746,4.175,1748,5.344,1749,4.175,1750,4.175,1751,4.175,1753,4.175,2109,4.807,2110,4.807,2111,4.807,2112,4.807,2113,4.807,2114,4.807,2115,4.807,2116,4.807,2117,4.807,2118,4.807,2119,4.175,2120,4.807,2121,4.807,2122,4.807,2123,4.175,2124,3.758,2125,4.807,2126,4.807,2127,6.787,2128,4.175,2129,4.807,2130,4.807,2131,4.807,2132,4.807]],["t/149",[25,0.025,26,0.045,27,0.025,28,0.025,43,0.042,44,0.025,45,0.04,46,0.043,47,0.881,49,0.114,50,0.114,51,0.043,138,0.782,139,0.64,140,0.847,152,0.335,159,0.847,163,1.746,164,1.194,165,2.259,166,2.259,168,2.782,170,3.714,172,3.714,195,0.881,252,3.801,253,1.15,255,1.894,343,2.493,546,4.125,651,3.714,908,6.55,1017,2.957,1018,2.957,1019,2.957,1069,4.379,1173,3.407,1315,3.714,1347,3.161,2133,4.75,2134,7.369,2135,4.75,2136,4.75,2137,4.75,2138,4.75,2139,4.75,2140,4.75,2141,4.75,2142,4.75,2143,4.75,2144,6.106,2145,4.75,2146,4.75,2147,4.75,2148,4.75,2149,4.75,2150,4.75]],["t/151",[24,2.691,25,0.028,26,0.043,27,0.02,28,0.02,43,0.032,44,0.02,45,0.028,46,0.034,49,0.09,50,0.09,51,0.034,67,1.561,138,1.233,139,0.611,147,1.436,159,1.424,242,1.497,252,4.238,255,1.497,258,2.815,260,4.238,311,2.691,313,3.573,320,1.055,351,2.077,359,3.768,439,4.687,553,1.785,605,2.934,646,2.336,791,3.259,888,3.259,915,3.259,916,5.323,967,2.498,1164,1.97,1323,1.873,1338,2.498,1485,5.184,1778,3.259,1779,3.259,2036,3.259,2043,4.687,2060,3.259,2061,4.53,2062,3.259,2063,2.934,2064,3.259,2065,3.259,2066,3.259,2068,3.259,2069,3.259,2070,6.802,2081,6.277,2083,3.259,2084,5.626,2085,4.53,2092,3.259,2151,5.215,2152,5.215,2153,5.994,2154,3.753,2155,5.215,2156,5.215,2157,3.753,2158,5.215,2159,3.753,2160,3.753,2161,3.753,2162,3.753,2163,3.753,2164,3.753,2165,3.753,2166,3.753,2167,3.753,2168,3.753,2169,5.215,2170,3.753,2171,3.753,2172,3.753,2173,3.753,2174,5.215,2175,3.753,2176,3.753,2177,3.753,2178,3.753,2179,3.753,2180,2.934,2181,3.753,2182,3.753,2183,3.753,2184,3.753,2185,3.753,2186,3.753,2187,3.753,2188,3.753,2189,3.753,2190,3.753]],["t/153",[10,2.918,17,1.621,25,0.02,26,0.045,27,0.02,28,0.02,43,0.04,44,0.02,45,0.035,46,0.033,49,0.09,50,0.09,51,0.033,138,1.064,139,0.632,140,1.153,152,0.263,159,0.927,163,1.372,164,0.938,183,1.81,195,1.109,248,1.318,255,1.488,259,0.64,293,1.959,320,1.049,326,1.428,361,1.862,363,1.621,366,2.918,384,3.062,399,1.22,487,1.372,512,2.918,583,2.676,584,1.695,588,2.676,589,2.676,836,1.959,838,2.918,842,2.484,923,3.241,1034,2.323,1078,2.484,1079,2.484,1129,2.983,1136,3.241,1153,2.918,1154,2.918,1158,2.36,1160,3.76,1197,2.676,1323,1.862,1350,2.484,1410,4.062,1547,4.062,1703,2.484,1708,2.918,1726,4.522,1761,2.918,1947,2.676,1949,3.241,1950,3.241,1951,3.241,1953,3.241,1954,3.241,1955,3.241,1956,4.512,1957,3.241,1958,3.241,1960,4.512,1961,3.241,1962,3.241,1964,4.512,1965,3.241,1966,3.241,1969,3.241,1970,3.241,1971,3.241,1972,3.241,1973,3.241,1974,3.241,1975,3.241,1976,2.918,1977,3.241,1978,3.241,1979,3.241,2063,2.918,2093,5.19,2094,3.241,2095,3.241,2096,3.241,2101,3.241,2104,3.241,2105,4.512,2106,3.241,2108,3.241,2191,3.732,2192,6.462,2193,3.241,2194,3.732]],["t/155",[25,0.027,26,0.045,27,0.027,28,0.027,43,0.04,44,0.027,45,0.034,46,0.046,49,0.123,50,0.123,51,0.046,73,1.292,100,3.421,159,0.917,163,1.89,164,1.292,353,1.617,399,1.68,641,4.604,642,3.2,845,4.604,1029,4.464,1158,2.916,1703,3.421,1708,4.019,1935,4.464,2128,6.08,2195,5.14,2196,6.419,2197,5.14,2198,5.14,2199,5.14,2200,7,2201,5.14,2202,7,2203,5.14,2204,5.14,2205,5.14,2206,7,2207,6.419,2208,5.14]],["t/157",[25,0.023,26,0.044,27,0.023,28,0.023,43,0.037,44,0.023,45,0.035,46,0.039,49,0.105,50,0.105,51,0.039,138,1.257,139,0.619,147,1.668,152,0.506,159,1.279,161,2.477,162,2.379,176,1.32,183,1.32,353,1.371,729,2.507,839,2.622,1538,1.668,1553,2.622,1575,2.622,1576,2.993,1578,2.812,1579,2.287,1582,2.507,1618,2.507,1619,2.507,1651,1.893,1655,1.893,1675,2.622,1676,2.622,2209,2.073,2210,2.073,2211,2.175,2212,3.504,2213,2.412,2214,3.582,2215,3.582,2216,2.9,2217,4.357,2218,2.712,2219,2.175,2220,3.195,2221,2.746,2222,2.746,2223,2.073,2224,3.814,2225,2.073,2226,2.073,2227,2.175,2228,2.073,2229,3.841,2230,2.9,2231,2.712,2232,3.125,2233,2.175,2234,3.125,2235,3.125,2236,3.125,2237,3.407]],["t/159",[25,0.022,26,0.045,27,0.022,28,0.022,43,0.04,44,0.022,45,0.036,46,0.036,49,0.097,50,0.097,51,0.036,67,1.688,138,0.906,139,0.494,147,2.106,152,0.509,176,1.229,183,1.229,291,2.499,320,1.755,353,1.276,462,2.97,526,2.376,553,3.185,1098,5.422,1338,2.7,1538,1.553,1553,2.499,1575,2.499,1576,2.39,1578,2.39,1582,2.39,1602,3.887,1618,2.39,1619,2.39,1651,2.39,1655,1.762,1675,2.499,1676,2.499,2209,1.93,2210,1.93,2212,2.97,2218,2.526,2221,2.617,2222,2.617,2223,1.93,2225,1.93,2226,1.93,2228,1.93,2233,2.025,2238,4.057,2239,4.057,2240,5.502,2241,7.38,2242,7.216,2243,4.057,2244,4.057,2245,5.502,2246,6.243,2247,5.502,2248,6.243,2249,4.057,2250,6.694,2251,4.057,2252,6.243,2253,4.057,2254,4.057,2255,4.057,2256,4.057,2257,4.057,2258,4.057]],["t/161",[25,0.02,26,0.045,27,0.02,28,0.02,43,0.038,44,0.02,45,0.035,46,0.034,49,0.092,50,0.092,51,0.034,138,1.312,139,0.652,147,1.461,152,0.522,159,1.34,161,2.712,162,2.604,176,1.156,183,1.156,353,1.201,729,2.835,839,2.964,1538,1.461,1553,2.397,1575,2.397,1576,2.835,1578,2.628,1579,2.003,1582,2.293,1618,2.293,1619,2.293,1651,1.658,1655,1.658,1675,2.397,1676,2.397,2209,1.816,2210,2.51,2211,2.634,2212,3.618,2213,2.921,2214,3.921,2215,3.921,2216,3.512,2218,2.376,2219,1.905,2220,2.921,2221,2.51,2222,2.51,2223,1.816,2224,3.612,2225,1.816,2226,1.816,2227,1.905,2228,1.816,2229,3.512,2230,2.54,2231,2.376,2232,2.738,2234,2.738,2235,2.738,2236,2.738,2237,2.984,2259,5.277,2260,3.817,2261,3.817,2262,3.817]],["t/163",[25,0.011,26,0.045,27,0.011,28,0.011,43,0.042,44,0.011,45,0.035,46,0.018,49,0.049,50,0.049,51,0.018,105,2.196,122,1.466,139,0.469,147,0.782,152,0.477,159,0.996,161,1.588,162,1.525,176,0.619,206,1.802,210,1.643,217,0.972,238,1.36,248,0.722,249,0.928,253,0.799,270,2.376,271,2.891,276,3.414,309,1.598,312,4.006,326,1.822,413,2.579,481,2.761,487,1.525,530,0.972,538,1.272,635,1.073,644,2.537,651,2.579,701,2.579,729,1.433,730,1.131,786,1.569,798,1.466,839,1.498,852,1.073,937,1.466,956,1.466,1048,1.932,1075,3.414,1354,3.214,1538,0.782,1543,1.598,1553,1.498,1556,1.775,1557,1.775,1575,2.537,1576,2.935,1578,2.983,1579,2.742,1581,3.722,1582,3.025,1592,1.598,1602,1.272,1618,2.426,1619,2.426,1620,4.595,1631,1.598,1651,1.802,1655,2.269,1675,2.537,1676,2.537,1679,1.775,1684,5.103,1761,2.579,1842,3.722,1866,1.466,1915,2.865,2067,2.579,2072,2.579,2119,2.865,2124,1.598,2209,1.569,2210,0.972,2211,1.02,2212,2.657,2213,1.131,2214,2.296,2215,2.296,2216,1.36,2219,1.02,2220,1.826,2221,1.569,2222,1.569,2223,0.972,2224,3.801,2225,0.972,2226,0.972,2227,1.02,2228,0.972,2233,2.607,2263,2.044,2264,3.299,2265,1.466,2266,2.044,2267,2.044,2268,3.299,2269,1.775,2270,3.299,2271,3.299,2272,3.299,2273,2.865,2274,3.299,2275,3.299,2276,2.044,2277,2.044,2278,3.299,2279,2.044,2280,3.299,2281,2.044,2282,5.876,2283,2.044,2284,2.044,2285,3.299,2286,3.299,2287,3.746,2288,2.044,2289,2.044,2290,2.044,2291,2.044,2292,2.044,2293,4.148,2294,4.134,2295,2.044,2296,2.044,2297,2.044,2298,2.044,2299,3.299,2300,3.299,2301,3.299,2302,2.044,2303,2.044,2304,2.044,2305,2.044,2306,2.044,2307,3.299,2308,3.299,2309,4.148,2310,2.044,2311,2.044,2312,2.044,2313,3.299,2314,2.044,2315,3.299,2316,3.299,2317,2.044,2318,2.044,2319,2.044,2320,3.299,2321,3.299,2322,4.148,2323,2.044,2324,2.044,2325,2.044,2326,2.044,2327,3.299,2328,3.299,2329,2.044,2330,2.044,2331,2.044,2332,2.044,2333,2.044,2334,2.044,2335,2.044,2336,2.044,2337,2.044,2338,2.044,2339,2.044,2340,2.044,2341,2.044,2342,2.044,2343,2.044,2344,3.299,2345,3.299,2346,4.148,2347,2.044,2348,2.044,2349,2.044,2350,2.044,2351,2.044,2352,3.299,2353,3.299,2354,3.299,2355,3.299,2356,2.044,2357,2.044,2358,2.044,2359,2.044,2360,2.044,2361,2.044,2362,2.044,2363,3.299,2364,3.299,2365,2.044,2366,2.044,2367,2.044,2368,2.044,2369,2.044,2370,2.044,2371,2.044,2372,3.299,2373,2.044,2374,2.044,2375,2.044,2376,2.044,2377,2.044,2378,2.044,2379,2.044,2380,1.598,2381,2.044,2382,2.044,2383,2.044,2384,2.044,2385,2.044,2386,2.044,2387,2.044,2388,2.044,2389,2.044,2390,2.044,2391,2.044]],["t/165",[12,1.837,25,0.015,26,0.045,27,0.015,28,0.015,29,1.718,43,0.035,44,0.015,45,0.027,46,0.025,49,0.066,50,0.066,51,0.025,73,1.048,80,1.985,89,1.979,105,2.777,138,1.142,139,0.622,147,1.597,152,0.519,159,1.261,161,1.925,162,1.849,176,0.836,210,0.868,271,2.309,291,1.253,303,1.148,353,0.868,406,3.933,429,2.777,443,2.158,445,2.158,453,2.158,456,2.158,481,1.837,485,1.895,493,3.262,538,2.597,635,1.448,642,2.597,644,2.735,661,1.527,729,1.812,802,2.777,839,1.895,852,1.448,869,3.262,956,1.979,1067,1.718,1093,2.158,1184,3.608,1472,1.837,1538,1.056,1541,2.992,1553,2.285,1574,2.397,1575,1.895,1576,3.011,1578,2.436,1579,1.448,1581,3.262,1582,2.857,1583,2.397,1584,2.397,1585,2.397,1586,2.397,1587,2.397,1588,3.623,1589,2.397,1590,2.397,1591,2.158,1592,2.158,1593,2.397,1594,2.397,1599,2.397,1600,2.397,1601,2.397,1602,4.704,1603,2.397,1604,3.623,1605,2.397,1606,3.623,1607,3.262,1608,2.397,1609,4.87,1610,2.397,1611,2.397,1612,2.397,1613,2.397,1614,2.397,1615,4.369,1616,2.397,1617,2.397,1618,1.812,1619,1.812,1620,3.933,1623,4.369,1624,2.397,1625,2.397,1626,2.397,1627,2.397,1628,4.369,1629,3.933,1630,2.397,1631,3.262,1632,2.397,1633,2.397,1634,4.369,1635,2.397,1636,2.397,1637,2.397,1638,2.397,1639,2.397,1640,3.623,1641,2.397,1642,2.397,1643,2.397,1644,2.397,1645,2.397,1646,2.397,1647,3.623,1648,2.397,1649,2.397,1650,2.397,1651,1.812,1652,2.397,1653,2.397,1654,2.397,1655,1.199,1656,2.397,1662,2.158,1675,1.895,1676,1.895,2123,2.397,2209,1.985,2210,1.313,2211,1.377,2212,3.013,2213,1.527,2214,2.784,2215,2.784,2216,1.837,2219,1.377,2220,2.309,2221,1.985,2222,1.985,2223,1.313,2224,2.784,2225,1.313,2226,1.313,2227,1.377,2228,1.313,2232,2.992,2233,1.377,2234,1.979,2235,1.979,2236,1.979,2265,1.979,2269,2.397,2287,1.979,2380,2.158,2392,3.262,2393,2.759,2394,2.759,2395,2.759,2396,2.759,2397,2.759,2398,2.759,2399,2.397,2400,2.759,2401,2.759]],["t/167",[25,0.022,26,0.045,27,0.022,28,0.022,43,0.039,44,0.022,45,0.04,46,0.037,49,0.099,50,0.099,51,0.037,138,1.222,139,0.501,152,0.445,159,1.126,161,2.415,162,2.319,176,1.254,183,1.69,351,2.292,353,1.303,729,2.424,839,2.534,1538,1.585,1575,2.534,1576,2.933,1578,2.741,1579,2.173,1582,2.424,1618,2.424,1619,2.424,1651,1.799,1655,1.799,1675,2.534,1676,2.534,1724,2.97,2209,1.97,2210,1.97,2211,2.067,2212,3.453,2213,2.292,2214,3.492,2215,3.492,2219,2.067,2220,3.088,2221,2.654,2222,2.654,2223,1.97,2224,3.737,2225,1.97,2226,1.97,2227,2.067,2228,1.97,2231,2.578,2233,3.149,2402,4.141,2403,4.141,2404,6.751,2405,4.141,2406,3.713,2407,6.309,2408,4.845,2409,4.141,2410,4.141,2411,4.141,2412,2.756,2413,2.97,2414,4.141,2415,4.141,2416,4.141,2417,4.141,2418,2.756,2419,3.596,2420,4.141]],["t/169",[25,0.02,26,0.045,27,0.02,28,0.02,43,0.038,44,0.02,45,0.035,46,0.034,49,0.09,50,0.09,51,0.034,138,1.162,139,0.47,152,0.424,159,1.072,161,2.299,162,2.208,176,1.141,183,1.141,210,1.645,351,2.085,353,1.185,729,2.272,1538,2.002,1553,2.375,1575,2.947,1576,3.205,1578,3.065,1579,2.745,1582,2.819,1618,2.819,1619,2.819,1651,2.272,1655,2.272,1675,2.947,1676,2.947,1724,2.701,2209,1.792,2210,1.792,2211,1.88,2212,3.356,2213,2.085,2214,3.324,2215,3.324,2218,3.255,2219,2.61,2220,3.591,2221,3.087,2222,3.087,2223,2.487,2224,4.083,2225,2.487,2226,2.487,2227,2.61,2228,2.487,2229,4.318,2230,3.48,2231,3.255,2233,2.61,2406,3.48,2408,3.271,2412,2.507,2413,2.701,2418,2.507,2419,3.271,2421,5.229,2422,3.767,2423,3.767,2424,5.229,2425,3.767,2426,3.767,2427,3.767,2428,3.767,2429,3.767]],["t/171",[25,0.025,26,0.045,27,0.025,28,0.025,43,0.039,44,0.025,45,0.035,46,0.041,49,0.11,50,0.11,51,0.041,73,1.153,124,3.973,152,0.496,159,1.065,202,2.289,210,1.443,255,1.829,303,1.908,341,2.407,346,3.053,353,1.443,375,3.586,384,1.908,390,3.586,399,1.499,487,1.686,538,2.855,635,2.407,1032,2.686,1129,3.509,1158,2.083,1411,3.983,2430,5.764,2431,3.983,2432,3.983,2433,3.983,2434,5.185,2435,5.969,2436,4.586,2437,3.586,2438,4.586,2439,4.586,2440,4.586,2441,3.586,2442,3.983,2443,5.764,2444,5.764,2445,3.983,2446,3.983,2447,3.983,2448,5.969,2449,4.586,2450,4.586,2451,4.586,2452,4.586,2453,4.586,2454,4.586,2455,4.586,2456,4.586,2457,4.586]],["t/173",[25,0.026,26,0.045,27,0.026,28,0.026,43,0.04,44,0.026,45,0.037,46,0.044,49,0.118,50,0.118,51,0.044,124,4.159,152,0.509,202,2.458,210,1.55,303,2.049,326,1.885,351,2.726,353,1.55,375,3.851,384,2.856,390,3.851,399,1.61,538,3.066,1032,2.885,1129,3.603,1158,2.237,2430,5.962,2431,4.277,2432,4.277,2433,4.277,2434,4.277,2442,4.277,2443,4.277,2444,4.277,2445,4.277,2446,4.277,2447,4.277,2458,4.925,2459,4.925,2460,4.925,2461,4.925,2462,4.925,2463,4.925,2464,4.925,2465,4.925,2466,4.925]],["t/175",[25,0.027,26,0.044,27,0.027,28,0.027,43,0.039,44,0.027,45,0.037,46,0.046,49,0.123,50,0.123,51,0.046,138,1.151,152,0.362,176,1.553,183,1.553,258,2.356,353,1.613,1538,2.676,1553,2.911,1576,2.227,1578,2.784,1582,2.784,1618,2.784,1619,2.784,1651,2.784,1655,2.227,1675,2.911,1676,2.911,1691,4.453,2209,2.439,2210,2.439,2211,2.559,2212,2.439,2218,3.192,2219,2.559,2221,3.049,2222,3.049,2223,2.439,2225,2.439,2226,2.439,2227,2.559,2228,2.439,2233,2.559,2406,3.412,2412,3.412,2418,3.412,2467,4.009]],["t/177",[25,0.024,26,0.044,27,0.024,28,0.024,43,0.037,44,0.024,45,0.035,46,0.04,49,0.108,50,0.108,51,0.04,129,5.132,138,0.969,139,0.403,147,1.716,152,0.524,159,1.171,161,2.513,162,2.413,176,1.358,183,1.358,258,2.162,353,1.411,638,5.132,729,2.555,839,2.672,1538,2.251,1553,2.672,1575,2.672,1576,1.948,1578,2.555,1582,2.555,1602,4.087,1618,2.555,1619,2.555,1651,2.555,1655,1.948,1675,2.672,1676,2.672,2209,2.133,2210,2.133,2211,2.238,2212,3.532,2218,2.791,2219,2.238,2221,2.798,2222,2.798,2223,2.133,2225,2.133,2226,2.133,2227,2.238,2228,2.133,2233,2.238,2406,2.984,2412,2.984,2413,3.216,2418,2.984,2437,5.132,2467,3.506,2468,4.484,2469,3.894,2470,5.108,2471,5.701,2472,3.894]],["t/179",[25,0.021,26,0.045,27,0.021,28,0.021,43,0.039,44,0.021,45,0.033,46,0.036,49,0.095,50,0.095,51,0.036,129,4.832,138,1.181,139,0.487,147,1.522,152,0.535,159,1.28,161,2.365,162,2.272,176,1.205,183,1.205,353,1.251,638,4.832,729,2.684,839,2.807,1538,1.522,1541,3.893,1553,2.465,1575,3.016,1576,2.884,1578,2.684,1579,2.087,1582,2.358,1602,3.847,1618,2.358,1619,2.358,1651,2.358,1655,1.727,1675,2.465,1676,2.465,2209,1.891,2210,1.891,2211,1.985,2212,3.605,2213,2.201,2214,3.42,2215,3.42,2219,1.985,2220,3.004,2221,2.582,2222,2.582,2223,1.891,2224,3.675,2225,1.891,2226,1.891,2227,1.985,2228,1.891,2229,3.612,2230,2.646,2231,2.475,2233,1.985,2265,2.852,2287,2.852,2392,4.244,2406,2.646,2412,2.646,2413,2.852,2418,2.646,2437,4.832,2467,3.109,2469,3.453,2470,4.714,2471,5.367,2472,3.453]],["t/181",[25,0.022,26,0.045,27,0.022,28,0.022,43,0.039,44,0.022,45,0.033,46,0.036,49,0.097,50,0.097,51,0.036,138,1.236,139,0.601,147,1.553,152,0.509,159,1.249,161,2.39,162,2.295,176,1.229,183,1.229,353,1.276,635,2.129,644,2.836,729,2.39,839,2.499,899,3.523,1158,2.499,1336,3.523,1538,1.553,1541,3.946,1553,2.499,1575,2.499,1576,2.908,1578,2.908,1579,2.129,1582,2.712,1618,2.39,1619,2.39,1651,1.762,1655,1.762,1675,2.499,1676,2.499,2209,1.93,2210,1.93,2211,2.025,2212,3.433,2213,2.245,2214,3.456,2215,3.456,2216,2.7,2219,2.025,2220,3.045,2221,2.617,2222,2.617,2223,1.93,2224,3.705,2225,1.93,2226,1.93,2227,2.025,2228,1.93,2229,3.662,2230,2.7,2231,2.526,2232,2.91,2233,2.025,2234,2.91,2235,2.91,2236,2.91,2237,3.172,2265,2.91,2287,2.91,2380,3.172,2392,4.302,2399,3.523,2473,4.057,2474,4.057]],["t/183",[25,0.026,26,0.045,27,0.026,28,0.026,43,0.042,44,0.026,45,0.036,46,0.043,49,0.116,50,0.116,51,0.043,55,4.818,139,0.643,140,1.099,152,0.34,195,1.144,210,1.516,253,1.492,259,1.165,291,2.189,339,3.207,387,2.405,487,1.771,553,2.292,635,2.529,644,2.799,786,2.932,884,4.185,1020,2.667,2441,3.767,2475,4.185,2476,4.818,2477,4.818,2478,4.818,2479,4.818,2480,4.818,2481,4.818,2482,4.818,2483,6.162,2484,4.818,2485,6.162,2486,4.818,2487,4.818,2488,4.818,2489,4.818,2490,4.818,2491,4.818,2492,4.818,2493,4.818,2494,4.818,2495,4.818,2496,4.818,2497,4.818,2498,4.818,2499,4.818,2500,4.818]],["t/185",[25,0.027,26,0.045,27,0.027,28,0.027,43,0.039,44,0.027,45,0.034,46,0.046,49,0.123,50,0.123,51,0.046,140,0.912,152,0.493,195,0.949,210,1.609,253,1.238,258,1.88,259,1.097,291,2.323,339,3.403,387,2.552,462,3.481,471,2.04,635,2.684,786,2.433,1020,2.83,2193,5.557,2441,3.998,2475,4.441,2484,3.998,2501,5.114,2502,5.114,2503,5.114,2504,5.114,2505,5.114,2506,6.399,2507,5.114,2508,5.114,2509,5.114,2510,5.114,2511,5.114,2512,5.114,2513,5.114,2514,5.114]],["t/187",[21,1.181,25,0.026,26,0.045,27,0.037,28,0.026,43,0.038,44,0.026,45,0.033,46,0.044,47,0.905,49,0.117,50,0.117,51,0.044,139,0.558,140,0.87,152,0.344,174,2.215,183,1.477,195,0.905,200,3.813,202,2.434,210,1.535,259,1.065,374,1.226,387,2.434,399,1.594,476,3.036,487,1.793,491,2.029,500,3.498,736,2.857,786,2.32,802,3.246,808,2.56,845,3.498,929,2.029,935,4.236,1041,3.813,1164,2.56,2484,4.856,2515,4.877,2516,4.877,2517,4.877,2518,4.877,2519,4.877,2520,4.877,2521,4.236,2522,4.877,2523,4.877,2524,4.877,2525,4.877,2526,4.877,2527,4.877,2528,4.877,2529,4.877,2530,4.877,2531,4.877,2532,4.877,2533,4.877,2534,4.877,2535,4.877,2536,4.877,2537,4.877]],["t/189",[21,1.572,25,0.028,26,0.044,27,0.028,28,0.028,43,0.035,44,0.028,45,0.035,46,0.047,47,0.971,49,0.126,50,0.126,51,0.047,138,0.862,139,0.583,140,0.934,148,2.49,159,0.934,173,2.377,174,2.377,175,1.924,176,1.586,191,2.747,195,0.971,206,2.82,207,2.377,246,3.408,259,0.897,301,2.897,342,2.612,344,2.747,345,2.612,347,2.612,374,1.315,634,4.546,657,3.258,807,3.754,808,2.747,809,3.483,920,4.546,929,2.178,1034,3.258,1085,2.897,1086,4.092,1158,2.377,1164,2.747,1165,4.092,1166,4.546,1167,4.546,1168,4.546,1169,4.092,2538,5.234,2539,5.234]],["t/191",[21,1.675,25,0.027,26,0.045,27,0.027,28,0.027,43,0.039,44,0.027,45,0.037,46,0.045,47,0.93,49,0.12,50,0.12,51,0.045,139,0.567,140,0.894,148,2.384,164,1.259,191,2.63,195,0.93,206,2.745,207,2.276,213,2.276,253,1.759,259,0.859,303,2.085,310,2.501,320,1.408,343,2.63,374,1.259,399,1.638,534,4.352,535,4.352,670,3.918,808,2.63,821,4.352,822,4.352,823,4.352,824,4.352,825,4.352,826,4.352,827,4.352,828,4.352,830,4.352,1134,2.935,1197,3.594,1976,3.918,2540,7.265,2541,6.318,2542,5.011,2543,5.011]],["t/193",[17,3.062,21,1.118,25,0.025,26,0.045,27,0.025,28,0.025,29,2.875,43,0.04,44,0.025,45,0.038,46,0.041,47,0.857,49,0.111,50,0.111,67,2.495,139,0.633,140,0.824,148,2.197,152,0.326,173,2.098,174,2.098,175,1.698,176,1.399,183,1.399,195,0.857,206,2.605,217,2.197,246,3.147,253,1.452,259,1.142,310,2.305,324,3.074,326,1.768,341,2.424,342,2.993,343,2.424,344,2.424,345,2.305,346,3.991,347,2.305,348,3.312,530,2.197,657,2.875,836,2.424,1016,3.074,1074,4.011,1075,3.312,1076,3.611,1077,3.611,1078,3.074,1079,3.074,1080,4.011,1081,4.011,1082,4.011,1083,4.011,1084,4.011,1085,2.556,1086,3.611,1087,3.611,1088,4.011,1468,2.875,2544,4.618,2545,4.618,2546,3.611,2547,5.996,2548,4.618,2549,4.618,2550,4.618]],["t/195",[20,4.57,21,1.274,25,0.028,26,0.044,27,0.028,28,0.028,43,0.038,44,0.028,45,0.035,46,0.047,49,0.126,50,0.126,51,0.047,65,3.774,139,0.585,140,0.939,152,0.371,159,1.162,195,0.976,253,1.79,259,1.117,270,2.626,271,2.912,399,1.72,839,2.39,929,2.71,1129,3.251,1160,2.912,1164,2.762,1724,3.774,1726,3.502,2551,5.261,2552,5.261,2553,4.114,2554,5.261,2555,5.261,2556,5.261,2557,5.261,2558,5.261,2559,5.261,2560,5.261,2561,5.261,2562,5.261]],["t/197",[25,0.031,26,0.044,27,0.031,28,0.031,43,0.037,44,0.031,45,0.037,46,0.051,47,1.063,49,0.137,50,0.137,51,0.051,258,2.106,374,1.439,584,2.602,857,4.108,1354,2.725,1406,4.975,1499,3.812,1932,4.975,2563,5.728,2564,5.728,2565,5.728,2566,5.728,2567,5.728,2568,4.975,2569,5.728,2570,5.728,2571,5.728,2572,5.728,2573,5.728,2574,5.728]],["t/199",[21,1.046,25,0.023,26,0.044,27,0.034,28,0.023,43,0.037,44,0.023,45,0.037,46,0.039,49,0.104,50,0.104,51,0.039,73,1.085,138,0.945,139,0.515,140,1.024,152,0.405,164,1.085,168,3.361,173,1.962,195,1.065,202,2.156,204,3.098,210,1.359,213,1.962,218,3.377,248,1.526,249,1.962,253,1.56,255,1.723,256,2.53,258,1.588,259,1.105,310,2.156,343,2.267,485,1.962,487,1.588,491,1.797,530,2.055,582,3.751,629,2.875,635,2.267,636,3.751,1163,3.751,1164,2.267,1186,3.751,1252,4.757,1254,3.377,1257,3.377,1259,3.377,1260,3.377,1267,3.377,1284,3.098,1293,2.875,1311,3.377,1347,2.875,1560,3.098,1866,4.116,2575,4.319,2576,7.148,2577,4.319,2578,4.319,2579,4.319,2580,4.319,2581,4.319,2582,4.319,2583,4.319,2584,4.319,2585,5.738,2586,4.319,2587,4.319,2588,4.319,2589,4.319,2590,6.444,2591,4.319,2592,4.319,2593,4.319,2594,4.319,2595,4.319,2596,4.319,2597,4.319,2598,4.319,2599,5.738,2600,4.319,2601,4.319,2602,5.738,2603,4.319,2604,4.319,2605,4.319,2606,4.319,2607,4.319,2608,4.319,2609,4.319,2610,4.319,2611,4.319,2612,4.319,2613,4.319]],["t/201",[25,0.026,26,0.044,27,0.026,28,0.026,43,0.04,44,0.026,45,0.042,46,0.044,47,0.912,49,0.118,50,0.118,51,0.044,258,2.652,353,1.546,360,4.801,361,3.6,374,1.235,526,2.878,584,3.276,730,2.719,1440,4.267,1447,4.267,1452,4.267,1454,4.267,1458,4.267,1459,4.267,1462,4.267,1571,4.267,2180,3.841,2614,4.267,2615,4.913,2616,6.239,2617,7.213,2618,4.913,2619,6.239,2620,4.913,2621,6.239,2622,6.239,2623,4.913,2624,6.239,2625,6.239,2626,4.913,2627,4.913,2628,4.913,2629,4.913,2630,4.913,2631,4.913,2632,4.913,2633,4.913,2634,4.913,2635,4.913]],["t/203",[1,3.749,23,3.825,25,0.026,26,0.045,27,0.026,28,0.026,43,0.038,44,0.026,45,0.033,46,0.043,47,0.89,49,0.115,50,0.115,51,0.043,73,1.544,258,1.763,259,0.822,310,3.066,320,1.348,361,2.393,363,2.083,374,1.205,584,2.178,663,5.336,725,4.804,730,2.654,857,3.439,950,3.439,1326,3.749,1350,4.089,1354,2.281,1499,3.191,1844,5.336,1845,4.165,1968,4.165,2521,4.165,2568,4.165,2614,4.165,2636,6.144,2637,4.795,2638,4.795,2639,4.795,2640,7.149,2641,4.795,2642,4.795,2643,4.795,2644,4.795,2645,4.795,2646,4.795,2647,4.795,2648,4.795,2649,6.144,2650,4.795,2651,4.795,2652,4.795,2653,4.795,2654,4.795,2655,4.795,2656,4.795,2657,6.144,2658,4.795,2659,4.795,2660,4.795,2661,4.795]],["t/205",[23,3.683,25,0.024,26,0.044,27,0.032,28,0.024,43,0.04,44,0.024,45,0.04,46,0.041,47,0.84,49,0.109,50,0.109,51,0.041,52,3.929,67,1.882,138,0.745,210,1.424,258,2.175,320,1.853,353,1.424,359,3.275,360,3.938,361,2.953,363,2.57,374,1.137,471,1.805,487,1.663,553,2.815,583,4.243,584,2.688,585,3.929,586,3.929,587,3.929,588,4.243,589,3.245,590,4.626,591,3.929,592,3.245,593,5.139,594,3.929,595,5.139,596,5.139,597,5.139,598,3.929,599,5.139,600,5.139,601,4.626,602,5.139,603,3.929,604,3.929,605,3.537,852,2.375,942,3.537,1032,2.65,1048,2.65,1469,3.929,1947,3.245,2067,3.537,2077,3.929,2662,4.524,2663,4.524,2664,4.524,2665,4.524,2666,4.524,2667,5.917,2668,5.917,2669,4.524,2670,4.524,2671,3.929,2672,3.929,2673,4.524,2674,4.524,2675,4.524,2676,5.917,2677,4.524,2678,4.524,2679,4.524,2680,4.524,2681,4.524,2682,4.524,2683,4.524,2684,4.524,2685,4.524,2686,4.524,2687,4.524,2688,4.524]],["t/207",[1,4.121,4,3.78,21,0.922,25,0.02,26,0.045,27,0.02,28,0.02,43,0.041,44,0.02,45,0.035,46,0.034,49,0.091,50,0.091,51,0.034,56,2.979,73,0.957,80,1.812,93,3.309,133,2.979,138,0.627,152,0.46,159,0.94,217,1.812,253,1.276,258,1.401,270,3.534,271,3.919,304,3.309,320,1.481,471,1.52,485,1.73,592,4.334,644,1.73,661,2.109,839,2.394,902,2.979,1038,2.732,1067,2.372,1193,2.732,1197,2.732,1311,2.979,1323,1.901,1468,3.762,1538,1.458,1542,2.979,1552,3.309,1560,2.732,1573,4.577,1678,3.309,1681,3.309,1802,3.309,1803,3.309,1809,3.309,1842,2.979,2072,2.979,2273,3.309,2546,2.979,2553,4.121,2672,3.309,2689,5.248,2690,3.309,2691,3.81,2692,3.81,2693,5.27,2694,3.81,2695,5.27,2696,3.81,2697,5.27,2698,3.81,2699,3.81,2700,3.81,2701,3.81,2702,3.81,2703,6.042,2704,3.81,2705,3.81,2706,3.81,2707,3.81,2708,3.309,2709,3.309,2710,3.309,2711,3.309,2712,4.577,2713,3.309,2714,3.309,2715,3.309,2716,4.577,2717,3.309,2718,3.309,2719,3.309,2720,3.309,2721,3.309,2722,3.309,2723,3.81,2724,3.81,2725,3.81,2726,3.81,2727,3.81,2728,3.81,2729,3.81,2730,3.81,2731,3.81,2732,3.81,2733,3.81,2734,3.81,2735,3.81,2736,3.81,2737,3.81,2738,3.81,2739,5.27,2740,3.81,2741,3.81,2742,3.81,2743,3.81,2744,3.309,2745,3.81,2746,3.81,2747,3.81,2748,3.81,2749,3.81,2750,3.81,2751,3.81,2752,3.309,2753,3.81,2754,3.309,2755,3.309,2756,3.309]],["t/209",[21,1.164,25,0.026,26,0.044,27,0.026,28,0.026,43,0.041,44,0.026,45,0.033,46,0.043,49,0.115,50,0.115,51,0.043,56,3.758,73,1.208,80,2.287,133,3.758,138,0.792,152,0.479,159,1.098,217,2.287,258,1.767,259,0.824,320,1.351,471,1.917,592,4.413,652,3.758,661,2.661,682,4.811,1025,3.199,1193,3.447,1323,2.399,1468,2.992,1538,1.84,1560,3.447,1900,4.175,2546,3.758,2689,5.344,2690,5.344,2708,4.175,2709,4.175,2710,4.175,2711,4.175,2712,5.344,2713,4.175,2714,4.175,2715,4.175,2716,5.344,2717,4.175,2718,4.175,2719,4.175,2720,4.175,2721,4.175,2722,4.175,2752,4.175,2754,4.175,2755,4.175,2756,4.175,2757,4.807,2758,4.807,2759,4.807,2760,6.153,2761,4.807,2762,4.807,2763,7.396,2764,4.807,2765,4.807,2766,4.807,2767,4.807,2768,4.807,2769,4.807]],["t/211",[17,1.646,21,1.271,25,0.02,26,0.045,27,0.02,28,0.02,43,0.041,44,0.02,45,0.037,46,0.034,49,0.091,50,0.091,51,0.034,65,2.717,140,0.676,152,0.425,183,1.59,195,0.703,218,2.962,238,2.521,242,1.511,248,1.338,249,2.385,253,1.575,259,1.171,270,1.891,271,2.097,272,3.29,276,5.069,277,4.559,291,1.721,297,3.29,320,1.065,326,1.45,351,3.6,353,1.652,384,1.576,387,2.62,399,1.238,462,2.497,485,2.385,491,1.576,655,2.962,670,2.962,786,2.497,901,3.29,929,1.576,950,2.717,1025,2.521,1085,2.097,1129,2.62,1158,1.721,1160,2.097,1214,2.717,1322,2.521,1354,2.497,1485,2.717,1499,2.521,1561,2.962,1629,2.962,1807,3.29,1866,4.321,2770,3.788,2771,6.504,2772,3.788,2773,3.788,2774,3.788,2775,3.788,2776,3.788,2777,3.788,2778,3.788,2779,3.788,2780,3.788,2781,3.788,2782,3.788,2783,3.788,2784,3.788,2785,3.788,2786,3.788,2787,3.788,2788,3.788,2789,3.788,2790,3.788,2791,3.788,2792,3.788,2793,3.788,2794,6.024,2795,3.788,2796,3.788,2797,6.024,2798,3.788,2799,3.788,2800,3.788,2801,3.788,2802,3.788,2803,3.788,2804,3.788,2805,3.788,2806,3.788,2807,3.788,2808,3.788,2809,3.788,2810,5.249,2811,3.788,2812,3.788,2813,3.788,2814,3.788,2815,3.788,2816,3.788]],["t/213",[17,3.078,21,1.134,25,0.025,26,0.045,27,0.025,28,0.025,43,0.04,44,0.025,45,0.038,46,0.042,47,0.869,49,0.112,50,0.112,51,0.042,58,3.662,67,2.517,138,0.771,139,0.421,152,0.33,159,0.836,191,2.458,202,3.02,253,1.134,270,2.337,271,2.592,276,3.359,324,3.117,326,1.793,341,2.458,342,2.337,343,2.458,345,2.337,347,2.337,348,3.359,353,1.904,374,1.177,399,1.531,462,2.228,471,1.868,491,1.948,836,2.458,852,3.176,1076,4.731,1077,3.662,1078,3.117,1079,3.117,1169,3.662,1175,4.067,1176,4.067,1193,3.359,1294,4.067,1793,4.067,2124,3.662,2180,3.662,2294,4.067,2671,4.067,2817,6.051,2818,4.683,2819,4.683,2820,4.683,2821,4.683,2822,4.683,2823,4.683,2824,4.683,2825,6.051,2826,4.683,2827,4.683,2828,4.683,2829,4.683]],["t/238",[21,0.902,23,2.319,25,0.02,26,0.045,27,0.028,28,0.02,43,0.042,44,0.02,45,0.039,46,0.033,49,0.089,50,0.089,51,0.033,67,1.55,71,2.182,139,0.536,140,0.926,152,0.509,159,1.065,195,0.963,210,1.632,253,1.445,259,0.89,310,1.859,361,1.859,363,1.618,384,1.55,553,2.84,584,1.692,657,3.717,661,3.305,786,2.468,857,2.671,967,3.974,1028,2.671,1035,3.721,1036,3.721,1054,2.912,1075,2.671,1085,3.891,1199,3.235,1220,3.235,1350,2.479,1468,2.319,1499,2.479,1566,3.235,1591,4.057,2553,2.912,2744,3.235,2830,3.725,2831,5.188,2832,3.725,2833,3.725,2834,5.188,2835,5.188,2836,5.188,2837,5.188,2838,6.457,2839,3.725,2840,3.725,2841,5.97,2842,5.97,2843,5.188,2844,3.725,2845,3.725,2846,3.725,2847,3.725,2848,3.725,2849,3.725,2850,3.725,2851,5.188,2852,5.188,2853,5.188,2854,5.188,2855,3.725,2856,3.725,2857,3.725,2858,3.725,2859,3.725,2860,3.725,2861,3.725,2862,3.725,2863,3.725,2864,3.725,2865,3.725,2866,3.725]]],"invertedIndex":[["",{"_index":26,"t":{"75":{"position":[[7,1],[33,2],[84,2],[219,1],[281,3],[322,2],[358,2],[411,1],[419,2],[490,1],[495,2],[511,2],[602,1],[618,1],[655,1],[695,1],[707,1],[723,2],[736,1],[752,1],[764,2],[777,1],[789,1],[806,2],[819,1],[836,1],[849,1],[851,2],[929,2],[998,1],[1013,2],[1026,1],[1054,1],[1073,1],[1137,2],[1155,1],[1192,1],[1218,1],[1244,1],[1271,2],[1295,1],[1326,1],[1351,1],[1363,2],[1390,1],[1506,2],[1521,1],[1543,1],[1562,1],[1584,1],[1618,1],[1633,1],[1641,1],[1657,1],[1705,1],[1733,1],[1753,2],[1756,1],[1758,2],[1851,1],[1861,1],[1884,1],[1924,1],[1926,2],[1984,1],[2073,1],[2104,1],[2128,1],[2154,1],[2178,1],[2215,1],[2253,1],[2258,2],[2304,1],[2389,1],[2413,1],[2435,1],[2470,1],[2506,1],[2529,1],[2531,1],[2544,2],[2567,1],[2597,1],[2645,2],[2648,1],[2664,1],[2696,1],[2714,3],[2718,2],[2770,2],[2773,1],[2775,2],[2840,2],[2948,1],[2981,1],[3046,1],[3081,1],[3090,2],[3150,2],[3217,1],[3221,2],[3238,1],[3266,1],[3295,1],[3326,1],[3346,1],[3350,2],[3367,1],[3396,1],[3425,1],[3456,1],[3458,2],[3527,2],[3556,1],[3562,2],[3579,1],[3599,1],[3606,2],[3623,1],[3629,2],[3646,1],[3667,1],[3674,1],[3726,1],[3757,1],[3763,1],[3765,2],[3847,1],[3863,2],[3880,1],[3884,2],[3905,1],[3921,2],[3938,1],[3943,1],[3945,2],[4012,1],[4042,1],[4061,1],[4081,1],[4101,1],[4109,2],[4112,2],[4176,2],[4217,1],[4321,2],[4324,2],[4403,1],[4457,2],[4460,2],[4525,2],[4619,1],[4685,2],[4703,1],[4724,1],[4741,2],[4840,1],[4875,1],[4887,2],[4890,1],[4892,2],[4969,1],[4971,2],[5040,2],[5104,1],[5149,2],[5246,1],[5284,1],[5305,2],[5356,1],[5393,1],[5412,2],[5415,1],[5431,2],[5461,1],[5484,2],[5514,1],[5535,2],[5563,1],[5584,2],[5612,1],[5621,3],[5625,2]]},"77":{"position":[[7,1],[43,1],[85,3],[126,2],[188,1],[254,2],[321,1],[536,1],[544,1],[560,1],[562,1],[592,1],[594,1],[610,2],[630,1],[702,1],[774,1],[840,1],[893,1],[984,2],[1007,1],[1037,1],[1202,1],[1230,1],[1269,1],[1276,1],[1278,2],[1281,1],[1297,1],[1352,1],[1411,3],[1415,2],[1476,2],[1537,2],[1573,1],[1630,2],[1718,1],[1777,3],[1781,1],[1798,1],[1815,2],[1862,1],[1864,1],[1894,1],[1905,1],[1933,1],[1961,1],[1972,1],[1996,1],[2004,1],[2006,1]]},"79":{"position":[[7,1],[43,1],[110,3],[165,1],[246,1],[302,1],[326,1],[387,1],[454,1],[477,1],[520,1],[542,1],[572,1],[642,1],[649,1],[660,1],[674,1],[733,1],[738,1],[743,1],[757,1],[772,1],[777,1],[815,1],[834,1],[858,1],[888,1],[911,1],[939,1],[963,1],[991,2],[994,1],[1020,2],[1028,1],[1037,3],[1053,1],[1112,3],[1137,1],[1206,1],[1261,1],[1284,1],[1319,1]]},"81":{"position":[[7,1],[43,1],[108,3],[149,2],[197,1],[272,1],[274,3],[293,1],[295,3],[299,2],[371,1],[377,2],[445,1],[465,1],[467,3],[471,2],[507,1],[514,1],[534,1],[572,1],[574,2],[608,1],[615,1],[632,1],[669,1],[671,2],[701,1],[746,2],[782,1],[850,1],[878,1],[908,1],[956,2],[959,1],[975,1],[991,2],[994,1],[1007,2],[1026,1],[1060,1],[1078,3],[1082,2],[1129,2],[1132,1],[1162,2],[1302,2],[1362,1],[1369,1],[1386,1],[1396,1],[1409,2],[1487,1],[1520,1],[1531,1],[1556,1],[1589,1],[1600,1],[1620,1],[1630,1],[1636,1],[1638,3],[1642,3],[1646,1],[1714,2],[1744,1],[1752,1],[1759,1],[1770,1],[1790,1],[1823,1],[1863,1],[1879,1],[1894,1],[1933,1],[1938,1],[1993,1],[2013,3],[2037,1],[2050,1],[2075,1],[2128,1],[2165,1],[2201,1],[2218,1],[2232,1],[2236,1],[2250,1],[2254,1],[2270,1],[2279,1],[2284,1],[2289,1],[2296,1],[2306,1],[2311,1],[2316,1],[2323,1],[2325,1],[2329,1],[2334,1],[2338,1],[2344,1],[2351,1],[2363,1],[2371,1]]},"83":{"position":[[7,1],[43,1],[85,3],[126,2],[173,1],[249,1],[269,1],[284,1],[306,1],[325,1],[344,1],[367,1],[391,1],[399,2],[431,1],[433,3],[448,1],[455,1],[474,1],[487,1],[489,1],[547,2],[571,1],[599,1],[684,1],[724,1],[733,1],[743,1],[759,1],[766,1],[776,1],[792,1],[799,1],[807,2],[903,1],[919,1],[929,1],[949,1],[965,1],[970,1],[982,1],[998,1],[1017,1],[1033,1],[1045,1],[1047,2],[1101,2],[1104,1],[1116,1],[1128,1],[1132,1],[1136,1],[1141,2],[1151,2],[1203,2],[1206,1],[1208,2],[1301,2],[1324,1],[1338,2],[1347,1],[1352,1],[1361,1],[1386,1],[1393,1],[1412,1],[1425,1],[1448,1],[1480,2],[1548,1],[1582,1],[1591,1],[1598,1],[1603,1],[1631,1],[1659,1],[1678,1],[1687,1],[1694,1],[1699,1],[1727,1],[1756,1],[1761,2],[1785,1],[1812,1],[1856,1],[1876,1],[1921,1],[1947,1],[1968,1],[1979,1],[1990,1],[2023,1],[2048,1],[2077,1],[2093,1],[2109,2],[2177,2],[2258,2],[2334,1],[2350,1],[2365,1],[2381,1],[2389,1],[2403,1],[2420,1],[2470,1],[2503,1],[2513,1],[2518,1],[2520,3]]},"85":{"position":[[7,1],[43,1],[108,3],[375,1],[400,1],[407,2],[479,1],[481,2],[534,1],[536,1],[779,2],[782,2],[813,1],[815,3],[839,1],[874,1],[881,1],[891,1],[902,1],[931,1],[935,1],[988,1],[990,1],[1016,3],[1091,2],[1110,1],[1131,1],[1147,1],[1162,2],[1194,1],[1201,1],[1211,1],[1226,1],[1282,1],[1308,2],[1357,1],[1361,1],[1391,1],[1408,1],[1431,1],[1459,1],[1486,1],[1528,1],[1582,1],[1602,1],[1639,2],[1652,1],[1708,1],[1743,1],[1748,1],[1769,1],[1795,1],[1838,1],[1854,1],[1957,1],[2035,1],[2039,1],[2076,2],[2105,1],[2234,2],[2375,1],[2439,3],[2458,1],[2513,1],[2558,1],[2575,1],[2604,1],[2644,1],[2677,2],[2713,1],[2773,1],[2817,1],[2836,1],[2878,1],[2963,2],[3006,1],[3032,1],[3079,2],[3082,2],[3085,1],[3100,3],[3116,1],[3125,2],[3176,1],[3207,1],[3226,1],[3233,1],[3254,1],[3264,1],[3288,1],[3315,1],[3334,1],[3347,1],[3352,1],[3356,1],[3360,1],[3380,1],[3387,1],[3391,1],[3397,1],[3405,1],[3471,3],[3492,1],[3508,1],[3517,1],[3519,1],[3521,2],[3569,1],[3579,1],[3588,1],[3590,2],[3643,2],[3646,1],[3648,2],[3680,1],[3687,1],[3708,1],[3718,1],[3730,2],[3777,2],[3884,1],[3920,1],[3944,1],[3958,2],[4005,1],[4012,1],[4037,1],[4047,1],[4075,1],[4086,1],[4101,1],[4106,1],[4126,1],[4163,1],[4167,2],[4176,1],[4191,1],[4193,2],[4234,2],[4315,1],[4355,1],[4390,1],[4402,1],[4425,1],[4456,1],[4481,1],[4518,1],[4524,1],[4526,1],[4528,1],[4530,3],[4534,1],[4536,2],[4667,1],[4669,3],[4752,1],[4766,1],[4768,1],[4907,2],[4946,1],[4948,2],[5001,2],[5004,1],[5016,1],[5043,1],[5045,3],[5060,1],[5067,1],[5091,1],[5101,1],[5128,1],[5158,1],[5190,1],[5284,3],[5291,1],[5314,1],[5373,1],[5375,1],[5388,1],[5395,1],[5417,1],[5468,1],[5470,3],[5474,2],[5522,1],[5534,1],[5544,1],[5549,1],[5554,1],[5556,2],[5590,2],[5686,1],[5699,2],[5702,1],[5707,1],[5711,1],[5722,1],[5727,1],[5731,1],[5741,1],[5747,1]]},"87":{"position":[[7,1],[43,1],[108,3],[171,1],[173,2],[215,1],[217,1],[228,2],[260,1],[262,1],[332,2],[335,2],[338,2],[341,1],[372,1],[374,1],[440,2],[443,2],[446,3],[450,2],[504,3],[508,2],[640,1],[674,1],[676,2],[723,2],[818,1],[865,2],[934,1],[1014,1],[1033,1],[1047,1],[1067,1],[1117,1],[1143,1],[1186,2],[1189,2],[1192,1],[1230,3],[1234,1],[1268,1],[1270,2],[1308,2],[1400,2],[1495,1],[1542,2],[1611,1],[1689,1],[1708,1],[1722,1],[1742,1],[1792,1],[1818,1],[1861,2],[1864,2],[1867,1],[1887,2],[1966,3],[1970,1]]},"89":{"position":[[7,1],[43,1],[108,3],[149,2],[317,2],[406,1],[452,2],[455,2],[506,2],[589,2],[592,1],[594,2],[664,1],[737,1],[756,1],[773,1],[793,1],[836,1],[901,1],[920,1],[934,1],[954,1],[984,3]]},"91":{"position":[[7,1],[43,1],[108,3],[149,2],[219,1],[278,2],[367,2],[370,1],[372,2],[440,1],[477,2],[536,2],[591,1],[610,1],[623,1],[643,1],[675,3]]},"93":{"position":[[7,1],[43,1],[108,3],[149,2],[317,2],[417,2],[560,2],[563,1],[565,2],[621,1],[629,2],[701,1],[768,1],[787,1],[804,1],[824,1],[849,1],[878,1],[955,2],[958,2],[961,1],[973,1],[987,2],[1057,1],[1092,1],[1104,1],[1120,3],[1124,3]]},"95":{"position":[[7,1],[43,1],[108,3],[149,2],[273,2],[299,1],[312,2],[315,1],[333,1],[376,1],[430,1],[510,1],[528,1],[548,1],[569,1],[645,1],[667,1],[686,1],[732,1],[742,1],[758,1],[778,1],[876,1],[896,2],[899,1],[901,2],[923,2],[932,1],[944,2],[956,1],[962,2],[997,1],[1024,1],[1029,1],[1045,1],[1072,1],[1077,1],[1100,1],[1102,1],[1104,1],[1111,1],[1122,1],[1132,1],[1143,1],[1149,2],[1170,1],[1181,1],[1191,1],[1201,1],[1207,2],[1216,1],[1223,1],[1233,1],[1243,1],[1253,1],[1259,2],[1269,1],[1276,1],[1287,1],[1298,1],[1308,1],[1314,2],[1322,2],[1325,2],[1376,1],[1396,1],[1412,1],[1419,1],[1443,1],[1459,1],[1484,1],[1566,1],[1581,1],[1594,3],[1609,1],[1617,1],[1621,1],[1625,1],[1643,1],[1655,1],[1657,1],[1673,1],[1675,1],[1682,1],[1693,1],[1698,2],[1716,1],[1726,1],[1731,2],[1753,1],[1763,1],[1768,2],[1789,1],[1800,1],[1805,2],[1827,1],[1832,2],[1845,2],[1848,2],[1959,1],[2029,2],[2060,1],[2073,1],[2090,1],[2100,1],[2124,1],[2140,1],[2144,1],[2151,1],[2169,2],[2172,2],[2175,2],[2251,2],[2277,1],[2290,2],[2293,1],[2311,1],[2354,1],[2408,1],[2432,1],[2449,1],[2451,3],[2466,1],[2473,1],[2492,1],[2505,1],[2637,1],[2641,1],[2654,1],[2667,1],[2677,1],[2682,1],[2689,1],[2699,1],[2703,1],[2716,1],[2729,1],[2739,1],[2744,1],[2751,1],[2756,2],[2777,1],[2789,1],[2809,2],[2812,1],[2814,2],[2836,2],[2845,1],[2857,2],[2869,1],[2875,2],[2918,2],[2921,1],[2933,1],[2946,1],[2959,1],[2979,2],[3058,1],[3064,1],[3070,1],[3077,1],[3085,3],[3089,2],[3092,2],[3095,2],[3165,2],[3191,1],[3204,2],[3207,1],[3225,1],[3268,1],[3322,1],[3402,1],[3420,1],[3440,1],[3459,1],[3505,1],[3515,1],[3531,1],[3551,1],[3621,1],[3641,2],[3644,1],[3646,2],[3668,2],[3677,1],[3689,2],[3701,1],[3724,1],[3738,1],[3755,1],[3763,1],[3790,1],[3805,1],[3828,1],[3847,1],[3870,1],[3880,2],[4095,2],[4098,2],[4101,2],[4206,2],[4232,1],[4245,2],[4248,1],[4266,1],[4309,1],[4363,1],[4386,1],[4403,1],[4483,1],[4503,1],[4511,2],[4611,1],[4797,1],[4813,2],[4878,1],[4894,1],[5023,2],[5093,2],[5181,1],[5227,1],[5237,1],[5253,1],[5383,1],[5403,2],[5406,1],[5408,2],[5430,2],[5439,1],[5452,2],[5464,1],[5470,2],[5505,1],[5532,1],[5537,1],[5553,1],[5580,1],[5585,1],[5593,2],[5625,1],[5627,1],[5629,1],[5636,1],[5640,1],[5658,1],[5662,1],[5679,1],[5701,1],[5705,1],[5718,2],[5739,1],[5761,1],[5765,1],[5782,1],[5803,1],[5820,2],[5829,1],[5836,1],[5840,1],[5857,1],[5878,1],[5899,1],[5916,2],[5926,1],[5933,1],[5937,1],[5955,1],[5959,1],[5977,1],[5981,1],[5998,1],[6015,2],[6023,2],[6026,2],[6090,1],[6092,1],[6119,1],[6128,2],[6131,2],[6182,1],[6202,1],[6207,2],[6315,1],[6322,1],[6346,1],[6362,1],[6387,1],[6469,1],[6484,1],[6497,3],[6512,1],[6520,1],[6524,1],[6528,1],[6546,1],[6562,1],[6582,1],[6584,1],[6600,1],[6602,1],[6610,1],[6632,1],[6648,2],[6667,1],[6688,1],[6692,1],[6704,2],[6724,1],[6728,1],[6745,1],[6749,1],[6761,2],[6782,1],[6786,1],[6804,1],[6820,2],[6833,2],[6836,2],[6966,1],[6983,2],[7014,1],[7021,1],[7037,1],[7061,1],[7077,1],[7081,1],[7088,1],[7117,1],[7129,1],[7140,1],[7160,1],[7172,1],[7183,1],[7269,2],[7272,2],[7275,2],[7384,2],[7410,1],[7423,2],[7426,1],[7444,1],[7487,1],[7547,1],[7747,1],[7890,1],[7977,1],[7997,2],[8000,1],[8002,2],[8024,2],[8033,1],[8044,2],[8056,1],[8082,1],[8091,2],[8094,2],[8110,1],[8112,1],[8328,2],[8331,2],[8383,2],[8386,1],[8388,2],[8448,2],[8451,1],[8464,3],[8468,3],[8472,3],[8476,1],[8739,2],[8793,1],[8795,2],[8849,3],[8856,2],[8862,3],[8870,2],[8877,3],[8884,2],[8890,3],[8899,1],[8915,1],[8935,1],[8948,1],[8972,1],[8986,2],[9024,3],[9031,1],[9047,1],[9058,1],[9071,1],[9095,1],[9108,1],[9132,1],[9145,1],[9169,1],[9182,1],[9197,2],[9246,1],[9250,2],[9256,1],[9260,2],[9266,1],[9270,2],[9276,1],[9281,1],[9297,1],[9299,2],[9375,1],[9380,1],[9385,1],[9406,1],[9411,1],[9416,1],[9436,1],[9443,2],[9446,1]]},"97":{"position":[[7,1],[43,1],[85,3],[126,2],[177,1],[257,1],[295,1],[348,2],[417,1],[419,3],[440,1],[457,1],[464,1],[483,1],[485,2],[581,1],[666,2],[720,1],[736,1],[744,2],[811,1],[838,1],[866,1],[893,1],[915,2],[1028,1],[1052,2],[1126,1],[1142,1],[1152,1],[1157,2],[1249,1],[1272,2],[1335,1],[1339,1],[1355,1],[1360,2],[1493,1],[1495,2],[1565,1],[1589,1],[1668,1],[1688,1],[1711,1],[1731,1],[1736,2],[1757,2],[1760,1],[1762,2],[1827,1],[1834,1],[1859,1],[1872,1],[1903,2],[1924,1],[1939,2],[1967,1],[1988,2],[2016,1],[2044,1],[2072,1],[2077,2],[2133,1],[2149,1],[2158,2],[2179,1],[2197,1],[2212,1],[2232,1],[2242,1],[2262,1],[2275,1],[2291,1],[2300,2],[2322,1],[2340,1],[2355,1],[2376,1],[2386,1],[2407,1],[2409,1],[2411,3]]},"99":{"position":[[7,1],[43,1],[108,3],[165,1],[220,2],[258,1],[318,2],[361,1],[368,1],[379,1],[393,1],[452,1],[457,1],[462,1],[476,1],[491,1],[496,1],[529,1],[531,2],[575,1],[594,1],[611,1],[631,1],[636,2],[708,1],[726,1],[749,1],[768,1],[773,2],[825,2],[828,1],[830,2],[855,2],[926,1],[933,1],[942,3]]},"101":{"position":[[7,1],[43,1],[108,3],[149,2],[222,1],[238,1],[303,2],[370,1],[399,2],[458,2],[513,1],[532,1],[545,1],[565,1],[597,1],[599,2]]},"103":{"position":[[7,1],[43,1],[108,3],[223,2],[226,1],[240,1],[289,1],[304,1],[338,2],[392,1],[439,2],[478,1],[501,2],[504,1],[506,2],[578,1],[585,1],[612,1],[629,2],[648,1],[654,1],[659,1],[666,1],[694,3],[698,3]]},"105":{"position":[[7,1],[43,1],[85,3],[126,2],[169,1],[171,3],[192,1],[209,1],[216,1],[235,1],[237,2],[333,1],[394,2],[481,2],[576,1],[592,1],[600,2],[665,1],[681,1],[708,1],[724,1],[755,1],[771,1],[783,2],[842,1],[844,2],[979,1],[995,1],[1005,1],[1010,2],[1102,1],[1125,2],[1188,1],[1192,1],[1208,1],[1213,2],[1346,1],[1348,2],[1418,1],[1442,1],[1520,1],[1540,1],[1563,1],[1583,1],[1607,2],[1610,1],[1612,2],[1678,1],[1685,1],[1707,1],[1720,1],[1748,2],[1769,1],[1784,2],[1812,1],[1833,2],[1861,1],[1889,1],[1917,1],[1922,2],[1978,1],[1994,1],[2003,2],[2024,1],[2042,1],[2057,1],[2077,1],[2087,1],[2107,1],[2120,1],[2136,1],[2145,2],[2167,1],[2185,1],[2200,1],[2221,1],[2231,1],[2252,1],[2254,1],[2256,3]]},"107":{"position":[[7,1],[43,1],[85,3],[138,2],[251,2],[290,1],[292,3],[314,1],[316,1],[379,2],[392,1],[397,2],[447,1],[488,1],[512,1],[519,2],[569,1],[643,1],[645,2],[712,1],[719,1],[731,1],[749,1],[765,1],[771,2],[825,1],[867,1],[883,1],[903,1],[919,1],[940,1],[956,1],[984,1],[1006,1],[1065,1],[1080,1],[1082,2],[1111,1],[1179,1],[1210,1],[1243,1],[1263,2],[1266,1],[1268,2],[1319,1],[1326,1],[1338,1],[1352,1],[1380,2],[1388,1],[1396,2],[1428,1],[1470,1],[1513,2],[1522,3]]},"109":{"position":[[7,1],[43,1],[105,3],[146,2],[201,1],[260,2],[319,2],[374,1],[393,1],[406,1],[426,1],[476,2],[479,1],[481,2],[545,2],[553,3]]},"111":{"position":[[7,1],[43,1],[108,3],[149,2],[229,1],[270,1],[329,2],[390,1],[409,1],[423,1],[443,1],[448,2],[492,1],[504,2],[539,1],[552,2],[655,2],[687,1],[703,2],[735,2],[749,2],[779,2],[840,1],[857,2],[881,2],[890,1]]},"113":{"position":[[7,1],[43,1],[85,3],[140,1],[176,1],[247,3],[280,2],[338,1],[340,3],[363,1],[403,1],[411,1],[429,1],[436,1],[457,1],[459,2],[493,1],[558,2],[644,2],[701,1],[717,1],[725,2],[752,1],[768,1],[795,1],[811,1],[842,1],[858,1],[870,2],[925,1],[941,1],[951,1],[956,2],[1050,1],[1073,2],[1153,1],[1158,1],[1174,1],[1179,1],[1198,1],[1214,1],[1221,2],[1354,1],[1356,2],[1432,1],[1456,1],[1535,1],[1555,1],[1578,1],[1598,1],[1603,2],[1615,1],[1638,2],[1641,1],[1643,2],[1711,1],[1718,1],[1741,1],[1754,1],[1781,1],[1788,1],[1804,1],[1819,1],[1842,2],[1863,1],[1878,2],[1906,1],[1920,1],[1944,2],[1972,1],[1986,1],[2017,1],[2035,1],[2046,2],[2077,1],[2093,1],[2102,2],[2123,1],[2141,1],[2156,1],[2176,1],[2186,1],[2206,1],[2219,1],[2235,1],[2244,2],[2266,1],[2284,1],[2299,1],[2320,1],[2330,1],[2351,1],[2353,1],[2355,2],[2384,2],[2392,3]]},"115":{"position":[[7,1],[43,1],[108,3],[149,2],[190,1],[261,1],[326,2],[395,1],[449,1],[462,2],[505,1],[585,1],[623,1],[644,2],[706,2],[769,1],[854,1],[944,1],[1024,1],[1026,3],[1052,1],[1054,1],[1104,2],[1118,1],[1125,1],[1135,1],[1150,1],[1198,1],[1242,1],[1262,1],[1277,1],[1297,1],[1301,1],[1307,2],[1358,1],[1540,2],[1591,2],[1636,1],[1638,2],[1713,1],[1723,1],[1808,1],[1843,1],[1857,1],[1878,1],[1910,1],[1915,1],[1939,1],[1953,1],[1979,1],[1994,1],[2015,1],[2022,1],[2037,1],[2054,1],[2056,1],[2082,1],[2096,1],[2121,1],[2131,1],[2146,1],[2167,1],[2192,1],[2206,1],[2232,1],[2242,1],[2257,1],[2274,1]]},"117":{"position":[[7,1],[43,1],[108,3],[149,2],[202,1],[262,2],[321,1],[360,1],[367,1],[378,1],[418,1],[464,1],[486,2],[489,1],[518,1],[520,2],[568,1],[596,2],[709,1],[721,2],[833,1],[846,2],[904,2],[972,2],[998,1],[1012,2],[1079,2],[1133,1],[1146,1],[1151,2],[1201,1],[1218,1],[1246,1],[1276,1],[1400,1],[1418,1],[1488,1],[1490,1],[1515,1],[1517,2],[1550,2],[1598,2],[1656,2],[1669,1],[1694,1],[1712,1],[1761,1],[1784,1],[1802,1],[1863,1],[1879,1],[1887,1],[1889,1]]},"119":{"position":[[7,1],[33,2],[119,1],[184,3],[237,1],[409,1],[425,2],[428,3],[440,1],[456,1],[458,3],[476,1],[515,1],[531,4],[546,1],[562,1],[582,1],[593,2],[633,1],[741,1],[767,1],[774,2],[829,1],[947,1],[962,2],[1018,1],[1048,1],[1081,1],[1112,1],[1144,1],[1157,1],[1184,1],[1225,1],[1249,2],[1383,3],[1395,2],[1403,3],[1422,2],[1430,3],[1450,1],[1504,2],[1507,4],[1512,1],[1514,2],[1568,1],[1574,1],[1595,1],[1601,1],[1617,1],[1619,1],[1621,2],[1652,1],[1671,1],[1722,2],[1725,1],[1924,3]]},"121":{"position":[[7,1],[43,1],[85,3],[126,2],[169,1],[249,1],[287,1],[308,2],[370,2],[433,1],[518,1],[608,1],[688,1],[690,3],[716,1],[718,1],[768,2],[782,1],[789,1],[799,1],[814,1],[881,1],[901,1],[916,1],[936,1],[940,1],[946,2],[997,1],[1023,1],[1043,2],[1052,1],[1087,2],[1133,2],[1314,2],[1339,2],[1373,2],[1403,2],[1440,2],[1474,2],[1506,2],[1531,2],[1566,2],[1597,2],[1635,2],[1686,2],[1731,1],[1733,2],[1808,1],[1818,1],[1903,1],[1938,1],[1952,1],[1973,1],[2005,1],[2010,1],[2034,1],[2048,1],[2074,1],[2089,1],[2110,1],[2117,1],[2132,1],[2149,1],[2151,1],[2177,1],[2191,1],[2216,1],[2226,1],[2241,1],[2262,1],[2287,1],[2301,1],[2327,1],[2337,1],[2352,1],[2369,1]]},"123":{"position":[[7,1],[43,1],[76,1],[100,3],[158,1],[223,2],[267,1],[352,1],[387,1],[545,2],[588,1],[655,2],[729,2],[765,1],[871,3],[894,1],[929,1],[1087,2],[1131,1],[1217,1],[1252,1],[1281,1],[1402,1],[1562,2],[1590,2],[1666,2],[1721,1],[1806,1],[1927,1],[1942,2],[2004,1],[2110,3],[2133,1],[2168,1],[2338,1],[2377,3],[2393,1],[2437,1],[2453,1],[2467,1],[2483,1],[2502,1],[2546,1],[2562,1],[2576,1],[2592,1],[2611,1],[2651,1],[2667,1],[2681,1],[2697,1],[2716,1],[2738,1],[2767,1],[2797,1],[2813,1],[2820,2],[2961,2],[2983,1],[2995,1],[3007,1],[3034,1],[3046,1],[3058,1],[3084,1],[3096,1],[3108,1]]},"125":{"position":[[7,1],[33,2],[100,2],[136,1],[201,3],[242,2],[276,1],[390,2],[464,1],[487,1],[493,2],[538,1],[550,2],[640,1],[654,2],[722,2],[725,1],[763,3]]},"127":{"position":[[7,1],[43,1],[108,3],[167,1],[205,1],[225,2],[285,1],[299,2],[336,1],[356,1],[441,1],[470,1],[484,1],[498,1],[506,2],[538,1],[612,1],[628,1],[642,1],[656,1],[678,1],[704,1],[873,2],[946,1],[1061,1],[1140,1],[1153,1],[1166,1],[1180,1],[1185,2],[1210,1],[1275,1],[1347,3],[1369,1],[1385,1],[1398,1],[1411,1],[1470,2],[1551,1],[1573,1],[1636,1],[1638,2],[1715,1],[1737,1],[1801,1],[1803,2],[1835,1],[1896,1],[1920,1],[1935,1],[1940,2],[2027,1],[2124,3],[2128,2],[2183,1],[2187,1],[2200,1],[2241,1],[2248,1],[2255,1]]},"129":{"position":[[7,1],[43,1],[85,3],[126,2],[170,1],[249,1],[287,1],[340,2],[468,2],[512,2],[565,1],[567,2],[641,1],[671,1],[693,3],[697,2],[700,3],[712,3],[716,2],[758,2],[790,2],[823,1],[829,2],[866,1],[878,2],[920,1],[922,2],[967,2],[970,1],[1002,2],[1010,1],[1019,3]]},"131":{"position":[[7,1],[33,3],[37,1],[158,1],[280,1],[301,3],[315,1],[380,3],[511,1],[530,1],[556,1],[587,3],[662,1],[694,1],[740,1],[745,2],[828,2],[897,1],[1056,2],[1157,2],[1229,1],[1240,1],[1268,1],[1291,1],[1347,1],[1413,1],[1468,1],[1479,1],[1506,1],[1641,3],[1652,1],[1695,1],[1709,1],[1719,1],[1790,1],[1828,1],[1872,2],[1885,1],[1905,1],[1941,1],[1999,1],[2046,1],[2073,1],[2080,1],[2088,1],[2132,1],[2152,1],[2169,1],[2176,1],[2188,1],[2197,1],[2201,1],[2210,1],[2224,1],[2349,1],[2358,1],[2368,1],[2374,1],[2380,1],[2400,1],[2426,1],[2438,1],[2461,1],[2489,1],[2496,1],[2505,1],[2514,1],[2516,1],[2531,1],[2548,1],[2550,2],[2585,1],[2587,2],[2697,1],[2749,1],[2758,2],[2785,1],[2819,1],[2847,3],[2872,1],[2913,1],[2925,2],[2978,2],[2981,1],[3004,1],[3027,2],[3036,1],[3042,3],[3046,1]]},"133":{"position":[[7,1],[33,3],[37,1],[98,2],[111,1],[153,3],[194,2],[238,1],[317,1],[355,1],[408,2],[507,2],[610,2],[643,2],[663,1],[665,1],[820,1],[837,1],[853,1],[868,1],[916,1],[924,1],[939,1],[966,1],[1000,1],[1007,1],[1009,2],[1064,1],[1111,1],[1134,1],[1141,1],[1143,1],[1145,2],[1164,1],[1209,1],[1334,1],[1370,1],[1397,3],[1419,1],[1449,1],[1483,1],[1531,2],[1534,1],[1582,3]]},"135":{"position":[[7,1],[43,1],[85,3],[135,1],[224,1],[254,1],[317,1],[414,1],[434,1],[460,1],[518,1],[614,1],[634,1],[660,1],[718,1],[769,1],[822,1],[859,1],[886,1],[909,2],[912,1],[920,2],[947,1],[984,1],[1020,1],[1025,1],[1058,1],[1063,1],[1080,3]]},"137":{"position":[[7,1],[43,1],[85,3],[146,1],[174,1],[243,1],[263,1],[322,1],[332,1],[355,1],[365,1],[370,2],[387,1],[389,3],[404,1],[411,1],[422,1],[437,1],[566,1],[582,1],[592,1],[610,1],[632,1],[664,1],[680,1],[705,1],[721,1],[757,1],[773,1],[797,1],[879,1],[906,1],[1006,1],[1123,1],[1174,1],[1208,1],[1262,1],[1368,1],[1412,1],[1483,1],[1513,1],[1543,1],[1683,1],[1698,1],[1847,1],[1859,1],[1882,2],[1885,1],[1893,2],[1913,1],[1920,1],[1943,1],[1958,1],[1989,2],[2009,1],[2026,2],[2056,1],[2081,2],[2111,1],[2143,1],[2173,1],[2193,1],[2213,1],[2231,1],[2238,2],[2291,1],[2303,1],[2314,2],[2331,1],[2351,1],[2362,1],[2378,1],[2390,1],[2406,1],[2421,1],[2433,1],[2444,2],[2462,1],[2482,1],[2493,1],[2510,1],[2522,1],[2539,1],[2541,1],[2543,3]]},"139":{"position":[[7,1],[65,2],[143,2],[222,2],[258,1],[323,3],[364,2],[436,2],[512,2],[591,2],[652,2],[655,2],[725,2],[789,1],[805,1],[816,2],[880,1],[904,2],[991,1],[1012,2],[1081,2],[1105,1],[1145,2],[1206,2],[1251,1],[1264,2],[1267,1],[1269,2],[1381,2],[1486,2],[1552,2],[1576,1],[1627,2],[1630,2],[1693,1],[1794,2],[1797,1],[1832,2],[1863,3],[1882,1],[1894,1],[1896,2],[1932,1],[1963,1],[1965,2],[2034,1],[2106,1],[2108,2],[2158,1],[2180,1],[2335,2],[2338,1],[2340,2],[2391,1],[2443,1],[2445,2],[2496,1],[2545,1],[2594,1],[2647,1],[2676,2],[3069,1],[3071,2],[3141,1],[3271,1],[3273,1],[3275,2],[3308,1],[3347,2],[3463,2],[3533,2],[3536,2],[3579,1],[3599,2],[3668,1],[3677,1],[3681,1],[3688,2],[3718,1],[3734,1],[3752,1],[3759,2],[3827,2],[3871,1],[3890,1],[3923,1],[3994,2],[4052,2],[4097,1],[4154,1],[4166,2],[4192,1],[4234,2],[4237,1],[4239,2],[4279,1],[4291,2],[4325,1],[4338,2],[4404,2],[4407,1],[4422,1],[4444,1],[4494,2],[4504,1],[4511,3],[4515,2],[4588,2],[4591,1],[4610,3],[4617,1],[4653,1],[4667,1],[4674,1],[4707,1],[4720,1],[4722,3],[4726,3],[4766,1],[4821,2],[4824,1],[4852,4],[4869,3],[4891,1],[4947,1],[4974,3],[4992,1],[5013,1],[5107,2],[5110,1],[5125,1],[5142,1],[5161,1],[5182,1],[5199,1],[5218,1],[5243,1],[5285,3],[5307,1],[5415,1],[5421,1],[5462,1],[5468,1],[5496,1],[5551,2],[5554,2]]},"141":{"position":[[7,1],[43,1],[85,3],[146,1],[167,1],[255,1],[274,1],[284,1],[304,1],[322,1],[378,1],[414,1],[433,1],[450,1],[470,1],[489,1],[625,1],[758,1],[890,1],[1048,1],[1070,1],[1087,1],[1122,2],[1125,2],[1128,1],[1138,1],[1168,1],[1178,1],[1189,1],[1197,3],[1212,1],[1261,1],[1270,1],[1342,3],[1353,1],[1386,1],[1441,2],[1444,1],[1458,2],[1485,1],[1509,2],[1534,2],[1557,1],[1561,1],[1579,1],[1601,1],[1605,1],[1623,1],[1637,2],[1651,1],[1660,1],[1662,1],[1682,1],[1700,1],[1715,1],[1744,1],[1762,1],[1779,1],[1796,1],[1801,1],[1816,1],[1833,1],[1849,1],[1866,1],[1872,3]]},"143":{"position":[[7,1],[43,1],[102,3],[156,1],[219,2],[222,2],[238,4],[243,2],[317,1],[500,1],[526,1],[575,1],[702,1],[726,1],[760,2],[763,2],[781,4],[802,1],[990,1],[1018,1],[1070,1],[1155,3],[1230,1],[1256,1],[1292,2],[1295,2],[1302,4],[1317,1],[1404,1],[1441,2],[1444,2],[1453,4],[1469,1],[1549,1],[1562,1],[1572,1],[1604,2],[1607,2],[1616,4],[1632,1],[1714,3],[1743,1],[1758,1],[1768,1],[1800,2],[1803,1],[1810,4],[1833,1],[2149,2],[2152,2],[2174,4],[2198,1],[2288,3]]},"145":{"position":[[7,1],[43,1],[102,3],[163,1],[193,1],[222,1],[245,2],[341,2],[555,2],[662,2],[934,2],[1028,2],[1275,2],[1318,1],[1376,1],[1382,1],[1395,1],[1401,1],[1416,1],[1421,2],[1480,1],[1515,2],[1518,2],[1521,1],[1556,1],[1576,1],[1622,1],[1643,1],[1689,1],[1710,1],[1731,1],[1752,1],[1773,1],[1794,1],[1801,2],[1804,3],[1826,2],[1829,1],[1837,2],[1944,1],[1962,1],[1973,1],[1991,1],[2015,1],[2033,1],[2044,1],[2062,1],[2086,1],[2104,1],[2114,1],[2132,1],[2157,1],[2175,1],[2185,1],[2203,1],[2228,1],[2246,1],[2257,1],[2275,1],[2316,1],[2324,1],[2331,3]]},"147":{"position":[[7,1],[43,1],[85,3],[146,1],[174,1],[240,1],[344,1],[358,1],[390,1],[480,2],[565,1],[616,1],[702,1],[736,1],[806,1],[857,1],[890,1],[914,2],[917,1],[919,2],[994,2],[1089,2],[1199,1],[1227,1],[1250,1],[1255,1],[1257,3]]},"149":{"position":[[7,1],[43,1],[85,3],[126,2],[169,1],[176,2],[210,1],[295,2],[298,1],[317,1],[399,1],[437,1],[471,1],[533,1],[552,1],[599,1],[655,1],[690,1],[702,1],[715,1],[727,1],[747,1],[836,1],[907,1],[936,1],[966,1],[1016,2],[1019,1],[1038,1],[1069,1],[1091,1],[1123,1],[1128,3],[1132,3]]},"151":{"position":[[7,1],[75,1],[134,3],[190,1],[213,2],[313,2],[326,1],[465,2],[478,1],[618,2],[757,2],[790,2],[960,2],[970,1],[1109,2],[1119,1],[1259,2],[1270,1],[1414,2],[1644,2],[1813,2],[1948,2],[2085,2],[2222,2],[2249,1]]},"153":{"position":[[7,1],[43,1],[102,3],[163,1],[184,1],[272,1],[291,1],[301,1],[321,1],[366,1],[402,1],[421,1],[438,1],[458,1],[463,2],[503,1],[610,1],[715,1],[819,1],[984,2],[1027,1],[1085,1],[1104,1],[1117,1],[1137,1],[1177,1],[1196,1],[1228,2],[1231,2],[1234,1],[1257,1],[1274,1],[1283,1],[1290,1],[1307,1],[1315,1],[1317,3],[1332,1],[1381,1],[1390,1],[1462,3],[1473,1],[1506,1],[1556,2],[1559,1],[1573,2],[1600,1],[1624,2],[1649,2],[1672,1],[1676,1],[1694,1],[1716,1],[1720,1],[1738,1],[1752,2],[1825,1],[1843,1],[1854,1],[1872,1],[1896,1],[1914,1],[1925,1],[1943,1],[1967,1],[1985,1],[1995,1],[2013,1],[2038,1],[2056,1],[2066,1],[2084,1],[2106,1],[2114,1],[2121,3]]},"155":{"position":[[7,1],[43,1],[85,3],[146,1],[167,1],[265,1],[357,1],[449,1],[463,1],[481,1],[535,1],[581,1],[592,1],[619,1],[636,1],[663,1],[671,1],[691,2],[694,1],[703,2],[726,1],[740,2],[763,1],[802,1],[807,1],[818,1],[820,3]]},"157":{"position":[[7,1],[43,1],[85,3],[141,1],[196,2],[218,1],[231,2],[250,2],[280,2],[291,2],[342,2],[371,2],[385,2],[406,2],[417,2],[504,1],[697,1],[704,1],[724,1],[749,1],[769,1],[814,3],[904,1],[919,1],[947,2],[950,1],[952,2],[955,1],[1036,3],[1051,1],[1183,2],[1186,1],[1202,2],[1211,3]]},"159":{"position":[[7,1],[43,1],[85,3],[141,1],[186,1],[234,1],[265,1],[289,1],[310,1],[328,1],[386,1],[402,1],[499,1],[515,1],[537,2],[618,1],[634,1],[650,1],[671,2],[685,1],[692,1],[723,1],[746,1],[750,1],[766,1],[807,1],[812,1],[816,1],[849,1],[854,1],[898,1],[903,1],[947,1],[952,1],[969,1],[984,1],[1190,1],[1197,1],[1218,1],[1243,1],[1263,1],[1276,1],[1306,3],[1367,1],[1382,1],[1401,1],[1403,3],[1423,1],[1546,2],[1549,1],[1570,2],[1579,3]]},"161":{"position":[[7,1],[43,1],[85,3],[141,1],[196,2],[218,1],[231,2],[250,2],[280,2],[291,2],[342,2],[371,2],[385,2],[406,2],[417,2],[493,1],[548,2],[570,1],[576,1],[589,2],[601,1],[614,2],[626,1],[639,2],[650,2],[701,2],[730,2],[744,2],[759,2],[770,2],[837,1],[896,1],[1089,1],[1096,1],[1116,1],[1141,1],[1161,1],[1206,3],[1296,1],[1311,1],[1339,2],[1342,1],[1344,2],[1347,1],[1428,3],[1443,1],[1576,2],[1579,1],[1595,2],[1604,3]]},"163":{"position":[[7,1],[43,1],[98,3],[139,2],[173,1],[228,2],[257,2],[273,2],[300,2],[311,2],[362,2],[391,2],[405,2],[426,2],[437,2],[497,2],[563,1],[565,1],[739,1],[746,1],[766,1],[791,1],[811,1],[856,3],[860,2],[934,1],[995,2],[1050,1],[1052,1],[1130,1],[1219,1],[1252,1],[1282,1],[1322,1],[1364,1],[1376,1],[1389,1],[1395,1],[1404,1],[1427,1],[1439,3],[1462,1],[1464,1],[1476,2],[1496,1],[1558,2],[1602,2],[1705,1],[1759,3],[1778,1],[1837,1],[1895,2],[1976,1],[1978,1],[2104,1],[2140,1],[2196,1],[2234,1],[2268,2],[2296,1],[2322,1],[2331,3],[2356,1],[2358,1],[2403,2],[2425,1],[2511,1],[2565,3],[2586,1],[2649,1],[2711,2],[2780,1],[2782,1],[2886,1],[2900,1],[2934,1],[2969,1],[2984,3],[3008,1],[3010,1],[3046,2],[3067,1],[3150,1],[3204,3],[3224,1],[3285,1],[3345,2],[3383,1],[3385,1],[3488,1],[3551,1],[3589,1],[3666,2],[3744,2],[3823,2],[3904,2],[3979,1],[4001,3],[4024,1],[4026,1],[4054,2],[4074,1],[4154,1],[4208,3],[4227,1],[4286,1],[4344,2],[4395,1],[4397,1],[4539,1],[4575,1],[4616,1],[4655,1],[4696,1],[4725,3],[4751,1],[4753,1],[4827,2],[4850,1],[4936,1],[5164,2],[5409,2],[5443,1],[5471,2],[5474,1],[5481,2],[5486,1],[5492,2],[5525,1],[5581,1],[5620,1],[5660,1],[5676,1],[5683,1],[5690,1],[5697,2],[5765,1],[5794,3],[5830,1],[5861,3],[5896,1],[5926,3],[5960,1],[5989,3],[5993,3]]},"165":{"position":[[7,1],[43,1],[85,3],[126,2],[160,1],[215,2],[237,1],[250,2],[269,2],[299,2],[310,2],[361,2],[390,2],[404,2],[425,2],[436,2],[512,1],[514,1],[688,1],[695,1],[715,1],[740,1],[760,1],[805,3],[827,1],[829,1],[975,2],[1076,2],[1148,1],[1159,1],[1187,1],[1210,1],[1280,1],[1335,1],[1346,1],[1373,1],[1508,3],[1519,1],[1562,1],[1576,1],[1586,1],[1638,1],[1676,1],[1720,2],[1733,1],[1753,1],[1789,1],[1847,1],[1894,1],[1921,1],[1928,1],[1936,1],[1980,1],[2000,1],[2017,1],[2024,1],[2036,1],[2045,1],[2049,1],[2058,1],[2072,1],[2197,1],[2206,1],[2216,1],[2222,1],[2228,1],[2248,1],[2274,1],[2286,1],[2309,1],[2337,1],[2344,1],[2353,1],[2362,1],[2364,1],[2379,1],[2396,3],[2415,1],[2417,1],[2494,2],[2497,2],[2585,1],[2645,1],[2654,2],[2701,1],[2766,1],[2875,2],[2909,1],[2937,2],[2940,1],[2947,2],[2952,1],[2984,1],[3030,1],[3056,1],[3064,1],[3070,3]]},"167":{"position":[[7,1],[43,1],[85,3],[141,1],[196,2],[218,1],[231,2],[250,2],[269,2],[280,2],[331,2],[360,2],[374,2],[389,2],[401,2],[444,1],[638,1],[645,1],[665,1],[690,1],[710,1],[755,3],[851,1],[866,1],[902,1],[904,3],[923,1],[974,1],[1061,4],[1082,1],[1133,1],[1214,4],[1235,1],[1286,1],[1373,4],[1601,2],[1604,1],[1624,2],[1653,1],[1681,1],[1690,3]]},"169":{"position":[[7,1],[43,1],[85,3],[141,1],[196,2],[218,1],[231,2],[250,2],[269,2],[299,2],[328,2],[342,2],[358,2],[379,1],[572,1],[579,1],[599,1],[624,1],[644,1],[689,3],[779,1],[794,1],[824,1],[826,2],[829,1],[910,3],[928,1],[1121,1],[1128,1],[1148,1],[1173,1],[1193,1],[1238,3],[1328,1],[1343,1],[1388,2],[1415,1],[1424,1],[1431,1],[1452,2],[1479,1],[1488,1],[1495,1],[1501,1],[1503,2],[1506,1],[1587,3],[1606,1],[1657,1],[1871,2],[1874,1],[1894,2],[1923,1],[1932,3]]},"171":{"position":[[7,1],[43,1],[85,3],[136,1],[141,2],[175,1],[194,1],[196,3],[211,1],[218,1],[229,1],[260,1],[279,1],[293,1],[390,1],[405,1],[447,1],[474,1],[489,1],[523,2],[560,2],[563,1],[571,2],[579,2],[608,1],[615,1],[637,1],[651,1],[665,1],[672,1],[681,1],[699,1],[703,1],[716,1],[730,1],[737,1],[746,1],[752,1],[770,3],[798,1],[884,1],[891,1],[913,1],[951,1],[964,1],[971,1],[993,1],[1075,1],[1077,1]]},"173":{"position":[[7,1],[43,1],[85,3],[136,1],[141,2],[175,1],[181,1],[200,1],[202,3],[217,1],[224,1],[235,1],[266,1],[285,1],[299,1],[396,1],[425,1],[466,1],[490,1],[526,1],[621,2],[624,1],[632,2],[640,2],[669,1],[676,1],[698,1],[712,1],[726,1],[733,1],[742,1],[760,1],[764,1],[777,1],[791,1],[798,1],[807,1],[813,1],[815,3]]},"175":{"position":[[7,1],[43,1],[85,3],[141,1],[196,1],[241,1],[394,1],[408,1],[433,1],[453,1],[498,3],[540,1],[555,1],[583,1],[585,3],[604,1],[725,2],[728,1],[748,2],[757,3]]},"177":{"position":[[7,1],[43,1],[85,3],[141,1],[196,2],[218,1],[230,2],[248,2],[269,2],[280,2],[333,2],[365,2],[385,2],[406,2],[421,2],[463,1],[660,1],[669,1],[691,1],[716,1],[736,1],[781,3],[844,1],[859,1],[880,1],[882,3],[901,1],[1045,2],[1048,1],[1068,2],[1077,3]]},"179":{"position":[[7,1],[43,1],[85,3],[141,1],[196,2],[218,1],[231,2],[250,2],[269,2],[280,2],[333,2],[365,2],[385,2],[406,2],[420,2],[471,2],[500,2],[514,2],[529,2],[541,2],[586,1],[588,1],[806,1],[813,1],[828,1],[850,1],[875,1],[895,1],[940,3],[962,1],[964,1],[1072,1],[1087,1],[1116,1],[1137,3],[1156,1],[1158,1],[1238,2],[1254,1],[1323,1],[1467,2],[1470,1],[1490,2],[1499,3]]},"181":{"position":[[7,1],[43,1],[85,3],[141,1],[196,2],[218,1],[231,2],[250,2],[280,2],[291,2],[342,2],[371,2],[385,2],[406,2],[417,2],[493,1],[495,1],[669,1],[676,1],[696,1],[721,1],[741,1],[786,3],[808,1],[810,1],[917,1],[932,1],[960,1],[973,1],[984,1],[991,1],[993,1],[999,2],[1002,3],[1021,1],[1023,1],[1113,2],[1129,1],[1194,1],[1303,2],[1328,2],[1386,2],[1389,1],[1405,2],[1440,2],[1448,3]]},"183":{"position":[[7,1],[43,1],[103,3],[237,2],[240,1],[242,2],[298,1],[300,3],[318,1],[325,1],[336,1],[353,1],[392,1],[434,1],[510,3],[514,1],[530,1],[535,2],[578,1],[682,1],[696,1],[730,1],[742,1],[762,1],[806,2],[849,1],[940,1],[960,1],[974,1],[986,1],[1006,1],[1050,2],[1082,3]]},"185":{"position":[[7,1],[43,1],[103,3],[218,2],[221,1],[223,2],[288,1],[290,3],[308,1],[315,1],[326,1],[342,1],[388,1],[433,1],[442,1],[449,1],[460,1],[462,2],[516,1],[574,1],[590,1],[622,1],[638,1],[705,1],[721,1],[757,1],[773,1],[817,1],[822,1],[859,1],[861,2],[893,3]]},"187":{"position":[[7,1],[43,1],[108,3],[228,2],[231,1],[233,2],[296,1],[298,3],[313,1],[320,1],[331,1],[343,1],[347,1],[352,1],[362,1],[367,2],[500,1],[502,2],[582,2],[596,1],[631,2],[634,1],[699,1],[758,2],[768,1],[787,1],[799,1],[819,1],[866,1],[912,2],[954,2],[957,1],[973,2],[982,3],[986,3]]},"189":{"position":[[7,1],[43,1],[108,3],[149,2],[203,1],[262,2],[321,2],[376,1],[395,1],[408,1],[428,1],[460,2],[512,2],[515,1],[517,2],[566,2],[611,2],[670,2],[677,1],[686,3]]},"191":{"position":[[7,1],[43,1],[108,3],[162,1],[184,1],[268,1],[330,2],[387,1],[415,2],[477,2],[536,1],[555,1],[572,1],[592,1],[628,2],[679,1],[708,1],[748,2],[751,2],[754,1],[765,1],[778,2],[828,1],[839,1],[849,1],[866,3],[888,2],[891,1],[912,2],[921,3]]},"193":{"position":[[7,1],[33,2],[122,1],[169,1],[218,1],[288,3],[343,1],[398,2],[436,1],[496,2],[539,1],[546,1],[557,1],[571,1],[630,1],[635,1],[640,1],[654,1],[669,1],[674,1],[707,1],[709,2],[753,1],[772,1],[789,1],[809,1],[814,2],[886,1],[904,1],[927,1],[946,1],[951,2],[1003,2],[1006,1],[1008,2],[1033,2],[1104,1],[1111,1],[1120,3]]},"195":{"position":[[7,1],[43,1],[85,3],[126,2],[179,1],[237,2],[263,3],[267,1],[310,1],[372,2],[394,1],[465,2],[512,1],[535,2],[538,1],[546,2],[581,1],[585,1],[629,1],[633,1],[680,2],[714,2],[720,3]]},"197":{"position":[[7,1],[43,1],[108,3],[227,2],[230,1],[253,1],[317,1],[369,2],[372,2],[392,1],[415,1],[458,3]]},"199":{"position":[[7,1],[43,1],[105,3],[146,2],[219,1],[380,2],[412,1],[448,1],[462,1],[500,1],[505,2],[560,1],[586,1],[599,2],[647,2],[706,2],[764,2],[821,2],[883,2],[945,2],[1006,2],[1096,1],[1098,2],[1149,2],[1201,1],[1261,2],[1347,1],[1375,2],[1418,1],[1457,1],[1511,1]]},"201":{"position":[[7,1],[43,1],[108,3],[149,2],[208,1],[499,3],[543,2],[546,1],[560,1],[652,4],[669,1],[755,4],[772,1],[877,4],[894,1],[990,4],[1003,1],[1018,1],[1033,1],[1148,3]]},"203":{"position":[[7,1],[43,1],[108,3],[149,2],[215,1],[217,1],[227,1],[252,2],[264,1],[274,2],[277,2],[280,2],[298,2],[301,2],[351,1],[362,1],[405,1],[437,3],[450,1],[460,1],[534,1],[564,1],[582,1],[662,5],[668,2],[686,2],[705,1],[707,2],[776,1],[844,1],[913,1],[915,2],[984,1]]},"205":{"position":[[7,1],[43,1],[108,3],[165,1],[216,1],[234,1],[284,1],[413,2],[554,1],[637,3],[656,1],[752,1],[769,1],[822,1],[1115,3],[1134,1],[1251,1],[1269,1]]},"207":{"position":[[7,1],[33,2],[67,1],[91,1],[110,2],[153,2],[306,1],[322,1],[324,2],[376,2],[429,1],[472,1],[480,1],[488,1],[490,1],[498,2],[541,1],[550,1],[552,1],[560,2],[576,2],[659,1],[708,1],[731,1],[751,1],[788,1],[986,1],[1028,2],[1083,2],[1144,1],[1170,1],[1180,2],[1229,2],[1296,1],[1301,1],[1303,1],[1513,1],[1515,1],[1527,1],[1586,3],[1649,1],[1697,2],[1765,2],[1833,2],[1925,1],[1975,1],[2054,1],[2064,1]]},"209":{"position":[[7,1],[33,2],[73,2],[181,1],[240,3],[310,1],[312,2],[399,1],[419,1],[468,1],[493,1],[508,1],[535,2],[584,1],[784,1],[857,1],[877,1],[913,1],[992,1],[1002,1],[1020,1],[1041,1]]},"211":{"position":[[7,1],[43,1],[85,3],[142,1],[144,1],[198,2],[201,2],[318,1],[377,1],[438,1],[455,2],[543,1],[578,2],[613,1],[635,1],[672,2],[743,1],[784,1],[808,1],[851,2],[898,1],[900,1],[1270,2],[1273,2],[1313,1],[1315,3],[1319,2],[1405,1],[1412,1],[1423,1],[1436,1],[1464,1],[1490,1],[1506,1],[1526,1],[1542,1],[1626,1],[1628,2],[1660,1],[1683,2],[1686,1],[1699,1],[1706,1],[1727,1],[1729,2],[1760,1],[1786,2],[1794,1],[1802,2],[1811,2],[1831,3],[1846,1],[1877,1],[1910,1],[1918,2],[1962,1],[1979,2],[2022,1],[2055,1],[2073,1],[2081,2],[2116,2],[2211,1],[2258,3],[2262,3]]},"213":{"position":[[7,1],[43,1],[108,3],[165,1],[234,1],[305,1],[312,1],[323,1],[337,1],[373,1],[378,1],[383,1],[397,1],[412,1],[417,1],[438,1],[454,1],[465,1],[498,1],[509,1],[615,3],[632,1],[664,1],[680,1],[714,2],[717,1],[787,1],[885,1],[911,1],[1004,2],[1019,1],[1038,1],[1062,2],[1065,1],[1098,1],[1118,3],[1122,3]]},"238":{"position":[[7,1],[43,1],[85,3],[201,2],[204,1],[206,2],[248,1],[270,1],[302,1],[314,1],[330,1],[340,1],[364,1],[386,1],[418,1],[442,1],[465,1],[494,1],[502,1],[504,1],[526,1],[599,1],[638,1],[642,3],[649,1],[666,1],[734,1],[741,1],[743,2],[770,2],[872,1],[969,1],[1002,1],[1018,1],[1037,1],[1042,1],[1061,1],[1081,1],[1085,1],[1102,1],[1121,1],[1125,1],[1142,1],[1162,1],[1166,1],[1171,2],[1214,1],[1221,1],[1232,1],[1234,2],[1290,1],[1319,1],[1323,1],[1327,1],[1331,1],[1341,1],[1345,1],[1365,1],[1385,1],[1392,2],[1418,1],[1428,1],[1436,1],[1441,1],[1454,1],[1464,1],[1472,1],[1477,1],[1481,1],[1524,1],[1548,1],[1575,1],[1652,3],[1663,1],[1680,1],[1721,1],[1723,3]]}}}],["0",{"_index":152,"t":{"75":{"position":[[2369,3],[2536,2],[2542,1],[3219,1],[3348,1],[3882,1],[3940,2]]},"77":{"position":[[246,2]]},"79":{"position":[[644,2]]},"81":{"position":[[509,2],[610,2],[664,4],[999,2],[1005,1],[1364,2],[1754,2],[1761,2]]},"83":{"position":[[271,2],[327,2],[346,2],[450,2],[532,2],[538,2],[544,2],[1130,1],[1134,1],[1388,2]]},"85":{"position":[[876,2],[1030,2],[1051,2],[1112,2],[1133,2],[1196,2],[1914,2],[3228,2],[3682,2],[4007,2],[4165,1],[5062,2],[5390,2]]},"95":{"position":[[878,2],[1398,2],[1414,2],[1499,2],[1598,2],[1619,1],[1623,1],[1818,2],[1980,3],[2468,2],[2791,2],[3623,2],[3726,1],[3985,3],[4022,2],[4075,3],[4736,2],[4980,2],[5385,2],[6094,3],[6107,3],[6111,3],[6124,3],[6204,2],[6317,2],[6402,2],[6501,2],[6522,1],[6526,1],[6941,3],[7016,2],[7249,3],[7655,2],[7663,2],[7836,2],[7979,2],[8839,1],[9028,2],[9248,1],[9268,1]]},"97":{"position":[[459,2],[1318,1],[1829,2]]},"99":{"position":[[363,2]]},"103":{"position":[[480,2],[580,2]]},"105":{"position":[[211,2],[910,1],[948,1],[1680,2]]},"107":{"position":[[394,2],[714,2],[1321,2]]},"109":{"position":[[85,2]]},"113":{"position":[[431,2],[1106,1],[1617,2],[1713,2]]},"115":{"position":[[1120,2]]},"117":{"position":[[362,2]]},"119":{"position":[[701,2]]},"121":{"position":[[784,2]]},"123":{"position":[[790,2],[856,2],[2029,2],[2095,2]]},"125":{"position":[[408,2]]},"127":{"position":[[412,2],[596,2],[1439,3]]},"131":{"position":[[742,2],[1487,3],[1665,3],[1869,2],[2154,3],[2171,2],[2396,3]]},"135":{"position":[[888,2]]},"137":{"position":[[406,2],[1861,2],[1915,2]]},"139":{"position":[[3439,2],[3513,2],[3529,3],[3662,2],[3720,2],[4857,5],[4922,3],[4938,3],[4942,4],[5144,3],[5163,5],[5201,3],[5220,5],[5329,3],[5333,2]]},"141":{"position":[[1072,2]]},"143":{"position":[[395,3],[882,3]]},"145":{"position":[[797,2],[1418,2]]},"147":{"position":[[1103,1],[1252,2]]},"149":{"position":[[679,2]]},"153":{"position":[[1198,2]]},"157":{"position":[[364,3],[368,2],[382,2],[399,2],[466,2]]},"159":{"position":[[193,2],[201,2],[204,2],[529,2],[687,2],[809,2]]},"161":{"position":[[364,3],[368,2],[382,2],[399,2],[466,2],[723,3],[727,2],[741,2]]},"163":{"position":[[250,3],[254,2],[270,2],[291,2],[384,3],[388,2],[402,2],[419,2],[486,2],[2380,2],[4051,2],[5445,2]]},"165":{"position":[[383,3],[387,2],[401,2],[418,2],[485,2],[1354,3],[1532,3],[1717,2],[2002,3],[2019,2],[2244,3],[2491,2],[2911,2]]},"167":{"position":[[353,3],[357,2],[371,2]]},"169":{"position":[[321,3],[325,2],[339,2]]},"171":{"position":[[138,2],[213,2],[274,4],[610,2]]},"173":{"position":[[138,2],[219,2],[280,4],[671,2]]},"175":{"position":[[218,2]]},"177":{"position":[[359,2],[362,2],[376,2],[382,2],[396,2],[399,2]]},"179":{"position":[[359,2],[362,2],[376,2],[382,2],[396,2],[399,2],[493,3],[497,2],[511,2]]},"181":{"position":[[364,3],[368,2],[382,2],[399,2],[466,2],[1110,2]]},"183":{"position":[[320,2]]},"185":{"position":[[310,2],[444,2],[824,3]]},"187":{"position":[[315,2]]},"193":{"position":[[541,2]]},"195":{"position":[[514,2]]},"199":{"position":[[85,2],[282,2]]},"207":{"position":[[818,2],[828,3],[1009,2],[1430,2]]},"209":{"position":[[614,2],[626,3],[807,2]]},"211":{"position":[[1407,2],[1662,2],[1701,2]]},"213":{"position":[[307,2]]},"238":{"position":[[646,2],[1044,2],[1087,2],[1127,2],[1168,2],[1216,2],[1483,3]]}}}],["0${i",{"_index":2518,"t":{"187":{"position":[[354,7]]}}}],["0)\\nscreen",{"_index":1931,"t":{"139":{"position":[[4926,11]]}}}],["0,0",{"_index":2273,"t":{"163":{"position":[[1188,3],[3520,3]]},"207":{"position":[[350,5]]}}}],["0.0",{"_index":1538,"t":{"129":{"position":[[688,4],[825,3]]},"131":{"position":[[2827,4]]},"133":{"position":[[956,4]]},"157":{"position":[[803,4]]},"159":{"position":[[1295,4]]},"161":{"position":[[1195,4]]},"163":{"position":[[845,4]]},"165":{"position":[[794,4]]},"167":{"position":[[744,4]]},"169":{"position":[[678,4],[1227,4]]},"175":{"position":[[487,4],[567,4],[572,4]]},"177":{"position":[[256,4],[770,4]]},"179":{"position":[[929,4]]},"181":{"position":[[775,4]]},"207":{"position":[[873,7]]},"209":{"position":[[671,7]]}}}],["0.001",{"_index":1606,"t":{"131":{"position":[[1491,7],[2351,6]]},"165":{"position":[[1358,7],[2199,6]]}}}],["0.005",{"_index":1724,"t":{"135":{"position":[[923,6]]},"167":{"position":[[1683,6]]},"169":{"position":[[1925,6]]},"195":{"position":[[549,6]]}}}],["0.01",{"_index":183,"t":{"75":{"position":[[2859,5]]},"79":{"position":[[1023,4]]},"97":{"position":[[1926,5]]},"99":{"position":[[928,4]]},"105":{"position":[[1771,5]]},"107":{"position":[[1399,5],[1516,5]]},"113":{"position":[[1865,5]]},"137":{"position":[[2011,5]]},"141":{"position":[[1461,5],[1487,5],[1537,5]]},"153":{"position":[[1576,5],[1602,5],[1652,5]]},"157":{"position":[[1205,5]]},"159":{"position":[[1573,5]]},"161":{"position":[[1598,5]]},"167":{"position":[[1627,5],[1655,5]]},"169":{"position":[[1897,5]]},"175":{"position":[[751,5]]},"177":{"position":[[1071,5]]},"179":{"position":[[1493,5]]},"181":{"position":[[1408,5]]},"187":{"position":[[976,5]]},"193":{"position":[[1106,4]]},"211":{"position":[[1805,5],[2024,5]]}}}],["0.02",{"_index":1976,"t":{"141":{"position":[[1512,5]]},"153":{"position":[[1627,5]]},"191":{"position":[[915,5]]}}}],["0.025",{"_index":447,"t":{"83":{"position":[[308,6]]}}}],["0.04",{"_index":1547,"t":{"129":{"position":[[1005,4]]},"141":{"position":[[1581,5],[1625,5]]},"153":{"position":[[1696,5],[1740,5]]}}}],["0.05",{"_index":60,"t":{"75":{"position":[[413,5]]},"83":{"position":[[393,5]]},"113":{"position":[[1821,5]]},"137":{"position":[[1896,5]]}}}],["0.06",{"_index":2424,"t":{"169":{"position":[[1417,6],[1481,6]]}}}],["0.1",{"_index":1158,"t":{"107":{"position":[[1383,4]]},"109":{"position":[[548,4]]},"113":{"position":[[2387,4]]},"141":{"position":[[1640,4]]},"145":{"position":[[1840,4],[2326,4]]},"153":{"position":[[1755,4],[2116,4]]},"155":{"position":[[728,4],[765,4]]},"171":{"position":[[574,4]]},"173":{"position":[[635,4]]},"181":{"position":[[995,3],[1443,4]]},"189":{"position":[[673,3]]},"211":{"position":[[1789,4]]}}}],["0.2",{"_index":1214,"t":{"113":{"position":[[1181,4]]},"137":{"position":[[2233,4]]},"139":{"position":[[3449,4]]},"211":{"position":[[2075,5]]}}}],["0.25",{"_index":791,"t":{"89":{"position":[[758,5]]},"151":{"position":[[1737,6]]}}}],["0.3",{"_index":1032,"t":{"97":{"position":[[738,5]]},"105":{"position":[[594,5]]},"113":{"position":[[719,5]]},"137":{"position":[[775,5]]},"171":{"position":[[732,4]]},"173":{"position":[[793,4]]},"205":{"position":[[1203,5]]}}}],["0.35",{"_index":2387,"t":{"163":{"position":[[5685,4]]}}}],["0.4",{"_index":1761,"t":{"137":{"position":[[1545,4]]},"153":{"position":[[1801,5]]},"163":{"position":[[1334,4],[1339,4]]}}}],["0.5",{"_index":210,"t":{"75":{"position":[[4063,5],[4103,5]]},"83":{"position":[[573,4]]},"95":{"position":[[3072,4],[3079,5]]},"103":{"position":[[661,4]]},"107":{"position":[[986,4],[1008,4]]},"117":{"position":[[1696,4]]},"127":{"position":[[2217,5]]},"131":{"position":[[612,5],[2376,3]]},"133":{"position":[[1136,4]]},"145":{"position":[[1097,5],[1920,5]]},"163":{"position":[[1391,3],[2368,4],[3019,4],[5678,4],[5692,4]]},"165":{"position":[[2224,3]]},"169":{"position":[[1426,4],[1490,4]]},"171":{"position":[[667,4]]},"173":{"position":[[728,4]]},"183":{"position":[[684,4]]},"185":{"position":[[775,5]]},"187":{"position":[[868,4]]},"199":{"position":[[257,4]]},"205":{"position":[[1234,5]]},"238":{"position":[[1367,4],[1387,4]]}}}],["0.7",{"_index":456,"t":{"83":{"position":[[601,4]]},"133":{"position":[[968,4]]},"165":{"position":[[3058,5]]}}}],["0.75",{"_index":798,"t":{"89":{"position":[[922,5]]},"127":{"position":[[500,5]]},"139":{"position":[[3643,5]]},"163":{"position":[[4039,5]]}}}],["0.8",{"_index":1048,"t":{"97":{"position":[[1267,4]]},"105":{"position":[[1120,4]]},"113":{"position":[[1068,4]]},"137":{"position":[[650,4]]},"145":{"position":[[623,5]]},"163":{"position":[[1294,4],[1299,4]]},"205":{"position":[[901,4]]}}}],["0.87",{"_index":1470,"t":{"125":{"position":[[375,5]]}}}],["0.95",{"_index":1221,"t":{"113":{"position":[[1783,4]]}}}],["0.99",{"_index":186,"t":{"75":{"position":[[2950,5],[2983,6],[3048,5],[3083,6]]}}}],["000000",{"_index":598,"t":{"85":{"position":[[2320,10]]},"205":{"position":[[499,10]]}}}],["004620",{"_index":2679,"t":{"205":{"position":[[1027,10]]}}}],["00ff99",{"_index":591,"t":{"85":{"position":[[2222,11]]},"205":{"position":[[401,11]]}}}],["0123456789",{"_index":2478,"t":{"183":{"position":[[355,11]]}}}],["0x0000ff",{"_index":2082,"t":{"145":{"position":[[976,9]]}}}],["0x00ff00",{"_index":144,"t":{"75":{"position":[[2180,9]]},"95":{"position":[[6883,9]]}}}],["0x1099bb",{"_index":2549,"t":{"193":{"position":[[261,9]]}}}],["0x111111",{"_index":1469,"t":{"125":{"position":[[358,9]]},"205":{"position":[[964,11]]}}}],["0x333333",{"_index":1464,"t":{"123":{"position":[[2997,9]]}}}],["0x3333dd",{"_index":2029,"t":{"143":{"position":[[1510,9]]}}}],["0x33ff00",{"_index":2089,"t":{"145":{"position":[[1182,10]]}}}],["0x666666",{"_index":1465,"t":{"123":{"position":[[3048,9]]}}}],["0x808080",{"_index":1212,"t":{"113":{"position":[[860,9]]}}}],["0xaa0000",{"_index":2000,"t":{"143":{"position":[[618,9]]}}}],["0xaa00bb",{"_index":2024,"t":{"143":{"position":[[1357,9]]}}}],["0xfeeb77",{"_index":2152,"t":{"151":{"position":[[363,9],[1007,9]]}}}],["0xff0000",{"_index":156,"t":{"75":{"position":[[2437,9]]},"95":{"position":[[1895,9],[3927,9],[4690,9],[4942,9]]},"145":{"position":[[613,9],[1880,9]]}}}],["0xff00ff",{"_index":2170,"t":{"151":{"position":[[1694,9]]}}}],["0xffbd01",{"_index":2155,"t":{"151":{"position":[[516,9],[1157,9]]}}}],["0xffc2c2",{"_index":2451,"t":{"171":{"position":[[826,10]]}}}],["0xffd900",{"_index":2062,"t":{"145":{"position":[[327,9]]},"151":{"position":[[1482,9]]}}}],["0xffffff",{"_index":313,"t":{"77":{"position":[[1621,8]]},"95":{"position":[[7626,10],[7793,9]]},"105":{"position":[[773,9]]},"107":{"position":[[885,9]]},"123":{"position":[[3098,9]]},"131":{"position":[[564,9]]},"143":{"position":[[362,9],[848,9]]},"145":{"position":[[1578,9]]},"151":{"position":[[655,9],[1307,9],[1848,10],[1985,10],[2122,10]]}}}],["1",{"_index":159,"t":{"75":{"position":[[2508,2]]},"81":{"position":[[1785,2],[1805,2],[1896,2],[1922,2],[2039,2],[2130,2],[2203,2],[2286,2]]},"83":{"position":[[972,2],[1138,2]]},"85":{"position":[[1894,3],[2000,3],[3490,1],[5288,2],[5464,3],[5536,2],[5724,2],[5743,3]]},"95":{"position":[[200,2],[1905,3],[1934,3],[2146,4],[3937,3],[3966,3],[4660,3],[4700,3],[4952,3],[5090,2],[6099,3],[6103,3],[6115,3],[6121,2],[6893,3],[6922,3],[7083,4],[7803,3],[9258,1],[9278,2]]},"115":{"position":[[1303,3],[1912,2]]},"117":{"position":[[1865,2]]},"121":{"position":[[942,3],[2007,2]]},"125":{"position":[[388,1]]},"127":{"position":[[2166,1],[2172,2]]},"131":{"position":[[1743,2],[1776,4],[2434,3],[2463,3],[2543,4]]},"137":{"position":[[612,2]]},"139":{"position":[[2849,2],[3035,2],[3581,3],[4614,2]]},"141":{"position":[[1559,1],[1603,1]]},"143":{"position":[[372,3],[628,3],[858,3],[1367,3],[1520,3]]},"145":{"position":[[337,3],[658,3],[986,3],[1588,3],[1890,3]]},"149":{"position":[[812,2]]},"151":{"position":[[339,1],[373,3],[526,3],[665,3],[901,3],[983,1],[1017,3],[1050,3],[1167,3],[1200,3],[1317,3],[1350,3],[1492,3],[1704,3],[1888,3],[2025,3],[2162,3],[2355,3]]},"153":{"position":[[1674,1],[1718,1]]},"155":{"position":[[804,2]]},"157":{"position":[[379,2],[393,2],[396,2],[402,3],[460,2]]},"161":{"position":[[379,2],[393,2],[396,2],[402,3],[460,2],[738,2],[752,2],[755,3],[813,2]]},"163":{"position":[[399,2],[413,2],[416,2],[422,3],[480,2],[5484,1]]},"165":{"position":[[398,2],[412,2],[415,2],[421,3],[479,2],[1624,4],[2282,3],[2311,3],[2391,4],[2950,1]]},"167":{"position":[[368,2],[382,2],[385,3]]},"169":{"position":[[336,2],[350,2],[353,4]]},"171":{"position":[[886,2],[966,2]]},"177":{"position":[[355,3],[379,2],[402,3]]},"179":{"position":[[355,3],[379,2],[402,3],[508,2],[522,2],[525,3]]},"181":{"position":[[379,2],[393,2],[396,2],[402,3],[460,2]]},"189":{"position":[[578,1]]},"195":{"position":[[683,2],[717,2]]},"207":{"position":[[399,1],[425,3]]},"209":{"position":[[495,2],[819,3]]},"213":{"position":[[612,2]]},"238":{"position":[[304,2],[940,3],[1347,4]]}}}],["1,1",{"_index":2274,"t":{"163":{"position":[[1207,3],[3539,3]]}}}],["1.,0",{"_index":1632,"t":{"131":{"position":[[1978,9]]},"165":{"position":[[1826,9]]}}}],["1.0",{"_index":1651,"t":{"131":{"position":[[2416,5]]},"133":{"position":[[951,4],[961,4],[1129,4]]},"157":{"position":[[808,5]]},"159":{"position":[[1300,5],[1395,5]]},"161":{"position":[[1200,5]]},"163":{"position":[[850,5],[1304,5],[1344,5]]},"165":{"position":[[799,5],[2264,5]]},"167":{"position":[[749,5]]},"169":{"position":[[683,5],[1232,5]]},"175":{"position":[[492,5],[577,5]]},"177":{"position":[[775,5],[874,5]]},"179":{"position":[[934,5],[1131,5]]},"181":{"position":[[780,5]]}}}],["1.0)).xy",{"_index":2228,"t":{"157":{"position":[[793,9]]},"159":{"position":[[1285,9]]},"161":{"position":[[1185,9]]},"163":{"position":[[835,9]]},"165":{"position":[[784,9]]},"167":{"position":[[734,9]]},"169":{"position":[[668,9],[1217,9]]},"175":{"position":[[477,9]]},"177":{"position":[[760,9]]},"179":{"position":[[919,9]]},"181":{"position":[[765,9]]}}}],["1.1",{"_index":1522,"t":{"127":{"position":[[2243,4]]}}}],["1.2",{"_index":1274,"t":{"115":{"position":[[1782,5]]},"121":{"position":[[1877,5]]}}}],["1.25",{"_index":1195,"t":{"111":{"position":[[860,5],[884,5]]}}}],["1.5",{"_index":1983,"t":{"141":{"position":[[1764,4]]}}}],["10",{"_index":487,"t":{"83":{"position":[[1349,2]]},"85":{"position":[[3349,2]]},"103":{"position":[[272,3],[276,4],[650,3]]},"115":{"position":[[1725,3]]},"117":{"position":[[369,3]]},"121":{"position":[[1820,3]]},"123":{"position":[[2669,3],[2785,3]]},"141":{"position":[[1388,3]]},"143":{"position":[[1127,3]]},"147":{"position":[[704,3]]},"153":{"position":[[1508,3]]},"163":{"position":[[1472,3],[5009,4],[5048,4]]},"171":{"position":[[1057,4]]},"183":{"position":[[327,3]]},"187":{"position":[[349,2]]},"199":{"position":[[295,3]]},"205":{"position":[[996,3]]}}}],["100",{"_index":138,"t":{"75":{"position":[[2068,4],[2099,4],[2130,4],[2156,4],[2391,4],[2415,4],[3260,5],[3390,5],[3721,4],[3752,4]]},"77":{"position":[[1609,4]]},"81":{"position":[[447,4]]},"95":{"position":[[512,4],[2410,4],[3404,4],[4365,4],[7658,4],[7839,4],[7844,4]]},"97":{"position":[[1567,4]]},"103":{"position":[[291,4],[306,4]]},"105":{"position":[[1420,4]]},"107":{"position":[[721,4],[1328,4]]},"113":{"position":[[413,4],[1216,4],[1434,4]]},"119":{"position":[[905,4]]},"123":{"position":[[793,4],[2032,4]]},"131":{"position":[[2178,4]]},"133":{"position":[[1235,4]]},"135":{"position":[[662,4]]},"137":{"position":[[245,4]]},"139":{"position":[[3508,4],[3673,3],[3873,4],[3945,4],[4506,4]]},"143":{"position":[[474,5],[678,5],[907,5],[963,5],[1185,4],[1205,5],[1384,4]]},"145":{"position":[[429,5],[805,5],[1017,4],[1022,5],[1133,5],[1969,3],[2040,3],[2110,3],[2181,3],[2253,3]]},"147":{"position":[[346,4],[360,4]]},"149":{"position":[[171,4]]},"151":{"position":[[282,4],[287,5],[434,4],[439,5],[587,4],[592,5],[731,5],[1778,4],[1783,4]]},"153":{"position":[[1850,3],[1921,3],[1991,3],[2062,3]]},"157":{"position":[[220,4],[226,4],[239,4],[245,4],[258,4],[263,4],[269,4],[274,5]]},"159":{"position":[[188,4],[196,4]]},"161":{"position":[[220,4],[226,4],[239,4],[245,4],[258,4],[263,4],[269,4],[274,5],[572,3],[578,4],[584,4],[597,3],[603,4],[609,4],[622,3],[628,4],[633,5]]},"165":{"position":[[239,4],[245,4],[258,4],[264,4],[277,4],[282,4],[288,4],[293,5],[2026,4]]},"167":{"position":[[220,4],[226,4],[239,4],[245,4],[258,4],[263,5],[1462,5]]},"169":{"position":[[220,4],[226,4],[239,4],[245,4],[258,4],[263,5]]},"175":{"position":[[198,4],[208,4],[221,6]]},"177":{"position":[[220,4],[238,4]]},"179":{"position":[[220,4],[226,4],[239,4],[245,4],[258,4],[263,5]]},"181":{"position":[[220,4],[226,4],[239,4],[245,4],[258,4],[263,4],[269,4],[274,5]]},"189":{"position":[[594,4]]},"199":{"position":[[285,4],[290,4]]},"205":{"position":[[236,4]]},"207":{"position":[[2032,5]]},"209":{"position":[[970,5]]},"213":{"position":[[1021,4]]}}}],["100.0",{"_index":2468,"t":{"177":{"position":[[261,7]]}}}],["100.0*sin(uv.x*0.5+time*0.5)*amplitude*1.2",{"_index":2338,"t":{"163":{"position":[[3769,44]]}}}],["1000",{"_index":443,"t":{"83":{"position":[[251,5],[794,4]]},"131":{"position":[[2498,6]]},"165":{"position":[[2346,6]]}}}],["10000",{"_index":1207,"t":{"113":{"position":[[405,5]]}}}],["1099bb",{"_index":374,"t":{"81":{"position":[[80,10]]},"85":{"position":[[80,10]]},"87":{"position":[[80,10]]},"89":{"position":[[80,10]]},"91":{"position":[[80,10]]},"93":{"position":[[80,10]]},"95":{"position":[[80,10]]},"99":{"position":[[80,10]]},"101":{"position":[[80,10]]},"103":{"position":[[80,10]]},"111":{"position":[[80,10]]},"115":{"position":[[80,10]]},"117":{"position":[[80,10]]},"119":{"position":[[173,10]]},"123":{"position":[[90,9]]},"125":{"position":[[190,10]]},"127":{"position":[[97,10]]},"131":{"position":[[352,10]]},"139":{"position":[[312,10]]},"187":{"position":[[80,10]]},"189":{"position":[[80,10]]},"191":{"position":[[80,10]]},"197":{"position":[[80,10]]},"201":{"position":[[80,10]]},"203":{"position":[[80,10]]},"205":{"position":[[80,10]]},"213":{"position":[[80,10]]}}}],["110",{"_index":1752,"t":{"137":{"position":[[1176,4],[1210,4]]},"139":{"position":[[4994,4]]}}}],["1100",{"_index":2464,"t":{"173":{"position":[[528,6]]}}}],["111",{"_index":48,"t":{"75":{"position":[[256,7]]},"79":{"position":[[85,7]]}}}],["115",{"_index":1407,"t":{"123":{"position":[[811,4],[2050,4]]}}}],["12",{"_index":1947,"t":{"139":{"position":[[5587,4]]},"141":{"position":[[1303,3]]},"153":{"position":[[1423,3]]},"205":{"position":[[1111,3]]}}}],["120",{"_index":1410,"t":{"123":{"position":[[834,4],[2073,4]]},"145":{"position":[[832,5],[1940,3],[2153,3],[2224,3]]},"153":{"position":[[1821,3],[2034,3]]}}}],["12px",{"_index":2864,"t":{"238":{"position":[[1614,7]]}}}],["130",{"_index":1409,"t":{"123":{"position":[[820,4],[2059,4]]}}}],["14",{"_index":1336,"t":{"119":{"position":[[527,3]]},"181":{"position":[[986,4]]}}}],["140",{"_index":2160,"t":{"151":{"position":[[726,4]]}}}],["15",{"_index":919,"t":{"95":{"position":[[4388,3]]}}}],["150",{"_index":526,"t":{"85":{"position":[[402,4]]},"115":{"position":[[1084,4]]},"121":{"position":[[748,4]]},"123":{"position":[[825,4],[843,4],[2064,4],[2082,4]]},"143":{"position":[[935,5],[1020,4],[1190,4],[1195,4],[1258,4],[1920,4],[1925,5],[2357,4],[2362,5]]},"159":{"position":[[208,6]]},"201":{"position":[[1005,4]]}}}],["150.0*sin(uv.x*0.75+time*0.75)*amplitude*1.4",{"_index":2340,"t":{"163":{"position":[[3848,46]]}}}],["16",{"_index":967,"t":{"95":{"position":[[7849,4]]},"119":{"position":[[421,3]]},"139":{"position":[[4800,3],[5508,3]]},"151":{"position":[[1788,4]]},"238":{"position":[[316,3],[1039,2],[1223,3]]}}}],["160",{"_index":524,"t":{"85":{"position":[[377,4]]},"95":{"position":[[5441,4]]},"123":{"position":[[802,4],[2041,4]]}}}],["170",{"_index":1446,"t":{"123":{"position":[[2485,4],[2594,4],[2699,4],[2815,4]]}}}],["175",{"_index":1244,"t":{"115":{"position":[[1056,4]]},"121":{"position":[[720,4]]}}}],["18",{"_index":1895,"t":{"139":{"position":[[3665,2]]}}}],["190",{"_index":2203,"t":{"155":{"position":[[465,4]]}}}],["1}.png",{"_index":2504,"t":{"185":{"position":[[390,9]]}}}],["2",{"_index":139,"t":{"75":{"position":[[2075,2],[2106,3],[3728,2],[3759,3]]},"79":{"position":[[913,2],[965,2],[1263,3],[1321,3]]},"81":{"position":[[1935,2],[2267,2],[2304,1],[2327,1]]},"83":{"position":[[931,2],[1661,2],[1758,2],[1858,2],[1923,2],[2515,2]]},"85":{"position":[[1530,3],[1750,2],[2560,3],[2646,3],[2819,3],[2880,3],[4520,3]]},"87":{"position":[[1035,2],[1069,2],[1710,2],[1744,2]]},"89":{"position":[[795,2],[956,2]]},"91":{"position":[[612,2],[645,2]]},"93":{"position":[[789,2],[826,2]]},"95":{"position":[[734,2],[744,3],[958,3],[1026,2],[1074,2],[1113,2],[1124,2],[1134,2],[1145,3],[1172,2],[1183,2],[1193,2],[1203,3],[1225,2],[1235,2],[1245,2],[1255,3],[1278,2],[1289,2],[1300,2],[1310,3],[1684,2],[1695,2],[1718,2],[1728,2],[1755,2],[1765,2],[1791,2],[1802,2],[1829,2],[1961,3],[2092,2],[2126,3],[2142,1],[2210,2],[2639,1],[2679,2],[2701,1],[2741,2],[2871,3],[3507,2],[3517,3],[3703,3],[3740,2],[5229,2],[5239,3],[5466,3],[5534,2],[5582,2],[5638,1],[5660,1],[5681,1],[5703,1],[5741,1],[5763,1],[5784,1],[5805,1],[5838,1],[5859,1],[5880,1],[5901,1],[5935,1],[5957,1],[5979,1],[6000,1],[6612,1],[6634,1],[6669,1],[6690,1],[6726,1],[6747,1],[6784,1],[6806,1],[6968,1],[7063,3],[7079,1],[7142,2],[7185,3],[8058,3]]},"97":{"position":[[1154,2],[1322,1],[1337,1],[1357,2],[1690,2],[1733,2],[2074,2]]},"99":{"position":[[596,2],[633,2],[728,2],[770,2]]},"101":{"position":[[534,2],[567,2]]},"105":{"position":[[1007,2],[1171,1],[1190,1],[1210,2],[1542,2],[1585,3],[1919,2]]},"109":{"position":[[395,2],[428,2]]},"111":{"position":[[411,2],[445,2]]},"113":{"position":[[953,2],[1110,2],[1155,2],[1176,2],[1557,2],[1600,2]]},"115":{"position":[[1264,3],[1299,1]]},"119":{"position":[[442,2],[564,2]]},"121":{"position":[[903,3],[938,1]]},"125":{"position":[[466,2],[489,3]]},"127":{"position":[[472,2],[630,2],[658,2],[1155,2],[1182,2],[1400,2],[1937,2],[2185,1]]},"131":{"position":[[664,2],[696,3],[1278,4],[1767,5],[1806,3]]},"135":{"position":[[436,2],[636,2]]},"137":{"position":[[334,2],[367,2],[594,2],[2175,2]]},"139":{"position":[[3461,1],[3585,2],[3683,4]]},"141":{"position":[[276,2],[306,2],[435,2],[472,2],[1803,2],[1835,3]]},"143":{"position":[[779,1],[1402,1],[1451,1],[1547,1],[1574,3],[1741,1],[1770,3]]},"145":{"position":[[1384,2],[1403,2]]},"149":{"position":[[704,2],[729,3],[1071,2],[1125,2]]},"151":{"position":[[491,1],[631,1],[1132,1],[1283,1],[1961,1]]},"153":{"position":[[293,2],[323,2],[423,2],[460,2],[1106,2],[1139,2]]},"157":{"position":[[288,2],[414,2],[463,2],[469,2]]},"159":{"position":[[291,2],[851,2]]},"161":{"position":[[288,2],[414,2],[463,2],[469,2],[647,2],[767,2],[816,4]]},"163":{"position":[[308,2],[434,2],[483,2],[489,2],[1385,3]]},"165":{"position":[[307,2],[433,2],[482,2],[488,2],[1197,4],[1615,5],[1654,3],[3032,2],[3066,3]]},"167":{"position":[[277,2],[397,3]]},"169":{"position":[[1433,3],[1497,3]]},"177":{"position":[[277,2]]},"179":{"position":[[277,2],[537,3]]},"181":{"position":[[288,2],[414,2],[463,2],[469,2]]},"183":{"position":[[732,2],[764,2],[976,2],[1008,2]]},"187":{"position":[[789,2],[821,2]]},"189":{"position":[[397,2],[430,2]]},"191":{"position":[[557,2],[594,2]]},"193":{"position":[[774,2],[811,2],[906,2],[948,2]]},"195":{"position":[[583,1],[631,1]]},"199":{"position":[[450,2],[502,2]]},"213":{"position":[[467,3]]},"238":{"position":[[640,1],[1329,1],[1343,1]]}}}],["2./length(uv.y*500",{"_index":2341,"t":{"163":{"position":[[3907,19]]}}}],["2.1",{"_index":2678,"t":{"205":{"position":[[923,4]]}}}],["2.2",{"_index":1627,"t":{"131":{"position":[[1887,4]]},"165":{"position":[[1735,4]]}}}],["2.5",{"_index":2037,"t":{"143":{"position":[[1754,3]]}}}],["20",{"_index":384,"t":{"81":{"position":[[373,3]]},"83":{"position":[[286,3],[1326,3]]},"97":{"position":[[442,3]]},"105":{"position":[[194,3]]},"127":{"position":[[1326,3]]},"135":{"position":[[1022,2],[1060,2]]},"137":{"position":[[413,3]]},"143":{"position":[[1686,3],[2260,3]]},"145":{"position":[[1964,3],[1993,4],[2035,3],[2064,4],[2106,3],[2134,4],[2177,3],[2205,4],[2248,3],[2277,4]]},"153":{"position":[[1845,3],[1874,4],[1916,3],[1945,4],[1987,3],[2015,4],[2058,3],[2086,4]]},"171":{"position":[[748,3]]},"173":{"position":[[183,3],[226,3],[809,3]]},"211":{"position":[[1414,3]]},"238":{"position":[[1691,3]]}}}],["200",{"_index":1354,"t":{"119":{"position":[[910,4],[915,4]]},"123":{"position":[[327,5],[649,5],[1192,5],[1368,4],[1782,5],[1893,4]]},"133":{"position":[[1259,4],[1284,5]]},"135":{"position":[[462,4],[641,4]]},"139":{"position":[[3736,4]]},"143":{"position":[[420,5],[447,5],[658,4],[663,4],[668,4]]},"145":{"position":[[859,5],[1128,4]]},"163":{"position":[[265,4],[281,4],[286,4],[294,5],[1742,4],[1755,3],[2548,4],[2561,3],[3187,4],[3200,3],[4191,4],[4204,3]]},"197":{"position":[[417,4]]},"203":{"position":[[946,5]]},"211":{"position":[[1514,4],[1550,4]]}}}],["200.0*sin(uv.x+time)*amplitude*1.6",{"_index":2342,"t":{"163":{"position":[[3929,36]]}}}],["2000",{"_index":463,"t":{"83":{"position":[[761,4],[801,5],[2037,5],[2050,6]]}}}],["220",{"_index":2067,"t":{"145":{"position":[[456,5],[482,5]]},"163":{"position":[[5085,5],[5158,5]]},"205":{"position":[[771,4]]}}}],["240",{"_index":2002,"t":{"143":{"position":[[673,4],[1200,4]]}}}],["25",{"_index":341,"t":{"79":{"position":[[651,3]]},"99":{"position":[[370,3]]},"123":{"position":[[2455,3]]},"137":{"position":[[1764,3]]},"141":{"position":[[1375,3]]},"143":{"position":[[1989,4],[2027,4],[2065,4]]},"171":{"position":[[220,3]]},"193":{"position":[[548,3]]},"213":{"position":[[314,3]]}}}],["25.0",{"_index":1690,"t":{"133":{"position":[[918,5]]}}}],["250",{"_index":2084,"t":{"145":{"position":[[1012,4]]},"151":{"position":[[930,4],[1079,4],[1229,4],[1380,4]]}}}],["2500",{"_index":645,"t":{"85":{"position":[[3382,4]]}}}],["255",{"_index":2716,"t":{"207":{"position":[[863,4],[868,4]]},"209":{"position":[[661,4],[666,4]]}}}],["256",{"_index":2766,"t":{"209":{"position":[[401,4]]}}}],["26",{"_index":2193,"t":{"153":{"position":[[1495,3]]},"185":{"position":[[317,3],[819,2]]}}}],["270",{"_index":2031,"t":{"143":{"position":[[1538,4]]}}}],["272d37",{"_index":1498,"t":{"127":{"position":[[1283,10]]},"139":{"position":[[4810,10],[5540,10]]}}}],["2d",{"_index":492,"t":{"83":{"position":[[1507,2]]}}}],["3",{"_index":147,"t":{"75":{"position":[[2255,2]]},"81":{"position":[[2277,1],[2336,1]]},"85":{"position":[[1745,2],[2037,1],[3317,3]]},"95":{"position":[[2691,2],[2753,2],[3128,2]]},"131":{"position":[[1811,4]]},"141":{"position":[[1702,2],[1798,2]]},"143":{"position":[[1560,1],[1614,1]]},"151":{"position":[[2098,1]]},"157":{"position":[[472,3]]},"159":{"position":[[312,2],[900,2]]},"161":{"position":[[472,4]]},"163":{"position":[[492,4]]},"165":{"position":[[491,4],[1659,4]]},"177":{"position":[[417,3]]},"179":{"position":[[417,2]]},"181":{"position":[[472,4]]}}}],["3./length(uv.y*400",{"_index":2339,"t":{"163":{"position":[[3826,19]]}}}],["30",{"_index":202,"t":{"75":{"position":[[3559,2],[3601,4],[3626,2],[3669,4]]},"119":{"position":[[1570,3],[1597,3]]},"123":{"position":[[839,3],[2078,3]]},"145":{"position":[[1213,4],[1558,3]]},"147":{"position":[[859,3]]},"171":{"position":[[683,3]]},"173":{"position":[[744,3]]},"187":{"position":[[322,3]]},"199":{"position":[[343,3]]},"213":{"position":[[385,3],[419,3]]}}}],["300",{"_index":353,"t":{"79":{"position":[[860,4]]},"107":{"position":[[514,4],[964,4]]},"139":{"position":[[3478,4],[3892,4],[3951,4]]},"145":{"position":[[706,5],[886,5],[1239,5]]},"155":{"position":[[665,5]]},"157":{"position":[[1109,5]]},"159":{"position":[[1486,5]]},"161":{"position":[[1502,5]]},"165":{"position":[[2824,5]]},"167":{"position":[[1405,5]]},"169":{"position":[[1720,5]]},"171":{"position":[[407,4]]},"173":{"position":[[492,4]]},"175":{"position":[[666,5]]},"177":{"position":[[963,5]]},"179":{"position":[[1385,5]]},"181":{"position":[[1252,5]]},"201":{"position":[[1020,4]]},"205":{"position":[[1253,4]]},"211":{"position":[[637,4],[810,4]]},"213":{"position":[[546,4],[559,4]]}}}],["310",{"_index":2201,"t":{"155":{"position":[[451,4]]}}}],["315",{"_index":1712,"t":{"135":{"position":[[441,4]]}}}],["32",{"_index":2135,"t":{"149":{"position":[[212,3]]}}}],["320",{"_index":1481,"t":{"127":{"position":[[338,4]]},"143":{"position":[[992,4],[1232,4]]},"145":{"position":[[733,5]]}}}],["325",{"_index":1248,"t":{"115":{"position":[[1079,4]]},"121":{"position":[[743,4]]}}}],["35",{"_index":1451,"t":{"123":{"position":[[2564,3]]}}}],["350",{"_index":2043,"t":{"143":{"position":[[1915,4],[2352,4]]},"145":{"position":[[760,5]]},"151":{"position":[[1516,5],[1543,5],[1596,5]]}}}],["36",{"_index":585,"t":{"85":{"position":[[2159,3]]},"205":{"position":[[338,3]]}}}],["360",{"_index":1117,"t":{"105":{"position":[[952,3]]}}}],["370",{"_index":2174,"t":{"151":{"position":[[1915,4],[2257,4]]}}}],["375",{"_index":2046,"t":{"143":{"position":[[1984,4]]}}}],["3].map((i",{"_index":1893,"t":{"139":{"position":[[3588,10]]}}}],["3d",{"_index":490,"t":{"83":{"position":[[1492,2]]}}}],["4",{"_index":553,"t":{"85":{"position":[[1203,2],[2347,2]]},"95":{"position":[[1627,2],[4146,2],[6530,2],[6548,1]]},"105":{"position":[[1175,1]]},"107":{"position":[[767,3]]},"127":{"position":[[428,3],[1994,3],[2014,3]]},"141":{"position":[[1868,3]]},"151":{"position":[[2194,2]]},"159":{"position":[[497,1],[616,1],[648,1],[949,2]]},"183":{"position":[[532,2]]},"205":{"position":[[526,2],[944,2]]},"238":{"position":[[1123,1],[1443,3],[1479,1]]}}}],["4./length(uv.y*300",{"_index":2337,"t":{"163":{"position":[[3747,19]]}}}],["40",{"_index":346,"t":{"79":{"position":[[745,3],[779,3]]},"99":{"position":[[464,3],[498,3]]},"127":{"position":[[1413,3]]},"171":{"position":[[393,3]]},"193":{"position":[[642,3],[676,3]]}}}],["400",{"_index":351,"t":{"79":{"position":[[836,4]]},"107":{"position":[[490,4],[927,4]]},"119":{"position":[[704,4],[709,4],[769,4]]},"151":{"position":[[1570,5]]},"167":{"position":[[1496,5]]},"169":{"position":[[1777,5]]},"173":{"position":[[468,4]]},"211":{"position":[[615,4],[786,4],[1508,3],[1544,3]]}}}],["410",{"_index":1247,"t":{"115":{"position":[[1074,4]]},"121":{"position":[[738,4]]}}}],["420",{"_index":2036,"t":{"143":{"position":[[1732,4]]},"151":{"position":[[2277,4]]}}}],["425",{"_index":2048,"t":{"143":{"position":[[2022,4]]}}}],["430",{"_index":2370,"t":{"163":{"position":[[5122,5]]}}}],["440",{"_index":605,"t":{"85":{"position":[[2434,4]]},"151":{"position":[[1773,4]]},"205":{"position":[[613,4]]}}}],["445",{"_index":1251,"t":{"115":{"position":[[1099,4]]},"121":{"position":[[763,4]]}}}],["45",{"_index":1411,"t":{"123":{"position":[[848,3],[2087,3]]},"171":{"position":[[177,3]]}}}],["450",{"_index":2180,"t":{"151":{"position":[[2189,4]]},"201":{"position":[[1035,4]]},"213":{"position":[[666,4]]}}}],["459",{"_index":2459,"t":{"173":{"position":[[399,4]]}}}],["460",{"_index":2183,"t":{"151":{"position":[[2267,4]]}}}],["465",{"_index":1249,"t":{"115":{"position":[[1089,4]]},"121":{"position":[[753,4]]}}}],["475",{"_index":2050,"t":{"143":{"position":[[2060,4]]}}}],["480",{"_index":2077,"t":{"145":{"position":[[800,4]]},"205":{"position":[[1271,4]]}}}],["4a1850",{"_index":594,"t":{"85":{"position":[[2254,10]]},"205":{"position":[[433,10]]}}}],["5",{"_index":67,"t":{"75":{"position":[[492,2]]},"79":{"position":[[740,2],[774,2]]},"83":{"position":[[369,2],[1076,1]]},"85":{"position":[[883,2],[1840,3],[2282,2],[3358,1]]},"95":{"position":[[4880,2],[7308,2]]},"99":{"position":[[459,2],[493,2]]},"115":{"position":[[1127,2]]},"121":{"position":[[791,2]]},"151":{"position":[[1920,2]]},"159":{"position":[[267,2]]},"193":{"position":[[637,2],[671,2]]},"205":{"position":[[461,2]]},"213":{"position":[[380,2],[414,2]]},"238":{"position":[[1164,1]]}}}],["5./length(uv.y*200",{"_index":2333,"t":{"163":{"position":[[3669,19]]}}}],["50",{"_index":258,"t":{"77":{"position":[[249,4]]},"83":{"position":[[967,2]]},"95":{"position":[[3792,3],[7726,4],[8150,5],[8193,5],[8236,5],[8279,5],[8322,5]]},"123":{"position":[[798,3],[867,3],[2037,3],[2106,3]]},"143":{"position":[[502,3],[528,3],[704,3],[728,3],[1389,3]]},"145":{"position":[[377,4],[403,4],[508,4]]},"151":{"position":[[278,3],[430,3],[583,3],[722,3],[935,4],[1084,4],[1234,4],[1389,4],[1923,4],[2060,4],[2197,4]]},"175":{"position":[[204,3],[214,3]]},"177":{"position":[[226,3],[244,3]]},"185":{"position":[[451,3]]},"197":{"position":[[394,3]]},"199":{"position":[[375,4]]},"201":{"position":[[649,2],[752,2],[874,2],[987,2]]},"203":{"position":[[879,3]]},"205":{"position":[[218,3],[754,3]]},"207":{"position":[[1902,4]]},"209":{"position":[[1043,3]]}}}],["50.0*sin",{"_index":2334,"t":{"163":{"position":[[3691,9]]}}}],["500",{"_index":1900,"t":{"139":{"position":[[3754,4]]},"209":{"position":[[1022,4]]}}}],["5000",{"_index":480,"t":{"83":{"position":[[1144,6]]}}}],["510",{"_index":2177,"t":{"151":{"position":[[2052,4]]}}}],["520",{"_index":2188,"t":{"151":{"position":[[2297,5]]}}}],["55",{"_index":1406,"t":{"123":{"position":[[807,3],[859,3],[2046,3],[2098,3]]},"197":{"position":[[350,3]]}}}],["550",{"_index":1935,"t":{"139":{"position":[[5015,4]]},"155":{"position":[[621,5]]}}}],["570",{"_index":2186,"t":{"151":{"position":[[2287,4]]}}}],["590",{"_index":2187,"t":{"151":{"position":[[2292,4]]}}}],["5x5",{"_index":1074,"t":{"99":{"position":[[330,3]]},"193":{"position":[[508,3]]}}}],["6",{"_index":601,"t":{"85":{"position":[[2377,2],[2400,2]]},"95":{"position":[[8035,2]]},"205":{"position":[[556,2],[579,2]]}}}],["60",{"_index":852,"t":{"95":{"position":[[934,3],[2847,3],[3679,3]]},"123":{"position":[[863,3],[2102,3]]},"131":{"position":[[3038,3]]},"143":{"position":[[1543,3],[1737,3]]},"147":{"position":[[892,3]]},"163":{"position":[[5488,3]]},"165":{"position":[[2954,3]]},"205":{"position":[[1048,3]]},"213":{"position":[[682,3],[1040,3]]}}}],["600",{"_index":646,"t":{"85":{"position":[[3393,3],[3407,4]]},"107":{"position":[[958,3]]},"123":{"position":[[71,4]]},"139":{"position":[[3494,4]]},"145":{"position":[[1397,3],[1645,5],[1712,4],[1754,4],[1796,4]]},"151":{"position":[[2251,5]]}}}],["640",{"_index":2263,"t":{"163":{"position":[[76,4]]}}}],["655",{"_index":1246,"t":{"115":{"position":[[1065,4]]},"121":{"position":[[729,4]]}}}],["685",{"_index":1250,"t":{"115":{"position":[[1094,4]]},"121":{"position":[[758,4]]}}}],["7",{"_index":888,"t":{"95":{"position":[[2434,2]]},"151":{"position":[[2057,2]]}}}],["70",{"_index":2581,"t":{"199":{"position":[[359,3]]}}}],["700",{"_index":2182,"t":{"151":{"position":[[2262,4]]}}}],["730",{"_index":2185,"t":{"151":{"position":[[2282,4]]}}}],["75",{"_index":1245,"t":{"115":{"position":[[1061,3],[1070,3]]},"121":{"position":[[725,3],[734,3]]},"123":{"position":[[1364,3],[1889,3]]}}}],["780",{"_index":2184,"t":{"151":{"position":[[2272,4]]}}}],["8",{"_index":661,"t":{"85":{"position":[[3922,2]]},"125":{"position":[[411,2]]},"127":{"position":[[599,3]]},"131":{"position":[[2392,3]]},"165":{"position":[[2240,3]]},"207":{"position":[[2066,2]]},"209":{"position":[[1004,2]]},"238":{"position":[[1083,1],[1321,1],[1338,2]]}}}],["80",{"_index":1338,"t":{"119":{"position":[[548,3]]},"123":{"position":[[786,3],[830,3],[2025,3],[2069,3]]},"131":{"position":[[584,2]]},"151":{"position":[[1385,3]]},"159":{"position":[[818,3]]}}}],["800",{"_index":1144,"t":{"107":{"position":[[921,3]]},"145":{"position":[[1378,3],[1624,4],[1691,4],[1733,4],[1775,4]]}}}],["9",{"_index":1929,"t":{"139":{"position":[[4863,5]]}}}],["918",{"_index":2458,"t":{"173":{"position":[[177,3]]}}}],["95",{"_index":1408,"t":{"123":{"position":[[816,3],[852,3],[2055,3],[2091,3]]}}}],["999",{"_index":364,"t":{"79":{"position":[[1104,7]]}}}],["a.click",{"_index":337,"t":{"79":{"position":[[484,10]]}}}],["a.download",{"_index":334,"t":{"79":{"position":[[443,10]]}}}],["a.href",{"_index":336,"t":{"79":{"position":[[470,6]]}}}],["a.remove",{"_index":338,"t":{"79":{"position":[[495,11]]}}}],["a1",{"_index":720,"t":{"85":{"position":[[5531,2]]}}}],["a2",{"_index":719,"t":{"85":{"position":[[5515,3],[5546,2]]}}}],["aabb",{"_index":70,"t":{"75":{"position":[[522,4]]}}}],["above",{"_index":218,"t":{"75":{"position":[[4335,5]]},"199":{"position":[[896,5]]},"211":{"position":[[518,5]]}}}],["abs(cos(gl_fragcoord.y",{"_index":2426,"t":{"169":{"position":[[1455,23]]}}}],["abs(sin(gl_fragcoord.x",{"_index":2423,"t":{"169":{"position":[[1391,23]]}}}],["acceess",{"_index":2733,"t":{"207":{"position":[[1275,7]]}}}],["acceleration",{"_index":182,"t":{"75":{"position":[[2843,12],[2872,12],[3168,12],[4758,12],[4999,12],[5171,12]]}}}],["accessed",{"_index":1051,"t":{"97":{"position":[[1430,8]]},"105":{"position":[[1286,8]]},"113":{"position":[[1295,8]]}}}],["achieve",{"_index":1792,"t":{"139":{"position":[[504,7]]}}}],["acolor",{"_index":2470,"t":{"177":{"position":[[556,7],[671,7]]},"179":{"position":[[662,7],[830,7]]}}}],["active",{"_index":2641,"t":{"203":{"position":[[255,8]]}}}],["add",{"_index":248,"t":{"75":{"position":[[5628,3]]},"85":{"position":[[2079,3],[2680,3]]},"89":{"position":[[152,3]]},"93":{"position":[[152,3]]},"107":{"position":[[648,3]]},"115":{"position":[[329,3],[647,3],[1543,3],[1594,3]]},"117":{"position":[[1154,3]]},"119":{"position":[[1252,3]]},"121":{"position":[[311,3],[1638,3],[1689,3]]},"123":{"position":[[2823,3]]},"127":{"position":[[876,3],[1188,3]]},"129":{"position":[[832,3]]},"131":{"position":[[2590,3]]},"139":{"position":[[3350,3],[3762,3],[4194,3],[4341,3],[4518,3]]},"153":{"position":[[466,3]]},"163":{"position":[[5167,3]]},"199":{"position":[[602,3]]},"211":{"position":[[675,3]]}}}],["addattribute('acolor",{"_index":2469,"t":{"177":{"position":[[309,23]]},"179":{"position":[[309,23]]}}}],["addattribute('auvs",{"_index":2213,"t":{"157":{"position":[[320,21]]},"161":{"position":[[320,21],[679,21]]},"163":{"position":[[340,21]]},"165":{"position":[[339,21]]},"167":{"position":[[309,21]]},"169":{"position":[[277,21]]},"179":{"position":[[449,21]]},"181":{"position":[[320,21]]}}}],["addattribute('avertexposition",{"_index":2211,"t":{"157":{"position":[[163,32]]},"161":{"position":[[163,32],[515,32]]},"163":{"position":[[195,32]]},"165":{"position":[[182,32]]},"167":{"position":[[163,32]]},"169":{"position":[[163,32]]},"175":{"position":[[163,32]]},"177":{"position":[[163,32]]},"179":{"position":[[163,32]]},"181":{"position":[[163,32]]}}}],["addattribute('avpos",{"_index":2238,"t":{"159":{"position":[[163,22]]}}}],["addchild",{"_index":2822,"t":{"213":{"position":[[771,8]]}}}],["added",{"_index":1793,"t":{"139":{"position":[[540,5]]},"213":{"position":[[739,5]]}}}],["addeventlistener",{"_index":1801,"t":{"139":{"position":[[728,17]]}}}],["addindex([0",{"_index":2216,"t":{"157":{"position":[[446,13]]},"161":{"position":[[446,13],[799,13]]},"163":{"position":[[466,13]]},"165":{"position":[[465,13]]},"181":{"position":[[446,13]]}}}],["adjust",{"_index":2761,"t":{"209":{"position":[[315,6]]}}}],["advanced",{"_index":2692,"t":{"207":{"position":[[127,8]]}}}],["again",{"_index":1435,"t":{"123":{"position":[[1945,6]]},"145":{"position":[[584,5]]}}}],["aicol",{"_index":2248,"t":{"159":{"position":[[563,8],[1089,6],[1199,6]]}}}],["aipos",{"_index":2246,"t":{"159":{"position":[[441,8],[1067,6],[1278,6]]}}}],["ajax.googleapis.com/ajax/libs/webfont/1/webfont.js",{"_index":2651,"t":{"203":{"position":[[469,56]]}}}],["alien",{"_index":1140,"t":{"107":{"position":[[784,5],[819,5],[1346,5]]}}}],["alien.anchor.x",{"_index":1146,"t":{"107":{"position":[[969,14]]}}}],["alien.anchor.y",{"_index":1147,"t":{"107":{"position":[[991,14]]}}}],["alien.rotation",{"_index":1157,"t":{"107":{"position":[[1365,14]]}}}],["alien.tint",{"_index":1142,"t":{"107":{"position":[[856,10]]}}}],["alien.x",{"_index":1143,"t":{"107":{"position":[[895,7]]}}}],["alien.y",{"_index":1145,"t":{"107":{"position":[[932,7]]}}}],["aliencontainer",{"_index":1131,"t":{"107":{"position":[[432,14]]}}}],["aliencontainer.addchild(alien",{"_index":1149,"t":{"107":{"position":[[1033,31]]}}}],["aliencontainer.cacheasbitmap",{"_index":1156,"t":{"107":{"position":[[1181,28],[1212,30]]}}}],["aliencontainer.rotation",{"_index":1162,"t":{"107":{"position":[[1489,23]]}}}],["aliencontainer.scale.x",{"_index":1159,"t":{"107":{"position":[[1405,22]]}}}],["aliencontainer.scale.y",{"_index":1161,"t":{"107":{"position":[[1447,22]]}}}],["aliencontainer.x",{"_index":1132,"t":{"107":{"position":[[471,16]]}}}],["aliencontainer.y",{"_index":1133,"t":{"107":{"position":[[495,16]]}}}],["alienframes",{"_index":1124,"t":{"107":{"position":[[302,11]]}}}],["alienframes[i",{"_index":1139,"t":{"107":{"position":[[751,13]]}}}],["aliens",{"_index":1108,"t":{"105":{"position":[[149,6],[162,6],[1250,6]]},"107":{"position":[[270,6],[283,6],[663,6],[1288,6]]}}}],["aliens.length",{"_index":1120,"t":{"105":{"position":[[1687,14]]}}}],["aliens.push(alien",{"_index":1148,"t":{"107":{"position":[[1013,19]]}}}],["aliens.push(dude",{"_index":1119,"t":{"105":{"position":[[1301,18]]}}}],["aliens[i",{"_index":1121,"t":{"105":{"position":[[1722,10]]},"107":{"position":[[1354,10]]}}}],["align",{"_index":1499,"t":{"127":{"position":[[1330,6]]},"197":{"position":[[354,6]]},"203":{"position":[[898,6]]},"211":{"position":[[581,5]]},"238":{"position":[[1637,6]]}}}],["allow",{"_index":810,"t":{"93":{"position":[[320,5]]},"117":{"position":[[647,5]]}}}],["allowing",{"_index":92,"t":{"75":{"position":[[893,8]]}}}],["along",{"_index":1015,"t":{"95":{"position":[[9220,5]]}}}],["alpha",{"_index":1200,"t":{"113":{"position":[[234,6]]},"125":{"position":[[368,6]]},"139":{"position":[[3442,6]]}}}],["alpha=0.5",{"_index":1695,"t":{"133":{"position":[[1041,9]]}}}],["alpha=0.7",{"_index":1693,"t":{"133":{"position":[[990,9]]}}}],["already",{"_index":740,"t":{"87":{"position":[[744,7],[1929,7]]},"93":{"position":[[1008,7]]}}}],["alternatively",{"_index":1189,"t":{"111":{"position":[[658,14]]}}}],["amount",{"_index":651,"t":{"85":{"position":[[3754,6],[5713,8],[5733,7]]},"149":{"position":[[188,6]]},"163":{"position":[[2038,7],[2360,7]]}}}],["amount+1",{"_index":2306,"t":{"163":{"position":[[2298,10]]}}}],["amplitude",{"_index":2328,"t":{"163":{"position":[[3445,10],[4028,10]]}}}],["anchor",{"_index":808,"t":{"91":{"position":[[500,6]]},"101":{"position":[[422,6]]},"105":{"position":[[405,6]]},"109":{"position":[[283,6]]},"113":{"position":[[569,6]]},"117":{"position":[[868,6]]},"187":{"position":[[737,7]]},"189":{"position":[[285,6]]},"191":{"position":[[437,6]]}}}],["angle",{"_index":220,"t":{"75":{"position":[[4359,5]]},"95":{"position":[[3749,5],[4045,6]]}}}],["anglestart",{"_index":907,"t":{"95":{"position":[[3713,10],[3765,11],[4033,11]]}}}],["angletomouse",{"_index":221,"t":{"75":{"position":[[4390,12]]}}}],["anim",{"_index":2527,"t":{"187":{"position":[[591,4]]}}}],["anim.anchor.set(0.5",{"_index":2533,"t":{"187":{"position":[[824,21]]}}}],["anim.animationspeed",{"_index":2534,"t":{"187":{"position":[[846,19]]}}}],["anim.play",{"_index":2535,"t":{"187":{"position":[[873,12]]}}}],["anim.rotation",{"_index":2537,"t":{"187":{"position":[[959,13]]}}}],["anim.x",{"_index":2531,"t":{"187":{"position":[[761,6]]}}}],["anim.y",{"_index":2532,"t":{"187":{"position":[[792,6]]}}}],["animate",{"_index":174,"t":{"75":{"position":[[2732,7]]},"81":{"position":[[1096,7]]},"83":{"position":[[1165,7]]},"85":{"position":[[3604,7],[4962,7]]},"95":{"position":[[8345,7]]},"99":{"position":[[787,7]]},"103":{"position":[[453,7]]},"129":{"position":[[925,7]]},"131":{"position":[[2939,7]]},"187":{"position":[[915,7]]},"189":{"position":[[474,7]]},"193":{"position":[[965,7]]}}}],["animated",{"_index":22,"t":{"73":{"position":[[218,8]]}}}],["animatedsprite",{"_index":2484,"t":{"183":{"position":[[552,14],[823,14]]},"185":{"position":[[485,14]]},"187":{"position":[[515,14],[639,14]]}}}],["animating",{"_index":2441,"t":{"171":{"position":[[532,9]]},"183":{"position":[[1059,9]]},"185":{"position":[[870,9]]}}}],["animation",{"_index":2380,"t":{"163":{"position":[[5422,11]]},"165":{"position":[[2888,11]]},"181":{"position":[[1316,11]]}}}],["antialias",{"_index":1323,"t":{"119":{"position":[[144,10]]},"125":{"position":[[161,10]]},"127":{"position":[[68,10]]},"139":{"position":[[283,10]]},"143":{"position":[[68,10]]},"145":{"position":[[68,10]]},"151":{"position":[[100,10]]},"153":{"position":[[68,10]]},"207":{"position":[[1552,10]]},"209":{"position":[[206,10]]}}}],["anymore",{"_index":2603,"t":{"199":{"position":[[1123,7]]}}}],["apart",{"_index":95,"t":{"75":{"position":[[947,5]]}}}],["api",{"_index":2689,"t":{"207":{"position":[[63,3],[87,3],[1258,4]]},"209":{"position":[[69,3],[551,3]]}}}],["app",{"_index":44,"t":{"75":{"position":[[215,3]]},"77":{"position":[[39,3]]},"79":{"position":[[39,3]]},"81":{"position":[[39,3]]},"83":{"position":[[39,3]]},"85":{"position":[[39,3]]},"87":{"position":[[39,3]]},"89":{"position":[[39,3]]},"91":{"position":[[39,3]]},"93":{"position":[[39,3]]},"95":{"position":[[39,3]]},"97":{"position":[[39,3]]},"99":{"position":[[39,3]]},"101":{"position":[[39,3]]},"103":{"position":[[39,3]]},"105":{"position":[[39,3]]},"107":{"position":[[39,3]]},"109":{"position":[[39,3]]},"111":{"position":[[39,3]]},"113":{"position":[[39,3]]},"115":{"position":[[39,3]]},"117":{"position":[[39,3]]},"119":{"position":[[115,3]]},"121":{"position":[[39,3]]},"123":{"position":[[39,3]]},"125":{"position":[[132,3]]},"127":{"position":[[39,3]]},"129":{"position":[[39,3]]},"131":{"position":[[311,3]]},"133":{"position":[[107,3]]},"135":{"position":[[39,3]]},"137":{"position":[[39,3]]},"139":{"position":[[254,3]]},"141":{"position":[[39,3]]},"143":{"position":[[39,3]]},"145":{"position":[[39,3],[1482,4]]},"147":{"position":[[39,3]]},"149":{"position":[[39,3]]},"151":{"position":[[71,3]]},"153":{"position":[[39,3]]},"155":{"position":[[39,3]]},"157":{"position":[[39,3]]},"159":{"position":[[39,3]]},"161":{"position":[[39,3]]},"163":{"position":[[39,3]]},"165":{"position":[[39,3]]},"167":{"position":[[39,3]]},"169":{"position":[[39,3]]},"171":{"position":[[39,3]]},"173":{"position":[[39,3]]},"175":{"position":[[39,3]]},"177":{"position":[[39,3]]},"179":{"position":[[39,3]]},"181":{"position":[[39,3]]},"183":{"position":[[39,3]]},"185":{"position":[[39,3]]},"187":{"position":[[39,3]]},"189":{"position":[[39,3]]},"191":{"position":[[39,3]]},"193":{"position":[[214,3]]},"195":{"position":[[39,3]]},"197":{"position":[[39,3]]},"199":{"position":[[39,3]]},"201":{"position":[[39,3]]},"203":{"position":[[39,3]]},"205":{"position":[[39,3]]},"207":{"position":[[1523,3]]},"209":{"position":[[177,3]]},"211":{"position":[[39,3]]},"213":{"position":[[39,3]]},"238":{"position":[[39,3]]}}}],["app.renderer",{"_index":1204,"t":{"113":{"position":[[365,12]]}}}],["app.renderer.events.cursorstyles.default",{"_index":1233,"t":{"115":{"position":[[354,40]]}}}],["app.renderer.events.cursorstyles.hover",{"_index":1234,"t":{"115":{"position":[[410,38]]}}}],["app.renderer.extract.base64(bunnycontainer",{"_index":331,"t":{"79":{"position":[[334,44]]}}}],["app.renderer.generatetexture(circle",{"_index":2143,"t":{"149":{"position":[[749,36]]}}}],["app.renderer.render(app.stage",{"_index":2816,"t":{"211":{"position":[[2180,30]]}}}],["app.renderer.render(brush",{"_index":296,"t":{"77":{"position":[[1325,26]]}}}],["app.renderer.render(container",{"_index":2829,"t":{"213":{"position":[[1067,30]]}}}],["app.renderer.render(gridquad",{"_index":2388,"t":{"163":{"position":[[5735,29]]}}}],["app.renderer.render(line",{"_index":317,"t":{"77":{"position":[[1692,25]]}}}],["app.renderer.render(noisequad",{"_index":2390,"t":{"163":{"position":[[5865,30]]}}}],["app.renderer.render(ripplequad",{"_index":2389,"t":{"163":{"position":[[5798,31]]}}}],["app.renderer.render(wavequad",{"_index":2391,"t":{"163":{"position":[[5930,29]]}}}],["app.renderer.screen",{"_index":1665,"t":{"131":{"position":[[2874,20]]}}}],["app.renderer.screen.height",{"_index":498,"t":{"83":{"position":[[1729,26],[1894,26]]},"131":{"position":[[667,26]]}}}],["app.renderer.screen.width",{"_index":496,"t":{"83":{"position":[[1605,25],[1633,25],[1701,25],[1830,25],[2422,26]]}}}],["app.screen",{"_index":166,"t":{"75":{"position":[[2599,11]]},"77":{"position":[[564,11],[1039,11]]},"79":{"position":[[574,11]]},"81":{"position":[[910,11]]},"117":{"position":[[1278,11]]},"119":{"position":[[1050,11]]},"125":{"position":[[642,11]]},"127":{"position":[[287,11]]},"133":{"position":[[1451,11]]},"145":{"position":[[195,11]]},"149":{"position":[[968,11]]}}}],["app.screen.height",{"_index":140,"t":{"75":{"position":[[2078,18],[3369,18],[3648,18],[3731,18],[3887,17]]},"85":{"position":[[1710,18],[2577,17]]},"87":{"position":[[1049,17],[1724,17]]},"89":{"position":[[775,17],[936,17]]},"91":{"position":[[625,17]]},"93":{"position":[[806,17]]},"97":{"position":[[297,18],[895,19],[1693,17]]},"99":{"position":[[613,17]]},"101":{"position":[[547,17]]},"105":{"position":[[726,18],[1545,17]]},"109":{"position":[[408,17]]},"111":{"position":[[425,17]]},"113":{"position":[[813,18],[1560,17]]},"115":{"position":[[625,18]]},"117":{"position":[[466,19]]},"121":{"position":[[289,18]]},"125":{"position":[[469,17]]},"127":{"position":[[169,18]]},"129":{"position":[[289,18]]},"133":{"position":[[357,18],[1264,17]]},"135":{"position":[[256,18]]},"137":{"position":[[337,17],[1515,18]]},"139":{"position":[[3974,19]]},"141":{"position":[[286,17],[452,17],[1355,17]]},"149":{"position":[[439,18]]},"153":{"position":[[303,17],[440,17],[1119,17],[1475,17]]},"183":{"position":[[744,17],[988,17]]},"185":{"position":[[640,18]]},"187":{"position":[[801,17]]},"189":{"position":[[410,17]]},"191":{"position":[[574,17]]},"193":{"position":[[791,17]]},"195":{"position":[[446,18]]},"199":{"position":[[464,18],[1459,18]]},"211":{"position":[[179,18]]},"238":{"position":[[1063,17],[1144,17]]}}}],["app.screen.width",{"_index":195,"t":{"75":{"position":[[3240,17],[3581,17],[3829,17]]},"85":{"position":[[1917,17],[2049,17]]},"87":{"position":[[1016,16],[1691,16]]},"89":{"position":[[739,16],[903,16]]},"91":{"position":[[593,16]]},"93":{"position":[[770,16]]},"97":{"position":[[259,17],[840,18],[1651,16]]},"99":{"position":[[577,16]]},"101":{"position":[[515,16]]},"105":{"position":[[683,17],[1503,16]]},"109":{"position":[[376,16]]},"111":{"position":[[392,16]]},"113":{"position":[[770,17],[1518,16]]},"115":{"position":[[587,17]]},"117":{"position":[[420,18]]},"121":{"position":[[251,17]]},"127":{"position":[[207,17]]},"129":{"position":[[251,17]]},"133":{"position":[[319,17],[1240,16]]},"135":{"position":[[226,17],[416,17],[616,17]]},"137":{"position":[[305,16],[1485,17]]},"139":{"position":[[3956,17]]},"141":{"position":[[257,16],[416,16]]},"149":{"position":[[401,17]]},"153":{"position":[[274,16],[404,16],[1087,16]]},"183":{"position":[[698,17],[942,17]]},"185":{"position":[[592,17]]},"187":{"position":[[770,16]]},"189":{"position":[[378,16]]},"191":{"position":[[538,16]]},"193":{"position":[[755,16]]},"195":{"position":[[428,17]]},"199":{"position":[[414,17],[1420,17]]},"211":{"position":[[153,17]]},"238":{"position":[[1020,16],[1104,16]]}}}],["app.stage",{"_index":282,"t":{"77":{"position":[[1051,9]]},"119":{"position":[[1673,11]]},"137":{"position":[[1574,9]]}}}],["app.stage.addchild",{"_index":281,"t":{"77":{"position":[[916,19]]},"123":{"position":[[2836,19]]}}}],["app.stage.addchild(aliencontainer",{"_index":1135,"t":{"107":{"position":[[581,35]]}}}],["app.stage.addchild(anim",{"_index":2536,"t":{"187":{"position":[[886,25]]}}}],["app.stage.addchild(arc",{"_index":2026,"t":{"143":{"position":[[1416,24]]}}}],["app.stage.addchild(arc2",{"_index":2032,"t":{"143":{"position":[[1578,25]]}}}],["app.stage.addchild(arc3",{"_index":2038,"t":{"143":{"position":[[1774,25]]}}}],["app.stage.addchild(background",{"_index":1019,"t":{"97":{"position":[[316,31]]},"115":{"position":[[674,31]]},"121":{"position":[[338,31]]},"129":{"position":[[308,31]]},"133":{"position":[[376,31]]},"149":{"position":[[350,31]]}}}],["app.stage.addchild(basictext",{"_index":2666,"t":{"205":{"position":[[241,30]]}}}],["app.stage.addchild(beatifulrect",{"_index":2059,"t":{"143":{"position":[[2392,33]]}}}],["app.stage.addchild(bezier",{"_index":2005,"t":{"143":{"position":[[732,27]]}}}],["app.stage.addchild(bezier2",{"_index":2021,"t":{"143":{"position":[[1263,28]]}}}],["app.stage.addchild(bg",{"_index":1708,"t":{"135":{"position":[[275,23]]},"153":{"position":[[326,23]]},"155":{"position":[[229,23]]}}}],["app.stage.addchild(bitmapfonttext",{"_index":2574,"t":{"197":{"position":[[422,35]]}}}],["app.stage.addchild(bottom",{"_index":628,"t":{"85":{"position":[[2935,27]]}}}],["app.stage.addchild(bunny",{"_index":809,"t":{"91":{"position":[[648,26]]},"101":{"position":[[570,26]]},"109":{"position":[[431,26]]},"117":{"position":[[1174,26]]},"189":{"position":[[433,26]]}}}],["app.stage.addchild(button",{"_index":1267,"t":{"115":{"position":[[1563,27]]},"121":{"position":[[1658,27]]},"199":{"position":[[619,27]]}}}],["app.stage.addchild(character",{"_index":827,"t":{"93":{"position":[[891,30]]},"191":{"position":[[597,30]]}}}],["app.stage.addchild(combinequad",{"_index":2379,"t":{"163":{"position":[[5376,32]]}}}],["app.stage.addchild(container",{"_index":836,"t":{"95":{"position":[[388,30],[2366,30],[3280,30],[4321,30],[7499,30]]},"99":{"position":[[189,30]]},"133":{"position":[[1290,30]]},"137":{"position":[[198,30]]},"141":{"position":[[999,30]]},"147":{"position":[[198,30]]},"153":{"position":[[953,30]]},"193":{"position":[[367,30]]},"213":{"position":[[189,30]]}}}],["app.stage.addchild(coordinates",{"_index":1936,"t":{"139":{"position":[[5020,32]]}}}],["app.stage.addchild(description",{"_index":1948,"t":{"139":{"position":[[5592,32]]}}}],["app.stage.addchild(displacementsprite",{"_index":1750,"t":{"137":{"position":[[1065,39]]},"147":{"position":[[753,39]]}}}],["app.stage.addchild(dude",{"_index":1054,"t":{"97":{"position":[[1467,25]]},"105":{"position":[[1320,25]]},"238":{"position":[[1487,25]]}}}],["app.stage.addchild(egg",{"_index":800,"t":{"89":{"position":[[959,24]]}}}],["app.stage.addchild(explosion",{"_index":2514,"t":{"185":{"position":[[828,30]]}}}],["app.stage.addchild(fast",{"_index":2500,"t":{"183":{"position":[[1024,25]]}}}],["app.stage.addchild(flower",{"_index":793,"t":{"89":{"position":[[798,27]]}}}],["app.stage.addchild(focus",{"_index":2145,"t":{"149":{"position":[[864,26]]}}}],["app.stage.addchild(g",{"_index":2440,"t":{"171":{"position":[[500,22]]}}}],["app.stage.addchild(goback",{"_index":772,"t":{"87":{"position":[[1747,27]]}}}],["app.stage.addchild(gonext",{"_index":753,"t":{"87":{"position":[[1072,27]]}}}],["app.stage.addchild(graphics",{"_index":2092,"t":{"145":{"position":[[1245,29]]},"151":{"position":[[2407,29]]}}}],["app.stage.addchild(gridcontainer",{"_index":2375,"t":{"163":{"position":[[5233,34]]}}}],["app.stage.addchild(help",{"_index":1972,"t":{"141":{"position":[[1392,25]]},"153":{"position":[[1512,25]]}}}],["app.stage.addchild(littledudes",{"_index":1714,"t":{"135":{"position":[[467,32]]}}}],["app.stage.addchild(littlerobot",{"_index":1719,"t":{"135":{"position":[[667,32]]}}}],["app.stage.addchild(mask",{"_index":2205,"t":{"155":{"position":[[489,24]]}}}],["app.stage.addchild(new",{"_index":1325,"t":{"119":{"position":[[239,22],[478,22],[635,22]]},"125":{"position":[[278,22]]},"139":{"position":[[3310,22]]}}}],["app.stage.addchild(noisecontainer",{"_index":2377,"t":{"163":{"position":[[5305,35]]}}}],["app.stage.addchild(outputsprite",{"_index":2779,"t":{"211":{"position":[[688,33]]}}}],["app.stage.addchild(pixi.sprite.from('https://pixijs.com/assets/bunny.png",{"_index":1495,"t":{"127":{"position":[[948,76]]}}}],["app.stage.addchild(plane",{"_index":1097,"t":{"103":{"position":[[311,26]]}}}],["app.stage.addchild(quad",{"_index":2236,"t":{"157":{"position":[[1134,25]]},"161":{"position":[[1527,25]]},"165":{"position":[[2849,25]]},"181":{"position":[[1277,25]]}}}],["app.stage.addchild(realpath",{"_index":1998,"t":{"143":{"position":[[532,29]]}}}],["app.stage.addchild(realpath2",{"_index":2014,"t":{"143":{"position":[[1025,30]]}}}],["app.stage.addchild(rectandhole",{"_index":2053,"t":{"143":{"position":[[2116,32]]}}}],["app.stage.addchild(redsquare",{"_index":250,"t":{"75":{"position":[[5641,29]]}}}],["app.stage.addchild(reelcontainer",{"_index":570,"t":{"85":{"position":[[1604,34]]}}}],["app.stage.addchild(richtext",{"_index":2675,"t":{"205":{"position":[[776,29]]}}}],["app.stage.addchild(ring",{"_index":1759,"t":{"137":{"position":[[1377,25]]}}}],["app.stage.addchild(ripplecontainer",{"_index":2376,"t":{"163":{"position":[[5268,36]]}}}],["app.stage.addchild(rope",{"_index":395,"t":{"81":{"position":[[806,25]]}}}],["app.stage.addchild(screenshottext",{"_index":373,"t":{"79":{"position":[[1325,34]]}}}],["app.stage.addchild(skewtext",{"_index":2688,"t":{"205":{"position":[[1276,29]]}}}],["app.stage.addchild(slider",{"_index":1492,"t":{"127":{"position":[[820,27]]}}}],["app.stage.addchild(slow",{"_index":2493,"t":{"183":{"position":[[780,25]]}}}],["app.stage.addchild(snakecontainer",{"_index":2465,"t":{"173":{"position":[[535,35]]}}}],["app.stage.addchild(sprite",{"_index":1193,"t":{"111":{"position":[[793,27]]},"207":{"position":[[2069,27]]},"209":{"position":[[1047,27]]},"213":{"position":[[686,27]]}}}],["app.stage.addchild(sprites",{"_index":1201,"t":{"113":{"position":[[251,28]]}}}],["app.stage.addchild(star.sprite",{"_index":458,"t":{"83":{"position":[[633,32]]}}}],["app.stage.addchild(strip",{"_index":2436,"t":{"171":{"position":[[412,26]]}}}],["app.stage.addchild(stuffcontainer",{"_index":2783,"t":{"211":{"position":[[815,35]]}}}],["app.stage.addchild(text",{"_index":1566,"t":{"131":{"position":[[700,25]]},"238":{"position":[[1695,25]]}}}],["app.stage.addchild(text1",{"_index":2632,"t":{"201":{"position":[[1040,26]]}}}],["app.stage.addchild(text2",{"_index":2633,"t":{"201":{"position":[[1067,26]]}}}],["app.stage.addchild(text3",{"_index":2634,"t":{"201":{"position":[[1094,26]]}}}],["app.stage.addchild(text4",{"_index":2635,"t":{"201":{"position":[[1121,26]]}}}],["app.stage.addchild(textsample",{"_index":2661,"t":{"203":{"position":[[952,31]]}}}],["app.stage.addchild(thing",{"_index":2094,"t":{"145":{"position":[[1341,26]]},"153":{"position":[[1050,26]]}}}],["app.stage.addchild(tilingsprite",{"_index":2558,"t":{"195":{"position":[[468,33]]}}}],["app.stage.addchild(title",{"_index":1503,"t":{"127":{"position":[[1443,26]]}}}],["app.stage.addchild(top",{"_index":627,"t":{"85":{"position":[[2910,24]]}}}],["app.stage.addchild(triangle",{"_index":2467,"t":{"175":{"position":[[672,29]]},"177":{"position":[[992,29]]},"179":{"position":[[1414,29]]}}}],["app.stage.addchild(triangle2",{"_index":2429,"t":{"169":{"position":[[1807,29]]}}}],["app.stage.addchild(triangle3",{"_index":2417,"t":{"167":{"position":[[1526,29]]}}}],["app.stage.addchild(triangles",{"_index":2257,"t":{"159":{"position":[[1492,30]]}}}],["app.stage.addchild(videosprite",{"_index":2613,"t":{"199":{"position":[[1478,32]]}}}],["app.stage.addchild(wavecontainer",{"_index":2378,"t":{"163":{"position":[[5341,34]]}}}],["app.stage.addeventlistener('pointermove",{"_index":1474,"t":{"125":{"position":[[676,41]]},"127":{"position":[[1585,41]]}}}],["app.stage.eventmode",{"_index":163,"t":{"75":{"position":[[2547,19]]},"77":{"position":[[987,19]]},"79":{"position":[[522,19]]},"81":{"position":[[858,19]]},"107":{"position":[[549,19]]},"117":{"position":[[1226,19]]},"119":{"position":[[998,19]]},"125":{"position":[[518,19]]},"127":{"position":[[1553,19],[1717,19]]},"133":{"position":[[1463,19]]},"137":{"position":[[126,19]]},"141":{"position":[[126,19]]},"145":{"position":[[143,19]]},"147":{"position":[[126,19]]},"149":{"position":[[916,19]]},"153":{"position":[[143,19]]},"155":{"position":[[126,19]]}}}],["app.stage.filterarea",{"_index":1664,"t":{"131":{"position":[[2851,20]]}}}],["app.stage.filters",{"_index":1666,"t":{"131":{"position":[[2895,17]]},"141":{"position":[[1030,17],[1150,17]]}}}],["app.stage.hitarea",{"_index":165,"t":{"75":{"position":[[2579,17]]},"77":{"position":[[1019,17]]},"79":{"position":[[554,17]]},"81":{"position":[[890,17]]},"117":{"position":[[1258,17]]},"119":{"position":[[1030,17]]},"125":{"position":[[622,17]]},"127":{"position":[[267,17]]},"133":{"position":[[1431,17]]},"145":{"position":[[175,17]]},"149":{"position":[[948,17]]}}}],["app.stage.name",{"_index":1340,"t":{"119":{"position":[[567,14]]}}}],["app.stage.off('pointermove",{"_index":1317,"t":{"117":{"position":[[1804,28]]}}}],["app.stage.on('mousemove",{"_index":167,"t":{"75":{"position":[[2611,25]]},"81":{"position":[[922,25]]}}}],["app.stage.on('pointerdown",{"_index":340,"t":{"79":{"position":[[586,27]]},"145":{"position":[[1487,27]]}}}],["app.stage.on('pointermove",{"_index":1315,"t":{"117":{"position":[[1720,27]]},"133":{"position":[[1495,27]]},"149":{"position":[[980,27]]}}}],["app.stage.on('pointertap",{"_index":1154,"t":{"107":{"position":[[1123,26]]},"141":{"position":[[1095,26]]},"153":{"position":[[1201,26]]}}}],["app.stage.on('pointerup",{"_index":1301,"t":{"117":{"position":[[1290,25]]}}}],["app.stage.on('pointerupoutside",{"_index":1303,"t":{"117":{"position":[[1328,32]]}}}],["app.stage.removeeventlistener('pointermove",{"_index":1511,"t":{"127":{"position":[[1747,44]]}}}],["app.start",{"_index":339,"t":{"79":{"position":[[507,12]]},"107":{"position":[[1067,12]]},"129":{"position":[[907,12]]},"183":{"position":[[1069,12]]},"185":{"position":[[880,12]]}}}],["app.stop",{"_index":329,"t":{"79":{"position":[[304,11]]},"107":{"position":[[126,11]]},"129":{"position":[[384,11]]}}}],["app.ticker.add",{"_index":399,"t":{"81":{"position":[[1111,17]]},"97":{"position":[[1739,17]]},"103":{"position":[[483,17]]},"105":{"position":[[1589,17]]},"107":{"position":[[1245,17]]},"109":{"position":[[458,17]]},"113":{"position":[[1620,17]]},"135":{"position":[[891,17]]},"137":{"position":[[1864,17]]},"145":{"position":[[1808,17]]},"147":{"position":[[896,17]]},"153":{"position":[[1538,17]]},"155":{"position":[[673,17]]},"171":{"position":[[542,17]]},"173":{"position":[[603,17]]},"187":{"position":[[936,17]]},"191":{"position":[[870,17]]},"195":{"position":[[517,17]]},"211":{"position":[[1665,17]]},"213":{"position":[[1044,17]]}}}],["app.ticker.add((delta",{"_index":176,"t":{"75":{"position":[[2747,22]]},"79":{"position":[[968,22]]},"83":{"position":[[1180,22]]},"85":{"position":[[3620,22],[4978,22]]},"95":{"position":[[8360,22]]},"99":{"position":[[802,22]]},"129":{"position":[[944,22]]},"131":{"position":[[2955,22]]},"141":{"position":[[1418,22]]},"157":{"position":[[1160,22]]},"159":{"position":[[1523,22]]},"161":{"position":[[1553,22]]},"163":{"position":[[5448,22]]},"165":{"position":[[2914,22]]},"167":{"position":[[1578,22]]},"169":{"position":[[1848,22]]},"175":{"position":[[702,22]]},"177":{"position":[[1022,22]]},"179":{"position":[[1444,22]]},"181":{"position":[[1363,22]]},"189":{"position":[[489,22]]},"193":{"position":[[980,22]]}}}],["appears",{"_index":1288,"t":{"117":{"position":[[767,7]]}}}],["application",{"_index":1524,"t":{"129":{"position":[[348,11],[888,11]]},"131":{"position":[[852,11]]}}}],["applied",{"_index":177,"t":{"75":{"position":[[2778,7]]}}}],["apply",{"_index":1819,"t":{"139":{"position":[[1174,5],[1272,5]]}}}],["arc",{"_index":2022,"t":{"143":{"position":[[1298,3],[1313,3],[1447,3],[1610,3]]}}}],["arc.arc(600",{"_index":2025,"t":{"143":{"position":[[1371,12]]}}}],["arc.linestyle(5",{"_index":2023,"t":{"143":{"position":[[1340,16]]}}}],["arc2",{"_index":2027,"t":{"143":{"position":[[1464,4]]}}}],["arc2.arc(650",{"_index":2030,"t":{"143":{"position":[[1524,13]]}}}],["arc2.linestyle(6",{"_index":2028,"t":{"143":{"position":[[1492,17]]}}}],["arc3",{"_index":2033,"t":{"143":{"position":[[1627,4]]}}}],["arc3.arc(650",{"_index":2035,"t":{"143":{"position":[[1718,13]]}}}],["arc3.linetexturestyle",{"_index":2034,"t":{"143":{"position":[[1655,23]]}}}],["arcradius",{"_index":918,"t":{"95":{"position":[[4376,9],[4751,11],[4995,11]]}}}],["area",{"_index":558,"t":{"85":{"position":[[1342,5]]},"123":{"position":[[1108,4],[1585,4],[2523,6],[2744,6]]},"125":{"position":[[580,4]]},"139":{"position":[[4006,4]]}}}],["areas",{"_index":1427,"t":{"123":{"position":[[1679,5]]}}}],["arguments",{"_index":1533,"t":{"129":{"position":[[593,10]]}}}],["arial",{"_index":583,"t":{"85":{"position":[[2140,8]]},"141":{"position":[[1284,8]]},"153":{"position":[[1404,8]]},"205":{"position":[[319,8],[857,8]]}}}],["around",{"_index":149,"t":{"75":{"position":[[2281,6]]},"137":{"position":[[2258,6]]}}}],["arr",{"_index":422,"t":{"81":{"position":[[1739,4]]}}}],["arr.length",{"_index":424,"t":{"81":{"position":[[1772,10],[1792,10]]}}}],["arr[k",{"_index":425,"t":{"81":{"position":[[1815,7]]}}}],["array",{"_index":387,"t":{"81":{"position":[[489,6],[1856,6],[1899,6],[1925,7],[2107,7],[2148,8],[2181,7],[2206,8]]},"97":{"position":[[361,5]]},"105":{"position":[[1257,5]]},"113":{"position":[[293,5],[1266,5]]},"115":{"position":[[1608,5]]},"121":{"position":[[1703,5]]},"183":{"position":[[255,5]]},"185":{"position":[[236,5]]},"187":{"position":[[246,5]]},"211":{"position":[[864,5],[1286,5]]}}}],["article",{"_index":31,"t":{"75":{"position":[[59,7]]}}}],["asset",{"_index":813,"t":{"93":{"position":[[462,5],[498,5]]}}}],["assets",{"_index":731,"t":{"87":{"position":[[252,7],[364,7],[687,6],[1301,6],[1407,6]]},"89":{"position":[[160,6],[329,6]]},"93":{"position":[[160,6],[330,6]]},"95":{"position":[[4544,6]]}}}],["async",{"_index":327,"t":{"79":{"position":[[270,5]]},"87":{"position":[[149,5],[642,5],[1180,5],[1236,5],[1855,5]]},"93":{"position":[[949,5]]},"101":{"position":[[185,5],[200,5],[612,5]]}}}],["attribute",{"_index":2212,"t":{"157":{"position":[[203,9],[310,9],[349,9],[436,9],[550,9],[582,9]]},"159":{"position":[[1030,9],[1052,9],[1074,9]]},"161":{"position":[[203,9],[310,9],[349,9],[436,9],[555,9],[669,9],[708,9],[789,9],[942,9],[974,9]]},"163":{"position":[[235,9],[330,9],[369,9],[456,9],[592,9],[624,9]]},"165":{"position":[[222,9],[329,9],[368,9],[455,9],[541,9],[573,9]]},"167":{"position":[[203,9],[299,9],[338,9],[420,9],[491,9],[523,9]]},"169":{"position":[[203,9],[306,9],[425,9],[457,9],[974,9],[1006,9]]},"175":{"position":[[287,9]]},"177":{"position":[[203,9],[299,9],[340,9],[440,9],[509,9],[541,9]]},"179":{"position":[[203,9],[299,9],[340,9],[439,9],[478,9],[560,9],[615,9],[647,9],[670,9]]},"181":{"position":[[203,9],[310,9],[349,9],[436,9],[522,9],[554,9]]}}}],["audio",{"_index":2599,"t":{"199":{"position":[[961,5],[991,5]]}}}],["auto",{"_index":1510,"t":{"127":{"position":[[1739,7]]}}}],["autostart",{"_index":2475,"t":{"183":{"position":[[68,10]]},"185":{"position":[[68,10]]}}}],["auvs",{"_index":2220,"t":{"157":{"position":[[597,5],[706,5]]},"161":{"position":[[989,5],[1098,5]]},"163":{"position":[[639,5],[748,5]]},"165":{"position":[[588,5],[697,5]]},"167":{"position":[[538,5],[647,5]]},"169":{"position":[[472,5],[581,5],[1021,5],[1130,5]]},"179":{"position":[[685,5],[815,5]]},"181":{"position":[[569,5],[678,5]]}}}],["auxiliar",{"_index":817,"t":{"93":{"position":[[568,8]]}}}],["avertexposition",{"_index":2219,"t":{"157":{"position":[[565,16]]},"161":{"position":[[957,16]]},"163":{"position":[[607,16]]},"165":{"position":[[556,16]]},"167":{"position":[[506,16]]},"169":{"position":[[440,16],[989,16]]},"175":{"position":[[302,16]]},"177":{"position":[[524,16]]},"179":{"position":[[630,16]]},"181":{"position":[[537,16]]}}}],["avoid",{"_index":2744,"t":{"207":{"position":[[1738,5]]},"238":{"position":[[754,5]]}}}],["avpos",{"_index":2251,"t":{"159":{"position":[[1045,6]]}}}],["await",{"_index":330,"t":{"79":{"position":[[328,5]]},"87":{"position":[[453,5],[820,5],[1497,5]]},"93":{"position":[[1059,5]]},"101":{"position":[[152,5],[240,5]]}}}],["awaited",{"_index":1090,"t":{"101":{"position":[[335,7]]}}}],["away",{"_index":227,"t":{"75":{"position":[[4548,4]]},"83":{"position":[[2286,4]]},"91":{"position":[[172,4]]}}}],["axes",{"_index":1886,"t":{"139":{"position":[[3365,5]]}}}],["axis",{"_index":510,"t":{"83":{"position":[[2153,4]]}}}],["b",{"_index":129,"t":{"75":{"position":[[1882,1],[1920,3]]},"177":{"position":[[374,1],[394,1],[415,1]]},"179":{"position":[[374,1],[394,1],[415,1]]}}}],["b.scale.set(math.abs(sin",{"_index":905,"t":{"95":{"position":[[3033,24]]}}}],["back",{"_index":200,"t":{"75":{"position":[[3513,4]]},"87":{"position":[[1906,4]]},"187":{"position":[[538,4]]}}}],["background",{"_index":47,"t":{"75":{"position":[[244,11]]},"77":{"position":[[619,10],[936,11]]},"81":{"position":[[68,11]]},"85":{"position":[[68,11]]},"87":{"position":[[68,11],[540,10]]},"89":{"position":[[68,11]]},"91":{"position":[[68,11]]},"93":{"position":[[68,11],[352,10],[427,10]]},"95":{"position":[[68,11]]},"97":{"position":[[142,10],[166,10]]},"99":{"position":[[68,11]]},"101":{"position":[[68,11]]},"103":{"position":[[68,11]]},"111":{"position":[[68,11]]},"115":{"position":[[68,11],[474,13],[494,10],[651,10]]},"117":{"position":[[68,11]]},"119":{"position":[[161,11]]},"121":{"position":[[138,13],[158,10],[315,10]]},"123":{"position":[[78,11]]},"125":{"position":[[178,11]]},"127":{"position":[[85,11]]},"129":{"position":[[136,10],[159,10]]},"131":{"position":[[340,11]]},"133":{"position":[[204,10],[227,10]]},"139":{"position":[[300,11]]},"149":{"position":[[306,10]]},"187":{"position":[[68,11]]},"189":{"position":[[68,11]]},"191":{"position":[[68,11]]},"193":{"position":[[249,11]]},"197":{"position":[[68,11]]},"201":{"position":[[68,11]]},"203":{"position":[[68,11]]},"205":{"position":[[68,11]]},"213":{"position":[[68,11]]}}}],["background.filters",{"_index":1545,"t":{"129":{"position":[[847,18]]}}}],["background.height",{"_index":1018,"t":{"97":{"position":[[277,17]]},"115":{"position":[[605,17]]},"121":{"position":[[269,17]]},"129":{"position":[[269,17]]},"133":{"position":[[337,17]]},"149":{"position":[[419,17]]}}}],["background.mask",{"_index":2146,"t":{"149":{"position":[[891,15]]}}}],["background.width",{"_index":1017,"t":{"97":{"position":[[240,16]]},"115":{"position":[[568,16]]},"121":{"position":[[232,16]]},"129":{"position":[[232,16]]},"133":{"position":[[300,16]]},"149":{"position":[[382,16]]}}}],["backgroundalpha",{"_index":1163,"t":{"109":{"position":[[68,16]]},"199":{"position":[[68,16]]}}}],["backgroundcolor",{"_index":323,"t":{"79":{"position":[[68,16]]}}}],["backout",{"_index":721,"t":{"85":{"position":[[5559,7]]}}}],["backout(0.5",{"_index":648,"t":{"85":{"position":[[3449,13]]}}}],["backout(amount",{"_index":724,"t":{"85":{"position":[[5670,15]]}}}],["ball",{"_index":889,"t":{"95":{"position":[[2500,4],[2885,4]]}}}],["ball.anchor.set(0.5",{"_index":891,"t":{"95":{"position":[[2565,21]]}}}],["ball.position.set",{"_index":893,"t":{"95":{"position":[[2613,18]]}}}],["ballamount",{"_index":887,"t":{"95":{"position":[[2421,10],[2475,11],[2656,10],[2718,10],[2948,10]]}}}],["balls",{"_index":885,"t":{"95":{"position":[[2221,6],[2443,5]]}}}],["balls.foreach((b",{"_index":898,"t":{"95":{"position":[[2897,17]]}}}],["balls.push(ball",{"_index":896,"t":{"95":{"position":[[2759,17]]}}}],["base",{"_index":837,"t":{"95":{"position":[[425,4],[3317,4],[4398,4]]}}}],["base.height",{"_index":841,"t":{"95":{"position":[[536,11],[3428,11],[4491,11]]}}}],["base.mask",{"_index":847,"t":{"95":{"position":[[748,9],[3521,9],[4787,9]]}}}],["base.width",{"_index":840,"t":{"95":{"position":[[517,10],[3409,10],[4472,10]]}}}],["based",{"_index":29,"t":{"75":{"position":[[36,5]]},"81":{"position":[[1668,5]]},"85":{"position":[[3761,5]]},"131":{"position":[[899,8]]},"165":{"position":[[831,7]]},"193":{"position":[[56,5]]}}}],["basespeed",{"_index":446,"t":{"83":{"position":[[296,9],[1363,11]]}}}],["basetexture",{"_index":2703,"t":{"207":{"position":[[448,12],[522,12],[1718,11]]}}}],["basetexture.format",{"_index":2739,"t":{"207":{"position":[[1433,19],[1453,19]]}}}],["basetexture.premultiplyalpha",{"_index":2737,"t":{"207":{"position":[[1365,30]]}}}],["basetexture.type",{"_index":2740,"t":{"207":{"position":[[1473,17]]}}}],["basetextures",{"_index":2746,"t":{"207":{"position":[[1790,12]]}}}],["basic",{"_index":16,"t":{"73":{"position":[[176,5]]},"75":{"position":[[516,5]]},"85":{"position":[[5477,5]]}}}],["basic/container",{"_index":2544,"t":{"193":{"position":[[65,16]]}}}],["basically",{"_index":936,"t":{"95":{"position":[[5053,9]]}}}],["basictext",{"_index":2662,"t":{"205":{"position":[[155,9]]}}}],["basictext.x",{"_index":2664,"t":{"205":{"position":[[204,11]]}}}],["basictext.y",{"_index":2665,"t":{"205":{"position":[[222,11]]}}}],["bc",{"_index":1647,"t":{"131":{"position":[[2365,2],[2477,4]]},"165":{"position":[[2213,2],[2325,4]]}}}],["beatifulrect",{"_index":2054,"t":{"143":{"position":[[2185,12]]}}}],["beatifulrect.beginfill(0xff0000",{"_index":2056,"t":{"143":{"position":[[2292,33]]}}}],["beatifulrect.drawrect(80",{"_index":2057,"t":{"143":{"position":[[2326,25]]}}}],["beatifulrect.endfill",{"_index":2058,"t":{"143":{"position":[[2368,23]]}}}],["beatifulrect.linetexturestyle",{"_index":2055,"t":{"143":{"position":[[2221,31]]}}}],["become",{"_index":2824,"t":{"213":{"position":[[823,6]]}}}],["before",{"_index":950,"t":{"95":{"position":[[6275,6]]},"129":{"position":[[773,6]]},"203":{"position":[[175,6]]},"211":{"position":[[2149,6]]}}}],["beginfill(0",{"_index":1345,"t":{"119":{"position":[[674,13]]}}}],["beginfill(0x0",{"_index":2577,"t":{"199":{"position":[[241,15]]}}}],["beginfill(0x272d37",{"_index":1482,"t":{"127":{"position":[[378,20]]}}}],["beginfill(0xff0000",{"_index":2138,"t":{"149":{"position":[[493,20]]}}}],["beginfill(0xffffff",{"_index":256,"t":{"77":{"position":[[210,20]]},"119":{"position":[[869,20]]},"123":{"position":[[1303,20],[1828,20]]},"125":{"position":[[317,20]]},"127":{"position":[[560,20]]},"139":{"position":[[3622,20]]},"199":{"position":[[310,20]]}}}],["being",{"_index":1111,"t":{"105":{"position":[[536,5]]}}}],["below",{"_index":15,"t":{"73":{"position":[[169,6]]}}}],["best",{"_index":1644,"t":{"131":{"position":[[2321,4]]},"165":{"position":[[2169,4]]}}}],["better",{"_index":652,"t":{"85":{"position":[[3794,6]]},"95":{"position":[[4518,6],[4571,6]]},"209":{"position":[[345,6]]}}}],["between",{"_index":64,"t":{"75":{"position":[[451,7],[533,7],[1784,7],[4146,7],[5032,7]]},"97":{"position":[[1310,7]]},"105":{"position":[[902,7],[1163,7]]},"113":{"position":[[1098,7]]},"127":{"position":[[2157,7]]}}}],["bezier",{"_index":1987,"t":{"143":{"position":[[225,6],[568,6],[766,6]]}}}],["bezier.beziercurveto(100",{"_index":2001,"t":{"143":{"position":[[632,25]]}}}],["bezier.linestyle(5",{"_index":1999,"t":{"143":{"position":[[598,19]]}}}],["bezier.position.x",{"_index":2003,"t":{"143":{"position":[[684,17]]}}}],["bezier.position.y",{"_index":2004,"t":{"143":{"position":[[708,17]]}}}],["bezier2",{"_index":2015,"t":{"143":{"position":[[1062,7]]}}}],["bezier2.beziercurveto(0",{"_index":2018,"t":{"143":{"position":[[1159,24]]}}}],["bezier2.linetexturestyle",{"_index":2016,"t":{"143":{"position":[[1093,26]]}}}],["bezier2.position.x",{"_index":2019,"t":{"143":{"position":[[1211,18]]}}}],["bezier2.position.y",{"_index":2020,"t":{"143":{"position":[[1237,18]]}}}],["bg",{"_index":1703,"t":{"135":{"position":[[132,2]]},"137":{"position":[[1409,2]]},"141":{"position":[[164,2]]},"153":{"position":[[181,2]]},"155":{"position":[[164,2]]}}}],["bg.alpha",{"_index":1760,"t":{"137":{"position":[[1534,8]]}}}],["bg.anchor.set(0.5",{"_index":1949,"t":{"141":{"position":[[230,19]]},"153":{"position":[[247,19]]}}}],["bg.height",{"_index":1707,"t":{"135":{"position":[[244,9]]},"137":{"position":[[1503,9]]}}}],["bg.rotation",{"_index":1973,"t":{"141":{"position":[[1446,11]]},"153":{"position":[[1561,11]]}}}],["bg.width",{"_index":1706,"t":{"135":{"position":[[215,8]]},"137":{"position":[[1474,8]]}}}],["bg.x",{"_index":1950,"t":{"141":{"position":[[250,4]]},"153":{"position":[[267,4]]}}}],["bg.y",{"_index":1951,"t":{"141":{"position":[[279,4]]},"153":{"position":[[296,4]]}}}],["bgfront",{"_index":1953,"t":{"141":{"position":[[481,7]]},"153":{"position":[[495,7]]}}}],["bgfront.anchor.set(0.5",{"_index":1954,"t":{"141":{"position":[[558,24]]},"153":{"position":[[572,24]]}}}],["bgfront.rotation",{"_index":1974,"t":{"141":{"position":[[1467,16]]},"153":{"position":[[1582,16]]}}}],["big",{"_index":2764,"t":{"209":{"position":[[374,3]]}}}],["bigger",{"_index":1292,"t":{"117":{"position":[[921,7]]}}}],["bit",{"_index":302,"t":{"77":{"position":[[1450,3]]},"97":{"position":[[932,3]]},"103":{"position":[[543,3]]},"107":{"position":[[1304,3]]},"117":{"position":[[917,3]]}}}],["bitmap",{"_index":2567,"t":{"197":{"position":[[276,7]]}}}],["bitmapfonttext",{"_index":2565,"t":{"197":{"position":[[238,14]]}}}],["bitmapfonttext.x",{"_index":2572,"t":{"197":{"position":[[375,16]]}}}],["bitmapfonttext.y",{"_index":2573,"t":{"197":{"position":[[398,16]]}}}],["black",{"_index":1343,"t":{"119":{"position":[[608,5],[743,6]]}}}],["blackbox",{"_index":1344,"t":{"119":{"position":[[624,8]]}}}],["blackbox.addchild(new",{"_index":1352,"t":{"119":{"position":[[831,21]]}}}],["blackbox.eventmode",{"_index":1358,"t":{"119":{"position":[[1093,18]]}}}],["blackbox.name",{"_index":1348,"t":{"119":{"position":[[727,13]]}}}],["blackbox.x",{"_index":1349,"t":{"119":{"position":[[756,10]]}}}],["blackbox].foreach((object",{"_index":1374,"t":{"119":{"position":[[1695,26]]}}}],["blend",{"_index":18,"t":{"73":{"position":[[192,5]]},"97":{"position":[[988,5]]},"133":{"position":[[1012,5]]}}}],["blendmode",{"_index":392,"t":{"81":{"position":[[757,9]]}}}],["blur",{"_index":546,"t":{"85":{"position":[[1054,5],[3740,4],[3843,4]]},"149":{"position":[[183,4]]}}}],["bluramount",{"_index":1725,"t":{"135":{"position":[[936,10],[1027,13]]}}}],["bluramount2",{"_index":1727,"t":{"135":{"position":[[972,11],[1065,14]]}}}],["blurfilter1",{"_index":1720,"t":{"135":{"position":[[706,11],[824,14]]}}}],["blurfilter1.blur",{"_index":1728,"t":{"135":{"position":[[1003,16]]}}}],["blurfilter2",{"_index":1721,"t":{"135":{"position":[[757,11],[861,14]]}}}],["blurfilter2.blur",{"_index":1729,"t":{"135":{"position":[[1041,16]]}}}],["blursize",{"_index":2134,"t":{"149":{"position":[[201,8],[535,9],[554,9],[692,9],[717,9]]}}}],["bold",{"_index":589,"t":{"85":{"position":[[2196,7]]},"141":{"position":[[1319,7]]},"153":{"position":[[1439,7]]},"205":{"position":[[375,7]]}}}],["both",{"_index":179,"t":{"75":{"position":[[2805,4],[5188,4]]},"89":{"position":[[368,4]]},"107":{"position":[[1094,4]]}}}],["bottom",{"_index":572,"t":{"85":{"position":[[1654,6],[1950,6]]},"95":{"position":[[562,6],[1262,6],[1734,6],[1771,6],[5919,6],[6707,6],[6764,6]]}}}],["bottom.addchild(playtext",{"_index":615,"t":{"85":{"position":[[2650,26]]}}}],["bottom.addlistener('pointerdown",{"_index":632,"t":{"85":{"position":[[3045,33]]}}}],["bottom.beginfill(0",{"_index":580,"t":{"85":{"position":[[1980,19]]}}}],["bottom.cursor",{"_index":631,"t":{"85":{"position":[[3018,13]]}}}],["bottom.drawrect(0",{"_index":581,"t":{"85":{"position":[[2004,18]]}}}],["bottom.eventmode",{"_index":630,"t":{"85":{"position":[[2989,16]]}}}],["bottom.height",{"_index":844,"t":{"95":{"position":[[653,13]]}}}],["bottom.width",{"_index":843,"t":{"95":{"position":[[632,12]]}}}],["boundary",{"_index":1781,"t":{"139":{"position":[[114,8],[1025,8]]}}}],["bounding",{"_index":1055,"t":{"97":{"position":[[1507,8]]},"105":{"position":[[1360,8]]},"113":{"position":[[1368,8]]}}}],["bounds",{"_index":1069,"t":{"97":{"position":[[2112,9]]},"105":{"position":[[1957,9]]},"137":{"position":[[256,6]]},"149":{"position":[[648,6],[815,8]]}}}],["bounds.height",{"_index":1741,"t":{"137":{"position":[[723,14],[2447,14],[2495,14],[2524,14]]}}}],["bounds.width",{"_index":1739,"t":{"137":{"position":[[682,13],[2317,13],[2364,13],[2392,13]]}}}],["bounds.x",{"_index":1776,"t":{"137":{"position":[[2293,9],[2353,8]]}}}],["bounds.y",{"_index":1777,"t":{"137":{"position":[[2423,9],[2484,8]]}}}],["bounds1",{"_index":76,"t":{"75":{"position":[[610,7]]}}}],["bounds1.height",{"_index":88,"t":{"75":{"position":[[821,14]]}}}],["bounds1.width",{"_index":84,"t":{"75":{"position":[[738,13]]}}}],["bounds1.x",{"_index":81,"t":{"75":{"position":[[685,9],[726,9]]}}}],["bounds1.y",{"_index":85,"t":{"75":{"position":[[767,9],[809,9]]}}}],["bounds2",{"_index":78,"t":{"75":{"position":[[647,7]]}}}],["bounds2.height",{"_index":87,"t":{"75":{"position":[[791,14]]}}}],["bounds2.width",{"_index":83,"t":{"75":{"position":[[709,13]]}}}],["bounds2.x",{"_index":82,"t":{"75":{"position":[[697,9],[754,9]]}}}],["bounds2.y",{"_index":86,"t":{"75":{"position":[[779,9],[838,10]]}}}],["bourke",{"_index":994,"t":{"95":{"position":[[8523,6]]}}}],["box",{"_index":1056,"t":{"97":{"position":[[1516,3]]},"105":{"position":[[1369,3]]},"113":{"position":[[1377,3],[1381,3]]},"119":{"position":[[614,3],[750,5],[789,3],[956,5]]}}}],["boxes",{"_index":1328,"t":{"119":{"position":[[306,5]]}}}],["break",{"_index":869,"t":{"95":{"position":[[1648,6],[6575,6]]},"131":{"position":[[2482,6],[2507,6]]},"165":{"position":[[2330,6],[2355,6]]}}}],["bring",{"_index":1826,"t":{"139":{"position":[[1389,5]]}}}],["brings",{"_index":2523,"t":{"187":{"position":[[530,7]]}}}],["brush",{"_index":254,"t":{"77":{"position":[[170,5],[182,5]]}}}],["brush.position.set(x",{"_index":295,"t":{"77":{"position":[[1299,21]]}}}],["buffer",{"_index":1098,"t":{"103":{"position":[[349,6],[385,6]]},"159":{"position":[[321,6],[450,7],[572,7]]}}}],["buffer.data.length",{"_index":1103,"t":{"103":{"position":[[587,19]]}}}],["buffer.data[i",{"_index":1104,"t":{"103":{"position":[[614,14]]}}}],["buffer.data[instanceoffset",{"_index":2250,"t":{"159":{"position":[[780,26],[822,26],[871,26],[920,26]]}}}],["buffer.update",{"_index":1106,"t":{"103":{"position":[[668,16]]}}}],["buffers",{"_index":2809,"t":{"211":{"position":[[1823,7]]}}}],["build",{"_index":538,"t":{"85":{"position":[[785,5],[1165,5],[1642,5]]},"131":{"position":[[2761,5]]},"163":{"position":[[142,5]]},"165":{"position":[[129,5],[2657,5]]},"171":{"position":[[144,5]]},"173":{"position":[[144,5]]}}}],["builds",{"_index":529,"t":{"85":{"position":[[433,6]]}}}],["bunch",{"_index":1136,"t":{"107":{"position":[[654,5]]},"153":{"position":[[472,5]]}}}],["bundle",{"_index":739,"t":{"87":{"position":[[715,7],[733,6]]}}}],["bundles",{"_index":728,"t":{"87":{"position":[[219,8],[511,7]]}}}],["bunnies",{"_index":1076,"t":{"99":{"position":[[342,7]]},"193":{"position":[[520,7]]},"213":{"position":[[727,7],[815,7]]}}}],["bunny",{"_index":342,"t":{"79":{"position":[[668,5]]},"91":{"position":[[434,5]]},"99":{"position":[[387,5],[646,5]]},"101":{"position":[[364,5]]},"109":{"position":[[195,5]]},"117":{"position":[[541,5],[562,5],[610,5],[798,5],[1071,7]]},"127":{"position":[[880,5],[940,5],[1266,8]]},"189":{"position":[[197,5]]},"193":{"position":[[565,5],[824,5]]},"213":{"position":[[331,5]]}}}],["bunny's",{"_index":1291,"t":{"117":{"position":[[860,7]]},"127":{"position":[[1837,7]]}}}],["bunny.anchor.set(0.5",{"_index":344,"t":{"79":{"position":[[702,22]]},"91":{"position":[[513,22]]},"99":{"position":[[421,22]]},"101":{"position":[[435,22]]},"109":{"position":[[296,22]]},"117":{"position":[[881,22]]},"127":{"position":[[1109,22]]},"189":{"position":[[298,22]]},"193":{"position":[[599,22]]}}}],["bunny.cursor",{"_index":1290,"t":{"117":{"position":[[820,12]]}}}],["bunny.eventmode",{"_index":1286,"t":{"117":{"position":[[693,15]]}}}],["bunny.on('pointerdown",{"_index":1297,"t":{"117":{"position":[[1034,23]]}}}],["bunny.rotation",{"_index":1169,"t":{"109":{"position":[[530,14]]},"189":{"position":[[655,14]]},"213":{"position":[[423,14]]}}}],["bunny.scale.set(3",{"_index":1296,"t":{"117":{"position":[[952,19]]},"127":{"position":[[1089,19],[2223,17]]}}}],["bunny.texture.basetexture.scalemode",{"_index":1496,"t":{"127":{"position":[[1025,35]]}}}],["bunny.x",{"_index":345,"t":{"79":{"position":[[725,7]]},"91":{"position":[[583,7]]},"99":{"position":[[444,7]]},"101":{"position":[[505,7]]},"109":{"position":[[366,7]]},"117":{"position":[[1125,7]]},"127":{"position":[[1132,7]]},"189":{"position":[[368,7]]},"193":{"position":[[622,7]]},"213":{"position":[[365,7]]}}}],["bunny.y",{"_index":347,"t":{"79":{"position":[[749,7]]},"91":{"position":[[615,7]]},"99":{"position":[[468,7]]},"101":{"position":[[537,7]]},"109":{"position":[[398,7]]},"117":{"position":[[1138,7]]},"127":{"position":[[1158,7]]},"189":{"position":[[400,7]]},"193":{"position":[[646,7]]},"213":{"position":[[389,7]]}}}],["bunnycontainer",{"_index":325,"t":{"79":{"position":[[231,14],[1360,16]]}}}],["bunnycontainer.addchild(bunny",{"_index":349,"t":{"79":{"position":[[783,31]]}}}],["bunnycontainer.height",{"_index":357,"t":{"79":{"position":[[941,21]]}}}],["bunnycontainer.pivot.x",{"_index":354,"t":{"79":{"position":[[865,22]]}}}],["bunnycontainer.pivot.y",{"_index":356,"t":{"79":{"position":[[916,22]]}}}],["bunnycontainer.rotation",{"_index":358,"t":{"79":{"position":[[996,23]]}}}],["bunnycontainer.width",{"_index":355,"t":{"79":{"position":[[890,20]]}}}],["bunnycontainer.x",{"_index":350,"t":{"79":{"position":[[817,16]]}}}],["bunnycontainer.y",{"_index":352,"t":{"79":{"position":[[841,16]]}}}],["button",{"_index":1252,"t":{"115":{"position":[[1143,6],[1319,6],[1370,6],[1598,6]]},"117":{"position":[[729,6]]},"121":{"position":[[807,6],[958,6],[1036,6],[1136,6],[1693,6]]},"123":{"position":[[242,6],[563,6],[1641,6]]},"199":{"position":[[161,6],[212,6],[396,6],[536,6],[1116,6]]}}}],["button.anchor.set(0.5",{"_index":1256,"t":{"115":{"position":[[1209,23]]},"121":{"position":[[848,23]]}}}],["button.cursor",{"_index":1254,"t":{"115":{"position":[[1184,13]]},"121":{"position":[[1009,13]]},"199":{"position":[[572,13]]}}}],["button.destroy",{"_index":2604,"t":{"199":{"position":[[1131,17]]}}}],["button.eventmode",{"_index":1260,"t":{"115":{"position":[[1341,16]]},"121":{"position":[[980,16]]},"199":{"position":[[543,16]]}}}],["button.height",{"_index":2584,"t":{"199":{"position":[[485,14]]}}}],["button.on('pointertap",{"_index":2601,"t":{"199":{"position":[[1035,23]]}}}],["button.width",{"_index":2583,"t":{"199":{"position":[[434,13]]}}}],["button.x",{"_index":1257,"t":{"115":{"position":[[1233,8]]},"121":{"position":[[872,8]]},"199":{"position":[[403,8]]}}}],["button.y",{"_index":1259,"t":{"115":{"position":[[1268,8]]},"121":{"position":[[907,8]]},"199":{"position":[[453,8]]}}}],["buttonpositions",{"_index":1243,"t":{"115":{"position":[[1036,15]]},"121":{"position":[[700,15]]}}}],["buttonpositions[i",{"_index":1258,"t":{"115":{"position":[[1244,17],[1279,17]]},"121":{"position":[[883,17],[918,17]]}}}],["buttons",{"_index":1242,"t":{"115":{"position":[[1016,7]]},"121":{"position":[[680,7]]}}}],["buttons.push(button",{"_index":1268,"t":{"115":{"position":[[1614,21]]},"121":{"position":[[1709,21]]}}}],["buttons[0].scale.set(1.2",{"_index":1270,"t":{"115":{"position":[[1666,26]]},"121":{"position":[[1761,26]]}}}],["buttons[2].rotation",{"_index":1271,"t":{"115":{"position":[[1693,19]]},"121":{"position":[[1788,19]]}}}],["buttons[3].scale.set(0.8",{"_index":1272,"t":{"115":{"position":[[1729,26]]},"121":{"position":[[1824,26]]}}}],["buttons[4].rotation",{"_index":1275,"t":{"115":{"position":[[1788,19]]},"121":{"position":[[1883,19]]}}}],["buttons[4].scale.set(0.8",{"_index":1273,"t":{"115":{"position":[[1756,25]]},"121":{"position":[[1851,25]]}}}],["cache",{"_index":829,"t":{"93":{"position":[[1032,6]]}}}],["calclight(p",{"_index":1652,"t":{"131":{"position":[[2440,12]]},"165":{"position":[[2288,12]]}}}],["calclight(vec3",{"_index":1603,"t":{"131":{"position":[[1441,14]]},"165":{"position":[[1308,14]]}}}],["calculate",{"_index":122,"t":{"75":{"position":[[1761,9],[4115,9],[4744,9],[4974,9]]},"83":{"position":[[810,9],[1764,9]]},"95":{"position":[[965,9],[5473,9]]},"163":{"position":[[2148,11]]}}}],["calculatebounds",{"_index":1853,"t":{"139":{"position":[[2124,15],[2140,17]]}}}],["calculated",{"_index":653,"t":{"85":{"position":[[3804,10]]}}}],["calculates",{"_index":89,"t":{"75":{"position":[[854,10]]},"95":{"position":[[5122,10]]},"131":{"position":[[1083,10]]},"165":{"position":[[1002,10]]}}}],["calculation",{"_index":1601,"t":{"131":{"position":[[1423,12]]},"165":{"position":[[1290,12]]}}}],["call",{"_index":984,"t":{"95":{"position":[[8391,4]]},"101":{"position":[[602,4]]}}}],["calling",{"_index":814,"t":{"93":{"position":[[473,7]]}}}],["calls",{"_index":2731,"t":{"207":{"position":[[1194,5]]}}}],["cam",{"_index":1623,"t":{"131":{"position":[[1786,3],[1927,5],[2212,4]]},"165":{"position":[[1634,3],[1775,5],[2060,4]]}}}],["camera",{"_index":469,"t":{"83":{"position":[[885,7]]},"139":{"position":[[183,6],[493,7],[859,7]]}}}],["camera\\'s",{"_index":1851,"t":{"139":{"position":[[2057,9]]}}}],["cameraz",{"_index":444,"t":{"83":{"position":[[261,7],[768,7],[1330,7],[1450,8],[1559,8]]}}}],["cant",{"_index":1681,"t":{"133":{"position":[[613,4]]},"207":{"position":[[1239,4]]}}}],["canvas",{"_index":1468,"t":{"125":{"position":[[118,7],[573,6]]},"139":{"position":[[240,7]]},"193":{"position":[[115,6]]},"207":{"position":[[589,7],[652,6],[1491,8]]},"209":{"position":[[412,6]]},"238":{"position":[[840,6]]}}}],["canvas.getcontext('2d",{"_index":2711,"t":{"207":{"position":[[753,24]]},"209":{"position":[[510,24]]}}}],["canvas.height",{"_index":2709,"t":{"207":{"position":[[717,13]]},"209":{"position":[[479,13]]}}}],["canvas.transfercontroltooffscreen",{"_index":2548,"t":{"193":{"position":[[171,36]]}}}],["canvas.width",{"_index":2708,"t":{"207":{"position":[[695,12]]},"209":{"position":[[455,12]]}}}],["canvas2d",{"_index":2690,"t":{"207":{"position":[[69,8]]},"209":{"position":[[51,8],[542,8]]}}}],["capture",{"_index":1908,"t":{"139":{"position":[[4044,7]]}}}],["careful",{"_index":2748,"t":{"207":{"position":[[1824,8]]}}}],["cb(delta",{"_index":988,"t":{"95":{"position":[[8453,10]]}}}],["cells",{"_index":2196,"t":{"155":{"position":[[259,5],[514,7]]}}}],["cells.mask",{"_index":2204,"t":{"155":{"position":[[470,10]]}}}],["cells.scale.set(1.5",{"_index":2198,"t":{"155":{"position":[[324,21]]}}}],["center",{"_index":206,"t":{"75":{"position":[[3969,6]]},"83":{"position":[[2136,6],[2169,7],[2306,7]]},"91":{"position":[[480,6],[562,6]]},"99":{"position":[[556,6],[639,6]]},"101":{"position":[[402,6],[484,6]]},"109":{"position":[[263,6],[345,6]]},"117":{"position":[[849,6]]},"127":{"position":[[1337,9]]},"139":{"position":[[5388,6]]},"163":{"position":[[1178,6],[2174,6],[3510,6]]},"189":{"position":[[265,6],[347,6]]},"191":{"position":[[418,6],[503,6]]},"193":{"position":[[734,6],[817,6]]}}}],["centerd",{"_index":1209,"t":{"113":{"position":[[600,7]]}}}],["centered",{"_index":1110,"t":{"105":{"position":[[436,8]]}}}],["chachicle",{"_index":2616,"t":{"201":{"position":[[210,10],[626,12]]}}}],["change",{"_index":476,"t":{"83":{"position":[[1050,6]]},"85":{"position":[[4848,7]]},"97":{"position":[[969,6]]},"127":{"position":[[1246,6]]},"139":{"position":[[470,6]]},"187":{"position":[[712,6]]}}}],["changed",{"_index":483,"t":{"83":{"position":[[1241,7]]},"127":{"position":[[905,7]]}}}],["changes",{"_index":236,"t":{"75":{"position":[[4988,7],[5160,7]]}}}],["character",{"_index":821,"t":{"93":{"position":[[691,9]]},"191":{"position":[[377,9]]}}}],["character.anchor.set(0.5",{"_index":822,"t":{"93":{"position":[[729,26]]},"191":{"position":[[450,26]]}}}],["character.cursor",{"_index":826,"t":{"93":{"position":[[861,16]]},"191":{"position":[[691,16]]}}}],["character.eventmode",{"_index":825,"t":{"93":{"position":[[829,19]]},"191":{"position":[[659,19]]}}}],["character.on('pointertap",{"_index":828,"t":{"93":{"position":[[922,26]]},"191":{"position":[[721,26]]}}}],["character.rotation",{"_index":2543,"t":{"191":{"position":[[893,18]]}}}],["character.texture",{"_index":830,"t":{"93":{"position":[[1039,17]]},"191":{"position":[[810,17]]}}}],["character.x",{"_index":823,"t":{"93":{"position":[[756,11]]},"191":{"position":[[524,11]]}}}],["character.y",{"_index":824,"t":{"93":{"position":[[792,11]]},"191":{"position":[[560,11]]}}}],["chars",{"_index":1928,"t":{"139":{"position":[[4826,6]]}}}],["check",{"_index":12,"t":{"73":{"position":[[129,5]]},"75":{"position":[[527,5],[3093,5]]},"95":{"position":[[8798,5]]},"131":{"position":[[194,5],[1150,6]]},"165":{"position":[[1069,6]]}}}],["checks",{"_index":1436,"t":{"123":{"position":[[1977,6]]}}}],["child",{"_index":1794,"t":{"139":{"position":[[551,7]]}}}],["children",{"_index":2825,"t":{"213":{"position":[[830,8],[901,9]]}}}],["choice",{"_index":2705,"t":{"207":{"position":[[568,7]]}}}],["circle",{"_index":252,"t":{"77":{"position":[[137,6]]},"125":{"position":[[57,6],[256,6],[269,6],[614,7]]},"133":{"position":[[982,7]]},"145":{"position":[[1038,6]]},"149":{"position":[[149,6],[464,6]]},"151":{"position":[[760,6],[800,7],[841,6],[963,6],[1112,6]]}}}],["circle.filters",{"_index":2140,"t":{"149":{"position":[[584,14]]}}}],["circle.position.copyfrom(e.global",{"_index":1476,"t":{"125":{"position":[[727,35]]}}}],["circle.position.set(app.screen.width",{"_index":1471,"t":{"125":{"position":[[427,36]]}}}],["clamped",{"_index":1517,"t":{"127":{"position":[[1983,7]]}}}],["class",{"_index":1802,"t":{"139":{"position":[[746,5],[1993,5]]},"207":{"position":[[261,5]]}}}],["cleaner",{"_index":1570,"t":{"131":{"position":[[796,7]]}}}],["clear",{"_index":297,"t":{"77":{"position":[[1369,6],[1580,8],[1735,6]]},"211":{"position":[[2244,6]]}}}],["clears",{"_index":2815,"t":{"211":{"position":[[2130,6]]}}}],["click",{"_index":1151,"t":{"107":{"position":[[1105,5]]},"123":{"position":[[1630,5]]},"139":{"position":[[4522,5],[5470,5]]},"145":{"position":[[1429,5]]}}}],["click/tap",{"_index":2585,"t":{"199":{"position":[[663,9],[912,9]]}}}],["clipinput(k",{"_index":421,"t":{"81":{"position":[[1726,12],[1881,12],[1908,11],[2167,13],[2189,11]]}}}],["code",{"_index":8,"t":{"73":{"position":[[78,4]]},"95":{"position":[[8673,4]]}}}],["col",{"_index":1640,"t":{"131":{"position":[[2128,3],[2422,3]]},"165":{"position":[[1976,3],[2270,3]]}}}],["colliding",{"_index":234,"t":{"75":{"position":[[4918,9]]}}}],["collision",{"_index":91,"t":{"75":{"position":[[882,10],[5074,9]]}}}],["collisionpush",{"_index":240,"t":{"75":{"position":[[5090,13]]}}}],["collisionpush.x",{"_index":243,"t":{"75":{"position":[[5229,16],[5339,16]]}}}],["collisionpush.y",{"_index":244,"t":{"75":{"position":[[5267,16],[5376,16]]}}}],["collisionresponse(greensquare",{"_index":241,"t":{"75":{"position":[[5106,30]]}}}],["collisionresponse(object1",{"_index":96,"t":{"75":{"position":[[962,26]]}}}],["color",{"_index":312,"t":{"77":{"position":[[1614,6]]},"125":{"position":[[351,6]]},"139":{"position":[[3432,6]]},"163":{"position":[[2228,5],[2324,6],[2894,5],[2928,5],[2948,7],[4548,5]]}}}],["color.rgb",{"_index":2304,"t":{"163":{"position":[[2258,9]]}}}],["color1",{"_index":2278,"t":{"163":{"position":[[1275,6],[1397,6]]}}}],["color2",{"_index":2280,"t":{"163":{"position":[[1315,6],[1406,7]]}}}],["colorsize",{"_index":2242,"t":{"159":{"position":[[300,9],[404,13],[517,11],[580,10],[636,11],[768,11]]}}}],["combination",{"_index":2351,"t":{"163":{"position":[[4353,11]]}}}],["combinequad",{"_index":2365,"t":{"163":{"position":[[4924,11]]}}}],["combinequad.position.set(430",{"_index":2371,"t":{"163":{"position":[[5128,29]]}}}],["combines",{"_index":1150,"t":{"107":{"position":[[1085,8]]}}}],["combineshader",{"_index":2364,"t":{"163":{"position":[[4836,13],[4962,15]]}}}],["combineuniforms",{"_index":2363,"t":{"163":{"position":[[4735,15],[4900,17]]}}}],["complete",{"_index":695,"t":{"85":{"position":[[4866,9]]}}}],["completed",{"_index":1531,"t":{"129":{"position":[[531,9]]}}}],["completely",{"_index":765,"t":{"87":{"position":[[1418,10]]}}}],["completion",{"_index":833,"t":{"95":{"position":[[222,11]]}}}],["connect",{"_index":1800,"t":{"139":{"position":[[708,7]]}}}],["connects",{"_index":306,"t":{"77":{"position":[[1484,8]]}}}],["const",{"_index":43,"t":{"75":{"position":[[209,5],[391,5],[471,5],[604,5],[641,5],[1056,5],[1140,5],[1274,5],[1366,5],[1509,5],[1604,5],[1853,5],[1876,5],[1966,5],[2288,5],[2511,5],[3982,5],[4194,5],[4384,5],[4594,5],[4688,5],[5084,5]]},"77":{"position":[[33,5],[176,5],[310,5],[538,5],[576,5],[613,5],[682,5],[754,5],[814,5]]},"79":{"position":[[33,5],[151,5],[225,5],[316,5],[379,5],[662,5],[1041,5],[1116,5]]},"81":{"position":[[33,5],[178,5],[257,5],[278,5],[353,5],[430,5],[452,5],[690,5],[1388,5],[1478,5],[1547,5],[2042,5],[2067,5],[2157,5],[2223,5],[2241,5]]},"83":{"position":[[33,5],[155,5],[232,5],[274,5],[290,5],[349,5],[372,5],[419,5],[476,5],[893,5],[934,5],[1414,5],[1540,5],[1797,5],[1861,5],[1926,5],[2003,5]]},"85":{"position":[[33,5],[358,5],[382,5],[515,5],[801,5],[819,5],[893,5],[977,5],[1213,5],[1695,5],[1844,5],[1944,5],[2093,5],[2443,5],[2696,5],[3256,5],[3276,5],[3321,5],[3369,5],[3710,5],[4039,5],[4063,5],[4652,5],[4754,5],[5006,5],[5030,5],[5093,5],[5116,5]]},"87":{"position":[[33,5],[193,5],[795,5],[921,5],[1472,5],[1598,5]]},"89":{"position":[[33,5],[384,5],[651,5],[826,5]]},"91":{"position":[[33,5],[198,5],[428,5]]},"93":{"position":[[33,5],[685,5]]},"95":{"position":[[33,5],[276,5],[317,5],[419,5],[499,5],[556,5],[675,5],[989,5],[1037,5],[1085,5],[1445,5],[1474,5],[1659,5],[2254,5],[2295,5],[2397,5],[2415,5],[2437,5],[2494,5],[2923,5],[3168,5],[3209,5],[3311,5],[3391,5],[3448,5],[3707,5],[3743,5],[3777,5],[3796,5],[3838,5],[4209,5],[4250,5],[4352,5],[4370,5],[4392,5],[4592,5],[4863,5],[4883,5],[5170,5],[5497,5],[5545,5],[5610,5],[6348,5],[6377,5],[6586,5],[7387,5],[7428,5],[7530,5],[7731,5],[8097,5],[8917,5],[9049,5],[9123,5],[9367,5],[9398,5]]},"97":{"position":[[33,5],[160,5],[401,5],[423,5],[570,5],[1541,5],[1572,5],[1861,5]]},"99":{"position":[[33,5],[149,5],[244,5],[381,5]]},"101":{"position":[[33,5],[224,5],[358,5]]},"103":{"position":[[33,5],[228,5],[379,5]]},"105":{"position":[[33,5],[156,5],[175,5],[322,5],[1394,5],[1425,5],[1709,5]]},"107":{"position":[[33,5],[277,5],[296,5],[426,5],[733,5],[813,5],[1340,5]]},"109":{"position":[[33,5],[189,5]]},"111":{"position":[[33,5],[257,5]]},"113":{"position":[[33,5],[126,5],[324,5],[344,5],[482,5],[1408,5],[1439,5],[1743,5]]},"115":{"position":[[33,5],[172,5],[245,5],[488,5],[749,5],[830,5],[920,5],[1010,5],[1030,5],[1137,5]]},"117":{"position":[[33,5],[188,5],[556,5]]},"119":{"position":[[109,5],[225,5],[445,5],[462,5],[618,5],[814,5],[1146,5],[1167,5],[1201,5]]},"121":{"position":[[33,5],[152,5],[413,5],[494,5],[584,5],[674,5],[694,5],[801,5]]},"123":{"position":[[33,5],[141,5],[249,5],[570,5],[1113,5],[1264,5],[1703,5],[1788,5],[2326,5],[2381,5],[2490,5],[2599,5],[2704,5]]},"125":{"position":[[126,5],[263,5]]},"127":{"position":[[33,5],[149,5],[188,5],[318,5],[343,5],[525,5],[934,5],[1198,5],[1898,5],[2175,5]]},"129":{"position":[[33,5],[153,5]]},"131":{"position":[[305,5],[519,5],[882,5]]},"133":{"position":[[101,5],[221,5],[646,5],[1148,5],[1321,5]]},"135":{"position":[[33,5],[126,5],[299,5],[500,5],[700,5],[751,5],[930,5],[966,5]]},"137":{"position":[[33,5],[158,5],[229,5],[250,5],[373,5],[424,5],[881,5],[981,5],[1251,5],[1403,5],[1945,5]]},"139":{"position":[[248,5],[2160,5],[2522,5],[2568,5],[3292,5],[3567,5],[4409,5],[4873,5],[5112,5],[5169,5],[5289,5]]},"141":{"position":[[33,5],[158,5],[309,5],[362,5],[475,5],[612,5],[745,5],[878,5],[1201,5],[1645,5]]},"143":{"position":[[33,5],[143,5],[302,5],[562,5],[786,5],[1056,5],[1307,5],[1458,5],[1621,5],[1815,5],[2179,5]]},"145":{"position":[[33,5],[207,5],[1306,5]]},"147":{"position":[[33,5],[158,5],[229,5],[365,5],[591,5]]},"149":{"position":[[33,5],[156,5],[195,5],[300,5],[458,5],[642,5],[733,5],[824,5]]},"151":{"position":[[65,5],[175,5],[2238,5]]},"153":{"position":[[33,5],[175,5],[350,5],[489,5],[597,5],[702,5],[807,5],[1015,5],[1321,5]]},"155":{"position":[[33,5],[158,5],[253,5],[346,5],[522,5]]},"157":{"position":[[33,5],[126,5],[491,5],[1040,5]]},"159":{"position":[[33,5],[126,5],[270,5],[294,5],[315,5],[725,5],[971,5],[1407,5]]},"161":{"position":[[33,5],[126,5],[477,5],[821,5],[883,5],[1432,5]]},"163":{"position":[[33,5],[158,5],[547,5],[914,5],[1028,5],[1443,5],[1479,5],[1687,5],[1763,5],[1817,5],[1952,5],[2335,5],[2406,5],[2491,5],[2569,5],[2627,5],[2757,5],[2988,5],[3049,5],[3131,5],[3208,5],[3264,5],[3361,5],[4005,5],[4057,5],[4136,5],[4212,5],[4266,5],[4370,5],[4729,5],[4830,5],[4918,5]]},"165":{"position":[[33,5],[145,5],[496,5],[809,5],[2400,5],[2688,5],[2755,5]]},"167":{"position":[[33,5],[126,5],[430,5],[908,5],[1066,5],[1219,5]]},"169":{"position":[[33,5],[126,5],[366,5],[914,5],[1591,5],[1641,5]]},"171":{"position":[[33,5],[158,5],[181,5],[281,5],[439,5]]},"173":{"position":[[33,5],[158,5],[187,5],[287,5],[404,5]]},"175":{"position":[[33,5],[126,5],[228,5],[589,5]]},"177":{"position":[[33,5],[126,5],[450,5],[886,5]]},"179":{"position":[[33,5],[126,5],[570,5],[944,5],[1141,5],[1241,5],[1308,5]]},"181":{"position":[[33,5],[126,5],[477,5],[790,5],[1006,5],[1116,5],[1183,5]]},"183":{"position":[[33,5],[283,5],[338,5],[378,5],[423,5],[516,5],[567,5],[838,5]]},"185":{"position":[[33,5],[264,5],[328,5],[500,5]]},"187":{"position":[[33,5],[283,5],[333,5],[585,5]]},"189":{"position":[[33,5],[191,5]]},"191":{"position":[[33,5],[170,5],[248,5],[371,5]]},"193":{"position":[[109,5],[158,5],[208,5],[327,5],[422,5],[559,5]]},"195":{"position":[[33,5],[165,5],[375,5]]},"197":{"position":[[33,5],[232,5]]},"199":{"position":[[33,5],[206,5],[1187,5],[1329,5]]},"201":{"position":[[33,5],[548,5],[657,5],[760,5],[882,5]]},"203":{"position":[[33,5],[353,5],[574,5],[759,5]]},"205":{"position":[[33,5],[149,5],[272,5],[641,5],[806,5],[1119,5]]},"207":{"position":[[474,5],[535,5],[646,5],[741,5],[778,5],[1290,5],[1517,5],[1627,5],[1907,5],[1962,5]]},"209":{"position":[[171,5],[385,5],[406,5],[498,5],[574,5],[859,5],[900,5]]},"211":{"position":[[33,5],[126,5],[417,5],[524,5],[722,5],[885,5],[1301,5],[1425,5],[1749,5],[1835,5]]},"213":{"position":[[33,5],[149,5],[220,5],[325,5],[500,5],[619,5]]},"238":{"position":[[33,5],[233,5],[261,5],[332,5],[410,5],[488,5],[515,5],[588,5],[1004,5],[1047,5],[1090,5],[1130,5],[1279,5],[1513,5]]}}}],["construct",{"_index":1892,"t":{"139":{"position":[[3539,9]]}}}],["constructor",{"_index":1542,"t":{"129":{"position":[[746,11]]},"139":{"position":[[791,13]]},"207":{"position":[[308,13]]}}}],["contain",{"_index":2598,"t":{"199":{"position":[[953,7]]}}}],["container",{"_index":17,"t":{"73":{"position":[[182,9]]},"85":{"position":[[992,10]]},"95":{"position":[[323,9],[2301,9],[3215,9],[4256,9],[7434,9]]},"99":{"position":[[155,9],[539,9],[668,9],[844,10]]},"107":{"position":[[416,9]]},"133":{"position":[[1154,9]]},"137":{"position":[[164,9]]},"141":{"position":[[368,9]]},"147":{"position":[[164,9]]},"153":{"position":[[356,9]]},"193":{"position":[[333,9],[717,9],[846,9],[1022,10]]},"211":{"position":[[1384,9]]},"213":{"position":[[155,9],[752,9],[846,10],[868,9]]}}}],["container.addchild(ball",{"_index":892,"t":{"95":{"position":[[2587,25]]}}}],["container.addchild(base",{"_index":850,"t":{"95":{"position":[[814,25],[3559,25],[5261,25]]}}}],["container.addchild(bg",{"_index":1762,"t":{"137":{"position":[[1550,23]]}}}],["container.addchild(bgfront",{"_index":1955,"t":{"141":{"position":[[583,28]]},"153":{"position":[[901,27]]}}}],["container.addchild(bottom",{"_index":849,"t":{"95":{"position":[[786,27]]}}}],["container.addchild(bunny",{"_index":1077,"t":{"99":{"position":[[502,26]]},"193":{"position":[[680,26]]},"213":{"position":[[471,26]]}}}],["container.addchild(edge",{"_index":945,"t":{"95":{"position":[[5321,25]]}}}],["container.addchild(flag",{"_index":2110,"t":{"147":{"position":[[311,25]]}}}],["container.addchild(halfcircle",{"_index":971,"t":{"95":{"position":[[7935,31]]}}}],["container.addchild(light1",{"_index":1963,"t":{"141":{"position":[[850,27]]}}}],["container.addchild(light2",{"_index":1959,"t":{"141":{"position":[[717,27]]}}}],["container.addchild(maggot",{"_index":1734,"t":{"137":{"position":[[521,27]]}}}],["container.addchild(mask",{"_index":851,"t":{"95":{"position":[[840,25],[3585,25],[5347,25]]}}}],["container.addchild(panda",{"_index":1967,"t":{"141":{"position":[[972,26]]}}}],["container.addchild(rectangle",{"_index":970,"t":{"95":{"position":[[7904,30]]}}}],["container.addchild(roundingmask",{"_index":944,"t":{"95":{"position":[[5287,33]]}}}],["container.filterarea",{"_index":1699,"t":{"133":{"position":[[1188,20]]}}}],["container.filters",{"_index":1701,"t":{"133":{"position":[[1401,17]]},"137":{"position":[[1105,17]]}}}],["container.height",{"_index":1084,"t":{"99":{"position":[[751,16]]},"193":{"position":[[929,16]]}}}],["container.mask",{"_index":2192,"t":{"153":{"position":[[1162,14],[1239,17],[1259,14],[1292,14]]}}}],["container.pivot.x",{"_index":1081,"t":{"99":{"position":[[690,17]]},"193":{"position":[[868,17]]}}}],["container.pivot.y",{"_index":1083,"t":{"99":{"position":[[731,17]]},"193":{"position":[[909,17]]}}}],["container.position",{"_index":835,"t":{"95":{"position":[[357,18],[2335,18],[3249,18],[4290,18],[7468,18]]}}}],["container.rotation",{"_index":1088,"t":{"99":{"position":[[906,18]]},"193":{"position":[[1084,18]]}}}],["container.width",{"_index":1082,"t":{"99":{"position":[[710,15]]},"193":{"position":[[888,15]]}}}],["container.x",{"_index":1078,"t":{"99":{"position":[[563,11]]},"141":{"position":[[402,11]]},"153":{"position":[[390,11]]},"193":{"position":[[741,11]]},"213":{"position":[[1007,11]]}}}],["container.y",{"_index":1079,"t":{"99":{"position":[[599,11]]},"141":{"position":[[438,11]]},"153":{"position":[[426,11]]},"193":{"position":[[777,11]]},"213":{"position":[[1026,11]]}}}],["containspoint",{"_index":1862,"t":{"139":{"position":[[2356,13]]}}}],["containspoint(point",{"_index":1863,"t":{"139":{"position":[[2370,20]]}}}],["content",{"_index":1561,"t":{"131":{"position":[[292,8]]},"139":{"position":[[392,7],[525,7],[632,7],[823,7],[1073,7],[2094,11],[2455,7],[5362,7]]},"211":{"position":[[2160,7]]}}}],["content's",{"_index":1827,"t":{"139":{"position":[[1414,9],[1670,9],[3103,9]]}}}],["contentbounds",{"_index":1854,"t":{"139":{"position":[[2166,13]]}}}],["contentbounds.height",{"_index":1861,"t":{"139":{"position":[[2313,21]]}}}],["contentbounds.width",{"_index":1860,"t":{"139":{"position":[[2292,20]]}}}],["contentbounds.x",{"_index":1858,"t":{"139":{"position":[[2258,16]]}}}],["contentbounds.y",{"_index":1859,"t":{"139":{"position":[[2275,16]]}}}],["contents",{"_index":1791,"t":{"139":{"position":[[443,8]]}}}],["continue",{"_index":947,"t":{"95":{"position":[[6054,8],[6241,8]]}}}],["control",{"_index":1042,"t":{"97":{"position":[[1094,7]]},"105":{"position":[[825,7]]}}}],["cool",{"_index":2683,"t":{"205":{"position":[[1159,6]]}}}],["coordinate",{"_index":467,"t":{"83":{"position":[[854,10]]},"139":{"position":[[3354,10]]}}}],["coordinates",{"_index":1016,"t":{"95":{"position":[[9335,11]]},"99":{"position":[[678,11]]},"139":{"position":[[4879,11],[4959,14],[5342,11]]},"147":{"position":[[1052,12]]},"193":{"position":[[856,11]]}}}],["coordinates.text",{"_index":1942,"t":{"139":{"position":[[5226,16]]}}}],["coordinates.x",{"_index":1933,"t":{"139":{"position":[[4978,13]]}}}],["coordinates.y",{"_index":1934,"t":{"139":{"position":[[4999,13]]}}}],["coords",{"_index":1822,"t":{"139":{"position":[[1216,6],[1402,6]]}}}],["copymousedata",{"_index":1818,"t":{"139":{"position":[[1157,13]]}}}],["cordon",{"_index":199,"t":{"75":{"position":[[3497,7]]}}}],["corners",{"_index":870,"t":{"95":{"position":[[1665,7],[2041,7],[6592,7],[6995,7]]}}}],["corners.length",{"_index":880,"t":{"95":{"position":[[2075,14]]}}}],["corners[i",{"_index":882,"t":{"95":{"position":[[2130,9],[7067,9]]}}}],["correspond",{"_index":405,"t":{"81":{"position":[[1326,10]]}}}],["count",{"_index":1129,"t":{"107":{"position":[[386,5],[1390,5]]},"135":{"position":[[880,5],[914,5]]},"137":{"position":[[1853,5],[1887,5]]},"141":{"position":[[1064,5],[1631,5]]},"145":{"position":[[1410,5],[1831,5],[2318,5]]},"153":{"position":[[1190,5],[1746,5],[2108,5]]},"171":{"position":[[130,5],[565,5],[674,6],[739,6]]},"173":{"position":[[130,5],[626,5],[735,6],[800,6]]},"195":{"position":[[506,5],[540,5]]},"211":{"position":[[1654,5],[1796,5]]}}}],["courier",{"_index":2863,"t":{"238":{"position":[[1589,8]]}}}],["cover",{"_index":1907,"t":{"139":{"position":[[4011,5]]}}}],["covered",{"_index":1428,"t":{"123":{"position":[[1685,7]]}}}],["covers",{"_index":573,"t":{"85":{"position":[[1661,6]]},"127":{"position":[[244,6]]}}}],["crawl",{"_index":1775,"t":{"137":{"position":[[2272,5]]}}}],["create",{"_index":259,"t":{"77":{"position":[[257,6]]},"81":{"position":[[474,6],[577,6],[674,6]]},"83":{"position":[[402,6]]},"85":{"position":[[484,6]]},"87":{"position":[[868,6],[1545,6]]},"89":{"position":[[597,6]]},"91":{"position":[[181,6],[375,6]]},"93":{"position":[[632,6]]},"97":{"position":[[129,6],[351,6],[488,6],[1055,6],[1275,6],[1498,6]]},"99":{"position":[[223,6],[321,6],[871,6]]},"101":{"position":[[306,6]]},"103":{"position":[[550,6]]},"105":{"position":[[240,6],[786,6],[847,6],[1128,6],[1351,6]]},"107":{"position":[[400,6],[774,6]]},"109":{"position":[[149,6]]},"113":{"position":[[283,6],[462,6],[873,6],[1076,6],[1359,6]]},"115":{"position":[[465,6],[709,6]]},"117":{"position":[[152,6],[523,6]]},"121":{"position":[[129,6],[373,6]]},"123":{"position":[[658,6]]},"125":{"position":[[245,6]]},"129":{"position":[[129,6],[570,6]]},"133":{"position":[[197,6]]},"145":{"position":[[1284,6]]},"153":{"position":[[993,6]]},"183":{"position":[[245,6],[538,6],[809,6]]},"185":{"position":[[226,6],[465,6]]},"187":{"position":[[236,6],[505,6]]},"189":{"position":[[152,6]]},"191":{"position":[[333,6]]},"193":{"position":[[401,6],[499,6],[1049,6]]},"195":{"position":[[129,6],[240,6]]},"199":{"position":[[149,6],[1152,6],[1264,6]]},"203":{"position":[[710,6]]},"209":{"position":[[558,6]]},"211":{"position":[[204,6],[458,6],[854,6],[1276,6],[1326,6]]},"238":{"position":[[209,6],[1237,6]]}}}],["createbunny",{"_index":1281,"t":{"117":{"position":[[380,12]]}}}],["createbunny(x",{"_index":1282,"t":{"117":{"position":[[500,14]]}}}],["created",{"_index":2773,"t":{"211":{"position":[[510,7]]}}}],["creategradtexture",{"_index":2760,"t":{"209":{"position":[[290,19],[879,20]]}}}],["creates",{"_index":2538,"t":{"189":{"position":[[614,7]]}}}],["creating",{"_index":1669,"t":{"133":{"position":[[81,8]]}}}],["crop",{"_index":2838,"t":{"238":{"position":[[521,4],[601,5],[713,5],[919,5]]}}}],["cross",{"_index":1633,"t":{"131":{"position":[[2012,6]]},"165":{"position":[[1860,6]]}}}],["crosterian",{"_index":2625,"t":{"201":{"position":[[426,11],[963,13]]}}}],["css",{"_index":1225,"t":{"115":{"position":[[152,3]]}}}],["ctx",{"_index":2710,"t":{"207":{"position":[[747,3]]},"209":{"position":[[504,3]]}}}],["ctx.createlineargradient(0",{"_index":2713,"t":{"207":{"position":[[790,27]]},"209":{"position":[[586,27]]}}}],["ctx.fillrect(0",{"_index":2722,"t":{"207":{"position":[[993,15]]},"209":{"position":[[791,15]]}}}],["ctx.fillstyle",{"_index":2721,"t":{"207":{"position":[[972,13]]},"209":{"position":[[770,13]]}}}],["cubic",{"_index":409,"t":{"81":{"position":[[1434,5],[1648,5]]}}}],["cubicinterpolation(array",{"_index":428,"t":{"81":{"position":[[1949,25]]}}}],["cubicinterpolation(historyx",{"_index":415,"t":{"81":{"position":[[1489,28]]}}}],["cubicinterpolation(historyy",{"_index":417,"t":{"81":{"position":[[1558,28]]}}}],["current",{"_index":308,"t":{"77":{"position":[[1525,7]]}}}],["currenttargetname",{"_index":1364,"t":{"119":{"position":[[1207,17],[1364,18]]}}}],["currenttexture",{"_index":2772,"t":{"211":{"position":[[423,14]]}}}],["cursor",{"_index":1181,"t":{"111":{"position":[[518,6]]},"115":{"position":[[340,6]]},"117":{"position":[[760,6]]},"139":{"position":[[1912,6],[1923,8],[2067,6],[4306,6]]}}}],["cursor(value",{"_index":1848,"t":{"139":{"position":[[2020,13]]}}}],["curve",{"_index":408,"t":{"81":{"position":[[1423,5]]},"143":{"position":[[232,5],[773,5]]}}}],["custom",{"_index":1231,"t":{"115":{"position":[[333,6]]},"123":{"position":[[548,6]]}}}],["customuniform",{"_index":1537,"t":{"129":{"position":[[673,14]]}}}],["cyan",{"_index":2718,"t":{"207":{"position":[[903,8]]},"209":{"position":[[701,8]]}}}],["d",{"_index":1615,"t":{"131":{"position":[[1650,1],[1692,2],[2222,1]]},"165":{"position":[[1517,1],[1559,2],[2070,1]]}}}],["d.y",{"_index":1648,"t":{"131":{"position":[[2370,3]]},"165":{"position":[[2218,3]]}}}],["d8",{"_index":2832,"t":{"238":{"position":[[267,2]]}}}],["d8.isvertical(rotate",{"_index":2834,"t":{"238":{"position":[[342,21],[420,21]]}}}],["data",{"_index":1307,"t":{"117":{"position":[[1545,4]]},"129":{"position":[[665,5]]},"131":{"position":[[867,4]]}}}],["date.now",{"_index":696,"t":{"85":{"position":[[4895,11],[5018,11]]}}}],["days",{"_index":2525,"t":{"187":{"position":[[561,4]]}}}],["deacceleration",{"_index":178,"t":{"75":{"position":[[2786,14]]}}}],["default",{"_index":1038,"t":{"97":{"position":[[980,7]]},"133":{"position":[[521,7]]},"139":{"position":[[643,8],[1278,7]]},"207":{"position":[[501,7]]}}}],["defaulticon",{"_index":1227,"t":{"115":{"position":[[178,11],[397,12]]}}}],["deg",{"_index":470,"t":{"83":{"position":[[899,3]]}}}],["degrees",{"_index":1118,"t":{"105":{"position":[[956,7]]}}}],["delta",{"_index":246,"t":{"75":{"position":[[5463,6],[5516,6],[5565,6],[5614,6]]},"79":{"position":[[1030,6]]},"83":{"position":[[1341,5]]},"95":{"position":[[888,7],[926,5],[2801,7],[2839,5],[3633,7],[3671,5],[5395,7],[5433,5],[7989,7],[8027,5]]},"99":{"position":[[862,5],[935,6]]},"129":{"position":[[1012,6]]},"131":{"position":[[3030,5]]},"189":{"position":[[569,5],[679,6]]},"193":{"position":[[1040,5],[1113,6]]}}}],["demo",{"_index":2757,"t":{"209":{"position":[[41,4]]}}}],["demos",{"_index":7,"t":{"73":{"position":[[68,5]]}}}],["denominator",{"_index":1011,"t":{"95":{"position":[[8923,11],[9011,12],[9110,12],[9184,12]]}}}],["depending",{"_index":511,"t":{"83":{"position":[[2195,9],[2265,9]]}}}],["depends",{"_index":656,"t":{"85":{"position":[[3848,7]]}}}],["derived",{"_index":1852,"t":{"139":{"position":[[2077,7]]}}}],["description",{"_index":1944,"t":{"139":{"position":[[5295,11]]}}}],["description.position.set(110",{"_index":1946,"t":{"139":{"position":[[5557,29]]}}}],["designated",{"_index":1299,"t":{"117":{"position":[[1105,10]]}}}],["desktop",{"_index":1187,"t":{"111":{"position":[[611,8]]}}}],["desyrel",{"_index":2571,"t":{"197":{"position":[[329,10]]}}}],["detect",{"_index":667,"t":{"85":{"position":[[4196,6]]}}}],["detection",{"_index":41,"t":{"75":{"position":[[191,9]]}}}],["determine",{"_index":996,"t":{"95":{"position":[[8577,9]]}}}],["determined",{"_index":672,"t":{"85":{"position":[[4270,10]]}}}],["determines",{"_index":381,"t":{"81":{"position":[[314,10],[389,10]]}}}],["development/collision",{"_index":40,"t":{"75":{"position":[[169,21]]}}}],["devices",{"_index":1674,"t":{"133":{"position":[[446,7]]}}}],["diamond",{"_index":2847,"t":{"238":{"position":[[790,7]]}}}],["different",{"_index":71,"t":{"75":{"position":[[545,9]]},"85":{"position":[[491,9]]},"113":{"position":[[647,9],[666,9]]},"121":{"position":[[1123,9]]},"133":{"position":[[623,9]]},"139":{"position":[[212,9]]},"238":{"position":[[827,9]]}}}],["dir",{"_index":946,"t":{"95":{"position":[[6038,3]]}}}],["direction",{"_index":193,"t":{"75":{"position":[[3189,9],[4129,9],[4370,9]]},"95":{"position":[[6215,9]]},"97":{"position":[[1199,9]]},"105":{"position":[[863,9],[1052,9]]},"113":{"position":[[889,9],[998,9]]}}}],["disable",{"_index":1845,"t":{"139":{"position":[[1975,7]]},"203":{"position":[[290,7]]}}}],["disjoint",{"_index":1783,"t":{"139":{"position":[[153,8]]}}}],["displacementfilter",{"_index":1748,"t":{"137":{"position":[[987,18],[1125,21]]},"147":{"position":[[597,18],[808,21]]}}}],["displacementfilter.padding",{"_index":2115,"t":{"147":{"position":[[675,26]]}}}],["displacementfilter.scale.x",{"_index":1751,"t":{"137":{"position":[[1147,26]]},"147":{"position":[[830,26]]}}}],["displacementfilter.scale.y",{"_index":1753,"t":{"137":{"position":[[1181,26]]},"147":{"position":[[863,26]]}}}],["displacementsprite",{"_index":1746,"t":{"137":{"position":[[887,18]]},"147":{"position":[[371,18]]}}}],["displacementsprite.anchor.set(0.5",{"_index":1754,"t":{"137":{"position":[[1215,35]]}}}],["displacementsprite.position",{"_index":2116,"t":{"147":{"position":[[708,27]]}}}],["displacementsprite.position.set(eventdata.data.global.x",{"_index":1767,"t":{"137":{"position":[[1706,55]]}}}],["displacementsprite.texture.basetexture.wrapmode",{"_index":2114,"t":{"147":{"position":[[517,47]]}}}],["displacementsprite.width",{"_index":2132,"t":{"147":{"position":[[1201,25]]}}}],["displacementsprite.x",{"_index":2127,"t":{"147":{"position":[[1065,23],[1177,21],[1229,20]]}}}],["dist(p",{"_index":1609,"t":{"131":{"position":[[1545,6],[1584,6],[1623,6],[2226,8]]},"165":{"position":[[1412,6],[1451,6],[1490,6],[2074,8]]}}}],["dist(p+eps.xxy).x",{"_index":1613,"t":{"131":{"position":[[1603,17]]},"165":{"position":[[1470,17]]}}}],["dist(p+eps.xyx).x",{"_index":1611,"t":{"131":{"position":[[1564,17]]},"165":{"position":[[1431,17]]}}}],["dist(p+eps.yxx).x",{"_index":1608,"t":{"131":{"position":[[1525,17]]},"165":{"position":[[1392,17]]}}}],["dist(vec3",{"_index":1587,"t":{"131":{"position":[[1216,9]]},"165":{"position":[[1135,9]]}}}],["distance",{"_index":105,"t":{"75":{"position":[[1146,8],[1328,9],[1353,9],[1775,8]]},"83":{"position":[[940,8],[1000,9],[1035,9]]},"131":{"position":[[1059,8],[2270,8]]},"163":{"position":[[2160,8],[2187,8]]},"165":{"position":[[978,8],[2118,8]]}}}],["distancebetweentwopoints",{"_index":229,"t":{"75":{"position":[[4621,25]]}}}],["distancebetweentwopoints(p1",{"_index":125,"t":{"75":{"position":[[1818,28]]}}}],["distancecenter",{"_index":503,"t":{"83":{"position":[[1932,14],[2405,14]]}}}],["distances",{"_index":1586,"t":{"131":{"position":[[1200,10]]},"165":{"position":[[1119,10]]}}}],["distancescale",{"_index":505,"t":{"83":{"position":[[2009,13],[2079,13],[2336,13],[2367,13]]}}}],["distmouseredsquare",{"_index":228,"t":{"75":{"position":[[4600,18],[4705,18]]}}}],["document.body.append(a",{"_index":333,"t":{"79":{"position":[[418,24]]}}}],["document.body.appendchild(app.view",{"_index":51,"t":{"75":{"position":[[285,36]]},"77":{"position":[[89,36]]},"79":{"position":[[114,36]]},"81":{"position":[[112,36]]},"83":{"position":[[89,36]]},"85":{"position":[[112,36]]},"87":{"position":[[112,36]]},"89":{"position":[[112,36]]},"91":{"position":[[112,36]]},"93":{"position":[[112,36]]},"95":{"position":[[112,36]]},"97":{"position":[[89,36]]},"99":{"position":[[112,36]]},"101":{"position":[[112,36]]},"103":{"position":[[112,36]]},"105":{"position":[[89,36]]},"107":{"position":[[89,36]]},"109":{"position":[[109,36]]},"111":{"position":[[112,36]]},"113":{"position":[[89,36]]},"115":{"position":[[112,36]]},"117":{"position":[[112,36]]},"119":{"position":[[188,36]]},"121":{"position":[[89,36]]},"123":{"position":[[104,36]]},"125":{"position":[[205,36]]},"127":{"position":[[112,36]]},"129":{"position":[[89,36]]},"131":{"position":[[384,36]]},"133":{"position":[[157,36]]},"135":{"position":[[89,36]]},"137":{"position":[[89,36]]},"139":{"position":[[327,36]]},"141":{"position":[[89,36]]},"143":{"position":[[106,36]]},"145":{"position":[[106,36]]},"147":{"position":[[89,36]]},"149":{"position":[[89,36]]},"151":{"position":[[138,36]]},"153":{"position":[[106,36]]},"155":{"position":[[89,36]]},"157":{"position":[[89,36]]},"159":{"position":[[89,36]]},"161":{"position":[[89,36]]},"163":{"position":[[102,36]]},"165":{"position":[[89,36]]},"167":{"position":[[89,36]]},"169":{"position":[[89,36]]},"171":{"position":[[89,36]]},"173":{"position":[[89,36]]},"175":{"position":[[89,36]]},"177":{"position":[[89,36]]},"179":{"position":[[89,36]]},"181":{"position":[[89,36]]},"183":{"position":[[107,36]]},"185":{"position":[[107,36]]},"187":{"position":[[112,36]]},"189":{"position":[[112,36]]},"191":{"position":[[112,36]]},"195":{"position":[[89,36]]},"197":{"position":[[112,36]]},"199":{"position":[[109,36]]},"201":{"position":[[112,36]]},"203":{"position":[[112,36]]},"205":{"position":[[112,36]]},"207":{"position":[[1590,36]]},"209":{"position":[[244,36]]},"211":{"position":[[89,36]]},"213":{"position":[[112,36]]},"238":{"position":[[89,36]]}}}],["document.body.appendchild(canvas",{"_index":2550,"t":{"193":{"position":[[292,34]]}}}],["document.createelement('a",{"_index":332,"t":{"79":{"position":[[389,28]]}}}],["document.createelement('canvas",{"_index":2546,"t":{"193":{"position":[[124,33]]},"207":{"position":[[661,33]]},"209":{"position":[[421,33]]}}}],["document.createelement('script",{"_index":2646,"t":{"203":{"position":[[364,33]]}}}],["document.getelementsbytagname('script')[0",{"_index":2655,"t":{"203":{"position":[[584,43]]}}}],["document.location.protocol",{"_index":2648,"t":{"203":{"position":[[407,29]]}}}],["doesn't",{"_index":2162,"t":{"151":{"position":[[848,7]]}}}],["doesnt",{"_index":2846,"t":{"238":{"position":[[778,6]]}}}],["doing",{"_index":1551,"t":{"131":{"position":[[92,5]]}}}],["don't",{"_index":204,"t":{"75":{"position":[[3801,5]]},"95":{"position":[[8657,5]]},"139":{"position":[[464,5]]},"199":{"position":[[1101,5]]}}}],["done",{"_index":180,"t":{"75":{"position":[[2819,4]]},"85":{"position":[[3530,4]]}}}],["dont",{"_index":2697,"t":{"207":{"position":[[362,4],[600,4]]}}}],["dot",{"_index":1617,"t":{"131":{"position":[[1669,4]]},"165":{"position":[[1536,4]]}}}],["dotrice",{"_index":2621,"t":{"201":{"position":[[342,8],[845,8]]}}}],["down",{"_index":1836,"t":{"139":{"position":[[1656,4]]}}}],["downloaded",{"_index":741,"t":{"87":{"position":[[752,10],[1937,10]]}}}],["downstream",{"_index":1814,"t":{"139":{"position":[[1053,10]]}}}],["dragging",{"_index":290,"t":{"77":{"position":[[1193,8],[1286,10],[1896,8],[1963,8]]},"127":{"position":[[1646,8]]}}}],["dragtarget",{"_index":1300,"t":{"117":{"position":[[1207,10],[1405,12],[1701,10],[1789,12],[1868,10]]}}}],["dragtarget.alpha",{"_index":1318,"t":{"117":{"position":[[1846,16]]}}}],["dragtarget.parent.tolocal(event.global",{"_index":1305,"t":{"117":{"position":[[1420,39]]}}}],["dragtarget.position",{"_index":1306,"t":{"117":{"position":[[1466,21]]}}}],["draw",{"_index":1485,"t":{"127":{"position":[[509,4]]},"145":{"position":[[344,4],[665,4],[937,4],[1031,4],[1451,4]]},"151":{"position":[[793,4],[1417,4],[1647,4],[1816,4],[1951,4],[2088,4],[2225,4]]},"211":{"position":[[273,4]]}}}],["drawcircle(0",{"_index":257,"t":{"77":{"position":[[231,14]]},"125":{"position":[[393,14]]},"127":{"position":[[581,14]]}}}],["drawcircle(radius",{"_index":2139,"t":{"149":{"position":[[514,18]]}}}],["drawing",{"_index":300,"t":{"77":{"position":[[1433,7]]}}}],["drawn",{"_index":262,"t":{"77":{"position":[[297,5],[1506,5]]}}}],["drawrect(0",{"_index":1346,"t":{"119":{"position":[[688,12]]},"127":{"position":[[399,12]]}}}],["drawrect(100",{"_index":1353,"t":{"119":{"position":[[890,14]]}}}],["drawrect(starbutton3.x",{"_index":1419,"t":{"123":{"position":[[1324,24]]}}}],["drawrect(starbutton4.x",{"_index":1432,"t":{"123":{"position":[[1849,24]]}}}],["drawroundedrect(0",{"_index":2578,"t":{"199":{"position":[[262,19]]}}}],["drawstar(0",{"_index":1894,"t":{"139":{"position":[[3649,12]]}}}],["dropshadow",{"_index":596,"t":{"85":{"position":[[2285,11]]},"205":{"position":[[464,11],[866,11]]}}}],["dropshadowalpha",{"_index":2677,"t":{"205":{"position":[[884,16]]}}}],["dropshadowangle",{"_index":600,"t":{"85":{"position":[[2350,16]]},"205":{"position":[[529,16],[906,16]]}}}],["dropshadowblur",{"_index":599,"t":{"85":{"position":[[2331,15]]},"205":{"position":[[510,15],[928,15]]}}}],["dropshadowcolor",{"_index":597,"t":{"85":{"position":[[2303,16]]},"205":{"position":[[482,16],[947,16]]}}}],["dropshadowdistance",{"_index":602,"t":{"85":{"position":[[2380,19]]},"205":{"position":[[559,19],[976,19]]}}}],["dude",{"_index":1028,"t":{"97":{"position":[[576,4],[696,4],[769,4],[1216,4],[1305,4],[1383,4],[1867,4]]},"105":{"position":[[328,4],[511,4],[624,4],[1069,4],[1158,4],[1236,4],[1715,4]]},"113":{"position":[[488,4],[1244,4],[1749,4]]},"238":{"position":[[1285,4]]}}}],["dude.anchor.set(0.5",{"_index":1030,"t":{"97":{"position":[[644,21]]},"105":{"position":[[459,21]]},"113":{"position":[[622,21]]}}}],["dude.blendmode",{"_index":1040,"t":{"97":{"position":[[1013,14]]}}}],["dude.direction",{"_index":1044,"t":{"97":{"position":[[1111,14],[1888,14],[2047,14]]},"105":{"position":[[964,14],[1733,14],[1892,14]]},"113":{"position":[[910,14],[1827,14],[2020,14]]}}}],["dude.offset",{"_index":1215,"t":{"113":{"position":[[1186,11],[1806,12]]}}}],["dude.rotation",{"_index":1066,"t":{"97":{"position":[[2030,13]]},"105":{"position":[[1875,13]]},"113":{"position":[[2003,13]]}}}],["dude.scale.set(0.8",{"_index":1031,"t":{"97":{"position":[[701,18]]},"105":{"position":[[557,18]]},"113":{"position":[[682,18]]}}}],["dude.scale.x",{"_index":2859,"t":{"238":{"position":[[1352,12]]}}}],["dude.scale.y",{"_index":1220,"t":{"113":{"position":[[1768,12],[1922,14],[1988,14]]},"238":{"position":[[1372,12]]}}}],["dude.speed",{"_index":1049,"t":{"97":{"position":[[1324,10],[1969,11],[2018,11]]},"105":{"position":[[1177,10],[1814,11],[1863,11]]},"113":{"position":[[1142,10],[1908,11],[1974,11]]}}}],["dude.texture.rotate",{"_index":2862,"t":{"238":{"position":[[1550,24]]}}}],["dude.tint",{"_index":1113,"t":{"105":{"position":[[745,9]]},"113":{"position":[[832,9]]}}}],["dude.turningspeed",{"_index":1047,"t":{"97":{"position":[[1231,17],[1906,17]]},"105":{"position":[[1084,17],[1751,17]]},"113":{"position":[[1032,17],[1845,17]]}}}],["dude.x",{"_index":1035,"t":{"97":{"position":[[804,6],[1932,6],[2125,7],[2151,6],[2189,7],[2234,6]]},"105":{"position":[[658,6],[1777,6],[1970,7],[1996,6],[2034,7],[2079,6]]},"113":{"position":[[745,6],[1871,6],[2069,7],[2095,6],[2133,7],[2178,6]]},"238":{"position":[[1411,6],[1665,7]]}}}],["dude.y",{"_index":1036,"t":{"97":{"position":[[859,6],[1981,6],[2267,7],[2293,6],[2332,7],[2378,6]]},"105":{"position":[[701,6],[1826,6],[2112,7],[2138,6],[2177,7],[2223,6]]},"113":{"position":[[788,6],[1937,6],[2211,7],[2237,6],[2276,7],[2322,6]]},"238":{"position":[[1447,6],[1682,6]]}}}],["dudearray",{"_index":1023,"t":{"97":{"position":[[407,9],[1397,9]]}}}],["dudearray.length",{"_index":1062,"t":{"97":{"position":[[1836,17]]}}}],["dudearray.push(dude",{"_index":1053,"t":{"97":{"position":[[1445,21]]}}}],["dudearray[i",{"_index":1063,"t":{"97":{"position":[[1874,13]]}}}],["dudebounds",{"_index":1058,"t":{"97":{"position":[[1578,10]]},"105":{"position":[[1431,10]]},"113":{"position":[[1445,10]]}}}],["dudebounds.height",{"_index":1073,"t":{"97":{"position":[[2303,18],[2357,18],[2388,18]]},"105":{"position":[[2148,18],[2202,18],[2233,18]]},"113":{"position":[[2247,18],[2301,18],[2332,18]]}}}],["dudebounds.width",{"_index":1071,"t":{"97":{"position":[[2161,17],[2214,17],[2244,17]]},"105":{"position":[[2006,17],[2059,17],[2089,17]]},"113":{"position":[[2105,17],[2158,17],[2188,17]]}}}],["dudebounds.x",{"_index":1070,"t":{"97":{"position":[[2135,13],[2199,12]]},"105":{"position":[[1980,13],[2044,12]]},"113":{"position":[[2079,13],[2143,12]]}}}],["dudebounds.y",{"_index":1072,"t":{"97":{"position":[[2277,13],[2342,12]]},"105":{"position":[[2122,13],[2187,12]]},"113":{"position":[[2221,13],[2286,12]]}}}],["dudeboundspadding",{"_index":1057,"t":{"97":{"position":[[1547,17],[1612,18],[1632,18],[1670,17],[1713,17]]},"105":{"position":[[1400,17],[1464,18],[1484,18],[1522,17],[1565,17]]},"113":{"position":[[1414,17],[1479,18],[1499,18],[1537,17],[1580,17]]}}}],["dudes",{"_index":1022,"t":{"97":{"position":[[395,5],[1535,5],[1785,5],[2089,5]]},"105":{"position":[[1388,5],[1635,5],[1934,5]]}}}],["dxcenter",{"_index":501,"t":{"83":{"position":[[1803,8],[1970,8],[2493,9]]}}}],["dycenter",{"_index":502,"t":{"83":{"position":[[1867,8],[1981,8],[1992,10]]}}}],["dynamic",{"_index":2770,"t":{"211":{"position":[[240,7]]}}}],["dynamically",{"_index":2542,"t":{"191":{"position":[[781,11]]}}}],["e",{"_index":1475,"t":{"125":{"position":[[718,3]]},"139":{"position":[[1828,3],[4400,3],[4584,3],[5103,3]]}}}],["e.currenttarget.name",{"_index":1365,"t":{"119":{"position":[[1227,21]]}}}],["e.global.x",{"_index":1938,"t":{"139":{"position":[[5127,14]]}}}],["e.global.y",{"_index":1939,"t":{"139":{"position":[[5148,12]]}}}],["e.screen.x",{"_index":1940,"t":{"139":{"position":[[5184,14]]}}}],["e.screen.y",{"_index":1941,"t":{"139":{"position":[[5205,12]]}}}],["e.target.name",{"_index":1363,"t":{"119":{"position":[[1186,14]]}}}],["e.type",{"_index":1361,"t":{"119":{"position":[[1159,7]]}}}],["each",{"_index":238,"t":{"75":{"position":[[5043,4]]},"95":{"position":[[6066,4],[8414,4]]},"119":{"position":[[394,4]]},"163":{"position":[[1624,4]]},"211":{"position":[[1739,4]]}}}],["easier",{"_index":1294,"t":{"117":{"position":[[937,6]]},"213":{"position":[[962,6]]}}}],["easily",{"_index":1050,"t":{"97":{"position":[[1423,6]]},"105":{"position":[[1279,6]]},"113":{"position":[[1288,6]]}}}],["easing",{"_index":482,"t":{"83":{"position":[[1218,7],[1259,6]]},"85":{"position":[[4722,7],[4834,7]]}}}],["easy",{"_index":2607,"t":{"199":{"position":[[1323,5]]}}}],["edge",{"_index":904,"t":{"95":{"position":[[3027,5],[4820,4],[4889,4]]}}}],["edge.drawroundedrect(0",{"_index":933,"t":{"95":{"position":[[4956,23]]}}}],["edge.endfill",{"_index":934,"t":{"95":{"position":[[5007,15]]}}}],["edge.linestyle(linesize",{"_index":932,"t":{"95":{"position":[[4917,24]]}}}],["edge.mask",{"_index":943,"t":{"95":{"position":[[5243,9]]}}}],["edges",{"_index":413,"t":{"81":{"position":[[1471,6]]},"95":{"position":[[4167,6],[5163,6]]},"163":{"position":[[1196,5],[3528,5]]}}}],["effect",{"_index":2313,"t":{"163":{"position":[[2721,7],[3354,6]]}}}],["egg",{"_index":794,"t":{"89":{"position":[[832,3]]}}}],["egg.anchor.set(0.5",{"_index":796,"t":{"89":{"position":[[874,20]]}}}],["egg.x",{"_index":797,"t":{"89":{"position":[[895,5]]}}}],["egg.y",{"_index":799,"t":{"89":{"position":[[928,5]]}}}],["egghead",{"_index":734,"t":{"87":{"position":[[382,10]]},"89":{"position":[[439,12],[487,8]]},"93":{"position":[[404,12],[1094,9]]}}}],["egghead.png",{"_index":1125,"t":{"107":{"position":[[318,14]]}}}],["elements",{"_index":2828,"t":{"213":{"position":[[981,8]]}}}],["ellipse",{"_index":2167,"t":{"151":{"position":[[1262,7]]}}}],["embedded",{"_index":1572,"t":{"131":{"position":[[834,8]]}}}],["empty",{"_index":1130,"t":{"107":{"position":[[410,5]]}}}],["enable",{"_index":1284,"t":{"117":{"position":[[599,6]]},"119":{"position":[[965,6]]},"125":{"position":[[496,6]]},"199":{"position":[[508,6]]}}}],["enabled",{"_index":1968,"t":{"141":{"position":[[1079,7],[1130,7],[1140,9],[1170,7]]},"203":{"position":[[678,7]]}}}],["end",{"_index":871,"t":{"95":{"position":[[1835,3]]}}}],["endfill",{"_index":1347,"t":{"119":{"position":[[714,12],[920,12]]},"123":{"position":[[1373,11],[1898,11]]},"125":{"position":[[414,12]]},"149":{"position":[[572,11]]},"199":{"position":[[299,10]]}}}],["enough",{"_index":763,"t":{"87":{"position":[[1330,6]]}}}],["eps",{"_index":1605,"t":{"131":{"position":[[1475,3]]},"165":{"position":[[1342,3]]}}}],["eps.xxy).x",{"_index":1614,"t":{"131":{"position":[[1630,10]]},"165":{"position":[[1497,10]]}}}],["eps.xyx).x",{"_index":1612,"t":{"131":{"position":[[1591,11]]},"165":{"position":[[1458,11]]}}}],["eps.yxx).x",{"_index":1610,"t":{"131":{"position":[[1552,11]]},"165":{"position":[[1419,11]]}}}],["equivalent",{"_index":1116,"t":{"105":{"position":[[934,10]]}}}],["error('the",{"_index":1850,"t":{"139":{"position":[[2046,10]]}}}],["eslint",{"_index":1844,"t":{"139":{"position":[[1968,6]]},"203":{"position":[[283,6],[671,6]]}}}],["etc",{"_index":2530,"t":{"187":{"position":[[754,3]]}}}],["even",{"_index":1426,"t":{"123":{"position":[[1669,4]]}}}],["event",{"_index":168,"t":{"75":{"position":[[2637,7]]},"81":{"position":[[948,7]]},"119":{"position":[[1256,5],[1326,5]]},"133":{"position":[[1523,7]]},"139":{"position":[[1019,5]]},"149":{"position":[[1008,7]]},"199":{"position":[[673,5],[922,5]]}}}],["event.data",{"_index":1314,"t":{"117":{"position":[[1671,11]]}}}],["event.global.x",{"_index":170,"t":{"75":{"position":[[2666,15]]},"81":{"position":[[1028,15]]},"149":{"position":[[1040,14]]}}}],["event.global.y",{"_index":172,"t":{"75":{"position":[[2698,15]]},"81":{"position":[[1062,15]]},"149":{"position":[[1093,14]]}}}],["eventboundary",{"_index":1799,"t":{"139":{"position":[[689,14]]}}}],["eventdata.data.global.y",{"_index":1768,"t":{"137":{"position":[[1768,25]]}}}],["events",{"_index":1190,"t":{"111":{"position":[[695,7]]},"117":{"position":[[686,6],[981,6],[1027,6]]},"119":{"position":[[67,6],[88,6],[384,6]]},"121":{"position":[[1060,6],[1103,6],[1143,7],[1332,6],[1524,6]]},"139":{"position":[[136,6],[600,6],[1046,6],[1649,6]]}}}],["everywhere",{"_index":1356,"t":{"119":{"position":[[986,11]]},"139":{"position":[[4067,11]]}}}],["exact",{"_index":1584,"t":{"131":{"position":[[1168,5]]},"165":{"position":[[1087,5]]}}}],["example",{"_index":530,"t":{"85":{"position":[[444,8]]},"87":{"position":[[185,7]]},"95":{"position":[[5039,7],[5082,7]]},"97":{"position":[[944,8]]},"119":{"position":[[41,7]]},"125":{"position":[[46,8]]},"131":{"position":[[220,7]]},"139":{"position":[[73,7]]},"163":{"position":[[1678,8]]},"193":{"position":[[41,7]]},"199":{"position":[[755,8]]}}}],["examples",{"_index":2,"t":{"73":{"position":[[22,8],[160,8]]},"95":{"position":[[8715,8]]}}}],["except",{"_index":939,"t":{"95":{"position":[[5096,6]]}}}],["exception",{"_index":2845,"t":{"238":{"position":[[760,9]]}}}],["explosion",{"_index":2506,"t":{"185":{"position":[[475,9],[506,9]]}}}],["explosion.anchor.set(0.5",{"_index":2510,"t":{"185":{"position":[[659,26]]}}}],["explosion.gotoandplay(math.random",{"_index":2513,"t":{"185":{"position":[[781,35]]}}}],["explosion.rotation",{"_index":2511,"t":{"185":{"position":[[686,18]]}}}],["explosion.scale.set(0.75",{"_index":2512,"t":{"185":{"position":[[732,24]]}}}],["explosion.x",{"_index":2508,"t":{"185":{"position":[[562,11]]}}}],["explosion.y",{"_index":2509,"t":{"185":{"position":[[610,11]]}}}],["explosiontextures",{"_index":2502,"t":{"185":{"position":[[270,17]]}}}],["explosiontextures.push(texture",{"_index":2505,"t":{"185":{"position":[[400,32]]}}}],["extends",{"_index":1803,"t":{"139":{"position":[[762,7]]},"207":{"position":[[284,7]]}}}],["extra",{"_index":640,"t":{"85":{"position":[[3282,5],[3362,6],[3399,5]]},"97":{"position":[[1067,5]]},"105":{"position":[[798,5]]}}}],["extras",{"_index":1779,"t":{"139":{"position":[[56,8]]},"151":{"position":[[56,8]]}}}],["factor",{"_index":427,"t":{"81":{"position":[[1848,7],[1872,6]]}}}],["fake",{"_index":2743,"t":{"207":{"position":[[1713,4]]}}}],["false",{"_index":291,"t":{"77":{"position":[[1204,6],[1376,6],[1404,6],[1742,6],[1770,6],[1974,6]]},"85":{"position":[[3118,6],[3581,6]]},"95":{"position":[[4052,7],[8638,5],[8908,6],[9040,6],[9290,6]]},"115":{"position":[[1955,6],[2208,6]]},"121":{"position":[[2050,6],[2303,6]]},"131":{"position":[[2751,6]]},"137":{"position":[[1370,6]]},"159":{"position":[[472,6],[591,6]]},"165":{"position":[[2647,6]]},"183":{"position":[[79,6]]},"185":{"position":[[79,6]]},"211":{"position":[[2251,6]]}}}],["families",{"_index":2639,"t":{"203":{"position":[[229,9]]}}}],["far",{"_index":226,"t":{"75":{"position":[[4544,3]]},"83":{"position":[[2282,3]]}}}],["fast",{"_index":55,"t":{"75":{"position":[[365,4]]},"83":{"position":[[2212,4]]},"183":{"position":[[818,4],[844,4]]}}}],["fast.anchor.set(0.5",{"_index":2494,"t":{"183":{"position":[[886,21]]}}}],["fast.play",{"_index":2499,"t":{"183":{"position":[[1011,12]]}}}],["fast.scale.set(scaling",{"_index":2495,"t":{"183":{"position":[[908,24]]}}}],["fast.width",{"_index":2497,"t":{"183":{"position":[[962,11]]}}}],["fast.x",{"_index":2496,"t":{"183":{"position":[[933,6]]}}}],["fast.y",{"_index":2498,"t":{"183":{"position":[[979,6]]}}}],["featured",{"_index":14,"t":{"73":{"position":[[151,8]]}}}],["feedback",{"_index":1507,"t":{"127":{"position":[[1655,8]]},"139":{"position":[[4360,8]]}}}],["fetch('https://pixijs.com/assets/pixi",{"_index":1526,"t":{"129":{"position":[[396,37]]}}}],["ffffff",{"_index":590,"t":{"85":{"position":[[2210,11]]},"123":{"position":[[2367,9]]},"205":{"position":[[389,11],[1006,12]]}}}],["figure",{"_index":219,"t":{"75":{"position":[[4344,6],[4463,6]]}}}],["file",{"_index":1571,"t":{"131":{"position":[[823,4]]},"201":{"position":[[171,5]]}}}],["files",{"_index":778,"t":{"87":{"position":[[1919,5]]}}}],["fill",{"_index":363,"t":{"79":{"position":[[1098,5]]},"85":{"position":[[2204,5]]},"95":{"position":[[2032,4],[6986,4]]},"123":{"position":[[2361,5]]},"127":{"position":[[1277,5]]},"131":{"position":[[558,5]]},"139":{"position":[[4804,5],[5534,5]]},"141":{"position":[[1327,5]]},"145":{"position":[[254,4],[564,4]]},"153":{"position":[[1447,5]]},"203":{"position":[[883,5]]},"205":{"position":[[383,5],[1000,5]]},"238":{"position":[[1622,5]]}}}],["filter",{"_index":650,"t":{"85":{"position":[[3745,6]]},"129":{"position":[[504,7],[585,7],[634,6],[739,6],[840,6],[868,9],[937,6]]},"131":{"position":[[504,6],[2611,7],[2771,6],[2778,6],[2915,9]]},"133":{"position":[[1327,6],[1421,9]]},"141":{"position":[[315,6],[1050,9],[1180,8],[1664,7]]}}}],["filter.uniforms.customuniform",{"_index":1544,"t":{"129":{"position":[[793,29],[972,29]]}}}],["filter.uniforms.mouse.copyfrom(event.global",{"_index":1702,"t":{"133":{"position":[[1536,45]]}}}],["filter.uniforms.time",{"_index":1667,"t":{"131":{"position":[[2983,20]]}}}],["filtered",{"_index":2314,"t":{"163":{"position":[[2741,8]]}}}],["filters",{"_index":1670,"t":{"133":{"position":[[90,7]]},"141":{"position":[[1250,7]]}}}],["filters/bg_depth_blur.jpg",{"_index":1705,"t":{"135":{"position":[[186,28]]}}}],["filters/depth_blur_dudes.jpg",{"_index":1710,"t":{"135":{"position":[[368,31]]}}}],["filters/depth_blur_moby.jpg",{"_index":1716,"t":{"135":{"position":[[569,30]]}}}],["filters/displace.png",{"_index":1747,"t":{"137":{"position":[[957,23]]}}}],["filters/displacement_map_repeat.jpg",{"_index":2113,"t":{"147":{"position":[[441,38]]}}}],["filters/flag.png",{"_index":2109,"t":{"147":{"position":[[291,19]]}}}],["filters/ring.png",{"_index":1756,"t":{"137":{"position":[[1313,19]]}}}],["filters/shader.frag",{"_index":1527,"t":{"129":{"position":[[434,21]]}}}],["final",{"_index":2350,"t":{"163":{"position":[[4347,5]]}}}],["finally",{"_index":1033,"t":{"97":{"position":[[747,7],[1363,7]]},"105":{"position":[[603,7],[1216,7]]},"113":{"position":[[1224,7]]}}}],["find",{"_index":5,"t":{"73":{"position":[[50,4]]},"95":{"position":[[1328,4],[6134,4]]}}}],["finish",{"_index":1525,"t":{"129":{"position":[[377,6]]}}}],["first",{"_index":1543,"t":{"129":{"position":[[780,5]]},"139":{"position":[[1301,5],[5402,5]]},"163":{"position":[[998,5]]}}}],["fit",{"_index":557,"t":{"85":{"position":[[1331,3]]}}}],["fixed",{"_index":955,"t":{"95":{"position":[[7329,5]]}}}],["flag",{"_index":818,"t":{"93":{"position":[[577,4]]},"147":{"position":[[235,4]]}}}],["flag.filters",{"_index":2118,"t":{"147":{"position":[[793,12]]}}}],["flag.position",{"_index":2117,"t":{"147":{"position":[[738,14]]}}}],["flag.x",{"_index":2111,"t":{"147":{"position":[[337,6]]}}}],["flag.y",{"_index":2112,"t":{"147":{"position":[[351,6]]}}}],["flash",{"_index":2526,"t":{"187":{"position":[[569,6]]}}}],["flexibility",{"_index":2827,"t":{"213":{"position":[[937,11]]}}}],["flight",{"_index":477,"t":{"83":{"position":[[1057,6]]}}}],["float",{"_index":1582,"t":{"131":{"position":[[1044,5],[1231,5],[1283,5],[1338,5],[1875,5],[2144,5]]},"133":{"position":[[683,6],[796,5]]},"157":{"position":[[543,6],[837,6]]},"159":{"position":[[1023,6],[1329,6]]},"161":{"position":[[935,6],[1229,6]]},"163":{"position":[[585,6],[1072,6],[1106,5],[1998,6],[2032,5],[2054,5],[2181,5],[2802,6],[2836,5],[2888,5],[3405,6],[3439,5],[3464,5],[4417,6]]},"165":{"position":[[534,6],[904,6],[963,5],[1150,5],[1202,5],[1723,5],[1992,5]]},"167":{"position":[[484,6],[778,6]]},"169":{"position":[[418,6],[712,6],[967,6],[1261,6]]},"175":{"position":[[280,6],[521,6]]},"177":{"position":[[502,6],[804,6]]},"179":{"position":[[608,6],[984,6]]},"181":{"position":[[515,6],[830,6],[893,5]]}}}],["float32array(geometry.instancecount",{"_index":2244,"t":{"159":{"position":[[350,35]]}}}],["floor(p.x)+floor(p.y",{"_index":1589,"t":{"131":{"position":[[1242,22]]},"165":{"position":[[1161,22]]}}}],["floor(uv*zoom",{"_index":2277,"t":{"163":{"position":[[1254,15]]}}}],["flower",{"_index":787,"t":{"89":{"position":[[657,6]]}}}],["flower.anchor.set(0.5",{"_index":789,"t":{"89":{"position":[[704,23]]}}}],["flower.x",{"_index":790,"t":{"89":{"position":[[728,8]]}}}],["flower.y",{"_index":792,"t":{"89":{"position":[[764,8]]}}}],["flowertop",{"_index":732,"t":{"87":{"position":[[270,12]]},"93":{"position":[[1106,13]]}}}],["flowertop.png",{"_index":1126,"t":{"107":{"position":[[333,16]]}}}],["focus",{"_index":2144,"t":{"149":{"position":[[830,5],[909,6]]}}}],["focus.height",{"_index":2150,"t":{"149":{"position":[[1110,12]]}}}],["focus.position.x",{"_index":2147,"t":{"149":{"position":[[1021,16]]}}}],["focus.position.y",{"_index":2149,"t":{"149":{"position":[[1074,16]]}}}],["focus.width",{"_index":2148,"t":{"149":{"position":[[1057,11]]}}}],["follow",{"_index":1466,"t":{"125":{"position":[[69,6],[657,6]]}}}],["font",{"_index":2614,"t":{"201":{"position":[[166,4]]},"203":{"position":[[320,4]]}}}],["font/desyrel.xml').then",{"_index":2564,"t":{"197":{"position":[[200,26]]}}}],["fontfamily",{"_index":361,"t":{"79":{"position":[[1076,11]]},"85":{"position":[[2128,11]]},"127":{"position":[[1294,11]]},"139":{"position":[[4768,11],[5512,11]]},"141":{"position":[[1272,11]]},"153":{"position":[[1392,11]]},"201":{"position":[[614,11],[720,11],[833,11],[951,11]]},"203":{"position":[[846,11]]},"205":{"position":[[307,11],[845,11]]},"238":{"position":[[1577,11]]}}}],["fontname",{"_index":1932,"t":{"139":{"position":[[4949,9]]},"197":{"position":[[319,9]]}}}],["fonts",{"_index":2568,"t":{"197":{"position":[[284,5]]},"203":{"position":[[169,5]]}}}],["fontsize",{"_index":584,"t":{"85":{"position":[[2149,9]]},"119":{"position":[[411,9],[517,9]]},"127":{"position":[[1316,9]]},"131":{"position":[[574,9]]},"139":{"position":[[4790,9],[5498,9]]},"141":{"position":[[1293,9]]},"153":{"position":[[1413,9]]},"197":{"position":[[340,9]]},"201":{"position":[[639,9],[742,9],[864,9],[977,9]]},"203":{"position":[[869,9]]},"205":{"position":[[328,9],[1038,9]]},"238":{"position":[[1604,9]]}}}],["fontstyle",{"_index":586,"t":{"85":{"position":[[2163,10]]},"205":{"position":[[342,10]]}}}],["fontweight",{"_index":588,"t":{"85":{"position":[[2184,11]]},"141":{"position":[[1307,11]]},"153":{"position":[[1427,11]]},"205":{"position":[[363,11],[1052,11]]}}}],["forced",{"_index":1677,"t":{"133":{"position":[[481,6]]}}}],["forces",{"_index":815,"t":{"93":{"position":[[486,6]]}}}],["foreach((event",{"_index":1838,"t":{"139":{"position":[[1776,17]]}}}],["forward",{"_index":1628,"t":{"131":{"position":[[1897,7],[1960,8],[2023,10]]},"165":{"position":[[1745,7],[1808,8],[1871,10]]}}}],["found",{"_index":949,"t":{"95":{"position":[[6269,5]]}}}],["fov",{"_index":445,"t":{"83":{"position":[[280,3],[1593,4],[1689,4]]},"131":{"position":[[1881,3]]},"165":{"position":[[1729,3]]}}}],["fov*forward",{"_index":1638,"t":{"131":{"position":[[2090,14]]},"165":{"position":[[1938,14]]}}}],["fragment",{"_index":1568,"t":{"131":{"position":[[748,8],[888,8],[2809,9]]},"133":{"position":[[491,8],[583,8]]}}}],["fragmentcombinesrc",{"_index":2352,"t":{"163":{"position":[[4376,18],[4880,19]]}}}],["fragmentgridsrc",{"_index":2271,"t":{"163":{"position":[[1034,15],[1526,16]]}}}],["fragmentnoisesrc",{"_index":2315,"t":{"163":{"position":[[2763,16],[3097,17]]}}}],["fragmentripplesrc",{"_index":2300,"t":{"163":{"position":[[1958,17],[2455,18]]}}}],["fragmentsrc",{"_index":2392,"t":{"165":{"position":[[815,11],[2731,12]]},"179":{"position":[[950,11],[1284,12]]},"181":{"position":[[796,11],[1159,12]]}}}],["fragmentwavesrc",{"_index":2327,"t":{"163":{"position":[[3367,15],[4104,16]]}}}],["frame",{"_index":657,"t":{"85":{"position":[[3859,5]]},"99":{"position":[[878,5]]},"107":{"position":[[800,5]]},"189":{"position":[[622,5]]},"193":{"position":[[1056,5]]},"238":{"position":[[496,5],[706,6],[912,6]]}}}],["framekey",{"_index":2477,"t":{"183":{"position":[[344,8]]}}}],["framename",{"_index":1138,"t":{"107":{"position":[[739,9]]}}}],["framentsource",{"_index":1535,"t":{"129":{"position":[[619,14]]}}}],["frames",{"_index":2516,"t":{"187":{"position":[[289,6]]}}}],["frames.push(pixi.texture.from(`rollsequence00${val}.png",{"_index":2522,"t":{"187":{"position":[[440,59]]}}}],["friend",{"_index":1283,"t":{"117":{"position":[[547,8]]}}}],["fruits",{"_index":2785,"t":{"211":{"position":[[891,6]]}}}],["fruits.length",{"_index":2799,"t":{"211":{"position":[[1466,16]]}}}],["fullscreen",{"_index":2610,"t":{"199":{"position":[[1389,10]]}}}],["fun",{"_index":1166,"t":{"109":{"position":[[493,4]]},"189":{"position":[[529,4]]}}}],["function",{"_index":73,"t":{"75":{"position":[[563,8],[953,8],[1809,8],[4528,8]]},"77":{"position":[[519,8],[1238,8],[1866,8],[1935,8]]},"79":{"position":[[276,8]]},"81":{"position":[[1717,8],[1825,8],[1940,8]]},"83":{"position":[[686,8],[1266,8]]},"85":{"position":[[453,8],[3128,8],[3155,8],[3544,8],[4568,9],[4673,8],[5497,8],[5567,8],[5661,8]]},"87":{"position":[[155,8],[648,8],[1242,8]]},"95":{"position":[[8742,8]]},"101":{"position":[[191,8],[206,8],[618,8]]},"107":{"position":[[617,8],[1160,8]]},"111":{"position":[[821,8]]},"115":{"position":[[1819,8],[1917,8],[2058,8],[2169,8]]},"117":{"position":[[491,8],[1373,8],[1492,8],[1763,8]]},"119":{"position":[[1124,8]]},"121":{"position":[[1914,8],[2012,8],[2153,8],[2264,8]]},"123":{"position":[[2964,8],[3009,8],[3060,8]]},"127":{"position":[[1528,8],[1693,8],[1877,8]]},"129":{"position":[[541,8]]},"131":{"position":[[1068,9],[2289,8],[2553,8]]},"137":{"position":[[1649,8]]},"155":{"position":[[564,8]]},"165":{"position":[[987,9],[2137,8]]},"171":{"position":[[774,8]]},"199":{"position":[[1073,8]]},"203":{"position":[[339,11],[689,8]]},"207":{"position":[[143,9]]},"209":{"position":[[281,8]]}}}],["functions",{"_index":990,"t":{"95":{"position":[[8485,9]]}}}],["funtion",{"_index":717,"t":{"85":{"position":[[5488,8]]}}}],["further",{"_index":35,"t":{"75":{"position":[[95,7],[3818,7]]}}}],["g",{"_index":2437,"t":{"171":{"position":[[445,1]]},"177":{"position":[[371,2],[391,2],[412,2]]},"179":{"position":[[371,2],[391,2],[412,2]]}}}],["g.beginfill(0xff0022",{"_index":2455,"t":{"171":{"position":[[995,22]]}}}],["g.clear",{"_index":2449,"t":{"171":{"position":[[800,10]]}}}],["g.drawcircle(points[i].x",{"_index":2456,"t":{"171":{"position":[[1018,25]]}}}],["g.endfill",{"_index":2457,"t":{"171":{"position":[[1062,12]]}}}],["g.linestyle(2",{"_index":2450,"t":{"171":{"position":[[811,14]]}}}],["g.lineto(points[i].x",{"_index":2454,"t":{"171":{"position":[[915,21]]}}}],["g.moveto(points[0].x",{"_index":2452,"t":{"171":{"position":[[837,21]]}}}],["g.x",{"_index":2438,"t":{"171":{"position":[[470,3]]}}}],["g.y",{"_index":2439,"t":{"171":{"position":[[485,3]]}}}],["game",{"_index":39,"t":{"75":{"position":[[164,4]]},"87":{"position":[[349,5],[605,5],[1388,4]]}}}],["generate",{"_index":2272,"t":{"163":{"position":[[1132,10],[2106,10]]}}}],["generated",{"_index":1026,"t":{"97":{"position":[[546,9]]},"105":{"position":[[298,9]]},"131":{"position":[[110,9],[282,9]]}}}],["generates",{"_index":2270,"t":{"163":{"position":[[1010,9],[2729,9]]}}}],["generatespinner1",{"_index":834,"t":{"95":{"position":[[282,16]]}}}],["generatespinner1(new",{"_index":974,"t":{"95":{"position":[[8114,20]]}}}],["generatespinner2",{"_index":886,"t":{"95":{"position":[[2260,16]]}}}],["generatespinner2(new",{"_index":976,"t":{"95":{"position":[[8156,20]]}}}],["generatespinner3",{"_index":906,"t":{"95":{"position":[[3174,16]]}}}],["generatespinner3(new",{"_index":978,"t":{"95":{"position":[[8199,20]]}}}],["generatespinner4",{"_index":917,"t":{"95":{"position":[[4215,16]]}}}],["generatespinner4(new",{"_index":980,"t":{"95":{"position":[[8242,20]]}}}],["generatespinner5",{"_index":958,"t":{"95":{"position":[[7393,16]]}}}],["generatespinner5(new",{"_index":982,"t":{"95":{"position":[[8285,20]]}}}],["geometry",{"_index":2209,"t":{"157":{"position":[[132,8]]},"159":{"position":[[132,8]]},"161":{"position":[[132,8]]},"163":{"position":[[148,9],[164,8]]},"165":{"position":[[135,9],[151,8]]},"167":{"position":[[132,8]]},"169":{"position":[[132,8]]},"175":{"position":[[132,8]]},"177":{"position":[[132,8]]},"179":{"position":[[132,8]]},"181":{"position":[[132,8]]}}}],["geometry.addattribute",{"_index":2245,"t":{"159":{"position":[[418,22],[540,22]]}}}],["geometry.instancecount",{"_index":2240,"t":{"159":{"position":[[242,22],[694,23]]}}}],["geometry.instanced",{"_index":2239,"t":{"159":{"position":[[215,18]]}}}],["geometry2",{"_index":2259,"t":{"161":{"position":[[483,9],[870,12]]}}}],["geometry3",{"_index":2260,"t":{"161":{"position":[[827,9]]}}}],["gettangent(k",{"_index":426,"t":{"81":{"position":[[1834,13],[2077,14],[2115,12]]}}}],["give",{"_index":93,"t":{"75":{"position":[[908,4]]},"207":{"position":[[1266,4]]}}}],["given",{"_index":123,"t":{"75":{"position":[[1796,5]]}}}],["gives",{"_index":2826,"t":{"213":{"position":[[918,5]]}}}],["gl",{"_index":2734,"t":{"207":{"position":[[1298,2]]}}}],["gl.pixelstorei(gl.unpack_premultiply_alpha_webgl",{"_index":2736,"t":{"207":{"position":[[1315,49]]}}}],["gl.teximage2d(basetexture.target",{"_index":2738,"t":{"207":{"position":[[1396,33]]}}}],["gl_fragcolor",{"_index":1655,"t":{"131":{"position":[[2518,12]]},"133":{"position":[[926,12],[1051,12]]},"157":{"position":[[906,12]]},"159":{"position":[[1369,12]]},"161":{"position":[[1298,12]]},"163":{"position":[[1414,12],[2309,12],[2956,12],[3966,12],[4683,12]]},"165":{"position":[[2366,12]]},"167":{"position":[[853,12]]},"169":{"position":[[781,12],[1330,12]]},"175":{"position":[[542,12]]},"177":{"position":[[846,12]]},"179":{"position":[[1074,12]]},"181":{"position":[[919,12]]}}}],["gl_fragcolor.g",{"_index":2425,"t":{"169":{"position":[[1437,14]]}}}],["gl_fragcolor.r",{"_index":2422,"t":{"169":{"position":[[1373,14]]}}}],["gl_position",{"_index":2225,"t":{"157":{"position":[[712,11]]},"159":{"position":[[1206,11]]},"161":{"position":[[1104,11]]},"163":{"position":[[754,11]]},"165":{"position":[[703,11]]},"167":{"position":[[653,11]]},"169":{"position":[[587,11],[1136,11]]},"175":{"position":[[396,11]]},"177":{"position":[[679,11]]},"179":{"position":[[838,11]]},"181":{"position":[[684,11]]}}}],["global",{"_index":294,"t":{"77":{"position":[[1261,7]]},"139":{"position":[[1209,6],[1395,6],[4833,11],[5118,6],[5245,8]]}}}],["global}\\nscreen",{"_index":1943,"t":{"139":{"position":[[5254,18]]}}}],["gltexture",{"_index":2704,"t":{"207":{"position":[[461,10]]}}}],["gltexture.height",{"_index":2730,"t":{"207":{"position":[[1153,16]]}}}],["gltexture.width",{"_index":2729,"t":{"207":{"position":[[1128,15]]}}}],["gltextures",{"_index":2750,"t":{"207":{"position":[[1861,11]]}}}],["go",{"_index":777,"t":{"87":{"position":[[1903,2]]}}}],["goback",{"_index":767,"t":{"87":{"position":[[1604,6]]}}}],["goback.anchor.set(0.5",{"_index":769,"t":{"87":{"position":[[1656,23]]}}}],["goback.cursor",{"_index":774,"t":{"87":{"position":[[1804,13]]}}}],["goback.destroy",{"_index":776,"t":{"87":{"position":[[1869,17]]}}}],["goback.eventmode",{"_index":773,"t":{"87":{"position":[[1775,16]]}}}],["goback.on('pointertap",{"_index":775,"t":{"87":{"position":[[1831,23]]}}}],["goback.x",{"_index":770,"t":{"87":{"position":[[1680,8]]}}}],["goback.y",{"_index":771,"t":{"87":{"position":[[1713,8]]}}}],["going",{"_index":668,"t":{"85":{"position":[[4203,5]]},"147":{"position":[[1146,5]]}}}],["gonext",{"_index":748,"t":{"87":{"position":[[927,6]]}}}],["gonext.anchor.set(0.5",{"_index":750,"t":{"87":{"position":[[981,23]]}}}],["gonext.cursor",{"_index":755,"t":{"87":{"position":[[1129,13]]}}}],["gonext.destroy",{"_index":757,"t":{"87":{"position":[[1194,17]]}}}],["gonext.eventmode",{"_index":754,"t":{"87":{"position":[[1100,16]]}}}],["gonext.on('pointertap",{"_index":756,"t":{"87":{"position":[[1156,23]]}}}],["gonext.x",{"_index":751,"t":{"87":{"position":[[1005,8]]}}}],["gonext.y",{"_index":752,"t":{"87":{"position":[[1038,8]]}}}],["good",{"_index":1185,"t":{"111":{"position":[[590,5]]}}}],["google",{"_index":2636,"t":{"203":{"position":[[162,6],[219,7]]}}}],["gpu",{"_index":2707,"t":{"207":{"position":[[642,3]]}}}],["grab",{"_index":1295,"t":{"117":{"position":[[947,4]]}}}],["gradbasetexture",{"_index":2741,"t":{"207":{"position":[[1633,15]]}}}],["gradbasetexture.setsize(500",{"_index":2751,"t":{"207":{"position":[[1873,28]]}}}],["gradient",{"_index":592,"t":{"85":{"position":[[2237,8]]},"205":{"position":[[416,8]]},"207":{"position":[[78,8],[379,8],[1807,9]]},"209":{"position":[[60,8],[565,8]]}}}],["gradientresource",{"_index":2695,"t":{"207":{"position":[[267,16],[1676,20]]}}}],["gradtexture",{"_index":2752,"t":{"207":{"position":[[1913,11]]},"209":{"position":[[865,11]]}}}],["graph",{"_index":1784,"t":{"139":{"position":[[168,6],[458,5],[1686,6]]}}}],["graphics",{"_index":24,"t":{"73":{"position":[[239,8]]},"139":{"position":[[3558,8]]},"145":{"position":[[213,8]]},"151":{"position":[[181,8]]}}}],["graphics.beginfill(0x3500fa",{"_index":2189,"t":{"151":{"position":[[2326,28]]}}}],["graphics.beginfill(0x35cc5a",{"_index":2172,"t":{"151":{"position":[[1859,28]]}}}],["graphics.beginfill(0x55335a",{"_index":2178,"t":{"151":{"position":[[2133,28]]}}}],["graphics.beginfill(0x650a5a",{"_index":2153,"t":{"151":{"position":[[377,29],[1021,28],[1708,28]]}}}],["graphics.beginfill(0xaa4f08",{"_index":2158,"t":{"151":{"position":[[669,29],[1321,28]]}}}],["graphics.beginfill(0xc34288",{"_index":2156,"t":{"151":{"position":[[530,29],[1171,28]]}}}],["graphics.beginfill(0xde3249",{"_index":2151,"t":{"151":{"position":[[226,29],[872,28]]}}}],["graphics.beginfill(0xff3300",{"_index":2060,"t":{"145":{"position":[[274,29]]},"151":{"position":[[1430,29]]}}}],["graphics.beginfill(0xff700b",{"_index":2071,"t":{"145":{"position":[[629,28]]}}}],["graphics.beginfill(0xffcc5a",{"_index":2175,"t":{"151":{"position":[[1996,28]]}}}],["graphics.beginfill(0xffff0b",{"_index":2086,"t":{"145":{"position":[[1068,28]]}}}],["graphics.beziercurveto",{"_index":2100,"t":{"145":{"position":[[1651,23]]}}}],["graphics.closepath",{"_index":2069,"t":{"145":{"position":[[513,21],[892,21]]},"151":{"position":[[1602,21]]}}}],["graphics.drawcircle(100",{"_index":2164,"t":{"151":{"position":[[905,24]]}}}],["graphics.drawcircle(250",{"_index":2165,"t":{"151":{"position":[[1054,24]]}}}],["graphics.drawcircle(400",{"_index":2166,"t":{"151":{"position":[[1204,24]]}}}],["graphics.drawcircle(470",{"_index":2087,"t":{"145":{"position":[[1103,24]]}}}],["graphics.drawellipse(600",{"_index":2168,"t":{"151":{"position":[[1354,25]]}}}],["graphics.drawpolygon(path",{"_index":2190,"t":{"151":{"position":[[2359,27]]}}}],["graphics.drawrect(200",{"_index":2154,"t":{"151":{"position":[[407,22]]}}}],["graphics.drawrect(350",{"_index":2157,"t":{"151":{"position":[[560,22]]}}}],["graphics.drawrect(50",{"_index":2083,"t":{"145":{"position":[[990,21]]},"151":{"position":[[256,21]]}}}],["graphics.drawrect(530",{"_index":2159,"t":{"151":{"position":[[699,22]]}}}],["graphics.drawroundedrect(50",{"_index":2171,"t":{"151":{"position":[[1744,28]]}}}],["graphics.drawstar(280",{"_index":2176,"t":{"151":{"position":[[2029,22]]}}}],["graphics.drawstar(360",{"_index":2173,"t":{"151":{"position":[[1892,22]]}}}],["graphics.drawstar(470",{"_index":2179,"t":{"151":{"position":[[2166,22]]}}}],["graphics.endfill",{"_index":2070,"t":{"145":{"position":[[535,19],[914,19],[1139,19]]},"151":{"position":[[293,19],[445,19],[598,19],[737,19],[940,19],[1089,19],[1239,19],[1394,19],[1624,19],[1793,19],[1928,19],[2065,19],[2202,19],[2387,19]]}}}],["graphics.linestyle(0",{"_index":2085,"t":{"145":{"position":[[1045,22]]},"151":{"position":[[767,22],[2303,22]]}}}],["graphics.linestyle(10",{"_index":2061,"t":{"145":{"position":[[304,22],[590,22]]},"151":{"position":[[493,22],[1134,22]]}}}],["graphics.linestyle(2",{"_index":2081,"t":{"145":{"position":[[954,21]]},"151":{"position":[[341,21],[633,21],[985,21],[1285,21],[1672,21],[1826,21],[1963,21]]}}}],["graphics.linestyle(20",{"_index":2088,"t":{"145":{"position":[[1159,22]]}}}],["graphics.linestyle(4",{"_index":2169,"t":{"151":{"position":[[1460,21],[2100,21]]}}}],["graphics.linestyle(math.random",{"_index":2098,"t":{"145":{"position":[[1523,32]]}}}],["graphics.lineto(100",{"_index":2066,"t":{"145":{"position":[[408,20]]},"151":{"position":[[1549,20]]}}}],["graphics.lineto(210",{"_index":2080,"t":{"145":{"position":[[865,20]]}}}],["graphics.lineto(250",{"_index":2065,"t":{"145":{"position":[[382,20],[435,20]]},"151":{"position":[[1522,20]]}}}],["graphics.lineto(330",{"_index":2078,"t":{"145":{"position":[[811,20]]}}}],["graphics.lineto(410",{"_index":2079,"t":{"145":{"position":[[838,20]]}}}],["graphics.lineto(450",{"_index":2074,"t":{"145":{"position":[[712,20]]}}}],["graphics.lineto(50",{"_index":2068,"t":{"145":{"position":[[462,19],[488,19]]},"151":{"position":[[1576,19]]}}}],["graphics.lineto(570",{"_index":2075,"t":{"145":{"position":[[739,20]]}}}],["graphics.lineto(600",{"_index":2091,"t":{"145":{"position":[[1218,20]]}}}],["graphics.moveto(210",{"_index":2073,"t":{"145":{"position":[[685,20]]}}}],["graphics.moveto(30",{"_index":2090,"t":{"145":{"position":[[1193,19]]}}}],["graphics.moveto(50",{"_index":2064,"t":{"145":{"position":[[357,19]]},"151":{"position":[[1496,19]]}}}],["graphics.moveto(math.random",{"_index":2099,"t":{"145":{"position":[[1592,29]]}}}],["graphics.quadraticcurveto(600",{"_index":2076,"t":{"145":{"position":[[766,30]]}}}],["grd",{"_index":2712,"t":{"207":{"position":[[784,3],[988,4]]},"209":{"position":[[580,3],[786,4]]}}}],["grd.addcolorstop(0",{"_index":2714,"t":{"207":{"position":[[832,19]]},"209":{"position":[[630,19]]}}}],["grd.addcolorstop(0.3",{"_index":2717,"t":{"207":{"position":[[881,21]]},"209":{"position":[[679,21]]}}}],["grd.addcolorstop(0.7",{"_index":2719,"t":{"207":{"position":[[912,21]]},"209":{"position":[[710,21]]}}}],["grd.addcolorstop(1",{"_index":2720,"t":{"207":{"position":[[942,19]]},"209":{"position":[[740,19]]}}}],["green",{"_index":133,"t":{"75":{"position":[[1933,5],[3111,5],[3468,5]]},"207":{"position":[[962,9]]},"209":{"position":[[760,9]]}}}],["greensquare",{"_index":135,"t":{"75":{"position":[[1972,11],[5671,13]]}}}],["greensquare.acceleration",{"_index":145,"t":{"75":{"position":[[2190,24]]}}}],["greensquare.acceleration.set",{"_index":245,"t":{"75":{"position":[[5308,29]]}}}],["greensquare.acceleration.set(greensquare.acceleration.x",{"_index":188,"t":{"75":{"position":[[2990,55]]}}}],["greensquare.acceleration.x",{"_index":196,"t":{"75":{"position":[[3268,26],[3298,27],[5434,26]]}}}],["greensquare.acceleration.y",{"_index":189,"t":{"75":{"position":[[3054,26],[3398,26],[3428,27],[5487,26]]}}}],["greensquare.height",{"_index":142,"t":{"75":{"position":[[2135,18]]}}}],["greensquare.mass",{"_index":146,"t":{"75":{"position":[[2236,16],[5248,18],[5286,18]]}}}],["greensquare.position.set((app.screen.width",{"_index":137,"t":{"75":{"position":[[2023,42],[3676,42]]}}}],["greensquare.tint",{"_index":143,"t":{"75":{"position":[[2161,16]]}}}],["greensquare.width",{"_index":141,"t":{"75":{"position":[[2110,17]]}}}],["greensquare.x",{"_index":194,"t":{"75":{"position":[[3202,14],[3224,13],[3540,15],[3565,13],[5417,13]]}}}],["greensquare.y",{"_index":197,"t":{"75":{"position":[[3331,14],[3353,13],[3609,13],[3632,13],[5470,13]]}}}],["grid",{"_index":1075,"t":{"99":{"position":[[334,4]]},"163":{"position":[[1022,5],[1152,5],[1917,4],[2126,5]]},"193":{"position":[[512,4]]},"238":{"position":[[1406,4]]}}}],["gridcontainer",{"_index":2296,"t":{"163":{"position":[[1823,13]]}}}],["gridcontainer.addchild(gridquad",{"_index":2297,"t":{"163":{"position":[[1861,33]]}}}],["gridcontainer.position.set(10",{"_index":2366,"t":{"163":{"position":[[4978,30]]}}}],["gridh",{"_index":2854,"t":{"238":{"position":[[1136,5],[1466,5]]}}}],["gridquad",{"_index":2295,"t":{"163":{"position":[[1769,8]]}}}],["gridquad.shader.uniforms.zoom",{"_index":2381,"t":{"163":{"position":[[5495,29]]}}}],["gridshader",{"_index":2286,"t":{"163":{"position":[[1485,10],[1804,12]]}}}],["gridtexture",{"_index":2293,"t":{"163":{"position":[[1693,11],[2390,12],[5782,11]]}}}],["griduniforms",{"_index":2285,"t":{"163":{"position":[[1449,12],[1543,14]]}}}],["gridw",{"_index":2853,"t":{"238":{"position":[[1096,5],[1430,5]]}}}],["growing",{"_index":1369,"t":{"119":{"position":[[1535,7]]}}}],["guv",{"_index":2276,"t":{"163":{"position":[[1248,3]]}}}],["guv.y",{"_index":2284,"t":{"163":{"position":[[1378,6]]}}}],["h",{"_index":1591,"t":{"131":{"position":[[1289,1]]},"165":{"position":[[1208,1]]},"238":{"position":[[338,1],[584,3]]}}}],["h2",{"_index":1595,"t":{"131":{"position":[[1344,2]]}}}],["hack",{"_index":2844,"t":{"238":{"position":[[746,4]]}}}],["half",{"_index":1643,"t":{"131":{"position":[[2258,4]]},"165":{"position":[[2106,4]]}}}],["halfcircle",{"_index":959,"t":{"95":{"position":[[7536,10],[7892,11]]}}}],["halfcircle.arc(0",{"_index":962,"t":{"95":{"position":[[7637,17]]}}}],["halfcircle.beginfill(0xff0000",{"_index":960,"t":{"95":{"position":[[7570,31]]}}}],["halfcircle.endfill",{"_index":963,"t":{"95":{"position":[[7676,21]]}}}],["halfcircle.linestyle(2",{"_index":961,"t":{"95":{"position":[[7602,23]]}}}],["halfcircle.position.set(50",{"_index":964,"t":{"95":{"position":[[7698,27]]}}}],["halfcircle.rotation",{"_index":972,"t":{"95":{"position":[[8062,19]]}}}],["halfhandlewidth",{"_index":1515,"t":{"127":{"position":[[1904,15],[2107,16]]}}}],["hand",{"_index":1180,"t":{"111":{"position":[[513,4]]},"117":{"position":[[755,4]]}}}],["handle",{"_index":1486,"t":{"127":{"position":[[518,6],[531,6],[717,6],[1236,6],[1509,6],[1673,6],[1860,6],[1947,6],[2141,6]]},"129":{"position":[[515,6]]}}}],["handle's",{"_index":1512,"t":{"127":{"position":[[1817,8]]}}}],["handle.cursor",{"_index":1491,"t":{"127":{"position":[[690,13]]}}}],["handle.eventmode",{"_index":1490,"t":{"127":{"position":[[661,16]]}}}],["handle.width",{"_index":1516,"t":{"127":{"position":[[1922,12]]}}}],["handle.x",{"_index":1489,"t":{"127":{"position":[[633,8],[2018,8],[2189,10]]}}}],["handle.y",{"_index":1487,"t":{"127":{"position":[[603,8]]}}}],["handler",{"_index":528,"t":{"85":{"position":[[425,7],[3535,8]]},"139":{"position":[[4545,7]]}}}],["handlers",{"_index":1911,"t":{"139":{"position":[[4204,8]]}}}],["handling",{"_index":986,"t":{"95":{"position":[[8401,8]]},"121":{"position":[[1114,8]]}}}],["happens",{"_index":2726,"t":{"207":{"position":[[1063,7]]}}}],["hasn't",{"_index":812,"t":{"93":{"position":[[443,6]]}}}],["having",{"_index":921,"t":{"95":{"position":[[4537,6]]}}}],["header",{"_index":616,"t":{"85":{"position":[[2684,6]]}}}],["headertext",{"_index":617,"t":{"85":{"position":[[2702,10]]}}}],["headertext.height",{"_index":625,"t":{"85":{"position":[[2859,18]]}}}],["headertext.width",{"_index":623,"t":{"85":{"position":[[2799,17]]}}}],["headertext.x",{"_index":621,"t":{"85":{"position":[[2760,12]]}}}],["headertext.y",{"_index":624,"t":{"85":{"position":[[2823,12]]}}}],["height",{"_index":271,"t":{"77":{"position":[[553,6],[603,6]]},"131":{"position":[[1098,6],[2282,6]]},"163":{"position":[[68,7],[1747,7],[2553,7],[3192,7],[4196,7]]},"165":{"position":[[1017,6],[2130,6]]},"195":{"position":[[303,6]]},"207":{"position":[[342,7],[407,6],[543,6],[733,7],[1019,8],[1172,7]]},"211":{"position":[[171,7]]},"213":{"position":[[551,7]]}}}],["heightmaps",{"_index":1645,"t":{"131":{"position":[[2330,11]]},"165":{"position":[[2178,11]]}}}],["helmlok.png",{"_index":1127,"t":{"107":{"position":[[350,14]]}}}],["help",{"_index":10,"t":{"73":{"position":[[95,4]]},"141":{"position":[[1207,4]]},"153":{"position":[[1327,4]]}}}],["help.x",{"_index":1971,"t":{"141":{"position":[[1379,6]]},"153":{"position":[[1499,6]]}}}],["help.y",{"_index":1970,"t":{"141":{"position":[[1346,6]]},"153":{"position":[[1466,6]]}}}],["helper",{"_index":989,"t":{"95":{"position":[[8478,6]]}}}],["here",{"_index":4,"t":{"73":{"position":[[37,4]]},"87":{"position":[[1278,4]]},"139":{"position":[[175,5]]},"207":{"position":[[118,4],[1700,4]]}}}],["highp",{"_index":1683,"t":{"133":{"position":[[677,5]]}}}],["history",{"_index":386,"t":{"81":{"position":[[481,7],[1192,7],[1342,8]]}}}],["historysize",{"_index":380,"t":{"81":{"position":[[302,11],[359,11],[516,12],[1533,13],[1602,13]]}}}],["historyx",{"_index":378,"t":{"81":{"position":[[263,8]]}}}],["historyx.pop",{"_index":401,"t":{"81":{"position":[[1200,15]]}}}],["historyx.push(0",{"_index":388,"t":{"81":{"position":[[536,17]]}}}],["historyx.unshift(mouseposition.x",{"_index":402,"t":{"81":{"position":[[1216,34]]}}}],["historyy",{"_index":379,"t":{"81":{"position":[[284,8]]}}}],["historyy.pop",{"_index":403,"t":{"81":{"position":[[1251,15]]}}}],["historyy.push(0",{"_index":389,"t":{"81":{"position":[[554,17]]}}}],["historyy.unshift(mouseposition.y",{"_index":404,"t":{"81":{"position":[[1267,34]]}}}],["hit",{"_index":69,"t":{"75":{"position":[[507,3]]},"95":{"position":[[1480,3],[1560,5],[1583,4],[6256,3],[6383,3],[6463,5],[6486,4]]},"123":{"position":[[1104,3],[1581,3],[2740,3]]},"139":{"position":[[4002,3]]}}}],["hit.x",{"_index":868,"t":{"95":{"position":[[1611,5],[6514,5]]}}}],["hitarea",{"_index":1400,"t":{"123":{"position":[[555,7],[667,7],[1952,7]]}}}],["hitareas",{"_index":1422,"t":{"123":{"position":[[1593,8]]}}}],["hits",{"_index":468,"t":{"83":{"position":[[876,4]]}}}],["hitting",{"_index":951,"t":{"95":{"position":[[6282,7]]}}}],["holder",{"_index":1107,"t":{"105":{"position":[[129,6]]},"107":{"position":[[254,6]]}}}],["hole",{"_index":2039,"t":{"143":{"position":[[1805,4]]}}}],["hover",{"_index":1255,"t":{"115":{"position":[[1200,8]]},"119":{"position":[[74,5]]}}}],["hovericon",{"_index":1229,"t":{"115":{"position":[[251,9],[451,10]]}}}],["http",{"_index":2650,"t":{"203":{"position":[[462,6]]}}}],["http://paulbourke.net/geometry/pointlineplane",{"_index":995,"t":{"95":{"position":[[8530,46]]}}}],["https",{"_index":2649,"t":{"203":{"position":[[441,8],[452,7]]}}}],["https://developer.mozilla.org/en",{"_index":2758,"t":{"209":{"position":[[76,32]]}}}],["https://en.wikipedia.org/wiki/bΓ©zier_curve",{"_index":1989,"t":{"143":{"position":[[259,42]]}}}],["https://github.com/bfred",{"_index":2593,"t":{"199":{"position":[[835,24]]}}}],["https://github.com/createjs/tweenjs/blob/master/src/tweenjs/ease.js",{"_index":723,"t":{"85":{"position":[[5593,67]]}}}],["https://github.com/osuushi/smooth.js",{"_index":420,"t":{"81":{"position":[[1677,36]]}}}],["https://github.com/pixijs/pixi.js/blob/dev/packages/core/src/textures/resources/baseimageresource.js#l54",{"_index":2694,"t":{"207":{"position":[[156,104]]}}}],["https://github.com/pixijs/pixi.js/pull/7381",{"_index":1831,"t":{"139":{"position":[[1508,43]]}}}],["https://github.com/pixijs/pixi.js/wiki/v5",{"_index":1668,"t":{"133":{"position":[[39,41]]}}}],["https://pixijs.com/assets/bg_grass.jpg",{"_index":264,"t":{"77":{"position":[[366,42]]}}}],["https://pixijs.com/assets/bg_rotate.jpg",{"_index":266,"t":{"77":{"position":[[431,43]]}}}],["https://pixijs.com/assets/egghead.png",{"_index":518,"t":{"85":{"position":[[168,40]]},"87":{"position":[[399,40]]},"89":{"position":[[275,41]]},"93":{"position":[[275,41]]}}}],["https://pixijs.com/assets/flowertop.png",{"_index":519,"t":{"85":{"position":[[209,42]]},"87":{"position":[[289,42]]},"89":{"position":[[204,43]]},"93":{"position":[[204,43]]}}}],["https://pixijs.com/assets/helmlok.png",{"_index":520,"t":{"85":{"position":[[252,40]]}}}],["https://pixijs.com/assets/rt_object_01.png",{"_index":2786,"t":{"211":{"position":[[902,45]]}}}],["https://pixijs.com/assets/rt_object_02.png",{"_index":2787,"t":{"211":{"position":[[948,45]]}}}],["https://pixijs.com/assets/rt_object_03.png",{"_index":2788,"t":{"211":{"position":[[994,45]]}}}],["https://pixijs.com/assets/rt_object_04.png",{"_index":2789,"t":{"211":{"position":[[1040,45]]}}}],["https://pixijs.com/assets/rt_object_05.png",{"_index":2790,"t":{"211":{"position":[[1086,45]]}}}],["https://pixijs.com/assets/rt_object_06.png",{"_index":2791,"t":{"211":{"position":[[1132,45]]}}}],["https://pixijs.com/assets/rt_object_07.png",{"_index":2792,"t":{"211":{"position":[[1178,45]]}}}],["https://pixijs.com/assets/rt_object_08.png",{"_index":2793,"t":{"211":{"position":[[1224,45]]}}}],["https://pixijs.com/assets/skully.png",{"_index":521,"t":{"85":{"position":[[293,39]]}}}],["https://pixijs.com/assets/webfont",{"_index":2617,"t":{"201":{"position":[[221,34],[287,34],[361,34],[438,34]]}}}],["https://spicyyoghurt.com/tutorials/html5",{"_index":37,"t":{"75":{"position":[[112,40]]}}}],["https://www.shadertoy.com/view/wtlswx",{"_index":1574,"t":{"131":{"position":[[917,37]]},"165":{"position":[[848,37]]}}}],["huge",{"_index":2130,"t":{"147":{"position":[[1160,4]]}}}],["icons",{"_index":1226,"t":{"115":{"position":[[166,5]]}}}],["id",{"_index":1588,"t":{"131":{"position":[[1237,2],[1265,2]]},"165":{"position":[[1156,2],[1184,2]]}}}],["ids",{"_index":2784,"t":{"211":{"position":[[879,5]]}}}],["if(d.x",{"_index":1646,"t":{"131":{"position":[[2342,6]]},"165":{"position":[[2190,6]]}}}],["if(t",{"_index":1654,"t":{"131":{"position":[[2491,4]]},"165":{"position":[[2339,4]]}}}],["ignore",{"_index":1423,"t":{"123":{"position":[[1602,6]]}}}],["image",{"_index":929,"t":{"95":{"position":[[4848,5]]},"97":{"position":[[522,5]]},"105":{"position":[[274,5]]},"107":{"position":[[689,5]]},"109":{"position":[[177,5]]},"115":{"position":[[738,5]]},"117":{"position":[[177,5]]},"121":{"position":[[402,5]]},"129":{"position":[[147,5]]},"133":{"position":[[215,5],[1034,6]]},"187":{"position":[[272,5]]},"189":{"position":[[180,5]]},"195":{"position":[[154,5],[325,5]]},"211":{"position":[[873,5]]}}}],["images",{"_index":2765,"t":{"209":{"position":[[378,6]]}}}],["imagetoreveal",{"_index":274,"t":{"77":{"position":[[688,13],[948,14]]}}}],["imagetoreveal.mask",{"_index":280,"t":{"77":{"position":[[874,18]]}}}],["implementation",{"_index":1824,"t":{"139":{"position":[[1286,14]]}}}],["import",{"_index":25,"t":{"75":{"position":[[0,6]]},"77":{"position":[[0,6]]},"79":{"position":[[0,6]]},"81":{"position":[[0,6]]},"83":{"position":[[0,6]]},"85":{"position":[[0,6]]},"87":{"position":[[0,6]]},"89":{"position":[[0,6]]},"91":{"position":[[0,6]]},"93":{"position":[[0,6]]},"95":{"position":[[0,6]]},"97":{"position":[[0,6]]},"99":{"position":[[0,6]]},"101":{"position":[[0,6]]},"103":{"position":[[0,6]]},"105":{"position":[[0,6]]},"107":{"position":[[0,6]]},"109":{"position":[[0,6]]},"111":{"position":[[0,6]]},"113":{"position":[[0,6]]},"115":{"position":[[0,6]]},"117":{"position":[[0,6]]},"119":{"position":[[0,6]]},"121":{"position":[[0,6]]},"123":{"position":[[0,6]]},"125":{"position":[[0,6]]},"127":{"position":[[0,6]]},"129":{"position":[[0,6]]},"131":{"position":[[0,6]]},"133":{"position":[[0,6]]},"135":{"position":[[0,6]]},"137":{"position":[[0,6]]},"139":{"position":[[0,6],[33,6]]},"141":{"position":[[0,6]]},"143":{"position":[[0,6]]},"145":{"position":[[0,6]]},"147":{"position":[[0,6]]},"149":{"position":[[0,6]]},"151":{"position":[[0,6],[33,6]]},"153":{"position":[[0,6]]},"155":{"position":[[0,6]]},"157":{"position":[[0,6]]},"159":{"position":[[0,6]]},"161":{"position":[[0,6]]},"163":{"position":[[0,6]]},"165":{"position":[[0,6]]},"167":{"position":[[0,6]]},"169":{"position":[[0,6]]},"171":{"position":[[0,6]]},"173":{"position":[[0,6]]},"175":{"position":[[0,6]]},"177":{"position":[[0,6]]},"179":{"position":[[0,6]]},"181":{"position":[[0,6]]},"183":{"position":[[0,6]]},"185":{"position":[[0,6]]},"187":{"position":[[0,6]]},"189":{"position":[[0,6]]},"191":{"position":[[0,6]]},"193":{"position":[[0,6]]},"195":{"position":[[0,6]]},"197":{"position":[[0,6]]},"199":{"position":[[0,6]]},"201":{"position":[[0,6]]},"203":{"position":[[0,6]]},"205":{"position":[[0,6]]},"207":{"position":[[0,6]]},"209":{"position":[[0,6]]},"211":{"position":[[0,6]]},"213":{"position":[[0,6]]},"238":{"position":[[0,6]]}}}],["important",{"_index":1037,"t":{"97":{"position":[[922,9]]}}}],["impulse",{"_index":62,"t":{"75":{"position":[[438,7],[916,7],[1610,7],[1697,7],[1725,7]]}}}],["impulsepower",{"_index":66,"t":{"75":{"position":[[477,12],[1620,12]]}}}],["in/zoom",{"_index":1922,"t":{"139":{"position":[[4533,7]]}}}],["include",{"_index":2642,"t":{"203":{"position":[[304,7]]}}}],["increment",{"_index":1223,"t":{"113":{"position":[[2358,9]]}}}],["independent",{"_index":1086,"t":{"99":{"position":[[884,11]]},"189":{"position":[[628,11]]},"193":{"position":[[1062,11]]}}}],["info",{"_index":2723,"t":{"207":{"position":[[1036,4]]}}}],["information",{"_index":1988,"t":{"143":{"position":[[246,12]]}}}],["inherits",{"_index":2529,"t":{"187":{"position":[[654,8]]}}}],["init",{"_index":725,"t":{"87":{"position":[[164,6],[1972,7]]},"101":{"position":[[215,6],[627,7]]},"203":{"position":[[266,7],[698,6]]}}}],["initial",{"_index":460,"t":{"83":{"position":[[715,8],[735,7]]},"111":{"position":[[340,7]]},"139":{"position":[[4298,7]]}}}],["inline",{"_index":2595,"t":{"199":{"position":[[870,6]]}}}],["inner",{"_index":2133,"t":{"149":{"position":[[129,5]]}}}],["input",{"_index":1556,"t":{"131":{"position":[[179,5]]},"163":{"position":[[1925,5]]}}}],["inputsize",{"_index":1680,"t":{"133":{"position":[[548,11],[751,10]]}}}],["inputsize.xy",{"_index":1687,"t":{"133":{"position":[[855,12]]}}}],["inside",{"_index":1089,"t":{"101":{"position":[[175,6]]},"119":{"position":[[793,6]]}}}],["instanceof",{"_index":1205,"t":{"113":{"position":[[378,10]]}}}],["instanceoffset",{"_index":2249,"t":{"159":{"position":[[731,14]]}}}],["instantly",{"_index":744,"t":{"87":{"position":[[784,10],[1461,10]]}}}],["int",{"_index":1641,"t":{"131":{"position":[[2163,3]]},"165":{"position":[[2011,3]]}}}],["interact",{"_index":54,"t":{"75":{"position":[[349,8]]}}}],["interactive",{"_index":1134,"t":{"107":{"position":[[537,11]]},"115":{"position":[[1326,14]]},"117":{"position":[[622,14]]},"121":{"position":[[965,14]]},"125":{"position":[[588,12]]},"139":{"position":[[4180,11],[4252,11]]},"191":{"position":[[647,11]]}}}],["interactivity",{"_index":629,"t":{"85":{"position":[[2974,14]]},"111":{"position":[[461,13]]},"119":{"position":[[972,13]]},"125":{"position":[[503,14]]},"199":{"position":[[515,13]]}}}],["intercept",{"_index":991,"t":{"95":{"position":[[8500,9]]}}}],["interleave",{"_index":2217,"t":{"157":{"position":[[476,14]]}}}],["interpolate",{"_index":261,"t":{"77":{"position":[[281,11]]}}}],["interpolation",{"_index":410,"t":{"81":{"position":[[1440,13],[1654,13]]}}}],["intersect",{"_index":997,"t":{"95":{"position":[[8663,9]]}}}],["intersect(0",{"_index":863,"t":{"95":{"position":[[1486,12],[6389,12]]}}}],["intersect(x1",{"_index":1003,"t":{"95":{"position":[[8751,13]]}}}],["intersecting",{"_index":858,"t":{"95":{"position":[[1337,12],[6143,12]]}}}],["intersection",{"_index":859,"t":{"95":{"position":[[1363,12],[1568,12],[6169,12],[6471,12],[8591,12],[9207,12],[9354,12]]},"123":{"position":[[732,12],[1964,12]]}}}],["intersection.y",{"_index":879,"t":{"95":{"position":[[2012,16],[7145,14],[7217,16]]}}}],["inverse",{"_index":1820,"t":{"139":{"position":[[1180,7]]}}}],["inversed",{"_index":2330,"t":{"163":{"position":[[3624,8]]}}}],["ios",{"_index":2724,"t":{"207":{"position":[[1041,3]]}}}],["ios10",{"_index":2596,"t":{"199":{"position":[[886,5]]}}}],["ios9",{"_index":2588,"t":{"199":{"position":[[767,4]]}}}],["isegghead",{"_index":820,"t":{"93":{"position":[[611,9],[963,9],[975,11]]}}}],["isflower",{"_index":2540,"t":{"191":{"position":[[153,8],[756,8],[767,10],[830,8]]}}}],["it's",{"_index":1293,"t":{"117":{"position":[[932,4]]},"131":{"position":[[2629,4]]},"139":{"position":[[387,4]]},"147":{"position":[[1110,4]]},"199":{"position":[[1313,4]]}}}],["it/iphone",{"_index":2594,"t":{"199":{"position":[[860,9]]}}}],["italic",{"_index":587,"t":{"85":{"position":[[2174,9]]},"205":{"position":[[353,9]]}}}],["item",{"_index":2797,"t":{"211":{"position":[[1431,4],[1744,4],[1755,4]]}}}],["item.anchor.set(0.5",{"_index":2802,"t":{"211":{"position":[[1555,21]]}}}],["item.rotation",{"_index":2808,"t":{"211":{"position":[[1772,13]]}}}],["item.x",{"_index":2800,"t":{"211":{"position":[[1483,6]]}}}],["item.y",{"_index":2801,"t":{"211":{"position":[[1519,6]]}}}],["items",{"_index":2794,"t":{"211":{"position":[[1295,5],[1307,5],[1338,5]]}}}],["items.length",{"_index":2806,"t":{"211":{"position":[[1708,13]]}}}],["items.push(item",{"_index":2804,"t":{"211":{"position":[[1608,17]]}}}],["items[i",{"_index":2807,"t":{"211":{"position":[[1762,9]]}}}],["iterate",{"_index":1060,"t":{"97":{"position":[[1765,7]]},"105":{"position":[[1615,7]]},"113":{"position":[[1646,7]]}}}],["itself",{"_index":901,"t":{"95":{"position":[[3000,6]]},"211":{"position":[[293,6]]}}}],["ix",{"_index":414,"t":{"81":{"position":[[1484,2],[1622,3]]}}}],["iy",{"_index":416,"t":{"81":{"position":[[1553,2],[1632,3]]}}}],["i}.ase",{"_index":2479,"t":{"183":{"position":[[367,10]]}}}],["j",{"_index":552,"t":{"85":{"position":[[1192,1],[1199,1],[1206,4],[1359,1],[4003,1],[4010,1],[4032,4],[4103,2]]}}}],["javascript",{"_index":38,"t":{"75":{"position":[[153,10]]}}}],["jonlepage",{"_index":957,"t":{"95":{"position":[[7353,9]]}}}],["k",{"_index":423,"t":{"81":{"position":[[1749,2],[1757,1],[1767,2],[1788,1],[2048,1],[2220,2]]}}}],["keep",{"_index":2129,"t":{"147":{"position":[[1129,4]]}}}],["knock",{"_index":134,"t":{"75":{"position":[[1954,5]]}}}],["know",{"_index":2698,"t":{"207":{"position":[[367,4]]}}}],["larger",{"_index":2121,"t":{"147":{"position":[[980,6]]}}}],["lastdrawnpoint",{"_index":292,"t":{"77":{"position":[[1215,14],[1556,16],[1783,14],[1800,14],[1981,14]]}}}],["lastdrawnpoint.set(x",{"_index":318,"t":{"77":{"position":[[1836,21]]}}}],["lastdrawnpoint.y",{"_index":315,"t":{"77":{"position":[[1659,17]]}}}],["later",{"_index":1052,"t":{"97":{"position":[[1439,5]]},"105":{"position":[[1295,5]]},"113":{"position":[[1304,5]]}}}],["left",{"_index":857,"t":{"95":{"position":[[1317,4],[1778,4],[1812,5],[6018,4],[6655,5],[6714,4]]},"197":{"position":[[361,7]]},"203":{"position":[[905,7]]},"238":{"position":[[1644,7]]}}}],["length",{"_index":956,"t":{"95":{"position":[[7335,6],[8832,6]]},"131":{"position":[[1143,6]]},"163":{"position":[[2198,7]]},"165":{"position":[[1062,6]]}}}],["length(mouse",{"_index":1689,"t":{"133":{"position":[[889,13]]}}}],["lerp",{"_index":716,"t":{"85":{"position":[[5483,4]]}}}],["lerp(a1",{"_index":718,"t":{"85":{"position":[[5506,8]]}}}],["lerp(t.propertybeginvalue",{"_index":706,"t":{"85":{"position":[[5192,26]]}}}],["let's",{"_index":1034,"t":{"97":{"position":[[755,5]]},"107":{"position":[[1271,5]]},"109":{"position":[[498,5]]},"145":{"position":[[1278,5]]},"153":{"position":[[987,5]]},"189":{"position":[[534,5]]}}}],["lets",{"_index":1112,"t":{"105":{"position":[[611,4]]}}}],["library",{"_index":686,"t":{"85":{"position":[[4625,7]]}}}],["light",{"_index":1600,"t":{"131":{"position":[[1415,7]]},"165":{"position":[[1282,7]]}}}],["light1",{"_index":1960,"t":{"141":{"position":[[751,6]]},"153":{"position":[[708,6],[937,7]]}}}],["light1.anchor.set(0.5",{"_index":1962,"t":{"141":{"position":[[826,23]]},"153":{"position":[[783,23]]}}}],["light1.rotation",{"_index":1975,"t":{"141":{"position":[[1493,15]]},"153":{"position":[[1608,15]]}}}],["light2",{"_index":1956,"t":{"141":{"position":[[618,6]]},"153":{"position":[[603,6],[929,7]]}}}],["light2.anchor.set(0.5",{"_index":1958,"t":{"141":{"position":[[693,23]]},"153":{"position":[[678,23]]}}}],["light2.rotation",{"_index":1977,"t":{"141":{"position":[[1518,15]]},"153":{"position":[[1633,15]]}}}],["lighter",{"_index":2680,"t":{"205":{"position":[[1064,10]]}}}],["limit",{"_index":2316,"t":{"163":{"position":[[2842,6],[3012,6]]}}}],["line",{"_index":260,"t":{"77":{"position":[[266,4],[316,4],[1548,4],[1575,4]]},"95":{"position":[[5596,4],[6236,4],[6294,4],[8495,4],[8617,4]]},"139":{"position":[[1988,4]]},"143":{"position":[[2155,4]]},"145":{"position":[[263,4],[573,4]]},"151":{"position":[[328,4],[480,4],[972,4],[1121,4],[1272,4]]}}}],["lineal",{"_index":2619,"t":{"201":{"position":[[279,7],[732,9]]}}}],["linejoin",{"_index":2667,"t":{"205":{"position":[[618,9],[1075,9]]}}}],["lines",{"_index":942,"t":{"95":{"position":[[5154,5],[8651,5],[8819,5],[8989,5]]},"145":{"position":[[1463,5]]},"205":{"position":[[725,7]]}}}],["linesize",{"_index":931,"t":{"95":{"position":[[4869,8],[5642,9],[5664,9],[5685,9],[5707,10],[5745,9],[5767,9],[5788,9],[5809,10],[5842,9],[5863,9],[5884,9],[5905,10],[5939,9],[5961,9],[5983,9],[6004,10],[6616,9],[6638,9],[6673,9],[6694,9],[6730,9],[6751,9],[6788,9],[6810,9],[6972,10],[7131,8],[7174,8]]}}}],["linestyle",{"_index":311,"t":{"77":{"position":[[1589,12]]},"125":{"position":[[338,12]]},"139":{"position":[[3419,12]]},"151":{"position":[[816,9]]}}}],["lineto(0",{"_index":1889,"t":{"139":{"position":[[3483,10]]}}}],["lineto(36",{"_index":2580,"t":{"199":{"position":[[347,11]]}}}],["lineto(70",{"_index":2582,"t":{"199":{"position":[[363,11]]}}}],["lineto(700",{"_index":1891,"t":{"139":{"position":[[3516,12]]}}}],["lineto(x",{"_index":316,"t":{"77":{"position":[[1677,10]]}}}],["linting",{"_index":1001,"t":{"95":{"position":[[8724,7]]}}}],["listen",{"_index":173,"t":{"75":{"position":[[2721,6]]},"81":{"position":[[1085,6]]},"83":{"position":[[1154,6]]},"85":{"position":[[3593,6],[4951,6]]},"95":{"position":[[8334,6]]},"99":{"position":[[776,6]]},"103":{"position":[[442,6]]},"127":{"position":[[1473,6]]},"131":{"position":[[2928,6]]},"189":{"position":[[463,6]]},"193":{"position":[[954,6]]},"199":{"position":[[650,6]]}}}],["little",{"_index":301,"t":{"77":{"position":[[1443,6]]},"97":{"position":[[1528,6]]},"105":{"position":[[1381,6]]},"107":{"position":[[1297,6]]},"109":{"position":[[523,6]]},"113":{"position":[[1393,6]]},"117":{"position":[[534,6]]},"189":{"position":[[559,6]]}}}],["littledudes",{"_index":1709,"t":{"135":{"position":[[305,11]]}}}],["littledudes.filters",{"_index":1722,"t":{"135":{"position":[[802,19]]}}}],["littledudes.x",{"_index":1711,"t":{"135":{"position":[[400,13]]}}}],["littledudes.y",{"_index":1713,"t":{"135":{"position":[[446,13]]}}}],["littlerobot",{"_index":1715,"t":{"135":{"position":[[506,11]]}}}],["littlerobot.filters",{"_index":1723,"t":{"135":{"position":[[839,19]]}}}],["littlerobot.x",{"_index":1717,"t":{"135":{"position":[[600,13]]}}}],["littlerobot.y",{"_index":1718,"t":{"135":{"position":[[646,13]]}}}],["load",{"_index":730,"t":{"87":{"position":[[237,5],[703,4],[1349,4]]},"89":{"position":[[170,4],[320,4]]},"93":{"position":[[170,4],[340,4],[438,4],[481,4],[507,4]]},"107":{"position":[[141,4]]},"129":{"position":[[369,4],[526,4]]},"163":{"position":[[863,4]]},"201":{"position":[[152,4]]},"203":{"position":[[152,4]]}}}],["loaded",{"_index":736,"t":{"87":{"position":[[526,6],[906,6],[1429,6],[1583,6]]},"89":{"position":[[377,6],[635,6]]},"91":{"position":[[413,6]]},"93":{"position":[[450,6],[670,6]]},"101":{"position":[[343,6]]},"131":{"position":[[809,6]]},"187":{"position":[[412,6]]}}}],["loader",{"_index":2521,"t":{"187":{"position":[[433,6]]},"203":{"position":[[325,6]]}}}],["loader/chachicle.ttf",{"_index":2618,"t":{"201":{"position":[[256,22]]}}}],["loader/crosterian.woff2",{"_index":2626,"t":{"201":{"position":[[473,25]]}}}],["loader/dotrice",{"_index":2623,"t":{"201":{"position":[[396,14]]}}}],["loader/lineal.otf",{"_index":2620,"t":{"201":{"position":[[322,19]]}}}],["loading",{"_index":801,"t":{"91":{"position":[[158,7]]}}}],["loadscreenassets",{"_index":745,"t":{"87":{"position":[[801,16],[1478,16]]}}}],["local",{"_index":1080,"t":{"99":{"position":[[662,5]]},"193":{"position":[[840,5]]}}}],["located",{"_index":1945,"t":{"139":{"position":[[5373,7]]}}}],["logical",{"_index":673,"t":{"85":{"position":[[4291,7]]}}}],["logs",{"_index":1319,"t":{"119":{"position":[[49,4],[451,4],[1272,4],[1525,4]]}}}],["logs.join('\\n",{"_index":1373,"t":{"119":{"position":[[1654,16]]}}}],["logs.length",{"_index":1370,"t":{"119":{"position":[[1555,12],[1582,12]]}}}],["logs.push",{"_index":1368,"t":{"119":{"position":[[1452,11]]}}}],["logs.push(`${currenttargetname",{"_index":1366,"t":{"119":{"position":[[1277,31]]}}}],["logs.shift",{"_index":1371,"t":{"119":{"position":[[1603,13]]}}}],["logtext",{"_index":1335,"t":{"119":{"position":[[468,7],[1631,7]]}}}],["logtext.text",{"_index":1372,"t":{"119":{"position":[[1639,12]]}}}],["logtext.x",{"_index":1339,"t":{"119":{"position":[[552,9]]}}}],["logtext.y",{"_index":1337,"t":{"119":{"position":[[536,9]]}}}],["long",{"_index":382,"t":{"81":{"position":[[329,4]]},"119":{"position":[[1547,4]]}}}],["look",{"_index":304,"t":{"77":{"position":[[1465,4]]},"207":{"position":[[113,4]]}}}],["looking",{"_index":508,"t":{"83":{"position":[[2120,7]]}}}],["loop",{"_index":184,"t":{"75":{"position":[[2891,4]]}}}],["lot",{"_index":2671,"t":{"205":{"position":[[690,3]]},"213":{"position":[[930,3]]}}}],["m",{"_index":432,"t":{"81":{"position":[[2073,1]]}}}],["m[0",{"_index":436,"t":{"81":{"position":[[2318,4]]}}}],["m[1",{"_index":438,"t":{"81":{"position":[[2365,5]]}}}],["made",{"_index":237,"t":{"75":{"position":[[5027,4]]},"123":{"position":[[1648,4]]}}}],["maggot",{"_index":1731,"t":{"137":{"position":[[430,6],[1951,6]]}}}],["maggot.anchor.set(0.5",{"_index":1733,"t":{"137":{"position":[[497,23]]}}}],["maggot.direction",{"_index":1735,"t":{"137":{"position":[[549,16],[1972,16],[2146,16]]}}}],["maggot.original",{"_index":1743,"t":{"137":{"position":[[781,15]]}}}],["maggot.original.copyfrom(maggot.scale",{"_index":1744,"t":{"137":{"position":[[817,39]]}}}],["maggot.original.x",{"_index":1774,"t":{"137":{"position":[[2195,17]]}}}],["maggot.rotation",{"_index":1772,"t":{"137":{"position":[[2127,15]]}}}],["maggot.scale.set(1",{"_index":1742,"t":{"137":{"position":[[738,18]]}}}],["maggot.scale.x",{"_index":1773,"t":{"137":{"position":[[2178,14]]}}}],["maggot.speed",{"_index":1736,"t":{"137":{"position":[[597,12],[2058,13],[2113,13]]}}}],["maggot.turnspeed",{"_index":1737,"t":{"137":{"position":[[615,16],[1992,16]]}}}],["maggot.x",{"_index":1738,"t":{"137":{"position":[[655,8],[2017,8],[2281,9],[2305,8],[2341,9],[2380,8]]}}}],["maggot.y",{"_index":1740,"t":{"137":{"position":[[696,8],[2072,8],[2411,9],[2435,8],[2472,9],[2512,8]]}}}],["maggots",{"_index":1202,"t":{"113":{"position":[[330,7],[657,8],[1123,7],[1258,7],[1400,7],[2058,7]]},"137":{"position":[[379,7],[2250,7]]}}}],["maggots.length",{"_index":1218,"t":{"113":{"position":[[1720,15]]},"137":{"position":[[1922,15]]}}}],["maggots.push(dude",{"_index":1216,"t":{"113":{"position":[[1310,19]]}}}],["maggots.push(maggot",{"_index":1745,"t":{"137":{"position":[[857,21]]}}}],["maggots[i",{"_index":1219,"t":{"113":{"position":[[1756,11]]},"137":{"position":[[1960,11]]}}}],["magically",{"_index":2519,"t":{"187":{"position":[[370,9]]}}}],["main",{"_index":1619,"t":{"131":{"position":[[1702,6]]},"133":{"position":[[813,6]]},"157":{"position":[[690,6],[897,6]]},"159":{"position":[[1183,6],[1360,6]]},"161":{"position":[[1082,6],[1289,6]]},"163":{"position":[[732,6],[1123,6],[2097,6],[2879,6],[3481,6],[4532,6]]},"165":{"position":[[681,6],[1569,6]]},"167":{"position":[[631,6],[844,6]]},"169":{"position":[[565,6],[772,6],[1114,6],[1321,6]]},"175":{"position":[[387,6],[533,6]]},"177":{"position":[[653,6],[837,6]]},"179":{"position":[[799,6],[1065,6]]},"181":{"position":[[662,6],[910,6]]}}}],["make",{"_index":303,"t":{"77":{"position":[[1457,4]]},"107":{"position":[[522,4]]},"115":{"position":[[1310,4]]},"117":{"position":[[907,4]]},"121":{"position":[[949,4]]},"125":{"position":[[553,4]]},"127":{"position":[[228,4],[302,4]]},"131":{"position":[[2619,4]]},"139":{"position":[[3830,4],[3997,4],[4169,4],[4242,4]]},"147":{"position":[[483,4],[952,4]]},"165":{"position":[[2500,4]]},"171":{"position":[[582,4]]},"173":{"position":[[643,4]]},"191":{"position":[[631,4]]}}}],["makegamescreen",{"_index":758,"t":{"87":{"position":[[1212,17],[1251,16]]}}}],["makeloadscreen",{"_index":738,"t":{"87":{"position":[[622,17],[657,16],[1948,17]]}}}],["makes",{"_index":2124,"t":{"147":{"position":[[1013,5]]},"163":{"position":[[1935,5]]},"213":{"position":[[953,5]]}}}],["manifest",{"_index":726,"t":{"87":{"position":[[176,8],[478,9]]}}}],["manifestexample",{"_index":727,"t":{"87":{"position":[[199,15],[488,15]]}}}],["map",{"_index":489,"t":{"83":{"position":[[1483,3]]},"139":{"position":[[1042,3]]}}}],["margin",{"_index":574,"t":{"85":{"position":[[1701,6],[1771,7],[1935,8],[2041,7],[2067,8],[2597,6]]}}}],["mask",{"_index":845,"t":{"95":{"position":[[681,4],[760,5],[780,5],[1858,4],[3138,5],[3454,4],[3533,5],[3553,5],[3890,4],[5026,4],[5137,4],[5176,4],[5255,5],[6049,4],[6846,4]]},"123":{"position":[[1095,5],[1572,4],[1698,4]]},"155":{"position":[[352,4],[483,5]]},"187":{"position":[[745,4]]}}}],["mask.anchor.set(0.5",{"_index":2199,"t":{"155":{"position":[[420,21]]}}}],["mask.arc(0",{"_index":914,"t":{"95":{"position":[[4010,11]]}}}],["mask.beginfill(0xff0000",{"_index":875,"t":{"95":{"position":[[1909,24],[3941,24],[6897,24]]}}}],["mask.clear",{"_index":873,"t":{"95":{"position":[[1863,13],[3895,13],[6851,13]]}}}],["mask.endfill",{"_index":883,"t":{"95":{"position":[[2153,15],[4079,15],[7253,15]]}}}],["mask.linestyle(2",{"_index":874,"t":{"95":{"position":[[1877,17],[3909,17],[6865,17]]}}}],["mask.lineto(0",{"_index":877,"t":{"95":{"position":[[1965,14],[4060,14],[7234,14]]}}}],["mask.lineto(corners[i",{"_index":881,"t":{"95":{"position":[[2102,21],[7039,21]]}}}],["mask.lineto(intersection.x",{"_index":878,"t":{"95":{"position":[[1984,27],[7090,26],[7189,27]]}}}],["mask.lineto(x1",{"_index":913,"t":{"95":{"position":[[3989,15]]}}}],["mask.moveto(0",{"_index":876,"t":{"95":{"position":[[1938,14],[3970,14],[6926,14],[6945,14]]}}}],["mask.position.set(size",{"_index":846,"t":{"95":{"position":[[709,22],[3482,22],[5204,22]]}}}],["mask.x",{"_index":2200,"t":{"155":{"position":[[442,6],[696,6],[718,7]]}}}],["mask.y",{"_index":2202,"t":{"155":{"position":[[456,6],[733,6],[755,7]]}}}],["masking",{"_index":923,"t":{"95":{"position":[[4583,8]]},"153":{"position":[[1370,7]]}}}],["masks",{"_index":1424,"t":{"123":{"position":[[1609,6]]}}}],["mat3",{"_index":2221,"t":{"157":{"position":[[611,4],[643,4]]},"159":{"position":[[1104,4],[1136,4]]},"161":{"position":[[1003,4],[1035,4]]},"163":{"position":[[653,4],[685,4]]},"165":{"position":[[602,4],[634,4]]},"167":{"position":[[552,4],[584,4]]},"169":{"position":[[486,4],[518,4],[1035,4],[1067,4]]},"175":{"position":[[327,4],[359,4]]},"177":{"position":[[572,4],[604,4]]},"179":{"position":[[699,4],[731,4]]},"181":{"position":[[583,4],[615,4]]}}}],["match",{"_index":1000,"t":{"95":{"position":[[8704,5]]},"127":{"position":[[1968,5]]}}}],["matches",{"_index":1403,"t":{"123":{"position":[[680,7]]}}}],["math",{"_index":992,"t":{"95":{"position":[[8510,4]]}}}],["math.abs(e.deltay",{"_index":1920,"t":{"139":{"position":[[4459,20]]}}}],["math.abs(mask.x",{"_index":2208,"t":{"155":{"position":[[773,16]]}}}],["math.atan2",{"_index":222,"t":{"75":{"position":[[4405,11]]}}}],["math.atan2(dycenter",{"_index":516,"t":{"83":{"position":[[2472,20]]}}}],["math.cos((i",{"_index":2447,"t":{"171":{"position":[[718,11]]},"173":{"position":[[779,11]]}}}],["math.cos(anglestart",{"_index":910,"t":{"95":{"position":[[3807,20]]}}}],["math.cos(angletomouse",{"_index":232,"t":{"75":{"position":[[4817,22]]}}}],["math.cos(count",{"_index":1726,"t":{"135":{"position":[[949,16]]},"141":{"position":[[1607,15],[1717,16],[1746,15]]},"145":{"position":[[1975,15],[2017,15],[2116,15],[2159,15],[2259,15]]},"153":{"position":[[1722,15],[1856,15],[1898,15],[1997,15],[2040,15]]},"195":{"position":[[635,16]]}}}],["math.cos(deg",{"_index":473,"t":{"83":{"position":[[984,13]]}}}],["math.cos(dude.direction",{"_index":1065,"t":{"97":{"position":[[1991,24]]},"105":{"position":[[1836,24]]},"113":{"position":[[1947,24]]}}}],["math.cos(i",{"_index":894,"t":{"95":{"position":[[2643,10]]}}}],["math.cos(maggot.direction",{"_index":1771,"t":{"137":{"position":[[2084,26]]}}}],["math.cos(phase",{"_index":853,"t":{"95":{"position":[[999,14],[5507,14]]}}}],["math.floor(i",{"_index":348,"t":{"79":{"position":[[759,12]]},"99":{"position":[[478,12]]},"193":{"position":[[656,12]]},"213":{"position":[[399,12]]}}}],["math.floor(math.random",{"_index":641,"t":{"85":{"position":[[3290,24]]},"97":{"position":[[813,24],[868,24]]},"117":{"position":[[393,24],[439,24]]},"155":{"position":[[594,24],[638,24]]}}}],["math.floor(t",{"_index":431,"t":{"81":{"position":[[2052,14]]}}}],["math.hypot(a",{"_index":132,"t":{"75":{"position":[[1906,13]]}}}],["math.max(0",{"_index":506,"t":{"83":{"position":[[2025,11]]}}}],["math.max(halfhandlewidth",{"_index":1519,"t":{"127":{"position":[[2029,25]]}}}],["math.min",{"_index":1520,"t":{"127":{"position":[[2055,9]]}}}],["math.min(1",{"_index":702,"t":{"85":{"position":[[5130,11]]}}}],["math.min(15",{"_index":1919,"t":{"139":{"position":[[4446,12]]}}}],["math.min(symbol_size",{"_index":562,"t":{"85":{"position":[[1410,20],[4404,20]]}}}],["math.pi",{"_index":471,"t":{"83":{"position":[[921,7],[2505,7]]},"85":{"position":[[2367,7]]},"95":{"position":[[947,8],[1016,7],[1064,7],[2669,7],[2731,7],[2860,8],[2961,7],[3692,8],[3730,7],[5455,8],[5524,7],[5572,7],[7666,9],[8047,8]]},"97":{"position":[[1144,7],[2064,7]]},"105":{"position":[[997,7],[1909,7]]},"113":{"position":[[943,7],[2037,8]]},"115":{"position":[[1715,7],[1810,8]]},"121":{"position":[[1810,7],[1905,8]]},"137":{"position":[[584,7],[2165,7]]},"143":{"position":[[1393,8],[1406,9],[1551,8],[1564,7],[1745,8],[1760,7]]},"185":{"position":[[723,8]]},"205":{"position":[[546,7]]},"207":{"position":[[2056,7]]},"209":{"position":[[994,7]]},"213":{"position":[[456,8]]}}}],["math.random",{"_index":462,"t":{"83":{"position":[[745,13],[778,13],[905,13],[951,13]]},"97":{"position":[[722,13],[1128,13],[1251,13],[1341,13]]},"105":{"position":[[578,13],[667,13],[710,13],[757,13],[981,13],[1104,13],[1194,13]]},"107":{"position":[[869,13],[905,13],[942,13]]},"113":{"position":[[703,13],[754,13],[797,13],[844,13],[927,13],[1052,13],[1160,13],[1200,13]]},"137":{"position":[[568,13],[634,13],[666,13],[707,13],[759,13]]},"145":{"position":[[1562,13],[1629,13],[1675,13],[1696,13],[1717,13],[1738,13],[1759,13],[1780,13]]},"159":{"position":[[856,14],[905,14],[954,14]]},"185":{"position":[[576,13],[624,13],[707,13],[759,13]]},"211":{"position":[[1492,13],[1528,13]]},"213":{"position":[[440,13]]}}}],["math.round((app.screen.width",{"_index":369,"t":{"79":{"position":[[1208,28]]}}}],["math.round((bottom.width",{"_index":610,"t":{"85":{"position":[[2515,24]]}}}],["math.round((margin",{"_index":613,"t":{"85":{"position":[[2606,18],[2838,18]]}}}],["math.round((symbol_size",{"_index":566,"t":{"85":{"position":[[1488,23],[4483,23]]}}}],["math.round((top.width",{"_index":622,"t":{"85":{"position":[[2775,21]]}}}],["math.round(app.screen.width",{"_index":577,"t":{"85":{"position":[[1797,27]]}}}],["math.round(screenshottext.height",{"_index":372,"t":{"79":{"position":[[1286,32]]}}}],["math.sign(e.deltay",{"_index":1918,"t":{"139":{"position":[[4424,19]]}}}],["math.sin((i",{"_index":2445,"t":{"171":{"position":[[653,11]]},"173":{"position":[[714,11]]}}}],["math.sin((timer",{"_index":1105,"t":{"103":{"position":[[632,15]]}}}],["math.sin(anglestart",{"_index":912,"t":{"95":{"position":[[3849,20]]}}}],["math.sin(angletomouse",{"_index":233,"t":{"75":{"position":[[4852,22]]}}}],["math.sin(count",{"_index":1160,"t":{"107":{"position":[[1430,16],[1472,16]]},"135":{"position":[[986,16]]},"137":{"position":[[2215,15]]},"141":{"position":[[1563,15],[1684,15],[1781,14],[1818,14],[1851,14]]},"145":{"position":[[1946,15],[2046,15],[2088,15],[2187,15],[2230,15]]},"153":{"position":[[1678,15],[1827,15],[1927,15],[1969,15],[2068,15]]},"195":{"position":[[587,16]]},"211":{"position":[[2057,15]]}}}],["math.sin(deg",{"_index":475,"t":{"83":{"position":[[1019,13]]}}}],["math.sin(dude.direction",{"_index":1064,"t":{"97":{"position":[[1942,24]]},"105":{"position":[[1787,24]]},"113":{"position":[[1881,24]]}}}],["math.sin(i",{"_index":895,"t":{"95":{"position":[[2705,10],[2935,10]]}}}],["math.sin(maggot.direction",{"_index":1770,"t":{"137":{"position":[[2029,26]]}}}],["math.sin(phase",{"_index":854,"t":{"95":{"position":[[1047,14],[5555,14]]}}}],["math.sin(tick",{"_index":1222,"t":{"113":{"position":[[1790,13]]}}}],["math.sin(time",{"_index":2386,"t":{"163":{"position":[[5662,13]]}}}],["math.sin(time)*5+10",{"_index":2382,"t":{"163":{"position":[[5527,20]]}}}],["math.sqrt",{"_index":106,"t":{"75":{"position":[[1157,10]]}}}],["math.sqrt(dxcenter",{"_index":504,"t":{"83":{"position":[[1949,18]]}}}],["matrix",{"_index":1810,"t":{"139":{"position":[[917,6]]},"141":{"position":[[1653,6]]}}}],["matrix[1",{"_index":1980,"t":{"141":{"position":[[1672,9]]}}}],["matrix[2",{"_index":1981,"t":{"141":{"position":[[1705,9]]}}}],["matrix[3",{"_index":1982,"t":{"141":{"position":[[1734,9]]}}}],["matrix[4",{"_index":1984,"t":{"141":{"position":[[1769,9]]}}}],["matrix[5",{"_index":1985,"t":{"141":{"position":[[1806,9]]}}}],["matrix[6",{"_index":1986,"t":{"141":{"position":[[1839,9]]}}}],["max",{"_index":1616,"t":{"131":{"position":[[1660,4]]},"165":{"position":[[1527,4]]}}}],["mean",{"_index":1287,"t":{"117":{"position":[[746,4]]}}}],["means",{"_index":1795,"t":{"139":{"position":[[594,5]]}}}],["mediump",{"_index":1675,"t":{"133":{"position":[[460,7]]},"157":{"position":[[535,7],[829,7]]},"159":{"position":[[1015,7],[1321,7]]},"161":{"position":[[927,7],[1221,7]]},"163":{"position":[[577,7],[1064,7],[1990,7],[2794,7],[3397,7],[4409,7]]},"165":{"position":[[526,7],[896,7]]},"167":{"position":[[476,7],[770,7]]},"169":{"position":[[410,7],[704,7],[959,7],[1253,7]]},"175":{"position":[[272,7],[513,7]]},"177":{"position":[[494,7],[796,7]]},"179":{"position":[[600,7],[976,7]]},"181":{"position":[[507,7],[822,7]]}}}],["memories",{"_index":2524,"t":{"187":{"position":[[543,8]]}}}],["memory",{"_index":2728,"t":{"207":{"position":[[1121,6]]}}}],["merged",{"_index":1832,"t":{"139":{"position":[[1558,7]]}}}],["mesh",{"_index":1557,"t":{"131":{"position":[[204,4]]},"163":{"position":[[1665,4]]}}}],["meshes",{"_index":2289,"t":{"163":{"position":[[1582,6]]}}}],["method",{"_index":2823,"t":{"213":{"position":[[780,6]]}}}],["methods",{"_index":1847,"t":{"139":{"position":[[1999,7]]}}}],["middle",{"_index":201,"t":{"75":{"position":[[3530,6]]}}}],["mind",{"_index":654,"t":{"85":{"position":[[3828,4]]}}}],["mipmap",{"_index":1660,"t":{"131":{"position":[[2661,7]]}}}],["mipmapping",{"_index":2396,"t":{"165":{"position":[[2537,11]]}}}],["mirrors",{"_index":2857,"t":{"238":{"position":[[1195,7]]}}}],["mix(ripple",{"_index":2361,"t":{"163":{"position":[[4698,11]]}}}],["mobile",{"_index":1186,"t":{"111":{"position":[[600,6]]},"199":{"position":[[733,6]]}}}],["mod(guv.x",{"_index":2283,"t":{"163":{"position":[[1366,9]]}}}],["mod(id",{"_index":1590,"t":{"131":{"position":[[1270,7]]},"165":{"position":[[1189,7]]}}}],["mode",{"_index":1039,"t":{"97":{"position":[[994,4]]},"111":{"position":[[158,4]]},"117":{"position":[[271,4],[736,4]]}}}],["modes",{"_index":19,"t":{"73":{"position":[[198,5]]}}}],["modified",{"_index":998,"t":{"95":{"position":[[8678,8]]}}}],["modify",{"_index":1046,"t":{"97":{"position":[[1188,6]]},"105":{"position":[[1041,6]]},"113":{"position":[[987,6]]}}}],["monster",{"_index":619,"t":{"85":{"position":[[2735,7]]}}}],["more",{"_index":902,"t":{"95":{"position":[[3014,4]]},"131":{"position":[[232,4]]},"207":{"position":[[1856,4]]}}}],["mount",{"_index":1341,"t":{"119":{"position":[[596,5],[777,5]]}}}],["mouse",{"_index":203,"t":{"75":{"position":[[3775,5],[4158,5],[4562,5]]},"81":{"position":[[1176,5]]},"107":{"position":[[1099,5]]},"111":{"position":[[584,5],[681,5],[738,5]]},"117":{"position":[[670,5],[814,5],[992,5]]},"119":{"position":[[284,5]]},"121":{"position":[[1046,5],[1321,5]]},"133":{"position":[[731,6],[1372,6]]},"139":{"position":[[5423,5]]}}}],["mouse.xy",{"_index":1697,"t":{"133":{"position":[[1083,9]]}}}],["mousecoords",{"_index":160,"t":{"75":{"position":[[2517,11],[4647,12]]}}}],["mousecoords.x",{"_index":169,"t":{"75":{"position":[[2650,13],[3849,13],[3866,13],[4235,13]]}}}],["mousecoords.y",{"_index":171,"t":{"75":{"position":[[2682,13],[3907,13],[3924,13],[4278,13]]}}}],["mouseposition",{"_index":396,"t":{"81":{"position":[[836,13],[961,13],[977,13],[1137,16]]}}}],["mouseposition.x",{"_index":397,"t":{"81":{"position":[[1010,15]]}}}],["mouseposition.y",{"_index":398,"t":{"81":{"position":[[1044,15]]}}}],["move",{"_index":148,"t":{"75":{"position":[[2276,4]]},"91":{"position":[[539,4]]},"99":{"position":[[534,4]]},"101":{"position":[[461,4]]},"109":{"position":[[322,4]]},"117":{"position":[[1082,4]]},"119":{"position":[[273,5]]},"139":{"position":[[484,4]]},"189":{"position":[[324,4]]},"191":{"position":[[480,4]]},"193":{"position":[[712,4]]}}}],["moved",{"_index":1513,"t":{"127":{"position":[[1870,6]]}}}],["movement",{"_index":1043,"t":{"97":{"position":[[1102,8]]},"103":{"position":[[557,9]]},"105":{"position":[[833,8]]},"117":{"position":[[1622,8]]}}}],["movementspeed",{"_index":59,"t":{"75":{"position":[[397,13],[4726,14]]}}}],["moves",{"_index":58,"t":{"75":{"position":[[385,5],[3129,5]]},"125":{"position":[[103,5]]},"213":{"position":[[878,6]]}}}],["moveto",{"_index":1890,"t":{"139":{"position":[[3499,8]]}}}],["moveto(0",{"_index":1888,"t":{"139":{"position":[[3466,10]]}}}],["moveto(36",{"_index":2579,"t":{"199":{"position":[[331,11]]}}}],["moveto(lastdrawnpoint.x",{"_index":314,"t":{"77":{"position":[[1633,25]]}}}],["moving",{"_index":512,"t":{"83":{"position":[[2224,7]]},"145":{"position":[[1293,6]]},"153":{"position":[[1002,6]]}}}],["mr",{"_index":1167,"t":{"109":{"position":[[511,2]]},"189":{"position":[[547,2]]}}}],["much",{"_index":1569,"t":{"131":{"position":[[791,4]]}}}],["multiple",{"_index":2672,"t":{"205":{"position":[[716,8]]},"207":{"position":[[1781,8]]}}}],["multiply",{"_index":900,"t":{"95":{"position":[[2982,8]]}}}],["multitouch",{"_index":1309,"t":{"117":{"position":[[1587,10]]}}}],["n",{"_index":1607,"t":{"131":{"position":[[1504,1],[1678,6]]},"139":{"position":[[5417,3],[5464,3]]},"165":{"position":[[1371,1],[1545,6]]}}}],["name",{"_index":729,"t":{"87":{"position":[[231,5],[264,5],[343,5],[376,5]]},"97":{"position":[[528,4]]},"105":{"position":[[280,4]]},"107":{"position":[[806,6]]},"157":{"position":[[213,4],[359,4]]},"161":{"position":[[213,4],[359,4],[565,4],[718,4]]},"163":{"position":[[245,4],[379,4]]},"165":{"position":[[232,4],[378,4]]},"167":{"position":[[213,4],[348,4]]},"169":{"position":[[213,4],[316,4]]},"177":{"position":[[213,4],[350,4]]},"179":{"position":[[213,4],[350,4],[488,4]]},"181":{"position":[[213,4],[359,4]]}}}],["need",{"_index":1560,"t":{"131":{"position":[[263,4]]},"199":{"position":[[1107,4]]},"207":{"position":[[605,4]]},"209":{"position":[[340,4]]}}}],["needs",{"_index":2699,"t":{"207":{"position":[[388,5]]}}}],["nest",{"_index":1798,"t":{"139":{"position":[[676,4]]}}}],["nested",{"_index":1780,"t":{"139":{"position":[[107,6]]}}}],["new",{"_index":45,"t":{"75":{"position":[[221,3],[1035,3],[1075,3],[1297,3],[1392,3],[1681,3],[1986,3],[2217,3],[2306,3],[2472,3],[4014,3],[4219,3]]},"77":{"position":[[45,3],[190,3],[323,3],[842,3],[1818,3]]},"79":{"position":[[45,3],[248,3],[676,3],[1055,3],[1139,3]]},"81":{"position":[[45,3],[703,3]]},"83":{"position":[[45,3],[499,3]]},"85":{"position":[[45,3],[841,3],[904,3],[1060,3],[1228,3],[1856,3],[1959,3],[2107,3],[2460,3],[2715,3]]},"87":{"position":[[45,3],[877,3],[936,3],[1554,3],[1613,3]]},"89":{"position":[[45,3],[606,3]]},"91":{"position":[[45,3],[384,3]]},"93":{"position":[[45,3],[641,3],[703,3]]},"95":{"position":[[45,3],[335,3],[688,3],[2313,3],[3227,3],[3461,3],[4268,3],[4613,3],[4896,3],[5183,3],[7446,3],[7549,3],[7749,3]]},"97":{"position":[[45,3],[138,3],[497,3],[1591,3]]},"99":{"position":[[45,3],[167,3],[232,3],[395,3]]},"101":{"position":[[45,3],[315,3]]},"103":{"position":[[45,3],[242,3]]},"105":{"position":[[45,3],[249,3],[1444,3]]},"107":{"position":[[45,3],[449,3]]},"109":{"position":[[45,3],[158,3]]},"111":{"position":[[45,3]]},"113":{"position":[[45,3],[142,3],[471,3],[1458,3]]},"115":{"position":[[45,3],[1152,3]]},"117":{"position":[[45,3],[570,3]]},"119":{"position":[[121,3]]},"121":{"position":[[45,3],[816,3]]},"123":{"position":[[45,3],[269,3],[590,3],[767,3],[1133,3],[1283,3],[1723,3],[1808,3],[2006,3],[2340,3],[2395,3],[2504,3],[2613,3],[2718,3]]},"125":{"position":[[138,3]]},"127":{"position":[[45,3],[358,3],[540,3],[1212,3]]},"129":{"position":[[45,3],[581,3],[643,3]]},"131":{"position":[[317,3],[532,3],[2787,3]]},"133":{"position":[[113,3],[1166,3],[1211,3],[1336,3],[1379,3]]},"135":{"position":[[45,3],[720,3],[771,3]]},"137":{"position":[[45,3],[176,3],[265,3],[799,3],[1008,3]]},"139":{"position":[[260,3],[882,3],[993,3],[1107,3],[2042,3],[2679,3],[3399,3],[3602,3],[3925,3],[4893,3],[5309,3]]},"141":{"position":[[45,3],[324,3],[380,3],[1214,3]]},"143":{"position":[[45,3],[319,3],[577,3],[804,3],[1072,3],[1319,3],[1471,3],[1634,3],[1835,3],[2200,3]]},"145":{"position":[[45,3],[224,3],[1320,3]]},"147":{"position":[[45,3],[176,3],[618,3]]},"149":{"position":[[45,3],[319,3],[473,3],[601,4],[657,3],[838,3]]},"151":{"position":[[77,3],[192,3]]},"153":{"position":[[45,3],[368,3],[1029,3],[1334,3]]},"155":{"position":[[45,3],[537,3]]},"157":{"position":[[45,3],[143,3],[1053,3]]},"159":{"position":[[45,3],[143,3],[330,3],[1425,3]]},"161":{"position":[[45,3],[143,3],[495,3],[1445,3]]},"163":{"position":[[45,3],[175,3],[1780,3],[1839,3],[2588,3],[2651,3],[3226,3],[3287,3],[4229,3],[4288,3],[4938,3]]},"165":{"position":[[45,3],[162,3],[2768,3]]},"167":{"position":[[45,3],[143,3],[925,3],[949,3],[1084,3],[1108,3],[1237,3],[1261,3]]},"169":{"position":[[45,3],[143,3],[1608,3],[1659,3]]},"171":{"position":[[45,3],[295,3],[449,3]]},"173":{"position":[[45,3],[301,3],[427,3]]},"175":{"position":[[45,3],[143,3],[606,3]]},"177":{"position":[[45,3],[143,3],[903,3]]},"179":{"position":[[45,3],[143,3],[1325,3]]},"181":{"position":[[45,3],[143,3],[1196,3]]},"183":{"position":[[45,3],[580,3],[851,3]]},"185":{"position":[[45,3],[518,3]]},"187":{"position":[[45,3],[598,3]]},"189":{"position":[[45,3],[161,3]]},"191":{"position":[[45,3],[342,3],[389,3]]},"193":{"position":[[220,3],[345,3],[410,3],[573,3]]},"195":{"position":[[45,3],[396,3]]},"197":{"position":[[45,3],[255,3]]},"199":{"position":[[45,3],[221,3],[1273,3],[1349,3]]},"201":{"position":[[45,3],[562,3],[593,3],[671,3],[699,3],[774,3],[812,3],[896,3],[930,3]]},"203":{"position":[[45,3],[778,3]]},"205":{"position":[[45,3],[167,3],[286,3],[658,3],[824,3],[1136,3]]},"207":{"position":[[1529,3],[1651,3],[1927,3],[1977,3]]},"209":{"position":[[183,3],[915,3]]},"211":{"position":[[45,3],[467,3],[545,3],[745,3],[1929,3]]},"213":{"position":[[45,3],[167,3],[339,3],[634,3]]},"238":{"position":[[45,3],[528,3],[668,3],[874,3],[1246,3],[1292,3],[1526,3],[1598,5]]}}}],["next",{"_index":1846,"t":{"139":{"position":[[1983,4]]}}}],["nicer",{"_index":305,"t":{"77":{"position":[[1470,5]]}}}],["noise",{"_index":1581,"t":{"131":{"position":[[1029,6],[2601,5],[2832,6]]},"163":{"position":[[2750,6],[2867,6],[3024,6],[4610,5]]},"165":{"position":[[948,6],[2419,6]]}}}],["noisecontainer",{"_index":2324,"t":{"163":{"position":[[3270,14]]}}}],["noisecontainer.addchild(noisequad",{"_index":2325,"t":{"163":{"position":[[3309,35]]}}}],["noisecontainer.position.set(10",{"_index":2368,"t":{"163":{"position":[[5053,31]]}}}],["noisequad",{"_index":2323,"t":{"163":{"position":[[3214,9]]}}}],["noisequad.shader.uniforms.limit",{"_index":2385,"t":{"163":{"position":[[5628,31]]}}}],["noiseshader",{"_index":2321,"t":{"163":{"position":[[3055,11],[3250,13]]}}}],["noisetexture",{"_index":2322,"t":{"163":{"position":[[3137,12],[4791,13],[5913,12]]}}}],["noiseuniforms",{"_index":2320,"t":{"163":{"position":[[2994,13],[3115,15]]}}}],["none",{"_index":1010,"t":{"95":{"position":[[8807,4]]}}}],["normal",{"_index":2855,"t":{"238":{"position":[[1174,6]]}}}],["normalize",{"_index":1184,"t":{"111":{"position":[[564,9]]},"127":{"position":[[2131,9]]},"131":{"position":[[1508,10],[1907,10],[2001,10]]},"165":{"position":[[1375,10],[1755,10],[1849,10]]}}}],["normalize(cross",{"_index":1630,"t":{"131":{"position":[[1943,16]]},"165":{"position":[[1791,16]]}}}],["normalize(vec3",{"_index":1635,"t":{"131":{"position":[[2048,15]]},"165":{"position":[[1896,15]]}}}],["normalized",{"_index":1380,"t":{"121":{"position":[[1071,10]]}}}],["note",{"_index":1549,"t":{"131":{"position":[[46,4]]},"133":{"position":[[411,5]]}}}],["now",{"_index":655,"t":{"85":{"position":[[3839,3],[5012,3],[5142,4]]},"93":{"position":[[512,4]]},"211":{"position":[[1322,3]]}}}],["null",{"_index":293,"t":{"77":{"position":[[1232,5],[1998,5]]},"81":{"position":[[852,5],[2017,5]]},"85":{"position":[[3463,5],[3510,6]]},"95":{"position":[[1378,5],[6184,5]]},"117":{"position":[[1220,5],[1460,5],[1881,5]]},"131":{"position":[[513,5]]},"139":{"position":[[2843,5],[3029,5]]},"141":{"position":[[1191,5]]},"153":{"position":[[1309,5]]}}}],["number",{"_index":1045,"t":{"97":{"position":[[1165,6]]},"105":{"position":[[895,6],[1018,6]]},"113":{"position":[[964,6]]}}}],["number(math.sin(time",{"_index":2401,"t":{"165":{"position":[[3035,20]]}}}],["numbers",{"_index":2131,"t":{"147":{"position":[[1165,8]]}}}],["object",{"_index":692,"t":{"85":{"position":[[4770,7]]},"95":{"position":[[9311,6]]}}}],["object.addeventlistener('pointerenter",{"_index":1375,"t":{"119":{"position":[[1727,39]]}}}],["object.addeventlistener('pointerleave",{"_index":1377,"t":{"119":{"position":[[1777,39]]}}}],["object.addeventlistener('pointerout",{"_index":1379,"t":{"119":{"position":[[1876,37]]}}}],["object.addeventlistener('pointerover",{"_index":1378,"t":{"119":{"position":[[1827,38]]}}}],["object.assign(pixi.sprite.from('t1",{"_index":273,"t":{"77":{"position":[[632,37]]}}}],["object.assign(pixi.sprite.from('t2",{"_index":275,"t":{"77":{"position":[[704,37]]}}}],["object1",{"_index":97,"t":{"75":{"position":[[1003,9]]}}}],["object1.acceleration.x",{"_index":111,"t":{"75":{"position":[[1408,22]]}}}],["object1.acceleration.y",{"_index":113,"t":{"75":{"position":[[1457,22]]}}}],["object1.getbounds",{"_index":77,"t":{"75":{"position":[[620,20]]}}}],["object1.mass",{"_index":120,"t":{"75":{"position":[[1643,13]]}}}],["object1.x",{"_index":102,"t":{"75":{"position":[[1103,10],[1181,10],[1207,10]]}}}],["object1.y",{"_index":104,"t":{"75":{"position":[[1126,10],[1233,10],[1259,11]]}}}],["object2",{"_index":75,"t":{"75":{"position":[[593,8],[989,8],[1016,9]]}}}],["object2.acceleration.x",{"_index":112,"t":{"75":{"position":[[1433,23]]}}}],["object2.acceleration.y",{"_index":114,"t":{"75":{"position":[[1482,23]]}}}],["object2.getbounds",{"_index":79,"t":{"75":{"position":[[657,20]]}}}],["object2.mass",{"_index":121,"t":{"75":{"position":[[1659,14]]}}}],["object2.x",{"_index":101,"t":{"75":{"position":[[1091,9],[1168,10],[1194,10]]}}}],["object2.y",{"_index":103,"t":{"75":{"position":[[1114,9],[1220,10],[1246,10]]}}}],["object[property",{"_index":694,"t":{"85":{"position":[[4808,17]]}}}],["objects",{"_index":53,"t":{"75":{"position":[[341,7],[463,7],[939,7]]}}}],["offscreencanvas",{"_index":2545,"t":{"193":{"position":[[92,16]]}}}],["offset",{"_index":2119,"t":{"147":{"position":[[922,6]]},"163":{"position":[[1158,8],[3490,8]]}}}],["offsets",{"_index":2332,"t":{"163":{"position":[[3648,8]]}}}],["offsetx",{"_index":2851,"t":{"238":{"position":[[1010,7],[1420,7]]}}}],["offsety",{"_index":2852,"t":{"238":{"position":[[1053,7],[1456,7]]}}}],["old",{"_index":1673,"t":{"133":{"position":[[442,3]]}}}],["on('mousedown",{"_index":1381,"t":{"121":{"position":[[1342,16]]}}}],["on('mousemove",{"_index":1763,"t":{"137":{"position":[[1584,16]]}}}],["on('mouseout",{"_index":1385,"t":{"121":{"position":[[1477,15]]}}}],["on('mouseover",{"_index":1384,"t":{"121":{"position":[[1443,16]]}}}],["on('mouseup",{"_index":1382,"t":{"121":{"position":[[1376,14]]}}}],["on('mouseupoutside",{"_index":1383,"t":{"121":{"position":[[1406,21]]}}}],["on('pointerdown",{"_index":283,"t":{"77":{"position":[[1061,18]]},"115":{"position":[[1377,18]]},"121":{"position":[[1151,18]]},"123":{"position":[[411,18],[953,18],[1428,18],[2192,18]]},"127":{"position":[[724,18]]}}}],["on('pointermove",{"_index":288,"t":{"77":{"position":[[1156,18]]}}}],["on('pointerout",{"_index":1265,"t":{"115":{"position":[[1508,17]]},"121":{"position":[[1282,17]]},"123":{"position":[[499,17],[1041,17],[1516,17],[2280,17]]}}}],["on('pointerover",{"_index":1263,"t":{"115":{"position":[[1475,18]]},"121":{"position":[[1249,18]]},"123":{"position":[[452,18],[994,18],[1469,18],[2233,18]]}}}],["on('pointerup",{"_index":285,"t":{"77":{"position":[[1093,16]]},"115":{"position":[[1410,16]]},"121":{"position":[[1184,16]]},"127":{"position":[[756,16]]}}}],["on('pointerupoutside",{"_index":287,"t":{"77":{"position":[[1121,23]]},"115":{"position":[[1439,23]]},"121":{"position":[[1213,23]]},"127":{"position":[[784,23]]}}}],["on('touchend",{"_index":1387,"t":{"121":{"position":[[1569,15]]}}}],["on('touchendoutside",{"_index":1388,"t":{"121":{"position":[[1600,22]]}}}],["on('touchmove",{"_index":1765,"t":{"137":{"position":[[1616,16]]}}}],["on('touchstart",{"_index":1386,"t":{"121":{"position":[[1534,17]]}}}],["onassetsloaded",{"_index":527,"t":{"85":{"position":[[410,14],[462,16]]},"107":{"position":[[626,16]]}}}],["onassetsloaded(perlin",{"_index":1657,"t":{"131":{"position":[[2562,22]]}}}],["onbuttondown",{"_index":1261,"t":{"115":{"position":[[1396,13],[1828,14]]},"121":{"position":[[1170,13],[1359,13],[1552,13],[1923,14]]}}}],["onbuttonout",{"_index":1266,"t":{"115":{"position":[[1526,13],[2178,13]]},"121":{"position":[[1300,13],[1493,12],[2273,13]]}}}],["onbuttonover",{"_index":1264,"t":{"115":{"position":[[1494,13],[2067,14]]},"121":{"position":[[1268,13],[1460,13],[2162,14]]}}}],["onbuttonup",{"_index":1262,"t":{"115":{"position":[[1427,11],[1463,11],[1926,12]]},"121":{"position":[[1201,11],[1237,11],[1391,11],[1428,11],[1585,11],[1623,11],[2021,12]]}}}],["once",{"_index":781,"t":{"89":{"position":[[363,4]]},"127":{"position":[[1504,4],[1664,4]]}}}],["onchange",{"_index":689,"t":{"85":{"position":[[4730,9],[4856,9]]}}}],["onclick",{"_index":1155,"t":{"107":{"position":[[1150,9],[1169,9]]},"111":{"position":[[645,9],[725,9],[769,9],[830,9]]},"123":{"position":[[430,8],[972,8],[1447,8],[2211,8],[2973,9]]}}}],["oncomplete",{"_index":690,"t":{"85":{"position":[[4740,11],[4876,11]]}}}],["ondrag",{"_index":1505,"t":{"127":{"position":[[1627,8],[1792,8]]}}}],["ondrag(e",{"_index":1514,"t":{"127":{"position":[[1886,9]]}}}],["ondragend",{"_index":1302,"t":{"117":{"position":[[1316,11],[1361,11],[1772,11]]},"127":{"position":[[773,10],[808,11]]}}}],["ondragend(e",{"_index":1509,"t":{"127":{"position":[[1702,12]]}}}],["ondragmove",{"_index":1316,"t":{"117":{"position":[[1748,12],[1833,12]]}}}],["ondragmove(event",{"_index":1304,"t":{"117":{"position":[[1382,17]]}}}],["ondragstart",{"_index":1298,"t":{"117":{"position":[[1058,12],[1501,13]]},"127":{"position":[[743,12],[1537,13]]}}}],["one",{"_index":309,"t":{"77":{"position":[[1533,3]]},"119":{"position":[[810,3]]},"163":{"position":[[894,3]]}}}],["onevent",{"_index":1376,"t":{"119":{"position":[[1767,9],[1817,9],[1866,9],[1914,9]]}}}],["onevent(e",{"_index":1359,"t":{"119":{"position":[[1133,10]]}}}],["onloaded(data",{"_index":1532,"t":{"129":{"position":[[550,14]]}}}],["onplayvideo",{"_index":2602,"t":{"199":{"position":[[1059,13],[1082,13]]}}}],["onpointermove",{"_index":1764,"t":{"137":{"position":[[1601,14],[1633,15]]}}}],["onpointermove(eventdata",{"_index":1766,"t":{"137":{"position":[[1658,24]]}}}],["onpointerout",{"_index":1399,"t":{"123":{"position":[[517,13],[1059,13],[1534,13],[2298,13],[3069,14]]}}}],["onpointerover",{"_index":1398,"t":{"123":{"position":[[471,14],[1013,14],[1488,14],[2252,14],[3018,15]]}}}],["ontick",{"_index":973,"t":{"95":{"position":[[8103,6]]}}}],["ontick.foreach((cb",{"_index":987,"t":{"95":{"position":[[8428,19]]}}}],["onto",{"_index":1787,"t":{"139":{"position":[[231,4]]}}}],["opt",{"_index":1177,"t":{"111":{"position":[[451,3]]}}}],["optimal",{"_index":1550,"t":{"131":{"position":[[77,7]]}}}],["options",{"_index":52,"t":{"75":{"position":[[325,7]]},"205":{"position":[[697,7]]}}}],["order",{"_index":1320,"t":{"119":{"position":[[58,5],[323,5]]}}}],["original",{"_index":999,"t":{"95":{"position":[[8692,8]]},"139":{"position":[[937,8]]}}}],["out",{"_index":13,"t":{"73":{"position":[[135,3]]},"75":{"position":[[3486,3],[4351,3],[4470,3]]},"77":{"position":[[1425,3]]},"139":{"position":[[4541,3],[4661,5],[5490,5]]}}}],["outcolor",{"_index":2282,"t":{"163":{"position":[[1355,8],[1429,9],[3580,8],[3657,8],[3735,8],[3814,8],[3895,8]]}}}],["outdir",{"_index":948,"t":{"95":{"position":[[6083,6],[6555,6]]}}}],["outdir[0",{"_index":953,"t":{"95":{"position":[[7119,9]]}}}],["outdir[1",{"_index":954,"t":{"95":{"position":[[7162,9]]}}}],["outdir[i",{"_index":952,"t":{"95":{"position":[[6564,10]]}}}],["outer",{"_index":1342,"t":{"119":{"position":[[602,5]]}}}],["outline",{"_index":2163,"t":{"151":{"position":[[864,7]]}}}],["output",{"_index":2292,"t":{"163":{"position":[[1646,6]]}}}],["outputframe",{"_index":1685,"t":{"133":{"position":[[775,12]]}}}],["outputframe.xy",{"_index":1688,"t":{"133":{"position":[[870,15],[1095,15]]}}}],["outputframe.zw",{"_index":1698,"t":{"133":{"position":[[1113,15]]}}}],["outputsprite",{"_index":2774,"t":{"211":{"position":[[530,12]]}}}],["outputsprite.anchor.set(0.5",{"_index":2778,"t":{"211":{"position":[[642,29]]}}}],["outputsprite.scale.set(1",{"_index":2814,"t":{"211":{"position":[[2030,24]]}}}],["outputsprite.texture",{"_index":2811,"t":{"211":{"position":[[1941,20]]}}}],["outputsprite.x",{"_index":2776,"t":{"211":{"position":[[598,14]]}}}],["outputsprite.y",{"_index":2777,"t":{"211":{"position":[[620,14]]}}}],["over",{"_index":669,"t":{"85":{"position":[[4209,4]]},"97":{"position":[[1221,4]]},"105":{"position":[[1074,4]]},"113":{"position":[[1022,4]]},"117":{"position":[[789,4]]},"119":{"position":[[297,4]]},"125":{"position":[[109,4]]},"139":{"position":[[5435,4]]},"147":{"position":[[1115,4]]}}}],["override",{"_index":1817,"t":{"139":{"position":[[1148,8]]}}}],["p",{"_index":406,"t":{"81":{"position":[[1394,1],[2163,1]]},"131":{"position":[[1226,2],[1456,2],[2195,1]]},"165":{"position":[[1145,2],[1323,2],[2043,1]]}}}],["p.x",{"_index":418,"t":{"81":{"position":[[1616,3]]}}}],["p.y",{"_index":419,"t":{"81":{"position":[[1626,3]]}}}],["p.y)*0.04).r*5.1",{"_index":1594,"t":{"131":{"position":[[1320,17]]},"165":{"position":[[1239,17]]}}}],["p.z,id",{"_index":1599,"t":{"131":{"position":[[1404,8]]},"165":{"position":[[1271,8]]}}}],["p1.x",{"_index":127,"t":{"75":{"position":[[1863,4]]}}}],["p1.y",{"_index":130,"t":{"75":{"position":[[1886,4]]}}}],["p2",{"_index":126,"t":{"75":{"position":[[1847,3]]}}}],["p2.x",{"_index":128,"t":{"75":{"position":[[1870,5]]}}}],["p2.y",{"_index":131,"t":{"75":{"position":[[1893,5]]}}}],["p[0",{"_index":435,"t":{"81":{"position":[[2291,4]]}}}],["p[1",{"_index":437,"t":{"81":{"position":[[2346,4]]}}}],["padding",{"_index":1730,"t":{"137":{"position":[[235,7],[286,8],[296,8],[324,7],[357,7]]}}}],["page",{"_index":3,"t":{"73":{"position":[[31,5]]}}}],["panda",{"_index":1964,"t":{"141":{"position":[[884,5]]},"153":{"position":[[813,5],[945,7]]}}}],["panda.anchor.set(0.5",{"_index":1966,"t":{"141":{"position":[[949,22]]},"153":{"position":[[878,22]]}}}],["panda.scale.x",{"_index":1978,"t":{"141":{"position":[[1543,13]]},"153":{"position":[[1658,13]]}}}],["panda.scale.y",{"_index":1979,"t":{"141":{"position":[[1587,13]]},"153":{"position":[[1702,13]]}}}],["parallel",{"_index":1012,"t":{"95":{"position":[[8999,8]]}}}],["particular",{"_index":1312,"t":{"117":{"position":[[1639,10]]}}}],["pass",{"_index":1842,"t":{"139":{"position":[[1899,4],[2111,4],[2343,4]]},"163":{"position":[[1004,5],[1629,4],[1905,5],[4365,4]]},"207":{"position":[[327,4]]}}}],["passes",{"_index":2264,"t":{"163":{"position":[[539,7],[5711,6]]}}}],["path",{"_index":1164,"t":{"109":{"position":[[183,5]]},"115":{"position":[[744,4]]},"117":{"position":[[183,4]]},"121":{"position":[[408,4]]},"151":{"position":[[2244,4]]},"187":{"position":[[278,4]]},"189":{"position":[[186,4]]},"195":{"position":[[160,4]]},"199":{"position":[[1182,4]]}}}],["paths",{"_index":1137,"t":{"107":{"position":[[695,5]]}}}],["paul",{"_index":993,"t":{"95":{"position":[[8518,4]]}}}],["people",{"_index":2727,"t":{"207":{"position":[[1091,6]]}}}],["per",{"_index":2747,"t":{"207":{"position":[[1803,3]]}}}],["performance",{"_index":920,"t":{"95":{"position":[[4525,11]]},"189":{"position":[[599,11]]}}}],["performant",{"_index":1559,"t":{"131":{"position":[[237,10]]}}}],["perlin",{"_index":1658,"t":{"131":{"position":[[2594,6],[2839,7]]}}}],["perlin.basetexture.mipmap",{"_index":1663,"t":{"131":{"position":[[2723,25]]}}}],["perlin.basetexture.wrapmode",{"_index":1661,"t":{"131":{"position":[[2669,27]]}}}],["perlinnoise",{"_index":2266,"t":{"163":{"position":[[870,11]]}}}],["perlintexture",{"_index":2268,"t":{"163":{"position":[[920,13],[3031,14]]}}}],["phase",{"_index":701,"t":{"85":{"position":[[5122,5],[5277,6]]},"95":{"position":[[870,5],[911,5],[917,5],[938,5],[2783,5],[2824,5],[2830,5],[2851,5],[2971,7],[3615,5],[3656,5],[3662,5],[3683,5],[3757,5],[5377,5],[5418,5],[5424,5],[5446,5],[7971,5],[8012,5],[8018,5],[8038,5],[8084,6]]},"163":{"position":[[2060,6],[2373,6]]}}}],["phases",{"_index":2372,"t":{"163":{"position":[[5175,6],[5202,6]]}}}],["physics",{"_index":42,"t":{"75":{"position":[[201,7]]}}}],["pi*2",{"_index":1115,"t":{"105":{"position":[[916,4]]}}}],["pixel",{"_index":2700,"t":{"207":{"position":[[401,5]]}}}],["pixelation",{"_index":1171,"t":{"111":{"position":[[193,10]]},"117":{"position":[[280,10]]}}}],["pixels",{"_index":2126,"t":{"147":{"position":[[1038,6]]}}}],["pixi",{"_index":27,"t":{"75":{"position":[[12,4]]},"77":{"position":[[12,4]]},"79":{"position":[[12,4]]},"81":{"position":[[12,4]]},"83":{"position":[[12,4]]},"85":{"position":[[12,4]]},"87":{"position":[[12,4]]},"89":{"position":[[12,4]]},"91":{"position":[[12,4]]},"93":{"position":[[12,4]]},"95":{"position":[[12,4],[8710,4]]},"97":{"position":[[12,4]]},"99":{"position":[[12,4]]},"101":{"position":[[12,4]]},"103":{"position":[[12,4]]},"105":{"position":[[12,4]]},"107":{"position":[[12,4]]},"109":{"position":[[12,4]]},"111":{"position":[[12,4]]},"113":{"position":[[12,4]]},"115":{"position":[[12,4]]},"117":{"position":[[12,4]]},"119":{"position":[[12,4]]},"121":{"position":[[12,4]]},"123":{"position":[[12,4]]},"125":{"position":[[12,4]]},"127":{"position":[[12,4]]},"129":{"position":[[12,4]]},"131":{"position":[[12,4]]},"133":{"position":[[12,4]]},"135":{"position":[[12,4]]},"137":{"position":[[12,4]]},"139":{"position":[[12,4]]},"141":{"position":[[12,4]]},"143":{"position":[[12,4]]},"145":{"position":[[12,4]]},"147":{"position":[[12,4]]},"149":{"position":[[12,4]]},"151":{"position":[[12,4]]},"153":{"position":[[12,4]]},"155":{"position":[[12,4]]},"157":{"position":[[12,4]]},"159":{"position":[[12,4]]},"161":{"position":[[12,4]]},"163":{"position":[[12,4]]},"165":{"position":[[12,4]]},"167":{"position":[[12,4]]},"169":{"position":[[12,4]]},"171":{"position":[[12,4]]},"173":{"position":[[12,4]]},"175":{"position":[[12,4]]},"177":{"position":[[12,4]]},"179":{"position":[[12,4]]},"181":{"position":[[12,4]]},"183":{"position":[[12,4]]},"185":{"position":[[12,4]]},"187":{"position":[[12,4],[428,4],[687,4]]},"189":{"position":[[12,4]]},"191":{"position":[[12,4]]},"193":{"position":[[12,4]]},"195":{"position":[[12,4]]},"197":{"position":[[12,4]]},"199":{"position":[[12,4],[806,4],[970,5]]},"201":{"position":[[12,4]]},"203":{"position":[[12,4]]},"205":{"position":[[12,4],[196,7]]},"207":{"position":[[12,4]]},"209":{"position":[[12,4]]},"211":{"position":[[12,4]]},"213":{"position":[[12,4]]},"238":{"position":[[12,4],[773,4]]}}}],["pixi.animatedsprite(explosiontextures",{"_index":2507,"t":{"185":{"position":[[522,39]]}}}],["pixi.animatedsprite(frames",{"_index":2528,"t":{"187":{"position":[[602,28]]}}}],["pixi.animatedsprite(textures",{"_index":2485,"t":{"183":{"position":[[584,30],[855,30]]}}}],["pixi.application",{"_index":46,"t":{"75":{"position":[[225,18]]},"77":{"position":[[49,18]]},"79":{"position":[[49,18]]},"81":{"position":[[49,18]]},"83":{"position":[[49,18]]},"85":{"position":[[49,18]]},"87":{"position":[[49,18]]},"89":{"position":[[49,18]]},"91":{"position":[[49,18]]},"93":{"position":[[49,18]]},"95":{"position":[[49,18]]},"97":{"position":[[49,18]]},"99":{"position":[[49,18]]},"101":{"position":[[49,18]]},"103":{"position":[[49,18]]},"105":{"position":[[49,18]]},"107":{"position":[[49,18]]},"109":{"position":[[49,18]]},"111":{"position":[[49,18]]},"113":{"position":[[49,18]]},"115":{"position":[[49,18]]},"117":{"position":[[49,18]]},"119":{"position":[[125,18]]},"121":{"position":[[49,18]]},"125":{"position":[[142,18]]},"127":{"position":[[49,18]]},"129":{"position":[[49,18]]},"131":{"position":[[321,18]]},"133":{"position":[[117,18]]},"135":{"position":[[49,18]]},"137":{"position":[[49,18]]},"139":{"position":[[264,18]]},"141":{"position":[[49,18]]},"143":{"position":[[49,18]]},"145":{"position":[[49,18]]},"147":{"position":[[49,18]]},"149":{"position":[[49,18]]},"151":{"position":[[81,18]]},"153":{"position":[[49,18]]},"155":{"position":[[49,18]]},"157":{"position":[[49,18]]},"159":{"position":[[49,18]]},"161":{"position":[[49,18]]},"163":{"position":[[49,18]]},"165":{"position":[[49,18]]},"167":{"position":[[49,18]]},"169":{"position":[[49,18]]},"171":{"position":[[49,18]]},"173":{"position":[[49,18]]},"175":{"position":[[49,18]]},"177":{"position":[[49,18]]},"179":{"position":[[49,18]]},"181":{"position":[[49,18]]},"183":{"position":[[49,18]]},"185":{"position":[[49,18]]},"187":{"position":[[49,18]]},"189":{"position":[[49,18]]},"191":{"position":[[49,18]]},"193":{"position":[[224,18]]},"195":{"position":[[49,18]]},"197":{"position":[[49,18]]},"199":{"position":[[49,18]]},"201":{"position":[[49,18]]},"203":{"position":[[49,18]]},"205":{"position":[[49,18]]},"207":{"position":[[1533,18]]},"209":{"position":[[187,18]]},"211":{"position":[[49,18]]},"213":{"position":[[49,18]]},"238":{"position":[[49,18]]}}}],["pixi.application(800",{"_index":1389,"t":{"123":{"position":[[49,21]]}}}],["pixi.assets.add('egghead",{"_index":780,"t":{"89":{"position":[[248,26]]},"93":{"position":[[248,26]]}}}],["pixi.assets.add('flowertop",{"_index":779,"t":{"89":{"position":[[175,28]]},"93":{"position":[[175,28]]}}}],["pixi.assets.add('t1",{"_index":263,"t":{"77":{"position":[[344,21]]}}}],["pixi.assets.add('t2",{"_index":265,"t":{"77":{"position":[[409,21]]}}}],["pixi.assets.addbundle('fonts",{"_index":2615,"t":{"201":{"position":[[177,30]]}}}],["pixi.assets.backgroundload(['flowertop",{"_index":811,"t":{"93":{"position":[[363,40]]}}}],["pixi.assets.backgroundloadbundle(['load",{"_index":737,"t":{"87":{"position":[[556,39]]}}}],["pixi.assets.init",{"_index":735,"t":{"87":{"position":[[459,18]]}}}],["pixi.assets.load",{"_index":517,"t":{"85":{"position":[[149,18]]}}}],["pixi.assets.load('egghead').then((texture",{"_index":816,"t":{"93":{"position":[[517,42]]}}}],["pixi.assets.load('https://pixijs.com/assets/bg_grass.jpg').then((grasstexture",{"_index":2136,"t":{"149":{"position":[[216,78]]}}}],["pixi.assets.load('https://pixijs.com/assets/bg_grass.jpg').then((texture",{"_index":1092,"t":{"103":{"position":[[149,73]]}}}],["pixi.assets.load('https://pixijs.com/assets/bitmap",{"_index":2563,"t":{"197":{"position":[[149,50]]}}}],["pixi.assets.load('https://pixijs.com/assets/bunny.png",{"_index":804,"t":{"91":{"position":[[221,56]]},"101":{"position":[[246,56]]}}}],["pixi.assets.load('https://pixijs.com/assets/flowertop.png').then((texture",{"_index":2830,"t":{"238":{"position":[[126,74]]}}}],["pixi.assets.load('https://pixijs.com/assets/perlin.jpg').then(onassetsloaded",{"_index":1562,"t":{"131":{"position":[[421,78]]}}}],["pixi.assets.load('https://pixijs.com/assets/spritesheet/0123456789.json').then((spritesheet",{"_index":2476,"t":{"183":{"position":[[144,92]]}}}],["pixi.assets.load('https://pixijs.com/assets/spritesheet/fighter.json').then",{"_index":2515,"t":{"187":{"position":[[149,78]]}}}],["pixi.assets.load('https://pixijs.com/assets/spritesheet/mc.json').then",{"_index":2501,"t":{"185":{"position":[[144,73]]}}}],["pixi.assets.load('https://pixijs.com/assets/spritesheet/monsters.json",{"_index":1123,"t":{"107":{"position":[[156,71]]}}}],["pixi.assets.load(['flowertop",{"_index":783,"t":{"89":{"position":[[408,30]]}}}],["pixi.assets.load(['t1",{"_index":267,"t":{"77":{"position":[[475,23]]}}}],["pixi.assets.load(isegghead",{"_index":831,"t":{"93":{"position":[[1065,26]]}}}],["pixi.assets.loadbundle('fonts').then",{"_index":2627,"t":{"201":{"position":[[503,39]]}}}],["pixi.assets.loadbundle('game",{"_index":766,"t":{"87":{"position":[[1503,28]]}}}],["pixi.assets.loadbundle('load",{"_index":746,"t":{"87":{"position":[[826,28]]}}}],["pixi.basetexture(new",{"_index":2742,"t":{"207":{"position":[[1655,20]]}}}],["pixi.bitmapfont.from('coordinates",{"_index":1927,"t":{"139":{"position":[[4730,35]]}}}],["pixi.bitmaptext",{"_index":2566,"t":{"197":{"position":[[259,16]]}}}],["pixi.bitmaptext('global",{"_index":1930,"t":{"139":{"position":[[4897,24]]}}}],["pixi.blend_modes.add",{"_index":394,"t":{"81":{"position":[[784,21]]},"97":{"position":[[1030,21]]}}}],["pixi.buffer(new",{"_index":2243,"t":{"159":{"position":[[334,15]]}}}],["pixi.container",{"_index":326,"t":{"79":{"position":[[252,17]]},"85":{"position":[[845,17],[908,17]]},"95":{"position":[[339,17],[2317,17],[3231,17],[4272,17],[7450,17]]},"99":{"position":[[171,17]]},"107":{"position":[[453,17]]},"133":{"position":[[1170,17]]},"137":{"position":[[180,17]]},"139":{"position":[[886,17]]},"141":{"position":[[384,17]]},"147":{"position":[[180,17]]},"153":{"position":[[372,17]]},"163":{"position":[[1843,17],[2655,17],[3291,17],[4292,17]]},"173":{"position":[[431,17]]},"193":{"position":[[349,17]]},"211":{"position":[[749,17]]},"213":{"position":[[171,17]]}}}],["pixi.displayobject",{"_index":1804,"t":{"139":{"position":[[770,18]]}}}],["pixi.eventboundary(this.content",{"_index":1816,"t":{"139":{"position":[[1111,33]]}}}],["pixi.eventboundary.prototype.copymousedata.call(this.boundary",{"_index":1825,"t":{"139":{"position":[[1307,62]]}}}],["pixi.filter(null",{"_index":1536,"t":{"129":{"position":[[647,17]]},"131":{"position":[[2791,17]]},"133":{"position":[[1340,17]]}}}],["pixi.filters.blurfilter",{"_index":547,"t":{"85":{"position":[[1064,26]]},"135":{"position":[[724,26],[775,26]]}}}],["pixi.filters.blurfilter(blursize",{"_index":2141,"t":{"149":{"position":[[606,35]]}}}],["pixi.filters.colormatrixfilter",{"_index":1952,"t":{"141":{"position":[[328,33]]}}}],["pixi.filters.displacementfilter(displacementsprite",{"_index":1749,"t":{"137":{"position":[[1012,52]]},"147":{"position":[[622,52]]}}}],["pixi.geometry",{"_index":2210,"t":{"157":{"position":[[147,15]]},"159":{"position":[[147,15]]},"161":{"position":[[147,15],[499,15]]},"163":{"position":[[179,15]]},"165":{"position":[[166,15]]},"167":{"position":[[147,15]]},"169":{"position":[[147,15]]},"175":{"position":[[147,15]]},"177":{"position":[[147,15]]},"179":{"position":[[147,15]]},"181":{"position":[[147,15]]}}}],["pixi.geometry.merge([geometry",{"_index":2261,"t":{"161":{"position":[[839,30]]}}}],["pixi.graphics",{"_index":255,"t":{"77":{"position":[[194,15],[327,16]]},"85":{"position":[[1860,16],[1963,16]]},"95":{"position":[[692,16],[3465,16],[4617,16],[4900,16],[5187,16],[7553,16],[7753,16]]},"119":{"position":[[658,15],[853,15]]},"123":{"position":[[1287,15],[1812,15]]},"125":{"position":[[301,15]]},"127":{"position":[[362,15],[544,15]]},"139":{"position":[[3403,15],[3606,15]]},"143":{"position":[[323,16],[581,16],[808,16],[1076,16],[1323,16],[1475,16],[1638,16],[1839,16],[2204,16]]},"145":{"position":[[228,16],[1324,16]]},"149":{"position":[[477,15]]},"151":{"position":[[196,16]]},"153":{"position":[[1033,16]]},"171":{"position":[[453,16]]},"199":{"position":[[225,15]]}}}],["pixi.groupd8",{"_index":2833,"t":{"238":{"position":[[272,13]]}}}],["pixi.js",{"_index":28,"t":{"75":{"position":[[22,10]]},"77":{"position":[[22,10]]},"79":{"position":[[22,10]]},"81":{"position":[[22,10]]},"83":{"position":[[22,10]]},"85":{"position":[[22,10]]},"87":{"position":[[22,10]]},"89":{"position":[[22,10]]},"91":{"position":[[22,10]]},"93":{"position":[[22,10]]},"95":{"position":[[22,10]]},"97":{"position":[[22,10]]},"99":{"position":[[22,10]]},"101":{"position":[[22,10]]},"103":{"position":[[22,10]]},"105":{"position":[[22,10]]},"107":{"position":[[22,10]]},"109":{"position":[[22,10]]},"111":{"position":[[22,10]]},"113":{"position":[[22,10]]},"115":{"position":[[22,10]]},"117":{"position":[[22,10]]},"119":{"position":[[22,10]]},"121":{"position":[[22,10]]},"123":{"position":[[22,10]]},"125":{"position":[[22,10]]},"127":{"position":[[22,10]]},"129":{"position":[[22,10]]},"131":{"position":[[22,10]]},"133":{"position":[[22,10]]},"135":{"position":[[22,10]]},"137":{"position":[[22,10]]},"139":{"position":[[22,10]]},"141":{"position":[[22,10]]},"143":{"position":[[22,10]]},"145":{"position":[[22,10]]},"147":{"position":[[22,10]]},"149":{"position":[[22,10]]},"151":{"position":[[22,10]]},"153":{"position":[[22,10]]},"155":{"position":[[22,10]]},"157":{"position":[[22,10]]},"159":{"position":[[22,10]]},"161":{"position":[[22,10]]},"163":{"position":[[22,10]]},"165":{"position":[[22,10]]},"167":{"position":[[22,10]]},"169":{"position":[[22,10]]},"171":{"position":[[22,10]]},"173":{"position":[[22,10]]},"175":{"position":[[22,10]]},"177":{"position":[[22,10]]},"179":{"position":[[22,10]]},"181":{"position":[[22,10]]},"183":{"position":[[22,10]]},"185":{"position":[[22,10]]},"187":{"position":[[22,10]]},"189":{"position":[[22,10]]},"191":{"position":[[22,10]]},"193":{"position":[[22,10]]},"195":{"position":[[22,10]]},"197":{"position":[[22,10]]},"199":{"position":[[22,10]]},"201":{"position":[[22,10]]},"203":{"position":[[22,10]]},"205":{"position":[[22,10]]},"207":{"position":[[22,10]]},"209":{"position":[[22,10]]},"211":{"position":[[22,10]]},"213":{"position":[[22,10]]},"238":{"position":[[22,10]]}}}],["pixi.matrix",{"_index":1812,"t":{"139":{"position":[[997,14],[2683,14]]}}}],["pixi.mesh(geometry",{"_index":2233,"t":{"157":{"position":[[1057,19]]},"159":{"position":[[1429,19]]},"163":{"position":[[1784,19],[2592,19],[3230,19],[4233,19],[4942,19]]},"165":{"position":[[2772,19]]},"167":{"position":[[929,19],[1088,19],[1241,19]]},"169":{"position":[[1612,19],[1663,19]]},"175":{"position":[[610,19]]},"177":{"position":[[907,19]]},"179":{"position":[[1329,19]]},"181":{"position":[[1200,19]]}}}],["pixi.mesh(geometry3",{"_index":2262,"t":{"161":{"position":[[1449,20]]}}}],["pixi.particlecontainer(10000",{"_index":1198,"t":{"113":{"position":[[146,29]]}}}],["pixi.point",{"_index":100,"t":{"75":{"position":[[1079,11],[1301,11],[1396,11],[1685,11],[4018,11],[4223,11]]},"77":{"position":[[1822,13]]},"133":{"position":[[1383,13]]},"137":{"position":[[803,13]]},"155":{"position":[[541,13]]}}}],["pixi.point(0",{"_index":98,"t":{"75":{"position":[[1039,14],[2221,14],[2476,14]]},"81":{"position":[[650,13]]}}}],["pixi.point(160",{"_index":977,"t":{"95":{"position":[[8177,15]]}}}],["pixi.point(270",{"_index":979,"t":{"95":{"position":[[8220,15]]}}}],["pixi.point(380",{"_index":981,"t":{"95":{"position":[[8263,15]]}}}],["pixi.point(490",{"_index":983,"t":{"95":{"position":[[8306,15]]}}}],["pixi.point(50",{"_index":975,"t":{"95":{"position":[[8135,14]]}}}],["pixi.point(i",{"_index":2431,"t":{"171":{"position":[[247,12]]},"173":{"position":[[253,12]]}}}],["pixi.polygon",{"_index":1405,"t":{"123":{"position":[[771,14],[2010,14]]}}}],["pixi.program.from",{"_index":2403,"t":{"167":{"position":[[446,19]]}}}],["pixi.rectangle",{"_index":1059,"t":{"97":{"position":[[1595,15]]},"105":{"position":[[1448,15]]},"113":{"position":[[1462,15]]},"137":{"position":[[269,15]]},"139":{"position":[[3929,15]]}}}],["pixi.rectangle(0",{"_index":2142,"t":{"149":{"position":[[661,17]]}}}],["pixi.rectangle(100",{"_index":1700,"t":{"133":{"position":[[1215,19]]}}}],["pixi.rectangle(texture.frame.x",{"_index":2839,"t":{"238":{"position":[[532,31]]}}}],["pixi.renderer",{"_index":1206,"t":{"113":{"position":[[389,13]]}}}],["pixi.rendertexture.create",{"_index":2294,"t":{"163":{"position":[[1707,27],[2513,27],[3152,27],[4156,27]]},"213":{"position":[[511,27]]}}}],["pixi.rendertexture.create(stagesize",{"_index":277,"t":{"77":{"position":[[776,37]]},"211":{"position":[[320,37],[379,37]]}}}],["pixi.resource",{"_index":2696,"t":{"207":{"position":[[292,13]]}}}],["pixi.scale_modes.linear",{"_index":2819,"t":{"213":{"position":[[575,24]]}}}],["pixi.scale_modes.nearest",{"_index":1173,"t":{"111":{"position":[[231,25]]},"117":{"position":[[323,25]]},"127":{"position":[[1063,25]]},"149":{"position":[[786,25]]}}}],["pixi.settings.scale_mode",{"_index":1172,"t":{"111":{"position":[[204,24]]}}}],["pixi.shader(program",{"_index":2407,"t":{"167":{"position":[[953,20],[1112,20],[1265,20]]}}}],["pixi.shader.from",{"_index":2218,"t":{"157":{"position":[[506,18]]},"159":{"position":[[986,18]]},"161":{"position":[[898,18]]},"169":{"position":[[381,18],[930,18]]},"175":{"position":[[243,18]]},"177":{"position":[[465,18]]}}}],["pixi.shader.from(vertexsrc",{"_index":2287,"t":{"163":{"position":[[1498,27],[2427,27],[3069,27],[4076,27],[4852,27]]},"165":{"position":[[2703,27]]},"179":{"position":[[1256,27]]},"181":{"position":[[1131,27]]}}}],["pixi.simpleplane(texture",{"_index":1094,"t":{"103":{"position":[[246,25]]}}}],["pixi.simplerope(pixi.texture.from('https://pixijs.com/assets/snake.png",{"_index":2433,"t":{"171":{"position":[[299,73]]},"173":{"position":[[305,73]]}}}],["pixi.simplerope(trailtexture",{"_index":391,"t":{"81":{"position":[[707,29]]}}}],["pixi.sprite(currenttexture",{"_index":2775,"t":{"211":{"position":[[549,28]]}}}],["pixi.sprite(gradtexture",{"_index":2754,"t":{"207":{"position":[[1981,25]]},"209":{"position":[[919,25]]}}}],["pixi.sprite(grasstexture",{"_index":2137,"t":{"149":{"position":[[323,26]]}}}],["pixi.sprite(loadscreenassets.egghead",{"_index":768,"t":{"87":{"position":[[1617,38]]}}}],["pixi.sprite(loadscreenassets.flowertop",{"_index":749,"t":{"87":{"position":[[940,40]]}}}],["pixi.sprite(pixi.texture.white",{"_index":136,"t":{"75":{"position":[[1990,32],[2310,32]]}}}],["pixi.sprite(rendertexture",{"_index":279,"t":{"77":{"position":[[846,27]]}}}],["pixi.sprite(rt",{"_index":2821,"t":{"213":{"position":[[638,16]]}}}],["pixi.sprite(slottextures[math.floor(math.random",{"_index":555,"t":{"85":{"position":[[1232,49]]}}}],["pixi.sprite(startexture",{"_index":452,"t":{"83":{"position":[[503,25]]}}}],["pixi.sprite(texture",{"_index":343,"t":{"79":{"position":[[680,21]]},"93":{"position":[[707,21]]},"99":{"position":[[399,21]]},"117":{"position":[[574,21]]},"149":{"position":[[842,21]]},"191":{"position":[[393,21]]},"193":{"position":[[577,21]]},"199":{"position":[[1353,21]]},"213":{"position":[[343,21]]}}}],["pixi.sprite(texturebutton",{"_index":1253,"t":{"115":{"position":[[1156,27]]},"121":{"position":[[820,27]]}}}],["pixi.sprite(textures[i",{"_index":2858,"t":{"238":{"position":[[1296,22]]}}}],["pixi.sprite(yellowstar",{"_index":1394,"t":{"123":{"position":[[273,24],[594,24],[1137,24],[1727,24]]}}}],["pixi.sprite.from('https://pixijs.com/assets/bg_button.jpg",{"_index":1235,"t":{"115":{"position":[[507,60]]},"121":{"position":[[171,60]]}}}],["pixi.sprite.from('https://pixijs.com/assets/bg_grass.jpg",{"_index":1523,"t":{"129":{"position":[[172,59]]},"133":{"position":[[240,59]]},"137":{"position":[[1414,59]]}}}],["pixi.sprite.from('https://pixijs.com/assets/bg_plane.jpg",{"_index":2195,"t":{"155":{"position":[[169,59]]}}}],["pixi.sprite.from('https://pixijs.com/assets/bg_rotate.jpg",{"_index":842,"t":{"95":{"position":[[571,60]]},"97":{"position":[[179,60]]},"141":{"position":[[169,60]]},"143":{"position":[[158,60]]},"153":{"position":[[186,60]]}}}],["pixi.sprite.from('https://pixijs.com/assets/bg_scene_rotate.jpg",{"_index":838,"t":{"95":{"position":[[432,66],[3324,66],[4405,66]]},"141":{"position":[[491,66]]},"153":{"position":[[505,66]]}}}],["pixi.sprite.from('https://pixijs.com/assets/bunny.png",{"_index":1165,"t":{"109":{"position":[[203,56]]},"111":{"position":[[272,56]]},"189":{"position":[[205,56]]}}}],["pixi.sprite.from('https://pixijs.com/assets/cells.png",{"_index":2197,"t":{"155":{"position":[[267,56]]}}}],["pixi.sprite.from('https://pixijs.com/assets/circle.png",{"_index":890,"t":{"95":{"position":[[2507,57]]}}}],["pixi.sprite.from('https://pixijs.com/assets/egghead.png",{"_index":1109,"t":{"105":{"position":[[335,58]]}}}],["pixi.sprite.from('https://pixijs.com/assets/flowertop.png",{"_index":1029,"t":{"97":{"position":[[583,60]]},"155":{"position":[[359,60]]}}}],["pixi.sprite.from('https://pixijs.com/assets/light_rotate_1.png",{"_index":1961,"t":{"141":{"position":[[760,65]]},"153":{"position":[[717,65]]}}}],["pixi.sprite.from('https://pixijs.com/assets/light_rotate_2.png",{"_index":1957,"t":{"141":{"position":[[627,65]]},"153":{"position":[[612,65]]}}}],["pixi.sprite.from('https://pixijs.com/assets/maggot.png",{"_index":1732,"t":{"137":{"position":[[439,57]]}}}],["pixi.sprite.from('https://pixijs.com/assets/maggot_tiny.png",{"_index":1208,"t":{"113":{"position":[[495,62]]}}}],["pixi.sprite.from('https://pixijs.com/assets/panda.png",{"_index":1965,"t":{"141":{"position":[[892,56]]},"153":{"position":[[821,56]]}}}],["pixi.sprite.from('https://pixijs.com/assets/pixi",{"_index":1704,"t":{"135":{"position":[[137,48],[319,48],[520,48]]},"137":{"position":[[908,48],[1264,48]]},"147":{"position":[[242,48],[392,48]]}}}],["pixi.sprite.from(framename",{"_index":1141,"t":{"107":{"position":[[827,28]]}}}],["pixi.sprite.from(fruits[i",{"_index":2798,"t":{"211":{"position":[[1438,25]]}}}],["pixi.sprite.from(resolvedtexture",{"_index":806,"t":{"91":{"position":[[442,34]]}}}],["pixi.sprite.from(texture",{"_index":1091,"t":{"101":{"position":[[372,26]]}}}],["pixi.sprite.from(textures.egghead",{"_index":795,"t":{"89":{"position":[[838,35]]}}}],["pixi.sprite.from(textures.flowertop",{"_index":788,"t":{"89":{"position":[[666,37]]}}}],["pixi.text",{"_index":1326,"t":{"119":{"position":[[262,10],[501,13]]},"139":{"position":[[5313,10]]},"203":{"position":[[782,10]]}}}],["pixi.text('basic",{"_index":2663,"t":{"205":{"position":[[171,16]]}}}],["pixi.text('chachicle.ttf",{"_index":2628,"t":{"201":{"position":[[566,26]]}}}],["pixi.text('click",{"_index":366,"t":{"79":{"position":[[1143,16]]},"141":{"position":[[1218,16]]},"153":{"position":[[1338,16]]}}}],["pixi.text('crosterian.woff2",{"_index":2631,"t":{"201":{"position":[[900,29]]}}}],["pixi.text('dotrice",{"_index":2630,"t":{"201":{"position":[[778,18]]}}}],["pixi.text('drag",{"_index":1497,"t":{"127":{"position":[[1216,15]]}}}],["pixi.text('hit",{"_index":1448,"t":{"123":{"position":[[2508,14]]}}}],["pixi.text('lineal.otf",{"_index":2629,"t":{"201":{"position":[[675,23]]}}}],["pixi.text('mask",{"_index":1455,"t":{"123":{"position":[[2617,17],[2722,15]]}}}],["pixi.text('pixi",{"_index":618,"t":{"85":{"position":[[2719,15]]}}}],["pixi.text('pixijs",{"_index":1563,"t":{"131":{"position":[[536,19]]}}}],["pixi.text('rich",{"_index":2670,"t":{"205":{"position":[[662,15]]}}}],["pixi.text('skew",{"_index":2682,"t":{"205":{"position":[[1140,15]]}}}],["pixi.text('spin",{"_index":607,"t":{"85":{"position":[[2464,15]]}}}],["pixi.text('standard",{"_index":1441,"t":{"123":{"position":[[2399,21]]}}}],["pixi.text(`rotate",{"_index":2861,"t":{"238":{"position":[[1530,17]]}}}],["pixi.textstyle",{"_index":360,"t":{"79":{"position":[[1059,16]]},"85":{"position":[[2111,16]]},"123":{"position":[[2344,16]]},"201":{"position":[[597,16],[703,16],[816,16],[934,16]]},"205":{"position":[[290,16],[828,16]]}}}],["pixi.texture(gradbasetexture",{"_index":2753,"t":{"207":{"position":[[1931,30]]}}}],["pixi.texture(texture.basetexture",{"_index":2843,"t":{"238":{"position":[[672,33],[878,33]]}}}],["pixi.texture.from('https://pixijs.com/assets/bg_displacement.jpg",{"_index":2411,"t":{"167":{"position":[[1305,67]]}}}],["pixi.texture.from('https://pixijs.com/assets/bg_rotate.jpg",{"_index":2409,"t":{"167":{"position":[[1152,61]]}}}],["pixi.texture.from('https://pixijs.com/assets/bg_scene_rotate.jpg",{"_index":2231,"t":{"157":{"position":[[968,67]]},"161":{"position":[[1360,67]]},"167":{"position":[[993,67]]},"169":{"position":[[842,67],[1519,67]]},"179":{"position":[[1171,66]]},"181":{"position":[[1036,67]]}}}],["pixi.texture.from('https://pixijs.com/assets/bunny.png",{"_index":324,"t":{"79":{"position":[[167,57]]},"99":{"position":[[260,57]]},"117":{"position":[[204,57]]},"193":{"position":[[438,57]]},"213":{"position":[[236,57]]}}}],["pixi.texture.from('https://pixijs.com/assets/button.png",{"_index":1237,"t":{"115":{"position":[[771,58]]},"121":{"position":[[435,58]]}}}],["pixi.texture.from('https://pixijs.com/assets/button_down.png",{"_index":1239,"t":{"115":{"position":[[856,63]]},"121":{"position":[[520,63]]}}}],["pixi.texture.from('https://pixijs.com/assets/button_over.png",{"_index":1241,"t":{"115":{"position":[[946,63]]},"121":{"position":[[610,63]]}}}],["pixi.texture.from('https://pixijs.com/assets/egghead.png",{"_index":534,"t":{"85":{"position":[[538,59]]},"191":{"position":[[270,59]]}}}],["pixi.texture.from('https://pixijs.com/assets/flowertop.png",{"_index":535,"t":{"85":{"position":[[598,61]]},"191":{"position":[[186,61]]}}}],["pixi.texture.from('https://pixijs.com/assets/helmlok.png",{"_index":536,"t":{"85":{"position":[[660,59]]}}}],["pixi.texture.from('https://pixijs.com/assets/p2.jpeg",{"_index":2551,"t":{"195":{"position":[[181,55]]}}}],["pixi.texture.from('https://pixijs.com/assets/perlin.jpg",{"_index":2269,"t":{"163":{"position":[[936,58]]},"165":{"position":[[2426,58]]}}}],["pixi.texture.from('https://pixijs.com/assets/skully.png",{"_index":537,"t":{"85":{"position":[[720,58]]}}}],["pixi.texture.from('https://pixijs.com/assets/star.png",{"_index":441,"t":{"83":{"position":[[175,56]]}}}],["pixi.texture.from('https://pixijs.com/assets/trail.png",{"_index":377,"t":{"81":{"position":[[199,57]]}}}],["pixi.texture.from('https://pixijs.com/assets/video.mp4",{"_index":2605,"t":{"199":{"position":[[1203,57]]}}}],["pixi.texture.from('https://pixijs.com/assets/yellowstar.png",{"_index":1391,"t":{"123":{"position":[[160,62]]}}}],["pixi.texture.from(`explosion_sequence_a",{"_index":2503,"t":{"185":{"position":[[344,39]]}}}],["pixi.texture.from(canvas",{"_index":2767,"t":{"209":{"position":[[830,26]]}}}],["pixi.texture.from(framekey",{"_index":2480,"t":{"183":{"position":[[394,28]]}}}],["pixi.tilingsprite",{"_index":2557,"t":{"195":{"position":[[400,18]]}}}],["pixi.types.float",{"_index":2247,"t":{"159":{"position":[[479,17],[598,17]]}}}],["pixi.wrap_modes.repeat",{"_index":1662,"t":{"131":{"position":[[2699,23]]},"147":{"position":[[567,23]]},"165":{"position":[[2587,23]]}}}],["pixi/graphics",{"_index":1778,"t":{"139":{"position":[[40,15]]},"151":{"position":[[40,15]]}}}],["pixijs",{"_index":1,"t":{"73":{"position":[[15,6],[121,7]]},"203":{"position":[[793,7]]},"207":{"position":[[36,6],[1232,6]]}}}],["place",{"_index":1896,"t":{"139":{"position":[[3691,5]]}}}],["plane",{"_index":1093,"t":{"103":{"position":[[234,5]]},"131":{"position":[[1118,5]]},"165":{"position":[[1037,5]]}}}],["plane.geometry.getbuffer('avertexposition",{"_index":1100,"t":{"103":{"position":[[394,44]]}}}],["plane.x",{"_index":1095,"t":{"103":{"position":[[281,7]]}}}],["plane.y",{"_index":1096,"t":{"103":{"position":[[296,7]]}}}],["platforms",{"_index":2587,"t":{"199":{"position":[[740,10]]}}}],["play",{"_index":582,"t":{"85":{"position":[[2083,4]]},"199":{"position":[[156,4]]}}}],["playing",{"_index":636,"t":{"85":{"position":[[3146,8]]},"199":{"position":[[688,7]]}}}],["playtext",{"_index":606,"t":{"85":{"position":[[2449,8]]}}}],["playtext.height",{"_index":614,"t":{"85":{"position":[[2627,16]]}}}],["playtext.width",{"_index":611,"t":{"85":{"position":[[2542,15]]}}}],["playtext.x",{"_index":609,"t":{"85":{"position":[[2502,10]]}}}],["playtext.y",{"_index":612,"t":{"85":{"position":[[2564,10]]}}}],["please",{"_index":1548,"t":{"131":{"position":[[39,6]]}}}],["point",{"_index":207,"t":{"75":{"position":[[3976,5]]},"77":{"position":[[1512,5]]},"91":{"position":[[507,5]]},"95":{"position":[[982,6],[1839,5],[5490,6],[8604,5]]},"101":{"position":[[429,5]]},"105":{"position":[[412,5],[521,5]]},"109":{"position":[[290,5]]},"113":{"position":[[576,5]]},"117":{"position":[[875,5]]},"123":{"position":[[723,5]]},"189":{"position":[[292,5]]},"191":{"position":[[444,5]]}}}],["point.y",{"_index":1865,"t":{"139":{"position":[[2433,9]]}}}],["pointer",{"_index":213,"t":{"75":{"position":[[4164,7],[4568,7]]},"85":{"position":[[3034,10]]},"87":{"position":[[1145,10],[1820,10]]},"93":{"position":[[880,10]]},"111":{"position":[[541,10]]},"117":{"position":[[835,10],[1019,7]]},"121":{"position":[[1025,10],[1094,8]]},"123":{"position":[[354,10],[896,10],[1219,10],[2135,10]]},"125":{"position":[[80,7],[668,7]]},"127":{"position":[[706,10],[1974,8]]},"191":{"position":[[710,10]]},"199":{"position":[[588,10]]}}}],["pointerdown",{"_index":284,"t":{"77":{"position":[[1080,12]]},"139":{"position":[[1695,14]]}}}],["pointerdown(event",{"_index":319,"t":{"77":{"position":[[1875,18]]}}}],["pointerenter",{"_index":1330,"t":{"119":{"position":[[332,13],[1407,14]]}}}],["pointerleave",{"_index":1331,"t":{"119":{"position":[[346,13],[1434,15]]}}}],["pointermove",{"_index":289,"t":{"77":{"position":[[1175,13],[1247,13]]},"127":{"position":[[1483,11]]},"139":{"position":[[1723,14],[4055,11]]}}}],["pointermove(event",{"_index":321,"t":{"77":{"position":[[1913,19]]}}}],["pointerout",{"_index":1333,"t":{"119":{"position":[[373,10]]},"139":{"position":[[1753,13]]}}}],["pointerover",{"_index":1332,"t":{"119":{"position":[[360,12]]},"139":{"position":[[1738,14]]}}}],["pointers",{"_index":1183,"t":{"111":{"position":[[555,8]]}}}],["pointerup",{"_index":286,"t":{"77":{"position":[[1110,10],[1145,10]]},"139":{"position":[[1710,12]]}}}],["pointerup(event",{"_index":322,"t":{"77":{"position":[[1944,16]]}}}],["points",{"_index":124,"t":{"75":{"position":[[1802,6]]},"77":{"position":[[303,6]]},"81":{"position":[[458,6],[589,7],[737,8],[1316,6]]},"171":{"position":[[187,6],[373,8]]},"173":{"position":[[193,6],[379,8]]}}}],["points.length",{"_index":2443,"t":{"171":{"position":[[617,14],[893,14],[973,14]]},"173":{"position":[[678,14]]}}}],["points.push(new",{"_index":390,"t":{"81":{"position":[[634,15]]},"171":{"position":[[231,15]]},"173":{"position":[[237,15]]}}}],["points[0].y",{"_index":2453,"t":{"171":{"position":[[859,13]]}}}],["points[i",{"_index":407,"t":{"81":{"position":[[1398,10]]}}}],["points[i].x",{"_index":2446,"t":{"171":{"position":[[687,11]]},"173":{"position":[[748,11]]}}}],["points[i].y",{"_index":2444,"t":{"171":{"position":[[639,11],[937,13],[1044,12]]},"173":{"position":[[700,11]]}}}],["polyfill",{"_index":2592,"t":{"199":{"position":[[824,8]]}}}],["polygon",{"_index":2181,"t":{"151":{"position":[[2230,7]]}}}],["pops",{"_index":198,"t":{"75":{"position":[[3481,4],[3508,4]]}}}],["position",{"_index":491,"t":{"83":{"position":[[1495,8]]},"85":{"position":[[1020,9],[1672,8],[3423,11]]},"95":{"position":[[301,10],[378,9],[2279,10],[2356,9],[3193,10],[3270,9],[4234,10],[4311,9],[7412,10],[7489,9]]},"97":{"position":[[792,11]]},"105":{"position":[[647,10],[1658,8]]},"111":{"position":[[348,8]]},"113":{"position":[[191,9],[1691,8]]},"117":{"position":[[1116,8]]},"127":{"position":[[1826,8],[1956,8],[2148,8]]},"147":{"position":[[940,8]]},"187":{"position":[[723,9]]},"199":{"position":[[383,8]]},"211":{"position":[[1357,8]]},"213":{"position":[[972,8]]}}}],["positions",{"_index":464,"t":{"83":{"position":[[825,9]]},"85":{"position":[[3975,9]]},"97":{"position":[[1806,9]]},"103":{"position":[[368,10],[531,9]]}}}],["positionsize",{"_index":2241,"t":{"159":{"position":[[276,12],[388,13],[458,13],[501,13],[620,13],[652,13],[752,13]]}}}],["possible",{"_index":2290,"t":{"163":{"position":[[1592,9]]}}}],["power",{"_index":2555,"t":{"195":{"position":[[359,5]]}}}],["precision",{"_index":1676,"t":{"133":{"position":[[468,9],[633,9],[667,9]]},"157":{"position":[[525,9],[818,10]]},"159":{"position":[[1005,9],[1310,10]]},"161":{"position":[[917,9],[1210,10]]},"163":{"position":[[567,9],[1054,9],[1980,9],[2784,9],[3387,9],[4399,9]]},"165":{"position":[[516,9],[886,9]]},"167":{"position":[[466,9],[759,10]]},"169":{"position":[[400,9],[693,10],[949,9],[1242,10]]},"175":{"position":[[262,9],[502,10]]},"177":{"position":[[484,9],[785,10]]},"179":{"position":[[590,9],[966,9]]},"181":{"position":[[497,9],[812,9]]}}}],["preferably",{"_index":2554,"t":{"195":{"position":[[343,10]]}}}],["prepare",{"_index":251,"t":{"77":{"position":[[129,7]]}}}],["prerounded",{"_index":922,"t":{"95":{"position":[[4551,10]]}}}],["pressed",{"_index":1504,"t":{"127":{"position":[[1519,8]]}}}],["prevent",{"_index":411,"t":{"81":{"position":[[1457,7]]},"119":{"position":[[1517,7]]}}}],["previous",{"_index":307,"t":{"77":{"position":[[1497,8]]}}}],["previousposition",{"_index":545,"t":{"85":{"position":[[1033,17]]}}}],["prevy",{"_index":665,"t":{"85":{"position":[[4069,5],[4170,5]]}}}],["product",{"_index":671,"t":{"85":{"position":[[4259,7],[4643,8]]}}}],["program",{"_index":2402,"t":{"167":{"position":[[436,7]]}}}],["project",{"_index":1785,"t":{"139":{"position":[[201,7]]}}}],["projection",{"_index":494,"t":{"83":{"position":[[1529,10]]},"139":{"position":[[406,11],[946,10],[2468,10],[3835,10]]}}}],["projectionmatrix",{"_index":2223,"t":{"157":{"position":[[648,17]]},"159":{"position":[[1141,17]]},"161":{"position":[[1040,17]]},"163":{"position":[[690,17]]},"165":{"position":[[639,17]]},"167":{"position":[[589,17]]},"169":{"position":[[523,17],[1072,17]]},"175":{"position":[[364,17]]},"177":{"position":[[609,17]]},"179":{"position":[[736,17]]},"181":{"position":[[620,17]]}}}],["projectionsystem",{"_index":1869,"t":{"139":{"position":[[2528,16]]}}}],["projectionsystem.transform",{"_index":1873,"t":{"139":{"position":[[2620,26],[2649,26]]}}}],["projectionsystem.transform.append(this.worldtransform",{"_index":1875,"t":{"139":{"position":[[2757,55]]}}}],["projectionsystem.transform.copyfrom(this.originaltransform",{"_index":1879,"t":{"139":{"position":[[2938,60]]}}}],["projectionsystem.transform.copyto(this.originaltransform",{"_index":1874,"t":{"139":{"position":[[2698,58]]}}}],["projectionsystem.update(null",{"_index":1876,"t":{"139":{"position":[[2813,29],[2999,29]]}}}],["projector",{"_index":1788,"t":{"139":{"position":[[369,9],[566,10],[752,9],[3282,9],[3298,9],[3333,13],[3779,9]]}}}],["projector.content.addchild",{"_index":1887,"t":{"139":{"position":[[3371,27]]}}}],["projector.content.addchild(...stars",{"_index":1901,"t":{"139":{"position":[[3789,37]]}}}],["projector.content.addeventlistener('pointermove",{"_index":1937,"t":{"139":{"position":[[5053,49]]}}}],["projector.content.eventmode",{"_index":1910,"t":{"139":{"position":[[4126,27]]}}}],["projector.content.hitarea",{"_index":1906,"t":{"139":{"position":[[3897,25],[4099,26]]}}}],["projector.hitarea",{"_index":1909,"t":{"139":{"position":[[4079,17]]}}}],["projector.x",{"_index":1904,"t":{"139":{"position":[[3859,11]]}}}],["projector.y",{"_index":1905,"t":{"139":{"position":[[3878,11]]}}}],["promise",{"_index":742,"t":{"87":{"position":[[767,7],[1444,7]]},"89":{"position":[[355,7],[518,7]]},"91":{"position":[[190,7],[290,7]]},"93":{"position":[[996,7]]}}}],["promise<{flowertop",{"_index":784,"t":{"89":{"position":[[458,19]]}}}],["propagate",{"_index":1782,"t":{"139":{"position":[[126,9],[613,9],[1633,9]]}}}],["proper",{"_index":484,"t":{"83":{"position":[[1252,6]]},"85":{"position":[[4252,6],[4609,6]]}}}],["properties",{"_index":1041,"t":{"97":{"position":[[1073,10]]},"105":{"position":[[804,10]]},"187":{"position":[[671,10]]}}}],["property",{"_index":688,"t":{"85":{"position":[[4698,9],[4778,9]]}}}],["propertybeginvalue",{"_index":693,"t":{"85":{"position":[[4788,19]]}}}],["pure",{"_index":1552,"t":{"131":{"position":[[98,4]]},"207":{"position":[[1183,4]]}}}],["push",{"_index":63,"t":{"75":{"position":[[446,4]]},"97":{"position":[[1374,4]]},"105":{"position":[[1227,4]]},"113":{"position":[[1235,4]]}}}],["quad",{"_index":2232,"t":{"157":{"position":[[1046,4]]},"161":{"position":[[1438,4]]},"165":{"position":[[2682,5],[2761,4]]},"181":{"position":[[1189,4]]}}}],["quad.position.set(400",{"_index":2234,"t":{"157":{"position":[[1086,22]]},"161":{"position":[[1479,22]]},"165":{"position":[[2801,22]]},"181":{"position":[[1229,22]]}}}],["quad.rotation",{"_index":2237,"t":{"157":{"position":[[1188,13]]},"161":{"position":[[1581,13]]},"181":{"position":[[1391,13]]}}}],["quad.scale.set(2",{"_index":2235,"t":{"157":{"position":[[1115,18]]},"161":{"position":[[1508,18]]},"165":{"position":[[2830,18]]},"181":{"position":[[1258,18]]}}}],["quad.scale.set(number(math.cos(time",{"_index":2400,"t":{"165":{"position":[[2992,37]]}}}],["quad.shader.uniforms.time",{"_index":2399,"t":{"165":{"position":[[2958,25]]},"181":{"position":[[1414,25]]}}}],["quality",{"_index":2763,"t":{"209":{"position":[[352,7],[391,7],[470,8],[617,8],[810,8]]}}}],["r",{"_index":638,"t":{"85":{"position":[[3262,1],[3716,1]]},"177":{"position":[[368,2],[388,2],[409,2]]},"179":{"position":[[368,2],[388,2],[409,2]]}}}],["r.blur.blury",{"_index":659,"t":{"85":{"position":[[3871,12]]}}}],["r.position",{"_index":643,"t":{"85":{"position":[[3336,10],[3886,11],[3946,11],[4088,12]]}}}],["r.previousposition",{"_index":660,"t":{"85":{"position":[[3900,19],[3925,18]]}}}],["r.symbols.length",{"_index":662,"t":{"85":{"position":[[4014,17],[4108,17]]}}}],["r.symbols[j",{"_index":664,"t":{"85":{"position":[[4049,13]]}}}],["rabbit",{"_index":1168,"t":{"109":{"position":[[514,6]]},"189":{"position":[[550,6]]}}}],["radial",{"_index":465,"t":{"83":{"position":[[840,6]]},"95":{"position":[[215,6],[3131,6]]}}}],["radians",{"_index":1114,"t":{"105":{"position":[[876,8]]},"113":{"position":[[902,7]]}}}],["radius",{"_index":908,"t":{"95":{"position":[[3783,6],[3830,7],[3872,7],[4025,7]]},"149":{"position":[[135,6],[162,6],[545,6],[564,7],[682,7],[707,7]]}}}],["random",{"_index":466,"t":{"83":{"position":[[847,6]]},"97":{"position":[[675,6],[785,6],[1284,6]]},"105":{"position":[[490,6],[640,6],[856,6],[1137,6]]},"113":{"position":[[882,6],[1085,6]]},"145":{"position":[[1456,6]]}}}],["randomize",{"_index":1102,"t":{"103":{"position":[[509,9]]}}}],["randomizestar(star",{"_index":457,"t":{"83":{"position":[[606,19],[695,19],[1459,20]]}}}],["randomly",{"_index":2795,"t":{"211":{"position":[[1348,8]]}}}],["rate",{"_index":658,"t":{"85":{"position":[[3865,5]]}}}],["raydir",{"_index":1634,"t":{"131":{"position":[[2039,6],[2203,6],[2453,7]]},"165":{"position":[[1887,6],[2051,6],[2301,7]]}}}],["raymarch",{"_index":1639,"t":{"131":{"position":[[2114,8]]},"165":{"position":[[1962,8]]}}}],["rc",{"_index":541,"t":{"85":{"position":[[899,2],[1003,3]]}}}],["rc.addchild(symbol",{"_index":568,"t":{"85":{"position":[[1561,20]]}}}],["rc.filters",{"_index":550,"t":{"85":{"position":[[1136,10]]}}}],["rc.x",{"_index":542,"t":{"85":{"position":[[926,4]]}}}],["rd",{"_index":1604,"t":{"131":{"position":[[1464,3],[1675,2]]},"165":{"position":[[1331,3],[1542,2]]}}}],["reach",{"_index":764,"t":{"87":{"position":[[1378,5]]}}}],["read",{"_index":2356,"t":{"163":{"position":[[4541,6]]}}}],["reading",{"_index":36,"t":{"75":{"position":[[103,8]]}}}],["real",{"_index":486,"t":{"83":{"position":[[1289,5]]},"85":{"position":[[4638,4]]},"131":{"position":[[768,4]]}}}],["really",{"_index":493,"t":{"83":{"position":[[1515,6]]},"131":{"position":[[1129,6],[2310,6]]},"165":{"position":[[1048,6],[2158,6]]}}}],["realpath",{"_index":1990,"t":{"143":{"position":[[308,8]]}}}],["realpath.linestyle(2",{"_index":1991,"t":{"143":{"position":[[340,21]]}}}],["realpath.lineto(100",{"_index":1993,"t":{"143":{"position":[[399,20]]}}}],["realpath.lineto(200",{"_index":1994,"t":{"143":{"position":[[426,20]]}}}],["realpath.lineto(240",{"_index":1995,"t":{"143":{"position":[[453,20]]}}}],["realpath.moveto(0",{"_index":1992,"t":{"143":{"position":[[376,18]]}}}],["realpath.position.x",{"_index":1996,"t":{"143":{"position":[[480,19]]}}}],["realpath.position.y",{"_index":1997,"t":{"143":{"position":[[506,19]]}}}],["realpath2",{"_index":2006,"t":{"143":{"position":[[792,9]]}}}],["realpath2.linestyle(2",{"_index":2007,"t":{"143":{"position":[[825,22]]}}}],["realpath2.lineto(0",{"_index":2009,"t":{"143":{"position":[[886,19]]}}}],["realpath2.lineto(150",{"_index":2010,"t":{"143":{"position":[[913,21]]}}}],["realpath2.lineto(240",{"_index":2011,"t":{"143":{"position":[[941,21]]}}}],["realpath2.moveto(0",{"_index":2008,"t":{"143":{"position":[[862,19]]}}}],["realpath2.position.x",{"_index":2012,"t":{"143":{"position":[[969,20]]}}}],["realpath2.position.y",{"_index":2013,"t":{"143":{"position":[[997,20]]}}}],["reason",{"_index":1308,"t":{"117":{"position":[[1557,6]]}}}],["received",{"_index":1367,"t":{"119":{"position":[[1309,8]]}}}],["rectandhole",{"_index":2040,"t":{"143":{"position":[[1821,11]]}}}],["rectandhole.beginfill(0x00ff00",{"_index":2041,"t":{"143":{"position":[[1856,32]]}}}],["rectandhole.beginhole",{"_index":2044,"t":{"143":{"position":[[1931,24]]}}}],["rectandhole.drawcircle(375",{"_index":2045,"t":{"143":{"position":[[1956,27]]}}}],["rectandhole.drawcircle(425",{"_index":2047,"t":{"143":{"position":[[1994,27]]}}}],["rectandhole.drawcircle(475",{"_index":2049,"t":{"143":{"position":[[2032,27]]}}}],["rectandhole.drawrect(350",{"_index":2042,"t":{"143":{"position":[[1889,25]]}}}],["rectandhole.endfill",{"_index":2052,"t":{"143":{"position":[[2093,22]]}}}],["rectandhole.endhole",{"_index":2051,"t":{"143":{"position":[[2070,22]]}}}],["rectangle",{"_index":916,"t":{"95":{"position":[[4157,9],[7319,9],[7737,9]]},"145":{"position":[[944,9]]},"151":{"position":[[216,9],[316,9],[468,9],[621,9],[1662,9]]}}}],["rectangle.drawroundedrect(0",{"_index":966,"t":{"95":{"position":[[7807,28]]}}}],["rectangle.endfill",{"_index":968,"t":{"95":{"position":[[7854,20]]}}}],["rectangle.linestyle(2",{"_index":965,"t":{"95":{"position":[[7770,22]]}}}],["rectangle.mask",{"_index":969,"t":{"95":{"position":[[7875,14]]}}}],["red",{"_index":56,"t":{"75":{"position":[[374,3],[3956,3],[4183,3],[4580,3],[4778,3]]},"207":{"position":[[934,7]]},"209":{"position":[[732,7]]}}}],["redraw",{"_index":872,"t":{"95":{"position":[[1851,6],[3883,6],[6839,6]]}}}],["redspeed",{"_index":230,"t":{"75":{"position":[[4694,8],[4842,9],[4877,9]]}}}],["redsquare",{"_index":150,"t":{"75":{"position":[[2294,9],[4957,11],[5137,11]]}}}],["redsquare.acceleration",{"_index":157,"t":{"75":{"position":[[2447,22]]}}}],["redsquare.acceleration.set",{"_index":231,"t":{"75":{"position":[[4789,27],[5201,27]]}}}],["redsquare.acceleration.set(redsquare.acceleration.x",{"_index":185,"t":{"75":{"position":[[2896,51]]}}}],["redsquare.acceleration.x",{"_index":247,"t":{"75":{"position":[[5538,24]]}}}],["redsquare.acceleration.y",{"_index":187,"t":{"75":{"position":[[2956,24],[5587,24]]}}}],["redsquare.height",{"_index":154,"t":{"75":{"position":[[2396,16],[4083,17]]}}}],["redsquare.mass",{"_index":158,"t":{"75":{"position":[[2491,14],[5358,16],[5395,16]]}}}],["redsquare.position.set(0",{"_index":151,"t":{"75":{"position":[[2343,25]]}}}],["redsquare.tint",{"_index":155,"t":{"75":{"position":[[2420,14]]}}}],["redsquare.width",{"_index":153,"t":{"75":{"position":[[2373,15],[4044,16]]}}}],["redsquare.x",{"_index":209,"t":{"75":{"position":[[4030,11],[5523,11]]}}}],["redsquare.y",{"_index":211,"t":{"75":{"position":[[4069,11],[5572,11]]}}}],["redsquarecenterposition",{"_index":208,"t":{"75":{"position":[[3988,23],[4660,24]]}}}],["redsquarecenterposition.x",{"_index":215,"t":{"75":{"position":[[4251,26]]}}}],["redsquarecenterposition.y",{"_index":216,"t":{"75":{"position":[[4294,26]]}}}],["reducing",{"_index":181,"t":{"75":{"position":[[2827,8]]}}}],["reel",{"_index":544,"t":{"85":{"position":[[983,4],[3988,5],[4299,5]]}}}],["reel.blur",{"_index":551,"t":{"85":{"position":[[1149,12]]}}}],["reel.blur.blurx",{"_index":548,"t":{"85":{"position":[[1094,15]]}}}],["reel.blur.blury",{"_index":549,"t":{"85":{"position":[[1115,15]]}}}],["reel.symbols.push(symbol",{"_index":567,"t":{"85":{"position":[[1534,26]]}}}],["reel_width",{"_index":523,"t":{"85":{"position":[[364,10],[937,11],[1827,10]]}}}],["reelcontainer",{"_index":540,"t":{"85":{"position":[[825,13],[1681,13]]}}}],["reelcontainer.addchild(rc",{"_index":543,"t":{"85":{"position":[[949,27]]}}}],["reelcontainer.x",{"_index":576,"t":{"85":{"position":[[1779,15]]}}}],["reelcontainer.y",{"_index":575,"t":{"85":{"position":[[1753,15]]}}}],["reels",{"_index":539,"t":{"85":{"position":[[795,5],[807,5],[3524,5]]}}}],["reels.length",{"_index":637,"t":{"85":{"position":[[3235,13],[3475,12],[3689,13]]}}}],["reels.push(reel",{"_index":569,"t":{"85":{"position":[[1584,17]]}}}],["reels[i",{"_index":639,"t":{"85":{"position":[[3266,9],[3720,9]]}}}],["reelscomplete",{"_index":649,"t":{"85":{"position":[[3494,13],[3553,15]]}}}],["reference",{"_index":1021,"t":{"97":{"position":[[378,9]]},"117":{"position":[[1528,9]]}}}],["regular",{"_index":2622,"t":{"201":{"position":[[351,9],[854,9]]}}}],["regular.woff",{"_index":2624,"t":{"201":{"position":[[411,14],[797,14]]}}}],["related",{"_index":1321,"t":{"119":{"position":[[80,7]]}}}],["released",{"_index":1508,"t":{"127":{"position":[[1683,9]]}}}],["remove",{"_index":698,"t":{"85":{"position":[[5036,6]]},"139":{"position":[[1495,6]]}}}],["remove.length",{"_index":714,"t":{"85":{"position":[[5397,14]]}}}],["remove.push(t",{"_index":713,"t":{"85":{"position":[[5357,15]]}}}],["render",{"_index":1866,"t":{"139":{"position":[[2448,6]]},"163":{"position":[[5700,6]]},"199":{"position":[[789,6],[931,6]]},"211":{"position":[[215,6],[492,6],[2084,6]]}}}],["render(renderer",{"_index":1867,"t":{"139":{"position":[[2479,16]]}}}],["rendered",{"_index":1807,"t":{"139":{"position":[[842,8]]},"211":{"position":[[2171,8]]}}}],["renderer",{"_index":2735,"t":{"207":{"position":[[1305,9]]}}}],["renderer.batch.flush",{"_index":1868,"t":{"139":{"position":[[2498,23],[2914,23]]}}}],["renderer.projection",{"_index":1870,"t":{"139":{"position":[[2547,20]]}}}],["renderer.rendertexture",{"_index":1872,"t":{"139":{"position":[[2596,23]]}}}],["rendering",{"_index":1554,"t":{"131":{"position":[[120,9]]}}}],["renderpoints",{"_index":2448,"t":{"171":{"position":[[754,15],[783,14]]}}}],["renders",{"_index":1789,"t":{"139":{"position":[[379,7]]}}}],["rendertexture",{"_index":276,"t":{"77":{"position":[[760,13],[1354,14],[1720,14]]},"163":{"position":[[5767,14],[5832,14],[5898,14],[5962,14]]},"211":{"position":[[304,13],[440,14],[1848,14],[1863,13],[1964,14],[2213,14]]},"213":{"position":[[1100,14]]}}}],["rendertexture2",{"_index":2771,"t":{"211":{"position":[[362,14],[1879,15],[1895,14],[2228,15]]}}}],["rendertexturesprite",{"_index":278,"t":{"77":{"position":[[820,19],[895,20],[963,20]]}}}],["rendertexturesystem",{"_index":1871,"t":{"139":{"position":[[2574,19]]}}}],["rendertexturesystem.current",{"_index":1877,"t":{"139":{"position":[[2852,30],[3038,30]]}}}],["repeat",{"_index":2123,"t":{"147":{"position":[[997,6]]},"165":{"position":[[2510,6]]}}}],["replaced",{"_index":685,"t":{"85":{"position":[[4593,8]]},"95":{"position":[[4834,8]]}}}],["requestanimationframe(animate",{"_index":2474,"t":{"181":{"position":[[1331,31]]}}}],["require",{"_index":2597,"t":{"199":{"position":[[902,7]]}}}],["requirement",{"_index":2600,"t":{"199":{"position":[[1023,11]]}}}],["requires",{"_index":2552,"t":{"195":{"position":[[269,8]]}}}],["res.text",{"_index":1529,"t":{"129":{"position":[[471,11]]}}}],["reset",{"_index":2128,"t":{"147":{"position":[[1092,5]]},"155":{"position":[[555,8],[573,7],[809,8]]}}}],["resizeto",{"_index":49,"t":{"75":{"position":[[264,9]]},"77":{"position":[[68,9]]},"79":{"position":[[93,9]]},"81":{"position":[[91,9]]},"83":{"position":[[68,9]]},"85":{"position":[[91,9]]},"87":{"position":[[91,9]]},"89":{"position":[[91,9]]},"91":{"position":[[91,9]]},"93":{"position":[[91,9]]},"95":{"position":[[91,9]]},"97":{"position":[[68,9]]},"99":{"position":[[91,9]]},"101":{"position":[[91,9]]},"103":{"position":[[91,9]]},"105":{"position":[[68,9]]},"107":{"position":[[68,9]]},"109":{"position":[[88,9]]},"111":{"position":[[91,9]]},"113":{"position":[[68,9]]},"115":{"position":[[91,9]]},"117":{"position":[[91,9]]},"121":{"position":[[68,9]]},"129":{"position":[[68,9]]},"131":{"position":[[363,9]]},"133":{"position":[[136,9]]},"135":{"position":[[68,9]]},"137":{"position":[[68,9]]},"141":{"position":[[68,9]]},"143":{"position":[[85,9]]},"145":{"position":[[85,9]]},"147":{"position":[[68,9]]},"149":{"position":[[68,9]]},"151":{"position":[[117,9]]},"153":{"position":[[85,9]]},"155":{"position":[[68,9]]},"157":{"position":[[68,9]]},"159":{"position":[[68,9]]},"161":{"position":[[68,9]]},"163":{"position":[[81,9]]},"165":{"position":[[68,9]]},"167":{"position":[[68,9]]},"169":{"position":[[68,9]]},"171":{"position":[[68,9]]},"173":{"position":[[68,9]]},"175":{"position":[[68,9]]},"177":{"position":[[68,9]]},"179":{"position":[[68,9]]},"181":{"position":[[68,9]]},"183":{"position":[[86,9]]},"185":{"position":[[86,9]]},"187":{"position":[[91,9]]},"189":{"position":[[91,9]]},"191":{"position":[[91,9]]},"193":{"position":[[271,9]]},"195":{"position":[[68,9]]},"197":{"position":[[91,9]]},"199":{"position":[[88,9]]},"201":{"position":[[91,9]]},"203":{"position":[[91,9]]},"205":{"position":[[91,9]]},"207":{"position":[[1569,9]]},"209":{"position":[[223,9]]},"211":{"position":[[68,9]]},"213":{"position":[[91,9]]},"238":{"position":[[68,9]]}}}],["resizing",{"_index":2745,"t":{"207":{"position":[[1744,8]]}}}],["resolution",{"_index":2820,"t":{"213":{"position":[[600,11]]}}}],["resolved",{"_index":747,"t":{"87":{"position":[[897,8],[1574,8]]},"89":{"position":[[346,8],[626,8]]},"91":{"position":[[404,8]]},"93":{"position":[[661,8],[1016,8]]}}}],["resolves",{"_index":743,"t":{"87":{"position":[[775,8],[1452,8]]},"89":{"position":[[526,9]]},"91":{"position":[[298,9]]}}}],["resource",{"_index":1573,"t":{"131":{"position":[[872,9]]},"207":{"position":[[54,8],[1836,8]]}}}],["resources",{"_index":1122,"t":{"107":{"position":[[146,9]]}}}],["respond",{"_index":1285,"t":{"117":{"position":[[659,7]]}}}],["result",{"_index":239,"t":{"75":{"position":[[5060,6]]}}}],["results",{"_index":90,"t":{"75":{"position":[[869,7]]}}}],["resume",{"_index":1546,"t":{"129":{"position":[[881,6]]}}}],["retain",{"_index":1170,"t":{"111":{"position":[[186,6]]}}}],["return",{"_index":80,"t":{"75":{"position":[[678,6],[1028,6],[1674,6],[1899,6]]},"81":{"position":[[1154,7],[1808,6],[1865,6],[2260,6]]},"85":{"position":[[3191,7],[4932,6],[5524,6],[5688,6]]},"95":{"position":[[881,6],[2794,6],[3626,6],[5388,6],[7982,6],[8631,6],[8901,6],[9033,6],[9283,6],[9302,6],[9429,6]]},"115":{"position":[[2123,7],[2234,7]]},"121":{"position":[[2218,7],[2329,7]]},"131":{"position":[[1387,6],[1685,6]]},"139":{"position":[[1934,6],[2393,6]]},"165":{"position":[[1257,6],[1552,6]]},"207":{"position":[[1500,6]]},"209":{"position":[[823,6]]}}}],["reverse",{"_index":192,"t":{"75":{"position":[[3160,7]]}}}],["reversed",{"_index":940,"t":{"95":{"position":[[5109,8]]}}}],["rgba(255",{"_index":2715,"t":{"207":{"position":[[852,10]]},"209":{"position":[[650,10]]}}}],["richtext",{"_index":2669,"t":{"205":{"position":[[647,8]]}}}],["richtext.x",{"_index":2673,"t":{"205":{"position":[[741,10]]}}}],["richtext.y",{"_index":2674,"t":{"205":{"position":[[758,10]]}}}],["right",{"_index":802,"t":{"91":{"position":[[166,5]]},"95":{"position":[[1210,5],[1705,5],[1741,5],[5823,5],[6771,5],[6827,5]]},"131":{"position":[[1993,5],[2082,5]]},"165":{"position":[[1841,5],[1930,5]]},"187":{"position":[[576,5]]}}}],["ring",{"_index":1755,"t":{"137":{"position":[[1257,4]]}}}],["ring.anchor.set(0.5",{"_index":1757,"t":{"137":{"position":[[1333,21]]}}}],["ring.position.copyfrom(displacementsprite.position",{"_index":1769,"t":{"137":{"position":[[1794,52]]}}}],["ring.visible",{"_index":1758,"t":{"137":{"position":[[1355,12],[1685,12]]}}}],["ripple",{"_index":2299,"t":{"163":{"position":[[1944,7],[4568,6]]}}}],["ripplecontainer",{"_index":2311,"t":{"163":{"position":[[2633,15]]}}}],["ripplecontainer.addchild(ripplequad",{"_index":2312,"t":{"163":{"position":[[2673,37]]}}}],["ripplecontainer.position.set(220",{"_index":2367,"t":{"163":{"position":[[5014,33]]}}}],["ripplequad",{"_index":2310,"t":{"163":{"position":[[2575,10]]}}}],["ripplequad.shader.uniforms.phase",{"_index":2383,"t":{"163":{"position":[[5548,32]]}}}],["rippleshader",{"_index":2308,"t":{"163":{"position":[[2412,12],[2612,14]]}}}],["rippletexture",{"_index":2309,"t":{"163":{"position":[[2497,13],[4766,14],[5847,13]]}}}],["rippleuniforms",{"_index":2307,"t":{"163":{"position":[[2341,14],[2474,16]]}}}],["roboto",{"_index":362,"t":{"79":{"position":[[1088,9]]},"127":{"position":[[1306,9]]},"139":{"position":[[4780,9],[5524,9]]}}}],["roll",{"_index":1289,"t":{"117":{"position":[[784,4]]}}}],["root",{"_index":1806,"t":{"139":{"position":[[831,4]]}}}],["rope",{"_index":375,"t":{"81":{"position":[[172,5],[584,4],[685,4],[696,4]]},"171":{"position":[[152,5]]},"173":{"position":[[152,5]]}}}],["rope.blendmode",{"_index":393,"t":{"81":{"position":[[767,14]]}}}],["ropelength",{"_index":2430,"t":{"171":{"position":[[164,10],[262,11],[705,10]]},"173":{"position":[[164,10],[268,11],[766,10]]}}}],["ropesize",{"_index":385,"t":{"81":{"position":[[380,8],[436,8],[617,9],[1371,9],[1522,8],[1591,8]]}}}],["rotate",{"_index":1085,"t":{"99":{"position":[[833,6]]},"107":{"position":[[1277,6]]},"109":{"position":[[504,6]]},"139":{"position":[[5449,6]]},"189":{"position":[[540,6]]},"193":{"position":[[1011,6]]},"211":{"position":[[1732,6]]},"238":{"position":[[295,6],[307,6],[320,9],[630,7],[725,8],[931,6]]}}}],["rotated",{"_index":2831,"t":{"238":{"position":[[216,7],[1263,7]]}}}],["rotatedtexture",{"_index":2842,"t":{"238":{"position":[[611,15],[651,14],[857,14]]}}}],["rotatedtexture.rotate",{"_index":2849,"t":{"238":{"position":[[944,24]]}}}],["rotation",{"_index":500,"t":{"83":{"position":[[1787,9]]},"113":{"position":[[207,9]]},"139":{"position":[[4351,8]]},"187":{"position":[[927,8]]}}}],["rotations",{"_index":2856,"t":{"238":{"position":[[1181,9]]}}}],["round",{"_index":2668,"t":{"205":{"position":[[628,8],[1085,8]]}}}],["rounded",{"_index":915,"t":{"95":{"position":[[4149,7],[7311,7]]},"151":{"position":[[1654,7]]}}}],["roundingmask",{"_index":924,"t":{"95":{"position":[[4598,12],[4799,13]]}}}],["roundingmask.beginfill(0",{"_index":925,"t":{"95":{"position":[[4634,25]]}}}],["roundingmask.drawroundedrect(0",{"_index":927,"t":{"95":{"position":[[4704,31]]}}}],["roundingmask.endfill",{"_index":928,"t":{"95":{"position":[[4763,23]]}}}],["roundingmask.linestyle(1",{"_index":926,"t":{"95":{"position":[[4664,25]]}}}],["rt",{"_index":2817,"t":{"213":{"position":[[506,2],[1115,2]]}}}],["rules",{"_index":1002,"t":{"95":{"position":[[8732,6]]}}}],["running",{"_index":634,"t":{"85":{"position":[[3108,7],[3181,9],[3199,7],[3571,7]]},"189":{"position":[[583,7]]}}}],["s",{"_index":663,"t":{"85":{"position":[[4045,1]]},"203":{"position":[[580,1],[658,3]]}}}],["s.parentnode.insertbefore(wf",{"_index":2656,"t":{"203":{"position":[[628,29]]}}}],["s.scale.x",{"_index":676,"t":{"85":{"position":[[4380,9]]}}}],["s.scale.y",{"_index":677,"t":{"85":{"position":[[4392,9]]}}}],["s.texture",{"_index":674,"t":{"85":{"position":[[4305,9]]}}}],["s.texture.height",{"_index":679,"t":{"85":{"position":[[4458,18]]}}}],["s.texture.width",{"_index":678,"t":{"85":{"position":[[4427,16]]}}}],["s.width",{"_index":681,"t":{"85":{"position":[[4509,8]]}}}],["s.x",{"_index":680,"t":{"85":{"position":[[4477,3]]}}}],["s.y",{"_index":666,"t":{"85":{"position":[[4077,4],[4082,3],[4158,4]]}}}],["same",{"_index":937,"t":{"95":{"position":[[5067,4]]},"105":{"position":[[546,4]]},"133":{"position":[[567,4]]},"163":{"position":[[519,4]]}}}],["sampler2d",{"_index":1579,"t":{"131":{"position":[[991,9],[1019,9]]},"157":{"position":[[871,9]]},"161":{"position":[[1263,9]]},"163":{"position":[[2075,9],[2857,9],[4451,9],[4480,9],[4508,9]]},"165":{"position":[[938,9]]},"167":{"position":[[812,9]]},"169":{"position":[[746,9],[1295,9]]},"179":{"position":[[1039,9]]},"181":{"position":[[864,9]]}}}],["scale",{"_index":499,"t":{"83":{"position":[[1779,5],[2180,5]]},"85":{"position":[[1311,5]]},"97":{"position":[[682,5]]},"105":{"position":[[497,5]]},"111":{"position":[[152,5]]},"113":{"position":[[178,6]]},"117":{"position":[[265,5]]},"127":{"position":[[892,5],[1257,5],[1845,5]]}}}],["scalemode",{"_index":2818,"t":{"213":{"position":[[564,10]]}}}],["scales",{"_index":897,"t":{"95":{"position":[[2890,6]]}}}],["scaling",{"_index":884,"t":{"95":{"position":[[2213,7]]},"183":{"position":[[522,7]]}}}],["scatter",{"_index":1211,"t":{"113":{"position":[[728,7]]}}}],["scene",{"_index":1322,"t":{"119":{"position":[[102,6]]},"127":{"position":[[261,5]]},"131":{"position":[[160,5]]},"139":{"position":[[162,5],[452,5],[1084,6],[1680,5]]},"211":{"position":[[282,5]]}}}],["screen",{"_index":191,"t":{"75":{"position":[[3143,6],[3788,7]]},"87":{"position":[[243,8],[355,8],[596,8],[611,10],[708,6],[855,9],[1354,6],[1393,6],[1532,9]]},"91":{"position":[[576,6]]},"101":{"position":[[498,6]]},"109":{"position":[[359,6]]},"139":{"position":[[4027,6],[4845,6],[5175,6],[5273,11]]},"189":{"position":[[361,6]]},"191":{"position":[[517,6]]},"213":{"position":[[997,6]]}}}],["screen.height",{"_index":1518,"t":{"127":{"position":[[1998,13]]}}}],["screenpos",{"_index":1686,"t":{"133":{"position":[[827,9],[905,10]]}}}],["screenshot",{"_index":335,"t":{"79":{"position":[[456,13],[1168,12]]}}}],["screenshottext",{"_index":365,"t":{"79":{"position":[[1122,14]]}}}],["screenshottext.width",{"_index":370,"t":{"79":{"position":[[1239,21]]}}}],["screenshottext.x",{"_index":368,"t":{"79":{"position":[[1189,16]]}}}],["screenshottext.y",{"_index":371,"t":{"79":{"position":[[1267,16]]}}}],["script",{"_index":2644,"t":{"203":{"position":[[332,6]]}}}],["scroll",{"_index":1917,"t":{"139":{"position":[[4415,6],[4497,6]]}}}],["second",{"_index":2072,"t":{"145":{"position":[[672,6]]},"163":{"position":[[1898,6],[2714,6]]},"207":{"position":[[1071,6]]}}}],["seconds",{"_index":478,"t":{"83":{"position":[[1078,7]]}}}],["secondtexture",{"_index":2541,"t":{"191":{"position":[[254,13],[851,14]]}}}],["see",{"_index":1329,"t":{"119":{"position":[[315,3]]}}}],["seen",{"_index":2373,"t":{"163":{"position":[[5216,4]]}}}],["segment",{"_index":856,"t":{"95":{"position":[[1156,7],[1350,8],[1451,7],[5725,7],[6071,7],[6156,8],[6354,7]]}}}],["segment[0",{"_index":864,"t":{"95":{"position":[[1508,11],[6411,11]]}}}],["segment[1",{"_index":865,"t":{"95":{"position":[[1520,11],[6423,11]]}}}],["segment[2",{"_index":866,"t":{"95":{"position":[[1532,11],[6435,11]]}}}],["segment[3",{"_index":867,"t":{"95":{"position":[[1544,12],[6447,12]]}}}],["segments",{"_index":855,"t":{"95":{"position":[[1091,8],[5601,8],[5616,8],[8622,8],[9230,8]]}}}],["segments.length",{"_index":861,"t":{"95":{"position":[[1421,16],[6324,16]]}}}],["segments[i",{"_index":862,"t":{"95":{"position":[[1461,12],[6364,12]]}}}],["separately",{"_index":2374,"t":{"163":{"position":[[5221,11]]}}}],["set",{"_index":242,"t":{"75":{"position":[[5152,3]]},"81":{"position":[[749,3]]},"85":{"position":[[2966,3]]},"97":{"position":[[669,3],[761,3]]},"105":{"position":[[397,3],[484,3],[616,3]]},"111":{"position":[[332,3]]},"113":{"position":[[561,3]]},"115":{"position":[[1641,3]]},"121":{"position":[[1736,3]]},"127":{"position":[[1943,3]]},"129":{"position":[[764,3]]},"139":{"position":[[2016,3],[4294,3]]},"145":{"position":[[248,3],[558,3]]},"151":{"position":[[808,3]]},"211":{"position":[[1921,3]]}}}],["setinterval",{"_index":479,"t":{"83":{"position":[[1086,14]]}}}],["setup",{"_index":269,"t":{"77":{"position":[[528,7]]},"117":{"position":[[975,5]]},"139":{"position":[[99,5]]}}}],["shader",{"_index":1553,"t":{"131":{"position":[[103,6],[273,6],[757,7]]},"133":{"position":[[422,6],[500,6],[536,6],[603,6]]},"157":{"position":[[497,6],[1077,8]]},"159":{"position":[[977,6],[1449,8]]},"161":{"position":[[889,6],[1470,8]]},"163":{"position":[[507,7],[524,6]]},"165":{"position":[[2667,6],[2694,6],[2792,8]]},"169":{"position":[[372,6],[1632,8]]},"175":{"position":[[234,6],[630,8]]},"177":{"position":[[456,6],[927,8]]},"179":{"position":[[1247,6],[1349,8]]},"181":{"position":[[1122,6],[1220,8]]}}}],["shader2",{"_index":2421,"t":{"169":{"position":[[920,7],[1683,9]]}}}],["shaderfrag",{"_index":1682,"t":{"133":{"position":[[652,10],[1358,11]]}}}],["shaders",{"_index":2267,"t":{"163":{"position":[[905,8]]}}}],["shape",{"_index":2063,"t":{"145":{"position":[[351,5],[679,5],[1300,5]]},"151":{"position":[[1424,5]]},"153":{"position":[[1009,5]]}}}],["shaped",{"_index":2848,"t":{"238":{"position":[[798,6]]}}}],["sharing",{"_index":2288,"t":{"163":{"position":[[1561,7]]}}}],["sharp",{"_index":412,"t":{"81":{"position":[[1465,5]]}}}],["shorter",{"_index":1585,"t":{"131":{"position":[[1192,7]]},"165":{"position":[[1111,7]]}}}],["shoves",{"_index":94,"t":{"75":{"position":[[932,6]]}}}],["show",{"_index":2860,"t":{"238":{"position":[[1395,4]]}}}],["shows",{"_index":1179,"t":{"111":{"position":[[507,5]]},"139":{"position":[[81,5]]}}}],["silly",{"_index":1269,"t":{"115":{"position":[[1650,5]]},"121":{"position":[[1745,5]]}}}],["simple",{"_index":481,"t":{"83":{"position":[[1211,6],[1522,6]]},"85":{"position":[[4544,6]]},"131":{"position":[[1136,6]]},"163":{"position":[[1145,6],[2119,6],[3601,8]]},"165":{"position":[[1055,6]]}}}],["simplicity",{"_index":2291,"t":{"163":{"position":[[1613,10]]}}}],["sin",{"_index":899,"t":{"95":{"position":[[2929,3],[2991,3],[3060,3],[3066,3]]},"181":{"position":[[962,4]]}}}],["sin(distance*25.0+phase",{"_index":2305,"t":{"163":{"position":[[2271,24]]}}}],["sin(time",{"_index":1696,"t":{"133":{"position":[[1072,10]]}}}],["size",{"_index":839,"t":{"95":{"position":[[505,4],[530,5],[550,5],[647,5],[669,5],[737,4],[1031,5],[1079,5],[1106,4],[1117,4],[1127,4],[1138,4],[1164,5],[1176,4],[1186,4],[1196,4],[1218,4],[1228,4],[1238,4],[1248,4],[1271,4],[1282,4],[1293,4],[1303,4],[1677,4],[1688,4],[1711,4],[1721,4],[1748,4],[1758,4],[1784,4],[1795,4],[1822,4],[1954,4],[2403,4],[2632,4],[2684,4],[2694,4],[2746,4],[3397,4],[3422,5],[3442,5],[3510,4],[4358,4],[4485,5],[4505,5],[4739,5],[4745,5],[4983,5],[4989,5],[5232,4],[5539,5],[5587,5],[5631,4],[5653,4],[5674,4],[5696,4],[5733,5],[5756,4],[5777,4],[5798,4],[5831,4],[5852,4],[5873,4],[5894,4],[5928,4],[5950,4],[5972,4],[5993,4],[6299,4],[6605,4],[6627,4],[6662,4],[6683,4],[6719,4],[6740,4],[6777,4],[6799,4],[6961,4]]},"105":{"position":[[551,5]]},"157":{"position":[[298,4],[424,4]]},"161":{"position":[[298,4],[424,4],[657,4],[777,4]]},"163":{"position":[[318,4],[444,4]]},"165":{"position":[[317,4],[443,4]]},"167":{"position":[[287,4],[408,4]]},"177":{"position":[[287,4],[428,4]]},"179":{"position":[[287,4],[427,4],[548,4]]},"181":{"position":[[298,4],[424,4]]},"195":{"position":[[331,4]]},"207":{"position":[[509,4],[1730,4]]}}}],["sizes",{"_index":1210,"t":{"113":{"position":[[676,5]]}}}],["skewstyle",{"_index":2676,"t":{"205":{"position":[[812,9],[1166,11]]}}}],["skewtext",{"_index":2681,"t":{"205":{"position":[[1125,8]]}}}],["skewtext.anchor.set(0.5",{"_index":2685,"t":{"205":{"position":[[1209,24]]}}}],["skewtext.skew.set(0.65",{"_index":2684,"t":{"205":{"position":[[1178,23]]}}}],["skewtext.x",{"_index":2686,"t":{"205":{"position":[[1240,10]]}}}],["skewtext.y",{"_index":2687,"t":{"205":{"position":[[1258,10]]}}}],["skipupdatetransform",{"_index":298,"t":{"77":{"position":[[1383,20],[1749,20]]}}}],["skully.png",{"_index":1128,"t":{"107":{"position":[[365,13]]}}}],["slider",{"_index":1479,"t":{"127":{"position":[[311,6],[349,6],[927,6]]}}}],["slider.addchild(handle",{"_index":1493,"t":{"127":{"position":[[848,24]]}}}],["slider.height",{"_index":1488,"t":{"127":{"position":[[614,13]]}}}],["slider.tolocal(e.global).x",{"_index":1521,"t":{"127":{"position":[[2065,27]]}}}],["slider.x",{"_index":1483,"t":{"127":{"position":[[432,8]]}}}],["slider.y",{"_index":1484,"t":{"127":{"position":[[475,8]]}}}],["sliderwidth",{"_index":1480,"t":{"127":{"position":[[324,11],[415,12],[457,12],[644,11],[2093,11],[2202,12]]}}}],["slooww",{"_index":1213,"t":{"113":{"position":[[1135,6]]}}}],["slot",{"_index":531,"t":{"85":{"position":[[501,4]]}}}],["slots",{"_index":620,"t":{"85":{"position":[[2743,8],[3662,6]]}}}],["slottextures",{"_index":533,"t":{"85":{"position":[[521,12]]}}}],["slottextures.length",{"_index":556,"t":{"85":{"position":[[1284,23],[4357,22]]}}}],["slottextures[math.floor(math.random",{"_index":675,"t":{"85":{"position":[[4317,37]]}}}],["slow",{"_index":2483,"t":{"183":{"position":[[547,4],[573,4]]}}}],["slow.anchor.set(0.5",{"_index":2486,"t":{"183":{"position":[[615,21]]}}}],["slow.animationspeed",{"_index":2488,"t":{"183":{"position":[[662,19]]}}}],["slow.play",{"_index":2492,"t":{"183":{"position":[[767,12]]}}}],["slow.scale.set(scaling",{"_index":2487,"t":{"183":{"position":[[637,24]]}}}],["slow.width",{"_index":2490,"t":{"183":{"position":[[718,11]]}}}],["slow.x",{"_index":2489,"t":{"183":{"position":[[689,6]]}}}],["slow.y",{"_index":2491,"t":{"183":{"position":[[735,6]]}}}],["slowly",{"_index":1327,"t":{"119":{"position":[[290,6]]}}}],["small",{"_index":2331,"t":{"163":{"position":[[3642,5]]}}}],["smooth",{"_index":299,"t":{"77":{"position":[[1418,6]]},"81":{"position":[[404,6],[1412,6]]}}}],["snake",{"_index":2442,"t":{"171":{"position":[[591,5]]},"173":{"position":[[652,5]]}}}],["snakecontainer",{"_index":2460,"t":{"173":{"position":[[410,14]]}}}],["snakecontainer.addchild(strip",{"_index":2466,"t":{"173":{"position":[[571,31]]}}}],["snakecontainer.scale.set(800",{"_index":2463,"t":{"173":{"position":[[497,28]]}}}],["snakecontainer.x",{"_index":2461,"t":{"173":{"position":[[449,16]]}}}],["snakecontainer.y",{"_index":2462,"t":{"173":{"position":[[473,16]]}}}],["snippet",{"_index":2640,"t":{"203":{"position":[[239,12],[743,7],[824,9],[858,10]]}}}],["snippets",{"_index":9,"t":{"73":{"position":[[83,8]]}}}],["solve",{"_index":1797,"t":{"139":{"position":[[661,5]]}}}],["somehow",{"_index":2762,"t":{"209":{"position":[[328,7]]}}}],["somewhat",{"_index":30,"t":{"75":{"position":[[42,8]]}}}],["source",{"_index":1027,"t":{"97":{"position":[[563,6]]},"105":{"position":[[315,6]]}}}],["spawn",{"_index":2749,"t":{"207":{"position":[[1850,5]]}}}],["specify",{"_index":1540,"t":{"129":{"position":[[719,7]]}}}],["speed",{"_index":115,"t":{"75":{"position":[[1515,5],[1635,5],[4478,5]]},"83":{"position":[[319,5],[1064,5],[1295,5],[1317,6],[1354,6],[2383,5]]},"85":{"position":[[3770,6]]},"97":{"position":[[1291,5]]},"105":{"position":[[1144,5]]},"113":{"position":[[1092,5]]}}}],["spends",{"_index":762,"t":{"87":{"position":[[1323,6]]}}}],["spicy",{"_index":32,"t":{"75":{"position":[[70,5]]}}}],["spinner",{"_index":832,"t":{"95":{"position":[[192,7],[2202,7],[3120,7],[4138,7],[7300,7],[7342,7],[8419,8]]}}}],["spinning",{"_index":2805,"t":{"211":{"position":[[1640,9]]}}}],["sprite",{"_index":21,"t":{"73":{"position":[[211,6],[227,6]]},"83":{"position":[[491,7]]},"87":{"position":[[881,6],[1558,6]]},"89":{"position":[[610,6]]},"91":{"position":[[388,6],[548,6]]},"93":{"position":[[645,6]]},"97":{"position":[[153,6],[501,6],[1006,6]]},"99":{"position":[[652,6]]},"101":{"position":[[319,6],[470,6]]},"105":{"position":[[253,6],[452,6]]},"109":{"position":[[162,6],[331,6]]},"111":{"position":[[263,6]]},"113":{"position":[[475,6],[615,6],[1015,6]]},"117":{"position":[[1091,6]]},"123":{"position":[[235,6],[692,7]]},"143":{"position":[[149,6]]},"147":{"position":[[497,6],[933,6]]},"187":{"position":[[692,6]]},"189":{"position":[[165,6],[333,6]]},"191":{"position":[[346,6],[489,6],[640,6]]},"193":{"position":[[830,6]]},"195":{"position":[[256,6]]},"199":{"position":[[1277,6]]},"207":{"position":[[1968,6]]},"209":{"position":[[906,6]]},"211":{"position":[[471,6],[591,6]]},"213":{"position":[[625,6]]},"238":{"position":[[1250,6]]}}}],["sprite's",{"_index":807,"t":{"91":{"position":[[491,8]]},"101":{"position":[[413,8]]},"109":{"position":[[274,8]]},"189":{"position":[[276,8]]}}}],["sprite.anchor.set(0.5",{"_index":1174,"t":{"111":{"position":[[357,23]]}}}],["sprite.cursor",{"_index":1182,"t":{"111":{"position":[[525,13]]}}}],["sprite.eventmode",{"_index":1178,"t":{"111":{"position":[[475,16]]}}}],["sprite.height",{"_index":2769,"t":{"209":{"position":[[1027,13]]}}}],["sprite.on('click",{"_index":1191,"t":{"111":{"position":[[706,18]]}}}],["sprite.on('pointerdown",{"_index":1188,"t":{"111":{"position":[[620,24]]}}}],["sprite.on('tap",{"_index":1192,"t":{"111":{"position":[[752,16]]}}}],["sprite.position.set(100",{"_index":2755,"t":{"207":{"position":[[2007,24]]},"209":{"position":[[945,24]]}}}],["sprite.rotation",{"_index":2756,"t":{"207":{"position":[[2038,15]]},"209":{"position":[[976,15]]}}}],["sprite.scale.x",{"_index":1194,"t":{"111":{"position":[[842,14]]}}}],["sprite.scale.y",{"_index":1196,"t":{"111":{"position":[[866,14]]}}}],["sprite.texture",{"_index":2017,"t":{"143":{"position":[[1140,14],[1699,14],[2273,14]]}}}],["sprite.width",{"_index":2768,"t":{"209":{"position":[[1007,12]]}}}],["sprite.x",{"_index":1175,"t":{"111":{"position":[[381,8]]},"213":{"position":[[655,8]]}}}],["sprite.y",{"_index":1176,"t":{"111":{"position":[[414,8]]},"213":{"position":[[671,8]]}}}],["sprites",{"_index":1197,"t":{"113":{"position":[[132,7],[316,7],[1666,7]]},"153":{"position":[[481,7]]},"191":{"position":[[429,7]]},"207":{"position":[[1757,7]]}}}],["sprites.addchild(dude",{"_index":1217,"t":{"113":{"position":[[1330,23]]}}}],["spritesheet",{"_index":2520,"t":{"187":{"position":[[396,11]]}}}],["spritesheet.data.frames[framekey].duration",{"_index":2481,"t":{"183":{"position":[[436,43]]}}}],["square",{"_index":57,"t":{"75":{"position":[[378,6],[1939,6],[2265,6],[3117,6],[3474,6],[4187,6],[4488,6],[4584,6],[4782,6],[5048,6]]},"95":{"position":[[203,6]]}}}],["square's",{"_index":205,"t":{"75":{"position":[[3960,8]]}}}],["squaremask",{"_index":1418,"t":{"123":{"position":[[1270,10],[1404,11],[2908,11]]}}}],["squaremask2",{"_index":1431,"t":{"123":{"position":[[1794,11],[1929,12],[2920,12]]}}}],["squares",{"_index":72,"t":{"75":{"position":[[555,7],[2810,8],[4906,7],[5193,7]]}}}],["srcs",{"_index":733,"t":{"87":{"position":[[283,5],[393,5]]}}}],["stage",{"_index":249,"t":{"75":{"position":[[5635,5]]},"107":{"position":[[531,5]]},"115":{"position":[[665,8],[1557,5]]},"117":{"position":[[1168,5]]},"119":{"position":[[584,8],[1387,7]]},"121":{"position":[[329,8],[1652,5]]},"123":{"position":[[2830,5]]},"127":{"position":[[238,5],[1498,5]]},"145":{"position":[[1442,5]]},"163":{"position":[[5185,5]]},"199":{"position":[[613,5]]},"211":{"position":[[682,5],[2095,5]]}}}],["stageheight",{"_index":1477,"t":{"127":{"position":[[155,11],[486,11],[1168,11]]}}}],["stagesize",{"_index":272,"t":{"77":{"position":[[582,9],[670,11],[742,11]]},"211":{"position":[[132,9]]}}}],["stagewidth",{"_index":1478,"t":{"127":{"position":[[194,10],[443,11],[1142,10],[1387,10]]}}}],["standard",{"_index":1392,"t":{"123":{"position":[[226,8]]}}}],["star",{"_index":439,"t":{"83":{"position":[[149,5],[482,4],[820,4],[871,4],[1420,4],[1487,4],[1774,4],[2112,4],[2190,4]]},"139":{"position":[[3553,4],[4247,4],[5408,6]]},"151":{"position":[[1821,4],[1956,4],[2093,4]]}}}],["star.addeventlistener('click",{"_index":1923,"t":{"139":{"position":[[4553,30]]}}}],["star.addeventlistener('wheel",{"_index":1916,"t":{"139":{"position":[[4369,30]]}}}],["star.cursor",{"_index":1914,"t":{"139":{"position":[[4313,11],[4641,11],[4695,11]]}}}],["star.eventmode",{"_index":1913,"t":{"139":{"position":[[4264,14]]}}}],["star.rotation",{"_index":1921,"t":{"139":{"position":[[4480,13]]}}}],["star.scale.set(1",{"_index":1926,"t":{"139":{"position":[[4676,18]]}}}],["star.scale.set(1.33",{"_index":1925,"t":{"139":{"position":[[4619,21]]}}}],["star.scale.x",{"_index":1924,"t":{"139":{"position":[[4596,13]]}}}],["star.sprite.anchor.x",{"_index":454,"t":{"83":{"position":[[550,20]]}}}],["star.sprite.anchor.y",{"_index":455,"t":{"83":{"position":[[578,20]]}}}],["star.sprite.rotation",{"_index":515,"t":{"83":{"position":[[2449,20]]}}}],["star.sprite.scale.x",{"_index":507,"t":{"83":{"position":[[2057,19]]}}}],["star.sprite.scale.y",{"_index":514,"t":{"83":{"position":[[2314,19]]}}}],["star.sprite.x",{"_index":495,"t":{"83":{"position":[[1568,13],[1814,13]]}}}],["star.sprite.y",{"_index":497,"t":{"83":{"position":[[1664,13],[1878,13]]}}}],["star.x",{"_index":472,"t":{"83":{"position":[[975,6],[1584,6]]}}}],["star.y",{"_index":474,"t":{"83":{"position":[[1010,6],[1680,6]]}}}],["star.z",{"_index":461,"t":{"83":{"position":[[726,6],[1440,7],[1550,6]]}}}],["staramount",{"_index":442,"t":{"83":{"position":[[238,10],[457,11],[1395,11]]}}}],["starbasesize",{"_index":450,"t":{"83":{"position":[[378,12],[2095,13],[2352,12]]}}}],["starbutton1",{"_index":1393,"t":{"123":{"position":[[255,11],[399,11],[439,12],[486,12],[531,13],[2869,12]]}}}],["starbutton1.cursor",{"_index":1396,"t":{"123":{"position":[[333,18]]}}}],["starbutton1.eventmode",{"_index":1397,"t":{"123":{"position":[[365,21]]}}}],["starbutton1.position.set(50",{"_index":1395,"t":{"123":{"position":[[298,28]]}}}],["starbutton1.x",{"_index":1443,"t":{"123":{"position":[[2439,13]]}}}],["starbutton1.y",{"_index":1445,"t":{"123":{"position":[[2469,13]]}}}],["starbutton2",{"_index":1401,"t":{"123":{"position":[[576,11],[941,11],[981,12],[1028,12],[1073,13],[2856,12]]}}}],["starbutton2.cursor",{"_index":1412,"t":{"123":{"position":[[875,18]]}}}],["starbutton2.eventmode",{"_index":1413,"t":{"123":{"position":[[907,21]]}}}],["starbutton2.hitarea",{"_index":1404,"t":{"123":{"position":[[745,19]]}}}],["starbutton2.position.set(250",{"_index":1402,"t":{"123":{"position":[[619,29]]}}}],["starbutton2.x",{"_index":1450,"t":{"123":{"position":[[2548,13]]}}}],["starbutton2.y",{"_index":1453,"t":{"123":{"position":[[2578,13]]}}}],["starbutton3",{"_index":1414,"t":{"123":{"position":[[1119,11],[1416,11],[1456,12],[1503,12],[1548,13],[2882,12]]}}}],["starbutton3.cursor",{"_index":1416,"t":{"123":{"position":[[1198,18]]}}}],["starbutton3.eventmode",{"_index":1417,"t":{"123":{"position":[[1230,21]]}}}],["starbutton3.mask",{"_index":1421,"t":{"123":{"position":[[1385,16]]}}}],["starbutton3.position.set(450",{"_index":1415,"t":{"123":{"position":[[1162,29]]}}}],["starbutton3.x",{"_index":1457,"t":{"123":{"position":[[2653,13]]}}}],["starbutton3.y",{"_index":1420,"t":{"123":{"position":[[1349,14],[2683,13]]}}}],["starbutton4",{"_index":1429,"t":{"123":{"position":[[1709,11],[2180,11],[2220,12],[2267,12],[2312,13],[2895,12]]}}}],["starbutton4.cursor",{"_index":1438,"t":{"123":{"position":[[2114,18]]}}}],["starbutton4.eventmode",{"_index":1439,"t":{"123":{"position":[[2146,21]]}}}],["starbutton4.hitarea",{"_index":1437,"t":{"123":{"position":[[1984,19]]}}}],["starbutton4.mask",{"_index":1434,"t":{"123":{"position":[[1910,16]]}}}],["starbutton4.position.set(600",{"_index":1430,"t":{"123":{"position":[[1752,29]]}}}],["starbutton4.x",{"_index":1461,"t":{"123":{"position":[[2769,13]]}}}],["starbutton4.y",{"_index":1433,"t":{"123":{"position":[[1874,14],[2799,13]]}}}],["stars",{"_index":451,"t":{"83":{"position":[[413,5],[425,5]]},"139":{"position":[[3573,5],[3701,5],[3766,5],[4174,5],[5440,5]]}}}],["stars.foreach((star",{"_index":1912,"t":{"139":{"position":[[4213,20]]}}}],["stars.push(star",{"_index":459,"t":{"83":{"position":[[666,17]]}}}],["stars[0].x",{"_index":1897,"t":{"139":{"position":[[3707,10]]}}}],["stars[1].x",{"_index":1898,"t":{"139":{"position":[[3723,10]]}}}],["stars[2].x",{"_index":1899,"t":{"139":{"position":[[3741,10]]}}}],["stars[i",{"_index":488,"t":{"83":{"position":[[1427,9]]}}}],["starstretch",{"_index":449,"t":{"83":{"position":[[355,11],[2391,11]]}}}],["start",{"_index":635,"t":{"85":{"position":[[3140,5],[4888,6]]},"91":{"position":[[152,5]]},"163":{"position":[[5412,5]]},"165":{"position":[[2878,5]]},"171":{"position":[[526,5]]},"181":{"position":[[1306,5]]},"183":{"position":[[1053,5]]},"185":{"position":[[864,5]]},"199":{"position":[[682,5]]}}}],["started",{"_index":11,"t":{"73":{"position":[[108,7]]}}}],["startexture",{"_index":440,"t":{"83":{"position":[[161,11]]}}}],["starting",{"_index":2637,"t":{"203":{"position":[[182,11]]}}}],["startplay",{"_index":633,"t":{"85":{"position":[[3087,12],[3164,11]]}}}],["static",{"_index":164,"t":{"75":{"position":[[2569,9]]},"77":{"position":[[1009,9]]},"79":{"position":[[544,9]]},"81":{"position":[[880,9]]},"85":{"position":[[3008,9]]},"87":{"position":[[1119,9],[1794,9]]},"93":{"position":[[851,9]]},"107":{"position":[[571,9]]},"111":{"position":[[494,9]]},"115":{"position":[[1360,9]]},"117":{"position":[[711,9],[1248,9]]},"119":{"position":[[1020,9],[1083,9],[1114,9]]},"121":{"position":[[999,9]]},"123":{"position":[[389,9],[931,9],[1254,9],[2170,9]]},"125":{"position":[[540,9]]},"127":{"position":[[680,9],[1575,9]]},"133":{"position":[[1485,9]]},"137":{"position":[[148,9]]},"139":{"position":[[1884,9],[4156,9],[4281,9]]},"141":{"position":[[148,9]]},"145":{"position":[[165,9]]},"147":{"position":[[148,9]]},"149":{"position":[[938,9]]},"153":{"position":[[165,9]]},"155":{"position":[[148,9]]},"191":{"position":[[681,9]]},"199":{"position":[[562,9]]}}}],["steeper",{"_index":903,"t":{"95":{"position":[[3019,7]]}}}],["step(limit",{"_index":2318,"t":{"163":{"position":[[2936,11]]}}}],["stetch",{"_index":2609,"t":{"199":{"position":[[1378,6]]}}}],["still",{"_index":1425,"t":{"123":{"position":[[1624,5]]},"147":{"position":[[1032,5]]}}}],["stop",{"_index":1506,"t":{"127":{"position":[[1641,4]]},"129":{"position":[[343,4]]}}}],["store",{"_index":1020,"t":{"97":{"position":[[370,5]]},"105":{"position":[[139,5]]},"107":{"position":[[264,5]]},"113":{"position":[[302,5]]},"117":{"position":[[1520,5]]},"139":{"position":[[927,5]]},"183":{"position":[[264,5]]},"185":{"position":[[245,5]]}}}],["straight",{"_index":941,"t":{"95":{"position":[[5145,8]]}}}],["strength",{"_index":61,"t":{"75":{"position":[[422,8]]}}}],["stretchfactor",{"_index":513,"t":{"83":{"position":[[2241,13]]}}}],["strip",{"_index":2432,"t":{"171":{"position":[[287,5]]},"173":{"position":[[293,5]]}}}],["strip.x",{"_index":2434,"t":{"171":{"position":[[382,7],[476,8]]},"173":{"position":[[388,7]]}}}],["strip.y",{"_index":2435,"t":{"171":{"position":[[397,7],[491,8]]}}}],["stroke",{"_index":593,"t":{"85":{"position":[[2246,7]]},"205":{"position":[[425,7],[1019,7]]}}}],["strokethickness",{"_index":595,"t":{"85":{"position":[[2265,16]]},"205":{"position":[[444,16],[1094,16]]}}}],["stuff",{"_index":2796,"t":{"211":{"position":[[1378,5]]}}}],["stuffcontainer",{"_index":2780,"t":{"211":{"position":[[728,14]]}}}],["stuffcontainer.addchild(item",{"_index":2803,"t":{"211":{"position":[[1577,30]]}}}],["stuffcontainer.rotation",{"_index":2813,"t":{"211":{"position":[[1997,23]]}}}],["stuffcontainer.x",{"_index":2781,"t":{"211":{"position":[[767,16]]}}}],["stuffcontainer.y",{"_index":2782,"t":{"211":{"position":[[791,16]]}}}],["style",{"_index":359,"t":{"79":{"position":[[1047,5],[1181,7]]},"85":{"position":[[2099,5],[2494,7],[2752,7]]},"115":{"position":[[156,5]]},"123":{"position":[[2332,5],[2421,7],[2530,7],[2635,7],[2751,7]]},"143":{"position":[[2168,5]]},"145":{"position":[[268,5],[578,5]]},"151":{"position":[[333,5],[485,5],[977,5],[1126,5],[1277,5]]},"205":{"position":[[278,5],[733,7]]}}}],["styles",{"_index":1232,"t":{"115":{"position":[[347,6]]}}}],["super",{"_index":1805,"t":{"139":{"position":[[807,8]]}}}],["super(256",{"_index":2701,"t":{"207":{"position":[[414,10]]}}}],["super.updatetransform",{"_index":1882,"t":{"139":{"position":[[3143,24]]}}}],["supported!\\nwoo",{"_index":2569,"t":{"197":{"position":[[294,15]]}}}],["sure",{"_index":1472,"t":{"125":{"position":[[558,4]]},"127":{"position":[[233,4]]},"131":{"position":[[2624,4]]},"147":{"position":[[488,4],[1019,4]]},"165":{"position":[[2505,4]]}}}],["swap",{"_index":670,"t":{"85":{"position":[[4218,4]]},"191":{"position":[[793,4]]},"211":{"position":[[1814,4]]}}}],["symbol",{"_index":554,"t":{"85":{"position":[[1219,6],[1321,6],[1335,6],[3968,6]]}}}],["symbol.height",{"_index":564,"t":{"85":{"position":[[1461,15]]}}}],["symbol.scale.x",{"_index":560,"t":{"85":{"position":[[1376,14]]}}}],["symbol.scale.y",{"_index":561,"t":{"85":{"position":[[1393,14]]}}}],["symbol.width",{"_index":563,"t":{"85":{"position":[[1433,13],[1514,13]]}}}],["symbol.x",{"_index":565,"t":{"85":{"position":[[1477,8]]}}}],["symbol.y",{"_index":559,"t":{"85":{"position":[[1348,8]]}}}],["symbol_size",{"_index":525,"t":{"85":{"position":[[388,11],[1363,12],[1447,11],[1731,11],[2023,11],[4128,11],[4142,12],[4178,12],[4444,11]]}}}],["symbols",{"_index":532,"t":{"85":{"position":[[506,8],[1007,8],[1175,7]]}}}],["t",{"_index":429,"t":{"81":{"position":[[1975,2],[2215,1],[2234,1],[2238,2],[2252,1],[2313,2]]},"85":{"position":[[5099,1],[5519,2],[5541,2],[5551,2],[5695,3],[5705,1],[5709,1],[5729,1]]},"127":{"position":[[2181,1],[2250,4]]},"131":{"position":[[2150,1],[2199,1]]},"165":{"position":[[1998,1],[2047,1]]}}}],["t+=d.x*0.5;//jump",{"_index":1642,"t":{"131":{"position":[[2235,17]]},"165":{"position":[[2083,17]]}}}],["t.change",{"_index":709,"t":{"85":{"position":[[5250,10]]}}}],["t.change(t",{"_index":710,"t":{"85":{"position":[[5261,12]]}}}],["t.complete",{"_index":711,"t":{"85":{"position":[[5329,12]]}}}],["t.complete(t",{"_index":712,"t":{"85":{"position":[[5342,14]]}}}],["t.easing(phase",{"_index":708,"t":{"85":{"position":[[5229,17]]}}}],["t.object[t.property",{"_index":705,"t":{"85":{"position":[[5169,20],[5293,20]]}}}],["t.start",{"_index":703,"t":{"85":{"position":[[5149,8]]}}}],["t.target",{"_index":707,"t":{"85":{"position":[[5219,9],[5316,9]]}}}],["t.time",{"_index":704,"t":{"85":{"position":[[5160,8]]}}}],["t/150",{"_index":1653,"t":{"131":{"position":[[2469,7]]},"165":{"position":[[2317,7]]}}}],["t2",{"_index":433,"t":{"81":{"position":[[2229,2],[2256,3],[2281,2],[2308,2],[2340,3],[2359,3]]}}}],["t2']).then(setup",{"_index":268,"t":{"77":{"position":[[499,19]]}}}],["t3",{"_index":434,"t":{"81":{"position":[[2247,2],[2272,2],[2298,3],[2331,2],[2353,3]]}}}],["take",{"_index":367,"t":{"79":{"position":[[1163,4]]}}}],["takes",{"_index":2298,"t":{"163":{"position":[[1911,5]]}}}],["takescreenshot",{"_index":328,"t":{"79":{"position":[[285,16],[614,16]]}}}],["tangentfactor",{"_index":430,"t":{"81":{"position":[[1978,14],[1998,14],[2023,13],[2092,14],[2133,14]]}}}],["tap",{"_index":1153,"t":{"107":{"position":[[1119,3]]},"141":{"position":[[1238,3]]},"153":{"position":[[1358,3]]}}}],["target",{"_index":642,"t":{"85":{"position":[[3327,6],[3435,7],[4708,7],[4826,7]]},"95":{"position":[[975,6],[5483,6]]},"119":{"position":[[399,9],[1332,7]]},"131":{"position":[[1821,6],[1918,6]]},"155":{"position":[[528,6]]},"165":{"position":[[1669,6],[1766,6]]}}}],["target.x",{"_index":2206,"t":{"155":{"position":[[583,8],[706,9],[792,9]]}}}],["target.y",{"_index":2207,"t":{"155":{"position":[[627,8],[743,9]]}}}],["targetname",{"_index":1362,"t":{"119":{"position":[[1173,10],[1343,17]]}}}],["temp",{"_index":2810,"t":{"211":{"position":[[1841,4],[1912,5]]}}}],["temporary",{"_index":1809,"t":{"139":{"position":[[907,9]]},"207":{"position":[[579,9]]}}}],["test",{"_index":68,"t":{"75":{"position":[[498,4]]}}}],["testforaabb(greensquare",{"_index":235,"t":{"75":{"position":[[4931,25]]}}}],["testforaabb(object1",{"_index":74,"t":{"75":{"position":[[572,20]]}}}],["testing",{"_index":1068,"t":{"97":{"position":[[2098,7]]},"105":{"position":[[1943,7]]}}}],["teximage2d",{"_index":2691,"t":{"207":{"position":[[99,10]]}}}],["texin",{"_index":2301,"t":{"163":{"position":[[2085,6],[2383,6]]}}}],["texnoise",{"_index":2354,"t":{"163":{"position":[[4490,9],[4781,9]]}}}],["texripple",{"_index":2353,"t":{"163":{"position":[[4461,10],[4755,10]]}}}],["text",{"_index":23,"t":{"73":{"position":[[234,4]]},"85":{"position":[[2088,4],[2691,4]]},"131":{"position":[[525,4]]},"203":{"position":[[728,4],[801,4]]},"205":{"position":[[188,4],[678,4]]},"238":{"position":[[1519,4]]}}}],["text.anchor.set(0.5",{"_index":1564,"t":{"131":{"position":[[591,20]]}}}],["text.position.set(app.renderer.screen.width",{"_index":1565,"t":{"131":{"position":[[618,43]]}}}],["text.x",{"_index":2865,"t":{"238":{"position":[[1656,6]]}}}],["text.y",{"_index":2866,"t":{"238":{"position":[[1673,6]]}}}],["text/javascript",{"_index":2653,"t":{"203":{"position":[[536,18]]}}}],["text1",{"_index":1440,"t":{"123":{"position":[[2387,5],[2933,6]]},"201":{"position":[[554,5]]}}}],["text1.x",{"_index":1442,"t":{"123":{"position":[[2429,7]]}}}],["text1.y",{"_index":1444,"t":{"123":{"position":[[2459,7]]}}}],["text2",{"_index":1447,"t":{"123":{"position":[[2496,5],[2940,6]]},"201":{"position":[[663,5]]}}}],["text2.x",{"_index":1449,"t":{"123":{"position":[[2538,7]]}}}],["text2.y",{"_index":1452,"t":{"123":{"position":[[2568,7]]},"201":{"position":[[995,7]]}}}],["text3",{"_index":1454,"t":{"123":{"position":[[2605,5],[2947,6]]},"201":{"position":[[766,5]]}}}],["text3.x",{"_index":1456,"t":{"123":{"position":[[2643,7]]}}}],["text3.y",{"_index":1458,"t":{"123":{"position":[[2673,7]]},"201":{"position":[[1010,7]]}}}],["text4",{"_index":1459,"t":{"123":{"position":[[2710,5],[2954,6]]},"201":{"position":[[888,5]]}}}],["text4.x",{"_index":1460,"t":{"123":{"position":[[2759,7]]}}}],["text4.y",{"_index":1462,"t":{"123":{"position":[[2789,7]]},"201":{"position":[[1025,7]]}}}],["textsample",{"_index":2658,"t":{"203":{"position":[[765,10]]}}}],["textsample.position.set(50",{"_index":2660,"t":{"203":{"position":[[918,27]]}}}],["texture",{"_index":253,"t":{"77":{"position":[[144,8]]},"79":{"position":[[157,7]]},"81":{"position":[[160,7]]},"83":{"position":[[137,7]]},"85":{"position":[[4225,8]]},"87":{"position":[[913,7],[1590,7]]},"89":{"position":[[478,8],[496,9],[548,8]]},"91":{"position":[[320,8],[420,7]]},"93":{"position":[[599,7],[677,7]]},"99":{"position":[[236,7],[250,7]]},"101":{"position":[[230,7],[350,7]]},"105":{"position":[[425,7]]},"113":{"position":[[589,7]]},"117":{"position":[[161,7],[194,7]]},"131":{"position":[[185,8]]},"143":{"position":[[1131,8],[1690,8],[2160,7],[2264,8]]},"149":{"position":[[739,7]]},"163":{"position":[[882,7],[1653,7]]},"183":{"position":[[384,7],[496,8]]},"185":{"position":[[334,7]]},"191":{"position":[[176,7],[363,7],[802,7],[841,7]]},"193":{"position":[[414,7],[428,7]]},"195":{"position":[[138,7],[171,7],[280,8],[419,8]]},"199":{"position":[[1167,7],[1193,7],[1300,7]]},"207":{"position":[[46,7],[619,7]]},"211":{"position":[[499,7],[1933,7],[2108,7],[2141,7]]},"213":{"position":[[226,7]]},"238":{"position":[[250,10],[506,8],[1271,7]]}}}],["texture.basetexture.scalemode",{"_index":1280,"t":{"117":{"position":[[291,29]]}}}],["texture.frame.height",{"_index":2836,"t":{"238":{"position":[[388,21],[444,20]]}}}],["texture.frame.width",{"_index":2835,"t":{"238":{"position":[[366,19],[467,20]]}}}],["texture.frame.y",{"_index":2840,"t":{"238":{"position":[[564,16]]}}}],["texture2d(noise",{"_index":1592,"t":{"131":{"position":[[1293,16]]},"163":{"position":[[2902,16]]},"165":{"position":[[1212,16]]}}}],["texture2d(texin",{"_index":2303,"t":{"163":{"position":[[2236,16]]}}}],["texture2d(texnoise",{"_index":2358,"t":{"163":{"position":[[4618,19]]}}}],["texture2d(texripple",{"_index":2357,"t":{"163":{"position":[[4577,20]]}}}],["texture2d(texwave",{"_index":2360,"t":{"163":{"position":[[4657,18]]}}}],["texture2d(usampler",{"_index":1596,"t":{"131":{"position":[[1349,19]]}}}],["texture2d(usampler2",{"_index":2230,"t":{"157":{"position":[[921,20]]},"161":{"position":[[1313,20]]},"169":{"position":[[796,20],[1345,20]]},"179":{"position":[[1089,20]]},"181":{"position":[[934,20]]}}}],["texture2d(usamplertexture",{"_index":2405,"t":{"167":{"position":[[868,26]]}}}],["texturebutton",{"_index":1236,"t":{"115":{"position":[[755,13],[2039,14],[2259,14]]},"121":{"position":[[419,13],[2134,14],[2354,14]]}}}],["texturebuttondown",{"_index":1238,"t":{"115":{"position":[[836,17],[1880,18]]},"121":{"position":[[500,17],[1975,18]]}}}],["texturebuttonover",{"_index":1240,"t":{"115":{"position":[[926,17],[1996,18],[2148,18]]},"121":{"position":[[590,17],[2091,18],[2243,18]]}}}],["texturepromise",{"_index":803,"t":{"91":{"position":[[204,14]]}}}],["texturepromise.then((resolvedtexture",{"_index":805,"t":{"91":{"position":[[329,37]]}}}],["textures",{"_index":786,"t":{"89":{"position":[[642,8]]},"107":{"position":[[675,8]]},"111":{"position":[[171,9]]},"115":{"position":[[721,8]]},"121":{"position":[[385,8]]},"163":{"position":[[1569,8],[5725,9]]},"183":{"position":[[274,8],[289,8]]},"185":{"position":[[255,8]]},"187":{"position":[[255,8]]},"211":{"position":[[222,11],[248,8]]},"238":{"position":[[224,8],[239,8]]}}}],["textures.push",{"_index":2482,"t":{"183":{"position":[[480,15]]}}}],["textures.push(rotatedtexture",{"_index":2850,"t":{"238":{"position":[[971,30]]}}}],["texturespromise",{"_index":782,"t":{"89":{"position":[[390,15]]}}}],["texturespromise.then((textures",{"_index":785,"t":{"89":{"position":[[557,31]]}}}],["texwave",{"_index":2355,"t":{"163":{"position":[[4518,8],[4805,8]]}}}],["that'll",{"_index":1813,"t":{"139":{"position":[[1034,7]]}}}],["that's",{"_index":2732,"t":{"207":{"position":[[1202,6]]}}}],["the\\ncustom",{"_index":2659,"t":{"203":{"position":[[812,11]]}}}],["then((res",{"_index":1528,"t":{"129":{"position":[[456,11]]}}}],["then(onassetsloaded",{"_index":522,"t":{"85":{"position":[[333,24]]},"107":{"position":[[228,22]]}}}],["then(onloaded",{"_index":1530,"t":{"129":{"position":[[483,16]]}}}],["there's",{"_index":2125,"t":{"147":{"position":[[1024,7]]}}}],["thing",{"_index":2093,"t":{"145":{"position":[[1312,5]]},"153":{"position":[[1021,5],[1179,6],[1276,6]]}}}],["thing.beginfill(0x8bc5ff",{"_index":2194,"t":{"153":{"position":[[1775,25]]}}}],["thing.beginfill(0xffff00",{"_index":2103,"t":{"145":{"position":[[1894,25]]}}}],["thing.clear",{"_index":2101,"t":{"145":{"position":[[1845,14]]},"153":{"position":[[1760,14]]}}}],["thing.closepath",{"_index":2107,"t":{"145":{"position":[[2282,18]]}}}],["thing.linestyle(0",{"_index":2191,"t":{"153":{"position":[[1142,19]]}}}],["thing.linestyle(10",{"_index":2102,"t":{"145":{"position":[[1860,19]]}}}],["thing.lineto",{"_index":2106,"t":{"145":{"position":[[2139,13],[2210,13]]},"153":{"position":[[2020,13]]}}}],["thing.lineto(120",{"_index":2105,"t":{"145":{"position":[[1998,16],[2069,16]]},"153":{"position":[[1879,16],[1950,16]]}}}],["thing.moveto",{"_index":2104,"t":{"145":{"position":[[1926,13]]},"153":{"position":[[1807,13]]}}}],["thing.rotation",{"_index":2108,"t":{"145":{"position":[[2301,14]]},"153":{"position":[[2091,14]]}}}],["thing.x",{"_index":2095,"t":{"145":{"position":[[1368,7]]},"153":{"position":[[1077,7]]}}}],["thing.y",{"_index":2096,"t":{"145":{"position":[[1387,7]]},"153":{"position":[[1109,7]]}}}],["third",{"_index":2326,"t":{"163":{"position":[[3348,5]]}}}],["this._bounds.addframematrix",{"_index":1856,"t":{"139":{"position":[[2208,28]]}}}],["this.addeventlistener(event",{"_index":1839,"t":{"139":{"position":[[1799,28]]}}}],["this.alpha",{"_index":1278,"t":{"115":{"position":[[1899,10]]},"117":{"position":[[1683,10]]},"121":{"position":[[1994,10]]}}}],["this.boundary",{"_index":1815,"t":{"139":{"position":[[1091,13]]}}}],["this.boundary.copymousedata",{"_index":1823,"t":{"139":{"position":[[1223,27]]}}}],["this.boundary.cursor",{"_index":1843,"t":{"139":{"position":[[1941,21]]}}}],["this.boundary.hittest(point.x",{"_index":1864,"t":{"139":{"position":[[2400,32]]}}}],["this.boundary.hittest(to.global.x",{"_index":1834,"t":{"139":{"position":[[1578,34]]}}}],["this.boundary.mapevent(e",{"_index":1840,"t":{"139":{"position":[[1835,27]]}}}],["this.content",{"_index":1808,"t":{"139":{"position":[[867,12]]}}}],["this.content.disabletempparent(null",{"_index":1885,"t":{"139":{"position":[[3233,37]]}}}],["this.content.enabletempparent",{"_index":1883,"t":{"139":{"position":[[3168,32]]}}}],["this.content.getbounds",{"_index":1855,"t":{"139":{"position":[[2182,25]]}}}],["this.content.render(renderer",{"_index":1878,"t":{"139":{"position":[[2883,30]]}}}],["this.content.updatetransform",{"_index":1884,"t":{"139":{"position":[[3201,31]]}}}],["this.data",{"_index":1313,"t":{"117":{"position":[[1659,9]]}}}],["this.eventmode",{"_index":1841,"t":{"139":{"position":[[1867,14]]}}}],["this.isdown",{"_index":1276,"t":{"115":{"position":[[1845,11],[1941,11],[2107,13],[2218,13]]},"121":{"position":[[1940,11],[2036,11],[2202,13],[2313,13]]}}}],["this.isover",{"_index":1279,"t":{"115":{"position":[[1965,13],[2084,11],[2194,11]]},"121":{"position":[[2060,13],[2179,11],[2289,11]]}}}],["this.originaltransform",{"_index":1811,"t":{"139":{"position":[[968,22]]}}}],["this.texture",{"_index":1277,"t":{"115":{"position":[[1865,12],[1981,12],[2024,12],[2133,12],[2244,12]]},"121":{"position":[[1960,12],[2076,12],[2119,12],[2228,12],[2339,12]]}}}],["this.tint",{"_index":1463,"t":{"123":{"position":[[2985,9],[3036,9],[3086,9]]}}}],["this.worldtransform",{"_index":1857,"t":{"139":{"position":[[2237,20]]}}}],["this.worldtransform.applyinverse(to.global",{"_index":1828,"t":{"139":{"position":[[1430,43]]}}}],["through",{"_index":1061,"t":{"97":{"position":[[1773,7]]},"105":{"position":[[1623,7]]},"113":{"position":[[1654,7]]},"139":{"position":[[1904,7],[2116,7],[2348,7]]}}}],["throw",{"_index":1849,"t":{"139":{"position":[[2036,5]]}}}],["tick",{"_index":985,"t":{"95":{"position":[[8396,4]]},"113":{"position":[[1610,4],[2379,4]]}}}],["ticker",{"_index":1224,"t":{"113":{"position":[[2372,6]]}}}],["tiling",{"_index":20,"t":{"73":{"position":[[204,6]]},"195":{"position":[[249,6]]}}}],["tilingsprite",{"_index":2556,"t":{"195":{"position":[[381,12]]}}}],["tilingsprite.tileposition.x",{"_index":2561,"t":{"195":{"position":[[652,27]]}}}],["tilingsprite.tileposition.y",{"_index":2562,"t":{"195":{"position":[[686,27]]}}}],["tilingsprite.tilescale.x",{"_index":2559,"t":{"195":{"position":[[556,24]]}}}],["tilingsprite.tilescale.y",{"_index":2560,"t":{"195":{"position":[[604,24]]}}}],["time",{"_index":644,"t":{"85":{"position":[[3375,4],[3443,5],[3820,4],[4716,5],[4842,5]]},"87":{"position":[[1337,4],[1368,4]]},"97":{"position":[[1226,4]]},"105":{"position":[[1079,4]]},"113":{"position":[[1027,4]]},"131":{"position":[[1050,5],[2821,5]]},"133":{"position":[[802,5]]},"163":{"position":[[3470,5],[4045,5],[5438,4],[5476,4],[5584,5],[5622,5]]},"165":{"position":[[969,5],[2485,5],[2904,4],[2942,4],[2986,5]]},"181":{"position":[[899,5],[967,5],[1104,5]]},"183":{"position":[[429,4],[505,4]]},"207":{"position":[[1078,4]]}}}],["time*0.25)*amplitude",{"_index":2336,"t":{"163":{"position":[[3712,22]]}}}],["time+cos(time)+2",{"_index":1626,"t":{"131":{"position":[[1850,18]]},"165":{"position":[[1698,18]]}}}],["timer",{"_index":1101,"t":{"103":{"position":[[472,5],[685,8]]}}}],["title",{"_index":1324,"t":{"119":{"position":[[231,5]]},"127":{"position":[[1192,5],[1204,5]]}}}],["title.anchor.set(0.5",{"_index":1502,"t":{"127":{"position":[[1417,21]]}}}],["title.roundpixels",{"_index":1500,"t":{"127":{"position":[[1351,17]]}}}],["title.x",{"_index":1334,"t":{"119":{"position":[[432,7]]},"127":{"position":[[1377,7]]}}}],["title.y",{"_index":1501,"t":{"127":{"position":[[1403,7]]}}}],["to.global",{"_index":1829,"t":{"139":{"position":[[1474,11]]}}}],["to.global.y",{"_index":1835,"t":{"139":{"position":[[1613,13]]}}}],["to.target",{"_index":1833,"t":{"139":{"position":[[1566,9]]}}}],["todo",{"_index":1830,"t":{"139":{"position":[[1489,5]]}}}],["toggling",{"_index":819,"t":{"93":{"position":[[586,8]]}}}],["tomousedirection",{"_index":214,"t":{"75":{"position":[[4200,16]]}}}],["tomousedirection.x",{"_index":224,"t":{"75":{"position":[[4437,19]]}}}],["tomousedirection.y",{"_index":223,"t":{"75":{"position":[[4417,19]]}}}],["top",{"_index":571,"t":{"85":{"position":[[1648,3],[1850,3]]},"95":{"position":[[1152,3],[1701,3],[1808,3],[5721,3],[6651,3],[6823,3]]},"119":{"position":[[1265,3]]}}}],["top.addchild(headertext",{"_index":626,"t":{"85":{"position":[[2884,25]]}}}],["top.beginfill(0",{"_index":578,"t":{"85":{"position":[[1877,16]]}}}],["top.drawrect(0",{"_index":579,"t":{"85":{"position":[[1898,15]]}}}],["totaldudes",{"_index":1024,"t":{"97":{"position":[[429,10],[466,11]]},"105":{"position":[[181,10],[218,11]]}}}],["totalsprites",{"_index":1203,"t":{"113":{"position":[[350,12],[438,13]]}}}],["totaltime",{"_index":1567,"t":{"131":{"position":[[730,9],[3006,10],[3017,9]]}}}],["touch",{"_index":1152,"t":{"107":{"position":[[1113,5]]},"111":{"position":[[574,5],[689,5],[782,5]]},"117":{"position":[[680,5],[1000,5],[1650,5]]},"121":{"position":[[1054,5],[1513,5]]}}}],["towards",{"_index":509,"t":{"83":{"position":[[2128,7],[2161,7]]}}}],["track",{"_index":1311,"t":{"117":{"position":[[1612,5]]},"199":{"position":[[997,5]]},"207":{"position":[[1110,5]]}}}],["trail",{"_index":383,"t":{"81":{"position":[[338,5],[415,5]]}}}],["trailtexture",{"_index":376,"t":{"81":{"position":[[184,12]]}}}],["transform",{"_index":1087,"t":{"99":{"position":[[896,9]]},"139":{"position":[[957,10],[3113,9]]},"193":{"position":[[1074,9]]}}}],["transformation",{"_index":2539,"t":{"189":{"position":[[640,14]]}}}],["transforms",{"_index":1790,"t":{"139":{"position":[[422,10]]}}}],["translationmatrix",{"_index":2222,"t":{"157":{"position":[[616,18],[751,17]]},"159":{"position":[[1109,18],[1245,17]]},"161":{"position":[[1008,18],[1143,17]]},"163":{"position":[[658,18],[793,17]]},"165":{"position":[[607,18],[742,17]]},"167":{"position":[[557,18],[692,17]]},"169":{"position":[[491,18],[626,17],[1040,18],[1175,17]]},"175":{"position":[[332,18],[435,17]]},"177":{"position":[[577,18],[718,17]]},"179":{"position":[[704,18],[877,17]]},"181":{"position":[[588,18],[723,17]]}}}],["travelling",{"_index":225,"t":{"75":{"position":[[4505,10]]}}}],["triangle",{"_index":2406,"t":{"167":{"position":[[914,8],[1567,10]]},"169":{"position":[[1597,8],[1837,10]]},"175":{"position":[[595,8]]},"177":{"position":[[892,8]]},"179":{"position":[[1314,8]]}}}],["triangle.position.set(400",{"_index":2412,"t":{"167":{"position":[[1378,26]]},"169":{"position":[[1693,26]]},"175":{"position":[[639,26]]},"177":{"position":[[936,26]]},"179":{"position":[[1358,26]]}}}],["triangle.rotation",{"_index":2418,"t":{"167":{"position":[[1606,17]]},"169":{"position":[[1876,17]]},"175":{"position":[[730,17]]},"177":{"position":[[1050,17]]},"179":{"position":[[1472,17]]}}}],["triangle.scale.set(2",{"_index":2413,"t":{"167":{"position":[[1411,22]]},"169":{"position":[[1726,22]]},"177":{"position":[[969,22]]},"179":{"position":[[1391,22]]}}}],["triangle2",{"_index":2408,"t":{"167":{"position":[[1072,9],[1556,10]]},"169":{"position":[[1647,9]]}}}],["triangle2.position.set(200",{"_index":2414,"t":{"167":{"position":[[1434,27]]}}}],["triangle2.position.set(500",{"_index":2427,"t":{"169":{"position":[[1749,27]]}}}],["triangle2.rotation",{"_index":2419,"t":{"167":{"position":[[1633,18]]},"169":{"position":[[1903,18]]}}}],["triangle2.scale.set(3",{"_index":2428,"t":{"169":{"position":[[1783,23]]}}}],["triangle3",{"_index":2410,"t":{"167":{"position":[[1225,9]]}}}],["triangle3.position.set(500",{"_index":2415,"t":{"167":{"position":[[1468,27]]}}}],["triangle3.rotation",{"_index":2420,"t":{"167":{"position":[[1661,18]]}}}],["triangle3.scale.set(3",{"_index":2416,"t":{"167":{"position":[[1502,23]]}}}],["triangles",{"_index":2255,"t":{"159":{"position":[[1413,9]]}}}],["triangles.position.set(400",{"_index":2256,"t":{"159":{"position":[[1458,27]]}}}],["triangles.rotation",{"_index":2258,"t":{"159":{"position":[[1551,18]]}}}],["trigger",{"_index":2575,"t":{"199":{"position":[[188,7]]}}}],["trim",{"_index":2841,"t":{"238":{"position":[[594,4],[719,5],[925,5]]}}}],["true",{"_index":320,"t":{"77":{"position":[[1907,5]]},"83":{"position":[[626,6]]},"85":{"position":[[2297,5],[2413,5],[3209,5]]},"93":{"position":[[623,5]]},"113":{"position":[[185,5],[201,5],[217,5],[228,5],[241,5]]},"115":{"position":[[1859,5],[2098,5]]},"119":{"position":[[155,5]]},"121":{"position":[[1954,5],[2193,5]]},"125":{"position":[[172,5]]},"127":{"position":[[79,5],[1371,5]]},"137":{"position":[[1700,5]]},"139":{"position":[[294,5]]},"141":{"position":[[1089,5]]},"143":{"position":[[79,5]]},"145":{"position":[[79,5]]},"151":{"position":[[111,5]]},"153":{"position":[[79,5]]},"159":{"position":[[236,5],[532,4],[666,4]]},"191":{"position":[[164,5]]},"203":{"position":[[566,7]]},"205":{"position":[[476,5],[592,5],[878,5]]},"207":{"position":[[1507,5],[1563,5]]},"209":{"position":[[217,5]]},"211":{"position":[[2123,6]]}}}],["turn",{"_index":1969,"t":{"141":{"position":[[1245,4]]},"153":{"position":[[1365,4]]}}}],["tween",{"_index":691,"t":{"85":{"position":[[4760,5],[4939,6]]}}}],["tweening",{"_index":683,"t":{"85":{"position":[[4551,8],[4616,8],[4658,8]]}}}],["tweening.length",{"_index":699,"t":{"85":{"position":[[5069,16]]}}}],["tweening.push(tween",{"_index":697,"t":{"85":{"position":[[4910,21]]}}}],["tweening.splice(tweening.indexof(remove[i",{"_index":715,"t":{"85":{"position":[[5419,44]]}}}],["tweening[i",{"_index":700,"t":{"85":{"position":[[5103,12]]}}}],["tweenjs",{"_index":722,"t":{"85":{"position":[[5581,8]]}}}],["tweento(object",{"_index":687,"t":{"85":{"position":[[4682,15]]}}}],["tweento(r",{"_index":647,"t":{"85":{"position":[[3412,10]]}}}],["twist",{"_index":2812,"t":{"211":{"position":[[1982,5]]}}}],["two",{"_index":65,"t":{"75":{"position":[[459,3],[541,3],[1792,3],[4902,3]]},"95":{"position":[[8613,3]]},"195":{"position":[[368,3]]},"211":{"position":[[211,3]]}}}],["type",{"_index":1360,"t":{"119":{"position":[[1152,4],[1318,7],[1398,4],[1425,4]]}}}],["u",{"_index":2214,"t":{"157":{"position":[[374,2],[388,2],[409,2]]},"161":{"position":[[374,2],[388,2],[409,2],[733,2],[747,2],[762,2]]},"163":{"position":[[394,2],[408,2],[429,2]]},"165":{"position":[[393,2],[407,2],[428,2]]},"167":{"position":[[363,2],[377,2],[392,2]]},"169":{"position":[[331,2],[345,2],[361,2]]},"179":{"position":[[503,2],[517,2],[532,2]]},"181":{"position":[[374,2],[388,2],[409,2]]}}}],["ua",{"_index":1013,"t":{"95":{"position":[[9055,2],[9242,3],[9253,2],[9382,2],[9413,2]]}}}],["ub",{"_index":1014,"t":{"95":{"position":[[9129,2],[9263,2],[9273,2]]}}}],["under",{"_index":2589,"t":{"199":{"position":[[776,5]]}}}],["underlying",{"_index":1694,"t":{"133":{"position":[[1023,10]]}}}],["uniform",{"_index":1578,"t":{"131":{"position":[[983,7],[1011,7],[1036,7]]},"133":{"position":[[572,7],[718,7],[738,7],[762,7],[788,7]]},"157":{"position":[[603,7],[635,7],[863,7]]},"159":{"position":[[1096,7],[1128,7]]},"161":{"position":[[995,7],[1027,7],[1255,7]]},"163":{"position":[[645,7],[677,7],[1098,7],[2024,7],[2046,7],[2067,7],[2828,7],[2849,7],[3431,7],[3456,7],[4443,7],[4472,7],[4500,7]]},"165":{"position":[[594,7],[626,7],[930,7],[955,7]]},"167":{"position":[[544,7],[576,7],[804,7]]},"169":{"position":[[478,7],[510,7],[738,7],[1027,7],[1059,7],[1287,7]]},"175":{"position":[[319,7],[351,7]]},"177":{"position":[[564,7],[596,7]]},"179":{"position":[[691,7],[723,7],[1031,7]]},"181":{"position":[[575,7],[607,7],[856,7],[885,7]]}}}],["uniforms",{"_index":1541,"t":{"129":{"position":[[727,8]]},"165":{"position":[[2406,8],[2744,10]]},"179":{"position":[[1147,8],[1297,10]]},"181":{"position":[[1012,8],[1172,10]]}}}],["uniforms.noise.basetexture.mipmap",{"_index":2398,"t":{"165":{"position":[[2611,33]]}}}],["uniforms.noise.basetexture.wrapmode",{"_index":2397,"t":{"165":{"position":[[2549,35]]}}}],["until",{"_index":760,"t":{"87":{"position":[[1283,5]]}}}],["up",{"_index":1629,"t":{"131":{"position":[[1938,2],[2019,3],[2069,3]]},"165":{"position":[[1786,2],[1867,3],[1917,3]]},"211":{"position":[[1993,3]]}}}],["update",{"_index":175,"t":{"75":{"position":[[2740,6],[3807,6]]},"81":{"position":[[1104,6],[1165,6],[1305,6]]},"83":{"position":[[1173,6]]},"85":{"position":[[3612,7],[3651,6],[3733,6],[3961,6],[4970,7]]},"95":{"position":[[904,6],[2817,6],[2878,6],[3649,6],[5411,6],[8005,6],[8353,6]]},"97":{"position":[[1795,6]]},"99":{"position":[[795,6]]},"103":{"position":[[461,6]]},"105":{"position":[[1645,6]]},"113":{"position":[[1678,6]]},"119":{"position":[[1624,6]]},"127":{"position":[[1806,6]]},"129":{"position":[[900,6]]},"131":{"position":[[2947,7]]},"147":{"position":[[970,6]]},"189":{"position":[[482,6]]},"193":{"position":[[973,6]]}}}],["updates",{"_index":1881,"t":{"139":{"position":[[3095,7]]}}}],["updatetransform",{"_index":1880,"t":{"139":{"position":[[3074,15],[3123,17]]}}}],["upload",{"_index":2693,"t":{"207":{"position":[[136,6],[1056,6]]}}}],["upload(renderer",{"_index":2702,"t":{"207":{"position":[[431,16]]}}}],["uploaded",{"_index":2706,"t":{"207":{"position":[[630,8]]}}}],["url",{"_index":34,"t":{"75":{"position":[[87,3]]},"79":{"position":[[322,3],[479,4]]}}}],["url(\\'https://pixijs.com/assets/bunny.png\\'),auto",{"_index":1228,"t":{"115":{"position":[[192,52]]}}}],["url(\\'https://pixijs.com/assets/bunny_saturated.png\\'),auto",{"_index":1230,"t":{"115":{"position":[[263,62]]}}}],["us/docs/web/api/canvasrenderingcontext2d/createlineargradient",{"_index":2759,"t":{"209":{"position":[[109,61]]}}}],["usampler",{"_index":1580,"t":{"131":{"position":[[1001,9]]}}}],["usampler2",{"_index":2229,"t":{"157":{"position":[[881,10],[957,10]]},"161":{"position":[[1273,10],[1349,10]]},"169":{"position":[[756,10],[831,10],[1305,10],[1508,10]]},"179":{"position":[[1049,10],[1160,10]]},"181":{"position":[[874,10],[1025,10]]}}}],["usamplertexture",{"_index":2404,"t":{"167":{"position":[[822,16],[976,16],[1135,16],[1288,16]]}}}],["use",{"_index":217,"t":{"75":{"position":[[4327,3]]},"99":{"position":[[858,3]]},"111":{"position":[[673,3]]},"121":{"position":[[1317,3],[1509,3]]},"129":{"position":[[786,3]]},"131":{"position":[[773,3]]},"139":{"position":[[2007,3]]},"163":{"position":[[515,3]]},"193":{"position":[[1036,3]]},"207":{"position":[[1098,3]]},"209":{"position":[[538,3]]}}}],["used",{"_index":485,"t":{"83":{"position":[[1280,4]]},"97":{"position":[[1180,4]]},"101":{"position":[[170,4]]},"105":{"position":[[1033,4]]},"113":{"position":[[979,4]]},"123":{"position":[[714,4]]},"131":{"position":[[144,4],[2298,4]]},"139":{"position":[[193,4]]},"165":{"position":[[2146,4],[2525,4]]},"199":{"position":[[180,4]]},"207":{"position":[[1116,4]]},"211":{"position":[[265,4],[1631,4]]}}}],["useful",{"_index":2586,"t":{"199":{"position":[[717,6]]}}}],["user",{"_index":761,"t":{"87":{"position":[[1318,4],[1894,4]]},"127":{"position":[[916,4]]}}}],["uses",{"_index":1025,"t":{"97":{"position":[[513,4]]},"105":{"position":[[265,4]]},"133":{"position":[[543,4]]},"209":{"position":[[46,4]]},"211":{"position":[[483,4]]}}}],["using",{"_index":310,"t":{"77":{"position":[[1540,5]]},"107":{"position":[[790,5]]},"117":{"position":[[1006,5]]},"127":{"position":[[921,5]]},"139":{"position":[[400,5],[719,5]]},"191":{"position":[[353,5]]},"193":{"position":[[86,5]]},"199":{"position":[[1284,5]]},"203":{"position":[[733,5],[806,5]]},"238":{"position":[[1257,5]]}}}],["usseful",{"_index":2725,"t":{"207":{"position":[[1045,7]]}}}],["utility",{"_index":684,"t":{"85":{"position":[[4560,7]]}}}],["uv",{"_index":1620,"t":{"131":{"position":[[1716,2],[1764,2],[1773,2]]},"163":{"position":[[1167,2],[1216,2],[2137,2],[2206,2],[2253,4],[3499,2],[3548,2]]},"165":{"position":[[1583,2],[1612,2],[1621,2]]}}}],["uv.x",{"_index":1636,"t":{"131":{"position":[[2064,4]]},"165":{"position":[[1912,4]]}}}],["uv.x*0.25",{"_index":2335,"t":{"163":{"position":[[3701,10]]}}}],["uv.y",{"_index":1637,"t":{"131":{"position":[[2075,4]]},"165":{"position":[[1923,4]]}}}],["uvs",{"_index":1199,"t":{"113":{"position":[[223,4]]},"238":{"position":[[805,4]]}}}],["v",{"_index":2215,"t":{"157":{"position":[[377,1],[391,1],[412,1]]},"161":{"position":[[377,1],[391,1],[412,1],[736,1],[750,1],[765,1]]},"163":{"position":[[397,1],[411,1],[432,1]]},"165":{"position":[[396,1],[410,1],[431,1]]},"167":{"position":[[366,1],[380,1],[395,1]]},"169":{"position":[[334,1],[348,1],[364,1]]},"179":{"position":[[506,1],[520,1],[535,1]]},"181":{"position":[[377,1],[391,1],[412,1]]}}}],["v5",{"_index":1678,"t":{"133":{"position":[[518,2]]},"207":{"position":[[43,2]]}}}],["val",{"_index":2517,"t":{"187":{"position":[[339,3]]}}}],["value",{"_index":2122,"t":{"147":{"position":[[987,6]]}}}],["values",{"_index":400,"t":{"81":{"position":[[1182,6]]},"115":{"position":[[1656,9]]},"121":{"position":[[1751,9]]},"147":{"position":[[1134,6]]}}}],["variety",{"_index":6,"t":{"73":{"position":[[57,7]]}}}],["varying",{"_index":1575,"t":{"131":{"position":[[955,7]]},"133":{"position":[[690,7]]},"157":{"position":[[666,7],[844,7]]},"159":{"position":[[1159,7],[1336,7]]},"161":{"position":[[1058,7],[1236,7]]},"163":{"position":[[708,7],[1079,7],[2005,7],[2809,7],[3412,7],[4424,7]]},"165":{"position":[[657,7],[911,7]]},"167":{"position":[[607,7],[785,7]]},"169":{"position":[[541,7],[719,7],[1090,7],[1268,7]]},"177":{"position":[[627,7],[811,7]]},"179":{"position":[[754,7],[773,7],[991,7],[1012,7]]},"181":{"position":[[638,7],[837,7]]}}}],["vcol",{"_index":2252,"t":{"159":{"position":[[1172,5],[1192,4],[1349,5]]}}}],["vcollision",{"_index":99,"t":{"75":{"position":[[1062,10]]}}}],["vcollision.x",{"_index":108,"t":{"75":{"position":[[1313,12]]}}}],["vcollision.y",{"_index":109,"t":{"75":{"position":[[1338,12]]}}}],["vcollisionnorm",{"_index":107,"t":{"75":{"position":[[1280,14]]}}}],["vcollisionnorm.x",{"_index":117,"t":{"75":{"position":[[1545,16],[1707,17]]}}}],["vcollisionnorm.y",{"_index":119,"t":{"75":{"position":[[1586,17],[1735,17]]}}}],["vcolor",{"_index":2471,"t":{"177":{"position":[[640,7],[662,6],[824,7]]},"179":{"position":[[786,7],[821,6],[1004,7]]}}}],["vec2",{"_index":1576,"t":{"131":{"position":[[963,4],[1211,4],[1470,4],[1481,5],[1711,4],[2217,4]]},"133":{"position":[[698,4],[726,4],[822,4]]},"157":{"position":[[560,4],[592,4],[674,4],[852,4]]},"159":{"position":[[1040,4],[1062,4]]},"161":{"position":[[952,4],[984,4],[1066,4],[1244,4]]},"163":{"position":[[602,4],[634,4],[716,4],[1087,4],[1211,4],[1243,4],[2013,4],[2132,4],[2817,4],[3420,4],[3543,4],[4432,4]]},"165":{"position":[[551,4],[583,4],[665,4],[919,4],[1130,4],[1337,4],[1348,5],[1578,4],[2065,4]]},"167":{"position":[[501,4],[533,4],[615,4],[793,4]]},"169":{"position":[[435,4],[467,4],[549,4],[727,4],[984,4],[1016,4],[1098,4],[1276,4]]},"175":{"position":[[297,4]]},"177":{"position":[[519,4]]},"179":{"position":[[625,4],[680,4],[762,4],[1020,4]]},"181":{"position":[[532,4],[564,4],[646,4],[845,4]]}}}],["vec2(0.5",{"_index":2302,"t":{"163":{"position":[[2211,11]]}}}],["vec2(0.5))*2.0",{"_index":2275,"t":{"163":{"position":[[1227,15],[3559,15]]}}}],["vec2(h",{"_index":2393,"t":{"165":{"position":[[1264,6]]}}}],["vec2(h+h2",{"_index":1598,"t":{"131":{"position":[[1394,9]]}}}],["vec2(p.x",{"_index":1593,"t":{"131":{"position":[[1310,9]]},"165":{"position":[[1229,9]]}}}],["vec2(vtexturecoord.x",{"_index":1621,"t":{"131":{"position":[[1721,21]]}}}],["vec2(vuvs.x,1",{"_index":2394,"t":{"165":{"position":[[1588,14]]}}}],["vec3",{"_index":1602,"t":{"131":{"position":[[1436,4],[1459,4],[1499,4],[1519,5],[1645,4],[1654,5],[1781,4],[1816,4],[1892,4],[1933,4],[1988,4],[2034,4],[2123,4],[2190,4],[2360,4],[2428,5]]},"159":{"position":[[1084,4],[1167,4],[1344,4]]},"163":{"position":[[3575,4]]},"165":{"position":[[1303,4],[1326,4],[1366,4],[1386,5],[1512,4],[1521,5],[1629,4],[1664,4],[1740,4],[1781,4],[1836,4],[1882,4],[1971,4],[2038,4],[2208,4],[2276,5]]},"177":{"position":[[551,4],[635,4],[819,4]]},"179":{"position":[[657,4],[781,4],[999,4]]}}}],["vec3(0",{"_index":1631,"t":{"131":{"position":[[1969,8],[2134,9]]},"163":{"position":[[3591,9]]},"165":{"position":[[1817,8],[1982,9]]}}}],["vec3(0.,time",{"_index":1624,"t":{"131":{"position":[[1792,12]]},"165":{"position":[[1640,12]]}}}],["vec3(0.8,0.0",{"_index":1650,"t":{"131":{"position":[[2402,13]]},"165":{"position":[[2250,13]]}}}],["vec3(1.0",{"_index":1649,"t":{"131":{"position":[[2382,9]]},"165":{"position":[[2230,9]]}}}],["vec3(avertexposition",{"_index":2227,"t":{"157":{"position":[[771,21]]},"161":{"position":[[1163,21]]},"163":{"position":[[813,21]]},"165":{"position":[[762,21]]},"167":{"position":[[712,21]]},"169":{"position":[[646,21],[1195,21]]},"175":{"position":[[455,21]]},"177":{"position":[[738,21]]},"179":{"position":[[897,21]]},"181":{"position":[[743,21]]}}}],["vec3(avpos",{"_index":2253,"t":{"159":{"position":[[1265,10]]}}}],["vec3(sin(time)*0.1",{"_index":1625,"t":{"131":{"position":[[1830,19]]},"165":{"position":[[1678,19]]}}}],["vec4",{"_index":1684,"t":{"133":{"position":[[746,4],[770,4],[1066,5]]},"163":{"position":[[1270,4],[1310,4],[1350,4],[2223,4],[4563,4],[4605,4],[4645,4]]}}}],["vec4((projectionmatrix",{"_index":2226,"t":{"157":{"position":[[726,22]]},"159":{"position":[[1220,22]]},"161":{"position":[[1118,22]]},"163":{"position":[[768,22]]},"165":{"position":[[717,22]]},"167":{"position":[[667,22]]},"169":{"position":[[601,22],[1150,22]]},"175":{"position":[[410,22]]},"177":{"position":[[693,22]]},"179":{"position":[[852,22]]},"181":{"position":[[698,22]]}}}],["vec4(0.4",{"_index":2281,"t":{"163":{"position":[[1324,9]]}}}],["vec4(0.8",{"_index":2279,"t":{"163":{"position":[[1284,9]]}}}],["vec4(1.0",{"_index":1691,"t":{"133":{"position":[[941,9]]},"175":{"position":[[557,9]]}}}],["vec4(col",{"_index":1656,"t":{"131":{"position":[[2533,9]]},"165":{"position":[[2381,9]]}}}],["vec4(color",{"_index":2319,"t":{"163":{"position":[[2971,12]]}}}],["vec4(outcolor,1.0",{"_index":2343,"t":{"163":{"position":[[3981,19]]}}}],["vec4(vcol",{"_index":2254,"t":{"159":{"position":[[1384,10]]}}}],["vec4(vcolor",{"_index":2472,"t":{"177":{"position":[[861,12]]},"179":{"position":[[1118,12]]}}}],["vector",{"_index":212,"t":{"75":{"position":[[4139,6]]}}}],["version",{"_index":1558,"t":{"131":{"position":[[209,7],[248,7]]}}}],["vertex",{"_index":1679,"t":{"133":{"position":[[529,6],[596,6]]},"163":{"position":[[500,6]]}}}],["vertexshader",{"_index":1534,"t":{"129":{"position":[[604,14]]}}}],["vertexsrc",{"_index":2265,"t":{"163":{"position":[[553,9]]},"165":{"position":[[502,9]]},"179":{"position":[[576,9]]},"181":{"position":[[483,9]]}}}],["vertice",{"_index":1099,"t":{"103":{"position":[[360,7],[523,7]]}}}],["very",{"_index":682,"t":{"85":{"position":[[4539,4]]},"147":{"position":[[1155,4]]},"209":{"position":[[364,4],[369,4]]}}}],["vfiltercoord",{"_index":2120,"t":{"147":{"position":[[957,12]]}}}],["video",{"_index":2576,"t":{"199":{"position":[[200,5],[700,5],[877,5],[1161,5],[1294,5]]}}}],["videos",{"_index":2590,"t":{"199":{"position":[[796,6],[938,6],[976,6]]}}}],["videosprite",{"_index":2608,"t":{"199":{"position":[[1335,11]]}}}],["videosprite.height",{"_index":2612,"t":{"199":{"position":[[1438,18]]}}}],["videosprite.width",{"_index":2611,"t":{"199":{"position":[[1400,17]]}}}],["view",{"_index":2547,"t":{"193":{"position":[[164,4],[243,5]]}}}],["void",{"_index":1618,"t":{"131":{"position":[[1697,4]]},"133":{"position":[[808,4]]},"157":{"position":[[685,4],[892,4]]},"159":{"position":[[1178,4],[1355,4]]},"161":{"position":[[1077,4],[1284,4]]},"163":{"position":[[727,4],[1118,4],[2092,4],[2874,4],[3476,4],[4527,4]]},"165":{"position":[[676,4],[1564,4]]},"167":{"position":[[626,4],[839,4]]},"169":{"position":[[560,4],[767,4],[1109,4],[1316,4]]},"175":{"position":[[382,4],[528,4]]},"177":{"position":[[648,4],[832,4]]},"179":{"position":[[794,4],[1060,4]]},"181":{"position":[[657,4],[905,4]]}}}],["vrelativevelocity",{"_index":110,"t":{"75":{"position":[[1372,17]]}}}],["vrelativevelocity.x",{"_index":116,"t":{"75":{"position":[[1523,19]]}}}],["vrelativevelocity.y",{"_index":118,"t":{"75":{"position":[[1564,19]]}}}],["vtexturecoord",{"_index":1577,"t":{"131":{"position":[[968,14]]},"133":{"position":[[703,14],[839,13]]}}}],["vtexturecoord).r",{"_index":1597,"t":{"131":{"position":[[1369,17]]}}}],["vtexturecoord.y",{"_index":1622,"t":{"131":{"position":[[1746,17]]}}}],["vuvs",{"_index":2224,"t":{"157":{"position":[[679,5],[699,4],[857,5],[942,4]]},"161":{"position":[[1071,5],[1091,4],[1249,5],[1334,4]]},"163":{"position":[[721,5],[741,4],[1092,5],[1221,5],[2018,5],[2142,5],[2822,5],[3425,5],[3553,5],[4437,5],[4598,6],[4638,6],[4676,6]]},"165":{"position":[[670,5],[690,4],[924,5]]},"167":{"position":[[620,5],[640,4],[798,5],[895,6]]},"169":{"position":[[554,5],[574,4],[732,5],[817,6],[1103,5],[1123,4],[1281,5],[1366,6]]},"179":{"position":[[767,5],[808,4],[1025,5],[1110,5]]},"181":{"position":[[651,5],[671,4],[850,5],[955,4]]}}}],["vuvs).r",{"_index":2317,"t":{"163":{"position":[[2919,8]]}}}],["vuvs.x",{"_index":2473,"t":{"181":{"position":[[975,8]]}}}],["vuvs.y",{"_index":2395,"t":{"165":{"position":[[1603,8]]}}}],["w",{"_index":2837,"t":{"238":{"position":[[416,1],[581,2]]}}}],["wait",{"_index":759,"t":{"87":{"position":[[1273,4]]},"129":{"position":[[360,4]]}}}],["want",{"_index":1310,"t":{"117":{"position":[[1604,4]]}}}],["wanted",{"_index":1555,"t":{"131":{"position":[[169,6]]}}}],["warning",{"_index":1539,"t":{"129":{"position":[[704,7]]}}}],["warpspeed",{"_index":448,"t":{"83":{"position":[[334,9],[1106,9],[1118,9],[1304,10]]}}}],["wave",{"_index":2359,"t":{"163":{"position":[[4650,4]]}}}],["wave,noise.r",{"_index":2362,"t":{"163":{"position":[[4710,14]]}}}],["wavecontainer",{"_index":2348,"t":{"163":{"position":[[4272,13]]}}}],["wavecontainer.addchild(wavequad",{"_index":2349,"t":{"163":{"position":[[4310,33]]}}}],["wavecontainer.position.set(10",{"_index":2369,"t":{"163":{"position":[[5091,30]]}}}],["wavefunctions",{"_index":2329,"t":{"163":{"position":[[3610,13]]}}}],["wavequad",{"_index":2347,"t":{"163":{"position":[[4218,8]]}}}],["wavequad.shader.uniforms.time",{"_index":2384,"t":{"163":{"position":[[5590,29]]}}}],["waveshader",{"_index":2345,"t":{"163":{"position":[[4063,10],[4253,12]]}}}],["wavetexture",{"_index":2346,"t":{"163":{"position":[[4142,11],[4814,12],[5977,11]]}}}],["waveuniforms",{"_index":2344,"t":{"163":{"position":[[4011,12],[4121,14]]}}}],["way",{"_index":938,"t":{"95":{"position":[[5072,3]]},"123":{"position":[[1661,4]]},"131":{"position":[[85,3]]}}}],["web",{"_index":2643,"t":{"203":{"position":[[316,3]]}}}],["webfont",{"_index":2657,"t":{"203":{"position":[[751,7],[834,9]]}}}],["webgl",{"_index":2553,"t":{"195":{"position":[[315,5]]},"207":{"position":[[93,5],[1188,5]]},"238":{"position":[[851,5]]}}}],["welcome",{"_index":0,"t":{"73":{"position":[[0,7]]}}}],["well",{"_index":930,"t":{"95":{"position":[[4857,5]]}}}],["wf",{"_index":2645,"t":{"203":{"position":[[359,2]]}}}],["wf.async",{"_index":2654,"t":{"203":{"position":[[555,8]]}}}],["wf.src",{"_index":2647,"t":{"203":{"position":[[398,6]]}}}],["wf.type",{"_index":2652,"t":{"203":{"position":[[526,7]]}}}],["wheel",{"_index":1837,"t":{"139":{"position":[[1767,8],[4198,5],[4345,5],[5429,5]]}}}],["wheels",{"_index":608,"t":{"85":{"position":[[2484,9]]}}}],["wherever",{"_index":1467,"t":{"125":{"position":[[88,8]]}}}],["whether",{"_index":190,"t":{"75":{"position":[[3099,7]]}}}],["white",{"_index":1350,"t":{"119":{"position":[[783,5],[804,5],[949,6]]},"141":{"position":[[1333,8]]},"153":{"position":[[1453,8]]},"203":{"position":[[722,5],[889,8]]},"238":{"position":[[1628,8]]}}}],["whitebox",{"_index":1351,"t":{"119":{"position":[[820,8],[1685,9]]}}}],["whitebox.eventmode",{"_index":1357,"t":{"119":{"position":[[1062,18]]}}}],["whitebox.name",{"_index":1355,"t":{"119":{"position":[[933,13]]}}}],["whole",{"_index":1473,"t":{"125":{"position":[[567,5]]},"127":{"position":[[255,5]]},"139":{"position":[[4021,5]]}}}],["whose",{"_index":1494,"t":{"127":{"position":[[886,5]]}}}],["width",{"_index":270,"t":{"77":{"position":[[546,6],[596,6],[1602,6]]},"125":{"position":[[381,6]]},"139":{"position":[[3454,6]]},"143":{"position":[[1120,6],[1679,6],[2253,6]]},"147":{"position":[[1120,5]]},"163":{"position":[[1735,6],[2541,6],[3180,6],[4184,6]]},"195":{"position":[[291,5]]},"207":{"position":[[332,5],[482,5],[710,6],[821,6],[1012,6],[1146,6]]},"211":{"position":[[146,6]]},"213":{"position":[[539,6]]}}}],["winding",{"_index":860,"t":{"95":{"position":[[1388,7],[1601,7],[1635,7],[2062,8],[6194,7],[6504,7],[6538,7],[7023,8]]}}}],["window",{"_index":50,"t":{"75":{"position":[[274,6]]},"77":{"position":[[78,6]]},"79":{"position":[[103,6]]},"81":{"position":[[101,6]]},"83":{"position":[[78,6]]},"85":{"position":[[101,6]]},"87":{"position":[[101,6]]},"89":{"position":[[101,6]]},"91":{"position":[[101,6]]},"93":{"position":[[101,6]]},"95":{"position":[[101,6]]},"97":{"position":[[78,6]]},"99":{"position":[[101,6]]},"101":{"position":[[101,6]]},"103":{"position":[[101,6]]},"105":{"position":[[78,6]]},"107":{"position":[[78,6]]},"109":{"position":[[98,6]]},"111":{"position":[[101,6]]},"113":{"position":[[78,6]]},"115":{"position":[[101,6]]},"117":{"position":[[101,6]]},"121":{"position":[[78,6]]},"129":{"position":[[78,6]]},"131":{"position":[[373,6]]},"133":{"position":[[146,6]]},"135":{"position":[[78,6]]},"137":{"position":[[78,6]]},"141":{"position":[[78,6]]},"143":{"position":[[95,6]]},"145":{"position":[[95,6]]},"147":{"position":[[78,6]]},"149":{"position":[[78,6]]},"151":{"position":[[127,6]]},"153":{"position":[[95,6]]},"155":{"position":[[78,6]]},"157":{"position":[[78,6]]},"159":{"position":[[78,6]]},"161":{"position":[[78,6]]},"163":{"position":[[91,6]]},"165":{"position":[[78,6]]},"167":{"position":[[78,6]]},"169":{"position":[[78,6]]},"171":{"position":[[78,6]]},"173":{"position":[[78,6]]},"175":{"position":[[78,6]]},"177":{"position":[[78,6]]},"179":{"position":[[78,6]]},"181":{"position":[[78,6]]},"183":{"position":[[96,6]]},"185":{"position":[[96,6]]},"187":{"position":[[101,6]]},"189":{"position":[[101,6]]},"191":{"position":[[101,6]]},"193":{"position":[[281,6]]},"195":{"position":[[78,6]]},"197":{"position":[[101,6]]},"199":{"position":[[98,6]]},"201":{"position":[[101,6]]},"203":{"position":[[101,6]]},"205":{"position":[[101,6]]},"207":{"position":[[1579,6]]},"209":{"position":[[233,6]]},"211":{"position":[[78,6]]},"213":{"position":[[101,6]]},"238":{"position":[[78,6]]}}}],["window.app",{"_index":2097,"t":{"145":{"position":[[1469,10]]}}}],["window.mask",{"_index":848,"t":{"95":{"position":[[766,11],[3539,11]]}}}],["window.webfontconfig",{"_index":2638,"t":{"203":{"position":[[194,20]]}}}],["without",{"_index":2591,"t":{"199":{"position":[[811,7]]}}}],["won't",{"_index":1796,"t":{"139":{"position":[[607,5]]}}}],["wont",{"_index":1671,"t":{"133":{"position":[[429,4]]}}}],["wordwrap",{"_index":603,"t":{"85":{"position":[[2403,9]]},"205":{"position":[[582,9]]}}}],["wordwrapwidth",{"_index":604,"t":{"85":{"position":[[2419,14]]},"205":{"position":[[598,14]]}}}],["work",{"_index":1672,"t":{"133":{"position":[[434,4]]}}}],["works",{"_index":935,"t":{"95":{"position":[[5047,5]]},"187":{"position":[[380,5]]}}}],["world",{"_index":1786,"t":{"139":{"position":[[225,5],[1424,5],[5336,5]]}}}],["worldtransform",{"_index":1821,"t":{"139":{"position":[[1188,14]]}}}],["wrap",{"_index":1067,"t":{"97":{"position":[[2080,4]]},"105":{"position":[[1925,4]]},"113":{"position":[[2049,4]]},"137":{"position":[[2241,4]]},"165":{"position":[[2517,4]]},"207":{"position":[[1244,4]]}}}],["wrapping",{"_index":1659,"t":{"131":{"position":[[2634,8]]},"147":{"position":[[507,9],[1004,8]]}}}],["x",{"_index":161,"t":{"75":{"position":[[2533,2]]},"77":{"position":[[1271,2]]},"81":{"position":[[996,2]]},"83":{"position":[[535,2]]},"95":{"position":[[995,1],[1502,2],[5503,1],[6405,2],[9327,1],[9373,1],[9438,2]]},"117":{"position":[[1135,2]]},"147":{"position":[[1098,1]]},"157":{"position":[[234,2],[253,2],[283,2]]},"161":{"position":[[234,2],[253,2],[283,2],[592,2],[617,2],[642,2]]},"163":{"position":[[260,2],[276,2],[303,2]]},"165":{"position":[[253,2],[272,2],[302,2]]},"167":{"position":[[234,2],[253,2],[272,2]]},"169":{"position":[[234,2],[253,2],[272,2]]},"177":{"position":[[233,2],[251,2],[272,2]]},"179":{"position":[[234,2],[253,2],[272,2]]},"181":{"position":[[234,2],[253,2],[283,2]]}}}],["x+100",{"_index":1902,"t":{"139":{"position":[[3846,6]]}}}],["x,y",{"_index":1583,"t":{"131":{"position":[[1114,3]]},"165":{"position":[[1033,3]]}}}],["x1",{"_index":909,"t":{"95":{"position":[[3802,2],[8844,4],[8956,3],[9097,3],[9141,3],[9171,3],[9377,2],[9393,4]]}}}],["x2",{"_index":1004,"t":{"95":{"position":[[8769,3],[8853,2],[8950,3],[9134,4],[9387,3]]}}}],["x3",{"_index":1006,"t":{"95":{"position":[[8777,3],[8873,3],[8968,3],[9067,3],[9103,4],[9177,4]]}}}],["x4",{"_index":1008,"t":{"95":{"position":[[8785,3],[8881,2],[8962,3],[9060,4]]}}}],["y",{"_index":162,"t":{"75":{"position":[[2539,2]]},"77":{"position":[[1274,1],[1321,3],[1688,3],[1858,3]]},"81":{"position":[[1002,2]]},"83":{"position":[[541,2],[2151,1]]},"85":{"position":[[3752,1]]},"95":{"position":[[1043,1],[1505,2],[5551,1],[6408,2],[9333,1],[9404,1],[9441,1]]},"117":{"position":[[515,2],[1148,2]]},"127":{"position":[[1954,1]]},"157":{"position":[[237,1],[256,1],[286,1]]},"161":{"position":[[237,1],[256,1],[286,1],[595,1],[620,1],[645,1]]},"163":{"position":[[263,1],[279,1],[306,1]]},"165":{"position":[[256,1],[275,1],[305,1]]},"167":{"position":[[237,1],[256,1],[275,1]]},"169":{"position":[[237,1],[256,1],[275,1]]},"177":{"position":[[236,1],[254,1],[275,1]]},"179":{"position":[[237,1],[256,1],[275,1]]},"181":{"position":[[237,1],[256,1],[286,1]]}}}],["y+300",{"_index":1903,"t":{"139":{"position":[[3853,5]]}}}],["y1",{"_index":911,"t":{"95":{"position":[[3844,2],[4005,4],[8765,3],[8859,2],[8980,5],[9073,3],[9147,3],[9165,3],[9408,2],[9424,4]]}}}],["y2",{"_index":1005,"t":{"95":{"position":[[8773,3],[8866,3],[8974,3],[9159,3],[9418,3]]}}}],["y3",{"_index":1007,"t":{"95":{"position":[[8781,3],[8887,2],[8944,3],[9079,3],[9091,3],[9153,3]]}}}],["y4",{"_index":1009,"t":{"95":{"position":[[8789,3],[8894,4],[8937,4],[9085,3]]}}}],["yay",{"_index":2570,"t":{"197":{"position":[[310,6]]}}}],["yellow",{"_index":1692,"t":{"133":{"position":[[973,8]]}}}],["yellowstar",{"_index":1390,"t":{"123":{"position":[[147,10]]}}}],["yes",{"_index":2606,"t":{"199":{"position":[[1308,4]]}}}],["yoghurt",{"_index":33,"t":{"75":{"position":[[76,7]]}}}],["z",{"_index":453,"t":{"83":{"position":[[529,2],[1546,1],[1600,2],[1696,2],[2045,2]]},"131":{"position":[[1105,3]]},"165":{"position":[[1024,3]]}}}],["zero",{"_index":2161,"t":{"151":{"position":[[829,4]]}}}],["zoom",{"_index":1915,"t":{"139":{"position":[[4327,5],[4528,4],[4655,5],[4709,5],[5479,4]]},"163":{"position":[[1112,5],[1466,5]]}}}]],"pipeline":["stemmer"]}}] \ No newline at end of file +[{"documents":[{"i":16,"t":"Examples","u":"/examples","b":[]},{"i":40,"t":"Collision Detection","u":"/examples/advanced/collision-detection","b":["Advanced"]},{"i":42,"t":"Scratch Card","u":"/examples/advanced/scratch-card","b":["Advanced"]},{"i":44,"t":"Screen Shot","u":"/examples/advanced/screen-shot","b":["Advanced"]},{"i":46,"t":"Mouse Trail","u":"/examples/advanced/mouse-trail","b":["Advanced"]},{"i":48,"t":"Star Warp","u":"/examples/advanced/star-warp","b":["Advanced"]},{"i":50,"t":"Async","u":"/examples/assets/async","b":["Assets"]},{"i":52,"t":"Slots","u":"/examples/advanced/slots","b":["Advanced"]},{"i":54,"t":"Background","u":"/examples/assets/background","b":["Assets"]},{"i":56,"t":"Multiple","u":"/examples/assets/multiple","b":["Assets"]},{"i":58,"t":"Bundle","u":"/examples/assets/bundle","b":["Assets"]},{"i":60,"t":"Promise","u":"/examples/assets/promise","b":["Assets"]},{"i":62,"t":"Cache As Bitmap","u":"/examples/basic/cache-as-bitmap","b":["Basic"]},{"i":64,"t":"Blend Modes","u":"/examples/basic/blend-modes","b":["Basic"]},{"i":66,"t":"Container","u":"/examples/basic/container","b":["Basic"]},{"i":68,"t":"Spinners","u":"/examples/advanced/spinners","b":["Advanced"]},{"i":70,"t":"Simple Plane","u":"/examples/basic/simple-plane","b":["Basic"]},{"i":72,"t":"Tinting","u":"/examples/basic/tinting","b":["Basic"]},{"i":74,"t":"Click","u":"/examples/events/click","b":["Events"]},{"i":76,"t":"Transparent Background","u":"/examples/basic/transparent-background","b":["Basic"]},{"i":78,"t":"Particle Container","u":"/examples/basic/particle-container","b":["Basic"]},{"i":80,"t":"Custom Mouse Icon","u":"/examples/events/custom-mouse-icon","b":["Events"]},{"i":82,"t":"Interactivity","u":"/examples/events/interactivity","b":["Events"]},{"i":84,"t":"Logger","u":"/examples/events/logger","b":["Events"]},{"i":86,"t":"Custom Hitarea","u":"/examples/events/custom-hitarea","b":["Events"]},{"i":88,"t":"Dragging","u":"/examples/events/dragging","b":["Events"]},{"i":90,"t":"Pointer Tracker","u":"/examples/events/pointer-tracker","b":["Events"]},{"i":92,"t":"Mouse Blending","u":"/examples/filters-advanced/mouse-blending","b":["Filters Advanced"]},{"i":94,"t":"Slider","u":"/examples/events/slider","b":["Events"]},{"i":96,"t":"Shader Toy Filter Render Texture","u":"/examples/filters-advanced/shader-toy-filter-render-texture","b":["Filters Advanced"]},{"i":98,"t":"Custom","u":"/examples/filters-advanced/custom","b":["Filters Advanced"]},{"i":100,"t":"Blur","u":"/examples/filters-basic/blur","b":["Filters Basic"]},{"i":102,"t":"Nested Boundary With Projection","u":"/examples/events/nested-boundary-with-projection","b":["Events"]},{"i":104,"t":"Displacement Map Crawlies","u":"/examples/filters-basic/displacement-map-crawlies","b":["Filters Basic"]},{"i":106,"t":"Color Matrix","u":"/examples/filters-basic/color-matrix","b":["Filters Basic"]},{"i":108,"t":"Dynamic","u":"/examples/graphics/dynamic","b":["Graphics"]},{"i":110,"t":"Simple","u":"/examples/graphics/simple","b":["Graphics"]},{"i":146,"t":"Graphics","u":"/examples/masks/graphics","b":["Masks"]},{"i":148,"t":"Advanced","u":"/examples/graphics/advanced","b":["Graphics"]},{"i":150,"t":"Displacement Map Flag","u":"/examples/filters-basic/displacement-map-flag","b":["Filters Basic"]},{"i":152,"t":"Interleaving Geometry","u":"/examples/mesh-and-shaders/interleaving-geometry","b":["Mesh And Shaders"]},{"i":154,"t":"Instanced Geometry","u":"/examples/mesh-and-shaders/instanced-geometry","b":["Mesh And Shaders"]},{"i":156,"t":"Sprite","u":"/examples/masks/sprite","b":["Masks"]},{"i":158,"t":"Shader Toy Mesh","u":"/examples/mesh-and-shaders/shader-toy-mesh","b":["Mesh And Shaders"]},{"i":160,"t":"Merging Geometry","u":"/examples/mesh-and-shaders/merging-geometry","b":["Mesh And Shaders"]},{"i":162,"t":"Sharing Geometry","u":"/examples/mesh-and-shaders/sharing-geometry","b":["Mesh And Shaders"]},{"i":164,"t":"Multi Pass Shader Generated Mesh","u":"/examples/mesh-and-shaders/multi-pass-shader-generated-mesh","b":["Mesh And Shaders"]},{"i":166,"t":"Shared Shader","u":"/examples/mesh-and-shaders/shared-shader","b":["Mesh And Shaders"]},{"i":168,"t":"Textured Mesh Advanced","u":"/examples/mesh-and-shaders/textured-mesh-advanced","b":["Mesh And Shaders"]},{"i":170,"t":"Triangle","u":"/examples/mesh-and-shaders/triangle","b":["Mesh And Shaders"]},{"i":172,"t":"Triangle Textured","u":"/examples/mesh-and-shaders/triangle-textured","b":["Mesh And Shaders"]},{"i":174,"t":"Triangle Color","u":"/examples/mesh-and-shaders/triangle-color","b":["Mesh And Shaders"]},{"i":176,"t":"Filter","u":"/examples/masks/filter","b":["Masks"]},{"i":178,"t":"Uniforms","u":"/examples/mesh-and-shaders/uniforms","b":["Mesh And Shaders"]},{"i":180,"t":"Animated Sprite Animation Speed","u":"/examples/sprite/animated-sprite-animation-speed","b":["Sprite"]},{"i":182,"t":"Animated Sprite Explosion","u":"/examples/sprite/animated-sprite-explosion","b":["Sprite"]},{"i":184,"t":"Basic","u":"/examples/offscreen-canvas/basic","b":["Offscreen Canvas"]},{"i":186,"t":"Basic","u":"/examples/sprite/basic","b":["Sprite"]},{"i":188,"t":"Texture Swap","u":"/examples/sprite/texture-swap","b":["Sprite"]},{"i":190,"t":"Bitmap Text","u":"/examples/text/bitmap-text","b":["Text"]},{"i":192,"t":"Tiling Sprite","u":"/examples/sprite/tiling-sprite","b":["Sprite"]},{"i":194,"t":"Video","u":"/examples/sprite/video","b":["Sprite"]},{"i":196,"t":"Animated Sprite Jet","u":"/examples/sprite/animated-sprite-jet","b":["Sprite"]},{"i":198,"t":"Web Font","u":"/examples/text/web-font","b":["Text"]},{"i":200,"t":"Gradient Resource","u":"/examples/textures/gradient-resource","b":["Textures"]},{"i":202,"t":"Pixi Text","u":"/examples/text/pixi-text","b":["Text"]},{"i":204,"t":"From Font","u":"/examples/text/from-font","b":["Text"]},{"i":206,"t":"Render Texture Advanced","u":"/examples/textures/render-texture-advanced","b":["Textures"]},{"i":208,"t":"Gradient Basic","u":"/examples/textures/gradient-basic","b":["Textures"]},{"i":210,"t":"Texture Rotate","u":"/examples/textures/texture-rotate","b":["Textures"]},{"i":243,"t":"Render Texture Basic","u":"/examples/textures/render-texture-basic","b":["Textures"]},{"i":257,"t":"Textured Mesh Basic","u":"/examples/mesh-and-shaders/textured-mesh-basic","b":["Mesh And Shaders"]}],"index":{"version":"2.3.9","fields":["t"],"fieldVectors":[["t/16",[0,4.792]],["t/40",[1,3.77,2,3.77]],["t/42",[3,3.77,4,3.77]],["t/44",[5,3.77,6,3.77]],["t/46",[7,2.948,8,3.77]],["t/48",[9,3.77,10,3.77]],["t/50",[11,4.792]],["t/52",[12,4.792]],["t/54",[13,4.162]],["t/56",[14,4.792]],["t/58",[15,4.792]],["t/60",[16,4.792]],["t/62",[17,3.77,18,3.274]],["t/64",[19,3.77,20,3.77]],["t/66",[21,4.162]],["t/68",[22,4.792]],["t/70",[23,3.274,24,3.77]],["t/72",[25,4.792]],["t/74",[26,4.792]],["t/76",[13,3.274,27,3.77]],["t/78",[21,3.274,28,3.77]],["t/80",[7,2.429,29,2.429,30,3.107]],["t/82",[31,4.792]],["t/84",[32,4.792]],["t/86",[29,2.948,33,3.77]],["t/88",[34,4.792]],["t/90",[35,3.77,36,3.77]],["t/92",[7,2.948,37,3.77]],["t/94",[38,4.792]],["t/96",[39,1.649,40,1.997,41,1.997,42,1.797,43,1.53]],["t/98",[29,3.747]],["t/100",[44,4.792]],["t/102",[45,3.107,46,3.107,47,3.107]],["t/104",[48,2.699,49,2.699,50,3.107]],["t/106",[51,3.274,52,3.77]],["t/108",[53,4.792]],["t/110",[23,4.162]],["t/146",[54,4.792]],["t/148",[55,3.747]],["t/150",[48,2.699,49,2.699,56,3.107]],["t/152",[57,3.77,58,2.704]],["t/154",[58,2.704,59,3.77]],["t/156",[60,3.189]],["t/158",[39,2.229,40,2.699,61,2.229]],["t/160",[58,2.704,62,3.77]],["t/162",[58,2.704,63,3.77]],["t/164",[39,1.649,61,1.649,64,2.299,65,2.299,66,2.299]],["t/166",[39,2.704,67,3.77]],["t/168",[55,2.429,61,2.229,68,2.429]],["t/170",[69,3.747]],["t/172",[68,2.948,69,2.948]],["t/174",[51,3.274,69,2.948]],["t/176",[41,4.162]],["t/178",[70,4.792]],["t/180",[60,1.759,71,2.066,72,2.643,73,2.643]],["t/182",[60,2.068,71,2.429,74,3.107]],["t/184",[75,3.189]],["t/186",[75,3.189]],["t/188",[43,2.509,76,3.77]],["t/190",[18,3.274,77,3.274]],["t/192",[60,2.509,78,3.77]],["t/194",[79,4.792]],["t/196",[60,2.068,71,2.429,80,3.107]],["t/198",[81,3.77,82,3.274]],["t/200",[83,3.274,84,3.77]],["t/202",[77,3.274,85,3.77]],["t/204",[82,4.162]],["t/206",[42,2.429,43,2.068,55,2.429]],["t/208",[75,2.509,83,3.274]],["t/210",[43,2.509,86,3.77]],["t/243",[42,2.429,43,2.068,75,2.068]],["t/257",[61,2.229,68,2.429,75,2.068]]],"invertedIndex":[["advanced",{"_index":55,"t":{"148":{"position":[[0,8]]},"168":{"position":[[14,8]]},"206":{"position":[[15,8]]}}}],["animated",{"_index":71,"t":{"180":{"position":[[0,8]]},"182":{"position":[[0,8]]},"196":{"position":[[0,8]]}}}],["animation",{"_index":72,"t":{"180":{"position":[[16,9]]}}}],["async",{"_index":11,"t":{"50":{"position":[[0,5]]}}}],["background",{"_index":13,"t":{"54":{"position":[[0,10]]},"76":{"position":[[12,10]]}}}],["basic",{"_index":75,"t":{"184":{"position":[[0,5]]},"186":{"position":[[0,5]]},"208":{"position":[[9,5]]},"243":{"position":[[15,5]]},"257":{"position":[[14,5]]}}}],["bitmap",{"_index":18,"t":{"62":{"position":[[9,6]]},"190":{"position":[[0,6]]}}}],["blend",{"_index":19,"t":{"64":{"position":[[0,5]]}}}],["blending",{"_index":37,"t":{"92":{"position":[[6,8]]}}}],["blur",{"_index":44,"t":{"100":{"position":[[0,4]]}}}],["boundary",{"_index":46,"t":{"102":{"position":[[7,8]]}}}],["bundle",{"_index":15,"t":{"58":{"position":[[0,6]]}}}],["cache",{"_index":17,"t":{"62":{"position":[[0,5]]}}}],["card",{"_index":4,"t":{"42":{"position":[[8,4]]}}}],["click",{"_index":26,"t":{"74":{"position":[[0,5]]}}}],["collision",{"_index":1,"t":{"40":{"position":[[0,9]]}}}],["color",{"_index":51,"t":{"106":{"position":[[0,5]]},"174":{"position":[[9,5]]}}}],["container",{"_index":21,"t":{"66":{"position":[[0,9]]},"78":{"position":[[9,9]]}}}],["crawlies",{"_index":50,"t":{"104":{"position":[[17,8]]}}}],["custom",{"_index":29,"t":{"80":{"position":[[0,6]]},"86":{"position":[[0,6]]},"98":{"position":[[0,6]]}}}],["detection",{"_index":2,"t":{"40":{"position":[[10,9]]}}}],["displacement",{"_index":48,"t":{"104":{"position":[[0,12]]},"150":{"position":[[0,12]]}}}],["dragging",{"_index":34,"t":{"88":{"position":[[0,8]]}}}],["dynamic",{"_index":53,"t":{"108":{"position":[[0,7]]}}}],["examples",{"_index":0,"t":{"16":{"position":[[0,8]]}}}],["explosion",{"_index":74,"t":{"182":{"position":[[16,9]]}}}],["filter",{"_index":41,"t":{"96":{"position":[[11,6]]},"176":{"position":[[0,6]]}}}],["flag",{"_index":56,"t":{"150":{"position":[[17,4]]}}}],["font",{"_index":82,"t":{"198":{"position":[[4,4]]},"204":{"position":[[5,4]]}}}],["generated",{"_index":66,"t":{"164":{"position":[[18,9]]}}}],["geometry",{"_index":58,"t":{"152":{"position":[[13,8]]},"154":{"position":[[10,8]]},"160":{"position":[[8,8]]},"162":{"position":[[8,8]]}}}],["gradient",{"_index":83,"t":{"200":{"position":[[0,8]]},"208":{"position":[[0,8]]}}}],["graphics",{"_index":54,"t":{"146":{"position":[[0,8]]}}}],["hitarea",{"_index":33,"t":{"86":{"position":[[7,7]]}}}],["icon",{"_index":30,"t":{"80":{"position":[[13,4]]}}}],["instanced",{"_index":59,"t":{"154":{"position":[[0,9]]}}}],["interactivity",{"_index":31,"t":{"82":{"position":[[0,13]]}}}],["interleaving",{"_index":57,"t":{"152":{"position":[[0,12]]}}}],["jet",{"_index":80,"t":{"196":{"position":[[16,3]]}}}],["logger",{"_index":32,"t":{"84":{"position":[[0,6]]}}}],["map",{"_index":49,"t":{"104":{"position":[[13,3]]},"150":{"position":[[13,3]]}}}],["matrix",{"_index":52,"t":{"106":{"position":[[6,6]]}}}],["merging",{"_index":62,"t":{"160":{"position":[[0,7]]}}}],["mesh",{"_index":61,"t":{"158":{"position":[[11,4]]},"164":{"position":[[28,4]]},"168":{"position":[[9,4]]},"257":{"position":[[9,4]]}}}],["modes",{"_index":20,"t":{"64":{"position":[[6,5]]}}}],["mouse",{"_index":7,"t":{"46":{"position":[[0,5]]},"80":{"position":[[7,5]]},"92":{"position":[[0,5]]}}}],["multi",{"_index":64,"t":{"164":{"position":[[0,5]]}}}],["multiple",{"_index":14,"t":{"56":{"position":[[0,8]]}}}],["nested",{"_index":45,"t":{"102":{"position":[[0,6]]}}}],["particle",{"_index":28,"t":{"78":{"position":[[0,8]]}}}],["pass",{"_index":65,"t":{"164":{"position":[[6,4]]}}}],["pixi",{"_index":85,"t":{"202":{"position":[[0,4]]}}}],["plane",{"_index":24,"t":{"70":{"position":[[7,5]]}}}],["pointer",{"_index":35,"t":{"90":{"position":[[0,7]]}}}],["projection",{"_index":47,"t":{"102":{"position":[[21,10]]}}}],["promise",{"_index":16,"t":{"60":{"position":[[0,7]]}}}],["render",{"_index":42,"t":{"96":{"position":[[18,6]]},"206":{"position":[[0,6]]},"243":{"position":[[0,6]]}}}],["resource",{"_index":84,"t":{"200":{"position":[[9,8]]}}}],["rotate",{"_index":86,"t":{"210":{"position":[[8,6]]}}}],["scratch",{"_index":3,"t":{"42":{"position":[[0,7]]}}}],["screen",{"_index":5,"t":{"44":{"position":[[0,6]]}}}],["shader",{"_index":39,"t":{"96":{"position":[[0,6]]},"158":{"position":[[0,6]]},"164":{"position":[[11,6]]},"166":{"position":[[7,6]]}}}],["shared",{"_index":67,"t":{"166":{"position":[[0,6]]}}}],["sharing",{"_index":63,"t":{"162":{"position":[[0,7]]}}}],["shot",{"_index":6,"t":{"44":{"position":[[7,4]]}}}],["simple",{"_index":23,"t":{"70":{"position":[[0,6]]},"110":{"position":[[0,6]]}}}],["slider",{"_index":38,"t":{"94":{"position":[[0,6]]}}}],["slots",{"_index":12,"t":{"52":{"position":[[0,5]]}}}],["speed",{"_index":73,"t":{"180":{"position":[[26,5]]}}}],["spinners",{"_index":22,"t":{"68":{"position":[[0,8]]}}}],["sprite",{"_index":60,"t":{"156":{"position":[[0,6]]},"180":{"position":[[9,6]]},"182":{"position":[[9,6]]},"192":{"position":[[7,6]]},"196":{"position":[[9,6]]}}}],["star",{"_index":9,"t":{"48":{"position":[[0,4]]}}}],["swap",{"_index":76,"t":{"188":{"position":[[8,4]]}}}],["text",{"_index":77,"t":{"190":{"position":[[7,4]]},"202":{"position":[[5,4]]}}}],["texture",{"_index":43,"t":{"96":{"position":[[25,7]]},"188":{"position":[[0,7]]},"206":{"position":[[7,7]]},"210":{"position":[[0,7]]},"243":{"position":[[7,7]]}}}],["textured",{"_index":68,"t":{"168":{"position":[[0,8]]},"172":{"position":[[9,8]]},"257":{"position":[[0,8]]}}}],["tiling",{"_index":78,"t":{"192":{"position":[[0,6]]}}}],["tinting",{"_index":25,"t":{"72":{"position":[[0,7]]}}}],["toy",{"_index":40,"t":{"96":{"position":[[7,3]]},"158":{"position":[[7,3]]}}}],["tracker",{"_index":36,"t":{"90":{"position":[[8,7]]}}}],["trail",{"_index":8,"t":{"46":{"position":[[6,5]]}}}],["transparent",{"_index":27,"t":{"76":{"position":[[0,11]]}}}],["triangle",{"_index":69,"t":{"170":{"position":[[0,8]]},"172":{"position":[[0,8]]},"174":{"position":[[0,8]]}}}],["uniforms",{"_index":70,"t":{"178":{"position":[[0,8]]}}}],["video",{"_index":79,"t":{"194":{"position":[[0,5]]}}}],["warp",{"_index":10,"t":{"48":{"position":[[5,4]]}}}],["web",{"_index":81,"t":{"198":{"position":[[0,3]]}}}]],"pipeline":["stemmer"]}},{"documents":[{"i":17,"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":"/examples","h":"","p":16},{"i":41,"t":"import * as PIXI from 'pixi.js'; // Based somewhat on this article by Spicy Yoghurt // URL for further reading: https://spicyyoghurt.com/tutorials/html5-javascript-game-development/collision-detection-physics const app = new PIXI.Application({ background: '#111', resizeTo: window }); document.body.appendChild(app.view); // Options for how objects interact // How fast the red square moves const movementSpeed = 0.05; // Strength of the impulse push between two objects const impulsePower = 5; // Test For Hit // A basic AABB check between two different squares function testForAABB(object1, object2) { const bounds1 = object1.getBounds(); const bounds2 = object2.getBounds(); return bounds1.x < bounds2.x + bounds2.width && bounds1.x + bounds1.width > bounds2.x && bounds1.y < bounds2.y + bounds2.height && bounds1.y + bounds1.height > bounds2.y; } // Calculates the results of a collision, allowing us to give an impulse that // shoves objects apart function collisionResponse(object1, object2) { if (!object1 || !object2) { return new PIXI.Point(0); } const vCollision = new PIXI.Point( object2.x - object1.x, object2.y - object1.y, ); const distance = Math.sqrt( (object2.x - object1.x) * (object2.x - object1.x) + (object2.y - object1.y) * (object2.y - object1.y), ); const vCollisionNorm = new PIXI.Point( vCollision.x / distance, vCollision.y / distance, ); const vRelativeVelocity = new PIXI.Point( object1.acceleration.x - object2.acceleration.x, object1.acceleration.y - object2.acceleration.y, ); const speed = vRelativeVelocity.x * vCollisionNorm.x + vRelativeVelocity.y * vCollisionNorm.y; const impulse = impulsePower * speed / (object1.mass + object2.mass); return new PIXI.Point( impulse * vCollisionNorm.x, impulse * vCollisionNorm.y, ); } // Calculate the distance between two given points function distanceBetweenTwoPoints(p1, p2) { const a = p1.x - p2.x; const b = p1.y - p2.y; return Math.hypot(a, b); } // The green square we will knock about const greenSquare = new PIXI.Sprite(PIXI.Texture.WHITE); greenSquare.position.set((app.screen.width - 100) / 2, (app.screen.height - 100) / 2); greenSquare.width = 100; greenSquare.height = 100; greenSquare.tint = 0x00FF00; greenSquare.acceleration = new PIXI.Point(0); greenSquare.mass = 3; // The square you move around const redSquare = new PIXI.Sprite(PIXI.Texture.WHITE); redSquare.position.set(0, 0); redSquare.width = 100; redSquare.height = 100; redSquare.tint = 0xFF0000; redSquare.acceleration = new PIXI.Point(0); redSquare.mass = 1; const mouseCoords = { x: 0, y: 0 }; app.stage.eventMode = 'static'; app.stage.hitArea = app.screen; app.stage.on('mousemove', (event) => { mouseCoords.x = event.global.x; mouseCoords.y = event.global.y; }); // Listen for animate update app.ticker.add((delta) => { // Applied deacceleration for both squares, done by reducing the // acceleration by 0.01% of the acceleration every loop redSquare.acceleration.set(redSquare.acceleration.x * 0.99, redSquare.acceleration.y * 0.99); greenSquare.acceleration.set(greenSquare.acceleration.x * 0.99, greenSquare.acceleration.y * 0.99); // Check whether the green square ever moves off the screen // If so, reverse acceleration in that direction if (greenSquare.x < 0 || greenSquare.x > (app.screen.width - 100)) { greenSquare.acceleration.x = -greenSquare.acceleration.x; } if (greenSquare.y < 0 || greenSquare.y > (app.screen.height - 100)) { greenSquare.acceleration.y = -greenSquare.acceleration.y; } // If the green square pops out of the cordon, it pops back into the // middle if ((greenSquare.x < -30 || greenSquare.x > (app.screen.width + 30)) || greenSquare.y < -30 || greenSquare.y > (app.screen.height + 30)) { greenSquare.position.set((app.screen.width - 100) / 2, (app.screen.height - 100) / 2); } // If the mouse is off screen, then don't update any further if (app.screen.width > mouseCoords.x || mouseCoords.x > 0 || app.screen.height > mouseCoords.y || mouseCoords.y > 0) { // Get the red square's center point const redSquareCenterPosition = new PIXI.Point( redSquare.x + (redSquare.width * 0.5), redSquare.y + (redSquare.height * 0.5), ); // Calculate the direction vector between the mouse pointer and // the red square const toMouseDirection = new PIXI.Point( mouseCoords.x - redSquareCenterPosition.x, mouseCoords.y - redSquareCenterPosition.y, ); // Use the above to figure out the angle that direction has const angleToMouse = Math.atan2( toMouseDirection.y, toMouseDirection.x, ); // Figure out the speed the square should be travelling by, as a // function of how far away from the mouse pointer the red square is const distMouseRedSquare = distanceBetweenTwoPoints( mouseCoords, redSquareCenterPosition, ); const redSpeed = distMouseRedSquare * movementSpeed; // Calculate the acceleration of the red square redSquare.acceleration.set( Math.cos(angleToMouse) * redSpeed, Math.sin(angleToMouse) * redSpeed, ); } // If the two squares are colliding if (testForAABB(greenSquare, redSquare)) { // Calculate the changes in acceleration that should be made between // each square as a result of the collision const collisionPush = collisionResponse(greenSquare, redSquare); // Set the changes in acceleration for both squares redSquare.acceleration.set( (collisionPush.x * greenSquare.mass), (collisionPush.y * greenSquare.mass), ); greenSquare.acceleration.set( -(collisionPush.x * redSquare.mass), -(collisionPush.y * redSquare.mass), ); } greenSquare.x += greenSquare.acceleration.x * delta; greenSquare.y += greenSquare.acceleration.y * delta; redSquare.x += redSquare.acceleration.x * delta; redSquare.y += redSquare.acceleration.y * delta; }); // Add to stage app.stage.addChild(redSquare, greenSquare);","s":"Collision Detection","u":"/examples/advanced/collision-detection","h":"","p":40},{"i":43,"t":"import * as PIXI from 'pixi.js'; const app = new PIXI.Application({ resizeTo: window }); document.body.appendChild(app.view); // prepare circle texture, that will be our brush const brush = new PIXI.Graphics() .beginFill(0xffffff) .drawCircle(0, 0, 50); // Create a line that will interpolate the drawn points const line = new PIXI.Graphics(); PIXI.Assets.add('t1', 'https://pixijs.com/assets/bg_grass.jpg'); PIXI.Assets.add('t2', 'https://pixijs.com/assets/bg_rotate.jpg'); PIXI.Assets.load(['t1', 't2']).then(setup); function setup() { const { width, height } = app.screen; const stageSize = { width, height }; const background = Object.assign(PIXI.Sprite.from('t1'), stageSize); const imageToReveal = Object.assign(PIXI.Sprite.from('t2'), stageSize); const renderTexture = PIXI.RenderTexture.create(stageSize); const renderTextureSprite = new PIXI.Sprite(renderTexture); imageToReveal.mask = renderTextureSprite; app.stage.addChild( background, imageToReveal, renderTextureSprite, ); app.stage.eventMode = 'static'; app.stage.hitArea = app.screen; app.stage .on('pointerdown', pointerDown) .on('pointerup', pointerUp) .on('pointerupoutside', pointerUp) .on('pointermove', pointerMove); let dragging = false; let lastDrawnPoint = null; function pointerMove({ global: { x, y } }) { if (dragging) { brush.position.set(x, y); app.renderer.render(brush, { renderTexture, clear: false, skipUpdateTransform: false, }); // Smooth out the drawing a little bit to make it look nicer // this connects the previous drawn point to the current one // using a line if (lastDrawnPoint) { line .clear() .lineStyle({ width: 100, color: 0xffffff }) .moveTo(lastDrawnPoint.x, lastDrawnPoint.y) .lineTo(x, y); app.renderer.render(line, { renderTexture, clear: false, skipUpdateTransform: false, }); } lastDrawnPoint = lastDrawnPoint || new PIXI.Point(); lastDrawnPoint.set(x, y); } } function pointerDown(event) { dragging = true; pointerMove(event); } function pointerUp(event) { dragging = false; lastDrawnPoint = null; } }","s":"Scratch Card","u":"/examples/advanced/scratch-card","h":"","p":42},{"i":45,"t":"import * as PIXI from 'pixi.js'; const app = new PIXI.Application({ backgroundColor: '#111', resizeTo: window }); document.body.appendChild(app.view); const texture = PIXI.Texture.from('https://pixijs.com/assets/bunny.png'); const bunnyContainer = new PIXI.Container(); async function takeScreenshot() { app.stop(); const url = await app.renderer.extract.base64(bunnyContainer); const a = document.createElement('a'); document.body.append(a); a.download = 'screenshot'; a.href = url; a.click(); a.remove(); app.start(); } app.stage.eventMode = 'static'; app.stage.hitArea = app.screen; app.stage.on('pointerdown', takeScreenshot); for (let i = 0; i < 25; i++) { const bunny = new PIXI.Sprite(texture); bunny.anchor.set(0.5); bunny.x = (i % 5) * 40; bunny.y = Math.floor(i / 5) * 40; bunnyContainer.addChild(bunny); } bunnyContainer.x = 400; bunnyContainer.y = 300; bunnyContainer.pivot.x = bunnyContainer.width / 2; bunnyContainer.pivot.y = bunnyContainer.height / 2; app.ticker.add((delta) => { bunnyContainer.rotation += 0.01 * delta; }); const style = new PIXI.TextStyle({ fontFamily: 'Roboto', fill: '#999', }); const screenshotText = new PIXI.Text('Click To Take Screenshot', style); screenshotText.x = Math.round((app.screen.width - screenshotText.width) / 2); screenshotText.y = Math.round(screenshotText.height / 2); app.stage.addChild(screenshotText, bunnyContainer);","s":"Screen Shot","u":"/examples/advanced/screen-shot","h":"","p":44},{"i":47,"t":"import * as PIXI from 'pixi.js'; const app = new PIXI.Application({ background: '#1099bb', resizeTo: window }); document.body.appendChild(app.view); // Get the texture for rope. const trailTexture = PIXI.Texture.from('https://pixijs.com/assets/trail.png'); const historyX = []; const historyY = []; // historySize determines how long the trail will be. const historySize = 20; // ropeSize determines how smooth the trail will be. const ropeSize = 100; const points = []; // Create history array. for (let i = 0; i < historySize; i++) { historyX.push(0); historyY.push(0); } // Create rope points. for (let i = 0; i < ropeSize; i++) { points.push(new PIXI.Point(0, 0)); } // Create the rope const rope = new PIXI.SimpleRope(trailTexture, points); // Set the blendmode rope.blendmode = PIXI.BLEND_MODES.ADD; app.stage.addChild(rope); let mouseposition = null; app.stage.eventMode = 'static'; app.stage.hitArea = app.screen; app.stage.on('mousemove', (event) => { mouseposition = mouseposition || { x: 0, y: 0 }; mouseposition.x = event.global.x; mouseposition.y = event.global.y; }); // Listen for animate update app.ticker.add(() => { if (!mouseposition) return; // Update the mouse values to history historyX.pop(); historyX.unshift(mouseposition.x); historyY.pop(); historyY.unshift(mouseposition.y); // Update the points to correspond with history. for (let i = 0; i < ropeSize; i++) { const p = points[i]; // Smooth the curve with cubic interpolation to prevent sharp edges. const ix = cubicInterpolation(historyX, i / ropeSize * historySize); const iy = cubicInterpolation(historyY, i / ropeSize * historySize); p.x = ix; p.y = iy; } }); /** * Cubic interpolation based on https://github.com/osuushi/Smooth.js */ function clipInput(k, arr) { if (k < 0) k = 0; if (k > arr.length - 1) k = arr.length - 1; return arr[k]; } function getTangent(k, factor, array) { return factor * (clipInput(k + 1, array) - clipInput(k - 1, array)) / 2; } function cubicInterpolation(array, t, tangentFactor) { if (tangentFactor === null) tangentFactor = 1; const k = Math.floor(t); const m = [getTangent(k, tangentFactor, array), getTangent(k + 1, tangentFactor, array)]; const p = [clipInput(k, array), clipInput(k + 1, array)]; t -= k; const t2 = t * t; const t3 = t * t2; return (2 * t3 - 3 * t2 + 1) * p[0] + (t3 - 2 * t2 + t) * m[0] + (-2 * t3 + 3 * t2) * p[1] + (t3 - t2) * m[1]; }","s":"Mouse Trail","u":"/examples/advanced/mouse-trail","h":"","p":46},{"i":49,"t":"import * as PIXI from 'pixi.js'; const app = new PIXI.Application({ resizeTo: window }); document.body.appendChild(app.view); // Get the texture for star. const starTexture = PIXI.Texture.from('https://pixijs.com/assets/star.png'); const starAmount = 1000; let cameraZ = 0; const fov = 20; const baseSpeed = 0.025; let speed = 0; let warpSpeed = 0; const starStretch = 5; const starBaseSize = 0.05; // Create the stars const stars = []; for (let i = 0; i < starAmount; i++) { const star = { sprite: new PIXI.Sprite(starTexture), z: 0, x: 0, y: 0, }; star.sprite.anchor.x = 0.5; star.sprite.anchor.y = 0.7; randomizeStar(star, true); app.stage.addChild(star.sprite); stars.push(star); } function randomizeStar(star, initial) { star.z = initial ? Math.random() * 2000 : cameraZ + Math.random() * 1000 + 2000; // Calculate star positions with radial random coordinate so no star hits the camera. const deg = Math.random() * Math.PI * 2; const distance = Math.random() * 50 + 1; star.x = Math.cos(deg) * distance; star.y = Math.sin(deg) * distance; } // Change flight speed every 5 seconds setInterval(() => { warpSpeed = warpSpeed > 0 ? 0 : 1; }, 5000); // Listen for animate update app.ticker.add((delta) => { // Simple easing. This should be changed to proper easing function when used for real. speed += (warpSpeed - speed) / 20; cameraZ += delta * 10 * (speed + baseSpeed); for (let i = 0; i < starAmount; i++) { const star = stars[i]; if (star.z < cameraZ) randomizeStar(star); // Map star 3d position to 2d with really simple projection const z = star.z - cameraZ; star.sprite.x = star.x * (fov / z) * app.renderer.screen.width + app.renderer.screen.width / 2; star.sprite.y = star.y * (fov / z) * app.renderer.screen.width + app.renderer.screen.height / 2; // Calculate star scale & rotation. const dxCenter = star.sprite.x - app.renderer.screen.width / 2; const dyCenter = star.sprite.y - app.renderer.screen.height / 2; const distanceCenter = Math.sqrt(dxCenter * dxCenter + dyCenter * dyCenter); const distanceScale = Math.max(0, (2000 - z) / 2000); star.sprite.scale.x = distanceScale * starBaseSize; // Star is looking towards center so that y axis is towards center. // Scale the star depending on how fast we are moving, what the stretchfactor is // and depending on how far away it is from the center. star.sprite.scale.y = distanceScale * starBaseSize + distanceScale * speed * starStretch * distanceCenter / app.renderer.screen.width; star.sprite.rotation = Math.atan2(dyCenter, dxCenter) + Math.PI / 2; } });","s":"Star Warp","u":"/examples/advanced/star-warp","h":"","p":48},{"i":51,"t":"import * as PIXI from 'pixi.js'; const app = new PIXI.Application({ background: '#1099bb', resizeTo: window }); document.body.appendChild(app.view); // await can only be used inside an async function async function init() { const texture = await PIXI.Assets.load('https://pixijs.com/assets/bunny.png'); // create a new Sprite from the awaited loaded Texture const bunny = PIXI.Sprite.from(texture); // center the sprite's anchor point bunny.anchor.set(0.5); // move the sprite to the center of the screen bunny.x = app.screen.width / 2; bunny.y = app.screen.height / 2; app.stage.addChild(bunny); } // Call that async function init();","s":"Async","u":"/examples/assets/async","h":"","p":50},{"i":53,"t":"import * as PIXI from 'pixi.js'; const app = new PIXI.Application({ background: '#1099bb', resizeTo: window }); document.body.appendChild(app.view); PIXI.Assets.load([ 'https://pixijs.com/assets/eggHead.png', 'https://pixijs.com/assets/flowerTop.png', 'https://pixijs.com/assets/helmlok.png', 'https://pixijs.com/assets/skully.png', ]).then(onAssetsLoaded); const REEL_WIDTH = 160; const SYMBOL_SIZE = 150; // onAssetsLoaded handler builds the example. function onAssetsLoaded() { // Create different slot symbols. const slotTextures = [ PIXI.Texture.from('https://pixijs.com/assets/eggHead.png'), PIXI.Texture.from('https://pixijs.com/assets/flowerTop.png'), PIXI.Texture.from('https://pixijs.com/assets/helmlok.png'), PIXI.Texture.from('https://pixijs.com/assets/skully.png'), ]; // Build the reels const reels = []; const reelContainer = new PIXI.Container(); for (let i = 0; i < 5; i++) { const rc = new PIXI.Container(); rc.x = i * REEL_WIDTH; reelContainer.addChild(rc); const reel = { container: rc, symbols: [], position: 0, previousPosition: 0, blur: new PIXI.filters.BlurFilter(), }; reel.blur.blurX = 0; reel.blur.blurY = 0; rc.filters = [reel.blur]; // Build the symbols for (let j = 0; j < 4; j++) { const symbol = new PIXI.Sprite(slotTextures[Math.floor(Math.random() * slotTextures.length)]); // Scale the symbol to fit symbol area. symbol.y = j * SYMBOL_SIZE; symbol.scale.x = symbol.scale.y = Math.min(SYMBOL_SIZE / symbol.width, SYMBOL_SIZE / symbol.height); symbol.x = Math.round((SYMBOL_SIZE - symbol.width) / 2); reel.symbols.push(symbol); rc.addChild(symbol); } reels.push(reel); } app.stage.addChild(reelContainer); // Build top & bottom covers and position reelContainer const margin = (app.screen.height - SYMBOL_SIZE * 3) / 2; reelContainer.y = margin; reelContainer.x = Math.round(app.screen.width - REEL_WIDTH * 5); const top = new PIXI.Graphics(); top.beginFill(0, 1); top.drawRect(0, 0, app.screen.width, margin); const bottom = new PIXI.Graphics(); bottom.beginFill(0, 1); bottom.drawRect(0, SYMBOL_SIZE * 3 + margin, app.screen.width, margin); // Add play text const style = new PIXI.TextStyle({ fontFamily: 'Arial', fontSize: 36, fontStyle: 'italic', fontWeight: 'bold', fill: ['#ffffff', '#00ff99'], // gradient stroke: '#4a1850', strokeThickness: 5, dropShadow: true, dropShadowColor: '#000000', dropShadowBlur: 4, dropShadowAngle: Math.PI / 6, dropShadowDistance: 6, wordWrap: true, wordWrapWidth: 440, }); const playText = new PIXI.Text('Spin the wheels!', style); playText.x = Math.round((bottom.width - playText.width) / 2); playText.y = app.screen.height - margin + Math.round((margin - playText.height) / 2); bottom.addChild(playText); // Add header text const headerText = new PIXI.Text('PIXI MONSTER SLOTS!', style); headerText.x = Math.round((top.width - headerText.width) / 2); headerText.y = Math.round((margin - headerText.height) / 2); top.addChild(headerText); app.stage.addChild(top); app.stage.addChild(bottom); // Set the interactivity. bottom.eventMode = 'static'; bottom.cursor = 'pointer'; bottom.addListener('pointerdown', () => { startPlay(); }); let running = false; // Function to start playing. function startPlay() { if (running) return; running = true; for (let i = 0; i < reels.length; i++) { const r = reels[i]; const extra = Math.floor(Math.random() * 3); const target = r.position + 10 + i * 5 + extra; const time = 2500 + i * 600 + extra * 600; tweenTo(r, 'position', target, time, backout(0.5), null, i === reels.length - 1 ? reelsComplete : null); } } // Reels done handler. function reelsComplete() { running = false; } // Listen for animate update. app.ticker.add((delta) => { // Update the slots. for (let i = 0; i < reels.length; i++) { const r = reels[i]; // Update blur filter y amount based on speed. // This would be better if calculated with time in mind also. Now blur depends on frame rate. r.blur.blurY = (r.position - r.previousPosition) * 8; r.previousPosition = r.position; // Update symbol positions on reel. for (let j = 0; j < r.symbols.length; j++) { const s = r.symbols[j]; const prevy = s.y; s.y = ((r.position + j) % r.symbols.length) * SYMBOL_SIZE - SYMBOL_SIZE; if (s.y < 0 && prevy > SYMBOL_SIZE) { // Detect going over and swap a texture. // This should in proper product be determined from some logical reel. s.texture = slotTextures[Math.floor(Math.random() * slotTextures.length)]; s.scale.x = s.scale.y = Math.min(SYMBOL_SIZE / s.texture.width, SYMBOL_SIZE / s.texture.height); s.x = Math.round((SYMBOL_SIZE - s.width) / 2); } } } }); } // Very simple tweening utility function. This should be replaced with a proper tweening library in a real product. const tweening = []; function tweenTo(object, property, target, time, easing, onchange, oncomplete) { const tween = { object, property, propertyBeginValue: object[property], target, easing, time, change: onchange, complete: oncomplete, start: Date.now(), }; tweening.push(tween); return tween; } // Listen for animate update. app.ticker.add((delta) => { const now = Date.now(); const remove = []; for (let i = 0; i < tweening.length; i++) { const t = tweening[i]; const phase = Math.min(1, (now - t.start) / t.time); t.object[t.property] = lerp(t.propertyBeginValue, t.target, t.easing(phase)); if (t.change) t.change(t); if (phase === 1) { t.object[t.property] = t.target; if (t.complete) t.complete(t); remove.push(t); } } for (let i = 0; i < remove.length; i++) { tweening.splice(tweening.indexOf(remove[i]), 1); } }); // Basic lerp funtion. function lerp(a1, a2, t) { return a1 * (1 - t) + a2 * t; } // Backout function from tweenjs. // https://github.com/CreateJS/TweenJS/blob/master/src/tweenjs/Ease.js function backout(amount) { return (t) => (--t * t * ((amount + 1) * t + amount) + 1); }","s":"Slots","u":"/examples/advanced/slots","h":"","p":52},{"i":55,"t":"import * as PIXI from 'pixi.js'; const app = new PIXI.Application({ background: '#1099bb', resizeTo: window }); document.body.appendChild(app.view); // Add the assets to load PIXI.Assets.add('flowerTop', 'https://pixijs.com/assets/flowerTop.png'); PIXI.Assets.add('eggHead', 'https://pixijs.com/assets/eggHead.png'); // Allow the assets to load in the background PIXI.Assets.backgroundLoad(['flowerTop', 'eggHead']); // If the background load hasn't loaded this asset yet, calling load forces this asset to load now. PIXI.Assets.load('eggHead').then((texture) => { // auxiliar flag for toggling the texture let isEggHead = true; // create a new Sprite from the resolved loaded texture const character = new PIXI.Sprite(texture); character.anchor.set(0.5); character.x = app.screen.width / 2; character.y = app.screen.height / 2; character.eventMode = 'static'; character.cursor = 'pointer'; app.stage.addChild(character); character.on('pointertap', async () => { isEggHead = !isEggHead; // These promise are already resolved in the cache. character.texture = await PIXI.Assets.load(isEggHead ? 'eggHead' : 'flowerTop'); }); });","s":"Background","u":"/examples/assets/background","h":"","p":54},{"i":57,"t":"import * as PIXI from 'pixi.js'; const app = new PIXI.Application({ background: '#1099bb', resizeTo: window }); document.body.appendChild(app.view); // Add the assets to load PIXI.Assets.add('flowerTop', 'https://pixijs.com/assets/flowerTop.png'); PIXI.Assets.add('eggHead', 'https://pixijs.com/assets/eggHead.png'); // Load the assets and get a resolved promise once both are loaded const texturesPromise = PIXI.Assets.load(['flowerTop', 'eggHead']); // => Promise<{flowerTop: Texture, eggHead: Texture}> // When the promise resolves, we have the texture! texturesPromise.then((textures) => { // create a new Sprite from the resolved loaded Textures const flower = PIXI.Sprite.from(textures.flowerTop); flower.anchor.set(0.5); flower.x = app.screen.width * 0.25; flower.y = app.screen.height / 2; app.stage.addChild(flower); const egg = PIXI.Sprite.from(textures.eggHead); egg.anchor.set(0.5); egg.x = app.screen.width * 0.75; egg.y = app.screen.height / 2; app.stage.addChild(egg); });","s":"Multiple","u":"/examples/assets/multiple","h":"","p":56},{"i":59,"t":"import * as PIXI from 'pixi.js'; const app = new PIXI.Application({ background: '#1099bb', resizeTo: window }); document.body.appendChild(app.view); async function init() { // manifest example const manifestExample = { bundles: [{ name: 'load-screen', assets: [ { name: 'flowerTop', srcs: 'https://pixijs.com/assets/flowerTop.png', }, ], }, { name: 'game-screen', assets: [ { name: 'eggHead', srcs: 'https://pixijs.com/assets/eggHead.png', }, ], }], }; await PIXI.Assets.init({ manifest: manifestExample }); // bundles can be loaded in the background too! PIXI.Assets.backgroundLoadBundle(['load-screen', 'game-screen']); makeLoadScreen(); } async function makeLoadScreen() { // get the assets from the load screen bundle. // If the bundle was already downloaded the promise resolves instantly! const loadScreenAssets = await PIXI.Assets.loadBundle('load-screen'); // create a new Sprite from the resolved loaded texture const goNext = new PIXI.Sprite(loadScreenAssets.flowerTop); goNext.anchor.set(0.5); goNext.x = app.screen.width / 2; goNext.y = app.screen.height / 2; app.stage.addChild(goNext); goNext.eventMode = 'static'; goNext.cursor = 'pointer'; goNext.on('pointertap', async () => { goNext.destroy(); makeGameScreen(); }); } async function makeGameScreen() { // Wait here until you get the assets // If the user spends enough time in the load screen by the time they reach the game screen // the assets are completely loaded and the promise resolves instantly! const loadScreenAssets = await PIXI.Assets.loadBundle('game-screen'); // create a new Sprite from the resolved loaded texture const goBack = new PIXI.Sprite(loadScreenAssets.eggHead); goBack.anchor.set(0.5); goBack.x = app.screen.width / 2; goBack.y = app.screen.height / 2; app.stage.addChild(goBack); goBack.eventMode = 'static'; goBack.cursor = 'pointer'; goBack.on('pointertap', async () => { goBack.destroy(); // The user can go back and the files are already downloaded makeLoadScreen(); }); } init();","s":"Bundle","u":"/examples/assets/bundle","h":"","p":58},{"i":61,"t":"import * as PIXI from 'pixi.js'; const app = new PIXI.Application({ background: '#1099bb', resizeTo: window }); document.body.appendChild(app.view); // Start loading right away and create a promise const texturePromise = PIXI.Assets.load('https://pixijs.com/assets/bunny.png'); // When the promise resolves, we have the texture! texturePromise.then((resolvedTexture) => { // create a new Sprite from the resolved loaded Texture const bunny = PIXI.Sprite.from(resolvedTexture); // center the sprite's anchor point bunny.anchor.set(0.5); // move the sprite to the center of the screen bunny.x = app.screen.width / 2; bunny.y = app.screen.height / 2; app.stage.addChild(bunny); });","s":"Promise","u":"/examples/assets/promise","h":"","p":60},{"i":63,"t":"import * as PIXI from 'pixi.js'; const app = new PIXI.Application({ resizeTo: window }); document.body.appendChild(app.view); app.stop(); // load resources PIXI.Assets.load('https://pixijs.com/assets/spritesheet/monsters.json') .then(onAssetsLoaded); // holder to store aliens const aliens = []; const alienFrames = [ 'eggHead.png', 'flowerTop.png', 'helmlok.png', 'skully.png', ]; let count = 0; // create an empty container const alienContainer = new PIXI.Container(); alienContainer.x = 400; alienContainer.y = 300; // make the stage interactive app.stage.eventMode = 'static'; app.stage.addChild(alienContainer); function onAssetsLoaded() { // add a bunch of aliens with textures from image paths for (let i = 0; i < 100; i++) { const frameName = alienFrames[i % 4]; // create an alien using the frame name.. const alien = PIXI.Sprite.from(frameName); alien.tint = Math.random() * 0xFFFFFF; alien.x = Math.random() * 800 - 400; alien.y = Math.random() * 600 - 300; alien.anchor.x = 0.5; alien.anchor.y = 0.5; aliens.push(alien); alienContainer.addChild(alien); } app.start(); } // Combines both mouse click + touch tap app.stage.on('pointertap', onClick); function onClick() { alienContainer.cacheAsBitmap = !alienContainer.cacheAsBitmap; } app.ticker.add(() => { // let's rotate the aliens a little bit for (let i = 0; i < 100; i++) { const alien = aliens[i]; alien.rotation += 0.1; } count += 0.01; alienContainer.scale.x = Math.sin(count); alienContainer.scale.y = Math.sin(count); alienContainer.rotation += 0.01; });","s":"Cache As Bitmap","u":"/examples/basic/cache-as-bitmap","h":"","p":62},{"i":65,"t":"import * as PIXI from 'pixi.js'; const app = new PIXI.Application({ resizeTo: window }); document.body.appendChild(app.view); // create a new background sprite const background = PIXI.Sprite.from('https://pixijs.com/assets/bg_rotate.jpg'); background.width = app.screen.width; background.height = app.screen.height; app.stage.addChild(background); // create an array to store a reference to the dudes const dudeArray = []; const totaldudes = 20; for (let i = 0; i < totaldudes; i++) { // create a new Sprite that uses the image name that we just generated as its source const dude = PIXI.Sprite.from('https://pixijs.com/assets/flowerTop.png'); dude.anchor.set(0.5); // set a random scale for the dude dude.scale.set(0.8 + Math.random() * 0.3); // finally let's set the dude to be at a random position... dude.x = Math.floor(Math.random() * app.screen.width); dude.y = Math.floor(Math.random() * app.screen.height); // The important bit of this example, this is how you change the default blend mode of the sprite dude.blendMode = PIXI.BLEND_MODES.ADD; // create some extra properties that will control movement dude.direction = Math.random() * Math.PI * 2; // this number will be used to modify the direction of the dude over time dude.turningSpeed = Math.random() - 0.8; // create a random speed for the dude between 0 - 2 dude.speed = 2 + Math.random() * 2; // finally we push the dude into the dudeArray so it it can be easily accessed later dudeArray.push(dude); app.stage.addChild(dude); } // create a bounding box for the little dudes const dudeBoundsPadding = 100; const dudeBounds = new PIXI.Rectangle( -dudeBoundsPadding, -dudeBoundsPadding, app.screen.width + dudeBoundsPadding * 2, app.screen.height + dudeBoundsPadding * 2, ); app.ticker.add(() => { // iterate through the dudes and update the positions for (let i = 0; i < dudeArray.length; i++) { const dude = dudeArray[i]; dude.direction += dude.turningSpeed * 0.01; dude.x += Math.sin(dude.direction) * dude.speed; dude.y += Math.cos(dude.direction) * dude.speed; dude.rotation = -dude.direction - Math.PI / 2; // wrap the dudes by testing their bounds... if (dude.x < dudeBounds.x) { dude.x += dudeBounds.width; } else if (dude.x > dudeBounds.x + dudeBounds.width) { dude.x -= dudeBounds.width; } if (dude.y < dudeBounds.y) { dude.y += dudeBounds.height; } else if (dude.y > dudeBounds.y + dudeBounds.height) { dude.y -= dudeBounds.height; } } });","s":"Blend Modes","u":"/examples/basic/blend-modes","h":"","p":64},{"i":67,"t":"import * as PIXI from 'pixi.js'; const app = new PIXI.Application({ background: '#1099bb', resizeTo: window }); document.body.appendChild(app.view); const container = new PIXI.Container(); app.stage.addChild(container); // Create a new texture const texture = PIXI.Texture.from('https://pixijs.com/assets/bunny.png'); // Create a 5x5 grid of bunnies for (let i = 0; i < 25; i++) { const bunny = new PIXI.Sprite(texture); bunny.anchor.set(0.5); bunny.x = (i % 5) * 40; bunny.y = Math.floor(i / 5) * 40; container.addChild(bunny); } // Move container to the center container.x = app.screen.width / 2; container.y = app.screen.height / 2; // Center bunny sprite in local container coordinates container.pivot.x = container.width / 2; container.pivot.y = container.height / 2; // Listen for animate update app.ticker.add((delta) => { // rotate the container! // use delta to create frame-independent transform container.rotation -= 0.01 * delta; });","s":"Container","u":"/examples/basic/container","h":"","p":66},{"i":69,"t":"import * as PIXI from 'pixi.js'; const app = new PIXI.Application({ background: '#1099bb', resizeTo: window }); document.body.appendChild(app.view); /* --------------------------------------- Spinner 1. Square with radial completion. -------------------------------------- */ const generateSpinner1 = (position) => { const container = new PIXI.Container(); container.position = position; app.stage.addChild(container); const base = PIXI.Sprite.from('https://pixijs.com/assets/bg_scene_rotate.jpg'); const size = 100; base.width = size; base.height = size; const bottom = PIXI.Sprite.from('https://pixijs.com/assets/bg_rotate.jpg'); bottom.width = size; bottom.height = size; const mask = new PIXI.Graphics(); mask.position.set(size / 2, size / 2); base.mask = mask; window.mask = mask; container.addChild(bottom); container.addChild(base); container.addChild(mask); let phase = 0; return (delta) => { // Update phase phase += delta / 60; phase %= (Math.PI * 2); // Calculate target point. const x = Math.cos(phase - Math.PI / 2) * size; const y = Math.sin(phase - Math.PI / 2) * size; const segments = [ [-size / 2, -size / 2, size / 2, -size / 2], // top segment [size / 2, -size / 2, size / 2, size / 2], // right [-size / 2, size / 2, size / 2, size / 2], // bottom [-size / 2, -size / 2, -size / 2, size / 2], // left ]; // Find the intersecting segment. let intersection = null; let winding = 0; for (let i = 0; i < segments.length; i++) { const segment = segments[i]; const hit = intersect(0, 0, x, y, segment[0], segment[1], segment[2], segment[3]); if (hit) { intersection = hit; if (i === 0) winding = hit.x > 0 ? 0 : 4; else winding = i; break; } } const corners = [ size / 2, -size / 2, // Top right size / 2, size / 2, // Bottom right -size / 2, size / 2, // Bottom left -size / 2, -size / 2, // Top left, 0, -size / 2, // End point ]; // Redraw mask mask.clear(); mask.lineStyle(2, 0xff0000, 1); mask.beginFill(0xff0000, 1); mask.moveTo(0, -size / 2); mask.lineTo(0, 0); mask.lineTo(intersection.x, intersection.y); // fill the corners for (let i = winding; i < corners.length / 2; i++) { mask.lineTo(corners[i * 2], corners[i * 2 + 1]); } mask.endFill(); }; }; /* ----------------------- Spinner 2. Scaling balls. ---------------------- */ const generateSpinner2 = (position) => { const container = new PIXI.Container(); container.position = position; app.stage.addChild(container); const size = 100; const ballAmount = 7; const balls = []; for (let i = 0; i < ballAmount; i++) { const ball = PIXI.Sprite.from('https://pixijs.com/assets/circle.png'); ball.anchor.set(0.5); container.addChild(ball); ball.position.set( size / 2 + Math.cos(i / ballAmount * Math.PI * 2) * size / 3, size / 2 + Math.sin(i / ballAmount * Math.PI * 2) * size / 3, ); balls.push(ball); } let phase = 0; return (delta) => { // Update phase phase += delta / 60; phase %= (Math.PI * 2); // Update ball scales balls.forEach((b, i) => { const sin = Math.sin(i / ballAmount * Math.PI - phase); // Multiply sin with itself to get more steeper edge. b.scale.set(Math.abs(sin * sin * sin * 0.5) + 0.5); }); }; }; /* --------------------- Spinner 3. Radial mask. -------------------- */ const generateSpinner3 = (position) => { const container = new PIXI.Container(); container.position = position; app.stage.addChild(container); const base = PIXI.Sprite.from('https://pixijs.com/assets/bg_scene_rotate.jpg'); const size = 100; base.width = size; base.height = size; const mask = new PIXI.Graphics(); mask.position.set(size / 2, size / 2); base.mask = mask; window.mask = mask; container.addChild(base); container.addChild(mask); let phase = 0; return (delta) => { // Update phase phase += delta / 60; phase %= (Math.PI * 2); const angleStart = 0 - Math.PI / 2; const angle = phase + angleStart; const radius = 50; const x1 = Math.cos(angleStart) * radius; const y1 = Math.sin(angleStart) * radius; // Redraw mask mask.clear(); mask.lineStyle(2, 0xff0000, 1); mask.beginFill(0xff0000, 1); mask.moveTo(0, 0); mask.lineTo(x1, y1); mask.arc(0, 0, radius, angleStart, angle, false); mask.lineTo(0, 0); mask.endFill(); }; }; /* --------------------------------- Spinner 4. Rounded rectangle edges. ------------------------------- */ const generateSpinner4 = (position) => { const container = new PIXI.Container(); container.position = position; app.stage.addChild(container); const size = 100; const arcRadius = 15; const base = PIXI.Sprite.from('https://pixijs.com/assets/bg_scene_rotate.jpg'); base.width = size; base.height = size; // For better performance having assets prerounded would be better than masking. const roundingMask = new PIXI.Graphics(); roundingMask.beginFill(0, 1); roundingMask.lineStyle(1, 0xff0000, 1); roundingMask.drawRoundedRect(0, 0, size, size, arcRadius); roundingMask.endFill(); base.mask = roundingMask; // The edge could be replaced with image as well. const lineSize = 5; const edge = new PIXI.Graphics(); edge.lineStyle(lineSize, 0xff0000, 1); edge.drawRoundedRect(0, 0, size, size, arcRadius); edge.endFill(); // Mask in this example works basically the same way as in example 1. // Except it is reversed and calculates the mask in straight lines in edges. const mask = new PIXI.Graphics(); mask.position.set(size / 2, size / 2); edge.mask = mask; container.addChild(base); container.addChild(roundingMask); container.addChild(edge); container.addChild(mask); let phase = 0; return (delta) => { // Update phase phase += delta / 160; phase %= (Math.PI * 2); // Calculate target point. const x = Math.cos(phase - Math.PI / 2) * size; const y = Math.sin(phase - Math.PI / 2) * size; // Line segments const segments = [ [-size / 2 + lineSize, -size / 2 + lineSize, size / 2 - lineSize, -size / 2 + lineSize], // top segment [size / 2 - lineSize, -size / 2 + lineSize, size / 2 - lineSize, size / 2 - lineSize], // right [-size / 2 + lineSize, size / 2 - lineSize, size / 2 - lineSize, size / 2 - lineSize], // bottom [-size / 2 + lineSize, -size / 2 + lineSize, -size / 2 + lineSize, size / 2 - lineSize], // left ]; // To which dir should mask continue at each segment let outDir = [ [0, -1], [1, 0], [0, 1], [-1, 0], ]; // Find the intersecting segment. let intersection = null; let winding = 0; // What direction should the line continue after hit has been found before hitting the line size for (let i = 0; i < segments.length; i++) { const segment = segments[i]; const hit = intersect(0, 0, x, y, segment[0], segment[1], segment[2], segment[3]); if (hit) { intersection = hit; if (i === 0) winding = hit.x < 0 ? 0 : 4; else winding = 4 - i; outDir = outDir[i]; break; } } const corners = [ -size / 2 - lineSize, -size / 2 - lineSize, // Top left, -size / 2 - lineSize, size / 2 + lineSize, // Bottom left size / 2 + lineSize, size / 2 + lineSize, // Bottom right size / 2 + lineSize, -size / 2 - lineSize, // Top right ]; // Redraw mask mask.clear(); mask.lineStyle(2, 0x00ff00, 1); mask.beginFill(0xff0000, 1); mask.moveTo(0, 0); mask.moveTo(0, -size / 2 - lineSize); // fill the corners for (let i = 0; i < winding; i++) { mask.lineTo(corners[i * 2], corners[i * 2 + 1]); } mask.lineTo(intersection.x + outDir[0] * lineSize * 2, intersection.y + outDir[1] * lineSize * 2); mask.lineTo(intersection.x, intersection.y); mask.lineTo(0, 0); mask.endFill(); }; }; /* --------------------- Spinner 5. Rounded rectangle fixed length spinner by jonlepage -------------------- */ const generateSpinner5 = (position) => { const container = new PIXI.Container(); container.position = position; app.stage.addChild(container); const halfCircle = new PIXI.Graphics(); halfCircle.beginFill(0xff0000); halfCircle.lineStyle(2, 0xffffff); halfCircle.arc(0, 0, 100, 0, Math.PI); halfCircle.endFill(); halfCircle.position.set(50, 50); const rectangle = new PIXI.Graphics(); rectangle.lineStyle(2, 0xffffff, 1); rectangle.drawRoundedRect(0, 0, 100, 100, 16); rectangle.endFill(); rectangle.mask = halfCircle; container.addChild(rectangle); container.addChild(halfCircle); let phase = 0; return (delta) => { // Update phase phase += delta / 6; phase %= (Math.PI * 2); halfCircle.rotation = phase; }; }; const onTick = [ generateSpinner1(new PIXI.Point(50, 50)), generateSpinner2(new PIXI.Point(160, 50)), generateSpinner3(new PIXI.Point(270, 50)), generateSpinner4(new PIXI.Point(380, 50)), generateSpinner5(new PIXI.Point(490, 50)), ]; // Listen for animate update app.ticker.add((delta) => { // Call tick handling for each spinner. onTick.forEach((cb) => { cb(delta); }); }); /** * Helper functions line intercept math by Paul Bourke http://paulbourke.net/geometry/pointlineplane/ Determine the intersection point of two line segments Return FALSE if the lines don't intersect Code modified from original to match pixi examples linting rules. */ function intersect(x1, y1, x2, y2, x3, y3, x4, y4) { // Check if none of the lines are of length 0 if ((x1 === x2 && y1 === y2) || (x3 === x4 && y3 === y4)) { return false; } const denominator = ((y4 - y3) * (x2 - x1) - (x4 - x3) * (y2 - y1)); // Lines are parallel if (denominator === 0) { return false; } const ua = ((x4 - x3) * (y1 - y3) - (y4 - y3) * (x1 - x3)) / denominator; const ub = ((x2 - x1) * (y1 - y3) - (y2 - y1) * (x1 - x3)) / denominator; // is the intersection along the segments if (ua < 0 || ua > 1 || ub < 0 || ub > 1) { return false; } // Return a object with the x and y coordinates of the intersection const x = x1 + ua * (x2 - x1); const y = y1 + ua * (y2 - y1); return { x, y }; }","s":"Spinners","u":"/examples/advanced/spinners","h":"","p":68},{"i":71,"t":"import * as PIXI from 'pixi.js'; const app = new PIXI.Application({ background: '#1099bb', resizeTo: window }); document.body.appendChild(app.view); PIXI.Assets.load('https://pixijs.com/assets/bg_grass.jpg').then((texture) => { const plane = new PIXI.SimplePlane(texture, 10, 10); plane.x = 100; plane.y = 100; app.stage.addChild(plane); // Get the buffer for vertice positions. const buffer = plane.geometry.getBuffer('aVertexPosition'); // Listen for animate update let timer = 0; app.ticker.add(() => { // Randomize the vertice positions a bit to create movement. for (let i = 0; i < buffer.data.length; i++) { buffer.data[i] += Math.sin((timer / 10) + i) * 0.5; } buffer.update(); timer++; }); });","s":"Simple Plane","u":"/examples/basic/simple-plane","h":"","p":70},{"i":73,"t":"import * as PIXI from 'pixi.js'; const app = new PIXI.Application({ resizeTo: window }); document.body.appendChild(app.view); // holder to store the aliens const aliens = []; const totalDudes = 20; for (let i = 0; i < totalDudes; i++) { // create a new Sprite that uses the image name that we just generated as its source const dude = PIXI.Sprite.from('https://pixijs.com/assets/eggHead.png'); // set the anchor point so the texture is centered on the sprite dude.anchor.set(0.5); // set a random scale for the dude - no point them all being the same size! dude.scale.set(0.8 + Math.random() * 0.3); // finally lets set the dude to be at a random position.. dude.x = Math.random() * app.screen.width; dude.y = Math.random() * app.screen.height; dude.tint = Math.random() * 0xFFFFFF; // create some extra properties that will control movement : // create a random direction in radians. This is a number between 0 and PI*2 which is the equivalent of 0 - 360 degrees dude.direction = Math.random() * Math.PI * 2; // this number will be used to modify the direction of the dude over time dude.turningSpeed = Math.random() - 0.8; // create a random speed for the dude between 2 - 4 dude.speed = 2 + Math.random() * 2; // finally we push the dude into the aliens array so it it can be easily accessed later aliens.push(dude); app.stage.addChild(dude); } // create a bounding box for the little dudes const dudeBoundsPadding = 100; const dudeBounds = new PIXI.Rectangle(-dudeBoundsPadding, -dudeBoundsPadding, app.screen.width + dudeBoundsPadding * 2, app.screen.height + dudeBoundsPadding * 2); app.ticker.add(() => { // iterate through the dudes and update their position for (let i = 0; i < aliens.length; i++) { const dude = aliens[i]; dude.direction += dude.turningSpeed * 0.01; dude.x += Math.sin(dude.direction) * dude.speed; dude.y += Math.cos(dude.direction) * dude.speed; dude.rotation = -dude.direction - Math.PI / 2; // wrap the dudes by testing their bounds... if (dude.x < dudeBounds.x) { dude.x += dudeBounds.width; } else if (dude.x > dudeBounds.x + dudeBounds.width) { dude.x -= dudeBounds.width; } if (dude.y < dudeBounds.y) { dude.y += dudeBounds.height; } else if (dude.y > dudeBounds.y + dudeBounds.height) { dude.y -= dudeBounds.height; } } });","s":"Tinting","u":"/examples/basic/tinting","h":"","p":72},{"i":75,"t":"import * as PIXI from 'pixi.js'; const app = new PIXI.Application({ background: '#1099bb', resizeTo: window }); document.body.appendChild(app.view); // Scale mode for all textures, will retain pixelation PIXI.settings.SCALE_MODE = PIXI.SCALE_MODES.NEAREST; const sprite = PIXI.Sprite.from('https://pixijs.com/assets/bunny.png'); // Set the initial position sprite.anchor.set(0.5); sprite.x = app.screen.width / 2; sprite.y = app.screen.height / 2; // Opt-in to interactivity sprite.eventMode = 'static'; // Shows hand cursor sprite.cursor = 'pointer'; // Pointers normalize touch and mouse (good for mobile and desktop) sprite.on('pointerdown', onClick); // Alternatively, use the mouse & touch events: // sprite.on('click', onClick); // mouse-only // sprite.on('tap', onClick); // touch-only app.stage.addChild(sprite); function onClick() { sprite.scale.x *= 1.25; sprite.scale.y *= 1.25; }","s":"Click","u":"/examples/events/click","h":"","p":74},{"i":77,"t":"import * as PIXI from 'pixi.js'; const app = new PIXI.Application({ backgroundAlpha: 0, resizeTo: window }); document.body.appendChild(app.view); // create a new Sprite from an image path. const bunny = PIXI.Sprite.from('https://pixijs.com/assets/bunny.png'); // center the sprite's anchor point bunny.anchor.set(0.5); // move the sprite to the center of the screen bunny.x = app.screen.width / 2; bunny.y = app.screen.height / 2; app.stage.addChild(bunny); app.ticker.add(() => { // just for fun, let's rotate mr rabbit a little bunny.rotation += 0.1; });","s":"Transparent Background","u":"/examples/basic/transparent-background","h":"","p":76},{"i":79,"t":"import * as PIXI from 'pixi.js'; const app = new PIXI.Application({ resizeTo: window }); document.body.appendChild(app.view); const sprites = new PIXI.ParticleContainer(10000, { scale: true, position: true, rotation: true, uvs: true, alpha: true, }); app.stage.addChild(sprites); // create an array to store all the sprites const maggots = []; const totalSprites = app.renderer instanceof PIXI.Renderer ? 10000 : 100; for (let i = 0; i < totalSprites; i++) { // create a new Sprite const dude = PIXI.Sprite.from('https://pixijs.com/assets/maggot_tiny.png'); // set the anchor point so the texture is centerd on the sprite dude.anchor.set(0.5); // different maggots, different sizes dude.scale.set(0.8 + Math.random() * 0.3); // scatter them all dude.x = Math.random() * app.screen.width; dude.y = Math.random() * app.screen.height; dude.tint = Math.random() * 0x808080; // create a random direction in radians dude.direction = Math.random() * Math.PI * 2; // this number will be used to modify the direction of the sprite over time dude.turningSpeed = Math.random() - 0.8; // create a random speed between 0 - 2, and these maggots are slooww dude.speed = (2 + Math.random() * 2) * 0.2; dude.offset = Math.random() * 100; // finally we push the dude into the maggots array so it it can be easily accessed later maggots.push(dude); sprites.addChild(dude); } // create a bounding box box for the little maggots const dudeBoundsPadding = 100; const dudeBounds = new PIXI.Rectangle( -dudeBoundsPadding, -dudeBoundsPadding, app.screen.width + dudeBoundsPadding * 2, app.screen.height + dudeBoundsPadding * 2, ); let tick = 0; app.ticker.add(() => { // iterate through the sprites and update their position for (let i = 0; i < maggots.length; i++) { const dude = maggots[i]; dude.scale.y = 0.95 + Math.sin(tick + dude.offset) * 0.05; dude.direction += dude.turningSpeed * 0.01; dude.x += Math.sin(dude.direction) * (dude.speed * dude.scale.y); dude.y += Math.cos(dude.direction) * (dude.speed * dude.scale.y); dude.rotation = -dude.direction + Math.PI; // wrap the maggots if (dude.x < dudeBounds.x) { dude.x += dudeBounds.width; } else if (dude.x > dudeBounds.x + dudeBounds.width) { dude.x -= dudeBounds.width; } if (dude.y < dudeBounds.y) { dude.y += dudeBounds.height; } else if (dude.y > dudeBounds.y + dudeBounds.height) { dude.y -= dudeBounds.height; } } // increment the ticker tick += 0.1; });","s":"Particle Container","u":"/examples/basic/particle-container","h":"","p":78},{"i":81,"t":"import * as PIXI from 'pixi.js'; const app = new PIXI.Application({ background: '#1099bb', resizeTo: window }); document.body.appendChild(app.view); // Css style for icons const defaultIcon = 'url(\\'https://pixijs.com/assets/bunny.png\\'),auto'; const hoverIcon = 'url(\\'https://pixijs.com/assets/bunny_saturated.png\\'),auto'; // Add custom cursor styles app.renderer.events.cursorStyles.default = defaultIcon; app.renderer.events.cursorStyles.hover = hoverIcon; // create a background... const background = PIXI.Sprite.from('https://pixijs.com/assets/bg_button.jpg'); background.width = app.screen.width; background.height = app.screen.height; // add background to stage... app.stage.addChild(background); // create some textures from an image path const textureButton = PIXI.Texture.from('https://pixijs.com/assets/button.png'); const textureButtonDown = PIXI.Texture.from('https://pixijs.com/assets/button_down.png'); const textureButtonOver = PIXI.Texture.from('https://pixijs.com/assets/button_over.png'); const buttons = []; const buttonPositions = [ 175, 75, 655, 75, 410, 325, 150, 465, 685, 445, ]; for (let i = 0; i < 5; i++) { const button = new PIXI.Sprite(textureButton); button.cursor = 'hover'; button.anchor.set(0.5); button.x = buttonPositions[i * 2]; button.y = buttonPositions[i * 2 + 1]; // make the button interactive... button.eventMode = 'static'; button .on('pointerdown', onButtonDown) .on('pointerup', onButtonUp) .on('pointerupoutside', onButtonUp) .on('pointerover', onButtonOver) .on('pointerout', onButtonOut); // add it to the stage app.stage.addChild(button); // add button to array buttons.push(button); } // set some silly values... buttons[0].scale.set(1.2); buttons[2].rotation = Math.PI / 10; buttons[3].scale.set(0.8); buttons[4].scale.set(0.8, 1.2); buttons[4].rotation = Math.PI; function onButtonDown() { this.isdown = true; this.texture = textureButtonDown; this.alpha = 1; } function onButtonUp() { this.isdown = false; if (this.isOver) { this.texture = textureButtonOver; } else { this.texture = textureButton; } } function onButtonOver() { this.isOver = true; if (this.isdown) { return; } this.texture = textureButtonOver; } function onButtonOut() { this.isOver = false; if (this.isdown) { return; } this.texture = textureButton; }","s":"Custom Mouse Icon","u":"/examples/events/custom-mouse-icon","h":"","p":80},{"i":83,"t":"import * as PIXI from 'pixi.js'; const app = new PIXI.Application({ resizeTo: window }); document.body.appendChild(app.view); // create a background... const background = PIXI.Sprite.from('https://pixijs.com/assets/bg_button.jpg'); background.width = app.screen.width; background.height = app.screen.height; // add background to stage... app.stage.addChild(background); // create some textures from an image path const textureButton = PIXI.Texture.from('https://pixijs.com/assets/button.png'); const textureButtonDown = PIXI.Texture.from('https://pixijs.com/assets/button_down.png'); const textureButtonOver = PIXI.Texture.from('https://pixijs.com/assets/button_over.png'); const buttons = []; const buttonPositions = [ 175, 75, 655, 75, 410, 325, 150, 465, 685, 445, ]; for (let i = 0; i < 5; i++) { const button = new PIXI.Sprite(textureButton); button.anchor.set(0.5); button.x = buttonPositions[i * 2]; button.y = buttonPositions[i * 2 + 1]; // make the button interactive... button.eventMode = 'static'; button.cursor = 'pointer'; button // Mouse & touch events are normalized into // the pointer* events for handling different // button events. .on('pointerdown', onButtonDown) .on('pointerup', onButtonUp) .on('pointerupoutside', onButtonUp) .on('pointerover', onButtonOver) .on('pointerout', onButtonOut); // Use mouse-only events // .on('mousedown', onButtonDown) // .on('mouseup', onButtonUp) // .on('mouseupoutside', onButtonUp) // .on('mouseover', onButtonOver) // .on('mouseout', onButtonOut) // Use touch-only events // .on('touchstart', onButtonDown) // .on('touchend', onButtonUp) // .on('touchendoutside', onButtonUp) // add it to the stage app.stage.addChild(button); // add button to array buttons.push(button); } // set some silly values... buttons[0].scale.set(1.2); buttons[2].rotation = Math.PI / 10; buttons[3].scale.set(0.8); buttons[4].scale.set(0.8, 1.2); buttons[4].rotation = Math.PI; function onButtonDown() { this.isdown = true; this.texture = textureButtonDown; this.alpha = 1; } function onButtonUp() { this.isdown = false; if (this.isOver) { this.texture = textureButtonOver; } else { this.texture = textureButton; } } function onButtonOver() { this.isOver = true; if (this.isdown) { return; } this.texture = textureButtonOver; } function onButtonOut() { this.isOver = false; if (this.isdown) { return; } this.texture = textureButton; }","s":"Interactivity","u":"/examples/events/interactivity","h":"","p":82},{"i":85,"t":"import * as PIXI from 'pixi.js'; // This example logs the order of events hover-related events in the scene. const app = new PIXI.Application({ antialias: true, background: '#1099bb', }); document.body.appendChild(app.view); const title = app.stage.addChild(new PIXI.Text( `Move your mouse slowly over the boxes to see the order of pointerenter, pointerleave, pointerover, pointerout events on each target!`, { fontSize: 16, }, )); title.x = 2; const logs = []; const logText = app.stage.addChild(new PIXI.Text('', { fontSize: 14, })); logText.y = 80; logText.x = 2; app.stage.name = 'stage'; // Mount outer black box const blackBox = app.stage.addChild(new PIXI.Graphics() .beginFill(0) .drawRect(0, 0, 400, 400) .endFill()); blackBox.name = 'black box'; blackBox.x = 400; // Mount white box inside the white one const whiteBox = blackBox.addChild(new PIXI.Graphics() .beginFill(0xffffff) .drawRect(100, 100, 200, 200) .endFill()); whiteBox.name = 'white box'; // Enable interactivity everywhere! app.stage.eventMode = 'static'; app.stage.hitArea = app.screen; whiteBox.eventMode = 'static'; blackBox.eventMode = 'static'; function onEvent(e) { const type = e.type; const targetName = e.target.name; const currentTargetName = e.currentTarget.name; // Add event to top of logs logs.push(`${currentTargetName} received ${type} event (target is ${targetName})`); if (currentTargetName === 'stage' || type === 'pointerenter' || type === 'pointerleave') { logs.push('-----------------------------------------', ''); } // Prevent logs from growing too long if (logs.length > 30) { while (logs.length > 30) { logs.shift(); } } // Update logText logText.text = logs.join('\\n'); } [app.stage, whiteBox, blackBox].forEach((object) => { object.addEventListener('pointerenter', onEvent); object.addEventListener('pointerleave', onEvent); object.addEventListener('pointerover', onEvent); object.addEventListener('pointerout', onEvent); });","s":"Logger","u":"/examples/events/logger","h":"","p":84},{"i":87,"t":"import * as PIXI from 'pixi.js'; const app = new PIXI.Application(800, 600, { background: '#1099bb' }); document.body.appendChild(app.view); const yellowStar = PIXI.Texture.from('https://pixijs.com/assets/yellowstar.png'); // Standard Sprite Button const starButton1 = new PIXI.Sprite(yellowStar); starButton1.position.set(50, 200); starButton1.cursor = 'pointer'; starButton1.eventMode = 'static'; starButton1 .on('pointerdown', onClick, starButton1) .on('pointerover', onPointerOver, starButton1) .on('pointerout', onPointerOut, starButton1); // Custom Hitarea Button const starButton2 = new PIXI.Sprite(yellowStar); starButton2.position.set(250, 200); // Create a hitarea that matches the sprite, which will be used for point // intersection starButton2.hitArea = new PIXI.Polygon([ 80, 0, 100, 50, 160, 55, 115, 95, 130, 150, 80, 120, 30, 150, 45, 95, 0, 55, 60, 50, ]); starButton2.cursor = 'pointer'; starButton2.eventMode = 'static'; starButton2 .on('pointerdown', onClick, starButton2) .on('pointerover', onPointerOver, starButton2) .on('pointerout', onPointerOut, starButton2); // With Mask, No Hit Area const starButton3 = new PIXI.Sprite(yellowStar); starButton3.position.set(450, 200); starButton3.cursor = 'pointer'; starButton3.eventMode = 'static'; const squareMask = new PIXI.Graphics() .beginFill(0xFFFFFF) .drawRect(starButton3.x, starButton3.y, 75, 200) .endFill(); starButton3.mask = squareMask; starButton3 .on('pointerdown', onClick, starButton3) .on('pointerover', onPointerOver, starButton3) .on('pointerout', onPointerOut, starButton3); // With a Mask and Hit Area // Hitareas ignore masks. You can still click on a button made in this way, // even from areas covered by a mask const starButton4 = new PIXI.Sprite(yellowStar); starButton4.position.set(600, 200); const squareMask2 = new PIXI.Graphics() .beginFill(0xFFFFFF) .drawRect(starButton4.x, starButton4.y, 75, 200) .endFill(); starButton4.mask = squareMask2; // Again, hitarea for intersection checks starButton4.hitArea = new PIXI.Polygon([ 80, 0, 100, 50, 160, 55, 115, 95, 130, 150, 80, 120, 30, 150, 45, 95, 0, 55, 60, 50, ]); starButton4.cursor = 'pointer'; starButton4.eventMode = 'static'; starButton4 .on('pointerdown', onClick, starButton4) .on('pointerover', onPointerOver, starButton4) .on('pointerout', onPointerOut, starButton4); const style = new PIXI.TextStyle({ fill: '#ffffff' }); const text1 = new PIXI.Text('Standard', style); text1.x = starButton1.x + 25; text1.y = starButton1.y + 170; const text2 = new PIXI.Text('Hit Area', style); text2.x = starButton2.x + 35; text2.y = starButton2.y + 170; const text3 = new PIXI.Text('Mask', style); text3.x = starButton3.x + 10; text3.y = starButton3.y + 170; const text4 = new PIXI.Text('Mask + Hit Area', style); text4.x = starButton4.x - 10; text4.y = starButton4.y + 170; // Add to stage app.stage.addChild( starButton2, starButton1, starButton3, starButton4, squareMask, squareMask2, text1, text2, text3, text4, ); function onClick() { this.tint = 0x333333; } function onPointerOver() { this.tint = 0x666666; } function onPointerOut() { this.tint = 0xFFFFFF; }","s":"Custom Hitarea","u":"/examples/events/custom-hitarea","h":"","p":86},{"i":89,"t":"import * as PIXI from 'pixi.js'; const app = new PIXI.Application({ background: '#1099bb', resizeTo: window }); document.body.appendChild(app.view); // create a texture from an image path const texture = PIXI.Texture.from('https://pixijs.com/assets/bunny.png'); // Scale mode for pixelation texture.baseTexture.scaleMode = PIXI.SCALE_MODES.NEAREST; for (let i = 0; i < 10; i++) { createBunny( Math.floor(Math.random() * app.screen.width), Math.floor(Math.random() * app.screen.height), ); } function createBunny(x, y) { // create our little bunny friend.. const bunny = new PIXI.Sprite(texture); // enable the bunny to be interactive... this will allow it to respond to mouse and touch events bunny.eventMode = 'static'; // this button mode will mean the hand cursor appears when you roll over the bunny with your mouse bunny.cursor = 'pointer'; // center the bunny's anchor point bunny.anchor.set(0.5); // make it a bit bigger, so it's easier to grab bunny.scale.set(3); // setup events for mouse + touch using // the pointer events bunny.on('pointerdown', onDragStart, bunny); // move the sprite to its designated position bunny.x = x; bunny.y = y; // add it to the stage app.stage.addChild(bunny); } let dragTarget = null; app.stage.eventMode = 'static'; app.stage.hitArea = app.screen; app.stage.on('pointerup', onDragEnd); app.stage.on('pointerupoutside', onDragEnd); function onDragMove(event) { if (dragTarget) { dragTarget.parent.toLocal(event.global, null, dragTarget.position); } } function onDragStart() { // store a reference to the data // the reason for this is because of multitouch // we want to track the movement of this particular touch // this.data = event.data; this.alpha = 0.5; dragTarget = this; app.stage.on('pointermove', onDragMove); } function onDragEnd() { if (dragTarget) { app.stage.off('pointermove', onDragMove); dragTarget.alpha = 1; dragTarget = null; } }","s":"Dragging","u":"/examples/events/dragging","h":"","p":88},{"i":91,"t":"import * as PIXI from 'pixi.js'; // In this a example, a circle will follow the pointer wherever it // moves over the canvas. const app = new PIXI.Application({ antialias: true, background: '#1099bb', }); document.body.appendChild(app.view); // Create the circle const circle = app.stage.addChild(new PIXI.Graphics() .beginFill(0xffffff) .lineStyle({ color: 0x111111, alpha: 0.87, width: 1 }) .drawCircle(0, 0, 8) .endFill()); circle.position.set(app.screen.width / 2, app.screen.height / 2); // Enable interactivity! app.stage.eventMode = 'static'; // Make sure the whole canvas area is interactive, not just the circle. app.stage.hitArea = app.screen; // Follow the pointer app.stage.addEventListener('pointermove', (e) => { circle.position.copyFrom(e.global); });","s":"Pointer Tracker","u":"/examples/events/pointer-tracker","h":"","p":90},{"i":93,"t":"import * as PIXI from 'pixi.js'; /** * https://github.com/pixijs/pixi.js/wiki/v5-Creating-Filters */ const app = new PIXI.Application({ resizeTo: window }); document.body.appendChild(app.view); // Create background image const background = PIXI.Sprite.from('https://pixijs.com/assets/bg_grass.jpg'); background.width = app.screen.width; background.height = app.screen.height; app.stage.addChild(background); // NOTE: this shader wont work on old devices where mediump precision is forced in fragment shader // because v5 default vertex shader uses `inputSize` in it. Same uniform in fragment and vertex shader // cant have different precision :( const shaderFrag = ` precision highp float; varying vec2 vTextureCoord; uniform vec2 mouse; uniform vec4 inputSize; uniform vec4 outputFrame; uniform float time; void main() { vec2 screenPos = vTextureCoord * inputSize.xy + outputFrame.xy; if (length(mouse - screenPos) < 25.0) { gl_FragColor = vec4(1.0, 1.0, 0.0, 1.0) * 0.7; //yellow circle, alpha=0.7 } else { // blend with underlying image, alpha=0.5 gl_FragColor = vec4( sin(time), (mouse.xy - outputFrame.xy) / outputFrame.zw, 1.0) * 0.5; } } `; const container = new PIXI.Container(); container.filterArea = new PIXI.Rectangle(100, 100, app.screen.width - 200, app.screen.height - 200); app.stage.addChild(container); const filter = new PIXI.Filter(null, shaderFrag, { mouse: new PIXI.Point(), }); container.filters = [filter]; app.stage.hitArea = app.screen; app.stage.eventMode = 'static'; app.stage.on('pointermove', (event) => { filter.uniforms.mouse.copyFrom(event.global); });","s":"Mouse Blending","u":"/examples/filters-advanced/mouse-blending","h":"","p":92},{"i":95,"t":"import * as PIXI from 'pixi.js'; const app = new PIXI.Application({ antialias: true, background: '#1099bb', }); document.body.appendChild(app.view); const stageHeight = app.screen.height; const stageWidth = app.screen.width; // Make sure stage covers the whole scene app.stage.hitArea = app.screen; // Make the slider const sliderWidth = 320; const slider = new PIXI.Graphics() .beginFill(0x272d37) .drawRect(0, 0, sliderWidth, 4); slider.x = (stageWidth - sliderWidth) / 2; slider.y = stageHeight * 0.75; // Draw the handle const handle = new PIXI.Graphics() .beginFill(0xffffff) .drawCircle(0, 0, 8); handle.y = slider.height / 2; handle.x = sliderWidth / 2; handle.eventMode = 'static'; handle.cursor = 'pointer'; handle .on('pointerdown', onDragStart) .on('pointerup', onDragEnd) .on('pointerupoutside', onDragEnd); app.stage.addChild(slider); slider.addChild(handle); // Add bunny whose scale can be changed by user using slider const bunny = app.stage.addChild(PIXI.Sprite.from('https://pixijs.com/assets/bunny.png')); bunny.texture.baseTexture.scaleMode = PIXI.SCALE_MODES.NEAREST; bunny.scale.set(3); bunny.anchor.set(0.5); bunny.x = stageWidth / 2; bunny.y = stageHeight / 2; // Add title const title = new PIXI.Text('Drag the handle to change the scale of bunny.', { fill: '#272d37', fontFamily: 'Roboto', fontSize: 20, align: 'center', }); title.roundPixels = true; title.x = stageWidth / 2; title.y = 40; title.anchor.set(0.5, 0); app.stage.addChild(title); // Listen to pointermove on stage once handle is pressed. function onDragStart() { app.stage.eventMode = 'static'; app.stage.addEventListener('pointermove', onDrag); } // Stop dragging feedback once the handle is released. function onDragEnd(e) { app.stage.eventMode = 'auto'; app.stage.removeEventListener('pointermove', onDrag); } // Update the handle's position & bunny's scale when the handle is moved. function onDrag(e) { const halfHandleWidth = handle.width / 2; // Set handle y-position to match pointer, clamped to (4, screen.height - 4). handle.x = Math.max(halfHandleWidth, Math.min( slider.toLocal(e.global).x, sliderWidth - halfHandleWidth, )); // Normalize handle position between -1 and 1. const t = 2 * ((handle.x / sliderWidth) - 0.5); bunny.scale.set(3 * (1.1 + t)); }","s":"Slider","u":"/examples/events/slider","h":"","p":94},{"i":97,"t":"import * as PIXI from 'pixi.js'; /** * Please note that this is not the most optimal way of doing pure shader generated rendering and should be used when the * scene is wanted as input texture. Check the mesh version of example for more performant version if you need only shader * generated content. **/ const app = new PIXI.Application({ background: '#1099bb', resizeTo: window }); document.body.appendChild(app.view); PIXI.Assets.load('https://pixijs.com/assets/perlin.jpg').then(onAssetsLoaded); let filter = null; const text = new PIXI.Text('PixiJS', { fill: 0xFFFFFF, fontSize: 80 }); text.anchor.set(0.5, 0.5); text.position.set(app.renderer.screen.width / 2, app.renderer.screen.height / 2); app.stage.addChild(text); let totalTime = 0; // Fragment shader, in real use this would be much cleaner when loaded from a file // or embedded into the application as data resource. const fragment = `//Based on this: https://www.shadertoy.com/view/wtlSWX varying vec2 vTextureCoord; uniform sampler2D uSampler; uniform sampler2D noise; uniform float time; // Distance function. Just calculates the height (z) from x,y plane with really simple length check. // Its not exact as there could be shorter distances. vec2 dist(vec3 p) { float id = floor(p.x)+floor(p.y); id = mod(id, 2.); float h = texture2D(noise, vec2(p.x, p.y)*0.04).r*5.1; float h2 = texture2D(uSampler, vTextureCoord).r; return vec2(h+h2-p.z,id); } //Light calculation. vec3 calclight(vec3 p, vec3 rd) { vec2 eps = vec2( 0., 0.001); vec3 n = normalize( vec3( dist(p+eps.yxx).x - dist(p-eps.yxx).x, dist(p+eps.xyx).x - dist(p-eps.xyx).x, dist(p+eps.xxy).x - dist(p-eps.xxy).x )); vec3 d = vec3( max( 0., dot( -rd ,n))); return d; } void main() { vec2 uv = vec2(vTextureCoord.x, 1.-vTextureCoord.y); uv *=2.; uv-=1.; vec3 cam = vec3(0.,time -2., -3.); vec3 target = vec3(sin(time)*0.1, time+cos(time)+2., 0. ); float fov = 2.2; vec3 forward = normalize( target - cam); vec3 up = normalize(cross( forward, vec3(0., 1.,0.))); vec3 right = normalize( cross( up, forward)); vec3 raydir = normalize(vec3( uv.x *up + uv.y * right + fov*forward)); //Do the raymarch vec3 col = vec3(0.); float t = 0.; for( int i = 0; i < 100; i++) { vec3 p = t * raydir + cam; vec2 d = dist(p); t+=d.x*0.5;//Jump only half of the distance as height function used is not really the best for heightmaps. if(d.x < 0.001) { vec3 bc = d.y < 0.5 ? vec3(1.0, .8, 0.) : vec3(0.8,0.0, 1.0); col = vec3( 1.) * calclight(p, raydir) * (1. - t/150.) *bc; break; } if(t > 1000.) { break; } } gl_FragColor = vec4(col, 1.); } `; function onAssetsLoaded(perlin) { // Add perlin noise for filter, make sure it's wrapping and does not have mipmap. perlin.baseTexture.wrapMode = PIXI.WRAP_MODES.REPEAT; perlin.baseTexture.mipmap = false; // Build the filter filter = new PIXI.Filter(null, fragment, { time: 0.0, noise: perlin, }); app.stage.filterArea = app.renderer.screen; app.stage.filters = [filter]; // Listen for animate update. app.ticker.add((delta) => { filter.uniforms.time = totalTime; totalTime += delta / 60; }); }","s":"Shader Toy Filter Render Texture","u":"/examples/filters-advanced/shader-toy-filter-render-texture","h":"","p":96},{"i":99,"t":"import * as PIXI from 'pixi.js'; const app = new PIXI.Application({ resizeTo: window }); document.body.appendChild(app.view); // Create background image const background = PIXI.Sprite.from('https://pixijs.com/assets/bg_grass.jpg'); background.width = app.screen.width; background.height = app.screen.height; app.stage.addChild(background); // Stop application wait for load to finish app.stop(); fetch('https://pixijs.com/assets/pixi-filters/shader.frag') .then((res) => res.text()) .then(onLoaded); let filter; // Handle the load completed function onLoaded(data) { // Create the new filter, arguments: (vertexShader, framentSource) filter = new PIXI.Filter(null, data, { customUniform: 0.0, }); // === WARNING === // specify uniforms in filter constructor // or set them BEFORE first use // filter.uniforms.customUniform = 0.0 // Add the filter background.filters = [filter]; // Resume application update app.start(); } // Animate the filter app.ticker.add((delta) => { filter.uniforms.customUniform += 0.04 * delta; });","s":"Custom","u":"/examples/filters-advanced/custom","h":"","p":98},{"i":101,"t":"import * as PIXI from 'pixi.js'; const app = new PIXI.Application({ resizeTo: window }); document.body.appendChild(app.view); const bg = PIXI.Sprite.from('https://pixijs.com/assets/pixi-filters/bg_depth_blur.jpg'); bg.width = app.screen.width; bg.height = app.screen.height; app.stage.addChild(bg); const littleDudes = PIXI.Sprite.from('https://pixijs.com/assets/pixi-filters/depth_blur_dudes.jpg'); littleDudes.x = (app.screen.width / 2) - 315; littleDudes.y = 200; app.stage.addChild(littleDudes); const littleRobot = PIXI.Sprite.from('https://pixijs.com/assets/pixi-filters/depth_blur_moby.jpg'); littleRobot.x = (app.screen.width / 2) - 200; littleRobot.y = 100; app.stage.addChild(littleRobot); const blurFilter1 = new PIXI.filters.BlurFilter(); const blurFilter2 = new PIXI.filters.BlurFilter(); littleDudes.filters = [blurFilter1]; littleRobot.filters = [blurFilter2]; let count = 0; app.ticker.add(() => { count += 0.005; const blurAmount = Math.cos(count); const blurAmount2 = Math.sin(count); blurFilter1.blur = 20 * (blurAmount); blurFilter2.blur = 20 * (blurAmount2); });","s":"Blur","u":"/examples/filters-basic/blur","h":"","p":100},{"i":103,"t":"import * as PIXI from 'pixi.js'; import '@pixi/graphics-extras'; // This example shows how you can setup a nested boundary to propagate events // into a disjoint scene graph. Here, a camera is used to project an different // world onto the canvas. const app = new PIXI.Application({ antialias: true, background: '#1099bb', }); document.body.appendChild(app.view); // A projector renders it's content using projection. The transforms in // the contents scene graph don't change if you move the camera. To achieve // this, the content is not added as a \"child\" to the projector; however, this // means events won't propagate into the content by default. // // To solve this, we nest our own EventBoundary, and connect it using // addEventListener! class Projector extends PIXI.DisplayObject { constructor() { super(); // The content root to be rendered by this camera. this.content = new PIXI.Container(); // Temporary matrix to store the original projection transform. this.originalTransform = new PIXI.Matrix(); // The event boundary that'll map events downstream into the content // scene. this.boundary = new PIXI.EventBoundary(this.content); // Override copyMouseData to apply inverse worldTransform on // global coords this.boundary.copyMouseData = (from, to) => { // Apply default implementation first PIXI.EventBoundary.prototype.copyMouseData.call(this.boundary, from, to); // Then bring global coords into content's world this.worldTransform.applyInverse(to.global, to.global); // TODO: Remove after https://github.com/pixijs/pixi.js/pull/7381 // is merged! to.target = this.boundary.hitTest(to.global.x, to.global.y); }; // Propagate these events down into the content's scene graph! [ 'pointerdown', 'pointerup', 'pointermove', 'pointerover', 'pointerout', 'wheel', ].forEach((event) => { this.addEventListener(event, (e) => this.boundary.mapEvent(e)); }); this.eventMode = 'static'; } // Pass through cursor get cursor() { return this.boundary.cursor; } // eslint-disable-next-line class-methods-use-this set cursor(value) { throw new Error('The camera\\'s cursor is derived from its content!'); } // Pass through calculateBounds calculateBounds() { const contentBounds = this.content.getBounds(); this._bounds.addFrameMatrix( this.worldTransform, contentBounds.x, contentBounds.y, contentBounds.width, contentBounds.height, ); } // Pass through containsPoint containsPoint(point) { return !!this.boundary.hitTest(point.x, point.y); } // Render content with projection render(renderer) { renderer.batch.flush(); const projectionSystem = renderer.projection; const renderTextureSystem = renderer.renderTexture; projectionSystem.transform = projectionSystem.transform || new PIXI.Matrix(); projectionSystem.transform.copyTo(this.originalTransform); projectionSystem.transform.append(this.worldTransform); projectionSystem.update(null, null, 1, !renderTextureSystem.current); this.content.render(renderer); renderer.batch.flush(); projectionSystem.transform.copyFrom(this.originalTransform); projectionSystem.update(null, null, 1, !renderTextureSystem.current); } // updateTransform also updates content's transform updateTransform() { super.updateTransform(); this.content.enableTempParent(); this.content.updateTransform(); this.content.disableTempParent(null); } } // The projector const projector = app.stage.addChild(new Projector()); // Add coordinate axes! projector.content.addChild( new PIXI.Graphics() .lineStyle({ color: 0, alpha: 0.2, width: 2 }) .moveTo(0, -300) .lineTo(0, 600) .moveTo(-100, 0) .lineTo(700, 0), ); // Construct the star Graphics const stars = [1, 2, 3].map((i) => new PIXI.Graphics() .beginFill(0xffffff, 0.75) .drawStar(0, 0, 18 / i, 100 * i / 2)); // Place the stars stars[0].x = 0; stars[1].x = 200; stars[2].x = 500; // Add stars to the projector projector.content.addChild(...stars); // Make projection x+100, y+300 projector.x = 100; projector.y = 300; projector.content.hitArea = new PIXI.Rectangle(-100, -300, app.screen.width, app.screen.height); // Make hit-area cover the whole screen so we can capture // pointermove everywhere! projector.hitArea = projector.content.hitArea; projector.content.eventMode = 'static'; // Make stars interactive & add wheel handlers stars.forEach((star) => { // Make star interactive star.eventMode = 'static'; // Set initial cursor star.cursor = 'zoom-in'; // Add wheel rotation feedback star.addEventListener('wheel', (e) => { const scroll = Math.sign(e.deltaY) * Math.min(15, Math.abs(e.deltaY)); star.rotation += scroll / 100; }); // Add click zoom-in/zoom-out handler star.addEventListener('click', (e) => { if (star.scale.x === 1) { star.scale.set(1.33); star.cursor = 'zoom-out'; } else { star.scale.set(1); star.cursor = 'zoom-in'; } }); }); PIXI.BitmapFont.from('coordinates', { fontFamily: 'Roboto', fontSize: 16, fill: '#272d37', }, { chars: ['Global:() Screen-.,', ['0', '9']] }); const coordinates = new PIXI.BitmapText('Global: (0, 0)\\nScreen: (0, 0)', { fontName: 'coordinates', }); coordinates.x = 110; coordinates.y = 550; app.stage.addChild(coordinates); projector.content.addEventListener('pointermove', (e) => { const global = `(${e.global.x | 0}, ${e.global.y | 0})`; const screen = `(${e.screen.x | 0}, ${e.screen.y | 0})`; coordinates.text = `Global: ${global}\\nScreen: ${screen}`; }); const description = new PIXI.Text( 'The (0, 0) world coordinates for the content is located at the center of the first star!' + '\\n * Mouse wheel over stars to rotate them' + '\\n * Click to zoom in or out', { fontSize: 16, fontFamily: 'Roboto', fill: '#272d37', }, ); description.position.set(110, 12); app.stage.addChild(description);","s":"Nested Boundary With Projection","u":"/examples/events/nested-boundary-with-projection","h":"","p":102},{"i":105,"t":"import * as PIXI from 'pixi.js'; const app = new PIXI.Application({ resizeTo: window }); document.body.appendChild(app.view); app.stage.eventMode = 'static'; const container = new PIXI.Container(); app.stage.addChild(container); const padding = 100; const bounds = new PIXI.Rectangle( -padding, -padding, app.screen.width + padding * 2, app.screen.height + padding * 2, ); const maggots = []; for (let i = 0; i < 20; i++) { const maggot = PIXI.Sprite.from('https://pixijs.com/assets/maggot.png'); maggot.anchor.set(0.5); container.addChild(maggot); maggot.direction = Math.random() * Math.PI * 2; maggot.speed = 1; maggot.turnSpeed = Math.random() - 0.8; maggot.x = Math.random() * bounds.width; maggot.y = Math.random() * bounds.height; maggot.scale.set(1 + Math.random() * 0.3); maggot.original = new PIXI.Point(); maggot.original.copyFrom(maggot.scale); maggots.push(maggot); } const displacementSprite = PIXI.Sprite.from('https://pixijs.com/assets/pixi-filters/displace.png'); const displacementFilter = new PIXI.filters.DisplacementFilter(displacementSprite); app.stage.addChild(displacementSprite); container.filters = [displacementFilter]; displacementFilter.scale.x = 110; displacementFilter.scale.y = 110; displacementSprite.anchor.set(0.5); const ring = PIXI.Sprite.from('https://pixijs.com/assets/pixi-filters/ring.png'); ring.anchor.set(0.5); ring.visible = false; app.stage.addChild(ring); const bg = PIXI.Sprite.from('https://pixijs.com/assets/bg_grass.jpg'); bg.width = app.screen.width; bg.height = app.screen.height; bg.alpha = 0.4; container.addChild(bg); app.stage .on('mousemove', onPointerMove) .on('touchmove', onPointerMove); function onPointerMove(eventData) { ring.visible = true; displacementSprite.position.set(eventData.data.global.x - 25, eventData.data.global.y); ring.position.copyFrom(displacementSprite.position); } let count = 0; app.ticker.add(() => { count += 0.05; for (let i = 0; i < maggots.length; i++) { const maggot = maggots[i]; maggot.direction += maggot.turnSpeed * 0.01; maggot.x += Math.sin(maggot.direction) * maggot.speed; maggot.y += Math.cos(maggot.direction) * maggot.speed; maggot.rotation = -maggot.direction - Math.PI / 2; maggot.scale.x = maggot.original.x + Math.sin(count) * 0.2; // wrap the maggots around as the crawl if (maggot.x < bounds.x) { maggot.x += bounds.width; } else if (maggot.x > bounds.x + bounds.width) { maggot.x -= bounds.width; } if (maggot.y < bounds.y) { maggot.y += bounds.height; } else if (maggot.y > bounds.y + bounds.height) { maggot.y -= bounds.height; } } });","s":"Displacement Map Crawlies","u":"/examples/filters-basic/displacement-map-crawlies","h":"","p":104},{"i":107,"t":"import * as PIXI from 'pixi.js'; const app = new PIXI.Application({ resizeTo: window }); document.body.appendChild(app.view); app.stage.eventMode = 'static'; const bg = PIXI.Sprite.from('https://pixijs.com/assets/bg_rotate.jpg'); bg.anchor.set(0.5); bg.x = app.screen.width / 2; bg.y = app.screen.height / 2; const filter = new PIXI.filters.ColorMatrixFilter(); const container = new PIXI.Container(); container.x = app.screen.width / 2; container.y = app.screen.height / 2; const bgFront = PIXI.Sprite.from('https://pixijs.com/assets/bg_scene_rotate.jpg'); bgFront.anchor.set(0.5); container.addChild(bgFront); const light2 = PIXI.Sprite.from('https://pixijs.com/assets/light_rotate_2.png'); light2.anchor.set(0.5); container.addChild(light2); const light1 = PIXI.Sprite.from('https://pixijs.com/assets/light_rotate_1.png'); light1.anchor.set(0.5); container.addChild(light1); const panda = PIXI.Sprite.from('https://pixijs.com/assets/panda.png'); panda.anchor.set(0.5); container.addChild(panda); app.stage.addChild(container); app.stage.filters = [filter]; let count = 0; let enabled = true; app.stage.on('pointertap', () => { enabled = !enabled; app.stage.filters = enabled ? [filter] : null; }); const help = new PIXI.Text('Click or tap to turn filters on / off.', { fontFamily: 'Arial', fontSize: 12, fontWeight: 'bold', fill: 'white', }); help.y = app.screen.height - 25; help.x = 10; app.stage.addChild(help); app.ticker.add((delta) => { bg.rotation += 0.01; bgFront.rotation -= 0.01; light1.rotation += 0.02; light2.rotation += 0.01; panda.scale.x = 1 + Math.sin(count) * 0.04; panda.scale.y = 1 + Math.cos(count) * 0.04; count += 0.1; const { matrix } = filter; matrix[1] = Math.sin(count) * 3; matrix[2] = Math.cos(count); matrix[3] = Math.cos(count) * 1.5; matrix[4] = Math.sin(count / 3) * 2; matrix[5] = Math.sin(count / 2); matrix[6] = Math.sin(count / 4); });","s":"Color Matrix","u":"/examples/filters-basic/color-matrix","h":"","p":106},{"i":109,"t":"import * as PIXI from 'pixi.js'; const app = new PIXI.Application({ antialias: true, resizeTo: window }); document.body.appendChild(app.view); app.stage.eventMode = 'static'; app.stage.hitArea = app.screen; const graphics = new PIXI.Graphics(); // set a fill and line style graphics.beginFill(0xFF3300); graphics.lineStyle(10, 0xffd900, 1); // draw a shape graphics.moveTo(50, 50); graphics.lineTo(250, 50); graphics.lineTo(100, 100); graphics.lineTo(250, 220); graphics.lineTo(50, 220); graphics.lineTo(50, 50); graphics.closePath(); graphics.endFill(); // set a fill and line style again graphics.lineStyle(10, 0xFF0000, 0.8); graphics.beginFill(0xFF700B, 1); // draw a second shape graphics.moveTo(210, 300); graphics.lineTo(450, 320); graphics.lineTo(570, 350); graphics.quadraticCurveTo(600, 0, 480, 100); graphics.lineTo(330, 120); graphics.lineTo(410, 200); graphics.lineTo(210, 300); graphics.closePath(); graphics.endFill(); // draw a rectangle graphics.lineStyle(2, 0x0000FF, 1); graphics.drawRect(50, 250, 100, 100); // draw a circle graphics.lineStyle(0); graphics.beginFill(0xFFFF0B, 0.5); graphics.drawCircle(470, 200, 100); graphics.endFill(); graphics.lineStyle(20, 0x33FF00); graphics.moveTo(30, 30); graphics.lineTo(600, 300); app.stage.addChild(graphics); // let's create a moving shape const thing = new PIXI.Graphics(); app.stage.addChild(thing); thing.x = 800 / 2; thing.y = 600 / 2; let count = 0; // Just click on the stage to draw random lines window.app = app; app.stage.on('pointerdown', () => { graphics.lineStyle(Math.random() * 30, Math.random() * 0xFFFFFF, 1); graphics.moveTo(Math.random() * 800, Math.random() * 600); graphics.bezierCurveTo( Math.random() * 800, Math.random() * 600, Math.random() * 800, Math.random() * 600, Math.random() * 800, Math.random() * 600, ); }); app.ticker.add(() => { count += 0.1; thing.clear(); thing.lineStyle(10, 0xff0000, 1); thing.beginFill(0xffFF00, 0.5); thing.moveTo(-120 + Math.sin(count) * 20, -100 + Math.cos(count) * 20); thing.lineTo(120 + Math.cos(count) * 20, -100 + Math.sin(count) * 20); thing.lineTo(120 + Math.sin(count) * 20, 100 + Math.cos(count) * 20); thing.lineTo(-120 + Math.cos(count) * 20, 100 + Math.sin(count) * 20); thing.lineTo(-120 + Math.sin(count) * 20, -100 + Math.cos(count) * 20); thing.closePath(); thing.rotation = count * 0.1; });","s":"Dynamic","u":"/examples/graphics/dynamic","h":"","p":108},{"i":111,"t":"import * as PIXI from 'pixi.js'; import '@pixi/graphics-extras'; const app = new PIXI.Application({ antialias: true, resizeTo: window }); document.body.appendChild(app.view); const graphics = new PIXI.Graphics(); // Rectangle graphics.beginFill(0xDE3249); graphics.drawRect(50, 50, 100, 100); graphics.endFill(); // Rectangle + line style 1 graphics.lineStyle(2, 0xFEEB77, 1); graphics.beginFill(0x650A5A); graphics.drawRect(200, 50, 100, 100); graphics.endFill(); // Rectangle + line style 2 graphics.lineStyle(10, 0xFFBD01, 1); graphics.beginFill(0xC34288); graphics.drawRect(350, 50, 100, 100); graphics.endFill(); // Rectangle 2 graphics.lineStyle(2, 0xFFFFFF, 1); graphics.beginFill(0xAA4F08); graphics.drawRect(530, 50, 140, 100); graphics.endFill(); // Circle graphics.lineStyle(0); // draw a circle, set the lineStyle to zero so the circle doesn't have an outline graphics.beginFill(0xDE3249, 1); graphics.drawCircle(100, 250, 50); graphics.endFill(); // Circle + line style 1 graphics.lineStyle(2, 0xFEEB77, 1); graphics.beginFill(0x650A5A, 1); graphics.drawCircle(250, 250, 50); graphics.endFill(); // Circle + line style 2 graphics.lineStyle(10, 0xFFBD01, 1); graphics.beginFill(0xC34288, 1); graphics.drawCircle(400, 250, 50); graphics.endFill(); // Ellipse + line style 2 graphics.lineStyle(2, 0xFFFFFF, 1); graphics.beginFill(0xAA4F08, 1); graphics.drawEllipse(600, 250, 80, 50); graphics.endFill(); // draw a shape graphics.beginFill(0xFF3300); graphics.lineStyle(4, 0xffd900, 1); graphics.moveTo(50, 350); graphics.lineTo(250, 350); graphics.lineTo(100, 400); graphics.lineTo(50, 350); graphics.closePath(); graphics.endFill(); // draw a rounded rectangle graphics.lineStyle(2, 0xFF00FF, 1); graphics.beginFill(0x650A5A, 0.25); graphics.drawRoundedRect(50, 440, 100, 100, 16); graphics.endFill(); // draw star graphics.lineStyle(2, 0xFFFFFF); graphics.beginFill(0x35CC5A, 1); graphics.drawStar(360, 370, 5, 50); graphics.endFill(); // draw star 2 graphics.lineStyle(2, 0xFFFFFF); graphics.beginFill(0xFFCC5A, 1); graphics.drawStar(280, 510, 7, 50); graphics.endFill(); // draw star 3 graphics.lineStyle(4, 0xFFFFFF); graphics.beginFill(0x55335A, 1); graphics.drawStar(470, 450, 4, 50); graphics.endFill(); // draw polygon const path = [600, 370, 700, 460, 780, 420, 730, 570, 590, 520]; graphics.lineStyle(0); graphics.beginFill(0x3500FA, 1); graphics.drawPolygon(path); graphics.endFill(); app.stage.addChild(graphics);","s":"Simple","u":"/examples/graphics/simple","h":"","p":110},{"i":147,"t":"import * as PIXI from 'pixi.js'; const app = new PIXI.Application({ antialias: true, resizeTo: window }); document.body.appendChild(app.view); app.stage.eventMode = 'static'; const bg = PIXI.Sprite.from('https://pixijs.com/assets/bg_rotate.jpg'); bg.anchor.set(0.5); bg.x = app.screen.width / 2; bg.y = app.screen.height / 2; app.stage.addChild(bg); const container = new PIXI.Container(); container.x = app.screen.width / 2; container.y = app.screen.height / 2; // add a bunch of sprites const bgFront = PIXI.Sprite.from('https://pixijs.com/assets/bg_scene_rotate.jpg'); bgFront.anchor.set(0.5); const light2 = PIXI.Sprite.from('https://pixijs.com/assets/light_rotate_2.png'); light2.anchor.set(0.5); const light1 = PIXI.Sprite.from('https://pixijs.com/assets/light_rotate_1.png'); light1.anchor.set(0.5); const panda = PIXI.Sprite.from('https://pixijs.com/assets/panda.png'); panda.anchor.set(0.5); container.addChild(bgFront, light2, light1, panda); app.stage.addChild(container); // let's create a moving shape const thing = new PIXI.Graphics(); app.stage.addChild(thing); thing.x = app.screen.width / 2; thing.y = app.screen.height / 2; thing.lineStyle(0); container.mask = thing; let count = 0; app.stage.on('pointertap', () => { if (!container.mask) { container.mask = thing; } else { container.mask = null; } }); const help = new PIXI.Text('Click or tap to turn masking on / off.', { fontFamily: 'Arial', fontSize: 12, fontWeight: 'bold', fill: 'white', }); help.y = app.screen.height - 26; help.x = 10; app.stage.addChild(help); app.ticker.add(() => { bg.rotation += 0.01; bgFront.rotation -= 0.01; light1.rotation += 0.02; light2.rotation += 0.01; panda.scale.x = 1 + Math.sin(count) * 0.04; panda.scale.y = 1 + Math.cos(count) * 0.04; count += 0.1; thing.clear(); thing.beginFill(0x8bc5ff, 0.4); thing.moveTo(-120 + Math.sin(count) * 20, -100 + Math.cos(count) * 20); thing.lineTo(120 + Math.cos(count) * 20, -100 + Math.sin(count) * 20); thing.lineTo(120 + Math.sin(count) * 20, 100 + Math.cos(count) * 20); thing.lineTo(-120 + Math.cos(count) * 20, 100 + Math.sin(count) * 20); thing.rotation = count * 0.1; });","s":"Graphics","u":"/examples/masks/graphics","h":"","p":146},{"i":149,"t":"import * as PIXI from 'pixi.js'; const app = new PIXI.Application({ antialias: true, resizeTo: window }); document.body.appendChild(app.view); const sprite = PIXI.Sprite.from('https://pixijs.com/assets/bg_rotate.jpg'); // // BEZIER CURVE //// // information: https://en.wikipedia.org/wiki/BΓ©zier_curve const realPath = new PIXI.Graphics(); realPath.lineStyle(2, 0xFFFFFF, 1); realPath.moveTo(0, 0); realPath.lineTo(100, 200); realPath.lineTo(200, 200); realPath.lineTo(240, 100); realPath.position.x = 50; realPath.position.y = 50; app.stage.addChild(realPath); const bezier = new PIXI.Graphics(); bezier.lineStyle(5, 0xAA0000, 1); bezier.bezierCurveTo(100, 200, 200, 200, 240, 100); bezier.position.x = 50; bezier.position.y = 50; app.stage.addChild(bezier); // // BEZIER CURVE 2 //// const realPath2 = new PIXI.Graphics(); realPath2.lineStyle(2, 0xFFFFFF, 1); realPath2.moveTo(0, 0); realPath2.lineTo(0, -100); realPath2.lineTo(150, 150); realPath2.lineTo(240, 100); realPath2.position.x = 320; realPath2.position.y = 150; app.stage.addChild(realPath2); const bezier2 = new PIXI.Graphics(); bezier2.lineTextureStyle({ width: 10, texture: sprite.texture }); bezier2.bezierCurveTo(0, -100, 150, 150, 240, 100); bezier2.position.x = 320; bezier2.position.y = 150; app.stage.addChild(bezier2); // // ARC //// const arc = new PIXI.Graphics(); arc.lineStyle(5, 0xAA00BB, 1); arc.arc(600, 100, 50, Math.PI, 2 * Math.PI); app.stage.addChild(arc); // // ARC 2 //// const arc2 = new PIXI.Graphics(); arc2.lineStyle(6, 0x3333DD, 1); arc2.arc(650, 270, 60, 2 * Math.PI, 3 * Math.PI / 2); app.stage.addChild(arc2); // // ARC 3 //// const arc3 = new PIXI.Graphics(); arc3.lineTextureStyle({ width: 20, texture: sprite.texture }); arc3.arc(650, 420, 60, 2 * Math.PI, 2.5 * Math.PI / 2); app.stage.addChild(arc3); // / Hole //// const rectAndHole = new PIXI.Graphics(); rectAndHole.beginFill(0x00FF00); rectAndHole.drawRect(350, 350, 150, 150); rectAndHole.beginHole(); rectAndHole.drawCircle(375, 375, 25); rectAndHole.drawCircle(425, 425, 25); rectAndHole.drawCircle(475, 475, 25); rectAndHole.endHole(); rectAndHole.endFill(); app.stage.addChild(rectAndHole); // // Line Texture Style //// const beatifulRect = new PIXI.Graphics(); beatifulRect.lineTextureStyle({ width: 20, texture: sprite.texture }); beatifulRect.beginFill(0xFF0000); beatifulRect.drawRect(80, 350, 150, 150); beatifulRect.endFill(); app.stage.addChild(beatifulRect);","s":"Advanced","u":"/examples/graphics/advanced","h":"","p":148},{"i":151,"t":"import * as PIXI from 'pixi.js'; const app = new PIXI.Application({ resizeTo: window }); document.body.appendChild(app.view); app.stage.eventMode = 'static'; const container = new PIXI.Container(); app.stage.addChild(container); const flag = PIXI.Sprite.from('https://pixijs.com/assets/pixi-filters/flag.png'); container.addChild(flag); flag.x = 100; flag.y = 100; const displacementSprite = PIXI.Sprite.from('https://pixijs.com/assets/pixi-filters/displacement_map_repeat.jpg'); // Make sure the sprite is wrapping. displacementSprite.texture.baseTexture.wrapMode = PIXI.WRAP_MODES.REPEAT; const displacementFilter = new PIXI.filters.DisplacementFilter(displacementSprite); displacementFilter.padding = 10; displacementSprite.position = flag.position; app.stage.addChild(displacementSprite); flag.filters = [displacementFilter]; displacementFilter.scale.x = 30; displacementFilter.scale.y = 60; app.ticker.add(() => { // Offset the sprite position to make vFilterCoord update to larger value. // Repeat wrapping makes sure there's still pixels on the coordinates. displacementSprite.x++; // Reset x to 0 when it's over width to keep values from going to very huge numbers. if (displacementSprite.x > displacementSprite.width) { displacementSprite.x = 0; } });","s":"Displacement Map Flag","u":"/examples/filters-basic/displacement-map-flag","h":"","p":150},{"i":153,"t":"import * as PIXI from 'pixi.js'; const app = new PIXI.Application({ resizeTo: window }); document.body.appendChild(app.view); const geometry = new PIXI.Geometry() .addAttribute('aVertexPosition', // the attribute name [-100, -100, // x, y 100, -100, // x, y 100, 100, -100, 100], // x, y 2) // the size of the attribute .addAttribute('aUvs', // the attribute name [0, 0, // u, v 1, 0, // u, v 1, 1, 0, 1], // u, v 2) // the size of the attribute .addIndex([0, 1, 2, 0, 2, 3]) .interleave(); const shader = PIXI.Shader.from(` precision mediump float; attribute vec2 aVertexPosition; attribute vec2 aUvs; uniform mat3 translationMatrix; uniform mat3 projectionMatrix; varying vec2 vUvs; void main() { vUvs = aUvs; gl_Position = vec4((projectionMatrix * translationMatrix * vec3(aVertexPosition, 1.0)).xy, 0.0, 1.0); }`, `precision mediump float; varying vec2 vUvs; uniform sampler2D uSampler2; void main() { gl_FragColor = texture2D(uSampler2, vUvs ); } `, { uSampler2: PIXI.Texture.from('https://pixijs.com/assets/bg_scene_rotate.jpg'), }); const quad = new PIXI.Mesh(geometry, shader); quad.position.set(400, 300); quad.scale.set(2); app.stage.addChild(quad); app.ticker.add((delta) => { quad.rotation += 0.01; });","s":"Interleaving Geometry","u":"/examples/mesh-and-shaders/interleaving-geometry","h":"","p":152},{"i":155,"t":"import * as PIXI from 'pixi.js'; const app = new PIXI.Application({ resizeTo: window }); document.body.appendChild(app.view); const geometry = new PIXI.Geometry() .addAttribute('aVPos', [-100, 0, 100, 0, 0, -150]); geometry.instanced = true; geometry.instanceCount = 5; const positionSize = 2; const colorSize = 3; const buffer = new PIXI.Buffer(new Float32Array(geometry.instanceCount * (positionSize + colorSize))); geometry.addAttribute( 'aIPos', buffer, positionSize, false, PIXI.TYPES.FLOAT, 4 * (positionSize + colorSize), 0, true ); geometry.addAttribute( 'aICol', buffer, colorSize, false, PIXI.TYPES.FLOAT, 4 * (positionSize + colorSize), 4 * positionSize, true ); for (let i = 0; i < geometry.instanceCount; i++) { const instanceOffset = i * (positionSize + colorSize); buffer.data[instanceOffset + 0] = i * 80; buffer.data[instanceOffset + 2] = Math.random(); buffer.data[instanceOffset + 3] = Math.random(); buffer.data[instanceOffset + 4] = Math.random(); } const shader = PIXI.Shader.from(` precision mediump float; attribute vec2 aVPos; attribute vec2 aIPos; attribute vec3 aICol; uniform mat3 translationMatrix; uniform mat3 projectionMatrix; varying vec3 vCol; void main() { vCol = aICol; gl_Position = vec4((projectionMatrix * translationMatrix * vec3(aVPos + aIPos, 1.0)).xy, 0.0, 1.0); }`, `precision mediump float; varying vec3 vCol; void main() { gl_FragColor = vec4(vCol, 1.0); } `); const triangles = new PIXI.Mesh(geometry, shader); triangles.position.set(400, 300); app.stage.addChild(triangles); app.ticker.add((delta) => { triangles.rotation += 0.01; });","s":"Instanced Geometry","u":"/examples/mesh-and-shaders/instanced-geometry","h":"","p":154},{"i":157,"t":"import * as PIXI from 'pixi.js'; const app = new PIXI.Application({ resizeTo: window }); document.body.appendChild(app.view); app.stage.eventMode = 'static'; const bg = PIXI.Sprite.from('https://pixijs.com/assets/bg_plane.jpg'); app.stage.addChild(bg); const cells = PIXI.Sprite.from('https://pixijs.com/assets/cells.png'); cells.scale.set(1.5); const mask = PIXI.Sprite.from('https://pixijs.com/assets/flowerTop.png'); mask.anchor.set(0.5); mask.x = 310; mask.y = 190; cells.mask = mask; app.stage.addChild(mask, cells); const target = new PIXI.Point(); reset(); function reset() { target.x = Math.floor(Math.random() * 550); target.y = Math.floor(Math.random() * 300); } app.ticker.add(() => { mask.x += (target.x - mask.x) * 0.1; mask.y += (target.y - mask.y) * 0.1; if (Math.abs(mask.x - target.x) < 1) { reset(); } });","s":"Sprite","u":"/examples/masks/sprite","h":"","p":156},{"i":159,"t":"import * as PIXI from 'pixi.js'; const app = new PIXI.Application({ resizeTo: window }); document.body.appendChild(app.view); // Build geometry. const geometry = new PIXI.Geometry() .addAttribute('aVertexPosition', // the attribute name [-100, -100, // x, y 100, -100, // x, y 100, 100, -100, 100], // x, y 2) // the size of the attribute .addAttribute('aUvs', // the attribute name [0, 0, // u, v 1, 0, // u, v 1, 1, 0, 1], // u, v 2) // the size of the attribute .addIndex([0, 1, 2, 0, 2, 3]); const vertexSrc = ` precision mediump float; attribute vec2 aVertexPosition; attribute vec2 aUvs; uniform mat3 translationMatrix; uniform mat3 projectionMatrix; varying vec2 vUvs; void main() { vUvs = aUvs; gl_Position = vec4((projectionMatrix * translationMatrix * vec3(aVertexPosition, 1.0)).xy, 0.0, 1.0); }`; const fragmentSrc = ` //Based on this: https://www.shadertoy.com/view/wtlSWX precision mediump float; varying vec2 vUvs; uniform sampler2D noise; uniform float time; // Distance function. Just calculates the height (z) from x,y plane with really simple length check. // Its not exact as there could be shorter distances. vec2 dist(vec3 p) { float id = floor(p.x)+floor(p.y); id = mod(id, 2.); float h = texture2D(noise, vec2(p.x, p.y)*0.04).r*5.1; return vec2(h-p.z,id); } //Light calculation. vec3 calclight(vec3 p, vec3 rd) { vec2 eps = vec2( 0., 0.001); vec3 n = normalize( vec3( dist(p+eps.yxx).x - dist(p-eps.yxx).x, dist(p+eps.xyx).x - dist(p-eps.xyx).x, dist(p+eps.xxy).x - dist(p-eps.xxy).x )); vec3 d = vec3( max( 0., dot( -rd ,n))); return d; } void main() { vec2 uv = vec2(vUvs.x,1.-vUvs.y); uv *=2.; uv-=1.; vec3 cam = vec3(0.,time -2., -3.); vec3 target = vec3(sin(time)*0.1, time+cos(time)+2., 0. ); float fov = 2.2; vec3 forward = normalize( target - cam); vec3 up = normalize(cross( forward, vec3(0., 1.,0.))); vec3 right = normalize( cross( up, forward)); vec3 raydir = normalize(vec3( uv.x *up + uv.y * right + fov*forward)); //Do the raymarch vec3 col = vec3(0.); float t = 0.; for( int i = 0; i < 100; i++) { vec3 p = t * raydir + cam; vec2 d = dist(p); t+=d.x*0.5;//Jump only half of the distance as height function used is not really the best for heightmaps. if(d.x < 0.001) { vec3 bc = d.y < 0.5 ? vec3(1.0, .8, 0.) : vec3(0.8,0.0, 1.0); col = vec3( 1.) * calclight(p, raydir) * (1. - t/150.) *bc; break; } if(t > 1000.) { break; } } gl_FragColor = vec4(col, 1.); }`; const uniforms = { noise: PIXI.Texture.from('https://pixijs.com/assets/perlin.jpg'), time: 0, }; // Make sure repeat wrap is used and no mipmapping. uniforms.noise.baseTexture.wrapMode = PIXI.WRAP_MODES.REPEAT; uniforms.noise.baseTexture.mipmap = false; // Build the shader and the quad. const shader = PIXI.Shader.from(vertexSrc, fragmentSrc, uniforms); const quad = new PIXI.Mesh(geometry, shader); quad.position.set(400, 300); quad.scale.set(2); app.stage.addChild(quad); // start the animation.. let time = 0; app.ticker.add((delta) => { time += 1 / 60; quad.shader.uniforms.time = time; quad.scale.set(Number(Math.cos(time)) + 2, Number(Math.sin(time * 0.7)) + 2); });","s":"Shader Toy Mesh","u":"/examples/mesh-and-shaders/shader-toy-mesh","h":"","p":158},{"i":161,"t":"import * as PIXI from 'pixi.js'; const app = new PIXI.Application({ resizeTo: window }); document.body.appendChild(app.view); const geometry = new PIXI.Geometry() .addAttribute('aVertexPosition', // the attribute name [-100, -100, // x, y 100, -100, // x, y 100, 100, -100, 100], // x, y 2) // the size of the attribute .addAttribute('aUvs', // the attribute name [0, 0, // u, v 1, 0, // u, v 1, 1, 0, 1], // u, v 2) // the size of the attribute .addIndex([0, 1, 2, 0, 2, 3]); const geometry2 = new PIXI.Geometry() .addAttribute('aVertexPosition', // the attribute name [-100 + 100, -100, // x, y 100 + 100, -100, // x, y 100 + 100, 100], // x, y 2) // the size of the attribute .addAttribute('aUvs', // the attribute name [0, 0, // u, v 1, 0, // u, v 1, 1], // u, v 2) // the size of the attribute .addIndex([0, 1, 2]); const geometry3 = PIXI.Geometry.merge([geometry, geometry2]); const shader = PIXI.Shader.from(` precision mediump float; attribute vec2 aVertexPosition; attribute vec2 aUvs; uniform mat3 translationMatrix; uniform mat3 projectionMatrix; varying vec2 vUvs; void main() { vUvs = aUvs; gl_Position = vec4((projectionMatrix * translationMatrix * vec3(aVertexPosition, 1.0)).xy, 0.0, 1.0); }`, `precision mediump float; varying vec2 vUvs; uniform sampler2D uSampler2; void main() { gl_FragColor = texture2D(uSampler2, vUvs ); } `, { uSampler2: PIXI.Texture.from('https://pixijs.com/assets/bg_scene_rotate.jpg'), }); const quad = new PIXI.Mesh(geometry3, shader); quad.position.set(400, 300); quad.scale.set(2); app.stage.addChild(quad); app.ticker.add((delta) => { quad.rotation += 0.01; });","s":"Merging Geometry","u":"/examples/mesh-and-shaders/merging-geometry","h":"","p":160},{"i":163,"t":"import * as PIXI from 'pixi.js'; const app = new PIXI.Application({ resizeTo: window }); document.body.appendChild(app.view); const geometry = new PIXI.Geometry() .addAttribute('aVertexPosition', // the attribute name [-100, -100, // x, y 100, -100, // x, y 100, 100], // x, y 2) // the size of the attribute .addAttribute('aUvs', // the attribute name [0, 0, // u, v 1, 0, // u, v 1, 1], // u, v 2); // the size of the attribute const program = PIXI.Program.from(` precision mediump float; attribute vec2 aVertexPosition; attribute vec2 aUvs; uniform mat3 translationMatrix; uniform mat3 projectionMatrix; varying vec2 vUvs; void main() { vUvs = aUvs; gl_Position = vec4((projectionMatrix * translationMatrix * vec3(aVertexPosition, 1.0)).xy, 0.0, 1.0); }`, `precision mediump float; varying vec2 vUvs; uniform sampler2D uSamplerTexture; void main() { gl_FragColor = texture2D(uSamplerTexture, vUvs); } `); const triangle = new PIXI.Mesh(geometry, new PIXI.Shader(program, { uSamplerTexture: PIXI.Texture.from('https://pixijs.com/assets/bg_scene_rotate.jpg'), })); const triangle2 = new PIXI.Mesh(geometry, new PIXI.Shader(program, { uSamplerTexture: PIXI.Texture.from('https://pixijs.com/assets/bg_rotate.jpg'), })); const triangle3 = new PIXI.Mesh(geometry, new PIXI.Shader(program, { uSamplerTexture: PIXI.Texture.from('https://pixijs.com/assets/bg_displacement.jpg'), })); triangle.position.set(400, 300); triangle.scale.set(2); triangle2.position.set(200, 100); triangle3.position.set(500, 400); triangle3.scale.set(3); app.stage.addChild(triangle3, triangle2, triangle); app.ticker.add((delta) => { triangle.rotation += 0.01; triangle2.rotation -= 0.01; triangle3.rotation -= 0.005; });","s":"Sharing Geometry","u":"/examples/mesh-and-shaders/sharing-geometry","h":"","p":162},{"i":165,"t":"import * as PIXI from 'pixi.js'; const app = new PIXI.Application({ height: 640, resizeTo: window }); document.body.appendChild(app.view); // Build geometry. const geometry = new PIXI.Geometry() .addAttribute('aVertexPosition', // the attribute name [0, 0, // x, y 200, 0, // x, y 200, 200, 0, 200], // x, y 2) // the size of the attribute .addAttribute('aUvs', // the attribute name [0, 0, // u, v 1, 0, // u, v 1, 1, 0, 1], // u, v 2) // the size of the attribute .addIndex([0, 1, 2, 0, 2, 3]); // Vertex shader. Use same shader for all passes. const vertexSrc = ` precision mediump float; attribute vec2 aVertexPosition; attribute vec2 aUvs; uniform mat3 translationMatrix; uniform mat3 projectionMatrix; varying vec2 vUvs; void main() { vUvs = aUvs; gl_Position = vec4((projectionMatrix * translationMatrix * vec3(aVertexPosition, 1.0)).xy, 0.0, 1.0); }`; // Load a perlinnoise texture for one of the shaders. const perlinTexture = PIXI.Texture.from('https://pixijs.com/assets/perlin.jpg'); // First pass, generates a grid. const fragmentGridSrc = ` precision mediump float; varying vec2 vUvs; uniform float zoom; void main() { //Generate a simple grid. //Offset uv so that center is 0,0 and edges are -1,1 vec2 uv = (vUvs-vec2(0.5))*2.0; vec2 gUv = floor(uv*zoom); vec4 color1 = vec4(0.8, 0.8, 0.8, 1.0); vec4 color2 = vec4(0.4, 0.4, 0.4, 1.0); vec4 outColor = mod(gUv.x + gUv.y, 2.) < 0.5 ? color1 : color2; gl_FragColor = outColor; }`; const gridUniforms = { zoom: 10, }; const gridShader = PIXI.Shader.from(vertexSrc, fragmentGridSrc, gridUniforms); // Sharing textures and meshes is possible. // But for simplicity each pass has its own output texture and mesh in this example. const gridTexture = PIXI.RenderTexture.create({ width: 200, height: 200 }); const gridQuad = new PIXI.Mesh(geometry, gridShader); const gridContainer = new PIXI.Container(); gridContainer.addChild(gridQuad); // Second pass. Takes grid as input and makes it ripple. const fragmentRippleSrc = ` precision mediump float; varying vec2 vUvs; uniform float amount; uniform float phase; uniform sampler2D texIn; void main() { //Generate a simple grid. vec2 uv = vUvs; //Calculate distance from center float distance = length( uv - vec2(0.5)); vec4 color = texture2D(texIn, uv); color.rgb *= sin(distance*25.0+phase) * amount+1.; gl_FragColor = color; }`; const rippleUniforms = { amount: 0.5, phase: 0, texIn: gridTexture, }; const rippleShader = PIXI.Shader.from(vertexSrc, fragmentRippleSrc, rippleUniforms); const rippleTexture = PIXI.RenderTexture.create({ width: 200, height: 200 }); const rippleQuad = new PIXI.Mesh(geometry, rippleShader); const rippleContainer = new PIXI.Container(); rippleContainer.addChild(rippleQuad); // Second effect. Generates a filtered noise. const fragmentNoiseSrc = ` precision mediump float; varying vec2 vUvs; uniform float limit; uniform sampler2D noise; void main() { float color = texture2D(noise, vUvs).r; color = step(limit, color); gl_FragColor = vec4(color); }`; const noiseUniforms = { limit: 0.5, noise: perlinTexture, }; const noiseShader = PIXI.Shader.from(vertexSrc, fragmentNoiseSrc, noiseUniforms); const noiseTexture = PIXI.RenderTexture.create({ width: 200, height: 200 }); const noiseQuad = new PIXI.Mesh(geometry, noiseShader); const noiseContainer = new PIXI.Container(); noiseContainer.addChild(noiseQuad); // Third effect const fragmentWaveSrc = ` precision mediump float; varying vec2 vUvs; uniform float amplitude; uniform float time; void main() { //Offset uv so that center is 0,0 and edges are -1,1 vec2 uv = (vUvs-vec2(0.5))*2.0; vec3 outColor = vec3(0.); //Simple wavefunctions inversed and with small offsets. outColor += 5./length(uv.y*200. - 50.0*sin( uv.x*0.25+ time*0.25)*amplitude); outColor += 4./length(uv.y*300. - 100.0*sin(uv.x*0.5+time*0.5)*amplitude*1.2); outColor += 3./length(uv.y*400. - 150.0*sin(uv.x*0.75+time*0.75)*amplitude*1.4); outColor += 2./length(uv.y*500. - 200.0*sin(uv.x+time)*amplitude*1.6); gl_FragColor = vec4(outColor,1.0); }`; const waveUniforms = { amplitude: 0.75, time: 0, }; const waveShader = PIXI.Shader.from(vertexSrc, fragmentWaveSrc, waveUniforms); const waveTexture = PIXI.RenderTexture.create({ width: 200, height: 200 }); const waveQuad = new PIXI.Mesh(geometry, waveShader); const waveContainer = new PIXI.Container(); waveContainer.addChild(waveQuad); // Final combination pass const fragmentCombineSrc = ` precision mediump float; varying vec2 vUvs; uniform sampler2D texRipple; uniform sampler2D texNoise; uniform sampler2D texWave; void main() { //Read color from all vec4 ripple = texture2D(texRipple, vUvs); vec4 noise = texture2D(texNoise, vUvs); vec4 wave = texture2D(texWave, vUvs); gl_FragColor = mix(ripple, wave,noise.r); }`; const combineUniforms = { texRipple: rippleTexture, texNoise: noiseTexture, texWave: waveTexture, }; const combineShader = PIXI.Shader.from(vertexSrc, fragmentCombineSrc, combineUniforms); const combineQuad = new PIXI.Mesh(geometry, combineShader); gridContainer.position.set(10, 10); rippleContainer.position.set(220, 10); noiseContainer.position.set(10, 220); waveContainer.position.set(10, 430); combineQuad.position.set(430, 220); // Add all phases to stage so all the phases can be seen separately. app.stage.addChild(gridContainer); app.stage.addChild(rippleContainer); app.stage.addChild(noiseContainer); app.stage.addChild(waveContainer); app.stage.addChild(combineQuad); // start the animation.. let time = 0; app.ticker.add((delta) => { time += 1 / 60; // gridQuad.shader.uniforms.zoom = Math.sin(time)*5+10; rippleQuad.shader.uniforms.phase = -time; waveQuad.shader.uniforms.time = time; noiseQuad.shader.uniforms.limit = Math.sin(time * 0.5) * 0.35 + 0.5; // Render the passes to get textures. app.renderer.render(gridQuad, { renderTexture: gridTexture }); app.renderer.render(rippleQuad, { renderTexture: rippleTexture }); app.renderer.render(noiseQuad, { renderTexture: noiseTexture }); app.renderer.render(waveQuad, { renderTexture: waveTexture }); });","s":"Multi Pass Shader Generated Mesh","u":"/examples/mesh-and-shaders/multi-pass-shader-generated-mesh","h":"","p":164},{"i":167,"t":"import * as PIXI from 'pixi.js'; const app = new PIXI.Application({ resizeTo: window }); document.body.appendChild(app.view); const geometry = new PIXI.Geometry() .addAttribute('aVertexPosition', // the attribute name [-100, -100, // x, y 100, -100, // x, y 100, 100]) // x, y .addAttribute('aUvs', // the attribute name [0, 0, // u, v 1, 0, // u, v 1, 1]); // u, v const shader = PIXI.Shader.from(` precision mediump float; attribute vec2 aVertexPosition; attribute vec2 aUvs; uniform mat3 translationMatrix; uniform mat3 projectionMatrix; varying vec2 vUvs; void main() { vUvs = aUvs; gl_Position = vec4((projectionMatrix * translationMatrix * vec3(aVertexPosition, 1.0)).xy, 0.0, 1.0); }`, `precision mediump float; varying vec2 vUvs; uniform sampler2D uSampler2; void main() { gl_FragColor = texture2D(uSampler2, vUvs); } `, { uSampler2: PIXI.Texture.from('https://pixijs.com/assets/bg_scene_rotate.jpg'), }); const shader2 = PIXI.Shader.from(` precision mediump float; attribute vec2 aVertexPosition; attribute vec2 aUvs; uniform mat3 translationMatrix; uniform mat3 projectionMatrix; varying vec2 vUvs; void main() { vUvs = aUvs; gl_Position = vec4((projectionMatrix * translationMatrix * vec3(aVertexPosition, 1.0)).xy, 0.0, 1.0); }`, `precision mediump float; varying vec2 vUvs; uniform sampler2D uSampler2; void main() { gl_FragColor = texture2D(uSampler2, vUvs); gl_FragColor.r += (abs(sin(gl_FragCoord.x * 0.06)) * 0.5) * 2.; gl_FragColor.g += (abs(cos(gl_FragCoord.y * 0.06)) * 0.5) * 2.; } `, { uSampler2: PIXI.Texture.from('https://pixijs.com/assets/bg_scene_rotate.jpg'), }); const triangle = new PIXI.Mesh(geometry, shader); const triangle2 = new PIXI.Mesh(geometry, shader2); triangle.position.set(400, 300); triangle.scale.set(2); triangle2.position.set(500, 400); triangle2.scale.set(3); app.stage.addChild(triangle2, triangle); app.ticker.add((delta) => { triangle.rotation += 0.01; triangle2.rotation -= 0.005; });","s":"Shared Shader","u":"/examples/mesh-and-shaders/shared-shader","h":"","p":166},{"i":169,"t":"import * as PIXI from 'pixi.js'; const app = new PIXI.Application({ resizeTo: window }); document.body.appendChild(app.view); let count = 0; // build a rope! const ropeLength = 45; const points = []; for (let i = 0; i < 25; i++) { points.push(new PIXI.Point(i * ropeLength, 0)); } const strip = new PIXI.SimpleRope(PIXI.Texture.from('https://pixijs.com/assets/snake.png'), points); strip.x = -40; strip.y = 300; app.stage.addChild(strip); const g = new PIXI.Graphics(); g.x = strip.x; g.y = strip.y; app.stage.addChild(g); // start animating app.ticker.add(() => { count += 0.1; // make the snake for (let i = 0; i < points.length; i++) { points[i].y = Math.sin((i * 0.5) + count) * 30; points[i].x = i * ropeLength + Math.cos((i * 0.3) + count) * 20; } renderPoints(); }); function renderPoints() { g.clear(); g.lineStyle(2, 0xffc2c2); g.moveTo(points[0].x, points[0].y); for (let i = 1; i < points.length; i++) { g.lineTo(points[i].x, points[i].y); } for (let i = 1; i < points.length; i++) { g.beginFill(0xff0022); g.drawCircle(points[i].x, points[i].y, 10); g.endFill(); } }","s":"Textured Mesh Advanced","u":"/examples/mesh-and-shaders/textured-mesh-advanced","h":"","p":168},{"i":171,"t":"import * as PIXI from 'pixi.js'; const app = new PIXI.Application({ resizeTo: window }); document.body.appendChild(app.view); const geometry = new PIXI.Geometry() .addAttribute('aVertexPosition', [-100, -50, 100, -50, 0, 100]); const shader = PIXI.Shader.from(` precision mediump float; attribute vec2 aVertexPosition; uniform mat3 translationMatrix; uniform mat3 projectionMatrix; void main() { gl_Position = vec4((projectionMatrix * translationMatrix * vec3(aVertexPosition, 1.0)).xy, 0.0, 1.0); }`, `precision mediump float; void main() { gl_FragColor = vec4(1.0, 0.0, 0.0, 1.0); } `); const triangle = new PIXI.Mesh(geometry, shader); triangle.position.set(400, 300); app.stage.addChild(triangle); app.ticker.add((delta) => { triangle.rotation += 0.01; });","s":"Triangle","u":"/examples/mesh-and-shaders/triangle","h":"","p":170},{"i":173,"t":"import * as PIXI from 'pixi.js'; const app = new PIXI.Application({ resizeTo: window }); document.body.appendChild(app.view); const geometry = new PIXI.Geometry() .addAttribute('aVertexPosition', // the attribute name [-100, -100, // x, y 100, -100, // x, y 100, 100], // x, y 2) // the size of the attribute .addAttribute('aColor', // the attribute name [1, 0, 0, // r, g, b 0, 1, 0, // r, g, b 0, 0, 1], // r, g, b 3) // the size of the attribute .addAttribute('aUvs', // the attribute name [0, 0, // u, v 1, 0, // u, v 1, 1], // u, v 2); // the size of the attribute const vertexSrc = ` precision mediump float; attribute vec2 aVertexPosition; attribute vec3 aColor; attribute vec2 aUvs; uniform mat3 translationMatrix; uniform mat3 projectionMatrix; varying vec2 vUvs; varying vec3 vColor; void main() { vUvs = aUvs; vColor = aColor; gl_Position = vec4((projectionMatrix * translationMatrix * vec3(aVertexPosition, 1.0)).xy, 0.0, 1.0); }`; const fragmentSrc = ` precision mediump float; varying vec3 vColor; varying vec2 vUvs; uniform sampler2D uSampler2; void main() { gl_FragColor = texture2D(uSampler2, vUvs) * vec4(vColor, 1.0); }`; const uniforms = { uSampler2: PIXI.Texture.from('https://pixijs.com/assets/bg_scene_rotate.jpg') }; const shader = PIXI.Shader.from(vertexSrc, fragmentSrc, uniforms); const triangle = new PIXI.Mesh(geometry, shader); triangle.position.set(400, 300); triangle.scale.set(2); app.stage.addChild(triangle); app.ticker.add((delta) => { triangle.rotation += 0.01; });","s":"Triangle Textured","u":"/examples/mesh-and-shaders/triangle-textured","h":"","p":172},{"i":175,"t":"import * as PIXI from 'pixi.js'; const app = new PIXI.Application({ resizeTo: window }); document.body.appendChild(app.view); const geometry = new PIXI.Geometry() .addAttribute('aVertexPosition', // the attribute name [-100, -50, // x, y 100, -50, // x, y 0.0, 100.0], // x, y 2) // the size of the attribute .addAttribute('aColor', // the attribute name [1, 0, 0, // r, g, b 0, 1, 0, // r, g, b 0, 0, 1], // r, g, b 3); // the size of the attribute const shader = PIXI.Shader.from(` precision mediump float; attribute vec2 aVertexPosition; attribute vec3 aColor; uniform mat3 translationMatrix; uniform mat3 projectionMatrix; varying vec3 vColor; void main() { vColor = aColor; gl_Position = vec4((projectionMatrix * translationMatrix * vec3(aVertexPosition, 1.0)).xy, 0.0, 1.0); }`, `precision mediump float; varying vec3 vColor; void main() { gl_FragColor = vec4(vColor, 1.0); } `); const triangle = new PIXI.Mesh(geometry, shader); triangle.position.set(400, 300); triangle.scale.set(2); app.stage.addChild(triangle); app.ticker.add((delta) => { triangle.rotation += 0.01; });","s":"Triangle Color","u":"/examples/mesh-and-shaders/triangle-color","h":"","p":174},{"i":177,"t":"import * as PIXI from 'pixi.js'; const app = new PIXI.Application({ resizeTo: window }); document.body.appendChild(app.view); // Inner radius of the circle const radius = 100; // The blur amount const blurSize = 32; PIXI.Assets.load('https://pixijs.com/assets/bg_grass.jpg').then((grassTexture) => { const background = new PIXI.Sprite(grassTexture); app.stage.addChild(background); background.width = app.screen.width; background.height = app.screen.height; const circle = new PIXI.Graphics() .beginFill(0xFF0000) .drawCircle(radius + blurSize, radius + blurSize, radius) .endFill(); circle.filters = [new PIXI.filters.BlurFilter(blurSize)]; const bounds = new PIXI.Rectangle(0, 0, (radius + blurSize) * 2, (radius + blurSize) * 2); const texture = app.renderer.generateTexture(circle, PIXI.SCALE_MODES.NEAREST, 1, bounds); const focus = new PIXI.Sprite(texture); app.stage.addChild(focus); background.mask = focus; app.stage.eventMode = 'static'; app.stage.hitArea = app.screen; app.stage.on('pointermove', (event) => { focus.position.x = event.global.x - focus.width / 2; focus.position.y = event.global.y - focus.height / 2; }); });","s":"Filter","u":"/examples/masks/filter","h":"","p":176},{"i":179,"t":"import * as PIXI from 'pixi.js'; const app = new PIXI.Application({ resizeTo: window }); document.body.appendChild(app.view); const geometry = new PIXI.Geometry() .addAttribute('aVertexPosition', // the attribute name [-100, -100, // x, y 100, -100, // x, y 100, 100, -100, 100], // x, y 2) // the size of the attribute .addAttribute('aUvs', // the attribute name [0, 0, // u, v 1, 0, // u, v 1, 1, 0, 1], // u, v 2) // the size of the attribute .addIndex([0, 1, 2, 0, 2, 3]); const vertexSrc = ` precision mediump float; attribute vec2 aVertexPosition; attribute vec2 aUvs; uniform mat3 translationMatrix; uniform mat3 projectionMatrix; varying vec2 vUvs; void main() { vUvs = aUvs; gl_Position = vec4((projectionMatrix * translationMatrix * vec3(aVertexPosition, 1.0)).xy, 0.0, 1.0); }`; const fragmentSrc = ` precision mediump float; varying vec2 vUvs; uniform sampler2D uSampler2; uniform float time; void main() { gl_FragColor = texture2D(uSampler2, vUvs + sin( (time + (vUvs.x) * 14.) ) * 0.1 ); }`; const uniforms = { uSampler2: PIXI.Texture.from('https://pixijs.com/assets/bg_scene_rotate.jpg'), time: 0, }; const shader = PIXI.Shader.from(vertexSrc, fragmentSrc, uniforms); const quad = new PIXI.Mesh(geometry, shader); quad.position.set(400, 300); quad.scale.set(2); app.stage.addChild(quad); // start the animation.. // requestAnimationFrame(animate); app.ticker.add((delta) => { quad.rotation += 0.01; quad.shader.uniforms.time += 0.1; });","s":"Uniforms","u":"/examples/mesh-and-shaders/uniforms","h":"","p":178},{"i":181,"t":"import * as PIXI from 'pixi.js'; const app = new PIXI.Application({ autoStart: false, resizeTo: window }); document.body.appendChild(app.view); PIXI.Assets.load('https://pixijs.com/assets/spritesheet/0123456789.json').then((spritesheet) => { // create an array to store the textures const textures = []; let i; for (i = 0; i < 10; i++) { const framekey = `0123456789 ${i}.ase`; const texture = PIXI.Texture.from(framekey); const time = spritesheet.data.frames[framekey].duration; textures.push({ texture, time }); } const scaling = 4; // create a slow AnimatedSprite const slow = new PIXI.AnimatedSprite(textures); slow.anchor.set(0.5); slow.scale.set(scaling); slow.animationSpeed = 0.5; slow.x = (app.screen.width - slow.width) / 2; slow.y = app.screen.height / 2; slow.play(); app.stage.addChild(slow); // create a fast AnimatedSprite const fast = new PIXI.AnimatedSprite(textures); fast.anchor.set(0.5); fast.scale.set(scaling); fast.x = (app.screen.width + fast.width) / 2; fast.y = app.screen.height / 2; fast.play(); app.stage.addChild(fast); // start animating app.start(); });","s":"Animated Sprite Animation Speed","u":"/examples/sprite/animated-sprite-animation-speed","h":"","p":180},{"i":183,"t":"import * as PIXI from 'pixi.js'; const app = new PIXI.Application({ autoStart: false, resizeTo: window }); document.body.appendChild(app.view); PIXI.Assets.load('https://pixijs.com/assets/spritesheet/mc.json').then(() => { // create an array to store the textures const explosionTextures = []; let i; for (i = 0; i < 26; i++) { const texture = PIXI.Texture.from(`Explosion_Sequence_A ${i + 1}.png`); explosionTextures.push(texture); } for (i = 0; i < 50; i++) { // create an explosion AnimatedSprite const explosion = new PIXI.AnimatedSprite(explosionTextures); explosion.x = Math.random() * app.screen.width; explosion.y = Math.random() * app.screen.height; explosion.anchor.set(0.5); explosion.rotation = Math.random() * Math.PI; explosion.scale.set(0.75 + Math.random() * 0.5); explosion.gotoAndPlay(Math.random() * 26 | 0); app.stage.addChild(explosion); } // start animating app.start(); });","s":"Animated Sprite Explosion","u":"/examples/sprite/animated-sprite-explosion","h":"","p":182},{"i":185,"t":"import * as PIXI from 'pixi.js'; // This example is the based on basic/container, but using OffscreenCanvas. const canvas = document.createElement('canvas'); const view = canvas.transferControlToOffscreen(); const app = new PIXI.Application({ view, background: 0x1099bb, resizeTo: window }); document.body.appendChild(canvas); const container = new PIXI.Container(); app.stage.addChild(container); // Create a new texture const texture = PIXI.Texture.from('https://pixijs.com/assets/bunny.png'); // Create a 5x5 grid of bunnies for (let i = 0; i < 25; i++) { const bunny = new PIXI.Sprite(texture); bunny.anchor.set(0.5); bunny.x = (i % 5) * 40; bunny.y = Math.floor(i / 5) * 40; container.addChild(bunny); } // Move container to the center container.x = app.screen.width / 2; container.y = app.screen.height / 2; // Center bunny sprite in local container coordinates container.pivot.x = container.width / 2; container.pivot.y = container.height / 2; // Listen for animate update app.ticker.add((delta) => { // rotate the container! // use delta to create frame-independent transform container.rotation -= 0.01 * delta; });","s":"Basic","u":"/examples/offscreen-canvas/basic","h":"","p":184},{"i":187,"t":"import * as PIXI from 'pixi.js'; const app = new PIXI.Application({ background: '#1099bb', resizeTo: window }); document.body.appendChild(app.view); // create a new Sprite from an image path const bunny = PIXI.Sprite.from('https://pixijs.com/assets/bunny.png'); // center the sprite's anchor point bunny.anchor.set(0.5); // move the sprite to the center of the screen bunny.x = app.screen.width / 2; bunny.y = app.screen.height / 2; app.stage.addChild(bunny); // Listen for animate update app.ticker.add((delta) => { // just for fun, let's rotate mr rabbit a little // delta is 1 if running at 100% performance // creates frame-independent transformation bunny.rotation += 0.1 * delta; });","s":"Basic","u":"/examples/sprite/basic","h":"","p":186},{"i":189,"t":"import * as PIXI from 'pixi.js'; const app = new PIXI.Application({ background: '#1099bb', resizeTo: window }); document.body.appendChild(app.view); let isFlower = true; const texture = PIXI.Texture.from('https://pixijs.com/assets/flowerTop.png'); const secondTexture = PIXI.Texture.from('https://pixijs.com/assets/eggHead.png'); // create a new Sprite using the texture const character = new PIXI.Sprite(texture); // center the sprites anchor point character.anchor.set(0.5); // move the sprite to the center of the screen character.x = app.screen.width / 2; character.y = app.screen.height / 2; app.stage.addChild(character); // make the sprite interactive character.eventMode = 'static'; character.cursor = 'pointer'; character.on('pointertap', () => { isFlower = !isFlower; // Dynamically swap the texture character.texture = isFlower ? texture : secondTexture; }); app.ticker.add(() => { character.rotation += 0.02; });","s":"Texture Swap","u":"/examples/sprite/texture-swap","h":"","p":188},{"i":191,"t":"import * as PIXI from 'pixi.js'; const app = new PIXI.Application({ background: '#1099bb', resizeTo: window }); document.body.appendChild(app.view); PIXI.Assets.load('https://pixijs.com/assets/bitmap-font/desyrel.xml').then(() => { const bitmapFontText = new PIXI.BitmapText( 'bitmap fonts are supported!\\nWoo yay!', { fontName: 'Desyrel', fontSize: 55, align: 'left', }, ); bitmapFontText.x = 50; bitmapFontText.y = 200; app.stage.addChild(bitmapFontText); });","s":"Bitmap Text","u":"/examples/text/bitmap-text","h":"","p":190},{"i":193,"t":"import * as PIXI from 'pixi.js'; const app = new PIXI.Application({ resizeTo: window }); document.body.appendChild(app.view); // create a texture from an image path const texture = PIXI.Texture.from('https://pixijs.com/assets/p2.jpeg'); /* create a tiling sprite ... * requires a texture, a width and a height * in WebGL the image size should preferably be a power of two */ const tilingSprite = new PIXI.TilingSprite( texture, app.screen.width, app.screen.height, ); app.stage.addChild(tilingSprite); let count = 0; app.ticker.add(() => { count += 0.005; tilingSprite.tileScale.x = 2 + Math.sin(count); tilingSprite.tileScale.y = 2 + Math.cos(count); tilingSprite.tilePosition.x += 1; tilingSprite.tilePosition.y += 1; });","s":"Tiling Sprite","u":"/examples/sprite/tiling-sprite","h":"","p":192},{"i":195,"t":"import * as PIXI from 'pixi.js'; const app = new PIXI.Application({ backgroundAlpha: 0, resizeTo: window }); document.body.appendChild(app.view); // Create play button that can be used to trigger the video const button = new PIXI.Graphics() .beginFill(0x0, 0.5) .drawRoundedRect(0, 0, 100, 100, 10) .endFill() .beginFill(0xffffff) .moveTo(36, 30) .lineTo(36, 70) .lineTo(70, 50); // Position the button button.x = (app.screen.width - button.width) / 2; button.y = (app.screen.height - button.height) / 2; // Enable interactivity on the button button.eventMode = 'static'; button.cursor = 'pointer'; // Add to the stage app.stage.addChild(button); // Listen for a click/tap event to start playing the video // this is useful for some mobile platforms. For example: // ios9 and under cannot render videos in PIXI without a // polyfill - https://github.com/bfred-it/iphone-inline-video // ios10 and above require a click/tap event to render videos // that contain audio in PIXI. Videos with no audio track do // not have this requirement button.on('pointertap', onPlayVideo); function onPlayVideo() { // Don't need the button anymore button.destroy(); // create a video texture from a path const texture = PIXI.Texture.from('https://pixijs.com/assets/video.mp4'); // create a new Sprite using the video texture (yes it's that easy) const videoSprite = new PIXI.Sprite(texture); // Stetch the fullscreen videoSprite.width = app.screen.width; videoSprite.height = app.screen.height; app.stage.addChild(videoSprite); }","s":"Video","u":"/examples/sprite/video","h":"","p":194},{"i":197,"t":"import * as PIXI from 'pixi.js'; const app = new PIXI.Application({ background: '#1099bb', resizeTo: window }); document.body.appendChild(app.view); PIXI.Assets.load('https://pixijs.com/assets/spritesheet/fighter.json').then(() => { // create an array of textures from an image path const frames = []; for (let i = 0; i < 30; i++) { const val = i < 10 ? `0${i}` : i; // magically works since the spritesheet was loaded with the pixi loader frames.push(PIXI.Texture.from(`rollSequence00${val}.png`)); } // create an AnimatedSprite (brings back memories from the days of Flash, right ?) const anim = new PIXI.AnimatedSprite(frames); /* * An AnimatedSprite inherits all the properties of a PIXI sprite * so you can change its position, its anchor, mask it, etc */ anim.x = app.screen.width / 2; anim.y = app.screen.height / 2; anim.anchor.set(0.5); anim.animationSpeed = 0.5; anim.play(); app.stage.addChild(anim); // Animate the rotation app.ticker.add(() => { anim.rotation += 0.01; }); });","s":"Animated Sprite Jet","u":"/examples/sprite/animated-sprite-jet","h":"","p":196},{"i":199,"t":"import * as PIXI from 'pixi.js'; const app = new PIXI.Application({ background: '#1099bb', resizeTo: window }); document.body.appendChild(app.view); // Load them google fonts before starting... window.WebFontConfig = { google: { families: ['Snippet'], }, active() { init(); }, }; /* eslint-disable */ // include the web-font loader script (function() { const wf = document.createElement('script'); wf.src = `${document.location.protocol === 'https:' ? 'https' : 'http' }://ajax.googleapis.com/ajax/libs/webfont/1/webfont.js`; wf.type = 'text/javascript'; wf.async = 'true'; const s = document.getElementsByTagName('script')[0]; s.parentNode.insertBefore(wf, s); }()); /* eslint-enabled */ function init() { // create some white text using the Snippet webfont const textSample = new PIXI.Text( 'PixiJS text using the\\ncustom \"Snippet\" Webfont', { fontFamily: 'Snippet', fontSize: 50, fill: 'white', align: 'left', } ); textSample.position.set(50, 200); app.stage.addChild(textSample); }","s":"Web Font","u":"/examples/text/web-font","h":"","p":198},{"i":201,"t":"import * as PIXI from 'pixi.js'; // PixiJS V5 Texture-Resource API + canvas2d gradient API + WebGL texImage2D // Look here for advanced upload function: // https://github.com/pixijs/pixi.js/blob/dev/packages/core/src/textures/resources/BaseImageResource.js#L54 class GradientResource extends PIXI.Resource { constructor() { // pass width and height. (0,0) if we dont know yet // gradient needs only 1 pixel height super(256, 1); } upload(renderer, baseTexture, glTexture) { const { width } = this; // default size or from baseTexture? const { height } = this; // your choice. // temporary canvas, we dont need it after texture is uploaded to GPU const canvas = document.createElement('canvas'); canvas.width = width; canvas.height = height; const ctx = canvas.getContext('2d'); const grd = ctx.createLinearGradient(0, 0, width, 0); grd.addColorStop(0, 'rgba(255, 255, 255, 0.0)'); grd.addColorStop(0.3, 'cyan'); grd.addColorStop(0.7, 'red'); grd.addColorStop(1, 'green'); ctx.fillStyle = grd; ctx.fillRect(0, 0, width, height); // This info ios usseful if upload happens second time // Some people use that to track used memory glTexture.width = width; glTexture.height = height; // PURE WEBGL CALLS - that's what its all about. // PixiJS cant wrap all that API, we give you acceess to it! const { gl } = renderer; gl.pixelStorei(gl.UNPACK_PREMULTIPLY_ALPHA_WEBGL, baseTexture.premultiplyAlpha); gl.texImage2D(baseTexture.target, 0, baseTexture.format, baseTexture.format, baseTexture.type, canvas); return true; } } const app = new PIXI.Application({ antialias: true, resizeTo: window }); document.body.appendChild(app.view); const gradBaseTexture = new PIXI.BaseTexture(new GradientResource()); // Here you can fake baseTexture size to avoid resizing all sprites // There can be multiple baseTextures per gradient, but be careful: // resource will spawn more glTextures! gradBaseTexture.setSize(500, 50); const gradTexture = new PIXI.Texture(gradBaseTexture); const sprite = new PIXI.Sprite(gradTexture); sprite.position.set(100, 100); sprite.rotation = Math.PI / 8; app.stage.addChild(sprite);","s":"Gradient Resource","u":"/examples/textures/gradient-resource","h":"","p":200},{"i":203,"t":"import * as PIXI from 'pixi.js'; const app = new PIXI.Application({ background: '#1099bb', resizeTo: window }); document.body.appendChild(app.view); const basicText = new PIXI.Text('Basic text in pixi'); basicText.x = 50; basicText.y = 100; app.stage.addChild(basicText); const style = new PIXI.TextStyle({ fontFamily: 'Arial', fontSize: 36, fontStyle: 'italic', fontWeight: 'bold', fill: ['#ffffff', '#00ff99'], // gradient stroke: '#4a1850', strokeThickness: 5, dropShadow: true, dropShadowColor: '#000000', dropShadowBlur: 4, dropShadowAngle: Math.PI / 6, dropShadowDistance: 6, wordWrap: true, wordWrapWidth: 440, lineJoin: 'round', }); const richText = new PIXI.Text('Rich text with a lot of options and across multiple lines', style); richText.x = 50; richText.y = 220; app.stage.addChild(richText); const skewStyle = new PIXI.TextStyle({ fontFamily: 'Arial', dropShadow: true, dropShadowAlpha: 0.8, dropShadowAngle: 2.1, dropShadowBlur: 4, dropShadowColor: '0x111111', dropShadowDistance: 10, fill: ['#ffffff'], stroke: '#004620', fontSize: 60, fontWeight: 'lighter', lineJoin: 'round', strokeThickness: 12, }); const skewText = new PIXI.Text('SKEW IS COOL', skewStyle); skewText.skew.set(0.65, -0.3); skewText.anchor.set(0.5, 0.5); skewText.x = 300; skewText.y = 480; app.stage.addChild(skewText);","s":"Pixi Text","u":"/examples/text/pixi-text","h":"","p":202},{"i":205,"t":"import * as PIXI from 'pixi.js'; const app = new PIXI.Application({ background: '#1099bb', resizeTo: window }); document.body.appendChild(app.view); // Load from any font file! PIXI.Assets.addBundle('fonts', { ChaChicle: 'https://pixijs.com/assets/webfont-loader/ChaChicle.ttf', Lineal: 'https://pixijs.com/assets/webfont-loader/Lineal.otf', 'Dotrice Regular': 'https://pixijs.com/assets/webfont-loader/Dotrice-Regular.woff', Crosterian: 'https://pixijs.com/assets/webfont-loader/Crosterian.woff2', }); PIXI.Assets.loadBundle('fonts').then(() => { const text1 = new PIXI.Text('ChaChicle.ttf', new PIXI.TextStyle({ fontFamily: 'ChaChicle', fontSize: 50 })); const text2 = new PIXI.Text('Lineal.otf', new PIXI.TextStyle({ fontFamily: 'Lineal', fontSize: 50 })); const text3 = new PIXI.Text('Dotrice Regular.woff', new PIXI.TextStyle({ fontFamily: 'Dotrice Regular', fontSize: 50 })); const text4 = new PIXI.Text('Crosterian.woff2', new PIXI.TextStyle({ fontFamily: 'Crosterian', fontSize: 50 })); text2.y = 150; text3.y = 300; text4.y = 450; app.stage.addChild(text1); app.stage.addChild(text2); app.stage.addChild(text3); app.stage.addChild(text4); });","s":"From Font","u":"/examples/text/from-font","h":"","p":204},{"i":207,"t":"import * as PIXI from 'pixi.js'; const app = new PIXI.Application({ resizeTo: window }); document.body.appendChild(app.view); const stageSize = { width: app.screen.width, height: app.screen.height, }; // create two render textures... these dynamic textures will be used to draw the scene into itself let renderTexture = PIXI.RenderTexture.create(stageSize); let renderTexture2 = PIXI.RenderTexture.create(stageSize); const currentTexture = renderTexture; // create a new sprite that uses the render texture we created above const outputSprite = new PIXI.Sprite(currentTexture); // align the sprite outputSprite.x = 400; outputSprite.y = 300; outputSprite.anchor.set(0.5); // add to stage app.stage.addChild(outputSprite); const stuffContainer = new PIXI.Container(); stuffContainer.x = 400; stuffContainer.y = 300; app.stage.addChild(stuffContainer); // create an array of image ids.. const fruits = [ 'https://pixijs.com/assets/rt_object_01.png', 'https://pixijs.com/assets/rt_object_02.png', 'https://pixijs.com/assets/rt_object_03.png', 'https://pixijs.com/assets/rt_object_04.png', 'https://pixijs.com/assets/rt_object_05.png', 'https://pixijs.com/assets/rt_object_06.png', 'https://pixijs.com/assets/rt_object_07.png', 'https://pixijs.com/assets/rt_object_08.png', ]; // create an array of items const items = []; // now create some items and randomly position them in the stuff container for (let i = 0; i < 20; i++) { const item = PIXI.Sprite.from(fruits[i % fruits.length]); item.x = Math.random() * 400 - 200; item.y = Math.random() * 400 - 200; item.anchor.set(0.5); stuffContainer.addChild(item); items.push(item); } // used for spinning! let count = 0; app.ticker.add(() => { for (let i = 0; i < items.length; i++) { // rotate each item const item = items[i]; item.rotation += 0.1; } count += 0.01; // swap the buffers ... const temp = renderTexture; renderTexture = renderTexture2; renderTexture2 = temp; // set the new texture outputSprite.texture = renderTexture; // twist this up! stuffContainer.rotation -= 0.01; outputSprite.scale.set(1 + Math.sin(count) * 0.2); // render the stage to the texture // the 'true' clears the texture before the content is rendered app.renderer.render(app.stage, { renderTexture: renderTexture2, clear: false, }); });","s":"Render Texture Advanced","u":"/examples/textures/render-texture-advanced","h":"","p":206},{"i":209,"t":"import * as PIXI from 'pixi.js'; // This demo uses canvas2d gradient API // https://developer.mozilla.org/en-US/docs/Web/API/CanvasRenderingContext2D/createLinearGradient const app = new PIXI.Application({ antialias: true, resizeTo: window }); document.body.appendChild(app.view); function createGradTexture() { // adjust it if somehow you need better quality for very very big images const quality = 256; const canvas = document.createElement('canvas'); canvas.width = quality; canvas.height = 1; const ctx = canvas.getContext('2d'); // use canvas2d API to create gradient const grd = ctx.createLinearGradient(0, 0, quality, 0); grd.addColorStop(0, 'rgba(255, 255, 255, 0.0)'); grd.addColorStop(0.3, 'cyan'); grd.addColorStop(0.7, 'red'); grd.addColorStop(1, 'green'); ctx.fillStyle = grd; ctx.fillRect(0, 0, quality, 1); return PIXI.Texture.from(canvas); } const gradTexture = createGradTexture(); const sprite = new PIXI.Sprite(gradTexture); sprite.position.set(100, 100); sprite.rotation = Math.PI / 8; sprite.width = 500; sprite.height = 50; app.stage.addChild(sprite);","s":"Gradient Basic","u":"/examples/textures/gradient-basic","h":"","p":208},{"i":211,"t":"import * as PIXI from 'pixi.js'; const app = new PIXI.Application({ resizeTo: window }); document.body.appendChild(app.view); PIXI.Assets.load('https://pixijs.com/assets/flowerTop.png').then((texture) => { // create rotated textures const textures = [texture]; const D8 = PIXI.groupD8; for (let rotate = 1; rotate < 16; rotate++) { const h = D8.isVertical(rotate) ? texture.frame.width : texture.frame.height; const w = D8.isVertical(rotate) ? texture.frame.height : texture.frame.width; const { frame } = texture; const crop = new PIXI.Rectangle(texture.frame.x, texture.frame.y, w, h); const trim = crop; let rotatedTexture; if (rotate % 2 === 0) { rotatedTexture = new PIXI.Texture(texture.baseTexture, frame, crop, trim, rotate); } else { // HACK to avoid exception // PIXI doesnt like diamond-shaped UVs, because they are different in canvas and webgl rotatedTexture = new PIXI.Texture(texture.baseTexture, frame, crop, trim, rotate - 1); rotatedTexture.rotate++; } textures.push(rotatedTexture); } const offsetX = app.screen.width / 16 | 0; const offsetY = app.screen.height / 8 | 0; const gridW = app.screen.width / 4 | 0; const gridH = app.screen.height / 5 | 0; // normal rotations and mirrors for (let i = 0; i < 16; i++) { // create a new Sprite using rotated texture const dude = new PIXI.Sprite(textures[i < 8 ? i * 2 : (i - 8) * 2 + 1]); dude.scale.x = 0.5; dude.scale.y = 0.5; // show it in grid dude.x = offsetX + gridW * (i % 4); dude.y = offsetY + gridH * (i / 4 | 0); app.stage.addChild(dude); const text = new PIXI.Text(`rotate = ${dude.texture.rotate}`, { fontFamily: 'Courier New', fontSize: '12px', fill: 'white', align: 'left', }); text.x = dude.x; text.y = dude.y - 20; app.stage.addChild(text); } });","s":"Texture Rotate","u":"/examples/textures/texture-rotate","h":"","p":210},{"i":244,"t":"import * as PIXI from 'pixi.js'; const app = new PIXI.Application({ background: '#1099bb', resizeTo: window }); document.body.appendChild(app.view); const container = new PIXI.Container(); app.stage.addChild(container); const texture = PIXI.Texture.from('https://pixijs.com/assets/bunny.png'); for (let i = 0; i < 25; i++) { const bunny = new PIXI.Sprite(texture); bunny.x = (i % 5) * 30; bunny.y = Math.floor(i / 5) * 30; bunny.rotation = Math.random() * (Math.PI * 2); container.addChild(bunny); } const rt = PIXI.RenderTexture.create({ width: 300, height: 300, scaleMode: PIXI.SCALE_MODES.LINEAR, resolution: 1, }); const sprite = new PIXI.Sprite(rt); sprite.x = 450; sprite.y = 60; app.stage.addChild(sprite); /* * All the bunnies are added to the container with the addChild method * when you do this, all the bunnies become children of the container, and when a container moves, * so do all its children. * This gives you a lot of flexibility and makes it easier to position elements on the screen */ container.x = 100; container.y = 60; app.ticker.add(() => { app.renderer.render(container, { renderTexture: rt }); });","s":"Render Texture Basic","u":"/examples/textures/render-texture-basic","h":"","p":243},{"i":258,"t":"import * as PIXI from 'pixi.js'; const app = new PIXI.Application({ resizeTo: window }); document.body.appendChild(app.view); let count = 0; // build a rope! const ropeLength = 918 / 20; const points = []; for (let i = 0; i < 20; i++) { points.push(new PIXI.Point(i * ropeLength, 0)); } const strip = new PIXI.SimpleRope(PIXI.Texture.from('https://pixijs.com/assets/snake.png'), points); strip.x = -459; const snakeContainer = new PIXI.Container(); snakeContainer.x = 400; snakeContainer.y = 300; snakeContainer.scale.set(800 / 1100); app.stage.addChild(snakeContainer); snakeContainer.addChild(strip); app.ticker.add(() => { count += 0.1; // make the snake for (let i = 0; i < points.length; i++) { points[i].y = Math.sin((i * 0.5) + count) * 30; points[i].x = i * ropeLength + Math.cos((i * 0.3) + count) * 20; } });","s":"Textured Mesh Basic","u":"/examples/mesh-and-shaders/textured-mesh-basic","h":"","p":257}],"index":{"version":"2.3.9","fields":["t"],"fieldVectors":[["t/17",[0,6.021,1,5.524,2,6.136,3,6.021,4,4.318,5,5.229,6,6.021,7,6.021,8,5.229,9,6.021,10,4.708,11,6.021,12,4.007,13,4.318,14,6.021,15,6.021,16,4.708,17,2.616,18,4.708,19,6.021,20,5.229,21,1.71,22,6.021,23,3.748,24,4.318]],["t/41",[12,2.316,13,3.11,16,1.708,25,0.012,26,0.045,27,0.012,28,0.012,29,1.36,30,2.184,31,2.184,32,2.184,33,2.184,34,1.897,35,3.479,36,2.184,37,2.184,38,2.184,39,1.897,40,2.184,41,2.184,42,2.184,43,0.04,44,0.012,45,0.037,46,0.02,47,0.405,48,1.897,49,0.052,50,0.052,51,0.02,52,1.897,53,4.336,54,2.184,55,1.708,56,4.223,57,5.749,58,2.721,59,3.479,60,1.567,61,2.184,62,5.401,63,1.567,64,3.595,65,3.547,66,3.479,67,0.909,68,2.184,69,1.567,70,2.184,71,1.279,72,4.946,73,1.243,74,2.184,75,4.336,76,2.184,77,2.184,78,2.184,79,2.184,80,2.353,81,3.479,82,3.479,83,2.184,84,2.184,85,3.479,86,3.479,87,2.184,88,2.184,89,1.567,90,2.184,91,3.479,92,2.184,93,1.897,94,2.184,95,2.184,96,2.184,97,2.184,98,3.766,99,2.184,100,3.829,101,4.336,102,4.336,103,4.336,104,4.336,105,3.292,106,2.184,107,2.184,108,2.184,109,2.184,110,2.184,111,2.184,112,2.184,113,2.184,114,2.184,115,2.7,116,2.184,117,3.479,118,2.184,119,3.479,120,2.184,121,2.184,122,3.547,123,2.184,124,1.454,125,2.184,126,2.184,127,2.184,128,2.184,129,2.721,130,2.184,131,2.184,132,2.184,133,3.391,134,2.184,135,3.479,136,3.479,137,3.479,138,1.09,139,0.444,140,0.964,141,2.184,142,2.184,143,2.184,144,1.897,145,2.184,146,4.336,147,0.836,148,1.039,149,1.897,150,4.336,151,2.184,152,0.426,153,3.479,154,3.479,155,2.184,156,1.708,157,2.184,158,4.336,159,0.39,160,3.479,161,0.836,162,0.803,163,0.803,164,0.549,165,1.039,166,1.039,167,1.897,168,1.279,169,4.946,170,1.708,171,4.946,172,1.708,173,0.992,174,0.992,175,1.279,176,0.662,177,2.184,178,2.184,179,2.721,180,1.897,181,2.184,182,5.754,183,0.662,184,2.184,185,2.184,186,4.946,187,3.479,188,2.184,189,4.946,190,2.184,191,1.826,192,2.184,193,2.886,194,5.401,195,0.805,196,4.336,197,5.401,198,3.479,199,2.184,200,1.708,201,2.184,202,2.468,203,2.276,204,1.567,205,2.184,206,0.949,207,0.992,208,3.479,209,3.479,210,1.095,211,3.479,212,2.184,213,1.581,214,2.184,215,2.184,216,2.184,217,1.039,218,1.708,219,3.479,220,1.897,221,2.184,222,2.184,223,2.184,224,2.184,225,2.184,226,1.897,227,1.708,228,3.479,229,2.184,230,4.336,231,3.479,232,2.184,233,2.184,234,2.184,235,2.184,236,3.479,237,1.897,238,1.454,239,2.184,240,2.184,241,2.184,242,0.871,243,3.479,244,3.479,245,2.184,246,2.596,247,2.184,248,0.772,249,0.992,250,2.184]],["t/43",[13,2.84,25,0.021,26,0.045,27,0.021,28,0.021,43,0.04,44,0.021,45,0.037,46,0.036,47,1.004,49,0.095,50,0.095,51,0.036,73,1.666,100,2.636,124,2.636,138,0.652,152,0.279,161,1.516,162,2.437,163,1.456,164,0.995,165,1.884,166,2.575,207,1.799,251,3.96,252,2.466,253,0.959,254,5.413,255,2.159,256,2.32,257,3.097,258,1.456,259,0.679,260,4.126,261,3.96,262,5.413,263,3.96,264,3.96,265,3.96,266,3.96,267,3.96,268,3.96,269,3.097,270,3.078,271,2.996,272,5.356,273,3.96,274,5.413,275,3.96,276,4.423,277,3.44,278,6.166,279,3.96,280,3.96,281,3.44,282,3.097,283,2.636,284,3.44,285,2.84,286,4.701,287,2.84,288,3.96,289,4.232,290,5.756,291,3.254,292,6.94,293,2.841,294,3.44,295,3.96,296,3.96,297,5.356,298,5.413,299,3.44,300,3.96,301,2.192,302,2.636,303,1.648,304,3.44,305,3.96,306,3.96,307,3.96,308,3.96,309,3.097,310,1.977,311,2.84,312,2.84,313,2.079,314,3.96,315,3.96,316,3.96,317,3.96,318,3.96,319,3.96,320,1.113,321,3.96,322,3.96]],["t/45",[25,0.024,26,0.045,27,0.024,28,0.024,34,5.139,43,0.041,44,0.024,45,0.039,46,0.041,48,3.929,49,0.109,50,0.109,51,0.041,67,2.462,73,1.137,139,0.628,152,0.319,163,1.663,164,1.137,165,2.152,166,2.152,176,1.371,183,1.371,246,2.375,253,1.095,323,4.524,324,3.011,325,5.917,326,1.732,327,3.245,328,5.917,329,3.537,330,3.245,331,4.524,332,4.524,333,4.524,334,4.524,335,5.917,336,4.524,337,4.524,338,4.524,339,3.011,340,3.929,341,2.375,342,2.258,343,2.375,344,2.375,345,2.258,346,3.938,347,2.258,348,3.245,349,4.524,350,4.524,351,2.504,352,4.524,353,1.424,354,4.524,355,4.524,356,4.524,357,4.524,358,4.524,359,3.275,360,3.011,361,2.258,362,3.537,363,1.965,364,4.524,365,4.524,366,3.537,367,4.524,368,4.524,369,4.524,370,4.524,371,4.524,372,4.524,373,4.524]],["t/47",[25,0.017,26,0.045,27,0.017,28,0.017,29,1.996,43,0.041,44,0.017,45,0.025,46,0.029,47,0.595,49,0.077,50,0.077,51,0.029,73,1.381,80,2.87,98,2.784,124,4.016,138,0.528,139,0.542,147,1.785,152,0.499,159,1.262,161,1.227,162,1.179,163,1.179,164,0.806,165,1.525,166,1.525,167,2.784,168,1.878,170,2.507,172,2.507,173,1.456,174,1.456,175,2.02,203,1.683,242,1.279,253,0.776,259,0.942,293,2.447,299,4.05,374,0.806,375,4.718,376,3.206,377,3.206,378,3.206,379,3.206,380,6.411,381,4.663,382,2.784,383,4.663,384,1.334,385,6.689,386,5.495,387,3.531,388,3.206,389,3.206,390,2.507,391,3.206,392,3.206,393,3.206,394,2.784,395,3.206,396,6.034,397,3.206,398,3.206,399,1.048,400,2.299,401,3.206,402,3.206,403,3.206,404,3.206,405,3.206,406,3.646,407,3.206,408,2.784,409,4.663,410,4.663,411,2.784,412,3.206,413,2.507,414,4.663,415,3.206,416,4.663,417,3.206,418,3.206,419,3.206,420,3.206,421,6.411,422,3.206,423,6.689,424,4.663,425,3.206,426,5.495,427,4.663,428,3.206,429,4.452,430,6.411,431,3.206,432,3.206,433,6.689,434,6.411,435,3.206,436,3.206,437,3.206,438,3.206]],["t/49",[21,0.758,25,0.017,26,0.045,27,0.017,28,0.017,43,0.041,44,0.017,45,0.024,46,0.028,49,0.075,50,0.075,51,0.028,55,2.448,60,2.245,67,1.907,73,1.152,105,3.608,115,4.13,122,3.287,139,0.596,152,0.514,159,0.818,161,1.198,162,1.685,173,1.422,174,1.422,175,1.151,176,0.948,206,2.355,210,0.985,226,2.719,227,2.448,246,1.643,253,0.758,258,1.151,259,0.537,320,0.88,384,1.907,439,5.605,440,3.131,441,3.131,442,5.421,443,3.583,444,6.35,445,4.238,446,4.583,447,3.131,448,5.966,449,4.583,450,5.421,451,3.98,452,3.131,453,4.965,454,3.131,455,3.131,456,2.448,457,5.421,458,3.131,459,3.131,460,3.583,461,5.421,462,2.838,463,5.966,464,2.245,465,2.719,466,2.084,467,2.719,468,3.131,469,2.719,470,3.131,471,1.828,472,4.583,473,3.131,474,4.583,475,3.131,476,1.949,477,3.131,478,3.131,479,3.131,480,3.131,481,3.05,482,3.98,483,2.719,484,2.719,485,1.422,486,2.448,487,1.151,488,3.131,489,2.719,490,3.131,491,1.302,492,3.131,493,2.448,494,2.719,495,4.583,496,6.35,497,4.583,498,3.98,499,2.537,500,2.245,501,5.421,502,5.421,503,4.583,504,3.131,505,5.966,506,3.131,507,3.131,508,3.131,509,4.583,510,3.131,511,4.583,512,2.448,513,3.131,514,3.131,515,3.131,516,3.131]],["t/51",[21,1.595,25,0.029,26,0.044,27,0.029,28,0.029,43,0.038,44,0.029,45,0.035,46,0.048,47,0.995,49,0.129,50,0.129,51,0.048,73,1.793,139,0.592,140,0.956,148,2.55,191,2.813,195,0.995,206,2.862,207,2.435,253,1.595,259,0.919,327,5.116,330,4.725,342,2.675,344,2.813,345,2.675,347,2.675,374,1.347,485,2.435,517,4.655,518,5.151,519,4.655,520,5.36,521,3.14,522,5.36,523,3.844,524,2.813,525,3.567,526,4.655]],["t/53",[16,1.61,17,0.894,23,2.066,25,0.011,26,0.045,27,0.011,28,0.011,29,1.282,43,0.041,44,0.011,45,0.035,46,0.018,47,0.382,49,0.049,50,0.049,51,0.018,67,1.989,71,1.206,73,1.591,80,2.274,115,1.282,139,0.529,140,0.592,147,1.595,152,0.485,159,1.094,162,0.757,164,0.517,173,1.507,174,1.507,175,1.927,176,1.005,180,1.788,195,0.616,213,0.935,242,0.821,248,1.172,253,0.498,255,1.323,259,0.353,291,1.507,293,1.742,320,1.171,326,1.27,359,2.307,360,1.37,361,1.027,363,0.894,374,0.517,429,4.081,464,1.476,471,0.821,476,1.282,481,1.37,482,2.882,484,2.882,486,1.61,487,0.757,491,1.734,499,1.139,527,2.059,528,1.476,529,1.476,530,2.059,531,2.059,532,1.788,533,4.168,534,1.61,535,6.33,536,1.206,537,2.882,538,2.882,539,2.059,540,0.979,541,2.059,542,4.168,543,2.059,544,1.788,545,1.788,546,2.059,547,2.059,548,2.595,549,4.168,550,3.318,551,3.318,552,2.059,553,2.059,554,4.168,555,2.059,556,3.62,557,1.788,558,2.059,559,2.059,560,2.059,561,2.059,562,6.131,563,1.578,564,4.78,565,2.059,566,3.318,567,2.059,568,1.476,569,2.059,570,2.059,571,2.059,572,3.318,573,3.318,574,2.059,575,2.059,576,3.318,577,2.059,578,2.059,579,2.059,580,2.059,581,2.594,582,2.882,583,1.788,584,5.603,585,2.059,586,2.059,587,2.059,588,2.059,589,2.059,590,2.059,591,2.059,592,1.788,593,1.476,594,0.935,595,1.788,596,1.788,597,1.788,598,1.476,599,1.476,600,1.61,601,1.788,602,1.476,603,1.788,604,1.788,605,1.788,606,1.788,607,1.788,608,1.788,609,1.788,610,1.788,611,2.594,612,1.788,613,1.788,614,1.788,615,1.61,616,2.059,617,2.059,618,2.059,619,2.059,620,2.059,621,2.059,622,2.059,623,3.318,624,2.059,625,2.059,626,2.059,627,2.059,628,2.059,629,2.059,630,3.318,631,2.059,632,2.059,633,2.059,634,2.059,635,2.059,636,2.059,637,2.059,638,2.059,639,1.37,640,2.059,641,2.059,642,2.059,643,3.318,644,4.152,645,1.742,646,1.788,647,4.168,648,2.594,649,3.318,650,3.259,651,1.476,652,2.976,653,4.78,654,2.381,655,2.059,656,2.066,657,2.059,658,2.059,659,3.318,660,1.37,661,3.259,662,1.61,663,2.059,664,2.059,665,3.259,666,2.059,667,1.282,668,2.059,669,2.059,670,3.318,671,1.139,672,3.318,673,1.788,674,2.059,675,3.318,676,4.168,677,2.059,678,1.788,679,1.081,680,1.61,681,3.318,682,2.059,683,2.059,684,2.059,685,2.059,686,2.059,687,2.059,688,2.059,689,2.059,690,2.059,691,2.059,692,1.61,693,4.168,694,2.059,695,1.788,696,2.059,697,2.059,698,3.318,699,3.318,700,3.318,701,3.318,702,1.788,703,2.059,704,2.059,705,2.059,706,3.318,707,2.059,708,1.788,709,2.059,710,2.059,711,2.594,712,2.059,713,2.059,714,2.059,715,3.318,716,2.059,717,3.318,718,2.059,719,2.059,720,2.059,721,2.059,722,2.059,723,2.059,724,2.059,725,2.059,726,2.059,727,2.059,728,2.059,729,3.318,730,2.059,731,2.059,732,2.059,733,2.059,734,2.059]],["t/55",[21,1.181,25,0.026,26,0.044,27,0.026,28,0.026,43,0.033,44,0.026,45,0.037,46,0.044,47,1.268,49,0.117,50,0.117,51,0.044,139,0.558,140,0.87,164,1.226,195,0.905,213,2.215,248,1.723,253,1.503,259,0.836,320,1.371,327,3.498,330,3.498,343,2.56,374,1.226,521,3.638,528,3.498,529,3.498,665,3.813,735,4.454,736,4.112,737,4.236,738,4.236,739,4.236,740,4.877,741,4.856,742,4.877,743,6.21,744,4.877,745,4.877,746,4.877,747,4.877,748,4.236,749,4.877,750,6.833,751,4.454,752,4.236,753,4.236,754,4.236,755,4.236,756,4.236,757,4.236,758,4.236,759,4.236,760,3.498,761,4.236,762,4.877,763,4.236,764,4.877,765,4.236]],["t/57",[21,1.232,25,0.027,26,0.044,27,0.027,28,0.027,43,0.039,44,0.027,45,0.034,46,0.046,47,0.944,49,0.122,50,0.122,51,0.046,139,0.573,140,1.138,179,3.978,195,1.184,248,1.798,253,1.687,259,0.872,374,1.278,521,3.736,528,3.649,529,3.649,735,4.575,736,3.531,737,4.419,738,4.419,741,4.987,751,4.575,760,4.575,766,4.419,767,5.088,768,5.088,769,5.088,770,3.978,771,5.088,772,2.42,773,5.088,774,5.088,775,5.088,776,5.088,777,4.419,778,5.088,779,5.088,780,5.088,781,5.088,782,5.088,783,5.088,784,3.649,785,5.088,786,5.088]],["t/59",[4,2.78,21,1.291,25,0.021,26,0.045,27,0.021,28,0.021,39,5.296,43,0.038,44,0.021,45,0.037,46,0.035,47,0.99,49,0.093,50,0.093,51,0.035,73,1.532,139,0.59,140,0.952,164,1.34,191,3.956,195,0.99,200,3.031,213,2.423,253,1.291,259,0.914,327,4.94,330,4.373,374,0.974,518,4.17,521,3.847,528,2.78,529,2.78,540,1.844,654,2.423,735,4.94,736,3.375,741,3.031,751,3.825,760,3.825,761,4.632,765,3.366,770,4.17,787,5.333,788,5.333,789,5.333,790,2.853,791,5.333,792,3.876,793,3.876,794,6.098,795,5.333,796,5.333,797,5.333,798,5.333,799,3.876,800,3.876,801,3.876,802,3.876,803,3.876,804,3.876,805,3.876,806,3.876,807,3.876,808,3.876,809,3.876,810,5.333,811,3.366,812,3.876,813,4.632,814,3.876,815,3.876,816,3.876,817,3.876,818,3.876,819,3.876,820,3.876,821,3.876,822,3.876,823,3.876,824,3.876,825,3.876,826,3.876,827,3.876,828,3.876,829,3.876,830,3.876]],["t/61",[21,1.6,25,0.029,26,0.044,27,0.029,28,0.029,43,0.038,44,0.029,45,0.035,46,0.048,47,1,49,0.129,50,0.129,51,0.048,139,0.594,140,0.961,148,2.564,191,2.829,195,1,206,2.872,207,2.448,227,4.214,253,1.6,259,1.133,342,2.69,344,2.829,345,2.69,347,2.69,374,1.354,519,4.68,521,3.156,523,3.865,524,2.829,525,3.587,645,2.829,751,3.865,760,4.741,770,4.214,831,5.389,832,3.587,833,5.389,834,5.389,835,5.389]],["t/63",[17,1.821,25,0.022,26,0.045,27,0.022,28,0.022,43,0.04,44,0.022,45,0.03,46,0.038,49,0.101,50,0.101,51,0.038,73,1.414,138,0.926,152,0.448,163,1.541,164,1.054,179,3.278,183,1.704,203,2.201,210,1.77,248,1.481,249,1.904,259,0.965,301,2.321,302,2.79,303,1.744,310,2.093,313,2.201,326,1.605,329,3.278,339,2.79,351,3.114,353,1.77,399,1.371,462,3.02,532,3.641,537,3.641,563,1.994,656,2.61,667,2.61,736,2.321,772,1.994,790,1.821,836,4.193,837,4.193,838,3.641,839,2.321,840,5.893,841,4.193,842,4.193,843,4.193,844,4.193,845,4.193,846,2.808,847,4.193,848,4.193,849,4.193,850,4.193,851,2.456,852,4.193,853,3.641,854,1.744,855,4.193,856,4.193,857,4.193,858,6.349,859,4.193,860,4.193,861,4.193,862,3.641,863,4.193,864,4.193,865,4.193,866,4.193,867,4.193,868,4.193,869,3.007,870,3.007,871,3.278,872,3.278,873,4.399,874,5.626,875,2.61,876,2.321,877,3.641,878,4.193,879,1.904,880,4.193,881,3.114,882,4.193,883,4.193]],["t/65",[18,2.763,21,1.405,25,0.019,26,0.045,27,0.019,28,0.019,43,0.039,44,0.019,45,0.034,46,0.032,47,0.928,49,0.085,50,0.085,51,0.032,63,2.535,64,2.352,115,2.2,138,0.582,139,0.638,140,1.035,152,0.409,175,1.299,183,1.071,193,2.352,195,1.077,242,1.994,259,1.185,301,1.956,302,2.352,384,1.47,387,1.764,394,3.069,399,1.155,462,3.001,464,2.535,466,3.862,471,1.994,476,2.2,485,1.605,491,1.47,499,1.956,540,1.681,650,2.763,651,3.586,654,1.605,679,1.855,790,1.535,839,1.956,854,1.47,875,2.2,884,2.352,885,2.2,886,2.2,887,2.2,888,3.069,889,5.48,890,5,891,4.343,892,2.352,893,2.763,894,3.069,895,5.097,896,3.069,897,2.763,898,2.763,899,2.07,900,3.91,901,4.958,902,4.958,903,3.534,904,2.535,905,2.763,906,3.534,907,2.763,908,3.069,909,2.535,910,4.537,911,2.763,912,2.763,913,3.91,914,2.07,915,4.537,916,2.763,917,2.763,918,2.763,919,3.534,920,2.763,921,2.763,922,2.535,923,5.206,924,2.763,925,2.352,926,2.763,927,2.535,928,3.534,929,3.534,930,2.763,931,2.763,932,2.763,933,2.2,934,3.069,935,2.535,936,3.91,937,4.537,938,3.91,939,4.537]],["t/67",[17,3.103,21,1.158,25,0.026,26,0.045,27,0.026,28,0.026,43,0.038,44,0.026,45,0.038,46,0.043,47,0.888,49,0.115,50,0.115,51,0.043,67,2.552,139,0.641,140,0.853,148,2.276,152,0.337,173,2.173,174,2.173,175,1.759,176,1.449,183,1.449,195,0.888,206,2.665,217,2.276,246,3.22,253,1.485,259,1.161,324,3.184,326,1.831,341,2.511,342,3.062,343,2.511,344,2.511,345,2.388,346,4.083,347,2.388,348,3.431,374,1.202,667,2.978,876,2.648,940,2.511,941,4.155,942,3.431,943,3.74,944,3.74,945,3.184,946,3.184,947,4.155,948,3.184,949,4.155,950,4.155,951,4.155,952,4.155,953,3.74,954,3.74,955,4.155]],["t/69",[2,1.062,5,1.859,8,1.062,12,0.814,17,1.69,25,0.007,26,0.045,27,0.011,28,0.007,43,0.041,44,0.007,45,0.031,46,0.011,47,0.227,49,0.029,50,0.029,51,0.011,57,1.062,65,0.877,67,0.89,69,3.304,73,0.307,80,2.633,89,0.877,122,1.535,138,0.759,139,0.713,144,1.062,147,1.092,152,0.524,156,2.677,159,1.174,161,1.763,162,1.694,173,0.556,174,0.556,175,1.694,176,0.371,193,0.814,204,0.877,207,1.555,210,0.673,220,1.859,238,1.424,246,2.806,255,1.838,258,1.694,260,2.422,291,1.767,293,1.123,313,1.123,326,1.489,363,0.93,374,0.307,413,1.674,465,1.859,471,2.388,491,2.224,526,1.062,534,0.957,540,1.018,563,1.628,581,3.345,582,4.001,611,0.957,652,1.332,662,1.674,695,1.062,702,1.062,711,5.303,735,0.877,832,2.847,854,0.509,884,0.814,940,2.042,948,0.814,956,4.607,957,1.223,958,1.223,959,3.89,960,2.853,961,2.231,962,3.609,963,2.853,964,2.853,965,1.223,966,1.223,967,4.381,968,2.853,969,2.853,970,2.14,971,1.223,972,2.853,973,2.853,974,1.498,975,2.14,976,2.14,977,3.89,978,4.607,979,3.068,980,2.14,981,4.001,982,4.889,983,2.14,984,2.14,985,2.14,986,2.14,987,2.14,988,2.14,989,2.14,990,2.14,991,1.674,992,3.423,993,1.223,994,2.853,995,2.853,996,2.853,997,2.853,998,3.423,999,2.853,1000,2.853,1001,2.853,1002,1.223,1003,2.14,1004,2.14,1005,2.853,1006,1.062,1007,2.14,1008,1.223,1009,3.89,1010,1.062,1011,2.14,1012,1.223,1013,1.223,1014,1.223,1015,1.223,1016,1.223,1017,2.14,1018,1.223,1019,1.223,1020,1.223,1021,2.973,1022,1.223,1023,1.062,1024,0.957,1025,1.223,1026,2.853,1027,1.223,1028,1.223,1029,2.853,1030,2.973,1031,4.889,1032,1.223,1033,5.346,1034,1.223,1035,1.223,1036,1.223,1037,1.859,1038,2.231,1039,1.223,1040,2.853,1041,1.223,1042,1.062,1043,1.223,1044,1.223,1045,1.062,1046,2.14,1047,1.223,1048,1.223,1049,1.223,1050,1.223,1051,1.223,1052,7.041,1053,1.223,1054,1.223,1055,1.223,1056,1.062,1057,1.223,1058,0.877,1059,0.957,1060,1.223,1061,1.223,1062,1.223,1063,2.677,1064,1.223,1065,1.223,1066,1.223,1067,1.223,1068,2.14,1069,2.14,1070,1.223,1071,0.877,1072,1.223,1073,1.223,1074,1.223,1075,1.223,1076,1.223,1077,1.535,1078,1.223,1079,1.223,1080,2.14,1081,1.223,1082,1.223,1083,1.223,1084,1.223,1085,1.223,1086,1.223,1087,1.223,1088,0.814,1089,1.223,1090,1.223,1091,1.223,1092,1.223,1093,1.223,1094,1.223,1095,1.223,1096,1.223,1097,1.223,1098,1.223,1099,1.223,1100,1.223,1101,1.223,1102,1.223,1103,1.223,1104,1.223,1105,1.062,1106,1.062,1107,1.223,1108,1.223,1109,1.223,1110,1.223,1111,1.223,1112,1.223,1113,1.223,1114,1.223,1115,1.223,1116,1.223,1117,1.223,1118,1.223,1119,1.062,1120,1.062,1121,1.223,1122,1.223,1123,1.223,1124,3.89,1125,3.89,1126,4.278,1127,4.278,1128,3.423,1129,3.423,1130,1.223,1131,3.423,1132,1.223,1133,3.89,1134,2.853,1135,1.223]],["t/71",[25,0.028,26,0.045,27,0.028,28,0.028,43,0.038,44,0.028,45,0.035,46,0.047,47,0.979,49,0.127,50,0.127,51,0.047,138,1.074,152,0.46,173,2.396,174,2.396,175,1.939,210,1.66,259,0.904,302,3.511,374,1.326,399,1.725,464,4.679,487,2.604,909,3.784,1136,5.275,1137,4.125,1138,5.275,1139,5.275,1140,5.275,1141,5.275,1142,5.666,1143,6.524,1144,5.275,1145,6.524,1146,5.275,1147,5.275,1148,5.275,1149,5.275,1150,5.275]],["t/73",[21,1.211,25,0.019,26,0.045,27,0.019,28,0.019,43,0.038,44,0.019,45,0.031,46,0.032,49,0.085,50,0.085,51,0.032,63,2.535,64,3.328,115,2.2,138,0.582,139,0.638,140,0.892,152,0.445,175,1.299,183,1.071,193,3.328,195,0.928,207,2.271,242,2.315,253,0.856,259,1.142,301,1.956,313,1.855,384,1.47,387,1.764,399,1.155,462,3.381,466,4.199,471,1.994,485,1.605,491,2.08,499,1.956,524,1.855,563,1.681,650,2.763,654,1.605,679,1.855,790,1.535,838,3.069,839,1.956,840,5.04,854,1.47,877,3.069,889,5.04,891,4.343,892,2.352,893,2.763,894,3.069,895,5.097,897,2.763,898,2.763,899,2.07,900,3.91,901,4.958,902,4.958,907,2.763,908,3.069,909,2.535,910,4.537,911,3.91,912,2.763,913,3.91,914,2.07,915,4.537,916,2.763,917,2.763,918,2.763,920,2.763,921,2.763,922,2.535,923,5.206,924,2.763,925,2.352,926,2.763,927,2.535,930,2.763,931,2.763,932,2.763,933,2.2,934,3.069,935,2.535,936,3.91,937,4.537,938,3.91,939,4.537,962,1.605,1058,2.535,1151,3.534,1152,3.534,1153,3.534,1154,3.534,1155,3.069,1156,3.069,1157,3.534,1158,3.534,1159,3.534,1160,3.534,1161,3.534,1162,3.534]],["t/75",[21,1.216,25,0.027,26,0.044,27,0.027,28,0.027,43,0.034,44,0.027,45,0.027,46,0.045,47,0.932,49,0.121,50,0.121,51,0.045,73,1.262,139,0.568,140,0.896,164,1.262,195,0.932,203,3.636,213,2.282,217,2.39,242,2.004,374,1.262,460,3.928,491,2.09,499,2.781,639,3.344,772,2.39,870,4.969,873,5.686,905,3.928,1163,5.024,1164,4.363,1165,5.024,1166,3.603,1167,3.928,1168,5.024,1169,4.363,1170,4.363,1171,5.024,1172,5.024,1173,4.363,1174,4.363,1175,3.603,1176,5.024,1177,5.024,1178,3.603,1179,5.024,1180,4.363,1181,5.024,1182,5.024,1183,5.024,1184,3.344,1185,5.024,1186,5.024,1187,3.603,1188,5.024,1189,6.328,1190,5.024]],["t/77",[21,1.616,25,0.029,26,0.044,27,0.029,28,0.029,43,0.036,44,0.029,45,0.036,46,0.049,49,0.131,50,0.131,51,0.049,139,0.6,140,0.977,148,2.606,152,0.386,191,2.875,195,1.016,206,2.9,207,2.488,259,0.939,301,3.032,342,2.734,344,2.875,345,2.734,347,2.734,399,1.791,523,3.928,524,2.875,525,3.646,854,2.279,875,3.41,876,3.032,879,2.488,1167,4.283,1191,4.757,1192,2.875,1193,4.757,1194,4.757,1195,4.757,1196,4.283]],["t/79",[21,1.372,25,0.018,26,0.045,27,0.018,28,0.018,43,0.038,44,0.018,45,0.033,46,0.03,49,0.081,50,0.081,51,0.03,60,2.427,63,2.427,64,2.253,71,2.84,115,2.107,138,0.933,139,0.612,140,0.865,152,0.437,175,1.244,183,1.025,193,3.227,195,0.9,207,1.537,242,1.35,253,0.819,259,1.123,301,1.873,320,1.84,387,2.42,399,1.106,462,3.415,466,3.227,471,1.934,485,1.537,491,2.017,499,1.873,500,2.427,524,1.776,654,1.537,679,1.776,839,1.873,879,1.537,895,4.064,897,2.646,898,2.646,899,1.982,900,2.646,901,4.888,902,4.888,910,4.43,911,2.646,912,2.646,913,3.791,914,1.982,915,4.43,916,2.646,917,2.646,918,2.646,921,2.646,922,3.478,923,5.121,924,2.646,925,2.253,926,2.646,927,2.427,930,2.646,931,2.646,932,2.646,933,2.107,936,3.791,937,4.43,938,3.791,939,4.43,1105,4.211,1155,2.94,1156,2.94,1197,4.064,1198,3.385,1199,2.94,1200,2.646,1201,3.385,1202,5.919,1203,4.849,1204,3.385,1205,3.385,1206,3.385,1207,3.385,1208,3.385,1209,3.385,1210,3.385,1211,3.385,1212,3.385,1213,3.385,1214,2.427,1215,4.849,1216,3.385,1217,3.385,1218,2.94,1219,2.94,1220,4.921,1221,3.385,1222,3.385,1223,3.385,1224,3.385]],["t/81",[25,0.02,26,0.045,27,0.02,28,0.02,43,0.041,44,0.02,45,0.028,46,0.034,47,1.21,49,0.091,50,0.091,51,0.034,67,1.585,73,1.638,80,2.507,139,0.473,140,0.68,152,0.269,159,0.94,164,0.957,195,0.707,242,1.52,248,2.304,249,2.394,259,0.904,283,2.536,285,2.732,287,2.732,291,2.394,303,1.585,320,1.481,359,2.109,374,0.957,387,1.901,400,2.732,471,2.102,487,1.401,536,2.231,772,1.812,851,2.231,854,1.585,885,2.372,886,2.372,887,2.372,1175,2.732,1192,2,1225,3.81,1226,3.81,1227,5.27,1228,3.81,1229,5.27,1230,3.81,1231,3.309,1232,3.81,1233,3.81,1234,3.81,1235,3.309,1236,5.248,1237,3.309,1238,4.577,1239,3.309,1240,5.248,1241,3.309,1242,3.309,1243,3.309,1244,3.309,1245,4.121,1246,3.309,1247,3.309,1248,3.309,1249,3.309,1250,3.309,1251,3.309,1252,4.339,1253,3.309,1254,2.979,1255,3.309,1256,3.309,1257,2.979,1258,4.577,1259,2.979,1260,2.979,1261,4.577,1262,5.248,1263,2.979,1264,4.577,1265,2.979,1266,4.577,1267,2.979,1268,3.309,1269,3.309,1270,3.309,1271,3.309,1272,3.309,1273,3.309,1274,3.309,1275,3.309,1276,5.663,1277,5.945,1278,2.979,1279,5.248]],["t/83",[25,0.02,26,0.045,27,0.02,28,0.02,43,0.039,44,0.02,45,0.027,46,0.033,47,1.098,49,0.088,50,0.088,51,0.033,67,1.524,71,2.146,73,1.611,80,2.44,139,0.461,140,0.654,152,0.258,159,0.915,164,0.921,195,0.68,203,2.692,213,2.33,217,2.44,242,1.461,248,2.091,249,2.33,259,0.879,283,2.438,285,2.627,287,2.627,291,2.33,303,1.524,320,1.441,387,1.828,400,2.627,471,2.046,487,1.347,536,2.146,772,1.743,851,2.146,854,1.524,870,3.678,885,2.281,886,2.281,887,2.281,1106,3.182,1184,4.491,1192,1.923,1235,3.182,1236,5.139,1237,3.182,1238,4.454,1239,3.182,1240,5.139,1241,3.182,1242,3.182,1243,3.182,1244,3.182,1245,4.01,1246,3.182,1247,3.182,1248,3.182,1249,3.182,1250,3.182,1251,3.182,1252,4.491,1253,3.182,1254,2.864,1256,3.182,1257,2.864,1258,4.454,1259,2.864,1260,2.864,1261,5.568,1262,6.236,1263,2.864,1264,5.139,1265,2.864,1266,5.139,1267,2.864,1268,3.182,1269,3.182,1270,3.182,1271,3.182,1272,3.182,1273,3.182,1274,3.182,1275,3.182,1276,5.568,1277,5.861,1278,2.864,1279,5.139,1280,3.663,1281,3.663,1282,3.663,1283,3.663,1284,3.663,1285,3.663,1286,3.663,1287,3.663,1288,3.663]],["t/85",[25,0.021,26,0.045,27,0.021,28,0.021,43,0.04,44,0.021,45,0.021,46,0.035,47,0.718,51,0.035,73,0.972,138,0.637,139,0.478,148,1.84,152,0.273,163,1.422,164,1.531,165,1.84,166,1.84,168,3.12,175,1.422,202,2.658,203,2.031,238,2.575,248,1.367,249,2.419,255,2.125,256,2.266,282,3.025,309,3.025,320,1.087,351,3.372,374,0.972,382,3.36,411,3.36,517,3.36,540,1.84,581,3.025,594,2.419,639,2.575,652,3.316,679,2.031,922,4.707,1088,2.575,1184,4.054,1255,3.36,1289,6.563,1290,5.326,1291,3.869,1292,2.575,1293,1.931,1294,3.36,1295,4.763,1296,4.165,1297,3.869,1298,3.869,1299,3.869,1300,5.326,1301,5.326,1302,3.36,1303,3.36,1304,3.36,1305,5.326,1306,3.36,1307,3.869,1308,2.575,1309,3.869,1310,3.869,1311,5.326,1312,3.869,1313,5.326,1314,3.869,1315,3.869,1316,3.36,1317,3.545,1318,3.869,1319,3.869,1320,4.054,1321,5.326,1322,3.869,1323,3.869,1324,2.534,1325,3.869,1326,2.775,1327,3.36,1328,3.869,1329,3.869,1330,3.869,1331,6.563,1332,3.869,1333,5.326,1334,3.869,1335,5.326,1336,3.869,1337,3.869,1338,3.869,1339,3.869,1340,3.869,1341,5.326,1342,3.869,1343,3.869,1344,3.869,1345,3.869,1346,3.869,1347,6.563,1348,3.869,1349,3.869,1350,3.869]],["t/87",[21,1.098,25,0.016,26,0.045,27,0.016,28,0.016,43,0.04,44,0.016,45,0.041,47,0.573,51,0.028,69,3.856,73,1.351,138,0.747,152,0.418,164,1.489,202,2.264,207,1.402,213,2.692,237,2.681,248,1.091,249,1.402,255,1.809,256,2.657,258,2.179,259,0.529,281,2.681,283,3.944,313,1.62,341,1.62,359,3.495,360,2.055,363,1.341,374,0.776,485,1.402,487,1.668,534,3.547,536,3.471,568,4.251,600,2.414,656,1.922,869,2.214,873,4.937,967,3.856,974,2.381,981,3.939,1059,2.414,1231,2.681,1245,3.547,1252,3.579,1263,4.634,1265,4.634,1308,3.944,1317,3.019,1324,3.14,1351,3.087,1352,3.087,1353,3.087,1354,3.087,1355,6.601,1356,5.927,1357,3.087,1358,3.087,1359,3.087,1360,6.314,1361,6.314,1362,5.377,1363,6.601,1364,3.087,1365,3.087,1366,3.087,1367,4.536,1368,5.147,1369,4.536,1370,5.927,1371,4.536,1372,3.547,1373,3.939,1374,3.087,1375,3.087,1376,6.601,1377,3.087,1378,3.087,1379,3.087,1380,5.377,1381,3.087,1382,4.536,1383,3.087,1384,3.087,1385,3.087,1386,3.087,1387,2.681,1388,3.087,1389,3.087,1390,3.087,1391,6.601,1392,3.087,1393,5.377,1394,3.087,1395,4.536,1396,3.087,1397,2.681,1398,3.087,1399,3.087,1400,3.087,1401,3.087,1402,3.939,1403,3.087,1404,3.087,1405,3.087,1406,3.087,1407,3.087,1408,5.927,1409,3.939,1410,3.087,1411,3.087,1412,3.087,1413,3.087,1414,2.681,1415,3.087,1416,3.939,1417,4.536,1418,3.087,1419,3.087,1420,2.681,1421,3.939,1422,3.087,1423,3.087,1424,2.681,1425,5.377,1426,3.087,1427,3.087]],["t/89",[21,0.972,25,0.021,26,0.045,27,0.021,28,0.021,43,0.033,44,0.021,45,0.029,46,0.036,47,0.745,49,0.096,50,0.096,51,0.036,73,1.675,140,0.717,148,1.91,152,0.283,159,0.717,161,1.537,162,2.009,163,1.476,164,1.373,165,1.91,166,1.91,195,0.745,203,3.26,206,1.745,207,1.824,210,1.264,213,2.482,248,1.419,249,1.824,253,1.323,259,0.937,269,3.14,293,3.26,301,2.223,302,2.673,303,1.671,310,2.004,324,2.673,342,3.481,343,2.108,344,2.108,345,2.004,347,2.004,374,1.009,487,1.476,491,1.671,499,2.223,524,2.108,525,2.673,651,3.919,679,2.108,739,3.488,839,2.223,851,2.352,854,1.671,870,4.455,888,3.488,905,4.273,909,2.88,1164,3.488,1166,2.88,1174,3.488,1175,2.88,1184,4.134,1192,2.108,1252,2.673,1278,3.14,1326,2.88,1428,4.016,1429,4.016,1430,4.016,1431,4.016,1432,4.016,1433,4.016,1434,4.016,1435,4.016,1436,4.016,1437,4.016,1438,3.488,1439,4.016,1440,2.673,1441,3.488,1442,4.016,1443,3.488,1444,4.016,1445,4.746,1446,4.016,1447,6.973,1448,4.016,1449,5.394,1450,4.016,1451,4.016,1452,4.016,1453,4.016,1454,3.14,1455,4.016,1456,4.016,1457,4.016,1458,3.14,1459,4.016,1460,4.016,1461,4.016,1462,3.14,1463,5.464,1464,4.016,1465,4.016]],["t/91",[25,0.028,26,0.044,27,0.028,28,0.028,43,0.035,44,0.028,45,0.028,46,0.047,47,0.971,51,0.047,58,4.092,139,0.583,140,0.934,152,0.369,159,0.934,163,1.924,164,1.315,165,2.49,166,2.49,213,2.949,252,4.594,255,2.088,256,3.066,257,4.092,259,0.897,270,2.612,303,2.178,311,3.754,312,3.754,320,1.471,374,1.315,540,2.49,568,3.754,639,3.483,671,2.897,679,2.747,851,3.066,1200,4.092,1293,2.612,1295,4.092,1317,3.483,1326,3.754,1466,6.492,1467,5.234,1468,4.042,1469,4.546,1470,5.234,1471,5.234,1472,3.483,1473,4.092,1474,4.546,1475,4.546,1476,5.234]],["t/93",[17,1.818,18,3.271,25,0.022,26,0.045,27,0.022,28,0.022,43,0.038,44,0.022,45,0.038,46,0.038,47,1.042,49,0.1,50,0.1,51,0.038,71,2.451,100,2.785,138,0.689,140,1.002,163,1.538,164,1.051,165,1.99,166,1.99,168,2.451,195,1.042,203,2.949,210,1.316,252,2.605,259,0.717,326,1.601,456,3.271,654,1.9,660,3.739,854,2.337,885,2.605,886,2.605,887,2.605,892,2.785,904,3.001,940,2.196,1058,3.001,1324,2.672,1462,3.271,1477,4.184,1478,4.184,1479,3.634,1480,3.271,1481,3.634,1482,3.08,1483,4.184,1484,4.184,1485,4.184,1486,4.184,1487,1.9,1488,2.881,1489,4.184,1490,4.879,1491,3.634,1492,4.879,1493,5.618,1494,3.072,1495,3.634,1496,5.618,1497,4.184,1498,2.441,1499,1.9,1500,2.755,1501,4.879,1502,5.508,1503,4.184,1504,1.818,1505,1.818,1506,5.618,1507,4.184,1508,5.618,1509,4.184,1510,4.184,1511,2.441,1512,3.634,1513,2.755,1514,1.601,1515,4.184,1516,4.184,1517,4.184,1518,4.184,1519,4.184,1520,4.184,1521,4.184,1522,4.184,1523,4.184,1524,3.271,1525,3.634,1526,4.184]],["t/95",[25,0.019,26,0.045,27,0.019,28,0.019,43,0.04,44,0.019,45,0.034,46,0.032,47,0.666,51,0.032,64,2.39,73,1.471,139,0.655,140,0.641,152,0.413,159,0.902,162,1.32,163,1.859,164,1.271,165,1.708,166,1.708,173,1.631,175,1.32,195,0.666,206,1.56,210,1.13,213,2.297,242,1.432,248,1.787,249,2.297,255,2.017,256,2.103,257,2.808,283,2.39,285,2.575,287,2.575,289,2.808,290,3.119,303,2.104,310,1.792,320,1.421,342,2.922,344,1.885,345,1.792,346,2.39,347,1.792,361,1.792,362,2.808,363,1.56,374,0.902,384,1.494,429,3.366,476,2.236,483,3.119,491,2.435,499,3.24,563,2.785,583,3.119,594,1.631,671,1.988,766,4.392,784,2.575,813,3.119,1120,3.119,1166,2.575,1178,2.575,1292,2.39,1293,1.792,1294,4.392,1304,3.119,1316,3.119,1438,3.119,1443,4.392,1445,4.392,1449,4.392,1472,2.39,1473,2.808,1474,3.119,1527,5.854,1528,6.354,1529,5.854,1530,6.949,1531,2.808,1532,3.591,1533,3.591,1534,3.591,1535,2.575,1536,6.436,1537,3.591,1538,3.591,1539,5.854,1540,3.591,1541,3.591,1542,3.591,1543,3.591,1544,3.591,1545,3.591,1546,3.591,1547,3.591,1548,3.119,1549,2.39,1550,3.591,1551,3.591,1552,3.591,1553,3.591,1554,3.591,1555,5.057,1556,3.119,1557,3.119,1558,3.591,1559,3.591,1560,3.591,1561,3.591,1562,3.591,1563,3.591,1564,3.591,1565,5.057,1566,3.591,1567,3.591,1568,3.591,1569,3.591,1570,3.591,1571,3.591,1572,3.591]],["t/97",[12,2.888,23,1.81,25,0.016,26,0.045,27,0.016,28,0.016,29,1.81,43,0.028,44,0.016,45,0.028,46,0.026,47,0.54,49,0.07,50,0.07,51,0.026,73,1.304,80,2.064,89,2.085,105,2.888,138,0.479,139,0.553,147,1.113,152,0.472,159,1.099,173,1.321,174,1.321,175,1.069,176,0.881,210,1.365,217,1.383,246,1.526,248,1.027,253,0.704,271,2.402,291,1.321,293,1.526,303,1.21,313,1.526,363,1.263,374,0.731,406,4.059,429,2.888,443,2.274,445,2.274,453,2.274,481,1.935,485,1.971,486,2.274,493,3.393,498,2.525,521,1.703,540,1.383,548,1.81,594,1.321,652,2.701,654,1.971,660,4.099,671,1.609,832,2.888,893,3.393,974,1.526,991,3.393,1024,2.274,1059,2.274,1077,2.085,1137,2.274,1178,3.723,1292,1.935,1308,1.935,1440,1.935,1454,2.274,1472,1.935,1481,2.525,1482,2.358,1490,4.509,1494,2.255,1498,2.806,1499,1.321,1500,2.806,1501,2.525,1504,1.263,1505,1.263,1511,1.263,1513,1.263,1514,1.113,1524,2.274,1573,2.908,1574,2.908,1575,2.908,1576,2.525,1577,2.908,1578,2.908,1579,2.525,1580,2.525,1581,4.339,1582,2.908,1583,2.085,1584,2.274,1585,2.908,1586,2.908,1587,2.908,1588,2.908,1589,2.525,1590,5.191,1591,2.908,1592,2.908,1593,2.525,1594,2.908,1595,2.525,1596,2.525,1597,2.525,1598,2.278,1599,2.908,1600,4.059,1601,2.525,1602,2.525,1603,2.525,1604,2.525,1605,2.525,1606,3.769,1607,2.525,1608,2.525,1609,2.274,1610,2.274,1611,2.525,1612,2.525,1613,2.908,1614,2.908,1615,2.908,1616,2.908,1617,2.525,1618,2.525,1619,2.525,1620,4.746,1621,2.525,1622,3.769,1623,2.525,1624,3.769,1625,3.393,1626,2.525,1627,4.999,1628,2.525,1629,2.525,1630,2.525,1631,2.525,1632,2.525,1633,4.509,1634,2.525,1635,2.525,1636,4.059,1637,2.908,1638,2.908,1639,4.509,1640,2.525,1641,2.525,1642,2.525,1643,2.525,1644,4.509,1645,4.059,1646,2.525,1647,3.393,1648,2.525,1649,2.525,1650,4.509,1651,2.525,1652,2.525,1653,2.525,1654,2.525,1655,2.525,1656,3.769,1657,2.525,1658,2.525,1659,2.525,1660,2.525,1661,2.525,1662,2.525,1663,3.769,1664,2.525,1665,2.525,1666,2.525,1667,2.525,1668,2.525,1669,2.525,1670,2.525,1671,2.908,1672,4.339,1673,2.525,1674,2.908,1675,2.908,1676,2.274,1677,2.908,1678,2.908,1679,2.908,1680,2.525,1681,2.908]],["t/99",[25,0.026,26,0.045,27,0.026,28,0.026,43,0.033,44,0.026,45,0.036,46,0.044,47,1.151,49,0.117,50,0.117,51,0.044,73,1.223,140,0.868,174,2.21,175,1.789,176,1.474,195,0.903,217,2.314,242,1.941,246,2.554,248,1.719,259,1.063,329,3.804,339,3.238,660,5.134,736,3.432,811,4.225,854,2.024,885,3.029,886,3.029,887,3.029,1071,3.489,1454,3.804,1480,3.804,1514,2.373,1524,3.804,1536,4.225,1556,4.225,1595,5.385,1682,4.865,1683,4.865,1684,4.865,1685,4.865,1686,4.865,1687,4.865,1688,4.865,1689,4.865,1690,4.865,1691,4.865,1692,4.865,1693,4.865,1694,4.865,1695,4.865,1696,3.489,1697,3.804,1698,3.804,1699,6.201,1700,4.865,1701,4.865,1702,3.804]],["t/101",[25,0.027,26,0.045,27,0.027,28,0.027,43,0.042,44,0.027,45,0.037,46,0.045,49,0.119,50,0.119,51,0.045,138,0.817,139,0.564,140,0.885,152,0.35,195,1.278,384,2.612,399,1.622,557,5.453,846,3.134,881,2.746,1324,2.987,1703,3.302,1704,5.386,1705,4.961,1706,4.309,1707,4.309,1708,3.879,1709,4.961,1710,4.961,1711,4.961,1712,4.961,1713,4.961,1714,4.961,1715,4.961,1716,4.961,1717,4.961,1718,4.961,1719,4.961,1720,6.278,1721,6.278,1722,4.961,1723,4.961,1724,3.558,1725,6.278,1726,3.302,1727,6.278,1728,4.961,1729,4.961]],["t/103",[4,1.631,13,3.193,24,1.631,25,0.019,26,0.045,27,0.012,28,0.012,43,0.037,44,0.012,45,0.037,46,0.02,47,0.422,51,0.02,69,1.631,71,1.332,80,1.709,138,0.907,139,0.4,140,0.406,148,1.082,152,0.509,159,0.902,164,1.119,168,1.332,191,2.655,195,0.422,203,1.193,204,1.631,206,0.988,217,1.082,242,1.433,248,1.946,255,1.433,256,1.332,260,1.415,269,1.778,270,1.135,284,1.975,286,1.975,289,2.808,293,1.885,294,4.784,303,2.104,310,1.793,311,1.631,312,1.631,320,0.639,326,0.87,353,1.401,361,1.793,362,2.808,363,1.56,374,0.571,439,3.481,451,4.784,460,1.778,467,1.975,469,3.867,476,1.415,485,1.033,489,1.975,494,4.393,500,1.631,538,1.975,540,1.082,568,1.631,594,1.632,656,1.415,679,1.193,708,1.975,784,1.631,839,1.258,851,2.104,869,2.576,876,1.258,904,2.576,925,1.513,927,3.193,948,2.963,954,2.808,1088,2.391,1119,1.975,1173,1.975,1175,3.628,1184,3.366,1200,1.778,1214,1.631,1292,3.366,1293,1.135,1295,1.778,1296,1.778,1302,1.975,1303,1.975,1324,1.082,1327,1.975,1440,1.513,1468,1.415,1473,1.778,1475,4.393,1548,3.12,1557,1.975,1584,4.969,1625,2.808,1697,1.778,1698,2.808,1730,1.975,1731,1.975,1732,2.274,1733,3.592,1734,4.452,1735,2.274,1736,4.452,1737,2.274,1738,4.452,1739,2.274,1740,6.131,1741,2.274,1742,2.274,1743,2.274,1744,2.274,1745,1.975,1746,2.274,1747,2.274,1748,2.274,1749,2.274,1750,2.274,1751,2.274,1752,2.274,1753,2.274,1754,3.12,1755,1.975,1756,2.274,1757,2.274,1758,2.274,1759,1.975,1760,2.274,1761,1.975,1762,1.975,1763,2.274,1764,3.592,1765,2.274,1766,2.274,1767,2.274,1768,2.274,1769,2.274,1770,2.274,1771,3.592,1772,2.274,1773,2.274,1774,3.592,1775,2.274,1776,2.274,1777,2.274,1778,2.274,1779,4.452,1780,2.274,1781,2.274,1782,2.274,1783,2.274,1784,2.274,1785,2.274,1786,2.274,1787,2.274,1788,2.274,1789,5.058,1790,2.274,1791,2.274,1792,2.274,1793,2.274,1794,3.481,1795,2.274,1796,1.975,1797,1.975,1798,2.274,1799,2.274,1800,2.274,1801,2.274,1802,2.274,1803,2.274,1804,2.274,1805,3.592,1806,2.274,1807,2.274,1808,2.274,1809,2.274,1810,2.274,1811,2.274,1812,2.274,1813,2.274,1814,2.274,1815,2.274,1816,2.274,1817,2.274,1818,1.631,1819,2.274,1820,3.592,1821,2.274,1822,2.274,1823,2.274,1824,2.274,1825,3.592,1826,2.274,1827,2.274,1828,3.592,1829,3.592,1830,2.274,1831,2.274,1832,3.592,1833,2.274,1834,2.274,1835,2.274,1836,2.274,1837,2.274,1838,2.274,1839,2.274,1840,2.274,1841,2.274,1842,2.274,1843,2.274,1844,2.274,1845,2.274,1846,2.274,1847,2.274,1848,2.274,1849,2.274,1850,2.274,1851,2.274,1852,1.975,1853,2.274,1854,2.274,1855,2.274,1856,2.274,1857,2.274,1858,3.592,1859,2.274,1860,2.274,1861,2.274,1862,2.274,1863,2.274,1864,2.274,1865,2.274,1866,4.452,1867,4.784,1868,2.274,1869,3.592,1870,2.274,1871,2.274,1872,2.274,1873,2.274,1874,2.274,1875,2.274,1876,2.274,1877,2.274,1878,2.274,1879,2.274,1880,2.274,1881,2.274,1882,2.274,1883,2.274,1884,1.975,1885,2.274,1886,1.975,1887,2.274,1888,1.975,1889,2.274,1890,2.274,1891,2.274,1892,2.274,1893,2.274,1894,2.274,1895,2.274,1896,2.274,1897,2.274,1898,2.274,1899,2.274,1900,1.631,1901,2.274]],["t/105",[17,1.583,25,0.019,26,0.045,27,0.019,28,0.019,43,0.041,44,0.019,45,0.036,46,0.033,49,0.087,50,0.087,51,0.033,60,2.613,73,0.916,100,2.425,138,0.6,139,0.574,140,0.911,149,3.164,152,0.416,159,0.65,163,1.339,164,0.916,183,1.104,195,0.948,282,2.849,291,1.655,320,1.024,326,1.395,341,1.912,384,1.516,399,1.191,462,3.203,471,2.038,846,2.55,881,2.017,899,2.134,914,2.134,925,2.425,933,2.268,935,2.613,940,1.912,1202,4.437,1214,2.613,1218,3.164,1219,3.164,1480,2.849,1525,3.164,1703,2.425,1704,3.995,1706,3.164,1707,3.164,1886,4.437,1902,6.734,1903,5.109,1904,3.643,1905,3.643,1906,3.643,1907,5.9,1908,5.9,1909,5.109,1910,6.981,1911,6.395,1912,6.981,1913,6.395,1914,3.643,1915,3.643,1916,3.643,1917,3.643,1918,3.164,1919,3.643,1920,4.437,1921,3.164,1922,3.164,1923,3.164,1924,3.164,1925,3.643,1926,3.643,1927,3.643,1928,3.643,1929,5.109,1930,3.643,1931,3.643,1932,2.849,1933,3.643,1934,3.643,1935,5.109,1936,3.643,1937,3.643,1938,3.643,1939,3.643,1940,3.643,1941,3.643,1942,3.643,1943,3.643,1944,3.643,1945,3.643,1946,3.643,1947,5.109,1948,5.109]],["t/107",[10,3.128,17,1.738,25,0.021,26,0.045,27,0.021,28,0.021,43,0.041,44,0.021,45,0.036,46,0.036,49,0.096,50,0.096,51,0.036,139,0.645,140,1.106,147,2.086,152,0.282,159,0.972,163,1.471,164,1.005,176,1.212,183,1.878,195,1.011,293,2.099,320,1.124,326,1.531,341,2.099,361,1.996,363,1.738,366,3.128,487,1.471,563,1.903,593,2.869,594,1.817,598,2.869,599,2.869,660,4.43,846,2.72,871,3.128,872,3.128,879,1.817,881,3.855,884,2.662,940,2.099,945,2.662,946,2.662,961,3.128,1320,2.662,1479,3.474,1680,4.733,1702,4.261,1703,2.662,1726,4.125,1762,3.474,1900,2.869,1949,3.474,1950,3.474,1951,3.474,1952,4,1953,3.474,1954,3.474,1955,3.474,1956,3.474,1957,3.474,1958,3.474,1959,4,1960,3.474,1961,3.474,1962,3.474,1963,4,1964,3.474,1965,3.474,1966,3.474,1967,4,1968,5.78,1969,3.474,1970,3.474,1971,3.474,1972,3.474,1973,3.474,1974,3.474,1975,3.474,1976,3.128,1977,3.474,1978,3.474,1979,3.474,1980,4,1981,4,1982,4,1983,4,1984,4,1985,4,1986,4]],["t/109",[24,2.566,25,0.019,26,0.045,27,0.019,28,0.019,43,0.031,44,0.027,45,0.031,46,0.032,49,0.086,50,0.086,51,0.032,138,1.236,139,0.453,152,0.356,156,3.944,159,1.193,163,1.315,164,0.899,165,1.702,166,1.702,202,2.518,210,1.587,242,2.012,249,1.625,252,2.228,255,2.012,258,2.148,259,0.614,260,3.14,313,1.878,320,1.006,340,3.108,353,1.838,359,2.792,363,2.191,384,3.122,399,1.17,462,3.464,466,2.381,512,2.798,656,4.164,846,2.916,862,5.81,869,2.566,875,2.228,879,2.291,881,3.703,914,2.096,1038,2.798,1063,2.798,1293,1.786,1324,2.4,1372,4.961,1397,3.108,1531,2.798,1535,4.798,1726,4.452,1987,3.108,1988,4.381,1989,3.108,1990,4.568,1991,3.108,1992,4.381,1993,3.108,1994,3.944,1995,4.381,1996,4.381,1997,5.074,1998,3.578,1999,2.798,2000,3.578,2001,3.578,2002,3.578,2003,2.798,2004,3.578,2005,3.108,2006,3.578,2007,3.578,2008,3.578,2009,3.108,2010,3.578,2011,3.108,2012,3.108,2013,3.108,2014,3.578,2015,3.578,2016,3.578,2017,3.578,2018,3.578,2019,3.578,2020,3.108,2021,3.108,2022,3.108,2023,3.108,2024,3.108,2025,3.578,2026,3.578,2027,3.578,2028,3.578,2029,3.108,2030,3.578,2031,3.578,2032,3.108,2033,4.381,2034,4.381,2035,3.578,2036,3.108]],["t/111",[24,2.691,25,0.028,26,0.043,27,0.02,28,0.02,43,0.032,44,0.02,45,0.028,46,0.034,49,0.09,50,0.09,51,0.034,67,1.561,138,1.233,139,0.611,147,1.436,159,1.424,242,1.497,252,4.238,255,1.497,258,2.815,260,4.238,311,2.691,313,3.573,320,1.055,351,2.077,359,3.768,439,4.687,563,1.785,615,2.934,656,2.336,777,3.259,1010,3.259,1037,3.259,1038,5.323,1088,2.498,1192,1.97,1293,1.873,1308,2.498,1535,5.184,1730,3.259,1731,3.259,1987,3.259,1988,4.53,1989,3.259,1990,2.934,1991,3.259,1992,3.259,1993,3.259,1995,3.259,1996,3.259,1997,6.802,2003,4.687,2009,6.277,2011,3.259,2012,5.626,2013,4.53,2020,3.259,2037,5.215,2038,5.215,2039,5.994,2040,3.753,2041,5.215,2042,5.215,2043,3.753,2044,5.215,2045,3.753,2046,3.753,2047,3.753,2048,3.753,2049,3.753,2050,3.753,2051,3.753,2052,3.753,2053,3.753,2054,3.753,2055,5.215,2056,3.753,2057,3.753,2058,3.753,2059,3.753,2060,5.215,2061,3.753,2062,3.753,2063,3.753,2064,3.753,2065,3.753,2066,2.934,2067,3.753,2068,3.753,2069,3.753,2070,3.753,2071,3.259,2072,3.753,2073,3.753,2074,3.753,2075,3.753,2076,3.753,2077,3.753]],["t/147",[10,2.918,17,1.621,25,0.02,26,0.045,27,0.02,28,0.02,43,0.04,44,0.02,45,0.035,46,0.033,49,0.09,50,0.09,51,0.033,138,1.064,139,0.632,140,1.153,152,0.263,159,0.927,163,1.372,164,0.938,183,1.81,195,1.109,248,1.318,255,1.488,259,0.64,293,1.959,320,1.049,326,1.428,361,1.862,363,1.621,366,2.918,384,3.062,399,1.22,487,1.372,512,2.918,593,2.676,594,1.695,598,2.676,599,2.676,846,2.983,853,3.241,871,2.918,872,2.918,875,2.323,879,2.36,881,3.76,884,2.484,940,1.959,945,2.484,946,2.484,961,2.918,1045,3.241,1197,2.676,1293,1.862,1320,2.484,1372,4.062,1702,4.062,1703,2.484,1708,2.918,1726,4.522,1900,2.676,1932,2.918,1949,3.241,1950,3.241,1951,3.241,1953,3.241,1954,3.241,1955,3.241,1956,4.512,1957,3.241,1958,3.241,1960,4.512,1961,3.241,1962,3.241,1964,4.512,1965,3.241,1966,3.241,1969,3.241,1970,3.241,1971,3.241,1972,3.241,1973,3.241,1974,3.241,1975,3.241,1976,2.918,1977,3.241,1978,3.241,1979,3.241,1990,2.918,2021,5.19,2022,3.241,2023,3.241,2024,3.241,2029,3.241,2032,3.241,2033,4.512,2034,3.241,2036,3.241,2078,3.732,2079,6.462,2080,3.241,2081,3.732]],["t/149",[21,0.877,25,0.019,26,0.045,27,0.019,28,0.019,43,0.041,44,0.019,45,0.04,46,0.033,49,0.087,50,0.087,51,0.033,138,1.179,139,0.643,147,1.948,152,0.359,159,1.199,253,1.545,255,2.962,258,2.471,260,2.256,270,2.936,313,2.671,320,1.018,341,3.088,359,2.006,384,2.117,408,4.42,471,2.78,487,1.332,536,4.35,884,2.412,974,2.671,1293,1.809,1324,3.197,1531,3.979,2003,3.979,2071,3.147,2082,5.883,2083,3.623,2084,3.623,2085,3.623,2086,3.623,2087,3.623,2088,3.623,2089,3.623,2090,3.623,2091,3.623,2092,3.623,2093,3.623,2094,3.623,2095,3.623,2096,3.623,2097,5.089,2098,3.623,2099,3.623,2100,3.623,2101,3.623,2102,3.623,2103,3.623,2104,3.623,2105,3.623,2106,3.623,2107,3.623,2108,3.623,2109,3.623,2110,3.623,2111,3.623,2112,5.883,2113,3.623,2114,3.623,2115,3.623,2116,3.623,2117,6.38,2118,3.623,2119,3.623,2120,3.623,2121,3.623,2122,3.623,2123,3.623,2124,3.623,2125,3.623,2126,3.623,2127,3.623,2128,3.623,2129,3.623,2130,3.623,2131,3.623,2132,3.623,2133,3.623,2134,3.623,2135,3.623,2136,3.623,2137,3.623,2138,3.623,2139,3.623,2140,3.623,2141,3.623,2142,3.623,2143,3.623,2144,3.623,2145,3.623,2146,3.623,2147,3.623,2148,3.623,2149,3.623,2150,3.623,2151,3.623,2152,3.623]],["t/151",[17,2.088,21,1.49,25,0.026,26,0.044,27,0.026,28,0.026,43,0.04,44,0.026,45,0.036,46,0.043,49,0.115,50,0.115,51,0.043,138,1.013,152,0.434,161,1.84,163,1.767,164,1.208,175,1.767,202,2.399,270,2.399,303,2.56,326,1.84,399,1.571,400,3.447,487,1.767,491,2,678,4.175,679,2.523,692,3.758,748,4.175,940,2.523,948,3.199,974,2.523,1387,4.175,1440,3.199,1472,4.095,1673,5.344,1676,3.758,1704,4.811,1918,4.175,1920,5.344,1921,4.175,1922,4.175,1923,4.175,1924,4.175,2153,4.807,2154,4.807,2155,4.807,2156,4.807,2157,4.807,2158,4.807,2159,4.807,2160,4.807,2161,4.807,2162,4.807,2163,4.175,2164,4.807,2165,4.807,2166,4.807,2167,4.175,2168,3.758,2169,4.807,2170,4.807,2171,6.787,2172,4.175,2173,4.807,2174,4.807,2175,4.807,2176,4.807]],["t/153",[25,0.023,26,0.044,27,0.023,28,0.023,43,0.037,44,0.023,45,0.035,46,0.039,49,0.105,50,0.105,51,0.039,138,1.257,139,0.619,147,1.668,152,0.506,159,1.279,161,2.477,162,2.379,176,1.32,183,1.32,353,1.371,790,2.507,962,2.622,1482,2.622,1487,2.622,1488,2.622,1494,2.812,1498,2.507,1499,2.622,1500,2.993,1504,2.507,1505,2.507,1511,1.893,1513,1.893,1514,1.668,1598,2.287,2177,2.073,2178,2.073,2179,2.175,2180,3.504,2181,2.412,2182,3.582,2183,3.582,2184,2.9,2185,4.357,2186,2.712,2187,2.175,2188,3.195,2189,2.746,2190,2.746,2191,2.073,2192,3.814,2193,2.073,2194,2.073,2195,2.175,2196,2.073,2197,3.841,2198,2.9,2199,2.712,2200,3.125,2201,2.175,2202,3.125,2203,3.125,2204,3.125,2205,3.407]],["t/155",[25,0.022,26,0.045,27,0.022,28,0.022,43,0.04,44,0.022,45,0.036,46,0.036,49,0.097,50,0.097,51,0.036,67,1.688,138,0.906,139,0.494,147,2.106,152,0.509,176,1.229,183,1.229,291,2.499,320,1.755,353,1.276,462,2.97,536,2.376,563,3.185,1142,5.422,1308,2.7,1482,2.499,1487,2.499,1488,2.499,1494,2.39,1498,2.39,1499,2.499,1500,2.39,1504,2.39,1505,2.39,1511,1.762,1513,2.39,1514,1.553,1620,3.887,2177,1.93,2178,1.93,2180,2.97,2186,2.526,2189,2.617,2190,2.617,2191,1.93,2193,1.93,2194,1.93,2196,1.93,2201,2.025,2206,4.057,2207,4.057,2208,5.502,2209,7.38,2210,7.216,2211,4.057,2212,4.057,2213,5.502,2214,6.243,2215,5.502,2216,6.243,2217,4.057,2218,6.694,2219,4.057,2220,6.243,2221,4.057,2222,4.057,2223,4.057,2224,4.057,2225,4.057,2226,4.057]],["t/157",[25,0.027,26,0.045,27,0.027,28,0.027,43,0.04,44,0.027,45,0.034,46,0.046,49,0.123,50,0.123,51,0.046,73,1.292,100,3.421,159,0.917,163,1.89,164,1.292,353,1.617,399,1.68,651,4.604,652,3.2,879,2.916,896,4.464,967,4.604,1703,3.421,1708,4.019,1888,4.464,2172,6.08,2227,5.14,2228,6.419,2229,5.14,2230,5.14,2231,5.14,2232,7,2233,5.14,2234,7,2235,5.14,2236,5.14,2237,5.14,2238,7,2239,6.419,2240,5.14]],["t/159",[12,1.837,25,0.015,26,0.045,27,0.015,28,0.015,29,1.718,43,0.035,44,0.015,45,0.027,46,0.025,49,0.066,50,0.066,51,0.025,73,1.048,80,1.985,89,1.979,105,2.777,138,1.142,139,0.622,147,1.597,152,0.519,159,1.261,161,1.925,162,1.849,176,0.836,210,0.868,271,2.309,291,1.253,303,1.148,353,0.868,406,3.933,429,2.777,443,2.158,445,2.158,453,2.158,456,2.158,481,1.837,485,1.895,493,3.262,548,2.597,645,1.448,652,2.597,654,2.735,671,1.527,790,1.812,832,2.777,933,1.718,962,1.895,974,1.448,991,3.262,1077,1.979,1137,2.158,1178,3.608,1472,1.837,1482,2.285,1487,1.895,1488,1.895,1494,2.436,1498,2.857,1499,1.895,1500,3.011,1504,1.812,1505,1.812,1511,1.199,1513,1.812,1514,1.056,1597,2.397,1598,1.448,1600,3.262,1601,2.397,1602,2.397,1603,2.397,1604,2.397,1605,2.397,1606,3.623,1607,2.397,1608,2.397,1609,2.158,1610,2.158,1611,2.397,1612,2.397,1617,2.397,1618,2.397,1619,2.397,1620,4.704,1621,2.397,1622,3.623,1623,2.397,1624,3.623,1625,3.262,1626,2.397,1627,4.87,1628,2.397,1629,2.397,1630,2.397,1631,2.397,1632,2.397,1633,4.369,1634,2.397,1635,2.397,1636,3.933,1639,4.369,1640,2.397,1641,2.397,1642,2.397,1643,2.397,1644,4.369,1645,3.933,1646,2.397,1647,3.262,1648,2.397,1649,2.397,1650,4.369,1651,2.397,1652,2.397,1653,2.397,1654,2.397,1655,2.397,1656,3.623,1657,2.397,1658,2.397,1659,2.397,1660,2.397,1661,2.397,1662,2.397,1663,3.623,1664,2.397,1665,2.397,1666,2.397,1667,2.397,1668,2.397,1669,2.397,1670,2.397,1676,2.158,1696,2.992,2167,2.397,2177,1.985,2178,1.313,2179,1.377,2180,3.013,2181,1.527,2182,2.784,2183,2.784,2184,1.837,2187,1.377,2188,2.309,2189,1.985,2190,1.985,2191,1.313,2192,2.784,2193,1.313,2194,1.313,2195,1.377,2196,1.313,2200,2.992,2201,1.377,2202,1.979,2203,1.979,2204,1.979,2241,1.979,2242,3.262,2243,2.759,2244,2.759,2245,2.759,2246,2.397,2247,2.759,2248,2.759,2249,2.759,2250,1.979,2251,2.158,2252,2.397,2253,2.759,2254,2.759]],["t/161",[25,0.02,26,0.045,27,0.02,28,0.02,43,0.038,44,0.02,45,0.035,46,0.034,49,0.092,50,0.092,51,0.034,138,1.312,139,0.652,147,1.461,152,0.522,159,1.34,161,2.712,162,2.604,176,1.156,183,1.156,353,1.201,790,2.835,962,2.964,1482,2.397,1487,2.397,1488,2.397,1494,2.628,1498,2.293,1499,2.397,1500,2.835,1504,2.293,1505,2.293,1511,1.658,1513,1.658,1514,1.461,1598,2.003,2177,1.816,2178,2.51,2179,2.634,2180,3.618,2181,2.921,2182,3.921,2183,3.921,2184,3.512,2186,2.376,2187,1.905,2188,2.921,2189,2.51,2190,2.51,2191,1.816,2192,3.612,2193,1.816,2194,1.816,2195,1.905,2196,1.816,2197,3.512,2198,2.54,2199,2.376,2200,2.738,2202,2.738,2203,2.738,2204,2.738,2205,2.984,2255,5.277,2256,3.817,2257,3.817,2258,3.817]],["t/163",[25,0.022,26,0.045,27,0.022,28,0.022,43,0.039,44,0.022,45,0.04,46,0.037,49,0.099,50,0.099,51,0.037,138,1.222,139,0.501,152,0.445,159,1.126,161,2.415,162,2.319,176,1.254,183,1.69,351,2.292,353,1.303,790,2.424,962,2.534,1487,2.534,1488,2.534,1494,2.741,1498,2.424,1499,2.534,1500,2.933,1504,2.424,1505,2.424,1511,1.799,1513,1.799,1514,1.585,1598,2.173,1724,2.97,2177,1.97,2178,1.97,2179,2.067,2180,3.453,2181,2.292,2182,3.492,2183,3.492,2187,2.067,2188,3.088,2189,2.654,2190,2.654,2191,1.97,2192,3.737,2193,1.97,2194,1.97,2195,2.067,2196,1.97,2199,2.578,2201,3.149,2259,4.141,2260,4.141,2261,6.751,2262,4.141,2263,3.713,2264,6.309,2265,4.845,2266,4.141,2267,4.141,2268,4.141,2269,2.756,2270,2.97,2271,4.141,2272,4.141,2273,4.141,2274,4.141,2275,2.756,2276,3.596,2277,4.141]],["t/165",[25,0.011,26,0.045,27,0.011,28,0.011,43,0.042,44,0.011,45,0.035,46,0.018,49,0.049,50,0.049,51,0.018,105,2.196,122,1.466,139,0.469,147,0.782,152,0.477,159,0.996,161,1.588,162,1.525,176,0.619,206,1.802,210,1.643,217,0.972,238,1.36,248,0.722,249,0.928,253,0.799,270,2.376,271,2.891,276,3.414,309,1.598,312,4.006,326,1.822,413,2.579,481,2.761,487,1.525,540,0.972,548,1.272,645,1.073,654,2.537,661,2.579,711,2.579,736,1.131,772,1.569,784,1.466,790,1.433,914,1.932,942,3.414,962,1.498,974,1.073,1058,1.466,1077,1.466,1324,3.214,1482,1.498,1487,2.537,1488,2.537,1492,1.775,1494,2.983,1498,3.025,1499,2.537,1500,2.935,1502,5.103,1504,2.426,1505,2.426,1511,2.269,1513,1.802,1514,0.782,1579,1.775,1580,1.775,1598,2.742,1600,3.722,1610,1.598,1620,1.272,1636,4.595,1647,1.598,1698,1.598,1794,3.722,1818,1.466,1867,2.865,1932,2.579,1994,2.579,1999,2.579,2163,2.865,2168,1.598,2177,1.569,2178,0.972,2179,1.02,2180,2.657,2181,1.131,2182,2.296,2183,2.296,2184,1.36,2187,1.02,2188,1.826,2189,1.569,2190,1.569,2191,0.972,2192,3.801,2193,0.972,2194,0.972,2195,1.02,2196,0.972,2201,2.607,2241,1.466,2246,1.775,2250,3.746,2251,1.598,2278,2.044,2279,3.299,2280,2.044,2281,2.044,2282,3.299,2283,3.299,2284,3.299,2285,3.299,2286,2.865,2287,3.299,2288,3.299,2289,2.044,2290,2.044,2291,3.299,2292,2.044,2293,3.299,2294,2.044,2295,5.876,2296,2.044,2297,2.044,2298,3.299,2299,3.299,2300,2.044,2301,2.044,2302,2.044,2303,2.044,2304,2.044,2305,4.148,2306,4.134,2307,2.044,2308,2.044,2309,2.044,2310,2.044,2311,3.299,2312,3.299,2313,3.299,2314,2.044,2315,2.044,2316,2.044,2317,2.044,2318,2.044,2319,3.299,2320,3.299,2321,4.148,2322,2.044,2323,2.044,2324,2.044,2325,3.299,2326,2.044,2327,3.299,2328,3.299,2329,2.044,2330,2.044,2331,2.044,2332,3.299,2333,3.299,2334,4.148,2335,2.044,2336,2.044,2337,2.044,2338,2.044,2339,3.299,2340,3.299,2341,2.044,2342,2.044,2343,2.044,2344,2.044,2345,2.044,2346,2.044,2347,2.044,2348,2.044,2349,2.044,2350,2.044,2351,2.044,2352,2.044,2353,2.044,2354,2.044,2355,2.044,2356,3.299,2357,3.299,2358,4.148,2359,2.044,2360,2.044,2361,2.044,2362,2.044,2363,2.044,2364,3.299,2365,3.299,2366,3.299,2367,3.299,2368,2.044,2369,2.044,2370,2.044,2371,2.044,2372,2.044,2373,2.044,2374,2.044,2375,3.299,2376,3.299,2377,2.044,2378,2.044,2379,2.044,2380,2.044,2381,2.044,2382,2.044,2383,2.044,2384,3.299,2385,2.044,2386,2.044,2387,2.044,2388,2.044,2389,2.044,2390,2.044,2391,2.044,2392,2.044,2393,2.044,2394,2.044,2395,2.044,2396,2.044,2397,2.044,2398,2.044,2399,2.044,2400,2.044,2401,2.044,2402,2.044]],["t/167",[25,0.02,26,0.045,27,0.02,28,0.02,43,0.038,44,0.02,45,0.035,46,0.034,49,0.09,50,0.09,51,0.034,138,1.162,139,0.47,152,0.424,159,1.072,161,2.299,162,2.208,176,1.141,183,1.141,210,1.645,351,2.085,353,1.185,790,2.272,1482,2.375,1487,2.947,1488,2.947,1494,3.065,1498,2.819,1499,2.947,1500,3.205,1504,2.819,1505,2.819,1511,2.272,1513,2.272,1514,2.002,1598,2.745,1724,2.701,2177,1.792,2178,1.792,2179,1.88,2180,3.356,2181,2.085,2182,3.324,2183,3.324,2186,3.255,2187,2.61,2188,3.591,2189,3.087,2190,3.087,2191,2.487,2192,4.083,2193,2.487,2194,2.487,2195,2.61,2196,2.487,2197,4.318,2198,3.48,2199,3.255,2201,2.61,2263,3.48,2265,3.271,2269,2.507,2270,2.701,2275,2.507,2276,3.271,2403,5.229,2404,3.767,2405,3.767,2406,5.229,2407,3.767,2408,3.767,2409,3.767,2410,3.767,2411,3.767]],["t/169",[25,0.025,26,0.045,27,0.025,28,0.025,43,0.039,44,0.025,45,0.035,46,0.041,49,0.11,50,0.11,51,0.041,73,1.153,124,3.973,152,0.496,159,1.065,202,2.289,210,1.443,255,1.829,303,1.908,341,2.407,346,3.053,353,1.443,375,3.586,384,1.908,390,3.586,399,1.499,487,1.686,548,2.855,645,2.407,846,3.509,879,2.083,899,2.686,1373,3.983,2412,5.764,2413,3.983,2414,3.983,2415,3.983,2416,5.185,2417,5.969,2418,4.586,2419,3.586,2420,4.586,2421,4.586,2422,4.586,2423,3.586,2424,3.983,2425,5.764,2426,5.764,2427,3.983,2428,3.983,2429,3.983,2430,5.969,2431,4.586,2432,4.586,2433,4.586,2434,4.586,2435,4.586,2436,4.586,2437,4.586,2438,4.586,2439,4.586]],["t/171",[25,0.027,26,0.044,27,0.027,28,0.027,43,0.039,44,0.027,45,0.037,46,0.046,49,0.123,50,0.123,51,0.046,138,1.151,152,0.362,176,1.553,183,1.553,258,2.356,353,1.613,1482,2.911,1487,2.911,1488,2.911,1494,2.784,1498,2.784,1500,2.227,1504,2.784,1505,2.784,1511,2.227,1512,4.453,1513,2.784,1514,2.676,2177,2.439,2178,2.439,2179,2.559,2180,2.439,2186,3.192,2187,2.559,2189,3.049,2190,3.049,2191,2.439,2193,2.439,2194,2.439,2195,2.559,2196,2.439,2201,2.559,2263,3.412,2269,3.412,2275,3.412,2440,4.009]],["t/173",[25,0.021,26,0.045,27,0.021,28,0.021,43,0.039,44,0.021,45,0.033,46,0.036,49,0.095,50,0.095,51,0.036,129,4.832,138,1.181,139,0.487,147,1.522,152,0.535,159,1.28,161,2.365,162,2.272,176,1.205,183,1.205,353,1.251,648,4.832,790,2.684,962,2.807,1482,2.465,1487,2.465,1488,2.465,1494,2.684,1498,2.358,1499,3.016,1500,2.884,1504,2.358,1505,2.358,1511,1.727,1513,2.358,1514,1.522,1598,2.087,1620,3.847,1696,3.893,2177,1.891,2178,1.891,2179,1.985,2180,3.605,2181,2.201,2182,3.42,2183,3.42,2187,1.985,2188,3.004,2189,2.582,2190,2.582,2191,1.891,2192,3.675,2193,1.891,2194,1.891,2195,1.985,2196,1.891,2197,3.612,2198,2.646,2199,2.475,2201,1.985,2241,2.852,2242,4.244,2250,2.852,2263,2.646,2269,2.646,2270,2.852,2275,2.646,2419,4.832,2440,3.109,2441,3.453,2442,4.714,2443,5.367,2444,3.453]],["t/175",[25,0.024,26,0.044,27,0.024,28,0.024,43,0.037,44,0.024,45,0.035,46,0.04,49,0.108,50,0.108,51,0.04,129,5.132,138,0.969,139,0.403,147,1.716,152,0.524,159,1.171,161,2.513,162,2.413,176,1.358,183,1.358,258,2.162,353,1.411,648,5.132,790,2.555,962,2.672,1482,2.672,1487,2.672,1488,2.672,1494,2.555,1498,2.555,1499,2.672,1500,1.948,1504,2.555,1505,2.555,1511,1.948,1513,2.555,1514,2.251,1620,4.087,2177,2.133,2178,2.133,2179,2.238,2180,3.532,2186,2.791,2187,2.238,2189,2.798,2190,2.798,2191,2.133,2193,2.133,2194,2.133,2195,2.238,2196,2.133,2201,2.238,2263,2.984,2269,2.984,2270,3.216,2275,2.984,2419,5.132,2440,3.506,2441,3.894,2442,5.108,2443,5.701,2444,3.894,2445,4.484]],["t/177",[25,0.025,26,0.045,27,0.025,28,0.025,43,0.042,44,0.025,45,0.04,46,0.043,47,0.881,49,0.114,50,0.114,51,0.043,138,0.782,139,0.64,140,0.847,152,0.335,159,0.847,163,1.746,164,1.194,165,2.259,166,2.259,168,2.782,170,3.714,172,3.714,195,0.881,252,3.801,253,1.15,255,1.894,343,2.493,556,4.125,661,3.714,885,2.957,886,2.957,887,2.957,935,4.379,1030,6.55,1166,3.407,1317,3.161,1462,3.714,2446,4.75,2447,7.369,2448,4.75,2449,4.75,2450,4.75,2451,4.75,2452,4.75,2453,4.75,2454,4.75,2455,4.75,2456,4.75,2457,6.106,2458,4.75,2459,4.75,2460,4.75,2461,4.75,2462,4.75,2463,4.75]],["t/179",[25,0.022,26,0.045,27,0.022,28,0.022,43,0.039,44,0.022,45,0.033,46,0.036,49,0.097,50,0.097,51,0.036,138,1.236,139,0.601,147,1.553,152,0.509,159,1.249,161,2.39,162,2.295,176,1.229,183,1.229,353,1.276,645,2.129,654,2.836,790,2.39,879,2.499,962,2.499,1021,3.523,1306,3.523,1482,2.499,1487,2.499,1488,2.499,1494,2.908,1498,2.712,1499,2.499,1500,2.908,1504,2.39,1505,2.39,1511,1.762,1513,1.762,1514,1.553,1598,2.129,1696,3.946,2177,1.93,2178,1.93,2179,2.025,2180,3.433,2181,2.245,2182,3.456,2183,3.456,2184,2.7,2187,2.025,2188,3.045,2189,2.617,2190,2.617,2191,1.93,2192,3.705,2193,1.93,2194,1.93,2195,2.025,2196,1.93,2197,3.662,2198,2.7,2199,2.526,2200,2.91,2201,2.025,2202,2.91,2203,2.91,2204,2.91,2205,3.172,2241,2.91,2242,4.302,2250,2.91,2251,3.172,2252,3.523,2464,4.057,2465,4.057]],["t/181",[25,0.026,26,0.045,27,0.026,28,0.026,43,0.042,44,0.026,45,0.036,46,0.043,49,0.116,50,0.116,51,0.043,55,4.818,139,0.643,140,1.099,152,0.34,195,1.144,210,1.516,253,1.492,259,1.165,291,2.189,339,3.207,387,2.405,487,1.771,563,2.292,645,2.529,654,2.799,772,2.932,839,2.667,1006,4.185,2423,3.767,2466,4.185,2467,4.818,2468,4.818,2469,4.818,2470,4.818,2471,4.818,2472,4.818,2473,4.818,2474,6.162,2475,4.818,2476,6.162,2477,4.818,2478,4.818,2479,4.818,2480,4.818,2481,4.818,2482,4.818,2483,4.818,2484,4.818,2485,4.818,2486,4.818,2487,4.818,2488,4.818,2489,4.818,2490,4.818,2491,4.818]],["t/183",[25,0.027,26,0.045,27,0.027,28,0.027,43,0.039,44,0.027,45,0.034,46,0.046,49,0.123,50,0.123,51,0.046,140,0.912,152,0.493,195,0.949,210,1.609,253,1.238,258,1.88,259,1.097,291,2.323,339,3.403,387,2.552,462,3.481,471,2.04,645,2.684,772,2.433,839,2.83,2080,5.557,2423,3.998,2466,4.441,2475,3.998,2492,5.114,2493,5.114,2494,5.114,2495,5.114,2496,5.114,2497,6.399,2498,5.114,2499,5.114,2500,5.114,2501,5.114,2502,5.114,2503,5.114,2504,5.114,2505,5.114]],["t/185",[17,3.062,21,1.118,25,0.025,26,0.045,27,0.025,28,0.025,29,2.875,43,0.04,44,0.025,45,0.038,46,0.041,47,0.857,49,0.111,50,0.111,67,2.495,139,0.633,140,0.824,148,2.197,152,0.326,173,2.098,174,2.098,175,1.698,176,1.399,183,1.399,195,0.857,206,2.605,217,2.197,246,3.147,253,1.452,259,1.142,310,2.305,324,3.074,326,1.768,341,2.424,342,2.993,343,2.424,344,2.424,345,2.305,346,3.991,347,2.305,348,3.312,540,2.197,667,2.875,876,2.556,940,2.424,941,4.011,942,3.312,943,3.611,944,3.611,945,3.074,946,3.074,947,4.011,948,3.074,949,4.011,950,4.011,951,4.011,952,4.011,953,3.611,954,3.611,955,4.011,1468,2.875,2506,4.618,2507,4.618,2508,3.611,2509,5.996,2510,4.618,2511,4.618,2512,4.618]],["t/187",[21,1.572,25,0.028,26,0.044,27,0.028,28,0.028,43,0.035,44,0.028,45,0.035,46,0.047,47,0.971,49,0.126,50,0.126,51,0.047,138,0.862,139,0.583,140,0.934,148,2.49,159,0.934,173,2.377,174,2.377,175,1.924,176,1.586,191,2.747,195,0.971,206,2.82,207,2.377,246,3.408,259,0.897,301,2.897,342,2.612,344,2.747,345,2.612,347,2.612,374,1.315,523,3.754,524,2.747,525,3.483,644,4.546,667,3.258,854,2.178,875,3.258,876,2.897,879,2.377,953,4.092,1042,4.546,1167,4.092,1192,2.747,1193,4.546,1194,4.546,1195,4.546,1196,4.092,2513,5.234,2514,5.234]],["t/189",[21,1.675,25,0.027,26,0.045,27,0.027,28,0.027,43,0.039,44,0.027,45,0.037,46,0.045,47,0.93,49,0.12,50,0.12,51,0.045,139,0.567,140,0.894,148,2.384,164,1.259,191,2.63,195,0.93,206,2.745,207,2.276,213,2.276,253,1.759,259,0.859,303,2.085,310,2.501,320,1.408,343,2.63,374,1.259,399,1.638,524,2.63,544,4.352,545,4.352,680,3.918,752,4.352,753,4.352,754,4.352,755,4.352,756,4.352,757,4.352,758,4.352,759,4.352,763,4.352,851,2.935,1197,3.594,1976,3.918,2515,7.265,2516,6.318,2517,5.011,2518,5.011]],["t/191",[25,0.031,26,0.044,27,0.031,28,0.031,43,0.037,44,0.031,45,0.037,46,0.051,47,1.063,49,0.137,50,0.137,51,0.051,258,2.106,374,1.439,594,2.602,979,4.108,1324,2.725,1368,4.975,1549,3.812,1884,4.975,2519,5.728,2520,5.728,2521,5.728,2522,5.728,2523,5.728,2524,4.975,2525,5.728,2526,5.728,2527,5.728,2528,5.728,2529,5.728,2530,5.728]],["t/193",[20,4.57,21,1.274,25,0.028,26,0.044,27,0.028,28,0.028,43,0.038,44,0.028,45,0.035,46,0.047,49,0.126,50,0.126,51,0.047,65,3.774,139,0.585,140,0.939,152,0.371,159,1.162,195,0.976,253,1.79,259,1.117,270,2.626,271,2.912,399,1.72,846,3.251,854,2.71,881,2.912,962,2.39,1192,2.762,1724,3.774,1726,3.502,2531,5.261,2532,5.261,2533,4.114,2534,5.261,2535,5.261,2536,5.261,2537,5.261,2538,5.261,2539,5.261,2540,5.261,2541,5.261,2542,5.261]],["t/195",[21,1.046,25,0.023,26,0.044,27,0.034,28,0.023,43,0.037,44,0.023,45,0.037,46,0.039,49,0.104,50,0.104,51,0.039,73,1.085,138,0.945,139,0.515,140,1.024,152,0.405,164,1.085,168,3.361,173,1.962,195,1.065,202,2.156,204,3.098,210,1.359,213,1.962,218,3.377,248,1.526,249,1.962,253,1.56,255,1.723,256,2.53,258,1.588,259,1.105,310,2.156,343,2.267,485,1.962,487,1.588,491,1.797,540,2.055,592,3.751,639,2.875,645,2.267,646,3.751,1180,3.751,1191,3.751,1192,2.267,1252,4.757,1254,3.377,1257,3.377,1259,3.377,1260,3.377,1267,3.377,1317,2.875,1326,3.098,1440,2.875,1458,3.377,1583,3.098,1818,4.116,2543,4.319,2544,7.148,2545,4.319,2546,4.319,2547,4.319,2548,4.319,2549,4.319,2550,4.319,2551,4.319,2552,4.319,2553,5.738,2554,4.319,2555,4.319,2556,4.319,2557,4.319,2558,6.444,2559,4.319,2560,4.319,2561,4.319,2562,4.319,2563,4.319,2564,4.319,2565,4.319,2566,4.319,2567,5.738,2568,4.319,2569,4.319,2570,5.738,2571,4.319,2572,4.319,2573,4.319,2574,4.319,2575,4.319,2576,4.319,2577,4.319,2578,4.319,2579,4.319,2580,4.319,2581,4.319]],["t/197",[21,1.181,25,0.026,26,0.045,27,0.037,28,0.026,43,0.038,44,0.026,45,0.033,46,0.044,47,0.905,49,0.117,50,0.117,51,0.044,139,0.558,140,0.87,152,0.344,174,2.215,183,1.477,195,0.905,200,3.813,202,2.434,210,1.535,259,1.065,374,1.226,387,2.434,399,1.594,476,3.036,487,1.793,491,2.029,500,3.498,521,2.857,524,2.56,772,2.32,832,3.246,854,2.029,907,3.813,967,3.498,1056,4.236,1192,2.56,2475,4.856,2582,4.877,2583,4.877,2584,4.877,2585,4.877,2586,4.877,2587,4.877,2588,4.236,2589,4.877,2590,4.877,2591,4.877,2592,4.877,2593,4.877,2594,4.877,2595,4.877,2596,4.877,2597,4.877,2598,4.877,2599,4.877,2600,4.877,2601,4.877,2602,4.877,2603,4.877,2604,4.877]],["t/199",[1,3.749,23,3.825,25,0.026,26,0.045,27,0.026,28,0.026,43,0.038,44,0.026,45,0.033,46,0.043,47,0.89,49,0.115,50,0.115,51,0.043,73,1.544,258,1.763,259,0.822,310,3.066,320,1.348,361,2.393,363,2.083,374,1.205,518,4.804,594,2.178,673,5.336,736,2.654,979,3.439,1071,3.439,1296,3.749,1320,4.089,1324,2.281,1549,3.191,1796,5.336,1797,4.165,1968,4.165,2524,4.165,2588,4.165,2605,6.144,2606,4.795,2607,4.795,2608,4.795,2609,7.149,2610,4.795,2611,4.795,2612,4.795,2613,4.165,2614,4.795,2615,4.795,2616,4.795,2617,4.795,2618,4.795,2619,6.144,2620,4.795,2621,4.795,2622,4.795,2623,4.795,2624,4.795,2625,4.795,2626,4.795,2627,6.144,2628,4.795,2629,4.795,2630,4.795,2631,4.795]],["t/201",[1,4.121,4,3.78,21,0.922,25,0.02,26,0.045,27,0.02,28,0.02,43,0.041,44,0.02,45,0.035,46,0.034,49,0.091,50,0.091,51,0.034,56,2.979,73,0.957,80,1.812,93,3.309,133,2.979,138,0.627,152,0.46,159,0.94,217,1.812,253,1.276,258,1.401,270,3.534,271,3.919,304,3.309,320,1.481,471,1.52,485,1.73,602,4.334,654,1.73,671,2.109,904,2.732,933,2.372,962,2.394,1024,2.979,1187,2.732,1197,2.732,1293,1.901,1458,2.979,1468,3.762,1491,3.309,1495,3.309,1514,1.458,1576,3.309,1583,2.732,1596,4.577,1697,2.979,1754,3.309,1755,3.309,1761,3.309,1794,2.979,1999,2.979,2286,3.309,2508,2.979,2533,4.121,2632,5.248,2633,3.309,2634,3.81,2635,3.81,2636,5.27,2637,3.81,2638,5.27,2639,3.81,2640,5.27,2641,3.81,2642,3.81,2643,3.81,2644,3.81,2645,3.81,2646,6.042,2647,3.81,2648,3.81,2649,3.81,2650,3.81,2651,3.309,2652,3.309,2653,3.309,2654,3.309,2655,4.577,2656,3.309,2657,3.309,2658,3.309,2659,4.577,2660,3.309,2661,3.309,2662,3.309,2663,3.309,2664,3.309,2665,3.309,2666,3.81,2667,3.81,2668,3.81,2669,3.81,2670,3.81,2671,3.81,2672,3.81,2673,3.81,2674,3.81,2675,3.81,2676,3.81,2677,3.81,2678,3.81,2679,3.81,2680,3.81,2681,3.81,2682,5.27,2683,3.81,2684,3.81,2685,3.81,2686,3.81,2687,3.309,2688,3.81,2689,3.309,2690,3.81,2691,3.81,2692,3.81,2693,3.81,2694,3.81,2695,3.81,2696,3.309,2697,3.81,2698,3.309,2699,3.309,2700,3.309]],["t/203",[23,3.683,25,0.024,26,0.044,27,0.032,28,0.024,43,0.04,44,0.024,45,0.04,46,0.041,47,0.84,49,0.109,50,0.109,51,0.041,52,3.929,67,1.882,138,0.745,210,1.424,258,2.175,320,1.853,353,1.424,359,3.275,360,3.938,361,2.953,363,2.57,374,1.137,471,1.805,487,1.663,563,2.815,593,4.243,594,2.688,595,3.929,596,3.929,597,3.929,598,4.243,599,3.245,600,4.626,601,3.929,602,3.245,603,5.139,604,3.929,605,5.139,606,5.139,607,5.139,608,3.929,609,5.139,610,5.139,611,4.626,612,5.139,613,3.929,614,3.929,615,3.537,899,2.65,914,2.65,974,2.375,1063,3.537,1469,3.929,1900,3.245,1994,3.537,2005,3.929,2689,3.929,2701,4.524,2702,4.524,2703,4.524,2704,4.524,2705,4.524,2706,5.917,2707,5.917,2708,4.524,2709,4.524,2710,3.929,2711,4.524,2712,4.524,2713,4.524,2714,5.917,2715,4.524,2716,4.524,2717,4.524,2718,4.524,2719,4.524,2720,4.524,2721,4.524,2722,4.524,2723,4.524,2724,4.524,2725,4.524,2726,4.524]],["t/205",[25,0.026,26,0.044,27,0.026,28,0.026,43,0.04,44,0.026,45,0.042,46,0.044,47,0.912,49,0.118,50,0.118,51,0.044,258,2.652,353,1.546,360,4.801,361,3.6,374,1.235,536,2.878,594,3.276,736,2.719,1402,4.267,1409,4.267,1414,4.267,1416,4.267,1420,4.267,1421,4.267,1424,4.267,1593,4.267,2066,3.841,2613,4.267,2727,4.913,2728,6.239,2729,7.213,2730,4.913,2731,6.239,2732,4.913,2733,6.239,2734,6.239,2735,4.913,2736,6.239,2737,6.239,2738,4.913,2739,4.913,2740,4.913,2741,4.913,2742,4.913,2743,4.913,2744,4.913,2745,4.913,2746,4.913,2747,4.913]],["t/207",[17,1.646,21,1.271,25,0.02,26,0.045,27,0.02,28,0.02,43,0.041,44,0.02,45,0.037,46,0.034,49,0.091,50,0.091,51,0.034,65,2.717,140,0.676,152,0.425,183,1.59,195,0.703,218,2.962,238,2.521,242,1.511,248,1.338,249,2.385,253,1.575,259,1.171,270,1.891,271,2.097,272,3.29,276,5.069,277,4.559,291,1.721,297,3.29,320,1.065,326,1.45,351,3.6,353,1.652,384,1.576,387,2.62,399,1.238,462,2.497,485,2.385,491,1.576,665,2.962,680,2.962,772,2.497,846,2.62,854,1.576,876,2.097,879,1.721,881,2.097,892,2.521,1023,3.29,1071,2.717,1214,2.717,1292,2.521,1324,2.497,1535,2.717,1549,2.521,1584,2.962,1645,2.962,1759,3.29,1818,4.321,2748,3.788,2749,6.504,2750,3.788,2751,3.788,2752,3.788,2753,3.788,2754,3.788,2755,3.788,2756,3.788,2757,3.788,2758,3.788,2759,3.788,2760,3.788,2761,3.788,2762,3.788,2763,3.788,2764,3.788,2765,3.788,2766,3.788,2767,3.788,2768,3.788,2769,3.788,2770,3.788,2771,3.788,2772,6.024,2773,3.788,2774,3.788,2775,6.024,2776,3.788,2777,3.788,2778,3.788,2779,3.788,2780,3.788,2781,3.788,2782,3.788,2783,3.788,2784,3.788,2785,3.788,2786,3.788,2787,3.788,2788,5.249,2789,3.788,2790,3.788,2791,3.788,2792,3.788,2793,3.788,2794,3.788]],["t/209",[21,1.164,25,0.026,26,0.044,27,0.026,28,0.026,43,0.041,44,0.026,45,0.033,46,0.043,49,0.115,50,0.115,51,0.043,56,3.758,73,1.208,80,2.287,133,3.758,138,0.792,152,0.479,159,1.098,217,2.287,258,1.767,259,0.824,320,1.351,471,1.917,602,4.413,662,3.758,671,2.661,692,4.811,892,3.199,1187,3.447,1293,2.399,1468,2.992,1514,1.84,1583,3.447,1852,4.175,2508,3.758,2632,5.344,2633,5.344,2651,4.175,2652,4.175,2653,4.175,2654,4.175,2655,5.344,2656,4.175,2657,4.175,2658,4.175,2659,5.344,2660,4.175,2661,4.175,2662,4.175,2663,4.175,2664,4.175,2665,4.175,2696,4.175,2698,4.175,2699,4.175,2700,4.175,2795,4.807,2796,4.807,2797,4.807,2798,6.153,2799,4.807,2800,4.807,2801,7.396,2802,4.807,2803,4.807,2804,4.807,2805,4.807,2806,4.807,2807,4.807]],["t/211",[21,0.902,23,2.319,25,0.02,26,0.045,27,0.028,28,0.02,43,0.042,44,0.02,45,0.039,46,0.033,49,0.089,50,0.089,51,0.033,67,1.55,71,2.182,139,0.536,140,0.926,152,0.509,159,1.065,195,0.963,210,1.632,253,1.445,259,0.89,310,1.859,361,1.859,363,1.618,384,1.55,563,2.84,594,1.692,667,3.717,671,3.305,772,2.468,876,3.891,895,2.671,901,3.721,902,3.721,920,2.912,942,2.671,979,2.671,1088,3.974,1199,3.235,1220,3.235,1320,2.479,1468,2.319,1549,2.479,1589,3.235,1609,4.057,2533,2.912,2687,3.235,2808,3.725,2809,5.188,2810,3.725,2811,3.725,2812,5.188,2813,5.188,2814,5.188,2815,5.188,2816,6.457,2817,3.725,2818,3.725,2819,5.97,2820,5.97,2821,5.188,2822,3.725,2823,3.725,2824,3.725,2825,3.725,2826,3.725,2827,3.725,2828,3.725,2829,5.188,2830,5.188,2831,5.188,2832,5.188,2833,3.725,2834,3.725,2835,3.725,2836,3.725,2837,3.725,2838,3.725,2839,3.725,2840,3.725,2841,3.725,2842,3.725,2843,3.725,2844,3.725]],["t/244",[17,3.078,21,1.134,25,0.025,26,0.045,27,0.025,28,0.025,43,0.04,44,0.025,45,0.038,46,0.042,47,0.869,49,0.112,50,0.112,51,0.042,58,3.662,67,2.517,138,0.771,139,0.421,152,0.33,159,0.836,191,2.458,202,3.02,253,1.134,270,2.337,271,2.592,276,3.359,324,3.117,326,1.793,341,2.458,342,2.337,343,2.458,345,2.337,347,2.337,348,3.359,353,1.904,374,1.177,399,1.531,462,2.228,471,1.868,491,1.948,940,2.458,943,4.731,944,3.662,945,3.117,946,3.117,974,3.176,1169,4.067,1170,4.067,1187,3.359,1196,3.662,1441,4.067,1745,4.067,2066,3.662,2168,3.662,2306,4.067,2710,4.067,2845,6.051,2846,4.683,2847,4.683,2848,4.683,2849,4.683,2850,4.683,2851,4.683,2852,4.683,2853,6.051,2854,4.683,2855,4.683,2856,4.683,2857,4.683]],["t/258",[25,0.026,26,0.045,27,0.026,28,0.026,43,0.04,44,0.026,45,0.037,46,0.044,49,0.118,50,0.118,51,0.044,124,4.159,152,0.509,202,2.458,210,1.55,303,2.049,326,1.885,351,2.726,353,1.55,375,3.851,384,2.856,390,3.851,399,1.61,548,3.066,846,3.603,879,2.237,899,2.885,2412,5.962,2413,4.277,2414,4.277,2415,4.277,2416,4.277,2424,4.277,2425,4.277,2426,4.277,2427,4.277,2428,4.277,2429,4.277,2858,4.925,2859,4.925,2860,4.925,2861,4.925,2862,4.925,2863,4.925,2864,4.925,2865,4.925,2866,4.925]]],"invertedIndex":[["",{"_index":26,"t":{"41":{"position":[[7,1],[33,2],[84,2],[219,1],[281,3],[322,2],[358,2],[411,1],[419,2],[490,1],[495,2],[511,2],[602,1],[618,1],[655,1],[695,1],[707,1],[723,2],[736,1],[752,1],[764,2],[777,1],[789,1],[806,2],[819,1],[836,1],[849,1],[851,2],[929,2],[998,1],[1013,2],[1026,1],[1054,1],[1073,1],[1137,2],[1155,1],[1192,1],[1218,1],[1244,1],[1271,2],[1295,1],[1326,1],[1351,1],[1363,2],[1390,1],[1506,2],[1521,1],[1543,1],[1562,1],[1584,1],[1618,1],[1633,1],[1641,1],[1657,1],[1705,1],[1733,1],[1753,2],[1756,1],[1758,2],[1851,1],[1861,1],[1884,1],[1924,1],[1926,2],[1984,1],[2073,1],[2104,1],[2128,1],[2154,1],[2178,1],[2215,1],[2253,1],[2258,2],[2304,1],[2389,1],[2413,1],[2435,1],[2470,1],[2506,1],[2529,1],[2531,1],[2544,2],[2567,1],[2597,1],[2645,2],[2648,1],[2664,1],[2696,1],[2714,3],[2718,2],[2770,2],[2773,1],[2775,2],[2840,2],[2948,1],[2981,1],[3046,1],[3081,1],[3090,2],[3150,2],[3217,1],[3221,2],[3238,1],[3266,1],[3295,1],[3326,1],[3346,1],[3350,2],[3367,1],[3396,1],[3425,1],[3456,1],[3458,2],[3527,2],[3556,1],[3562,2],[3579,1],[3599,1],[3606,2],[3623,1],[3629,2],[3646,1],[3667,1],[3674,1],[3726,1],[3757,1],[3763,1],[3765,2],[3847,1],[3863,2],[3880,1],[3884,2],[3905,1],[3921,2],[3938,1],[3943,1],[3945,2],[4012,1],[4042,1],[4061,1],[4081,1],[4101,1],[4109,2],[4112,2],[4176,2],[4217,1],[4321,2],[4324,2],[4403,1],[4457,2],[4460,2],[4525,2],[4619,1],[4685,2],[4703,1],[4724,1],[4741,2],[4840,1],[4875,1],[4887,2],[4890,1],[4892,2],[4969,1],[4971,2],[5040,2],[5104,1],[5149,2],[5246,1],[5284,1],[5305,2],[5356,1],[5393,1],[5412,2],[5415,1],[5431,2],[5461,1],[5484,2],[5514,1],[5535,2],[5563,1],[5584,2],[5612,1],[5621,3],[5625,2]]},"43":{"position":[[7,1],[43,1],[85,3],[126,2],[188,1],[254,2],[321,1],[536,1],[544,1],[560,1],[562,1],[592,1],[594,1],[610,2],[630,1],[702,1],[774,1],[840,1],[893,1],[984,2],[1007,1],[1037,1],[1202,1],[1230,1],[1269,1],[1276,1],[1278,2],[1281,1],[1297,1],[1352,1],[1411,3],[1415,2],[1476,2],[1537,2],[1573,1],[1630,2],[1718,1],[1777,3],[1781,1],[1798,1],[1815,2],[1862,1],[1864,1],[1894,1],[1905,1],[1933,1],[1961,1],[1972,1],[1996,1],[2004,1],[2006,1]]},"45":{"position":[[7,1],[43,1],[110,3],[165,1],[246,1],[302,1],[326,1],[387,1],[454,1],[477,1],[520,1],[542,1],[572,1],[642,1],[649,1],[660,1],[674,1],[733,1],[738,1],[743,1],[757,1],[772,1],[777,1],[815,1],[834,1],[858,1],[888,1],[911,1],[939,1],[963,1],[991,2],[994,1],[1020,2],[1028,1],[1037,3],[1053,1],[1112,3],[1137,1],[1206,1],[1261,1],[1284,1],[1319,1]]},"47":{"position":[[7,1],[43,1],[108,3],[149,2],[197,1],[272,1],[274,3],[293,1],[295,3],[299,2],[371,1],[377,2],[445,1],[465,1],[467,3],[471,2],[507,1],[514,1],[534,1],[572,1],[574,2],[608,1],[615,1],[632,1],[669,1],[671,2],[701,1],[746,2],[782,1],[850,1],[878,1],[908,1],[956,2],[959,1],[975,1],[991,2],[994,1],[1007,2],[1026,1],[1060,1],[1078,3],[1082,2],[1129,2],[1132,1],[1162,2],[1302,2],[1362,1],[1369,1],[1386,1],[1396,1],[1409,2],[1487,1],[1520,1],[1531,1],[1556,1],[1589,1],[1600,1],[1620,1],[1630,1],[1636,1],[1638,3],[1642,3],[1646,1],[1714,2],[1744,1],[1752,1],[1759,1],[1770,1],[1790,1],[1823,1],[1863,1],[1879,1],[1894,1],[1933,1],[1938,1],[1993,1],[2013,3],[2037,1],[2050,1],[2075,1],[2128,1],[2165,1],[2201,1],[2218,1],[2232,1],[2236,1],[2250,1],[2254,1],[2270,1],[2279,1],[2284,1],[2289,1],[2296,1],[2306,1],[2311,1],[2316,1],[2323,1],[2325,1],[2329,1],[2334,1],[2338,1],[2344,1],[2351,1],[2363,1],[2371,1]]},"49":{"position":[[7,1],[43,1],[85,3],[126,2],[173,1],[249,1],[269,1],[284,1],[306,1],[325,1],[344,1],[367,1],[391,1],[399,2],[431,1],[433,3],[448,1],[455,1],[474,1],[487,1],[489,1],[547,2],[571,1],[599,1],[684,1],[724,1],[733,1],[743,1],[759,1],[766,1],[776,1],[792,1],[799,1],[807,2],[903,1],[919,1],[929,1],[949,1],[965,1],[970,1],[982,1],[998,1],[1017,1],[1033,1],[1045,1],[1047,2],[1101,2],[1104,1],[1116,1],[1128,1],[1132,1],[1136,1],[1141,2],[1151,2],[1203,2],[1206,1],[1208,2],[1301,2],[1324,1],[1338,2],[1347,1],[1352,1],[1361,1],[1386,1],[1393,1],[1412,1],[1425,1],[1448,1],[1480,2],[1548,1],[1582,1],[1591,1],[1598,1],[1603,1],[1631,1],[1659,1],[1678,1],[1687,1],[1694,1],[1699,1],[1727,1],[1756,1],[1761,2],[1785,1],[1812,1],[1856,1],[1876,1],[1921,1],[1947,1],[1968,1],[1979,1],[1990,1],[2023,1],[2048,1],[2077,1],[2093,1],[2109,2],[2177,2],[2258,2],[2334,1],[2350,1],[2365,1],[2381,1],[2389,1],[2403,1],[2420,1],[2470,1],[2503,1],[2513,1],[2518,1],[2520,3]]},"51":{"position":[[7,1],[43,1],[108,3],[149,2],[222,1],[238,1],[303,2],[370,1],[399,2],[458,2],[513,1],[532,1],[545,1],[565,1],[597,1],[599,2]]},"53":{"position":[[7,1],[43,1],[108,3],[375,1],[400,1],[407,2],[479,1],[481,2],[534,1],[536,1],[779,2],[782,2],[813,1],[815,3],[839,1],[874,1],[881,1],[891,1],[902,1],[931,1],[935,1],[988,1],[990,1],[1016,3],[1091,2],[1110,1],[1131,1],[1147,1],[1162,2],[1194,1],[1201,1],[1211,1],[1226,1],[1282,1],[1308,2],[1357,1],[1361,1],[1391,1],[1408,1],[1431,1],[1459,1],[1486,1],[1528,1],[1582,1],[1602,1],[1639,2],[1652,1],[1708,1],[1743,1],[1748,1],[1769,1],[1795,1],[1838,1],[1854,1],[1957,1],[2035,1],[2039,1],[2076,2],[2105,1],[2234,2],[2375,1],[2439,3],[2458,1],[2513,1],[2558,1],[2575,1],[2604,1],[2644,1],[2677,2],[2713,1],[2773,1],[2817,1],[2836,1],[2878,1],[2963,2],[3006,1],[3032,1],[3079,2],[3082,2],[3085,1],[3100,3],[3116,1],[3125,2],[3176,1],[3207,1],[3226,1],[3233,1],[3254,1],[3264,1],[3288,1],[3315,1],[3334,1],[3347,1],[3352,1],[3356,1],[3360,1],[3380,1],[3387,1],[3391,1],[3397,1],[3405,1],[3471,3],[3492,1],[3508,1],[3517,1],[3519,1],[3521,2],[3569,1],[3579,1],[3588,1],[3590,2],[3643,2],[3646,1],[3648,2],[3680,1],[3687,1],[3708,1],[3718,1],[3730,2],[3777,2],[3884,1],[3920,1],[3944,1],[3958,2],[4005,1],[4012,1],[4037,1],[4047,1],[4075,1],[4086,1],[4101,1],[4106,1],[4126,1],[4163,1],[4167,2],[4176,1],[4191,1],[4193,2],[4234,2],[4315,1],[4355,1],[4390,1],[4402,1],[4425,1],[4456,1],[4481,1],[4518,1],[4524,1],[4526,1],[4528,1],[4530,3],[4534,1],[4536,2],[4667,1],[4669,3],[4752,1],[4766,1],[4768,1],[4907,2],[4946,1],[4948,2],[5001,2],[5004,1],[5016,1],[5043,1],[5045,3],[5060,1],[5067,1],[5091,1],[5101,1],[5128,1],[5158,1],[5190,1],[5284,3],[5291,1],[5314,1],[5373,1],[5375,1],[5388,1],[5395,1],[5417,1],[5468,1],[5470,3],[5474,2],[5522,1],[5534,1],[5544,1],[5549,1],[5554,1],[5556,2],[5590,2],[5686,1],[5699,2],[5702,1],[5707,1],[5711,1],[5722,1],[5727,1],[5731,1],[5741,1],[5747,1]]},"55":{"position":[[7,1],[43,1],[108,3],[149,2],[317,2],[417,2],[560,2],[563,1],[565,2],[621,1],[629,2],[701,1],[768,1],[787,1],[804,1],[824,1],[849,1],[878,1],[955,2],[958,2],[961,1],[973,1],[987,2],[1057,1],[1092,1],[1104,1],[1120,3],[1124,3]]},"57":{"position":[[7,1],[43,1],[108,3],[149,2],[317,2],[406,1],[452,2],[455,2],[506,2],[589,2],[592,1],[594,2],[664,1],[737,1],[756,1],[773,1],[793,1],[836,1],[901,1],[920,1],[934,1],[954,1],[984,3]]},"59":{"position":[[7,1],[43,1],[108,3],[171,1],[173,2],[215,1],[217,1],[228,2],[260,1],[262,1],[332,2],[335,2],[338,2],[341,1],[372,1],[374,1],[440,2],[443,2],[446,3],[450,2],[504,3],[508,2],[640,1],[674,1],[676,2],[723,2],[818,1],[865,2],[934,1],[1014,1],[1033,1],[1047,1],[1067,1],[1117,1],[1143,1],[1186,2],[1189,2],[1192,1],[1230,3],[1234,1],[1268,1],[1270,2],[1308,2],[1400,2],[1495,1],[1542,2],[1611,1],[1689,1],[1708,1],[1722,1],[1742,1],[1792,1],[1818,1],[1861,2],[1864,2],[1867,1],[1887,2],[1966,3],[1970,1]]},"61":{"position":[[7,1],[43,1],[108,3],[149,2],[219,1],[278,2],[367,2],[370,1],[372,2],[440,1],[477,2],[536,2],[591,1],[610,1],[623,1],[643,1],[675,3]]},"63":{"position":[[7,1],[43,1],[85,3],[138,2],[251,2],[290,1],[292,3],[314,1],[316,1],[379,2],[392,1],[397,2],[447,1],[488,1],[512,1],[519,2],[569,1],[643,1],[645,2],[712,1],[719,1],[731,1],[749,1],[765,1],[771,2],[825,1],[867,1],[883,1],[903,1],[919,1],[940,1],[956,1],[984,1],[1006,1],[1065,1],[1080,1],[1082,2],[1111,1],[1179,1],[1210,1],[1243,1],[1263,2],[1266,1],[1268,2],[1319,1],[1326,1],[1338,1],[1352,1],[1380,2],[1388,1],[1396,2],[1428,1],[1470,1],[1513,2],[1522,3]]},"65":{"position":[[7,1],[43,1],[85,3],[126,2],[177,1],[257,1],[295,1],[348,2],[417,1],[419,3],[440,1],[457,1],[464,1],[483,1],[485,2],[581,1],[666,2],[720,1],[736,1],[744,2],[811,1],[838,1],[866,1],[893,1],[915,2],[1028,1],[1052,2],[1126,1],[1142,1],[1152,1],[1157,2],[1249,1],[1272,2],[1335,1],[1339,1],[1355,1],[1360,2],[1493,1],[1495,2],[1565,1],[1589,1],[1668,1],[1688,1],[1711,1],[1731,1],[1736,2],[1757,2],[1760,1],[1762,2],[1827,1],[1834,1],[1859,1],[1872,1],[1903,2],[1924,1],[1939,2],[1967,1],[1988,2],[2016,1],[2044,1],[2072,1],[2077,2],[2133,1],[2149,1],[2158,2],[2179,1],[2197,1],[2212,1],[2232,1],[2242,1],[2262,1],[2275,1],[2291,1],[2300,2],[2322,1],[2340,1],[2355,1],[2376,1],[2386,1],[2407,1],[2409,1],[2411,3]]},"67":{"position":[[7,1],[43,1],[108,3],[165,1],[220,2],[258,1],[318,2],[361,1],[368,1],[379,1],[393,1],[452,1],[457,1],[462,1],[476,1],[491,1],[496,1],[529,1],[531,2],[575,1],[594,1],[611,1],[631,1],[636,2],[708,1],[726,1],[749,1],[768,1],[773,2],[825,2],[828,1],[830,2],[855,2],[926,1],[933,1],[942,3]]},"69":{"position":[[7,1],[43,1],[108,3],[149,2],[273,2],[299,1],[312,2],[315,1],[333,1],[376,1],[430,1],[510,1],[528,1],[548,1],[569,1],[645,1],[667,1],[686,1],[732,1],[742,1],[758,1],[778,1],[876,1],[896,2],[899,1],[901,2],[923,2],[932,1],[944,2],[956,1],[962,2],[997,1],[1024,1],[1029,1],[1045,1],[1072,1],[1077,1],[1100,1],[1102,1],[1104,1],[1111,1],[1122,1],[1132,1],[1143,1],[1149,2],[1170,1],[1181,1],[1191,1],[1201,1],[1207,2],[1216,1],[1223,1],[1233,1],[1243,1],[1253,1],[1259,2],[1269,1],[1276,1],[1287,1],[1298,1],[1308,1],[1314,2],[1322,2],[1325,2],[1376,1],[1396,1],[1412,1],[1419,1],[1443,1],[1459,1],[1484,1],[1566,1],[1581,1],[1594,3],[1609,1],[1617,1],[1621,1],[1625,1],[1643,1],[1655,1],[1657,1],[1673,1],[1675,1],[1682,1],[1693,1],[1698,2],[1716,1],[1726,1],[1731,2],[1753,1],[1763,1],[1768,2],[1789,1],[1800,1],[1805,2],[1827,1],[1832,2],[1845,2],[1848,2],[1959,1],[2029,2],[2060,1],[2073,1],[2090,1],[2100,1],[2124,1],[2140,1],[2144,1],[2151,1],[2169,2],[2172,2],[2175,2],[2251,2],[2277,1],[2290,2],[2293,1],[2311,1],[2354,1],[2408,1],[2432,1],[2449,1],[2451,3],[2466,1],[2473,1],[2492,1],[2505,1],[2637,1],[2641,1],[2654,1],[2667,1],[2677,1],[2682,1],[2689,1],[2699,1],[2703,1],[2716,1],[2729,1],[2739,1],[2744,1],[2751,1],[2756,2],[2777,1],[2789,1],[2809,2],[2812,1],[2814,2],[2836,2],[2845,1],[2857,2],[2869,1],[2875,2],[2918,2],[2921,1],[2933,1],[2946,1],[2959,1],[2979,2],[3058,1],[3064,1],[3070,1],[3077,1],[3085,3],[3089,2],[3092,2],[3095,2],[3165,2],[3191,1],[3204,2],[3207,1],[3225,1],[3268,1],[3322,1],[3402,1],[3420,1],[3440,1],[3459,1],[3505,1],[3515,1],[3531,1],[3551,1],[3621,1],[3641,2],[3644,1],[3646,2],[3668,2],[3677,1],[3689,2],[3701,1],[3724,1],[3738,1],[3755,1],[3763,1],[3790,1],[3805,1],[3828,1],[3847,1],[3870,1],[3880,2],[4095,2],[4098,2],[4101,2],[4206,2],[4232,1],[4245,2],[4248,1],[4266,1],[4309,1],[4363,1],[4386,1],[4403,1],[4483,1],[4503,1],[4511,2],[4611,1],[4797,1],[4813,2],[4878,1],[4894,1],[5023,2],[5093,2],[5181,1],[5227,1],[5237,1],[5253,1],[5383,1],[5403,2],[5406,1],[5408,2],[5430,2],[5439,1],[5452,2],[5464,1],[5470,2],[5505,1],[5532,1],[5537,1],[5553,1],[5580,1],[5585,1],[5593,2],[5625,1],[5627,1],[5629,1],[5636,1],[5640,1],[5658,1],[5662,1],[5679,1],[5701,1],[5705,1],[5718,2],[5739,1],[5761,1],[5765,1],[5782,1],[5803,1],[5820,2],[5829,1],[5836,1],[5840,1],[5857,1],[5878,1],[5899,1],[5916,2],[5926,1],[5933,1],[5937,1],[5955,1],[5959,1],[5977,1],[5981,1],[5998,1],[6015,2],[6023,2],[6026,2],[6090,1],[6092,1],[6119,1],[6128,2],[6131,2],[6182,1],[6202,1],[6207,2],[6315,1],[6322,1],[6346,1],[6362,1],[6387,1],[6469,1],[6484,1],[6497,3],[6512,1],[6520,1],[6524,1],[6528,1],[6546,1],[6562,1],[6582,1],[6584,1],[6600,1],[6602,1],[6610,1],[6632,1],[6648,2],[6667,1],[6688,1],[6692,1],[6704,2],[6724,1],[6728,1],[6745,1],[6749,1],[6761,2],[6782,1],[6786,1],[6804,1],[6820,2],[6833,2],[6836,2],[6966,1],[6983,2],[7014,1],[7021,1],[7037,1],[7061,1],[7077,1],[7081,1],[7088,1],[7117,1],[7129,1],[7140,1],[7160,1],[7172,1],[7183,1],[7269,2],[7272,2],[7275,2],[7384,2],[7410,1],[7423,2],[7426,1],[7444,1],[7487,1],[7547,1],[7747,1],[7890,1],[7977,1],[7997,2],[8000,1],[8002,2],[8024,2],[8033,1],[8044,2],[8056,1],[8082,1],[8091,2],[8094,2],[8110,1],[8112,1],[8328,2],[8331,2],[8383,2],[8386,1],[8388,2],[8448,2],[8451,1],[8464,3],[8468,3],[8472,3],[8476,1],[8739,2],[8793,1],[8795,2],[8849,3],[8856,2],[8862,3],[8870,2],[8877,3],[8884,2],[8890,3],[8899,1],[8915,1],[8935,1],[8948,1],[8972,1],[8986,2],[9024,3],[9031,1],[9047,1],[9058,1],[9071,1],[9095,1],[9108,1],[9132,1],[9145,1],[9169,1],[9182,1],[9197,2],[9246,1],[9250,2],[9256,1],[9260,2],[9266,1],[9270,2],[9276,1],[9281,1],[9297,1],[9299,2],[9375,1],[9380,1],[9385,1],[9406,1],[9411,1],[9416,1],[9436,1],[9443,2],[9446,1]]},"71":{"position":[[7,1],[43,1],[108,3],[223,2],[226,1],[240,1],[289,1],[304,1],[338,2],[392,1],[439,2],[478,1],[501,2],[504,1],[506,2],[578,1],[585,1],[612,1],[629,2],[648,1],[654,1],[659,1],[666,1],[694,3],[698,3]]},"73":{"position":[[7,1],[43,1],[85,3],[126,2],[169,1],[171,3],[192,1],[209,1],[216,1],[235,1],[237,2],[333,1],[394,2],[481,2],[576,1],[592,1],[600,2],[665,1],[681,1],[708,1],[724,1],[755,1],[771,1],[783,2],[842,1],[844,2],[979,1],[995,1],[1005,1],[1010,2],[1102,1],[1125,2],[1188,1],[1192,1],[1208,1],[1213,2],[1346,1],[1348,2],[1418,1],[1442,1],[1520,1],[1540,1],[1563,1],[1583,1],[1607,2],[1610,1],[1612,2],[1678,1],[1685,1],[1707,1],[1720,1],[1748,2],[1769,1],[1784,2],[1812,1],[1833,2],[1861,1],[1889,1],[1917,1],[1922,2],[1978,1],[1994,1],[2003,2],[2024,1],[2042,1],[2057,1],[2077,1],[2087,1],[2107,1],[2120,1],[2136,1],[2145,2],[2167,1],[2185,1],[2200,1],[2221,1],[2231,1],[2252,1],[2254,1],[2256,3]]},"75":{"position":[[7,1],[43,1],[108,3],[149,2],[229,1],[270,1],[329,2],[390,1],[409,1],[423,1],[443,1],[448,2],[492,1],[504,2],[539,1],[552,2],[655,2],[687,1],[703,2],[735,2],[749,2],[779,2],[840,1],[857,2],[881,2],[890,1]]},"77":{"position":[[7,1],[43,1],[105,3],[146,2],[201,1],[260,2],[319,2],[374,1],[393,1],[406,1],[426,1],[476,2],[479,1],[481,2],[545,2],[553,3]]},"79":{"position":[[7,1],[43,1],[85,3],[140,1],[176,1],[247,3],[280,2],[338,1],[340,3],[363,1],[403,1],[411,1],[429,1],[436,1],[457,1],[459,2],[493,1],[558,2],[644,2],[701,1],[717,1],[725,2],[752,1],[768,1],[795,1],[811,1],[842,1],[858,1],[870,2],[925,1],[941,1],[951,1],[956,2],[1050,1],[1073,2],[1153,1],[1158,1],[1174,1],[1179,1],[1198,1],[1214,1],[1221,2],[1354,1],[1356,2],[1432,1],[1456,1],[1535,1],[1555,1],[1578,1],[1598,1],[1603,2],[1615,1],[1638,2],[1641,1],[1643,2],[1711,1],[1718,1],[1741,1],[1754,1],[1781,1],[1788,1],[1804,1],[1819,1],[1842,2],[1863,1],[1878,2],[1906,1],[1920,1],[1944,2],[1972,1],[1986,1],[2017,1],[2035,1],[2046,2],[2077,1],[2093,1],[2102,2],[2123,1],[2141,1],[2156,1],[2176,1],[2186,1],[2206,1],[2219,1],[2235,1],[2244,2],[2266,1],[2284,1],[2299,1],[2320,1],[2330,1],[2351,1],[2353,1],[2355,2],[2384,2],[2392,3]]},"81":{"position":[[7,1],[43,1],[108,3],[149,2],[190,1],[261,1],[326,2],[395,1],[449,1],[462,2],[505,1],[585,1],[623,1],[644,2],[706,2],[769,1],[854,1],[944,1],[1024,1],[1026,3],[1052,1],[1054,1],[1104,2],[1118,1],[1125,1],[1135,1],[1150,1],[1198,1],[1242,1],[1262,1],[1277,1],[1297,1],[1301,1],[1307,2],[1358,1],[1540,2],[1591,2],[1636,1],[1638,2],[1713,1],[1723,1],[1808,1],[1843,1],[1857,1],[1878,1],[1910,1],[1915,1],[1939,1],[1953,1],[1979,1],[1994,1],[2015,1],[2022,1],[2037,1],[2054,1],[2056,1],[2082,1],[2096,1],[2121,1],[2131,1],[2146,1],[2167,1],[2192,1],[2206,1],[2232,1],[2242,1],[2257,1],[2274,1]]},"83":{"position":[[7,1],[43,1],[85,3],[126,2],[169,1],[249,1],[287,1],[308,2],[370,2],[433,1],[518,1],[608,1],[688,1],[690,3],[716,1],[718,1],[768,2],[782,1],[789,1],[799,1],[814,1],[881,1],[901,1],[916,1],[936,1],[940,1],[946,2],[997,1],[1023,1],[1043,2],[1052,1],[1087,2],[1133,2],[1314,2],[1339,2],[1373,2],[1403,2],[1440,2],[1474,2],[1506,2],[1531,2],[1566,2],[1597,2],[1635,2],[1686,2],[1731,1],[1733,2],[1808,1],[1818,1],[1903,1],[1938,1],[1952,1],[1973,1],[2005,1],[2010,1],[2034,1],[2048,1],[2074,1],[2089,1],[2110,1],[2117,1],[2132,1],[2149,1],[2151,1],[2177,1],[2191,1],[2216,1],[2226,1],[2241,1],[2262,1],[2287,1],[2301,1],[2327,1],[2337,1],[2352,1],[2369,1]]},"85":{"position":[[7,1],[33,2],[119,1],[184,3],[237,1],[409,1],[425,2],[428,3],[440,1],[456,1],[458,3],[476,1],[515,1],[531,4],[546,1],[562,1],[582,1],[593,2],[633,1],[741,1],[767,1],[774,2],[829,1],[947,1],[962,2],[1018,1],[1048,1],[1081,1],[1112,1],[1144,1],[1157,1],[1184,1],[1225,1],[1249,2],[1383,3],[1395,2],[1403,3],[1422,2],[1430,3],[1450,1],[1504,2],[1507,4],[1512,1],[1514,2],[1568,1],[1574,1],[1595,1],[1601,1],[1617,1],[1619,1],[1621,2],[1652,1],[1671,1],[1722,2],[1725,1],[1924,3]]},"87":{"position":[[7,1],[43,1],[76,1],[100,3],[158,1],[223,2],[267,1],[352,1],[387,1],[545,2],[588,1],[655,2],[729,2],[765,1],[871,3],[894,1],[929,1],[1087,2],[1131,1],[1217,1],[1252,1],[1281,1],[1402,1],[1562,2],[1590,2],[1666,2],[1721,1],[1806,1],[1927,1],[1942,2],[2004,1],[2110,3],[2133,1],[2168,1],[2338,1],[2377,3],[2393,1],[2437,1],[2453,1],[2467,1],[2483,1],[2502,1],[2546,1],[2562,1],[2576,1],[2592,1],[2611,1],[2651,1],[2667,1],[2681,1],[2697,1],[2716,1],[2738,1],[2767,1],[2797,1],[2813,1],[2820,2],[2961,2],[2983,1],[2995,1],[3007,1],[3034,1],[3046,1],[3058,1],[3084,1],[3096,1],[3108,1]]},"89":{"position":[[7,1],[43,1],[108,3],[149,2],[202,1],[262,2],[321,1],[360,1],[367,1],[378,1],[418,1],[464,1],[486,2],[489,1],[518,1],[520,2],[568,1],[596,2],[709,1],[721,2],[833,1],[846,2],[904,2],[972,2],[998,1],[1012,2],[1079,2],[1133,1],[1146,1],[1151,2],[1201,1],[1218,1],[1246,1],[1276,1],[1400,1],[1418,1],[1488,1],[1490,1],[1515,1],[1517,2],[1550,2],[1598,2],[1656,2],[1669,1],[1694,1],[1712,1],[1761,1],[1784,1],[1802,1],[1863,1],[1879,1],[1887,1],[1889,1]]},"91":{"position":[[7,1],[33,2],[100,2],[136,1],[201,3],[242,2],[276,1],[390,2],[464,1],[487,1],[493,2],[538,1],[550,2],[640,1],[654,2],[722,2],[725,1],[763,3]]},"93":{"position":[[7,1],[33,3],[37,1],[98,2],[111,1],[153,3],[194,2],[238,1],[317,1],[355,1],[408,2],[507,2],[610,2],[643,2],[663,1],[665,1],[820,1],[837,1],[853,1],[868,1],[916,1],[924,1],[939,1],[966,1],[1000,1],[1007,1],[1009,2],[1064,1],[1111,1],[1134,1],[1141,1],[1143,1],[1145,2],[1164,1],[1209,1],[1334,1],[1370,1],[1397,3],[1419,1],[1449,1],[1483,1],[1531,2],[1534,1],[1582,3]]},"95":{"position":[[7,1],[43,1],[108,3],[167,1],[205,1],[225,2],[285,1],[299,2],[336,1],[356,1],[441,1],[470,1],[484,1],[498,1],[506,2],[538,1],[612,1],[628,1],[642,1],[656,1],[678,1],[704,1],[873,2],[946,1],[1061,1],[1140,1],[1153,1],[1166,1],[1180,1],[1185,2],[1210,1],[1275,1],[1347,3],[1369,1],[1385,1],[1398,1],[1411,1],[1470,2],[1551,1],[1573,1],[1636,1],[1638,2],[1715,1],[1737,1],[1801,1],[1803,2],[1835,1],[1896,1],[1920,1],[1935,1],[1940,2],[2027,1],[2124,3],[2128,2],[2183,1],[2187,1],[2200,1],[2241,1],[2248,1],[2255,1]]},"97":{"position":[[7,1],[33,3],[37,1],[158,1],[280,1],[301,3],[315,1],[380,3],[511,1],[530,1],[556,1],[587,3],[662,1],[694,1],[740,1],[745,2],[828,2],[897,1],[1056,2],[1157,2],[1229,1],[1240,1],[1268,1],[1291,1],[1347,1],[1413,1],[1468,1],[1479,1],[1506,1],[1641,3],[1652,1],[1695,1],[1709,1],[1719,1],[1790,1],[1828,1],[1872,2],[1885,1],[1905,1],[1941,1],[1999,1],[2046,1],[2073,1],[2080,1],[2088,1],[2132,1],[2152,1],[2169,1],[2176,1],[2188,1],[2197,1],[2201,1],[2210,1],[2224,1],[2349,1],[2358,1],[2368,1],[2374,1],[2380,1],[2400,1],[2426,1],[2438,1],[2461,1],[2489,1],[2496,1],[2505,1],[2514,1],[2516,1],[2531,1],[2548,1],[2550,2],[2585,1],[2587,2],[2697,1],[2749,1],[2758,2],[2785,1],[2819,1],[2847,3],[2872,1],[2913,1],[2925,2],[2978,2],[2981,1],[3004,1],[3027,2],[3036,1],[3042,3],[3046,1]]},"99":{"position":[[7,1],[43,1],[85,3],[126,2],[170,1],[249,1],[287,1],[340,2],[468,2],[512,2],[565,1],[567,2],[641,1],[671,1],[693,3],[697,2],[700,3],[712,3],[716,2],[758,2],[790,2],[823,1],[829,2],[866,1],[878,2],[920,1],[922,2],[967,2],[970,1],[1002,2],[1010,1],[1019,3]]},"101":{"position":[[7,1],[43,1],[85,3],[135,1],[224,1],[254,1],[317,1],[414,1],[434,1],[460,1],[518,1],[614,1],[634,1],[660,1],[718,1],[769,1],[822,1],[859,1],[886,1],[909,2],[912,1],[920,2],[947,1],[984,1],[1020,1],[1025,1],[1058,1],[1063,1],[1080,3]]},"103":{"position":[[7,1],[65,2],[143,2],[222,2],[258,1],[323,3],[364,2],[436,2],[512,2],[591,2],[652,2],[655,2],[725,2],[789,1],[805,1],[816,2],[880,1],[904,2],[991,1],[1012,2],[1081,2],[1105,1],[1145,2],[1206,2],[1251,1],[1264,2],[1267,1],[1269,2],[1381,2],[1486,2],[1552,2],[1576,1],[1627,2],[1630,2],[1693,1],[1794,2],[1797,1],[1832,2],[1863,3],[1882,1],[1894,1],[1896,2],[1932,1],[1963,1],[1965,2],[2034,1],[2106,1],[2108,2],[2158,1],[2180,1],[2335,2],[2338,1],[2340,2],[2391,1],[2443,1],[2445,2],[2496,1],[2545,1],[2594,1],[2647,1],[2676,2],[3069,1],[3071,2],[3141,1],[3271,1],[3273,1],[3275,2],[3308,1],[3347,2],[3463,2],[3533,2],[3536,2],[3579,1],[3599,2],[3668,1],[3677,1],[3681,1],[3688,2],[3718,1],[3734,1],[3752,1],[3759,2],[3827,2],[3871,1],[3890,1],[3923,1],[3994,2],[4052,2],[4097,1],[4154,1],[4166,2],[4192,1],[4234,2],[4237,1],[4239,2],[4279,1],[4291,2],[4325,1],[4338,2],[4404,2],[4407,1],[4422,1],[4444,1],[4494,2],[4504,1],[4511,3],[4515,2],[4588,2],[4591,1],[4610,3],[4617,1],[4653,1],[4667,1],[4674,1],[4707,1],[4720,1],[4722,3],[4726,3],[4766,1],[4821,2],[4824,1],[4852,4],[4869,3],[4891,1],[4947,1],[4974,3],[4992,1],[5013,1],[5107,2],[5110,1],[5125,1],[5142,1],[5161,1],[5182,1],[5199,1],[5218,1],[5243,1],[5285,3],[5307,1],[5415,1],[5421,1],[5462,1],[5468,1],[5496,1],[5551,2],[5554,2]]},"105":{"position":[[7,1],[43,1],[85,3],[146,1],[174,1],[243,1],[263,1],[322,1],[332,1],[355,1],[365,1],[370,2],[387,1],[389,3],[404,1],[411,1],[422,1],[437,1],[566,1],[582,1],[592,1],[610,1],[632,1],[664,1],[680,1],[705,1],[721,1],[757,1],[773,1],[797,1],[879,1],[906,1],[1006,1],[1123,1],[1174,1],[1208,1],[1262,1],[1368,1],[1412,1],[1483,1],[1513,1],[1543,1],[1683,1],[1698,1],[1847,1],[1859,1],[1882,2],[1885,1],[1893,2],[1913,1],[1920,1],[1943,1],[1958,1],[1989,2],[2009,1],[2026,2],[2056,1],[2081,2],[2111,1],[2143,1],[2173,1],[2193,1],[2213,1],[2231,1],[2238,2],[2291,1],[2303,1],[2314,2],[2331,1],[2351,1],[2362,1],[2378,1],[2390,1],[2406,1],[2421,1],[2433,1],[2444,2],[2462,1],[2482,1],[2493,1],[2510,1],[2522,1],[2539,1],[2541,1],[2543,3]]},"107":{"position":[[7,1],[43,1],[85,3],[146,1],[167,1],[255,1],[274,1],[284,1],[304,1],[322,1],[378,1],[414,1],[433,1],[450,1],[470,1],[489,1],[625,1],[758,1],[890,1],[1048,1],[1070,1],[1087,1],[1122,2],[1125,2],[1128,1],[1138,1],[1168,1],[1178,1],[1189,1],[1197,3],[1212,1],[1261,1],[1270,1],[1342,3],[1353,1],[1386,1],[1441,2],[1444,1],[1458,2],[1485,1],[1509,2],[1534,2],[1557,1],[1561,1],[1579,1],[1601,1],[1605,1],[1623,1],[1637,2],[1651,1],[1660,1],[1662,1],[1682,1],[1700,1],[1715,1],[1744,1],[1762,1],[1779,1],[1796,1],[1801,1],[1816,1],[1833,1],[1849,1],[1866,1],[1872,3]]},"109":{"position":[[7,1],[43,1],[102,3],[163,1],[193,1],[222,1],[245,2],[341,2],[555,2],[662,2],[934,2],[1028,2],[1275,2],[1318,1],[1376,1],[1382,1],[1395,1],[1401,1],[1416,1],[1421,2],[1480,1],[1515,2],[1518,2],[1521,1],[1556,1],[1576,1],[1622,1],[1643,1],[1689,1],[1710,1],[1731,1],[1752,1],[1773,1],[1794,1],[1801,2],[1804,3],[1826,2],[1829,1],[1837,2],[1944,1],[1962,1],[1973,1],[1991,1],[2015,1],[2033,1],[2044,1],[2062,1],[2086,1],[2104,1],[2114,1],[2132,1],[2157,1],[2175,1],[2185,1],[2203,1],[2228,1],[2246,1],[2257,1],[2275,1],[2316,1],[2324,1],[2331,3]]},"111":{"position":[[7,1],[75,1],[134,3],[190,1],[213,2],[313,2],[326,1],[465,2],[478,1],[618,2],[757,2],[790,2],[960,2],[970,1],[1109,2],[1119,1],[1259,2],[1270,1],[1414,2],[1644,2],[1813,2],[1948,2],[2085,2],[2222,2],[2249,1]]},"147":{"position":[[7,1],[43,1],[102,3],[163,1],[184,1],[272,1],[291,1],[301,1],[321,1],[366,1],[402,1],[421,1],[438,1],[458,1],[463,2],[503,1],[610,1],[715,1],[819,1],[984,2],[1027,1],[1085,1],[1104,1],[1117,1],[1137,1],[1177,1],[1196,1],[1228,2],[1231,2],[1234,1],[1257,1],[1274,1],[1283,1],[1290,1],[1307,1],[1315,1],[1317,3],[1332,1],[1381,1],[1390,1],[1462,3],[1473,1],[1506,1],[1556,2],[1559,1],[1573,2],[1600,1],[1624,2],[1649,2],[1672,1],[1676,1],[1694,1],[1716,1],[1720,1],[1738,1],[1752,2],[1825,1],[1843,1],[1854,1],[1872,1],[1896,1],[1914,1],[1925,1],[1943,1],[1967,1],[1985,1],[1995,1],[2013,1],[2038,1],[2056,1],[2066,1],[2084,1],[2106,1],[2114,1],[2121,3]]},"149":{"position":[[7,1],[43,1],[102,3],[156,1],[219,2],[222,2],[238,4],[243,2],[317,1],[500,1],[526,1],[575,1],[702,1],[726,1],[760,2],[763,2],[781,4],[802,1],[990,1],[1018,1],[1070,1],[1155,3],[1230,1],[1256,1],[1292,2],[1295,2],[1302,4],[1317,1],[1404,1],[1441,2],[1444,2],[1453,4],[1469,1],[1549,1],[1562,1],[1572,1],[1604,2],[1607,2],[1616,4],[1632,1],[1714,3],[1743,1],[1758,1],[1768,1],[1800,2],[1803,1],[1810,4],[1833,1],[2149,2],[2152,2],[2174,4],[2198,1],[2288,3]]},"151":{"position":[[7,1],[43,1],[85,3],[146,1],[174,1],[240,1],[344,1],[358,1],[390,1],[480,2],[565,1],[616,1],[702,1],[736,1],[806,1],[857,1],[890,1],[914,2],[917,1],[919,2],[994,2],[1089,2],[1199,1],[1227,1],[1250,1],[1255,1],[1257,3]]},"153":{"position":[[7,1],[43,1],[85,3],[141,1],[196,2],[218,1],[231,2],[250,2],[280,2],[291,2],[342,2],[371,2],[385,2],[406,2],[417,2],[504,1],[697,1],[704,1],[724,1],[749,1],[769,1],[814,3],[904,1],[919,1],[947,2],[950,1],[952,2],[955,1],[1036,3],[1051,1],[1183,2],[1186,1],[1202,2],[1211,3]]},"155":{"position":[[7,1],[43,1],[85,3],[141,1],[186,1],[234,1],[265,1],[289,1],[310,1],[328,1],[386,1],[402,1],[499,1],[515,1],[537,2],[618,1],[634,1],[650,1],[671,2],[685,1],[692,1],[723,1],[746,1],[750,1],[766,1],[807,1],[812,1],[816,1],[849,1],[854,1],[898,1],[903,1],[947,1],[952,1],[969,1],[984,1],[1190,1],[1197,1],[1218,1],[1243,1],[1263,1],[1276,1],[1306,3],[1367,1],[1382,1],[1401,1],[1403,3],[1423,1],[1546,2],[1549,1],[1570,2],[1579,3]]},"157":{"position":[[7,1],[43,1],[85,3],[146,1],[167,1],[265,1],[357,1],[449,1],[463,1],[481,1],[535,1],[581,1],[592,1],[619,1],[636,1],[663,1],[671,1],[691,2],[694,1],[703,2],[726,1],[740,2],[763,1],[802,1],[807,1],[818,1],[820,3]]},"159":{"position":[[7,1],[43,1],[85,3],[126,2],[160,1],[215,2],[237,1],[250,2],[269,2],[299,2],[310,2],[361,2],[390,2],[404,2],[425,2],[436,2],[512,1],[514,1],[688,1],[695,1],[715,1],[740,1],[760,1],[805,3],[827,1],[829,1],[975,2],[1076,2],[1148,1],[1159,1],[1187,1],[1210,1],[1280,1],[1335,1],[1346,1],[1373,1],[1508,3],[1519,1],[1562,1],[1576,1],[1586,1],[1638,1],[1676,1],[1720,2],[1733,1],[1753,1],[1789,1],[1847,1],[1894,1],[1921,1],[1928,1],[1936,1],[1980,1],[2000,1],[2017,1],[2024,1],[2036,1],[2045,1],[2049,1],[2058,1],[2072,1],[2197,1],[2206,1],[2216,1],[2222,1],[2228,1],[2248,1],[2274,1],[2286,1],[2309,1],[2337,1],[2344,1],[2353,1],[2362,1],[2364,1],[2379,1],[2396,3],[2415,1],[2417,1],[2494,2],[2497,2],[2585,1],[2645,1],[2654,2],[2701,1],[2766,1],[2875,2],[2909,1],[2937,2],[2940,1],[2947,2],[2952,1],[2984,1],[3030,1],[3056,1],[3064,1],[3070,3]]},"161":{"position":[[7,1],[43,1],[85,3],[141,1],[196,2],[218,1],[231,2],[250,2],[280,2],[291,2],[342,2],[371,2],[385,2],[406,2],[417,2],[493,1],[548,2],[570,1],[576,1],[589,2],[601,1],[614,2],[626,1],[639,2],[650,2],[701,2],[730,2],[744,2],[759,2],[770,2],[837,1],[896,1],[1089,1],[1096,1],[1116,1],[1141,1],[1161,1],[1206,3],[1296,1],[1311,1],[1339,2],[1342,1],[1344,2],[1347,1],[1428,3],[1443,1],[1576,2],[1579,1],[1595,2],[1604,3]]},"163":{"position":[[7,1],[43,1],[85,3],[141,1],[196,2],[218,1],[231,2],[250,2],[269,2],[280,2],[331,2],[360,2],[374,2],[389,2],[401,2],[444,1],[638,1],[645,1],[665,1],[690,1],[710,1],[755,3],[851,1],[866,1],[902,1],[904,3],[923,1],[974,1],[1061,4],[1082,1],[1133,1],[1214,4],[1235,1],[1286,1],[1373,4],[1601,2],[1604,1],[1624,2],[1653,1],[1681,1],[1690,3]]},"165":{"position":[[7,1],[43,1],[98,3],[139,2],[173,1],[228,2],[257,2],[273,2],[300,2],[311,2],[362,2],[391,2],[405,2],[426,2],[437,2],[497,2],[563,1],[565,1],[739,1],[746,1],[766,1],[791,1],[811,1],[856,3],[860,2],[934,1],[995,2],[1050,1],[1052,1],[1130,1],[1219,1],[1252,1],[1282,1],[1322,1],[1364,1],[1376,1],[1389,1],[1395,1],[1404,1],[1427,1],[1439,3],[1462,1],[1464,1],[1476,2],[1496,1],[1558,2],[1602,2],[1705,1],[1759,3],[1778,1],[1837,1],[1895,2],[1976,1],[1978,1],[2104,1],[2140,1],[2196,1],[2234,1],[2268,2],[2296,1],[2322,1],[2331,3],[2356,1],[2358,1],[2403,2],[2425,1],[2511,1],[2565,3],[2586,1],[2649,1],[2711,2],[2780,1],[2782,1],[2886,1],[2900,1],[2934,1],[2969,1],[2984,3],[3008,1],[3010,1],[3046,2],[3067,1],[3150,1],[3204,3],[3224,1],[3285,1],[3345,2],[3383,1],[3385,1],[3488,1],[3551,1],[3589,1],[3666,2],[3744,2],[3823,2],[3904,2],[3979,1],[4001,3],[4024,1],[4026,1],[4054,2],[4074,1],[4154,1],[4208,3],[4227,1],[4286,1],[4344,2],[4395,1],[4397,1],[4539,1],[4575,1],[4616,1],[4655,1],[4696,1],[4725,3],[4751,1],[4753,1],[4827,2],[4850,1],[4936,1],[5164,2],[5409,2],[5443,1],[5471,2],[5474,1],[5481,2],[5486,1],[5492,2],[5525,1],[5581,1],[5620,1],[5660,1],[5676,1],[5683,1],[5690,1],[5697,2],[5765,1],[5794,3],[5830,1],[5861,3],[5896,1],[5926,3],[5960,1],[5989,3],[5993,3]]},"167":{"position":[[7,1],[43,1],[85,3],[141,1],[196,2],[218,1],[231,2],[250,2],[269,2],[299,2],[328,2],[342,2],[358,2],[379,1],[572,1],[579,1],[599,1],[624,1],[644,1],[689,3],[779,1],[794,1],[824,1],[826,2],[829,1],[910,3],[928,1],[1121,1],[1128,1],[1148,1],[1173,1],[1193,1],[1238,3],[1328,1],[1343,1],[1388,2],[1415,1],[1424,1],[1431,1],[1452,2],[1479,1],[1488,1],[1495,1],[1501,1],[1503,2],[1506,1],[1587,3],[1606,1],[1657,1],[1871,2],[1874,1],[1894,2],[1923,1],[1932,3]]},"169":{"position":[[7,1],[43,1],[85,3],[136,1],[141,2],[175,1],[194,1],[196,3],[211,1],[218,1],[229,1],[260,1],[279,1],[293,1],[390,1],[405,1],[447,1],[474,1],[489,1],[523,2],[560,2],[563,1],[571,2],[579,2],[608,1],[615,1],[637,1],[651,1],[665,1],[672,1],[681,1],[699,1],[703,1],[716,1],[730,1],[737,1],[746,1],[752,1],[770,3],[798,1],[884,1],[891,1],[913,1],[951,1],[964,1],[971,1],[993,1],[1075,1],[1077,1]]},"171":{"position":[[7,1],[43,1],[85,3],[141,1],[196,1],[241,1],[394,1],[408,1],[433,1],[453,1],[498,3],[540,1],[555,1],[583,1],[585,3],[604,1],[725,2],[728,1],[748,2],[757,3]]},"173":{"position":[[7,1],[43,1],[85,3],[141,1],[196,2],[218,1],[231,2],[250,2],[269,2],[280,2],[333,2],[365,2],[385,2],[406,2],[420,2],[471,2],[500,2],[514,2],[529,2],[541,2],[586,1],[588,1],[806,1],[813,1],[828,1],[850,1],[875,1],[895,1],[940,3],[962,1],[964,1],[1072,1],[1087,1],[1116,1],[1137,3],[1156,1],[1158,1],[1238,2],[1254,1],[1323,1],[1467,2],[1470,1],[1490,2],[1499,3]]},"175":{"position":[[7,1],[43,1],[85,3],[141,1],[196,2],[218,1],[230,2],[248,2],[269,2],[280,2],[333,2],[365,2],[385,2],[406,2],[421,2],[463,1],[660,1],[669,1],[691,1],[716,1],[736,1],[781,3],[844,1],[859,1],[880,1],[882,3],[901,1],[1045,2],[1048,1],[1068,2],[1077,3]]},"177":{"position":[[7,1],[43,1],[85,3],[126,2],[169,1],[176,2],[210,1],[295,2],[298,1],[317,1],[399,1],[437,1],[471,1],[533,1],[552,1],[599,1],[655,1],[690,1],[702,1],[715,1],[727,1],[747,1],[836,1],[907,1],[936,1],[966,1],[1016,2],[1019,1],[1038,1],[1069,1],[1091,1],[1123,1],[1128,3],[1132,3]]},"179":{"position":[[7,1],[43,1],[85,3],[141,1],[196,2],[218,1],[231,2],[250,2],[280,2],[291,2],[342,2],[371,2],[385,2],[406,2],[417,2],[493,1],[495,1],[669,1],[676,1],[696,1],[721,1],[741,1],[786,3],[808,1],[810,1],[917,1],[932,1],[960,1],[973,1],[984,1],[991,1],[993,1],[999,2],[1002,3],[1021,1],[1023,1],[1113,2],[1129,1],[1194,1],[1303,2],[1328,2],[1386,2],[1389,1],[1405,2],[1440,2],[1448,3]]},"181":{"position":[[7,1],[43,1],[103,3],[237,2],[240,1],[242,2],[298,1],[300,3],[318,1],[325,1],[336,1],[353,1],[392,1],[434,1],[510,3],[514,1],[530,1],[535,2],[578,1],[682,1],[696,1],[730,1],[742,1],[762,1],[806,2],[849,1],[940,1],[960,1],[974,1],[986,1],[1006,1],[1050,2],[1082,3]]},"183":{"position":[[7,1],[43,1],[103,3],[218,2],[221,1],[223,2],[288,1],[290,3],[308,1],[315,1],[326,1],[342,1],[388,1],[433,1],[442,1],[449,1],[460,1],[462,2],[516,1],[574,1],[590,1],[622,1],[638,1],[705,1],[721,1],[757,1],[773,1],[817,1],[822,1],[859,1],[861,2],[893,3]]},"185":{"position":[[7,1],[33,2],[122,1],[169,1],[218,1],[288,3],[343,1],[398,2],[436,1],[496,2],[539,1],[546,1],[557,1],[571,1],[630,1],[635,1],[640,1],[654,1],[669,1],[674,1],[707,1],[709,2],[753,1],[772,1],[789,1],[809,1],[814,2],[886,1],[904,1],[927,1],[946,1],[951,2],[1003,2],[1006,1],[1008,2],[1033,2],[1104,1],[1111,1],[1120,3]]},"187":{"position":[[7,1],[43,1],[108,3],[149,2],[203,1],[262,2],[321,2],[376,1],[395,1],[408,1],[428,1],[460,2],[512,2],[515,1],[517,2],[566,2],[611,2],[670,2],[677,1],[686,3]]},"189":{"position":[[7,1],[43,1],[108,3],[162,1],[184,1],[268,1],[330,2],[387,1],[415,2],[477,2],[536,1],[555,1],[572,1],[592,1],[628,2],[679,1],[708,1],[748,2],[751,2],[754,1],[765,1],[778,2],[828,1],[839,1],[849,1],[866,3],[888,2],[891,1],[912,2],[921,3]]},"191":{"position":[[7,1],[43,1],[108,3],[227,2],[230,1],[253,1],[317,1],[369,2],[372,2],[392,1],[415,1],[458,3]]},"193":{"position":[[7,1],[43,1],[85,3],[126,2],[179,1],[237,2],[263,3],[267,1],[310,1],[372,2],[394,1],[465,2],[512,1],[535,2],[538,1],[546,2],[581,1],[585,1],[629,1],[633,1],[680,2],[714,2],[720,3]]},"195":{"position":[[7,1],[43,1],[105,3],[146,2],[219,1],[380,2],[412,1],[448,1],[462,1],[500,1],[505,2],[560,1],[586,1],[599,2],[647,2],[706,2],[764,2],[821,2],[883,2],[945,2],[1006,2],[1096,1],[1098,2],[1149,2],[1201,1],[1261,2],[1347,1],[1375,2],[1418,1],[1457,1],[1511,1]]},"197":{"position":[[7,1],[43,1],[108,3],[228,2],[231,1],[233,2],[296,1],[298,3],[313,1],[320,1],[331,1],[343,1],[347,1],[352,1],[362,1],[367,2],[500,1],[502,2],[582,2],[596,1],[631,2],[634,1],[699,1],[758,2],[768,1],[787,1],[799,1],[819,1],[866,1],[912,2],[954,2],[957,1],[973,2],[982,3],[986,3]]},"199":{"position":[[7,1],[43,1],[108,3],[149,2],[215,1],[217,1],[227,1],[252,2],[264,1],[274,2],[277,2],[280,2],[298,2],[301,2],[351,1],[362,1],[405,1],[437,3],[450,1],[460,1],[534,1],[564,1],[582,1],[662,5],[668,2],[686,2],[705,1],[707,2],[776,1],[844,1],[913,1],[915,2],[984,1]]},"201":{"position":[[7,1],[33,2],[67,1],[91,1],[110,2],[153,2],[306,1],[322,1],[324,2],[376,2],[429,1],[472,1],[480,1],[488,1],[490,1],[498,2],[541,1],[550,1],[552,1],[560,2],[576,2],[659,1],[708,1],[731,1],[751,1],[788,1],[986,1],[1028,2],[1083,2],[1144,1],[1170,1],[1180,2],[1229,2],[1296,1],[1301,1],[1303,1],[1513,1],[1515,1],[1527,1],[1586,3],[1649,1],[1697,2],[1765,2],[1833,2],[1925,1],[1975,1],[2054,1],[2064,1]]},"203":{"position":[[7,1],[43,1],[108,3],[165,1],[216,1],[234,1],[284,1],[413,2],[554,1],[637,3],[656,1],[752,1],[769,1],[822,1],[1115,3],[1134,1],[1251,1],[1269,1]]},"205":{"position":[[7,1],[43,1],[108,3],[149,2],[208,1],[499,3],[543,2],[546,1],[560,1],[652,4],[669,1],[755,4],[772,1],[877,4],[894,1],[990,4],[1003,1],[1018,1],[1033,1],[1148,3]]},"207":{"position":[[7,1],[43,1],[85,3],[142,1],[144,1],[198,2],[201,2],[318,1],[377,1],[438,1],[455,2],[543,1],[578,2],[613,1],[635,1],[672,2],[743,1],[784,1],[808,1],[851,2],[898,1],[900,1],[1270,2],[1273,2],[1313,1],[1315,3],[1319,2],[1405,1],[1412,1],[1423,1],[1436,1],[1464,1],[1490,1],[1506,1],[1526,1],[1542,1],[1626,1],[1628,2],[1660,1],[1683,2],[1686,1],[1699,1],[1706,1],[1727,1],[1729,2],[1760,1],[1786,2],[1794,1],[1802,2],[1811,2],[1831,3],[1846,1],[1877,1],[1910,1],[1918,2],[1962,1],[1979,2],[2022,1],[2055,1],[2073,1],[2081,2],[2116,2],[2211,1],[2258,3],[2262,3]]},"209":{"position":[[7,1],[33,2],[73,2],[181,1],[240,3],[310,1],[312,2],[399,1],[419,1],[468,1],[493,1],[508,1],[535,2],[584,1],[784,1],[857,1],[877,1],[913,1],[992,1],[1002,1],[1020,1],[1041,1]]},"211":{"position":[[7,1],[43,1],[85,3],[201,2],[204,1],[206,2],[248,1],[270,1],[302,1],[314,1],[330,1],[340,1],[364,1],[386,1],[418,1],[442,1],[465,1],[494,1],[502,1],[504,1],[526,1],[599,1],[638,1],[642,3],[649,1],[666,1],[734,1],[741,1],[743,2],[770,2],[872,1],[969,1],[1002,1],[1018,1],[1037,1],[1042,1],[1061,1],[1081,1],[1085,1],[1102,1],[1121,1],[1125,1],[1142,1],[1162,1],[1166,1],[1171,2],[1214,1],[1221,1],[1232,1],[1234,2],[1290,1],[1319,1],[1323,1],[1327,1],[1331,1],[1341,1],[1345,1],[1365,1],[1385,1],[1392,2],[1418,1],[1428,1],[1436,1],[1441,1],[1454,1],[1464,1],[1472,1],[1477,1],[1481,1],[1524,1],[1548,1],[1575,1],[1652,3],[1663,1],[1680,1],[1721,1],[1723,3]]},"244":{"position":[[7,1],[43,1],[108,3],[165,1],[234,1],[305,1],[312,1],[323,1],[337,1],[373,1],[378,1],[383,1],[397,1],[412,1],[417,1],[438,1],[454,1],[465,1],[498,1],[509,1],[615,3],[632,1],[664,1],[680,1],[714,2],[717,1],[787,1],[885,1],[911,1],[1004,2],[1019,1],[1038,1],[1062,2],[1065,1],[1098,1],[1118,3],[1122,3]]},"258":{"position":[[7,1],[43,1],[85,3],[136,1],[141,2],[175,1],[181,1],[200,1],[202,3],[217,1],[224,1],[235,1],[266,1],[285,1],[299,1],[396,1],[425,1],[466,1],[490,1],[526,1],[621,2],[624,1],[632,2],[640,2],[669,1],[676,1],[698,1],[712,1],[726,1],[733,1],[742,1],[760,1],[764,1],[777,1],[791,1],[798,1],[807,1],[813,1],[815,3]]}}}],["0",{"_index":152,"t":{"41":{"position":[[2369,3],[2536,2],[2542,1],[3219,1],[3348,1],[3882,1],[3940,2]]},"43":{"position":[[246,2]]},"45":{"position":[[644,2]]},"47":{"position":[[509,2],[610,2],[664,4],[999,2],[1005,1],[1364,2],[1754,2],[1761,2]]},"49":{"position":[[271,2],[327,2],[346,2],[450,2],[532,2],[538,2],[544,2],[1130,1],[1134,1],[1388,2]]},"53":{"position":[[876,2],[1030,2],[1051,2],[1112,2],[1133,2],[1196,2],[1914,2],[3228,2],[3682,2],[4007,2],[4165,1],[5062,2],[5390,2]]},"63":{"position":[[394,2],[714,2],[1321,2]]},"65":{"position":[[459,2],[1318,1],[1829,2]]},"67":{"position":[[363,2]]},"69":{"position":[[878,2],[1398,2],[1414,2],[1499,2],[1598,2],[1619,1],[1623,1],[1818,2],[1980,3],[2468,2],[2791,2],[3623,2],[3726,1],[3985,3],[4022,2],[4075,3],[4736,2],[4980,2],[5385,2],[6094,3],[6107,3],[6111,3],[6124,3],[6204,2],[6317,2],[6402,2],[6501,2],[6522,1],[6526,1],[6941,3],[7016,2],[7249,3],[7655,2],[7663,2],[7836,2],[7979,2],[8839,1],[9028,2],[9248,1],[9268,1]]},"71":{"position":[[480,2],[580,2]]},"73":{"position":[[211,2],[910,1],[948,1],[1680,2]]},"77":{"position":[[85,2]]},"79":{"position":[[431,2],[1106,1],[1617,2],[1713,2]]},"81":{"position":[[1120,2]]},"83":{"position":[[784,2]]},"85":{"position":[[701,2]]},"87":{"position":[[790,2],[856,2],[2029,2],[2095,2]]},"89":{"position":[[362,2]]},"91":{"position":[[408,2]]},"95":{"position":[[412,2],[596,2],[1439,3]]},"97":{"position":[[742,2],[1487,3],[1665,3],[1869,2],[2154,3],[2171,2],[2396,3]]},"101":{"position":[[888,2]]},"103":{"position":[[3439,2],[3513,2],[3529,3],[3662,2],[3720,2],[4857,5],[4922,3],[4938,3],[4942,4],[5144,3],[5163,5],[5201,3],[5220,5],[5329,3],[5333,2]]},"105":{"position":[[406,2],[1861,2],[1915,2]]},"107":{"position":[[1072,2]]},"109":{"position":[[797,2],[1418,2]]},"147":{"position":[[1198,2]]},"149":{"position":[[395,3],[882,3]]},"151":{"position":[[1103,1],[1252,2]]},"153":{"position":[[364,3],[368,2],[382,2],[399,2],[466,2]]},"155":{"position":[[193,2],[201,2],[204,2],[529,2],[687,2],[809,2]]},"159":{"position":[[383,3],[387,2],[401,2],[418,2],[485,2],[1354,3],[1532,3],[1717,2],[2002,3],[2019,2],[2244,3],[2491,2],[2911,2]]},"161":{"position":[[364,3],[368,2],[382,2],[399,2],[466,2],[723,3],[727,2],[741,2]]},"163":{"position":[[353,3],[357,2],[371,2]]},"165":{"position":[[250,3],[254,2],[270,2],[291,2],[384,3],[388,2],[402,2],[419,2],[486,2],[2380,2],[4051,2],[5445,2]]},"167":{"position":[[321,3],[325,2],[339,2]]},"169":{"position":[[138,2],[213,2],[274,4],[610,2]]},"171":{"position":[[218,2]]},"173":{"position":[[359,2],[362,2],[376,2],[382,2],[396,2],[399,2],[493,3],[497,2],[511,2]]},"175":{"position":[[359,2],[362,2],[376,2],[382,2],[396,2],[399,2]]},"177":{"position":[[679,2]]},"179":{"position":[[364,3],[368,2],[382,2],[399,2],[466,2],[1110,2]]},"181":{"position":[[320,2]]},"183":{"position":[[310,2],[444,2],[824,3]]},"185":{"position":[[541,2]]},"193":{"position":[[514,2]]},"195":{"position":[[85,2],[282,2]]},"197":{"position":[[315,2]]},"201":{"position":[[818,2],[828,3],[1009,2],[1430,2]]},"207":{"position":[[1407,2],[1662,2],[1701,2]]},"209":{"position":[[614,2],[626,3],[807,2]]},"211":{"position":[[646,2],[1044,2],[1087,2],[1127,2],[1168,2],[1216,2],[1483,3]]},"244":{"position":[[307,2]]},"258":{"position":[[138,2],[219,2],[280,4],[671,2]]}}}],["0${i",{"_index":2585,"t":{"197":{"position":[[354,7]]}}}],["0)\\nscreen",{"_index":1883,"t":{"103":{"position":[[4926,11]]}}}],["0,0",{"_index":2286,"t":{"165":{"position":[[1188,3],[3520,3]]},"201":{"position":[[350,5]]}}}],["0.0",{"_index":1514,"t":{"93":{"position":[[956,4]]},"97":{"position":[[2827,4]]},"99":{"position":[[688,4],[825,3]]},"153":{"position":[[803,4]]},"155":{"position":[[1295,4]]},"159":{"position":[[794,4]]},"161":{"position":[[1195,4]]},"163":{"position":[[744,4]]},"165":{"position":[[845,4]]},"167":{"position":[[678,4],[1227,4]]},"171":{"position":[[487,4],[567,4],[572,4]]},"173":{"position":[[929,4]]},"175":{"position":[[256,4],[770,4]]},"179":{"position":[[775,4]]},"201":{"position":[[873,7]]},"209":{"position":[[671,7]]}}}],["0.001",{"_index":1624,"t":{"97":{"position":[[1491,7],[2351,6]]},"159":{"position":[[1358,7],[2199,6]]}}}],["0.005",{"_index":1724,"t":{"101":{"position":[[923,6]]},"163":{"position":[[1683,6]]},"167":{"position":[[1925,6]]},"193":{"position":[[549,6]]}}}],["0.01",{"_index":183,"t":{"41":{"position":[[2859,5]]},"45":{"position":[[1023,4]]},"63":{"position":[[1399,5],[1516,5]]},"65":{"position":[[1926,5]]},"67":{"position":[[928,4]]},"73":{"position":[[1771,5]]},"79":{"position":[[1865,5]]},"105":{"position":[[2011,5]]},"107":{"position":[[1461,5],[1487,5],[1537,5]]},"147":{"position":[[1576,5],[1602,5],[1652,5]]},"153":{"position":[[1205,5]]},"155":{"position":[[1573,5]]},"161":{"position":[[1598,5]]},"163":{"position":[[1627,5],[1655,5]]},"167":{"position":[[1897,5]]},"171":{"position":[[751,5]]},"173":{"position":[[1493,5]]},"175":{"position":[[1071,5]]},"179":{"position":[[1408,5]]},"185":{"position":[[1106,4]]},"197":{"position":[[976,5]]},"207":{"position":[[1805,5],[2024,5]]}}}],["0.02",{"_index":1976,"t":{"107":{"position":[[1512,5]]},"147":{"position":[[1627,5]]},"189":{"position":[[915,5]]}}}],["0.025",{"_index":447,"t":{"49":{"position":[[308,6]]}}}],["0.04",{"_index":1702,"t":{"99":{"position":[[1005,4]]},"107":{"position":[[1581,5],[1625,5]]},"147":{"position":[[1696,5],[1740,5]]}}}],["0.05",{"_index":60,"t":{"41":{"position":[[413,5]]},"49":{"position":[[393,5]]},"79":{"position":[[1821,5]]},"105":{"position":[[1896,5]]}}}],["0.06",{"_index":2406,"t":{"167":{"position":[[1417,6],[1481,6]]}}}],["0.1",{"_index":879,"t":{"63":{"position":[[1383,4]]},"77":{"position":[[548,4]]},"79":{"position":[[2387,4]]},"107":{"position":[[1640,4]]},"109":{"position":[[1840,4],[2326,4]]},"147":{"position":[[1755,4],[2116,4]]},"157":{"position":[[728,4],[765,4]]},"169":{"position":[[574,4]]},"179":{"position":[[995,3],[1443,4]]},"187":{"position":[[673,3]]},"207":{"position":[[1789,4]]},"258":{"position":[[635,4]]}}}],["0.2",{"_index":1214,"t":{"79":{"position":[[1181,4]]},"103":{"position":[[3449,4]]},"105":{"position":[[2233,4]]},"207":{"position":[[2075,5]]}}}],["0.25",{"_index":777,"t":{"57":{"position":[[758,5]]},"111":{"position":[[1737,6]]}}}],["0.3",{"_index":899,"t":{"65":{"position":[[738,5]]},"73":{"position":[[594,5]]},"79":{"position":[[719,5]]},"105":{"position":[[775,5]]},"169":{"position":[[732,4]]},"203":{"position":[[1203,5]]},"258":{"position":[[793,4]]}}}],["0.35",{"_index":2398,"t":{"165":{"position":[[5685,4]]}}}],["0.4",{"_index":1932,"t":{"105":{"position":[[1545,4]]},"147":{"position":[[1801,5]]},"165":{"position":[[1334,4],[1339,4]]}}}],["0.5",{"_index":210,"t":{"41":{"position":[[4063,5],[4103,5]]},"49":{"position":[[573,4]]},"63":{"position":[[986,4],[1008,4]]},"69":{"position":[[3072,4],[3079,5]]},"71":{"position":[[661,4]]},"89":{"position":[[1696,4]]},"93":{"position":[[1136,4]]},"95":{"position":[[2217,5]]},"97":{"position":[[612,5],[2376,3]]},"109":{"position":[[1097,5],[1920,5]]},"159":{"position":[[2224,3]]},"165":{"position":[[1391,3],[2368,4],[3019,4],[5678,4],[5692,4]]},"167":{"position":[[1426,4],[1490,4]]},"169":{"position":[[667,4]]},"181":{"position":[[684,4]]},"183":{"position":[[775,5]]},"195":{"position":[[257,4]]},"197":{"position":[[868,4]]},"203":{"position":[[1234,5]]},"211":{"position":[[1367,4],[1387,4]]},"258":{"position":[[728,4]]}}}],["0.7",{"_index":456,"t":{"49":{"position":[[601,4]]},"93":{"position":[[968,4]]},"159":{"position":[[3058,5]]}}}],["0.75",{"_index":784,"t":{"57":{"position":[[922,5]]},"95":{"position":[[500,5]]},"103":{"position":[[3643,5]]},"165":{"position":[[4039,5]]}}}],["0.8",{"_index":914,"t":{"65":{"position":[[1267,4]]},"73":{"position":[[1120,4]]},"79":{"position":[[1068,4]]},"105":{"position":[[650,4]]},"109":{"position":[[623,5]]},"165":{"position":[[1294,4],[1299,4]]},"203":{"position":[[901,4]]}}}],["0.87",{"_index":1470,"t":{"91":{"position":[[375,5]]}}}],["0.95",{"_index":1221,"t":{"79":{"position":[[1783,4]]}}}],["0.99",{"_index":186,"t":{"41":{"position":[[2950,5],[2983,6],[3048,5],[3083,6]]}}}],["000000",{"_index":608,"t":{"53":{"position":[[2320,10]]},"203":{"position":[[499,10]]}}}],["004620",{"_index":2717,"t":{"203":{"position":[[1027,10]]}}}],["00ff99",{"_index":601,"t":{"53":{"position":[[2222,11]]},"203":{"position":[[401,11]]}}}],["0123456789",{"_index":2469,"t":{"181":{"position":[[355,11]]}}}],["0x0000ff",{"_index":2010,"t":{"109":{"position":[[976,9]]}}}],["0x00ff00",{"_index":144,"t":{"41":{"position":[[2180,9]]},"69":{"position":[[6883,9]]}}}],["0x1099bb",{"_index":2511,"t":{"185":{"position":[[261,9]]}}}],["0x111111",{"_index":1469,"t":{"91":{"position":[[358,9]]},"203":{"position":[[964,11]]}}}],["0x333333",{"_index":1426,"t":{"87":{"position":[[2997,9]]}}}],["0x3333dd",{"_index":2124,"t":{"149":{"position":[[1510,9]]}}}],["0x33ff00",{"_index":2017,"t":{"109":{"position":[[1182,10]]}}}],["0x666666",{"_index":1427,"t":{"87":{"position":[[3048,9]]}}}],["0x808080",{"_index":1212,"t":{"79":{"position":[[860,9]]}}}],["0xaa0000",{"_index":2095,"t":{"149":{"position":[[618,9]]}}}],["0xaa00bb",{"_index":2119,"t":{"149":{"position":[[1357,9]]}}}],["0xfeeb77",{"_index":2038,"t":{"111":{"position":[[363,9],[1007,9]]}}}],["0xff0000",{"_index":156,"t":{"41":{"position":[[2437,9]]},"69":{"position":[[1895,9],[3927,9],[4690,9],[4942,9]]},"109":{"position":[[613,9],[1880,9]]}}}],["0xff00ff",{"_index":2056,"t":{"111":{"position":[[1694,9]]}}}],["0xffbd01",{"_index":2041,"t":{"111":{"position":[[516,9],[1157,9]]}}}],["0xffc2c2",{"_index":2433,"t":{"169":{"position":[[826,10]]}}}],["0xffd900",{"_index":1989,"t":{"109":{"position":[[327,9]]},"111":{"position":[[1482,9]]}}}],["0xffffff",{"_index":313,"t":{"43":{"position":[[1621,8]]},"63":{"position":[[885,9]]},"69":{"position":[[7626,10],[7793,9]]},"73":{"position":[[773,9]]},"87":{"position":[[3098,9]]},"97":{"position":[[564,9]]},"109":{"position":[[1578,9]]},"111":{"position":[[655,9],[1307,9],[1848,10],[1985,10],[2122,10]]},"149":{"position":[[362,9],[848,9]]}}}],["1",{"_index":159,"t":{"41":{"position":[[2508,2]]},"47":{"position":[[1785,2],[1805,2],[1896,2],[1922,2],[2039,2],[2130,2],[2203,2],[2286,2]]},"49":{"position":[[972,2],[1138,2]]},"53":{"position":[[1894,3],[2000,3],[3490,1],[5288,2],[5464,3],[5536,2],[5724,2],[5743,3]]},"69":{"position":[[200,2],[1905,3],[1934,3],[2146,4],[3937,3],[3966,3],[4660,3],[4700,3],[4952,3],[5090,2],[6099,3],[6103,3],[6115,3],[6121,2],[6893,3],[6922,3],[7083,4],[7803,3],[9258,1],[9278,2]]},"81":{"position":[[1303,3],[1912,2]]},"83":{"position":[[942,3],[2007,2]]},"89":{"position":[[1865,2]]},"91":{"position":[[388,1]]},"95":{"position":[[2166,1],[2172,2]]},"97":{"position":[[1743,2],[1776,4],[2434,3],[2463,3],[2543,4]]},"103":{"position":[[2849,2],[3035,2],[3581,3],[4614,2]]},"105":{"position":[[612,2]]},"107":{"position":[[1559,1],[1603,1]]},"109":{"position":[[337,3],[658,3],[986,3],[1588,3],[1890,3]]},"111":{"position":[[339,1],[373,3],[526,3],[665,3],[901,3],[983,1],[1017,3],[1050,3],[1167,3],[1200,3],[1317,3],[1350,3],[1492,3],[1704,3],[1888,3],[2025,3],[2162,3],[2355,3]]},"147":{"position":[[1674,1],[1718,1]]},"149":{"position":[[372,3],[628,3],[858,3],[1367,3],[1520,3]]},"153":{"position":[[379,2],[393,2],[396,2],[402,3],[460,2]]},"157":{"position":[[804,2]]},"159":{"position":[[398,2],[412,2],[415,2],[421,3],[479,2],[1624,4],[2282,3],[2311,3],[2391,4],[2950,1]]},"161":{"position":[[379,2],[393,2],[396,2],[402,3],[460,2],[738,2],[752,2],[755,3],[813,2]]},"163":{"position":[[368,2],[382,2],[385,3]]},"165":{"position":[[399,2],[413,2],[416,2],[422,3],[480,2],[5484,1]]},"167":{"position":[[336,2],[350,2],[353,4]]},"169":{"position":[[886,2],[966,2]]},"173":{"position":[[355,3],[379,2],[402,3],[508,2],[522,2],[525,3]]},"175":{"position":[[355,3],[379,2],[402,3]]},"177":{"position":[[812,2]]},"179":{"position":[[379,2],[393,2],[396,2],[402,3],[460,2]]},"187":{"position":[[578,1]]},"193":{"position":[[683,2],[717,2]]},"201":{"position":[[399,1],[425,3]]},"209":{"position":[[495,2],[819,3]]},"211":{"position":[[304,2],[940,3],[1347,4]]},"244":{"position":[[612,2]]}}}],["1,1",{"_index":2287,"t":{"165":{"position":[[1207,3],[3539,3]]}}}],["1.,0",{"_index":1648,"t":{"97":{"position":[[1978,9]]},"159":{"position":[[1826,9]]}}}],["1.0",{"_index":1513,"t":{"93":{"position":[[951,4],[961,4],[1129,4]]},"97":{"position":[[2416,5]]},"153":{"position":[[808,5]]},"155":{"position":[[1300,5],[1395,5]]},"159":{"position":[[799,5],[2264,5]]},"161":{"position":[[1200,5]]},"163":{"position":[[749,5]]},"165":{"position":[[850,5],[1304,5],[1344,5]]},"167":{"position":[[683,5],[1232,5]]},"171":{"position":[[492,5],[577,5]]},"173":{"position":[[934,5],[1131,5]]},"175":{"position":[[775,5],[874,5]]},"179":{"position":[[780,5]]}}}],["1.0)).xy",{"_index":2196,"t":{"153":{"position":[[793,9]]},"155":{"position":[[1285,9]]},"159":{"position":[[784,9]]},"161":{"position":[[1185,9]]},"163":{"position":[[734,9]]},"165":{"position":[[835,9]]},"167":{"position":[[668,9],[1217,9]]},"171":{"position":[[477,9]]},"173":{"position":[[919,9]]},"175":{"position":[[760,9]]},"179":{"position":[[765,9]]}}}],["1.1",{"_index":1572,"t":{"95":{"position":[[2243,4]]}}}],["1.2",{"_index":1274,"t":{"81":{"position":[[1782,5]]},"83":{"position":[[1877,5]]}}}],["1.25",{"_index":1189,"t":{"75":{"position":[[860,5],[884,5]]}}}],["1.5",{"_index":1983,"t":{"107":{"position":[[1764,4]]}}}],["10",{"_index":487,"t":{"49":{"position":[[1349,2]]},"53":{"position":[[3349,2]]},"71":{"position":[[272,3],[276,4],[650,3]]},"81":{"position":[[1725,3]]},"83":{"position":[[1820,3]]},"87":{"position":[[2669,3],[2785,3]]},"89":{"position":[[369,3]]},"107":{"position":[[1388,3]]},"147":{"position":[[1508,3]]},"149":{"position":[[1127,3]]},"151":{"position":[[704,3]]},"165":{"position":[[1472,3],[5009,4],[5048,4]]},"169":{"position":[[1057,4]]},"181":{"position":[[327,3]]},"195":{"position":[[295,3]]},"197":{"position":[[349,2]]},"203":{"position":[[996,3]]}}}],["100",{"_index":138,"t":{"41":{"position":[[2068,4],[2099,4],[2130,4],[2156,4],[2391,4],[2415,4],[3260,5],[3390,5],[3721,4],[3752,4]]},"43":{"position":[[1609,4]]},"47":{"position":[[447,4]]},"63":{"position":[[721,4],[1328,4]]},"65":{"position":[[1567,4]]},"69":{"position":[[512,4],[2410,4],[3404,4],[4365,4],[7658,4],[7839,4],[7844,4]]},"71":{"position":[[291,4],[306,4]]},"73":{"position":[[1420,4]]},"79":{"position":[[413,4],[1216,4],[1434,4]]},"85":{"position":[[905,4]]},"87":{"position":[[793,4],[2032,4]]},"93":{"position":[[1235,4]]},"97":{"position":[[2178,4]]},"101":{"position":[[662,4]]},"103":{"position":[[3508,4],[3673,3],[3873,4],[3945,4],[4506,4]]},"105":{"position":[[245,4]]},"109":{"position":[[429,5],[805,5],[1017,4],[1022,5],[1133,5],[1969,3],[2040,3],[2110,3],[2181,3],[2253,3]]},"111":{"position":[[282,4],[287,5],[434,4],[439,5],[587,4],[592,5],[731,5],[1778,4],[1783,4]]},"147":{"position":[[1850,3],[1921,3],[1991,3],[2062,3]]},"149":{"position":[[474,5],[678,5],[907,5],[963,5],[1185,4],[1205,5],[1384,4]]},"151":{"position":[[346,4],[360,4]]},"153":{"position":[[220,4],[226,4],[239,4],[245,4],[258,4],[263,4],[269,4],[274,5]]},"155":{"position":[[188,4],[196,4]]},"159":{"position":[[239,4],[245,4],[258,4],[264,4],[277,4],[282,4],[288,4],[293,5],[2026,4]]},"161":{"position":[[220,4],[226,4],[239,4],[245,4],[258,4],[263,4],[269,4],[274,5],[572,3],[578,4],[584,4],[597,3],[603,4],[609,4],[622,3],[628,4],[633,5]]},"163":{"position":[[220,4],[226,4],[239,4],[245,4],[258,4],[263,5],[1462,5]]},"167":{"position":[[220,4],[226,4],[239,4],[245,4],[258,4],[263,5]]},"171":{"position":[[198,4],[208,4],[221,6]]},"173":{"position":[[220,4],[226,4],[239,4],[245,4],[258,4],[263,5]]},"175":{"position":[[220,4],[238,4]]},"177":{"position":[[171,4]]},"179":{"position":[[220,4],[226,4],[239,4],[245,4],[258,4],[263,4],[269,4],[274,5]]},"187":{"position":[[594,4]]},"195":{"position":[[285,4],[290,4]]},"201":{"position":[[2032,5]]},"203":{"position":[[236,4]]},"209":{"position":[[970,5]]},"244":{"position":[[1021,4]]}}}],["100.0",{"_index":2445,"t":{"175":{"position":[[261,7]]}}}],["100.0*sin(uv.x*0.5+time*0.5)*amplitude*1.2",{"_index":2350,"t":{"165":{"position":[[3769,44]]}}}],["1000",{"_index":443,"t":{"49":{"position":[[251,5],[794,4]]},"97":{"position":[[2498,6]]},"159":{"position":[[2346,6]]}}}],["10000",{"_index":1207,"t":{"79":{"position":[[405,5]]}}}],["1099bb",{"_index":374,"t":{"47":{"position":[[80,10]]},"51":{"position":[[80,10]]},"53":{"position":[[80,10]]},"55":{"position":[[80,10]]},"57":{"position":[[80,10]]},"59":{"position":[[80,10]]},"61":{"position":[[80,10]]},"67":{"position":[[80,10]]},"69":{"position":[[80,10]]},"71":{"position":[[80,10]]},"75":{"position":[[80,10]]},"81":{"position":[[80,10]]},"85":{"position":[[173,10]]},"87":{"position":[[90,9]]},"89":{"position":[[80,10]]},"91":{"position":[[190,10]]},"95":{"position":[[97,10]]},"97":{"position":[[352,10]]},"103":{"position":[[312,10]]},"187":{"position":[[80,10]]},"189":{"position":[[80,10]]},"191":{"position":[[80,10]]},"197":{"position":[[80,10]]},"199":{"position":[[80,10]]},"203":{"position":[[80,10]]},"205":{"position":[[80,10]]},"244":{"position":[[80,10]]}}}],["110",{"_index":1886,"t":{"103":{"position":[[4994,4]]},"105":{"position":[[1176,4],[1210,4]]}}}],["1100",{"_index":2864,"t":{"258":{"position":[[528,6]]}}}],["111",{"_index":48,"t":{"41":{"position":[[256,7]]},"45":{"position":[[85,7]]}}}],["115",{"_index":1369,"t":{"87":{"position":[[811,4],[2050,4]]}}}],["12",{"_index":1900,"t":{"103":{"position":[[5587,4]]},"107":{"position":[[1303,3]]},"147":{"position":[[1423,3]]},"203":{"position":[[1111,3]]}}}],["120",{"_index":1372,"t":{"87":{"position":[[834,4],[2073,4]]},"109":{"position":[[832,5],[1940,3],[2153,3],[2224,3]]},"147":{"position":[[1821,3],[2034,3]]}}}],["12px",{"_index":2842,"t":{"211":{"position":[[1614,7]]}}}],["130",{"_index":1371,"t":{"87":{"position":[[820,4],[2059,4]]}}}],["14",{"_index":1306,"t":{"85":{"position":[[527,3]]},"179":{"position":[[986,4]]}}}],["140",{"_index":2046,"t":{"111":{"position":[[726,4]]}}}],["15",{"_index":1041,"t":{"69":{"position":[[4388,3]]}}}],["150",{"_index":536,"t":{"53":{"position":[[402,4]]},"81":{"position":[[1084,4]]},"83":{"position":[[748,4]]},"87":{"position":[[825,4],[843,4],[2064,4],[2082,4]]},"149":{"position":[[935,5],[1020,4],[1190,4],[1195,4],[1258,4],[1920,4],[1925,5],[2357,4],[2362,5]]},"155":{"position":[[208,6]]},"205":{"position":[[1005,4]]}}}],["150.0*sin(uv.x*0.75+time*0.75)*amplitude*1.4",{"_index":2352,"t":{"165":{"position":[[3848,46]]}}}],["16",{"_index":1088,"t":{"69":{"position":[[7849,4]]},"85":{"position":[[421,3]]},"103":{"position":[[4800,3],[5508,3]]},"111":{"position":[[1788,4]]},"211":{"position":[[316,3],[1039,2],[1223,3]]}}}],["160",{"_index":534,"t":{"53":{"position":[[377,4]]},"69":{"position":[[5441,4]]},"87":{"position":[[802,4],[2041,4]]}}}],["170",{"_index":1408,"t":{"87":{"position":[[2485,4],[2594,4],[2699,4],[2815,4]]}}}],["175",{"_index":1244,"t":{"81":{"position":[[1056,4]]},"83":{"position":[[720,4]]}}}],["18",{"_index":1847,"t":{"103":{"position":[[3665,2]]}}}],["190",{"_index":2235,"t":{"157":{"position":[[465,4]]}}}],["1}.png",{"_index":2495,"t":{"183":{"position":[[390,9]]}}}],["2",{"_index":139,"t":{"41":{"position":[[2075,2],[2106,3],[3728,2],[3759,3]]},"45":{"position":[[913,2],[965,2],[1263,3],[1321,3]]},"47":{"position":[[1935,2],[2267,2],[2304,1],[2327,1]]},"49":{"position":[[931,2],[1661,2],[1758,2],[1858,2],[1923,2],[2515,2]]},"51":{"position":[[534,2],[567,2]]},"53":{"position":[[1530,3],[1750,2],[2560,3],[2646,3],[2819,3],[2880,3],[4520,3]]},"55":{"position":[[789,2],[826,2]]},"57":{"position":[[795,2],[956,2]]},"59":{"position":[[1035,2],[1069,2],[1710,2],[1744,2]]},"61":{"position":[[612,2],[645,2]]},"65":{"position":[[1154,2],[1322,1],[1337,1],[1357,2],[1690,2],[1733,2],[2074,2]]},"67":{"position":[[596,2],[633,2],[728,2],[770,2]]},"69":{"position":[[734,2],[744,3],[958,3],[1026,2],[1074,2],[1113,2],[1124,2],[1134,2],[1145,3],[1172,2],[1183,2],[1193,2],[1203,3],[1225,2],[1235,2],[1245,2],[1255,3],[1278,2],[1289,2],[1300,2],[1310,3],[1684,2],[1695,2],[1718,2],[1728,2],[1755,2],[1765,2],[1791,2],[1802,2],[1829,2],[1961,3],[2092,2],[2126,3],[2142,1],[2210,2],[2639,1],[2679,2],[2701,1],[2741,2],[2871,3],[3507,2],[3517,3],[3703,3],[3740,2],[5229,2],[5239,3],[5466,3],[5534,2],[5582,2],[5638,1],[5660,1],[5681,1],[5703,1],[5741,1],[5763,1],[5784,1],[5805,1],[5838,1],[5859,1],[5880,1],[5901,1],[5935,1],[5957,1],[5979,1],[6000,1],[6612,1],[6634,1],[6669,1],[6690,1],[6726,1],[6747,1],[6784,1],[6806,1],[6968,1],[7063,3],[7079,1],[7142,2],[7185,3],[8058,3]]},"73":{"position":[[1007,2],[1171,1],[1190,1],[1210,2],[1542,2],[1585,3],[1919,2]]},"75":{"position":[[411,2],[445,2]]},"77":{"position":[[395,2],[428,2]]},"79":{"position":[[953,2],[1110,2],[1155,2],[1176,2],[1557,2],[1600,2]]},"81":{"position":[[1264,3],[1299,1]]},"83":{"position":[[903,3],[938,1]]},"85":{"position":[[442,2],[564,2]]},"91":{"position":[[466,2],[489,3]]},"95":{"position":[[472,2],[630,2],[658,2],[1155,2],[1182,2],[1400,2],[1937,2],[2185,1]]},"97":{"position":[[664,2],[696,3],[1278,4],[1767,5],[1806,3]]},"101":{"position":[[436,2],[636,2]]},"103":{"position":[[3461,1],[3585,2],[3683,4]]},"105":{"position":[[334,2],[367,2],[594,2],[2175,2]]},"107":{"position":[[276,2],[306,2],[435,2],[472,2],[1803,2],[1835,3]]},"109":{"position":[[1384,2],[1403,2]]},"111":{"position":[[491,1],[631,1],[1132,1],[1283,1],[1961,1]]},"147":{"position":[[293,2],[323,2],[423,2],[460,2],[1106,2],[1139,2]]},"149":{"position":[[779,1],[1402,1],[1451,1],[1547,1],[1574,3],[1741,1],[1770,3]]},"153":{"position":[[288,2],[414,2],[463,2],[469,2]]},"155":{"position":[[291,2],[851,2]]},"159":{"position":[[307,2],[433,2],[482,2],[488,2],[1197,4],[1615,5],[1654,3],[3032,2],[3066,3]]},"161":{"position":[[288,2],[414,2],[463,2],[469,2],[647,2],[767,2],[816,4]]},"163":{"position":[[277,2],[397,3]]},"165":{"position":[[308,2],[434,2],[483,2],[489,2],[1385,3]]},"167":{"position":[[1433,3],[1497,3]]},"173":{"position":[[277,2],[537,3]]},"175":{"position":[[277,2]]},"177":{"position":[[704,2],[729,3],[1071,2],[1125,2]]},"179":{"position":[[288,2],[414,2],[463,2],[469,2]]},"181":{"position":[[732,2],[764,2],[976,2],[1008,2]]},"185":{"position":[[774,2],[811,2],[906,2],[948,2]]},"187":{"position":[[397,2],[430,2]]},"189":{"position":[[557,2],[594,2]]},"193":{"position":[[583,1],[631,1]]},"195":{"position":[[450,2],[502,2]]},"197":{"position":[[789,2],[821,2]]},"211":{"position":[[640,1],[1329,1],[1343,1]]},"244":{"position":[[467,3]]}}}],["2./length(uv.y*500",{"_index":2353,"t":{"165":{"position":[[3907,19]]}}}],["2.1",{"_index":2716,"t":{"203":{"position":[[923,4]]}}}],["2.2",{"_index":1643,"t":{"97":{"position":[[1887,4]]},"159":{"position":[[1735,4]]}}}],["2.5",{"_index":2131,"t":{"149":{"position":[[1754,3]]}}}],["20",{"_index":384,"t":{"47":{"position":[[373,3]]},"49":{"position":[[286,3],[1326,3]]},"65":{"position":[[442,3]]},"73":{"position":[[194,3]]},"95":{"position":[[1326,3]]},"101":{"position":[[1022,2],[1060,2]]},"105":{"position":[[413,3]]},"109":{"position":[[1964,3],[1993,4],[2035,3],[2064,4],[2106,3],[2134,4],[2177,3],[2205,4],[2248,3],[2277,4]]},"147":{"position":[[1845,3],[1874,4],[1916,3],[1945,4],[1987,3],[2015,4],[2058,3],[2086,4]]},"149":{"position":[[1686,3],[2260,3]]},"169":{"position":[[748,3]]},"207":{"position":[[1414,3]]},"211":{"position":[[1691,3]]},"258":{"position":[[183,3],[226,3],[809,3]]}}}],["200",{"_index":1324,"t":{"85":{"position":[[910,4],[915,4]]},"87":{"position":[[327,5],[649,5],[1192,5],[1368,4],[1782,5],[1893,4]]},"93":{"position":[[1259,4],[1284,5]]},"101":{"position":[[462,4],[641,4]]},"103":{"position":[[3736,4]]},"109":{"position":[[859,5],[1128,4]]},"149":{"position":[[420,5],[447,5],[658,4],[663,4],[668,4]]},"165":{"position":[[265,4],[281,4],[286,4],[294,5],[1742,4],[1755,3],[2548,4],[2561,3],[3187,4],[3200,3],[4191,4],[4204,3]]},"191":{"position":[[417,4]]},"199":{"position":[[946,5]]},"207":{"position":[[1514,4],[1550,4]]}}}],["200.0*sin(uv.x+time)*amplitude*1.6",{"_index":2354,"t":{"165":{"position":[[3929,36]]}}}],["2000",{"_index":463,"t":{"49":{"position":[[761,4],[801,5],[2037,5],[2050,6]]}}}],["220",{"_index":1994,"t":{"109":{"position":[[456,5],[482,5]]},"165":{"position":[[5085,5],[5158,5]]},"203":{"position":[[771,4]]}}}],["240",{"_index":2097,"t":{"149":{"position":[[673,4],[1200,4]]}}}],["25",{"_index":341,"t":{"45":{"position":[[651,3]]},"67":{"position":[[370,3]]},"87":{"position":[[2455,3]]},"105":{"position":[[1764,3]]},"107":{"position":[[1375,3]]},"149":{"position":[[1989,4],[2027,4],[2065,4]]},"169":{"position":[[220,3]]},"185":{"position":[[548,3]]},"244":{"position":[[314,3]]}}}],["25.0",{"_index":1510,"t":{"93":{"position":[[918,5]]}}}],["250",{"_index":2012,"t":{"109":{"position":[[1012,4]]},"111":{"position":[[930,4],[1079,4],[1229,4],[1380,4]]}}}],["2500",{"_index":655,"t":{"53":{"position":[[3382,4]]}}}],["255",{"_index":2659,"t":{"201":{"position":[[863,4],[868,4]]},"209":{"position":[[661,4],[666,4]]}}}],["256",{"_index":2804,"t":{"209":{"position":[[401,4]]}}}],["26",{"_index":2080,"t":{"147":{"position":[[1495,3]]},"183":{"position":[[317,3],[819,2]]}}}],["270",{"_index":2126,"t":{"149":{"position":[[1538,4]]}}}],["272d37",{"_index":1548,"t":{"95":{"position":[[1283,10]]},"103":{"position":[[4810,10],[5540,10]]}}}],["2d",{"_index":492,"t":{"49":{"position":[[1507,2]]}}}],["3",{"_index":147,"t":{"41":{"position":[[2255,2]]},"47":{"position":[[2277,1],[2336,1]]},"53":{"position":[[1745,2],[2037,1],[3317,3]]},"69":{"position":[[2691,2],[2753,2],[3128,2]]},"97":{"position":[[1811,4]]},"107":{"position":[[1702,2],[1798,2]]},"111":{"position":[[2098,1]]},"149":{"position":[[1560,1],[1614,1]]},"153":{"position":[[472,3]]},"155":{"position":[[312,2],[900,2]]},"159":{"position":[[491,4],[1659,4]]},"161":{"position":[[472,4]]},"165":{"position":[[492,4]]},"173":{"position":[[417,2]]},"175":{"position":[[417,3]]},"179":{"position":[[472,4]]}}}],["3./length(uv.y*400",{"_index":2351,"t":{"165":{"position":[[3826,19]]}}}],["30",{"_index":202,"t":{"41":{"position":[[3559,2],[3601,4],[3626,2],[3669,4]]},"85":{"position":[[1570,3],[1597,3]]},"87":{"position":[[839,3],[2078,3]]},"109":{"position":[[1213,4],[1558,3]]},"151":{"position":[[859,3]]},"169":{"position":[[683,3]]},"195":{"position":[[343,3]]},"197":{"position":[[322,3]]},"244":{"position":[[385,3],[419,3]]},"258":{"position":[[744,3]]}}}],["300",{"_index":353,"t":{"45":{"position":[[860,4]]},"63":{"position":[[514,4],[964,4]]},"103":{"position":[[3478,4],[3892,4],[3951,4]]},"109":{"position":[[706,5],[886,5],[1239,5]]},"153":{"position":[[1109,5]]},"155":{"position":[[1486,5]]},"157":{"position":[[665,5]]},"159":{"position":[[2824,5]]},"161":{"position":[[1502,5]]},"163":{"position":[[1405,5]]},"167":{"position":[[1720,5]]},"169":{"position":[[407,4]]},"171":{"position":[[666,5]]},"173":{"position":[[1385,5]]},"175":{"position":[[963,5]]},"179":{"position":[[1252,5]]},"203":{"position":[[1253,4]]},"205":{"position":[[1020,4]]},"207":{"position":[[637,4],[810,4]]},"244":{"position":[[546,4],[559,4]]},"258":{"position":[[492,4]]}}}],["310",{"_index":2233,"t":{"157":{"position":[[451,4]]}}}],["315",{"_index":1712,"t":{"101":{"position":[[441,4]]}}}],["32",{"_index":2448,"t":{"177":{"position":[[212,3]]}}}],["320",{"_index":1531,"t":{"95":{"position":[[338,4]]},"109":{"position":[[733,5]]},"149":{"position":[[992,4],[1232,4]]}}}],["325",{"_index":1248,"t":{"81":{"position":[[1079,4]]},"83":{"position":[[743,4]]}}}],["35",{"_index":1413,"t":{"87":{"position":[[2564,3]]}}}],["350",{"_index":2003,"t":{"109":{"position":[[760,5]]},"111":{"position":[[1516,5],[1543,5],[1596,5]]},"149":{"position":[[1915,4],[2352,4]]}}}],["36",{"_index":595,"t":{"53":{"position":[[2159,3]]},"203":{"position":[[338,3]]}}}],["360",{"_index":1159,"t":{"73":{"position":[[952,3]]}}}],["370",{"_index":2060,"t":{"111":{"position":[[1915,4],[2257,4]]}}}],["375",{"_index":2139,"t":{"149":{"position":[[1984,4]]}}}],["3].map((i",{"_index":1845,"t":{"103":{"position":[[3588,10]]}}}],["3d",{"_index":490,"t":{"49":{"position":[[1492,2]]}}}],["4",{"_index":563,"t":{"53":{"position":[[1203,2],[2347,2]]},"63":{"position":[[767,3]]},"69":{"position":[[1627,2],[4146,2],[6530,2],[6548,1]]},"73":{"position":[[1175,1]]},"95":{"position":[[428,3],[1994,3],[2014,3]]},"107":{"position":[[1868,3]]},"111":{"position":[[2194,2]]},"155":{"position":[[497,1],[616,1],[648,1],[949,2]]},"181":{"position":[[532,2]]},"203":{"position":[[526,2],[944,2]]},"211":{"position":[[1123,1],[1443,3],[1479,1]]}}}],["4./length(uv.y*300",{"_index":2349,"t":{"165":{"position":[[3747,19]]}}}],["40",{"_index":346,"t":{"45":{"position":[[745,3],[779,3]]},"67":{"position":[[464,3],[498,3]]},"95":{"position":[[1413,3]]},"169":{"position":[[393,3]]},"185":{"position":[[642,3],[676,3]]}}}],["400",{"_index":351,"t":{"45":{"position":[[836,4]]},"63":{"position":[[490,4],[927,4]]},"85":{"position":[[704,4],[709,4],[769,4]]},"111":{"position":[[1570,5]]},"163":{"position":[[1496,5]]},"167":{"position":[[1777,5]]},"207":{"position":[[615,4],[786,4],[1508,3],[1544,3]]},"258":{"position":[[468,4]]}}}],["410",{"_index":1247,"t":{"81":{"position":[[1074,4]]},"83":{"position":[[738,4]]}}}],["420",{"_index":2071,"t":{"111":{"position":[[2277,4]]},"149":{"position":[[1732,4]]}}}],["425",{"_index":2141,"t":{"149":{"position":[[2022,4]]}}}],["430",{"_index":2382,"t":{"165":{"position":[[5122,5]]}}}],["440",{"_index":615,"t":{"53":{"position":[[2434,4]]},"111":{"position":[[1773,4]]},"203":{"position":[[613,4]]}}}],["445",{"_index":1251,"t":{"81":{"position":[[1099,4]]},"83":{"position":[[763,4]]}}}],["45",{"_index":1373,"t":{"87":{"position":[[848,3],[2087,3]]},"169":{"position":[[177,3]]}}}],["450",{"_index":2066,"t":{"111":{"position":[[2189,4]]},"205":{"position":[[1035,4]]},"244":{"position":[[666,4]]}}}],["459",{"_index":2859,"t":{"258":{"position":[[399,4]]}}}],["460",{"_index":2069,"t":{"111":{"position":[[2267,4]]}}}],["465",{"_index":1249,"t":{"81":{"position":[[1089,4]]},"83":{"position":[[753,4]]}}}],["475",{"_index":2143,"t":{"149":{"position":[[2060,4]]}}}],["480",{"_index":2005,"t":{"109":{"position":[[800,4]]},"203":{"position":[[1271,4]]}}}],["4a1850",{"_index":604,"t":{"53":{"position":[[2254,10]]},"203":{"position":[[433,10]]}}}],["5",{"_index":67,"t":{"41":{"position":[[492,2]]},"45":{"position":[[740,2],[774,2]]},"49":{"position":[[369,2],[1076,1]]},"53":{"position":[[883,2],[1840,3],[2282,2],[3358,1]]},"67":{"position":[[459,2],[493,2]]},"69":{"position":[[4880,2],[7308,2]]},"81":{"position":[[1127,2]]},"83":{"position":[[791,2]]},"111":{"position":[[1920,2]]},"155":{"position":[[267,2]]},"185":{"position":[[637,2],[671,2]]},"203":{"position":[[461,2]]},"211":{"position":[[1164,1]]},"244":{"position":[[380,2],[414,2]]}}}],["5./length(uv.y*200",{"_index":2345,"t":{"165":{"position":[[3669,19]]}}}],["50",{"_index":258,"t":{"43":{"position":[[249,4]]},"49":{"position":[[967,2]]},"69":{"position":[[3792,3],[7726,4],[8150,5],[8193,5],[8236,5],[8279,5],[8322,5]]},"87":{"position":[[798,3],[867,3],[2037,3],[2106,3]]},"109":{"position":[[377,4],[403,4],[508,4]]},"111":{"position":[[278,3],[430,3],[583,3],[722,3],[935,4],[1084,4],[1234,4],[1389,4],[1923,4],[2060,4],[2197,4]]},"149":{"position":[[502,3],[528,3],[704,3],[728,3],[1389,3]]},"171":{"position":[[204,3],[214,3]]},"175":{"position":[[226,3],[244,3]]},"183":{"position":[[451,3]]},"191":{"position":[[394,3]]},"195":{"position":[[375,4]]},"199":{"position":[[879,3]]},"201":{"position":[[1902,4]]},"203":{"position":[[218,3],[754,3]]},"205":{"position":[[649,2],[752,2],[874,2],[987,2]]},"209":{"position":[[1043,3]]}}}],["50.0*sin",{"_index":2346,"t":{"165":{"position":[[3691,9]]}}}],["500",{"_index":1852,"t":{"103":{"position":[[3754,4]]},"209":{"position":[[1022,4]]}}}],["5000",{"_index":480,"t":{"49":{"position":[[1144,6]]}}}],["510",{"_index":2063,"t":{"111":{"position":[[2052,4]]}}}],["520",{"_index":2075,"t":{"111":{"position":[[2297,5]]}}}],["55",{"_index":1368,"t":{"87":{"position":[[807,3],[859,3],[2046,3],[2098,3]]},"191":{"position":[[350,3]]}}}],["550",{"_index":1888,"t":{"103":{"position":[[5015,4]]},"157":{"position":[[621,5]]}}}],["570",{"_index":2073,"t":{"111":{"position":[[2287,4]]}}}],["590",{"_index":2074,"t":{"111":{"position":[[2292,4]]}}}],["5x5",{"_index":941,"t":{"67":{"position":[[330,3]]},"185":{"position":[[508,3]]}}}],["6",{"_index":611,"t":{"53":{"position":[[2377,2],[2400,2]]},"69":{"position":[[8035,2]]},"203":{"position":[[556,2],[579,2]]}}}],["60",{"_index":974,"t":{"69":{"position":[[934,3],[2847,3],[3679,3]]},"87":{"position":[[863,3],[2102,3]]},"97":{"position":[[3038,3]]},"149":{"position":[[1543,3],[1737,3]]},"151":{"position":[[892,3]]},"159":{"position":[[2954,3]]},"165":{"position":[[5488,3]]},"203":{"position":[[1048,3]]},"244":{"position":[[682,3],[1040,3]]}}}],["600",{"_index":656,"t":{"53":{"position":[[3393,3],[3407,4]]},"63":{"position":[[958,3]]},"87":{"position":[[71,4]]},"103":{"position":[[3494,4]]},"109":{"position":[[1397,3],[1645,5],[1712,4],[1754,4],[1796,4]]},"111":{"position":[[2251,5]]}}}],["640",{"_index":2278,"t":{"165":{"position":[[76,4]]}}}],["655",{"_index":1246,"t":{"81":{"position":[[1065,4]]},"83":{"position":[[729,4]]}}}],["685",{"_index":1250,"t":{"81":{"position":[[1094,4]]},"83":{"position":[[758,4]]}}}],["7",{"_index":1010,"t":{"69":{"position":[[2434,2]]},"111":{"position":[[2057,2]]}}}],["70",{"_index":2549,"t":{"195":{"position":[[359,3]]}}}],["700",{"_index":2068,"t":{"111":{"position":[[2262,4]]}}}],["730",{"_index":2072,"t":{"111":{"position":[[2282,4]]}}}],["75",{"_index":1245,"t":{"81":{"position":[[1061,3],[1070,3]]},"83":{"position":[[725,3],[734,3]]},"87":{"position":[[1364,3],[1889,3]]}}}],["780",{"_index":2070,"t":{"111":{"position":[[2272,4]]}}}],["8",{"_index":671,"t":{"53":{"position":[[3922,2]]},"91":{"position":[[411,2]]},"95":{"position":[[599,3]]},"97":{"position":[[2392,3]]},"159":{"position":[[2240,3]]},"201":{"position":[[2066,2]]},"209":{"position":[[1004,2]]},"211":{"position":[[1083,1],[1321,1],[1338,2]]}}}],["80",{"_index":1308,"t":{"85":{"position":[[548,3]]},"87":{"position":[[786,3],[830,3],[2025,3],[2069,3]]},"97":{"position":[[584,2]]},"111":{"position":[[1385,3]]},"155":{"position":[[818,3]]}}}],["800",{"_index":862,"t":{"63":{"position":[[921,3]]},"109":{"position":[[1378,3],[1624,4],[1691,4],[1733,4],[1775,4]]}}}],["9",{"_index":1881,"t":{"103":{"position":[[4863,5]]}}}],["918",{"_index":2858,"t":{"258":{"position":[[177,3]]}}}],["95",{"_index":1370,"t":{"87":{"position":[[816,3],[852,3],[2055,3],[2091,3]]}}}],["999",{"_index":364,"t":{"45":{"position":[[1104,7]]}}}],["a.click",{"_index":337,"t":{"45":{"position":[[484,10]]}}}],["a.download",{"_index":334,"t":{"45":{"position":[[443,10]]}}}],["a.href",{"_index":336,"t":{"45":{"position":[[470,6]]}}}],["a.remove",{"_index":338,"t":{"45":{"position":[[495,11]]}}}],["a1",{"_index":730,"t":{"53":{"position":[[5531,2]]}}}],["a2",{"_index":729,"t":{"53":{"position":[[5515,3],[5546,2]]}}}],["aabb",{"_index":70,"t":{"41":{"position":[[522,4]]}}}],["above",{"_index":218,"t":{"41":{"position":[[4335,5]]},"195":{"position":[[896,5]]},"207":{"position":[[518,5]]}}}],["abs(cos(gl_fragcoord.y",{"_index":2408,"t":{"167":{"position":[[1455,23]]}}}],["abs(sin(gl_fragcoord.x",{"_index":2405,"t":{"167":{"position":[[1391,23]]}}}],["acceess",{"_index":2676,"t":{"201":{"position":[[1275,7]]}}}],["acceleration",{"_index":182,"t":{"41":{"position":[[2843,12],[2872,12],[3168,12],[4758,12],[4999,12],[5171,12]]}}}],["accessed",{"_index":917,"t":{"65":{"position":[[1430,8]]},"73":{"position":[[1286,8]]},"79":{"position":[[1295,8]]}}}],["achieve",{"_index":1744,"t":{"103":{"position":[[504,7]]}}}],["acolor",{"_index":2442,"t":{"173":{"position":[[662,7],[830,7]]},"175":{"position":[[556,7],[671,7]]}}}],["active",{"_index":2610,"t":{"199":{"position":[[255,8]]}}}],["add",{"_index":248,"t":{"41":{"position":[[5628,3]]},"53":{"position":[[2079,3],[2680,3]]},"55":{"position":[[152,3]]},"57":{"position":[[152,3]]},"63":{"position":[[648,3]]},"81":{"position":[[329,3],[647,3],[1543,3],[1594,3]]},"83":{"position":[[311,3],[1638,3],[1689,3]]},"85":{"position":[[1252,3]]},"87":{"position":[[2823,3]]},"89":{"position":[[1154,3]]},"95":{"position":[[876,3],[1188,3]]},"97":{"position":[[2590,3]]},"99":{"position":[[832,3]]},"103":{"position":[[3350,3],[3762,3],[4194,3],[4341,3],[4518,3]]},"147":{"position":[[466,3]]},"165":{"position":[[5167,3]]},"195":{"position":[[602,3]]},"207":{"position":[[675,3]]}}}],["addattribute('acolor",{"_index":2441,"t":{"173":{"position":[[309,23]]},"175":{"position":[[309,23]]}}}],["addattribute('auvs",{"_index":2181,"t":{"153":{"position":[[320,21]]},"159":{"position":[[339,21]]},"161":{"position":[[320,21],[679,21]]},"163":{"position":[[309,21]]},"165":{"position":[[340,21]]},"167":{"position":[[277,21]]},"173":{"position":[[449,21]]},"179":{"position":[[320,21]]}}}],["addattribute('avertexposition",{"_index":2179,"t":{"153":{"position":[[163,32]]},"159":{"position":[[182,32]]},"161":{"position":[[163,32],[515,32]]},"163":{"position":[[163,32]]},"165":{"position":[[195,32]]},"167":{"position":[[163,32]]},"171":{"position":[[163,32]]},"173":{"position":[[163,32]]},"175":{"position":[[163,32]]},"179":{"position":[[163,32]]}}}],["addattribute('avpos",{"_index":2206,"t":{"155":{"position":[[163,22]]}}}],["addchild",{"_index":2850,"t":{"244":{"position":[[771,8]]}}}],["added",{"_index":1745,"t":{"103":{"position":[[540,5]]},"244":{"position":[[739,5]]}}}],["addeventlistener",{"_index":1753,"t":{"103":{"position":[[728,17]]}}}],["addindex([0",{"_index":2184,"t":{"153":{"position":[[446,13]]},"159":{"position":[[465,13]]},"161":{"position":[[446,13],[799,13]]},"165":{"position":[[466,13]]},"179":{"position":[[446,13]]}}}],["adjust",{"_index":2799,"t":{"209":{"position":[[315,6]]}}}],["advanced",{"_index":2635,"t":{"201":{"position":[[127,8]]}}}],["again",{"_index":1397,"t":{"87":{"position":[[1945,6]]},"109":{"position":[[584,5]]}}}],["aicol",{"_index":2216,"t":{"155":{"position":[[563,8],[1089,6],[1199,6]]}}}],["aipos",{"_index":2214,"t":{"155":{"position":[[441,8],[1067,6],[1278,6]]}}}],["ajax.googleapis.com/ajax/libs/webfont/1/webfont.js",{"_index":2621,"t":{"199":{"position":[[469,56]]}}}],["alien",{"_index":858,"t":{"63":{"position":[[784,5],[819,5],[1346,5]]}}}],["alien.anchor.x",{"_index":864,"t":{"63":{"position":[[969,14]]}}}],["alien.anchor.y",{"_index":865,"t":{"63":{"position":[[991,14]]}}}],["alien.rotation",{"_index":878,"t":{"63":{"position":[[1365,14]]}}}],["alien.tint",{"_index":860,"t":{"63":{"position":[[856,10]]}}}],["alien.x",{"_index":861,"t":{"63":{"position":[[895,7]]}}}],["alien.y",{"_index":863,"t":{"63":{"position":[[932,7]]}}}],["aliencontainer",{"_index":848,"t":{"63":{"position":[[432,14]]}}}],["aliencontainer.addchild(alien",{"_index":867,"t":{"63":{"position":[[1033,31]]}}}],["aliencontainer.cacheasbitmap",{"_index":874,"t":{"63":{"position":[[1181,28],[1212,30]]}}}],["aliencontainer.rotation",{"_index":883,"t":{"63":{"position":[[1489,23]]}}}],["aliencontainer.scale.x",{"_index":880,"t":{"63":{"position":[[1405,22]]}}}],["aliencontainer.scale.y",{"_index":882,"t":{"63":{"position":[[1447,22]]}}}],["aliencontainer.x",{"_index":849,"t":{"63":{"position":[[471,16]]}}}],["aliencontainer.y",{"_index":850,"t":{"63":{"position":[[495,16]]}}}],["alienframes",{"_index":841,"t":{"63":{"position":[[302,11]]}}}],["alienframes[i",{"_index":857,"t":{"63":{"position":[[751,13]]}}}],["aliens",{"_index":840,"t":{"63":{"position":[[270,6],[283,6],[663,6],[1288,6]]},"73":{"position":[[149,6],[162,6],[1250,6]]}}}],["aliens.length",{"_index":1162,"t":{"73":{"position":[[1687,14]]}}}],["aliens.push(alien",{"_index":866,"t":{"63":{"position":[[1013,19]]}}}],["aliens.push(dude",{"_index":1161,"t":{"73":{"position":[[1301,18]]}}}],["aliens[i",{"_index":877,"t":{"63":{"position":[[1354,10]]},"73":{"position":[[1722,10]]}}}],["align",{"_index":1549,"t":{"95":{"position":[[1330,6]]},"191":{"position":[[354,6]]},"199":{"position":[[898,6]]},"207":{"position":[[581,5]]},"211":{"position":[[1637,6]]}}}],["allow",{"_index":739,"t":{"55":{"position":[[320,5]]},"89":{"position":[[647,5]]}}}],["allowing",{"_index":92,"t":{"41":{"position":[[893,8]]}}}],["along",{"_index":1135,"t":{"69":{"position":[[9220,5]]}}}],["alpha",{"_index":1200,"t":{"79":{"position":[[234,6]]},"91":{"position":[[368,6]]},"103":{"position":[[3442,6]]}}}],["alpha=0.5",{"_index":1518,"t":{"93":{"position":[[1041,9]]}}}],["alpha=0.7",{"_index":1516,"t":{"93":{"position":[[990,9]]}}}],["already",{"_index":761,"t":{"55":{"position":[[1008,7]]},"59":{"position":[[744,7],[1929,7]]}}}],["alternatively",{"_index":1183,"t":{"75":{"position":[[658,14]]}}}],["amount",{"_index":661,"t":{"53":{"position":[[3754,6],[5713,8],[5733,7]]},"165":{"position":[[2038,7],[2360,7]]},"177":{"position":[[188,6]]}}}],["amount+1",{"_index":2318,"t":{"165":{"position":[[2298,10]]}}}],["amplitude",{"_index":2340,"t":{"165":{"position":[[3445,10],[4028,10]]}}}],["anchor",{"_index":524,"t":{"51":{"position":[[422,6]]},"61":{"position":[[500,6]]},"73":{"position":[[405,6]]},"77":{"position":[[283,6]]},"79":{"position":[[569,6]]},"89":{"position":[[868,6]]},"187":{"position":[[285,6]]},"189":{"position":[[437,6]]},"197":{"position":[[737,7]]}}}],["angle",{"_index":220,"t":{"41":{"position":[[4359,5]]},"69":{"position":[[3749,5],[4045,6]]}}}],["anglestart",{"_index":1029,"t":{"69":{"position":[[3713,10],[3765,11],[4033,11]]}}}],["angletomouse",{"_index":221,"t":{"41":{"position":[[4390,12]]}}}],["anim",{"_index":2594,"t":{"197":{"position":[[591,4]]}}}],["anim.anchor.set(0.5",{"_index":2600,"t":{"197":{"position":[[824,21]]}}}],["anim.animationspeed",{"_index":2601,"t":{"197":{"position":[[846,19]]}}}],["anim.play",{"_index":2602,"t":{"197":{"position":[[873,12]]}}}],["anim.rotation",{"_index":2604,"t":{"197":{"position":[[959,13]]}}}],["anim.x",{"_index":2598,"t":{"197":{"position":[[761,6]]}}}],["anim.y",{"_index":2599,"t":{"197":{"position":[[792,6]]}}}],["animate",{"_index":174,"t":{"41":{"position":[[2732,7]]},"47":{"position":[[1096,7]]},"49":{"position":[[1165,7]]},"53":{"position":[[3604,7],[4962,7]]},"67":{"position":[[787,7]]},"69":{"position":[[8345,7]]},"71":{"position":[[453,7]]},"97":{"position":[[2939,7]]},"99":{"position":[[925,7]]},"185":{"position":[[965,7]]},"187":{"position":[[474,7]]},"197":{"position":[[915,7]]}}}],["animated",{"_index":22,"t":{"17":{"position":[[218,8]]}}}],["animatedsprite",{"_index":2475,"t":{"181":{"position":[[552,14],[823,14]]},"183":{"position":[[485,14]]},"197":{"position":[[515,14],[639,14]]}}}],["animating",{"_index":2423,"t":{"169":{"position":[[532,9]]},"181":{"position":[[1059,9]]},"183":{"position":[[870,9]]}}}],["animation",{"_index":2251,"t":{"159":{"position":[[2888,11]]},"165":{"position":[[5422,11]]},"179":{"position":[[1316,11]]}}}],["antialias",{"_index":1293,"t":{"85":{"position":[[144,10]]},"91":{"position":[[161,10]]},"95":{"position":[[68,10]]},"103":{"position":[[283,10]]},"109":{"position":[[68,10]]},"111":{"position":[[100,10]]},"147":{"position":[[68,10]]},"149":{"position":[[68,10]]},"201":{"position":[[1552,10]]},"209":{"position":[[206,10]]}}}],["anymore",{"_index":2571,"t":{"195":{"position":[[1123,7]]}}}],["apart",{"_index":95,"t":{"41":{"position":[[947,5]]}}}],["api",{"_index":2632,"t":{"201":{"position":[[63,3],[87,3],[1258,4]]},"209":{"position":[[69,3],[551,3]]}}}],["app",{"_index":44,"t":{"41":{"position":[[215,3]]},"43":{"position":[[39,3]]},"45":{"position":[[39,3]]},"47":{"position":[[39,3]]},"49":{"position":[[39,3]]},"51":{"position":[[39,3]]},"53":{"position":[[39,3]]},"55":{"position":[[39,3]]},"57":{"position":[[39,3]]},"59":{"position":[[39,3]]},"61":{"position":[[39,3]]},"63":{"position":[[39,3]]},"65":{"position":[[39,3]]},"67":{"position":[[39,3]]},"69":{"position":[[39,3]]},"71":{"position":[[39,3]]},"73":{"position":[[39,3]]},"75":{"position":[[39,3]]},"77":{"position":[[39,3]]},"79":{"position":[[39,3]]},"81":{"position":[[39,3]]},"83":{"position":[[39,3]]},"85":{"position":[[115,3]]},"87":{"position":[[39,3]]},"89":{"position":[[39,3]]},"91":{"position":[[132,3]]},"93":{"position":[[107,3]]},"95":{"position":[[39,3]]},"97":{"position":[[311,3]]},"99":{"position":[[39,3]]},"101":{"position":[[39,3]]},"103":{"position":[[254,3]]},"105":{"position":[[39,3]]},"107":{"position":[[39,3]]},"109":{"position":[[39,3],[1482,4]]},"111":{"position":[[71,3]]},"147":{"position":[[39,3]]},"149":{"position":[[39,3]]},"151":{"position":[[39,3]]},"153":{"position":[[39,3]]},"155":{"position":[[39,3]]},"157":{"position":[[39,3]]},"159":{"position":[[39,3]]},"161":{"position":[[39,3]]},"163":{"position":[[39,3]]},"165":{"position":[[39,3]]},"167":{"position":[[39,3]]},"169":{"position":[[39,3]]},"171":{"position":[[39,3]]},"173":{"position":[[39,3]]},"175":{"position":[[39,3]]},"177":{"position":[[39,3]]},"179":{"position":[[39,3]]},"181":{"position":[[39,3]]},"183":{"position":[[39,3]]},"185":{"position":[[214,3]]},"187":{"position":[[39,3]]},"189":{"position":[[39,3]]},"191":{"position":[[39,3]]},"193":{"position":[[39,3]]},"195":{"position":[[39,3]]},"197":{"position":[[39,3]]},"199":{"position":[[39,3]]},"201":{"position":[[1523,3]]},"203":{"position":[[39,3]]},"205":{"position":[[39,3]]},"207":{"position":[[39,3]]},"209":{"position":[[177,3]]},"211":{"position":[[39,3]]},"244":{"position":[[39,3]]},"258":{"position":[[39,3]]}}}],["app.renderer",{"_index":1204,"t":{"79":{"position":[[365,12]]}}}],["app.renderer.events.cursorstyles.default",{"_index":1233,"t":{"81":{"position":[[354,40]]}}}],["app.renderer.events.cursorstyles.hover",{"_index":1234,"t":{"81":{"position":[[410,38]]}}}],["app.renderer.extract.base64(bunnycontainer",{"_index":331,"t":{"45":{"position":[[334,44]]}}}],["app.renderer.generatetexture(circle",{"_index":2456,"t":{"177":{"position":[[749,36]]}}}],["app.renderer.render(app.stage",{"_index":2794,"t":{"207":{"position":[[2180,30]]}}}],["app.renderer.render(brush",{"_index":296,"t":{"43":{"position":[[1325,26]]}}}],["app.renderer.render(container",{"_index":2857,"t":{"244":{"position":[[1067,30]]}}}],["app.renderer.render(gridquad",{"_index":2399,"t":{"165":{"position":[[5735,29]]}}}],["app.renderer.render(line",{"_index":317,"t":{"43":{"position":[[1692,25]]}}}],["app.renderer.render(noisequad",{"_index":2401,"t":{"165":{"position":[[5865,30]]}}}],["app.renderer.render(ripplequad",{"_index":2400,"t":{"165":{"position":[[5798,31]]}}}],["app.renderer.render(wavequad",{"_index":2402,"t":{"165":{"position":[[5930,29]]}}}],["app.renderer.screen",{"_index":1679,"t":{"97":{"position":[[2874,20]]}}}],["app.renderer.screen.height",{"_index":498,"t":{"49":{"position":[[1729,26],[1894,26]]},"97":{"position":[[667,26]]}}}],["app.renderer.screen.width",{"_index":496,"t":{"49":{"position":[[1605,25],[1633,25],[1701,25],[1830,25],[2422,26]]}}}],["app.screen",{"_index":166,"t":{"41":{"position":[[2599,11]]},"43":{"position":[[564,11],[1039,11]]},"45":{"position":[[574,11]]},"47":{"position":[[910,11]]},"85":{"position":[[1050,11]]},"89":{"position":[[1278,11]]},"91":{"position":[[642,11]]},"93":{"position":[[1451,11]]},"95":{"position":[[287,11]]},"109":{"position":[[195,11]]},"177":{"position":[[968,11]]}}}],["app.screen.height",{"_index":140,"t":{"41":{"position":[[2078,18],[3369,18],[3648,18],[3731,18],[3887,17]]},"51":{"position":[[547,17]]},"53":{"position":[[1710,18],[2577,17]]},"55":{"position":[[806,17]]},"57":{"position":[[775,17],[936,17]]},"59":{"position":[[1049,17],[1724,17]]},"61":{"position":[[625,17]]},"65":{"position":[[297,18],[895,19],[1693,17]]},"67":{"position":[[613,17]]},"73":{"position":[[726,18],[1545,17]]},"75":{"position":[[425,17]]},"77":{"position":[[408,17]]},"79":{"position":[[813,18],[1560,17]]},"81":{"position":[[625,18]]},"83":{"position":[[289,18]]},"89":{"position":[[466,19]]},"91":{"position":[[469,17]]},"93":{"position":[[357,18],[1264,17]]},"95":{"position":[[169,18]]},"99":{"position":[[289,18]]},"101":{"position":[[256,18]]},"103":{"position":[[3974,19]]},"105":{"position":[[337,17],[1515,18]]},"107":{"position":[[286,17],[452,17],[1355,17]]},"147":{"position":[[303,17],[440,17],[1119,17],[1475,17]]},"177":{"position":[[439,18]]},"181":{"position":[[744,17],[988,17]]},"183":{"position":[[640,18]]},"185":{"position":[[791,17]]},"187":{"position":[[410,17]]},"189":{"position":[[574,17]]},"193":{"position":[[446,18]]},"195":{"position":[[464,18],[1459,18]]},"197":{"position":[[801,17]]},"207":{"position":[[179,18]]},"211":{"position":[[1063,17],[1144,17]]}}}],["app.screen.width",{"_index":195,"t":{"41":{"position":[[3240,17],[3581,17],[3829,17]]},"51":{"position":[[515,16]]},"53":{"position":[[1917,17],[2049,17]]},"55":{"position":[[770,16]]},"57":{"position":[[739,16],[903,16]]},"59":{"position":[[1016,16],[1691,16]]},"61":{"position":[[593,16]]},"65":{"position":[[259,17],[840,18],[1651,16]]},"67":{"position":[[577,16]]},"73":{"position":[[683,17],[1503,16]]},"75":{"position":[[392,16]]},"77":{"position":[[376,16]]},"79":{"position":[[770,17],[1518,16]]},"81":{"position":[[587,17]]},"83":{"position":[[251,17]]},"89":{"position":[[420,18]]},"93":{"position":[[319,17],[1240,16]]},"95":{"position":[[207,17]]},"99":{"position":[[251,17]]},"101":{"position":[[226,17],[416,17],[616,17]]},"103":{"position":[[3956,17]]},"105":{"position":[[305,16],[1485,17]]},"107":{"position":[[257,16],[416,16]]},"147":{"position":[[274,16],[404,16],[1087,16]]},"177":{"position":[[401,17]]},"181":{"position":[[698,17],[942,17]]},"183":{"position":[[592,17]]},"185":{"position":[[755,16]]},"187":{"position":[[378,16]]},"189":{"position":[[538,16]]},"193":{"position":[[428,17]]},"195":{"position":[[414,17],[1420,17]]},"197":{"position":[[770,16]]},"207":{"position":[[153,17]]},"211":{"position":[[1020,16],[1104,16]]}}}],["app.stage",{"_index":282,"t":{"43":{"position":[[1051,9]]},"85":{"position":[[1673,11]]},"105":{"position":[[1574,9]]}}}],["app.stage.addchild",{"_index":281,"t":{"43":{"position":[[916,19]]},"87":{"position":[[2836,19]]}}}],["app.stage.addchild(aliencontainer",{"_index":852,"t":{"63":{"position":[[581,35]]}}}],["app.stage.addchild(anim",{"_index":2603,"t":{"197":{"position":[[886,25]]}}}],["app.stage.addchild(arc",{"_index":2121,"t":{"149":{"position":[[1416,24]]}}}],["app.stage.addchild(arc2",{"_index":2127,"t":{"149":{"position":[[1578,25]]}}}],["app.stage.addchild(arc3",{"_index":2132,"t":{"149":{"position":[[1774,25]]}}}],["app.stage.addchild(background",{"_index":887,"t":{"65":{"position":[[316,31]]},"81":{"position":[[674,31]]},"83":{"position":[[338,31]]},"93":{"position":[[376,31]]},"99":{"position":[[308,31]]},"177":{"position":[[350,31]]}}}],["app.stage.addchild(basictext",{"_index":2705,"t":{"203":{"position":[[241,30]]}}}],["app.stage.addchild(beatifulrect",{"_index":2152,"t":{"149":{"position":[[2392,33]]}}}],["app.stage.addchild(bezier",{"_index":2100,"t":{"149":{"position":[[732,27]]}}}],["app.stage.addchild(bezier2",{"_index":2116,"t":{"149":{"position":[[1263,28]]}}}],["app.stage.addchild(bg",{"_index":1708,"t":{"101":{"position":[[275,23]]},"147":{"position":[[326,23]]},"157":{"position":[[229,23]]}}}],["app.stage.addchild(bitmapfonttext",{"_index":2530,"t":{"191":{"position":[[422,35]]}}}],["app.stage.addchild(bottom",{"_index":638,"t":{"53":{"position":[[2935,27]]}}}],["app.stage.addchild(bunny",{"_index":525,"t":{"51":{"position":[[570,26]]},"61":{"position":[[648,26]]},"77":{"position":[[431,26]]},"89":{"position":[[1174,26]]},"187":{"position":[[433,26]]}}}],["app.stage.addchild(button",{"_index":1267,"t":{"81":{"position":[[1563,27]]},"83":{"position":[[1658,27]]},"195":{"position":[[619,27]]}}}],["app.stage.addchild(character",{"_index":758,"t":{"55":{"position":[[891,30]]},"189":{"position":[[597,30]]}}}],["app.stage.addchild(combinequad",{"_index":2391,"t":{"165":{"position":[[5376,32]]}}}],["app.stage.addchild(container",{"_index":940,"t":{"67":{"position":[[189,30]]},"69":{"position":[[388,30],[2366,30],[3280,30],[4321,30],[7499,30]]},"93":{"position":[[1290,30]]},"105":{"position":[[198,30]]},"107":{"position":[[999,30]]},"147":{"position":[[953,30]]},"151":{"position":[[198,30]]},"185":{"position":[[367,30]]},"244":{"position":[[189,30]]}}}],["app.stage.addchild(coordinates",{"_index":1889,"t":{"103":{"position":[[5020,32]]}}}],["app.stage.addchild(description",{"_index":1901,"t":{"103":{"position":[[5592,32]]}}}],["app.stage.addchild(displacementsprite",{"_index":1922,"t":{"105":{"position":[[1065,39]]},"151":{"position":[[753,39]]}}}],["app.stage.addchild(dude",{"_index":920,"t":{"65":{"position":[[1467,25]]},"73":{"position":[[1320,25]]},"211":{"position":[[1487,25]]}}}],["app.stage.addchild(egg",{"_index":786,"t":{"57":{"position":[[959,24]]}}}],["app.stage.addchild(explosion",{"_index":2505,"t":{"183":{"position":[[828,30]]}}}],["app.stage.addchild(fast",{"_index":2491,"t":{"181":{"position":[[1024,25]]}}}],["app.stage.addchild(flower",{"_index":779,"t":{"57":{"position":[[798,27]]}}}],["app.stage.addchild(focus",{"_index":2458,"t":{"177":{"position":[[864,26]]}}}],["app.stage.addchild(g",{"_index":2422,"t":{"169":{"position":[[500,22]]}}}],["app.stage.addchild(goback",{"_index":824,"t":{"59":{"position":[[1747,27]]}}}],["app.stage.addchild(gonext",{"_index":805,"t":{"59":{"position":[[1072,27]]}}}],["app.stage.addchild(graphics",{"_index":2020,"t":{"109":{"position":[[1245,29]]},"111":{"position":[[2407,29]]}}}],["app.stage.addchild(gridcontainer",{"_index":2387,"t":{"165":{"position":[[5233,34]]}}}],["app.stage.addchild(help",{"_index":1972,"t":{"107":{"position":[[1392,25]]},"147":{"position":[[1512,25]]}}}],["app.stage.addchild(littledudes",{"_index":1714,"t":{"101":{"position":[[467,32]]}}}],["app.stage.addchild(littlerobot",{"_index":1719,"t":{"101":{"position":[[667,32]]}}}],["app.stage.addchild(mask",{"_index":2237,"t":{"157":{"position":[[489,24]]}}}],["app.stage.addchild(new",{"_index":1295,"t":{"85":{"position":[[239,22],[478,22],[635,22]]},"91":{"position":[[278,22]]},"103":{"position":[[3310,22]]}}}],["app.stage.addchild(noisecontainer",{"_index":2389,"t":{"165":{"position":[[5305,35]]}}}],["app.stage.addchild(outputsprite",{"_index":2757,"t":{"207":{"position":[[688,33]]}}}],["app.stage.addchild(pixi.sprite.from('https://pixijs.com/assets/bunny.png",{"_index":1545,"t":{"95":{"position":[[948,76]]}}}],["app.stage.addchild(plane",{"_index":1141,"t":{"71":{"position":[[311,26]]}}}],["app.stage.addchild(quad",{"_index":2204,"t":{"153":{"position":[[1134,25]]},"159":{"position":[[2849,25]]},"161":{"position":[[1527,25]]},"179":{"position":[[1277,25]]}}}],["app.stage.addchild(realpath",{"_index":2093,"t":{"149":{"position":[[532,29]]}}}],["app.stage.addchild(realpath2",{"_index":2109,"t":{"149":{"position":[[1025,30]]}}}],["app.stage.addchild(rectandhole",{"_index":2146,"t":{"149":{"position":[[2116,32]]}}}],["app.stage.addchild(redsquare",{"_index":250,"t":{"41":{"position":[[5641,29]]}}}],["app.stage.addchild(reelcontainer",{"_index":580,"t":{"53":{"position":[[1604,34]]}}}],["app.stage.addchild(richtext",{"_index":2713,"t":{"203":{"position":[[776,29]]}}}],["app.stage.addchild(ring",{"_index":1930,"t":{"105":{"position":[[1377,25]]}}}],["app.stage.addchild(ripplecontainer",{"_index":2388,"t":{"165":{"position":[[5268,36]]}}}],["app.stage.addchild(rope",{"_index":395,"t":{"47":{"position":[[806,25]]}}}],["app.stage.addchild(screenshottext",{"_index":373,"t":{"45":{"position":[[1325,34]]}}}],["app.stage.addchild(skewtext",{"_index":2726,"t":{"203":{"position":[[1276,29]]}}}],["app.stage.addchild(slider",{"_index":1542,"t":{"95":{"position":[[820,27]]}}}],["app.stage.addchild(slow",{"_index":2484,"t":{"181":{"position":[[780,25]]}}}],["app.stage.addchild(snakecontainer",{"_index":2865,"t":{"258":{"position":[[535,35]]}}}],["app.stage.addchild(sprite",{"_index":1187,"t":{"75":{"position":[[793,27]]},"201":{"position":[[2069,27]]},"209":{"position":[[1047,27]]},"244":{"position":[[686,27]]}}}],["app.stage.addchild(sprites",{"_index":1201,"t":{"79":{"position":[[251,28]]}}}],["app.stage.addchild(star.sprite",{"_index":458,"t":{"49":{"position":[[633,32]]}}}],["app.stage.addchild(strip",{"_index":2418,"t":{"169":{"position":[[412,26]]}}}],["app.stage.addchild(stuffcontainer",{"_index":2761,"t":{"207":{"position":[[815,35]]}}}],["app.stage.addchild(text",{"_index":1589,"t":{"97":{"position":[[700,25]]},"211":{"position":[[1695,25]]}}}],["app.stage.addchild(text1",{"_index":2744,"t":{"205":{"position":[[1040,26]]}}}],["app.stage.addchild(text2",{"_index":2745,"t":{"205":{"position":[[1067,26]]}}}],["app.stage.addchild(text3",{"_index":2746,"t":{"205":{"position":[[1094,26]]}}}],["app.stage.addchild(text4",{"_index":2747,"t":{"205":{"position":[[1121,26]]}}}],["app.stage.addchild(textsample",{"_index":2631,"t":{"199":{"position":[[952,31]]}}}],["app.stage.addchild(thing",{"_index":2022,"t":{"109":{"position":[[1341,26]]},"147":{"position":[[1050,26]]}}}],["app.stage.addchild(tilingsprite",{"_index":2538,"t":{"193":{"position":[[468,33]]}}}],["app.stage.addchild(title",{"_index":1553,"t":{"95":{"position":[[1443,26]]}}}],["app.stage.addchild(top",{"_index":637,"t":{"53":{"position":[[2910,24]]}}}],["app.stage.addchild(triangle",{"_index":2440,"t":{"171":{"position":[[672,29]]},"173":{"position":[[1414,29]]},"175":{"position":[[992,29]]}}}],["app.stage.addchild(triangle2",{"_index":2411,"t":{"167":{"position":[[1807,29]]}}}],["app.stage.addchild(triangle3",{"_index":2274,"t":{"163":{"position":[[1526,29]]}}}],["app.stage.addchild(triangles",{"_index":2225,"t":{"155":{"position":[[1492,30]]}}}],["app.stage.addchild(videosprite",{"_index":2581,"t":{"195":{"position":[[1478,32]]}}}],["app.stage.addchild(wavecontainer",{"_index":2390,"t":{"165":{"position":[[5341,34]]}}}],["app.stage.addeventlistener('pointermove",{"_index":1474,"t":{"91":{"position":[[676,41]]},"95":{"position":[[1585,41]]}}}],["app.stage.eventmode",{"_index":163,"t":{"41":{"position":[[2547,19]]},"43":{"position":[[987,19]]},"45":{"position":[[522,19]]},"47":{"position":[[858,19]]},"63":{"position":[[549,19]]},"85":{"position":[[998,19]]},"89":{"position":[[1226,19]]},"91":{"position":[[518,19]]},"93":{"position":[[1463,19]]},"95":{"position":[[1553,19],[1717,19]]},"105":{"position":[[126,19]]},"107":{"position":[[126,19]]},"109":{"position":[[143,19]]},"147":{"position":[[143,19]]},"151":{"position":[[126,19]]},"157":{"position":[[126,19]]},"177":{"position":[[916,19]]}}}],["app.stage.filterarea",{"_index":1678,"t":{"97":{"position":[[2851,20]]}}}],["app.stage.filters",{"_index":1680,"t":{"97":{"position":[[2895,17]]},"107":{"position":[[1030,17],[1150,17]]}}}],["app.stage.hitarea",{"_index":165,"t":{"41":{"position":[[2579,17]]},"43":{"position":[[1019,17]]},"45":{"position":[[554,17]]},"47":{"position":[[890,17]]},"85":{"position":[[1030,17]]},"89":{"position":[[1258,17]]},"91":{"position":[[622,17]]},"93":{"position":[[1431,17]]},"95":{"position":[[267,17]]},"109":{"position":[[175,17]]},"177":{"position":[[948,17]]}}}],["app.stage.name",{"_index":1310,"t":{"85":{"position":[[567,14]]}}}],["app.stage.off('pointermove",{"_index":1464,"t":{"89":{"position":[[1804,28]]}}}],["app.stage.on('mousemove",{"_index":167,"t":{"41":{"position":[[2611,25]]},"47":{"position":[[922,25]]}}}],["app.stage.on('pointerdown",{"_index":340,"t":{"45":{"position":[[586,27]]},"109":{"position":[[1487,27]]}}}],["app.stage.on('pointermove",{"_index":1462,"t":{"89":{"position":[[1720,27]]},"93":{"position":[[1495,27]]},"177":{"position":[[980,27]]}}}],["app.stage.on('pointertap",{"_index":872,"t":{"63":{"position":[[1123,26]]},"107":{"position":[[1095,26]]},"147":{"position":[[1201,26]]}}}],["app.stage.on('pointerup",{"_index":1448,"t":{"89":{"position":[[1290,25]]}}}],["app.stage.on('pointerupoutside",{"_index":1450,"t":{"89":{"position":[[1328,32]]}}}],["app.stage.removeeventlistener('pointermove",{"_index":1561,"t":{"95":{"position":[[1747,44]]}}}],["app.start",{"_index":339,"t":{"45":{"position":[[507,12]]},"63":{"position":[[1067,12]]},"99":{"position":[[907,12]]},"181":{"position":[[1069,12]]},"183":{"position":[[880,12]]}}}],["app.stop",{"_index":329,"t":{"45":{"position":[[304,11]]},"63":{"position":[[126,11]]},"99":{"position":[[384,11]]}}}],["app.ticker.add",{"_index":399,"t":{"47":{"position":[[1111,17]]},"63":{"position":[[1245,17]]},"65":{"position":[[1739,17]]},"71":{"position":[[483,17]]},"73":{"position":[[1589,17]]},"77":{"position":[[458,17]]},"79":{"position":[[1620,17]]},"101":{"position":[[891,17]]},"105":{"position":[[1864,17]]},"109":{"position":[[1808,17]]},"147":{"position":[[1538,17]]},"151":{"position":[[896,17]]},"157":{"position":[[673,17]]},"169":{"position":[[542,17]]},"189":{"position":[[870,17]]},"193":{"position":[[517,17]]},"197":{"position":[[936,17]]},"207":{"position":[[1665,17]]},"244":{"position":[[1044,17]]},"258":{"position":[[603,17]]}}}],["app.ticker.add((delta",{"_index":176,"t":{"41":{"position":[[2747,22]]},"45":{"position":[[968,22]]},"49":{"position":[[1180,22]]},"53":{"position":[[3620,22],[4978,22]]},"67":{"position":[[802,22]]},"69":{"position":[[8360,22]]},"97":{"position":[[2955,22]]},"99":{"position":[[944,22]]},"107":{"position":[[1418,22]]},"153":{"position":[[1160,22]]},"155":{"position":[[1523,22]]},"159":{"position":[[2914,22]]},"161":{"position":[[1553,22]]},"163":{"position":[[1578,22]]},"165":{"position":[[5448,22]]},"167":{"position":[[1848,22]]},"171":{"position":[[702,22]]},"173":{"position":[[1444,22]]},"175":{"position":[[1022,22]]},"179":{"position":[[1363,22]]},"185":{"position":[[980,22]]},"187":{"position":[[489,22]]}}}],["appears",{"_index":1435,"t":{"89":{"position":[[767,7]]}}}],["application",{"_index":1595,"t":{"97":{"position":[[852,11]]},"99":{"position":[[348,11],[888,11]]}}}],["applied",{"_index":177,"t":{"41":{"position":[[2778,7]]}}}],["apply",{"_index":1771,"t":{"103":{"position":[[1174,5],[1272,5]]}}}],["arc",{"_index":2117,"t":{"149":{"position":[[1298,3],[1313,3],[1447,3],[1610,3]]}}}],["arc.arc(600",{"_index":2120,"t":{"149":{"position":[[1371,12]]}}}],["arc.linestyle(5",{"_index":2118,"t":{"149":{"position":[[1340,16]]}}}],["arc2",{"_index":2122,"t":{"149":{"position":[[1464,4]]}}}],["arc2.arc(650",{"_index":2125,"t":{"149":{"position":[[1524,13]]}}}],["arc2.linestyle(6",{"_index":2123,"t":{"149":{"position":[[1492,17]]}}}],["arc3",{"_index":2128,"t":{"149":{"position":[[1627,4]]}}}],["arc3.arc(650",{"_index":2130,"t":{"149":{"position":[[1718,13]]}}}],["arc3.linetexturestyle",{"_index":2129,"t":{"149":{"position":[[1655,23]]}}}],["arcradius",{"_index":1040,"t":{"69":{"position":[[4376,9],[4751,11],[4995,11]]}}}],["area",{"_index":568,"t":{"53":{"position":[[1342,5]]},"87":{"position":[[1108,4],[1585,4],[2523,6],[2744,6]]},"91":{"position":[[580,4]]},"103":{"position":[[4006,4]]}}}],["areas",{"_index":1389,"t":{"87":{"position":[[1679,5]]}}}],["arguments",{"_index":1690,"t":{"99":{"position":[[593,10]]}}}],["arial",{"_index":593,"t":{"53":{"position":[[2140,8]]},"107":{"position":[[1284,8]]},"147":{"position":[[1404,8]]},"203":{"position":[[319,8],[857,8]]}}}],["around",{"_index":149,"t":{"41":{"position":[[2281,6]]},"105":{"position":[[2258,6]]}}}],["arr",{"_index":422,"t":{"47":{"position":[[1739,4]]}}}],["arr.length",{"_index":424,"t":{"47":{"position":[[1772,10],[1792,10]]}}}],["arr[k",{"_index":425,"t":{"47":{"position":[[1815,7]]}}}],["array",{"_index":387,"t":{"47":{"position":[[489,6],[1856,6],[1899,6],[1925,7],[2107,7],[2148,8],[2181,7],[2206,8]]},"65":{"position":[[361,5]]},"73":{"position":[[1257,5]]},"79":{"position":[[293,5],[1266,5]]},"81":{"position":[[1608,5]]},"83":{"position":[[1703,5]]},"181":{"position":[[255,5]]},"183":{"position":[[236,5]]},"197":{"position":[[246,5]]},"207":{"position":[[864,5],[1286,5]]}}}],["article",{"_index":31,"t":{"41":{"position":[[59,7]]}}}],["asset",{"_index":743,"t":{"55":{"position":[[462,5],[498,5]]}}}],["assets",{"_index":735,"t":{"55":{"position":[[160,6],[330,6]]},"57":{"position":[[160,6],[329,6]]},"59":{"position":[[252,7],[364,7],[687,6],[1301,6],[1407,6]]},"69":{"position":[[4544,6]]}}}],["async",{"_index":327,"t":{"45":{"position":[[270,5]]},"51":{"position":[[185,5],[200,5],[612,5]]},"55":{"position":[[949,5]]},"59":{"position":[[149,5],[642,5],[1180,5],[1236,5],[1855,5]]}}}],["attribute",{"_index":2180,"t":{"153":{"position":[[203,9],[310,9],[349,9],[436,9],[550,9],[582,9]]},"155":{"position":[[1030,9],[1052,9],[1074,9]]},"159":{"position":[[222,9],[329,9],[368,9],[455,9],[541,9],[573,9]]},"161":{"position":[[203,9],[310,9],[349,9],[436,9],[555,9],[669,9],[708,9],[789,9],[942,9],[974,9]]},"163":{"position":[[203,9],[299,9],[338,9],[420,9],[491,9],[523,9]]},"165":{"position":[[235,9],[330,9],[369,9],[456,9],[592,9],[624,9]]},"167":{"position":[[203,9],[306,9],[425,9],[457,9],[974,9],[1006,9]]},"171":{"position":[[287,9]]},"173":{"position":[[203,9],[299,9],[340,9],[439,9],[478,9],[560,9],[615,9],[647,9],[670,9]]},"175":{"position":[[203,9],[299,9],[340,9],[440,9],[509,9],[541,9]]},"179":{"position":[[203,9],[310,9],[349,9],[436,9],[522,9],[554,9]]}}}],["audio",{"_index":2567,"t":{"195":{"position":[[961,5],[991,5]]}}}],["auto",{"_index":1560,"t":{"95":{"position":[[1739,7]]}}}],["autostart",{"_index":2466,"t":{"181":{"position":[[68,10]]},"183":{"position":[[68,10]]}}}],["auvs",{"_index":2188,"t":{"153":{"position":[[597,5],[706,5]]},"159":{"position":[[588,5],[697,5]]},"161":{"position":[[989,5],[1098,5]]},"163":{"position":[[538,5],[647,5]]},"165":{"position":[[639,5],[748,5]]},"167":{"position":[[472,5],[581,5],[1021,5],[1130,5]]},"173":{"position":[[685,5],[815,5]]},"179":{"position":[[569,5],[678,5]]}}}],["auxiliar",{"_index":747,"t":{"55":{"position":[[568,8]]}}}],["avertexposition",{"_index":2187,"t":{"153":{"position":[[565,16]]},"159":{"position":[[556,16]]},"161":{"position":[[957,16]]},"163":{"position":[[506,16]]},"165":{"position":[[607,16]]},"167":{"position":[[440,16],[989,16]]},"171":{"position":[[302,16]]},"173":{"position":[[630,16]]},"175":{"position":[[524,16]]},"179":{"position":[[537,16]]}}}],["avoid",{"_index":2687,"t":{"201":{"position":[[1738,5]]},"211":{"position":[[754,5]]}}}],["avpos",{"_index":2219,"t":{"155":{"position":[[1045,6]]}}}],["await",{"_index":330,"t":{"45":{"position":[[328,5]]},"51":{"position":[[152,5],[240,5]]},"55":{"position":[[1059,5]]},"59":{"position":[[453,5],[820,5],[1497,5]]}}}],["awaited",{"_index":520,"t":{"51":{"position":[[335,7]]}}}],["away",{"_index":227,"t":{"41":{"position":[[4548,4]]},"49":{"position":[[2286,4]]},"61":{"position":[[172,4]]}}}],["axes",{"_index":1838,"t":{"103":{"position":[[3365,5]]}}}],["axis",{"_index":510,"t":{"49":{"position":[[2153,4]]}}}],["b",{"_index":129,"t":{"41":{"position":[[1882,1],[1920,3]]},"173":{"position":[[374,1],[394,1],[415,1]]},"175":{"position":[[374,1],[394,1],[415,1]]}}}],["b.scale.set(math.abs(sin",{"_index":1027,"t":{"69":{"position":[[3033,24]]}}}],["back",{"_index":200,"t":{"41":{"position":[[3513,4]]},"59":{"position":[[1906,4]]},"197":{"position":[[538,4]]}}}],["background",{"_index":47,"t":{"41":{"position":[[244,11]]},"43":{"position":[[619,10],[936,11]]},"47":{"position":[[68,11]]},"51":{"position":[[68,11]]},"53":{"position":[[68,11]]},"55":{"position":[[68,11],[352,10],[427,10]]},"57":{"position":[[68,11]]},"59":{"position":[[68,11],[540,10]]},"61":{"position":[[68,11]]},"65":{"position":[[142,10],[166,10]]},"67":{"position":[[68,11]]},"69":{"position":[[68,11]]},"71":{"position":[[68,11]]},"75":{"position":[[68,11]]},"81":{"position":[[68,11],[474,13],[494,10],[651,10]]},"83":{"position":[[138,13],[158,10],[315,10]]},"85":{"position":[[161,11]]},"87":{"position":[[78,11]]},"89":{"position":[[68,11]]},"91":{"position":[[178,11]]},"93":{"position":[[204,10],[227,10]]},"95":{"position":[[85,11]]},"97":{"position":[[340,11]]},"99":{"position":[[136,10],[159,10]]},"103":{"position":[[300,11]]},"177":{"position":[[306,10]]},"185":{"position":[[249,11]]},"187":{"position":[[68,11]]},"189":{"position":[[68,11]]},"191":{"position":[[68,11]]},"197":{"position":[[68,11]]},"199":{"position":[[68,11]]},"203":{"position":[[68,11]]},"205":{"position":[[68,11]]},"244":{"position":[[68,11]]}}}],["background.filters",{"_index":1700,"t":{"99":{"position":[[847,18]]}}}],["background.height",{"_index":886,"t":{"65":{"position":[[277,17]]},"81":{"position":[[605,17]]},"83":{"position":[[269,17]]},"93":{"position":[[337,17]]},"99":{"position":[[269,17]]},"177":{"position":[[419,17]]}}}],["background.mask",{"_index":2459,"t":{"177":{"position":[[891,15]]}}}],["background.width",{"_index":885,"t":{"65":{"position":[[240,16]]},"81":{"position":[[568,16]]},"83":{"position":[[232,16]]},"93":{"position":[[300,16]]},"99":{"position":[[232,16]]},"177":{"position":[[382,16]]}}}],["backgroundalpha",{"_index":1191,"t":{"77":{"position":[[68,16]]},"195":{"position":[[68,16]]}}}],["backgroundcolor",{"_index":323,"t":{"45":{"position":[[68,16]]}}}],["backout",{"_index":731,"t":{"53":{"position":[[5559,7]]}}}],["backout(0.5",{"_index":658,"t":{"53":{"position":[[3449,13]]}}}],["backout(amount",{"_index":734,"t":{"53":{"position":[[5670,15]]}}}],["ball",{"_index":1011,"t":{"69":{"position":[[2500,4],[2885,4]]}}}],["ball.anchor.set(0.5",{"_index":1013,"t":{"69":{"position":[[2565,21]]}}}],["ball.position.set",{"_index":1015,"t":{"69":{"position":[[2613,18]]}}}],["ballamount",{"_index":1009,"t":{"69":{"position":[[2421,10],[2475,11],[2656,10],[2718,10],[2948,10]]}}}],["balls",{"_index":1007,"t":{"69":{"position":[[2221,6],[2443,5]]}}}],["balls.foreach((b",{"_index":1020,"t":{"69":{"position":[[2897,17]]}}}],["balls.push(ball",{"_index":1018,"t":{"69":{"position":[[2759,17]]}}}],["base",{"_index":960,"t":{"69":{"position":[[425,4],[3317,4],[4398,4]]}}}],["base.height",{"_index":964,"t":{"69":{"position":[[536,11],[3428,11],[4491,11]]}}}],["base.mask",{"_index":969,"t":{"69":{"position":[[748,9],[3521,9],[4787,9]]}}}],["base.width",{"_index":963,"t":{"69":{"position":[[517,10],[3409,10],[4472,10]]}}}],["based",{"_index":29,"t":{"41":{"position":[[36,5]]},"47":{"position":[[1668,5]]},"53":{"position":[[3761,5]]},"97":{"position":[[899,8]]},"159":{"position":[[831,7]]},"185":{"position":[[56,5]]}}}],["basespeed",{"_index":446,"t":{"49":{"position":[[296,9],[1363,11]]}}}],["basetexture",{"_index":2646,"t":{"201":{"position":[[448,12],[522,12],[1718,11]]}}}],["basetexture.format",{"_index":2682,"t":{"201":{"position":[[1433,19],[1453,19]]}}}],["basetexture.premultiplyalpha",{"_index":2680,"t":{"201":{"position":[[1365,30]]}}}],["basetexture.type",{"_index":2683,"t":{"201":{"position":[[1473,17]]}}}],["basetextures",{"_index":2690,"t":{"201":{"position":[[1790,12]]}}}],["basic",{"_index":16,"t":{"17":{"position":[[176,5]]},"41":{"position":[[516,5]]},"53":{"position":[[5477,5]]}}}],["basic/container",{"_index":2506,"t":{"185":{"position":[[65,16]]}}}],["basically",{"_index":1057,"t":{"69":{"position":[[5053,9]]}}}],["basictext",{"_index":2701,"t":{"203":{"position":[[155,9]]}}}],["basictext.x",{"_index":2703,"t":{"203":{"position":[[204,11]]}}}],["basictext.y",{"_index":2704,"t":{"203":{"position":[[222,11]]}}}],["bc",{"_index":1663,"t":{"97":{"position":[[2365,2],[2477,4]]},"159":{"position":[[2213,2],[2325,4]]}}}],["beatifulrect",{"_index":2147,"t":{"149":{"position":[[2185,12]]}}}],["beatifulrect.beginfill(0xff0000",{"_index":2149,"t":{"149":{"position":[[2292,33]]}}}],["beatifulrect.drawrect(80",{"_index":2150,"t":{"149":{"position":[[2326,25]]}}}],["beatifulrect.endfill",{"_index":2151,"t":{"149":{"position":[[2368,23]]}}}],["beatifulrect.linetexturestyle",{"_index":2148,"t":{"149":{"position":[[2221,31]]}}}],["become",{"_index":2852,"t":{"244":{"position":[[823,6]]}}}],["before",{"_index":1071,"t":{"69":{"position":[[6275,6]]},"99":{"position":[[773,6]]},"199":{"position":[[175,6]]},"207":{"position":[[2149,6]]}}}],["beginfill(0",{"_index":1315,"t":{"85":{"position":[[674,13]]}}}],["beginfill(0x0",{"_index":2545,"t":{"195":{"position":[[241,15]]}}}],["beginfill(0x272d37",{"_index":1532,"t":{"95":{"position":[[378,20]]}}}],["beginfill(0xff0000",{"_index":2451,"t":{"177":{"position":[[493,20]]}}}],["beginfill(0xffffff",{"_index":256,"t":{"43":{"position":[[210,20]]},"85":{"position":[[869,20]]},"87":{"position":[[1303,20],[1828,20]]},"91":{"position":[[317,20]]},"95":{"position":[[560,20]]},"103":{"position":[[3622,20]]},"195":{"position":[[310,20]]}}}],["being",{"_index":1153,"t":{"73":{"position":[[536,5]]}}}],["below",{"_index":15,"t":{"17":{"position":[[169,6]]}}}],["best",{"_index":1660,"t":{"97":{"position":[[2321,4]]},"159":{"position":[[2169,4]]}}}],["better",{"_index":662,"t":{"53":{"position":[[3794,6]]},"69":{"position":[[4518,6],[4571,6]]},"209":{"position":[[345,6]]}}}],["between",{"_index":64,"t":{"41":{"position":[[451,7],[533,7],[1784,7],[4146,7],[5032,7]]},"65":{"position":[[1310,7]]},"73":{"position":[[902,7],[1163,7]]},"79":{"position":[[1098,7]]},"95":{"position":[[2157,7]]}}}],["bezier",{"_index":2082,"t":{"149":{"position":[[225,6],[568,6],[766,6]]}}}],["bezier.beziercurveto(100",{"_index":2096,"t":{"149":{"position":[[632,25]]}}}],["bezier.linestyle(5",{"_index":2094,"t":{"149":{"position":[[598,19]]}}}],["bezier.position.x",{"_index":2098,"t":{"149":{"position":[[684,17]]}}}],["bezier.position.y",{"_index":2099,"t":{"149":{"position":[[708,17]]}}}],["bezier2",{"_index":2110,"t":{"149":{"position":[[1062,7]]}}}],["bezier2.beziercurveto(0",{"_index":2113,"t":{"149":{"position":[[1159,24]]}}}],["bezier2.linetexturestyle",{"_index":2111,"t":{"149":{"position":[[1093,26]]}}}],["bezier2.position.x",{"_index":2114,"t":{"149":{"position":[[1211,18]]}}}],["bezier2.position.y",{"_index":2115,"t":{"149":{"position":[[1237,18]]}}}],["bg",{"_index":1703,"t":{"101":{"position":[[132,2]]},"105":{"position":[[1409,2]]},"107":{"position":[[164,2]]},"147":{"position":[[181,2]]},"157":{"position":[[164,2]]}}}],["bg.alpha",{"_index":1931,"t":{"105":{"position":[[1534,8]]}}}],["bg.anchor.set(0.5",{"_index":1949,"t":{"107":{"position":[[230,19]]},"147":{"position":[[247,19]]}}}],["bg.height",{"_index":1707,"t":{"101":{"position":[[244,9]]},"105":{"position":[[1503,9]]}}}],["bg.rotation",{"_index":1973,"t":{"107":{"position":[[1446,11]]},"147":{"position":[[1561,11]]}}}],["bg.width",{"_index":1706,"t":{"101":{"position":[[215,8]]},"105":{"position":[[1474,8]]}}}],["bg.x",{"_index":1950,"t":{"107":{"position":[[250,4]]},"147":{"position":[[267,4]]}}}],["bg.y",{"_index":1951,"t":{"107":{"position":[[279,4]]},"147":{"position":[[296,4]]}}}],["bgfront",{"_index":1953,"t":{"107":{"position":[[481,7]]},"147":{"position":[[495,7]]}}}],["bgfront.anchor.set(0.5",{"_index":1954,"t":{"107":{"position":[[558,24]]},"147":{"position":[[572,24]]}}}],["bgfront.rotation",{"_index":1974,"t":{"107":{"position":[[1467,16]]},"147":{"position":[[1582,16]]}}}],["big",{"_index":2802,"t":{"209":{"position":[[374,3]]}}}],["bigger",{"_index":1439,"t":{"89":{"position":[[921,7]]}}}],["bit",{"_index":302,"t":{"43":{"position":[[1450,3]]},"63":{"position":[[1304,3]]},"65":{"position":[[932,3]]},"71":{"position":[[543,3]]},"89":{"position":[[917,3]]}}}],["bitmap",{"_index":2523,"t":{"191":{"position":[[276,7]]}}}],["bitmapfonttext",{"_index":2521,"t":{"191":{"position":[[238,14]]}}}],["bitmapfonttext.x",{"_index":2528,"t":{"191":{"position":[[375,16]]}}}],["bitmapfonttext.y",{"_index":2529,"t":{"191":{"position":[[398,16]]}}}],["black",{"_index":1313,"t":{"85":{"position":[[608,5],[743,6]]}}}],["blackbox",{"_index":1314,"t":{"85":{"position":[[624,8]]}}}],["blackbox.addchild(new",{"_index":1322,"t":{"85":{"position":[[831,21]]}}}],["blackbox.eventmode",{"_index":1329,"t":{"85":{"position":[[1093,18]]}}}],["blackbox.name",{"_index":1318,"t":{"85":{"position":[[727,13]]}}}],["blackbox.x",{"_index":1319,"t":{"85":{"position":[[756,10]]}}}],["blackbox].foreach((object",{"_index":1345,"t":{"85":{"position":[[1695,26]]}}}],["blend",{"_index":18,"t":{"17":{"position":[[192,5]]},"65":{"position":[[988,5]]},"93":{"position":[[1012,5]]}}}],["blendmode",{"_index":392,"t":{"47":{"position":[[757,9]]}}}],["blur",{"_index":556,"t":{"53":{"position":[[1054,5],[3740,4],[3843,4]]},"177":{"position":[[183,4]]}}}],["bluramount",{"_index":1725,"t":{"101":{"position":[[936,10],[1027,13]]}}}],["bluramount2",{"_index":1727,"t":{"101":{"position":[[972,11],[1065,14]]}}}],["blurfilter1",{"_index":1720,"t":{"101":{"position":[[706,11],[824,14]]}}}],["blurfilter1.blur",{"_index":1728,"t":{"101":{"position":[[1003,16]]}}}],["blurfilter2",{"_index":1721,"t":{"101":{"position":[[757,11],[861,14]]}}}],["blurfilter2.blur",{"_index":1729,"t":{"101":{"position":[[1041,16]]}}}],["blursize",{"_index":2447,"t":{"177":{"position":[[201,8],[535,9],[554,9],[692,9],[717,9]]}}}],["bold",{"_index":599,"t":{"53":{"position":[[2196,7]]},"107":{"position":[[1319,7]]},"147":{"position":[[1439,7]]},"203":{"position":[[375,7]]}}}],["both",{"_index":179,"t":{"41":{"position":[[2805,4],[5188,4]]},"57":{"position":[[368,4]]},"63":{"position":[[1094,4]]}}}],["bottom",{"_index":582,"t":{"53":{"position":[[1654,6],[1950,6]]},"69":{"position":[[562,6],[1262,6],[1734,6],[1771,6],[5919,6],[6707,6],[6764,6]]}}}],["bottom.addchild(playtext",{"_index":625,"t":{"53":{"position":[[2650,26]]}}}],["bottom.addlistener('pointerdown",{"_index":642,"t":{"53":{"position":[[3045,33]]}}}],["bottom.beginfill(0",{"_index":590,"t":{"53":{"position":[[1980,19]]}}}],["bottom.cursor",{"_index":641,"t":{"53":{"position":[[3018,13]]}}}],["bottom.drawrect(0",{"_index":591,"t":{"53":{"position":[[2004,18]]}}}],["bottom.eventmode",{"_index":640,"t":{"53":{"position":[[2989,16]]}}}],["bottom.height",{"_index":966,"t":{"69":{"position":[[653,13]]}}}],["bottom.width",{"_index":965,"t":{"69":{"position":[[632,12]]}}}],["boundary",{"_index":1733,"t":{"103":{"position":[[114,8],[1025,8]]}}}],["bounding",{"_index":921,"t":{"65":{"position":[[1507,8]]},"73":{"position":[[1360,8]]},"79":{"position":[[1368,8]]}}}],["bounds",{"_index":935,"t":{"65":{"position":[[2112,9]]},"73":{"position":[[1957,9]]},"105":{"position":[[256,6]]},"177":{"position":[[648,6],[815,8]]}}}],["bounds.height",{"_index":1913,"t":{"105":{"position":[[723,14],[2447,14],[2495,14],[2524,14]]}}}],["bounds.width",{"_index":1911,"t":{"105":{"position":[[682,13],[2317,13],[2364,13],[2392,13]]}}}],["bounds.x",{"_index":1947,"t":{"105":{"position":[[2293,9],[2353,8]]}}}],["bounds.y",{"_index":1948,"t":{"105":{"position":[[2423,9],[2484,8]]}}}],["bounds1",{"_index":76,"t":{"41":{"position":[[610,7]]}}}],["bounds1.height",{"_index":88,"t":{"41":{"position":[[821,14]]}}}],["bounds1.width",{"_index":84,"t":{"41":{"position":[[738,13]]}}}],["bounds1.x",{"_index":81,"t":{"41":{"position":[[685,9],[726,9]]}}}],["bounds1.y",{"_index":85,"t":{"41":{"position":[[767,9],[809,9]]}}}],["bounds2",{"_index":78,"t":{"41":{"position":[[647,7]]}}}],["bounds2.height",{"_index":87,"t":{"41":{"position":[[791,14]]}}}],["bounds2.width",{"_index":83,"t":{"41":{"position":[[709,13]]}}}],["bounds2.x",{"_index":82,"t":{"41":{"position":[[697,9],[754,9]]}}}],["bounds2.y",{"_index":86,"t":{"41":{"position":[[779,9],[838,10]]}}}],["bourke",{"_index":1114,"t":{"69":{"position":[[8523,6]]}}}],["box",{"_index":922,"t":{"65":{"position":[[1516,3]]},"73":{"position":[[1369,3]]},"79":{"position":[[1377,3],[1381,3]]},"85":{"position":[[614,3],[750,5],[789,3],[956,5]]}}}],["boxes",{"_index":1298,"t":{"85":{"position":[[306,5]]}}}],["break",{"_index":991,"t":{"69":{"position":[[1648,6],[6575,6]]},"97":{"position":[[2482,6],[2507,6]]},"159":{"position":[[2330,6],[2355,6]]}}}],["bring",{"_index":1778,"t":{"103":{"position":[[1389,5]]}}}],["brings",{"_index":2590,"t":{"197":{"position":[[530,7]]}}}],["brush",{"_index":254,"t":{"43":{"position":[[170,5],[182,5]]}}}],["brush.position.set(x",{"_index":295,"t":{"43":{"position":[[1299,21]]}}}],["buffer",{"_index":1142,"t":{"71":{"position":[[349,6],[385,6]]},"155":{"position":[[321,6],[450,7],[572,7]]}}}],["buffer.data.length",{"_index":1147,"t":{"71":{"position":[[587,19]]}}}],["buffer.data[i",{"_index":1148,"t":{"71":{"position":[[614,14]]}}}],["buffer.data[instanceoffset",{"_index":2218,"t":{"155":{"position":[[780,26],[822,26],[871,26],[920,26]]}}}],["buffer.update",{"_index":1150,"t":{"71":{"position":[[668,16]]}}}],["buffers",{"_index":2787,"t":{"207":{"position":[[1823,7]]}}}],["build",{"_index":548,"t":{"53":{"position":[[785,5],[1165,5],[1642,5]]},"97":{"position":[[2761,5]]},"159":{"position":[[129,5],[2657,5]]},"165":{"position":[[142,5]]},"169":{"position":[[144,5]]},"258":{"position":[[144,5]]}}}],["builds",{"_index":539,"t":{"53":{"position":[[433,6]]}}}],["bunch",{"_index":853,"t":{"63":{"position":[[654,5]]},"147":{"position":[[472,5]]}}}],["bundle",{"_index":795,"t":{"59":{"position":[[715,7],[733,6]]}}}],["bundles",{"_index":789,"t":{"59":{"position":[[219,8],[511,7]]}}}],["bunnies",{"_index":943,"t":{"67":{"position":[[342,7]]},"185":{"position":[[520,7]]},"244":{"position":[[727,7],[815,7]]}}}],["bunny",{"_index":342,"t":{"45":{"position":[[668,5]]},"51":{"position":[[364,5]]},"61":{"position":[[434,5]]},"67":{"position":[[387,5],[646,5]]},"77":{"position":[[195,5]]},"89":{"position":[[541,5],[562,5],[610,5],[798,5],[1071,7]]},"95":{"position":[[880,5],[940,5],[1266,8]]},"185":{"position":[[565,5],[824,5]]},"187":{"position":[[197,5]]},"244":{"position":[[331,5]]}}}],["bunny's",{"_index":1438,"t":{"89":{"position":[[860,7]]},"95":{"position":[[1837,7]]}}}],["bunny.anchor.set(0.5",{"_index":344,"t":{"45":{"position":[[702,22]]},"51":{"position":[[435,22]]},"61":{"position":[[513,22]]},"67":{"position":[[421,22]]},"77":{"position":[[296,22]]},"89":{"position":[[881,22]]},"95":{"position":[[1109,22]]},"185":{"position":[[599,22]]},"187":{"position":[[298,22]]}}}],["bunny.cursor",{"_index":1437,"t":{"89":{"position":[[820,12]]}}}],["bunny.eventmode",{"_index":1433,"t":{"89":{"position":[[693,15]]}}}],["bunny.on('pointerdown",{"_index":1444,"t":{"89":{"position":[[1034,23]]}}}],["bunny.rotation",{"_index":1196,"t":{"77":{"position":[[530,14]]},"187":{"position":[[655,14]]},"244":{"position":[[423,14]]}}}],["bunny.scale.set(3",{"_index":1443,"t":{"89":{"position":[[952,19]]},"95":{"position":[[1089,19],[2223,17]]}}}],["bunny.texture.basetexture.scalemode",{"_index":1546,"t":{"95":{"position":[[1025,35]]}}}],["bunny.x",{"_index":345,"t":{"45":{"position":[[725,7]]},"51":{"position":[[505,7]]},"61":{"position":[[583,7]]},"67":{"position":[[444,7]]},"77":{"position":[[366,7]]},"89":{"position":[[1125,7]]},"95":{"position":[[1132,7]]},"185":{"position":[[622,7]]},"187":{"position":[[368,7]]},"244":{"position":[[365,7]]}}}],["bunny.y",{"_index":347,"t":{"45":{"position":[[749,7]]},"51":{"position":[[537,7]]},"61":{"position":[[615,7]]},"67":{"position":[[468,7]]},"77":{"position":[[398,7]]},"89":{"position":[[1138,7]]},"95":{"position":[[1158,7]]},"185":{"position":[[646,7]]},"187":{"position":[[400,7]]},"244":{"position":[[389,7]]}}}],["bunnycontainer",{"_index":325,"t":{"45":{"position":[[231,14],[1360,16]]}}}],["bunnycontainer.addchild(bunny",{"_index":349,"t":{"45":{"position":[[783,31]]}}}],["bunnycontainer.height",{"_index":357,"t":{"45":{"position":[[941,21]]}}}],["bunnycontainer.pivot.x",{"_index":354,"t":{"45":{"position":[[865,22]]}}}],["bunnycontainer.pivot.y",{"_index":356,"t":{"45":{"position":[[916,22]]}}}],["bunnycontainer.rotation",{"_index":358,"t":{"45":{"position":[[996,23]]}}}],["bunnycontainer.width",{"_index":355,"t":{"45":{"position":[[890,20]]}}}],["bunnycontainer.x",{"_index":350,"t":{"45":{"position":[[817,16]]}}}],["bunnycontainer.y",{"_index":352,"t":{"45":{"position":[[841,16]]}}}],["button",{"_index":1252,"t":{"81":{"position":[[1143,6],[1319,6],[1370,6],[1598,6]]},"83":{"position":[[807,6],[958,6],[1036,6],[1136,6],[1693,6]]},"87":{"position":[[242,6],[563,6],[1641,6]]},"89":{"position":[[729,6]]},"195":{"position":[[161,6],[212,6],[396,6],[536,6],[1116,6]]}}}],["button.anchor.set(0.5",{"_index":1256,"t":{"81":{"position":[[1209,23]]},"83":{"position":[[848,23]]}}}],["button.cursor",{"_index":1254,"t":{"81":{"position":[[1184,13]]},"83":{"position":[[1009,13]]},"195":{"position":[[572,13]]}}}],["button.destroy",{"_index":2572,"t":{"195":{"position":[[1131,17]]}}}],["button.eventmode",{"_index":1260,"t":{"81":{"position":[[1341,16]]},"83":{"position":[[980,16]]},"195":{"position":[[543,16]]}}}],["button.height",{"_index":2552,"t":{"195":{"position":[[485,14]]}}}],["button.on('pointertap",{"_index":2569,"t":{"195":{"position":[[1035,23]]}}}],["button.width",{"_index":2551,"t":{"195":{"position":[[434,13]]}}}],["button.x",{"_index":1257,"t":{"81":{"position":[[1233,8]]},"83":{"position":[[872,8]]},"195":{"position":[[403,8]]}}}],["button.y",{"_index":1259,"t":{"81":{"position":[[1268,8]]},"83":{"position":[[907,8]]},"195":{"position":[[453,8]]}}}],["buttonpositions",{"_index":1243,"t":{"81":{"position":[[1036,15]]},"83":{"position":[[700,15]]}}}],["buttonpositions[i",{"_index":1258,"t":{"81":{"position":[[1244,17],[1279,17]]},"83":{"position":[[883,17],[918,17]]}}}],["buttons",{"_index":1242,"t":{"81":{"position":[[1016,7]]},"83":{"position":[[680,7]]}}}],["buttons.push(button",{"_index":1268,"t":{"81":{"position":[[1614,21]]},"83":{"position":[[1709,21]]}}}],["buttons[0].scale.set(1.2",{"_index":1270,"t":{"81":{"position":[[1666,26]]},"83":{"position":[[1761,26]]}}}],["buttons[2].rotation",{"_index":1271,"t":{"81":{"position":[[1693,19]]},"83":{"position":[[1788,19]]}}}],["buttons[3].scale.set(0.8",{"_index":1272,"t":{"81":{"position":[[1729,26]]},"83":{"position":[[1824,26]]}}}],["buttons[4].rotation",{"_index":1275,"t":{"81":{"position":[[1788,19]]},"83":{"position":[[1883,19]]}}}],["buttons[4].scale.set(0.8",{"_index":1273,"t":{"81":{"position":[[1756,25]]},"83":{"position":[[1851,25]]}}}],["cache",{"_index":762,"t":{"55":{"position":[[1032,6]]}}}],["calclight(p",{"_index":1667,"t":{"97":{"position":[[2440,12]]},"159":{"position":[[2288,12]]}}}],["calclight(vec3",{"_index":1621,"t":{"97":{"position":[[1441,14]]},"159":{"position":[[1308,14]]}}}],["calculate",{"_index":122,"t":{"41":{"position":[[1761,9],[4115,9],[4744,9],[4974,9]]},"49":{"position":[[810,9],[1764,9]]},"69":{"position":[[965,9],[5473,9]]},"165":{"position":[[2148,11]]}}}],["calculatebounds",{"_index":1805,"t":{"103":{"position":[[2124,15],[2140,17]]}}}],["calculated",{"_index":663,"t":{"53":{"position":[[3804,10]]}}}],["calculates",{"_index":89,"t":{"41":{"position":[[854,10]]},"69":{"position":[[5122,10]]},"97":{"position":[[1083,10]]},"159":{"position":[[1002,10]]}}}],["calculation",{"_index":1619,"t":{"97":{"position":[[1423,12]]},"159":{"position":[[1290,12]]}}}],["call",{"_index":526,"t":{"51":{"position":[[602,4]]},"69":{"position":[[8391,4]]}}}],["calling",{"_index":744,"t":{"55":{"position":[[473,7]]}}}],["calls",{"_index":2674,"t":{"201":{"position":[[1194,5]]}}}],["cam",{"_index":1639,"t":{"97":{"position":[[1786,3],[1927,5],[2212,4]]},"159":{"position":[[1634,3],[1775,5],[2060,4]]}}}],["camera",{"_index":469,"t":{"49":{"position":[[885,7]]},"103":{"position":[[183,6],[493,7],[859,7]]}}}],["camera\\'s",{"_index":1803,"t":{"103":{"position":[[2057,9]]}}}],["cameraz",{"_index":444,"t":{"49":{"position":[[261,7],[768,7],[1330,7],[1450,8],[1559,8]]}}}],["cant",{"_index":1495,"t":{"93":{"position":[[613,4]]},"201":{"position":[[1239,4]]}}}],["canvas",{"_index":1468,"t":{"91":{"position":[[118,7],[573,6]]},"103":{"position":[[240,7]]},"185":{"position":[[115,6]]},"201":{"position":[[589,7],[652,6],[1491,8]]},"209":{"position":[[412,6]]},"211":{"position":[[840,6]]}}}],["canvas.getcontext('2d",{"_index":2654,"t":{"201":{"position":[[753,24]]},"209":{"position":[[510,24]]}}}],["canvas.height",{"_index":2652,"t":{"201":{"position":[[717,13]]},"209":{"position":[[479,13]]}}}],["canvas.transfercontroltooffscreen",{"_index":2510,"t":{"185":{"position":[[171,36]]}}}],["canvas.width",{"_index":2651,"t":{"201":{"position":[[695,12]]},"209":{"position":[[455,12]]}}}],["canvas2d",{"_index":2633,"t":{"201":{"position":[[69,8]]},"209":{"position":[[51,8],[542,8]]}}}],["capture",{"_index":1860,"t":{"103":{"position":[[4044,7]]}}}],["careful",{"_index":2692,"t":{"201":{"position":[[1824,8]]}}}],["cb(delta",{"_index":1108,"t":{"69":{"position":[[8453,10]]}}}],["cells",{"_index":2228,"t":{"157":{"position":[[259,5],[514,7]]}}}],["cells.mask",{"_index":2236,"t":{"157":{"position":[[470,10]]}}}],["cells.scale.set(1.5",{"_index":2230,"t":{"157":{"position":[[324,21]]}}}],["center",{"_index":206,"t":{"41":{"position":[[3969,6]]},"49":{"position":[[2136,6],[2169,7],[2306,7]]},"51":{"position":[[402,6],[484,6]]},"61":{"position":[[480,6],[562,6]]},"67":{"position":[[556,6],[639,6]]},"77":{"position":[[263,6],[345,6]]},"89":{"position":[[849,6]]},"95":{"position":[[1337,9]]},"103":{"position":[[5388,6]]},"165":{"position":[[1178,6],[2174,6],[3510,6]]},"185":{"position":[[734,6],[817,6]]},"187":{"position":[[265,6],[347,6]]},"189":{"position":[[418,6],[503,6]]}}}],["centerd",{"_index":1209,"t":{"79":{"position":[[600,7]]}}}],["centered",{"_index":1152,"t":{"73":{"position":[[436,8]]}}}],["chachicle",{"_index":2728,"t":{"205":{"position":[[210,10],[626,12]]}}}],["change",{"_index":476,"t":{"49":{"position":[[1050,6]]},"53":{"position":[[4848,7]]},"65":{"position":[[969,6]]},"95":{"position":[[1246,6]]},"103":{"position":[[470,6]]},"197":{"position":[[712,6]]}}}],["changed",{"_index":483,"t":{"49":{"position":[[1241,7]]},"95":{"position":[[905,7]]}}}],["changes",{"_index":236,"t":{"41":{"position":[[4988,7],[5160,7]]}}}],["character",{"_index":752,"t":{"55":{"position":[[691,9]]},"189":{"position":[[377,9]]}}}],["character.anchor.set(0.5",{"_index":753,"t":{"55":{"position":[[729,26]]},"189":{"position":[[450,26]]}}}],["character.cursor",{"_index":757,"t":{"55":{"position":[[861,16]]},"189":{"position":[[691,16]]}}}],["character.eventmode",{"_index":756,"t":{"55":{"position":[[829,19]]},"189":{"position":[[659,19]]}}}],["character.on('pointertap",{"_index":759,"t":{"55":{"position":[[922,26]]},"189":{"position":[[721,26]]}}}],["character.rotation",{"_index":2518,"t":{"189":{"position":[[893,18]]}}}],["character.texture",{"_index":763,"t":{"55":{"position":[[1039,17]]},"189":{"position":[[810,17]]}}}],["character.x",{"_index":754,"t":{"55":{"position":[[756,11]]},"189":{"position":[[524,11]]}}}],["character.y",{"_index":755,"t":{"55":{"position":[[792,11]]},"189":{"position":[[560,11]]}}}],["chars",{"_index":1880,"t":{"103":{"position":[[4826,6]]}}}],["check",{"_index":12,"t":{"17":{"position":[[129,5]]},"41":{"position":[[527,5],[3093,5]]},"69":{"position":[[8798,5]]},"97":{"position":[[194,5],[1150,6]]},"159":{"position":[[1069,6]]}}}],["checks",{"_index":1398,"t":{"87":{"position":[[1977,6]]}}}],["child",{"_index":1746,"t":{"103":{"position":[[551,7]]}}}],["children",{"_index":2853,"t":{"244":{"position":[[830,8],[901,9]]}}}],["choice",{"_index":2648,"t":{"201":{"position":[[568,7]]}}}],["circle",{"_index":252,"t":{"43":{"position":[[137,6]]},"91":{"position":[[57,6],[256,6],[269,6],[614,7]]},"93":{"position":[[982,7]]},"109":{"position":[[1038,6]]},"111":{"position":[[760,6],[800,7],[841,6],[963,6],[1112,6]]},"177":{"position":[[149,6],[464,6]]}}}],["circle.filters",{"_index":2453,"t":{"177":{"position":[[584,14]]}}}],["circle.position.copyfrom(e.global",{"_index":1476,"t":{"91":{"position":[[727,35]]}}}],["circle.position.set(app.screen.width",{"_index":1471,"t":{"91":{"position":[[427,36]]}}}],["clamped",{"_index":1567,"t":{"95":{"position":[[1983,7]]}}}],["class",{"_index":1754,"t":{"103":{"position":[[746,5],[1993,5]]},"201":{"position":[[261,5]]}}}],["cleaner",{"_index":1592,"t":{"97":{"position":[[796,7]]}}}],["clear",{"_index":297,"t":{"43":{"position":[[1369,6],[1580,8],[1735,6]]},"207":{"position":[[2244,6]]}}}],["clears",{"_index":2793,"t":{"207":{"position":[[2130,6]]}}}],["click",{"_index":869,"t":{"63":{"position":[[1105,5]]},"87":{"position":[[1630,5]]},"103":{"position":[[4522,5],[5470,5]]},"109":{"position":[[1429,5]]}}}],["click/tap",{"_index":2553,"t":{"195":{"position":[[663,9],[912,9]]}}}],["clipinput(k",{"_index":421,"t":{"47":{"position":[[1726,12],[1881,12],[1908,11],[2167,13],[2189,11]]}}}],["code",{"_index":8,"t":{"17":{"position":[[78,4]]},"69":{"position":[[8673,4]]}}}],["col",{"_index":1656,"t":{"97":{"position":[[2128,3],[2422,3]]},"159":{"position":[[1976,3],[2270,3]]}}}],["colliding",{"_index":234,"t":{"41":{"position":[[4918,9]]}}}],["collision",{"_index":91,"t":{"41":{"position":[[882,10],[5074,9]]}}}],["collisionpush",{"_index":240,"t":{"41":{"position":[[5090,13]]}}}],["collisionpush.x",{"_index":243,"t":{"41":{"position":[[5229,16],[5339,16]]}}}],["collisionpush.y",{"_index":244,"t":{"41":{"position":[[5267,16],[5376,16]]}}}],["collisionresponse(greensquare",{"_index":241,"t":{"41":{"position":[[5106,30]]}}}],["collisionresponse(object1",{"_index":96,"t":{"41":{"position":[[962,26]]}}}],["color",{"_index":312,"t":{"43":{"position":[[1614,6]]},"91":{"position":[[351,6]]},"103":{"position":[[3432,6]]},"165":{"position":[[2228,5],[2324,6],[2894,5],[2928,5],[2948,7],[4548,5]]}}}],["color.rgb",{"_index":2316,"t":{"165":{"position":[[2258,9]]}}}],["color1",{"_index":2291,"t":{"165":{"position":[[1275,6],[1397,6]]}}}],["color2",{"_index":2293,"t":{"165":{"position":[[1315,6],[1406,7]]}}}],["colorsize",{"_index":2210,"t":{"155":{"position":[[300,9],[404,13],[517,11],[580,10],[636,11],[768,11]]}}}],["combination",{"_index":2363,"t":{"165":{"position":[[4353,11]]}}}],["combinequad",{"_index":2377,"t":{"165":{"position":[[4924,11]]}}}],["combinequad.position.set(430",{"_index":2383,"t":{"165":{"position":[[5128,29]]}}}],["combines",{"_index":868,"t":{"63":{"position":[[1085,8]]}}}],["combineshader",{"_index":2376,"t":{"165":{"position":[[4836,13],[4962,15]]}}}],["combineuniforms",{"_index":2375,"t":{"165":{"position":[[4735,15],[4900,17]]}}}],["complete",{"_index":705,"t":{"53":{"position":[[4866,9]]}}}],["completed",{"_index":1688,"t":{"99":{"position":[[531,9]]}}}],["completely",{"_index":817,"t":{"59":{"position":[[1418,10]]}}}],["completion",{"_index":957,"t":{"69":{"position":[[222,11]]}}}],["connect",{"_index":1752,"t":{"103":{"position":[[708,7]]}}}],["connects",{"_index":306,"t":{"43":{"position":[[1484,8]]}}}],["const",{"_index":43,"t":{"41":{"position":[[209,5],[391,5],[471,5],[604,5],[641,5],[1056,5],[1140,5],[1274,5],[1366,5],[1509,5],[1604,5],[1853,5],[1876,5],[1966,5],[2288,5],[2511,5],[3982,5],[4194,5],[4384,5],[4594,5],[4688,5],[5084,5]]},"43":{"position":[[33,5],[176,5],[310,5],[538,5],[576,5],[613,5],[682,5],[754,5],[814,5]]},"45":{"position":[[33,5],[151,5],[225,5],[316,5],[379,5],[662,5],[1041,5],[1116,5]]},"47":{"position":[[33,5],[178,5],[257,5],[278,5],[353,5],[430,5],[452,5],[690,5],[1388,5],[1478,5],[1547,5],[2042,5],[2067,5],[2157,5],[2223,5],[2241,5]]},"49":{"position":[[33,5],[155,5],[232,5],[274,5],[290,5],[349,5],[372,5],[419,5],[476,5],[893,5],[934,5],[1414,5],[1540,5],[1797,5],[1861,5],[1926,5],[2003,5]]},"51":{"position":[[33,5],[224,5],[358,5]]},"53":{"position":[[33,5],[358,5],[382,5],[515,5],[801,5],[819,5],[893,5],[977,5],[1213,5],[1695,5],[1844,5],[1944,5],[2093,5],[2443,5],[2696,5],[3256,5],[3276,5],[3321,5],[3369,5],[3710,5],[4039,5],[4063,5],[4652,5],[4754,5],[5006,5],[5030,5],[5093,5],[5116,5]]},"55":{"position":[[33,5],[685,5]]},"57":{"position":[[33,5],[384,5],[651,5],[826,5]]},"59":{"position":[[33,5],[193,5],[795,5],[921,5],[1472,5],[1598,5]]},"61":{"position":[[33,5],[198,5],[428,5]]},"63":{"position":[[33,5],[277,5],[296,5],[426,5],[733,5],[813,5],[1340,5]]},"65":{"position":[[33,5],[160,5],[401,5],[423,5],[570,5],[1541,5],[1572,5],[1861,5]]},"67":{"position":[[33,5],[149,5],[244,5],[381,5]]},"69":{"position":[[33,5],[276,5],[317,5],[419,5],[499,5],[556,5],[675,5],[989,5],[1037,5],[1085,5],[1445,5],[1474,5],[1659,5],[2254,5],[2295,5],[2397,5],[2415,5],[2437,5],[2494,5],[2923,5],[3168,5],[3209,5],[3311,5],[3391,5],[3448,5],[3707,5],[3743,5],[3777,5],[3796,5],[3838,5],[4209,5],[4250,5],[4352,5],[4370,5],[4392,5],[4592,5],[4863,5],[4883,5],[5170,5],[5497,5],[5545,5],[5610,5],[6348,5],[6377,5],[6586,5],[7387,5],[7428,5],[7530,5],[7731,5],[8097,5],[8917,5],[9049,5],[9123,5],[9367,5],[9398,5]]},"71":{"position":[[33,5],[228,5],[379,5]]},"73":{"position":[[33,5],[156,5],[175,5],[322,5],[1394,5],[1425,5],[1709,5]]},"75":{"position":[[33,5],[257,5]]},"77":{"position":[[33,5],[189,5]]},"79":{"position":[[33,5],[126,5],[324,5],[344,5],[482,5],[1408,5],[1439,5],[1743,5]]},"81":{"position":[[33,5],[172,5],[245,5],[488,5],[749,5],[830,5],[920,5],[1010,5],[1030,5],[1137,5]]},"83":{"position":[[33,5],[152,5],[413,5],[494,5],[584,5],[674,5],[694,5],[801,5]]},"85":{"position":[[109,5],[225,5],[445,5],[462,5],[618,5],[814,5],[1146,5],[1167,5],[1201,5]]},"87":{"position":[[33,5],[141,5],[249,5],[570,5],[1113,5],[1264,5],[1703,5],[1788,5],[2326,5],[2381,5],[2490,5],[2599,5],[2704,5]]},"89":{"position":[[33,5],[188,5],[556,5]]},"91":{"position":[[126,5],[263,5]]},"93":{"position":[[101,5],[221,5],[646,5],[1148,5],[1321,5]]},"95":{"position":[[33,5],[149,5],[188,5],[318,5],[343,5],[525,5],[934,5],[1198,5],[1898,5],[2175,5]]},"97":{"position":[[305,5],[519,5],[882,5]]},"99":{"position":[[33,5],[153,5]]},"101":{"position":[[33,5],[126,5],[299,5],[500,5],[700,5],[751,5],[930,5],[966,5]]},"103":{"position":[[248,5],[2160,5],[2522,5],[2568,5],[3292,5],[3567,5],[4409,5],[4873,5],[5112,5],[5169,5],[5289,5]]},"105":{"position":[[33,5],[158,5],[229,5],[250,5],[373,5],[424,5],[881,5],[981,5],[1251,5],[1403,5],[1945,5]]},"107":{"position":[[33,5],[158,5],[309,5],[362,5],[475,5],[612,5],[745,5],[878,5],[1201,5],[1645,5]]},"109":{"position":[[33,5],[207,5],[1306,5]]},"111":{"position":[[65,5],[175,5],[2238,5]]},"147":{"position":[[33,5],[175,5],[350,5],[489,5],[597,5],[702,5],[807,5],[1015,5],[1321,5]]},"149":{"position":[[33,5],[143,5],[302,5],[562,5],[786,5],[1056,5],[1307,5],[1458,5],[1621,5],[1815,5],[2179,5]]},"151":{"position":[[33,5],[158,5],[229,5],[365,5],[591,5]]},"153":{"position":[[33,5],[126,5],[491,5],[1040,5]]},"155":{"position":[[33,5],[126,5],[270,5],[294,5],[315,5],[725,5],[971,5],[1407,5]]},"157":{"position":[[33,5],[158,5],[253,5],[346,5],[522,5]]},"159":{"position":[[33,5],[145,5],[496,5],[809,5],[2400,5],[2688,5],[2755,5]]},"161":{"position":[[33,5],[126,5],[477,5],[821,5],[883,5],[1432,5]]},"163":{"position":[[33,5],[126,5],[430,5],[908,5],[1066,5],[1219,5]]},"165":{"position":[[33,5],[158,5],[547,5],[914,5],[1028,5],[1443,5],[1479,5],[1687,5],[1763,5],[1817,5],[1952,5],[2335,5],[2406,5],[2491,5],[2569,5],[2627,5],[2757,5],[2988,5],[3049,5],[3131,5],[3208,5],[3264,5],[3361,5],[4005,5],[4057,5],[4136,5],[4212,5],[4266,5],[4370,5],[4729,5],[4830,5],[4918,5]]},"167":{"position":[[33,5],[126,5],[366,5],[914,5],[1591,5],[1641,5]]},"169":{"position":[[33,5],[158,5],[181,5],[281,5],[439,5]]},"171":{"position":[[33,5],[126,5],[228,5],[589,5]]},"173":{"position":[[33,5],[126,5],[570,5],[944,5],[1141,5],[1241,5],[1308,5]]},"175":{"position":[[33,5],[126,5],[450,5],[886,5]]},"177":{"position":[[33,5],[156,5],[195,5],[300,5],[458,5],[642,5],[733,5],[824,5]]},"179":{"position":[[33,5],[126,5],[477,5],[790,5],[1006,5],[1116,5],[1183,5]]},"181":{"position":[[33,5],[283,5],[338,5],[378,5],[423,5],[516,5],[567,5],[838,5]]},"183":{"position":[[33,5],[264,5],[328,5],[500,5]]},"185":{"position":[[109,5],[158,5],[208,5],[327,5],[422,5],[559,5]]},"187":{"position":[[33,5],[191,5]]},"189":{"position":[[33,5],[170,5],[248,5],[371,5]]},"191":{"position":[[33,5],[232,5]]},"193":{"position":[[33,5],[165,5],[375,5]]},"195":{"position":[[33,5],[206,5],[1187,5],[1329,5]]},"197":{"position":[[33,5],[283,5],[333,5],[585,5]]},"199":{"position":[[33,5],[353,5],[574,5],[759,5]]},"201":{"position":[[474,5],[535,5],[646,5],[741,5],[778,5],[1290,5],[1517,5],[1627,5],[1907,5],[1962,5]]},"203":{"position":[[33,5],[149,5],[272,5],[641,5],[806,5],[1119,5]]},"205":{"position":[[33,5],[548,5],[657,5],[760,5],[882,5]]},"207":{"position":[[33,5],[126,5],[417,5],[524,5],[722,5],[885,5],[1301,5],[1425,5],[1749,5],[1835,5]]},"209":{"position":[[171,5],[385,5],[406,5],[498,5],[574,5],[859,5],[900,5]]},"211":{"position":[[33,5],[233,5],[261,5],[332,5],[410,5],[488,5],[515,5],[588,5],[1004,5],[1047,5],[1090,5],[1130,5],[1279,5],[1513,5]]},"244":{"position":[[33,5],[149,5],[220,5],[325,5],[500,5],[619,5]]},"258":{"position":[[33,5],[158,5],[187,5],[287,5],[404,5]]}}}],["construct",{"_index":1844,"t":{"103":{"position":[[3539,9]]}}}],["constructor",{"_index":1697,"t":{"99":{"position":[[746,11]]},"103":{"position":[[791,13]]},"201":{"position":[[308,13]]}}}],["contain",{"_index":2566,"t":{"195":{"position":[[953,7]]}}}],["container",{"_index":17,"t":{"17":{"position":[[182,9]]},"53":{"position":[[992,10]]},"63":{"position":[[416,9]]},"67":{"position":[[155,9],[539,9],[668,9],[844,10]]},"69":{"position":[[323,9],[2301,9],[3215,9],[4256,9],[7434,9]]},"93":{"position":[[1154,9]]},"105":{"position":[[164,9]]},"107":{"position":[[368,9]]},"147":{"position":[[356,9]]},"151":{"position":[[164,9]]},"185":{"position":[[333,9],[717,9],[846,9],[1022,10]]},"207":{"position":[[1384,9]]},"244":{"position":[[155,9],[752,9],[846,10],[868,9]]}}}],["container.addchild(ball",{"_index":1014,"t":{"69":{"position":[[2587,25]]}}}],["container.addchild(base",{"_index":972,"t":{"69":{"position":[[814,25],[3559,25],[5261,25]]}}}],["container.addchild(bg",{"_index":1933,"t":{"105":{"position":[[1550,23]]}}}],["container.addchild(bgfront",{"_index":1955,"t":{"107":{"position":[[583,28]]},"147":{"position":[[901,27]]}}}],["container.addchild(bottom",{"_index":971,"t":{"69":{"position":[[786,27]]}}}],["container.addchild(bunny",{"_index":944,"t":{"67":{"position":[[502,26]]},"185":{"position":[[680,26]]},"244":{"position":[[471,26]]}}}],["container.addchild(edge",{"_index":1066,"t":{"69":{"position":[[5321,25]]}}}],["container.addchild(flag",{"_index":2154,"t":{"151":{"position":[[311,25]]}}}],["container.addchild(halfcircle",{"_index":1092,"t":{"69":{"position":[[7935,31]]}}}],["container.addchild(light1",{"_index":1963,"t":{"107":{"position":[[850,27]]}}}],["container.addchild(light2",{"_index":1959,"t":{"107":{"position":[[717,27]]}}}],["container.addchild(maggot",{"_index":1906,"t":{"105":{"position":[[521,27]]}}}],["container.addchild(mask",{"_index":973,"t":{"69":{"position":[[840,25],[3585,25],[5347,25]]}}}],["container.addchild(panda",{"_index":1967,"t":{"107":{"position":[[972,26]]}}}],["container.addchild(rectangle",{"_index":1091,"t":{"69":{"position":[[7904,30]]}}}],["container.addchild(roundingmask",{"_index":1065,"t":{"69":{"position":[[5287,33]]}}}],["container.filterarea",{"_index":1522,"t":{"93":{"position":[[1188,20]]}}}],["container.filters",{"_index":1525,"t":{"93":{"position":[[1401,17]]},"105":{"position":[[1105,17]]}}}],["container.height",{"_index":952,"t":{"67":{"position":[[751,16]]},"185":{"position":[[929,16]]}}}],["container.mask",{"_index":2079,"t":{"147":{"position":[[1162,14],[1239,17],[1259,14],[1292,14]]}}}],["container.pivot.x",{"_index":949,"t":{"67":{"position":[[690,17]]},"185":{"position":[[868,17]]}}}],["container.pivot.y",{"_index":951,"t":{"67":{"position":[[731,17]]},"185":{"position":[[909,17]]}}}],["container.position",{"_index":959,"t":{"69":{"position":[[357,18],[2335,18],[3249,18],[4290,18],[7468,18]]}}}],["container.rotation",{"_index":955,"t":{"67":{"position":[[906,18]]},"185":{"position":[[1084,18]]}}}],["container.width",{"_index":950,"t":{"67":{"position":[[710,15]]},"185":{"position":[[888,15]]}}}],["container.x",{"_index":945,"t":{"67":{"position":[[563,11]]},"107":{"position":[[402,11]]},"147":{"position":[[390,11]]},"185":{"position":[[741,11]]},"244":{"position":[[1007,11]]}}}],["container.y",{"_index":946,"t":{"67":{"position":[[599,11]]},"107":{"position":[[438,11]]},"147":{"position":[[426,11]]},"185":{"position":[[777,11]]},"244":{"position":[[1026,11]]}}}],["containspoint",{"_index":1814,"t":{"103":{"position":[[2356,13]]}}}],["containspoint(point",{"_index":1815,"t":{"103":{"position":[[2370,20]]}}}],["content",{"_index":1584,"t":{"97":{"position":[[292,8]]},"103":{"position":[[392,7],[525,7],[632,7],[823,7],[1073,7],[2094,11],[2455,7],[5362,7]]},"207":{"position":[[2160,7]]}}}],["content's",{"_index":1779,"t":{"103":{"position":[[1414,9],[1670,9],[3103,9]]}}}],["contentbounds",{"_index":1806,"t":{"103":{"position":[[2166,13]]}}}],["contentbounds.height",{"_index":1813,"t":{"103":{"position":[[2313,21]]}}}],["contentbounds.width",{"_index":1812,"t":{"103":{"position":[[2292,20]]}}}],["contentbounds.x",{"_index":1810,"t":{"103":{"position":[[2258,16]]}}}],["contentbounds.y",{"_index":1811,"t":{"103":{"position":[[2275,16]]}}}],["contents",{"_index":1743,"t":{"103":{"position":[[443,8]]}}}],["continue",{"_index":1068,"t":{"69":{"position":[[6054,8],[6241,8]]}}}],["control",{"_index":908,"t":{"65":{"position":[[1094,7]]},"73":{"position":[[825,7]]}}}],["cool",{"_index":2721,"t":{"203":{"position":[[1159,6]]}}}],["coordinate",{"_index":467,"t":{"49":{"position":[[854,10]]},"103":{"position":[[3354,10]]}}}],["coordinates",{"_index":948,"t":{"67":{"position":[[678,11]]},"69":{"position":[[9335,11]]},"103":{"position":[[4879,11],[4959,14],[5342,11]]},"151":{"position":[[1052,12]]},"185":{"position":[[856,11]]}}}],["coordinates.text",{"_index":1895,"t":{"103":{"position":[[5226,16]]}}}],["coordinates.x",{"_index":1885,"t":{"103":{"position":[[4978,13]]}}}],["coordinates.y",{"_index":1887,"t":{"103":{"position":[[4999,13]]}}}],["coords",{"_index":1774,"t":{"103":{"position":[[1216,6],[1402,6]]}}}],["copymousedata",{"_index":1770,"t":{"103":{"position":[[1157,13]]}}}],["cordon",{"_index":199,"t":{"41":{"position":[[3497,7]]}}}],["corners",{"_index":992,"t":{"69":{"position":[[1665,7],[2041,7],[6592,7],[6995,7]]}}}],["corners.length",{"_index":1002,"t":{"69":{"position":[[2075,14]]}}}],["corners[i",{"_index":1004,"t":{"69":{"position":[[2130,9],[7067,9]]}}}],["correspond",{"_index":405,"t":{"47":{"position":[[1326,10]]}}}],["count",{"_index":846,"t":{"63":{"position":[[386,5],[1390,5]]},"101":{"position":[[880,5],[914,5]]},"105":{"position":[[1853,5],[1887,5]]},"107":{"position":[[1064,5],[1631,5]]},"109":{"position":[[1410,5],[1831,5],[2318,5]]},"147":{"position":[[1190,5],[1746,5],[2108,5]]},"169":{"position":[[130,5],[565,5],[674,6],[739,6]]},"193":{"position":[[506,5],[540,5]]},"207":{"position":[[1654,5],[1796,5]]},"258":{"position":[[130,5],[626,5],[735,6],[800,6]]}}}],["courier",{"_index":2841,"t":{"211":{"position":[[1589,8]]}}}],["cover",{"_index":1859,"t":{"103":{"position":[[4011,5]]}}}],["covered",{"_index":1390,"t":{"87":{"position":[[1685,7]]}}}],["covers",{"_index":583,"t":{"53":{"position":[[1661,6]]},"95":{"position":[[244,6]]}}}],["crawl",{"_index":1946,"t":{"105":{"position":[[2272,5]]}}}],["create",{"_index":259,"t":{"43":{"position":[[257,6]]},"47":{"position":[[474,6],[577,6],[674,6]]},"49":{"position":[[402,6]]},"51":{"position":[[306,6]]},"53":{"position":[[484,6]]},"55":{"position":[[632,6]]},"57":{"position":[[597,6]]},"59":{"position":[[868,6],[1545,6]]},"61":{"position":[[181,6],[375,6]]},"63":{"position":[[400,6],[774,6]]},"65":{"position":[[129,6],[351,6],[488,6],[1055,6],[1275,6],[1498,6]]},"67":{"position":[[223,6],[321,6],[871,6]]},"71":{"position":[[550,6]]},"73":{"position":[[240,6],[786,6],[847,6],[1128,6],[1351,6]]},"77":{"position":[[149,6]]},"79":{"position":[[283,6],[462,6],[873,6],[1076,6],[1359,6]]},"81":{"position":[[465,6],[709,6]]},"83":{"position":[[129,6],[373,6]]},"87":{"position":[[658,6]]},"89":{"position":[[152,6],[523,6]]},"91":{"position":[[245,6]]},"93":{"position":[[197,6]]},"99":{"position":[[129,6],[570,6]]},"109":{"position":[[1284,6]]},"147":{"position":[[993,6]]},"181":{"position":[[245,6],[538,6],[809,6]]},"183":{"position":[[226,6],[465,6]]},"185":{"position":[[401,6],[499,6],[1049,6]]},"187":{"position":[[152,6]]},"189":{"position":[[333,6]]},"193":{"position":[[129,6],[240,6]]},"195":{"position":[[149,6],[1152,6],[1264,6]]},"197":{"position":[[236,6],[505,6]]},"199":{"position":[[710,6]]},"207":{"position":[[204,6],[458,6],[854,6],[1276,6],[1326,6]]},"209":{"position":[[558,6]]},"211":{"position":[[209,6],[1237,6]]}}}],["createbunny",{"_index":1429,"t":{"89":{"position":[[380,12]]}}}],["createbunny(x",{"_index":1430,"t":{"89":{"position":[[500,14]]}}}],["created",{"_index":2751,"t":{"207":{"position":[[510,7]]}}}],["creategradtexture",{"_index":2798,"t":{"209":{"position":[[290,19],[879,20]]}}}],["creates",{"_index":2513,"t":{"187":{"position":[[614,7]]}}}],["creating",{"_index":1478,"t":{"93":{"position":[[81,8]]}}}],["crop",{"_index":2816,"t":{"211":{"position":[[521,4],[601,5],[713,5],[919,5]]}}}],["cross",{"_index":1649,"t":{"97":{"position":[[2012,6]]},"159":{"position":[[1860,6]]}}}],["crosterian",{"_index":2737,"t":{"205":{"position":[[426,11],[963,13]]}}}],["css",{"_index":1225,"t":{"81":{"position":[[152,3]]}}}],["ctx",{"_index":2653,"t":{"201":{"position":[[747,3]]},"209":{"position":[[504,3]]}}}],["ctx.createlineargradient(0",{"_index":2656,"t":{"201":{"position":[[790,27]]},"209":{"position":[[586,27]]}}}],["ctx.fillrect(0",{"_index":2665,"t":{"201":{"position":[[993,15]]},"209":{"position":[[791,15]]}}}],["ctx.fillstyle",{"_index":2664,"t":{"201":{"position":[[972,13]]},"209":{"position":[[770,13]]}}}],["cubic",{"_index":409,"t":{"47":{"position":[[1434,5],[1648,5]]}}}],["cubicinterpolation(array",{"_index":428,"t":{"47":{"position":[[1949,25]]}}}],["cubicinterpolation(historyx",{"_index":415,"t":{"47":{"position":[[1489,28]]}}}],["cubicinterpolation(historyy",{"_index":417,"t":{"47":{"position":[[1558,28]]}}}],["current",{"_index":308,"t":{"43":{"position":[[1525,7]]}}}],["currenttargetname",{"_index":1335,"t":{"85":{"position":[[1207,17],[1364,18]]}}}],["currenttexture",{"_index":2750,"t":{"207":{"position":[[423,14]]}}}],["cursor",{"_index":1175,"t":{"75":{"position":[[518,6]]},"81":{"position":[[340,6]]},"89":{"position":[[760,6]]},"103":{"position":[[1912,6],[1923,8],[2067,6],[4306,6]]}}}],["cursor(value",{"_index":1800,"t":{"103":{"position":[[2020,13]]}}}],["curve",{"_index":408,"t":{"47":{"position":[[1423,5]]},"149":{"position":[[232,5],[773,5]]}}}],["custom",{"_index":1231,"t":{"81":{"position":[[333,6]]},"87":{"position":[[548,6]]}}}],["customuniform",{"_index":1693,"t":{"99":{"position":[[673,14]]}}}],["cyan",{"_index":2661,"t":{"201":{"position":[[903,8]]},"209":{"position":[[701,8]]}}}],["d",{"_index":1633,"t":{"97":{"position":[[1650,1],[1692,2],[2222,1]]},"159":{"position":[[1517,1],[1559,2],[2070,1]]}}}],["d.y",{"_index":1664,"t":{"97":{"position":[[2370,3]]},"159":{"position":[[2218,3]]}}}],["d8",{"_index":2810,"t":{"211":{"position":[[267,2]]}}}],["d8.isvertical(rotate",{"_index":2812,"t":{"211":{"position":[[342,21],[420,21]]}}}],["data",{"_index":1454,"t":{"89":{"position":[[1545,4]]},"97":{"position":[[867,4]]},"99":{"position":[[665,5]]}}}],["date.now",{"_index":706,"t":{"53":{"position":[[4895,11],[5018,11]]}}}],["days",{"_index":2592,"t":{"197":{"position":[[561,4]]}}}],["deacceleration",{"_index":178,"t":{"41":{"position":[[2786,14]]}}}],["default",{"_index":904,"t":{"65":{"position":[[980,7]]},"93":{"position":[[521,7]]},"103":{"position":[[643,8],[1278,7]]},"201":{"position":[[501,7]]}}}],["defaulticon",{"_index":1227,"t":{"81":{"position":[[178,11],[397,12]]}}}],["deg",{"_index":470,"t":{"49":{"position":[[899,3]]}}}],["degrees",{"_index":1160,"t":{"73":{"position":[[956,7]]}}}],["delta",{"_index":246,"t":{"41":{"position":[[5463,6],[5516,6],[5565,6],[5614,6]]},"45":{"position":[[1030,6]]},"49":{"position":[[1341,5]]},"67":{"position":[[862,5],[935,6]]},"69":{"position":[[888,7],[926,5],[2801,7],[2839,5],[3633,7],[3671,5],[5395,7],[5433,5],[7989,7],[8027,5]]},"97":{"position":[[3030,5]]},"99":{"position":[[1012,6]]},"185":{"position":[[1040,5],[1113,6]]},"187":{"position":[[569,5],[679,6]]}}}],["demo",{"_index":2795,"t":{"209":{"position":[[41,4]]}}}],["demos",{"_index":7,"t":{"17":{"position":[[68,5]]}}}],["denominator",{"_index":1131,"t":{"69":{"position":[[8923,11],[9011,12],[9110,12],[9184,12]]}}}],["depending",{"_index":511,"t":{"49":{"position":[[2195,9],[2265,9]]}}}],["depends",{"_index":666,"t":{"53":{"position":[[3848,7]]}}}],["derived",{"_index":1804,"t":{"103":{"position":[[2077,7]]}}}],["description",{"_index":1897,"t":{"103":{"position":[[5295,11]]}}}],["description.position.set(110",{"_index":1899,"t":{"103":{"position":[[5557,29]]}}}],["designated",{"_index":1446,"t":{"89":{"position":[[1105,10]]}}}],["desktop",{"_index":1181,"t":{"75":{"position":[[611,8]]}}}],["desyrel",{"_index":2527,"t":{"191":{"position":[[329,10]]}}}],["detect",{"_index":677,"t":{"53":{"position":[[4196,6]]}}}],["detection",{"_index":41,"t":{"41":{"position":[[191,9]]}}}],["determine",{"_index":1116,"t":{"69":{"position":[[8577,9]]}}}],["determined",{"_index":682,"t":{"53":{"position":[[4270,10]]}}}],["determines",{"_index":381,"t":{"47":{"position":[[314,10],[389,10]]}}}],["development/collision",{"_index":40,"t":{"41":{"position":[[169,21]]}}}],["devices",{"_index":1486,"t":{"93":{"position":[[446,7]]}}}],["diamond",{"_index":2825,"t":{"211":{"position":[[790,7]]}}}],["different",{"_index":71,"t":{"41":{"position":[[545,9]]},"53":{"position":[[491,9]]},"79":{"position":[[647,9],[666,9]]},"83":{"position":[[1123,9]]},"93":{"position":[[623,9]]},"103":{"position":[[212,9]]},"211":{"position":[[827,9]]}}}],["dir",{"_index":1067,"t":{"69":{"position":[[6038,3]]}}}],["direction",{"_index":193,"t":{"41":{"position":[[3189,9],[4129,9],[4370,9]]},"65":{"position":[[1199,9]]},"69":{"position":[[6215,9]]},"73":{"position":[[863,9],[1052,9]]},"79":{"position":[[889,9],[998,9]]}}}],["disable",{"_index":1797,"t":{"103":{"position":[[1975,7]]},"199":{"position":[[290,7]]}}}],["disjoint",{"_index":1735,"t":{"103":{"position":[[153,8]]}}}],["displacementfilter",{"_index":1920,"t":{"105":{"position":[[987,18],[1125,21]]},"151":{"position":[[597,18],[808,21]]}}}],["displacementfilter.padding",{"_index":2159,"t":{"151":{"position":[[675,26]]}}}],["displacementfilter.scale.x",{"_index":1923,"t":{"105":{"position":[[1147,26]]},"151":{"position":[[830,26]]}}}],["displacementfilter.scale.y",{"_index":1924,"t":{"105":{"position":[[1181,26]]},"151":{"position":[[863,26]]}}}],["displacementsprite",{"_index":1918,"t":{"105":{"position":[[887,18]]},"151":{"position":[[371,18]]}}}],["displacementsprite.anchor.set(0.5",{"_index":1925,"t":{"105":{"position":[[1215,35]]}}}],["displacementsprite.position",{"_index":2160,"t":{"151":{"position":[[708,27]]}}}],["displacementsprite.position.set(eventdata.data.global.x",{"_index":1938,"t":{"105":{"position":[[1706,55]]}}}],["displacementsprite.texture.basetexture.wrapmode",{"_index":2158,"t":{"151":{"position":[[517,47]]}}}],["displacementsprite.width",{"_index":2176,"t":{"151":{"position":[[1201,25]]}}}],["displacementsprite.x",{"_index":2171,"t":{"151":{"position":[[1065,23],[1177,21],[1229,20]]}}}],["dist(p",{"_index":1627,"t":{"97":{"position":[[1545,6],[1584,6],[1623,6],[2226,8]]},"159":{"position":[[1412,6],[1451,6],[1490,6],[2074,8]]}}}],["dist(p+eps.xxy).x",{"_index":1631,"t":{"97":{"position":[[1603,17]]},"159":{"position":[[1470,17]]}}}],["dist(p+eps.xyx).x",{"_index":1629,"t":{"97":{"position":[[1564,17]]},"159":{"position":[[1431,17]]}}}],["dist(p+eps.yxx).x",{"_index":1626,"t":{"97":{"position":[[1525,17]]},"159":{"position":[[1392,17]]}}}],["dist(vec3",{"_index":1605,"t":{"97":{"position":[[1216,9]]},"159":{"position":[[1135,9]]}}}],["distance",{"_index":105,"t":{"41":{"position":[[1146,8],[1328,9],[1353,9],[1775,8]]},"49":{"position":[[940,8],[1000,9],[1035,9]]},"97":{"position":[[1059,8],[2270,8]]},"159":{"position":[[978,8],[2118,8]]},"165":{"position":[[2160,8],[2187,8]]}}}],["distancebetweentwopoints",{"_index":229,"t":{"41":{"position":[[4621,25]]}}}],["distancebetweentwopoints(p1",{"_index":125,"t":{"41":{"position":[[1818,28]]}}}],["distancecenter",{"_index":503,"t":{"49":{"position":[[1932,14],[2405,14]]}}}],["distances",{"_index":1604,"t":{"97":{"position":[[1200,10]]},"159":{"position":[[1119,10]]}}}],["distancescale",{"_index":505,"t":{"49":{"position":[[2009,13],[2079,13],[2336,13],[2367,13]]}}}],["distmouseredsquare",{"_index":228,"t":{"41":{"position":[[4600,18],[4705,18]]}}}],["document.body.append(a",{"_index":333,"t":{"45":{"position":[[418,24]]}}}],["document.body.appendchild(app.view",{"_index":51,"t":{"41":{"position":[[285,36]]},"43":{"position":[[89,36]]},"45":{"position":[[114,36]]},"47":{"position":[[112,36]]},"49":{"position":[[89,36]]},"51":{"position":[[112,36]]},"53":{"position":[[112,36]]},"55":{"position":[[112,36]]},"57":{"position":[[112,36]]},"59":{"position":[[112,36]]},"61":{"position":[[112,36]]},"63":{"position":[[89,36]]},"65":{"position":[[89,36]]},"67":{"position":[[112,36]]},"69":{"position":[[112,36]]},"71":{"position":[[112,36]]},"73":{"position":[[89,36]]},"75":{"position":[[112,36]]},"77":{"position":[[109,36]]},"79":{"position":[[89,36]]},"81":{"position":[[112,36]]},"83":{"position":[[89,36]]},"85":{"position":[[188,36]]},"87":{"position":[[104,36]]},"89":{"position":[[112,36]]},"91":{"position":[[205,36]]},"93":{"position":[[157,36]]},"95":{"position":[[112,36]]},"97":{"position":[[384,36]]},"99":{"position":[[89,36]]},"101":{"position":[[89,36]]},"103":{"position":[[327,36]]},"105":{"position":[[89,36]]},"107":{"position":[[89,36]]},"109":{"position":[[106,36]]},"111":{"position":[[138,36]]},"147":{"position":[[106,36]]},"149":{"position":[[106,36]]},"151":{"position":[[89,36]]},"153":{"position":[[89,36]]},"155":{"position":[[89,36]]},"157":{"position":[[89,36]]},"159":{"position":[[89,36]]},"161":{"position":[[89,36]]},"163":{"position":[[89,36]]},"165":{"position":[[102,36]]},"167":{"position":[[89,36]]},"169":{"position":[[89,36]]},"171":{"position":[[89,36]]},"173":{"position":[[89,36]]},"175":{"position":[[89,36]]},"177":{"position":[[89,36]]},"179":{"position":[[89,36]]},"181":{"position":[[107,36]]},"183":{"position":[[107,36]]},"187":{"position":[[112,36]]},"189":{"position":[[112,36]]},"191":{"position":[[112,36]]},"193":{"position":[[89,36]]},"195":{"position":[[109,36]]},"197":{"position":[[112,36]]},"199":{"position":[[112,36]]},"201":{"position":[[1590,36]]},"203":{"position":[[112,36]]},"205":{"position":[[112,36]]},"207":{"position":[[89,36]]},"209":{"position":[[244,36]]},"211":{"position":[[89,36]]},"244":{"position":[[112,36]]},"258":{"position":[[89,36]]}}}],["document.body.appendchild(canvas",{"_index":2512,"t":{"185":{"position":[[292,34]]}}}],["document.createelement('a",{"_index":332,"t":{"45":{"position":[[389,28]]}}}],["document.createelement('canvas",{"_index":2508,"t":{"185":{"position":[[124,33]]},"201":{"position":[[661,33]]},"209":{"position":[[421,33]]}}}],["document.createelement('script",{"_index":2616,"t":{"199":{"position":[[364,33]]}}}],["document.getelementsbytagname('script')[0",{"_index":2625,"t":{"199":{"position":[[584,43]]}}}],["document.location.protocol",{"_index":2618,"t":{"199":{"position":[[407,29]]}}}],["doesn't",{"_index":2048,"t":{"111":{"position":[[848,7]]}}}],["doesnt",{"_index":2824,"t":{"211":{"position":[[778,6]]}}}],["doing",{"_index":1575,"t":{"97":{"position":[[92,5]]}}}],["don't",{"_index":204,"t":{"41":{"position":[[3801,5]]},"69":{"position":[[8657,5]]},"103":{"position":[[464,5]]},"195":{"position":[[1101,5]]}}}],["done",{"_index":180,"t":{"41":{"position":[[2819,4]]},"53":{"position":[[3530,4]]}}}],["dont",{"_index":2640,"t":{"201":{"position":[[362,4],[600,4]]}}}],["dot",{"_index":1635,"t":{"97":{"position":[[1669,4]]},"159":{"position":[[1536,4]]}}}],["dotrice",{"_index":2733,"t":{"205":{"position":[[342,8],[845,8]]}}}],["down",{"_index":1788,"t":{"103":{"position":[[1656,4]]}}}],["downloaded",{"_index":796,"t":{"59":{"position":[[752,10],[1937,10]]}}}],["downstream",{"_index":1766,"t":{"103":{"position":[[1053,10]]}}}],["dragging",{"_index":290,"t":{"43":{"position":[[1193,8],[1286,10],[1896,8],[1963,8]]},"95":{"position":[[1646,8]]}}}],["dragtarget",{"_index":1447,"t":{"89":{"position":[[1207,10],[1405,12],[1701,10],[1789,12],[1868,10]]}}}],["dragtarget.alpha",{"_index":1465,"t":{"89":{"position":[[1846,16]]}}}],["dragtarget.parent.tolocal(event.global",{"_index":1452,"t":{"89":{"position":[[1420,39]]}}}],["dragtarget.position",{"_index":1453,"t":{"89":{"position":[[1466,21]]}}}],["draw",{"_index":1535,"t":{"95":{"position":[[509,4]]},"109":{"position":[[344,4],[665,4],[937,4],[1031,4],[1451,4]]},"111":{"position":[[793,4],[1417,4],[1647,4],[1816,4],[1951,4],[2088,4],[2225,4]]},"207":{"position":[[273,4]]}}}],["drawcircle(0",{"_index":257,"t":{"43":{"position":[[231,14]]},"91":{"position":[[393,14]]},"95":{"position":[[581,14]]}}}],["drawcircle(radius",{"_index":2452,"t":{"177":{"position":[[514,18]]}}}],["drawing",{"_index":300,"t":{"43":{"position":[[1433,7]]}}}],["drawn",{"_index":262,"t":{"43":{"position":[[297,5],[1506,5]]}}}],["drawrect(0",{"_index":1316,"t":{"85":{"position":[[688,12]]},"95":{"position":[[399,12]]}}}],["drawrect(100",{"_index":1323,"t":{"85":{"position":[[890,14]]}}}],["drawrect(starbutton3.x",{"_index":1381,"t":{"87":{"position":[[1324,24]]}}}],["drawrect(starbutton4.x",{"_index":1394,"t":{"87":{"position":[[1849,24]]}}}],["drawroundedrect(0",{"_index":2546,"t":{"195":{"position":[[262,19]]}}}],["drawstar(0",{"_index":1846,"t":{"103":{"position":[[3649,12]]}}}],["dropshadow",{"_index":606,"t":{"53":{"position":[[2285,11]]},"203":{"position":[[464,11],[866,11]]}}}],["dropshadowalpha",{"_index":2715,"t":{"203":{"position":[[884,16]]}}}],["dropshadowangle",{"_index":610,"t":{"53":{"position":[[2350,16]]},"203":{"position":[[529,16],[906,16]]}}}],["dropshadowblur",{"_index":609,"t":{"53":{"position":[[2331,15]]},"203":{"position":[[510,15],[928,15]]}}}],["dropshadowcolor",{"_index":607,"t":{"53":{"position":[[2303,16]]},"203":{"position":[[482,16],[947,16]]}}}],["dropshadowdistance",{"_index":612,"t":{"53":{"position":[[2380,19]]},"203":{"position":[[559,19],[976,19]]}}}],["dude",{"_index":895,"t":{"65":{"position":[[576,4],[696,4],[769,4],[1216,4],[1305,4],[1383,4],[1867,4]]},"73":{"position":[[328,4],[511,4],[624,4],[1069,4],[1158,4],[1236,4],[1715,4]]},"79":{"position":[[488,4],[1244,4],[1749,4]]},"211":{"position":[[1285,4]]}}}],["dude.anchor.set(0.5",{"_index":897,"t":{"65":{"position":[[644,21]]},"73":{"position":[[459,21]]},"79":{"position":[[622,21]]}}}],["dude.blendmode",{"_index":906,"t":{"65":{"position":[[1013,14]]}}}],["dude.direction",{"_index":910,"t":{"65":{"position":[[1111,14],[1888,14],[2047,14]]},"73":{"position":[[964,14],[1733,14],[1892,14]]},"79":{"position":[[910,14],[1827,14],[2020,14]]}}}],["dude.offset",{"_index":1215,"t":{"79":{"position":[[1186,11],[1806,12]]}}}],["dude.rotation",{"_index":932,"t":{"65":{"position":[[2030,13]]},"73":{"position":[[1875,13]]},"79":{"position":[[2003,13]]}}}],["dude.scale.set(0.8",{"_index":898,"t":{"65":{"position":[[701,18]]},"73":{"position":[[557,18]]},"79":{"position":[[682,18]]}}}],["dude.scale.x",{"_index":2837,"t":{"211":{"position":[[1352,12]]}}}],["dude.scale.y",{"_index":1220,"t":{"79":{"position":[[1768,12],[1922,14],[1988,14]]},"211":{"position":[[1372,12]]}}}],["dude.speed",{"_index":915,"t":{"65":{"position":[[1324,10],[1969,11],[2018,11]]},"73":{"position":[[1177,10],[1814,11],[1863,11]]},"79":{"position":[[1142,10],[1908,11],[1974,11]]}}}],["dude.texture.rotate",{"_index":2840,"t":{"211":{"position":[[1550,24]]}}}],["dude.tint",{"_index":1155,"t":{"73":{"position":[[745,9]]},"79":{"position":[[832,9]]}}}],["dude.turningspeed",{"_index":913,"t":{"65":{"position":[[1231,17],[1906,17]]},"73":{"position":[[1084,17],[1751,17]]},"79":{"position":[[1032,17],[1845,17]]}}}],["dude.x",{"_index":901,"t":{"65":{"position":[[804,6],[1932,6],[2125,7],[2151,6],[2189,7],[2234,6]]},"73":{"position":[[658,6],[1777,6],[1970,7],[1996,6],[2034,7],[2079,6]]},"79":{"position":[[745,6],[1871,6],[2069,7],[2095,6],[2133,7],[2178,6]]},"211":{"position":[[1411,6],[1665,7]]}}}],["dude.y",{"_index":902,"t":{"65":{"position":[[859,6],[1981,6],[2267,7],[2293,6],[2332,7],[2378,6]]},"73":{"position":[[701,6],[1826,6],[2112,7],[2138,6],[2177,7],[2223,6]]},"79":{"position":[[788,6],[1937,6],[2211,7],[2237,6],[2276,7],[2322,6]]},"211":{"position":[[1447,6],[1682,6]]}}}],["dudearray",{"_index":890,"t":{"65":{"position":[[407,9],[1397,9]]}}}],["dudearray.length",{"_index":928,"t":{"65":{"position":[[1836,17]]}}}],["dudearray.push(dude",{"_index":919,"t":{"65":{"position":[[1445,21]]}}}],["dudearray[i",{"_index":929,"t":{"65":{"position":[[1874,13]]}}}],["dudebounds",{"_index":924,"t":{"65":{"position":[[1578,10]]},"73":{"position":[[1431,10]]},"79":{"position":[[1445,10]]}}}],["dudebounds.height",{"_index":939,"t":{"65":{"position":[[2303,18],[2357,18],[2388,18]]},"73":{"position":[[2148,18],[2202,18],[2233,18]]},"79":{"position":[[2247,18],[2301,18],[2332,18]]}}}],["dudebounds.width",{"_index":937,"t":{"65":{"position":[[2161,17],[2214,17],[2244,17]]},"73":{"position":[[2006,17],[2059,17],[2089,17]]},"79":{"position":[[2105,17],[2158,17],[2188,17]]}}}],["dudebounds.x",{"_index":936,"t":{"65":{"position":[[2135,13],[2199,12]]},"73":{"position":[[1980,13],[2044,12]]},"79":{"position":[[2079,13],[2143,12]]}}}],["dudebounds.y",{"_index":938,"t":{"65":{"position":[[2277,13],[2342,12]]},"73":{"position":[[2122,13],[2187,12]]},"79":{"position":[[2221,13],[2286,12]]}}}],["dudeboundspadding",{"_index":923,"t":{"65":{"position":[[1547,17],[1612,18],[1632,18],[1670,17],[1713,17]]},"73":{"position":[[1400,17],[1464,18],[1484,18],[1522,17],[1565,17]]},"79":{"position":[[1414,17],[1479,18],[1499,18],[1537,17],[1580,17]]}}}],["dudes",{"_index":889,"t":{"65":{"position":[[395,5],[1535,5],[1785,5],[2089,5]]},"73":{"position":[[1388,5],[1635,5],[1934,5]]}}}],["dxcenter",{"_index":501,"t":{"49":{"position":[[1803,8],[1970,8],[2493,9]]}}}],["dycenter",{"_index":502,"t":{"49":{"position":[[1867,8],[1981,8],[1992,10]]}}}],["dynamic",{"_index":2748,"t":{"207":{"position":[[240,7]]}}}],["dynamically",{"_index":2517,"t":{"189":{"position":[[781,11]]}}}],["e",{"_index":1475,"t":{"91":{"position":[[718,3]]},"103":{"position":[[1828,3],[4400,3],[4584,3],[5103,3]]}}}],["e.currenttarget.name",{"_index":1336,"t":{"85":{"position":[[1227,21]]}}}],["e.global.x",{"_index":1891,"t":{"103":{"position":[[5127,14]]}}}],["e.global.y",{"_index":1892,"t":{"103":{"position":[[5148,12]]}}}],["e.screen.x",{"_index":1893,"t":{"103":{"position":[[5184,14]]}}}],["e.screen.y",{"_index":1894,"t":{"103":{"position":[[5205,12]]}}}],["e.target.name",{"_index":1334,"t":{"85":{"position":[[1186,14]]}}}],["e.type",{"_index":1332,"t":{"85":{"position":[[1159,7]]}}}],["each",{"_index":238,"t":{"41":{"position":[[5043,4]]},"69":{"position":[[6066,4],[8414,4]]},"85":{"position":[[394,4]]},"165":{"position":[[1624,4]]},"207":{"position":[[1739,4]]}}}],["easier",{"_index":1441,"t":{"89":{"position":[[937,6]]},"244":{"position":[[962,6]]}}}],["easily",{"_index":916,"t":{"65":{"position":[[1423,6]]},"73":{"position":[[1279,6]]},"79":{"position":[[1288,6]]}}}],["easing",{"_index":482,"t":{"49":{"position":[[1218,7],[1259,6]]},"53":{"position":[[4722,7],[4834,7]]}}}],["easy",{"_index":2575,"t":{"195":{"position":[[1323,5]]}}}],["edge",{"_index":1026,"t":{"69":{"position":[[3027,5],[4820,4],[4889,4]]}}}],["edge.drawroundedrect(0",{"_index":1054,"t":{"69":{"position":[[4956,23]]}}}],["edge.endfill",{"_index":1055,"t":{"69":{"position":[[5007,15]]}}}],["edge.linestyle(linesize",{"_index":1053,"t":{"69":{"position":[[4917,24]]}}}],["edge.mask",{"_index":1064,"t":{"69":{"position":[[5243,9]]}}}],["edges",{"_index":413,"t":{"47":{"position":[[1471,6]]},"69":{"position":[[4167,6],[5163,6]]},"165":{"position":[[1196,5],[3528,5]]}}}],["effect",{"_index":2325,"t":{"165":{"position":[[2721,7],[3354,6]]}}}],["egg",{"_index":780,"t":{"57":{"position":[[832,3]]}}}],["egg.anchor.set(0.5",{"_index":782,"t":{"57":{"position":[[874,20]]}}}],["egg.x",{"_index":783,"t":{"57":{"position":[[895,5]]}}}],["egg.y",{"_index":785,"t":{"57":{"position":[[928,5]]}}}],["egghead",{"_index":741,"t":{"55":{"position":[[404,12],[1094,9]]},"57":{"position":[[439,12],[487,8]]},"59":{"position":[[382,10]]}}}],["egghead.png",{"_index":842,"t":{"63":{"position":[[318,14]]}}}],["elements",{"_index":2856,"t":{"244":{"position":[[981,8]]}}}],["ellipse",{"_index":2053,"t":{"111":{"position":[[1262,7]]}}}],["embedded",{"_index":1594,"t":{"97":{"position":[[834,8]]}}}],["empty",{"_index":847,"t":{"63":{"position":[[410,5]]}}}],["enable",{"_index":1326,"t":{"85":{"position":[[965,6]]},"89":{"position":[[599,6]]},"91":{"position":[[496,6]]},"195":{"position":[[508,6]]}}}],["enabled",{"_index":1968,"t":{"107":{"position":[[1079,7],[1130,7],[1140,9],[1170,7]]},"199":{"position":[[678,7]]}}}],["end",{"_index":993,"t":{"69":{"position":[[1835,3]]}}}],["endfill",{"_index":1317,"t":{"85":{"position":[[714,12],[920,12]]},"87":{"position":[[1373,11],[1898,11]]},"91":{"position":[[414,12]]},"177":{"position":[[572,11]]},"195":{"position":[[299,10]]}}}],["enough",{"_index":815,"t":{"59":{"position":[[1330,6]]}}}],["eps",{"_index":1623,"t":{"97":{"position":[[1475,3]]},"159":{"position":[[1342,3]]}}}],["eps.xxy).x",{"_index":1632,"t":{"97":{"position":[[1630,10]]},"159":{"position":[[1497,10]]}}}],["eps.xyx).x",{"_index":1630,"t":{"97":{"position":[[1591,11]]},"159":{"position":[[1458,11]]}}}],["eps.yxx).x",{"_index":1628,"t":{"97":{"position":[[1552,11]]},"159":{"position":[[1419,11]]}}}],["equivalent",{"_index":1158,"t":{"73":{"position":[[934,10]]}}}],["error('the",{"_index":1802,"t":{"103":{"position":[[2046,10]]}}}],["eslint",{"_index":1796,"t":{"103":{"position":[[1968,6]]},"199":{"position":[[283,6],[671,6]]}}}],["etc",{"_index":2597,"t":{"197":{"position":[[754,3]]}}}],["even",{"_index":1388,"t":{"87":{"position":[[1669,4]]}}}],["event",{"_index":168,"t":{"41":{"position":[[2637,7]]},"47":{"position":[[948,7]]},"85":{"position":[[1256,5],[1326,5]]},"93":{"position":[[1523,7]]},"103":{"position":[[1019,5]]},"177":{"position":[[1008,7]]},"195":{"position":[[673,5],[922,5]]}}}],["event.data",{"_index":1461,"t":{"89":{"position":[[1671,11]]}}}],["event.global.x",{"_index":170,"t":{"41":{"position":[[2666,15]]},"47":{"position":[[1028,15]]},"177":{"position":[[1040,14]]}}}],["event.global.y",{"_index":172,"t":{"41":{"position":[[2698,15]]},"47":{"position":[[1062,15]]},"177":{"position":[[1093,14]]}}}],["eventboundary",{"_index":1751,"t":{"103":{"position":[[689,14]]}}}],["eventdata.data.global.y",{"_index":1939,"t":{"105":{"position":[[1768,25]]}}}],["events",{"_index":1184,"t":{"75":{"position":[[695,7]]},"83":{"position":[[1060,6],[1103,6],[1143,7],[1332,6],[1524,6]]},"85":{"position":[[67,6],[88,6],[384,6]]},"89":{"position":[[686,6],[981,6],[1027,6]]},"103":{"position":[[136,6],[600,6],[1046,6],[1649,6]]}}}],["everywhere",{"_index":1327,"t":{"85":{"position":[[986,11]]},"103":{"position":[[4067,11]]}}}],["exact",{"_index":1602,"t":{"97":{"position":[[1168,5]]},"159":{"position":[[1087,5]]}}}],["example",{"_index":540,"t":{"53":{"position":[[444,8]]},"59":{"position":[[185,7]]},"65":{"position":[[944,8]]},"69":{"position":[[5039,7],[5082,7]]},"85":{"position":[[41,7]]},"91":{"position":[[46,8]]},"97":{"position":[[220,7]]},"103":{"position":[[73,7]]},"165":{"position":[[1678,8]]},"185":{"position":[[41,7]]},"195":{"position":[[755,8]]}}}],["examples",{"_index":2,"t":{"17":{"position":[[22,8],[160,8]]},"69":{"position":[[8715,8]]}}}],["except",{"_index":1060,"t":{"69":{"position":[[5096,6]]}}}],["exception",{"_index":2823,"t":{"211":{"position":[[760,9]]}}}],["explosion",{"_index":2497,"t":{"183":{"position":[[475,9],[506,9]]}}}],["explosion.anchor.set(0.5",{"_index":2501,"t":{"183":{"position":[[659,26]]}}}],["explosion.gotoandplay(math.random",{"_index":2504,"t":{"183":{"position":[[781,35]]}}}],["explosion.rotation",{"_index":2502,"t":{"183":{"position":[[686,18]]}}}],["explosion.scale.set(0.75",{"_index":2503,"t":{"183":{"position":[[732,24]]}}}],["explosion.x",{"_index":2499,"t":{"183":{"position":[[562,11]]}}}],["explosion.y",{"_index":2500,"t":{"183":{"position":[[610,11]]}}}],["explosiontextures",{"_index":2493,"t":{"183":{"position":[[270,17]]}}}],["explosiontextures.push(texture",{"_index":2496,"t":{"183":{"position":[[400,32]]}}}],["extends",{"_index":1755,"t":{"103":{"position":[[762,7]]},"201":{"position":[[284,7]]}}}],["extra",{"_index":650,"t":{"53":{"position":[[3282,5],[3362,6],[3399,5]]},"65":{"position":[[1067,5]]},"73":{"position":[[798,5]]}}}],["extras",{"_index":1731,"t":{"103":{"position":[[56,8]]},"111":{"position":[[56,8]]}}}],["factor",{"_index":427,"t":{"47":{"position":[[1848,7],[1872,6]]}}}],["fake",{"_index":2686,"t":{"201":{"position":[[1713,4]]}}}],["false",{"_index":291,"t":{"43":{"position":[[1204,6],[1376,6],[1404,6],[1742,6],[1770,6],[1974,6]]},"53":{"position":[[3118,6],[3581,6]]},"69":{"position":[[4052,7],[8638,5],[8908,6],[9040,6],[9290,6]]},"81":{"position":[[1955,6],[2208,6]]},"83":{"position":[[2050,6],[2303,6]]},"97":{"position":[[2751,6]]},"105":{"position":[[1370,6]]},"155":{"position":[[472,6],[591,6]]},"159":{"position":[[2647,6]]},"181":{"position":[[79,6]]},"183":{"position":[[79,6]]},"207":{"position":[[2251,6]]}}}],["families",{"_index":2608,"t":{"199":{"position":[[229,9]]}}}],["far",{"_index":226,"t":{"41":{"position":[[4544,3]]},"49":{"position":[[2282,3]]}}}],["fast",{"_index":55,"t":{"41":{"position":[[365,4]]},"49":{"position":[[2212,4]]},"181":{"position":[[818,4],[844,4]]}}}],["fast.anchor.set(0.5",{"_index":2485,"t":{"181":{"position":[[886,21]]}}}],["fast.play",{"_index":2490,"t":{"181":{"position":[[1011,12]]}}}],["fast.scale.set(scaling",{"_index":2486,"t":{"181":{"position":[[908,24]]}}}],["fast.width",{"_index":2488,"t":{"181":{"position":[[962,11]]}}}],["fast.x",{"_index":2487,"t":{"181":{"position":[[933,6]]}}}],["fast.y",{"_index":2489,"t":{"181":{"position":[[979,6]]}}}],["featured",{"_index":14,"t":{"17":{"position":[[151,8]]}}}],["feedback",{"_index":1557,"t":{"95":{"position":[[1655,8]]},"103":{"position":[[4360,8]]}}}],["fetch('https://pixijs.com/assets/pixi",{"_index":1683,"t":{"99":{"position":[[396,37]]}}}],["ffffff",{"_index":600,"t":{"53":{"position":[[2210,11]]},"87":{"position":[[2367,9]]},"203":{"position":[[389,11],[1006,12]]}}}],["figure",{"_index":219,"t":{"41":{"position":[[4344,6],[4463,6]]}}}],["file",{"_index":1593,"t":{"97":{"position":[[823,4]]},"205":{"position":[[171,5]]}}}],["files",{"_index":830,"t":{"59":{"position":[[1919,5]]}}}],["fill",{"_index":363,"t":{"45":{"position":[[1098,5]]},"53":{"position":[[2204,5]]},"69":{"position":[[2032,4],[6986,4]]},"87":{"position":[[2361,5]]},"95":{"position":[[1277,5]]},"97":{"position":[[558,5]]},"103":{"position":[[4804,5],[5534,5]]},"107":{"position":[[1327,5]]},"109":{"position":[[254,4],[564,4]]},"147":{"position":[[1447,5]]},"199":{"position":[[883,5]]},"203":{"position":[[383,5],[1000,5]]},"211":{"position":[[1622,5]]}}}],["filter",{"_index":660,"t":{"53":{"position":[[3745,6]]},"93":{"position":[[1327,6],[1421,9]]},"97":{"position":[[504,6],[2611,7],[2771,6],[2778,6],[2915,9]]},"99":{"position":[[504,7],[585,7],[634,6],[739,6],[840,6],[868,9],[937,6]]},"107":{"position":[[315,6],[1050,9],[1180,8],[1664,7]]}}}],["filter.uniforms.customuniform",{"_index":1699,"t":{"99":{"position":[[793,29],[972,29]]}}}],["filter.uniforms.mouse.copyfrom(event.global",{"_index":1526,"t":{"93":{"position":[[1536,45]]}}}],["filter.uniforms.time",{"_index":1681,"t":{"97":{"position":[[2983,20]]}}}],["filtered",{"_index":2326,"t":{"165":{"position":[[2741,8]]}}}],["filters",{"_index":1479,"t":{"93":{"position":[[90,7]]},"107":{"position":[[1250,7]]}}}],["filters/bg_depth_blur.jpg",{"_index":1705,"t":{"101":{"position":[[186,28]]}}}],["filters/depth_blur_dudes.jpg",{"_index":1710,"t":{"101":{"position":[[368,31]]}}}],["filters/depth_blur_moby.jpg",{"_index":1716,"t":{"101":{"position":[[569,30]]}}}],["filters/displace.png",{"_index":1919,"t":{"105":{"position":[[957,23]]}}}],["filters/displacement_map_repeat.jpg",{"_index":2157,"t":{"151":{"position":[[441,38]]}}}],["filters/flag.png",{"_index":2153,"t":{"151":{"position":[[291,19]]}}}],["filters/ring.png",{"_index":1927,"t":{"105":{"position":[[1313,19]]}}}],["filters/shader.frag",{"_index":1684,"t":{"99":{"position":[[434,21]]}}}],["final",{"_index":2362,"t":{"165":{"position":[[4347,5]]}}}],["finally",{"_index":900,"t":{"65":{"position":[[747,7],[1363,7]]},"73":{"position":[[603,7],[1216,7]]},"79":{"position":[[1224,7]]}}}],["find",{"_index":5,"t":{"17":{"position":[[50,4]]},"69":{"position":[[1328,4],[6134,4]]}}}],["finish",{"_index":1682,"t":{"99":{"position":[[377,6]]}}}],["first",{"_index":1698,"t":{"99":{"position":[[780,5]]},"103":{"position":[[1301,5],[5402,5]]},"165":{"position":[[998,5]]}}}],["fit",{"_index":567,"t":{"53":{"position":[[1331,3]]}}}],["fixed",{"_index":1076,"t":{"69":{"position":[[7329,5]]}}}],["flag",{"_index":748,"t":{"55":{"position":[[577,4]]},"151":{"position":[[235,4]]}}}],["flag.filters",{"_index":2162,"t":{"151":{"position":[[793,12]]}}}],["flag.position",{"_index":2161,"t":{"151":{"position":[[738,14]]}}}],["flag.x",{"_index":2155,"t":{"151":{"position":[[337,6]]}}}],["flag.y",{"_index":2156,"t":{"151":{"position":[[351,6]]}}}],["flash",{"_index":2593,"t":{"197":{"position":[[569,6]]}}}],["flexibility",{"_index":2855,"t":{"244":{"position":[[937,11]]}}}],["flight",{"_index":477,"t":{"49":{"position":[[1057,6]]}}}],["float",{"_index":1498,"t":{"93":{"position":[[683,6],[796,5]]},"97":{"position":[[1044,5],[1231,5],[1283,5],[1338,5],[1875,5],[2144,5]]},"153":{"position":[[543,6],[837,6]]},"155":{"position":[[1023,6],[1329,6]]},"159":{"position":[[534,6],[904,6],[963,5],[1150,5],[1202,5],[1723,5],[1992,5]]},"161":{"position":[[935,6],[1229,6]]},"163":{"position":[[484,6],[778,6]]},"165":{"position":[[585,6],[1072,6],[1106,5],[1998,6],[2032,5],[2054,5],[2181,5],[2802,6],[2836,5],[2888,5],[3405,6],[3439,5],[3464,5],[4417,6]]},"167":{"position":[[418,6],[712,6],[967,6],[1261,6]]},"171":{"position":[[280,6],[521,6]]},"173":{"position":[[608,6],[984,6]]},"175":{"position":[[502,6],[804,6]]},"179":{"position":[[515,6],[830,6],[893,5]]}}}],["float32array(geometry.instancecount",{"_index":2212,"t":{"155":{"position":[[350,35]]}}}],["floor(p.x)+floor(p.y",{"_index":1607,"t":{"97":{"position":[[1242,22]]},"159":{"position":[[1161,22]]}}}],["floor(uv*zoom",{"_index":2290,"t":{"165":{"position":[[1254,15]]}}}],["flower",{"_index":773,"t":{"57":{"position":[[657,6]]}}}],["flower.anchor.set(0.5",{"_index":775,"t":{"57":{"position":[[704,23]]}}}],["flower.x",{"_index":776,"t":{"57":{"position":[[728,8]]}}}],["flower.y",{"_index":778,"t":{"57":{"position":[[764,8]]}}}],["flowertop",{"_index":765,"t":{"55":{"position":[[1106,13]]},"59":{"position":[[270,12]]}}}],["flowertop.png",{"_index":843,"t":{"63":{"position":[[333,16]]}}}],["focus",{"_index":2457,"t":{"177":{"position":[[830,5],[909,6]]}}}],["focus.height",{"_index":2463,"t":{"177":{"position":[[1110,12]]}}}],["focus.position.x",{"_index":2460,"t":{"177":{"position":[[1021,16]]}}}],["focus.position.y",{"_index":2462,"t":{"177":{"position":[[1074,16]]}}}],["focus.width",{"_index":2461,"t":{"177":{"position":[[1057,11]]}}}],["follow",{"_index":1466,"t":{"91":{"position":[[69,6],[657,6]]}}}],["font",{"_index":2613,"t":{"199":{"position":[[320,4]]},"205":{"position":[[166,4]]}}}],["font/desyrel.xml').then",{"_index":2520,"t":{"191":{"position":[[200,26]]}}}],["fontfamily",{"_index":361,"t":{"45":{"position":[[1076,11]]},"53":{"position":[[2128,11]]},"95":{"position":[[1294,11]]},"103":{"position":[[4768,11],[5512,11]]},"107":{"position":[[1272,11]]},"147":{"position":[[1392,11]]},"199":{"position":[[846,11]]},"203":{"position":[[307,11],[845,11]]},"205":{"position":[[614,11],[720,11],[833,11],[951,11]]},"211":{"position":[[1577,11]]}}}],["fontname",{"_index":1884,"t":{"103":{"position":[[4949,9]]},"191":{"position":[[319,9]]}}}],["fonts",{"_index":2524,"t":{"191":{"position":[[284,5]]},"199":{"position":[[169,5]]}}}],["fontsize",{"_index":594,"t":{"53":{"position":[[2149,9]]},"85":{"position":[[411,9],[517,9]]},"95":{"position":[[1316,9]]},"97":{"position":[[574,9]]},"103":{"position":[[4790,9],[5498,9]]},"107":{"position":[[1293,9]]},"147":{"position":[[1413,9]]},"191":{"position":[[340,9]]},"199":{"position":[[869,9]]},"203":{"position":[[328,9],[1038,9]]},"205":{"position":[[639,9],[742,9],[864,9],[977,9]]},"211":{"position":[[1604,9]]}}}],["fontstyle",{"_index":596,"t":{"53":{"position":[[2163,10]]},"203":{"position":[[342,10]]}}}],["fontweight",{"_index":598,"t":{"53":{"position":[[2184,11]]},"107":{"position":[[1307,11]]},"147":{"position":[[1427,11]]},"203":{"position":[[363,11],[1052,11]]}}}],["forced",{"_index":1489,"t":{"93":{"position":[[481,6]]}}}],["forces",{"_index":745,"t":{"55":{"position":[[486,6]]}}}],["foreach((event",{"_index":1790,"t":{"103":{"position":[[1776,17]]}}}],["forward",{"_index":1644,"t":{"97":{"position":[[1897,7],[1960,8],[2023,10]]},"159":{"position":[[1745,7],[1808,8],[1871,10]]}}}],["found",{"_index":1070,"t":{"69":{"position":[[6269,5]]}}}],["fov",{"_index":445,"t":{"49":{"position":[[280,3],[1593,4],[1689,4]]},"97":{"position":[[1881,3]]},"159":{"position":[[1729,3]]}}}],["fov*forward",{"_index":1654,"t":{"97":{"position":[[2090,14]]},"159":{"position":[[1938,14]]}}}],["fragment",{"_index":1490,"t":{"93":{"position":[[491,8],[583,8]]},"97":{"position":[[748,8],[888,8],[2809,9]]}}}],["fragmentcombinesrc",{"_index":2364,"t":{"165":{"position":[[4376,18],[4880,19]]}}}],["fragmentgridsrc",{"_index":2284,"t":{"165":{"position":[[1034,15],[1526,16]]}}}],["fragmentnoisesrc",{"_index":2327,"t":{"165":{"position":[[2763,16],[3097,17]]}}}],["fragmentripplesrc",{"_index":2312,"t":{"165":{"position":[[1958,17],[2455,18]]}}}],["fragmentsrc",{"_index":2242,"t":{"159":{"position":[[815,11],[2731,12]]},"173":{"position":[[950,11],[1284,12]]},"179":{"position":[[796,11],[1159,12]]}}}],["fragmentwavesrc",{"_index":2339,"t":{"165":{"position":[[3367,15],[4104,16]]}}}],["frame",{"_index":667,"t":{"53":{"position":[[3859,5]]},"63":{"position":[[800,5]]},"67":{"position":[[878,5]]},"185":{"position":[[1056,5]]},"187":{"position":[[622,5]]},"211":{"position":[[496,5],[706,6],[912,6]]}}}],["framekey",{"_index":2468,"t":{"181":{"position":[[344,8]]}}}],["framename",{"_index":856,"t":{"63":{"position":[[739,9]]}}}],["framentsource",{"_index":1692,"t":{"99":{"position":[[619,14]]}}}],["frames",{"_index":2583,"t":{"197":{"position":[[289,6]]}}}],["frames.push(pixi.texture.from(`rollsequence00${val}.png",{"_index":2589,"t":{"197":{"position":[[440,59]]}}}],["friend",{"_index":1431,"t":{"89":{"position":[[547,8]]}}}],["fruits",{"_index":2763,"t":{"207":{"position":[[891,6]]}}}],["fruits.length",{"_index":2777,"t":{"207":{"position":[[1466,16]]}}}],["fullscreen",{"_index":2578,"t":{"195":{"position":[[1389,10]]}}}],["fun",{"_index":1193,"t":{"77":{"position":[[493,4]]},"187":{"position":[[529,4]]}}}],["function",{"_index":73,"t":{"41":{"position":[[563,8],[953,8],[1809,8],[4528,8]]},"43":{"position":[[519,8],[1238,8],[1866,8],[1935,8]]},"45":{"position":[[276,8]]},"47":{"position":[[1717,8],[1825,8],[1940,8]]},"49":{"position":[[686,8],[1266,8]]},"51":{"position":[[191,8],[206,8],[618,8]]},"53":{"position":[[453,8],[3128,8],[3155,8],[3544,8],[4568,9],[4673,8],[5497,8],[5567,8],[5661,8]]},"59":{"position":[[155,8],[648,8],[1242,8]]},"63":{"position":[[617,8],[1160,8]]},"69":{"position":[[8742,8]]},"75":{"position":[[821,8]]},"81":{"position":[[1819,8],[1917,8],[2058,8],[2169,8]]},"83":{"position":[[1914,8],[2012,8],[2153,8],[2264,8]]},"85":{"position":[[1124,8]]},"87":{"position":[[2964,8],[3009,8],[3060,8]]},"89":{"position":[[491,8],[1373,8],[1492,8],[1763,8]]},"95":{"position":[[1528,8],[1693,8],[1877,8]]},"97":{"position":[[1068,9],[2289,8],[2553,8]]},"99":{"position":[[541,8]]},"105":{"position":[[1649,8]]},"157":{"position":[[564,8]]},"159":{"position":[[987,9],[2137,8]]},"169":{"position":[[774,8]]},"195":{"position":[[1073,8]]},"199":{"position":[[339,11],[689,8]]},"201":{"position":[[143,9]]},"209":{"position":[[281,8]]}}}],["functions",{"_index":1110,"t":{"69":{"position":[[8485,9]]}}}],["funtion",{"_index":727,"t":{"53":{"position":[[5488,8]]}}}],["further",{"_index":35,"t":{"41":{"position":[[95,7],[3818,7]]}}}],["g",{"_index":2419,"t":{"169":{"position":[[445,1]]},"173":{"position":[[371,2],[391,2],[412,2]]},"175":{"position":[[371,2],[391,2],[412,2]]}}}],["g.beginfill(0xff0022",{"_index":2437,"t":{"169":{"position":[[995,22]]}}}],["g.clear",{"_index":2431,"t":{"169":{"position":[[800,10]]}}}],["g.drawcircle(points[i].x",{"_index":2438,"t":{"169":{"position":[[1018,25]]}}}],["g.endfill",{"_index":2439,"t":{"169":{"position":[[1062,12]]}}}],["g.linestyle(2",{"_index":2432,"t":{"169":{"position":[[811,14]]}}}],["g.lineto(points[i].x",{"_index":2436,"t":{"169":{"position":[[915,21]]}}}],["g.moveto(points[0].x",{"_index":2434,"t":{"169":{"position":[[837,21]]}}}],["g.x",{"_index":2420,"t":{"169":{"position":[[470,3]]}}}],["g.y",{"_index":2421,"t":{"169":{"position":[[485,3]]}}}],["game",{"_index":39,"t":{"41":{"position":[[164,4]]},"59":{"position":[[349,5],[605,5],[1388,4]]}}}],["generate",{"_index":2285,"t":{"165":{"position":[[1132,10],[2106,10]]}}}],["generated",{"_index":893,"t":{"65":{"position":[[546,9]]},"73":{"position":[[298,9]]},"97":{"position":[[110,9],[282,9]]}}}],["generates",{"_index":2283,"t":{"165":{"position":[[1010,9],[2729,9]]}}}],["generatespinner1",{"_index":958,"t":{"69":{"position":[[282,16]]}}}],["generatespinner1(new",{"_index":1095,"t":{"69":{"position":[[8114,20]]}}}],["generatespinner2",{"_index":1008,"t":{"69":{"position":[[2260,16]]}}}],["generatespinner2(new",{"_index":1097,"t":{"69":{"position":[[8156,20]]}}}],["generatespinner3",{"_index":1028,"t":{"69":{"position":[[3174,16]]}}}],["generatespinner3(new",{"_index":1099,"t":{"69":{"position":[[8199,20]]}}}],["generatespinner4",{"_index":1039,"t":{"69":{"position":[[4215,16]]}}}],["generatespinner4(new",{"_index":1101,"t":{"69":{"position":[[8242,20]]}}}],["generatespinner5",{"_index":1079,"t":{"69":{"position":[[7393,16]]}}}],["generatespinner5(new",{"_index":1103,"t":{"69":{"position":[[8285,20]]}}}],["geometry",{"_index":2177,"t":{"153":{"position":[[132,8]]},"155":{"position":[[132,8]]},"159":{"position":[[135,9],[151,8]]},"161":{"position":[[132,8]]},"163":{"position":[[132,8]]},"165":{"position":[[148,9],[164,8]]},"167":{"position":[[132,8]]},"171":{"position":[[132,8]]},"173":{"position":[[132,8]]},"175":{"position":[[132,8]]},"179":{"position":[[132,8]]}}}],["geometry.addattribute",{"_index":2213,"t":{"155":{"position":[[418,22],[540,22]]}}}],["geometry.instancecount",{"_index":2208,"t":{"155":{"position":[[242,22],[694,23]]}}}],["geometry.instanced",{"_index":2207,"t":{"155":{"position":[[215,18]]}}}],["geometry2",{"_index":2255,"t":{"161":{"position":[[483,9],[870,12]]}}}],["geometry3",{"_index":2256,"t":{"161":{"position":[[827,9]]}}}],["gettangent(k",{"_index":426,"t":{"47":{"position":[[1834,13],[2077,14],[2115,12]]}}}],["give",{"_index":93,"t":{"41":{"position":[[908,4]]},"201":{"position":[[1266,4]]}}}],["given",{"_index":123,"t":{"41":{"position":[[1796,5]]}}}],["gives",{"_index":2854,"t":{"244":{"position":[[918,5]]}}}],["gl",{"_index":2677,"t":{"201":{"position":[[1298,2]]}}}],["gl.pixelstorei(gl.unpack_premultiply_alpha_webgl",{"_index":2679,"t":{"201":{"position":[[1315,49]]}}}],["gl.teximage2d(basetexture.target",{"_index":2681,"t":{"201":{"position":[[1396,33]]}}}],["gl_fragcolor",{"_index":1511,"t":{"93":{"position":[[926,12],[1051,12]]},"97":{"position":[[2518,12]]},"153":{"position":[[906,12]]},"155":{"position":[[1369,12]]},"159":{"position":[[2366,12]]},"161":{"position":[[1298,12]]},"163":{"position":[[853,12]]},"165":{"position":[[1414,12],[2309,12],[2956,12],[3966,12],[4683,12]]},"167":{"position":[[781,12],[1330,12]]},"171":{"position":[[542,12]]},"173":{"position":[[1074,12]]},"175":{"position":[[846,12]]},"179":{"position":[[919,12]]}}}],["gl_fragcolor.g",{"_index":2407,"t":{"167":{"position":[[1437,14]]}}}],["gl_fragcolor.r",{"_index":2404,"t":{"167":{"position":[[1373,14]]}}}],["gl_position",{"_index":2193,"t":{"153":{"position":[[712,11]]},"155":{"position":[[1206,11]]},"159":{"position":[[703,11]]},"161":{"position":[[1104,11]]},"163":{"position":[[653,11]]},"165":{"position":[[754,11]]},"167":{"position":[[587,11],[1136,11]]},"171":{"position":[[396,11]]},"173":{"position":[[838,11]]},"175":{"position":[[679,11]]},"179":{"position":[[684,11]]}}}],["global",{"_index":294,"t":{"43":{"position":[[1261,7]]},"103":{"position":[[1209,6],[1395,6],[4833,11],[5118,6],[5245,8]]}}}],["global}\\nscreen",{"_index":1896,"t":{"103":{"position":[[5254,18]]}}}],["gltexture",{"_index":2647,"t":{"201":{"position":[[461,10]]}}}],["gltexture.height",{"_index":2673,"t":{"201":{"position":[[1153,16]]}}}],["gltexture.width",{"_index":2672,"t":{"201":{"position":[[1128,15]]}}}],["gltextures",{"_index":2694,"t":{"201":{"position":[[1861,11]]}}}],["go",{"_index":829,"t":{"59":{"position":[[1903,2]]}}}],["goback",{"_index":819,"t":{"59":{"position":[[1604,6]]}}}],["goback.anchor.set(0.5",{"_index":821,"t":{"59":{"position":[[1656,23]]}}}],["goback.cursor",{"_index":826,"t":{"59":{"position":[[1804,13]]}}}],["goback.destroy",{"_index":828,"t":{"59":{"position":[[1869,17]]}}}],["goback.eventmode",{"_index":825,"t":{"59":{"position":[[1775,16]]}}}],["goback.on('pointertap",{"_index":827,"t":{"59":{"position":[[1831,23]]}}}],["goback.x",{"_index":822,"t":{"59":{"position":[[1680,8]]}}}],["goback.y",{"_index":823,"t":{"59":{"position":[[1713,8]]}}}],["going",{"_index":678,"t":{"53":{"position":[[4203,5]]},"151":{"position":[[1146,5]]}}}],["gonext",{"_index":800,"t":{"59":{"position":[[927,6]]}}}],["gonext.anchor.set(0.5",{"_index":802,"t":{"59":{"position":[[981,23]]}}}],["gonext.cursor",{"_index":807,"t":{"59":{"position":[[1129,13]]}}}],["gonext.destroy",{"_index":809,"t":{"59":{"position":[[1194,17]]}}}],["gonext.eventmode",{"_index":806,"t":{"59":{"position":[[1100,16]]}}}],["gonext.on('pointertap",{"_index":808,"t":{"59":{"position":[[1156,23]]}}}],["gonext.x",{"_index":803,"t":{"59":{"position":[[1005,8]]}}}],["gonext.y",{"_index":804,"t":{"59":{"position":[[1038,8]]}}}],["good",{"_index":1179,"t":{"75":{"position":[[590,5]]}}}],["google",{"_index":2605,"t":{"199":{"position":[[162,6],[219,7]]}}}],["gpu",{"_index":2650,"t":{"201":{"position":[[642,3]]}}}],["grab",{"_index":1442,"t":{"89":{"position":[[947,4]]}}}],["gradbasetexture",{"_index":2684,"t":{"201":{"position":[[1633,15]]}}}],["gradbasetexture.setsize(500",{"_index":2695,"t":{"201":{"position":[[1873,28]]}}}],["gradient",{"_index":602,"t":{"53":{"position":[[2237,8]]},"201":{"position":[[78,8],[379,8],[1807,9]]},"203":{"position":[[416,8]]},"209":{"position":[[60,8],[565,8]]}}}],["gradientresource",{"_index":2638,"t":{"201":{"position":[[267,16],[1676,20]]}}}],["gradtexture",{"_index":2696,"t":{"201":{"position":[[1913,11]]},"209":{"position":[[865,11]]}}}],["graph",{"_index":1736,"t":{"103":{"position":[[168,6],[458,5],[1686,6]]}}}],["graphics",{"_index":24,"t":{"17":{"position":[[239,8]]},"103":{"position":[[3558,8]]},"109":{"position":[[213,8]]},"111":{"position":[[181,8]]}}}],["graphics.beginfill(0x3500fa",{"_index":2076,"t":{"111":{"position":[[2326,28]]}}}],["graphics.beginfill(0x35cc5a",{"_index":2058,"t":{"111":{"position":[[1859,28]]}}}],["graphics.beginfill(0x55335a",{"_index":2064,"t":{"111":{"position":[[2133,28]]}}}],["graphics.beginfill(0x650a5a",{"_index":2039,"t":{"111":{"position":[[377,29],[1021,28],[1708,28]]}}}],["graphics.beginfill(0xaa4f08",{"_index":2044,"t":{"111":{"position":[[669,29],[1321,28]]}}}],["graphics.beginfill(0xc34288",{"_index":2042,"t":{"111":{"position":[[530,29],[1171,28]]}}}],["graphics.beginfill(0xde3249",{"_index":2037,"t":{"111":{"position":[[226,29],[872,28]]}}}],["graphics.beginfill(0xff3300",{"_index":1987,"t":{"109":{"position":[[274,29]]},"111":{"position":[[1430,29]]}}}],["graphics.beginfill(0xff700b",{"_index":1998,"t":{"109":{"position":[[629,28]]}}}],["graphics.beginfill(0xffcc5a",{"_index":2061,"t":{"111":{"position":[[1996,28]]}}}],["graphics.beginfill(0xffff0b",{"_index":2014,"t":{"109":{"position":[[1068,28]]}}}],["graphics.beziercurveto",{"_index":2028,"t":{"109":{"position":[[1651,23]]}}}],["graphics.closepath",{"_index":1996,"t":{"109":{"position":[[513,21],[892,21]]},"111":{"position":[[1602,21]]}}}],["graphics.drawcircle(100",{"_index":2050,"t":{"111":{"position":[[905,24]]}}}],["graphics.drawcircle(250",{"_index":2051,"t":{"111":{"position":[[1054,24]]}}}],["graphics.drawcircle(400",{"_index":2052,"t":{"111":{"position":[[1204,24]]}}}],["graphics.drawcircle(470",{"_index":2015,"t":{"109":{"position":[[1103,24]]}}}],["graphics.drawellipse(600",{"_index":2054,"t":{"111":{"position":[[1354,25]]}}}],["graphics.drawpolygon(path",{"_index":2077,"t":{"111":{"position":[[2359,27]]}}}],["graphics.drawrect(200",{"_index":2040,"t":{"111":{"position":[[407,22]]}}}],["graphics.drawrect(350",{"_index":2043,"t":{"111":{"position":[[560,22]]}}}],["graphics.drawrect(50",{"_index":2011,"t":{"109":{"position":[[990,21]]},"111":{"position":[[256,21]]}}}],["graphics.drawrect(530",{"_index":2045,"t":{"111":{"position":[[699,22]]}}}],["graphics.drawroundedrect(50",{"_index":2057,"t":{"111":{"position":[[1744,28]]}}}],["graphics.drawstar(280",{"_index":2062,"t":{"111":{"position":[[2029,22]]}}}],["graphics.drawstar(360",{"_index":2059,"t":{"111":{"position":[[1892,22]]}}}],["graphics.drawstar(470",{"_index":2065,"t":{"111":{"position":[[2166,22]]}}}],["graphics.endfill",{"_index":1997,"t":{"109":{"position":[[535,19],[914,19],[1139,19]]},"111":{"position":[[293,19],[445,19],[598,19],[737,19],[940,19],[1089,19],[1239,19],[1394,19],[1624,19],[1793,19],[1928,19],[2065,19],[2202,19],[2387,19]]}}}],["graphics.linestyle(0",{"_index":2013,"t":{"109":{"position":[[1045,22]]},"111":{"position":[[767,22],[2303,22]]}}}],["graphics.linestyle(10",{"_index":1988,"t":{"109":{"position":[[304,22],[590,22]]},"111":{"position":[[493,22],[1134,22]]}}}],["graphics.linestyle(2",{"_index":2009,"t":{"109":{"position":[[954,21]]},"111":{"position":[[341,21],[633,21],[985,21],[1285,21],[1672,21],[1826,21],[1963,21]]}}}],["graphics.linestyle(20",{"_index":2016,"t":{"109":{"position":[[1159,22]]}}}],["graphics.linestyle(4",{"_index":2055,"t":{"111":{"position":[[1460,21],[2100,21]]}}}],["graphics.linestyle(math.random",{"_index":2026,"t":{"109":{"position":[[1523,32]]}}}],["graphics.lineto(100",{"_index":1993,"t":{"109":{"position":[[408,20]]},"111":{"position":[[1549,20]]}}}],["graphics.lineto(210",{"_index":2008,"t":{"109":{"position":[[865,20]]}}}],["graphics.lineto(250",{"_index":1992,"t":{"109":{"position":[[382,20],[435,20]]},"111":{"position":[[1522,20]]}}}],["graphics.lineto(330",{"_index":2006,"t":{"109":{"position":[[811,20]]}}}],["graphics.lineto(410",{"_index":2007,"t":{"109":{"position":[[838,20]]}}}],["graphics.lineto(450",{"_index":2001,"t":{"109":{"position":[[712,20]]}}}],["graphics.lineto(50",{"_index":1995,"t":{"109":{"position":[[462,19],[488,19]]},"111":{"position":[[1576,19]]}}}],["graphics.lineto(570",{"_index":2002,"t":{"109":{"position":[[739,20]]}}}],["graphics.lineto(600",{"_index":2019,"t":{"109":{"position":[[1218,20]]}}}],["graphics.moveto(210",{"_index":2000,"t":{"109":{"position":[[685,20]]}}}],["graphics.moveto(30",{"_index":2018,"t":{"109":{"position":[[1193,19]]}}}],["graphics.moveto(50",{"_index":1991,"t":{"109":{"position":[[357,19]]},"111":{"position":[[1496,19]]}}}],["graphics.moveto(math.random",{"_index":2027,"t":{"109":{"position":[[1592,29]]}}}],["graphics.quadraticcurveto(600",{"_index":2004,"t":{"109":{"position":[[766,30]]}}}],["grd",{"_index":2655,"t":{"201":{"position":[[784,3],[988,4]]},"209":{"position":[[580,3],[786,4]]}}}],["grd.addcolorstop(0",{"_index":2657,"t":{"201":{"position":[[832,19]]},"209":{"position":[[630,19]]}}}],["grd.addcolorstop(0.3",{"_index":2660,"t":{"201":{"position":[[881,21]]},"209":{"position":[[679,21]]}}}],["grd.addcolorstop(0.7",{"_index":2662,"t":{"201":{"position":[[912,21]]},"209":{"position":[[710,21]]}}}],["grd.addcolorstop(1",{"_index":2663,"t":{"201":{"position":[[942,19]]},"209":{"position":[[740,19]]}}}],["green",{"_index":133,"t":{"41":{"position":[[1933,5],[3111,5],[3468,5]]},"201":{"position":[[962,9]]},"209":{"position":[[760,9]]}}}],["greensquare",{"_index":135,"t":{"41":{"position":[[1972,11],[5671,13]]}}}],["greensquare.acceleration",{"_index":145,"t":{"41":{"position":[[2190,24]]}}}],["greensquare.acceleration.set",{"_index":245,"t":{"41":{"position":[[5308,29]]}}}],["greensquare.acceleration.set(greensquare.acceleration.x",{"_index":188,"t":{"41":{"position":[[2990,55]]}}}],["greensquare.acceleration.x",{"_index":196,"t":{"41":{"position":[[3268,26],[3298,27],[5434,26]]}}}],["greensquare.acceleration.y",{"_index":189,"t":{"41":{"position":[[3054,26],[3398,26],[3428,27],[5487,26]]}}}],["greensquare.height",{"_index":142,"t":{"41":{"position":[[2135,18]]}}}],["greensquare.mass",{"_index":146,"t":{"41":{"position":[[2236,16],[5248,18],[5286,18]]}}}],["greensquare.position.set((app.screen.width",{"_index":137,"t":{"41":{"position":[[2023,42],[3676,42]]}}}],["greensquare.tint",{"_index":143,"t":{"41":{"position":[[2161,16]]}}}],["greensquare.width",{"_index":141,"t":{"41":{"position":[[2110,17]]}}}],["greensquare.x",{"_index":194,"t":{"41":{"position":[[3202,14],[3224,13],[3540,15],[3565,13],[5417,13]]}}}],["greensquare.y",{"_index":197,"t":{"41":{"position":[[3331,14],[3353,13],[3609,13],[3632,13],[5470,13]]}}}],["grid",{"_index":942,"t":{"67":{"position":[[334,4]]},"165":{"position":[[1022,5],[1152,5],[1917,4],[2126,5]]},"185":{"position":[[512,4]]},"211":{"position":[[1406,4]]}}}],["gridcontainer",{"_index":2308,"t":{"165":{"position":[[1823,13]]}}}],["gridcontainer.addchild(gridquad",{"_index":2309,"t":{"165":{"position":[[1861,33]]}}}],["gridcontainer.position.set(10",{"_index":2378,"t":{"165":{"position":[[4978,30]]}}}],["gridh",{"_index":2832,"t":{"211":{"position":[[1136,5],[1466,5]]}}}],["gridquad",{"_index":2307,"t":{"165":{"position":[[1769,8]]}}}],["gridquad.shader.uniforms.zoom",{"_index":2392,"t":{"165":{"position":[[5495,29]]}}}],["gridshader",{"_index":2299,"t":{"165":{"position":[[1485,10],[1804,12]]}}}],["gridtexture",{"_index":2305,"t":{"165":{"position":[[1693,11],[2390,12],[5782,11]]}}}],["griduniforms",{"_index":2298,"t":{"165":{"position":[[1449,12],[1543,14]]}}}],["gridw",{"_index":2831,"t":{"211":{"position":[[1096,5],[1430,5]]}}}],["growing",{"_index":1340,"t":{"85":{"position":[[1535,7]]}}}],["guv",{"_index":2289,"t":{"165":{"position":[[1248,3]]}}}],["guv.y",{"_index":2297,"t":{"165":{"position":[[1378,6]]}}}],["h",{"_index":1609,"t":{"97":{"position":[[1289,1]]},"159":{"position":[[1208,1]]},"211":{"position":[[338,1],[584,3]]}}}],["h2",{"_index":1613,"t":{"97":{"position":[[1344,2]]}}}],["hack",{"_index":2822,"t":{"211":{"position":[[746,4]]}}}],["half",{"_index":1659,"t":{"97":{"position":[[2258,4]]},"159":{"position":[[2106,4]]}}}],["halfcircle",{"_index":1080,"t":{"69":{"position":[[7536,10],[7892,11]]}}}],["halfcircle.arc(0",{"_index":1083,"t":{"69":{"position":[[7637,17]]}}}],["halfcircle.beginfill(0xff0000",{"_index":1081,"t":{"69":{"position":[[7570,31]]}}}],["halfcircle.endfill",{"_index":1084,"t":{"69":{"position":[[7676,21]]}}}],["halfcircle.linestyle(2",{"_index":1082,"t":{"69":{"position":[[7602,23]]}}}],["halfcircle.position.set(50",{"_index":1085,"t":{"69":{"position":[[7698,27]]}}}],["halfcircle.rotation",{"_index":1093,"t":{"69":{"position":[[8062,19]]}}}],["halfhandlewidth",{"_index":1565,"t":{"95":{"position":[[1904,15],[2107,16]]}}}],["hand",{"_index":1174,"t":{"75":{"position":[[513,4]]},"89":{"position":[[755,4]]}}}],["handle",{"_index":1536,"t":{"95":{"position":[[518,6],[531,6],[717,6],[1236,6],[1509,6],[1673,6],[1860,6],[1947,6],[2141,6]]},"99":{"position":[[515,6]]}}}],["handle's",{"_index":1562,"t":{"95":{"position":[[1817,8]]}}}],["handle.cursor",{"_index":1541,"t":{"95":{"position":[[690,13]]}}}],["handle.eventmode",{"_index":1540,"t":{"95":{"position":[[661,16]]}}}],["handle.width",{"_index":1566,"t":{"95":{"position":[[1922,12]]}}}],["handle.x",{"_index":1539,"t":{"95":{"position":[[633,8],[2018,8],[2189,10]]}}}],["handle.y",{"_index":1537,"t":{"95":{"position":[[603,8]]}}}],["handler",{"_index":538,"t":{"53":{"position":[[425,7],[3535,8]]},"103":{"position":[[4545,7]]}}}],["handlers",{"_index":1863,"t":{"103":{"position":[[4204,8]]}}}],["handling",{"_index":1106,"t":{"69":{"position":[[8401,8]]},"83":{"position":[[1114,8]]}}}],["happens",{"_index":2669,"t":{"201":{"position":[[1063,7]]}}}],["hasn't",{"_index":742,"t":{"55":{"position":[[443,6]]}}}],["having",{"_index":1043,"t":{"69":{"position":[[4537,6]]}}}],["header",{"_index":626,"t":{"53":{"position":[[2684,6]]}}}],["headertext",{"_index":627,"t":{"53":{"position":[[2702,10]]}}}],["headertext.height",{"_index":635,"t":{"53":{"position":[[2859,18]]}}}],["headertext.width",{"_index":633,"t":{"53":{"position":[[2799,17]]}}}],["headertext.x",{"_index":631,"t":{"53":{"position":[[2760,12]]}}}],["headertext.y",{"_index":634,"t":{"53":{"position":[[2823,12]]}}}],["height",{"_index":271,"t":{"43":{"position":[[553,6],[603,6]]},"97":{"position":[[1098,6],[2282,6]]},"159":{"position":[[1017,6],[2130,6]]},"165":{"position":[[68,7],[1747,7],[2553,7],[3192,7],[4196,7]]},"193":{"position":[[303,6]]},"201":{"position":[[342,7],[407,6],[543,6],[733,7],[1019,8],[1172,7]]},"207":{"position":[[171,7]]},"244":{"position":[[551,7]]}}}],["heightmaps",{"_index":1661,"t":{"97":{"position":[[2330,11]]},"159":{"position":[[2178,11]]}}}],["helmlok.png",{"_index":844,"t":{"63":{"position":[[350,14]]}}}],["help",{"_index":10,"t":{"17":{"position":[[95,4]]},"107":{"position":[[1207,4]]},"147":{"position":[[1327,4]]}}}],["help.x",{"_index":1971,"t":{"107":{"position":[[1379,6]]},"147":{"position":[[1499,6]]}}}],["help.y",{"_index":1970,"t":{"107":{"position":[[1346,6]]},"147":{"position":[[1466,6]]}}}],["helper",{"_index":1109,"t":{"69":{"position":[[8478,6]]}}}],["here",{"_index":4,"t":{"17":{"position":[[37,4]]},"59":{"position":[[1278,4]]},"103":{"position":[[175,5]]},"201":{"position":[[118,4],[1700,4]]}}}],["highp",{"_index":1497,"t":{"93":{"position":[[677,5]]}}}],["history",{"_index":386,"t":{"47":{"position":[[481,7],[1192,7],[1342,8]]}}}],["historysize",{"_index":380,"t":{"47":{"position":[[302,11],[359,11],[516,12],[1533,13],[1602,13]]}}}],["historyx",{"_index":378,"t":{"47":{"position":[[263,8]]}}}],["historyx.pop",{"_index":401,"t":{"47":{"position":[[1200,15]]}}}],["historyx.push(0",{"_index":388,"t":{"47":{"position":[[536,17]]}}}],["historyx.unshift(mouseposition.x",{"_index":402,"t":{"47":{"position":[[1216,34]]}}}],["historyy",{"_index":379,"t":{"47":{"position":[[284,8]]}}}],["historyy.pop",{"_index":403,"t":{"47":{"position":[[1251,15]]}}}],["historyy.push(0",{"_index":389,"t":{"47":{"position":[[554,17]]}}}],["historyy.unshift(mouseposition.y",{"_index":404,"t":{"47":{"position":[[1267,34]]}}}],["hit",{"_index":69,"t":{"41":{"position":[[507,3]]},"69":{"position":[[1480,3],[1560,5],[1583,4],[6256,3],[6383,3],[6463,5],[6486,4]]},"87":{"position":[[1104,3],[1581,3],[2740,3]]},"103":{"position":[[4002,3]]}}}],["hit.x",{"_index":990,"t":{"69":{"position":[[1611,5],[6514,5]]}}}],["hitarea",{"_index":1362,"t":{"87":{"position":[[555,7],[667,7],[1952,7]]}}}],["hitareas",{"_index":1384,"t":{"87":{"position":[[1593,8]]}}}],["hits",{"_index":468,"t":{"49":{"position":[[876,4]]}}}],["hitting",{"_index":1072,"t":{"69":{"position":[[6282,7]]}}}],["holder",{"_index":838,"t":{"63":{"position":[[254,6]]},"73":{"position":[[129,6]]}}}],["hole",{"_index":2133,"t":{"149":{"position":[[1805,4]]}}}],["hover",{"_index":1255,"t":{"81":{"position":[[1200,8]]},"85":{"position":[[74,5]]}}}],["hovericon",{"_index":1229,"t":{"81":{"position":[[251,9],[451,10]]}}}],["http",{"_index":2620,"t":{"199":{"position":[[462,6]]}}}],["http://paulbourke.net/geometry/pointlineplane",{"_index":1115,"t":{"69":{"position":[[8530,46]]}}}],["https",{"_index":2619,"t":{"199":{"position":[[441,8],[452,7]]}}}],["https://developer.mozilla.org/en",{"_index":2796,"t":{"209":{"position":[[76,32]]}}}],["https://en.wikipedia.org/wiki/bΓ©zier_curve",{"_index":2084,"t":{"149":{"position":[[259,42]]}}}],["https://github.com/bfred",{"_index":2561,"t":{"195":{"position":[[835,24]]}}}],["https://github.com/createjs/tweenjs/blob/master/src/tweenjs/ease.js",{"_index":733,"t":{"53":{"position":[[5593,67]]}}}],["https://github.com/osuushi/smooth.js",{"_index":420,"t":{"47":{"position":[[1677,36]]}}}],["https://github.com/pixijs/pixi.js/blob/dev/packages/core/src/textures/resources/baseimageresource.js#l54",{"_index":2637,"t":{"201":{"position":[[156,104]]}}}],["https://github.com/pixijs/pixi.js/pull/7381",{"_index":1783,"t":{"103":{"position":[[1508,43]]}}}],["https://github.com/pixijs/pixi.js/wiki/v5",{"_index":1477,"t":{"93":{"position":[[39,41]]}}}],["https://pixijs.com/assets/bg_grass.jpg",{"_index":264,"t":{"43":{"position":[[366,42]]}}}],["https://pixijs.com/assets/bg_rotate.jpg",{"_index":266,"t":{"43":{"position":[[431,43]]}}}],["https://pixijs.com/assets/egghead.png",{"_index":528,"t":{"53":{"position":[[168,40]]},"55":{"position":[[275,41]]},"57":{"position":[[275,41]]},"59":{"position":[[399,40]]}}}],["https://pixijs.com/assets/flowertop.png",{"_index":529,"t":{"53":{"position":[[209,42]]},"55":{"position":[[204,43]]},"57":{"position":[[204,43]]},"59":{"position":[[289,42]]}}}],["https://pixijs.com/assets/helmlok.png",{"_index":530,"t":{"53":{"position":[[252,40]]}}}],["https://pixijs.com/assets/rt_object_01.png",{"_index":2764,"t":{"207":{"position":[[902,45]]}}}],["https://pixijs.com/assets/rt_object_02.png",{"_index":2765,"t":{"207":{"position":[[948,45]]}}}],["https://pixijs.com/assets/rt_object_03.png",{"_index":2766,"t":{"207":{"position":[[994,45]]}}}],["https://pixijs.com/assets/rt_object_04.png",{"_index":2767,"t":{"207":{"position":[[1040,45]]}}}],["https://pixijs.com/assets/rt_object_05.png",{"_index":2768,"t":{"207":{"position":[[1086,45]]}}}],["https://pixijs.com/assets/rt_object_06.png",{"_index":2769,"t":{"207":{"position":[[1132,45]]}}}],["https://pixijs.com/assets/rt_object_07.png",{"_index":2770,"t":{"207":{"position":[[1178,45]]}}}],["https://pixijs.com/assets/rt_object_08.png",{"_index":2771,"t":{"207":{"position":[[1224,45]]}}}],["https://pixijs.com/assets/skully.png",{"_index":531,"t":{"53":{"position":[[293,39]]}}}],["https://pixijs.com/assets/webfont",{"_index":2729,"t":{"205":{"position":[[221,34],[287,34],[361,34],[438,34]]}}}],["https://spicyyoghurt.com/tutorials/html5",{"_index":37,"t":{"41":{"position":[[112,40]]}}}],["https://www.shadertoy.com/view/wtlswx",{"_index":1597,"t":{"97":{"position":[[917,37]]},"159":{"position":[[848,37]]}}}],["huge",{"_index":2174,"t":{"151":{"position":[[1160,4]]}}}],["icons",{"_index":1226,"t":{"81":{"position":[[166,5]]}}}],["id",{"_index":1606,"t":{"97":{"position":[[1237,2],[1265,2]]},"159":{"position":[[1156,2],[1184,2]]}}}],["ids",{"_index":2762,"t":{"207":{"position":[[879,5]]}}}],["if(d.x",{"_index":1662,"t":{"97":{"position":[[2342,6]]},"159":{"position":[[2190,6]]}}}],["if(t",{"_index":1669,"t":{"97":{"position":[[2491,4]]},"159":{"position":[[2339,4]]}}}],["ignore",{"_index":1385,"t":{"87":{"position":[[1602,6]]}}}],["image",{"_index":854,"t":{"63":{"position":[[689,5]]},"65":{"position":[[522,5]]},"69":{"position":[[4848,5]]},"73":{"position":[[274,5]]},"77":{"position":[[177,5]]},"81":{"position":[[738,5]]},"83":{"position":[[402,5]]},"89":{"position":[[177,5]]},"93":{"position":[[215,5],[1034,6]]},"99":{"position":[[147,5]]},"187":{"position":[[180,5]]},"193":{"position":[[154,5],[325,5]]},"197":{"position":[[272,5]]},"207":{"position":[[873,5]]}}}],["images",{"_index":2803,"t":{"209":{"position":[[378,6]]}}}],["imagetoreveal",{"_index":274,"t":{"43":{"position":[[688,13],[948,14]]}}}],["imagetoreveal.mask",{"_index":280,"t":{"43":{"position":[[874,18]]}}}],["implementation",{"_index":1776,"t":{"103":{"position":[[1286,14]]}}}],["import",{"_index":25,"t":{"41":{"position":[[0,6]]},"43":{"position":[[0,6]]},"45":{"position":[[0,6]]},"47":{"position":[[0,6]]},"49":{"position":[[0,6]]},"51":{"position":[[0,6]]},"53":{"position":[[0,6]]},"55":{"position":[[0,6]]},"57":{"position":[[0,6]]},"59":{"position":[[0,6]]},"61":{"position":[[0,6]]},"63":{"position":[[0,6]]},"65":{"position":[[0,6]]},"67":{"position":[[0,6]]},"69":{"position":[[0,6]]},"71":{"position":[[0,6]]},"73":{"position":[[0,6]]},"75":{"position":[[0,6]]},"77":{"position":[[0,6]]},"79":{"position":[[0,6]]},"81":{"position":[[0,6]]},"83":{"position":[[0,6]]},"85":{"position":[[0,6]]},"87":{"position":[[0,6]]},"89":{"position":[[0,6]]},"91":{"position":[[0,6]]},"93":{"position":[[0,6]]},"95":{"position":[[0,6]]},"97":{"position":[[0,6]]},"99":{"position":[[0,6]]},"101":{"position":[[0,6]]},"103":{"position":[[0,6],[33,6]]},"105":{"position":[[0,6]]},"107":{"position":[[0,6]]},"109":{"position":[[0,6]]},"111":{"position":[[0,6],[33,6]]},"147":{"position":[[0,6]]},"149":{"position":[[0,6]]},"151":{"position":[[0,6]]},"153":{"position":[[0,6]]},"155":{"position":[[0,6]]},"157":{"position":[[0,6]]},"159":{"position":[[0,6]]},"161":{"position":[[0,6]]},"163":{"position":[[0,6]]},"165":{"position":[[0,6]]},"167":{"position":[[0,6]]},"169":{"position":[[0,6]]},"171":{"position":[[0,6]]},"173":{"position":[[0,6]]},"175":{"position":[[0,6]]},"177":{"position":[[0,6]]},"179":{"position":[[0,6]]},"181":{"position":[[0,6]]},"183":{"position":[[0,6]]},"185":{"position":[[0,6]]},"187":{"position":[[0,6]]},"189":{"position":[[0,6]]},"191":{"position":[[0,6]]},"193":{"position":[[0,6]]},"195":{"position":[[0,6]]},"197":{"position":[[0,6]]},"199":{"position":[[0,6]]},"201":{"position":[[0,6]]},"203":{"position":[[0,6]]},"205":{"position":[[0,6]]},"207":{"position":[[0,6]]},"209":{"position":[[0,6]]},"211":{"position":[[0,6]]},"244":{"position":[[0,6]]},"258":{"position":[[0,6]]}}}],["important",{"_index":903,"t":{"65":{"position":[[922,9]]}}}],["impulse",{"_index":62,"t":{"41":{"position":[[438,7],[916,7],[1610,7],[1697,7],[1725,7]]}}}],["impulsepower",{"_index":66,"t":{"41":{"position":[[477,12],[1620,12]]}}}],["in/zoom",{"_index":1874,"t":{"103":{"position":[[4533,7]]}}}],["include",{"_index":2611,"t":{"199":{"position":[[304,7]]}}}],["increment",{"_index":1223,"t":{"79":{"position":[[2358,9]]}}}],["independent",{"_index":953,"t":{"67":{"position":[[884,11]]},"185":{"position":[[1062,11]]},"187":{"position":[[628,11]]}}}],["info",{"_index":2666,"t":{"201":{"position":[[1036,4]]}}}],["information",{"_index":2083,"t":{"149":{"position":[[246,12]]}}}],["inherits",{"_index":2596,"t":{"197":{"position":[[654,8]]}}}],["init",{"_index":518,"t":{"51":{"position":[[215,6],[627,7]]},"59":{"position":[[164,6],[1972,7]]},"199":{"position":[[266,7],[698,6]]}}}],["initial",{"_index":460,"t":{"49":{"position":[[715,8],[735,7]]},"75":{"position":[[340,7]]},"103":{"position":[[4298,7]]}}}],["inline",{"_index":2563,"t":{"195":{"position":[[870,6]]}}}],["inner",{"_index":2446,"t":{"177":{"position":[[129,5]]}}}],["input",{"_index":1579,"t":{"97":{"position":[[179,5]]},"165":{"position":[[1925,5]]}}}],["inputsize",{"_index":1493,"t":{"93":{"position":[[548,11],[751,10]]}}}],["inputsize.xy",{"_index":1507,"t":{"93":{"position":[[855,12]]}}}],["inside",{"_index":517,"t":{"51":{"position":[[175,6]]},"85":{"position":[[793,6]]}}}],["instanceof",{"_index":1205,"t":{"79":{"position":[[378,10]]}}}],["instanceoffset",{"_index":2217,"t":{"155":{"position":[[731,14]]}}}],["instantly",{"_index":797,"t":{"59":{"position":[[784,10],[1461,10]]}}}],["int",{"_index":1657,"t":{"97":{"position":[[2163,3]]},"159":{"position":[[2011,3]]}}}],["interact",{"_index":54,"t":{"41":{"position":[[349,8]]}}}],["interactive",{"_index":851,"t":{"63":{"position":[[537,11]]},"81":{"position":[[1326,14]]},"83":{"position":[[965,14]]},"89":{"position":[[622,14]]},"91":{"position":[[588,12]]},"103":{"position":[[4180,11],[4252,11]]},"189":{"position":[[647,11]]}}}],["interactivity",{"_index":639,"t":{"53":{"position":[[2974,14]]},"75":{"position":[[461,13]]},"85":{"position":[[972,13]]},"91":{"position":[[503,14]]},"195":{"position":[[515,13]]}}}],["intercept",{"_index":1111,"t":{"69":{"position":[[8500,9]]}}}],["interleave",{"_index":2185,"t":{"153":{"position":[[476,14]]}}}],["interpolate",{"_index":261,"t":{"43":{"position":[[281,11]]}}}],["interpolation",{"_index":410,"t":{"47":{"position":[[1440,13],[1654,13]]}}}],["intersect",{"_index":1117,"t":{"69":{"position":[[8663,9]]}}}],["intersect(0",{"_index":985,"t":{"69":{"position":[[1486,12],[6389,12]]}}}],["intersect(x1",{"_index":1123,"t":{"69":{"position":[[8751,13]]}}}],["intersecting",{"_index":980,"t":{"69":{"position":[[1337,12],[6143,12]]}}}],["intersection",{"_index":981,"t":{"69":{"position":[[1363,12],[1568,12],[6169,12],[6471,12],[8591,12],[9207,12],[9354,12]]},"87":{"position":[[732,12],[1964,12]]}}}],["intersection.y",{"_index":1001,"t":{"69":{"position":[[2012,16],[7145,14],[7217,16]]}}}],["inverse",{"_index":1772,"t":{"103":{"position":[[1180,7]]}}}],["inversed",{"_index":2342,"t":{"165":{"position":[[3624,8]]}}}],["ios",{"_index":2667,"t":{"201":{"position":[[1041,3]]}}}],["ios10",{"_index":2564,"t":{"195":{"position":[[886,5]]}}}],["ios9",{"_index":2556,"t":{"195":{"position":[[767,4]]}}}],["isegghead",{"_index":750,"t":{"55":{"position":[[611,9],[963,9],[975,11]]}}}],["isflower",{"_index":2515,"t":{"189":{"position":[[153,8],[756,8],[767,10],[830,8]]}}}],["it's",{"_index":1440,"t":{"89":{"position":[[932,4]]},"97":{"position":[[2629,4]]},"103":{"position":[[387,4]]},"151":{"position":[[1110,4]]},"195":{"position":[[1313,4]]}}}],["it/iphone",{"_index":2562,"t":{"195":{"position":[[860,9]]}}}],["italic",{"_index":597,"t":{"53":{"position":[[2174,9]]},"203":{"position":[[353,9]]}}}],["item",{"_index":2775,"t":{"207":{"position":[[1431,4],[1744,4],[1755,4]]}}}],["item.anchor.set(0.5",{"_index":2780,"t":{"207":{"position":[[1555,21]]}}}],["item.rotation",{"_index":2786,"t":{"207":{"position":[[1772,13]]}}}],["item.x",{"_index":2778,"t":{"207":{"position":[[1483,6]]}}}],["item.y",{"_index":2779,"t":{"207":{"position":[[1519,6]]}}}],["items",{"_index":2772,"t":{"207":{"position":[[1295,5],[1307,5],[1338,5]]}}}],["items.length",{"_index":2784,"t":{"207":{"position":[[1708,13]]}}}],["items.push(item",{"_index":2782,"t":{"207":{"position":[[1608,17]]}}}],["items[i",{"_index":2785,"t":{"207":{"position":[[1762,9]]}}}],["iterate",{"_index":926,"t":{"65":{"position":[[1765,7]]},"73":{"position":[[1615,7]]},"79":{"position":[[1646,7]]}}}],["itself",{"_index":1023,"t":{"69":{"position":[[3000,6]]},"207":{"position":[[293,6]]}}}],["ix",{"_index":414,"t":{"47":{"position":[[1484,2],[1622,3]]}}}],["iy",{"_index":416,"t":{"47":{"position":[[1553,2],[1632,3]]}}}],["i}.ase",{"_index":2470,"t":{"181":{"position":[[367,10]]}}}],["j",{"_index":562,"t":{"53":{"position":[[1192,1],[1199,1],[1206,4],[1359,1],[4003,1],[4010,1],[4032,4],[4103,2]]}}}],["javascript",{"_index":38,"t":{"41":{"position":[[153,10]]}}}],["jonlepage",{"_index":1078,"t":{"69":{"position":[[7353,9]]}}}],["k",{"_index":423,"t":{"47":{"position":[[1749,2],[1757,1],[1767,2],[1788,1],[2048,1],[2220,2]]}}}],["keep",{"_index":2173,"t":{"151":{"position":[[1129,4]]}}}],["knock",{"_index":134,"t":{"41":{"position":[[1954,5]]}}}],["know",{"_index":2641,"t":{"201":{"position":[[367,4]]}}}],["larger",{"_index":2165,"t":{"151":{"position":[[980,6]]}}}],["lastdrawnpoint",{"_index":292,"t":{"43":{"position":[[1215,14],[1556,16],[1783,14],[1800,14],[1981,14]]}}}],["lastdrawnpoint.set(x",{"_index":318,"t":{"43":{"position":[[1836,21]]}}}],["lastdrawnpoint.y",{"_index":315,"t":{"43":{"position":[[1659,17]]}}}],["later",{"_index":918,"t":{"65":{"position":[[1439,5]]},"73":{"position":[[1295,5]]},"79":{"position":[[1304,5]]}}}],["left",{"_index":979,"t":{"69":{"position":[[1317,4],[1778,4],[1812,5],[6018,4],[6655,5],[6714,4]]},"191":{"position":[[361,7]]},"199":{"position":[[905,7]]},"211":{"position":[[1644,7]]}}}],["length",{"_index":1077,"t":{"69":{"position":[[7335,6],[8832,6]]},"97":{"position":[[1143,6]]},"159":{"position":[[1062,6]]},"165":{"position":[[2198,7]]}}}],["length(mouse",{"_index":1509,"t":{"93":{"position":[[889,13]]}}}],["lerp",{"_index":726,"t":{"53":{"position":[[5483,4]]}}}],["lerp(a1",{"_index":728,"t":{"53":{"position":[[5506,8]]}}}],["lerp(t.propertybeginvalue",{"_index":716,"t":{"53":{"position":[[5192,26]]}}}],["let's",{"_index":875,"t":{"63":{"position":[[1271,5]]},"65":{"position":[[755,5]]},"77":{"position":[[498,5]]},"109":{"position":[[1278,5]]},"147":{"position":[[987,5]]},"187":{"position":[[534,5]]}}}],["lets",{"_index":1154,"t":{"73":{"position":[[611,4]]}}}],["library",{"_index":696,"t":{"53":{"position":[[4625,7]]}}}],["light",{"_index":1618,"t":{"97":{"position":[[1415,7]]},"159":{"position":[[1282,7]]}}}],["light1",{"_index":1960,"t":{"107":{"position":[[751,6]]},"147":{"position":[[708,6],[937,7]]}}}],["light1.anchor.set(0.5",{"_index":1962,"t":{"107":{"position":[[826,23]]},"147":{"position":[[783,23]]}}}],["light1.rotation",{"_index":1975,"t":{"107":{"position":[[1493,15]]},"147":{"position":[[1608,15]]}}}],["light2",{"_index":1956,"t":{"107":{"position":[[618,6]]},"147":{"position":[[603,6],[929,7]]}}}],["light2.anchor.set(0.5",{"_index":1958,"t":{"107":{"position":[[693,23]]},"147":{"position":[[678,23]]}}}],["light2.rotation",{"_index":1977,"t":{"107":{"position":[[1518,15]]},"147":{"position":[[1633,15]]}}}],["lighter",{"_index":2718,"t":{"203":{"position":[[1064,10]]}}}],["limit",{"_index":2328,"t":{"165":{"position":[[2842,6],[3012,6]]}}}],["line",{"_index":260,"t":{"43":{"position":[[266,4],[316,4],[1548,4],[1575,4]]},"69":{"position":[[5596,4],[6236,4],[6294,4],[8495,4],[8617,4]]},"103":{"position":[[1988,4]]},"109":{"position":[[263,4],[573,4]]},"111":{"position":[[328,4],[480,4],[972,4],[1121,4],[1272,4]]},"149":{"position":[[2155,4]]}}}],["lineal",{"_index":2731,"t":{"205":{"position":[[279,7],[732,9]]}}}],["linejoin",{"_index":2706,"t":{"203":{"position":[[618,9],[1075,9]]}}}],["lines",{"_index":1063,"t":{"69":{"position":[[5154,5],[8651,5],[8819,5],[8989,5]]},"109":{"position":[[1463,5]]},"203":{"position":[[725,7]]}}}],["linesize",{"_index":1052,"t":{"69":{"position":[[4869,8],[5642,9],[5664,9],[5685,9],[5707,10],[5745,9],[5767,9],[5788,9],[5809,10],[5842,9],[5863,9],[5884,9],[5905,10],[5939,9],[5961,9],[5983,9],[6004,10],[6616,9],[6638,9],[6673,9],[6694,9],[6730,9],[6751,9],[6788,9],[6810,9],[6972,10],[7131,8],[7174,8]]}}}],["linestyle",{"_index":311,"t":{"43":{"position":[[1589,12]]},"91":{"position":[[338,12]]},"103":{"position":[[3419,12]]},"111":{"position":[[816,9]]}}}],["lineto(0",{"_index":1841,"t":{"103":{"position":[[3483,10]]}}}],["lineto(36",{"_index":2548,"t":{"195":{"position":[[347,11]]}}}],["lineto(70",{"_index":2550,"t":{"195":{"position":[[363,11]]}}}],["lineto(700",{"_index":1843,"t":{"103":{"position":[[3516,12]]}}}],["lineto(x",{"_index":316,"t":{"43":{"position":[[1677,10]]}}}],["linting",{"_index":1121,"t":{"69":{"position":[[8724,7]]}}}],["listen",{"_index":173,"t":{"41":{"position":[[2721,6]]},"47":{"position":[[1085,6]]},"49":{"position":[[1154,6]]},"53":{"position":[[3593,6],[4951,6]]},"67":{"position":[[776,6]]},"69":{"position":[[8334,6]]},"71":{"position":[[442,6]]},"95":{"position":[[1473,6]]},"97":{"position":[[2928,6]]},"185":{"position":[[954,6]]},"187":{"position":[[463,6]]},"195":{"position":[[650,6]]}}}],["little",{"_index":301,"t":{"43":{"position":[[1443,6]]},"63":{"position":[[1297,6]]},"65":{"position":[[1528,6]]},"73":{"position":[[1381,6]]},"77":{"position":[[523,6]]},"79":{"position":[[1393,6]]},"89":{"position":[[534,6]]},"187":{"position":[[559,6]]}}}],["littledudes",{"_index":1709,"t":{"101":{"position":[[305,11]]}}}],["littledudes.filters",{"_index":1722,"t":{"101":{"position":[[802,19]]}}}],["littledudes.x",{"_index":1711,"t":{"101":{"position":[[400,13]]}}}],["littledudes.y",{"_index":1713,"t":{"101":{"position":[[446,13]]}}}],["littlerobot",{"_index":1715,"t":{"101":{"position":[[506,11]]}}}],["littlerobot.filters",{"_index":1723,"t":{"101":{"position":[[839,19]]}}}],["littlerobot.x",{"_index":1717,"t":{"101":{"position":[[600,13]]}}}],["littlerobot.y",{"_index":1718,"t":{"101":{"position":[[646,13]]}}}],["load",{"_index":736,"t":{"55":{"position":[[170,4],[340,4],[438,4],[481,4],[507,4]]},"57":{"position":[[170,4],[320,4]]},"59":{"position":[[237,5],[703,4],[1349,4]]},"63":{"position":[[141,4]]},"99":{"position":[[369,4],[526,4]]},"165":{"position":[[863,4]]},"199":{"position":[[152,4]]},"205":{"position":[[152,4]]}}}],["loaded",{"_index":521,"t":{"51":{"position":[[343,6]]},"55":{"position":[[450,6],[670,6]]},"57":{"position":[[377,6],[635,6]]},"59":{"position":[[526,6],[906,6],[1429,6],[1583,6]]},"61":{"position":[[413,6]]},"97":{"position":[[809,6]]},"197":{"position":[[412,6]]}}}],["loader",{"_index":2588,"t":{"197":{"position":[[433,6]]},"199":{"position":[[325,6]]}}}],["loader/chachicle.ttf",{"_index":2730,"t":{"205":{"position":[[256,22]]}}}],["loader/crosterian.woff2",{"_index":2738,"t":{"205":{"position":[[473,25]]}}}],["loader/dotrice",{"_index":2735,"t":{"205":{"position":[[396,14]]}}}],["loader/lineal.otf",{"_index":2732,"t":{"205":{"position":[[322,19]]}}}],["loading",{"_index":831,"t":{"61":{"position":[[158,7]]}}}],["loadscreenassets",{"_index":798,"t":{"59":{"position":[[801,16],[1478,16]]}}}],["local",{"_index":947,"t":{"67":{"position":[[662,5]]},"185":{"position":[[840,5]]}}}],["located",{"_index":1898,"t":{"103":{"position":[[5373,7]]}}}],["logical",{"_index":683,"t":{"53":{"position":[[4291,7]]}}}],["logs",{"_index":1289,"t":{"85":{"position":[[49,4],[451,4],[1272,4],[1525,4]]}}}],["logs.join('\\n",{"_index":1344,"t":{"85":{"position":[[1654,16]]}}}],["logs.length",{"_index":1341,"t":{"85":{"position":[[1555,12],[1582,12]]}}}],["logs.push",{"_index":1339,"t":{"85":{"position":[[1452,11]]}}}],["logs.push(`${currenttargetname",{"_index":1337,"t":{"85":{"position":[[1277,31]]}}}],["logs.shift",{"_index":1342,"t":{"85":{"position":[[1603,13]]}}}],["logtext",{"_index":1305,"t":{"85":{"position":[[468,7],[1631,7]]}}}],["logtext.text",{"_index":1343,"t":{"85":{"position":[[1639,12]]}}}],["logtext.x",{"_index":1309,"t":{"85":{"position":[[552,9]]}}}],["logtext.y",{"_index":1307,"t":{"85":{"position":[[536,9]]}}}],["long",{"_index":382,"t":{"47":{"position":[[329,4]]},"85":{"position":[[1547,4]]}}}],["look",{"_index":304,"t":{"43":{"position":[[1465,4]]},"201":{"position":[[113,4]]}}}],["looking",{"_index":508,"t":{"49":{"position":[[2120,7]]}}}],["loop",{"_index":184,"t":{"41":{"position":[[2891,4]]}}}],["lot",{"_index":2710,"t":{"203":{"position":[[690,3]]},"244":{"position":[[930,3]]}}}],["m",{"_index":432,"t":{"47":{"position":[[2073,1]]}}}],["m[0",{"_index":436,"t":{"47":{"position":[[2318,4]]}}}],["m[1",{"_index":438,"t":{"47":{"position":[[2365,5]]}}}],["made",{"_index":237,"t":{"41":{"position":[[5027,4]]},"87":{"position":[[1648,4]]}}}],["maggot",{"_index":1903,"t":{"105":{"position":[[430,6],[1951,6]]}}}],["maggot.anchor.set(0.5",{"_index":1905,"t":{"105":{"position":[[497,23]]}}}],["maggot.direction",{"_index":1907,"t":{"105":{"position":[[549,16],[1972,16],[2146,16]]}}}],["maggot.original",{"_index":1915,"t":{"105":{"position":[[781,15]]}}}],["maggot.original.copyfrom(maggot.scale",{"_index":1916,"t":{"105":{"position":[[817,39]]}}}],["maggot.original.x",{"_index":1945,"t":{"105":{"position":[[2195,17]]}}}],["maggot.rotation",{"_index":1943,"t":{"105":{"position":[[2127,15]]}}}],["maggot.scale.set(1",{"_index":1914,"t":{"105":{"position":[[738,18]]}}}],["maggot.scale.x",{"_index":1944,"t":{"105":{"position":[[2178,14]]}}}],["maggot.speed",{"_index":1908,"t":{"105":{"position":[[597,12],[2058,13],[2113,13]]}}}],["maggot.turnspeed",{"_index":1909,"t":{"105":{"position":[[615,16],[1992,16]]}}}],["maggot.x",{"_index":1910,"t":{"105":{"position":[[655,8],[2017,8],[2281,9],[2305,8],[2341,9],[2380,8]]}}}],["maggot.y",{"_index":1912,"t":{"105":{"position":[[696,8],[2072,8],[2411,9],[2435,8],[2472,9],[2512,8]]}}}],["maggots",{"_index":1202,"t":{"79":{"position":[[330,7],[657,8],[1123,7],[1258,7],[1400,7],[2058,7]]},"105":{"position":[[379,7],[2250,7]]}}}],["maggots.length",{"_index":1218,"t":{"79":{"position":[[1720,15]]},"105":{"position":[[1922,15]]}}}],["maggots.push(dude",{"_index":1216,"t":{"79":{"position":[[1310,19]]}}}],["maggots.push(maggot",{"_index":1917,"t":{"105":{"position":[[857,21]]}}}],["maggots[i",{"_index":1219,"t":{"79":{"position":[[1756,11]]},"105":{"position":[[1960,11]]}}}],["magically",{"_index":2586,"t":{"197":{"position":[[370,9]]}}}],["main",{"_index":1505,"t":{"93":{"position":[[813,6]]},"97":{"position":[[1702,6]]},"153":{"position":[[690,6],[897,6]]},"155":{"position":[[1183,6],[1360,6]]},"159":{"position":[[681,6],[1569,6]]},"161":{"position":[[1082,6],[1289,6]]},"163":{"position":[[631,6],[844,6]]},"165":{"position":[[732,6],[1123,6],[2097,6],[2879,6],[3481,6],[4532,6]]},"167":{"position":[[565,6],[772,6],[1114,6],[1321,6]]},"171":{"position":[[387,6],[533,6]]},"173":{"position":[[799,6],[1065,6]]},"175":{"position":[[653,6],[837,6]]},"179":{"position":[[662,6],[910,6]]}}}],["make",{"_index":303,"t":{"43":{"position":[[1457,4]]},"63":{"position":[[522,4]]},"81":{"position":[[1310,4]]},"83":{"position":[[949,4]]},"89":{"position":[[907,4]]},"91":{"position":[[553,4]]},"95":{"position":[[228,4],[302,4]]},"97":{"position":[[2619,4]]},"103":{"position":[[3830,4],[3997,4],[4169,4],[4242,4]]},"151":{"position":[[483,4],[952,4]]},"159":{"position":[[2500,4]]},"169":{"position":[[582,4]]},"189":{"position":[[631,4]]},"258":{"position":[[643,4]]}}}],["makegamescreen",{"_index":810,"t":{"59":{"position":[[1212,17],[1251,16]]}}}],["makeloadscreen",{"_index":794,"t":{"59":{"position":[[622,17],[657,16],[1948,17]]}}}],["makes",{"_index":2168,"t":{"151":{"position":[[1013,5]]},"165":{"position":[[1935,5]]},"244":{"position":[[953,5]]}}}],["manifest",{"_index":787,"t":{"59":{"position":[[176,8],[478,9]]}}}],["manifestexample",{"_index":788,"t":{"59":{"position":[[199,15],[488,15]]}}}],["map",{"_index":489,"t":{"49":{"position":[[1483,3]]},"103":{"position":[[1042,3]]}}}],["margin",{"_index":584,"t":{"53":{"position":[[1701,6],[1771,7],[1935,8],[2041,7],[2067,8],[2597,6]]}}}],["mask",{"_index":967,"t":{"69":{"position":[[681,4],[760,5],[780,5],[1858,4],[3138,5],[3454,4],[3533,5],[3553,5],[3890,4],[5026,4],[5137,4],[5176,4],[5255,5],[6049,4],[6846,4]]},"87":{"position":[[1095,5],[1572,4],[1698,4]]},"157":{"position":[[352,4],[483,5]]},"197":{"position":[[745,4]]}}}],["mask.anchor.set(0.5",{"_index":2231,"t":{"157":{"position":[[420,21]]}}}],["mask.arc(0",{"_index":1036,"t":{"69":{"position":[[4010,11]]}}}],["mask.beginfill(0xff0000",{"_index":997,"t":{"69":{"position":[[1909,24],[3941,24],[6897,24]]}}}],["mask.clear",{"_index":995,"t":{"69":{"position":[[1863,13],[3895,13],[6851,13]]}}}],["mask.endfill",{"_index":1005,"t":{"69":{"position":[[2153,15],[4079,15],[7253,15]]}}}],["mask.linestyle(2",{"_index":996,"t":{"69":{"position":[[1877,17],[3909,17],[6865,17]]}}}],["mask.lineto(0",{"_index":999,"t":{"69":{"position":[[1965,14],[4060,14],[7234,14]]}}}],["mask.lineto(corners[i",{"_index":1003,"t":{"69":{"position":[[2102,21],[7039,21]]}}}],["mask.lineto(intersection.x",{"_index":1000,"t":{"69":{"position":[[1984,27],[7090,26],[7189,27]]}}}],["mask.lineto(x1",{"_index":1035,"t":{"69":{"position":[[3989,15]]}}}],["mask.moveto(0",{"_index":998,"t":{"69":{"position":[[1938,14],[3970,14],[6926,14],[6945,14]]}}}],["mask.position.set(size",{"_index":968,"t":{"69":{"position":[[709,22],[3482,22],[5204,22]]}}}],["mask.x",{"_index":2232,"t":{"157":{"position":[[442,6],[696,6],[718,7]]}}}],["mask.y",{"_index":2234,"t":{"157":{"position":[[456,6],[733,6],[755,7]]}}}],["masking",{"_index":1045,"t":{"69":{"position":[[4583,8]]},"147":{"position":[[1370,7]]}}}],["masks",{"_index":1386,"t":{"87":{"position":[[1609,6]]}}}],["mat3",{"_index":2189,"t":{"153":{"position":[[611,4],[643,4]]},"155":{"position":[[1104,4],[1136,4]]},"159":{"position":[[602,4],[634,4]]},"161":{"position":[[1003,4],[1035,4]]},"163":{"position":[[552,4],[584,4]]},"165":{"position":[[653,4],[685,4]]},"167":{"position":[[486,4],[518,4],[1035,4],[1067,4]]},"171":{"position":[[327,4],[359,4]]},"173":{"position":[[699,4],[731,4]]},"175":{"position":[[572,4],[604,4]]},"179":{"position":[[583,4],[615,4]]}}}],["match",{"_index":1120,"t":{"69":{"position":[[8704,5]]},"95":{"position":[[1968,5]]}}}],["matches",{"_index":1365,"t":{"87":{"position":[[680,7]]}}}],["math",{"_index":1112,"t":{"69":{"position":[[8510,4]]}}}],["math.abs(e.deltay",{"_index":1872,"t":{"103":{"position":[[4459,20]]}}}],["math.abs(mask.x",{"_index":2240,"t":{"157":{"position":[[773,16]]}}}],["math.atan2",{"_index":222,"t":{"41":{"position":[[4405,11]]}}}],["math.atan2(dycenter",{"_index":516,"t":{"49":{"position":[[2472,20]]}}}],["math.cos((i",{"_index":2429,"t":{"169":{"position":[[718,11]]},"258":{"position":[[779,11]]}}}],["math.cos(anglestart",{"_index":1032,"t":{"69":{"position":[[3807,20]]}}}],["math.cos(angletomouse",{"_index":232,"t":{"41":{"position":[[4817,22]]}}}],["math.cos(count",{"_index":1726,"t":{"101":{"position":[[949,16]]},"107":{"position":[[1607,15],[1717,16],[1746,15]]},"109":{"position":[[1975,15],[2017,15],[2116,15],[2159,15],[2259,15]]},"147":{"position":[[1722,15],[1856,15],[1898,15],[1997,15],[2040,15]]},"193":{"position":[[635,16]]}}}],["math.cos(deg",{"_index":473,"t":{"49":{"position":[[984,13]]}}}],["math.cos(dude.direction",{"_index":931,"t":{"65":{"position":[[1991,24]]},"73":{"position":[[1836,24]]},"79":{"position":[[1947,24]]}}}],["math.cos(i",{"_index":1016,"t":{"69":{"position":[[2643,10]]}}}],["math.cos(maggot.direction",{"_index":1942,"t":{"105":{"position":[[2084,26]]}}}],["math.cos(phase",{"_index":975,"t":{"69":{"position":[[999,14],[5507,14]]}}}],["math.floor(i",{"_index":348,"t":{"45":{"position":[[759,12]]},"67":{"position":[[478,12]]},"185":{"position":[[656,12]]},"244":{"position":[[399,12]]}}}],["math.floor(math.random",{"_index":651,"t":{"53":{"position":[[3290,24]]},"65":{"position":[[813,24],[868,24]]},"89":{"position":[[393,24],[439,24]]},"157":{"position":[[594,24],[638,24]]}}}],["math.floor(t",{"_index":431,"t":{"47":{"position":[[2052,14]]}}}],["math.hypot(a",{"_index":132,"t":{"41":{"position":[[1906,13]]}}}],["math.max(0",{"_index":506,"t":{"49":{"position":[[2025,11]]}}}],["math.max(halfhandlewidth",{"_index":1569,"t":{"95":{"position":[[2029,25]]}}}],["math.min",{"_index":1570,"t":{"95":{"position":[[2055,9]]}}}],["math.min(1",{"_index":712,"t":{"53":{"position":[[5130,11]]}}}],["math.min(15",{"_index":1871,"t":{"103":{"position":[[4446,12]]}}}],["math.min(symbol_size",{"_index":572,"t":{"53":{"position":[[1410,20],[4404,20]]}}}],["math.pi",{"_index":471,"t":{"49":{"position":[[921,7],[2505,7]]},"53":{"position":[[2367,7]]},"65":{"position":[[1144,7],[2064,7]]},"69":{"position":[[947,8],[1016,7],[1064,7],[2669,7],[2731,7],[2860,8],[2961,7],[3692,8],[3730,7],[5455,8],[5524,7],[5572,7],[7666,9],[8047,8]]},"73":{"position":[[997,7],[1909,7]]},"79":{"position":[[943,7],[2037,8]]},"81":{"position":[[1715,7],[1810,8]]},"83":{"position":[[1810,7],[1905,8]]},"105":{"position":[[584,7],[2165,7]]},"149":{"position":[[1393,8],[1406,9],[1551,8],[1564,7],[1745,8],[1760,7]]},"183":{"position":[[723,8]]},"201":{"position":[[2056,7]]},"203":{"position":[[546,7]]},"209":{"position":[[994,7]]},"244":{"position":[[456,8]]}}}],["math.random",{"_index":462,"t":{"49":{"position":[[745,13],[778,13],[905,13],[951,13]]},"63":{"position":[[869,13],[905,13],[942,13]]},"65":{"position":[[722,13],[1128,13],[1251,13],[1341,13]]},"73":{"position":[[578,13],[667,13],[710,13],[757,13],[981,13],[1104,13],[1194,13]]},"79":{"position":[[703,13],[754,13],[797,13],[844,13],[927,13],[1052,13],[1160,13],[1200,13]]},"105":{"position":[[568,13],[634,13],[666,13],[707,13],[759,13]]},"109":{"position":[[1562,13],[1629,13],[1675,13],[1696,13],[1717,13],[1738,13],[1759,13],[1780,13]]},"155":{"position":[[856,14],[905,14],[954,14]]},"183":{"position":[[576,13],[624,13],[707,13],[759,13]]},"207":{"position":[[1492,13],[1528,13]]},"244":{"position":[[440,13]]}}}],["math.round((app.screen.width",{"_index":369,"t":{"45":{"position":[[1208,28]]}}}],["math.round((bottom.width",{"_index":620,"t":{"53":{"position":[[2515,24]]}}}],["math.round((margin",{"_index":623,"t":{"53":{"position":[[2606,18],[2838,18]]}}}],["math.round((symbol_size",{"_index":576,"t":{"53":{"position":[[1488,23],[4483,23]]}}}],["math.round((top.width",{"_index":632,"t":{"53":{"position":[[2775,21]]}}}],["math.round(app.screen.width",{"_index":587,"t":{"53":{"position":[[1797,27]]}}}],["math.round(screenshottext.height",{"_index":372,"t":{"45":{"position":[[1286,32]]}}}],["math.sign(e.deltay",{"_index":1870,"t":{"103":{"position":[[4424,19]]}}}],["math.sin((i",{"_index":2427,"t":{"169":{"position":[[653,11]]},"258":{"position":[[714,11]]}}}],["math.sin((timer",{"_index":1149,"t":{"71":{"position":[[632,15]]}}}],["math.sin(anglestart",{"_index":1034,"t":{"69":{"position":[[3849,20]]}}}],["math.sin(angletomouse",{"_index":233,"t":{"41":{"position":[[4852,22]]}}}],["math.sin(count",{"_index":881,"t":{"63":{"position":[[1430,16],[1472,16]]},"101":{"position":[[986,16]]},"105":{"position":[[2215,15]]},"107":{"position":[[1563,15],[1684,15],[1781,14],[1818,14],[1851,14]]},"109":{"position":[[1946,15],[2046,15],[2088,15],[2187,15],[2230,15]]},"147":{"position":[[1678,15],[1827,15],[1927,15],[1969,15],[2068,15]]},"193":{"position":[[587,16]]},"207":{"position":[[2057,15]]}}}],["math.sin(deg",{"_index":475,"t":{"49":{"position":[[1019,13]]}}}],["math.sin(dude.direction",{"_index":930,"t":{"65":{"position":[[1942,24]]},"73":{"position":[[1787,24]]},"79":{"position":[[1881,24]]}}}],["math.sin(i",{"_index":1017,"t":{"69":{"position":[[2705,10],[2935,10]]}}}],["math.sin(maggot.direction",{"_index":1941,"t":{"105":{"position":[[2029,26]]}}}],["math.sin(phase",{"_index":976,"t":{"69":{"position":[[1047,14],[5555,14]]}}}],["math.sin(tick",{"_index":1222,"t":{"79":{"position":[[1790,13]]}}}],["math.sin(time",{"_index":2397,"t":{"165":{"position":[[5662,13]]}}}],["math.sin(time)*5+10",{"_index":2393,"t":{"165":{"position":[[5527,20]]}}}],["math.sqrt",{"_index":106,"t":{"41":{"position":[[1157,10]]}}}],["math.sqrt(dxcenter",{"_index":504,"t":{"49":{"position":[[1949,18]]}}}],["matrix",{"_index":1762,"t":{"103":{"position":[[917,6]]},"107":{"position":[[1653,6]]}}}],["matrix[1",{"_index":1980,"t":{"107":{"position":[[1672,9]]}}}],["matrix[2",{"_index":1981,"t":{"107":{"position":[[1705,9]]}}}],["matrix[3",{"_index":1982,"t":{"107":{"position":[[1734,9]]}}}],["matrix[4",{"_index":1984,"t":{"107":{"position":[[1769,9]]}}}],["matrix[5",{"_index":1985,"t":{"107":{"position":[[1806,9]]}}}],["matrix[6",{"_index":1986,"t":{"107":{"position":[[1839,9]]}}}],["max",{"_index":1634,"t":{"97":{"position":[[1660,4]]},"159":{"position":[[1527,4]]}}}],["mean",{"_index":1434,"t":{"89":{"position":[[746,4]]}}}],["means",{"_index":1747,"t":{"103":{"position":[[594,5]]}}}],["mediump",{"_index":1487,"t":{"93":{"position":[[460,7]]},"153":{"position":[[535,7],[829,7]]},"155":{"position":[[1015,7],[1321,7]]},"159":{"position":[[526,7],[896,7]]},"161":{"position":[[927,7],[1221,7]]},"163":{"position":[[476,7],[770,7]]},"165":{"position":[[577,7],[1064,7],[1990,7],[2794,7],[3397,7],[4409,7]]},"167":{"position":[[410,7],[704,7],[959,7],[1253,7]]},"171":{"position":[[272,7],[513,7]]},"173":{"position":[[600,7],[976,7]]},"175":{"position":[[494,7],[796,7]]},"179":{"position":[[507,7],[822,7]]}}}],["memories",{"_index":2591,"t":{"197":{"position":[[543,8]]}}}],["memory",{"_index":2671,"t":{"201":{"position":[[1121,6]]}}}],["merged",{"_index":1784,"t":{"103":{"position":[[1558,7]]}}}],["mesh",{"_index":1580,"t":{"97":{"position":[[204,4]]},"165":{"position":[[1665,4]]}}}],["meshes",{"_index":2301,"t":{"165":{"position":[[1582,6]]}}}],["method",{"_index":2851,"t":{"244":{"position":[[780,6]]}}}],["methods",{"_index":1799,"t":{"103":{"position":[[1999,7]]}}}],["middle",{"_index":201,"t":{"41":{"position":[[3530,6]]}}}],["mind",{"_index":664,"t":{"53":{"position":[[3828,4]]}}}],["mipmap",{"_index":1674,"t":{"97":{"position":[[2661,7]]}}}],["mipmapping",{"_index":2247,"t":{"159":{"position":[[2537,11]]}}}],["mirrors",{"_index":2835,"t":{"211":{"position":[[1195,7]]}}}],["mix(ripple",{"_index":2373,"t":{"165":{"position":[[4698,11]]}}}],["mobile",{"_index":1180,"t":{"75":{"position":[[600,6]]},"195":{"position":[[733,6]]}}}],["mod(guv.x",{"_index":2296,"t":{"165":{"position":[[1366,9]]}}}],["mod(id",{"_index":1608,"t":{"97":{"position":[[1270,7]]},"159":{"position":[[1189,7]]}}}],["mode",{"_index":905,"t":{"65":{"position":[[994,4]]},"75":{"position":[[158,4]]},"89":{"position":[[271,4],[736,4]]}}}],["modes",{"_index":19,"t":{"17":{"position":[[198,5]]}}}],["modified",{"_index":1118,"t":{"69":{"position":[[8678,8]]}}}],["modify",{"_index":912,"t":{"65":{"position":[[1188,6]]},"73":{"position":[[1041,6]]},"79":{"position":[[987,6]]}}}],["monster",{"_index":629,"t":{"53":{"position":[[2735,7]]}}}],["more",{"_index":1024,"t":{"69":{"position":[[3014,4]]},"97":{"position":[[232,4]]},"201":{"position":[[1856,4]]}}}],["mount",{"_index":1311,"t":{"85":{"position":[[596,5],[777,5]]}}}],["mouse",{"_index":203,"t":{"41":{"position":[[3775,5],[4158,5],[4562,5]]},"47":{"position":[[1176,5]]},"63":{"position":[[1099,5]]},"75":{"position":[[584,5],[681,5],[738,5]]},"83":{"position":[[1046,5],[1321,5]]},"85":{"position":[[284,5]]},"89":{"position":[[670,5],[814,5],[992,5]]},"93":{"position":[[731,6],[1372,6]]},"103":{"position":[[5423,5]]}}}],["mouse.xy",{"_index":1520,"t":{"93":{"position":[[1083,9]]}}}],["mousecoords",{"_index":160,"t":{"41":{"position":[[2517,11],[4647,12]]}}}],["mousecoords.x",{"_index":169,"t":{"41":{"position":[[2650,13],[3849,13],[3866,13],[4235,13]]}}}],["mousecoords.y",{"_index":171,"t":{"41":{"position":[[2682,13],[3907,13],[3924,13],[4278,13]]}}}],["mouseposition",{"_index":396,"t":{"47":{"position":[[836,13],[961,13],[977,13],[1137,16]]}}}],["mouseposition.x",{"_index":397,"t":{"47":{"position":[[1010,15]]}}}],["mouseposition.y",{"_index":398,"t":{"47":{"position":[[1044,15]]}}}],["move",{"_index":148,"t":{"41":{"position":[[2276,4]]},"51":{"position":[[461,4]]},"61":{"position":[[539,4]]},"67":{"position":[[534,4]]},"77":{"position":[[322,4]]},"85":{"position":[[273,5]]},"89":{"position":[[1082,4]]},"103":{"position":[[484,4]]},"185":{"position":[[712,4]]},"187":{"position":[[324,4]]},"189":{"position":[[480,4]]}}}],["moved",{"_index":1563,"t":{"95":{"position":[[1870,6]]}}}],["movement",{"_index":909,"t":{"65":{"position":[[1102,8]]},"71":{"position":[[557,9]]},"73":{"position":[[833,8]]},"89":{"position":[[1622,8]]}}}],["movementspeed",{"_index":59,"t":{"41":{"position":[[397,13],[4726,14]]}}}],["moves",{"_index":58,"t":{"41":{"position":[[385,5],[3129,5]]},"91":{"position":[[103,5]]},"244":{"position":[[878,6]]}}}],["moveto",{"_index":1842,"t":{"103":{"position":[[3499,8]]}}}],["moveto(0",{"_index":1840,"t":{"103":{"position":[[3466,10]]}}}],["moveto(36",{"_index":2547,"t":{"195":{"position":[[331,11]]}}}],["moveto(lastdrawnpoint.x",{"_index":314,"t":{"43":{"position":[[1633,25]]}}}],["moving",{"_index":512,"t":{"49":{"position":[[2224,7]]},"109":{"position":[[1293,6]]},"147":{"position":[[1002,6]]}}}],["mr",{"_index":1194,"t":{"77":{"position":[[511,2]]},"187":{"position":[[547,2]]}}}],["much",{"_index":1591,"t":{"97":{"position":[[791,4]]}}}],["multiple",{"_index":2689,"t":{"201":{"position":[[1781,8]]},"203":{"position":[[716,8]]}}}],["multiply",{"_index":1022,"t":{"69":{"position":[[2982,8]]}}}],["multitouch",{"_index":1456,"t":{"89":{"position":[[1587,10]]}}}],["n",{"_index":1625,"t":{"97":{"position":[[1504,1],[1678,6]]},"103":{"position":[[5417,3],[5464,3]]},"159":{"position":[[1371,1],[1545,6]]}}}],["name",{"_index":790,"t":{"59":{"position":[[231,5],[264,5],[343,5],[376,5]]},"63":{"position":[[806,6]]},"65":{"position":[[528,4]]},"73":{"position":[[280,4]]},"153":{"position":[[213,4],[359,4]]},"159":{"position":[[232,4],[378,4]]},"161":{"position":[[213,4],[359,4],[565,4],[718,4]]},"163":{"position":[[213,4],[348,4]]},"165":{"position":[[245,4],[379,4]]},"167":{"position":[[213,4],[316,4]]},"173":{"position":[[213,4],[350,4],[488,4]]},"175":{"position":[[213,4],[350,4]]},"179":{"position":[[213,4],[359,4]]}}}],["need",{"_index":1583,"t":{"97":{"position":[[263,4]]},"195":{"position":[[1107,4]]},"201":{"position":[[605,4]]},"209":{"position":[[340,4]]}}}],["needs",{"_index":2642,"t":{"201":{"position":[[388,5]]}}}],["nest",{"_index":1750,"t":{"103":{"position":[[676,4]]}}}],["nested",{"_index":1732,"t":{"103":{"position":[[107,6]]}}}],["new",{"_index":45,"t":{"41":{"position":[[221,3],[1035,3],[1075,3],[1297,3],[1392,3],[1681,3],[1986,3],[2217,3],[2306,3],[2472,3],[4014,3],[4219,3]]},"43":{"position":[[45,3],[190,3],[323,3],[842,3],[1818,3]]},"45":{"position":[[45,3],[248,3],[676,3],[1055,3],[1139,3]]},"47":{"position":[[45,3],[703,3]]},"49":{"position":[[45,3],[499,3]]},"51":{"position":[[45,3],[315,3]]},"53":{"position":[[45,3],[841,3],[904,3],[1060,3],[1228,3],[1856,3],[1959,3],[2107,3],[2460,3],[2715,3]]},"55":{"position":[[45,3],[641,3],[703,3]]},"57":{"position":[[45,3],[606,3]]},"59":{"position":[[45,3],[877,3],[936,3],[1554,3],[1613,3]]},"61":{"position":[[45,3],[384,3]]},"63":{"position":[[45,3],[449,3]]},"65":{"position":[[45,3],[138,3],[497,3],[1591,3]]},"67":{"position":[[45,3],[167,3],[232,3],[395,3]]},"69":{"position":[[45,3],[335,3],[688,3],[2313,3],[3227,3],[3461,3],[4268,3],[4613,3],[4896,3],[5183,3],[7446,3],[7549,3],[7749,3]]},"71":{"position":[[45,3],[242,3]]},"73":{"position":[[45,3],[249,3],[1444,3]]},"75":{"position":[[45,3]]},"77":{"position":[[45,3],[158,3]]},"79":{"position":[[45,3],[142,3],[471,3],[1458,3]]},"81":{"position":[[45,3],[1152,3]]},"83":{"position":[[45,3],[816,3]]},"85":{"position":[[121,3]]},"87":{"position":[[45,3],[269,3],[590,3],[767,3],[1133,3],[1283,3],[1723,3],[1808,3],[2006,3],[2340,3],[2395,3],[2504,3],[2613,3],[2718,3]]},"89":{"position":[[45,3],[570,3]]},"91":{"position":[[138,3]]},"93":{"position":[[113,3],[1166,3],[1211,3],[1336,3],[1379,3]]},"95":{"position":[[45,3],[358,3],[540,3],[1212,3]]},"97":{"position":[[317,3],[532,3],[2787,3]]},"99":{"position":[[45,3],[581,3],[643,3]]},"101":{"position":[[45,3],[720,3],[771,3]]},"103":{"position":[[260,3],[882,3],[993,3],[1107,3],[2042,3],[2679,3],[3399,3],[3602,3],[3925,3],[4893,3],[5309,3]]},"105":{"position":[[45,3],[176,3],[265,3],[799,3],[1008,3]]},"107":{"position":[[45,3],[324,3],[380,3],[1214,3]]},"109":{"position":[[45,3],[224,3],[1320,3]]},"111":{"position":[[77,3],[192,3]]},"147":{"position":[[45,3],[368,3],[1029,3],[1334,3]]},"149":{"position":[[45,3],[319,3],[577,3],[804,3],[1072,3],[1319,3],[1471,3],[1634,3],[1835,3],[2200,3]]},"151":{"position":[[45,3],[176,3],[618,3]]},"153":{"position":[[45,3],[143,3],[1053,3]]},"155":{"position":[[45,3],[143,3],[330,3],[1425,3]]},"157":{"position":[[45,3],[537,3]]},"159":{"position":[[45,3],[162,3],[2768,3]]},"161":{"position":[[45,3],[143,3],[495,3],[1445,3]]},"163":{"position":[[45,3],[143,3],[925,3],[949,3],[1084,3],[1108,3],[1237,3],[1261,3]]},"165":{"position":[[45,3],[175,3],[1780,3],[1839,3],[2588,3],[2651,3],[3226,3],[3287,3],[4229,3],[4288,3],[4938,3]]},"167":{"position":[[45,3],[143,3],[1608,3],[1659,3]]},"169":{"position":[[45,3],[295,3],[449,3]]},"171":{"position":[[45,3],[143,3],[606,3]]},"173":{"position":[[45,3],[143,3],[1325,3]]},"175":{"position":[[45,3],[143,3],[903,3]]},"177":{"position":[[45,3],[319,3],[473,3],[601,4],[657,3],[838,3]]},"179":{"position":[[45,3],[143,3],[1196,3]]},"181":{"position":[[45,3],[580,3],[851,3]]},"183":{"position":[[45,3],[518,3]]},"185":{"position":[[220,3],[345,3],[410,3],[573,3]]},"187":{"position":[[45,3],[161,3]]},"189":{"position":[[45,3],[342,3],[389,3]]},"191":{"position":[[45,3],[255,3]]},"193":{"position":[[45,3],[396,3]]},"195":{"position":[[45,3],[221,3],[1273,3],[1349,3]]},"197":{"position":[[45,3],[598,3]]},"199":{"position":[[45,3],[778,3]]},"201":{"position":[[1529,3],[1651,3],[1927,3],[1977,3]]},"203":{"position":[[45,3],[167,3],[286,3],[658,3],[824,3],[1136,3]]},"205":{"position":[[45,3],[562,3],[593,3],[671,3],[699,3],[774,3],[812,3],[896,3],[930,3]]},"207":{"position":[[45,3],[467,3],[545,3],[745,3],[1929,3]]},"209":{"position":[[183,3],[915,3]]},"211":{"position":[[45,3],[528,3],[668,3],[874,3],[1246,3],[1292,3],[1526,3],[1598,5]]},"244":{"position":[[45,3],[167,3],[339,3],[634,3]]},"258":{"position":[[45,3],[301,3],[427,3]]}}}],["next",{"_index":1798,"t":{"103":{"position":[[1983,4]]}}}],["nicer",{"_index":305,"t":{"43":{"position":[[1470,5]]}}}],["noise",{"_index":1600,"t":{"97":{"position":[[1029,6],[2601,5],[2832,6]]},"159":{"position":[[948,6],[2419,6]]},"165":{"position":[[2750,6],[2867,6],[3024,6],[4610,5]]}}}],["noisecontainer",{"_index":2336,"t":{"165":{"position":[[3270,14]]}}}],["noisecontainer.addchild(noisequad",{"_index":2337,"t":{"165":{"position":[[3309,35]]}}}],["noisecontainer.position.set(10",{"_index":2380,"t":{"165":{"position":[[5053,31]]}}}],["noisequad",{"_index":2335,"t":{"165":{"position":[[3214,9]]}}}],["noisequad.shader.uniforms.limit",{"_index":2396,"t":{"165":{"position":[[5628,31]]}}}],["noiseshader",{"_index":2333,"t":{"165":{"position":[[3055,11],[3250,13]]}}}],["noisetexture",{"_index":2334,"t":{"165":{"position":[[3137,12],[4791,13],[5913,12]]}}}],["noiseuniforms",{"_index":2332,"t":{"165":{"position":[[2994,13],[3115,15]]}}}],["none",{"_index":1130,"t":{"69":{"position":[[8807,4]]}}}],["normal",{"_index":2833,"t":{"211":{"position":[[1174,6]]}}}],["normalize",{"_index":1178,"t":{"75":{"position":[[564,9]]},"95":{"position":[[2131,9]]},"97":{"position":[[1508,10],[1907,10],[2001,10]]},"159":{"position":[[1375,10],[1755,10],[1849,10]]}}}],["normalize(cross",{"_index":1646,"t":{"97":{"position":[[1943,16]]},"159":{"position":[[1791,16]]}}}],["normalize(vec3",{"_index":1651,"t":{"97":{"position":[[2048,15]]},"159":{"position":[[1896,15]]}}}],["normalized",{"_index":1280,"t":{"83":{"position":[[1071,10]]}}}],["note",{"_index":1481,"t":{"93":{"position":[[411,5]]},"97":{"position":[[46,4]]}}}],["now",{"_index":665,"t":{"53":{"position":[[3839,3],[5012,3],[5142,4]]},"55":{"position":[[512,4]]},"207":{"position":[[1322,3]]}}}],["null",{"_index":293,"t":{"43":{"position":[[1232,5],[1998,5]]},"47":{"position":[[852,5],[2017,5]]},"53":{"position":[[3463,5],[3510,6]]},"69":{"position":[[1378,5],[6184,5]]},"89":{"position":[[1220,5],[1460,5],[1881,5]]},"97":{"position":[[513,5]]},"103":{"position":[[2843,5],[3029,5]]},"107":{"position":[[1191,5]]},"147":{"position":[[1309,5]]}}}],["number",{"_index":911,"t":{"65":{"position":[[1165,6]]},"73":{"position":[[895,6],[1018,6]]},"79":{"position":[[964,6]]}}}],["number(math.sin(time",{"_index":2254,"t":{"159":{"position":[[3035,20]]}}}],["numbers",{"_index":2175,"t":{"151":{"position":[[1165,8]]}}}],["object",{"_index":702,"t":{"53":{"position":[[4770,7]]},"69":{"position":[[9311,6]]}}}],["object.addeventlistener('pointerenter",{"_index":1346,"t":{"85":{"position":[[1727,39]]}}}],["object.addeventlistener('pointerleave",{"_index":1348,"t":{"85":{"position":[[1777,39]]}}}],["object.addeventlistener('pointerout",{"_index":1350,"t":{"85":{"position":[[1876,37]]}}}],["object.addeventlistener('pointerover",{"_index":1349,"t":{"85":{"position":[[1827,38]]}}}],["object.assign(pixi.sprite.from('t1",{"_index":273,"t":{"43":{"position":[[632,37]]}}}],["object.assign(pixi.sprite.from('t2",{"_index":275,"t":{"43":{"position":[[704,37]]}}}],["object1",{"_index":97,"t":{"41":{"position":[[1003,9]]}}}],["object1.acceleration.x",{"_index":111,"t":{"41":{"position":[[1408,22]]}}}],["object1.acceleration.y",{"_index":113,"t":{"41":{"position":[[1457,22]]}}}],["object1.getbounds",{"_index":77,"t":{"41":{"position":[[620,20]]}}}],["object1.mass",{"_index":120,"t":{"41":{"position":[[1643,13]]}}}],["object1.x",{"_index":102,"t":{"41":{"position":[[1103,10],[1181,10],[1207,10]]}}}],["object1.y",{"_index":104,"t":{"41":{"position":[[1126,10],[1233,10],[1259,11]]}}}],["object2",{"_index":75,"t":{"41":{"position":[[593,8],[989,8],[1016,9]]}}}],["object2.acceleration.x",{"_index":112,"t":{"41":{"position":[[1433,23]]}}}],["object2.acceleration.y",{"_index":114,"t":{"41":{"position":[[1482,23]]}}}],["object2.getbounds",{"_index":79,"t":{"41":{"position":[[657,20]]}}}],["object2.mass",{"_index":121,"t":{"41":{"position":[[1659,14]]}}}],["object2.x",{"_index":101,"t":{"41":{"position":[[1091,9],[1168,10],[1194,10]]}}}],["object2.y",{"_index":103,"t":{"41":{"position":[[1114,9],[1220,10],[1246,10]]}}}],["object[property",{"_index":704,"t":{"53":{"position":[[4808,17]]}}}],["objects",{"_index":53,"t":{"41":{"position":[[341,7],[463,7],[939,7]]}}}],["offscreencanvas",{"_index":2507,"t":{"185":{"position":[[92,16]]}}}],["offset",{"_index":2163,"t":{"151":{"position":[[922,6]]},"165":{"position":[[1158,8],[3490,8]]}}}],["offsets",{"_index":2344,"t":{"165":{"position":[[3648,8]]}}}],["offsetx",{"_index":2829,"t":{"211":{"position":[[1010,7],[1420,7]]}}}],["offsety",{"_index":2830,"t":{"211":{"position":[[1053,7],[1456,7]]}}}],["old",{"_index":1485,"t":{"93":{"position":[[442,3]]}}}],["on('mousedown",{"_index":1281,"t":{"83":{"position":[[1342,16]]}}}],["on('mousemove",{"_index":1934,"t":{"105":{"position":[[1584,16]]}}}],["on('mouseout",{"_index":1285,"t":{"83":{"position":[[1477,15]]}}}],["on('mouseover",{"_index":1284,"t":{"83":{"position":[[1443,16]]}}}],["on('mouseup",{"_index":1282,"t":{"83":{"position":[[1376,14]]}}}],["on('mouseupoutside",{"_index":1283,"t":{"83":{"position":[[1406,21]]}}}],["on('pointerdown",{"_index":283,"t":{"43":{"position":[[1061,18]]},"81":{"position":[[1377,18]]},"83":{"position":[[1151,18]]},"87":{"position":[[411,18],[953,18],[1428,18],[2192,18]]},"95":{"position":[[724,18]]}}}],["on('pointermove",{"_index":288,"t":{"43":{"position":[[1156,18]]}}}],["on('pointerout",{"_index":1265,"t":{"81":{"position":[[1508,17]]},"83":{"position":[[1282,17]]},"87":{"position":[[499,17],[1041,17],[1516,17],[2280,17]]}}}],["on('pointerover",{"_index":1263,"t":{"81":{"position":[[1475,18]]},"83":{"position":[[1249,18]]},"87":{"position":[[452,18],[994,18],[1469,18],[2233,18]]}}}],["on('pointerup",{"_index":285,"t":{"43":{"position":[[1093,16]]},"81":{"position":[[1410,16]]},"83":{"position":[[1184,16]]},"95":{"position":[[756,16]]}}}],["on('pointerupoutside",{"_index":287,"t":{"43":{"position":[[1121,23]]},"81":{"position":[[1439,23]]},"83":{"position":[[1213,23]]},"95":{"position":[[784,23]]}}}],["on('touchend",{"_index":1287,"t":{"83":{"position":[[1569,15]]}}}],["on('touchendoutside",{"_index":1288,"t":{"83":{"position":[[1600,22]]}}}],["on('touchmove",{"_index":1936,"t":{"105":{"position":[[1616,16]]}}}],["on('touchstart",{"_index":1286,"t":{"83":{"position":[[1534,17]]}}}],["onassetsloaded",{"_index":537,"t":{"53":{"position":[[410,14],[462,16]]},"63":{"position":[[626,16]]}}}],["onassetsloaded(perlin",{"_index":1671,"t":{"97":{"position":[[2562,22]]}}}],["onbuttondown",{"_index":1261,"t":{"81":{"position":[[1396,13],[1828,14]]},"83":{"position":[[1170,13],[1359,13],[1552,13],[1923,14]]}}}],["onbuttonout",{"_index":1266,"t":{"81":{"position":[[1526,13],[2178,13]]},"83":{"position":[[1300,13],[1493,12],[2273,13]]}}}],["onbuttonover",{"_index":1264,"t":{"81":{"position":[[1494,13],[2067,14]]},"83":{"position":[[1268,13],[1460,13],[2162,14]]}}}],["onbuttonup",{"_index":1262,"t":{"81":{"position":[[1427,11],[1463,11],[1926,12]]},"83":{"position":[[1201,11],[1237,11],[1391,11],[1428,11],[1585,11],[1623,11],[2021,12]]}}}],["once",{"_index":766,"t":{"57":{"position":[[363,4]]},"95":{"position":[[1504,4],[1664,4]]}}}],["onchange",{"_index":699,"t":{"53":{"position":[[4730,9],[4856,9]]}}}],["onclick",{"_index":873,"t":{"63":{"position":[[1150,9],[1169,9]]},"75":{"position":[[645,9],[725,9],[769,9],[830,9]]},"87":{"position":[[430,8],[972,8],[1447,8],[2211,8],[2973,9]]}}}],["oncomplete",{"_index":700,"t":{"53":{"position":[[4740,11],[4876,11]]}}}],["ondrag",{"_index":1555,"t":{"95":{"position":[[1627,8],[1792,8]]}}}],["ondrag(e",{"_index":1564,"t":{"95":{"position":[[1886,9]]}}}],["ondragend",{"_index":1449,"t":{"89":{"position":[[1316,11],[1361,11],[1772,11]]},"95":{"position":[[773,10],[808,11]]}}}],["ondragend(e",{"_index":1559,"t":{"95":{"position":[[1702,12]]}}}],["ondragmove",{"_index":1463,"t":{"89":{"position":[[1748,12],[1833,12]]}}}],["ondragmove(event",{"_index":1451,"t":{"89":{"position":[[1382,17]]}}}],["ondragstart",{"_index":1445,"t":{"89":{"position":[[1058,12],[1501,13]]},"95":{"position":[[743,12],[1537,13]]}}}],["one",{"_index":309,"t":{"43":{"position":[[1533,3]]},"85":{"position":[[810,3]]},"165":{"position":[[894,3]]}}}],["onevent",{"_index":1347,"t":{"85":{"position":[[1767,9],[1817,9],[1866,9],[1914,9]]}}}],["onevent(e",{"_index":1330,"t":{"85":{"position":[[1133,10]]}}}],["onloaded(data",{"_index":1689,"t":{"99":{"position":[[550,14]]}}}],["onplayvideo",{"_index":2570,"t":{"195":{"position":[[1059,13],[1082,13]]}}}],["onpointermove",{"_index":1935,"t":{"105":{"position":[[1601,14],[1633,15]]}}}],["onpointermove(eventdata",{"_index":1937,"t":{"105":{"position":[[1658,24]]}}}],["onpointerout",{"_index":1361,"t":{"87":{"position":[[517,13],[1059,13],[1534,13],[2298,13],[3069,14]]}}}],["onpointerover",{"_index":1360,"t":{"87":{"position":[[471,14],[1013,14],[1488,14],[2252,14],[3018,15]]}}}],["ontick",{"_index":1094,"t":{"69":{"position":[[8103,6]]}}}],["ontick.foreach((cb",{"_index":1107,"t":{"69":{"position":[[8428,19]]}}}],["onto",{"_index":1739,"t":{"103":{"position":[[231,4]]}}}],["opt",{"_index":1171,"t":{"75":{"position":[[451,3]]}}}],["optimal",{"_index":1574,"t":{"97":{"position":[[77,7]]}}}],["options",{"_index":52,"t":{"41":{"position":[[325,7]]},"203":{"position":[[697,7]]}}}],["order",{"_index":1290,"t":{"85":{"position":[[58,5],[323,5]]}}}],["original",{"_index":1119,"t":{"69":{"position":[[8692,8]]},"103":{"position":[[937,8]]}}}],["out",{"_index":13,"t":{"17":{"position":[[135,3]]},"41":{"position":[[3486,3],[4351,3],[4470,3]]},"43":{"position":[[1425,3]]},"103":{"position":[[4541,3],[4661,5],[5490,5]]}}}],["outcolor",{"_index":2295,"t":{"165":{"position":[[1355,8],[1429,9],[3580,8],[3657,8],[3735,8],[3814,8],[3895,8]]}}}],["outdir",{"_index":1069,"t":{"69":{"position":[[6083,6],[6555,6]]}}}],["outdir[0",{"_index":1074,"t":{"69":{"position":[[7119,9]]}}}],["outdir[1",{"_index":1075,"t":{"69":{"position":[[7162,9]]}}}],["outdir[i",{"_index":1073,"t":{"69":{"position":[[6564,10]]}}}],["outer",{"_index":1312,"t":{"85":{"position":[[602,5]]}}}],["outline",{"_index":2049,"t":{"111":{"position":[[864,7]]}}}],["output",{"_index":2304,"t":{"165":{"position":[[1646,6]]}}}],["outputframe",{"_index":1503,"t":{"93":{"position":[[775,12]]}}}],["outputframe.xy",{"_index":1508,"t":{"93":{"position":[[870,15],[1095,15]]}}}],["outputframe.zw",{"_index":1521,"t":{"93":{"position":[[1113,15]]}}}],["outputsprite",{"_index":2752,"t":{"207":{"position":[[530,12]]}}}],["outputsprite.anchor.set(0.5",{"_index":2756,"t":{"207":{"position":[[642,29]]}}}],["outputsprite.scale.set(1",{"_index":2792,"t":{"207":{"position":[[2030,24]]}}}],["outputsprite.texture",{"_index":2789,"t":{"207":{"position":[[1941,20]]}}}],["outputsprite.x",{"_index":2754,"t":{"207":{"position":[[598,14]]}}}],["outputsprite.y",{"_index":2755,"t":{"207":{"position":[[620,14]]}}}],["over",{"_index":679,"t":{"53":{"position":[[4209,4]]},"65":{"position":[[1221,4]]},"73":{"position":[[1074,4]]},"79":{"position":[[1022,4]]},"85":{"position":[[297,4]]},"89":{"position":[[789,4]]},"91":{"position":[[109,4]]},"103":{"position":[[5435,4]]},"151":{"position":[[1115,4]]}}}],["override",{"_index":1769,"t":{"103":{"position":[[1148,8]]}}}],["p",{"_index":406,"t":{"47":{"position":[[1394,1],[2163,1]]},"97":{"position":[[1226,2],[1456,2],[2195,1]]},"159":{"position":[[1145,2],[1323,2],[2043,1]]}}}],["p.x",{"_index":418,"t":{"47":{"position":[[1616,3]]}}}],["p.y",{"_index":419,"t":{"47":{"position":[[1626,3]]}}}],["p.y)*0.04).r*5.1",{"_index":1612,"t":{"97":{"position":[[1320,17]]},"159":{"position":[[1239,17]]}}}],["p.z,id",{"_index":1617,"t":{"97":{"position":[[1404,8]]},"159":{"position":[[1271,8]]}}}],["p1.x",{"_index":127,"t":{"41":{"position":[[1863,4]]}}}],["p1.y",{"_index":130,"t":{"41":{"position":[[1886,4]]}}}],["p2",{"_index":126,"t":{"41":{"position":[[1847,3]]}}}],["p2.x",{"_index":128,"t":{"41":{"position":[[1870,5]]}}}],["p2.y",{"_index":131,"t":{"41":{"position":[[1893,5]]}}}],["p[0",{"_index":435,"t":{"47":{"position":[[2291,4]]}}}],["p[1",{"_index":437,"t":{"47":{"position":[[2346,4]]}}}],["padding",{"_index":1902,"t":{"105":{"position":[[235,7],[286,8],[296,8],[324,7],[357,7]]}}}],["page",{"_index":3,"t":{"17":{"position":[[31,5]]}}}],["panda",{"_index":1964,"t":{"107":{"position":[[884,5]]},"147":{"position":[[813,5],[945,7]]}}}],["panda.anchor.set(0.5",{"_index":1966,"t":{"107":{"position":[[949,22]]},"147":{"position":[[878,22]]}}}],["panda.scale.x",{"_index":1978,"t":{"107":{"position":[[1543,13]]},"147":{"position":[[1658,13]]}}}],["panda.scale.y",{"_index":1979,"t":{"107":{"position":[[1587,13]]},"147":{"position":[[1702,13]]}}}],["parallel",{"_index":1132,"t":{"69":{"position":[[8999,8]]}}}],["particular",{"_index":1459,"t":{"89":{"position":[[1639,10]]}}}],["pass",{"_index":1794,"t":{"103":{"position":[[1899,4],[2111,4],[2343,4]]},"165":{"position":[[1004,5],[1629,4],[1905,5],[4365,4]]},"201":{"position":[[327,4]]}}}],["passes",{"_index":2279,"t":{"165":{"position":[[539,7],[5711,6]]}}}],["path",{"_index":1192,"t":{"77":{"position":[[183,5]]},"81":{"position":[[744,4]]},"83":{"position":[[408,4]]},"89":{"position":[[183,4]]},"111":{"position":[[2244,4]]},"187":{"position":[[186,4]]},"193":{"position":[[160,4]]},"195":{"position":[[1182,4]]},"197":{"position":[[278,4]]}}}],["paths",{"_index":855,"t":{"63":{"position":[[695,5]]}}}],["paul",{"_index":1113,"t":{"69":{"position":[[8518,4]]}}}],["people",{"_index":2670,"t":{"201":{"position":[[1091,6]]}}}],["per",{"_index":2691,"t":{"201":{"position":[[1803,3]]}}}],["performance",{"_index":1042,"t":{"69":{"position":[[4525,11]]},"187":{"position":[[599,11]]}}}],["performant",{"_index":1582,"t":{"97":{"position":[[237,10]]}}}],["perlin",{"_index":1672,"t":{"97":{"position":[[2594,6],[2839,7]]}}}],["perlin.basetexture.mipmap",{"_index":1677,"t":{"97":{"position":[[2723,25]]}}}],["perlin.basetexture.wrapmode",{"_index":1675,"t":{"97":{"position":[[2669,27]]}}}],["perlinnoise",{"_index":2280,"t":{"165":{"position":[[870,11]]}}}],["perlintexture",{"_index":2282,"t":{"165":{"position":[[920,13],[3031,14]]}}}],["phase",{"_index":711,"t":{"53":{"position":[[5122,5],[5277,6]]},"69":{"position":[[870,5],[911,5],[917,5],[938,5],[2783,5],[2824,5],[2830,5],[2851,5],[2971,7],[3615,5],[3656,5],[3662,5],[3683,5],[3757,5],[5377,5],[5418,5],[5424,5],[5446,5],[7971,5],[8012,5],[8018,5],[8038,5],[8084,6]]},"165":{"position":[[2060,6],[2373,6]]}}}],["phases",{"_index":2384,"t":{"165":{"position":[[5175,6],[5202,6]]}}}],["physics",{"_index":42,"t":{"41":{"position":[[201,7]]}}}],["pi*2",{"_index":1157,"t":{"73":{"position":[[916,4]]}}}],["pixel",{"_index":2643,"t":{"201":{"position":[[401,5]]}}}],["pixelation",{"_index":1164,"t":{"75":{"position":[[193,10]]},"89":{"position":[[280,10]]}}}],["pixels",{"_index":2170,"t":{"151":{"position":[[1038,6]]}}}],["pixi",{"_index":27,"t":{"41":{"position":[[12,4]]},"43":{"position":[[12,4]]},"45":{"position":[[12,4]]},"47":{"position":[[12,4]]},"49":{"position":[[12,4]]},"51":{"position":[[12,4]]},"53":{"position":[[12,4]]},"55":{"position":[[12,4]]},"57":{"position":[[12,4]]},"59":{"position":[[12,4]]},"61":{"position":[[12,4]]},"63":{"position":[[12,4]]},"65":{"position":[[12,4]]},"67":{"position":[[12,4]]},"69":{"position":[[12,4],[8710,4]]},"71":{"position":[[12,4]]},"73":{"position":[[12,4]]},"75":{"position":[[12,4]]},"77":{"position":[[12,4]]},"79":{"position":[[12,4]]},"81":{"position":[[12,4]]},"83":{"position":[[12,4]]},"85":{"position":[[12,4]]},"87":{"position":[[12,4]]},"89":{"position":[[12,4]]},"91":{"position":[[12,4]]},"93":{"position":[[12,4]]},"95":{"position":[[12,4]]},"97":{"position":[[12,4]]},"99":{"position":[[12,4]]},"101":{"position":[[12,4]]},"103":{"position":[[12,4]]},"105":{"position":[[12,4]]},"107":{"position":[[12,4]]},"109":{"position":[[12,4]]},"111":{"position":[[12,4]]},"147":{"position":[[12,4]]},"149":{"position":[[12,4]]},"151":{"position":[[12,4]]},"153":{"position":[[12,4]]},"155":{"position":[[12,4]]},"157":{"position":[[12,4]]},"159":{"position":[[12,4]]},"161":{"position":[[12,4]]},"163":{"position":[[12,4]]},"165":{"position":[[12,4]]},"167":{"position":[[12,4]]},"169":{"position":[[12,4]]},"171":{"position":[[12,4]]},"173":{"position":[[12,4]]},"175":{"position":[[12,4]]},"177":{"position":[[12,4]]},"179":{"position":[[12,4]]},"181":{"position":[[12,4]]},"183":{"position":[[12,4]]},"185":{"position":[[12,4]]},"187":{"position":[[12,4]]},"189":{"position":[[12,4]]},"191":{"position":[[12,4]]},"193":{"position":[[12,4]]},"195":{"position":[[12,4],[806,4],[970,5]]},"197":{"position":[[12,4],[428,4],[687,4]]},"199":{"position":[[12,4]]},"201":{"position":[[12,4]]},"203":{"position":[[12,4],[196,7]]},"205":{"position":[[12,4]]},"207":{"position":[[12,4]]},"209":{"position":[[12,4]]},"211":{"position":[[12,4],[773,4]]},"244":{"position":[[12,4]]},"258":{"position":[[12,4]]}}}],["pixi.animatedsprite(explosiontextures",{"_index":2498,"t":{"183":{"position":[[522,39]]}}}],["pixi.animatedsprite(frames",{"_index":2595,"t":{"197":{"position":[[602,28]]}}}],["pixi.animatedsprite(textures",{"_index":2476,"t":{"181":{"position":[[584,30],[855,30]]}}}],["pixi.application",{"_index":46,"t":{"41":{"position":[[225,18]]},"43":{"position":[[49,18]]},"45":{"position":[[49,18]]},"47":{"position":[[49,18]]},"49":{"position":[[49,18]]},"51":{"position":[[49,18]]},"53":{"position":[[49,18]]},"55":{"position":[[49,18]]},"57":{"position":[[49,18]]},"59":{"position":[[49,18]]},"61":{"position":[[49,18]]},"63":{"position":[[49,18]]},"65":{"position":[[49,18]]},"67":{"position":[[49,18]]},"69":{"position":[[49,18]]},"71":{"position":[[49,18]]},"73":{"position":[[49,18]]},"75":{"position":[[49,18]]},"77":{"position":[[49,18]]},"79":{"position":[[49,18]]},"81":{"position":[[49,18]]},"83":{"position":[[49,18]]},"85":{"position":[[125,18]]},"89":{"position":[[49,18]]},"91":{"position":[[142,18]]},"93":{"position":[[117,18]]},"95":{"position":[[49,18]]},"97":{"position":[[321,18]]},"99":{"position":[[49,18]]},"101":{"position":[[49,18]]},"103":{"position":[[264,18]]},"105":{"position":[[49,18]]},"107":{"position":[[49,18]]},"109":{"position":[[49,18]]},"111":{"position":[[81,18]]},"147":{"position":[[49,18]]},"149":{"position":[[49,18]]},"151":{"position":[[49,18]]},"153":{"position":[[49,18]]},"155":{"position":[[49,18]]},"157":{"position":[[49,18]]},"159":{"position":[[49,18]]},"161":{"position":[[49,18]]},"163":{"position":[[49,18]]},"165":{"position":[[49,18]]},"167":{"position":[[49,18]]},"169":{"position":[[49,18]]},"171":{"position":[[49,18]]},"173":{"position":[[49,18]]},"175":{"position":[[49,18]]},"177":{"position":[[49,18]]},"179":{"position":[[49,18]]},"181":{"position":[[49,18]]},"183":{"position":[[49,18]]},"185":{"position":[[224,18]]},"187":{"position":[[49,18]]},"189":{"position":[[49,18]]},"191":{"position":[[49,18]]},"193":{"position":[[49,18]]},"195":{"position":[[49,18]]},"197":{"position":[[49,18]]},"199":{"position":[[49,18]]},"201":{"position":[[1533,18]]},"203":{"position":[[49,18]]},"205":{"position":[[49,18]]},"207":{"position":[[49,18]]},"209":{"position":[[187,18]]},"211":{"position":[[49,18]]},"244":{"position":[[49,18]]},"258":{"position":[[49,18]]}}}],["pixi.application(800",{"_index":1351,"t":{"87":{"position":[[49,21]]}}}],["pixi.assets.add('egghead",{"_index":738,"t":{"55":{"position":[[248,26]]},"57":{"position":[[248,26]]}}}],["pixi.assets.add('flowertop",{"_index":737,"t":{"55":{"position":[[175,28]]},"57":{"position":[[175,28]]}}}],["pixi.assets.add('t1",{"_index":263,"t":{"43":{"position":[[344,21]]}}}],["pixi.assets.add('t2",{"_index":265,"t":{"43":{"position":[[409,21]]}}}],["pixi.assets.addbundle('fonts",{"_index":2727,"t":{"205":{"position":[[177,30]]}}}],["pixi.assets.backgroundload(['flowertop",{"_index":740,"t":{"55":{"position":[[363,40]]}}}],["pixi.assets.backgroundloadbundle(['load",{"_index":793,"t":{"59":{"position":[[556,39]]}}}],["pixi.assets.init",{"_index":792,"t":{"59":{"position":[[459,18]]}}}],["pixi.assets.load",{"_index":527,"t":{"53":{"position":[[149,18]]}}}],["pixi.assets.load('egghead').then((texture",{"_index":746,"t":{"55":{"position":[[517,42]]}}}],["pixi.assets.load('https://pixijs.com/assets/bg_grass.jpg').then((grasstexture",{"_index":2449,"t":{"177":{"position":[[216,78]]}}}],["pixi.assets.load('https://pixijs.com/assets/bg_grass.jpg').then((texture",{"_index":1136,"t":{"71":{"position":[[149,73]]}}}],["pixi.assets.load('https://pixijs.com/assets/bitmap",{"_index":2519,"t":{"191":{"position":[[149,50]]}}}],["pixi.assets.load('https://pixijs.com/assets/bunny.png",{"_index":519,"t":{"51":{"position":[[246,56]]},"61":{"position":[[221,56]]}}}],["pixi.assets.load('https://pixijs.com/assets/flowertop.png').then((texture",{"_index":2808,"t":{"211":{"position":[[126,74]]}}}],["pixi.assets.load('https://pixijs.com/assets/perlin.jpg').then(onassetsloaded",{"_index":1585,"t":{"97":{"position":[[421,78]]}}}],["pixi.assets.load('https://pixijs.com/assets/spritesheet/0123456789.json').then((spritesheet",{"_index":2467,"t":{"181":{"position":[[144,92]]}}}],["pixi.assets.load('https://pixijs.com/assets/spritesheet/fighter.json').then",{"_index":2582,"t":{"197":{"position":[[149,78]]}}}],["pixi.assets.load('https://pixijs.com/assets/spritesheet/mc.json').then",{"_index":2492,"t":{"183":{"position":[[144,73]]}}}],["pixi.assets.load('https://pixijs.com/assets/spritesheet/monsters.json",{"_index":837,"t":{"63":{"position":[[156,71]]}}}],["pixi.assets.load(['flowertop",{"_index":768,"t":{"57":{"position":[[408,30]]}}}],["pixi.assets.load(['t1",{"_index":267,"t":{"43":{"position":[[475,23]]}}}],["pixi.assets.load(isegghead",{"_index":764,"t":{"55":{"position":[[1065,26]]}}}],["pixi.assets.loadbundle('fonts').then",{"_index":2739,"t":{"205":{"position":[[503,39]]}}}],["pixi.assets.loadbundle('game",{"_index":818,"t":{"59":{"position":[[1503,28]]}}}],["pixi.assets.loadbundle('load",{"_index":799,"t":{"59":{"position":[[826,28]]}}}],["pixi.basetexture(new",{"_index":2685,"t":{"201":{"position":[[1655,20]]}}}],["pixi.bitmapfont.from('coordinates",{"_index":1879,"t":{"103":{"position":[[4730,35]]}}}],["pixi.bitmaptext",{"_index":2522,"t":{"191":{"position":[[259,16]]}}}],["pixi.bitmaptext('global",{"_index":1882,"t":{"103":{"position":[[4897,24]]}}}],["pixi.blend_modes.add",{"_index":394,"t":{"47":{"position":[[784,21]]},"65":{"position":[[1030,21]]}}}],["pixi.buffer(new",{"_index":2211,"t":{"155":{"position":[[334,15]]}}}],["pixi.container",{"_index":326,"t":{"45":{"position":[[252,17]]},"53":{"position":[[845,17],[908,17]]},"63":{"position":[[453,17]]},"67":{"position":[[171,17]]},"69":{"position":[[339,17],[2317,17],[3231,17],[4272,17],[7450,17]]},"93":{"position":[[1170,17]]},"103":{"position":[[886,17]]},"105":{"position":[[180,17]]},"107":{"position":[[384,17]]},"147":{"position":[[372,17]]},"151":{"position":[[180,17]]},"165":{"position":[[1843,17],[2655,17],[3291,17],[4292,17]]},"185":{"position":[[349,17]]},"207":{"position":[[749,17]]},"244":{"position":[[171,17]]},"258":{"position":[[431,17]]}}}],["pixi.displayobject",{"_index":1756,"t":{"103":{"position":[[770,18]]}}}],["pixi.eventboundary(this.content",{"_index":1768,"t":{"103":{"position":[[1111,33]]}}}],["pixi.eventboundary.prototype.copymousedata.call(this.boundary",{"_index":1777,"t":{"103":{"position":[[1307,62]]}}}],["pixi.filter(null",{"_index":1524,"t":{"93":{"position":[[1340,17]]},"97":{"position":[[2791,17]]},"99":{"position":[[647,17]]}}}],["pixi.filters.blurfilter",{"_index":557,"t":{"53":{"position":[[1064,26]]},"101":{"position":[[724,26],[775,26]]}}}],["pixi.filters.blurfilter(blursize",{"_index":2454,"t":{"177":{"position":[[606,35]]}}}],["pixi.filters.colormatrixfilter",{"_index":1952,"t":{"107":{"position":[[328,33]]}}}],["pixi.filters.displacementfilter(displacementsprite",{"_index":1921,"t":{"105":{"position":[[1012,52]]},"151":{"position":[[622,52]]}}}],["pixi.geometry",{"_index":2178,"t":{"153":{"position":[[147,15]]},"155":{"position":[[147,15]]},"159":{"position":[[166,15]]},"161":{"position":[[147,15],[499,15]]},"163":{"position":[[147,15]]},"165":{"position":[[179,15]]},"167":{"position":[[147,15]]},"171":{"position":[[147,15]]},"173":{"position":[[147,15]]},"175":{"position":[[147,15]]},"179":{"position":[[147,15]]}}}],["pixi.geometry.merge([geometry",{"_index":2257,"t":{"161":{"position":[[839,30]]}}}],["pixi.graphics",{"_index":255,"t":{"43":{"position":[[194,15],[327,16]]},"53":{"position":[[1860,16],[1963,16]]},"69":{"position":[[692,16],[3465,16],[4617,16],[4900,16],[5187,16],[7553,16],[7753,16]]},"85":{"position":[[658,15],[853,15]]},"87":{"position":[[1287,15],[1812,15]]},"91":{"position":[[301,15]]},"95":{"position":[[362,15],[544,15]]},"103":{"position":[[3403,15],[3606,15]]},"109":{"position":[[228,16],[1324,16]]},"111":{"position":[[196,16]]},"147":{"position":[[1033,16]]},"149":{"position":[[323,16],[581,16],[808,16],[1076,16],[1323,16],[1475,16],[1638,16],[1839,16],[2204,16]]},"169":{"position":[[453,16]]},"177":{"position":[[477,15]]},"195":{"position":[[225,15]]}}}],["pixi.groupd8",{"_index":2811,"t":{"211":{"position":[[272,13]]}}}],["pixi.js",{"_index":28,"t":{"41":{"position":[[22,10]]},"43":{"position":[[22,10]]},"45":{"position":[[22,10]]},"47":{"position":[[22,10]]},"49":{"position":[[22,10]]},"51":{"position":[[22,10]]},"53":{"position":[[22,10]]},"55":{"position":[[22,10]]},"57":{"position":[[22,10]]},"59":{"position":[[22,10]]},"61":{"position":[[22,10]]},"63":{"position":[[22,10]]},"65":{"position":[[22,10]]},"67":{"position":[[22,10]]},"69":{"position":[[22,10]]},"71":{"position":[[22,10]]},"73":{"position":[[22,10]]},"75":{"position":[[22,10]]},"77":{"position":[[22,10]]},"79":{"position":[[22,10]]},"81":{"position":[[22,10]]},"83":{"position":[[22,10]]},"85":{"position":[[22,10]]},"87":{"position":[[22,10]]},"89":{"position":[[22,10]]},"91":{"position":[[22,10]]},"93":{"position":[[22,10]]},"95":{"position":[[22,10]]},"97":{"position":[[22,10]]},"99":{"position":[[22,10]]},"101":{"position":[[22,10]]},"103":{"position":[[22,10]]},"105":{"position":[[22,10]]},"107":{"position":[[22,10]]},"109":{"position":[[22,10]]},"111":{"position":[[22,10]]},"147":{"position":[[22,10]]},"149":{"position":[[22,10]]},"151":{"position":[[22,10]]},"153":{"position":[[22,10]]},"155":{"position":[[22,10]]},"157":{"position":[[22,10]]},"159":{"position":[[22,10]]},"161":{"position":[[22,10]]},"163":{"position":[[22,10]]},"165":{"position":[[22,10]]},"167":{"position":[[22,10]]},"169":{"position":[[22,10]]},"171":{"position":[[22,10]]},"173":{"position":[[22,10]]},"175":{"position":[[22,10]]},"177":{"position":[[22,10]]},"179":{"position":[[22,10]]},"181":{"position":[[22,10]]},"183":{"position":[[22,10]]},"185":{"position":[[22,10]]},"187":{"position":[[22,10]]},"189":{"position":[[22,10]]},"191":{"position":[[22,10]]},"193":{"position":[[22,10]]},"195":{"position":[[22,10]]},"197":{"position":[[22,10]]},"199":{"position":[[22,10]]},"201":{"position":[[22,10]]},"203":{"position":[[22,10]]},"205":{"position":[[22,10]]},"207":{"position":[[22,10]]},"209":{"position":[[22,10]]},"211":{"position":[[22,10]]},"244":{"position":[[22,10]]},"258":{"position":[[22,10]]}}}],["pixi.matrix",{"_index":1764,"t":{"103":{"position":[[997,14],[2683,14]]}}}],["pixi.mesh(geometry",{"_index":2201,"t":{"153":{"position":[[1057,19]]},"155":{"position":[[1429,19]]},"159":{"position":[[2772,19]]},"163":{"position":[[929,19],[1088,19],[1241,19]]},"165":{"position":[[1784,19],[2592,19],[3230,19],[4233,19],[4942,19]]},"167":{"position":[[1612,19],[1663,19]]},"171":{"position":[[610,19]]},"173":{"position":[[1329,19]]},"175":{"position":[[907,19]]},"179":{"position":[[1200,19]]}}}],["pixi.mesh(geometry3",{"_index":2258,"t":{"161":{"position":[[1449,20]]}}}],["pixi.particlecontainer(10000",{"_index":1198,"t":{"79":{"position":[[146,29]]}}}],["pixi.point",{"_index":100,"t":{"41":{"position":[[1079,11],[1301,11],[1396,11],[1685,11],[4018,11],[4223,11]]},"43":{"position":[[1822,13]]},"93":{"position":[[1383,13]]},"105":{"position":[[803,13]]},"157":{"position":[[541,13]]}}}],["pixi.point(0",{"_index":98,"t":{"41":{"position":[[1039,14],[2221,14],[2476,14]]},"47":{"position":[[650,13]]}}}],["pixi.point(160",{"_index":1098,"t":{"69":{"position":[[8177,15]]}}}],["pixi.point(270",{"_index":1100,"t":{"69":{"position":[[8220,15]]}}}],["pixi.point(380",{"_index":1102,"t":{"69":{"position":[[8263,15]]}}}],["pixi.point(490",{"_index":1104,"t":{"69":{"position":[[8306,15]]}}}],["pixi.point(50",{"_index":1096,"t":{"69":{"position":[[8135,14]]}}}],["pixi.point(i",{"_index":2413,"t":{"169":{"position":[[247,12]]},"258":{"position":[[253,12]]}}}],["pixi.polygon",{"_index":1367,"t":{"87":{"position":[[771,14],[2010,14]]}}}],["pixi.program.from",{"_index":2260,"t":{"163":{"position":[[446,19]]}}}],["pixi.rectangle",{"_index":925,"t":{"65":{"position":[[1595,15]]},"73":{"position":[[1448,15]]},"79":{"position":[[1462,15]]},"103":{"position":[[3929,15]]},"105":{"position":[[269,15]]}}}],["pixi.rectangle(0",{"_index":2455,"t":{"177":{"position":[[661,17]]}}}],["pixi.rectangle(100",{"_index":1523,"t":{"93":{"position":[[1215,19]]}}}],["pixi.rectangle(texture.frame.x",{"_index":2817,"t":{"211":{"position":[[532,31]]}}}],["pixi.renderer",{"_index":1206,"t":{"79":{"position":[[389,13]]}}}],["pixi.rendertexture.create",{"_index":2306,"t":{"165":{"position":[[1707,27],[2513,27],[3152,27],[4156,27]]},"244":{"position":[[511,27]]}}}],["pixi.rendertexture.create(stagesize",{"_index":277,"t":{"43":{"position":[[776,37]]},"207":{"position":[[320,37],[379,37]]}}}],["pixi.resource",{"_index":2639,"t":{"201":{"position":[[292,13]]}}}],["pixi.scale_modes.linear",{"_index":2847,"t":{"244":{"position":[[575,24]]}}}],["pixi.scale_modes.nearest",{"_index":1166,"t":{"75":{"position":[[231,25]]},"89":{"position":[[323,25]]},"95":{"position":[[1063,25]]},"177":{"position":[[786,25]]}}}],["pixi.settings.scale_mode",{"_index":1165,"t":{"75":{"position":[[204,24]]}}}],["pixi.shader(program",{"_index":2264,"t":{"163":{"position":[[953,20],[1112,20],[1265,20]]}}}],["pixi.shader.from",{"_index":2186,"t":{"153":{"position":[[506,18]]},"155":{"position":[[986,18]]},"161":{"position":[[898,18]]},"167":{"position":[[381,18],[930,18]]},"171":{"position":[[243,18]]},"175":{"position":[[465,18]]}}}],["pixi.shader.from(vertexsrc",{"_index":2250,"t":{"159":{"position":[[2703,27]]},"165":{"position":[[1498,27],[2427,27],[3069,27],[4076,27],[4852,27]]},"173":{"position":[[1256,27]]},"179":{"position":[[1131,27]]}}}],["pixi.simpleplane(texture",{"_index":1138,"t":{"71":{"position":[[246,25]]}}}],["pixi.simplerope(pixi.texture.from('https://pixijs.com/assets/snake.png",{"_index":2415,"t":{"169":{"position":[[299,73]]},"258":{"position":[[305,73]]}}}],["pixi.simplerope(trailtexture",{"_index":391,"t":{"47":{"position":[[707,29]]}}}],["pixi.sprite(currenttexture",{"_index":2753,"t":{"207":{"position":[[549,28]]}}}],["pixi.sprite(gradtexture",{"_index":2698,"t":{"201":{"position":[[1981,25]]},"209":{"position":[[919,25]]}}}],["pixi.sprite(grasstexture",{"_index":2450,"t":{"177":{"position":[[323,26]]}}}],["pixi.sprite(loadscreenassets.egghead",{"_index":820,"t":{"59":{"position":[[1617,38]]}}}],["pixi.sprite(loadscreenassets.flowertop",{"_index":801,"t":{"59":{"position":[[940,40]]}}}],["pixi.sprite(pixi.texture.white",{"_index":136,"t":{"41":{"position":[[1990,32],[2310,32]]}}}],["pixi.sprite(rendertexture",{"_index":279,"t":{"43":{"position":[[846,27]]}}}],["pixi.sprite(rt",{"_index":2849,"t":{"244":{"position":[[638,16]]}}}],["pixi.sprite(slottextures[math.floor(math.random",{"_index":565,"t":{"53":{"position":[[1232,49]]}}}],["pixi.sprite(startexture",{"_index":452,"t":{"49":{"position":[[503,25]]}}}],["pixi.sprite(texture",{"_index":343,"t":{"45":{"position":[[680,21]]},"55":{"position":[[707,21]]},"67":{"position":[[399,21]]},"89":{"position":[[574,21]]},"177":{"position":[[842,21]]},"185":{"position":[[577,21]]},"189":{"position":[[393,21]]},"195":{"position":[[1353,21]]},"244":{"position":[[343,21]]}}}],["pixi.sprite(texturebutton",{"_index":1253,"t":{"81":{"position":[[1156,27]]},"83":{"position":[[820,27]]}}}],["pixi.sprite(textures[i",{"_index":2836,"t":{"211":{"position":[[1296,22]]}}}],["pixi.sprite(yellowstar",{"_index":1356,"t":{"87":{"position":[[273,24],[594,24],[1137,24],[1727,24]]}}}],["pixi.sprite.from('https://pixijs.com/assets/bg_button.jpg",{"_index":1235,"t":{"81":{"position":[[507,60]]},"83":{"position":[[171,60]]}}}],["pixi.sprite.from('https://pixijs.com/assets/bg_grass.jpg",{"_index":1480,"t":{"93":{"position":[[240,59]]},"99":{"position":[[172,59]]},"105":{"position":[[1414,59]]}}}],["pixi.sprite.from('https://pixijs.com/assets/bg_plane.jpg",{"_index":2227,"t":{"157":{"position":[[169,59]]}}}],["pixi.sprite.from('https://pixijs.com/assets/bg_rotate.jpg",{"_index":884,"t":{"65":{"position":[[179,60]]},"69":{"position":[[571,60]]},"107":{"position":[[169,60]]},"147":{"position":[[186,60]]},"149":{"position":[[158,60]]}}}],["pixi.sprite.from('https://pixijs.com/assets/bg_scene_rotate.jpg",{"_index":961,"t":{"69":{"position":[[432,66],[3324,66],[4405,66]]},"107":{"position":[[491,66]]},"147":{"position":[[505,66]]}}}],["pixi.sprite.from('https://pixijs.com/assets/bunny.png",{"_index":1167,"t":{"75":{"position":[[272,56]]},"77":{"position":[[203,56]]},"187":{"position":[[205,56]]}}}],["pixi.sprite.from('https://pixijs.com/assets/cells.png",{"_index":2229,"t":{"157":{"position":[[267,56]]}}}],["pixi.sprite.from('https://pixijs.com/assets/circle.png",{"_index":1012,"t":{"69":{"position":[[2507,57]]}}}],["pixi.sprite.from('https://pixijs.com/assets/egghead.png",{"_index":1151,"t":{"73":{"position":[[335,58]]}}}],["pixi.sprite.from('https://pixijs.com/assets/flowertop.png",{"_index":896,"t":{"65":{"position":[[583,60]]},"157":{"position":[[359,60]]}}}],["pixi.sprite.from('https://pixijs.com/assets/light_rotate_1.png",{"_index":1961,"t":{"107":{"position":[[760,65]]},"147":{"position":[[717,65]]}}}],["pixi.sprite.from('https://pixijs.com/assets/light_rotate_2.png",{"_index":1957,"t":{"107":{"position":[[627,65]]},"147":{"position":[[612,65]]}}}],["pixi.sprite.from('https://pixijs.com/assets/maggot.png",{"_index":1904,"t":{"105":{"position":[[439,57]]}}}],["pixi.sprite.from('https://pixijs.com/assets/maggot_tiny.png",{"_index":1208,"t":{"79":{"position":[[495,62]]}}}],["pixi.sprite.from('https://pixijs.com/assets/panda.png",{"_index":1965,"t":{"107":{"position":[[892,56]]},"147":{"position":[[821,56]]}}}],["pixi.sprite.from('https://pixijs.com/assets/pixi",{"_index":1704,"t":{"101":{"position":[[137,48],[319,48],[520,48]]},"105":{"position":[[908,48],[1264,48]]},"151":{"position":[[242,48],[392,48]]}}}],["pixi.sprite.from(framename",{"_index":859,"t":{"63":{"position":[[827,28]]}}}],["pixi.sprite.from(fruits[i",{"_index":2776,"t":{"207":{"position":[[1438,25]]}}}],["pixi.sprite.from(resolvedtexture",{"_index":835,"t":{"61":{"position":[[442,34]]}}}],["pixi.sprite.from(texture",{"_index":522,"t":{"51":{"position":[[372,26]]}}}],["pixi.sprite.from(textures.egghead",{"_index":781,"t":{"57":{"position":[[838,35]]}}}],["pixi.sprite.from(textures.flowertop",{"_index":774,"t":{"57":{"position":[[666,37]]}}}],["pixi.text",{"_index":1296,"t":{"85":{"position":[[262,10],[501,13]]},"103":{"position":[[5313,10]]},"199":{"position":[[782,10]]}}}],["pixi.text('basic",{"_index":2702,"t":{"203":{"position":[[171,16]]}}}],["pixi.text('chachicle.ttf",{"_index":2740,"t":{"205":{"position":[[566,26]]}}}],["pixi.text('click",{"_index":366,"t":{"45":{"position":[[1143,16]]},"107":{"position":[[1218,16]]},"147":{"position":[[1338,16]]}}}],["pixi.text('crosterian.woff2",{"_index":2743,"t":{"205":{"position":[[900,29]]}}}],["pixi.text('dotrice",{"_index":2742,"t":{"205":{"position":[[778,18]]}}}],["pixi.text('drag",{"_index":1547,"t":{"95":{"position":[[1216,15]]}}}],["pixi.text('hit",{"_index":1410,"t":{"87":{"position":[[2508,14]]}}}],["pixi.text('lineal.otf",{"_index":2741,"t":{"205":{"position":[[675,23]]}}}],["pixi.text('mask",{"_index":1417,"t":{"87":{"position":[[2617,17],[2722,15]]}}}],["pixi.text('pixi",{"_index":628,"t":{"53":{"position":[[2719,15]]}}}],["pixi.text('pixijs",{"_index":1586,"t":{"97":{"position":[[536,19]]}}}],["pixi.text('rich",{"_index":2709,"t":{"203":{"position":[[662,15]]}}}],["pixi.text('skew",{"_index":2720,"t":{"203":{"position":[[1140,15]]}}}],["pixi.text('spin",{"_index":617,"t":{"53":{"position":[[2464,15]]}}}],["pixi.text('standard",{"_index":1403,"t":{"87":{"position":[[2399,21]]}}}],["pixi.text(`rotate",{"_index":2839,"t":{"211":{"position":[[1530,17]]}}}],["pixi.textstyle",{"_index":360,"t":{"45":{"position":[[1059,16]]},"53":{"position":[[2111,16]]},"87":{"position":[[2344,16]]},"203":{"position":[[290,16],[828,16]]},"205":{"position":[[597,16],[703,16],[816,16],[934,16]]}}}],["pixi.texture(gradbasetexture",{"_index":2697,"t":{"201":{"position":[[1931,30]]}}}],["pixi.texture(texture.basetexture",{"_index":2821,"t":{"211":{"position":[[672,33],[878,33]]}}}],["pixi.texture.from('https://pixijs.com/assets/bg_displacement.jpg",{"_index":2268,"t":{"163":{"position":[[1305,67]]}}}],["pixi.texture.from('https://pixijs.com/assets/bg_rotate.jpg",{"_index":2266,"t":{"163":{"position":[[1152,61]]}}}],["pixi.texture.from('https://pixijs.com/assets/bg_scene_rotate.jpg",{"_index":2199,"t":{"153":{"position":[[968,67]]},"161":{"position":[[1360,67]]},"163":{"position":[[993,67]]},"167":{"position":[[842,67],[1519,67]]},"173":{"position":[[1171,66]]},"179":{"position":[[1036,67]]}}}],["pixi.texture.from('https://pixijs.com/assets/bunny.png",{"_index":324,"t":{"45":{"position":[[167,57]]},"67":{"position":[[260,57]]},"89":{"position":[[204,57]]},"185":{"position":[[438,57]]},"244":{"position":[[236,57]]}}}],["pixi.texture.from('https://pixijs.com/assets/button.png",{"_index":1237,"t":{"81":{"position":[[771,58]]},"83":{"position":[[435,58]]}}}],["pixi.texture.from('https://pixijs.com/assets/button_down.png",{"_index":1239,"t":{"81":{"position":[[856,63]]},"83":{"position":[[520,63]]}}}],["pixi.texture.from('https://pixijs.com/assets/button_over.png",{"_index":1241,"t":{"81":{"position":[[946,63]]},"83":{"position":[[610,63]]}}}],["pixi.texture.from('https://pixijs.com/assets/egghead.png",{"_index":544,"t":{"53":{"position":[[538,59]]},"189":{"position":[[270,59]]}}}],["pixi.texture.from('https://pixijs.com/assets/flowertop.png",{"_index":545,"t":{"53":{"position":[[598,61]]},"189":{"position":[[186,61]]}}}],["pixi.texture.from('https://pixijs.com/assets/helmlok.png",{"_index":546,"t":{"53":{"position":[[660,59]]}}}],["pixi.texture.from('https://pixijs.com/assets/p2.jpeg",{"_index":2531,"t":{"193":{"position":[[181,55]]}}}],["pixi.texture.from('https://pixijs.com/assets/perlin.jpg",{"_index":2246,"t":{"159":{"position":[[2426,58]]},"165":{"position":[[936,58]]}}}],["pixi.texture.from('https://pixijs.com/assets/skully.png",{"_index":547,"t":{"53":{"position":[[720,58]]}}}],["pixi.texture.from('https://pixijs.com/assets/star.png",{"_index":441,"t":{"49":{"position":[[175,56]]}}}],["pixi.texture.from('https://pixijs.com/assets/trail.png",{"_index":377,"t":{"47":{"position":[[199,57]]}}}],["pixi.texture.from('https://pixijs.com/assets/video.mp4",{"_index":2573,"t":{"195":{"position":[[1203,57]]}}}],["pixi.texture.from('https://pixijs.com/assets/yellowstar.png",{"_index":1353,"t":{"87":{"position":[[160,62]]}}}],["pixi.texture.from(`explosion_sequence_a",{"_index":2494,"t":{"183":{"position":[[344,39]]}}}],["pixi.texture.from(canvas",{"_index":2805,"t":{"209":{"position":[[830,26]]}}}],["pixi.texture.from(framekey",{"_index":2471,"t":{"181":{"position":[[394,28]]}}}],["pixi.tilingsprite",{"_index":2537,"t":{"193":{"position":[[400,18]]}}}],["pixi.types.float",{"_index":2215,"t":{"155":{"position":[[479,17],[598,17]]}}}],["pixi.wrap_modes.repeat",{"_index":1676,"t":{"97":{"position":[[2699,23]]},"151":{"position":[[567,23]]},"159":{"position":[[2587,23]]}}}],["pixi/graphics",{"_index":1730,"t":{"103":{"position":[[40,15]]},"111":{"position":[[40,15]]}}}],["pixijs",{"_index":1,"t":{"17":{"position":[[15,6],[121,7]]},"199":{"position":[[793,7]]},"201":{"position":[[36,6],[1232,6]]}}}],["place",{"_index":1848,"t":{"103":{"position":[[3691,5]]}}}],["plane",{"_index":1137,"t":{"71":{"position":[[234,5]]},"97":{"position":[[1118,5]]},"159":{"position":[[1037,5]]}}}],["plane.geometry.getbuffer('avertexposition",{"_index":1144,"t":{"71":{"position":[[394,44]]}}}],["plane.x",{"_index":1139,"t":{"71":{"position":[[281,7]]}}}],["plane.y",{"_index":1140,"t":{"71":{"position":[[296,7]]}}}],["platforms",{"_index":2555,"t":{"195":{"position":[[740,10]]}}}],["play",{"_index":592,"t":{"53":{"position":[[2083,4]]},"195":{"position":[[156,4]]}}}],["playing",{"_index":646,"t":{"53":{"position":[[3146,8]]},"195":{"position":[[688,7]]}}}],["playtext",{"_index":616,"t":{"53":{"position":[[2449,8]]}}}],["playtext.height",{"_index":624,"t":{"53":{"position":[[2627,16]]}}}],["playtext.width",{"_index":621,"t":{"53":{"position":[[2542,15]]}}}],["playtext.x",{"_index":619,"t":{"53":{"position":[[2502,10]]}}}],["playtext.y",{"_index":622,"t":{"53":{"position":[[2564,10]]}}}],["please",{"_index":1573,"t":{"97":{"position":[[39,6]]}}}],["point",{"_index":207,"t":{"41":{"position":[[3976,5]]},"43":{"position":[[1512,5]]},"51":{"position":[[429,5]]},"61":{"position":[[507,5]]},"69":{"position":[[982,6],[1839,5],[5490,6],[8604,5]]},"73":{"position":[[412,5],[521,5]]},"77":{"position":[[290,5]]},"79":{"position":[[576,5]]},"87":{"position":[[723,5]]},"89":{"position":[[875,5]]},"187":{"position":[[292,5]]},"189":{"position":[[444,5]]}}}],["point.y",{"_index":1817,"t":{"103":{"position":[[2433,9]]}}}],["pointer",{"_index":213,"t":{"41":{"position":[[4164,7],[4568,7]]},"53":{"position":[[3034,10]]},"55":{"position":[[880,10]]},"59":{"position":[[1145,10],[1820,10]]},"75":{"position":[[541,10]]},"83":{"position":[[1025,10],[1094,8]]},"87":{"position":[[354,10],[896,10],[1219,10],[2135,10]]},"89":{"position":[[835,10],[1019,7]]},"91":{"position":[[80,7],[668,7]]},"95":{"position":[[706,10],[1974,8]]},"189":{"position":[[710,10]]},"195":{"position":[[588,10]]}}}],["pointerdown",{"_index":284,"t":{"43":{"position":[[1080,12]]},"103":{"position":[[1695,14]]}}}],["pointerdown(event",{"_index":319,"t":{"43":{"position":[[1875,18]]}}}],["pointerenter",{"_index":1300,"t":{"85":{"position":[[332,13],[1407,14]]}}}],["pointerleave",{"_index":1301,"t":{"85":{"position":[[346,13],[1434,15]]}}}],["pointermove",{"_index":289,"t":{"43":{"position":[[1175,13],[1247,13]]},"95":{"position":[[1483,11]]},"103":{"position":[[1723,14],[4055,11]]}}}],["pointermove(event",{"_index":321,"t":{"43":{"position":[[1913,19]]}}}],["pointerout",{"_index":1303,"t":{"85":{"position":[[373,10]]},"103":{"position":[[1753,13]]}}}],["pointerover",{"_index":1302,"t":{"85":{"position":[[360,12]]},"103":{"position":[[1738,14]]}}}],["pointers",{"_index":1177,"t":{"75":{"position":[[555,8]]}}}],["pointerup",{"_index":286,"t":{"43":{"position":[[1110,10],[1145,10]]},"103":{"position":[[1710,12]]}}}],["pointerup(event",{"_index":322,"t":{"43":{"position":[[1944,16]]}}}],["points",{"_index":124,"t":{"41":{"position":[[1802,6]]},"43":{"position":[[303,6]]},"47":{"position":[[458,6],[589,7],[737,8],[1316,6]]},"169":{"position":[[187,6],[373,8]]},"258":{"position":[[193,6],[379,8]]}}}],["points.length",{"_index":2425,"t":{"169":{"position":[[617,14],[893,14],[973,14]]},"258":{"position":[[678,14]]}}}],["points.push(new",{"_index":390,"t":{"47":{"position":[[634,15]]},"169":{"position":[[231,15]]},"258":{"position":[[237,15]]}}}],["points[0].y",{"_index":2435,"t":{"169":{"position":[[859,13]]}}}],["points[i",{"_index":407,"t":{"47":{"position":[[1398,10]]}}}],["points[i].x",{"_index":2428,"t":{"169":{"position":[[687,11]]},"258":{"position":[[748,11]]}}}],["points[i].y",{"_index":2426,"t":{"169":{"position":[[639,11],[937,13],[1044,12]]},"258":{"position":[[700,11]]}}}],["polyfill",{"_index":2560,"t":{"195":{"position":[[824,8]]}}}],["polygon",{"_index":2067,"t":{"111":{"position":[[2230,7]]}}}],["pops",{"_index":198,"t":{"41":{"position":[[3481,4],[3508,4]]}}}],["position",{"_index":491,"t":{"49":{"position":[[1495,8]]},"53":{"position":[[1020,9],[1672,8],[3423,11]]},"65":{"position":[[792,11]]},"69":{"position":[[301,10],[378,9],[2279,10],[2356,9],[3193,10],[3270,9],[4234,10],[4311,9],[7412,10],[7489,9]]},"73":{"position":[[647,10],[1658,8]]},"75":{"position":[[348,8]]},"79":{"position":[[191,9],[1691,8]]},"89":{"position":[[1116,8]]},"95":{"position":[[1826,8],[1956,8],[2148,8]]},"151":{"position":[[940,8]]},"195":{"position":[[383,8]]},"197":{"position":[[723,9]]},"207":{"position":[[1357,8]]},"244":{"position":[[972,8]]}}}],["positions",{"_index":464,"t":{"49":{"position":[[825,9]]},"53":{"position":[[3975,9]]},"65":{"position":[[1806,9]]},"71":{"position":[[368,10],[531,9]]}}}],["positionsize",{"_index":2209,"t":{"155":{"position":[[276,12],[388,13],[458,13],[501,13],[620,13],[652,13],[752,13]]}}}],["possible",{"_index":2302,"t":{"165":{"position":[[1592,9]]}}}],["power",{"_index":2535,"t":{"193":{"position":[[359,5]]}}}],["precision",{"_index":1488,"t":{"93":{"position":[[468,9],[633,9],[667,9]]},"153":{"position":[[525,9],[818,10]]},"155":{"position":[[1005,9],[1310,10]]},"159":{"position":[[516,9],[886,9]]},"161":{"position":[[917,9],[1210,10]]},"163":{"position":[[466,9],[759,10]]},"165":{"position":[[567,9],[1054,9],[1980,9],[2784,9],[3387,9],[4399,9]]},"167":{"position":[[400,9],[693,10],[949,9],[1242,10]]},"171":{"position":[[262,9],[502,10]]},"173":{"position":[[590,9],[966,9]]},"175":{"position":[[484,9],[785,10]]},"179":{"position":[[497,9],[812,9]]}}}],["preferably",{"_index":2534,"t":{"193":{"position":[[343,10]]}}}],["prepare",{"_index":251,"t":{"43":{"position":[[129,7]]}}}],["prerounded",{"_index":1044,"t":{"69":{"position":[[4551,10]]}}}],["pressed",{"_index":1554,"t":{"95":{"position":[[1519,8]]}}}],["prevent",{"_index":411,"t":{"47":{"position":[[1457,7]]},"85":{"position":[[1517,7]]}}}],["previous",{"_index":307,"t":{"43":{"position":[[1497,8]]}}}],["previousposition",{"_index":555,"t":{"53":{"position":[[1033,17]]}}}],["prevy",{"_index":675,"t":{"53":{"position":[[4069,5],[4170,5]]}}}],["product",{"_index":681,"t":{"53":{"position":[[4259,7],[4643,8]]}}}],["program",{"_index":2259,"t":{"163":{"position":[[436,7]]}}}],["project",{"_index":1737,"t":{"103":{"position":[[201,7]]}}}],["projection",{"_index":494,"t":{"49":{"position":[[1529,10]]},"103":{"position":[[406,11],[946,10],[2468,10],[3835,10]]}}}],["projectionmatrix",{"_index":2191,"t":{"153":{"position":[[648,17]]},"155":{"position":[[1141,17]]},"159":{"position":[[639,17]]},"161":{"position":[[1040,17]]},"163":{"position":[[589,17]]},"165":{"position":[[690,17]]},"167":{"position":[[523,17],[1072,17]]},"171":{"position":[[364,17]]},"173":{"position":[[736,17]]},"175":{"position":[[609,17]]},"179":{"position":[[620,17]]}}}],["projectionsystem",{"_index":1821,"t":{"103":{"position":[[2528,16]]}}}],["projectionsystem.transform",{"_index":1825,"t":{"103":{"position":[[2620,26],[2649,26]]}}}],["projectionsystem.transform.append(this.worldtransform",{"_index":1827,"t":{"103":{"position":[[2757,55]]}}}],["projectionsystem.transform.copyfrom(this.originaltransform",{"_index":1831,"t":{"103":{"position":[[2938,60]]}}}],["projectionsystem.transform.copyto(this.originaltransform",{"_index":1826,"t":{"103":{"position":[[2698,58]]}}}],["projectionsystem.update(null",{"_index":1828,"t":{"103":{"position":[[2813,29],[2999,29]]}}}],["projector",{"_index":1740,"t":{"103":{"position":[[369,9],[566,10],[752,9],[3282,9],[3298,9],[3333,13],[3779,9]]}}}],["projector.content.addchild",{"_index":1839,"t":{"103":{"position":[[3371,27]]}}}],["projector.content.addchild(...stars",{"_index":1853,"t":{"103":{"position":[[3789,37]]}}}],["projector.content.addeventlistener('pointermove",{"_index":1890,"t":{"103":{"position":[[5053,49]]}}}],["projector.content.eventmode",{"_index":1862,"t":{"103":{"position":[[4126,27]]}}}],["projector.content.hitarea",{"_index":1858,"t":{"103":{"position":[[3897,25],[4099,26]]}}}],["projector.hitarea",{"_index":1861,"t":{"103":{"position":[[4079,17]]}}}],["projector.x",{"_index":1856,"t":{"103":{"position":[[3859,11]]}}}],["projector.y",{"_index":1857,"t":{"103":{"position":[[3878,11]]}}}],["promise",{"_index":760,"t":{"55":{"position":[[996,7]]},"57":{"position":[[355,7],[518,7]]},"59":{"position":[[767,7],[1444,7]]},"61":{"position":[[190,7],[290,7]]}}}],["promise<{flowertop",{"_index":769,"t":{"57":{"position":[[458,19]]}}}],["propagate",{"_index":1734,"t":{"103":{"position":[[126,9],[613,9],[1633,9]]}}}],["proper",{"_index":484,"t":{"49":{"position":[[1252,6]]},"53":{"position":[[4252,6],[4609,6]]}}}],["properties",{"_index":907,"t":{"65":{"position":[[1073,10]]},"73":{"position":[[804,10]]},"197":{"position":[[671,10]]}}}],["property",{"_index":698,"t":{"53":{"position":[[4698,9],[4778,9]]}}}],["propertybeginvalue",{"_index":703,"t":{"53":{"position":[[4788,19]]}}}],["pure",{"_index":1576,"t":{"97":{"position":[[98,4]]},"201":{"position":[[1183,4]]}}}],["push",{"_index":63,"t":{"41":{"position":[[446,4]]},"65":{"position":[[1374,4]]},"73":{"position":[[1227,4]]},"79":{"position":[[1235,4]]}}}],["quad",{"_index":2200,"t":{"153":{"position":[[1046,4]]},"159":{"position":[[2682,5],[2761,4]]},"161":{"position":[[1438,4]]},"179":{"position":[[1189,4]]}}}],["quad.position.set(400",{"_index":2202,"t":{"153":{"position":[[1086,22]]},"159":{"position":[[2801,22]]},"161":{"position":[[1479,22]]},"179":{"position":[[1229,22]]}}}],["quad.rotation",{"_index":2205,"t":{"153":{"position":[[1188,13]]},"161":{"position":[[1581,13]]},"179":{"position":[[1391,13]]}}}],["quad.scale.set(2",{"_index":2203,"t":{"153":{"position":[[1115,18]]},"159":{"position":[[2830,18]]},"161":{"position":[[1508,18]]},"179":{"position":[[1258,18]]}}}],["quad.scale.set(number(math.cos(time",{"_index":2253,"t":{"159":{"position":[[2992,37]]}}}],["quad.shader.uniforms.time",{"_index":2252,"t":{"159":{"position":[[2958,25]]},"179":{"position":[[1414,25]]}}}],["quality",{"_index":2801,"t":{"209":{"position":[[352,7],[391,7],[470,8],[617,8],[810,8]]}}}],["r",{"_index":648,"t":{"53":{"position":[[3262,1],[3716,1]]},"173":{"position":[[368,2],[388,2],[409,2]]},"175":{"position":[[368,2],[388,2],[409,2]]}}}],["r.blur.blury",{"_index":669,"t":{"53":{"position":[[3871,12]]}}}],["r.position",{"_index":653,"t":{"53":{"position":[[3336,10],[3886,11],[3946,11],[4088,12]]}}}],["r.previousposition",{"_index":670,"t":{"53":{"position":[[3900,19],[3925,18]]}}}],["r.symbols.length",{"_index":672,"t":{"53":{"position":[[4014,17],[4108,17]]}}}],["r.symbols[j",{"_index":674,"t":{"53":{"position":[[4049,13]]}}}],["rabbit",{"_index":1195,"t":{"77":{"position":[[514,6]]},"187":{"position":[[550,6]]}}}],["radial",{"_index":465,"t":{"49":{"position":[[840,6]]},"69":{"position":[[215,6],[3131,6]]}}}],["radians",{"_index":1156,"t":{"73":{"position":[[876,8]]},"79":{"position":[[902,7]]}}}],["radius",{"_index":1030,"t":{"69":{"position":[[3783,6],[3830,7],[3872,7],[4025,7]]},"177":{"position":[[135,6],[162,6],[545,6],[564,7],[682,7],[707,7]]}}}],["random",{"_index":466,"t":{"49":{"position":[[847,6]]},"65":{"position":[[675,6],[785,6],[1284,6]]},"73":{"position":[[490,6],[640,6],[856,6],[1137,6]]},"79":{"position":[[882,6],[1085,6]]},"109":{"position":[[1456,6]]}}}],["randomize",{"_index":1146,"t":{"71":{"position":[[509,9]]}}}],["randomizestar(star",{"_index":457,"t":{"49":{"position":[[606,19],[695,19],[1459,20]]}}}],["randomly",{"_index":2773,"t":{"207":{"position":[[1348,8]]}}}],["rate",{"_index":668,"t":{"53":{"position":[[3865,5]]}}}],["raydir",{"_index":1650,"t":{"97":{"position":[[2039,6],[2203,6],[2453,7]]},"159":{"position":[[1887,6],[2051,6],[2301,7]]}}}],["raymarch",{"_index":1655,"t":{"97":{"position":[[2114,8]]},"159":{"position":[[1962,8]]}}}],["rc",{"_index":551,"t":{"53":{"position":[[899,2],[1003,3]]}}}],["rc.addchild(symbol",{"_index":578,"t":{"53":{"position":[[1561,20]]}}}],["rc.filters",{"_index":560,"t":{"53":{"position":[[1136,10]]}}}],["rc.x",{"_index":552,"t":{"53":{"position":[[926,4]]}}}],["rd",{"_index":1622,"t":{"97":{"position":[[1464,3],[1675,2]]},"159":{"position":[[1331,3],[1542,2]]}}}],["reach",{"_index":816,"t":{"59":{"position":[[1378,5]]}}}],["read",{"_index":2368,"t":{"165":{"position":[[4541,6]]}}}],["reading",{"_index":36,"t":{"41":{"position":[[103,8]]}}}],["real",{"_index":486,"t":{"49":{"position":[[1289,5]]},"53":{"position":[[4638,4]]},"97":{"position":[[768,4]]}}}],["really",{"_index":493,"t":{"49":{"position":[[1515,6]]},"97":{"position":[[1129,6],[2310,6]]},"159":{"position":[[1048,6],[2158,6]]}}}],["realpath",{"_index":2085,"t":{"149":{"position":[[308,8]]}}}],["realpath.linestyle(2",{"_index":2086,"t":{"149":{"position":[[340,21]]}}}],["realpath.lineto(100",{"_index":2088,"t":{"149":{"position":[[399,20]]}}}],["realpath.lineto(200",{"_index":2089,"t":{"149":{"position":[[426,20]]}}}],["realpath.lineto(240",{"_index":2090,"t":{"149":{"position":[[453,20]]}}}],["realpath.moveto(0",{"_index":2087,"t":{"149":{"position":[[376,18]]}}}],["realpath.position.x",{"_index":2091,"t":{"149":{"position":[[480,19]]}}}],["realpath.position.y",{"_index":2092,"t":{"149":{"position":[[506,19]]}}}],["realpath2",{"_index":2101,"t":{"149":{"position":[[792,9]]}}}],["realpath2.linestyle(2",{"_index":2102,"t":{"149":{"position":[[825,22]]}}}],["realpath2.lineto(0",{"_index":2104,"t":{"149":{"position":[[886,19]]}}}],["realpath2.lineto(150",{"_index":2105,"t":{"149":{"position":[[913,21]]}}}],["realpath2.lineto(240",{"_index":2106,"t":{"149":{"position":[[941,21]]}}}],["realpath2.moveto(0",{"_index":2103,"t":{"149":{"position":[[862,19]]}}}],["realpath2.position.x",{"_index":2107,"t":{"149":{"position":[[969,20]]}}}],["realpath2.position.y",{"_index":2108,"t":{"149":{"position":[[997,20]]}}}],["reason",{"_index":1455,"t":{"89":{"position":[[1557,6]]}}}],["received",{"_index":1338,"t":{"85":{"position":[[1309,8]]}}}],["rectandhole",{"_index":2134,"t":{"149":{"position":[[1821,11]]}}}],["rectandhole.beginfill(0x00ff00",{"_index":2135,"t":{"149":{"position":[[1856,32]]}}}],["rectandhole.beginhole",{"_index":2137,"t":{"149":{"position":[[1931,24]]}}}],["rectandhole.drawcircle(375",{"_index":2138,"t":{"149":{"position":[[1956,27]]}}}],["rectandhole.drawcircle(425",{"_index":2140,"t":{"149":{"position":[[1994,27]]}}}],["rectandhole.drawcircle(475",{"_index":2142,"t":{"149":{"position":[[2032,27]]}}}],["rectandhole.drawrect(350",{"_index":2136,"t":{"149":{"position":[[1889,25]]}}}],["rectandhole.endfill",{"_index":2145,"t":{"149":{"position":[[2093,22]]}}}],["rectandhole.endhole",{"_index":2144,"t":{"149":{"position":[[2070,22]]}}}],["rectangle",{"_index":1038,"t":{"69":{"position":[[4157,9],[7319,9],[7737,9]]},"109":{"position":[[944,9]]},"111":{"position":[[216,9],[316,9],[468,9],[621,9],[1662,9]]}}}],["rectangle.drawroundedrect(0",{"_index":1087,"t":{"69":{"position":[[7807,28]]}}}],["rectangle.endfill",{"_index":1089,"t":{"69":{"position":[[7854,20]]}}}],["rectangle.linestyle(2",{"_index":1086,"t":{"69":{"position":[[7770,22]]}}}],["rectangle.mask",{"_index":1090,"t":{"69":{"position":[[7875,14]]}}}],["red",{"_index":56,"t":{"41":{"position":[[374,3],[3956,3],[4183,3],[4580,3],[4778,3]]},"201":{"position":[[934,7]]},"209":{"position":[[732,7]]}}}],["redraw",{"_index":994,"t":{"69":{"position":[[1851,6],[3883,6],[6839,6]]}}}],["redspeed",{"_index":230,"t":{"41":{"position":[[4694,8],[4842,9],[4877,9]]}}}],["redsquare",{"_index":150,"t":{"41":{"position":[[2294,9],[4957,11],[5137,11]]}}}],["redsquare.acceleration",{"_index":157,"t":{"41":{"position":[[2447,22]]}}}],["redsquare.acceleration.set",{"_index":231,"t":{"41":{"position":[[4789,27],[5201,27]]}}}],["redsquare.acceleration.set(redsquare.acceleration.x",{"_index":185,"t":{"41":{"position":[[2896,51]]}}}],["redsquare.acceleration.x",{"_index":247,"t":{"41":{"position":[[5538,24]]}}}],["redsquare.acceleration.y",{"_index":187,"t":{"41":{"position":[[2956,24],[5587,24]]}}}],["redsquare.height",{"_index":154,"t":{"41":{"position":[[2396,16],[4083,17]]}}}],["redsquare.mass",{"_index":158,"t":{"41":{"position":[[2491,14],[5358,16],[5395,16]]}}}],["redsquare.position.set(0",{"_index":151,"t":{"41":{"position":[[2343,25]]}}}],["redsquare.tint",{"_index":155,"t":{"41":{"position":[[2420,14]]}}}],["redsquare.width",{"_index":153,"t":{"41":{"position":[[2373,15],[4044,16]]}}}],["redsquare.x",{"_index":209,"t":{"41":{"position":[[4030,11],[5523,11]]}}}],["redsquare.y",{"_index":211,"t":{"41":{"position":[[4069,11],[5572,11]]}}}],["redsquarecenterposition",{"_index":208,"t":{"41":{"position":[[3988,23],[4660,24]]}}}],["redsquarecenterposition.x",{"_index":215,"t":{"41":{"position":[[4251,26]]}}}],["redsquarecenterposition.y",{"_index":216,"t":{"41":{"position":[[4294,26]]}}}],["reducing",{"_index":181,"t":{"41":{"position":[[2827,8]]}}}],["reel",{"_index":554,"t":{"53":{"position":[[983,4],[3988,5],[4299,5]]}}}],["reel.blur",{"_index":561,"t":{"53":{"position":[[1149,12]]}}}],["reel.blur.blurx",{"_index":558,"t":{"53":{"position":[[1094,15]]}}}],["reel.blur.blury",{"_index":559,"t":{"53":{"position":[[1115,15]]}}}],["reel.symbols.push(symbol",{"_index":577,"t":{"53":{"position":[[1534,26]]}}}],["reel_width",{"_index":533,"t":{"53":{"position":[[364,10],[937,11],[1827,10]]}}}],["reelcontainer",{"_index":550,"t":{"53":{"position":[[825,13],[1681,13]]}}}],["reelcontainer.addchild(rc",{"_index":553,"t":{"53":{"position":[[949,27]]}}}],["reelcontainer.x",{"_index":586,"t":{"53":{"position":[[1779,15]]}}}],["reelcontainer.y",{"_index":585,"t":{"53":{"position":[[1753,15]]}}}],["reels",{"_index":549,"t":{"53":{"position":[[795,5],[807,5],[3524,5]]}}}],["reels.length",{"_index":647,"t":{"53":{"position":[[3235,13],[3475,12],[3689,13]]}}}],["reels.push(reel",{"_index":579,"t":{"53":{"position":[[1584,17]]}}}],["reels[i",{"_index":649,"t":{"53":{"position":[[3266,9],[3720,9]]}}}],["reelscomplete",{"_index":659,"t":{"53":{"position":[[3494,13],[3553,15]]}}}],["reference",{"_index":888,"t":{"65":{"position":[[378,9]]},"89":{"position":[[1528,9]]}}}],["regular",{"_index":2734,"t":{"205":{"position":[[351,9],[854,9]]}}}],["regular.woff",{"_index":2736,"t":{"205":{"position":[[411,14],[797,14]]}}}],["related",{"_index":1291,"t":{"85":{"position":[[80,7]]}}}],["released",{"_index":1558,"t":{"95":{"position":[[1683,9]]}}}],["remove",{"_index":708,"t":{"53":{"position":[[5036,6]]},"103":{"position":[[1495,6]]}}}],["remove.length",{"_index":724,"t":{"53":{"position":[[5397,14]]}}}],["remove.push(t",{"_index":723,"t":{"53":{"position":[[5357,15]]}}}],["render",{"_index":1818,"t":{"103":{"position":[[2448,6]]},"165":{"position":[[5700,6]]},"195":{"position":[[789,6],[931,6]]},"207":{"position":[[215,6],[492,6],[2084,6]]}}}],["render(renderer",{"_index":1819,"t":{"103":{"position":[[2479,16]]}}}],["rendered",{"_index":1759,"t":{"103":{"position":[[842,8]]},"207":{"position":[[2171,8]]}}}],["renderer",{"_index":2678,"t":{"201":{"position":[[1305,9]]}}}],["renderer.batch.flush",{"_index":1820,"t":{"103":{"position":[[2498,23],[2914,23]]}}}],["renderer.projection",{"_index":1822,"t":{"103":{"position":[[2547,20]]}}}],["renderer.rendertexture",{"_index":1824,"t":{"103":{"position":[[2596,23]]}}}],["rendering",{"_index":1577,"t":{"97":{"position":[[120,9]]}}}],["renderpoints",{"_index":2430,"t":{"169":{"position":[[754,15],[783,14]]}}}],["renders",{"_index":1741,"t":{"103":{"position":[[379,7]]}}}],["rendertexture",{"_index":276,"t":{"43":{"position":[[760,13],[1354,14],[1720,14]]},"165":{"position":[[5767,14],[5832,14],[5898,14],[5962,14]]},"207":{"position":[[304,13],[440,14],[1848,14],[1863,13],[1964,14],[2213,14]]},"244":{"position":[[1100,14]]}}}],["rendertexture2",{"_index":2749,"t":{"207":{"position":[[362,14],[1879,15],[1895,14],[2228,15]]}}}],["rendertexturesprite",{"_index":278,"t":{"43":{"position":[[820,19],[895,20],[963,20]]}}}],["rendertexturesystem",{"_index":1823,"t":{"103":{"position":[[2574,19]]}}}],["rendertexturesystem.current",{"_index":1829,"t":{"103":{"position":[[2852,30],[3038,30]]}}}],["repeat",{"_index":2167,"t":{"151":{"position":[[997,6]]},"159":{"position":[[2510,6]]}}}],["replaced",{"_index":695,"t":{"53":{"position":[[4593,8]]},"69":{"position":[[4834,8]]}}}],["requestanimationframe(animate",{"_index":2465,"t":{"179":{"position":[[1331,31]]}}}],["require",{"_index":2565,"t":{"195":{"position":[[902,7]]}}}],["requirement",{"_index":2568,"t":{"195":{"position":[[1023,11]]}}}],["requires",{"_index":2532,"t":{"193":{"position":[[269,8]]}}}],["res.text",{"_index":1686,"t":{"99":{"position":[[471,11]]}}}],["reset",{"_index":2172,"t":{"151":{"position":[[1092,5]]},"157":{"position":[[555,8],[573,7],[809,8]]}}}],["resizeto",{"_index":49,"t":{"41":{"position":[[264,9]]},"43":{"position":[[68,9]]},"45":{"position":[[93,9]]},"47":{"position":[[91,9]]},"49":{"position":[[68,9]]},"51":{"position":[[91,9]]},"53":{"position":[[91,9]]},"55":{"position":[[91,9]]},"57":{"position":[[91,9]]},"59":{"position":[[91,9]]},"61":{"position":[[91,9]]},"63":{"position":[[68,9]]},"65":{"position":[[68,9]]},"67":{"position":[[91,9]]},"69":{"position":[[91,9]]},"71":{"position":[[91,9]]},"73":{"position":[[68,9]]},"75":{"position":[[91,9]]},"77":{"position":[[88,9]]},"79":{"position":[[68,9]]},"81":{"position":[[91,9]]},"83":{"position":[[68,9]]},"89":{"position":[[91,9]]},"93":{"position":[[136,9]]},"97":{"position":[[363,9]]},"99":{"position":[[68,9]]},"101":{"position":[[68,9]]},"105":{"position":[[68,9]]},"107":{"position":[[68,9]]},"109":{"position":[[85,9]]},"111":{"position":[[117,9]]},"147":{"position":[[85,9]]},"149":{"position":[[85,9]]},"151":{"position":[[68,9]]},"153":{"position":[[68,9]]},"155":{"position":[[68,9]]},"157":{"position":[[68,9]]},"159":{"position":[[68,9]]},"161":{"position":[[68,9]]},"163":{"position":[[68,9]]},"165":{"position":[[81,9]]},"167":{"position":[[68,9]]},"169":{"position":[[68,9]]},"171":{"position":[[68,9]]},"173":{"position":[[68,9]]},"175":{"position":[[68,9]]},"177":{"position":[[68,9]]},"179":{"position":[[68,9]]},"181":{"position":[[86,9]]},"183":{"position":[[86,9]]},"185":{"position":[[271,9]]},"187":{"position":[[91,9]]},"189":{"position":[[91,9]]},"191":{"position":[[91,9]]},"193":{"position":[[68,9]]},"195":{"position":[[88,9]]},"197":{"position":[[91,9]]},"199":{"position":[[91,9]]},"201":{"position":[[1569,9]]},"203":{"position":[[91,9]]},"205":{"position":[[91,9]]},"207":{"position":[[68,9]]},"209":{"position":[[223,9]]},"211":{"position":[[68,9]]},"244":{"position":[[91,9]]},"258":{"position":[[68,9]]}}}],["resizing",{"_index":2688,"t":{"201":{"position":[[1744,8]]}}}],["resolution",{"_index":2848,"t":{"244":{"position":[[600,11]]}}}],["resolved",{"_index":751,"t":{"55":{"position":[[661,8],[1016,8]]},"57":{"position":[[346,8],[626,8]]},"59":{"position":[[897,8],[1574,8]]},"61":{"position":[[404,8]]}}}],["resolves",{"_index":770,"t":{"57":{"position":[[526,9]]},"59":{"position":[[775,8],[1452,8]]},"61":{"position":[[298,9]]}}}],["resource",{"_index":1596,"t":{"97":{"position":[[872,9]]},"201":{"position":[[54,8],[1836,8]]}}}],["resources",{"_index":836,"t":{"63":{"position":[[146,9]]}}}],["respond",{"_index":1432,"t":{"89":{"position":[[659,7]]}}}],["result",{"_index":239,"t":{"41":{"position":[[5060,6]]}}}],["results",{"_index":90,"t":{"41":{"position":[[869,7]]}}}],["resume",{"_index":1701,"t":{"99":{"position":[[881,6]]}}}],["retain",{"_index":1163,"t":{"75":{"position":[[186,6]]}}}],["return",{"_index":80,"t":{"41":{"position":[[678,6],[1028,6],[1674,6],[1899,6]]},"47":{"position":[[1154,7],[1808,6],[1865,6],[2260,6]]},"53":{"position":[[3191,7],[4932,6],[5524,6],[5688,6]]},"69":{"position":[[881,6],[2794,6],[3626,6],[5388,6],[7982,6],[8631,6],[8901,6],[9033,6],[9283,6],[9302,6],[9429,6]]},"81":{"position":[[2123,7],[2234,7]]},"83":{"position":[[2218,7],[2329,7]]},"97":{"position":[[1387,6],[1685,6]]},"103":{"position":[[1934,6],[2393,6]]},"159":{"position":[[1257,6],[1552,6]]},"201":{"position":[[1500,6]]},"209":{"position":[[823,6]]}}}],["reverse",{"_index":192,"t":{"41":{"position":[[3160,7]]}}}],["reversed",{"_index":1061,"t":{"69":{"position":[[5109,8]]}}}],["rgba(255",{"_index":2658,"t":{"201":{"position":[[852,10]]},"209":{"position":[[650,10]]}}}],["richtext",{"_index":2708,"t":{"203":{"position":[[647,8]]}}}],["richtext.x",{"_index":2711,"t":{"203":{"position":[[741,10]]}}}],["richtext.y",{"_index":2712,"t":{"203":{"position":[[758,10]]}}}],["right",{"_index":832,"t":{"61":{"position":[[166,5]]},"69":{"position":[[1210,5],[1705,5],[1741,5],[5823,5],[6771,5],[6827,5]]},"97":{"position":[[1993,5],[2082,5]]},"159":{"position":[[1841,5],[1930,5]]},"197":{"position":[[576,5]]}}}],["ring",{"_index":1926,"t":{"105":{"position":[[1257,4]]}}}],["ring.anchor.set(0.5",{"_index":1928,"t":{"105":{"position":[[1333,21]]}}}],["ring.position.copyfrom(displacementsprite.position",{"_index":1940,"t":{"105":{"position":[[1794,52]]}}}],["ring.visible",{"_index":1929,"t":{"105":{"position":[[1355,12],[1685,12]]}}}],["ripple",{"_index":2311,"t":{"165":{"position":[[1944,7],[4568,6]]}}}],["ripplecontainer",{"_index":2323,"t":{"165":{"position":[[2633,15]]}}}],["ripplecontainer.addchild(ripplequad",{"_index":2324,"t":{"165":{"position":[[2673,37]]}}}],["ripplecontainer.position.set(220",{"_index":2379,"t":{"165":{"position":[[5014,33]]}}}],["ripplequad",{"_index":2322,"t":{"165":{"position":[[2575,10]]}}}],["ripplequad.shader.uniforms.phase",{"_index":2394,"t":{"165":{"position":[[5548,32]]}}}],["rippleshader",{"_index":2320,"t":{"165":{"position":[[2412,12],[2612,14]]}}}],["rippletexture",{"_index":2321,"t":{"165":{"position":[[2497,13],[4766,14],[5847,13]]}}}],["rippleuniforms",{"_index":2319,"t":{"165":{"position":[[2341,14],[2474,16]]}}}],["roboto",{"_index":362,"t":{"45":{"position":[[1088,9]]},"95":{"position":[[1306,9]]},"103":{"position":[[4780,9],[5524,9]]}}}],["roll",{"_index":1436,"t":{"89":{"position":[[784,4]]}}}],["root",{"_index":1758,"t":{"103":{"position":[[831,4]]}}}],["rope",{"_index":375,"t":{"47":{"position":[[172,5],[584,4],[685,4],[696,4]]},"169":{"position":[[152,5]]},"258":{"position":[[152,5]]}}}],["rope.blendmode",{"_index":393,"t":{"47":{"position":[[767,14]]}}}],["ropelength",{"_index":2412,"t":{"169":{"position":[[164,10],[262,11],[705,10]]},"258":{"position":[[164,10],[268,11],[766,10]]}}}],["ropesize",{"_index":385,"t":{"47":{"position":[[380,8],[436,8],[617,9],[1371,9],[1522,8],[1591,8]]}}}],["rotate",{"_index":876,"t":{"63":{"position":[[1277,6]]},"67":{"position":[[833,6]]},"77":{"position":[[504,6]]},"103":{"position":[[5449,6]]},"185":{"position":[[1011,6]]},"187":{"position":[[540,6]]},"207":{"position":[[1732,6]]},"211":{"position":[[295,6],[307,6],[320,9],[630,7],[725,8],[931,6]]}}}],["rotated",{"_index":2809,"t":{"211":{"position":[[216,7],[1263,7]]}}}],["rotatedtexture",{"_index":2820,"t":{"211":{"position":[[611,15],[651,14],[857,14]]}}}],["rotatedtexture.rotate",{"_index":2827,"t":{"211":{"position":[[944,24]]}}}],["rotation",{"_index":500,"t":{"49":{"position":[[1787,9]]},"79":{"position":[[207,9]]},"103":{"position":[[4351,8]]},"197":{"position":[[927,8]]}}}],["rotations",{"_index":2834,"t":{"211":{"position":[[1181,9]]}}}],["round",{"_index":2707,"t":{"203":{"position":[[628,8],[1085,8]]}}}],["rounded",{"_index":1037,"t":{"69":{"position":[[4149,7],[7311,7]]},"111":{"position":[[1654,7]]}}}],["roundingmask",{"_index":1046,"t":{"69":{"position":[[4598,12],[4799,13]]}}}],["roundingmask.beginfill(0",{"_index":1047,"t":{"69":{"position":[[4634,25]]}}}],["roundingmask.drawroundedrect(0",{"_index":1049,"t":{"69":{"position":[[4704,31]]}}}],["roundingmask.endfill",{"_index":1050,"t":{"69":{"position":[[4763,23]]}}}],["roundingmask.linestyle(1",{"_index":1048,"t":{"69":{"position":[[4664,25]]}}}],["rt",{"_index":2845,"t":{"244":{"position":[[506,2],[1115,2]]}}}],["rules",{"_index":1122,"t":{"69":{"position":[[8732,6]]}}}],["running",{"_index":644,"t":{"53":{"position":[[3108,7],[3181,9],[3199,7],[3571,7]]},"187":{"position":[[583,7]]}}}],["s",{"_index":673,"t":{"53":{"position":[[4045,1]]},"199":{"position":[[580,1],[658,3]]}}}],["s.parentnode.insertbefore(wf",{"_index":2626,"t":{"199":{"position":[[628,29]]}}}],["s.scale.x",{"_index":686,"t":{"53":{"position":[[4380,9]]}}}],["s.scale.y",{"_index":687,"t":{"53":{"position":[[4392,9]]}}}],["s.texture",{"_index":684,"t":{"53":{"position":[[4305,9]]}}}],["s.texture.height",{"_index":689,"t":{"53":{"position":[[4458,18]]}}}],["s.texture.width",{"_index":688,"t":{"53":{"position":[[4427,16]]}}}],["s.width",{"_index":691,"t":{"53":{"position":[[4509,8]]}}}],["s.x",{"_index":690,"t":{"53":{"position":[[4477,3]]}}}],["s.y",{"_index":676,"t":{"53":{"position":[[4077,4],[4082,3],[4158,4]]}}}],["same",{"_index":1058,"t":{"69":{"position":[[5067,4]]},"73":{"position":[[546,4]]},"93":{"position":[[567,4]]},"165":{"position":[[519,4]]}}}],["sampler2d",{"_index":1598,"t":{"97":{"position":[[991,9],[1019,9]]},"153":{"position":[[871,9]]},"159":{"position":[[938,9]]},"161":{"position":[[1263,9]]},"163":{"position":[[812,9]]},"165":{"position":[[2075,9],[2857,9],[4451,9],[4480,9],[4508,9]]},"167":{"position":[[746,9],[1295,9]]},"173":{"position":[[1039,9]]},"179":{"position":[[864,9]]}}}],["scale",{"_index":499,"t":{"49":{"position":[[1779,5],[2180,5]]},"53":{"position":[[1311,5]]},"65":{"position":[[682,5]]},"73":{"position":[[497,5]]},"75":{"position":[[152,5]]},"79":{"position":[[178,6]]},"89":{"position":[[265,5]]},"95":{"position":[[892,5],[1257,5],[1845,5]]}}}],["scalemode",{"_index":2846,"t":{"244":{"position":[[564,10]]}}}],["scales",{"_index":1019,"t":{"69":{"position":[[2890,6]]}}}],["scaling",{"_index":1006,"t":{"69":{"position":[[2213,7]]},"181":{"position":[[522,7]]}}}],["scatter",{"_index":1211,"t":{"79":{"position":[[728,7]]}}}],["scene",{"_index":1292,"t":{"85":{"position":[[102,6]]},"95":{"position":[[261,5]]},"97":{"position":[[160,5]]},"103":{"position":[[162,5],[452,5],[1084,6],[1680,5]]},"207":{"position":[[282,5]]}}}],["screen",{"_index":191,"t":{"41":{"position":[[3143,6],[3788,7]]},"51":{"position":[[498,6]]},"59":{"position":[[243,8],[355,8],[596,8],[611,10],[708,6],[855,9],[1354,6],[1393,6],[1532,9]]},"61":{"position":[[576,6]]},"77":{"position":[[359,6]]},"103":{"position":[[4027,6],[4845,6],[5175,6],[5273,11]]},"187":{"position":[[361,6]]},"189":{"position":[[517,6]]},"244":{"position":[[997,6]]}}}],["screen.height",{"_index":1568,"t":{"95":{"position":[[1998,13]]}}}],["screenpos",{"_index":1506,"t":{"93":{"position":[[827,9],[905,10]]}}}],["screenshot",{"_index":335,"t":{"45":{"position":[[456,13],[1168,12]]}}}],["screenshottext",{"_index":365,"t":{"45":{"position":[[1122,14]]}}}],["screenshottext.width",{"_index":370,"t":{"45":{"position":[[1239,21]]}}}],["screenshottext.x",{"_index":368,"t":{"45":{"position":[[1189,16]]}}}],["screenshottext.y",{"_index":371,"t":{"45":{"position":[[1267,16]]}}}],["script",{"_index":2614,"t":{"199":{"position":[[332,6]]}}}],["scroll",{"_index":1869,"t":{"103":{"position":[[4415,6],[4497,6]]}}}],["second",{"_index":1999,"t":{"109":{"position":[[672,6]]},"165":{"position":[[1898,6],[2714,6]]},"201":{"position":[[1071,6]]}}}],["seconds",{"_index":478,"t":{"49":{"position":[[1078,7]]}}}],["secondtexture",{"_index":2516,"t":{"189":{"position":[[254,13],[851,14]]}}}],["see",{"_index":1299,"t":{"85":{"position":[[315,3]]}}}],["seen",{"_index":2385,"t":{"165":{"position":[[5216,4]]}}}],["segment",{"_index":978,"t":{"69":{"position":[[1156,7],[1350,8],[1451,7],[5725,7],[6071,7],[6156,8],[6354,7]]}}}],["segment[0",{"_index":986,"t":{"69":{"position":[[1508,11],[6411,11]]}}}],["segment[1",{"_index":987,"t":{"69":{"position":[[1520,11],[6423,11]]}}}],["segment[2",{"_index":988,"t":{"69":{"position":[[1532,11],[6435,11]]}}}],["segment[3",{"_index":989,"t":{"69":{"position":[[1544,12],[6447,12]]}}}],["segments",{"_index":977,"t":{"69":{"position":[[1091,8],[5601,8],[5616,8],[8622,8],[9230,8]]}}}],["segments.length",{"_index":983,"t":{"69":{"position":[[1421,16],[6324,16]]}}}],["segments[i",{"_index":984,"t":{"69":{"position":[[1461,12],[6364,12]]}}}],["separately",{"_index":2386,"t":{"165":{"position":[[5221,11]]}}}],["set",{"_index":242,"t":{"41":{"position":[[5152,3]]},"47":{"position":[[749,3]]},"53":{"position":[[2966,3]]},"65":{"position":[[669,3],[761,3]]},"73":{"position":[[397,3],[484,3],[616,3]]},"75":{"position":[[332,3]]},"79":{"position":[[561,3]]},"81":{"position":[[1641,3]]},"83":{"position":[[1736,3]]},"95":{"position":[[1943,3]]},"99":{"position":[[764,3]]},"103":{"position":[[2016,3],[4294,3]]},"109":{"position":[[248,3],[558,3]]},"111":{"position":[[808,3]]},"207":{"position":[[1921,3]]}}}],["setinterval",{"_index":479,"t":{"49":{"position":[[1086,14]]}}}],["setup",{"_index":269,"t":{"43":{"position":[[528,7]]},"89":{"position":[[975,5]]},"103":{"position":[[99,5]]}}}],["shader",{"_index":1482,"t":{"93":{"position":[[422,6],[500,6],[536,6],[603,6]]},"97":{"position":[[103,6],[273,6],[757,7]]},"153":{"position":[[497,6],[1077,8]]},"155":{"position":[[977,6],[1449,8]]},"159":{"position":[[2667,6],[2694,6],[2792,8]]},"161":{"position":[[889,6],[1470,8]]},"165":{"position":[[507,7],[524,6]]},"167":{"position":[[372,6],[1632,8]]},"171":{"position":[[234,6],[630,8]]},"173":{"position":[[1247,6],[1349,8]]},"175":{"position":[[456,6],[927,8]]},"179":{"position":[[1122,6],[1220,8]]}}}],["shader2",{"_index":2403,"t":{"167":{"position":[[920,7],[1683,9]]}}}],["shaderfrag",{"_index":1496,"t":{"93":{"position":[[652,10],[1358,11]]}}}],["shaders",{"_index":2281,"t":{"165":{"position":[[905,8]]}}}],["shape",{"_index":1990,"t":{"109":{"position":[[351,5],[679,5],[1300,5]]},"111":{"position":[[1424,5]]},"147":{"position":[[1009,5]]}}}],["shaped",{"_index":2826,"t":{"211":{"position":[[798,6]]}}}],["sharing",{"_index":2300,"t":{"165":{"position":[[1561,7]]}}}],["sharp",{"_index":412,"t":{"47":{"position":[[1465,5]]}}}],["shorter",{"_index":1603,"t":{"97":{"position":[[1192,7]]},"159":{"position":[[1111,7]]}}}],["shoves",{"_index":94,"t":{"41":{"position":[[932,6]]}}}],["show",{"_index":2838,"t":{"211":{"position":[[1395,4]]}}}],["shows",{"_index":1173,"t":{"75":{"position":[[507,5]]},"103":{"position":[[81,5]]}}}],["silly",{"_index":1269,"t":{"81":{"position":[[1650,5]]},"83":{"position":[[1745,5]]}}}],["simple",{"_index":481,"t":{"49":{"position":[[1211,6],[1522,6]]},"53":{"position":[[4544,6]]},"97":{"position":[[1136,6]]},"159":{"position":[[1055,6]]},"165":{"position":[[1145,6],[2119,6],[3601,8]]}}}],["simplicity",{"_index":2303,"t":{"165":{"position":[[1613,10]]}}}],["sin",{"_index":1021,"t":{"69":{"position":[[2929,3],[2991,3],[3060,3],[3066,3]]},"179":{"position":[[962,4]]}}}],["sin(distance*25.0+phase",{"_index":2317,"t":{"165":{"position":[[2271,24]]}}}],["sin(time",{"_index":1519,"t":{"93":{"position":[[1072,10]]}}}],["size",{"_index":962,"t":{"69":{"position":[[505,4],[530,5],[550,5],[647,5],[669,5],[737,4],[1031,5],[1079,5],[1106,4],[1117,4],[1127,4],[1138,4],[1164,5],[1176,4],[1186,4],[1196,4],[1218,4],[1228,4],[1238,4],[1248,4],[1271,4],[1282,4],[1293,4],[1303,4],[1677,4],[1688,4],[1711,4],[1721,4],[1748,4],[1758,4],[1784,4],[1795,4],[1822,4],[1954,4],[2403,4],[2632,4],[2684,4],[2694,4],[2746,4],[3397,4],[3422,5],[3442,5],[3510,4],[4358,4],[4485,5],[4505,5],[4739,5],[4745,5],[4983,5],[4989,5],[5232,4],[5539,5],[5587,5],[5631,4],[5653,4],[5674,4],[5696,4],[5733,5],[5756,4],[5777,4],[5798,4],[5831,4],[5852,4],[5873,4],[5894,4],[5928,4],[5950,4],[5972,4],[5993,4],[6299,4],[6605,4],[6627,4],[6662,4],[6683,4],[6719,4],[6740,4],[6777,4],[6799,4],[6961,4]]},"73":{"position":[[551,5]]},"153":{"position":[[298,4],[424,4]]},"159":{"position":[[317,4],[443,4]]},"161":{"position":[[298,4],[424,4],[657,4],[777,4]]},"163":{"position":[[287,4],[408,4]]},"165":{"position":[[318,4],[444,4]]},"173":{"position":[[287,4],[427,4],[548,4]]},"175":{"position":[[287,4],[428,4]]},"179":{"position":[[298,4],[424,4]]},"193":{"position":[[331,4]]},"201":{"position":[[509,4],[1730,4]]}}}],["sizes",{"_index":1210,"t":{"79":{"position":[[676,5]]}}}],["skewstyle",{"_index":2714,"t":{"203":{"position":[[812,9],[1166,11]]}}}],["skewtext",{"_index":2719,"t":{"203":{"position":[[1125,8]]}}}],["skewtext.anchor.set(0.5",{"_index":2723,"t":{"203":{"position":[[1209,24]]}}}],["skewtext.skew.set(0.65",{"_index":2722,"t":{"203":{"position":[[1178,23]]}}}],["skewtext.x",{"_index":2724,"t":{"203":{"position":[[1240,10]]}}}],["skewtext.y",{"_index":2725,"t":{"203":{"position":[[1258,10]]}}}],["skipupdatetransform",{"_index":298,"t":{"43":{"position":[[1383,20],[1749,20]]}}}],["skully.png",{"_index":845,"t":{"63":{"position":[[365,13]]}}}],["slider",{"_index":1529,"t":{"95":{"position":[[311,6],[349,6],[927,6]]}}}],["slider.addchild(handle",{"_index":1543,"t":{"95":{"position":[[848,24]]}}}],["slider.height",{"_index":1538,"t":{"95":{"position":[[614,13]]}}}],["slider.tolocal(e.global).x",{"_index":1571,"t":{"95":{"position":[[2065,27]]}}}],["slider.x",{"_index":1533,"t":{"95":{"position":[[432,8]]}}}],["slider.y",{"_index":1534,"t":{"95":{"position":[[475,8]]}}}],["sliderwidth",{"_index":1530,"t":{"95":{"position":[[324,11],[415,12],[457,12],[644,11],[2093,11],[2202,12]]}}}],["slooww",{"_index":1213,"t":{"79":{"position":[[1135,6]]}}}],["slot",{"_index":541,"t":{"53":{"position":[[501,4]]}}}],["slots",{"_index":630,"t":{"53":{"position":[[2743,8],[3662,6]]}}}],["slottextures",{"_index":543,"t":{"53":{"position":[[521,12]]}}}],["slottextures.length",{"_index":566,"t":{"53":{"position":[[1284,23],[4357,22]]}}}],["slottextures[math.floor(math.random",{"_index":685,"t":{"53":{"position":[[4317,37]]}}}],["slow",{"_index":2474,"t":{"181":{"position":[[547,4],[573,4]]}}}],["slow.anchor.set(0.5",{"_index":2477,"t":{"181":{"position":[[615,21]]}}}],["slow.animationspeed",{"_index":2479,"t":{"181":{"position":[[662,19]]}}}],["slow.play",{"_index":2483,"t":{"181":{"position":[[767,12]]}}}],["slow.scale.set(scaling",{"_index":2478,"t":{"181":{"position":[[637,24]]}}}],["slow.width",{"_index":2481,"t":{"181":{"position":[[718,11]]}}}],["slow.x",{"_index":2480,"t":{"181":{"position":[[689,6]]}}}],["slow.y",{"_index":2482,"t":{"181":{"position":[[735,6]]}}}],["slowly",{"_index":1297,"t":{"85":{"position":[[290,6]]}}}],["small",{"_index":2343,"t":{"165":{"position":[[3642,5]]}}}],["smooth",{"_index":299,"t":{"43":{"position":[[1418,6]]},"47":{"position":[[404,6],[1412,6]]}}}],["snake",{"_index":2424,"t":{"169":{"position":[[591,5]]},"258":{"position":[[652,5]]}}}],["snakecontainer",{"_index":2860,"t":{"258":{"position":[[410,14]]}}}],["snakecontainer.addchild(strip",{"_index":2866,"t":{"258":{"position":[[571,31]]}}}],["snakecontainer.scale.set(800",{"_index":2863,"t":{"258":{"position":[[497,28]]}}}],["snakecontainer.x",{"_index":2861,"t":{"258":{"position":[[449,16]]}}}],["snakecontainer.y",{"_index":2862,"t":{"258":{"position":[[473,16]]}}}],["snippet",{"_index":2609,"t":{"199":{"position":[[239,12],[743,7],[824,9],[858,10]]}}}],["snippets",{"_index":9,"t":{"17":{"position":[[83,8]]}}}],["solve",{"_index":1749,"t":{"103":{"position":[[661,5]]}}}],["somehow",{"_index":2800,"t":{"209":{"position":[[328,7]]}}}],["somewhat",{"_index":30,"t":{"41":{"position":[[42,8]]}}}],["source",{"_index":894,"t":{"65":{"position":[[563,6]]},"73":{"position":[[315,6]]}}}],["spawn",{"_index":2693,"t":{"201":{"position":[[1850,5]]}}}],["specify",{"_index":1695,"t":{"99":{"position":[[719,7]]}}}],["speed",{"_index":115,"t":{"41":{"position":[[1515,5],[1635,5],[4478,5]]},"49":{"position":[[319,5],[1064,5],[1295,5],[1317,6],[1354,6],[2383,5]]},"53":{"position":[[3770,6]]},"65":{"position":[[1291,5]]},"73":{"position":[[1144,5]]},"79":{"position":[[1092,5]]}}}],["spends",{"_index":814,"t":{"59":{"position":[[1323,6]]}}}],["spicy",{"_index":32,"t":{"41":{"position":[[70,5]]}}}],["spinner",{"_index":956,"t":{"69":{"position":[[192,7],[2202,7],[3120,7],[4138,7],[7300,7],[7342,7],[8419,8]]}}}],["spinning",{"_index":2783,"t":{"207":{"position":[[1640,9]]}}}],["sprite",{"_index":21,"t":{"17":{"position":[[211,6],[227,6]]},"49":{"position":[[491,7]]},"51":{"position":[[319,6],[470,6]]},"55":{"position":[[645,6]]},"57":{"position":[[610,6]]},"59":{"position":[[881,6],[1558,6]]},"61":{"position":[[388,6],[548,6]]},"65":{"position":[[153,6],[501,6],[1006,6]]},"67":{"position":[[652,6]]},"73":{"position":[[253,6],[452,6]]},"75":{"position":[[263,6]]},"77":{"position":[[162,6],[331,6]]},"79":{"position":[[475,6],[615,6],[1015,6]]},"87":{"position":[[235,6],[692,7]]},"89":{"position":[[1091,6]]},"149":{"position":[[149,6]]},"151":{"position":[[497,6],[933,6]]},"185":{"position":[[830,6]]},"187":{"position":[[165,6],[333,6]]},"189":{"position":[[346,6],[489,6],[640,6]]},"193":{"position":[[256,6]]},"195":{"position":[[1277,6]]},"197":{"position":[[692,6]]},"201":{"position":[[1968,6]]},"207":{"position":[[471,6],[591,6]]},"209":{"position":[[906,6]]},"211":{"position":[[1250,6]]},"244":{"position":[[625,6]]}}}],["sprite's",{"_index":523,"t":{"51":{"position":[[413,8]]},"61":{"position":[[491,8]]},"77":{"position":[[274,8]]},"187":{"position":[[276,8]]}}}],["sprite.anchor.set(0.5",{"_index":1168,"t":{"75":{"position":[[357,23]]}}}],["sprite.cursor",{"_index":1176,"t":{"75":{"position":[[525,13]]}}}],["sprite.eventmode",{"_index":1172,"t":{"75":{"position":[[475,16]]}}}],["sprite.height",{"_index":2807,"t":{"209":{"position":[[1027,13]]}}}],["sprite.on('click",{"_index":1185,"t":{"75":{"position":[[706,18]]}}}],["sprite.on('pointerdown",{"_index":1182,"t":{"75":{"position":[[620,24]]}}}],["sprite.on('tap",{"_index":1186,"t":{"75":{"position":[[752,16]]}}}],["sprite.position.set(100",{"_index":2699,"t":{"201":{"position":[[2007,24]]},"209":{"position":[[945,24]]}}}],["sprite.rotation",{"_index":2700,"t":{"201":{"position":[[2038,15]]},"209":{"position":[[976,15]]}}}],["sprite.scale.x",{"_index":1188,"t":{"75":{"position":[[842,14]]}}}],["sprite.scale.y",{"_index":1190,"t":{"75":{"position":[[866,14]]}}}],["sprite.texture",{"_index":2112,"t":{"149":{"position":[[1140,14],[1699,14],[2273,14]]}}}],["sprite.width",{"_index":2806,"t":{"209":{"position":[[1007,12]]}}}],["sprite.x",{"_index":1169,"t":{"75":{"position":[[381,8]]},"244":{"position":[[655,8]]}}}],["sprite.y",{"_index":1170,"t":{"75":{"position":[[414,8]]},"244":{"position":[[671,8]]}}}],["sprites",{"_index":1197,"t":{"79":{"position":[[132,7],[316,7],[1666,7]]},"147":{"position":[[481,7]]},"189":{"position":[[429,7]]},"201":{"position":[[1757,7]]}}}],["sprites.addchild(dude",{"_index":1217,"t":{"79":{"position":[[1330,23]]}}}],["spritesheet",{"_index":2587,"t":{"197":{"position":[[396,11]]}}}],["spritesheet.data.frames[framekey].duration",{"_index":2472,"t":{"181":{"position":[[436,43]]}}}],["square",{"_index":57,"t":{"41":{"position":[[378,6],[1939,6],[2265,6],[3117,6],[3474,6],[4187,6],[4488,6],[4584,6],[4782,6],[5048,6]]},"69":{"position":[[203,6]]}}}],["square's",{"_index":205,"t":{"41":{"position":[[3960,8]]}}}],["squaremask",{"_index":1380,"t":{"87":{"position":[[1270,10],[1404,11],[2908,11]]}}}],["squaremask2",{"_index":1393,"t":{"87":{"position":[[1794,11],[1929,12],[2920,12]]}}}],["squares",{"_index":72,"t":{"41":{"position":[[555,7],[2810,8],[4906,7],[5193,7]]}}}],["srcs",{"_index":791,"t":{"59":{"position":[[283,5],[393,5]]}}}],["stage",{"_index":249,"t":{"41":{"position":[[5635,5]]},"63":{"position":[[531,5]]},"81":{"position":[[665,8],[1557,5]]},"83":{"position":[[329,8],[1652,5]]},"85":{"position":[[584,8],[1387,7]]},"87":{"position":[[2830,5]]},"89":{"position":[[1168,5]]},"95":{"position":[[238,5],[1498,5]]},"109":{"position":[[1442,5]]},"165":{"position":[[5185,5]]},"195":{"position":[[613,5]]},"207":{"position":[[682,5],[2095,5]]}}}],["stageheight",{"_index":1527,"t":{"95":{"position":[[155,11],[486,11],[1168,11]]}}}],["stagesize",{"_index":272,"t":{"43":{"position":[[582,9],[670,11],[742,11]]},"207":{"position":[[132,9]]}}}],["stagewidth",{"_index":1528,"t":{"95":{"position":[[194,10],[443,11],[1142,10],[1387,10]]}}}],["standard",{"_index":1354,"t":{"87":{"position":[[226,8]]}}}],["star",{"_index":439,"t":{"49":{"position":[[149,5],[482,4],[820,4],[871,4],[1420,4],[1487,4],[1774,4],[2112,4],[2190,4]]},"103":{"position":[[3553,4],[4247,4],[5408,6]]},"111":{"position":[[1821,4],[1956,4],[2093,4]]}}}],["star.addeventlistener('click",{"_index":1875,"t":{"103":{"position":[[4553,30]]}}}],["star.addeventlistener('wheel",{"_index":1868,"t":{"103":{"position":[[4369,30]]}}}],["star.cursor",{"_index":1866,"t":{"103":{"position":[[4313,11],[4641,11],[4695,11]]}}}],["star.eventmode",{"_index":1865,"t":{"103":{"position":[[4264,14]]}}}],["star.rotation",{"_index":1873,"t":{"103":{"position":[[4480,13]]}}}],["star.scale.set(1",{"_index":1878,"t":{"103":{"position":[[4676,18]]}}}],["star.scale.set(1.33",{"_index":1877,"t":{"103":{"position":[[4619,21]]}}}],["star.scale.x",{"_index":1876,"t":{"103":{"position":[[4596,13]]}}}],["star.sprite.anchor.x",{"_index":454,"t":{"49":{"position":[[550,20]]}}}],["star.sprite.anchor.y",{"_index":455,"t":{"49":{"position":[[578,20]]}}}],["star.sprite.rotation",{"_index":515,"t":{"49":{"position":[[2449,20]]}}}],["star.sprite.scale.x",{"_index":507,"t":{"49":{"position":[[2057,19]]}}}],["star.sprite.scale.y",{"_index":514,"t":{"49":{"position":[[2314,19]]}}}],["star.sprite.x",{"_index":495,"t":{"49":{"position":[[1568,13],[1814,13]]}}}],["star.sprite.y",{"_index":497,"t":{"49":{"position":[[1664,13],[1878,13]]}}}],["star.x",{"_index":472,"t":{"49":{"position":[[975,6],[1584,6]]}}}],["star.y",{"_index":474,"t":{"49":{"position":[[1010,6],[1680,6]]}}}],["star.z",{"_index":461,"t":{"49":{"position":[[726,6],[1440,7],[1550,6]]}}}],["staramount",{"_index":442,"t":{"49":{"position":[[238,10],[457,11],[1395,11]]}}}],["starbasesize",{"_index":450,"t":{"49":{"position":[[378,12],[2095,13],[2352,12]]}}}],["starbutton1",{"_index":1355,"t":{"87":{"position":[[255,11],[399,11],[439,12],[486,12],[531,13],[2869,12]]}}}],["starbutton1.cursor",{"_index":1358,"t":{"87":{"position":[[333,18]]}}}],["starbutton1.eventmode",{"_index":1359,"t":{"87":{"position":[[365,21]]}}}],["starbutton1.position.set(50",{"_index":1357,"t":{"87":{"position":[[298,28]]}}}],["starbutton1.x",{"_index":1405,"t":{"87":{"position":[[2439,13]]}}}],["starbutton1.y",{"_index":1407,"t":{"87":{"position":[[2469,13]]}}}],["starbutton2",{"_index":1363,"t":{"87":{"position":[[576,11],[941,11],[981,12],[1028,12],[1073,13],[2856,12]]}}}],["starbutton2.cursor",{"_index":1374,"t":{"87":{"position":[[875,18]]}}}],["starbutton2.eventmode",{"_index":1375,"t":{"87":{"position":[[907,21]]}}}],["starbutton2.hitarea",{"_index":1366,"t":{"87":{"position":[[745,19]]}}}],["starbutton2.position.set(250",{"_index":1364,"t":{"87":{"position":[[619,29]]}}}],["starbutton2.x",{"_index":1412,"t":{"87":{"position":[[2548,13]]}}}],["starbutton2.y",{"_index":1415,"t":{"87":{"position":[[2578,13]]}}}],["starbutton3",{"_index":1376,"t":{"87":{"position":[[1119,11],[1416,11],[1456,12],[1503,12],[1548,13],[2882,12]]}}}],["starbutton3.cursor",{"_index":1378,"t":{"87":{"position":[[1198,18]]}}}],["starbutton3.eventmode",{"_index":1379,"t":{"87":{"position":[[1230,21]]}}}],["starbutton3.mask",{"_index":1383,"t":{"87":{"position":[[1385,16]]}}}],["starbutton3.position.set(450",{"_index":1377,"t":{"87":{"position":[[1162,29]]}}}],["starbutton3.x",{"_index":1419,"t":{"87":{"position":[[2653,13]]}}}],["starbutton3.y",{"_index":1382,"t":{"87":{"position":[[1349,14],[2683,13]]}}}],["starbutton4",{"_index":1391,"t":{"87":{"position":[[1709,11],[2180,11],[2220,12],[2267,12],[2312,13],[2895,12]]}}}],["starbutton4.cursor",{"_index":1400,"t":{"87":{"position":[[2114,18]]}}}],["starbutton4.eventmode",{"_index":1401,"t":{"87":{"position":[[2146,21]]}}}],["starbutton4.hitarea",{"_index":1399,"t":{"87":{"position":[[1984,19]]}}}],["starbutton4.mask",{"_index":1396,"t":{"87":{"position":[[1910,16]]}}}],["starbutton4.position.set(600",{"_index":1392,"t":{"87":{"position":[[1752,29]]}}}],["starbutton4.x",{"_index":1423,"t":{"87":{"position":[[2769,13]]}}}],["starbutton4.y",{"_index":1395,"t":{"87":{"position":[[1874,14],[2799,13]]}}}],["stars",{"_index":451,"t":{"49":{"position":[[413,5],[425,5]]},"103":{"position":[[3573,5],[3701,5],[3766,5],[4174,5],[5440,5]]}}}],["stars.foreach((star",{"_index":1864,"t":{"103":{"position":[[4213,20]]}}}],["stars.push(star",{"_index":459,"t":{"49":{"position":[[666,17]]}}}],["stars[0].x",{"_index":1849,"t":{"103":{"position":[[3707,10]]}}}],["stars[1].x",{"_index":1850,"t":{"103":{"position":[[3723,10]]}}}],["stars[2].x",{"_index":1851,"t":{"103":{"position":[[3741,10]]}}}],["stars[i",{"_index":488,"t":{"49":{"position":[[1427,9]]}}}],["starstretch",{"_index":449,"t":{"49":{"position":[[355,11],[2391,11]]}}}],["start",{"_index":645,"t":{"53":{"position":[[3140,5],[4888,6]]},"61":{"position":[[152,5]]},"159":{"position":[[2878,5]]},"165":{"position":[[5412,5]]},"169":{"position":[[526,5]]},"179":{"position":[[1306,5]]},"181":{"position":[[1053,5]]},"183":{"position":[[864,5]]},"195":{"position":[[682,5]]}}}],["started",{"_index":11,"t":{"17":{"position":[[108,7]]}}}],["startexture",{"_index":440,"t":{"49":{"position":[[161,11]]}}}],["starting",{"_index":2606,"t":{"199":{"position":[[182,11]]}}}],["startplay",{"_index":643,"t":{"53":{"position":[[3087,12],[3164,11]]}}}],["static",{"_index":164,"t":{"41":{"position":[[2569,9]]},"43":{"position":[[1009,9]]},"45":{"position":[[544,9]]},"47":{"position":[[880,9]]},"53":{"position":[[3008,9]]},"55":{"position":[[851,9]]},"59":{"position":[[1119,9],[1794,9]]},"63":{"position":[[571,9]]},"75":{"position":[[494,9]]},"81":{"position":[[1360,9]]},"83":{"position":[[999,9]]},"85":{"position":[[1020,9],[1083,9],[1114,9]]},"87":{"position":[[389,9],[931,9],[1254,9],[2170,9]]},"89":{"position":[[711,9],[1248,9]]},"91":{"position":[[540,9]]},"93":{"position":[[1485,9]]},"95":{"position":[[680,9],[1575,9]]},"103":{"position":[[1884,9],[4156,9],[4281,9]]},"105":{"position":[[148,9]]},"107":{"position":[[148,9]]},"109":{"position":[[165,9]]},"147":{"position":[[165,9]]},"151":{"position":[[148,9]]},"157":{"position":[[148,9]]},"177":{"position":[[938,9]]},"189":{"position":[[681,9]]},"195":{"position":[[562,9]]}}}],["steeper",{"_index":1025,"t":{"69":{"position":[[3019,7]]}}}],["step(limit",{"_index":2330,"t":{"165":{"position":[[2936,11]]}}}],["stetch",{"_index":2577,"t":{"195":{"position":[[1378,6]]}}}],["still",{"_index":1387,"t":{"87":{"position":[[1624,5]]},"151":{"position":[[1032,5]]}}}],["stop",{"_index":1556,"t":{"95":{"position":[[1641,4]]},"99":{"position":[[343,4]]}}}],["store",{"_index":839,"t":{"63":{"position":[[264,5]]},"65":{"position":[[370,5]]},"73":{"position":[[139,5]]},"79":{"position":[[302,5]]},"89":{"position":[[1520,5]]},"103":{"position":[[927,5]]},"181":{"position":[[264,5]]},"183":{"position":[[245,5]]}}}],["straight",{"_index":1062,"t":{"69":{"position":[[5145,8]]}}}],["strength",{"_index":61,"t":{"41":{"position":[[422,8]]}}}],["stretchfactor",{"_index":513,"t":{"49":{"position":[[2241,13]]}}}],["strip",{"_index":2414,"t":{"169":{"position":[[287,5]]},"258":{"position":[[293,5]]}}}],["strip.x",{"_index":2416,"t":{"169":{"position":[[382,7],[476,8]]},"258":{"position":[[388,7]]}}}],["strip.y",{"_index":2417,"t":{"169":{"position":[[397,7],[491,8]]}}}],["stroke",{"_index":603,"t":{"53":{"position":[[2246,7]]},"203":{"position":[[425,7],[1019,7]]}}}],["strokethickness",{"_index":605,"t":{"53":{"position":[[2265,16]]},"203":{"position":[[444,16],[1094,16]]}}}],["stuff",{"_index":2774,"t":{"207":{"position":[[1378,5]]}}}],["stuffcontainer",{"_index":2758,"t":{"207":{"position":[[728,14]]}}}],["stuffcontainer.addchild(item",{"_index":2781,"t":{"207":{"position":[[1577,30]]}}}],["stuffcontainer.rotation",{"_index":2791,"t":{"207":{"position":[[1997,23]]}}}],["stuffcontainer.x",{"_index":2759,"t":{"207":{"position":[[767,16]]}}}],["stuffcontainer.y",{"_index":2760,"t":{"207":{"position":[[791,16]]}}}],["style",{"_index":359,"t":{"45":{"position":[[1047,5],[1181,7]]},"53":{"position":[[2099,5],[2494,7],[2752,7]]},"81":{"position":[[156,5]]},"87":{"position":[[2332,5],[2421,7],[2530,7],[2635,7],[2751,7]]},"109":{"position":[[268,5],[578,5]]},"111":{"position":[[333,5],[485,5],[977,5],[1126,5],[1277,5]]},"149":{"position":[[2168,5]]},"203":{"position":[[278,5],[733,7]]}}}],["styles",{"_index":1232,"t":{"81":{"position":[[347,6]]}}}],["super",{"_index":1757,"t":{"103":{"position":[[807,8]]}}}],["super(256",{"_index":2644,"t":{"201":{"position":[[414,10]]}}}],["super.updatetransform",{"_index":1834,"t":{"103":{"position":[[3143,24]]}}}],["supported!\\nwoo",{"_index":2525,"t":{"191":{"position":[[294,15]]}}}],["sure",{"_index":1472,"t":{"91":{"position":[[558,4]]},"95":{"position":[[233,4]]},"97":{"position":[[2624,4]]},"151":{"position":[[488,4],[1019,4]]},"159":{"position":[[2505,4]]}}}],["swap",{"_index":680,"t":{"53":{"position":[[4218,4]]},"189":{"position":[[793,4]]},"207":{"position":[[1814,4]]}}}],["symbol",{"_index":564,"t":{"53":{"position":[[1219,6],[1321,6],[1335,6],[3968,6]]}}}],["symbol.height",{"_index":574,"t":{"53":{"position":[[1461,15]]}}}],["symbol.scale.x",{"_index":570,"t":{"53":{"position":[[1376,14]]}}}],["symbol.scale.y",{"_index":571,"t":{"53":{"position":[[1393,14]]}}}],["symbol.width",{"_index":573,"t":{"53":{"position":[[1433,13],[1514,13]]}}}],["symbol.x",{"_index":575,"t":{"53":{"position":[[1477,8]]}}}],["symbol.y",{"_index":569,"t":{"53":{"position":[[1348,8]]}}}],["symbol_size",{"_index":535,"t":{"53":{"position":[[388,11],[1363,12],[1447,11],[1731,11],[2023,11],[4128,11],[4142,12],[4178,12],[4444,11]]}}}],["symbols",{"_index":542,"t":{"53":{"position":[[506,8],[1007,8],[1175,7]]}}}],["t",{"_index":429,"t":{"47":{"position":[[1975,2],[2215,1],[2234,1],[2238,2],[2252,1],[2313,2]]},"53":{"position":[[5099,1],[5519,2],[5541,2],[5551,2],[5695,3],[5705,1],[5709,1],[5729,1]]},"95":{"position":[[2181,1],[2250,4]]},"97":{"position":[[2150,1],[2199,1]]},"159":{"position":[[1998,1],[2047,1]]}}}],["t+=d.x*0.5;//jump",{"_index":1658,"t":{"97":{"position":[[2235,17]]},"159":{"position":[[2083,17]]}}}],["t.change",{"_index":719,"t":{"53":{"position":[[5250,10]]}}}],["t.change(t",{"_index":720,"t":{"53":{"position":[[5261,12]]}}}],["t.complete",{"_index":721,"t":{"53":{"position":[[5329,12]]}}}],["t.complete(t",{"_index":722,"t":{"53":{"position":[[5342,14]]}}}],["t.easing(phase",{"_index":718,"t":{"53":{"position":[[5229,17]]}}}],["t.object[t.property",{"_index":715,"t":{"53":{"position":[[5169,20],[5293,20]]}}}],["t.start",{"_index":713,"t":{"53":{"position":[[5149,8]]}}}],["t.target",{"_index":717,"t":{"53":{"position":[[5219,9],[5316,9]]}}}],["t.time",{"_index":714,"t":{"53":{"position":[[5160,8]]}}}],["t/150",{"_index":1668,"t":{"97":{"position":[[2469,7]]},"159":{"position":[[2317,7]]}}}],["t2",{"_index":433,"t":{"47":{"position":[[2229,2],[2256,3],[2281,2],[2308,2],[2340,3],[2359,3]]}}}],["t2']).then(setup",{"_index":268,"t":{"43":{"position":[[499,19]]}}}],["t3",{"_index":434,"t":{"47":{"position":[[2247,2],[2272,2],[2298,3],[2331,2],[2353,3]]}}}],["take",{"_index":367,"t":{"45":{"position":[[1163,4]]}}}],["takes",{"_index":2310,"t":{"165":{"position":[[1911,5]]}}}],["takescreenshot",{"_index":328,"t":{"45":{"position":[[285,16],[614,16]]}}}],["tangentfactor",{"_index":430,"t":{"47":{"position":[[1978,14],[1998,14],[2023,13],[2092,14],[2133,14]]}}}],["tap",{"_index":871,"t":{"63":{"position":[[1119,3]]},"107":{"position":[[1238,3]]},"147":{"position":[[1358,3]]}}}],["target",{"_index":652,"t":{"53":{"position":[[3327,6],[3435,7],[4708,7],[4826,7]]},"69":{"position":[[975,6],[5483,6]]},"85":{"position":[[399,9],[1332,7]]},"97":{"position":[[1821,6],[1918,6]]},"157":{"position":[[528,6]]},"159":{"position":[[1669,6],[1766,6]]}}}],["target.x",{"_index":2238,"t":{"157":{"position":[[583,8],[706,9],[792,9]]}}}],["target.y",{"_index":2239,"t":{"157":{"position":[[627,8],[743,9]]}}}],["targetname",{"_index":1333,"t":{"85":{"position":[[1173,10],[1343,17]]}}}],["temp",{"_index":2788,"t":{"207":{"position":[[1841,4],[1912,5]]}}}],["temporary",{"_index":1761,"t":{"103":{"position":[[907,9]]},"201":{"position":[[579,9]]}}}],["test",{"_index":68,"t":{"41":{"position":[[498,4]]}}}],["testforaabb(greensquare",{"_index":235,"t":{"41":{"position":[[4931,25]]}}}],["testforaabb(object1",{"_index":74,"t":{"41":{"position":[[572,20]]}}}],["testing",{"_index":934,"t":{"65":{"position":[[2098,7]]},"73":{"position":[[1943,7]]}}}],["teximage2d",{"_index":2634,"t":{"201":{"position":[[99,10]]}}}],["texin",{"_index":2313,"t":{"165":{"position":[[2085,6],[2383,6]]}}}],["texnoise",{"_index":2366,"t":{"165":{"position":[[4490,9],[4781,9]]}}}],["texripple",{"_index":2365,"t":{"165":{"position":[[4461,10],[4755,10]]}}}],["text",{"_index":23,"t":{"17":{"position":[[234,4]]},"53":{"position":[[2088,4],[2691,4]]},"97":{"position":[[525,4]]},"199":{"position":[[728,4],[801,4]]},"203":{"position":[[188,4],[678,4]]},"211":{"position":[[1519,4]]}}}],["text.anchor.set(0.5",{"_index":1587,"t":{"97":{"position":[[591,20]]}}}],["text.position.set(app.renderer.screen.width",{"_index":1588,"t":{"97":{"position":[[618,43]]}}}],["text.x",{"_index":2843,"t":{"211":{"position":[[1656,6]]}}}],["text.y",{"_index":2844,"t":{"211":{"position":[[1673,6]]}}}],["text/javascript",{"_index":2623,"t":{"199":{"position":[[536,18]]}}}],["text1",{"_index":1402,"t":{"87":{"position":[[2387,5],[2933,6]]},"205":{"position":[[554,5]]}}}],["text1.x",{"_index":1404,"t":{"87":{"position":[[2429,7]]}}}],["text1.y",{"_index":1406,"t":{"87":{"position":[[2459,7]]}}}],["text2",{"_index":1409,"t":{"87":{"position":[[2496,5],[2940,6]]},"205":{"position":[[663,5]]}}}],["text2.x",{"_index":1411,"t":{"87":{"position":[[2538,7]]}}}],["text2.y",{"_index":1414,"t":{"87":{"position":[[2568,7]]},"205":{"position":[[995,7]]}}}],["text3",{"_index":1416,"t":{"87":{"position":[[2605,5],[2947,6]]},"205":{"position":[[766,5]]}}}],["text3.x",{"_index":1418,"t":{"87":{"position":[[2643,7]]}}}],["text3.y",{"_index":1420,"t":{"87":{"position":[[2673,7]]},"205":{"position":[[1010,7]]}}}],["text4",{"_index":1421,"t":{"87":{"position":[[2710,5],[2954,6]]},"205":{"position":[[888,5]]}}}],["text4.x",{"_index":1422,"t":{"87":{"position":[[2759,7]]}}}],["text4.y",{"_index":1424,"t":{"87":{"position":[[2789,7]]},"205":{"position":[[1025,7]]}}}],["textsample",{"_index":2628,"t":{"199":{"position":[[765,10]]}}}],["textsample.position.set(50",{"_index":2630,"t":{"199":{"position":[[918,27]]}}}],["texture",{"_index":253,"t":{"43":{"position":[[144,8]]},"45":{"position":[[157,7]]},"47":{"position":[[160,7]]},"49":{"position":[[137,7]]},"51":{"position":[[230,7],[350,7]]},"53":{"position":[[4225,8]]},"55":{"position":[[599,7],[677,7]]},"57":{"position":[[478,8],[496,9],[548,8]]},"59":{"position":[[913,7],[1590,7]]},"61":{"position":[[320,8],[420,7]]},"67":{"position":[[236,7],[250,7]]},"73":{"position":[[425,7]]},"79":{"position":[[589,7]]},"89":{"position":[[161,7],[194,7]]},"97":{"position":[[185,8]]},"149":{"position":[[1131,8],[1690,8],[2160,7],[2264,8]]},"165":{"position":[[882,7],[1653,7]]},"177":{"position":[[739,7]]},"181":{"position":[[384,7],[496,8]]},"183":{"position":[[334,7]]},"185":{"position":[[414,7],[428,7]]},"189":{"position":[[176,7],[363,7],[802,7],[841,7]]},"193":{"position":[[138,7],[171,7],[280,8],[419,8]]},"195":{"position":[[1167,7],[1193,7],[1300,7]]},"201":{"position":[[46,7],[619,7]]},"207":{"position":[[499,7],[1933,7],[2108,7],[2141,7]]},"211":{"position":[[250,10],[506,8],[1271,7]]},"244":{"position":[[226,7]]}}}],["texture.basetexture.scalemode",{"_index":1428,"t":{"89":{"position":[[291,29]]}}}],["texture.frame.height",{"_index":2814,"t":{"211":{"position":[[388,21],[444,20]]}}}],["texture.frame.width",{"_index":2813,"t":{"211":{"position":[[366,19],[467,20]]}}}],["texture.frame.y",{"_index":2818,"t":{"211":{"position":[[564,16]]}}}],["texture2d(noise",{"_index":1610,"t":{"97":{"position":[[1293,16]]},"159":{"position":[[1212,16]]},"165":{"position":[[2902,16]]}}}],["texture2d(texin",{"_index":2315,"t":{"165":{"position":[[2236,16]]}}}],["texture2d(texnoise",{"_index":2370,"t":{"165":{"position":[[4618,19]]}}}],["texture2d(texripple",{"_index":2369,"t":{"165":{"position":[[4577,20]]}}}],["texture2d(texwave",{"_index":2372,"t":{"165":{"position":[[4657,18]]}}}],["texture2d(usampler",{"_index":1614,"t":{"97":{"position":[[1349,19]]}}}],["texture2d(usampler2",{"_index":2198,"t":{"153":{"position":[[921,20]]},"161":{"position":[[1313,20]]},"167":{"position":[[796,20],[1345,20]]},"173":{"position":[[1089,20]]},"179":{"position":[[934,20]]}}}],["texture2d(usamplertexture",{"_index":2262,"t":{"163":{"position":[[868,26]]}}}],["texturebutton",{"_index":1236,"t":{"81":{"position":[[755,13],[2039,14],[2259,14]]},"83":{"position":[[419,13],[2134,14],[2354,14]]}}}],["texturebuttondown",{"_index":1238,"t":{"81":{"position":[[836,17],[1880,18]]},"83":{"position":[[500,17],[1975,18]]}}}],["texturebuttonover",{"_index":1240,"t":{"81":{"position":[[926,17],[1996,18],[2148,18]]},"83":{"position":[[590,17],[2091,18],[2243,18]]}}}],["texturepromise",{"_index":833,"t":{"61":{"position":[[204,14]]}}}],["texturepromise.then((resolvedtexture",{"_index":834,"t":{"61":{"position":[[329,37]]}}}],["textures",{"_index":772,"t":{"57":{"position":[[642,8]]},"63":{"position":[[675,8]]},"75":{"position":[[171,9]]},"81":{"position":[[721,8]]},"83":{"position":[[385,8]]},"165":{"position":[[1569,8],[5725,9]]},"181":{"position":[[274,8],[289,8]]},"183":{"position":[[255,8]]},"197":{"position":[[255,8]]},"207":{"position":[[222,11],[248,8]]},"211":{"position":[[224,8],[239,8]]}}}],["textures.push",{"_index":2473,"t":{"181":{"position":[[480,15]]}}}],["textures.push(rotatedtexture",{"_index":2828,"t":{"211":{"position":[[971,30]]}}}],["texturespromise",{"_index":767,"t":{"57":{"position":[[390,15]]}}}],["texturespromise.then((textures",{"_index":771,"t":{"57":{"position":[[557,31]]}}}],["texwave",{"_index":2367,"t":{"165":{"position":[[4518,8],[4805,8]]}}}],["that'll",{"_index":1765,"t":{"103":{"position":[[1034,7]]}}}],["that's",{"_index":2675,"t":{"201":{"position":[[1202,6]]}}}],["the\\ncustom",{"_index":2629,"t":{"199":{"position":[[812,11]]}}}],["then((res",{"_index":1685,"t":{"99":{"position":[[456,11]]}}}],["then(onassetsloaded",{"_index":532,"t":{"53":{"position":[[333,24]]},"63":{"position":[[228,22]]}}}],["then(onloaded",{"_index":1687,"t":{"99":{"position":[[483,16]]}}}],["there's",{"_index":2169,"t":{"151":{"position":[[1024,7]]}}}],["thing",{"_index":2021,"t":{"109":{"position":[[1312,5]]},"147":{"position":[[1021,5],[1179,6],[1276,6]]}}}],["thing.beginfill(0x8bc5ff",{"_index":2081,"t":{"147":{"position":[[1775,25]]}}}],["thing.beginfill(0xffff00",{"_index":2031,"t":{"109":{"position":[[1894,25]]}}}],["thing.clear",{"_index":2029,"t":{"109":{"position":[[1845,14]]},"147":{"position":[[1760,14]]}}}],["thing.closepath",{"_index":2035,"t":{"109":{"position":[[2282,18]]}}}],["thing.linestyle(0",{"_index":2078,"t":{"147":{"position":[[1142,19]]}}}],["thing.linestyle(10",{"_index":2030,"t":{"109":{"position":[[1860,19]]}}}],["thing.lineto",{"_index":2034,"t":{"109":{"position":[[2139,13],[2210,13]]},"147":{"position":[[2020,13]]}}}],["thing.lineto(120",{"_index":2033,"t":{"109":{"position":[[1998,16],[2069,16]]},"147":{"position":[[1879,16],[1950,16]]}}}],["thing.moveto",{"_index":2032,"t":{"109":{"position":[[1926,13]]},"147":{"position":[[1807,13]]}}}],["thing.rotation",{"_index":2036,"t":{"109":{"position":[[2301,14]]},"147":{"position":[[2091,14]]}}}],["thing.x",{"_index":2023,"t":{"109":{"position":[[1368,7]]},"147":{"position":[[1077,7]]}}}],["thing.y",{"_index":2024,"t":{"109":{"position":[[1387,7]]},"147":{"position":[[1109,7]]}}}],["third",{"_index":2338,"t":{"165":{"position":[[3348,5]]}}}],["this._bounds.addframematrix",{"_index":1808,"t":{"103":{"position":[[2208,28]]}}}],["this.addeventlistener(event",{"_index":1791,"t":{"103":{"position":[[1799,28]]}}}],["this.alpha",{"_index":1278,"t":{"81":{"position":[[1899,10]]},"83":{"position":[[1994,10]]},"89":{"position":[[1683,10]]}}}],["this.boundary",{"_index":1767,"t":{"103":{"position":[[1091,13]]}}}],["this.boundary.copymousedata",{"_index":1775,"t":{"103":{"position":[[1223,27]]}}}],["this.boundary.cursor",{"_index":1795,"t":{"103":{"position":[[1941,21]]}}}],["this.boundary.hittest(point.x",{"_index":1816,"t":{"103":{"position":[[2400,32]]}}}],["this.boundary.hittest(to.global.x",{"_index":1786,"t":{"103":{"position":[[1578,34]]}}}],["this.boundary.mapevent(e",{"_index":1792,"t":{"103":{"position":[[1835,27]]}}}],["this.content",{"_index":1760,"t":{"103":{"position":[[867,12]]}}}],["this.content.disabletempparent(null",{"_index":1837,"t":{"103":{"position":[[3233,37]]}}}],["this.content.enabletempparent",{"_index":1835,"t":{"103":{"position":[[3168,32]]}}}],["this.content.getbounds",{"_index":1807,"t":{"103":{"position":[[2182,25]]}}}],["this.content.render(renderer",{"_index":1830,"t":{"103":{"position":[[2883,30]]}}}],["this.content.updatetransform",{"_index":1836,"t":{"103":{"position":[[3201,31]]}}}],["this.data",{"_index":1460,"t":{"89":{"position":[[1659,9]]}}}],["this.eventmode",{"_index":1793,"t":{"103":{"position":[[1867,14]]}}}],["this.isdown",{"_index":1276,"t":{"81":{"position":[[1845,11],[1941,11],[2107,13],[2218,13]]},"83":{"position":[[1940,11],[2036,11],[2202,13],[2313,13]]}}}],["this.isover",{"_index":1279,"t":{"81":{"position":[[1965,13],[2084,11],[2194,11]]},"83":{"position":[[2060,13],[2179,11],[2289,11]]}}}],["this.originaltransform",{"_index":1763,"t":{"103":{"position":[[968,22]]}}}],["this.texture",{"_index":1277,"t":{"81":{"position":[[1865,12],[1981,12],[2024,12],[2133,12],[2244,12]]},"83":{"position":[[1960,12],[2076,12],[2119,12],[2228,12],[2339,12]]}}}],["this.tint",{"_index":1425,"t":{"87":{"position":[[2985,9],[3036,9],[3086,9]]}}}],["this.worldtransform",{"_index":1809,"t":{"103":{"position":[[2237,20]]}}}],["this.worldtransform.applyinverse(to.global",{"_index":1780,"t":{"103":{"position":[[1430,43]]}}}],["through",{"_index":927,"t":{"65":{"position":[[1773,7]]},"73":{"position":[[1623,7]]},"79":{"position":[[1654,7]]},"103":{"position":[[1904,7],[2116,7],[2348,7]]}}}],["throw",{"_index":1801,"t":{"103":{"position":[[2036,5]]}}}],["tick",{"_index":1105,"t":{"69":{"position":[[8396,4]]},"79":{"position":[[1610,4],[2379,4]]}}}],["ticker",{"_index":1224,"t":{"79":{"position":[[2372,6]]}}}],["tiling",{"_index":20,"t":{"17":{"position":[[204,6]]},"193":{"position":[[249,6]]}}}],["tilingsprite",{"_index":2536,"t":{"193":{"position":[[381,12]]}}}],["tilingsprite.tileposition.x",{"_index":2541,"t":{"193":{"position":[[652,27]]}}}],["tilingsprite.tileposition.y",{"_index":2542,"t":{"193":{"position":[[686,27]]}}}],["tilingsprite.tilescale.x",{"_index":2539,"t":{"193":{"position":[[556,24]]}}}],["tilingsprite.tilescale.y",{"_index":2540,"t":{"193":{"position":[[604,24]]}}}],["time",{"_index":654,"t":{"53":{"position":[[3375,4],[3443,5],[3820,4],[4716,5],[4842,5]]},"59":{"position":[[1337,4],[1368,4]]},"65":{"position":[[1226,4]]},"73":{"position":[[1079,4]]},"79":{"position":[[1027,4]]},"93":{"position":[[802,5]]},"97":{"position":[[1050,5],[2821,5]]},"159":{"position":[[969,5],[2485,5],[2904,4],[2942,4],[2986,5]]},"165":{"position":[[3470,5],[4045,5],[5438,4],[5476,4],[5584,5],[5622,5]]},"179":{"position":[[899,5],[967,5],[1104,5]]},"181":{"position":[[429,4],[505,4]]},"201":{"position":[[1078,4]]}}}],["time*0.25)*amplitude",{"_index":2348,"t":{"165":{"position":[[3712,22]]}}}],["time+cos(time)+2",{"_index":1642,"t":{"97":{"position":[[1850,18]]},"159":{"position":[[1698,18]]}}}],["timer",{"_index":1145,"t":{"71":{"position":[[472,5],[685,8]]}}}],["title",{"_index":1294,"t":{"85":{"position":[[231,5]]},"95":{"position":[[1192,5],[1204,5]]}}}],["title.anchor.set(0.5",{"_index":1552,"t":{"95":{"position":[[1417,21]]}}}],["title.roundpixels",{"_index":1550,"t":{"95":{"position":[[1351,17]]}}}],["title.x",{"_index":1304,"t":{"85":{"position":[[432,7]]},"95":{"position":[[1377,7]]}}}],["title.y",{"_index":1551,"t":{"95":{"position":[[1403,7]]}}}],["to.global",{"_index":1781,"t":{"103":{"position":[[1474,11]]}}}],["to.global.y",{"_index":1787,"t":{"103":{"position":[[1613,13]]}}}],["to.target",{"_index":1785,"t":{"103":{"position":[[1566,9]]}}}],["todo",{"_index":1782,"t":{"103":{"position":[[1489,5]]}}}],["toggling",{"_index":749,"t":{"55":{"position":[[586,8]]}}}],["tomousedirection",{"_index":214,"t":{"41":{"position":[[4200,16]]}}}],["tomousedirection.x",{"_index":224,"t":{"41":{"position":[[4437,19]]}}}],["tomousedirection.y",{"_index":223,"t":{"41":{"position":[[4417,19]]}}}],["top",{"_index":581,"t":{"53":{"position":[[1648,3],[1850,3]]},"69":{"position":[[1152,3],[1701,3],[1808,3],[5721,3],[6651,3],[6823,3]]},"85":{"position":[[1265,3]]}}}],["top.addchild(headertext",{"_index":636,"t":{"53":{"position":[[2884,25]]}}}],["top.beginfill(0",{"_index":588,"t":{"53":{"position":[[1877,16]]}}}],["top.drawrect(0",{"_index":589,"t":{"53":{"position":[[1898,15]]}}}],["totaldudes",{"_index":891,"t":{"65":{"position":[[429,10],[466,11]]},"73":{"position":[[181,10],[218,11]]}}}],["totalsprites",{"_index":1203,"t":{"79":{"position":[[350,12],[438,13]]}}}],["totaltime",{"_index":1590,"t":{"97":{"position":[[730,9],[3006,10],[3017,9]]}}}],["touch",{"_index":870,"t":{"63":{"position":[[1113,5]]},"75":{"position":[[574,5],[689,5],[782,5]]},"83":{"position":[[1054,5],[1513,5]]},"89":{"position":[[680,5],[1000,5],[1650,5]]}}}],["towards",{"_index":509,"t":{"49":{"position":[[2128,7],[2161,7]]}}}],["track",{"_index":1458,"t":{"89":{"position":[[1612,5]]},"195":{"position":[[997,5]]},"201":{"position":[[1110,5]]}}}],["trail",{"_index":383,"t":{"47":{"position":[[338,5],[415,5]]}}}],["trailtexture",{"_index":376,"t":{"47":{"position":[[184,12]]}}}],["transform",{"_index":954,"t":{"67":{"position":[[896,9]]},"103":{"position":[[957,10],[3113,9]]},"185":{"position":[[1074,9]]}}}],["transformation",{"_index":2514,"t":{"187":{"position":[[640,14]]}}}],["transforms",{"_index":1742,"t":{"103":{"position":[[422,10]]}}}],["translationmatrix",{"_index":2190,"t":{"153":{"position":[[616,18],[751,17]]},"155":{"position":[[1109,18],[1245,17]]},"159":{"position":[[607,18],[742,17]]},"161":{"position":[[1008,18],[1143,17]]},"163":{"position":[[557,18],[692,17]]},"165":{"position":[[658,18],[793,17]]},"167":{"position":[[491,18],[626,17],[1040,18],[1175,17]]},"171":{"position":[[332,18],[435,17]]},"173":{"position":[[704,18],[877,17]]},"175":{"position":[[577,18],[718,17]]},"179":{"position":[[588,18],[723,17]]}}}],["travelling",{"_index":225,"t":{"41":{"position":[[4505,10]]}}}],["triangle",{"_index":2263,"t":{"163":{"position":[[914,8],[1567,10]]},"167":{"position":[[1597,8],[1837,10]]},"171":{"position":[[595,8]]},"173":{"position":[[1314,8]]},"175":{"position":[[892,8]]}}}],["triangle.position.set(400",{"_index":2269,"t":{"163":{"position":[[1378,26]]},"167":{"position":[[1693,26]]},"171":{"position":[[639,26]]},"173":{"position":[[1358,26]]},"175":{"position":[[936,26]]}}}],["triangle.rotation",{"_index":2275,"t":{"163":{"position":[[1606,17]]},"167":{"position":[[1876,17]]},"171":{"position":[[730,17]]},"173":{"position":[[1472,17]]},"175":{"position":[[1050,17]]}}}],["triangle.scale.set(2",{"_index":2270,"t":{"163":{"position":[[1411,22]]},"167":{"position":[[1726,22]]},"173":{"position":[[1391,22]]},"175":{"position":[[969,22]]}}}],["triangle2",{"_index":2265,"t":{"163":{"position":[[1072,9],[1556,10]]},"167":{"position":[[1647,9]]}}}],["triangle2.position.set(200",{"_index":2271,"t":{"163":{"position":[[1434,27]]}}}],["triangle2.position.set(500",{"_index":2409,"t":{"167":{"position":[[1749,27]]}}}],["triangle2.rotation",{"_index":2276,"t":{"163":{"position":[[1633,18]]},"167":{"position":[[1903,18]]}}}],["triangle2.scale.set(3",{"_index":2410,"t":{"167":{"position":[[1783,23]]}}}],["triangle3",{"_index":2267,"t":{"163":{"position":[[1225,9]]}}}],["triangle3.position.set(500",{"_index":2272,"t":{"163":{"position":[[1468,27]]}}}],["triangle3.rotation",{"_index":2277,"t":{"163":{"position":[[1661,18]]}}}],["triangle3.scale.set(3",{"_index":2273,"t":{"163":{"position":[[1502,23]]}}}],["triangles",{"_index":2223,"t":{"155":{"position":[[1413,9]]}}}],["triangles.position.set(400",{"_index":2224,"t":{"155":{"position":[[1458,27]]}}}],["triangles.rotation",{"_index":2226,"t":{"155":{"position":[[1551,18]]}}}],["trigger",{"_index":2543,"t":{"195":{"position":[[188,7]]}}}],["trim",{"_index":2819,"t":{"211":{"position":[[594,4],[719,5],[925,5]]}}}],["true",{"_index":320,"t":{"43":{"position":[[1907,5]]},"49":{"position":[[626,6]]},"53":{"position":[[2297,5],[2413,5],[3209,5]]},"55":{"position":[[623,5]]},"79":{"position":[[185,5],[201,5],[217,5],[228,5],[241,5]]},"81":{"position":[[1859,5],[2098,5]]},"83":{"position":[[1954,5],[2193,5]]},"85":{"position":[[155,5]]},"91":{"position":[[172,5]]},"95":{"position":[[79,5],[1371,5]]},"103":{"position":[[294,5]]},"105":{"position":[[1700,5]]},"107":{"position":[[1089,5]]},"109":{"position":[[79,5]]},"111":{"position":[[111,5]]},"147":{"position":[[79,5]]},"149":{"position":[[79,5]]},"155":{"position":[[236,5],[532,4],[666,4]]},"189":{"position":[[164,5]]},"199":{"position":[[566,7]]},"201":{"position":[[1507,5],[1563,5]]},"203":{"position":[[476,5],[592,5],[878,5]]},"207":{"position":[[2123,6]]},"209":{"position":[[217,5]]}}}],["turn",{"_index":1969,"t":{"107":{"position":[[1245,4]]},"147":{"position":[[1365,4]]}}}],["tween",{"_index":701,"t":{"53":{"position":[[4760,5],[4939,6]]}}}],["tweening",{"_index":693,"t":{"53":{"position":[[4551,8],[4616,8],[4658,8]]}}}],["tweening.length",{"_index":709,"t":{"53":{"position":[[5069,16]]}}}],["tweening.push(tween",{"_index":707,"t":{"53":{"position":[[4910,21]]}}}],["tweening.splice(tweening.indexof(remove[i",{"_index":725,"t":{"53":{"position":[[5419,44]]}}}],["tweening[i",{"_index":710,"t":{"53":{"position":[[5103,12]]}}}],["tweenjs",{"_index":732,"t":{"53":{"position":[[5581,8]]}}}],["tweento(object",{"_index":697,"t":{"53":{"position":[[4682,15]]}}}],["tweento(r",{"_index":657,"t":{"53":{"position":[[3412,10]]}}}],["twist",{"_index":2790,"t":{"207":{"position":[[1982,5]]}}}],["two",{"_index":65,"t":{"41":{"position":[[459,3],[541,3],[1792,3],[4902,3]]},"69":{"position":[[8613,3]]},"193":{"position":[[368,3]]},"207":{"position":[[211,3]]}}}],["type",{"_index":1331,"t":{"85":{"position":[[1152,4],[1318,7],[1398,4],[1425,4]]}}}],["u",{"_index":2182,"t":{"153":{"position":[[374,2],[388,2],[409,2]]},"159":{"position":[[393,2],[407,2],[428,2]]},"161":{"position":[[374,2],[388,2],[409,2],[733,2],[747,2],[762,2]]},"163":{"position":[[363,2],[377,2],[392,2]]},"165":{"position":[[394,2],[408,2],[429,2]]},"167":{"position":[[331,2],[345,2],[361,2]]},"173":{"position":[[503,2],[517,2],[532,2]]},"179":{"position":[[374,2],[388,2],[409,2]]}}}],["ua",{"_index":1133,"t":{"69":{"position":[[9055,2],[9242,3],[9253,2],[9382,2],[9413,2]]}}}],["ub",{"_index":1134,"t":{"69":{"position":[[9129,2],[9263,2],[9273,2]]}}}],["under",{"_index":2557,"t":{"195":{"position":[[776,5]]}}}],["underlying",{"_index":1517,"t":{"93":{"position":[[1023,10]]}}}],["uniform",{"_index":1494,"t":{"93":{"position":[[572,7],[718,7],[738,7],[762,7],[788,7]]},"97":{"position":[[983,7],[1011,7],[1036,7]]},"153":{"position":[[603,7],[635,7],[863,7]]},"155":{"position":[[1096,7],[1128,7]]},"159":{"position":[[594,7],[626,7],[930,7],[955,7]]},"161":{"position":[[995,7],[1027,7],[1255,7]]},"163":{"position":[[544,7],[576,7],[804,7]]},"165":{"position":[[645,7],[677,7],[1098,7],[2024,7],[2046,7],[2067,7],[2828,7],[2849,7],[3431,7],[3456,7],[4443,7],[4472,7],[4500,7]]},"167":{"position":[[478,7],[510,7],[738,7],[1027,7],[1059,7],[1287,7]]},"171":{"position":[[319,7],[351,7]]},"173":{"position":[[691,7],[723,7],[1031,7]]},"175":{"position":[[564,7],[596,7]]},"179":{"position":[[575,7],[607,7],[856,7],[885,7]]}}}],["uniforms",{"_index":1696,"t":{"99":{"position":[[727,8]]},"159":{"position":[[2406,8],[2744,10]]},"173":{"position":[[1147,8],[1297,10]]},"179":{"position":[[1012,8],[1172,10]]}}}],["uniforms.noise.basetexture.mipmap",{"_index":2249,"t":{"159":{"position":[[2611,33]]}}}],["uniforms.noise.basetexture.wrapmode",{"_index":2248,"t":{"159":{"position":[[2549,35]]}}}],["until",{"_index":812,"t":{"59":{"position":[[1283,5]]}}}],["up",{"_index":1645,"t":{"97":{"position":[[1938,2],[2019,3],[2069,3]]},"159":{"position":[[1786,2],[1867,3],[1917,3]]},"207":{"position":[[1993,3]]}}}],["update",{"_index":175,"t":{"41":{"position":[[2740,6],[3807,6]]},"47":{"position":[[1104,6],[1165,6],[1305,6]]},"49":{"position":[[1173,6]]},"53":{"position":[[3612,7],[3651,6],[3733,6],[3961,6],[4970,7]]},"65":{"position":[[1795,6]]},"67":{"position":[[795,6]]},"69":{"position":[[904,6],[2817,6],[2878,6],[3649,6],[5411,6],[8005,6],[8353,6]]},"71":{"position":[[461,6]]},"73":{"position":[[1645,6]]},"79":{"position":[[1678,6]]},"85":{"position":[[1624,6]]},"95":{"position":[[1806,6]]},"97":{"position":[[2947,7]]},"99":{"position":[[900,6]]},"151":{"position":[[970,6]]},"185":{"position":[[973,6]]},"187":{"position":[[482,6]]}}}],["updates",{"_index":1833,"t":{"103":{"position":[[3095,7]]}}}],["updatetransform",{"_index":1832,"t":{"103":{"position":[[3074,15],[3123,17]]}}}],["upload",{"_index":2636,"t":{"201":{"position":[[136,6],[1056,6]]}}}],["upload(renderer",{"_index":2645,"t":{"201":{"position":[[431,16]]}}}],["uploaded",{"_index":2649,"t":{"201":{"position":[[630,8]]}}}],["url",{"_index":34,"t":{"41":{"position":[[87,3]]},"45":{"position":[[322,3],[479,4]]}}}],["url(\\'https://pixijs.com/assets/bunny.png\\'),auto",{"_index":1228,"t":{"81":{"position":[[192,52]]}}}],["url(\\'https://pixijs.com/assets/bunny_saturated.png\\'),auto",{"_index":1230,"t":{"81":{"position":[[263,62]]}}}],["us/docs/web/api/canvasrenderingcontext2d/createlineargradient",{"_index":2797,"t":{"209":{"position":[[109,61]]}}}],["usampler",{"_index":1599,"t":{"97":{"position":[[1001,9]]}}}],["usampler2",{"_index":2197,"t":{"153":{"position":[[881,10],[957,10]]},"161":{"position":[[1273,10],[1349,10]]},"167":{"position":[[756,10],[831,10],[1305,10],[1508,10]]},"173":{"position":[[1049,10],[1160,10]]},"179":{"position":[[874,10],[1025,10]]}}}],["usamplertexture",{"_index":2261,"t":{"163":{"position":[[822,16],[976,16],[1135,16],[1288,16]]}}}],["use",{"_index":217,"t":{"41":{"position":[[4327,3]]},"67":{"position":[[858,3]]},"75":{"position":[[673,3]]},"83":{"position":[[1317,3],[1509,3]]},"97":{"position":[[773,3]]},"99":{"position":[[786,3]]},"103":{"position":[[2007,3]]},"165":{"position":[[515,3]]},"185":{"position":[[1036,3]]},"201":{"position":[[1098,3]]},"209":{"position":[[538,3]]}}}],["used",{"_index":485,"t":{"49":{"position":[[1280,4]]},"51":{"position":[[170,4]]},"65":{"position":[[1180,4]]},"73":{"position":[[1033,4]]},"79":{"position":[[979,4]]},"87":{"position":[[714,4]]},"97":{"position":[[144,4],[2298,4]]},"103":{"position":[[193,4]]},"159":{"position":[[2146,4],[2525,4]]},"195":{"position":[[180,4]]},"201":{"position":[[1116,4]]},"207":{"position":[[265,4],[1631,4]]}}}],["useful",{"_index":2554,"t":{"195":{"position":[[717,6]]}}}],["user",{"_index":813,"t":{"59":{"position":[[1318,4],[1894,4]]},"95":{"position":[[916,4]]}}}],["uses",{"_index":892,"t":{"65":{"position":[[513,4]]},"73":{"position":[[265,4]]},"93":{"position":[[543,4]]},"207":{"position":[[483,4]]},"209":{"position":[[46,4]]}}}],["using",{"_index":310,"t":{"43":{"position":[[1540,5]]},"63":{"position":[[790,5]]},"89":{"position":[[1006,5]]},"95":{"position":[[921,5]]},"103":{"position":[[400,5],[719,5]]},"185":{"position":[[86,5]]},"189":{"position":[[353,5]]},"195":{"position":[[1284,5]]},"199":{"position":[[733,5],[806,5]]},"211":{"position":[[1257,5]]}}}],["usseful",{"_index":2668,"t":{"201":{"position":[[1045,7]]}}}],["utility",{"_index":694,"t":{"53":{"position":[[4560,7]]}}}],["uv",{"_index":1636,"t":{"97":{"position":[[1716,2],[1764,2],[1773,2]]},"159":{"position":[[1583,2],[1612,2],[1621,2]]},"165":{"position":[[1167,2],[1216,2],[2137,2],[2206,2],[2253,4],[3499,2],[3548,2]]}}}],["uv.x",{"_index":1652,"t":{"97":{"position":[[2064,4]]},"159":{"position":[[1912,4]]}}}],["uv.x*0.25",{"_index":2347,"t":{"165":{"position":[[3701,10]]}}}],["uv.y",{"_index":1653,"t":{"97":{"position":[[2075,4]]},"159":{"position":[[1923,4]]}}}],["uvs",{"_index":1199,"t":{"79":{"position":[[223,4]]},"211":{"position":[[805,4]]}}}],["v",{"_index":2183,"t":{"153":{"position":[[377,1],[391,1],[412,1]]},"159":{"position":[[396,1],[410,1],[431,1]]},"161":{"position":[[377,1],[391,1],[412,1],[736,1],[750,1],[765,1]]},"163":{"position":[[366,1],[380,1],[395,1]]},"165":{"position":[[397,1],[411,1],[432,1]]},"167":{"position":[[334,1],[348,1],[364,1]]},"173":{"position":[[506,1],[520,1],[535,1]]},"179":{"position":[[377,1],[391,1],[412,1]]}}}],["v5",{"_index":1491,"t":{"93":{"position":[[518,2]]},"201":{"position":[[43,2]]}}}],["val",{"_index":2584,"t":{"197":{"position":[[339,3]]}}}],["value",{"_index":2166,"t":{"151":{"position":[[987,6]]}}}],["values",{"_index":400,"t":{"47":{"position":[[1182,6]]},"81":{"position":[[1656,9]]},"83":{"position":[[1751,9]]},"151":{"position":[[1134,6]]}}}],["variety",{"_index":6,"t":{"17":{"position":[[57,7]]}}}],["varying",{"_index":1499,"t":{"93":{"position":[[690,7]]},"97":{"position":[[955,7]]},"153":{"position":[[666,7],[844,7]]},"155":{"position":[[1159,7],[1336,7]]},"159":{"position":[[657,7],[911,7]]},"161":{"position":[[1058,7],[1236,7]]},"163":{"position":[[607,7],[785,7]]},"165":{"position":[[708,7],[1079,7],[2005,7],[2809,7],[3412,7],[4424,7]]},"167":{"position":[[541,7],[719,7],[1090,7],[1268,7]]},"173":{"position":[[754,7],[773,7],[991,7],[1012,7]]},"175":{"position":[[627,7],[811,7]]},"179":{"position":[[638,7],[837,7]]}}}],["vcol",{"_index":2220,"t":{"155":{"position":[[1172,5],[1192,4],[1349,5]]}}}],["vcollision",{"_index":99,"t":{"41":{"position":[[1062,10]]}}}],["vcollision.x",{"_index":108,"t":{"41":{"position":[[1313,12]]}}}],["vcollision.y",{"_index":109,"t":{"41":{"position":[[1338,12]]}}}],["vcollisionnorm",{"_index":107,"t":{"41":{"position":[[1280,14]]}}}],["vcollisionnorm.x",{"_index":117,"t":{"41":{"position":[[1545,16],[1707,17]]}}}],["vcollisionnorm.y",{"_index":119,"t":{"41":{"position":[[1586,17],[1735,17]]}}}],["vcolor",{"_index":2443,"t":{"173":{"position":[[786,7],[821,6],[1004,7]]},"175":{"position":[[640,7],[662,6],[824,7]]}}}],["vec2",{"_index":1500,"t":{"93":{"position":[[698,4],[726,4],[822,4]]},"97":{"position":[[963,4],[1211,4],[1470,4],[1481,5],[1711,4],[2217,4]]},"153":{"position":[[560,4],[592,4],[674,4],[852,4]]},"155":{"position":[[1040,4],[1062,4]]},"159":{"position":[[551,4],[583,4],[665,4],[919,4],[1130,4],[1337,4],[1348,5],[1578,4],[2065,4]]},"161":{"position":[[952,4],[984,4],[1066,4],[1244,4]]},"163":{"position":[[501,4],[533,4],[615,4],[793,4]]},"165":{"position":[[602,4],[634,4],[716,4],[1087,4],[1211,4],[1243,4],[2013,4],[2132,4],[2817,4],[3420,4],[3543,4],[4432,4]]},"167":{"position":[[435,4],[467,4],[549,4],[727,4],[984,4],[1016,4],[1098,4],[1276,4]]},"171":{"position":[[297,4]]},"173":{"position":[[625,4],[680,4],[762,4],[1020,4]]},"175":{"position":[[519,4]]},"179":{"position":[[532,4],[564,4],[646,4],[845,4]]}}}],["vec2(0.5",{"_index":2314,"t":{"165":{"position":[[2211,11]]}}}],["vec2(0.5))*2.0",{"_index":2288,"t":{"165":{"position":[[1227,15],[3559,15]]}}}],["vec2(h",{"_index":2243,"t":{"159":{"position":[[1264,6]]}}}],["vec2(h+h2",{"_index":1616,"t":{"97":{"position":[[1394,9]]}}}],["vec2(p.x",{"_index":1611,"t":{"97":{"position":[[1310,9]]},"159":{"position":[[1229,9]]}}}],["vec2(vtexturecoord.x",{"_index":1637,"t":{"97":{"position":[[1721,21]]}}}],["vec2(vuvs.x,1",{"_index":2244,"t":{"159":{"position":[[1588,14]]}}}],["vec3",{"_index":1620,"t":{"97":{"position":[[1436,4],[1459,4],[1499,4],[1519,5],[1645,4],[1654,5],[1781,4],[1816,4],[1892,4],[1933,4],[1988,4],[2034,4],[2123,4],[2190,4],[2360,4],[2428,5]]},"155":{"position":[[1084,4],[1167,4],[1344,4]]},"159":{"position":[[1303,4],[1326,4],[1366,4],[1386,5],[1512,4],[1521,5],[1629,4],[1664,4],[1740,4],[1781,4],[1836,4],[1882,4],[1971,4],[2038,4],[2208,4],[2276,5]]},"165":{"position":[[3575,4]]},"173":{"position":[[657,4],[781,4],[999,4]]},"175":{"position":[[551,4],[635,4],[819,4]]}}}],["vec3(0",{"_index":1647,"t":{"97":{"position":[[1969,8],[2134,9]]},"159":{"position":[[1817,8],[1982,9]]},"165":{"position":[[3591,9]]}}}],["vec3(0.,time",{"_index":1640,"t":{"97":{"position":[[1792,12]]},"159":{"position":[[1640,12]]}}}],["vec3(0.8,0.0",{"_index":1666,"t":{"97":{"position":[[2402,13]]},"159":{"position":[[2250,13]]}}}],["vec3(1.0",{"_index":1665,"t":{"97":{"position":[[2382,9]]},"159":{"position":[[2230,9]]}}}],["vec3(avertexposition",{"_index":2195,"t":{"153":{"position":[[771,21]]},"159":{"position":[[762,21]]},"161":{"position":[[1163,21]]},"163":{"position":[[712,21]]},"165":{"position":[[813,21]]},"167":{"position":[[646,21],[1195,21]]},"171":{"position":[[455,21]]},"173":{"position":[[897,21]]},"175":{"position":[[738,21]]},"179":{"position":[[743,21]]}}}],["vec3(avpos",{"_index":2221,"t":{"155":{"position":[[1265,10]]}}}],["vec3(sin(time)*0.1",{"_index":1641,"t":{"97":{"position":[[1830,19]]},"159":{"position":[[1678,19]]}}}],["vec4",{"_index":1502,"t":{"93":{"position":[[746,4],[770,4],[1066,5]]},"165":{"position":[[1270,4],[1310,4],[1350,4],[2223,4],[4563,4],[4605,4],[4645,4]]}}}],["vec4((projectionmatrix",{"_index":2194,"t":{"153":{"position":[[726,22]]},"155":{"position":[[1220,22]]},"159":{"position":[[717,22]]},"161":{"position":[[1118,22]]},"163":{"position":[[667,22]]},"165":{"position":[[768,22]]},"167":{"position":[[601,22],[1150,22]]},"171":{"position":[[410,22]]},"173":{"position":[[852,22]]},"175":{"position":[[693,22]]},"179":{"position":[[698,22]]}}}],["vec4(0.4",{"_index":2294,"t":{"165":{"position":[[1324,9]]}}}],["vec4(0.8",{"_index":2292,"t":{"165":{"position":[[1284,9]]}}}],["vec4(1.0",{"_index":1512,"t":{"93":{"position":[[941,9]]},"171":{"position":[[557,9]]}}}],["vec4(col",{"_index":1670,"t":{"97":{"position":[[2533,9]]},"159":{"position":[[2381,9]]}}}],["vec4(color",{"_index":2331,"t":{"165":{"position":[[2971,12]]}}}],["vec4(outcolor,1.0",{"_index":2355,"t":{"165":{"position":[[3981,19]]}}}],["vec4(vcol",{"_index":2222,"t":{"155":{"position":[[1384,10]]}}}],["vec4(vcolor",{"_index":2444,"t":{"173":{"position":[[1118,12]]},"175":{"position":[[861,12]]}}}],["vector",{"_index":212,"t":{"41":{"position":[[4139,6]]}}}],["version",{"_index":1581,"t":{"97":{"position":[[209,7],[248,7]]}}}],["vertex",{"_index":1492,"t":{"93":{"position":[[529,6],[596,6]]},"165":{"position":[[500,6]]}}}],["vertexshader",{"_index":1691,"t":{"99":{"position":[[604,14]]}}}],["vertexsrc",{"_index":2241,"t":{"159":{"position":[[502,9]]},"165":{"position":[[553,9]]},"173":{"position":[[576,9]]},"179":{"position":[[483,9]]}}}],["vertice",{"_index":1143,"t":{"71":{"position":[[360,7],[523,7]]}}}],["very",{"_index":692,"t":{"53":{"position":[[4539,4]]},"151":{"position":[[1155,4]]},"209":{"position":[[364,4],[369,4]]}}}],["vfiltercoord",{"_index":2164,"t":{"151":{"position":[[957,12]]}}}],["video",{"_index":2544,"t":{"195":{"position":[[200,5],[700,5],[877,5],[1161,5],[1294,5]]}}}],["videos",{"_index":2558,"t":{"195":{"position":[[796,6],[938,6],[976,6]]}}}],["videosprite",{"_index":2576,"t":{"195":{"position":[[1335,11]]}}}],["videosprite.height",{"_index":2580,"t":{"195":{"position":[[1438,18]]}}}],["videosprite.width",{"_index":2579,"t":{"195":{"position":[[1400,17]]}}}],["view",{"_index":2509,"t":{"185":{"position":[[164,4],[243,5]]}}}],["void",{"_index":1504,"t":{"93":{"position":[[808,4]]},"97":{"position":[[1697,4]]},"153":{"position":[[685,4],[892,4]]},"155":{"position":[[1178,4],[1355,4]]},"159":{"position":[[676,4],[1564,4]]},"161":{"position":[[1077,4],[1284,4]]},"163":{"position":[[626,4],[839,4]]},"165":{"position":[[727,4],[1118,4],[2092,4],[2874,4],[3476,4],[4527,4]]},"167":{"position":[[560,4],[767,4],[1109,4],[1316,4]]},"171":{"position":[[382,4],[528,4]]},"173":{"position":[[794,4],[1060,4]]},"175":{"position":[[648,4],[832,4]]},"179":{"position":[[657,4],[905,4]]}}}],["vrelativevelocity",{"_index":110,"t":{"41":{"position":[[1372,17]]}}}],["vrelativevelocity.x",{"_index":116,"t":{"41":{"position":[[1523,19]]}}}],["vrelativevelocity.y",{"_index":118,"t":{"41":{"position":[[1564,19]]}}}],["vtexturecoord",{"_index":1501,"t":{"93":{"position":[[703,14],[839,13]]},"97":{"position":[[968,14]]}}}],["vtexturecoord).r",{"_index":1615,"t":{"97":{"position":[[1369,17]]}}}],["vtexturecoord.y",{"_index":1638,"t":{"97":{"position":[[1746,17]]}}}],["vuvs",{"_index":2192,"t":{"153":{"position":[[679,5],[699,4],[857,5],[942,4]]},"159":{"position":[[670,5],[690,4],[924,5]]},"161":{"position":[[1071,5],[1091,4],[1249,5],[1334,4]]},"163":{"position":[[620,5],[640,4],[798,5],[895,6]]},"165":{"position":[[721,5],[741,4],[1092,5],[1221,5],[2018,5],[2142,5],[2822,5],[3425,5],[3553,5],[4437,5],[4598,6],[4638,6],[4676,6]]},"167":{"position":[[554,5],[574,4],[732,5],[817,6],[1103,5],[1123,4],[1281,5],[1366,6]]},"173":{"position":[[767,5],[808,4],[1025,5],[1110,5]]},"179":{"position":[[651,5],[671,4],[850,5],[955,4]]}}}],["vuvs).r",{"_index":2329,"t":{"165":{"position":[[2919,8]]}}}],["vuvs.x",{"_index":2464,"t":{"179":{"position":[[975,8]]}}}],["vuvs.y",{"_index":2245,"t":{"159":{"position":[[1603,8]]}}}],["w",{"_index":2815,"t":{"211":{"position":[[416,1],[581,2]]}}}],["wait",{"_index":811,"t":{"59":{"position":[[1273,4]]},"99":{"position":[[360,4]]}}}],["want",{"_index":1457,"t":{"89":{"position":[[1604,4]]}}}],["wanted",{"_index":1578,"t":{"97":{"position":[[169,6]]}}}],["warning",{"_index":1694,"t":{"99":{"position":[[704,7]]}}}],["warpspeed",{"_index":448,"t":{"49":{"position":[[334,9],[1106,9],[1118,9],[1304,10]]}}}],["wave",{"_index":2371,"t":{"165":{"position":[[4650,4]]}}}],["wave,noise.r",{"_index":2374,"t":{"165":{"position":[[4710,14]]}}}],["wavecontainer",{"_index":2360,"t":{"165":{"position":[[4272,13]]}}}],["wavecontainer.addchild(wavequad",{"_index":2361,"t":{"165":{"position":[[4310,33]]}}}],["wavecontainer.position.set(10",{"_index":2381,"t":{"165":{"position":[[5091,30]]}}}],["wavefunctions",{"_index":2341,"t":{"165":{"position":[[3610,13]]}}}],["wavequad",{"_index":2359,"t":{"165":{"position":[[4218,8]]}}}],["wavequad.shader.uniforms.time",{"_index":2395,"t":{"165":{"position":[[5590,29]]}}}],["waveshader",{"_index":2357,"t":{"165":{"position":[[4063,10],[4253,12]]}}}],["wavetexture",{"_index":2358,"t":{"165":{"position":[[4142,11],[4814,12],[5977,11]]}}}],["waveuniforms",{"_index":2356,"t":{"165":{"position":[[4011,12],[4121,14]]}}}],["way",{"_index":1059,"t":{"69":{"position":[[5072,3]]},"87":{"position":[[1661,4]]},"97":{"position":[[85,3]]}}}],["web",{"_index":2612,"t":{"199":{"position":[[316,3]]}}}],["webfont",{"_index":2627,"t":{"199":{"position":[[751,7],[834,9]]}}}],["webgl",{"_index":2533,"t":{"193":{"position":[[315,5]]},"201":{"position":[[93,5],[1188,5]]},"211":{"position":[[851,5]]}}}],["welcome",{"_index":0,"t":{"17":{"position":[[0,7]]}}}],["well",{"_index":1051,"t":{"69":{"position":[[4857,5]]}}}],["wf",{"_index":2615,"t":{"199":{"position":[[359,2]]}}}],["wf.async",{"_index":2624,"t":{"199":{"position":[[555,8]]}}}],["wf.src",{"_index":2617,"t":{"199":{"position":[[398,6]]}}}],["wf.type",{"_index":2622,"t":{"199":{"position":[[526,7]]}}}],["wheel",{"_index":1789,"t":{"103":{"position":[[1767,8],[4198,5],[4345,5],[5429,5]]}}}],["wheels",{"_index":618,"t":{"53":{"position":[[2484,9]]}}}],["wherever",{"_index":1467,"t":{"91":{"position":[[88,8]]}}}],["whether",{"_index":190,"t":{"41":{"position":[[3099,7]]}}}],["white",{"_index":1320,"t":{"85":{"position":[[783,5],[804,5],[949,6]]},"107":{"position":[[1333,8]]},"147":{"position":[[1453,8]]},"199":{"position":[[722,5],[889,8]]},"211":{"position":[[1628,8]]}}}],["whitebox",{"_index":1321,"t":{"85":{"position":[[820,8],[1685,9]]}}}],["whitebox.eventmode",{"_index":1328,"t":{"85":{"position":[[1062,18]]}}}],["whitebox.name",{"_index":1325,"t":{"85":{"position":[[933,13]]}}}],["whole",{"_index":1473,"t":{"91":{"position":[[567,5]]},"95":{"position":[[255,5]]},"103":{"position":[[4021,5]]}}}],["whose",{"_index":1544,"t":{"95":{"position":[[886,5]]}}}],["width",{"_index":270,"t":{"43":{"position":[[546,6],[596,6],[1602,6]]},"91":{"position":[[381,6]]},"103":{"position":[[3454,6]]},"149":{"position":[[1120,6],[1679,6],[2253,6]]},"151":{"position":[[1120,5]]},"165":{"position":[[1735,6],[2541,6],[3180,6],[4184,6]]},"193":{"position":[[291,5]]},"201":{"position":[[332,5],[482,5],[710,6],[821,6],[1012,6],[1146,6]]},"207":{"position":[[146,6]]},"244":{"position":[[539,6]]}}}],["winding",{"_index":982,"t":{"69":{"position":[[1388,7],[1601,7],[1635,7],[2062,8],[6194,7],[6504,7],[6538,7],[7023,8]]}}}],["window",{"_index":50,"t":{"41":{"position":[[274,6]]},"43":{"position":[[78,6]]},"45":{"position":[[103,6]]},"47":{"position":[[101,6]]},"49":{"position":[[78,6]]},"51":{"position":[[101,6]]},"53":{"position":[[101,6]]},"55":{"position":[[101,6]]},"57":{"position":[[101,6]]},"59":{"position":[[101,6]]},"61":{"position":[[101,6]]},"63":{"position":[[78,6]]},"65":{"position":[[78,6]]},"67":{"position":[[101,6]]},"69":{"position":[[101,6]]},"71":{"position":[[101,6]]},"73":{"position":[[78,6]]},"75":{"position":[[101,6]]},"77":{"position":[[98,6]]},"79":{"position":[[78,6]]},"81":{"position":[[101,6]]},"83":{"position":[[78,6]]},"89":{"position":[[101,6]]},"93":{"position":[[146,6]]},"97":{"position":[[373,6]]},"99":{"position":[[78,6]]},"101":{"position":[[78,6]]},"105":{"position":[[78,6]]},"107":{"position":[[78,6]]},"109":{"position":[[95,6]]},"111":{"position":[[127,6]]},"147":{"position":[[95,6]]},"149":{"position":[[95,6]]},"151":{"position":[[78,6]]},"153":{"position":[[78,6]]},"155":{"position":[[78,6]]},"157":{"position":[[78,6]]},"159":{"position":[[78,6]]},"161":{"position":[[78,6]]},"163":{"position":[[78,6]]},"165":{"position":[[91,6]]},"167":{"position":[[78,6]]},"169":{"position":[[78,6]]},"171":{"position":[[78,6]]},"173":{"position":[[78,6]]},"175":{"position":[[78,6]]},"177":{"position":[[78,6]]},"179":{"position":[[78,6]]},"181":{"position":[[96,6]]},"183":{"position":[[96,6]]},"185":{"position":[[281,6]]},"187":{"position":[[101,6]]},"189":{"position":[[101,6]]},"191":{"position":[[101,6]]},"193":{"position":[[78,6]]},"195":{"position":[[98,6]]},"197":{"position":[[101,6]]},"199":{"position":[[101,6]]},"201":{"position":[[1579,6]]},"203":{"position":[[101,6]]},"205":{"position":[[101,6]]},"207":{"position":[[78,6]]},"209":{"position":[[233,6]]},"211":{"position":[[78,6]]},"244":{"position":[[101,6]]},"258":{"position":[[78,6]]}}}],["window.app",{"_index":2025,"t":{"109":{"position":[[1469,10]]}}}],["window.mask",{"_index":970,"t":{"69":{"position":[[766,11],[3539,11]]}}}],["window.webfontconfig",{"_index":2607,"t":{"199":{"position":[[194,20]]}}}],["without",{"_index":2559,"t":{"195":{"position":[[811,7]]}}}],["won't",{"_index":1748,"t":{"103":{"position":[[607,5]]}}}],["wont",{"_index":1483,"t":{"93":{"position":[[429,4]]}}}],["wordwrap",{"_index":613,"t":{"53":{"position":[[2403,9]]},"203":{"position":[[582,9]]}}}],["wordwrapwidth",{"_index":614,"t":{"53":{"position":[[2419,14]]},"203":{"position":[[598,14]]}}}],["work",{"_index":1484,"t":{"93":{"position":[[434,4]]}}}],["works",{"_index":1056,"t":{"69":{"position":[[5047,5]]},"197":{"position":[[380,5]]}}}],["world",{"_index":1738,"t":{"103":{"position":[[225,5],[1424,5],[5336,5]]}}}],["worldtransform",{"_index":1773,"t":{"103":{"position":[[1188,14]]}}}],["wrap",{"_index":933,"t":{"65":{"position":[[2080,4]]},"73":{"position":[[1925,4]]},"79":{"position":[[2049,4]]},"105":{"position":[[2241,4]]},"159":{"position":[[2517,4]]},"201":{"position":[[1244,4]]}}}],["wrapping",{"_index":1673,"t":{"97":{"position":[[2634,8]]},"151":{"position":[[507,9],[1004,8]]}}}],["x",{"_index":161,"t":{"41":{"position":[[2533,2]]},"43":{"position":[[1271,2]]},"47":{"position":[[996,2]]},"49":{"position":[[535,2]]},"69":{"position":[[995,1],[1502,2],[5503,1],[6405,2],[9327,1],[9373,1],[9438,2]]},"89":{"position":[[1135,2]]},"151":{"position":[[1098,1]]},"153":{"position":[[234,2],[253,2],[283,2]]},"159":{"position":[[253,2],[272,2],[302,2]]},"161":{"position":[[234,2],[253,2],[283,2],[592,2],[617,2],[642,2]]},"163":{"position":[[234,2],[253,2],[272,2]]},"165":{"position":[[260,2],[276,2],[303,2]]},"167":{"position":[[234,2],[253,2],[272,2]]},"173":{"position":[[234,2],[253,2],[272,2]]},"175":{"position":[[233,2],[251,2],[272,2]]},"179":{"position":[[234,2],[253,2],[283,2]]}}}],["x+100",{"_index":1854,"t":{"103":{"position":[[3846,6]]}}}],["x,y",{"_index":1601,"t":{"97":{"position":[[1114,3]]},"159":{"position":[[1033,3]]}}}],["x1",{"_index":1031,"t":{"69":{"position":[[3802,2],[8844,4],[8956,3],[9097,3],[9141,3],[9171,3],[9377,2],[9393,4]]}}}],["x2",{"_index":1124,"t":{"69":{"position":[[8769,3],[8853,2],[8950,3],[9134,4],[9387,3]]}}}],["x3",{"_index":1126,"t":{"69":{"position":[[8777,3],[8873,3],[8968,3],[9067,3],[9103,4],[9177,4]]}}}],["x4",{"_index":1128,"t":{"69":{"position":[[8785,3],[8881,2],[8962,3],[9060,4]]}}}],["y",{"_index":162,"t":{"41":{"position":[[2539,2]]},"43":{"position":[[1274,1],[1321,3],[1688,3],[1858,3]]},"47":{"position":[[1002,2]]},"49":{"position":[[541,2],[2151,1]]},"53":{"position":[[3752,1]]},"69":{"position":[[1043,1],[1505,2],[5551,1],[6408,2],[9333,1],[9404,1],[9441,1]]},"89":{"position":[[515,2],[1148,2]]},"95":{"position":[[1954,1]]},"153":{"position":[[237,1],[256,1],[286,1]]},"159":{"position":[[256,1],[275,1],[305,1]]},"161":{"position":[[237,1],[256,1],[286,1],[595,1],[620,1],[645,1]]},"163":{"position":[[237,1],[256,1],[275,1]]},"165":{"position":[[263,1],[279,1],[306,1]]},"167":{"position":[[237,1],[256,1],[275,1]]},"173":{"position":[[237,1],[256,1],[275,1]]},"175":{"position":[[236,1],[254,1],[275,1]]},"179":{"position":[[237,1],[256,1],[286,1]]}}}],["y+300",{"_index":1855,"t":{"103":{"position":[[3853,5]]}}}],["y1",{"_index":1033,"t":{"69":{"position":[[3844,2],[4005,4],[8765,3],[8859,2],[8980,5],[9073,3],[9147,3],[9165,3],[9408,2],[9424,4]]}}}],["y2",{"_index":1125,"t":{"69":{"position":[[8773,3],[8866,3],[8974,3],[9159,3],[9418,3]]}}}],["y3",{"_index":1127,"t":{"69":{"position":[[8781,3],[8887,2],[8944,3],[9079,3],[9091,3],[9153,3]]}}}],["y4",{"_index":1129,"t":{"69":{"position":[[8789,3],[8894,4],[8937,4],[9085,3]]}}}],["yay",{"_index":2526,"t":{"191":{"position":[[310,6]]}}}],["yellow",{"_index":1515,"t":{"93":{"position":[[973,8]]}}}],["yellowstar",{"_index":1352,"t":{"87":{"position":[[147,10]]}}}],["yes",{"_index":2574,"t":{"195":{"position":[[1308,4]]}}}],["yoghurt",{"_index":33,"t":{"41":{"position":[[76,7]]}}}],["z",{"_index":453,"t":{"49":{"position":[[529,2],[1546,1],[1600,2],[1696,2],[2045,2]]},"97":{"position":[[1105,3]]},"159":{"position":[[1024,3]]}}}],["zero",{"_index":2047,"t":{"111":{"position":[[829,4]]}}}],["zoom",{"_index":1867,"t":{"103":{"position":[[4327,5],[4528,4],[4655,5],[4709,5],[5479,4]]},"165":{"position":[[1112,5],[1466,5]]}}}]],"pipeline":["stemmer"]}}] \ No newline at end of file diff --git a/search-index-guides.json b/search-index-guides.json index f096f3e48..8b2cd4ed2 100644 --- a/search-index-guides.json +++ b/search-index-guides.json @@ -1 +1 @@ -[{"documents":[{"i":231,"t":"Welcome","u":"/guides","b":[]},{"i":239,"t":"Architecture Overview","u":"/guides/basics/architecture-overview","b":["Basics"]},{"i":247,"t":"Getting Started","u":"/guides/basics/getting-started","b":["Basics"]},{"i":273,"t":"Render Loop","u":"/guides/basics/render-loop","b":["Basics"]},{"i":285,"t":"Scene Graph","u":"/guides/basics/scene-graph","b":["Basics"]},{"i":299,"t":"What PixiJS Is","u":"/guides/basics/what-pixijs-is","b":["Basics"]},{"i":313,"t":"What PixiJS Is Not","u":"/guides/basics/what-pixijs-is-not","b":["Basics"]},{"i":331,"t":"Assets","u":"/guides/components/assets","b":["Components"]},{"i":346,"t":"Containers","u":"/guides/components/containers","b":["Components"]},{"i":354,"t":"Graphics","u":"/guides/components/graphics","b":["Components"]},{"i":368,"t":"Display Objects","u":"/guides/components/display-object","b":["Components"]},{"i":372,"t":"Spritesheets","u":"/guides/components/sprite-sheets","b":["Components"]},{"i":380,"t":"Interaction","u":"/guides/components/interaction","b":["Components"]},{"i":394,"t":"Sprites","u":"/guides/components/sprites","b":["Components"]},{"i":406,"t":"Text","u":"/guides/components/text","b":["Components"]},{"i":424,"t":"Textures","u":"/guides/components/textures","b":["Components"]},{"i":442,"t":"Upgrading PixiJS","u":"/guides/migrations/upgrading","b":["Migrations"]},{"i":444,"t":"v5 Migration Guide","u":"/guides/migrations/v5","b":["Migrations"]},{"i":474,"t":"v6 Migration Guide","u":"/guides/migrations/v6","b":["Migrations"]},{"i":480,"t":"v7 Migration Guide","u":"/guides/migrations/v7","b":["Migrations"]},{"i":516,"t":"Performance Tips","u":"/guides/production/performance-tips","b":["Production"]}],"index":{"version":"2.3.9","fields":["t"],"fieldVectors":[["t/231",[0,3.184]],["t/239",[1,2.45,2,2.45]],["t/247",[3,2.45,4,2.45]],["t/273",[5,2.45,6,2.45]],["t/285",[7,2.45,8,2.45]],["t/299",[9,2.179]],["t/313",[9,2.179]],["t/331",[10,3.184]],["t/346",[11,3.184]],["t/354",[12,3.184]],["t/368",[13,2.45,14,2.45]],["t/372",[15,3.184]],["t/380",[16,3.184]],["t/394",[17,3.184]],["t/406",[18,3.184]],["t/424",[19,3.184]],["t/442",[9,1.677,20,2.45]],["t/444",[21,1.991,22,1.363,23,1.363]],["t/474",[22,1.363,23,1.363,24,1.991]],["t/480",[22,1.363,23,1.363,25,1.991]],["t/516",[26,2.45,27,2.45]]],"invertedIndex":[["architecture",{"_index":1,"t":{"239":{"position":[[0,12]]}}}],["assets",{"_index":10,"t":{"331":{"position":[[0,6]]}}}],["containers",{"_index":11,"t":{"346":{"position":[[0,10]]}}}],["display",{"_index":13,"t":{"368":{"position":[[0,7]]}}}],["getting",{"_index":3,"t":{"247":{"position":[[0,7]]}}}],["graph",{"_index":8,"t":{"285":{"position":[[6,5]]}}}],["graphics",{"_index":12,"t":{"354":{"position":[[0,8]]}}}],["guide",{"_index":23,"t":{"444":{"position":[[13,5]]},"474":{"position":[[13,5]]},"480":{"position":[[13,5]]}}}],["interaction",{"_index":16,"t":{"380":{"position":[[0,11]]}}}],["loop",{"_index":6,"t":{"273":{"position":[[7,4]]}}}],["migration",{"_index":22,"t":{"444":{"position":[[3,9]]},"474":{"position":[[3,9]]},"480":{"position":[[3,9]]}}}],["objects",{"_index":14,"t":{"368":{"position":[[8,7]]}}}],["overview",{"_index":2,"t":{"239":{"position":[[13,8]]}}}],["performance",{"_index":26,"t":{"516":{"position":[[0,11]]}}}],["pixijs",{"_index":9,"t":{"299":{"position":[[5,6]]},"313":{"position":[[5,6]]},"442":{"position":[[10,6]]}}}],["render",{"_index":5,"t":{"273":{"position":[[0,6]]}}}],["scene",{"_index":7,"t":{"285":{"position":[[0,5]]}}}],["sprites",{"_index":17,"t":{"394":{"position":[[0,7]]}}}],["spritesheets",{"_index":15,"t":{"372":{"position":[[0,12]]}}}],["started",{"_index":4,"t":{"247":{"position":[[8,7]]}}}],["text",{"_index":18,"t":{"406":{"position":[[0,4]]}}}],["textures",{"_index":19,"t":{"424":{"position":[[0,8]]}}}],["tips",{"_index":27,"t":{"516":{"position":[[12,4]]}}}],["upgrading",{"_index":20,"t":{"442":{"position":[[0,9]]}}}],["v5",{"_index":21,"t":{"444":{"position":[[0,2]]}}}],["v6",{"_index":24,"t":{"474":{"position":[[0,2]]}}}],["v7",{"_index":25,"t":{"480":{"position":[[0,2]]}}}],["welcome",{"_index":0,"t":{"231":{"position":[[0,7]]}}}]],"pipeline":["stemmer"]}},{"documents":[{"i":233,"t":"About The Guides","u":"/guides","h":"#about-the-guides","p":231},{"i":235,"t":"Other Resources","u":"/guides","h":"#other-resources","p":231},{"i":241,"t":"The Code","u":"/guides/basics/architecture-overview","h":"#the-code","p":239},{"i":243,"t":"The Components","u":"/guides/basics/architecture-overview","h":"#the-components","p":239},{"i":245,"t":"Major Components","u":"/guides/basics/architecture-overview","h":"#major-components","p":239},{"i":249,"t":"Advanced Users","u":"/guides/basics/getting-started","h":"#advanced-users","p":247},{"i":251,"t":"A Note About JavaScript","u":"/guides/basics/getting-started","h":"#a-note-about-javascript","p":247},{"i":253,"t":"Components of a PixiJS Application","u":"/guides/basics/getting-started","h":"#components-of-a-pixijs-application","p":247},{"i":255,"t":"The HTML File","u":"/guides/basics/getting-started","h":"#the-html-file","p":247},{"i":257,"t":"Serving the File","u":"/guides/basics/getting-started","h":"#serving-the-file","p":247},{"i":259,"t":"Loading PixiJS","u":"/guides/basics/getting-started","h":"#loading-pixijs","p":247},{"i":261,"t":"Creating an Application","u":"/guides/basics/getting-started","h":"#creating-an-application","p":247},{"i":263,"t":"Adding the View to the DOM","u":"/guides/basics/getting-started","h":"#adding-the-view-to-the-dom","p":247},{"i":265,"t":"Creating a Sprite","u":"/guides/basics/getting-started","h":"#creating-a-sprite","p":247},{"i":267,"t":"Adding the Sprite to the Stage","u":"/guides/basics/getting-started","h":"#adding-the-sprite-to-the-stage","p":247},{"i":269,"t":"Writing an Update Loop","u":"/guides/basics/getting-started","h":"#writing-an-update-loop","p":247},{"i":271,"t":"Putting It All Together","u":"/guides/basics/getting-started","h":"#putting-it-all-together","p":247},{"i":275,"t":"Running Ticker Callbacks","u":"/guides/basics/render-loop","h":"#running-ticker-callbacks","p":273},{"i":277,"t":"Updating the Scene Graph","u":"/guides/basics/render-loop","h":"#updating-the-scene-graph","p":273},{"i":279,"t":"Rendering the Scene Graph","u":"/guides/basics/render-loop","h":"#rendering-the-scene-graph","p":273},{"i":281,"t":"Frame Rates","u":"/guides/basics/render-loop","h":"#frame-rates","p":273},{"i":283,"t":"Custom Render Loops","u":"/guides/basics/render-loop","h":"#custom-render-loops","p":273},{"i":287,"t":"The Scene Graph Is a Tree","u":"/guides/basics/scene-graph","h":"#the-scene-graph-is-a-tree","p":285},{"i":289,"t":"Parents and Children","u":"/guides/basics/scene-graph","h":"#parents-and-children","p":285},{"i":291,"t":"Render Order","u":"/guides/basics/scene-graph","h":"#render-order","p":285},{"i":293,"t":"Culling","u":"/guides/basics/scene-graph","h":"#culling","p":285},{"i":295,"t":"Local vs Global Coordinates","u":"/guides/basics/scene-graph","h":"#local-vs-global-coordinates","p":285},{"i":297,"t":"Global vs Screen Coordinates","u":"/guides/basics/scene-graph","h":"#global-vs-screen-coordinates","p":285},{"i":301,"t":"PixiJS Is ... Fast","u":"/guides/basics/what-pixijs-is","h":"#pixijs-is--fast","p":299},{"i":303,"t":"... More Than Just Sprites","u":"/guides/basics/what-pixijs-is","h":"#-more-than-just-sprites","p":299},{"i":305,"t":"... WebGL Native","u":"/guides/basics/what-pixijs-is","h":"#-webgl-native","p":299},{"i":307,"t":"... Open Source","u":"/guides/basics/what-pixijs-is","h":"#-open-source","p":299},{"i":309,"t":"... Extensible","u":"/guides/basics/what-pixijs-is","h":"#-extensible","p":299},{"i":311,"t":"... Easy to Deploy","u":"/guides/basics/what-pixijs-is","h":"#-easy-to-deploy","p":299},{"i":315,"t":"PixiJS Is Not ... A Framework","u":"/guides/basics/what-pixijs-is-not","h":"#pixijs-is-not--a-framework","p":313},{"i":317,"t":"... A 3D Renderer","u":"/guides/basics/what-pixijs-is-not","h":"#-a-3d-renderer","p":313},{"i":319,"t":"... A Mobile App","u":"/guides/basics/what-pixijs-is-not","h":"#-a-mobile-app","p":313},{"i":321,"t":"... A UI Library","u":"/guides/basics/what-pixijs-is-not","h":"#-a-ui-library","p":313},{"i":323,"t":"... A Data Store","u":"/guides/basics/what-pixijs-is-not","h":"#-a-data-store","p":313},{"i":325,"t":"... An Audio Library","u":"/guides/basics/what-pixijs-is-not","h":"#-an-audio-library","p":313},{"i":327,"t":"... A Development Environment","u":"/guides/basics/what-pixijs-is-not","h":"#-a-development-environment","p":313},{"i":329,"t":"So Is PixiJS Right For Me?","u":"/guides/basics/what-pixijs-is-not","h":"#so-is-pixijs-right-for-me","p":313},{"i":332,"t":"The Assets package","u":"/guides/components/assets","h":"#the-assets-package","p":331},{"i":334,"t":"Getting started","u":"/guides/components/assets","h":"#getting-started","p":331},{"i":336,"t":"Making our first Assets Promise","u":"/guides/components/assets","h":"#making-our-first-assets-promise","p":331},{"i":338,"t":"Warning about solved promises","u":"/guides/components/assets","h":"#warning-about-solved-promises","p":331},{"i":340,"t":"Using Async/Await","u":"/guides/components/assets","h":"#using-asyncawait","p":331},{"i":342,"t":"Loading multiple assets","u":"/guides/components/assets","h":"#loading-multiple-assets","p":331},{"i":344,"t":"Background loading","u":"/guides/components/assets","h":"#background-loading","p":331},{"i":348,"t":"Containers as Groups","u":"/guides/components/containers","h":"#containers-as-groups","p":346},{"i":350,"t":"Masking","u":"/guides/components/containers","h":"#masking","p":346},{"i":352,"t":"Filtering","u":"/guides/components/containers","h":"#filtering","p":346},{"i":356,"t":"Graphics Is About Building - Not Drawing","u":"/guides/components/graphics","h":"#graphics-is-about-building---not-drawing","p":354},{"i":358,"t":"Types of Primitives","u":"/guides/components/graphics","h":"#types-of-primitives","p":354},{"i":360,"t":"The Geometry List","u":"/guides/components/graphics","h":"#the-geometry-list","p":354},{"i":362,"t":"Graphics For Display","u":"/guides/components/graphics","h":"#graphics-for-display","p":354},{"i":364,"t":"Graphics as a Mask","u":"/guides/components/graphics","h":"#graphics-as-a-mask","p":354},{"i":366,"t":"Caveats and Gotchas","u":"/guides/components/graphics","h":"#caveats-and-gotchas","p":354},{"i":370,"t":"Commonly Used Attributes","u":"/guides/components/display-object","h":"#commonly-used-attributes","p":368},{"i":374,"t":"Anatomy of a Spritesheet","u":"/guides/components/sprite-sheets","h":"#anatomy-of-a-spritesheet","p":372},{"i":376,"t":"Doubly Efficient","u":"/guides/components/sprite-sheets","h":"#doubly-efficient","p":372},{"i":378,"t":"Creating SpriteSheets","u":"/guides/components/sprite-sheets","h":"#creating-spritesheets","p":372},{"i":382,"t":"Event Modes","u":"/guides/components/interaction","h":"#event-modes","p":380},{"i":384,"t":"Event Types","u":"/guides/components/interaction","h":"#event-types","p":380},{"i":386,"t":"Enabling Interaction","u":"/guides/components/interaction","h":"#enabling-interaction","p":380},{"i":388,"t":"Checking if Object is Interactive","u":"/guides/components/interaction","h":"#checking-if-object-is-interactive","p":380},{"i":390,"t":"Use Pointer Events","u":"/guides/components/interaction","h":"#use-pointer-events","p":380},{"i":392,"t":"Optimization","u":"/guides/components/interaction","h":"#optimization","p":380},{"i":396,"t":"Creating Sprites","u":"/guides/components/sprites","h":"#creating-sprites","p":394},{"i":398,"t":"Using Sprites","u":"/guides/components/sprites","h":"#using-sprites","p":394},{"i":400,"t":"Alpha, Tint and Blend Modes","u":"/guides/components/sprites","h":"#alpha-tint-and-blend-modes","p":394},{"i":402,"t":"Scale vs Width & Height","u":"/guides/components/sprites","h":"#scale-vs-width--height","p":394},{"i":404,"t":"Pivot vs Anchor","u":"/guides/components/sprites","h":"#pivot-vs-anchor","p":394},{"i":408,"t":"There Are Two Kinds of Text","u":"/guides/components/text","h":"#there-are-two-kinds-of-text","p":406},{"i":410,"t":"The Text Object","u":"/guides/components/text","h":"#the-text-object","p":406},{"i":412,"t":"Text Styles","u":"/guides/components/text","h":"#text-styles","p":406},{"i":414,"t":"Loading and Using Fonts","u":"/guides/components/text","h":"#loading-and-using-fonts","p":406},{"i":416,"t":"Caveats and Gotchas","u":"/guides/components/text","h":"#caveats-and-gotchas","p":406},{"i":418,"t":"BitmapText","u":"/guides/components/text","h":"#bitmaptext","p":406},{"i":420,"t":"BitmapFont","u":"/guides/components/text","h":"#bitmapfont","p":406},{"i":422,"t":"Selecting the Right Approach","u":"/guides/components/text","h":"#selecting-the-right-approach","p":406},{"i":426,"t":"Life-cycle of a Texture","u":"/guides/components/textures","h":"#life-cycle-of-a-texture","p":424},{"i":428,"t":"Serving the Image","u":"/guides/components/textures","h":"#serving-the-image","p":424},{"i":430,"t":"Loading the Image","u":"/guides/components/textures","h":"#loading-the-image","p":424},{"i":432,"t":"BaseTextures Own the Data","u":"/guides/components/textures","h":"#basetextures-own-the-data","p":424},{"i":434,"t":"Textures are a View on BaseTextures","u":"/guides/components/textures","h":"#textures-are-a-view-on-basetextures","p":424},{"i":436,"t":"Loading Textures","u":"/guides/components/textures","h":"#loading-textures","p":424},{"i":438,"t":"Unloading Textures","u":"/guides/components/textures","h":"#unloading-textures","p":424},{"i":440,"t":"Beyond Images","u":"/guides/components/textures","h":"#beyond-images","p":424},{"i":446,"t":"🚧 API Changes","u":"/guides/migrations/v5","h":"#-api-changes","p":444},{"i":447,"t":"Making WebGL First-Class","u":"/guides/migrations/v5","h":"#making-webgl-first-class","p":444},{"i":449,"t":"Renderer Parameters","u":"/guides/migrations/v5","h":"#renderer-parameters","p":444},{"i":451,"t":"Mesh, Plane, Rope","u":"/guides/migrations/v5","h":"#mesh-plane-rope","p":444},{"i":453,"t":"Graphics Holes","u":"/guides/migrations/v5","h":"#graphics-holes","p":444},{"i":455,"t":"Filter Padding","u":"/guides/migrations/v5","h":"#filter-padding","p":444},{"i":457,"t":"Filter Default Vertex Shader","u":"/guides/migrations/v5","h":"#filter-default-vertex-shader","p":444},{"i":459,"t":"Enable Mipmapping for RenderTexture","u":"/guides/migrations/v5","h":"#enable-mipmapping-for-rendertexture","p":444},{"i":461,"t":"BaseTexture Resources","u":"/guides/migrations/v5","h":"#basetexture-resources","p":444},{"i":463,"t":"BaseTexture.source","u":"/guides/migrations/v5","h":"#basetexturesource","p":444},{"i":465,"t":"Graphics Interaction","u":"/guides/migrations/v5","h":"#graphics-interaction","p":444},{"i":467,"t":"πŸ“¦ Publishing Changes","u":"/guides/migrations/v5","h":"#-publishing-changes","p":444},{"i":468,"t":"Canvas Becomes Legacy","u":"/guides/migrations/v5","h":"#canvas-becomes-legacy","p":444},{"i":470,"t":"Bundling Changes","u":"/guides/migrations/v5","h":"#bundling-changes","p":444},{"i":472,"t":"Webpack","u":"/guides/migrations/v5","h":"#webpack","p":444},{"i":476,"t":"Typings","u":"/guides/migrations/v6","h":"#typings","p":474},{"i":478,"t":"Mesh Internals","u":"/guides/migrations/v6","h":"#mesh-internals","p":474},{"i":482,"t":"πŸ‘‹ Dropping Internet Explorer","u":"/guides/migrations/v7","h":"#-dropping-internet-explorer","p":480},{"i":484,"t":"πŸ—‘οΈ Remove Polyfills","u":"/guides/migrations/v7","h":"#️-remove-polyfills","p":480},{"i":486,"t":"πŸ’¬ Output ES2020 (modules) and ES2017 (browser)","u":"/guides/migrations/v7","h":"#-output-es2020-modules-and-es2017-browser","p":480},{"i":488,"t":"🐭 Replaces InteractionManager with EventSystem","u":"/guides/migrations/v7","h":"#-replaces-interactionmanager-with-eventsystem","p":480},{"i":490,"t":"πŸ“¦ Replaces Loader with Assets","u":"/guides/migrations/v7","h":"#-replaces-loader-with-assets","p":480},{"i":492,"t":"🀝 Abandon the use of peerDependencies","u":"/guides/migrations/v7","h":"#-abandon-the-use-of-peerdependencies","p":480},{"i":494,"t":"πŸ‘‚ Other Changes","u":"/guides/migrations/v7","h":"#-other-changes","p":480},{"i":496,"t":"Exports from @pixi/core","u":"/guides/migrations/v7","h":"#exports-from-pixicore","p":480},{"i":498,"t":"Extract and Prepare Systems","u":"/guides/migrations/v7","h":"#extract-and-prepare-systems","p":480},{"i":500,"t":"Extensions Self-Install","u":"/guides/migrations/v7","h":"#extensions-self-install","p":480},{"i":502,"t":"Using hitTest with Events","u":"/guides/migrations/v7","h":"#using-hittest-with-events","p":480},{"i":504,"t":"New Async Extract Methods","u":"/guides/migrations/v7","h":"#new-async-extract-methods","p":480},{"i":506,"t":"Interactive Move Events","u":"/guides/migrations/v7","h":"#interactive-move-events","p":480},{"i":508,"t":"Interactive Property Handlers are Removed","u":"/guides/migrations/v7","h":"#interactive-property-handlers-are-removed","p":480},{"i":510,"t":"Property buttonMode has been removed","u":"/guides/migrations/v7","h":"#property-buttonmode-has-been-removed","p":480},{"i":512,"t":"☝️ Suggestions for Upgrading","u":"/guides/migrations/v7","h":"#️-suggestions-for-upgrading","p":480},{"i":514,"t":"πŸ—οΈ Plugin Supported","u":"/guides/migrations/v7","h":"#️-plugin-supported","p":480},{"i":517,"t":"General","u":"/guides/production/performance-tips","h":"#general","p":516},{"i":519,"t":"Sprites","u":"/guides/production/performance-tips","h":"#sprites","p":516},{"i":521,"t":"Graphics","u":"/guides/production/performance-tips","h":"#graphics","p":516},{"i":523,"t":"Texture","u":"/guides/production/performance-tips","h":"#texture","p":516},{"i":525,"t":"Text","u":"/guides/production/performance-tips","h":"#text","p":516},{"i":527,"t":"Masks","u":"/guides/production/performance-tips","h":"#masks","p":516},{"i":529,"t":"Filters","u":"/guides/production/performance-tips","h":"#filters","p":516},{"i":531,"t":"BlendModes","u":"/guides/production/performance-tips","h":"#blendmodes","p":516},{"i":533,"t":"CacheAsBitmap","u":"/guides/production/performance-tips","h":"#cacheasbitmap","p":516},{"i":535,"t":"Events","u":"/guides/production/performance-tips","h":"#events","p":516}],"index":{"version":"2.3.9","fields":["t"],"fieldVectors":[["t/233",[0,5.904]],["t/235",[1,5.232]],["t/241",[2,5.904]],["t/243",[3,4.79]],["t/245",[3,3.915,4,4.825]],["t/249",[5,4.825,6,4.825]],["t/251",[7,4.825,8,4.825]],["t/253",[3,3.311,9,2.9,10,3.616]],["t/255",[11,4.825,12,4.277]],["t/257",[12,4.277,13,4.277]],["t/259",[9,3.43,14,3.25]],["t/261",[10,4.277,15,3.645]],["t/263",[16,3.616,17,3.616,18,4.08]],["t/265",[15,3.645,19,4.277]],["t/267",[16,3.616,19,3.616,20,4.08]],["t/269",[21,4.08,22,4.08,23,4.08]],["t/271",[24,4.825,25,4.825]],["t/275",[26,4.08,27,4.08,28,4.08]],["t/277",[29,4.08,30,3.311,31,3.311]],["t/279",[30,3.311,31,3.311,32,4.08]],["t/281",[33,4.825,34,4.825]],["t/283",[35,4.08,36,3.616,37,4.08]],["t/287",[30,3.311,31,3.311,38,4.08]],["t/289",[39,4.825,40,4.825]],["t/291",[36,4.277,41,4.825]],["t/293",[42,5.904]],["t/295",[43,3.534,44,2.67,45,3.133,46,3.133]],["t/297",[44,2.67,45,3.133,46,3.133,47,3.534]],["t/301",[9,2.9,48,1.507,49,4.08]],["t/303",[48,1.507,50,4.08,51,3.082]],["t/305",[48,1.507,52,3.616,53,4.08]],["t/307",[48,1.507,54,4.08,55,4.08]],["t/309",[48,1.782,56,4.825]],["t/311",[48,1.507,57,4.08,58,4.08]],["t/315",[9,2.9,48,1.507,59,4.08]],["t/317",[48,1.507,60,4.08,61,3.616]],["t/319",[48,1.507,62,4.08,63,4.08]],["t/321",[48,1.507,64,4.08,65,3.616]],["t/323",[48,1.507,66,3.616,67,4.08]],["t/325",[48,1.507,65,3.616,68,4.08]],["t/327",[48,1.507,69,4.08,70,4.08]],["t/329",[9,3.43,71,4.277]],["t/332",[72,3.645,73,4.825]],["t/334",[74,4.825,75,4.825]],["t/336",[72,2.67,76,3.133,77,3.133,78,3.534]],["t/338",[79,4.08,80,4.08,81,4.08]],["t/340",[82,3.645,83,4.825]],["t/342",[14,2.748,72,3.082,84,4.08]],["t/344",[14,3.25,85,4.825]],["t/348",[86,4.825,87,4.825]],["t/350",[88,5.904]],["t/352",[89,5.904]],["t/356",[90,2.748,91,4.08,92,4.08]],["t/358",[93,4.277,94,4.825]],["t/360",[95,4.825,96,4.825]],["t/362",[90,3.25,97,4.825]],["t/364",[90,3.25,98,4.825]],["t/366",[99,4.277,100,4.277]],["t/370",[101,4.08,102,4.08,103,4.08]],["t/374",[104,4.825,105,4.825]],["t/376",[106,4.825,107,4.825]],["t/378",[15,3.645,108,4.825]],["t/382",[109,4.277,110,4.277]],["t/384",[93,4.277,109,4.277]],["t/386",[111,4.825,112,4.277]],["t/388",[113,4.08,114,3.616,115,3.311]],["t/390",[116,3.616,117,4.08,118,3.082]],["t/392",[119,5.904]],["t/396",[15,3.645,51,3.645]],["t/398",[51,3.645,82,3.645]],["t/400",[110,3.133,120,3.534,121,3.534,122,3.534]],["t/402",[44,2.355,48,1.151,123,3.117,124,3.117,125,3.117]],["t/404",[44,3.082,126,4.08,127,4.08]],["t/408",[128,4.08,129,4.08,130,3.082]],["t/410",[114,4.277,130,3.645]],["t/412",[130,3.645,131,4.825]],["t/414",[14,2.748,82,3.082,132,4.08]],["t/416",[99,4.277,100,4.277]],["t/418",[133,5.904]],["t/420",[134,5.904]],["t/422",[71,3.616,135,4.08,136,4.08]],["t/426",[137,4.08,138,4.08,139,3.616]],["t/428",[13,4.277,140,4.277]],["t/430",[14,3.25,140,4.277]],["t/432",[66,4.277,141,4.277]],["t/434",[17,3.616,141,3.616,142,3.311]],["t/436",[14,3.25,142,3.915]],["t/438",[142,3.915,143,4.825]],["t/440",[144,4.825,145,4.825]],["t/446",[48,1.507,146,4.08,147,3.082]],["t/447",[52,3.133,76,3.133,77,3.133,148,3.534]],["t/449",[61,4.277,149,4.825]],["t/451",[150,3.616,151,4.08,152,4.08]],["t/453",[90,3.25,153,4.825]],["t/455",[154,4.277,155,4.825]],["t/457",[154,3.133,156,3.534,157,3.534,158,3.534]],["t/459",[159,4.08,160,4.08,161,4.08]],["t/461",[1,4.277,162,4.825]],["t/463",[163,5.904]],["t/465",[90,3.25,112,4.277]],["t/467",[48,1.507,147,3.082,164,4.08]],["t/468",[165,4.08,166,4.08,167,4.08]],["t/470",[147,3.645,168,4.825]],["t/472",[169,5.904]],["t/476",[170,5.904]],["t/478",[150,4.277,171,4.825]],["t/482",[48,1.305,172,3.534,173,3.534,174,3.534]],["t/484",[48,1.507,175,4.08,176,4.08]],["t/486",[48,1.03,177,2.788,178,2.788,179,2.788,180,2.788,181,2.788]],["t/488",[48,1.305,182,3.133,183,3.534,184,3.534]],["t/490",[48,1.305,72,2.67,182,3.133,185,3.534]],["t/492",[48,1.305,116,3.133,186,3.534,187,3.534]],["t/494",[48,1.782,147,3.645]],["t/496",[188,4.825,189,4.825]],["t/498",[190,3.616,191,4.08,192,4.08]],["t/500",[193,4.08,194,4.08,195,4.08]],["t/502",[82,3.082,118,3.082,196,4.08]],["t/504",[190,3.133,197,3.534,198,3.534,199,3.534]],["t/506",[115,3.311,118,3.082,200,4.08]],["t/508",[115,2.868,201,3.133,202,3.534,203,3.133]],["t/510",[201,3.616,203,3.616,204,4.08]],["t/512",[48,1.507,205,4.08,206,4.08]],["t/514",[48,1.507,207,4.08,208,4.08]],["t/517",[209,5.904]],["t/519",[51,4.46]],["t/521",[90,3.977]],["t/523",[139,5.232]],["t/525",[130,4.46]],["t/527",[210,5.904]],["t/529",[211,5.904]],["t/531",[212,5.904]],["t/533",[213,5.904]],["t/535",[118,4.46]]],"invertedIndex":[["",{"_index":48,"t":{"301":{"position":[[10,3]]},"303":{"position":[[0,3]]},"305":{"position":[[0,3]]},"307":{"position":[[0,3]]},"309":{"position":[[0,3]]},"311":{"position":[[0,3]]},"315":{"position":[[14,3]]},"317":{"position":[[0,3]]},"319":{"position":[[0,3]]},"321":{"position":[[0,3]]},"323":{"position":[[0,3]]},"325":{"position":[[0,3]]},"327":{"position":[[0,3]]},"402":{"position":[[15,1]]},"446":{"position":[[0,2]]},"467":{"position":[[0,2]]},"482":{"position":[[0,2]]},"484":{"position":[[0,3]]},"486":{"position":[[0,2]]},"488":{"position":[[0,2]]},"490":{"position":[[0,2]]},"492":{"position":[[0,2]]},"494":{"position":[[0,2]]},"512":{"position":[[0,2]]},"514":{"position":[[0,3]]}}}],["3d",{"_index":60,"t":{"317":{"position":[[6,2]]}}}],["abandon",{"_index":186,"t":{"492":{"position":[[3,7]]}}}],["adding",{"_index":16,"t":{"263":{"position":[[0,6]]},"267":{"position":[[0,6]]}}}],["advanced",{"_index":5,"t":{"249":{"position":[[0,8]]}}}],["alpha",{"_index":120,"t":{"400":{"position":[[0,6]]}}}],["anatomy",{"_index":104,"t":{"374":{"position":[[0,7]]}}}],["anchor",{"_index":127,"t":{"404":{"position":[[9,6]]}}}],["api",{"_index":146,"t":{"446":{"position":[[3,3]]}}}],["app",{"_index":63,"t":{"319":{"position":[[13,3]]}}}],["application",{"_index":10,"t":{"253":{"position":[[23,11]]},"261":{"position":[[12,11]]}}}],["approach",{"_index":136,"t":{"422":{"position":[[20,8]]}}}],["assets",{"_index":72,"t":{"332":{"position":[[4,6]]},"336":{"position":[[17,6]]},"342":{"position":[[17,6]]},"490":{"position":[[24,6]]}}}],["async",{"_index":198,"t":{"504":{"position":[[4,5]]}}}],["async/await",{"_index":83,"t":{"340":{"position":[[6,11]]}}}],["attributes",{"_index":103,"t":{"370":{"position":[[14,10]]}}}],["audio",{"_index":68,"t":{"325":{"position":[[7,5]]}}}],["background",{"_index":85,"t":{"344":{"position":[[0,10]]}}}],["basetexture",{"_index":162,"t":{"461":{"position":[[0,11]]}}}],["basetexture.source",{"_index":163,"t":{"463":{"position":[[0,18]]}}}],["basetextures",{"_index":141,"t":{"432":{"position":[[0,12]]},"434":{"position":[[23,12]]}}}],["becomes",{"_index":166,"t":{"468":{"position":[[7,7]]}}}],["beyond",{"_index":144,"t":{"440":{"position":[[0,6]]}}}],["bitmapfont",{"_index":134,"t":{"420":{"position":[[0,10]]}}}],["bitmaptext",{"_index":133,"t":{"418":{"position":[[0,10]]}}}],["blend",{"_index":122,"t":{"400":{"position":[[16,5]]}}}],["blendmodes",{"_index":212,"t":{"531":{"position":[[0,10]]}}}],["browser",{"_index":181,"t":{"486":{"position":[[38,9]]}}}],["building",{"_index":91,"t":{"356":{"position":[[18,8]]}}}],["bundling",{"_index":168,"t":{"470":{"position":[[0,8]]}}}],["buttonmode",{"_index":204,"t":{"510":{"position":[[9,10]]}}}],["cacheasbitmap",{"_index":213,"t":{"533":{"position":[[0,13]]}}}],["callbacks",{"_index":28,"t":{"275":{"position":[[15,9]]}}}],["canvas",{"_index":165,"t":{"468":{"position":[[0,6]]}}}],["caveats",{"_index":99,"t":{"366":{"position":[[0,7]]},"416":{"position":[[0,7]]}}}],["changes",{"_index":147,"t":{"446":{"position":[[7,7]]},"467":{"position":[[14,7]]},"470":{"position":[[9,7]]},"494":{"position":[[9,7]]}}}],["checking",{"_index":113,"t":{"388":{"position":[[0,8]]}}}],["children",{"_index":40,"t":{"289":{"position":[[12,8]]}}}],["class",{"_index":148,"t":{"447":{"position":[[19,5]]}}}],["code",{"_index":2,"t":{"241":{"position":[[4,4]]}}}],["commonly",{"_index":101,"t":{"370":{"position":[[0,8]]}}}],["components",{"_index":3,"t":{"243":{"position":[[4,10]]},"245":{"position":[[6,10]]},"253":{"position":[[0,10]]}}}],["containers",{"_index":86,"t":{"348":{"position":[[0,10]]}}}],["coordinates",{"_index":46,"t":{"295":{"position":[[16,11]]},"297":{"position":[[17,11]]}}}],["creating",{"_index":15,"t":{"261":{"position":[[0,8]]},"265":{"position":[[0,8]]},"378":{"position":[[0,8]]},"396":{"position":[[0,8]]}}}],["culling",{"_index":42,"t":{"293":{"position":[[0,7]]}}}],["custom",{"_index":35,"t":{"283":{"position":[[0,6]]}}}],["cycle",{"_index":138,"t":{"426":{"position":[[5,5]]}}}],["data",{"_index":66,"t":{"323":{"position":[[6,4]]},"432":{"position":[[21,4]]}}}],["default",{"_index":156,"t":{"457":{"position":[[7,7]]}}}],["deploy",{"_index":58,"t":{"311":{"position":[[12,6]]}}}],["development",{"_index":69,"t":{"327":{"position":[[6,11]]}}}],["display",{"_index":97,"t":{"362":{"position":[[13,7]]}}}],["dom",{"_index":18,"t":{"263":{"position":[[23,3]]}}}],["doubly",{"_index":106,"t":{"376":{"position":[[0,6]]}}}],["drawing",{"_index":92,"t":{"356":{"position":[[33,7]]}}}],["dropping",{"_index":172,"t":{"482":{"position":[[3,8]]}}}],["easy",{"_index":57,"t":{"311":{"position":[[4,4]]}}}],["efficient",{"_index":107,"t":{"376":{"position":[[7,9]]}}}],["enable",{"_index":159,"t":{"459":{"position":[[0,6]]}}}],["enabling",{"_index":111,"t":{"386":{"position":[[0,8]]}}}],["environment",{"_index":70,"t":{"327":{"position":[[18,11]]}}}],["es2017",{"_index":180,"t":{"486":{"position":[[31,6]]}}}],["es2020",{"_index":178,"t":{"486":{"position":[[10,6]]}}}],["event",{"_index":109,"t":{"382":{"position":[[0,5]]},"384":{"position":[[0,5]]}}}],["events",{"_index":118,"t":{"390":{"position":[[12,6]]},"502":{"position":[[19,6]]},"506":{"position":[[17,6]]},"535":{"position":[[0,6]]}}}],["eventsystem",{"_index":184,"t":{"488":{"position":[[36,11]]}}}],["explorer",{"_index":174,"t":{"482":{"position":[[21,8]]}}}],["exports",{"_index":188,"t":{"496":{"position":[[0,7]]}}}],["extensible",{"_index":56,"t":{"309":{"position":[[4,10]]}}}],["extensions",{"_index":193,"t":{"500":{"position":[[0,10]]}}}],["extract",{"_index":190,"t":{"498":{"position":[[0,7]]},"504":{"position":[[10,7]]}}}],["fast",{"_index":49,"t":{"301":{"position":[[14,4]]}}}],["file",{"_index":12,"t":{"255":{"position":[[9,4]]},"257":{"position":[[12,4]]}}}],["filter",{"_index":154,"t":{"455":{"position":[[0,6]]},"457":{"position":[[0,6]]}}}],["filtering",{"_index":89,"t":{"352":{"position":[[0,9]]}}}],["filters",{"_index":211,"t":{"529":{"position":[[0,7]]}}}],["first",{"_index":77,"t":{"336":{"position":[[11,5]]},"447":{"position":[[13,5]]}}}],["fonts",{"_index":132,"t":{"414":{"position":[[18,5]]}}}],["frame",{"_index":33,"t":{"281":{"position":[[0,5]]}}}],["framework",{"_index":59,"t":{"315":{"position":[[20,9]]}}}],["general",{"_index":209,"t":{"517":{"position":[[0,7]]}}}],["geometry",{"_index":95,"t":{"360":{"position":[[4,8]]}}}],["getting",{"_index":74,"t":{"334":{"position":[[0,7]]}}}],["global",{"_index":45,"t":{"295":{"position":[[9,6]]},"297":{"position":[[0,6]]}}}],["gotchas",{"_index":100,"t":{"366":{"position":[[12,7]]},"416":{"position":[[12,7]]}}}],["graph",{"_index":31,"t":{"277":{"position":[[19,5]]},"279":{"position":[[20,5]]},"287":{"position":[[10,5]]}}}],["graphics",{"_index":90,"t":{"356":{"position":[[0,8]]},"362":{"position":[[0,8]]},"364":{"position":[[0,8]]},"453":{"position":[[0,8]]},"465":{"position":[[0,8]]},"521":{"position":[[0,8]]}}}],["groups",{"_index":87,"t":{"348":{"position":[[14,6]]}}}],["guides",{"_index":0,"t":{"233":{"position":[[10,6]]}}}],["handlers",{"_index":202,"t":{"508":{"position":[[21,8]]}}}],["height",{"_index":125,"t":{"402":{"position":[[17,6]]}}}],["hittest",{"_index":196,"t":{"502":{"position":[[6,7]]}}}],["holes",{"_index":153,"t":{"453":{"position":[[9,5]]}}}],["html",{"_index":11,"t":{"255":{"position":[[4,4]]}}}],["image",{"_index":140,"t":{"428":{"position":[[12,5]]},"430":{"position":[[12,5]]}}}],["images",{"_index":145,"t":{"440":{"position":[[7,6]]}}}],["install",{"_index":195,"t":{"500":{"position":[[16,7]]}}}],["interaction",{"_index":112,"t":{"386":{"position":[[9,11]]},"465":{"position":[[9,11]]}}}],["interactionmanager",{"_index":183,"t":{"488":{"position":[[12,18]]}}}],["interactive",{"_index":115,"t":{"388":{"position":[[22,11]]},"506":{"position":[[0,11]]},"508":{"position":[[0,11]]}}}],["internals",{"_index":171,"t":{"478":{"position":[[5,9]]}}}],["internet",{"_index":173,"t":{"482":{"position":[[12,8]]}}}],["javascript",{"_index":8,"t":{"251":{"position":[[13,10]]}}}],["kinds",{"_index":129,"t":{"408":{"position":[[14,5]]}}}],["legacy",{"_index":167,"t":{"468":{"position":[[15,6]]}}}],["library",{"_index":65,"t":{"321":{"position":[[9,7]]},"325":{"position":[[13,7]]}}}],["life",{"_index":137,"t":{"426":{"position":[[0,4]]}}}],["list",{"_index":96,"t":{"360":{"position":[[13,4]]}}}],["loader",{"_index":185,"t":{"490":{"position":[[12,6]]}}}],["loading",{"_index":14,"t":{"259":{"position":[[0,7]]},"342":{"position":[[0,7]]},"344":{"position":[[11,7]]},"414":{"position":[[0,7]]},"430":{"position":[[0,7]]},"436":{"position":[[0,7]]}}}],["local",{"_index":43,"t":{"295":{"position":[[0,5]]}}}],["loop",{"_index":23,"t":{"269":{"position":[[18,4]]}}}],["loops",{"_index":37,"t":{"283":{"position":[[14,5]]}}}],["major",{"_index":4,"t":{"245":{"position":[[0,5]]}}}],["making",{"_index":76,"t":{"336":{"position":[[0,6]]},"447":{"position":[[0,6]]}}}],["mask",{"_index":98,"t":{"364":{"position":[[14,4]]}}}],["masking",{"_index":88,"t":{"350":{"position":[[0,7]]}}}],["masks",{"_index":210,"t":{"527":{"position":[[0,5]]}}}],["mesh",{"_index":150,"t":{"451":{"position":[[0,5]]},"478":{"position":[[0,4]]}}}],["methods",{"_index":199,"t":{"504":{"position":[[18,7]]}}}],["mipmapping",{"_index":160,"t":{"459":{"position":[[7,10]]}}}],["mobile",{"_index":62,"t":{"319":{"position":[[6,6]]}}}],["modes",{"_index":110,"t":{"382":{"position":[[6,5]]},"400":{"position":[[22,5]]}}}],["modules",{"_index":179,"t":{"486":{"position":[[17,9]]}}}],["more",{"_index":50,"t":{"303":{"position":[[4,4]]}}}],["move",{"_index":200,"t":{"506":{"position":[[12,4]]}}}],["multiple",{"_index":84,"t":{"342":{"position":[[8,8]]}}}],["native",{"_index":53,"t":{"305":{"position":[[10,6]]}}}],["new",{"_index":197,"t":{"504":{"position":[[0,3]]}}}],["note",{"_index":7,"t":{"251":{"position":[[2,4]]}}}],["object",{"_index":114,"t":{"388":{"position":[[12,6]]},"410":{"position":[[9,6]]}}}],["open",{"_index":54,"t":{"307":{"position":[[4,4]]}}}],["optimization",{"_index":119,"t":{"392":{"position":[[0,12]]}}}],["order",{"_index":41,"t":{"291":{"position":[[7,5]]}}}],["output",{"_index":177,"t":{"486":{"position":[[3,6]]}}}],["package",{"_index":73,"t":{"332":{"position":[[11,7]]}}}],["padding",{"_index":155,"t":{"455":{"position":[[7,7]]}}}],["parameters",{"_index":149,"t":{"449":{"position":[[9,10]]}}}],["parents",{"_index":39,"t":{"289":{"position":[[0,7]]}}}],["peerdependencies",{"_index":187,"t":{"492":{"position":[[22,16]]}}}],["pivot",{"_index":126,"t":{"404":{"position":[[0,5]]}}}],["pixi/core",{"_index":189,"t":{"496":{"position":[[13,10]]}}}],["pixijs",{"_index":9,"t":{"253":{"position":[[16,6]]},"259":{"position":[[8,6]]},"301":{"position":[[0,6]]},"315":{"position":[[0,6]]},"329":{"position":[[6,6]]}}}],["plane",{"_index":151,"t":{"451":{"position":[[6,6]]}}}],["plugin",{"_index":207,"t":{"514":{"position":[[4,6]]}}}],["pointer",{"_index":117,"t":{"390":{"position":[[4,7]]}}}],["polyfills",{"_index":176,"t":{"484":{"position":[[11,9]]}}}],["prepare",{"_index":191,"t":{"498":{"position":[[12,7]]}}}],["primitives",{"_index":94,"t":{"358":{"position":[[9,10]]}}}],["promise",{"_index":78,"t":{"336":{"position":[[24,7]]}}}],["promises",{"_index":81,"t":{"338":{"position":[[21,8]]}}}],["property",{"_index":201,"t":{"508":{"position":[[12,8]]},"510":{"position":[[0,8]]}}}],["publishing",{"_index":164,"t":{"467":{"position":[[3,10]]}}}],["putting",{"_index":24,"t":{"271":{"position":[[0,7]]}}}],["rates",{"_index":34,"t":{"281":{"position":[[6,5]]}}}],["remove",{"_index":175,"t":{"484":{"position":[[4,6]]}}}],["removed",{"_index":203,"t":{"508":{"position":[[34,7]]},"510":{"position":[[29,7]]}}}],["render",{"_index":36,"t":{"283":{"position":[[7,6]]},"291":{"position":[[0,6]]}}}],["renderer",{"_index":61,"t":{"317":{"position":[[9,8]]},"449":{"position":[[0,8]]}}}],["rendering",{"_index":32,"t":{"279":{"position":[[0,9]]}}}],["rendertexture",{"_index":161,"t":{"459":{"position":[[22,13]]}}}],["replaces",{"_index":182,"t":{"488":{"position":[[3,8]]},"490":{"position":[[3,8]]}}}],["resources",{"_index":1,"t":{"235":{"position":[[6,9]]},"461":{"position":[[12,9]]}}}],["right",{"_index":71,"t":{"329":{"position":[[13,5]]},"422":{"position":[[14,5]]}}}],["rope",{"_index":152,"t":{"451":{"position":[[13,4]]}}}],["running",{"_index":26,"t":{"275":{"position":[[0,7]]}}}],["scale",{"_index":123,"t":{"402":{"position":[[0,5]]}}}],["scene",{"_index":30,"t":{"277":{"position":[[13,5]]},"279":{"position":[[14,5]]},"287":{"position":[[4,5]]}}}],["screen",{"_index":47,"t":{"297":{"position":[[10,6]]}}}],["selecting",{"_index":135,"t":{"422":{"position":[[0,9]]}}}],["self",{"_index":194,"t":{"500":{"position":[[11,4]]}}}],["serving",{"_index":13,"t":{"257":{"position":[[0,7]]},"428":{"position":[[0,7]]}}}],["shader",{"_index":158,"t":{"457":{"position":[[22,6]]}}}],["solved",{"_index":80,"t":{"338":{"position":[[14,6]]}}}],["source",{"_index":55,"t":{"307":{"position":[[9,6]]}}}],["sprite",{"_index":19,"t":{"265":{"position":[[11,6]]},"267":{"position":[[11,6]]}}}],["sprites",{"_index":51,"t":{"303":{"position":[[19,7]]},"396":{"position":[[9,7]]},"398":{"position":[[6,7]]},"519":{"position":[[0,7]]}}}],["spritesheet",{"_index":105,"t":{"374":{"position":[[13,11]]}}}],["spritesheets",{"_index":108,"t":{"378":{"position":[[9,12]]}}}],["stage",{"_index":20,"t":{"267":{"position":[[25,5]]}}}],["started",{"_index":75,"t":{"334":{"position":[[8,7]]}}}],["store",{"_index":67,"t":{"323":{"position":[[11,5]]}}}],["styles",{"_index":131,"t":{"412":{"position":[[5,6]]}}}],["suggestions",{"_index":205,"t":{"512":{"position":[[3,11]]}}}],["supported",{"_index":208,"t":{"514":{"position":[[11,9]]}}}],["systems",{"_index":192,"t":{"498":{"position":[[20,7]]}}}],["text",{"_index":130,"t":{"408":{"position":[[23,4]]},"410":{"position":[[4,4]]},"412":{"position":[[0,4]]},"525":{"position":[[0,4]]}}}],["texture",{"_index":139,"t":{"426":{"position":[[16,7]]},"523":{"position":[[0,7]]}}}],["textures",{"_index":142,"t":{"434":{"position":[[0,8]]},"436":{"position":[[8,8]]},"438":{"position":[[10,8]]}}}],["ticker",{"_index":27,"t":{"275":{"position":[[8,6]]}}}],["tint",{"_index":121,"t":{"400":{"position":[[7,4]]}}}],["together",{"_index":25,"t":{"271":{"position":[[15,8]]}}}],["tree",{"_index":38,"t":{"287":{"position":[[21,4]]}}}],["two",{"_index":128,"t":{"408":{"position":[[10,3]]}}}],["types",{"_index":93,"t":{"358":{"position":[[0,5]]},"384":{"position":[[6,5]]}}}],["typings",{"_index":170,"t":{"476":{"position":[[0,7]]}}}],["ui",{"_index":64,"t":{"321":{"position":[[6,2]]}}}],["unloading",{"_index":143,"t":{"438":{"position":[[0,9]]}}}],["update",{"_index":22,"t":{"269":{"position":[[11,6]]}}}],["updating",{"_index":29,"t":{"277":{"position":[[0,8]]}}}],["upgrading",{"_index":206,"t":{"512":{"position":[[19,9]]}}}],["use",{"_index":116,"t":{"390":{"position":[[0,3]]},"492":{"position":[[15,3]]}}}],["used",{"_index":102,"t":{"370":{"position":[[9,4]]}}}],["users",{"_index":6,"t":{"249":{"position":[[9,5]]}}}],["using",{"_index":82,"t":{"340":{"position":[[0,5]]},"398":{"position":[[0,5]]},"414":{"position":[[12,5]]},"502":{"position":[[0,5]]}}}],["vertex",{"_index":157,"t":{"457":{"position":[[15,6]]}}}],["view",{"_index":17,"t":{"263":{"position":[[11,4]]},"434":{"position":[[15,4]]}}}],["vs",{"_index":44,"t":{"295":{"position":[[6,2]]},"297":{"position":[[7,2]]},"402":{"position":[[6,2]]},"404":{"position":[[6,2]]}}}],["warning",{"_index":79,"t":{"338":{"position":[[0,7]]}}}],["webgl",{"_index":52,"t":{"305":{"position":[[4,5]]},"447":{"position":[[7,5]]}}}],["webpack",{"_index":169,"t":{"472":{"position":[[0,7]]}}}],["width",{"_index":124,"t":{"402":{"position":[[9,5]]}}}],["writing",{"_index":21,"t":{"269":{"position":[[0,7]]}}}]],"pipeline":["stemmer"]}},{"documents":[{"i":232,"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":"/guides","h":"","p":231},{"i":234,"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":"/guides","h":"#about-the-guides","p":231},{"i":236,"t":"As you explore the guides, you may find these resources valuable: PixiJS API documentation PixiJS Github repo","s":"Other Resources","u":"/guides","h":"#other-resources","p":231},{"i":240,"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":"/guides/basics/architecture-overview","h":"","p":239},{"i":242,"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":"/guides/basics/architecture-overview","h":"#the-code","p":239},{"i":244,"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":"/guides/basics/architecture-overview","h":"#the-components","p":239},{"i":246,"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":"/guides/basics/architecture-overview","h":"#major-components","p":239},{"i":248,"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":"/guides/basics/getting-started","h":"","p":247},{"i":250,"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":"/guides/basics/getting-started","h":"#advanced-users","p":247},{"i":252,"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":"/guides/basics/getting-started","h":"#a-note-about-javascript","p":247},{"i":254,"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":"/guides/basics/getting-started","h":"#components-of-a-pixijs-application","p":247},{"i":256,"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":"/guides/basics/getting-started","h":"#the-html-file","p":247},{"i":258,"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":"/guides/basics/getting-started","h":"#serving-the-file","p":247},{"i":260,"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":"/guides/basics/getting-started","h":"#loading-pixijs","p":247},{"i":262,"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":"/guides/basics/getting-started","h":"#creating-an-application","p":247},{"i":264,"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":"/guides/basics/getting-started","h":"#adding-the-view-to-the-dom","p":247},{"i":266,"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":"/guides/basics/getting-started","h":"#creating-a-sprite","p":247},{"i":268,"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":"/guides/basics/getting-started","h":"#adding-the-sprite-to-the-stage","p":247},{"i":270,"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":"/guides/basics/getting-started","h":"#writing-an-update-loop","p":247},{"i":272,"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":"/guides/basics/getting-started","h":"#putting-it-all-together","p":247},{"i":274,"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":"/guides/basics/render-loop","h":"","p":273},{"i":276,"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":"/guides/basics/render-loop","h":"#running-ticker-callbacks","p":273},{"i":278,"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":"/guides/basics/render-loop","h":"#updating-the-scene-graph","p":273},{"i":280,"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":"/guides/basics/render-loop","h":"#rendering-the-scene-graph","p":273},{"i":282,"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":"/guides/basics/render-loop","h":"#frame-rates","p":273},{"i":284,"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":"/guides/basics/render-loop","h":"#custom-render-loops","p":273},{"i":286,"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":"/guides/basics/scene-graph","h":"","p":285},{"i":288,"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":"/guides/basics/scene-graph","h":"#the-scene-graph-is-a-tree","p":285},{"i":290,"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":"/guides/basics/scene-graph","h":"#parents-and-children","p":285},{"i":292,"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":"/guides/basics/scene-graph","h":"#render-order","p":285},{"i":294,"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":"/guides/basics/scene-graph","h":"#culling","p":285},{"i":296,"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":"/guides/basics/scene-graph","h":"#local-vs-global-coordinates","p":285},{"i":298,"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":"/guides/basics/scene-graph","h":"#global-vs-screen-coordinates","p":285},{"i":300,"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":"/guides/basics/what-pixijs-is","h":"","p":299},{"i":302,"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":"/guides/basics/what-pixijs-is","h":"#pixijs-is--fast","p":299},{"i":304,"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":"/guides/basics/what-pixijs-is","h":"#-more-than-just-sprites","p":299},{"i":306,"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":"/guides/basics/what-pixijs-is","h":"#-webgl-native","p":299},{"i":308,"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":"/guides/basics/what-pixijs-is","h":"#-open-source","p":299},{"i":310,"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":"/guides/basics/what-pixijs-is","h":"#-extensible","p":299},{"i":312,"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":"/guides/basics/what-pixijs-is","h":"#-easy-to-deploy","p":299},{"i":314,"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":"/guides/basics/what-pixijs-is-not","h":"","p":313},{"i":316,"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":"/guides/basics/what-pixijs-is-not","h":"#pixijs-is-not--a-framework","p":313},{"i":318,"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":"/guides/basics/what-pixijs-is-not","h":"#-a-3d-renderer","p":313},{"i":320,"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":"/guides/basics/what-pixijs-is-not","h":"#-a-mobile-app","p":313},{"i":322,"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":"/guides/basics/what-pixijs-is-not","h":"#-a-ui-library","p":313},{"i":324,"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":"/guides/basics/what-pixijs-is-not","h":"#-a-data-store","p":313},{"i":326,"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":"/guides/basics/what-pixijs-is-not","h":"#-an-audio-library","p":313},{"i":328,"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":"/guides/basics/what-pixijs-is-not","h":"#-a-development-environment","p":313},{"i":330,"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":"/guides/basics/what-pixijs-is-not","h":"#so-is-pixijs-right-for-me","p":313},{"i":333,"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":"/guides/components/assets","h":"#the-assets-package","p":331},{"i":335,"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":"/guides/components/assets","h":"#getting-started","p":331},{"i":337,"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":"/guides/components/assets","h":"#making-our-first-assets-promise","p":331},{"i":339,"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":"/guides/components/assets","h":"#warning-about-solved-promises","p":331},{"i":341,"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":"/guides/components/assets","h":"#using-asyncawait","p":331},{"i":343,"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":"/guides/components/assets","h":"#loading-multiple-assets","p":331},{"i":345,"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":"/guides/components/assets","h":"#background-loading","p":331},{"i":347,"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":"/guides/components/containers","h":"","p":346},{"i":349,"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":"/guides/components/containers","h":"#containers-as-groups","p":346},{"i":351,"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":"/guides/components/containers","h":"#masking","p":346},{"i":353,"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":"/guides/components/containers","h":"#filtering","p":346},{"i":355,"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":"/guides/components/graphics","h":"","p":354},{"i":357,"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":"/guides/components/graphics","h":"#graphics-is-about-building---not-drawing","p":354},{"i":359,"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":"/guides/components/graphics","h":"#types-of-primitives","p":354},{"i":361,"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":"/guides/components/graphics","h":"#the-geometry-list","p":354},{"i":363,"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":"/guides/components/graphics","h":"#graphics-for-display","p":354},{"i":365,"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":"/guides/components/graphics","h":"#graphics-as-a-mask","p":354},{"i":367,"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":"/guides/components/graphics","h":"#caveats-and-gotchas","p":354},{"i":369,"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":"/guides/components/display-object","h":"","p":368},{"i":371,"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":"/guides/components/display-object","h":"#commonly-used-attributes","p":368},{"i":373,"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":"/guides/components/sprite-sheets","h":"","p":372},{"i":375,"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":"/guides/components/sprite-sheets","h":"#anatomy-of-a-spritesheet","p":372},{"i":377,"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":"/guides/components/sprite-sheets","h":"#doubly-efficient","p":372},{"i":379,"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":"/guides/components/sprite-sheets","h":"#creating-spritesheets","p":372},{"i":381,"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":"/guides/components/interaction","h":"","p":380},{"i":383,"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":"/guides/components/interaction","h":"#event-modes","p":380},{"i":385,"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 twice 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 twice 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":"/guides/components/interaction","h":"#event-types","p":380},{"i":387,"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":"/guides/components/interaction","h":"#enabling-interaction","p":380},{"i":389,"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":"/guides/components/interaction","h":"#checking-if-object-is-interactive","p":380},{"i":391,"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":"/guides/components/interaction","h":"#use-pointer-events","p":380},{"i":393,"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":"/guides/components/interaction","h":"#optimization","p":380},{"i":395,"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":"/guides/components/sprites","h":"","p":394},{"i":397,"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":"/guides/components/sprites","h":"#creating-sprites","p":394},{"i":399,"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":"/guides/components/sprites","h":"#using-sprites","p":394},{"i":401,"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":"/guides/components/sprites","h":"#alpha-tint-and-blend-modes","p":394},{"i":403,"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":"/guides/components/sprites","h":"#scale-vs-width--height","p":394},{"i":405,"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":"/guides/components/sprites","h":"#pivot-vs-anchor","p":394},{"i":407,"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":"/guides/components/text","h":"","p":406},{"i":409,"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":"/guides/components/text","h":"#there-are-two-kinds-of-text","p":406},{"i":411,"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":"/guides/components/text","h":"#the-text-object","p":406},{"i":413,"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":"/guides/components/text","h":"#text-styles","p":406},{"i":415,"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":"/guides/components/text","h":"#loading-and-using-fonts","p":406},{"i":417,"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":"/guides/components/text","h":"#caveats-and-gotchas","p":406},{"i":419,"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":"/guides/components/text","h":"#bitmaptext","p":406},{"i":421,"t":"3rd party solutions BitmapFont.from auto-generation","s":"BitmapFont","u":"/guides/components/text","h":"#bitmapfont","p":406},{"i":423,"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":"/guides/components/text","h":"#selecting-the-right-approach","p":406},{"i":425,"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":"/guides/components/textures","h":"","p":424},{"i":427,"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":"/guides/components/textures","h":"#life-cycle-of-a-texture","p":424},{"i":429,"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":"/guides/components/textures","h":"#serving-the-image","p":424},{"i":431,"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":"/guides/components/textures","h":"#loading-the-image","p":424},{"i":433,"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":"/guides/components/textures","h":"#basetextures-own-the-data","p":424},{"i":435,"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":"/guides/components/textures","h":"#textures-are-a-view-on-basetextures","p":424},{"i":437,"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":"/guides/components/textures","h":"#loading-textures","p":424},{"i":439,"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":"/guides/components/textures","h":"#unloading-textures","p":424},{"i":441,"t":"As we alluded to above, you can make a Texture out of more than just images: Video: Pass an HTML5