<!doctype html> <html lang="en"> <head> <meta http-equiv="Content-Type" content="text/html; charset=utf-8"> <title>PIXI Scatter Doctest</title> <link rel="stylesheet" href=".././3rdparty/highlight/styles/default.css"> <link rel="stylesheet" href="../../css/doctest.css"> <script src=".././3rdparty/highlight/highlight.pack.js"></script> <script src="../../dist/iwmlib.3rdparty.js"></script> <script src="../../dist/iwmlib.js"></script> <script src="../../dist/iwmlib.pixi.js"></script> </head> <body onload="Doctest.run()"> <h1> Scatter </h1> <p> Scatter objects are UI elements that can be rotated, scaled or moved around which typically leads to "scattered" layouts. The PIXI scatter defined here is a specialization of the <a href="../scatter.html">abstract scatter pattern</a>. </p> <p>PIXI scatter are organized in <code>ScatterContainer</code> parent nodes and <code>DisplayObjectScatter</code> child nodes. <p>Let's look at an example of a PIXI scatter. Since scatter objects are mainly used as main views it is a common use case that the scene itself is used as the <code>ScatterContainer</code>. The <code>DisplayObjectScatter</code> is simply used as a wrapper that makes any interative DisplayObject zoomable, rotatable and translatable.</p> <canvas id="canvas" class="grayBorder interactive">Canvas not supported</canvas> <script class="doctest"> class ScatterApp extends PIXIApp { sceneFactory() { return new ScatterContainer(this.renderer, { showBounds: true, showPolygon: true, app: this }) } setup() { super.setup() let x = 30 let y = 30 for (let key of ['women', 'king']) { let sprite = PIXI.Sprite.from('../examples/' + key + '.jpeg') sprite.interactive = true let scatter = new DisplayObjectScatter(sprite, this.renderer, { x: x, y: y, startScale: 0.25, minScale: 0.2, maxScale: 1 }) this.scene.addChild(sprite) scatter.zoom(0.5, { animate: 1.0 }) x += 100 y += 30 } return this } } const app = new ScatterApp({ view: canvas, autoResize: false, width: 450, height: 250 }) .setup() .run() </script> <h1> Two ScatterContainers in one canvas-element </h1> <p> You see two ScatterContainers within the same HTML-canvas-element. The Queen is included in the first, the King in the second ScatterContainer. You should interact the two images independently of each other. </p> <canvas id="canvas2" class="grayBorder interactive">Canvas not supported</canvas> <script class="doctest"> class DoubleScatterApp extends PIXIApp { setup() { super.setup() // Obey order in which ScatterContainer are created because the // InteractionMapper register event handlers in a first come first serve // order this.scatterContainerFront = new ScatterContainer(this.renderer, { app: this }) this.scatterContainerBack = new ScatterContainer(this.renderer, { app: this }) // Note that the addChild order is different because later children // are placed in front of earlier children. this.scene.addChild(this.scatterContainerBack) this.scene.addChild(this.scatterContainerFront) // Add the queen to ScatterContainer one let sprite1 = PIXI.Sprite.from('../examples/women.jpeg') sprite1.interactive = true let scatter1 = new DisplayObjectScatter(sprite1, this.renderer, { x: 20, y: 40, startScale: .5 }) this.scatterContainerBack.addChild(sprite1) // Add the king to ScatterContainer two let sprite2 = PIXI.Sprite.from('../examples/king.jpeg') sprite2.interactive = true let scatter2 = new DisplayObjectScatter(sprite2, this.renderer, { x: 280, y: 40, startScale: .5 }) this.scatterContainerFront.addChild(sprite2) return this } } const doubleScatterApp = new DoubleScatterApp({ view: canvas2, autoResize: false, width: 450, height: 250 }).setup().run() </script> <h1> Nested Scatter </h1> <p> Sometimes it can be required, that multiple scatters are nested in one another. E.g. when a map is displayed as scatter and another scatter is displayed on the map. </p> <canvas id="canvas3" class="grayBorder interactive">Canvas not supported</canvas> <script class="doctest"> class NestedScatterApp extends PIXIApp { sceneFactory() { return new ScatterContainer(this.renderer, { application: this, showBounds: true, showPolygon: true, app: this }) } setup() { super.setup() // Add the queen to ScatterContainer one let woman = PIXI.Sprite.from('../examples/women.jpeg') woman.interactive = true new DisplayObjectScatter(woman, this.renderer, { x: 20, y: 40, startScale: 2, maxScale: 5 }) this.scene.addChild(woman) let nestedKing = PIXI.Sprite.from('../examples/king.jpeg') nestedKing.interactive = true new DisplayObjectScatter(nestedKing, this.renderer, { x: 20, y: 20, startScale: 0.3 }) woman.addChild(nestedKing) let nestedQueen = PIXI.Sprite.from('../examples/women.jpeg') nestedQueen.interactive = true new DisplayObjectScatter(nestedQueen, this.renderer, { x: 40, y: 40, startScale: 0.3 }) woman.addChild(nestedQueen) let king = PIXI.Sprite.from('../examples/king.jpeg') king.interactive = true new DisplayObjectScatter(king, this.renderer, { x: 200, y: 20, startScale: 1 }) this.scene.addChild(king) return this } } const nestedScatterApp = new NestedScatterApp({ view: canvas3, autoResize: false, width: 450, height: 250 }).setup().run() </script> </body>