import { MotaOffscreenCanvas2D } from '../fx/canvas2d'; import { Camera } from './camera'; import { ICanvasCachedRenderItem, RenderItem, RenderItemPosition, withCacheRender } from './item'; export class Container extends RenderItem implements ICanvasCachedRenderItem { children: RenderItem[] = []; sortedChildren: RenderItem[] = []; canvas: MotaOffscreenCanvas2D; constructor(type: RenderItemPosition = 'static') { super(); this.canvas = new MotaOffscreenCanvas2D(); this.type = type; this.canvas.withGameScale(true); } render( canvas: HTMLCanvasElement, ctx: CanvasRenderingContext2D, camera: Camera ): void { this.emit('beforeUpdate', this); withCacheRender(this, canvas, ctx, camera, c => { this.sortedChildren.forEach(v => { v.render(c.canvas, c.ctx, camera); }); }); this.emit('afterUpdate', this); } size(width: number, height: number) { this.width = width; this.height = height; this.canvas.size(width, height); this.writing = this.using; this.update(this); } pos(x: number, y: number) { this.x = x; this.y = y; } /** * 添加子元素到这个容器上,然后在下一个tick执行更新 * @param children 要添加的子元素 */ appendChild(children: RenderItem[]) { children.forEach(v => (v.parent = this)); this.children.push(...children); this.sortedChildren = this.children .slice() .sort((a, b) => a.zIndex - b.zIndex); } }