Skip to content

Commit

Permalink
fix: fix canvas.ready never resolve when switch to webgl, webgpu rend…
Browse files Browse the repository at this point in the history
…erer (#1737)

* fix: fix canvas.ready never resolve when switch to webgl, webgpu renderer

* test: add test case
  • Loading branch information
Aarebecca authored Jul 18, 2024
1 parent f340e62 commit 9b77184
Show file tree
Hide file tree
Showing 4 changed files with 44 additions and 3 deletions.
1 change: 1 addition & 0 deletions __tests__/demos/canvas/index.ts
Original file line number Diff line number Diff line change
@@ -0,0 +1 @@
export { switchRenderer } from './switch-renderer';
37 changes: 37 additions & 0 deletions __tests__/demos/canvas/switch-renderer.ts
Original file line number Diff line number Diff line change
@@ -0,0 +1,37 @@
import { Circle } from '../../../packages/g';
import { Renderer as CanvasRenderer } from '../../../packages/g-canvas';
import { Renderer as SVGRenderer } from '../../../packages/g-svg';
import { Renderer as WebGLRenderer } from '../../../packages/g-webgl';

export async function switchRenderer(context) {
const { canvas, gui } = context;

await canvas.ready;

const circle = new Circle({
style: {
cx: 100,
cy: 100,
r: 50,
fill: 'red',
},
});

canvas.appendChild(circle);

const folder = gui.addFolder('renderer');
folder
.add({ renderer: 'canvas' }, 'renderer', ['canvas', 'svg', 'webgl'])
.onChange((name) => {
let renderer;
if (name === 'canvas') renderer = new CanvasRenderer();
else if (name === 'svg') renderer = new SVGRenderer();
else if (name === 'webgl') renderer = new WebGLRenderer();

canvas.setRenderer(renderer);

canvas.ready.then(() => {
alert(`Switch to ${name} renderer`);
});
});
}
2 changes: 2 additions & 0 deletions __tests__/main.ts
Original file line number Diff line number Diff line change
Expand Up @@ -18,6 +18,7 @@ import * as perf from './demos/perf';
import * as bugfix from './demos/bugfix';
import * as event from './demos/event';
import * as camera from './demos/camera';
import * as canvasCase from './demos/canvas';

const tests = {
...createSpecRender(namespace(basic2d, '2d')),
Expand All @@ -31,6 +32,7 @@ const tests = {
...createSpecRender(namespace(perf, 'perf')),
...createSpecRender(namespace(event, 'event')),
...createSpecRender(namespace(camera, 'camera')),
...createSpecRender(namespace(canvasCase, 'canvas')),
};

const renderers = {
Expand Down
7 changes: 4 additions & 3 deletions packages/g-lite/src/Canvas.ts
Original file line number Diff line number Diff line change
Expand Up @@ -570,13 +570,14 @@ export class Canvas extends EventTarget implements ICanvas {
} else {
this.dispatchEvent(new CustomEvent(CanvasEvent.READY));
}
if (this.readyPromise) {
this.resolveReadyPromise();
}
} else {
this.dispatchEvent(new CustomEvent(CanvasEvent.RENDERER_CHANGED));
}

if (this.readyPromise) {
this.resolveReadyPromise();
}

if (!firstContentfullPaint) {
this.getRoot().forEach((node) => {
const renderable = (node as Element).renderable;
Expand Down

0 comments on commit 9b77184

Please sign in to comment.