Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

fix submeshes have different instancing options #12786

Merged
merged 17 commits into from
Sep 23, 2022

Conversation

jk20012001
Copy link
Contributor

@jk20012001 jk20012001 commented Sep 15, 2022

Re: #

Changelog


Continuous Integration

This pull request:

  • needs automatic test cases check.

    Manual trigger with @cocos-robot run test cases afterward.

  • does not change any runtime related code or build configuration

    If any reviewer thinks the CI checks are needed, please uncheck this option, then close and reopen the issue.


Compatibility Check

This pull request:

  • changes public API, and have ensured backward compatibility with deprecated features.
  • affects platform compatibility, e.g. system version, browser version, platform sdk version, platform toolchain, language version, hardware compatibility etc.
  • affects file structure of the build package or build configuration which requires user project upgrade.
  • introduces breaking changes, please list all changes, affected features and the scope of violation.

@github-actions
Copy link

github-actions bot commented Sep 15, 2022

Interface Check Report

! WARNING this pull request has changed these public interfaces:

@@ -6669,13 +6669,8 @@
                  * @param ev100
                  */
                 protected setExposure(ev100: any): void;
             }
-            export interface IInstancedAttributeBlock {
-                buffer: Uint8Array;
-                views: __private._types_globals__TypedArray[];
-                attributes: gfx.Attribute[];
-            }
             export enum ModelType {
                 DEFAULT = 0,
                 SKINNING = 1,
                 BAKED_SKINNING = 2,
@@ -6731,13 +6726,8 @@
                  * @zh 获取上次更新时间戳
                  */
                 get updateStamp(): number;
                 /**
-                 * @en Whether GPU instancing is enabled for the current model
-                 * @zh 是否开启实例化渲染
-                 */
-                get isInstancingEnabled(): boolean;
-                /**
                  * @en Model level shadow bias
                  * @zh 阴影偏移值
                  */
                 get shadowBias(): number;
@@ -6808,13 +6798,8 @@
                  * @zh 是否动态合批
                  */
                 isDynamicBatching: boolean;
                 /**
-                 * @en The instance attributes
-                 * @zh 实例化属性
-                 */
-                instancedAttributes: IInstancedAttributeBlock;
-                /**
                  * @en The world axis-aligned bounding box
                  * @zh 世界空间包围盒
                  */
                 protected _worldBounds: geometry.AABB | null;
@@ -7027,15 +7012,19 @@
                  * @param subModelIndex sub model's index
                  */
                 getMacroPatches(subModelIndex: number): IMacroPatch[] | null;
                 protected _updateAttributesAndBinding(subModelIndex: number): void;
-                protected _getInstancedAttributeIndex(name: string): number;
-                protected _updateInstancedAttributes(attributes: gfx.Attribute[], pass: Pass): void;
+                protected _updateInstancedAttributes(attributes: gfx.Attribute[], subModel: SubModel): void;
                 protected _initLocalDescriptors(subModelIndex: number): void;
                 protected _initWorldBoundDescriptors(subModelIndex: number): void;
                 protected _updateLocalDescriptors(subModelIndex: number, descriptorSet: gfx.DescriptorSet): void;
                 protected _updateWorldBoundDescriptors(subModelIndex: number, descriptorSet: gfx.DescriptorSet): void;
             }
+            export interface IInstancedAttributeBlock {
+                buffer: Uint8Array;
+                views: __private._types_globals__TypedArray[];
+                attributes: gfx.Attribute[];
+            }
             /**
              * @en A sub part of the model, it describes how to render a specific sub mesh.
              * It contains geometry information in [[RenderingSubMesh]] and all sort of rendering configuration like shaders, macro patches, passes etc.
              * @zh 组成模型对象的子模型,它用来描述如何渲染模型的一个子网格。
@@ -7054,8 +7043,10 @@
                 protected _planarInstanceShader: gfx.Shader | null;
                 protected _planarShader: gfx.Shader | null;
                 protected _reflectionTex: gfx.Texture | null;
                 protected _reflectionSampler: gfx.Sampler | null;
+                protected _instancedAttributeBlock: IInstancedAttributeBlock;
+                protected _instancedWorldMatrixIndex: number;
                 /**
                  * @en
                  * sub model's passes
                  * @zh
@@ -7115,8 +7106,19 @@
                  * @zh 用于渲染平面阴影的着色器。
                  */
                 get planarShader(): gfx.Shader | null;
                 /**
+                 * @en The instance attribute block, access by sub model
+                 * @zh 硬件实例化属性,通过子模型访问
+                 */
+                get instancedAttributeBlock(): IInstancedAttributeBlock;
+                /**
+                 * @en Get or set instance matrix id, access by sub model
+                 * @zh 获取或者设置硬件实例化中的矩阵索引,通过子模型访问
+                 */
+                set instancedWorldMatrixIndex(val: number);
+                get instancedWorldMatrixIndex(): number;
+                /**
                  * @en
                  * init sub model
                  * @zh
                  * 子模型初始化
@@ -7172,8 +7174,38 @@
                  * @zh
                  * 几何数据改变后的回调
                  */
                 onGeometryChanged(): void;
+                /**
+                 * @en
+                 * get instanced attribute index
+                 * @zh
+                 * 获取硬件实例化相关索引
+                 */
+                /**
+                 * @internal
+                 */
+                getInstancedAttributeIndex(name: string): number;
+                /**
+                 * @en
+                 * update instancing related data, invoked by model
+                 * @zh
+                 * 更新硬件实例化相关数据,一般由model调用
+                 */
+                /**
+                 * @internal
+                 */
+                updateInstancedWorldMatrix(mat: math.Mat4, idx: number): void;
+                /**
+                 * @en
+                 * update instancing related data, invoked by model
+                 * @zh
+                 * 更新硬件实例化相关数据,一般由model调用
+                 */
+                /**
+                 * @internal
+                 */
+                UpdateInstancedAttributes(attributes: gfx.Attribute[]): void;
                 protected _flushPassInfo(): void;
             }
             /**
              * @en Ambient lighting representation in the render scene.
@@ -22350,9 +22382,9 @@
         hasPendingModels: boolean;
         dynamicOffsets: number[];
         constructor(pass: renderer.Pass);
         destroy(): void;
-        merge(subModel: renderer.scene.SubModel, attrs: renderer.scene.IInstancedAttributeBlock, passIdx: number, shaderImplant?: gfx.Shader | null): void;
+        merge(subModel: renderer.scene.SubModel, passIdx: number, shaderImplant?: gfx.Shader | null): void;
         uploadBuffers(cmdBuff: gfx.CommandBuffer): void;
         clear(): void;
     }
     export class PipelineStateManager {
@@ -52094,9 +52126,9 @@
             /**
              * @deprecated since v3.5.0, this is an engine private interface that will be removed in the future.
              */
             _updateLocalDescriptors(submodelIdx: number, descriptorSet: gfx.DescriptorSet): void;
-            protected _updateInstancedAttributes(attributes: gfx.Attribute[], pass: renderer.Pass): void;
+            protected _updateInstancedAttributes(attributes: gfx.Attribute[], subModel: renderer.scene.SubModel): void;
         }
         export interface _cocos_3d_skeletal_animation_skeletal_animation_utils__IInternalJointAnimInfo {
             downstream?: math.Mat4;
             curveData?: math.Mat4[];
@@ -52142,9 +52174,9 @@
              */
             uploadAnimation(anim: AnimationClip | null): void;
             protected _applyJointTexture(texture?: _cocos_3d_skeletal_animation_skeletal_animation_utils__IJointTextureHandle | null): void;
             protected _updateLocalDescriptors(submodelIdx: number, descriptorSet: gfx.DescriptorSet): void;
-            protected _updateInstancedAttributes(attributes: gfx.Attribute[], pass: renderer.Pass): void;
+            protected _updateInstancedAttributes(attributes: gfx.Attribute[], subModel: renderer.scene.SubModel): void;
         }
         /**
          * 动画使用的循环模式。
          */

@troublemaker52025
Copy link
Contributor

@cocos-robot run test cases

@github-actions
Copy link

@jk20012001, Please check the result of run test cases:

Task Details

Platform build runned result crashScene FailScene
ios_release PASS PASS PASS NA
Mac_debug PASS PASS PASS NA
WebMobile_debug PASS PASS PASS NA

@github-actions
Copy link

@jk20012001, Please check the result of run test cases:

Task Details

Platform build runned result crashScene FailScene
WebDesktop_release PASS PASS PASS NA
WebMobile_release PASS PASS PASS NA
Win32_release PASS PASS PASS NA
Android_debug PASS PASS PASS NA

@github-actions
Copy link

@jk20012001, Please check the result of run test cases:

Task Details

Platform build runned result crashScene FailScene
ios_release PASS PASS PASS NA
Mac_debug PASS PASS PASS NA
WebMobile_debug PASS PASS PASS NA

@github-actions
Copy link

@jk20012001, Please check the result of run test cases:

Task Details

Platform build runned result crashScene FailScene
WebDesktop_release PASS PASS PASS NA
WebMobile_release PASS PASS PASS NA
Win32_release PASS PASS PASS NA
Android_debug PASS PASS PASS NA

* The modification of instanced synchronize data to native

* fix instanced error
@github-actions
Copy link

@jk20012001, Please check the result of run test cases:

Task Details

Platform build runned result crashScene FailScene
WebDesktop_release PASS PASS PASS NA
WebMobile_release PASS PASS PASS NA
Win32_release FAIL NA NA NA
Android_debug FAIL NA NA NA

@github-actions
Copy link

@jk20012001, Please check the result of run test cases:

Task Details

Platform build runned result crashScene FailScene
ios_release FAIL NA NA NA
Mac_debug FAIL NA NA NA
WebMobile_debug PASS PASS PASS NA

@github-actions
Copy link

@jk20012001, Please check the result of run test cases:

Task Details

Platform build runned result crashScene FailScene
ios_release FAIL NA NA NA
Mac_debug FAIL NA NA NA
WebMobile_debug PASS PASS PASS NA

for (const p of passes) {
if (p.phase !== this._currentQueue.phaseID) continue;
const batchingScheme = p.batchingScheme;
// If the size of instances is not 0, it has been added
if (batchingScheme === BatchingSchemes.INSTANCING
&& !this._submitInfo.instances.size) {
const instancedBuffer = p.getInstancedBuffer();
instancedBuffer.merge(submodel, ro.model.instancedAttributes, passes.indexOf(p));
instancedBuffer.merge(subModel, ro.model.getInstancedAttributeBlock(subModel), passes.indexOf(p));
Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

this get function is named as same as native engine

@github-actions
Copy link

@jk20012001, Please check the result of run test cases:

Task Details

Platform build runned result crashScene FailScene
WebDesktop_release PASS PASS PASS NA
WebMobile_release PASS PASS PASS NA
Win32_release FAIL NA NA NA
Android_debug FAIL NA NA NA

@@ -50,15 +50,16 @@ void InstancedBuffer::destroy() {
_instances.clear();
}

void InstancedBuffer::merge(const scene::Model *model, const scene::SubModel *subModel, uint32_t passIdx) {
merge(model, subModel, passIdx, nullptr);
Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

arguments are modified as same as ts engine

@github-actions
Copy link

@jk20012001, Please check the result of run test cases:

Task Details

Platform build runned result crashScene FailScene
ios_release FAIL NA NA NA
Mac_debug FAIL NA NA NA
WebMobile_debug PASS PASS PASS NA

@github-actions
Copy link

@jk20012001, Please check the result of run test cases:

Task Details

Platform build runned result crashScene FailScene
WebDesktop_release PASS PASS PASS NA
WebMobile_release PASS PASS PASS NA
Win32_release FAIL NA NA NA
Android_debug FAIL NA NA NA

@github-actions
Copy link

@jk20012001, Please check the result of run test cases:

Task Details

Platform build runned result crashScene FailScene
WebDesktop_release PASS PASS PASS NA
WebMobile_release PASS PASS PASS NA
Win32_release FAIL NA NA NA
Android_debug FAIL NA NA NA

@github-actions
Copy link

@jk20012001, Please check the result of run test cases:

Task Details

Platform build runned result crashScene FailScene
ios_release FAIL NA NA NA
Mac_debug FAIL NA NA NA
WebMobile_debug PASS PASS PASS NA

let hasNonInstancingPass = false;
for (let i = 0; i < this._subModels.length; i++) {
const subModel = this._subModels[i];
const idx = this._instAnimInfoIdx;
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I am not sure if define variable outside for loop is better in ts.

@github-actions
Copy link

@jk20012001, Please check the result of run test cases:

Task Details

Platform build runned result crashScene FailScene
ios_release FAIL NA NA NA
Mac_debug FAIL NA NA NA
WebMobile_debug PASS PASS PASS NA

++i;
const auto &subModels = model->getSubModels();
const auto subModelCount = subModels.size();
for (uint32_t subModelIdx = 0; subModelIdx < subModelCount; ++subModelIdx) {
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Can use for in like

for (const auto &subModel : subModels) {
}

@github-actions
Copy link

@jk20012001, Please check the result of run test cases:

Task Details

Platform build runned result crashScene FailScene
WebDesktop_release PASS PASS PASS NA
WebMobile_release PASS PASS PASS NA
Win32_release FAIL NA NA NA
Android_debug FAIL NA NA NA

@github-actions
Copy link

@jk20012001, Please check the result of run test cases:

Task Details

Platform build runned result crashScene FailScene
ios_release FAIL NA NA NA
Mac_debug FAIL NA NA NA
WebMobile_debug PASS PASS PASS NA

@github-actions
Copy link

@jk20012001, Please check the result of run test cases:

Task Details

Platform build runned result crashScene FailScene
ios_release FAIL NA NA NA
Mac_debug FAIL NA NA NA
WebMobile_debug PASS PASS PASS NA

@github-actions
Copy link

@jk20012001, Please check the result of run test cases:

Task Details

Platform build runned result crashScene FailScene
WebDesktop_release PASS PASS PASS NA
WebMobile_release PASS PASS PASS NA
Win32_release FAIL NA NA NA
Android_debug FAIL NA NA NA

@github-actions
Copy link

@jk20012001, Please check the result of run test cases:

Task Details

Platform build runned result crashScene FailScene
ios_release FAIL NA NA NA
Mac_debug FAIL NA NA NA
WebMobile_debug PASS FAIL NA NA

@github-actions
Copy link

@jk20012001, Please check the result of run test cases:

Task Details

Platform build runned result crashScene FailScene
ios_release FAIL NA NA NA
Mac_debug FAIL NA NA NA
WebMobile_debug PASS PASS PASS NA

@github-actions
Copy link

@jk20012001, Please check the result of run test cases:

Task Details

Platform build runned result crashScene FailScene
WebDesktop_release PASS PASS PASS NA
WebMobile_release PASS PASS PASS NA
Win32_release FAIL NA NA NA
Android_debug FAIL NA NA NA

@jk20012001 jk20012001 merged commit 4ad23f2 into cocos:v3.6.2 Sep 23, 2022
cocos-robot pushed a commit to cocos-robot/engine that referenced this pull request Sep 23, 2022
minggo pushed a commit that referenced this pull request Sep 26, 2022
…12871)

Co-authored-by: cocos-robot <cocos-robot@cocos.com>
SantyWang added a commit that referenced this pull request Oct 12, 2022
* when checking useSystemFont, the fontFamily should appear (#12684)

Co-authored-by: zhangmingzhen <mingzhen.zhang@cocos.com>

* remove rebundant useLocalData (#12640)

(cherry picked from commit 7cca981)

Co-authored-by: zhangmingzhen <mingzhen.zhang@cocos.com>

* Modify version number (#12726)

Co-authored-by: liuyi <liuyi@cocos.com>

* fix builtin asset hot-reload (#12736)

* improve: move xr init to infrastructure (#12765)

* improve: move xr init to infrastructure

* fix: move initxr, before gfx

* fix: format warning

* [Feature] build template add config file (#12701)

* part of build template add config json for creating build templates and version checks for each platform

* update default template version

* add RenderQueue custom ability to classic pipeline (#12760)

* Wgpu 3.6.2 WGPU_CI_ON  (#12731)

* fix okhttp onClosing not call close (#12783)

* fix transparency, emissive and  specularfactor with dcc effects (#12798)

* reverse occlusion parameter in effects (#12795)

* [native] Fix getting wrong value of globals.ambient.skyLightingColor (#12810)

* refine:  remove unneeded code (#12808)

* feat: update meta files (#12807)

* middleware2d components rendering in native mode (#12788)

* middleware2d components rendering in native mode

* support spine/dragonbones set enable batch

* support spine rendering in batching mode

* get batcher2d instance from root

* process about with type conversion

* fix some code style

* use material hash to merge draw batch

* deal with fill z

* fix dragonbones fill z

* remove some code no used any more

* refactoring some code

* modify some code

* add free memory

* fix clang-tidy

* delete mesh-buffer-layout in destructor

* byte alignment

* [ci skip][AUTO]: Automated code generating update: 88c3a7f  (#12788) (#12818)

Co-authored-by: cocos-robot <cocos-robot@cocos.com>

* simplify (#12782)

* [code] move decode32 to unpack.chunk (#12823)

* [Optimize] Cache current time for audio player in minigame. (#12814)

* Cache current time for minigames

* Save current time as private member

* Make cache time changed in callback

* update cache time to abort middle state for seek

* LogRemote upgrade configuration protocol (#12833)

* update config

* Update LogRemote.cpp

* update default_skybox and sun direction (#12811)

* fix submeshes have different instancing options (#12786)

* [ci skip][AUTO]: Automated code generating update: 3200403  (#12786) (#12871)

Co-authored-by: cocos-robot <cocos-robot@cocos.com>

* spine/dragonbones support batch mode in web platform (#12847)

* spine/dragonbones support batch mode in web platform

* set data hash 0 in commitMiddleware

* optimizate merge draw batch for middleware

* keep commitIA in batcher2d

* modify deprecated about commitIA

* feat: support webgpu on build-engine (#12627)

* feat: support webgpu

* build-engine-feat: support building external asset

* update

* Publish @cocos/build-engine@4.4.0-webgpu.0

* fix tiled merge draw call with sprite (#12877)

* fix:CC_ASSERT(!_currentApp.expired()); (#12844)

application has destroyed when WebSocketServer process callback in game thread

* [Bug fix] remove the player of the audio source when its clip is set to null  (#12865)

* remove player when the audio source's clip is set to null

* fix binary format spine load crash (#12894)

* wgpu: remove reinit on same object (#12799)

* add i18n for skybox (#12899)

* 3.6.2 fix android orientation crash (#12885)

* do not cache argument in global space

* add doc

* add a comment for readAttachment (#12902)

* If it is preview, replace overrideUuid  directly (#12905)

* sort the attributes (#12904)

Co-authored-by: zhangmingzhen <mingzhen.zhang@cocos.com>

* add i18n for shadow (#12906)

* update default-skybox and sun direction (#12917)

* fix:WebSocket connection to 'ws://XXXX/' failed: A server must not mask any frames that it sends to the client. (#12882)

* remove USE_BATCHING (#12892)

* fix a native middleware blend problem (#12914)

* migrated remove USE_BATCHING (#12895)

* [feature] support output bullet.wasm on  runtime based platform which the using of wasm api is more similar with weixin (#12881)

* V3.6.2 fix particle crash (#12913)

* fix native crash

* revert to pointer

* revert

* do not use reference

* if PREVIEW load cce scripts before loadProjectBundles (#12916)

* If it is preview, replace overrideUuid  directly

* load cce scripts before loadProjectBundles

* Update game.ts

* Update game.ts

* Update game.ts

* Update game.ts

* fix download url request not encode space (#12826)

* Export texture info for wgpu WGPU_CI_ON (#12926)

* export texture info for wgpu

* missing js file

* update external config

Co-authored-by: Zeqiang Li <zeqiang-li@outlook.com.com>

* fix: build-engine (#12929)

* richtext addChild optimization (#12928)

* 1. remove rebundant invoking
2. ttf canvas texture resizes to width and height as (1,1)

* remove start() and move it to onLoad()

Co-authored-by: zhangmingzhen <mingzhen.zhang@cocos.com>

* fix animation asset on inspector preview bug (#12900)

* optimize label component editing

* fix animation asset on inspector preview bug

* optimize i18n break words

* update node-executable by env (#12930)

* Fix: toDataURL is not supported for this content on iPhone 7p (#12830)

* Fix: toDataURL is not supported for this content on iPhone 7p

* Add srgb transform. (#12873)

* add localCfg.cmake (#12932)

* _loadCCEScripts  will be browser-preview only  (#12925)

* _loadCCEScripts  will be browser-preview only

* add comment

* a compatible way of data copy & default buffer size for uniform buffer (#12935)

* a compatible way of data copy & default buffer size for uniform buffer

* update external config

* [fix] default scene ambient and dirlight color (#12955)

* sync readme for wgpu (#12966)

* [fix] specularIntensity is invalid with builtin-standard (#12971)

* [native] type2writer:add FLOAT3 to Color case for compatiblity (#12962)

* V3.6.2 format return null error fix (#12973)

* add i18n for model (#12985)

* fix potential mem leak (#12995)

* [fix] camera clear flag is skybox but skybox is disabled #13589 (#12964)

* [fix] shader compilation error with CC_DEVICE_SUPPORT_FLOAT_TEXTURE=0 (#13015)

* fix import

* sync tojs to swig about middleware and 2d module (#4)

* sync tojs to swig about scene module (#5)

* remove Model::getInstancedAttributeBlock

Co-authored-by: Zhang mingzhen <32831993+Zhmz@users.noreply.github.com>
Co-authored-by: zhangmingzhen <mingzhen.zhang@cocos.com>
Co-authored-by: LIUYIa <102024185+LIUYIa@users.noreply.github.com>
Co-authored-by: liuyi <liuyi@cocos.com>
Co-authored-by: fqamic <fqamic@vip.qq.com>
Co-authored-by: minggo <nudtzxm@gmail.com>
Co-authored-by: changhua <39176194+changhua0118@users.noreply.github.com>
Co-authored-by: hyde zhou <zlzhou.sh@outlook.com>
Co-authored-by: Zeqiang Li <zeqiang-li@outlook.com>
Co-authored-by: mmyduckx <308303735@qq.com>
Co-authored-by: 徐兵 <49358166+xubing0906@users.noreply.github.com>
Co-authored-by: James Chen <dumganhar@gmail.com>
Co-authored-by: bofeng-song <bofeng.song@chukong-inc.com>
Co-authored-by: 袁炜海 <35713518+dogodo-cc@users.noreply.github.com>
Co-authored-by: zhakesi <liqiao@cocos.com>
Co-authored-by: Cocos Robot <48829427+cocos-robot@users.noreply.github.com>
Co-authored-by: cocos-robot <cocos-robot@cocos.com>
Co-authored-by: 江战 <40414978+PatriceJiang@users.noreply.github.com>
Co-authored-by: jk20012001 <jkregister@163.com>
Co-authored-by: timlyeee <43355299+timlyeee@users.noreply.github.com>
Co-authored-by: PP <chinese1236@qq.com>
Co-authored-by: oahc09 <oahc09@gmail.com>
Co-authored-by: zhangxin <59186205+chichinohaha@users.noreply.github.com>
Co-authored-by: troublemaker52025 <troublemaker52025@outlook.com>
Co-authored-by: CC9701 <73738313+CC9701@users.noreply.github.com>
Co-authored-by: zxx43 <zxx43@hotmail.com>
Co-authored-by: Zeqiang Li <zeqiang-li@outlook.com.com>
Co-authored-by: 黄森斌 <arsen2010@126.com>
Co-authored-by: ycg <1670543365@qq.com>
Co-authored-by: AFeiYA <386665678@qq.com>
Co-authored-by: zhakesi <zhakesi@foxmail.com>
/**
* @internal
*/
public UpdateInstancedAttributes (attributes: Attribute[]) {
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Don't use capital letter as prefix.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
Projects
None yet
Development

Successfully merging this pull request may close these issues.

6 participants