From f109d83657dc576cb81e2ff2d9b4cdb692f1bf99 Mon Sep 17 00:00:00 2001 From: xiaoiver Date: Mon, 9 Oct 2023 10:39:37 +0800 Subject: [PATCH] fix: skip triggering render hooks when camera changed only. (#1548) * fix: skip triggering render hooks when camera changed only * chore: commit changeset --- .changeset/ten-boxes-love.md | 5 ++ .../g-lite/src/services/RenderingService.ts | 11 ++- site/examples/perf/webgl/demo/nodes.js | 80 ++++++++++++++----- 3 files changed, 73 insertions(+), 23 deletions(-) create mode 100644 .changeset/ten-boxes-love.md diff --git a/.changeset/ten-boxes-love.md b/.changeset/ten-boxes-love.md new file mode 100644 index 000000000..a8d537e21 --- /dev/null +++ b/.changeset/ten-boxes-love.md @@ -0,0 +1,5 @@ +--- +'@antv/g-lite': patch +--- + +Skip triggering render hooks when camera changed only. diff --git a/packages/g-lite/src/services/RenderingService.ts b/packages/g-lite/src/services/RenderingService.ts index 4a009fd50..12b20a15a 100644 --- a/packages/g-lite/src/services/RenderingService.ts +++ b/packages/g-lite/src/services/RenderingService.ts @@ -176,7 +176,14 @@ export class RenderingService { renderingContext.dirtyRectangleRenderingDisabled = this.disableDirtyRectangleRendering(); - if (!canvasConfig.disableRenderHooks) { + const onlyCameraChanged = + renderingContext.renderReasons.size === 1 && + renderingContext.renderReasons.has(RenderReason.CAMERA_CHANGED); + const shouldTriggerRenderHooks = + !canvasConfig.disableRenderHooks || + !(canvasConfig.disableRenderHooks && onlyCameraChanged); + + if (shouldTriggerRenderHooks) { this.renderDisplayObject( renderingContext.root, canvasConfig, @@ -186,7 +193,7 @@ export class RenderingService { this.hooks.beginFrame.call(); - if (!canvasConfig.disableRenderHooks) { + if (shouldTriggerRenderHooks) { renderingContext.renderListCurrentFrame.forEach((object) => { this.hooks.beforeRender.call(object); this.hooks.render.call(object); diff --git a/site/examples/perf/webgl/demo/nodes.js b/site/examples/perf/webgl/demo/nodes.js index 43b9c5211..7c7d99aec 100644 --- a/site/examples/perf/webgl/demo/nodes.js +++ b/site/examples/perf/webgl/demo/nodes.js @@ -1,4 +1,4 @@ -import { Canvas, CanvasEvent, Circle, Line, Text, runtime } from '@antv/g'; +import { Canvas, CanvasEvent, Circle, Line, Group, runtime } from '@antv/g'; import { Renderer as WebGLRenderer } from '@antv/g-webgl'; import { Plugin } from '@antv/g-plugin-dragndrop'; import Stats from 'stats.js'; @@ -10,8 +10,8 @@ import Stats from 'stats.js'; runtime.enableCSSParsing = false; -const NODE_NUM = 50000; -const EDGE_NUM = 50000; +const NODE_NUM = 5000; +const EDGE_NUM = 5000; const webglRenderer = new WebGLRenderer(); webglRenderer.registerPlugin( @@ -25,7 +25,7 @@ webglRenderer.registerPlugin( const canvas = new Canvas({ container: 'container', - width: 600, + width: 500, height: 500, renderer: webglRenderer, }); @@ -46,21 +46,61 @@ canvas.addEventListener(CanvasEvent.READY, () => { ]; let num = Math.floor(Math.sqrt(NODE_NUM) + 0.5); + const g1 = new Group({ + style: { + zIndex: 2, + }, + }); + const g2 = new Group({ + style: { + zIndex: 1, + }, + }); + const sourceMap = new WeakMap(); const targetMap = new WeakMap(); for (let i = 0; i < NODE_NUM; i++) { + const fill = colors[Math.floor(Math.random() * colors.length) || 0]; const circle = new Circle({ style: { - cx: (i % num) * 10, - cy: Math.floor(i / num) * 10, - fill: colors[Math.floor(Math.random() * colors.length) || 0], + // cx: (i % num) * 10, + // cy: Math.floor(i / num) * 10, + cx: Math.random() * 500, + cy: Math.random() * 500, + fill, r: 4, + // draggable: true }, }); nodes.push(circle); sourceMap.set(circle, []); + targetMap.set(circle, []); + + circle.addEventListener('mouseenter', () => { + circle.style.fill = 'red'; + }); + circle.addEventListener('mouseleave', () => { + circle.style.fill = fill; + }); + + // const text = new Text({ + // style: { + // x: 0, + // y: 4, + // text: `${i}`, + // textBaseline: "middle", + // textAlign: "center", + // fontSize: 4, + // fill: "black" + // } + // }); + // circle.appendChild(text); } + nodes.forEach((node) => { + g1.appendChild(node); + }); + for (let i = 0; i < EDGE_NUM; i++) { const source = nodes[Math.floor(Math.random() * NODE_NUM)]; const target = nodes[Math.floor(Math.random() * NODE_NUM)]; @@ -76,16 +116,22 @@ canvas.addEventListener(CanvasEvent.READY, () => { }); const sourceEdges = sourceMap.get(source); - // sourceEdges.push(line); + sourceEdges.push(line); const targetEdges = targetMap.get(target); - // targetEdges.push(line); + targetEdges.push(line); - canvas.appendChild(line); + g2.appendChild(line); + + // line.addEventListener("mouseenter", () => { + // line.style.stroke = "red"; + // }); + // line.addEventListener("mouseleave", () => { + // line.style.stroke = "grey"; + // }); } - nodes.forEach((circle) => { - canvas.appendChild(circle); - }); + canvas.appendChild(g1); + canvas.appendChild(g2); // stats const stats = new Stats(); @@ -126,8 +172,6 @@ canvas.addEventListener(CanvasEvent.READY, () => { } canvas.addEventListener('dragstart', function (e) { - canvas.getConfig().disableHitTesting = true; - if (e.target === canvas.document) { } else { const [x, y] = e.target.getPosition(); @@ -144,10 +188,6 @@ canvas.addEventListener(CanvasEvent.READY, () => { moveAt(e.target, e.canvasX, e.canvasY); } }); - canvas.addEventListener('dragend', function (e) { - console.log('dragend...'); - canvas.getConfig().disableHitTesting = false; - }); // handle mouse wheel event const bindWheelHandler = () => { @@ -161,8 +201,6 @@ canvas.addEventListener(CanvasEvent.READY, () => { .addEventListener( 'wheel', (e) => { - canvas.getConfig().disableHitTesting = false; - e.preventDefault(); let zoom; if (e.deltaY < 0) {