HumanBreak/src/core/render/container.ts

63 lines
1.7 KiB
TypeScript
Raw Normal View History

2024-05-09 23:49:53 +08:00
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);
});
});
2024-05-10 17:33:27 +08:00
this.writing = void 0;
2024-05-09 23:49:53 +08:00
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);
}
}