'use strict';
describe('getLocalBounds', function ()
{
it('should register correct local-bounds with a LOADED Sprite', function ()
{
const parent = new PIXI.Container();
const texture = PIXI.RenderTexture.create(10, 10);
const sprite = new PIXI.Sprite(texture);
parent.addChild(sprite);
let bounds = sprite.getLocalBounds();
expect(bounds.x).to.equal(0);
expect(bounds.y).to.equal(0);
expect(bounds.width).to.equal(10);
expect(bounds.height).to.equal(10);
sprite.position.x = 20;
sprite.position.y = 20;
sprite.scale.x = 2;
sprite.scale.y = 2;
bounds = sprite.getLocalBounds();
expect(bounds.x).to.equal(0);
expect(bounds.y).to.equal(0);
expect(bounds.width).to.equal(10);
expect(bounds.height).to.equal(10);
});
it('should register correct local-bounds with Graphics', function ()
{
const parent = new PIXI.Container();
const graphics = new PIXI.Graphics();
graphics.beginFill(0xFF0000).drawCircle(0, 0, 10);
parent.addChild(graphics);
const bounds = graphics.getLocalBounds();
expect(bounds.x).to.equal(-10);
expect(bounds.y).to.equal(-10);
expect(bounds.width).to.equal(20);
expect(bounds.height).to.equal(20);
});
it('should register correct local-bounds with Graphics after clear', function ()
{
const parent = new PIXI.Container();
const graphics = new PIXI.Graphics();
graphics.beginFill(0xFF0000).drawRect(0, 0, 20, 20);
parent.addChild(graphics);
let bounds = graphics.getLocalBounds();
expect(bounds.x).to.equal(0);
expect(bounds.y).to.equal(0);
expect(bounds.width).to.equal(20);
expect(bounds.height).to.equal(20);
graphics.clear();
graphics.beginFill(0xFF, 1);
graphics.drawRect(0, 0, 10, 10);
graphics.endFill();
bounds = graphics.getLocalBounds();
expect(bounds.x).to.equal(0);
expect(bounds.y).to.equal(0);
expect(bounds.width).to.equal(10);
expect(bounds.height).to.equal(10);
});
it('should register correct local-bounds with Graphics after generateCanvasTexture and clear', function ()
{
const parent = new PIXI.Container();
const graphics = new PIXI.Graphics();
graphics.beginFill(0xFF0000).drawRect(0, 0, 20, 20);
parent.addChild(graphics);
let bounds = graphics.getLocalBounds();
graphics.generateCanvasTexture();
expect(bounds.x).to.equal(0);
expect(bounds.y).to.equal(0);
expect(bounds.width).to.equal(20);
expect(bounds.height).to.equal(20);
graphics.clear();
graphics.beginFill(0xFF, 1);
graphics.drawRect(0, 0, 10, 10);
graphics.endFill();
bounds = graphics.getLocalBounds();
expect(bounds.x).to.equal(0);
expect(bounds.y).to.equal(0);
expect(bounds.width).to.equal(10);
expect(bounds.height).to.equal(10);
});
it('should register correct local-bounds with an empty Container', function ()
{
const parent = new PIXI.Container();
const container = new PIXI.Container();
parent.addChild(container);
const bounds = container.getLocalBounds();
expect(bounds.x).to.equal(0);
expect(bounds.y).to.equal(0);
expect(bounds.width).to.equal(0);
expect(bounds.height).to.equal(0);
});
it('should register correct local-bounds with an item that has already had its parent Container transformed', function ()
{
const parent = new PIXI.Container();
const container = new PIXI.Container();
const graphics = new PIXI.Graphics().beginFill(0xFF0000).drawRect(0, 0, 10, 10);
parent.addChild(container);
container.addChild(graphics);
container.position.x = 100;
container.position.y = 100;
const bounds = container.getLocalBounds();
expect(bounds.x).to.equal(0);
expect(bounds.y).to.equal(0);
expect(bounds.width).to.equal(10);
expect(bounds.height).to.equal(10);
});
/*
it('should register correct local-bounds with a Mesh', function ()
{
const parent = new PIXI.Container();
const texture = PIXI.RenderTexture.create(10, 10);
const plane = new PIXI.mesh.Plane(texture);
parent.addChild(plane);
plane.position.x = 20;
plane.position.y = 20;
const bounds = plane.getLocalBounds();
expect(bounds.x).to.equal(0);
expect(bounds.y).to.equal(0);
expect(bounds.width).to.equal(10);
expect(bounds.height).to.equal(10);
});
*/
it('should register correct local-bounds with a cachAsBitmap item inside after a render', function ()
{
const parent = new PIXI.Container();
const graphic = new PIXI.Graphics();
graphic.beginFill(0xffffff);
graphic.drawRect(0, 0, 100, 100);
graphic.endFill();
graphic.cacheAsBitmap = true;
parent.addChild(graphic);
const renderer = new PIXI.CanvasRenderer(100, 100);
renderer.sayHello = () => { /* empty */ };
renderer.render(parent);
const bounds = parent.getLocalBounds();
expect(bounds.x).to.equal(0);
expect(bounds.y).to.equal(0);
expect(bounds.width).to.equal(100);
expect(bounds.height).to.equal(100);
});
it('should register correct local-bounds with a Text', function ()
{
const text = new PIXI.Text('hello');
const bounds = text.getLocalBounds();
expect(bounds.width).to.not.equal(0);
expect(bounds.height).to.not.equal(0);
});
});