avocado-old/packages/graphics/traits/primitive.trait.js
2020-06-19 22:01:45 -05:00

81 lines
1.7 KiB
JavaScript

import {compose} from '@avocado/core';
import {StateProperty, Trait} from '@avocado/entity';
import {Color, Primitives} from '@avocado/graphics';
const decorate = compose(
)
export default class Primitive extends decorate(Trait) {
static defaultParams() {
return {
primitives: [],
};
}
static describeParams() {
return {
primitives: {
type: 'object',
label: 'Primitives',
},
};
}
static type() {
return 'primitive';
}
constructor(entity, params, state) {
super(entity, params, state);
this._primitives = undefined;
}
drawPrimitives() {
if (!this.entity.container) {
return;
}
if (this._primitives) {
this.entity.container.removeChild(this._primitives);
}
this._primitives = new Primitives();
for (let i = 0; i < this.params.primitives.length; i++) {
const primitive = this.params.primitives[i];
if ('circle' === primitive.type) {
const line = {
rgba: [255, 0, 255, 1],
thickness: 1,
...primitive.line,
};
const fill = primitive.fill ? primitive.fill : {
rgba: [0, 0, 0, 0]
};
this._primitives.drawCircle(
primitive.position || [0, 0],
primitive.radius,
Primitives.lineStyle(new Color(...line.rgba), 1),
Primitives.fillStyle(new Color(...fill.rgba)),
);
}
}
this.entity.container.addChild(this._primitives);
}
listeners() {
return {
traitAdded: (type) => {
if (-1 === [
'primitive',
'visible',
].indexOf(type)) {
return;
}
this.drawPrimitives();
},
};
}
}