From d0df21bb47240360fd3f24850efe6001a5e83600 Mon Sep 17 00:00:00 2001 From: ChiaNing Date: Mon, 18 Sep 2023 15:21:22 +0800 Subject: [PATCH] skip batch when GFX Texture is null --- cocos/2d/renderer/batcher-2d.ts | 15 +++++++++++---- 1 file changed, 11 insertions(+), 4 deletions(-) diff --git a/cocos/2d/renderer/batcher-2d.ts b/cocos/2d/renderer/batcher-2d.ts index 13e7126ec76..253b90ef0ef 100644 --- a/cocos/2d/renderer/batcher-2d.ts +++ b/cocos/2d/renderer/batcher-2d.ts @@ -490,8 +490,15 @@ export class Batcher2D implements IBatcher { * @param mat - The material used * @param enableBatch - component support multi draw batch or not */ - public commitMiddleware (comp: UIRenderer, meshBuffer: MeshBuffer, indexOffset: number, - indexCount: number, tex: TextureBase, mat: Material, enableBatch: boolean): void { + public commitMiddleware ( + comp: UIRenderer, + meshBuffer: MeshBuffer, + indexOffset: number, + indexCount: number, + tex: TextureBase, + mat: Material, + enableBatch: boolean, + ): void { // check if need merge draw batch const texture = tex.getGFXTexture(); if (enableBatch && this._middlewareEnableBatch && this._middlewareBuffer === meshBuffer @@ -654,7 +661,7 @@ export class Batcher2D implements IBatcher { this._currBID = -1; // Request ia failed - if (!ia) { + if (!ia || !this._currTexture) { return; } @@ -671,7 +678,7 @@ export class Batcher2D implements IBatcher { const curDrawBatch = this._currStaticRoot ? this._currStaticRoot._requireDrawBatch() : this._drawBatchPool.alloc(); curDrawBatch.visFlags = this._currLayer; - curDrawBatch.texture = this._currTexture!; + curDrawBatch.texture = this._currTexture; curDrawBatch.sampler = this._currSampler; curDrawBatch.inputAssembler = ia; curDrawBatch.useLocalData = this._currTransform;